提交 764af39a 编写于 作者: M Manjunath Hadli 提交者: Mauro Carvalho Chehab

[media] davinci: vpif capture: size up the memory for the buffers from the buffer pool

Size up the memory for the buffers from the buffer pool allocated in board
file.  Then adjust the reqbuf count depending the available memory.
Signed-off-by: NManjunath Hadli <manjunath.hadli@ti.com>
Signed-off-by: NLad, Prabhakar <prabhakar.lad@ti.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 fc613d44
...@@ -217,6 +217,23 @@ static int vpif_buffer_setup(struct videobuf_queue *q, unsigned int *count, ...@@ -217,6 +217,23 @@ static int vpif_buffer_setup(struct videobuf_queue *q, unsigned int *count,
/* Calculate the size of the buffer */ /* Calculate the size of the buffer */
*size = config_params.channel_bufsize[ch->channel_id]; *size = config_params.channel_bufsize[ch->channel_id];
/*
* Checking if the buffer size exceeds the available buffer
* ycmux_mode = 0 means 1 channel mode HD and
* ycmux_mode = 1 means 2 channels mode SD
*/
if (ch->vpifparams.std_info.ycmux_mode == 0) {
if (config_params.video_limit[ch->channel_id])
while (*size * *count > (config_params.video_limit[0]
+ config_params.video_limit[1]))
(*count)--;
} else {
if (config_params.video_limit[ch->channel_id])
while (*size * *count >
config_params.video_limit[ch->channel_id])
(*count)--;
}
if (*count < config_params.min_numbuffers) if (*count < config_params.min_numbuffers)
*count = config_params.min_numbuffers; *count = config_params.min_numbuffers;
return 0; return 0;
...@@ -890,7 +907,7 @@ static int vpif_reqbufs(struct file *file, void *priv, ...@@ -890,7 +907,7 @@ static int vpif_reqbufs(struct file *file, void *priv,
} }
} }
if (V4L2_BUF_TYPE_VIDEO_CAPTURE != reqbuf->type) if (V4L2_BUF_TYPE_VIDEO_CAPTURE != reqbuf->type || !vpif_dev)
return -EINVAL; return -EINVAL;
index = VPIF_VIDEO_INDEX; index = VPIF_VIDEO_INDEX;
...@@ -902,7 +919,7 @@ static int vpif_reqbufs(struct file *file, void *priv, ...@@ -902,7 +919,7 @@ static int vpif_reqbufs(struct file *file, void *priv,
/* Initialize videobuf queue as per the buffer type */ /* Initialize videobuf queue as per the buffer type */
videobuf_queue_dma_contig_init(&common->buffer_queue, videobuf_queue_dma_contig_init(&common->buffer_queue,
&video_qops, NULL, &video_qops, vpif_dev,
&common->irqlock, &common->irqlock,
reqbuf->type, reqbuf->type,
common->fmt.fmt.pix.field, common->fmt.fmt.pix.field,
...@@ -2171,6 +2188,7 @@ static __init int vpif_probe(struct platform_device *pdev) ...@@ -2171,6 +2188,7 @@ static __init int vpif_probe(struct platform_device *pdev)
struct video_device *vfd; struct video_device *vfd;
struct resource *res; struct resource *res;
int subdev_count; int subdev_count;
size_t size;
vpif_dev = &pdev->dev; vpif_dev = &pdev->dev;
...@@ -2225,6 +2243,23 @@ static __init int vpif_probe(struct platform_device *pdev) ...@@ -2225,6 +2243,23 @@ static __init int vpif_probe(struct platform_device *pdev)
ch->video_dev = vfd; ch->video_dev = vfd;
} }
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
if (res) {
size = resource_size(res);
/* The resources are divided into two equal memory and when we
* have HD output we can add them together
*/
for (j = 0; j < VPIF_CAPTURE_MAX_DEVICES; j++) {
ch = vpif_obj.dev[j];
ch->channel_id = j;
/* only enabled if second resource exists */
config_params.video_limit[ch->channel_id] = 0;
if (size)
config_params.video_limit[ch->channel_id] =
size/2;
}
}
for (j = 0; j < VPIF_CAPTURE_MAX_DEVICES; j++) { for (j = 0; j < VPIF_CAPTURE_MAX_DEVICES; j++) {
ch = vpif_obj.dev[j]; ch = vpif_obj.dev[j];
ch->channel_id = j; ch->channel_id = j;
......
...@@ -151,6 +151,7 @@ struct vpif_config_params { ...@@ -151,6 +151,7 @@ struct vpif_config_params {
u32 min_bufsize[VPIF_CAPTURE_NUM_CHANNELS]; u32 min_bufsize[VPIF_CAPTURE_NUM_CHANNELS];
u32 channel_bufsize[VPIF_CAPTURE_NUM_CHANNELS]; u32 channel_bufsize[VPIF_CAPTURE_NUM_CHANNELS];
u8 default_device[VPIF_CAPTURE_NUM_CHANNELS]; u8 default_device[VPIF_CAPTURE_NUM_CHANNELS];
u32 video_limit[VPIF_CAPTURE_NUM_CHANNELS];
u8 max_device_type; u8 max_device_type;
}; };
/* Struct which keeps track of the line numbers for the sliced vbi service */ /* Struct which keeps track of the line numbers for the sliced vbi service */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册