public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: "Wu, Songjun" <Songjun.Wu@microchip.com>
To: Hans Verkuil <hverkuil@xs4all.nl>, <nicolas.ferre@atmel.com>,
	<robh@kernel.org>
Cc: laurent.pinchart@ideasonboard.com,
	linux-arm-kernel@lists.infradead.org,
	linux-media@vger.kernel.org, "Arnd Bergmann" <arnd@arndb.de>,
	"Niklas Söderlund" <niklas.soderlund+renesas@ragnatech.se>,
	"Benoit Parrot" <bparrot@ti.com>,
	linux-kernel@vger.kernel.org,
	"Andrew-CT Chen" <andrew-ct.chen@mediatek.com>,
	"Sudip Mukherjee" <sudipm.mukherjee@gmail.com>,
	"Kamil Debski" <kamil@wypas.org>,
	"Tiffany Lin" <tiffany.lin@mediatek.com>,
	"Peter Griffin" <peter.griffin@linaro.org>,
	"Geert Uytterhoeven" <geert@linux-m68k.org>,
	"Mikhail Ulyanov" <mikhail.ulyanov@cogentembedded.com>,
	"Richard Röjfors" <richard@puffinpack.se>,
	"Hans Verkuil" <hans.verkuil@cisco.com>,
	"Laurent Pinchart" <laurent.pinchart+renesas@ideasonboard.com>,
	"Simon Horman" <horms+renesas@verge.net.au>
Subject: Re: [PATCH v8 1/2] [media] atmel-isc: add the Image Sensor Controller code
Date: Wed, 10 Aug 2016 15:14:43 +0800	[thread overview]
Message-ID: <24516b2e-e165-da81-cd2c-600c35b31f69@microchip.com> (raw)
In-Reply-To: <85f42659-d54f-a841-fa7c-7fc7d6ddb96b@xs4all.nl>



On 8/10/2016 15:12, Hans Verkuil wrote:
> On 08/10/2016 07:36 AM, Wu, Songjun wrote:
>>
>>
>> On 8/8/2016 17:56, Hans Verkuil wrote:
>>> On 08/08/2016 11:37 AM, Hans Verkuil wrote:
>>>> On 08/03/2016 10:08 AM, Songjun Wu wrote:
>>>>> Add driver for the Image Sensor Controller. It manages
>>>>> incoming data from a parallel based CMOS/CCD sensor.
>>>>> It has an internal image processor, also integrates a
>>>>> triple channel direct memory access controller master
>>>>> interface.
>>>>>
>>>>> Signed-off-by: Songjun Wu <songjun.wu@microchip.com>
>>>>> ---
>>>>>
>>>>> Changes in v8:
>>>>> - Power on the sensor on the first open in function
>>>>>   'isc_open'.
>>>>> - Power off the sensor on the last release in function
>>>>>   'isc_release'.
>>>>> - Remove the switch of the pipeline.
>>>>>
>>>>> Changes in v7:
>>>>> - Add enum_framesizes and enum_frameintervals.
>>>>> - Call s_stream(0) when stream start fail.
>>>>> - Fill the device_caps field of struct video_device
>>>>>   with V4L2_CAP_STREAMING and V4L2_CAP_VIDEO_CAPTURE.
>>>>> - Initialize the dev of struct vb2_queue.
>>>>> - Set field to FIELD_NONE if the pix field is not supported.
>>>>> - Return the result directly when call g/s_parm of subdev.
>>>>>
>>>>> Changes in v6: None
>>>>> Changes in v5:
>>>>> - Modify the macro definition and the related code.
>>>>>
>>>>> Changes in v4:
>>>>> - Modify the isc clock code since the dt is changed.
>>>>>
>>>>> Changes in v3:
>>>>> - Add pm runtime feature.
>>>>> - Modify the isc clock code since the dt is changed.
>>>>>
>>>>> Changes in v2:
>>>>> - Add "depends on COMMON_CLK" and "VIDEO_V4L2_SUBDEV_API"
>>>>>   in Kconfig file.
>>>>> - Correct typos and coding style according to Laurent's remarks
>>>>> - Delete the loop while in 'isc_clk_enable' function.
>>>>> - Replace 'hsync_active', 'vsync_active' and 'pclk_sample'
>>>>>   with 'pfe_cfg0' in struct isc_subdev_entity.
>>>>> - Add the code to support VIDIOC_CREATE_BUFS in
>>>>>   'isc_queue_setup' function.
>>>>> - Invoke isc_config to configure register in
>>>>>   'isc_start_streaming' function.
>>>>> - Add the struct completion 'comp' to synchronize with
>>>>>   the frame end interrupt in 'isc_stop_streaming' function.
>>>>> - Check the return value of the clk_prepare_enable
>>>>>   in 'isc_open' function.
>>>>> - Set the default format in 'isc_open' function.
>>>>> - Add an exit condition in the loop while in 'isc_config'.
>>>>> - Delete the hardware setup operation in 'isc_set_format'.
>>>>> - Refuse format modification during streaming
>>>>>   in 'isc_s_fmt_vid_cap' function.
>>>>> - Invoke v4l2_subdev_alloc_pad_config to allocate and
>>>>>   initialize the pad config in 'isc_async_complete' function.
>>>>> - Remove the '.owner  = THIS_MODULE,' in atmel_isc_driver.
>>>>> - Replace the module_platform_driver_probe() with
>>>>>   module_platform_driver().
>>>>>
>>>>>  drivers/media/platform/Kconfig                |    1 +
>>>>>  drivers/media/platform/Makefile               |    2 +
>>>>>  drivers/media/platform/atmel/Kconfig          |    9 +
>>>>>  drivers/media/platform/atmel/Makefile         |    1 +
>>>>>  drivers/media/platform/atmel/atmel-isc-regs.h |  165 +++
>>>>>  drivers/media/platform/atmel/atmel-isc.c      | 1503 +++++++++++++++++++++++++
>>>>>  6 files changed, 1681 insertions(+)
>>>>>  create mode 100644 drivers/media/platform/atmel/Kconfig
>>>>>  create mode 100644 drivers/media/platform/atmel/Makefile
>>>>>  create mode 100644 drivers/media/platform/atmel/atmel-isc-regs.h
>>>>>  create mode 100644 drivers/media/platform/atmel/atmel-isc.c
>>>>>
>>>>
>>>> <snip>
>>>>
>>>>> diff --git a/drivers/media/platform/atmel/atmel-isc.c b/drivers/media/platform/atmel/atmel-isc.c
>>>>> new file mode 100644
>>>>> index 0000000..d99d4a5
>>>>> --- /dev/null
>>>>> +++ b/drivers/media/platform/atmel/atmel-isc.c
>>>>
>>>> <snip>
>>>>
>>>>> +static int isc_set_default_fmt(struct isc_device *isc)
>>>>> +{
>>>>> +	u32 index = isc->num_user_formats - 1;
>>>>
>>>> Why pick the last format? Strictly speaking it doesn't matter, but in practice
>>>> the most common formats tend to be at the beginning of the format list.
>>>>
>>>>> +	struct v4l2_format f = {
>>>>> +		.type = V4L2_BUF_TYPE_VIDEO_CAPTURE,
>>>>> +		.fmt.pix = {
>>>>> +			.width		= VGA_WIDTH,
>>>>> +			.height		= VGA_HEIGHT,
>>>>> +			.field		= V4L2_FIELD_NONE,
>>>>> +			.pixelformat	= isc->user_formats[index]->fourcc,
>>>>> +		},
>>>>> +	};
>>>>> +
>>>>> +	return isc_set_fmt(isc, &f);
>>>>> +}
>>>>> +
>>>>> +static int isc_open(struct file *file)
>>>>> +{
>>>>> +	struct isc_device *isc = video_drvdata(file);
>>>>> +	struct v4l2_subdev *sd = isc->current_subdev->sd;
>>>>> +	int ret;
>>>>> +
>>>>> +	if (mutex_lock_interruptible(&isc->lock))
>>>>> +		return -ERESTARTSYS;
>>>>> +
>>>>> +	ret = v4l2_fh_open(file);
>>>>> +	if (ret < 0)
>>>>> +		goto unlock;
>>>>> +
>>>>> +	if (!v4l2_fh_is_singular_file(file))
>>>>> +		goto unlock;
>>>>> +
>>>>> +	ret = v4l2_subdev_call(sd, core, s_power, 1);
>>>>> +	if (ret < 0 && ret != -ENOIOCTLCMD)
>>>>> +		goto unlock;
>>>>> +
>>>>> +	ret = isc_set_default_fmt(isc);
>>>>
>>>> This doesn't belong here, this needs to be done in isc_async_complete().
>>>>
>>>> Having the code here means that every time you open the device, the format
>>>> changes back to the default. That's not what you want.
>>>
>>> Actually, you do need to set the format here since here is where you turn on
>>> the sensor power, but it should be the current format, not the default format.
>>>
>>> And in isc_set_default_fmt I recommend that you call the try fmt of the subdev
>>> in order to let the subdev adjust the proposed default format. The 'try' doesn't
>>> need to power on the sensor.
>>>
>> I replace the 'set fmt' with 'try fmt', then test with v4l2-compliance,
>> but there are tree fail cases. I think it's reasonable that setting a
>> default fmt on the first open. When app open the device on the first
>> open, it should set a fmt, or the default fmt will be set.
>
> It's not reasonable :-). In V4L2 all format (or any other for that matter) settings
> are persistent.
>
> Anyway, take a look at my atmel-isi driver:
>
> https://git.linuxtv.org/hverkuil/media_tree.git/tree/drivers/media/platform/atmel-isi.c?h=sama5d3
>
> There I use try_fmt as well, and that passes the compliance test just fine.
>
Thank you, I will try again.

> Regards,
>
> 	Hans
>

  reply	other threads:[~2016-08-10 18:01 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-08-03  8:08 [PATCH v8 0/2] [media] atmel-isc: add driver for Atmel ISC Songjun Wu
2016-08-03  8:08 ` [PATCH v8 1/2] [media] atmel-isc: add the Image Sensor Controller code Songjun Wu
2016-08-08  9:37   ` Hans Verkuil
2016-08-08  9:56     ` Hans Verkuil
2016-08-08 10:11       ` Wu, Songjun
2016-08-10  5:36       ` Wu, Songjun
2016-08-10  7:12         ` Hans Verkuil
2016-08-10  7:14           ` Wu, Songjun [this message]
2016-08-08 10:02     ` Wu, Songjun
2016-08-03  8:08 ` [PATCH v8 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver Songjun Wu

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=24516b2e-e165-da81-cd2c-600c35b31f69@microchip.com \
    --to=songjun.wu@microchip.com \
    --cc=andrew-ct.chen@mediatek.com \
    --cc=arnd@arndb.de \
    --cc=bparrot@ti.com \
    --cc=geert@linux-m68k.org \
    --cc=hans.verkuil@cisco.com \
    --cc=horms+renesas@verge.net.au \
    --cc=hverkuil@xs4all.nl \
    --cc=kamil@wypas.org \
    --cc=laurent.pinchart+renesas@ideasonboard.com \
    --cc=laurent.pinchart@ideasonboard.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    --cc=mikhail.ulyanov@cogentembedded.com \
    --cc=nicolas.ferre@atmel.com \
    --cc=niklas.soderlund+renesas@ragnatech.se \
    --cc=peter.griffin@linaro.org \
    --cc=richard@puffinpack.se \
    --cc=robh@kernel.org \
    --cc=sudipm.mukherjee@gmail.com \
    --cc=tiffany.lin@mediatek.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox