All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jacopo Mondi <jacopo@jmondi.org>
To: Adam Ford <aford173@gmail.com>
Cc: Laurent Pinchart <laurent.pinchart@ideasonboard.com>,
	Steve Longerbeam <slongerbeam@gmail.com>,
	Sakari Ailus <sakari.ailus@iki.fi>,
	Hans Verkuil <hverkuil-cisco@xs4all.nl>,
	mirela.rabulea@nxp.com, xavier.roumegue@oss.nxp.com,
	tomi.valkeinen@ideasonboard.com, hugues.fruchet@st.com,
	Prabhakar Mahadev Lad <prabhakar.mahadev-lad.rj@bp.renesas.com>,
	Fabio Estevam <festevam@gmail.com>,
	Eugen Hristev <Eugen.Hristev@microchip.com>,
	Jerome Brunet <jbrunet@baylibre.com>,
	Mauro Carvalho Chehab <mchehab@kernel.org>,
	linux-media <linux-media@vger.kernel.org>
Subject: Re: [PATCH v2 01/23] media: ov5640: Add pixel rate to modes
Date: Tue, 22 Feb 2022 08:48:06 +0100	[thread overview]
Message-ID: <20220222074806.xlnjct7k5f2p565m@uno.localdomain> (raw)
In-Reply-To: <CAHCN7xLQwrHE=8=qOnPTv6S=wPwz2_Hofe3pq7VT_Lqj94Jfvw@mail.gmail.com>

Hi Adam,

On Mon, Feb 21, 2022 at 02:14:43PM -0600, Adam Ford wrote:
> On Sun, Feb 20, 2022 at 5:53 AM Laurent Pinchart
> <laurent.pinchart@ideasonboard.com> wrote:
> >
> > Hi Jacopo,
> >
> > Thank you for the patch.
> >
> > On Thu, Feb 10, 2022 at 12:04:36PM +0100, Jacopo Mondi wrote:
> > > Add to each mode supported by the sensor the ideal pixel rate, as
> > > defined by Table 2.1 in the chip manual.
> > >
> > > The ideal pixel rate will be used to compute the MIPI CSI-2 clock tree.
> > >
>
> I tried this on my imx8mm at a variety of resolutions.  I don't have a
> functional display yet, so I couldn't test streaming to a screen, but
> I did capture images and encode them into an AVI. From what I can
> tell, the exposure seems to handle darker environments better now.

I noticed the same. Unfortunately I still have to clarify myself how
the auto-exposure target is handled, but yes I noticed the same.

> Maybe it's just a placebo effect.  If there are certain resolutions or
> formats you want me to test, let me know.
>
> Tested-by: Adam Ford <aford173@gmail.com> #imx8mm-beacon-kit
>

Thanks for testing. I was about to send a v3 yesterday but I found out
I need to update all my testing scripts first. There's RGB888 which
has weird colors here, and I never tested JPEG. Do you happen to know
if it's working with this driver ?

Thanks!
   j

