Received: by 10.223.185.116 with SMTP id b49csp4785591wrg; Tue, 27 Feb 2018 02:33:57 -0800 (PST) X-Google-Smtp-Source: AH8x225WxGG0ULBtiaeLyncLHQr0S1NfP3p6bWVbuQKehNkD3u9XjCP46gQ8bTATt+qgMpWMTR96 X-Received: by 10.167.130.133 with SMTP id s5mr13536457pfm.238.1519727637304; Tue, 27 Feb 2018 02:33:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519727637; cv=none; d=google.com; s=arc-20160816; b=NTNSgueCU++hgQbcZKxEO4AAYCytz/aW+l3oVockpnqx5Peu526GsaVi7duj4av6ao UTk2bENjGDx0AwsJEdA5Bap494oQ1zj4Qb/qrit2eIe4LSRdhrfuJmHELAh4w1cjZKX4 m1eXCFs/OEnkua1dRu1sJuOet1BMBaVCy/TDQptw2knLV6GjEWV7R4Q167xmDek2m5ju 1XQkRcLKqhOgvQSle5eAyaWBbMtCgYuZMO/ueA3E0SwgyQ5Q8mKeF89msgdgmfSihiYJ eWxx0rb5JskhfG6i7flW66AQN54+7OaXVnkW3fiK+y9dFK9jq+nc7w6KO2dk+RAO7UUs aeAw== 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:organization:from:cc:references:to:subject :arc-authentication-results; bh=felOUvNT31R937Eue70wACesg/Cx8Q+qSicdq35SczA=; b=I3PlxdEJnjdifUyleMI9jKD4YBwMIZ6li45Ag0oWuM48MmNcoYEjtXrYMwWLV3bs/C lvdNzUpAoPuAaOSHMig1wtSY2pYuzz0lQDvmZMihwrc+cgq/lW3uNutcMgrAHnrdfQ6I BkMhLWZSq2isIn4qVMB+JsZPwGPNVzUMwqxRZIrdCb4PxSKKpJTn0CkfTbPKDMSkKQwI sc7ML3VZgBP4YMij1nY2Xq6ttdAlTer6GbsO8GEALS7gV5aCF05yvMklyisxsm3kIycn 0naLbtvJOBg56a2Do6MBOqLjexlpY1/2+/EeVEB8fow5V+dc0MIiYrehDDfCa4D2ma9V YcLw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x6si1662456pgp.254.2018.02.27.02.33.43; Tue, 27 Feb 2018 02:33:57 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752811AbeB0KcU (ORCPT + 99 others); Tue, 27 Feb 2018 05:32:20 -0500 Received: from esa6.microchip.iphmx.com ([216.71.154.253]:33877 "EHLO esa6.microchip.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752751AbeB0KcT (ORCPT ); Tue, 27 Feb 2018 05:32:19 -0500 X-IronPort-AV: E=Sophos;i="5.47,400,1515481200"; d="scan'208";a="9191059" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa6.microchip.iphmx.com with ESMTP/TLS/DHE-RSA-AES256-SHA; 27 Feb 2018 03:32:19 -0700 Received: from [10.159.245.112] (10.10.76.4) by chn-sv-exch04.mchp-main.com (10.10.76.105) with Microsoft SMTP Server id 14.3.352.0; Tue, 27 Feb 2018 03:32:18 -0700 Subject: Re: [PATCH] spi: atmel: init FIFOs before spi enable To: Eugen Hristev , References: <1519727107-5821-1-git-send-email-eugen.hristev@microchip.com> CC: , , From: Nicolas Ferre Organization: microchip Message-ID: <9650154b-c0b4-48aa-1c98-8d86aa834202@microchip.com> Date: Tue, 27 Feb 2018 11:29:33 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <1519727107-5821-1-git-send-email-eugen.hristev@microchip.com> Content-Type: text/plain; charset="utf-8"; format=flowed 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 27/02/2018 at 11:25, Eugen Hristev wrote: > The datasheet recommends initializing FIFOs before > SPI enable. If we do not do it like this, there may be > a strange behavior. We noticed that DMA does not work properly > with FIFOs if we do not clear them beforehand or enable them > before SPIEN. > > Signed-off-by: Eugen Hristev Ok, good: Acked-by: Nicolas Ferre > --- > drivers/spi/spi-atmel.c | 8 +++++--- > 1 file changed, 5 insertions(+), 3 deletions(-) > > diff --git a/drivers/spi/spi-atmel.c b/drivers/spi/spi-atmel.c > index 6694709..0478758 100644 > --- a/drivers/spi/spi-atmel.c > +++ b/drivers/spi/spi-atmel.c > @@ -1489,6 +1489,11 @@ static void atmel_spi_init(struct atmel_spi *as) > { > spi_writel(as, CR, SPI_BIT(SWRST)); > spi_writel(as, CR, SPI_BIT(SWRST)); /* AT91SAM9263 Rev B workaround */ > + > + /* It is recommended to enable FIFOs first thing after reset */ > + if (as->fifo_size) > + spi_writel(as, CR, SPI_BIT(FIFOEN)); > + > if (as->caps.has_wdrbt) { > spi_writel(as, MR, SPI_BIT(WDRBT) | SPI_BIT(MODFDIS) > | SPI_BIT(MSTR)); > @@ -1499,9 +1504,6 @@ static void atmel_spi_init(struct atmel_spi *as) > if (as->use_pdc) > spi_writel(as, PTCR, SPI_BIT(RXTDIS) | SPI_BIT(TXTDIS)); > spi_writel(as, CR, SPI_BIT(SPIEN)); > - > - if (as->fifo_size) > - spi_writel(as, CR, SPI_BIT(FIFOEN)); > } > > static int atmel_spi_probe(struct platform_device *pdev) > -- Nicolas Ferre