Received: by 10.192.165.156 with SMTP id m28csp1086397imm; Wed, 11 Apr 2018 12:08:59 -0700 (PDT) X-Google-Smtp-Source: AIpwx48qiiAGgV3XQ0deiDvJP6UKtr5tuFX2sUQM9xjopTzFffhNO0McehL9xOFVmJjBzLWtI3mG X-Received: by 2002:a17:902:8481:: with SMTP id c1-v6mr6346947plo.310.1523473739013; Wed, 11 Apr 2018 12:08:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523473738; cv=none; d=google.com; s=arc-20160816; b=a1+fMlSkP0x2XM0vY6oCA2VDpa4by3Jx1beP/2viAfzRqMyG3BO+NMLk0XxTyU5mZy oV2DoccervguP1FH2yskNJi2T0eBHjHx/yIJz/JOAJms8jYgZz7rBFBNweX6c2/TvUMB /H4SPvKFHD6uNboc8YZasNz346IyZ0QL7xHbY/YqeuHeCK5fQazEnwcd+7/ztVY5Fn6Q 0E/SAAPTHHd2mJ0ELpIAB5ATg1Gf9DPdBWNslzPgYZ+PSFU6l6Ibz0zM9EMfyqaTZ7DL +2FlVSl6wS6CqT11aPJHJqd78GEsenjjb782M1Z3l5tQUOmd38cmO2hOJfhggvuA5Iuv 85kg== 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=F3BUbkYsi85oixU9azxZ+L4/xJK+4/b84rSughmOeq0=; b=OOvIf8t31ucKaGnh3CuNB/I2XL7Q0AK4YftdaKQtXyk/6BARaMwltrqImatgVTiE54 CzZB4S1QaDSBmLxLiwqQ3oUDIrsL5BncP22n5ngOY8LIwWZI40pQfCajcstABYdmMPqe 7EcsA6FRdXKMeP3kMgID3CcC4pmcC0oA9icxkarnrHe0tHURhXLptmLeM7X7mRbcgZKR fEhzMpmklIiCjswRLQ5hUUunTlI16Y7z6YPL/Fdb0+e+/YOgI2/Lb4Gv5329V2CEBgQ1 H/UPgrktWSZeTbbZTsHsH6vpxpj0uGcETNw2Vfw1DvAOMdsjz+zioBrkdr55fl3ZtHjo XPzg== 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 w6si1098701pgp.496.2018.04.11.12.08.22; Wed, 11 Apr 2018 12:08:58 -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 S934908AbeDKTEt (ORCPT + 99 others); Wed, 11 Apr 2018 15:04:49 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:40024 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934145AbeDKTEq (ORCPT ); Wed, 11 Apr 2018 15:04:46 -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 5E5A23EE; Wed, 11 Apr 2018 19:04:45 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andy Shevchenko , Adrian Hunter , Ulf Hansson , Sasha Levin Subject: [PATCH 4.9 266/310] sdhci: Advertise 2.0v supply on SDIO host controller Date: Wed, 11 Apr 2018 20:36:45 +0200 Message-Id: <20180411183634.103205303@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180411183622.305902791@linuxfoundation.org> References: <20180411183622.305902791@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.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Andy Shevchenko [ Upstream commit 2a609abe71ca59e4bd7139e161eaca2144ae6f2e ] On Intel Edison the Broadcom Wi-Fi card, which is connected to SDIO, requires 2.0v, while the host, according to Intel Merrifield TRM, supports 1.8v supply only. The card announces itself as mmc2: new ultra high speed DDR50 SDIO card at address 0001 Introduce a custom OCR mask for SDIO host controller on Intel Merrifield and add a special case to sdhci_set_power_noreg() to override 2.0v supply by enforcing 1.8v power choice. Signed-off-by: Andy Shevchenko Acked-by: Adrian Hunter Signed-off-by: Ulf Hansson Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- drivers/mmc/host/sdhci-pci-core.c | 2 ++ drivers/mmc/host/sdhci.c | 7 +++++++ 2 files changed, 9 insertions(+) --- a/drivers/mmc/host/sdhci-pci-core.c +++ b/drivers/mmc/host/sdhci-pci-core.c @@ -492,6 +492,8 @@ static int intel_mrfld_mmc_probe_slot(st slot->host->quirks2 |= SDHCI_QUIRK2_NO_1_8_V; break; case INTEL_MRFLD_SDIO: + /* Advertise 2.0v for compatibility with the SDIO card's OCR */ + slot->host->ocr_mask = MMC_VDD_20_21 | MMC_VDD_165_195; slot->host->mmc->caps |= MMC_CAP_NONREMOVABLE | MMC_CAP_POWER_OFF_CARD; break; --- a/drivers/mmc/host/sdhci.c +++ b/drivers/mmc/host/sdhci.c @@ -1404,6 +1404,13 @@ void sdhci_set_power_noreg(struct sdhci_ if (mode != MMC_POWER_OFF) { switch (1 << vdd) { case MMC_VDD_165_195: + /* + * Without a regulator, SDHCI does not support 2.0v + * so we only get here if the driver deliberately + * added the 2.0v range to ocr_avail. Map it to 1.8v + * for the purpose of turning on the power. + */ + case MMC_VDD_20_21: pwr = SDHCI_POWER_180; break; case MMC_VDD_29_30: