Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp2971343pxb; Mon, 17 Jan 2022 09:13:02 -0800 (PST) X-Google-Smtp-Source: ABdhPJx1yZdbBdBBeaT9FWqB8KpW5iCTdfw1vmujjMX7vM5NfsGgj4NHGojF3QBYAQxB8Qe9sFWt X-Received: by 2002:a17:90b:3a83:: with SMTP id om3mr15216256pjb.110.1642439581796; Mon, 17 Jan 2022 09:13:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642439581; cv=none; d=google.com; s=arc-20160816; b=junW0PjPPRv24Utc43DUjdgx6XLm77PaAWlYoeQkHbjhWcdlxcZLjIuLfr++BM+x4v Qu2Sqlu+ujlMK95UJDXk0DeyBxebxSAq/Keshv6q+xm9y8wWO2KJogJEKOtEfRlezeV+ BNpBQZdzVNsqkH7WR1I7frFBC79ENFUhyEvVIm7TJs17XZLrYAk6E52NCRy90CX/ucLo 3WD7qRMYmdxA/85wTCPMqxuA63fsCefi5X6tjBFwuWrj6i9FDmDNjJD1E6LsFkJIOleX f1s6Idqj39hFokT7AZzy7Z1cPeJUU5IPUzAO/A0ugY+CjxAdPskujXdUanVBIWpfAB8i gCGg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=Gk6v+zkr/8Bz9MIGt4fGPVyLyGj2QkozkhBTdVX/PUo=; b=f6Q6K2ahUPhfbY7EXvbXan0JuHGD8L6gWX/uompZ92dglnCNah5vTamPymO2k9Fvcb I8tEQQD1Bhub0j+HVcroozFhFyv9bcZfrrPzWI4R32p+PSyC4SZyncFdtCHUtgPkWnZt Mo5bGP/MOk1IhofRwbHRG6fKcdZxertHa4Tx546HGsL1uemK8030CiCajyEVaYFLJyDB pjxz+vfe8T3Nc+omVC71WQ2YS5zGm34oYZIFubiFq9AHkw+5QBh8AMz9VdXT+xuetSVL ZLvJZH1MexdguJjcF6Du3ox9zCwFDOha2Uh90PVv6tAsGwao+Kh/QbeBOoDAxfMjo3lw qZng== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=VIXTBpMj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e12si14652964pgm.823.2022.01.17.09.12.49; Mon, 17 Jan 2022 09:13:01 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=VIXTBpMj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238992AbiAQLSn (ORCPT + 99 others); Mon, 17 Jan 2022 06:18:43 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51098 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236728AbiAQLSj (ORCPT ); Mon, 17 Jan 2022 06:18:39 -0500 Received: from mail-ed1-x52c.google.com (mail-ed1-x52c.google.com [IPv6:2a00:1450:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2FAE6C06173F for ; Mon, 17 Jan 2022 03:18:39 -0800 (PST) Received: by mail-ed1-x52c.google.com with SMTP id m4so63982342edb.10 for ; Mon, 17 Jan 2022 03:18:39 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Gk6v+zkr/8Bz9MIGt4fGPVyLyGj2QkozkhBTdVX/PUo=; b=VIXTBpMjhqZKt4rQ3FtVXzMnmqezrKxs8k1eSDAutK1Jfyt7mC1LZ7DYG5m4sXOeYE K94/xRWf2H3fKlAcYXE4wuT6fRf8oiALFqZaYyy3N5mNLpqL9tX+SAmcHQHkhIFd2EZm 3CkbiYwRHinLAv3PxmapAgT73USBoOxYY/nb4= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Gk6v+zkr/8Bz9MIGt4fGPVyLyGj2QkozkhBTdVX/PUo=; b=lRtnUWD2MWruZh07HBD26OhNhOK5zOTo5VqLcvrxPFpJO9QLqIXhute6KVFogW+LDK FGKgAtV1MOMAq95vv7c/vrVFKlBAHCVG7LXAlPJ+tgRIov5KnllNZmNXJxclNHiTDz8k 4GBbsAhaqZE14TIsWFn5Ix5PFUx8QVqLH+WgKgo+PoMgGZ0LIseQJ8qR8cAczFMBApHF 7NS9IoT7QH11LoS8eMlEg0lNlbWZxzq4k3gkrn+QX+UMi4qwANGnRXDBvBMQtIdHXLyY lPObYKkxh9vs21cI9FugXyv3x2+9C6biQiKH7LYhPFEw0bkLcQF/CJN6zw0FRuegtePU xvbQ== X-Gm-Message-State: AOAM533DT64j1v+UJu7IwOxxG3cum7cODTrM07Grbx1tp8MQ8MX+YzSD 3GXaRb03IyC6b1tKXXTj842D5XBU79KC5g== X-Received: by 2002:a17:906:49c4:: with SMTP id w4mr16071378ejv.745.1642418317529; Mon, 17 Jan 2022 03:18:37 -0800 (PST) Received: from dario-ThinkPad-T14s-Gen-2i.homenet.telecomitalia.it (host-82-52-8-210.retail.telecomitalia.it. [82.52.8.210]) by smtp.gmail.com with ESMTPSA id f11sm5142713edv.67.2022.01.17.03.18.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 17 Jan 2022 03:18:37 -0800 (PST) From: Dario Binacchi To: linux-kernel@vger.kernel.org Cc: Michael Trimarchi , Dario Binacchi , Han Xu , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , linux-mtd@lists.infradead.org Subject: [RFC PATCH v2 3/5] mtd: rawnand: gpmi: use a table to get EDO mode setup Date: Mon, 17 Jan 2022 12:18:27 +0100 Message-Id: <20220117111829.1811997-4-dario.binacchi@amarulasolutions.com> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20220117111829.1811997-1-dario.binacchi@amarulasolutions.com> References: <20220117111829.1811997-1-dario.binacchi@amarulasolutions.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is a preparation patch for the upcoming validation of the GPMI controller clock rate. Co-developed-by: Michael Trimarchi Signed-off-by: Michael Trimarchi Signed-off-by: Dario Binacchi --- Changes in v2: - Add the patch to the series. drivers/mtd/nand/raw/gpmi-nand/gpmi-nand.c | 43 +++++++++++++++------- 1 file changed, 30 insertions(+), 13 deletions(-) diff --git a/drivers/mtd/nand/raw/gpmi-nand/gpmi-nand.c b/drivers/mtd/nand/raw/gpmi-nand/gpmi-nand.c index 73c3bf59b55e..4ac695aa5131 100644 --- a/drivers/mtd/nand/raw/gpmi-nand/gpmi-nand.c +++ b/drivers/mtd/nand/raw/gpmi-nand/gpmi-nand.c @@ -570,6 +570,27 @@ static int bch_set_geometry(struct gpmi_nand_data *this) return ret; } +struct edo_mode { + u32 tRC_min; + long clk_rate; + u8 wrn_dly_sel; +}; + +static const struct edo_mode edo_modes[] = { + {.tRC_min = 30000, .clk_rate = 22000000, + .wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_4_TO_8NS}, + {.tRC_min = 30000, .clk_rate = 22000000, + .wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_4_TO_8NS}, + {.tRC_min = 30000, .clk_rate = 22000000, + .wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_4_TO_8NS}, + {.tRC_min = 30000, .clk_rate = 22000000, + .wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_4_TO_8NS}, + {.tRC_min = 25000, .clk_rate = 80000000, + .wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_NO_DELAY}, + {.tRC_min = 20000, .clk_rate = 100000000, + .wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_NO_DELAY}, +}; + /* * <1> Firstly, we should know what's the GPMI-clock means. * The GPMI-clock is the internal clock in the gpmi nand controller. @@ -657,22 +678,18 @@ static void gpmi_nfc_compute_timings(struct gpmi_nand_data *this, int sample_delay_ps, sample_delay_factor; u16 busy_timeout_cycles; u8 wrn_dly_sel; + int i, emode = ARRAY_SIZE(edo_modes) - 1; - if (sdr->tRC_min >= 30000) { - /* ONFI non-EDO modes [0-3] */ - hw->clk_rate = 22000000; - wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_4_TO_8NS; - } else if (sdr->tRC_min >= 25000) { - /* ONFI EDO mode 4 */ - hw->clk_rate = 80000000; - wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_NO_DELAY; - } else { - /* ONFI EDO mode 5 */ - hw->clk_rate = 100000000; - wrn_dly_sel = BV_GPMI_CTRL1_WRN_DLY_SEL_NO_DELAY; + /* Search the required EDO mode */ + for (i = 0; i < ARRAY_SIZE(edo_modes); i++) { + if (sdr->tRC_min >= edo_modes[i].tRC_min) { + emode = i; + break; + } } - hw->clk_rate = clk_round_rate(r->clock[0], hw->clk_rate); + hw->clk_rate = clk_round_rate(r->clock[0], edo_modes[emode].clk_rate); + wrn_dly_sel = edo_modes[emode].wrn_dly_sel; /* SDR core timings are given in picoseconds */ period_ps = div_u64((u64)NSEC_PER_SEC * 1000, hw->clk_rate); -- 2.32.0