2010-04-23 12:38:37 +04:00
/*
* Memory - to - memory device framework for Video for Linux 2.
*
* Helper functions for devices that use memory buffers for both source
* and destination .
*
* Copyright ( c ) 2009 Samsung Electronics Co . , Ltd .
2011-03-13 21:23:32 +03:00
* Pawel Osciak , < pawel @ osciak . com >
2010-04-23 12:38:37 +04:00
* Marek Szyprowski , < m . szyprowski @ samsung . com >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by the
* Free Software Foundation ; either version 2 of the
* License , or ( at your option ) any later version
*/
# ifndef _MEDIA_V4L2_MEM2MEM_H
# define _MEDIA_V4L2_MEM2MEM_H
2015-09-22 16:30:29 +03:00
# include <media/videobuf2-v4l2.h>
2010-04-23 12:38:37 +04:00
/**
* struct v4l2_m2m_ops - mem - to - mem device driver callbacks
* @ device_run : required . Begin the actual job ( transaction ) inside this
* callback .
* The job does NOT have to end before this callback returns
* ( and it will be the usual case ) . When the job finishes ,
* v4l2_m2m_job_finish ( ) has to be called .
* @ job_ready : optional . Should return 0 if the driver does not have a job
* fully prepared to run yet ( i . e . it will not be able to finish a
* transaction without sleeping ) . If not provided , it will be
* assumed that one source and one destination buffer are all
* that is required for the driver to perform one full transaction .
* This method may not sleep .
2018-06-18 07:38:52 +03:00
* @ job_abort : optional . Informs the driver that it has to abort the currently
2010-04-23 12:38:37 +04:00
* running transaction as soon as possible ( i . e . as soon as it can
* stop the device safely ; e . g . in the next interrupt handler ) ,
* even if the transaction would not have been finished by then .
* After the driver performs the necessary steps , it has to call
* v4l2_m2m_job_finish ( ) ( as if the transaction ended normally ) .
* This function does not have to ( and will usually not ) wait
* until the device enters a state when it can be stopped .
*/
struct v4l2_m2m_ops {
void ( * device_run ) ( void * priv ) ;
int ( * job_ready ) ( void * priv ) ;
void ( * job_abort ) ( void * priv ) ;
} ;
2018-07-02 18:36:05 +03:00
struct video_device ;
2010-04-23 12:38:37 +04:00
struct v4l2_m2m_dev ;
2016-09-08 16:16:36 +03:00
/**
* struct v4l2_m2m_queue_ctx - represents a queue for buffers ready to be
* processed
*
* @ q : pointer to struct & vb2_queue
* @ rdy_queue : List of V4L2 mem - to - mem queues
* @ rdy_spinlock : spin lock to protect the struct usage
* @ num_rdy : number of buffers ready to be processed
* @ buffered : is the queue buffered ?
*
* Queue for buffers ready to be processed as soon as this
* instance receives access to the device .
*/
2010-04-23 12:38:37 +04:00
struct v4l2_m2m_queue_ctx {
2011-01-12 12:50:24 +03:00
struct vb2_queue q ;
2010-04-23 12:38:37 +04:00
struct list_head rdy_queue ;
2011-01-12 12:50:24 +03:00
spinlock_t rdy_spinlock ;
2010-04-23 12:38:37 +04:00
u8 num_rdy ;
2013-06-03 11:23:48 +04:00
bool buffered ;
2010-04-23 12:38:37 +04:00
} ;
2016-09-08 16:16:36 +03:00
/**
* struct v4l2_m2m_ctx - Memory to memory context structure
*
* @ q_lock : struct & mutex lock
2016-09-08 23:20:44 +03:00
* @ m2m_dev : opaque pointer to the internal data to handle M2M context
2016-09-08 16:16:36 +03:00
* @ cap_q_ctx : Capture ( output to memory ) queue context
* @ out_q_ctx : Output ( input from memory ) queue context
* @ queue : List of memory to memory contexts
* @ job_flags : Job queue flags , used internally by v4l2 - mem2mem . c :
* % TRANS_QUEUED , % TRANS_RUNNING and % TRANS_ABORT .
* @ finished : Wait queue used to signalize when a job queue finished .
* @ priv : Instance private data
2016-10-18 16:15:32 +03:00
*
* The memory to memory context is specific to a file handle , NOT to e . g .
* a device .
2016-09-08 16:16:36 +03:00
*/
2010-04-23 12:38:37 +04:00
struct v4l2_m2m_ctx {
2013-09-15 01:39:04 +04:00
/* optional cap/out vb2 queues lock */
struct mutex * q_lock ;
2016-09-08 16:16:36 +03:00
/* internal use only */
2010-04-23 12:38:37 +04:00
struct v4l2_m2m_dev * m2m_dev ;
struct v4l2_m2m_queue_ctx cap_q_ctx ;
struct v4l2_m2m_queue_ctx out_q_ctx ;
/* For device job queue */
struct list_head queue ;
unsigned long job_flags ;
2011-01-12 12:50:24 +03:00
wait_queue_head_t finished ;
2010-04-23 12:38:37 +04:00
void * priv ;
} ;
2016-09-08 16:16:36 +03:00
/**
* struct v4l2_m2m_buffer - Memory to memory buffer
*
* @ vb : pointer to struct & vb2_v4l2_buffer
* @ list : list of m2m buffers
*/
2011-01-12 12:50:24 +03:00
struct v4l2_m2m_buffer {
[media] media: videobuf2: Restructure vb2_buffer
Remove v4l2 stuff - v4l2_buf, v4l2_plane - from struct vb2_buffer.
Add new member variables - bytesused, length, offset, userptr, fd,
data_offset - to struct vb2_plane in order to cover all information
of v4l2_plane.
struct vb2_plane {
<snip>
unsigned int bytesused;
unsigned int length;
union {
unsigned int offset;
unsigned long userptr;
int fd;
} m;
unsigned int data_offset;
}
Replace v4l2_buf with new member variables - index, type, memory - which
are common fields for buffer management.
struct vb2_buffer {
<snip>
unsigned int index;
unsigned int type;
unsigned int memory;
unsigned int num_planes;
struct vb2_plane planes[VIDEO_MAX_PLANES];
<snip>
};
v4l2 specific fields - flags, field, timestamp, timecode,
sequence - are moved to vb2_v4l2_buffer in videobuf2-v4l2.c
struct vb2_v4l2_buffer {
struct vb2_buffer vb2_buf;
__u32 flags;
__u32 field;
struct timeval timestamp;
struct v4l2_timecode timecode;
__u32 sequence;
};
Signed-off-by: Junghak Sung <jh1009.sung@samsung.com>
Signed-off-by: Geunyoung Kim <nenggun.kim@samsung.com>
Acked-by: Seung-Woo Kim <sw0312.kim@samsung.com>
Acked-by: Inki Dae <inki.dae@samsung.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
2015-09-22 16:30:30 +03:00
struct vb2_v4l2_buffer vb ;
2011-01-12 12:50:24 +03:00
struct list_head list ;
} ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_get_curr_priv ( ) - return driver private data for the currently
* running instance or NULL if no instance is running
2016-09-08 16:39:58 +03:00
*
2016-09-08 23:20:44 +03:00
* @ m2m_dev : opaque pointer to the internal data to handle M2M context
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
void * v4l2_m2m_get_curr_priv ( struct v4l2_m2m_dev * m2m_dev ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_get_vq ( ) - return vb2_queue for the given type
2016-09-08 16:39:58 +03:00
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ type : type of the V4L2 buffer , as defined by enum & v4l2_buf_type
2016-09-08 16:16:27 +03:00
*/
2011-01-12 12:50:24 +03:00
struct vb2_queue * v4l2_m2m_get_vq ( struct v4l2_m2m_ctx * m2m_ctx ,
2010-04-23 12:38:37 +04:00
enum v4l2_buf_type type ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_try_schedule ( ) - check whether an instance is ready to be added to
* the pending job queue and add it if so .
2016-09-08 16:39:58 +03:00
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2016-09-08 16:16:27 +03:00
*
* There are three basic requirements an instance has to meet to be able to run :
* 1 ) at least one source buffer has to be queued ,
* 2 ) at least one destination buffer has to be queued ,
* 3 ) streaming has to be on .
*
* If a queue is buffered ( for example a decoder hardware ringbuffer that has
* to be drained before doing streamoff ) , allow scheduling without v4l2 buffers
* on that queue .
*
* There may also be additional , custom requirements . In such case the driver
* should supply a custom callback ( job_ready in v4l2_m2m_ops ) that should
* return 1 if the instance is ready .
* An example of the above could be an instance that requires more than one
* src / dst buffer per transaction .
*/
2014-07-22 16:36:04 +04:00
void v4l2_m2m_try_schedule ( struct v4l2_m2m_ctx * m2m_ctx ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_job_finish ( ) - inform the framework that a job has been finished
* and have it clean up
*
2016-09-08 23:20:44 +03:00
* @ m2m_dev : opaque pointer to the internal data to handle M2M context
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
*
2016-09-08 16:16:27 +03:00
* Called by a driver to yield back the device after it has finished with it .
* Should be called as soon as possible after reaching a state which allows
* other instances to take control of the device .
*
2016-09-08 16:16:36 +03:00
* This function has to be called only after & v4l2_m2m_ops - > device_run
* callback has been called on the driver . To prevent recursion , it should
* not be called directly from the & v4l2_m2m_ops - > device_run callback though .
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
void v4l2_m2m_job_finish ( struct v4l2_m2m_dev * m2m_dev ,
struct v4l2_m2m_ctx * m2m_ctx ) ;
2011-01-12 12:50:24 +03:00
static inline void
[media] media: videobuf2: Restructure vb2_buffer
Remove v4l2 stuff - v4l2_buf, v4l2_plane - from struct vb2_buffer.
Add new member variables - bytesused, length, offset, userptr, fd,
data_offset - to struct vb2_plane in order to cover all information
of v4l2_plane.
struct vb2_plane {
<snip>
unsigned int bytesused;
unsigned int length;
union {
unsigned int offset;
unsigned long userptr;
int fd;
} m;
unsigned int data_offset;
}
Replace v4l2_buf with new member variables - index, type, memory - which
are common fields for buffer management.
struct vb2_buffer {
<snip>
unsigned int index;
unsigned int type;
unsigned int memory;
unsigned int num_planes;
struct vb2_plane planes[VIDEO_MAX_PLANES];
<snip>
};
v4l2 specific fields - flags, field, timestamp, timecode,
sequence - are moved to vb2_v4l2_buffer in videobuf2-v4l2.c
struct vb2_v4l2_buffer {
struct vb2_buffer vb2_buf;
__u32 flags;
__u32 field;
struct timeval timestamp;
struct v4l2_timecode timecode;
__u32 sequence;
};
Signed-off-by: Junghak Sung <jh1009.sung@samsung.com>
Signed-off-by: Geunyoung Kim <nenggun.kim@samsung.com>
Acked-by: Seung-Woo Kim <sw0312.kim@samsung.com>
Acked-by: Inki Dae <inki.dae@samsung.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
2015-09-22 16:30:30 +03:00
v4l2_m2m_buf_done ( struct vb2_v4l2_buffer * buf , enum vb2_buffer_state state )
2011-01-12 12:50:24 +03:00
{
[media] media: videobuf2: Restructure vb2_buffer
Remove v4l2 stuff - v4l2_buf, v4l2_plane - from struct vb2_buffer.
Add new member variables - bytesused, length, offset, userptr, fd,
data_offset - to struct vb2_plane in order to cover all information
of v4l2_plane.
struct vb2_plane {
<snip>
unsigned int bytesused;
unsigned int length;
union {
unsigned int offset;
unsigned long userptr;
int fd;
} m;
unsigned int data_offset;
}
Replace v4l2_buf with new member variables - index, type, memory - which
are common fields for buffer management.
struct vb2_buffer {
<snip>
unsigned int index;
unsigned int type;
unsigned int memory;
unsigned int num_planes;
struct vb2_plane planes[VIDEO_MAX_PLANES];
<snip>
};
v4l2 specific fields - flags, field, timestamp, timecode,
sequence - are moved to vb2_v4l2_buffer in videobuf2-v4l2.c
struct vb2_v4l2_buffer {
struct vb2_buffer vb2_buf;
__u32 flags;
__u32 field;
struct timeval timestamp;
struct v4l2_timecode timecode;
__u32 sequence;
};
Signed-off-by: Junghak Sung <jh1009.sung@samsung.com>
Signed-off-by: Geunyoung Kim <nenggun.kim@samsung.com>
Acked-by: Seung-Woo Kim <sw0312.kim@samsung.com>
Acked-by: Inki Dae <inki.dae@samsung.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
2015-09-22 16:30:30 +03:00
vb2_buffer_done ( & buf - > vb2_buf , state ) ;
2011-01-12 12:50:24 +03:00
}
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_reqbufs ( ) - multi - queue - aware REQBUFS multiplexer
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ reqbufs : pointer to struct & v4l2_requestbuffers
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_reqbufs ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_requestbuffers * reqbufs ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_querybuf ( ) - multi - queue - aware QUERYBUF multiplexer
*
2016-09-08 16:39:58 +03:00
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ buf : pointer to struct & v4l2_buffer
*
2016-09-08 16:16:27 +03:00
* See v4l2_m2m_mmap ( ) documentation for details .
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_querybuf ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_buffer * buf ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_qbuf ( ) - enqueue a source or destination buffer , depending on
* the type
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ buf : pointer to struct & v4l2_buffer
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_qbuf ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_buffer * buf ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_dqbuf ( ) - dequeue a source or destination buffer , depending on
* the type
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ buf : pointer to struct & v4l2_buffer
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_dqbuf ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_buffer * buf ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_prepare_buf ( ) - prepare a source or destination buffer , depending on
* the type
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ buf : pointer to struct & v4l2_buffer
2016-09-08 16:16:27 +03:00
*/
2015-06-05 17:28:50 +03:00
int v4l2_m2m_prepare_buf ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_buffer * buf ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_create_bufs ( ) - create a source or destination buffer , depending
* on the type
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ create : pointer to struct & v4l2_create_buffers
2016-09-08 16:16:27 +03:00
*/
2013-05-21 11:16:28 +04:00
int v4l2_m2m_create_bufs ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_create_buffers * create ) ;
2010-04-23 12:38:37 +04:00
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_expbuf ( ) - export a source or destination buffer , depending on
* the type
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ eb : pointer to struct & v4l2_exportbuffer
2016-09-08 16:16:27 +03:00
*/
2012-06-14 18:32:24 +04:00
int v4l2_m2m_expbuf ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct v4l2_exportbuffer * eb ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_streamon ( ) - turn on streaming for a video queue
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ type : type of the V4L2 buffer , as defined by enum & v4l2_buf_type
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_streamon ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
enum v4l2_buf_type type ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_streamoff ( ) - turn off streaming for a video queue
2016-09-08 16:39:58 +03:00
*
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ type : type of the V4L2 buffer , as defined by enum & v4l2_buf_type
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_streamoff ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
enum v4l2_buf_type type ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_poll ( ) - poll replacement , for destination buffers only
*
2016-09-08 16:39:58 +03:00
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ wait : pointer to struct & poll_table_struct
*
2016-09-08 16:16:27 +03:00
* Call from the driver ' s poll ( ) function . Will poll both queues . If a buffer
* is available to dequeue ( with dqbuf ) from the source queue , this will
* indicate that a non - blocking write can be performed , while read will be
* returned in case of the destination queue .
*/
2017-07-03 10:02:56 +03:00
__poll_t v4l2_m2m_poll ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
2010-04-23 12:38:37 +04:00
struct poll_table_struct * wait ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_mmap ( ) - source and destination queues - aware mmap multiplexer
*
2016-09-08 16:39:58 +03:00
* @ file : pointer to struct & file
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ vma : pointer to struct & vm_area_struct
*
2016-09-08 16:16:27 +03:00
* Call from driver ' s mmap ( ) function . Will handle mmap ( ) for both queues
* seamlessly for videobuffer , which will receive normal per - queue offsets and
* proper videobuf queue pointers . The differentiation is made outside videobuf
* by adding a predefined offset to buffers from one of the queues and
* subtracting it before passing it back to videobuf . Only drivers ( and
* thus applications ) receive modified offsets .
*/
2010-04-23 12:38:37 +04:00
int v4l2_m2m_mmap ( struct file * file , struct v4l2_m2m_ctx * m2m_ctx ,
struct vm_area_struct * vma ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_init ( ) - initialize per - driver m2m data
*
2016-09-08 16:39:58 +03:00
* @ m2m_ops : pointer to struct v4l2_m2m_ops
*
2016-09-08 16:16:36 +03:00
* Usually called from driver ' s ` ` probe ( ) ` ` function .
*
* Return : returns an opaque pointer to the internal data to handle M2M context
2016-09-08 16:16:27 +03:00
*/
2012-09-11 13:32:17 +04:00
struct v4l2_m2m_dev * v4l2_m2m_init ( const struct v4l2_m2m_ops * m2m_ops ) ;
2016-09-08 16:16:27 +03:00
2018-07-02 18:36:05 +03:00
# if defined(CONFIG_MEDIA_CONTROLLER)
void v4l2_m2m_unregister_media_controller ( struct v4l2_m2m_dev * m2m_dev ) ;
int v4l2_m2m_register_media_controller ( struct v4l2_m2m_dev * m2m_dev ,
struct video_device * vdev , int function ) ;
# else
static inline void
v4l2_m2m_unregister_media_controller ( struct v4l2_m2m_dev * m2m_dev )
{
}
static inline int
v4l2_m2m_register_media_controller ( struct v4l2_m2m_dev * m2m_dev ,
struct video_device * vdev , int function )
{
return 0 ;
}
# endif
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_release ( ) - cleans up and frees a m2m_dev structure
*
2016-09-08 23:20:44 +03:00
* @ m2m_dev : opaque pointer to the internal data to handle M2M context
2016-09-08 16:39:58 +03:00
*
2016-09-08 16:16:36 +03:00
* Usually called from driver ' s ` ` remove ( ) ` ` function .
2016-09-08 16:16:27 +03:00
*/
2010-04-23 12:38:37 +04:00
void v4l2_m2m_release ( struct v4l2_m2m_dev * m2m_dev ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_ctx_init ( ) - allocate and initialize a m2m context
2016-09-08 16:39:58 +03:00
*
2016-09-08 23:20:44 +03:00
* @ m2m_dev : opaque pointer to the internal data to handle M2M context
2016-09-08 16:39:58 +03:00
* @ drv_priv : driver ' s instance private data
* @ queue_init : a callback for queue type - specific initialization function
* to be used for initializing videobuf_queues
2016-09-08 16:16:27 +03:00
*
2016-09-08 16:16:36 +03:00
* Usually called from driver ' s ` ` open ( ) ` ` function .
2016-09-08 16:16:27 +03:00
*/
2011-01-12 12:50:24 +03:00
struct v4l2_m2m_ctx * v4l2_m2m_ctx_init ( struct v4l2_m2m_dev * m2m_dev ,
void * drv_priv ,
int ( * queue_init ) ( void * priv , struct vb2_queue * src_vq , struct vb2_queue * dst_vq ) ) ;
2013-06-03 11:23:48 +04:00
static inline void v4l2_m2m_set_src_buffered ( struct v4l2_m2m_ctx * m2m_ctx ,
bool buffered )
{
m2m_ctx - > out_q_ctx . buffered = buffered ;
}
static inline void v4l2_m2m_set_dst_buffered ( struct v4l2_m2m_ctx * m2m_ctx ,
bool buffered )
{
m2m_ctx - > cap_q_ctx . buffered = buffered ;
}
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_ctx_release ( ) - release m2m context
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
*
2016-09-08 16:16:27 +03:00
* Usually called from driver ' s release ( ) function .
*/
2010-04-23 12:38:37 +04:00
void v4l2_m2m_ctx_release ( struct v4l2_m2m_ctx * m2m_ctx ) ;
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_buf_queue ( ) - add a buffer to the proper ready buffers list .
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ vbuf : pointer to struct & vb2_v4l2_buffer
*
2016-09-08 16:16:36 +03:00
* Call from videobuf_queue_ops - > ops - > buf_queue , videobuf_queue_ops callback .
2016-09-08 16:16:27 +03:00
*/
[media] media: videobuf2: Restructure vb2_buffer
Remove v4l2 stuff - v4l2_buf, v4l2_plane - from struct vb2_buffer.
Add new member variables - bytesused, length, offset, userptr, fd,
data_offset - to struct vb2_plane in order to cover all information
of v4l2_plane.
struct vb2_plane {
<snip>
unsigned int bytesused;
unsigned int length;
union {
unsigned int offset;
unsigned long userptr;
int fd;
} m;
unsigned int data_offset;
}
Replace v4l2_buf with new member variables - index, type, memory - which
are common fields for buffer management.
struct vb2_buffer {
<snip>
unsigned int index;
unsigned int type;
unsigned int memory;
unsigned int num_planes;
struct vb2_plane planes[VIDEO_MAX_PLANES];
<snip>
};
v4l2 specific fields - flags, field, timestamp, timecode,
sequence - are moved to vb2_v4l2_buffer in videobuf2-v4l2.c
struct vb2_v4l2_buffer {
struct vb2_buffer vb2_buf;
__u32 flags;
__u32 field;
struct timeval timestamp;
struct v4l2_timecode timecode;
__u32 sequence;
};
Signed-off-by: Junghak Sung <jh1009.sung@samsung.com>
Signed-off-by: Geunyoung Kim <nenggun.kim@samsung.com>
Acked-by: Seung-Woo Kim <sw0312.kim@samsung.com>
Acked-by: Inki Dae <inki.dae@samsung.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
2015-09-22 16:30:30 +03:00
void v4l2_m2m_buf_queue ( struct v4l2_m2m_ctx * m2m_ctx ,
struct vb2_v4l2_buffer * vbuf ) ;
2010-04-23 12:38:37 +04:00
/**
* v4l2_m2m_num_src_bufs_ready ( ) - return the number of source buffers ready for
* use
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline
unsigned int v4l2_m2m_num_src_bufs_ready ( struct v4l2_m2m_ctx * m2m_ctx )
{
2012-08-31 16:18:04 +04:00
return m2m_ctx - > out_q_ctx . num_rdy ;
2010-04-23 12:38:37 +04:00
}
/**
2016-09-22 13:59:03 +03:00
* v4l2_m2m_num_dst_bufs_ready ( ) - return the number of destination buffers
2010-04-23 12:38:37 +04:00
* ready for use
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline
unsigned int v4l2_m2m_num_dst_bufs_ready ( struct v4l2_m2m_ctx * m2m_ctx )
{
2012-08-31 16:18:04 +04:00
return m2m_ctx - > cap_q_ctx . num_rdy ;
2010-04-23 12:38:37 +04:00
}
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_next_buf ( ) - return next buffer from the list of ready buffers
2016-09-08 16:39:58 +03:00
*
* @ q_ctx : pointer to struct @ v4l2_m2m_queue_ctx
2016-09-08 16:16:27 +03:00
*/
2011-01-12 12:50:24 +03:00
void * v4l2_m2m_next_buf ( struct v4l2_m2m_queue_ctx * q_ctx ) ;
2010-04-23 12:38:37 +04:00
/**
* v4l2_m2m_next_src_buf ( ) - return next source buffer from the list of ready
* buffers
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline void * v4l2_m2m_next_src_buf ( struct v4l2_m2m_ctx * m2m_ctx )
{
2011-01-12 12:50:24 +03:00
return v4l2_m2m_next_buf ( & m2m_ctx - > out_q_ctx ) ;
2010-04-23 12:38:37 +04:00
}
/**
* v4l2_m2m_next_dst_buf ( ) - return next destination buffer from the list of
* ready buffers
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline void * v4l2_m2m_next_dst_buf ( struct v4l2_m2m_ctx * m2m_ctx )
{
2011-01-12 12:50:24 +03:00
return v4l2_m2m_next_buf ( & m2m_ctx - > cap_q_ctx ) ;
2010-04-23 12:38:37 +04:00
}
2018-06-26 16:26:52 +03:00
/**
* v4l2_m2m_last_buf ( ) - return last buffer from the list of ready buffers
*
* @ q_ctx : pointer to struct @ v4l2_m2m_queue_ctx
*/
void * v4l2_m2m_last_buf ( struct v4l2_m2m_queue_ctx * q_ctx ) ;
/**
* v4l2_m2m_last_src_buf ( ) - return last destination buffer from the list of
* ready buffers
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
*/
static inline void * v4l2_m2m_last_src_buf ( struct v4l2_m2m_ctx * m2m_ctx )
{
return v4l2_m2m_last_buf ( & m2m_ctx - > out_q_ctx ) ;
}
/**
* v4l2_m2m_last_dst_buf ( ) - return last destination buffer from the list of
* ready buffers
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
*/
static inline void * v4l2_m2m_last_dst_buf ( struct v4l2_m2m_ctx * m2m_ctx )
{
return v4l2_m2m_last_buf ( & m2m_ctx - > cap_q_ctx ) ;
}
2017-06-15 19:31:42 +03:00
/**
* v4l2_m2m_for_each_dst_buf ( ) - iterate over a list of destination ready
* buffers
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ b : current buffer of type struct v4l2_m2m_buffer
*/
# define v4l2_m2m_for_each_dst_buf(m2m_ctx, b) \
list_for_each_entry ( b , & m2m_ctx - > cap_q_ctx . rdy_queue , list )
/**
* v4l2_m2m_for_each_src_buf ( ) - iterate over a list of source ready buffers
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ b : current buffer of type struct v4l2_m2m_buffer
*/
# define v4l2_m2m_for_each_src_buf(m2m_ctx, b) \
list_for_each_entry ( b , & m2m_ctx - > out_q_ctx . rdy_queue , list )
/**
* v4l2_m2m_for_each_dst_buf_safe ( ) - iterate over a list of destination ready
* buffers safely
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ b : current buffer of type struct v4l2_m2m_buffer
* @ n : used as temporary storage
*/
# define v4l2_m2m_for_each_dst_buf_safe(m2m_ctx, b, n) \
list_for_each_entry_safe ( b , n , & m2m_ctx - > cap_q_ctx . rdy_queue , list )
/**
* v4l2_m2m_for_each_src_buf_safe ( ) - iterate over a list of source ready
* buffers safely
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ b : current buffer of type struct v4l2_m2m_buffer
* @ n : used as temporary storage
*/
# define v4l2_m2m_for_each_src_buf_safe(m2m_ctx, b, n) \
list_for_each_entry_safe ( b , n , & m2m_ctx - > out_q_ctx . rdy_queue , list )
2010-04-23 12:38:37 +04:00
/**
2011-01-12 12:50:24 +03:00
* v4l2_m2m_get_src_vq ( ) - return vb2_queue for source buffers
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline
2011-01-12 12:50:24 +03:00
struct vb2_queue * v4l2_m2m_get_src_vq ( struct v4l2_m2m_ctx * m2m_ctx )
2010-04-23 12:38:37 +04:00
{
2011-01-12 12:50:24 +03:00
return & m2m_ctx - > out_q_ctx . q ;
2010-04-23 12:38:37 +04:00
}
/**
2011-01-12 12:50:24 +03:00
* v4l2_m2m_get_dst_vq ( ) - return vb2_queue for destination buffers
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline
2011-01-12 12:50:24 +03:00
struct vb2_queue * v4l2_m2m_get_dst_vq ( struct v4l2_m2m_ctx * m2m_ctx )
2010-04-23 12:38:37 +04:00
{
2011-01-12 12:50:24 +03:00
return & m2m_ctx - > cap_q_ctx . q ;
2010-04-23 12:38:37 +04:00
}
2016-09-08 16:16:27 +03:00
/**
* v4l2_m2m_buf_remove ( ) - take off a buffer from the list of ready buffers and
* return it
2016-09-08 16:39:58 +03:00
*
* @ q_ctx : pointer to struct @ v4l2_m2m_queue_ctx
2016-09-08 16:16:27 +03:00
*/
2011-01-12 12:50:24 +03:00
void * v4l2_m2m_buf_remove ( struct v4l2_m2m_queue_ctx * q_ctx ) ;
2010-04-23 12:38:37 +04:00
/**
* v4l2_m2m_src_buf_remove ( ) - take off a source buffer from the list of ready
* buffers and return it
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline void * v4l2_m2m_src_buf_remove ( struct v4l2_m2m_ctx * m2m_ctx )
{
2011-01-12 12:50:24 +03:00
return v4l2_m2m_buf_remove ( & m2m_ctx - > out_q_ctx ) ;
2010-04-23 12:38:37 +04:00
}
/**
* v4l2_m2m_dst_buf_remove ( ) - take off a destination buffer from the list of
* ready buffers and return it
2015-08-22 11:34:40 +03:00
*
2016-09-08 16:39:58 +03:00
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
2010-04-23 12:38:37 +04:00
*/
static inline void * v4l2_m2m_dst_buf_remove ( struct v4l2_m2m_ctx * m2m_ctx )
{
2011-01-12 12:50:24 +03:00
return v4l2_m2m_buf_remove ( & m2m_ctx - > cap_q_ctx ) ;
2010-04-23 12:38:37 +04:00
}
2017-06-15 19:31:42 +03:00
/**
* v4l2_m2m_buf_remove_by_buf ( ) - take off exact buffer from the list of ready
* buffers
*
* @ q_ctx : pointer to struct @ v4l2_m2m_queue_ctx
* @ vbuf : the buffer to be removed
*/
void v4l2_m2m_buf_remove_by_buf ( struct v4l2_m2m_queue_ctx * q_ctx ,
struct vb2_v4l2_buffer * vbuf ) ;
/**
* v4l2_m2m_src_buf_remove_by_buf ( ) - take off exact source buffer from the list
* of ready buffers
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ vbuf : the buffer to be removed
*/
static inline void v4l2_m2m_src_buf_remove_by_buf ( struct v4l2_m2m_ctx * m2m_ctx ,
struct vb2_v4l2_buffer * vbuf )
{
v4l2_m2m_buf_remove_by_buf ( & m2m_ctx - > out_q_ctx , vbuf ) ;
}
/**
* v4l2_m2m_dst_buf_remove_by_buf ( ) - take off exact destination buffer from the
* list of ready buffers
*
* @ m2m_ctx : m2m context assigned to the instance given by struct & v4l2_m2m_ctx
* @ vbuf : the buffer to be removed
*/
static inline void v4l2_m2m_dst_buf_remove_by_buf ( struct v4l2_m2m_ctx * m2m_ctx ,
struct vb2_v4l2_buffer * vbuf )
{
v4l2_m2m_buf_remove_by_buf ( & m2m_ctx - > cap_q_ctx , vbuf ) ;
}
struct vb2_v4l2_buffer *
v4l2_m2m_buf_remove_by_idx ( struct v4l2_m2m_queue_ctx * q_ctx , unsigned int idx ) ;
static inline struct vb2_v4l2_buffer *
v4l2_m2m_src_buf_remove_by_idx ( struct v4l2_m2m_ctx * m2m_ctx , unsigned int idx )
{
return v4l2_m2m_buf_remove_by_idx ( & m2m_ctx - > out_q_ctx , idx ) ;
}
static inline struct vb2_v4l2_buffer *
v4l2_m2m_dst_buf_remove_by_idx ( struct v4l2_m2m_ctx * m2m_ctx , unsigned int idx )
{
return v4l2_m2m_buf_remove_by_idx ( & m2m_ctx - > cap_q_ctx , idx ) ;
}
2018-05-21 11:54:53 +03:00
/* v4l2 request helper */
2018-10-18 21:54:29 +03:00
void v4l2_m2m_request_queue ( struct media_request * req ) ;
2018-05-21 11:54:53 +03:00
2013-09-15 01:39:04 +04:00
/* v4l2 ioctl helpers */
int v4l2_m2m_ioctl_reqbufs ( struct file * file , void * priv ,
struct v4l2_requestbuffers * rb ) ;
int v4l2_m2m_ioctl_create_bufs ( struct file * file , void * fh ,
struct v4l2_create_buffers * create ) ;
int v4l2_m2m_ioctl_querybuf ( struct file * file , void * fh ,
struct v4l2_buffer * buf ) ;
int v4l2_m2m_ioctl_expbuf ( struct file * file , void * fh ,
struct v4l2_exportbuffer * eb ) ;
int v4l2_m2m_ioctl_qbuf ( struct file * file , void * fh ,
struct v4l2_buffer * buf ) ;
int v4l2_m2m_ioctl_dqbuf ( struct file * file , void * fh ,
struct v4l2_buffer * buf ) ;
2015-06-05 17:28:50 +03:00
int v4l2_m2m_ioctl_prepare_buf ( struct file * file , void * fh ,
struct v4l2_buffer * buf ) ;
2013-09-15 01:39:04 +04:00
int v4l2_m2m_ioctl_streamon ( struct file * file , void * fh ,
enum v4l2_buf_type type ) ;
int v4l2_m2m_ioctl_streamoff ( struct file * file , void * fh ,
enum v4l2_buf_type type ) ;
int v4l2_m2m_fop_mmap ( struct file * file , struct vm_area_struct * vma ) ;
2017-07-03 10:02:56 +03:00
__poll_t v4l2_m2m_fop_poll ( struct file * file , poll_table * wait ) ;
2013-09-15 01:39:04 +04:00
2010-04-23 12:38:37 +04:00
# endif /* _MEDIA_V4L2_MEM2MEM_H */