From: Alexander Stein <alexander.stein@ew.tq-group.com>
To: Manivannan Sadhasivam <mani@kernel.org>,
Mauro Carvalho Chehab <mchehab@kernel.org>,
Laurent Pinchart <laurent.pinchart@ideasonboard.com>,
linux-media@vger.kernel.org,
Dave Stevenson <dave.stevenson@raspberrypi.com>
Cc: Dave Stevenson <dave.stevenson@raspberrypi.com>
Subject: Re: [PATCH v2 06/13] media: i2c: imx290: Use CSI timings as per datasheet
Date: Mon, 06 Feb 2023 08:48:57 +0100 [thread overview]
Message-ID: <2669831.mvXUDI8C0e@steina-w> (raw)
In-Reply-To: <20230203191811.947697-7-dave.stevenson@raspberrypi.com>
Hi Dave,
thanks for the updated patch.
Am Freitag, 3. Februar 2023, 20:18:04 CET schrieb Dave Stevenson:
> Commit "98e0500eadb7 media: i2c: imx290: Add configurable link frequency
> and pixel rate" added support for the increased link frequencies
> on 2 data lanes, but didn't update the CSI timing registers in
> accordance with the datasheet.
>
> Use the specified settings.
>
> Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com>
> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> ---
> drivers/media/i2c/imx290.c | 126 +++++++++++++++++++++++++++++++------
> 1 file changed, 106 insertions(+), 20 deletions(-)
>
> diff --git a/drivers/media/i2c/imx290.c b/drivers/media/i2c/imx290.c
> index a5ea59353a4d..2abe4cdab819 100644
> --- a/drivers/media/i2c/imx290.c
> +++ b/drivers/media/i2c/imx290.c
> @@ -190,6 +190,18 @@ struct imx290_mode {
> u32 data_size;
> };
>
> +struct imx290_csi_cfg {
> + u16 repetition;
> + u16 tclkpost;
> + u16 thszero;
> + u16 thsprepare;
> + u16 tclktrail;
> + u16 thstrail;
> + u16 tclkzero;
> + u16 tclkprepare;
> + u16 tlpx;
> +};
> +
> struct imx290 {
> struct device *dev;
> struct clk *xclk;
> @@ -289,16 +301,6 @@ static const struct imx290_regval
> imx290_1080p_settings[] = { { IMX290_INCKSEL4, 0x01 },
> { IMX290_INCKSEL5, 0x1a },
> { IMX290_INCKSEL6, 0x1a },
> - /* data rate settings */
> - { IMX290_REPETITION, 0x10 },
> - { IMX290_TCLKPOST, 87 },
> - { IMX290_THSZERO, 55 },
> - { IMX290_THSPREPARE, 31 },
> - { IMX290_TCLKTRAIL, 31 },
> - { IMX290_THSTRAIL, 31 },
> - { IMX290_TCLKZERO, 119 },
> - { IMX290_TCLKPREPARE, 31 },
> - { IMX290_TLPX, 23 },
> };
>
> static const struct imx290_regval imx290_720p_settings[] = {
> @@ -314,16 +316,6 @@ static const struct imx290_regval
> imx290_720p_settings[] = { { IMX290_INCKSEL4, 0x01 },
> { IMX290_INCKSEL5, 0x1a },
> { IMX290_INCKSEL6, 0x1a },
> - /* data rate settings */
> - { IMX290_REPETITION, 0x10 },
> - { IMX290_TCLKPOST, 79 },
> - { IMX290_THSZERO, 47 },
> - { IMX290_THSPREPARE, 23 },
> - { IMX290_TCLKTRAIL, 23 },
> - { IMX290_THSTRAIL, 23 },
> - { IMX290_TCLKZERO, 87 },
> - { IMX290_TCLKPREPARE, 23 },
> - { IMX290_TLPX, 23 },
> };
>
> static const struct imx290_regval imx290_10bit_settings[] = {
> @@ -344,6 +336,58 @@ static const struct imx290_regval
> imx290_12bit_settings[] = { { IMX290_CSI_DT_FMT, IMX290_CSI_DT_FMT_RAW12 },
> };
>
> +static const struct imx290_csi_cfg imx290_csi_222_75mhz = {
> + /* 222.25MHz or 445.5Mbit/s per lane */
s/222.25/222.75/ ;-)
Despite that:
Reviewed-by: Alexander Stein <alexander.stein@ew.tq-group.com>
Best regards,
Alexander
> + .repetition = 0x10,
> + .tclkpost = 87,
> + .thszero = 55,
> + .thsprepare = 31,
> + .tclktrail = 31,
> + .thstrail = 31,
> + .tclkzero = 119,
> + .tclkprepare = 31,
> + .tlpx = 23,
> +};
> +
> +static const struct imx290_csi_cfg imx290_csi_445_5mhz = {
> + /* 445.5MHz or 891Mbit/s per lane */
> + .repetition = 0x00,
> + .tclkpost = 119,
> + .thszero = 103,
> + .thsprepare = 71,
> + .tclktrail = 55,
> + .thstrail = 63,
> + .tclkzero = 255,
> + .tclkprepare = 63,
> + .tlpx = 55,
> +};
> +
> +static const struct imx290_csi_cfg imx290_csi_148_5mhz = {
> + /* 148.5MHz or 297Mbit/s per lane */
> + .repetition = 0x10,
> + .tclkpost = 79,
> + .thszero = 47,
> + .thsprepare = 23,
> + .tclktrail = 23,
> + .thstrail = 23,
> + .tclkzero = 87,
> + .tclkprepare = 23,
> + .tlpx = 23,
> +};
> +
> +static const struct imx290_csi_cfg imx290_csi_297mhz = {
> + /* 297MHz or 594Mbit/s per lane */
> + .repetition = 0x00,
> + .tclkpost = 103,
> + .thszero = 87,
> + .thsprepare = 47,
> + .tclktrail = 39,
> + .thstrail = 47,
> + .tclkzero = 191,
> + .tclkprepare = 47,
> + .tlpx = 39,
> +};
> +
> /* supported link frequencies */
> #define FREQ_INDEX_1080P 0
> #define FREQ_INDEX_720P 1
> @@ -557,6 +601,42 @@ static int imx290_set_black_level(struct imx290
> *imx290, black_level >> (16 - bpp), err);
> }
>
> +static int imx290_set_csi_config(struct imx290 *imx290)
> +{
> + const s64 *link_freqs = imx290_link_freqs_ptr(imx290);
> + const struct imx290_csi_cfg *csi_cfg;
> + int ret = 0;
> +
> + switch (link_freqs[imx290->current_mode->link_freq_index]) {
> + case 445500000:
> + csi_cfg = &imx290_csi_445_5mhz;
> + break;
> + case 297000000:
> + csi_cfg = &imx290_csi_297mhz;
> + break;
> + case 222750000:
> + csi_cfg = &imx290_csi_222_75mhz;
> + break;
> + case 148500000:
> + csi_cfg = &imx290_csi_148_5mhz;
> + break;
> + default:
> + return -EINVAL;
> + }
> +
> + imx290_write(imx290, IMX290_REPETITION, csi_cfg->repetition, &ret);
> + imx290_write(imx290, IMX290_TCLKPOST, csi_cfg->tclkpost, &ret);
> + imx290_write(imx290, IMX290_THSZERO, csi_cfg->thszero, &ret);
> + imx290_write(imx290, IMX290_THSPREPARE, csi_cfg->thsprepare, &ret);
> + imx290_write(imx290, IMX290_TCLKTRAIL, csi_cfg->tclktrail, &ret);
> + imx290_write(imx290, IMX290_THSTRAIL, csi_cfg->thstrail, &ret);
> + imx290_write(imx290, IMX290_TCLKZERO, csi_cfg->tclkzero, &ret);
> + imx290_write(imx290, IMX290_TCLKPREPARE, csi_cfg->tclkprepare,
&ret);
> + imx290_write(imx290, IMX290_TLPX, csi_cfg->tlpx, &ret);
> +
> + return ret;
> +}
> +
> static int imx290_setup_format(struct imx290 *imx290,
> const struct v4l2_mbus_framefmt *format)
> {
> @@ -769,6 +849,12 @@ static int imx290_start_streaming(struct imx290
> *imx290, return ret;
> }
>
> + ret = imx290_set_csi_config(imx290);
> + if (ret < 0) {
> + dev_err(imx290->dev, "Could not set csi cfg\n");
> + return ret;
> + }
> +
> /* Apply the register values related to current frame format */
> format = v4l2_subdev_get_pad_format(&imx290->sd, state, 0);
> ret = imx290_setup_format(imx290, format);
next prev parent reply other threads:[~2023-02-06 7:49 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-02-03 19:17 [PATCH v2 00/13] imx290: Minor fixes, support for alternate INCK, and more ctrls Dave Stevenson
2023-02-03 19:17 ` [PATCH v2 01/13] media: i2c: imx290: Match kernel coding style on whitespace Dave Stevenson
2023-02-03 19:18 ` [PATCH v2 02/13] media: i2c: imx290: Set the colorspace fields in the format Dave Stevenson
2023-02-07 1:34 ` Laurent Pinchart
2023-02-03 19:18 ` [PATCH v2 03/13] media: i2c: imx290: Add V4L2_SUBDEV_FL_HAS_EVENTS and subscribe hooks Dave Stevenson
2023-02-03 19:18 ` [PATCH v2 04/13] media: i2c: imx290: Fix the pixel rate at 148.5Mpix/s Dave Stevenson
2023-02-03 19:18 ` [PATCH v2 05/13] media: i2c: imx290: Support 60fps in 2 lane operation Dave Stevenson
2023-02-03 19:18 ` [PATCH v2 06/13] media: i2c: imx290: Use CSI timings as per datasheet Dave Stevenson
2023-02-06 7:48 ` Alexander Stein [this message]
2023-02-03 19:18 ` [PATCH v2 07/13] media: i2c: imx290: Convert V4L2_CID_HBLANK to read/write Dave Stevenson
2023-02-06 7:59 ` Alexander Stein
2023-02-03 19:18 ` [PATCH v2 08/13] media: i2c: imx290: Convert V4L2_CID_VBLANK " Dave Stevenson
2023-02-03 19:18 ` [PATCH v2 09/13] media: i2c: imx290: VMAX is mode dependent Dave Stevenson
2023-02-07 1:46 ` Laurent Pinchart
2023-02-03 19:18 ` [PATCH v2 10/13] media: i2c: imx290: Remove duplicated write to IMX290_CTRL_07 Dave Stevenson
2023-02-03 19:18 ` [PATCH v2 11/13] media: i2c: imx290: Add support for 74.25MHz external clock Dave Stevenson
2023-02-06 8:24 ` Alexander Stein
2023-02-07 1:50 ` Laurent Pinchart
2023-02-03 19:18 ` [PATCH v2 12/13] media: i2c: imx290: Add support for H & V Flips Dave Stevenson
2023-02-07 1:52 ` Laurent Pinchart
2023-02-03 19:18 ` [PATCH v2 13/13] media: i2c: imx290: Add the error code to logs in start_streaming Dave Stevenson
2023-02-06 8:27 ` Alexander Stein
2023-02-07 1:53 ` Laurent Pinchart
2023-02-07 1:55 ` [PATCH v2 00/13] imx290: Minor fixes, support for alternate INCK, and more ctrls Laurent Pinchart
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=2669831.mvXUDI8C0e@steina-w \
--to=alexander.stein@ew.tq-group.com \
--cc=dave.stevenson@raspberrypi.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linux-media@vger.kernel.org \
--cc=mani@kernel.org \
--cc=mchehab@kernel.org \
/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