Received: by 2002:a05:7412:a9a2:b0:e2:908c:2ebd with SMTP id o34csp1053137rdh; Fri, 27 Oct 2023 03:29:52 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEJk/tWz596bYFB/8c80f6KwNPRWKgZ3bxootRaUUIeDP6nD0kXPDjIyxtTaVzTj5gQ6JA2 X-Received: by 2002:a81:4c05:0:b0:5a7:c49e:3f5c with SMTP id z5-20020a814c05000000b005a7c49e3f5cmr2324811ywa.21.1698402591927; Fri, 27 Oct 2023 03:29:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698402591; cv=none; d=google.com; s=arc-20160816; b=SwMIqjyj9mc8VH4Sqbg59je+Id9Vh3C2XwcqBrGGAjorRYTiMpP3nhSE0KSGI1zTPJ 15tVDUBqjd1W0un46vhp/VBexaza4pWSY8VUc5mzIPXZ6vumt9fdOjOpKdLop2y542Sz 4yKBb1NDI2acRUpnsA+l7BQT8lYXkd6ZQN0qvsTZN3ej+1Obs8fqONX1dgkMULOBVqSp mSILgqfn2tcJs/SaOwIfossrsAgW30UrBwDgn15+JiV2RvZ4A5Z2Xy4alRgYvCTG/xeo iMz93U2apJ8i5TH1P6K/WZfJGObDUcYD4CTuN6B05wN5vYl1DwZ3OfQQlxSSg+s0iBN+ PutQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=iZn35aVvF3CpjghTrj9bHg72KmEjxE0DqCJaX7l42PE=; fh=CPwCX34Ipyn5kOqnppNrLYFvP5dTZUJj1U8rVaUb91Y=; b=ZhpiRUXQdZziqrvIf+9mcVuNsREbOF5M/ZXLped9Bzji76hOBURauoVbNNqgy+1Fi1 0dJwQSY6gLLiEUJmYU4fwmvU1wuk5IkGKDUMmFOZjahkjnoJWZWI14gBT2kp9IUlA5S0 gzA49/m//+IXktr4nrXzmTPsHzcfASOEAfZTpURb3DQf1+I9fWkLwo9onLivcHJJ2thi bJ36pp7I81Saq7SEZ+SSjpTKrR2lg7mTJHZv6hZeOk8Gkc+rNfv978ryvgtIPPH26J4P OqO7GC8JngtNT4lTY/n8SrXo2sP10DS72cWK3Y0SjcLNwVYCPyOEQ2whqkOraLUhbXjE Hc5w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@raspberrypi.com header.s=google header.b=nGza0flx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=raspberrypi.com Return-Path: Received: from howler.vger.email (howler.vger.email. [2620:137:e000::3:4]) by mx.google.com with ESMTPS id t133-20020a81838b000000b005a7aad8dd41si2225220ywf.304.2023.10.27.03.29.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 27 Oct 2023 03:29:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) client-ip=2620:137:e000::3:4; Authentication-Results: mx.google.com; dkim=pass header.i=@raspberrypi.com header.s=google header.b=nGza0flx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:4 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=raspberrypi.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 19CB68348222; Fri, 27 Oct 2023 03:29:48 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235097AbjJ0K3c (ORCPT + 99 others); Fri, 27 Oct 2023 06:29:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55702 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231464AbjJ0K3a (ORCPT ); Fri, 27 Oct 2023 06:29:30 -0400 Received: from mail-yb1-xb29.google.com (mail-yb1-xb29.google.com [IPv6:2607:f8b0:4864:20::b29]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 61461121 for ; Fri, 27 Oct 2023 03:29:28 -0700 (PDT) Received: by mail-yb1-xb29.google.com with SMTP id 3f1490d57ef6-d84c24a810dso1321017276.2 for ; Fri, 27 Oct 2023 03:29:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=raspberrypi.com; s=google; t=1698402567; x=1699007367; darn=vger.kernel.org; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=iZn35aVvF3CpjghTrj9bHg72KmEjxE0DqCJaX7l42PE=; b=nGza0flxlzjhcKgbud1O5pKSEQHn41hCTWNZVQUyVORiH9aE2Ok6zbFNzGqZABqDPC DnJBpQgBCGCkZsaH/O3F6wxpYzmITh+IzGhQF2eumM7wIBvipt2tb1oTmY7iOlAZLHX6 TSxRCqjZ7emSdnT9T76JFO9uI2k7nlsJRmrNnh8FgTQzUaKWlF1EuE6TRn8aQu9vXAMV gEMOXTGk5LCJsPcUUX8WUkf9bmrrT66i8JnLF1iMBaggogCjni1lzAiug6h7CQKb4l+a tUd0Y60odND8OjnZHeYe1otfLhTqTL8zzrT9rv2EMRj6TsvToiiXHkGI42Vo7yhfv609 P86g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1698402567; x=1699007367; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=iZn35aVvF3CpjghTrj9bHg72KmEjxE0DqCJaX7l42PE=; b=MHHVku8xVmQ1NPucojF3ZTaxcBtCGoPyGJh1da4q8oWWmh0xiZ/qA9Oih8/CMhtbP1 n5uSMRggsEkAuOxroCU+THLuxKcJCOe9OPKqKPqwGmI5Bf5c0V0Y9TujTCfldvxij36R wWck8NWEcobvLoLQ17qiTl0sWZOQ5ebilxZ7xrHdJf6YxHMT26g553AIsKqg9gWYg1vw +vbBXp3kZzdHpirMLWjURP/3KoIhe9KCp9i9J67ZrKimU6YNrof/y3iD+eu8YsOAqpeT /KwAJBLXL/oresIxlF7tx4TDSWRyYrSqeqCIpqNqviKREtLvdobF2Hm7Ao5jgJbY/tX4 jtgg== X-Gm-Message-State: AOJu0YwEHmbBkLGzosNIxIle3kE+/P07+Lova/0V1ThY57ThwjZZANVd yV8f0palmmol7xcMtWNTbcqRQlLMSKVqjpXCgO2NBQ== X-Received: by 2002:a25:4097:0:b0:d9b:ff50:b100 with SMTP id n145-20020a254097000000b00d9bff50b100mr1855215yba.28.1698402567578; Fri, 27 Oct 2023 03:29:27 -0700 (PDT) MIME-Version: 1.0 References: <20231023-imx214-v1-0-b33f1bbd1fcf@apitzsch.eu> <20231023-imx214-v1-4-b33f1bbd1fcf@apitzsch.eu> <56kgwl7zehsxy2pp7nziwk2gt6joax42qpzs6eywufvcto7qxm@ts4i3ccdokjr> <3opzxxkqa4p6wxddx7bdf2dixphfuo4xunaaiqibvtppmyz6gr@vjxbtjjqiqvy> In-Reply-To: <3opzxxkqa4p6wxddx7bdf2dixphfuo4xunaaiqibvtppmyz6gr@vjxbtjjqiqvy> From: Dave Stevenson Date: Fri, 27 Oct 2023 11:29:11 +0100 Message-ID: Subject: Re: [PATCH 4/4] media: i2c: imx214: Add sensor's pixel matrix size To: Jacopo Mondi Cc: =?UTF-8?Q?Andr=C3=A9_Apitzsch?= , Ricardo Ribalda , Sakari Ailus , Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, ~postmarketos/upstreaming@lists.sr.ht Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=1.1 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, PDS_OTHER_BAD_TLD,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on howler.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Fri, 27 Oct 2023 03:29:48 -0700 (PDT) X-Spam-Level: * Hi Jacopo On Fri, 27 Oct 2023 at 09:57, Jacopo Mondi wrote: > > Hi Andre' > > On Wed, Oct 25, 2023 at 11:26:00PM +0200, Andr=C3=A9 Apitzsch wrote: > > Hi Jacopo, > > > > Am Dienstag, dem 24.10.2023 um 09:52 +0200 schrieb Jacopo Mondi: > > > Hi Andre' > > > > > > On Mon, Oct 23, 2023 at 11:47:53PM +0200, Andr=C3=A9 Apitzsch wrote: > > > > Set effictive and active sensor pixel sizes as shown in product > > > > > > s/effictive/effective > > > > > > > brief[1]. > > > > > > > > [1]: > > > > https://www.mouser.com/datasheet/2/897/ProductBrief_IMX214_20150428= -1289331.pdf > > > > > > > > Signed-off-by: Andr=C3=A9 Apitzsch > > > > --- > > > > drivers/media/i2c/imx214.c | 39 ++++++++++++++++++++++++++++++++-- > > > > ----- > > > > 1 file changed, 32 insertions(+), 7 deletions(-) > > > > > > > > diff --git a/drivers/media/i2c/imx214.c > > > > b/drivers/media/i2c/imx214.c > > > > index bef8dc36e2d0..a2d441cd8dcd 100644 > > > > --- a/drivers/media/i2c/imx214.c > > > > +++ b/drivers/media/i2c/imx214.c > > > > @@ -36,6 +36,14 @@ > > > > #define IMX214_EXPOSURE_STEP 1 > > > > #define IMX214_EXPOSURE_DEFAULT 0x0c70 > > > > > > > > +/* IMX214 native and active pixel array size */ > > > > +#define IMX214_NATIVE_WIDTH 4224U > > > > +#define IMX214_NATIVE_HEIGHT 3136U > > > > +#define IMX214_PIXEL_ARRAY_LEFT 8U > > > > +#define IMX214_PIXEL_ARRAY_TOP 8U > > > > +#define IMX214_PIXEL_ARRAY_WIDTH 4208U > > > > +#define IMX214_PIXEL_ARRAY_HEIGHT 3120U > > > > + > > > > > > I do get slightly different numbers from the datasheet version I have > > > > > > The sensor is said to have 4224x3208 total pixels of which 4208x3120 > > > are active ones. > > > > > > The pixel array diagram shows 64 "OPB" (optically black ?) lines, > > > followed by 8 dummy lines, followed by 3120 valid lines. There are 8 > > > dummy columns at each side of the 4208 valid ones. > > > > > > Now, NATIVE which represents the full pixel array size seems to be > > > 4224x3208 (other parts of the datasheet only report 3200 lines > > > though) > > > > > > BOUNDS represents the readabale array area, which I presume > > > corresponds to what is named as 'effective area' by the datasheet. It > > > excludes the OPB lines at the top of the image and seems to be > > > represented by (0, 64, 4224, 3160). > > > > > > CROP_DEFAULT represents the default crop rectangle which covers the > > > active pixel area, so it excludes 8 more lines of dummy pixels and 8 > > > dummy columns, which gives a rectangle (8, 72, 4208, 3120) > > > > > > Also note that the driver always reports a TGT_CROP rectangle with > > > top/left points set to 0. If my understanding is correct, V4L2 > > > selection targets are defined from the most external target > > > (TGT_NATIVE in this case), and the driver should be corrected to > > > initialize the crop rectangle with a top-left corner at (8, 72). > > > > > > Does this make sense ? > > > > As far as I understood, only the effective and active sizes of three > > sizes provided in the datasheet (total, effective and active) matter. > > By comparing the values used in imx219.c (and imx415.c) with the ones > > in the corresponding datasheets [1,2] I assume, that "effective" > > matches "NATIVE_SIZE", "active" matches "CROP_DEFAULT" and "total" is > > ignored. > > imx219 driver indeed does not consider the OPB areas in the definition > of the rectangles... > > Also looking at the X/Y_ADDR_START value assigned in the register tables > for full resolution mode (3280x2462) they have value of 0, indeed > meaning the active area is the only readable one. > > Then yes, you're right, for imx219 > NATIVE =3D effective > CROP_DEFAULT =3D BOUND =3D active > > > The commit message of 1ed36ecd1459b653cced8929bfb37dba94b64c5d ("media: > > i2c: imx219: Selection compliance fixes") seems to support me here: > > > > > > The top/left crop coordinates of the TGT_CROP rectangle were set to > > > (0, 0) instead of (8, 8) which is the offset from the larger physical > > > pixel array rectangle. > > > > This (8, 8) is half the difference between number of effective and > > active pixels of imx219[1]. > > > > Together with the 8 dummy lines and 8 dummy columns you mentioned, I > > still think my values are right. But I've just started working with > > V4L2, so I might be wrong. > > To actually verify if the 'effective area' is readable or not, we > should know what register controls the X/Y_ADDR_START value, and > that's an information I don't have in my version of the datasheet. I happen to have an IMX214 datasheet. X_ADDR_START is 0x0344/5 (set in multiples of 2) Y_ADDR_START is 0x0346/7 (set in multiples of 4) X_ADDR_END is 0x0348/9 (set in multiples of 2) Y_ADDR_END is 0x034a/b (set in multiples of 4) X_OUTPUT_SIZE 0x034c/d Y_OUTPUT_SIZE 0x034e/f X direction are 13bit values, Y direction are 12 bit. [12:8] or [11:8] in the low bits of the first register, [7:0] in the second register. Dave > It's however plausible that it behaves the same as imx219, as the > driver's register sequences seems to program the crop sizes in > register 0x034c and 0x034e and there's not programmed top-left corner > there. > > Ok then, let's be consistent and do the same as imx219 as you're doing > here. > > Reviewed-by: Jacopo Mondi > > > > > Could you share the imx214 datasheet with me? > > > > Best regards, > > Andr=C3=A9 > > > > [1] https://www.arducam.com/downloads/modules/RaspberryPi_camera/IMX219= DS.PDF > > [2] https://www.sony-semicon.com/files/62/pdf/p-12_IMX415-AAQR_AAMR_Fly= er.pdf > > > > > > Thanks > > > j > > > > > > > > > > static const char * const imx214_supply_name[] =3D { > > > > "vdda", > > > > "vddd", > > > > @@ -634,14 +642,31 @@ static int imx214_get_selection(struct > > > > v4l2_subdev *sd, > > > > { > > > > struct imx214 *imx214 =3D to_imx214(sd); > > > > > > > > - if (sel->target !=3D V4L2_SEL_TGT_CROP) > > > > - return -EINVAL; > > > > + switch (sel->target) { > > > > + case V4L2_SEL_TGT_CROP: > > > > + mutex_lock(&imx214->mutex); > > > > + sel->r =3D *__imx214_get_pad_crop(imx214, sd_state, > > > > sel->pad, > > > > + sel->which); > > > > + mutex_unlock(&imx214->mutex); > > > > + return 0; > > > > > > > > - mutex_lock(&imx214->mutex); > > > > - sel->r =3D *__imx214_get_pad_crop(imx214, sd_state, sel- > > > > >pad, > > > > - sel->which); > > > > - mutex_unlock(&imx214->mutex); > > > > - return 0; > > > > + case V4L2_SEL_TGT_NATIVE_SIZE: > > > > + sel->r.top =3D 0; > > > > + sel->r.left =3D 0; > > > > + sel->r.width =3D IMX214_NATIVE_WIDTH; > > > > + sel->r.height =3D IMX214_NATIVE_HEIGHT; > > > > + return 0; > > > > + > > > > + case V4L2_SEL_TGT_CROP_DEFAULT: > > > > + case V4L2_SEL_TGT_CROP_BOUNDS: > > > > + sel->r.top =3D IMX214_PIXEL_ARRAY_TOP; > > > > + sel->r.left =3D IMX214_PIXEL_ARRAY_LEFT; > > > > + sel->r.width =3D IMX214_PIXEL_ARRAY_WIDTH; > > > > + sel->r.height =3D IMX214_PIXEL_ARRAY_HEIGHT; > > > > + return 0; > > > > + } > > > > + > > > > + return -EINVAL; > > > > } > > > > > > > > static int imx214_entity_init_cfg(struct v4l2_subdev *subdev, > > > > > > > > -- > > > > 2.42.0 > > > > > >