Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp436984pxj; Fri, 11 Jun 2021 02:59:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzuKc+APVc1xPLV+gUgRJTm9BrMxN4QorfuvhpKCWrSov69T/nnXrFqHSwZ3K9GIEIGXVCn X-Received: by 2002:a17:906:95c8:: with SMTP id n8mr2942865ejy.357.1623405578882; Fri, 11 Jun 2021 02:59:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623405578; cv=none; d=google.com; s=arc-20160816; b=Ow2WLS2yk8K5G6Q2jJvN2xVEBvVmbdKHXyyh8FfNXd+ii7EMgxaML0RNNyG9USO7Vp Og6sPIl3vfN3H/KYKkPmqr4CXz6r/+T9f2ucC2u7fgduR9YDrRsnUEfjxBrPX006P1S4 iyzs4Rc5NbAr5ty7jVQxdUmKf6tZgOJSZjiN+WCRVgGtm668lEhwjl8vlTGG+P2M69ie zZOVlxhk0Zu4Pw+tsmSZ4JHX4ZifBAMZi0mmEcGwe9P54yXxMPNW41GrXA5KVHXZWZCP fRyPSlsFyMYRhJsFPm7vgXsS5Og/1I0Aj0wmERiHqjmfuJvIAbmaH708SaM5nwlbeKsb WAPg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:cc:to:subject:ironport-sdr:ironport-sdr; bh=gJjG50IQF2+kiOVeerCmhZHMfugfJ/cxNbcH7RzS6B0=; b=Pb7TTIe8QL0BbtApExbeURTvgmbalgHc30UPRiTlAfAdEC6/i1Rth0u3B0+c9T+JkK jGAFYHZ9Thh9XCbpime/NCRc68aulrQ4TtzmINTeZ6JUty18/tyFtUCDWE/4yes2wEpi XRWbnN3JqxvmKoRxU4TjlOX2HABxgOIXwPqlHXiBM5iq3gmUzQ+oE5oLKWioDqm0BOQ/ hhn3FjvG5RnvPk+fbECevQ0HHprgoVkuwuM4JMv5i2fuHC3KYNhb1KeIWc3PCCd2iVew u3KLYXbkzStt3ebuZYQ2g6ZGwErQBAeXm5EV9aqOYs4wj8YYz8shtez8mO2RUFBq5F9U k3LA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p16si4779603ejn.173.2021.06.11.02.59.14; Fri, 11 Jun 2021 02:59:38 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231574AbhFKJ5u (ORCPT + 99 others); Fri, 11 Jun 2021 05:57:50 -0400 Received: from mga01.intel.com ([192.55.52.88]:22313 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229633AbhFKJ5t (ORCPT ); Fri, 11 Jun 2021 05:57:49 -0400 IronPort-SDR: Ih0UJKlIcT70ve0x2Vdy4UAeNvErPBn8Fb8n6xQ1qw0FPJ3ZjbJmOAR+LD2E9vXnRHaiDOmDcf 2lRFFHKIo9iA== X-IronPort-AV: E=McAfee;i="6200,9189,10011"; a="226919043" X-IronPort-AV: E=Sophos;i="5.83,265,1616482800"; d="scan'208";a="226919043" Received: from orsmga007.jf.intel.com ([10.7.209.58]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Jun 2021 02:55:50 -0700 IronPort-SDR: qUa36L2aaKIGMlL5OUZWSUUgvFYp/PFy1rMhhXH0ucrC2Eexf9ntJ3hB/7BYKkvDQIVU7JJdSZ 7+L1Zi0c/Ygw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.83,265,1616482800"; d="scan'208";a="441519661" Received: from ahunter-desktop.fi.intel.com (HELO [10.237.72.79]) ([10.237.72.79]) by orsmga007.jf.intel.com with ESMTP; 11 Jun 2021 02:55:48 -0700 Subject: Re: [PATCH] mmc: sdhci: Clear unused bounce buffer at DMA mmap error path To: Takashi Iwai Cc: Ulf Hansson , linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org References: <20210611090330.13039-1-tiwai@suse.de> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki Message-ID: <98f90fcb-1134-f90b-db42-29f9505de046@intel.com> Date: Fri, 11 Jun 2021 12:56:16 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: <20210611090330.13039-1-tiwai@suse.de> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/06/21 12:03 pm, Takashi Iwai wrote: > When DMA-mapping of the bounce buffer fails, the driver tries to fall > back, but it leaves the allocated host->bounce_buffer although its > size is zero. Later on, the driver checks the use of bounce buffer > with host->bounce_buffer pointer, and it tries to use the buffer > incorrectly, resulting in Oops. > > This patch clears the release the unused buffer and clears the > bounce_buffer pointer for addressing the problem. > > Signed-off-by: Takashi Iwai One minor comment below, otherwise: Acked-by: Adrian Hunter > --- > drivers/mmc/host/sdhci.c | 6 +++++- > 1 file changed, 5 insertions(+), 1 deletion(-) > > diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c > index bf238ade1602..5f467b98ca88 100644 > --- a/drivers/mmc/host/sdhci.c > +++ b/drivers/mmc/host/sdhci.c > @@ -4072,9 +4072,13 @@ static void sdhci_allocate_bounce_buffer(struct sdhci_host *host) > bounce_size, > DMA_BIDIRECTIONAL); > ret = dma_mapping_error(mmc_dev(mmc), host->bounce_addr); > - if (ret) > + if (ret) { > + devm_kfree(mmc->parent, host->bounce_buffer); Everywhere else in this function mmc_dev(mmc) is used, so maybe use it here too instead of mmc->parent. > + host->bounce_buffer = NULL; > /* Again fall back to max_segs == 1 */ > return; > + } > + > host->bounce_buffer_size = bounce_size; > > /* Lie about this since we're bouncing */ >