Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751611AbcDTXLI (ORCPT ); Wed, 20 Apr 2016 19:11:08 -0400 Received: from mail-db3on0085.outbound.protection.outlook.com ([157.55.234.85]:29795 "EHLO emea01-db3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751150AbcDTXLG convert rfc822-to-8bit (ORCPT ); Wed, 20 Apr 2016 19:11:06 -0400 From: Han Xu To: Yunhui Cui , "dwmw2@infradead.org" , "computersforpeace@gmail.com" , "han.xu@freescale.com" CC: "linux-kernel@vger.kernel.org" , "linux-mtd@lists.infradead.org" , "linux-arm-kernel@lists.infradead.org" , Yao Yuan , "Yunhui Cui" Subject: Re: [PATCH 8/9] mtd: fsl-quadspi: disable AHB buffer prefetch Thread-Topic: [PATCH 8/9] mtd: fsl-quadspi: disable AHB buffer prefetch Thread-Index: AQHRlgI1BG2ejqJW40eJhGVmYE06xJ+Tfj9x Date: Wed, 20 Apr 2016 22:37:21 +0000 Message-ID: References: <1460605855-6689-1-git-send-email-B56489@freescale.com>,<1460605855-6689-9-git-send-email-B56489@freescale.com> In-Reply-To: <1460605855-6689-9-git-send-email-B56489@freescale.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=nxp.com; x-originating-ip: [192.88.168.49] x-ms-office365-filtering-correlation-id: 3677a9e6-a8e7-45d8-3893-08d3696c5685 x-microsoft-exchange-diagnostics: 1;DB5PR0401MB1847;5:S0Z9V1hKZWf0ej562/5ct8sZO74hpDRJX/SWpQsAIP7gyrH0Gw0g4c82JgwicV5z1hfcbjfzeo2DkppAM5d9CKOVswVsZmX0hSPGPGTKoGbXq5m1xQ5mJ0b5fBHkcJE/8GdYAPp0ZTWW2WkVS10qTVgzaa1w99wg7zmk9XTx0SIElB1OaLupt8uOWfv9KLAx;24:QpUV7MC5brjhFVhFyYG4epa58zH9AVT6VjvfpVQnewBdJZUDv3v8+4fmaoPJH5Q9k6gzOO+O9iZwSNyuyF9Y+GTVWTq0f06I92dNG4MvgZE=;7:/9y9wPyfgpSzm5WD6DOI8AihDmSeN4mI2c27bIY65k37bwk10JZRJKt6a20h4PFElFYY0ywMbNLZEOYUuKJMHFJvpWc/r7xWe2XConofiUFam1gCm1tihnC+sZtWieRSu2GC5RU6z8/cPBrsiAQOZKLSYqPIatUxTuW4EVw/9IHtgJbrnFfn0A44/FGZv+dL//O+5LbbeEyXOVJXjo4/dYrvI3uE4SDuD+KGK3L3ybY= x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:DB5PR0401MB1847; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:; x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(9101521026)(601004)(2401047)(8121501046)(5005006)(3002001)(10201501046)(6055026);SRVR:DB5PR0401MB1847;BCL:0;PCL:0;RULEID:;SRVR:DB5PR0401MB1847; x-forefront-prvs: 0918748D70 x-forefront-antispam-report: SFV:NSPM;SFS:(10009020)(6009001)(50944005)(377454003)(5004730100002)(3280700002)(1220700001)(1096002)(3846002)(102836003)(6116002)(2501003)(5003600100002)(586003)(5002640100001)(10400500002)(5001770100001)(106116001)(2906002)(76576001)(81166005)(4326007)(76176999)(54356999)(9686002)(19580405001)(19580395003)(50986999)(86362001)(2201001)(575784001)(33656002)(74316001)(66066001)(77096005)(189998001)(122556002)(3900700001)(5008740100001)(92566002)(3660700001)(2900100001)(2950100001)(87936001)(586874002)(7059030);DIR:OUT;SFP:1101;SCL:1;SRVR:DB5PR0401MB1847;H:DB5PR0401MB1845.eurprd04.prod.outlook.com;FPR:;SPF:None;MLV:sfv;LANG:en; spamdiagnosticoutput: 1:23 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7BIT MIME-Version: 1.0 X-OriginatorOrg: nxp.com X-MS-Exchange-CrossTenant-originalarrivaltime: 20 Apr 2016 22:37:21.6608 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB5PR0401MB1847 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3282 Lines: 79 ________________________________________ From: Yunhui Cui Sent: Wednesday, April 13, 2016 9:50 PM To: dwmw2@infradead.org; computersforpeace@gmail.com; han.xu@freescale.com Cc: linux-kernel@vger.kernel.org; linux-mtd@lists.infradead.org; linux-arm-kernel@lists.infradead.org; Yao Yuan; Yunhui Cui Subject: [PATCH 8/9] mtd: fsl-quadspi: disable AHB buffer prefetch From: Yunhui Cui A-009282: QuadSPI: QuadSPI data pre-fetch can result in incorrect data Affects: QuadSPI Description: With AHB buffer prefetch enabled, the QuadSPI may return incorrect data on the AHB interface. The buffer pre-fetch is enabled if the fetch size as configured either in the LUT or in the BUFxCR register is greater than 8 bytes. Impact: Only 64 bit read allowed. Workaround: Keep the read data size to 64 bits (8 Bytes), which disables the prefetch on the AHB buffer, and prevents this issue from occurring. Signed-off-by: Yunhui Cui --- drivers/mtd/spi-nor/fsl-quadspi.c | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/drivers/mtd/spi-nor/fsl-quadspi.c b/drivers/mtd/spi-nor/fsl-quadspi.c index fea18b6..d9f3e50 100644 --- a/drivers/mtd/spi-nor/fsl-quadspi.c +++ b/drivers/mtd/spi-nor/fsl-quadspi.c @@ -752,19 +752,36 @@ static void fsl_qspi_init_abh_read(struct fsl_qspi *q) { void __iomem *base = q->iobase; int seqid; + const struct fsl_qspi_devtype_data *devtype_data = q->devtype_data; /* AHB configuration for access buffer 0/1/2 .*/ qspi_writel(q, QUADSPI_BUFXCR_INVALID_MSTRID, base + QUADSPI_BUF0CR); qspi_writel(q, QUADSPI_BUFXCR_INVALID_MSTRID, base + QUADSPI_BUF1CR); qspi_writel(q, QUADSPI_BUFXCR_INVALID_MSTRID, base + QUADSPI_BUF2CR); + /* - * Set ADATSZ with the maximum AHB buffer size to improve the - * read performance. + * Errata: A-009282: QuadSPI data prefetch may result in incorrect data + * Workaround: Keep the read data size to 64 bits (8 bytes). + * This disables the prefetch on the AHB buffer and + * prevents this issue from occurring. */ - qspi_writel(q, QUADSPI_BUF3CR_ALLMST_MASK | - ((q->devtype_data->ahb_buf_size / 8) - << QUADSPI_BUF3CR_ADATSZ_SHIFT), - base + QUADSPI_BUF3CR); + if (devtype_data->devtype == FSL_QUADSPI_LS2080A || + devtype_data->devtype == FSL_QUADSPI_LS1021A) { Use QUIRK, not SoC name. + + qspi_writel(q, QUADSPI_BUF3CR_ALLMST_MASK | + (1 << QUADSPI_BUF3CR_ADATSZ_SHIFT), + base + QUADSPI_BUF3CR); + + } else { + /* + * Set ADATSZ with the maximum AHB buffer size to improve the + * read performance. + */ + qspi_writel(q, QUADSPI_BUF3CR_ALLMST_MASK | + ((q->devtype_data->ahb_buf_size / 8) + << QUADSPI_BUF3CR_ADATSZ_SHIFT), + base + QUADSPI_BUF3CR); + } /* We only use the buffer3 */ qspi_writel(q, 0, base + QUADSPI_BUF0IND); -- 2.1.0.27.g96db324