Received: by 10.213.65.68 with SMTP id h4csp836670imn; Tue, 27 Mar 2018 09:40:49 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/syYd2j54mpMpvgVXh+kHLpTv7UId4F4J74XJvGmf6XLd4dxn7yeeNpWviG6zWpa+iOsUt X-Received: by 10.98.247.19 with SMTP id h19mr27252pfi.239.1522168849328; Tue, 27 Mar 2018 09:40:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522168849; cv=none; d=google.com; s=arc-20160816; b=PbuRULms8Tbv/4/fqAb7YbpQ0UZlJpCxgv6n6stKCbe0Rrz7w8wEn/XqT8QRE28KlK /O56O2Fs3BD9R0nYg5nJFoX0NEAk70h3c/F63GnBRGogmJm95wdeaqfndaYO9kHY/I3t WKyKUidG6fUH7Guvvz50AAHi0Xa3lve6neOy4gYDmUmdB+LYJznRQmgazdBptMFMIe3l 0Wf6yry4nKj/rFpaRSUFzpLBwspACQxKZ2nLn/OxPgkXDCKtUssBFwWe0ezn3vBRWDQO r+W+0vLAptnXn5R8deLgA960SKBsOfbeCmk3zzMtYPdle0vR8kwyPCkQuGd4dcxyGQiY MPOg== 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=z/q0YNzgHStp5ARpEPaoYwWgCe/biX3WzzsFb+3cbio=; b=dRa3TJ+KOr41IzINfUFZA4FroZ8NxzPT8TJUT9HZT2MouE99wAi73GPXQTwIUk+FNF zJvaPTBuETOxiGSpfim1CGydzNieIG0zwUrjHlqonj0kkUbqVY1ya1qgJD8ehSmimKoC OXtIVnZwOe9cvwwSabOD3A7Wn+TNrvF08lJFICQ938Y4CDqrOfbM2LAP8eyCBRJICii8 oFaEfnvMqjz6GNm+F+nGufIPrCUTxB33dlon91c0q5L1jnVZ5ms2bGJ97ZzVvZ263woc 8h/dVZs7QrgNXkYmuV+hskpX2kasPJGiThRQwtgC/XRySYwdGjY5k9rsbXPAZaoKfS6H Tqeg== 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 y1-v6si1780855pli.586.2018.03.27.09.40.34; Tue, 27 Mar 2018 09:40:49 -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 S932181AbeC0QjN (ORCPT + 99 others); Tue, 27 Mar 2018 12:39:13 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:47084 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932088AbeC0QjK (ORCPT ); Tue, 27 Mar 2018 12:39:10 -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 5C59D102D; Tue, 27 Mar 2018 16:39:09 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Vineet Gupta , Evgeniy Didin , Andy Shevchenko , Douglas Anderson , Shawn Lin , Jisheng Zhang , Jaehoon Chung , Ulf Hansson Subject: [PATCH 4.15 019/105] mmc: dw_mmc: Fix the DTO/CTO timeout overflow calculation for 32-bit systems Date: Tue, 27 Mar 2018 18:26:59 +0200 Message-Id: <20180327162758.647363258@linuxfoundation.org> X-Mailer: git-send-email 2.16.3 In-Reply-To: <20180327162757.813009222@linuxfoundation.org> References: <20180327162757.813009222@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.15-stable review patch. If anyone has any objections, please let me know. ------------------ From: Evgeniy Didin commit c7151602255a36ba07c84fe2baeef846fdb988b8 upstream. The commit 9d9491a7da2a ("mmc: dw_mmc: Fix the DTO timeout calculation") and commit 4c2357f57dd5 ("mmc: dw_mmc: Fix the CTO timeout calculation") made changes, which cause multiply overflow for 32-bit systems. The broken timeout calculations leads to unexpected ETIMEDOUT errors and causes stacktrace splat (such as below) during normal data exchange with SD-card. | Running : 4M-check-reassembly-tcp-cmykw2-rotatew2.out -v0 -w1 | - Info: Finished target initialization. | mmcblk0: error -110 transferring data, sector 320544, nr 2048, cmd | response 0x900, card status 0x0 DIV_ROUND_UP_ULL helps to escape usage of __udivdi3() from libgcc and so code gets compiled on all 32-bit platforms as opposed to usage of DIV_ROUND_UP when we may only compile stuff on a very few arches. Lets cast this multiply to u64 type to prevent the overflow. Fixes: 9d9491a7da2a ("mmc: dw_mmc: Fix the DTO timeout calculation") Fixes: 4c2357f57dd5 ("mmc: dw_mmc: Fix the CTO timeout calculation") Tested-by: Vineet Gupta Reported-by: Vineet Gupta # ARC STAR 9001306872 HSDK, sdio: board crashes when copying big files Signed-off-by: Evgeniy Didin Cc: # 4.14 Reviewed-by: Andy Shevchenko Reviewed-by: Douglas Anderson Reviewed-by: Shawn Lin Reviewed-by: Jisheng Zhang Acked-by: Jaehoon Chung Signed-off-by: Ulf Hansson Signed-off-by: Greg Kroah-Hartman --- drivers/mmc/host/dw_mmc.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) --- a/drivers/mmc/host/dw_mmc.c +++ b/drivers/mmc/host/dw_mmc.c @@ -413,7 +413,9 @@ static inline void dw_mci_set_cto(struct cto_div = (mci_readl(host, CLKDIV) & 0xff) * 2; if (cto_div == 0) cto_div = 1; - cto_ms = DIV_ROUND_UP(MSEC_PER_SEC * cto_clks * cto_div, host->bus_hz); + + cto_ms = DIV_ROUND_UP_ULL((u64)MSEC_PER_SEC * cto_clks * cto_div, + host->bus_hz); /* add a bit spare time */ cto_ms += 10; @@ -1948,8 +1950,9 @@ static void dw_mci_set_drto(struct dw_mc drto_div = (mci_readl(host, CLKDIV) & 0xff) * 2; if (drto_div == 0) drto_div = 1; - drto_ms = DIV_ROUND_UP(MSEC_PER_SEC * drto_clks * drto_div, - host->bus_hz); + + drto_ms = DIV_ROUND_UP_ULL((u64)MSEC_PER_SEC * drto_clks * drto_div, + host->bus_hz); /* add a bit spare time */ drto_ms += 10;