Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3286283yba; Tue, 16 Apr 2019 08:19:57 -0700 (PDT) X-Google-Smtp-Source: APXvYqxeQcfmEN2ywDJLq4nTWFLE6qTwlwdWfJSwK8a9r//BHPRHlI+n9f7L9SMV1tWpvKCvkhfw X-Received: by 2002:a17:902:b713:: with SMTP id d19mr83593790pls.54.1555427996906; Tue, 16 Apr 2019 08:19:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555427996; cv=none; d=google.com; s=arc-20160816; b=sVLypzavdtCSm6W9I7Mt1pl0GGuKBXJdrFSF4vyOopvMOC1ybAwmL/1Oa+YAEL3yk6 3uXRG1xIMkPA2/5nqP+wZghdD3vkKy/7PmOmuwhRvIow7NeYMqs4bPusPtb7qOrXLTsw tFVLn44cOUclBDP8x6Ve2hXZUGc1B2RFeTx4sgA0RquEVyVUPT2X7dWcEF6JJLz9SWiR dyhTAda+JgAN2zZUvuQegChn3w5aIdSnAEFnBY3DabDhTyhv/BQYOQKs/VmHg1hx9aXv YRP23LScIbNmzR27QKEm7V73YYE0gMabgwZwcoVTsP864gDntvLHOLYfVYgid33PUexw TjjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:autocrypt:openpgp:from:references:cc:to:subject; bh=nKJlbZXPsWmEj0b/r4shgVOafCOnKrd/Jk8ZdwM9wps=; b=nGBtNFlqSjWPO7v2+OyJTmbQTPU/W3MJBLotDjQ9mgoH1QG//C/tfpU0YtM0c9xYQU 25ccG+5nOprT6+6dxsRwMlY8cupAn3dPifpWafLv26VsbA/VfYRaFVb+RaCa4DkthBZe PGNIdDNv6HwyPkKqR9abuOTYA3kG6gwI+s0eJLj0vOty8uFoeG6V0t8mbeghTHcqAshy s4yi5d+Qqi5LMn94+7JAIUYHBRzQZh9vmEGEEdU+n7vteQVWClMvP0gLj1ilg87kIvD1 CP/Z07KX6yRqq0lvxC9ihOaymt8WkfMDtpFzc0MELS5faZUEPSDGdo+dvWAcd84rTGhf lqPA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f2si23598347pfd.17.2019.04.16.08.19.40; Tue, 16 Apr 2019 08:19:56 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728667AbfDPPRl (ORCPT + 99 others); Tue, 16 Apr 2019 11:17:41 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:51002 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725796AbfDPPRl (ORCPT ); Tue, 16 Apr 2019 11:17:41 -0400 Received: from [IPv6:2804:431:9719:a941:6e62:4fbd:6f2d:d2e3] (unknown [IPv6:2804:431:9719:a941:6e62:4fbd:6f2d:d2e3]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: koike) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id 1D034280334; Tue, 16 Apr 2019 16:17:36 +0100 (BST) Subject: Re: [PATCH v2 11/15] media: vimc: Add and use new struct vimc_frame To: =?UTF-8?Q?Andr=c3=a9_Almeida?= , linux-media@vger.kernel.org Cc: mchehab@kernel.org, hverkuil@xs4all.nl, lucmaga@gmail.com, linux-kernel@vger.kernel.org, kernel@collabora.com, lkcamp@lists.libreplanetbr.org References: <20190327151743.18528-1-andrealmeid@collabora.com> <20190327151743.18528-12-andrealmeid@collabora.com> From: Helen Koike Openpgp: preference=signencrypt Autocrypt: addr=helen.koike@collabora.com; keydata= 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 Message-ID: Date: Tue, 16 Apr 2019 12:17:32 -0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.5.1 MIME-Version: 1.0 In-Reply-To: <20190327151743.18528-12-andrealmeid@collabora.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi André, Thanks for the patch, just some comments bellow. On 3/27/19 12:17 PM, André Almeida wrote: > Struct vimc_frame is intended to hold metadata about a frame, > such as memory address of a plane, number of planes and size > of each plane, to better integrated with the multiplanar operations. > The struct can be also used with singleplanar formats, making the > implementation of frame manipulation generic for both type of > formats. > > vimc_fill_frame function fills a vimc_frame structure given a > pixelformat, height and width. This is done once to avoid recalculations > and provide enough information to subdevices work with > the frame. > > Change the return and argument type of process_frame from void* to > vimc_frame*. Change the frame in subdevices structs from u8* to vimc_frame. > > Signed-off-by: André Almeida > --- > Change in v2: > - Fix alignment issues > > drivers/media/platform/vimc/vimc-capture.c | 6 +-- > drivers/media/platform/vimc/vimc-common.c | 36 +++++++++++++++ > drivers/media/platform/vimc/vimc-common.h | 49 +++++++++++++++++++-- > drivers/media/platform/vimc/vimc-debayer.c | 34 +++++++------- > drivers/media/platform/vimc/vimc-scaler.c | 26 ++++++----- > drivers/media/platform/vimc/vimc-sensor.c | 18 ++++---- > drivers/media/platform/vimc/vimc-streamer.c | 2 +- > 7 files changed, 127 insertions(+), 44 deletions(-) > > diff --git a/drivers/media/platform/vimc/vimc-capture.c b/drivers/media/platform/vimc/vimc-capture.c > index 3c93fbd51629..fae42b778711 100644 > --- a/drivers/media/platform/vimc/vimc-capture.c > +++ b/drivers/media/platform/vimc/vimc-capture.c > @@ -600,8 +600,8 @@ static void vimc_cap_comp_unbind(struct device *comp, struct device *master, > video_unregister_device(&vcap->vdev); > } > > -static void *vimc_cap_process_frame(struct vimc_ent_device *ved, > - const void *frame) > +static struct vimc_frame *vimc_cap_process_frame(struct vimc_ent_device *ved, > + const struct vimc_frame *frame) > { > struct vimc_cap_device *vcap = container_of(ved, struct vimc_cap_device, > ved); > @@ -630,7 +630,7 @@ static void *vimc_cap_process_frame(struct vimc_ent_device *ved, > > vbuf = vb2_plane_vaddr(&vimc_buf->vb2.vb2_buf, 0); > > - memcpy(vbuf, frame, vcap->format.fmt.pix.sizeimage); > + memcpy(vbuf, frame->plane_addr[0], vcap->format.fmt.pix.sizeimage); > > /* Set it as ready */ > vb2_set_plane_payload(&vimc_buf->vb2.vb2_buf, 0, > diff --git a/drivers/media/platform/vimc/vimc-common.c b/drivers/media/platform/vimc/vimc-common.c > index 8d314b5dbb73..26868a753c53 100644 > --- a/drivers/media/platform/vimc/vimc-common.c > +++ b/drivers/media/platform/vimc/vimc-common.c > @@ -380,6 +380,42 @@ int vimc_ent_sd_register(struct vimc_ent_device *ved, > } > EXPORT_SYMBOL_GPL(vimc_ent_sd_register); > > +void vimc_fill_frame(struct vimc_frame *frame, u32 pixelformat, u32 width, > + u32 height, bool multiplanar) > +{ > + unsigned int i; > + const struct v4l2_format_info *pix_info; > + > + pix_info = v4l2_format_info(pixelformat); > + frame->pixelformat = pixelformat; > + > + if (multiplanar) { > + struct v4l2_pix_format_mplane pix_fmt_mp; > + > + v4l2_fill_pixfmt_mp(&pix_fmt_mp, pixelformat, width, height); > + > + frame->num_planes = pix_fmt_mp.num_planes; > + for (i = 0; i < pix_fmt_mp.num_planes; i++) { > + frame->sizeimage[i] = pix_fmt_mp.plane_fmt[i].sizeimage; > + frame->bytesperline[i] = > + pix_fmt_mp.plane_fmt[i].bytesperline; > + frame->bpp[i] = pix_info->bpp[i]; > + frame->plane_addr[i] = NULL; > + } > + } else { > + struct v4l2_pix_format pix_fmt; > + > + v4l2_fill_pixfmt(&pix_fmt, pixelformat, width, height); > + > + frame->num_planes = 1; > + frame->sizeimage[0] = pix_fmt.sizeimage; > + frame->bytesperline[0] = pix_fmt.bytesperline; > + frame->bpp[0] = pix_info->bpp[0]; > + frame->plane_addr[0] = NULL; > + } > +} > +EXPORT_SYMBOL_GPL(vimc_fill_frame); > + > void vimc_ent_sd_unregister(struct vimc_ent_device *ved, struct v4l2_subdev *sd) > { > media_entity_cleanup(ved->ent); > diff --git a/drivers/media/platform/vimc/vimc-common.h b/drivers/media/platform/vimc/vimc-common.h > index 142ddfa69b3d..7d167dd696ca 100644 > --- a/drivers/media/platform/vimc/vimc-common.h > +++ b/drivers/media/platform/vimc/vimc-common.h > @@ -21,6 +21,7 @@ > #include > #include > #include > +#include > > #include "vimc-streamer.h" > > @@ -79,6 +80,31 @@ struct vimc_platform_data { > char entity_name[32]; > }; > > +/** > + * struct vimc_frame - metadata about frame components > + * > + * @pixelformat: fourcc pixelformat code > + * @plane_addr: pointer to kernel address of the plane > + * @num_planes: number of valid planes on a frame > + * @sizeimage: size in bytes of a plane > + * @bytesperline: number of bytes per line of a plane > + * @bpp: number of bytes per pixel of a plane Please, re-order the variable docs in the same order declared in the struct. > + * > + * This struct helps subdevices to get information about the frame on > + * multiplanar formats. If a singleplanar format is used, only the first > + * index of each array is used and num_planes is set to 1, so the > + * implementation is generic and the code will work for both formats. > + */ > + > +struct vimc_frame { > + u32 pixelformat; > + u32 sizeimage[TPG_MAX_PLANES]; > + u32 bytesperline[TPG_MAX_PLANES]; > + u8 *plane_addr[TPG_MAX_PLANES]; > + u8 bpp[TPG_MAX_PLANES]; any particular reason not to use unsigned int here? > + u8 num_planes; same here. Usually we use u8, u16, u32, s8, s16, etc, if we have some specific requirement to keep the data size (because of some API, protocol, or if the hardware requires it). The main reason, afaik, is that int is more efficient for the processor. In some architectures the cpu doesn't know how to deal with a byte directly, just with a word, so if you use u8, it means the processor will read a word and then do a mask, making it less efficient (and sometimes making the code bigger if done by the compiler). Another thing that just occurred to me, instead of adding those fields in vimc_frame, what do you think of having just: struct vimc_frame { struct v4l2_format fmt; u8 *plane_addr[TPG_MAX_PLANES]; }; So you wouldn't need the vimc_fil_frame. You could also just work with multiplanar, and convert to single planar in the capture: struct vimc_frame { struct v4l2_pix_format_mplane fmt; u8 *plane_addr[TPG_MAX_PLANES]; }; So the subdevices can just work with multiplanar (they doesn't need to know how to deal with single planar, just multiplanar with num_plane=1), and the capture can make the conversion if required. Helen > +}; > + > /** > * struct vimc_ent_device - core struct that represents a node in the topology > * > @@ -101,10 +127,10 @@ struct vimc_ent_device { > struct media_entity *ent; > struct media_pad *pads; > struct vimc_stream *stream; > - void * (*process_frame)(struct vimc_ent_device *ved, > - const void *frame); > + struct vimc_frame * (*process_frame)(struct vimc_ent_device *ved, > + const struct vimc_frame *frame); > void (*vdev_get_format)(struct vimc_ent_device *ved, > - struct v4l2_pix_format *fmt); > + struct v4l2_pix_format *fmt); > }; > > /** > @@ -206,4 +232,21 @@ void vimc_ent_sd_unregister(struct vimc_ent_device *ved, > */ > int vimc_link_validate(struct media_link *link); > > +/** > + * vimc_fill_frame - fills struct vimc_frame > + * > + * @frame: pointer to the frame to be filled > + * @pixelformat: pixelformat fourcc code > + * @width: width of the image > + * @height: height of the image > + * @multiplanar: flag to define if the stream is in singleplanar/multiplanar > + * mode > + * > + * This function fills the fields of vimc_frame in order to subdevs have > + * information about the frame being processed, works both for single > + * and multiplanar pixel formats. > + */ > +void vimc_fill_frame(struct vimc_frame *frame, u32 pixelformat, u32 width, > + u32 height, bool multiplanar); > + > #endif > diff --git a/drivers/media/platform/vimc/vimc-debayer.c b/drivers/media/platform/vimc/vimc-debayer.c > index 613b7abbe06e..c2fb1fab7fe9 100644 > --- a/drivers/media/platform/vimc/vimc-debayer.c > +++ b/drivers/media/platform/vimc/vimc-debayer.c > @@ -62,7 +62,7 @@ struct vimc_deb_device { > void (*set_rgb_src)(struct vimc_deb_device *vdeb, unsigned int lin, > unsigned int col, unsigned int rgb[3]); > /* Values calculated when the stream starts */ > - u8 *src_frame; > + struct vimc_frame src_frame; > const struct vimc_deb_pix_map *sink_pix_map; > unsigned int sink_bpp; > }; > @@ -325,7 +325,7 @@ static void vimc_deb_set_rgb_pix_rgb24(struct vimc_deb_device *vdeb, > > index = VIMC_FRAME_INDEX(lin, col, vdeb->sink_fmt.width, 3); > for (i = 0; i < 3; i++) > - vdeb->src_frame[index + i] = rgb[i]; > + vdeb->src_frame.plane_addr[0][index + i] = rgb[i]; > } > > static int vimc_deb_s_stream(struct v4l2_subdev *sd, int enable) > @@ -335,7 +335,6 @@ static int vimc_deb_s_stream(struct v4l2_subdev *sd, int enable) > if (enable) { > u32 src_pixelformat = vdeb->ved.stream->producer_pixfmt; > const struct v4l2_format_info *pix_info; > - unsigned int frame_size; > > /* We only support translating bayer to RGB24 */ > if (src_pixelformat != V4L2_PIX_FMT_RGB24) { > @@ -354,9 +353,9 @@ static int vimc_deb_s_stream(struct v4l2_subdev *sd, int enable) > vdeb->sink_pix_map->pixelformat; > > /* Calculate frame_size of the source */ > - pix_info = v4l2_format_info(src_pixelformat); > - frame_size = vdeb->sink_fmt.width * vdeb->sink_fmt.height * > - pix_info->bpp[0]; > + vimc_fill_frame(&vdeb->src_frame, src_pixelformat, > + vdeb->sink_fmt.width, vdeb->sink_fmt.height, > + vdeb->ved.stream->producer_pixfmt); > > /* Get bpp from the sink */ > pix_info = v4l2_format_info(vdeb->sink_pix_map->pixelformat); > @@ -366,16 +365,18 @@ static int vimc_deb_s_stream(struct v4l2_subdev *sd, int enable) > * Allocate the frame buffer. Use vmalloc to be able to > * allocate a large amount of memory > */ > - vdeb->src_frame = vmalloc(frame_size); > - if (!vdeb->src_frame) > + vdeb->src_frame.plane_addr[0] = > + vmalloc(vdeb->src_frame.sizeimage[0]); > + if (!vdeb->src_frame.plane_addr[0]) > return -ENOMEM; > > + > } else { > - if (!vdeb->src_frame) > + if (!vdeb->src_frame.plane_addr[0]) > return 0; > > - vfree(vdeb->src_frame); > - vdeb->src_frame = NULL; > + vfree(vdeb->src_frame.plane_addr[0]); > + vdeb->src_frame.plane_addr[0] = NULL; > } > > return 0; > @@ -487,8 +488,8 @@ static void vimc_deb_calc_rgb_sink(struct vimc_deb_device *vdeb, > } > } > > -static void *vimc_deb_process_frame(struct vimc_ent_device *ved, > - const void *sink_frame) > +static struct vimc_frame *vimc_deb_process_frame(struct vimc_ent_device *ved, > + const struct vimc_frame *sink_frame) > { > struct vimc_deb_device *vdeb = container_of(ved, struct vimc_deb_device, > ved); > @@ -496,16 +497,17 @@ static void *vimc_deb_process_frame(struct vimc_ent_device *ved, > unsigned int i, j; > > /* If the stream in this node is not active, just return */ > - if (!vdeb->src_frame) > + if (!vdeb->src_frame.plane_addr[0]) > return ERR_PTR(-EINVAL); > > for (i = 0; i < vdeb->sink_fmt.height; i++) > for (j = 0; j < vdeb->sink_fmt.width; j++) { > - vimc_deb_calc_rgb_sink(vdeb, sink_frame, i, j, rgb); > + vimc_deb_calc_rgb_sink(vdeb, sink_frame->plane_addr[0], > + i, j, rgb); > vdeb->set_rgb_src(vdeb, i, j, rgb); > } > > - return vdeb->src_frame; > + return &vdeb->src_frame; > > } > > diff --git a/drivers/media/platform/vimc/vimc-scaler.c b/drivers/media/platform/vimc/vimc-scaler.c > index 8544c745c6e6..92c639f1817e 100644 > --- a/drivers/media/platform/vimc/vimc-scaler.c > +++ b/drivers/media/platform/vimc/vimc-scaler.c > @@ -50,7 +50,7 @@ struct vimc_sca_device { > */ > struct v4l2_mbus_framefmt sink_fmt; > /* Values calculated when the stream starts */ > - u8 *src_frame; > + struct vimc_frame src_frame; > unsigned int src_line_size; > unsigned int bpp; > }; > @@ -234,16 +234,17 @@ static int vimc_sca_s_stream(struct v4l2_subdev *sd, int enable) > /* Allocate the frame buffer. Use vmalloc to be able to > * allocate a large amount of memory > */ > - vsca->src_frame = vmalloc(frame_size); > - if (!vsca->src_frame) > + vsca->src_frame.plane_addr[0] = vmalloc(frame_size); > + vsca->src_frame.sizeimage[0] = frame_size; > + if (!vsca->src_frame.plane_addr[0]) > return -ENOMEM; > > } else { > - if (!vsca->src_frame) > + if (!vsca->src_frame.plane_addr[0]) > return 0; > > - vfree(vsca->src_frame); > - vsca->src_frame = NULL; > + vfree(vsca->src_frame.plane_addr[0]); > + vsca->src_frame.plane_addr[0] = NULL; > } > > return 0; > @@ -306,8 +307,9 @@ static void vimc_sca_scale_pix(const struct vimc_sca_device *const vsca, > vsca->sd.name, index + j); > > /* copy the pixel to the position index + j */ > - vimc_sca_fill_pix(&vsca->src_frame[index + j], > - pixel, vsca->bpp); > + vimc_sca_fill_pix( > + &vsca->src_frame.plane_addr[0][index + j], > + pixel, vsca->bpp); > } > > /* move the index to the next line */ > @@ -327,8 +329,8 @@ static void vimc_sca_fill_src_frame(const struct vimc_sca_device *const vsca, > vimc_sca_scale_pix(vsca, i, j, sink_frame); > } > > -static void *vimc_sca_process_frame(struct vimc_ent_device *ved, > - const void *sink_frame) > +static struct vimc_frame *vimc_sca_process_frame(struct vimc_ent_device *ved, > + const struct vimc_frame *sink_frame) > { > struct vimc_sca_device *vsca = container_of(ved, struct vimc_sca_device, > ved); > @@ -337,9 +339,9 @@ static void *vimc_sca_process_frame(struct vimc_ent_device *ved, > if (!ved->stream) > return ERR_PTR(-EINVAL); > > - vimc_sca_fill_src_frame(vsca, sink_frame); > + vimc_sca_fill_src_frame(vsca, sink_frame->plane_addr[0]); > > - return vsca->src_frame; > + return &vsca->src_frame; > }; > > static void vimc_sca_release(struct v4l2_subdev *sd) > diff --git a/drivers/media/platform/vimc/vimc-sensor.c b/drivers/media/platform/vimc/vimc-sensor.c > index 1b2b75b27952..3495a3f3dd60 100644 > --- a/drivers/media/platform/vimc/vimc-sensor.c > +++ b/drivers/media/platform/vimc/vimc-sensor.c > @@ -36,7 +36,7 @@ struct vimc_sen_device { > struct device *dev; > struct tpg_data tpg; > struct task_struct *kthread_sen; > - u8 *frame; > + struct vimc_frame frame; > /* The active format */ > struct v4l2_mbus_framefmt mbus_format; > struct v4l2_ctrl_handler hdl; > @@ -177,14 +177,14 @@ static const struct v4l2_subdev_pad_ops vimc_sen_pad_ops = { > .set_fmt = vimc_sen_set_fmt, > }; > > -static void *vimc_sen_process_frame(struct vimc_ent_device *ved, > - const void *sink_frame) > +static struct vimc_frame *vimc_sen_process_frame(struct vimc_ent_device *ved, > + const struct vimc_frame *sink_frame) > { > struct vimc_sen_device *vsen = container_of(ved, struct vimc_sen_device, > ved); > > - tpg_fill_plane_buffer(&vsen->tpg, 0, 0, vsen->frame); > - return vsen->frame; > + tpg_fill_plane_buffer(&vsen->tpg, 0, 0, vsen->frame.plane_addr[0]); > + return &vsen->frame; > } > > static int vimc_sen_s_stream(struct v4l2_subdev *sd, int enable) > @@ -206,8 +206,8 @@ static int vimc_sen_s_stream(struct v4l2_subdev *sd, int enable) > * Allocate the frame buffer. Use vmalloc to be able to > * allocate a large amount of memory > */ > - vsen->frame = vmalloc(frame_size); > - if (!vsen->frame) > + vsen->frame.plane_addr[0] = vmalloc(frame_size); > + if (!vsen->frame.plane_addr[0]) > return -ENOMEM; > > /* configure the test pattern generator */ > @@ -215,8 +215,8 @@ static int vimc_sen_s_stream(struct v4l2_subdev *sd, int enable) > > } else { > > - vfree(vsen->frame); > - vsen->frame = NULL; > + vfree(vsen->frame.plane_addr[0]); > + vsen->frame.plane_addr[0] = NULL; > return 0; > } > > diff --git a/drivers/media/platform/vimc/vimc-streamer.c b/drivers/media/platform/vimc/vimc-streamer.c > index 26b674259489..216ac8a83ba5 100644 > --- a/drivers/media/platform/vimc/vimc-streamer.c > +++ b/drivers/media/platform/vimc/vimc-streamer.c > @@ -125,7 +125,7 @@ static int vimc_streamer_pipeline_init(struct vimc_stream *stream, > static int vimc_streamer_thread(void *data) > { > struct vimc_stream *stream = data; > - u8 *frame = NULL; > + struct vimc_frame *frame = NULL; > int i; > > set_freezable(); >