From patchwork Sat Apr 13 22:14:22 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Andrea della Porta X-Patchwork-Id: 788736 Received: from mail-ed1-f44.google.com (mail-ed1-f44.google.com [209.85.208.44]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 007C955E7B for ; Sat, 13 Apr 2024 22:14:42 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.44 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713046485; cv=none; b=omGAoCsNI4/U7GRWyi2Y3jiZkyw1uglh5uzLLHF+o0djeD0PbSHPKGyTtOfPWNGl1swI6pdry1ue/HpTGwtydKHGeSPQagrEo8EJ9LwhKYkznoKoSNwoLMxs8UICSfdRz4HwIrUJqiiAjggdM4DJV/JDYj9XBpLALc3b62tBkhY= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713046485; c=relaxed/simple; bh=D4cHZTrBFs9Y8i1w0bHj0gtliPoYKudctyXTaCkiaCo=; h=From:To:Subject:Date:Message-ID:MIME-Version; b=Y/0v9W7ffn1/XRNsXIDpC686Jd2pokB/1a50masgPqK9pJepfCy1v4xggWuSWlTcbR7Bwn6Jwkbge7Z9ROrVBaXipDpjbG2D93zSi1yFW3EHaOvQb58Ix5y4y4I8+nDIjunp16FRwk5XXsvcacPtFG0Eqjq2R32pRRL99VPu5cY= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=suse.com; spf=pass smtp.mailfrom=suse.com; dkim=pass (2048-bit key) header.d=suse.com header.i=@suse.com header.b=cYmGkNLk; arc=none smtp.client-ip=209.85.208.44 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=suse.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=suse.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=suse.com header.i=@suse.com header.b="cYmGkNLk" Received: by mail-ed1-f44.google.com with SMTP id 4fb4d7f45d1cf-56fffb1d14bso2735958a12.1 for ; Sat, 13 Apr 2024 15:14:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=google; t=1713046481; x=1713651281; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:from:to:cc:subject:date:message-id:reply-to; bh=bxFqmOp3HshWN+SgF1tbY2QlrStlEk1IWrM1mFhMRAI=; b=cYmGkNLkC/Pyi3/rbbEMfKfekynsdQwk3Co/A5dhbkyMNnT0Z5H/5lsRIZFuny3eBN jrZue4RrcDj+/EsgV4e8bYDwuMcx6DPPBj6z70PPmRLyi3jop/4XyFbBNiosbf+B+6q1 Ii1Mc2akZMWOi9eKsWifK98WWL0B2bQ7JwNdYDc7AxaHPruFfSZeaWsUQUBMPdxMe7e/ zHK32zJSnTywMhA6QxEJC6cLh2gSOeWsc+QGEqWgz9n2WUjm0R7A1z9hxN4BQY0nQGOF D+5v0AwbB+LtXwUqQMddR2rQyS5cgLfAYmohwMh4tAeB0EDespvqvzkD9fizIx7k4Ult X5Ow== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1713046481; x=1713651281; h=content-transfer-encoding:mime-version:message-id:date:subject:to :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=bxFqmOp3HshWN+SgF1tbY2QlrStlEk1IWrM1mFhMRAI=; b=OE/z87+obxaXwR2UB6A0NvelW6IykplW4zszMkv2AiZKCS9pMEiXTjCp8yKZyQqA5J LqivtdjMyTB4ISPzVfaWHDXqFpL3LHHTDs6THwfLofe+jz2cyjuFE3Ng8tT2eYPkEcgI +jOlcEHZAsc5iVFC05vn0iHO0xbvUqJDBsi3xkCDbRrXJuDhjL6ONG8qxRWkiYhhpkwA 3wBF9kKTfTT6IdijLh2NVzhc0dKv5QudOGJypaXI74g90OauQ1zU5yuMd7P1zNJG4Okl q1+Rh82D78YepMkFGrH0BtppBMZzkIjWDYkKaAG3TZdnsTOK8N3pWplvGwJNglbOSUrS 6HXQ== X-Forwarded-Encrypted: i=1; AJvYcCVxskdkh1cNjSg+rgQcup5Q8Sa93JuywO0J/ommOceQB11O4XKwG4XnRGEStErXWZn7wZqRFXajiulajo2j9jtBmGdE2m2H9C0X X-Gm-Message-State: AOJu0YynA6TxH/CxtdYVcnvt3bvfZsOLOGlvu9a4ysJVvM+N2NNRhrLm tCUKp5IR3d9QvTNx3i6p8OrTxAdWUTZK4OabLOeOw9mhf3G1iMYfLPKtutiFwOY= X-Google-Smtp-Source: AGHT+IFcFugdj9bcTWs2YQtc+IVEziRNNY4/ZWW62w81MoufOnOsTtn3loVBBMBQBvaAMW24sH/sXw== X-Received: by 2002:a05:6402:3895:b0:56f:db50:f2ca with SMTP id fd21-20020a056402389500b0056fdb50f2camr8490302edb.4.1713046481310; Sat, 13 Apr 2024 15:14:41 -0700 (PDT) Received: from localhost (host-87-4-160-102.retail.telecomitalia.it. [87.4.160.102]) by smtp.gmail.com with ESMTPSA id b11-20020aa7c6cb000000b0056e7ba0497dsm2976956eds.28.2024.04.13.15.14.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 13 Apr 2024 15:14:41 -0700 (PDT) From: Andrea della Porta To: Ulf Hansson , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Florian Fainelli , Broadcom internal kernel review list , Linus Walleij , Adrian Hunter , Kamal Dasu , Al Cooper , della Porta , linux-mmc@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-gpio@vger.kernel.org, Jonathan Bell , Phil Elwell Subject: [PATCH 0/6] Add support for BCM2712 SD card controller Date: Sun, 14 Apr 2024 00:14:22 +0200 Message-ID: X-Mailer: git-send-email 2.44.0 Precedence: bulk X-Mailing-List: linux-mmc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Hi, This patchset adds support for the SDHCI controller on Broadcom BCM2712 SoC in order to make it possible to boot (particularly) Raspberry Pi 5 from SD card. This work is heavily based on downstream contributions. Patch #1 and 2: introduce the dt binding definitions for, respectively, the new pin cfg/mux controller and the SD host controller as a preparatory step for the upcoming dts. Patch #3: add a somewhat reasonable (*almost* bare-minimum) dts to be used to boot Rpi5 boards. Since till now there was no support at all for any 2712 based chipset, both the SoC and board dts plus definitions for the new Pin and SD host controller have been added. Patch #4: the driver supporting the pin controller. Based on [1] and successive fix commits. Patch #5: add SDHCI support. Based on [2] and the next 2 fix commits. Drop the SD Express implementation for now, that will be added by patch #6. Patch #6: this patch offers SD Express support and can be considered totally optional. The callback plumbing is slightly different w.r.t. the downstream approach (see [3]), as explained in the patch comment. Not sure what is the best, any comment is highly appreciated. Tested succesfully on Raspberry Pi 5 using an SDxC card as the boot device. Still untested: - SD Express due to the lack of an Express capable card. Also, it will need PCIe support first. - card detection pin, since the sd was the booting and root fs device. Many thanks, Andrea Links: [1] - https://github.com/raspberrypi/linux/commit/d9b655314a826724538867bf9b6c229d04c25d84 [2] - https://github.com/raspberrypi/linux/commit/e3aa070496e840e72a4dc384718690ea4125fa6a [3] - https://github.com/raspberrypi/linux/commit/eb1df34db2a9a5b752eba40ee298c4ae87e26e87 Andrea della Porta (6): dt-bindings: pinctrl: Add support for BCM2712 pin controller dt-bindings: mmc: Add support for BCM2712 SD host controller arm64: dts: broadcom: Add support for BCM2712 pinctrl: bcm: Add pinconf/pinmux controller driver for BCM2712 mmc: sdhci-brcmstb: Add BCM2712 support mmc: sdhci-brcmstb: Add BCM2712 SD Express support .../bindings/mmc/brcm,sdhci-brcmstb.yaml | 51 +- .../pinctrl/brcm,bcm2712-pinctrl.yaml | 99 ++ arch/arm64/boot/dts/broadcom/Makefile | 1 + .../boot/dts/broadcom/bcm2712-rpi-5-b.dts | 313 +++++ arch/arm64/boot/dts/broadcom/bcm2712-rpi.dtsi | 81 ++ arch/arm64/boot/dts/broadcom/bcm2712.dtsi | 841 +++++++++++ drivers/mmc/host/Kconfig | 1 + drivers/mmc/host/sdhci-brcmstb.c | 275 ++++ drivers/pinctrl/bcm/Kconfig | 9 + drivers/pinctrl/bcm/Makefile | 1 + drivers/pinctrl/bcm/pinctrl-bcm2712.c | 1247 +++++++++++++++++ 11 files changed, 2918 insertions(+), 1 deletion(-) create mode 100644 Documentation/devicetree/bindings/pinctrl/brcm,bcm2712-pinctrl.yaml create mode 100644 arch/arm64/boot/dts/broadcom/bcm2712-rpi-5-b.dts create mode 100644 arch/arm64/boot/dts/broadcom/bcm2712-rpi.dtsi create mode 100644 arch/arm64/boot/dts/broadcom/bcm2712.dtsi create mode 100644 drivers/pinctrl/bcm/pinctrl-bcm2712.c