Received: by 2002:a05:7412:bbc7:b0:fc:a2b0:25d7 with SMTP id kh7csp3322845rdb; Tue, 6 Feb 2024 14:10:52 -0800 (PST) X-Google-Smtp-Source: AGHT+IEDj30U2ZRZRjFP5d34SwxilyHaVAo8rY9H6yATDDGcJJr0ZFDECUDqUxefbGrwF7fi+Qrr X-Received: by 2002:ae9:c118:0:b0:783:9bd6:742 with SMTP id z24-20020ae9c118000000b007839bd60742mr3195302qki.77.1707257452031; Tue, 06 Feb 2024 14:10:52 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1707257452; cv=pass; d=google.com; s=arc-20160816; b=MZ92//8KMsk77z10mfVAQrbZl2eG6S33n8apgmwxQeUCAook2UmuXMwcnLRpVvaySW 2HIno74e2CxNh7qx+o5uyzhn6EGa2CbScE/NHy3cUn7tGRvYC/YxtWvDohSymCrucQnG QtJAVAVUx+9zZ1tJHbDRM++dbsh1H9ez+GW0kvtJgiusOLoY+alNDEzsN4wfmqVmvenY iH3BWBcXTWI+7JRRd5deFo09rDogoayTdg9G++JP3U6j8qUyRBlHr3MoGAldzNhuQGN8 +cwUoB+8I6GMeh+2Kg39EYAvq/Y5YwimLcFlLB8ygkB3TttKSJ1y2HWYDoc6objR5cDc pBdQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:references:cc:to:from :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=Mcz5D0g4BHyRQnc3gCk6hBip0QzXdbt1TI5pKNgciC4=; fh=AHPrcAE7f820Q3BhgXtSA7uYHOk5DV7SCLhB3IrmJYc=; b=UrSRoRiPnk9enn3eU1+6y1zK+9m/jfixGqWGQ0Wow6XvXIMQv/958xXx+zLo1KWLzu nu6fMR397u1gsmH47ZFxdkUFe9YG7ofcjYpkqOE5nWwh4FUnV1meQH0M2/Pc0pa/LTjW AUnn+T752yefLJ+3PMASNO4cFXjHha6Ki0Oybdcb7uSbuSB3OJK6eqmDv8A1XkyeUHxF a6YRfBJN2SEGcGbI0xzFz0uNRtc33USNwgmcf+Dus1Zm4N5e0okPMDvD/FyErRbly7Zh +6BYIxn1zqRK0y/ygCi/iZzUIzgAgar9xtR68jYfuHGD30NuRz10owkEo016aDa0JChx Huuw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=uXUIalSW; arc=pass (i=1 spf=pass spfdomain=ti.com dkim=pass dkdomain=ti.com dmarc=pass fromdomain=ti.com); spf=pass (google.com: domain of linux-kernel+bounces-55676-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-55676-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com X-Forwarded-Encrypted: i=1; AJvYcCXXDwB8TlUEugJRh+uBv05OkfSzmXzGa1Pgx0VmNmEJm9Ppeuj2w+htPJGvEx8A3P9hc8TRF4vc9v9gIY+NOTWL7BsBtr2AV3xhQBlWfw== Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id g25-20020a05620a109900b00783da46f069si3194790qkk.615.2024.02.06.14.10.51 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 06 Feb 2024 14:10:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-55676-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=uXUIalSW; arc=pass (i=1 spf=pass spfdomain=ti.com dkim=pass dkdomain=ti.com dmarc=pass fromdomain=ti.com); spf=pass (google.com: domain of linux-kernel+bounces-55676-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-55676-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com 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 ny.mirrors.kernel.org (Postfix) with ESMTPS id B3FA01C2319C for ; Tue, 6 Feb 2024 22:10:51 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id BE3811BF24; Tue, 6 Feb 2024 22:10:44 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=ti.com header.i=@ti.com header.b="uXUIalSW" Received: from fllv0015.ext.ti.com (fllv0015.ext.ti.com [198.47.19.141]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9D3D91BC3C; Tue, 6 Feb 2024 22:10:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=198.47.19.141 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707257443; cv=none; b=Bim9yoDvYASMWhb6Fs6H5l5+mX6l2VeTSK/YMSLUcolN/+kgRCsaslIVzEVOynyxu+S3LSDBBpZ3cRKsd/6M08gqKpMHFH+zUbsKhMT0VaWKMsFkPecQsFW9r0VPwSiUV24gu0jKu/mXIXKVTd2M6m48td9aTNB/TpO0DIO73FI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707257443; c=relaxed/simple; bh=mEm6lEIKUnmm3MKFJcqd+RobgDKepf6Ct1cJxtyjksw=; h=Message-ID:Date:MIME-Version:Subject:From:To:CC:References: In-Reply-To:Content-Type; b=mnFCBddCZ0sysDy7rX1jIp9o2fRvYweyLEeSqdNSGLCW/5KNJR6Jjo2GtQvylyPrvj6NB6s9Xh8iujHwezn7nq0OlBx/wP8VmL0XL2Qukpisl4y2PszEH0yhMkQ87yIAEpfdJJ6b0GZR1jbZLqOfVqz/wYp3WA7+u/YEGurCdBM= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ti.com; spf=pass smtp.mailfrom=ti.com; dkim=pass (1024-bit key) header.d=ti.com header.i=@ti.com header.b=uXUIalSW; arc=none smtp.client-ip=198.47.19.141 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ti.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ti.com Received: from lelv0265.itg.ti.com ([10.180.67.224]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id 416MAcIf010841; Tue, 6 Feb 2024 16:10:38 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1707257438; bh=Mcz5D0g4BHyRQnc3gCk6hBip0QzXdbt1TI5pKNgciC4=; h=Date:Subject:From:To:CC:References:In-Reply-To; b=uXUIalSWNwr6KT8We8G1DqLMXzSaDxt11rjHZpNG/YVUuVPDB7FoKk6r/2A/ujHhk yhvX6cgit/wwvGqoW2L6f9YeFbuaPWgQpfQOcrhpXjF+atWO7RGjrxbnl4W1KEUsAh mmDhMTkovtKtBpBk4ekHYmRVlekUhtvYMyZXyuew= Received: from DLEE115.ent.ti.com (dlee115.ent.ti.com [157.170.170.26]) by lelv0265.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 416MAcsu028596 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 6 Feb 2024 16:10:38 -0600 Received: from DLEE113.ent.ti.com (157.170.170.24) by DLEE115.ent.ti.com (157.170.170.26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.23; Tue, 6 Feb 2024 16:10:38 -0600 Received: from lelvsmtp5.itg.ti.com (10.180.75.250) by DLEE113.ent.ti.com (157.170.170.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.23 via Frontend Transport; Tue, 6 Feb 2024 16:10:38 -0600 Received: from [128.247.81.105] (judy-hp.dhcp.ti.com [128.247.81.105]) by lelvsmtp5.itg.ti.com (8.15.2/8.15.2) with ESMTP id 416MAc6t116843; Tue, 6 Feb 2024 16:10:38 -0600 Message-ID: <66265f27-2314-40e3-a653-35e037685c1d@ti.com> Date: Tue, 6 Feb 2024 16:10:38 -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 v1 2/5] mmc: sdhci_am654: Write ITAPDLY for DDR52 timing Content-Language: en-US From: Judith Mendez To: Andrew Davis , Ulf Hansson CC: Adrian Hunter , , , Randolph Sapp , Vignesh Raghavendra References: <20240131215044.3163469-1-jm@ti.com> <20240131215044.3163469-3-jm@ti.com> <54161b26-329c-4faa-b6f7-73fe82efb525@ti.com> In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 On 2/6/24 3:58 PM, Judith Mendez wrote: > Hi Andrew, > > On 2/1/24 1:36 PM, Andrew Davis wrote: >> On 1/31/24 3:50 PM, Judith Mendez wrote: >>> For DDR52 timing, DLL is enabled but tuning is not carried >>> out, therefore the ITAPDLY value in PHY CTRL 4 register is >>> not correct. Fix this by writing ITAPDLY after enabling DLL. >>> >>> Fixes: a161c45f2979 ("mmc: sdhci_am654: Enable DLL only for some >>> speed modes") >>> Signed-off-by: Judith Mendez >>> --- >>>   drivers/mmc/host/sdhci_am654.c | 27 +++++++++++++++------------ >>>   1 file changed, 15 insertions(+), 12 deletions(-) >>> >>> diff --git a/drivers/mmc/host/sdhci_am654.c >>> b/drivers/mmc/host/sdhci_am654.c >>> index a3798c9912f6..ff18a274b6f2 100644 >>> --- a/drivers/mmc/host/sdhci_am654.c >>> +++ b/drivers/mmc/host/sdhci_am654.c >>> @@ -170,7 +170,19 @@ struct sdhci_am654_driver_data { >>>   #define DLL_CALIB    (1 << 4) >>>   }; >>> -static void sdhci_am654_setup_dll(struct sdhci_host *host, unsigned >>> int clock) >>> +static void sdhci_am654_write_itapdly(struct sdhci_am654_data >>> *sdhci_am654, >>> +                      u32 itapdly) >> >> This patch is confusing, looks like you switched the place of these two >> functions, but diff is not really liking that. You can mess with >> --diff-algorithm and the like to get a more readable patch. But in >> this case why switch their spots at all? >> >> Seems to be so you can call sdhci_am654_write_itapdly() from >> sdhci_am654_setup_dll() without a forward declaration, instead >> why not just call sdhci_am654_write_itapdly() after calling >> sdhci_am654_setup_dll() below. That also saves to from having >> to pass in `timing` to sdhci_am654_write_itapdly() just to >> have it pass it right through to sdhci_am654_setup_dll(). > > Really the only reason I did this is because we call > sdhci_am654_write_itapdly() in sdhci_am654_setup_delay_chain and > I wanted to keep the flow for setting up DLL the same. > I agree the patch looks confusing, so I will fix this for v2. TBH I think it is a good idea to keep the flow the same as it is for sdhci_am654_setup_delay_chain(). Unless you know of a strong enough reason to change, I am leaning towards leaving the patch as is. > > ~ Judith > >> Andrew >> >>> +{ >>> +    /* Set ITAPCHGWIN before writing to ITAPDLY */ >>> +    regmap_update_bits(sdhci_am654->base, PHY_CTRL4, ITAPCHGWIN_MASK, >>> +               0x1 << ITAPCHGWIN_SHIFT); >>> +    regmap_update_bits(sdhci_am654->base, PHY_CTRL4, ITAPDLYSEL_MASK, >>> +               itapdly << ITAPDLYSEL_SHIFT); >>> +    regmap_update_bits(sdhci_am654->base, PHY_CTRL4, >>> ITAPCHGWIN_MASK, 0); >>> +} >>> + >>> +static void sdhci_am654_setup_dll(struct sdhci_host *host, unsigned >>> int clock, >>> +                  unsigned char timing) >>>   { >>>       struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host); >>>       struct sdhci_am654_data *sdhci_am654 = >>> sdhci_pltfm_priv(pltfm_host); >>> @@ -236,17 +248,8 @@ static void sdhci_am654_setup_dll(struct >>> sdhci_host *host, unsigned int clock) >>>           dev_err(mmc_dev(host->mmc), "DLL failed to relock\n"); >>>           return; >>>       } >>> -} >>> -static void sdhci_am654_write_itapdly(struct sdhci_am654_data >>> *sdhci_am654, >>> -                      u32 itapdly) >>> -{ >>> -    /* Set ITAPCHGWIN before writing to ITAPDLY */ >>> -    regmap_update_bits(sdhci_am654->base, PHY_CTRL4, ITAPCHGWIN_MASK, >>> -               1 << ITAPCHGWIN_SHIFT); >>> -    regmap_update_bits(sdhci_am654->base, PHY_CTRL4, ITAPDLYSEL_MASK, >>> -               itapdly << ITAPDLYSEL_SHIFT); >>> -    regmap_update_bits(sdhci_am654->base, PHY_CTRL4, >>> ITAPCHGWIN_MASK, 0); >>> +    sdhci_am654_write_itapdly(sdhci_am654, >>> sdhci_am654->itap_del_sel[timing]); >>>   } >>>   static void sdhci_am654_setup_delay_chain(struct sdhci_am654_data >>> *sdhci_am654, >>> @@ -298,7 +301,7 @@ static void sdhci_am654_set_clock(struct >>> sdhci_host *host, unsigned int clock) >>>       regmap_update_bits(sdhci_am654->base, PHY_CTRL4, mask, val); >>>       if (timing > MMC_TIMING_UHS_SDR25 && clock >= CLOCK_TOO_SLOW_HZ) { >>> -        sdhci_am654_setup_dll(host, clock); >>> +        sdhci_am654_setup_dll(host, clock, timing); >>>           sdhci_am654->dll_enable = true; >>>       } else { >>>           sdhci_am654_setup_delay_chain(sdhci_am654, timing); > >