> > > Signed-off-by: Jacopo Mondi <jacopo@jmondi.org>
> >
> > Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> >
> > > ---
> > >  drivers/media/i2c/ov5640.c | 44 +++++++++++++++++++++++++++++++++++---
> > >  1 file changed, 41 insertions(+), 3 deletions(-)
> > >
> > > diff --git a/drivers/media/i2c/ov5640.c b/drivers/media/i2c/ov5640.c
> > > index db5a19babe67..01f4a075f86e 100644
> > > --- a/drivers/media/i2c/ov5640.c
> > > +++ b/drivers/media/i2c/ov5640.c
> > > @@ -118,6 +118,29 @@ enum ov5640_frame_rate {
> > >       OV5640_NUM_FRAMERATES,
> > >  };
> > >
> > > +enum ov5640_pixel_rate_id {
> > > +     OV5640_PIXEL_RATE_168M,
> > > +     OV5640_PIXEL_RATE_148M,
> > > +     OV5640_PIXEL_RATE_124M,
> > > +     OV5640_PIXEL_RATE_96M,
> > > +     OV5640_PIXEL_RATE_48M,
> > > +     OV5640_NUM_PIXEL_RATES,
> > > +};
> > > +
> > > +/*
> > > + * The chip manual suggests 24/48/96/192 MHz pixel clocks.
> > > + *
> > > + * 192MHz exceeds the sysclk limits; use 168MHz as maximum pixel rate for
> > > + * full resolution mode @15 FPS.
> > > + */
> > > +static const u32 ov5640_pixel_rates[] = {
> > > +     [OV5640_PIXEL_RATE_168M] = 168000000,
> > > +     [OV5640_PIXEL_RATE_148M] = 148000000,
> > > +     [OV5640_PIXEL_RATE_124M] = 124000000,
> > > +     [OV5640_PIXEL_RATE_96M] = 96000000,
> > > +     [OV5640_PIXEL_RATE_48M] = 48000000,
> > > +};
> > > +
> > >  enum ov5640_format_mux {
> > >       OV5640_FMT_MUX_YUV422 = 0,
> > >       OV5640_FMT_MUX_RGB,
> > > @@ -189,6 +212,7 @@ struct reg_value {
> > >  struct ov5640_mode_info {
> > >       enum ov5640_mode_id id;
> > >       enum ov5640_downsize_mode dn_mode;
> > > +     enum ov5640_pixel_rate_id pixel_rate;
> > >       u32 hact;
> > >       u32 htot;
> > >       u32 vact;
> > > @@ -565,7 +589,9 @@ static const struct reg_value ov5640_setting_QSXGA_2592_1944[] = {
> > >
> > >  /* power-on sensor init reg table */
> > >  static const struct ov5640_mode_info ov5640_mode_init_data = {
> > > -     0, SUBSAMPLING, 640, 1896, 480, 984,
> > > +     0, SUBSAMPLING,
> > > +     OV5640_PIXEL_RATE_96M,
> > > +     640, 1896, 480, 984,
> > >       ov5640_init_setting_30fps_VGA,
> > >       ARRAY_SIZE(ov5640_init_setting_30fps_VGA),
> > >       OV5640_30_FPS,
> > > @@ -574,51 +600,61 @@ static const struct ov5640_mode_info ov5640_mode_init_data = {
> > >  static const struct ov5640_mode_info
> > >  ov5640_mode_data[OV5640_NUM_MODES] = {
> > >       {OV5640_MODE_QQVGA_160_120, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_48M,
> > >        160, 1896, 120, 984,
> > >        ov5640_setting_QQVGA_160_120,
> > >        ARRAY_SIZE(ov5640_setting_QQVGA_160_120),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_QCIF_176_144, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_48M,
> > >        176, 1896, 144, 984,
> > >        ov5640_setting_QCIF_176_144,
> > >        ARRAY_SIZE(ov5640_setting_QCIF_176_144),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_QVGA_320_240, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_48M,
> > >        320, 1896, 240, 984,
> > >        ov5640_setting_QVGA_320_240,
> > >        ARRAY_SIZE(ov5640_setting_QVGA_320_240),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_VGA_640_480, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_48M,
> > >        640, 1896, 480, 1080,
> > >        ov5640_setting_VGA_640_480,
> > >        ARRAY_SIZE(ov5640_setting_VGA_640_480),
> > >        OV5640_60_FPS},
> > >       {OV5640_MODE_NTSC_720_480, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_96M,
> > >        720, 1896, 480, 984,
> > >        ov5640_setting_NTSC_720_480,
> > >        ARRAY_SIZE(ov5640_setting_NTSC_720_480),
> > >       OV5640_30_FPS},
> > >       {OV5640_MODE_PAL_720_576, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_96M,
> > >        720, 1896, 576, 984,
> > >        ov5640_setting_PAL_720_576,
> > >        ARRAY_SIZE(ov5640_setting_PAL_720_576),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_XGA_1024_768, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_96M,
> > >        1024, 1896, 768, 1080,
> > >        ov5640_setting_XGA_1024_768,
> > >        ARRAY_SIZE(ov5640_setting_XGA_1024_768),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_720P_1280_720, SUBSAMPLING,
> > > +      OV5640_PIXEL_RATE_124M,
> > >        1280, 1892, 720, 740,
> > >        ov5640_setting_720P_1280_720,
> > >        ARRAY_SIZE(ov5640_setting_720P_1280_720),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_1080P_1920_1080, SCALING,
> > > +      OV5640_PIXEL_RATE_148M,
> > >        1920, 2500, 1080, 1120,
> > >        ov5640_setting_1080P_1920_1080,
> > >        ARRAY_SIZE(ov5640_setting_1080P_1920_1080),
> > >        OV5640_30_FPS},
> > >       {OV5640_MODE_QSXGA_2592_1944, SCALING,
> > > +      OV5640_PIXEL_RATE_168M,
> > >        2592, 2844, 1944, 1968,
> > >        ov5640_setting_QSXGA_2592_1944,
> > >        ARRAY_SIZE(ov5640_setting_QSXGA_2592_1944),
> > > @@ -2743,6 +2779,7 @@ static const struct v4l2_ctrl_ops ov5640_ctrl_ops = {
> > >
> > >  static int ov5640_init_controls(struct ov5640_dev *sensor)
> > >  {
> > > +     const struct ov5640_mode_info *mode = sensor->current_mode;
> > >       const struct v4l2_ctrl_ops *ops = &ov5640_ctrl_ops;
> > >       struct ov5640_ctrls *ctrls = &sensor->ctrls;
> > >       struct v4l2_ctrl_handler *hdl = &ctrls->handler;
> > > @@ -2755,8 +2792,9 @@ static int ov5640_init_controls(struct ov5640_dev *sensor)
> > >
> > >       /* Clock related controls */
> > >       ctrls->pixel_rate = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_PIXEL_RATE,
> > > -                                           0, INT_MAX, 1,
> > > -                                           ov5640_calc_pixel_rate(sensor));
> > > +                                   ov5640_pixel_rates[OV5640_NUM_PIXEL_RATES - 1],
> > > +                                   ov5640_pixel_rates[0], 1,
> > > +                                   ov5640_pixel_rates[mode->pixel_rate]);
> > >
> > >       /* Auto/manual white balance */
> > >       ctrls->auto_wb = v4l2_ctrl_new_std(hdl, ops,
> >
> > --
> > Regards,
> >
> > Laurent Pinchart

  reply	other threads:[~2022-02-22  7:48 UTC|newest]

Thread overview: 64+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-02-10 11:04 [PATCH v2 00/23] media: ov5640: Rework the clock tree programming for MIPI Jacopo Mondi
2022-02-10 11:04 ` [PATCH v2 01/23] media: ov5640: Add pixel rate to modes Jacopo Mondi
2022-02-20 11:53   ` Laurent Pinchart
2022-02-21 20:14     ` Adam Ford
2022-02-22  7:48       ` Jacopo Mondi [this message]
2022-02-22 19:08         ` Adam Ford
2022-02-10 11:04 ` [PATCH v2 02/23] media: ov5604: Re-arrange modes definition Jacopo Mondi
2022-02-10 11:04 ` [PATCH v2 03/23] media: ov5640: Add ov5640_is_csi2() function Jacopo Mondi
2022-02-10 11:04 ` [PATCH v2 04/23] media: ov5640: Associate bpp with formats Jacopo Mondi
2022-02-10 11:04 ` [PATCH v2 05/23] media: ov5640: Add LINK_FREQ control Jacopo Mondi
2022-02-20 11:55   ` Laurent Pinchart
2022-02-10 11:04 ` [PATCH v2 06/23] media: ov5640: Update pixel_rate and link_freq Jacopo Mondi
2022-02-10 11:04 ` [PATCH v2 07/23] media: ov5640: Rework CSI-2 clock tree Jacopo Mondi
2022-02-20 12:17   ` Laurent Pinchart
2022-02-21 11:39     ` Jacopo Mondi
2022-02-21 12:12       ` Laurent Pinchart
2022-02-10 11:04 ` [PATCH v2 08/23] media: ov5640: Rework timings programming Jacopo Mondi
2022-02-20 12:44   ` Laurent Pinchart
2022-02-10 11:04 ` [PATCH v2 09/23] media: ov5640: Fix 720x480 in RGB888 mode Jacopo Mondi
2022-02-20 12:50   ` Laurent Pinchart
2022-02-10 11:04 ` [PATCH v2 10/23] media: ov5640: Rework analog crop rectangles Jacopo Mondi
2022-02-11  9:34   ` [v2.1] " Jacopo Mondi
2022-02-20 12:56     ` Laurent Pinchart
2022-02-10 11:04 ` [PATCH v2 11/23] media: ov5640: Re-sort per-mode register tables Jacopo Mondi
2022-02-20 12:52   ` Laurent Pinchart
2022-02-20 12:59     ` Laurent Pinchart
2022-02-10 11:04 ` [PATCH v2 12/23] media: ov5640: Remove ov5640_mode_init_data Jacopo Mondi
2022-02-20 12:58   ` Laurent Pinchart
2022-02-10 11:09 ` [PATCH v2 13/23] media: ov5640: Add HBLANK control Jacopo Mondi
2022-02-10 11:09 ` [PATCH v2 14/23] media: ov5640: Add VBLANK control Jacopo Mondi
2022-02-20 13:01   ` Laurent Pinchart
2022-02-10 11:10 ` [PATCH v2 15/23] media: ov5640: Fix durations to comply with FPS Jacopo Mondi
2022-02-20 13:03   ` Laurent Pinchart
2022-02-10 11:10 ` [PATCH v2 16/23] media: ov5640: Implement init_cfg Jacopo Mondi
2022-02-10 11:10 ` [PATCH v2 17/23] media: ov5640: Implement get_selection Jacopo Mondi
2022-02-20 13:06   ` Laurent Pinchart
2022-02-10 11:10 ` [PATCH v2 18/23] media: ov5640: Limit frame_interval to DVP mode only Jacopo Mondi
2022-02-10 11:10 ` [PATCH v2 19/23] media: ov5640: Register device properties Jacopo Mondi
2022-02-10 11:10 ` [PATCH v2 20/23] media: ov5640: Add RGB565_1X16 format Jacopo Mondi
2022-02-20 13:07   ` Laurent Pinchart
2022-02-10 11:10 ` [PATCH v2 21/23] media: ov5640: Add RGB888/BGR888 formats Jacopo Mondi
2022-02-20 13:13   ` Laurent Pinchart
2022-02-10 11:10 ` [PATCH v2 22/23] media: ov5640: Restrict sizes to mbus code Jacopo Mondi
2022-02-20 13:16   ` Laurent Pinchart
2022-02-21 12:42     ` Jacopo Mondi
2022-02-10 11:10 ` [PATCH v2 23/23] media: ov5640: Adjust format to bpp in s_fmt Jacopo Mondi
2022-02-10 12:03 ` [PATCH v2 00/23] media: ov5640: Rework the clock tree programming for MIPI Tomi Valkeinen
2022-02-10 12:10   ` Tomi Valkeinen
2022-02-10 13:00 ` Tomi Valkeinen
2022-02-10 17:11   ` Jacopo Mondi
2022-02-11  7:55     ` Tomi Valkeinen
2022-02-11  8:01       ` Tomi Valkeinen
2022-02-11  9:36   ` Jacopo Mondi
2022-02-11 10:09 ` Eugen.Hristev
2022-02-11 11:25   ` Jacopo Mondi
2022-02-14 14:06     ` Eugen.Hristev
2022-02-14 14:38       ` Jacopo Mondi
2022-02-14 15:08         ` Eugen.Hristev
2022-02-14 18:56           ` Jacopo Mondi
2022-02-17 14:25             ` Eugen.Hristev
2022-02-21  8:51               ` Jacopo Mondi
2022-02-21  9:04                 ` Eugen.Hristev
2022-02-21 11:18                   ` Jacopo Mondi
2022-02-21 13:31                   ` Jacopo Mondi

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=20220222074806.xlnjct7k5f2p565m@uno.localdomain \
    --to=jacopo@jmondi.org \
    --cc=Eugen.Hristev@microchip.com \
    --cc=aford173@gmail.com \
    --cc=festevam@gmail.com \
    --cc=hugues.fruchet@st.com \
    --cc=hverkuil-cisco@xs4all.nl \
    --cc=jbrunet@baylibre.com \
    --cc=laurent.pinchart@ideasonboard.com \
    --cc=linux-media@vger.kernel.org \
    --cc=mchehab@kernel.org \
    --cc=mirela.rabulea@nxp.com \
    --cc=prabhakar.mahadev-lad.rj@bp.renesas.com \
    --cc=sakari.ailus@iki.fi \
    --cc=slongerbeam@gmail.com \
    --cc=tomi.valkeinen@ideasonboard.com \
    --cc=xavier.roumegue@oss.nxp.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.