2015-08-02 14:15:23 -03:00
/*
* vsp1_pipe . h - - R - Car VSP1 Pipeline
*
* Copyright ( C ) 2013 - 2015 Renesas Electronics Corporation
*
* Contact : Laurent Pinchart ( laurent . pinchart @ ideasonboard . 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 __VSP1_PIPE_H__
# define __VSP1_PIPE_H__
2016-01-17 19:53:56 -02:00
# include <linux/kref.h>
2015-08-02 14:15:23 -03:00
# include <linux/list.h>
# include <linux/spinlock.h>
# include <linux/wait.h>
# include <media/media-entity.h>
2015-11-08 20:06:57 -02:00
struct vsp1_dl_list ;
2015-08-02 14:15:23 -03:00
struct vsp1_rwpf ;
2015-08-03 10:21:49 -03:00
/*
* struct vsp1_format_info - VSP1 video format description
* @ fourcc : V4L2 pixel format FCC identifier
2016-06-09 14:57:02 -03:00
* @ mbus : media bus format code
* @ hwfmt : VSP1 hardware format
* @ swap : swap register control
2015-08-03 10:21:49 -03:00
* @ planes : number of planes
* @ bpp : bits per pixel
* @ swap_yc : the Y and C components are swapped ( Y comes before C )
* @ swap_uv : the U and V components are swapped ( V comes before U )
* @ hsub : horizontal subsampling factor
* @ vsub : vertical subsampling factor
* @ alpha : has an alpha channel
*/
struct vsp1_format_info {
u32 fourcc ;
unsigned int mbus ;
unsigned int hwfmt ;
unsigned int swap ;
unsigned int planes ;
unsigned int bpp [ 3 ] ;
bool swap_yc ;
bool swap_uv ;
unsigned int hsub ;
unsigned int vsub ;
bool alpha ;
} ;
2015-08-02 14:15:23 -03:00
enum vsp1_pipeline_state {
VSP1_PIPELINE_STOPPED ,
VSP1_PIPELINE_RUNNING ,
VSP1_PIPELINE_STOPPING ,
} ;
/*
* struct vsp1_pipeline - A VSP1 hardware pipeline
2015-08-02 18:24:55 -03:00
* @ pipe : the media pipeline
2015-08-02 14:15:23 -03:00
* @ irqlock : protects the pipeline state
2015-08-02 18:24:55 -03:00
* @ state : current state
2016-05-13 19:13:51 -03:00
* @ wq : wait queue to wait for state change completion
2015-08-02 18:24:55 -03:00
* @ frame_end : frame end interrupt handler
2015-08-02 14:15:23 -03:00
* @ lock : protects the pipeline use count and stream count
2016-01-17 19:53:56 -02:00
* @ kref : pipeline reference count
2015-08-02 18:24:55 -03:00
* @ stream_count : number of streaming video nodes
* @ buffers_ready : bitmask of RPFs and WPFs with at least one buffer available
2016-04-10 02:59:04 -03:00
* @ sequence : frame sequence number
2015-08-02 18:24:55 -03:00
* @ num_inputs : number of RPFs
2015-08-05 16:40:31 -03:00
* @ inputs : array of RPFs in the pipeline ( indexed by RPF index )
2015-08-02 18:24:55 -03:00
* @ output : WPF at the output of the pipeline
* @ bru : BRU entity , if present
2016-02-24 20:40:22 -03:00
* @ hgo : HGO entity , if present
2016-09-06 11:38:56 -03:00
* @ hgt : HGT entity , if present
2015-08-02 18:24:55 -03:00
* @ lif : LIF entity , if present
* @ uds : UDS entity , if present
* @ uds_input : entity at the input of the UDS , if the UDS is present
* @ entities : list of entities in the pipeline
2015-09-07 01:40:25 -03:00
* @ dl : display list associated with the pipeline
2016-07-12 10:06:34 -03:00
* @ div_size : The maximum allowed partition size for the pipeline
* @ partitions : The number of partitions used to process one frame
2016-09-11 23:26:35 -03:00
* @ current_partition : The partition number currently being configured
2015-08-02 14:15:23 -03:00
*/
struct vsp1_pipeline {
struct media_pipeline pipe ;
spinlock_t irqlock ;
enum vsp1_pipeline_state state ;
wait_queue_head_t wq ;
void ( * frame_end ) ( struct vsp1_pipeline * pipe ) ;
struct mutex lock ;
2016-01-17 19:53:56 -02:00
struct kref kref ;
2015-08-02 14:15:23 -03:00
unsigned int stream_count ;
unsigned int buffers_ready ;
2016-04-10 02:59:04 -03:00
unsigned int sequence ;
2015-08-02 14:15:23 -03:00
unsigned int num_inputs ;
struct vsp1_rwpf * inputs [ VSP1_MAX_RPF ] ;
struct vsp1_rwpf * output ;
struct vsp1_entity * bru ;
2016-02-24 20:40:22 -03:00
struct vsp1_entity * hgo ;
2016-09-06 11:38:56 -03:00
struct vsp1_entity * hgt ;
2015-08-02 14:15:23 -03:00
struct vsp1_entity * lif ;
struct vsp1_entity * uds ;
struct vsp1_entity * uds_input ;
struct list_head entities ;
2015-09-07 01:40:25 -03:00
2015-11-08 20:06:57 -02:00
struct vsp1_dl_list * dl ;
2016-07-12 10:06:34 -03:00
unsigned int div_size ;
unsigned int partitions ;
2016-09-11 23:26:35 -03:00
struct v4l2_rect partition ;
unsigned int current_partition ;
2015-08-02 14:15:23 -03:00
} ;
void vsp1_pipeline_reset ( struct vsp1_pipeline * pipe ) ;
2015-08-02 17:32:13 -03:00
void vsp1_pipeline_init ( struct vsp1_pipeline * pipe ) ;
2015-08-02 14:15:23 -03:00
void vsp1_pipeline_run ( struct vsp1_pipeline * pipe ) ;
bool vsp1_pipeline_stopped ( struct vsp1_pipeline * pipe ) ;
int vsp1_pipeline_stop ( struct vsp1_pipeline * pipe ) ;
bool vsp1_pipeline_ready ( struct vsp1_pipeline * pipe ) ;
void vsp1_pipeline_frame_end ( struct vsp1_pipeline * pipe ) ;
void vsp1_pipeline_propagate_alpha ( struct vsp1_pipeline * pipe ,
2016-06-19 23:19:43 -03:00
struct vsp1_dl_list * dl , unsigned int alpha ) ;
2015-08-02 14:15:23 -03:00
void vsp1_pipelines_suspend ( struct vsp1_device * vsp1 ) ;
void vsp1_pipelines_resume ( struct vsp1_device * vsp1 ) ;
2016-09-15 16:08:09 -03:00
const struct vsp1_format_info * vsp1_get_format_info ( struct vsp1_device * vsp1 ,
u32 fourcc ) ;
2015-08-03 10:21:49 -03:00
2015-08-02 14:15:23 -03:00
# endif /* __VSP1_PIPE_H__ */