Received: by 2002:ab2:3350:0:b0:1f4:6588:b3a7 with SMTP id o16csp248396lqe; Fri, 5 Apr 2024 22:26:44 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWjtpH1t4LFMStjw5j/goahJXBb4CU7naXoyMOBnamSVhCJHblJUniLMfIN4M/flfeV5cyyc9EJFcEf+mBbWfOfs6KFgoHvQvPwb3Q6qw== X-Google-Smtp-Source: AGHT+IH6ot4hTKPdzv3qTCbPKG1POL0N8waecz/MDzkTAe8Sjj+ADgpP+q5/zMXgeRpp5fxSMyXW X-Received: by 2002:a05:6808:1526:b0:3c3:d80c:ee5f with SMTP id u38-20020a056808152600b003c3d80cee5fmr3705887oiw.51.1712381204119; Fri, 05 Apr 2024 22:26:44 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712381204; cv=pass; d=google.com; s=arc-20160816; b=iKuMIaR0NJg5CzHYzunJTb9maEypljvsx+hcqP9rgHiTzvjXNpBvl4Etqn3djSskao ind1P/SX2+3EOjea748HecyeCCYQgfIGPBAQnFd4YgYF0fL5IsWoICExHF7DbN5mnl4p sW+DKCMvxHyPkVk45hCEPO3gXR2wV98ZINLOFJaG1tuRfRJZgaoAFwKgI8y0VVim7rVw FWYt+L7xhHtTvqhgUNMNexvbsRnprkwgKXubC8aL2WxA1mphbAKu5tJqdu9DSPMHcSRJ LPrUWb3OmAg/o0K5rFnbcgj+4DYYllrNwIRUSSfH3J+a/f0drwAfxbRPZgXBSPk2RfoV 7RLQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=BNON1J0zR9mGYVO4Em2CLHDLLvir7/ucqCdtp1IZ9CM=; fh=xXwbvOg5UUQCXO2Fy93vdlbL6EZBR4SaJ0EAbwk2qO8=; b=Y7P5vjryhti9M4i6ntNZAMc6biLnucUmVQ+vKfbDx/2y7p8L4COzZ/CH+6xKgS1BBi /r0j6TdM3IDQxRKlLmlwCHvlaWYQy4e++cBfmvizV5Qr9kt8AH9sNbLofZgJeC2NfSC6 fftEKLBN8Nu2Ic9iONIGW+OckUBu4G4tnblvOpQeSYuPJU4DDKtD3BXjJvpVACPqr9BO EfB/5CjanBtb0kZwTVp9FBnICTH1Y+N7Z6IME8JlkIH07n7xdgElr1GiyuYb1QH09Rf1 weM8jbmS9jKeMn2F0eVMlX/XKHbA1/77paNZUXmyEtF20YygogJBaIAscduqr6+AL0Xx Z1bQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=fail header.i=@luigi311.com header.s=x header.b=lYYo38LY; arc=pass (i=1 spf=pass spfdomain=luigi311.com dkim=pass dkdomain=luigi311.com); spf=pass (google.com: domain of linux-kernel+bounces-133813-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-133813-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id p35-20020a631e63000000b005df469b4f7asi2527560pgm.489.2024.04.05.22.26.43 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 05 Apr 2024 22:26:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-133813-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=fail header.i=@luigi311.com header.s=x header.b=lYYo38LY; arc=pass (i=1 spf=pass spfdomain=luigi311.com dkim=pass dkdomain=luigi311.com); spf=pass (google.com: domain of linux-kernel+bounces-133813-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-133813-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 8CFD2282CE0 for ; Sat, 6 Apr 2024 05:26:43 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 26F3E20317; Sat, 6 Apr 2024 05:26:37 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=fail reason="signature verification failed" (2048-bit key) header.d=luigi311.com header.i=@luigi311.com header.b="lYYo38LY" Received: from mail-108-mta59.mxroute.com (mail-108-mta59.mxroute.com [136.175.108.59]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6AAE91DA21 for ; Sat, 6 Apr 2024 05:26:34 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=136.175.108.59 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712381196; cv=none; b=dYeWIvqDP/R1+UNWx9ZKuT95cIhhEfEIv1Wu52mSNRmHSBE0Ex2iRpER8cDuRhimIcb1+YqrTEnBHJbCLoZTVps+7LdmxNgbcc1v2xjwiVq6UxfGOdheSCJ43esakjypg8Up7tKsdWx7+k4+Kbaye161ZgyfVxHOCQTkAjE+o18= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712381196; c=relaxed/simple; bh=BG8LcYwweZBCV9PEAn7PNGz++FzqdB3/RIwjA6WLWIA=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=V7qddTmMuvb9XHnrBYgBbyKbnUPNE5sgTqlIsOv5r58si5M8S9PpyBI82PIE2OwqpdXdJlWU6R9IGN50kROdO31TiCBO4nsY+V4iIJKrw/xzIgP7jpUWz4MOF4ASQz+ZRWRX68wZgu22ijGmsp9vcjVqsHsvKw5MwA2kT9PdqTs= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=luigi311.com; spf=pass smtp.mailfrom=luigi311.com; dkim=pass (2048-bit key) header.d=luigi311.com header.i=@luigi311.com header.b=lYYo38LY; arc=none smtp.client-ip=136.175.108.59 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=luigi311.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=luigi311.com Received: from filter006.mxroute.com ([136.175.111.2] filter006.mxroute.com) (Authenticated sender: mN4UYu2MZsgR) by mail-108-mta59.mxroute.com (ZoneMTA) with ESMTPSA id 18eb1daa55d0003bea.011 for (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384); Sat, 06 Apr 2024 05:21:20 +0000 X-Zone-Loop: 5318af1bf2be7c384f93fa8bcec26023aa34edaadf26 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=luigi311.com; s=x; h=Content-Transfer-Encoding:Content-Type:In-Reply-To: From:References:Cc:To:Subject:MIME-Version:Date:Message-ID:Sender:Reply-To: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID:List-Id:List-Help:List-Unsubscribe: List-Subscribe:List-Post:List-Owner:List-Archive; bh=BNON1J0zR9mGYVO4Em2CLHDLLvir7/ucqCdtp1IZ9CM=; b=lYYo38LYiW6zyh7FZufIl1WrzC eisaOu/2/JNj0Asq7SEj5D8O1BNbyKV8Xxzme3LXfzwSoQlbvuUhsIFqujBChYeqh09PebGSaquFJ EKgVdk9UoTU0WmhHy0ck2qrk9wP/jyLcbw5Ac2p8SJ1SJfq9Th9xsMfrilUwnOtW8Im91SlXAOPSI 56nA9jIB22PoEB4yAN2wZ1yhzx0RmXBG4NJV8UbUI2sEv2JNmcLAzzvsGq4lkt0owpfehT9W9D5Oh 0A9TfIFZAuba817gNb/gBw2rZffqNoLcm36yN6yDAkcnEX2hAQSJkU/xWsYPVb8aaGixuoHkIx3KD Wr7P1BjQ==; Message-ID: <3050aed0-df58-440f-87b9-d91d30382c41@luigi311.com> Date: Fri, 5 Apr 2024 23:21:15 -0600 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v3 21/25] drivers: media: i2c: imx258: Use macros To: Tommaso Merciai Cc: Sakari Ailus , linux-media@vger.kernel.org, dave.stevenson@raspberrypi.com, jacopo.mondi@ideasonboard.com, mchehab@kernel.org, robh@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, kernel@pengutronix.de, festevam@gmail.com, devicetree@vger.kernel.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, pavel@ucw.cz, phone-devel@vger.kernel.org, Ondrej Jirman References: <20240403150355.189229-1-git@luigi311.com> <20240403150355.189229-22-git@luigi311.com> <082190a8-7ac5-4240-9a16-6b9168c67d57@luigi311.com> Content-Language: en-US From: Luis Garcia In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Authenticated-Id: git@luigi311.com On 4/5/24 08:11, Tommaso Merciai wrote: > Hi Luis, > > On Fri, Apr 05, 2024 at 04:33:38AM -0600, Luis Garcia wrote: >> On 4/4/24 00:46, Sakari Ailus wrote: >>> On Wed, Apr 03, 2024 at 01:17:26PM -0600, Luigi311 wrote: >>>> On 4/3/24 10:23, Sakari Ailus wrote: >>>>> Hi Luis, >>>>> >>>>> On Wed, Apr 03, 2024 at 09:03:50AM -0600, git@luigi311.com wrote: >>>>>> From: Luis Garcia >>>>>> >>>>>> Use understandable macros instead of raw values. >>>>>> >>>>>> Signed-off-by: Ondrej Jirman >>>>>> Signed-off-by: Luis Garcia >>>>>> --- >>>>>> drivers/media/i2c/imx258.c | 434 ++++++++++++++++++------------------- >>>>>> 1 file changed, 207 insertions(+), 227 deletions(-) >>>>>> >>>>>> diff --git a/drivers/media/i2c/imx258.c b/drivers/media/i2c/imx258.c >>>>>> index e2ecf6109516..30352c33f63c 100644 >>>>>> --- a/drivers/media/i2c/imx258.c >>>>>> +++ b/drivers/media/i2c/imx258.c >>>>>> @@ -33,8 +33,6 @@ >>>>>> #define IMX258_VTS_30FPS_VGA 0x034c >>>>>> #define IMX258_VTS_MAX 65525 >>>>>> >>>>>> -#define IMX258_REG_VTS 0x0340 >>>>>> - >>>>>> /* HBLANK control - read only */ >>>>>> #define IMX258_PPL_DEFAULT 5352 >>>>>> >>>>>> @@ -90,6 +88,53 @@ >>>>>> #define IMX258_PIXEL_ARRAY_WIDTH 4208U >>>>>> #define IMX258_PIXEL_ARRAY_HEIGHT 3120U >>>>>> >>>>>> +/* regs */ >>>>>> +#define IMX258_REG_PLL_MULT_DRIV 0x0310 >>>>>> +#define IMX258_REG_IVTPXCK_DIV 0x0301 >>>>>> +#define IMX258_REG_IVTSYCK_DIV 0x0303 >>>>>> +#define IMX258_REG_PREPLLCK_VT_DIV 0x0305 >>>>>> +#define IMX258_REG_IOPPXCK_DIV 0x0309 >>>>>> +#define IMX258_REG_IOPSYCK_DIV 0x030b >>>>>> +#define IMX258_REG_PREPLLCK_OP_DIV 0x030d >>>>>> +#define IMX258_REG_PHASE_PIX_OUTEN 0x3030 >>>>>> +#define IMX258_REG_PDPIX_DATA_RATE 0x3032 >>>>>> +#define IMX258_REG_SCALE_MODE 0x0401 >>>>>> +#define IMX258_REG_SCALE_MODE_EXT 0x3038 >>>>>> +#define IMX258_REG_AF_WINDOW_MODE 0x7bcd >>>>>> +#define IMX258_REG_FRM_LENGTH_CTL 0x0350 >>>>>> +#define IMX258_REG_CSI_LANE_MODE 0x0114 >>>>>> +#define IMX258_REG_X_EVN_INC 0x0381 >>>>>> +#define IMX258_REG_X_ODD_INC 0x0383 >>>>>> +#define IMX258_REG_Y_EVN_INC 0x0385 >>>>>> +#define IMX258_REG_Y_ODD_INC 0x0387 >>>>>> +#define IMX258_REG_BINNING_MODE 0x0900 >>>>>> +#define IMX258_REG_BINNING_TYPE_V 0x0901 >>>>>> +#define IMX258_REG_FORCE_FD_SUM 0x300d >>>>>> +#define IMX258_REG_DIG_CROP_X_OFFSET 0x0408 >>>>>> +#define IMX258_REG_DIG_CROP_Y_OFFSET 0x040a >>>>>> +#define IMX258_REG_DIG_CROP_IMAGE_WIDTH 0x040c >>>>>> +#define IMX258_REG_DIG_CROP_IMAGE_HEIGHT 0x040e >>>>>> +#define IMX258_REG_SCALE_M 0x0404 >>>>>> +#define IMX258_REG_X_OUT_SIZE 0x034c >>>>>> +#define IMX258_REG_Y_OUT_SIZE 0x034e >>>>>> +#define IMX258_REG_X_ADD_STA 0x0344 >>>>>> +#define IMX258_REG_Y_ADD_STA 0x0346 >>>>>> +#define IMX258_REG_X_ADD_END 0x0348 >>>>>> +#define IMX258_REG_Y_ADD_END 0x034a >>>>>> +#define IMX258_REG_EXCK_FREQ 0x0136 >>>>>> +#define IMX258_REG_CSI_DT_FMT 0x0112 >>>>>> +#define IMX258_REG_LINE_LENGTH_PCK 0x0342 >>>>>> +#define IMX258_REG_SCALE_M_EXT 0x303a >>>>>> +#define IMX258_REG_FRM_LENGTH_LINES 0x0340 >>>>>> +#define IMX258_REG_FINE_INTEG_TIME 0x0200 >>>>>> +#define IMX258_REG_PLL_IVT_MPY 0x0306 >>>>>> +#define IMX258_REG_PLL_IOP_MPY 0x030e >>>>>> +#define IMX258_REG_REQ_LINK_BIT_RATE_MBPS_H 0x0820 >>>>>> +#define IMX258_REG_REQ_LINK_BIT_RATE_MBPS_L 0x0822 >>>>>> + >>>>>> +#define REG8(a, v) { a, v } >>>>>> +#define REG16(a, v) { a, ((v) >> 8) & 0xff }, { (a) + 1, (v) & 0xff } >>>>> >>>>> The patch is nice but these macros are better replaced by the V4L2 CCI >>>>> helper that also offers register access functions. Could you add a patch to >>>>> convert the driver to use it (maybe after this one)? >>>>> >>>> >>>> Ohh perfect, using something else would be great. Ill go ahead and see >>>> if I can get that working. >>> >>> Thanks. It may be easier to just do it in this one actually. Up to you. >>> >> >> I've made the swap but looks like its not playing nice with my ppp, >> its causing a crash and showing a call trace as soon as it does its >> first read to check the identity. I went in and dropped the cci_read >> and left it with the original implementation and I'm getting a very >> similar crash with cci_write too so it looks like its not liking >> how I'm implementing it. Looking at the few other drivers that were >> swapped over to use that, I don't seem to be missing anything. It's >> a big change so its not really something I can describe what I've >> changed but I do have the change on my github here >> https://github.com/luigi311/linux/commit/840593acb20eee87ce361e6929edf51eefbbe737 > > I checked your commit to switch to cci helper. > I think you are missing the right cci regmap initialization. > > Please take care to use: devm_cci_regmap_init_i2c > > /** > * devm_cci_regmap_init_i2c() - Create regmap to use with cci_*() register > * access functions > * > * @client: i2c_client to create the regmap for > * @reg_addr_bits: register address width to use (8 or 16) > * > * Note the memory for the created regmap is devm() managed, tied to the client. > * > * Return: %0 on success or a negative error code on failure. > */ > > Check drivers/media/i2c/imx290.c:1530 > Hope this help :) > > Note: > Somewhere into the github commit you are reading 16bit reg and storing > that into 64bit val. Take care! :) > > Thanks & Regards, > Tommaso > > Ohh my god your right, looks like i missed that when i was replicating the cci patch for that same driver lol. Looks like that fixed it and the driver is now loading so i can continue to debug it and make sure everything is set correct since i had a few that were messed up since i couldn't test it. >> if you can provide some guidance, if not I can skip this change >> all together and we can do a separate attempt at swapping over to it. >>