Received: by 10.213.65.68 with SMTP id h4csp889372imn; Tue, 27 Mar 2018 10:38:36 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+oIkCaLpPKvdHVIHpvBFb4sE1XJ+a5ppbJPlVV90E/Q5ZaHbdelBMv3TO9Id3/QGHFQwn+ X-Received: by 10.98.32.80 with SMTP id g77mr200785pfg.216.1522172316458; Tue, 27 Mar 2018 10:38:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522172316; cv=none; d=google.com; s=arc-20160816; b=bGgJSHDj1ebl4ywjM+5MX3x2raS6BFO0VHohlHhY6U5YVH2w/V5reChQYi8rsfXzrR 9egDUX81V2BhGMKw2AVTKjWvRJ3xiEyxWCCDFOm74uAMUWwpK/RrykzYzhSQZnxl3S1o 3HKMSwTlYLxJuRQdUx2f0P3G+9ABj++yol1L/csRsZKJXo8//EpTzBoz1V8HNq6MHcsu tZEUlAHXvzOtzHclXws0z5F3TecT73MBKpwPDrTsspMA/ObIljXxdEmQ6B+ZMk/y0fC1 1owqrM0InBKFVhoKmtxGzySt47MizwxIwQ/OyhUvEAP/slh1Tjt7rBT5hEyE1GMlOr+a WUDg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=ii1DYBs9MhNkgSB5sAhhBg8jrm9RqWFM6Hrd1pzJPQc=; b=PZSJ0EwzbVVLU6iv9ENvDNbkcgcberJhHMQkKfD+/xqTzSMN0zcJXJUARq+qAEb/bc Ik460MELvwyWgRCDEwcPMgLgDy68fcewsy14ao4XpQXQkLu9usETKSru0dwWvIePKPll EWlyWHs8YLbUYkPsanVFmKqG8HKqsdQImAHdRVFjQftB8qJs0AQCkr50Zf+19iaYxihb v1ZRuju95Hd5+F5lnRYRN1orUjiVhEyVEIs8YPbd5S4EPtw1SoCu/sq08SgISm8VpNLO yZD3hNCAhttsQLxwA7ojfDwdDs2BL68S7VSA4py1nWZHYMvbzKQ+OdlZ7conp8H0V67A 4jrw== 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 o69si1221539pfj.329.2018.03.27.10.38.21; Tue, 27 Mar 2018 10:38:36 -0700 (PDT) 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 S1754500AbeC0Rgy (ORCPT + 99 others); Tue, 27 Mar 2018 13:36:54 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:44530 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754314AbeC0Qes (ORCPT ); Tue, 27 Mar 2018 12:34:48 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 4C2321226; Tue, 27 Mar 2018 16:34:47 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Evgeniy Didin , Jaehoon Chung , Ulf Hansson , Andy Shevchenko , Jisheng Zhang , Shawn Lin , Alexey Brodkin , Eugeniy Paltsev , linux-snps-arc@lists.infradead.org Subject: [PATCH 4.14 021/101] mmc: dw_mmc: fix falling from idmac to PIO mode when dw_mci_reset occurs Date: Tue, 27 Mar 2018 18:26:53 +0200 Message-Id: <20180327162751.275889617@linuxfoundation.org> X-Mailer: git-send-email 2.16.3 In-Reply-To: <20180327162749.993880276@linuxfoundation.org> References: <20180327162749.993880276@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Evgeniy Didin commit 47b7de2f6c18f75d1f2716efe752cba43f32a626 upstream. It was found that in IDMAC mode after soft-reset driver switches to PIO mode. That's what happens in case of DTO timeout overflow calculation failure: 1. soft-reset is called 2. driver restarts dma 3. descriptors states are checked, one of descriptor is owned by the IDMAC. 4. driver can't use DMA and then switches to PIO mode. Failure was already fixed in: https://www.spinics.net/lists/linux-mmc/msg48125.html. Behaviour while soft-reset is not something we except or even want to happen. So we switch from dw_mci_idmac_reset to dw_mci_idmac_init, so descriptors are cleaned before starting dma. And while at it explicitly zero des0 which otherwise might contain garbage as being allocated by dmam_alloc_coherent(). Signed-off-by: Evgeniy Didin Cc: Jaehoon Chung Cc: Ulf Hansson Cc: Andy Shevchenko Cc: Jisheng Zhang Cc: Shawn Lin Cc: Alexey Brodkin Cc: Eugeniy Paltsev Cc: linux-snps-arc@lists.infradead.org Cc: # 4.4+ Signed-off-by: Ulf Hansson Signed-off-by: Greg Kroah-Hartman --- drivers/mmc/host/dw_mmc.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) --- a/drivers/mmc/host/dw_mmc.c +++ b/drivers/mmc/host/dw_mmc.c @@ -564,6 +564,7 @@ static int dw_mci_idmac_init(struct dw_m (sizeof(struct idmac_desc_64addr) * (i + 1))) >> 32; /* Initialize reserved and buffer size fields to "0" */ + p->des0 = 0; p->des1 = 0; p->des2 = 0; p->des3 = 0; @@ -586,6 +587,7 @@ static int dw_mci_idmac_init(struct dw_m i++, p++) { p->des3 = cpu_to_le32(host->sg_dma + (sizeof(struct idmac_desc) * (i + 1))); + p->des0 = 0; p->des1 = 0; } @@ -1801,8 +1803,8 @@ static bool dw_mci_reset(struct dw_mci * } if (host->use_dma == TRANS_MODE_IDMAC) - /* It is also recommended that we reset and reprogram idmac */ - dw_mci_idmac_reset(host); + /* It is also required that we reinit idmac */ + dw_mci_idmac_init(host); ret = true;