Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp817921ybz; Wed, 22 Apr 2020 08:31:30 -0700 (PDT) X-Google-Smtp-Source: APiQypJhnqeTs7lgTbPYHb3MbEYmtrVaht5RZEifYxXTDRSEx/b5K30hpXWHdRQEK4eTinoSewVQ X-Received: by 2002:a50:cb84:: with SMTP id k4mr24323415edi.89.1587569490452; Wed, 22 Apr 2020 08:31:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587569490; cv=none; d=google.com; s=arc-20160816; b=z2lGjJ4e9LrfNS/7OnY/RUJJ/r4IkhADJfRcfwJMQ65jNWX9FLb5okvvfKLiGGAlJG FN+T1zBqqHE11i3tar4OTkXo2PY1GND6xrLGjGj+UzTTFEZT87bJBCPQ7GE32JW+jkQW 0U15szk+bBENimJVkAuwEwPwSroIieVdoAsM+FIY8Xy9L3ESGfx4TmKW6WUuruf0svEp 4FCmS4PdlttSUIfMqzexiNcP2ikOlq+mJyNMoj+TtZ435eo41Nlo6Qds06+c92dy3T8e 9FC2lvGsnJC33k9eZAVNH0FbFTMpqAWrEzjWG9xfZ1ddrp+B+lfVkkPGk8ujTLZV+tOv C22A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=d7zPCuXJ8t1idTwEDmuFecgNOpkxyKcilAhFQ/qi9MU=; b=xJwqAGbn/qVp7zK+Az0FfM0rCY6e1I4fqpFLfKsBkQ1CFzunKpCnl1bb2itMJHOfIX XN9LY777WyVLYTIlGJ8LjjPd3HUCeqyLD+GXHYbchebf06Y4+2ObCFY2H+X68oBWSTvE PdVzcKiEVMqIflTHPwbFwA7HIkB9bl2EO7NWjSOBcJDdblIa2vO3wxu4roG838+TPfBo ILTM2sXlpmTTP1GlRbD90pAXRiapxrij4oHKVLcb7BpkGETuUbWut02/qkIhKfCbohar FR9GjVRqhaeXmi5mEj8JJl5cYy5dC7Z4rYN+gD8VA/duJbF9RaHS+TB9TrszvoOFR+5n KbQA== ARC-Authentication-Results: i=1; mx.google.com; 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 nj3si3512118ejb.144.2020.04.22.08.31.03; Wed, 22 Apr 2020 08:31:30 -0700 (PDT) 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; 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 S1726161AbgDVP36 (ORCPT + 99 others); Wed, 22 Apr 2020 11:29:58 -0400 Received: from mail-out.m-online.net ([212.18.0.9]:36949 "EHLO mail-out.m-online.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726006AbgDVP36 (ORCPT ); Wed, 22 Apr 2020 11:29:58 -0400 Received: from frontend01.mail.m-online.net (unknown [192.168.8.182]) by mail-out.m-online.net (Postfix) with ESMTP id 496krg2xvLz1qrMW; Wed, 22 Apr 2020 17:29:55 +0200 (CEST) Received: from localhost (dynscan1.mnet-online.de [192.168.6.70]) by mail.m-online.net (Postfix) with ESMTP id 496krg1fS6z1qr44; Wed, 22 Apr 2020 17:29:55 +0200 (CEST) X-Virus-Scanned: amavisd-new at mnet-online.de Received: from mail.mnet-online.de ([192.168.8.182]) by localhost (dynscan1.mail.m-online.net [192.168.6.70]) (amavisd-new, port 10024) with ESMTP id gpc7EwN5kMR7; Wed, 22 Apr 2020 17:29:53 +0200 (CEST) X-Auth-Info: VZnIEV8jQsmO1NWOjpCi2rkjveYliaMIX7iFMxDCgX0= Received: from [IPv6:::1] (unknown [195.140.253.167]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.mnet-online.de (Postfix) with ESMTPSA; Wed, 22 Apr 2020 17:29:53 +0200 (CEST) Subject: Re: [PATCH v2] mtd: rawnand: denali: add more delays before latching incoming data To: Masahiro Yamada , linux-mtd@lists.infradead.org Cc: Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , linux-kernel@vger.kernel.org References: <20200317071821.9916-1-yamada.masahiro@socionext.com> From: Marek Vasut Message-ID: <6093dfab-1e9e-824a-b639-33d340b377f9@denx.de> Date: Wed, 22 Apr 2020 17:29:53 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.5.0 MIME-Version: 1.0 In-Reply-To: <20200317071821.9916-1-yamada.masahiro@socionext.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/17/20 8:18 AM, Masahiro Yamada wrote: > The Denali IP have several registers to specify how many clock cycles > should be waited between falling/rising signals. You can improve the > NAND access performance by programming these registers with optimized > values. > > Because struct nand_sdr_timings represents the device requirement > in pico seconds, denali_setup_data_interface() computes the register > values by dividing the device timings with the clock period. > > Marek Vasut reported this driver in the latest kernel does not work > on his SOCFPGA board. (The on-board NAND chip is mode 5) > > The suspicious parameter is acc_clks, so this commit relaxes it. > > The Denali NAND Flash Memory Controller User's Guide describes this > register as follows: > > acc_clks > signifies the number of bus interface clk_x clock cycles, > controller should wait from read enable going low to sending > out a strobe of clk_x for capturing of incoming data. > > Currently, acc_clks is calculated only based on tREA, the delay on the > chip side. This does not include additional delays that come from the > data path on the PCB and in the SoC, load capacity of the pins, etc. > > This relatively becomes a big factor on faster timing modes like mode 5. > > Before supporting the ->setup_data_interface() hook (e.g. Linux 4.12), > the Denali driver hacks acc_clks in a couple of ways [1] [2] to support > the timing mode 5. > > We would not go back to the hard-coded acc_clks, but we need to include > this factor into the delay somehow. Let's say the amount of the additional > delay is 10000 pico sec. > > In the new calculation, acc_clks is determined by timings->tREA_max + > data_setup_on_host. > > Also, prolong the RE# low period to make sure the data hold is met. > > Finally, re-center the data latch timing for extra safety. > > [1] https://github.com/torvalds/linux/blob/v4.12/drivers/mtd/nand/denali.c#L276 > [2] https://github.com/torvalds/linux/blob/v4.12/drivers/mtd/nand/denali.c#L282 > > Reported-by: Marek Vasut > Signed-off-by: Masahiro Yamada I tested it on the AV SoCFPGA, this seems to work, so feel free to apply.