From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 93A13C369C2 for ; Sat, 26 Apr 2025 01:16:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Type:Cc:To:Subject: Message-ID:Date:MIME-Version:In-Reply-To:References:From:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=034y+j6rfKKAiZX1DICXtWOFgjtHAUTobsF8AzSrZ2U=; b=4xUSydhC1+oMkQtRqQhDxT6HnD Z417rGWnZEptfGqN3/i0sMzG2oV8C8P07QWumyz+MDMiL5vPo1l70QGPpAkCWXwd9SBojv9Hc+J4/ e3B7rjVAu3Y299KVSzb4gPIAtMFDqAEnX/N2U5x9rKYK4OjKK1e3TAvBRtSkAgFBVOWg5SVfNfAJ6 nhVj4938ASpn0tv7oAhUWV5kzbyn7s+EpyMtFD+KhXVGXaXuuRSlBvCWANrQ1O7oVXo5OUo4X6Vst jJeTntow+0aFPPweJ+r9UNcMvG1I9pmJLm0ZnL8ad7gO/+axFzFqeX6ItH51DahTkdM/C1sJXB3U3 zpVruA2w==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux)) id 1u8U9D-00000001F00-1wIV; Sat, 26 Apr 2025 01:16:03 +0000 Received: from mail-vk1-xa34.google.com ([2607:f8b0:4864:20::a34]) by bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux)) id 1u8U6j-00000001Eif-31Or for linux-arm-kernel@lists.infradead.org; Sat, 26 Apr 2025 01:13:31 +0000 Received: by mail-vk1-xa34.google.com with SMTP id 71dfb90a1353d-528ce9730cfso1076655e0c.3 for ; Fri, 25 Apr 2025 18:13:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; t=1745630008; x=1746234808; darn=lists.infradead.org; h=cc:to:subject:message-id:date:thread-index:mime-version:in-reply-to :references:from:from:to:cc:subject:date:message-id:reply-to; bh=034y+j6rfKKAiZX1DICXtWOFgjtHAUTobsF8AzSrZ2U=; b=Yg3bGx9p9zJOtqblg/RkGnSOahTTw8PVs9UW4sIKeHx0VOsiejFvmO0n2XCdMqynjH +jVjK2hoPynO01nR0olVwdORjW4lrJssYzbqgb5jY1KuG1zG7Xsw5JuB+rJfODBOk1TC 2TLs262G3HsQWgbXdlrcfdaCp2RiQDnEjfn+w= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1745630008; x=1746234808; h=cc:to:subject:message-id:date:thread-index:mime-version:in-reply-to :references:from:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=034y+j6rfKKAiZX1DICXtWOFgjtHAUTobsF8AzSrZ2U=; b=GpPGLPVtRd0EZ/tmpyebt12z90zqNSf8UNTj1NwHQZfrlZ73lv4Iqz6DZ+FAmntWPN UPBC0jn3e6uwSAQVcZvDkp5ewh4G16lyYbj4l5ChLsEExvN9POr7wSi08l0h7YiUtdF3 C8pX9PbrU1dezeedC6T/UVy672III6EC6b+IHDaRJoy0vT2wXKC/W8lRBvg53jan9Ld3 YKrwOmHFoMF6oQWGaD0RetQNw/1ybJKMFB0eaWrSR3lATP/MMfmALdJL807lA0fuIuzD FOlZ0HgxMzpnsz/wUCVZzipu81RUIeTI3UTNUVbwO5aqAhQQp2WE8+hqMzCbHqA/9rvr cjZg== X-Forwarded-Encrypted: i=1; AJvYcCU9JxfCt1vFv9WPXbKTtIKrpC2n1SgEVyppedk3Fkh/S5NYrTM9xERh/q0gL6/wkR8jMGc++g08bFeAKzQsKM5D@lists.infradead.org X-Gm-Message-State: AOJu0YwlwJapMXN1PMHI9ZTXrXKl8no0D1w+2tt2JcizXu2I0Tc1EvX1 zF0IgkDikDtqauj74xtmaqvvPZjlbeDhWF3xzmlP/f7cIU32PdLSjByzvPuv75PHJca3DJarf3d jpLuF9yk0SFGPGwqVNp9vj4FXweIXMwspO0+T X-Gm-Gg: ASbGncthix2qnNLrcwGobghewvV60QWZU322RUcExpK3e07A4blzVg2LYS1kWA2epG9 AHvYq5sBfReUhAAcF5ABjGMe0+voLfPuIWFO0+5MalRjyfXrss1PvpzSII4YG2EYejLwgiPQc56 fqSNih27sRED7QDhr4j4dTlXlLbWWrPBZMnw== X-Google-Smtp-Source: AGHT+IGDZ9/Feuo8TT79yyf/erpihB9wYIENSdaLEF3c7ll4Nfsef2mCZ8pCsTAr4iQCA3R7DK0CEnmllMp/ho77BrU= X-Received: by 2002:a05:6122:6594:b0:528:bd71:8a8e with SMTP id 71dfb90a1353d-52a9702836fmr1276952e0c.5.1745630008563; Fri, 25 Apr 2025 18:13:28 -0700 (PDT) From: William Zhang References: <20250406-bcmbca-peripherals-arm-v2-0-22130836c2ed@linaro.org> <20250406-bcmbca-peripherals-arm-v2-10-22130836c2ed@linaro.org> In-Reply-To: <20250406-bcmbca-peripherals-arm-v2-10-22130836c2ed@linaro.org> MIME-Version: 1.0 X-Mailer: Microsoft Outlook 16.0 Thread-Index: AQKk0Iba5S5vFfMGFNn0Sizjy9mbxwGNeTBIshaDuYA= Date: Fri, 25 Apr 2025 18:13:26 -0700 X-Gm-Features: ATxdqUEF7QswsDYWIT62tPu1PtoOui55cYiegvw85UKL9KXHn190j7XDU4dnIqE Message-ID: <62fd647b4c1ba40747b164da49288216@mail.gmail.com> Subject: RE: [PATCH v2 10/12] ARM64: dts: bcm6856: Add BCMBCA peripherals To: Linus Walleij , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Anand Gore , Kursad Oney , Florian Fainelli , =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , Broadcom internal kernel review list , Olivia Mackall , Ray Jui , Scott Branden , Florian Fainelli Cc: devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-crypto@vger.kernel.org Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-256; boundary="00000000000096a1400633a428f0" X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250425_181329_767318_8DF84B0C X-CRM114-Status: GOOD ( 21.76 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org --00000000000096a1400633a428f0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable > -----Original Message----- > From: Linus Walleij > Sent: Sunday, April 6, 2025 8:33 AM > To: Rob Herring ; Krzysztof Kozlowski > ; > Conor Dooley ; William Zhang > ; Anand Gore ; > Kursad Oney ; Florian Fainelli > ; Rafa=C5=82 Mi=C5=82ecki ; > Broadcom > internal kernel review list ; > Olivia > Mackall ; Ray Jui ; Scott Branden > ; Florian Fainelli > Cc: devicetree@vger.kernel.org; linux-arm-kernel@lists.infradead.org; > linux- > crypto@vger.kernel.org; Linus Walleij > Subject: [PATCH v2 10/12] ARM64: dts: bcm6856: Add BCMBCA peripherals > > All the BCMBCA SoCs share a set of peripherals at 0xff800000, > albeit at slightly varying memory locations on the bus and > with varying IRQ assignments. ARM64 SoCs have additional > peripherals at 0xff858000. On BCM6856 the PERF window was > too big so adjust it down to its real size (0x3000) and add > another window for PERF1 at 0xff858000. > > Add the watchdog, GPIO blocks, RNG, LED, second UART and DMA > blocks for the BCM6856 based on the vendor files 6856_map_part.h > and 6856_intr.h from the "bcmopen-consumer" code drop. > > This SoC has up to 256 possible GPIOs due to having 8 > registers with 32 GPIOs in each available. > > Signed-off-by: Linus Walleij > --- > arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi | 138 > ++++++++++++++++++++++- > 1 file changed, 137 insertions(+), 1 deletion(-) > > diff --git a/arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi > b/arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi > index > 00c62c1e5df00c722884a7adfcb7be08a43c0dc3..d6d0b8e1a65b494be414dd584 > 1b65f8ff489d684 100644 > --- a/arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi > +++ b/arch/arm64/boot/dts/broadcom/bcmbca/bcm6856.dtsi > @@ -93,11 +93,103 @@ gic: interrupt-controller@1000 { > }; > }; > > + /* PERF Peripherals */ > bus@ff800000 { > compatible =3D "simple-bus"; > #address-cells =3D <1>; > #size-cells =3D <1>; > - ranges =3D <0x0 0x0 0xff800000 0x800000>; > + ranges =3D <0x0 0x0 0xff800000 0x3000>; > + > + watchdog@480 { > + compatible =3D "brcm,bcm6345-wdt"; > + reg =3D <0x480 0x10>; > + }; > + > + watchdog@4c0 { > + compatible =3D "brcm,bcm6345-wdt"; > + reg =3D <0x4c0 0x10>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 0 .. 31 */ > + gpio0: gpio@500 { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x500 0x04>, <0x520 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 32 .. 63 */ > + gpio1: gpio@504 { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x504 0x04>, <0x524 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 64 .. 95 */ > + gpio2: gpio@508 { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x508 0x04>, <0x528 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 96 .. 127 */ > + gpio3: gpio@50c { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x50c 0x04>, <0x52c 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 128 .. 159 */ > + gpio4: gpio@510 { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x510 0x04>, <0x530 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 160 .. 191 */ > + gpio5: gpio@514 { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x514 0x04>, <0x534 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 192 .. 223 */ > + gpio6: gpio@518 { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x518 0x04>, <0x538 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > + > + /* GPIOs 224 .. 255 */ > + gpio7: gpio@51c { > + compatible =3D "brcm,bcm6345-gpio"; > + reg =3D <0x51c 0x04>, <0x53c 0x04>; > + reg-names =3D "dirout", "dat"; > + gpio-controller; > + #gpio-cells =3D <2>; > + status =3D "disabled"; > + }; > > uart0: serial@640 { > compatible =3D "brcm,bcm6345-uart"; > @@ -108,6 +200,29 @@ uart0: serial@640 { > status =3D "disabled"; > }; > > + uart1: serial@660 { > + compatible =3D "brcm,bcm6345-uart"; > + reg =3D <0x660 0x18>; > + interrupts =3D ; > + clocks =3D <&periph_clk>; > + clock-names =3D "refclk"; > + status =3D "disabled"; > + }; > + > + leds: led-controller@800 { > + #address-cells =3D <1>; > + #size-cells =3D <0>; > + compatible =3D "brcm,bcm63138-leds"; > + reg =3D <0x800 0xdc>; > + status =3D "disabled"; > + }; > + > + rng@b80 { > + compatible =3D "brcm,iproc-rng200"; > + reg =3D <0xb80 0x28>; > + interrupts =3D ; > + }; > + > hsspi: spi@1000 { > #address-cells =3D <1>; > #size-cells =3D <0>; > @@ -134,4 +249,25 @@ nandcs: nand@0 { > }; > }; > }; > + > + /* PERF1 Peripherals */ Same here. I suggest to keep it under the same bus@ff800000 node. > + bus@ff858000 { > + compatible =3D "simple-bus"; > + #address-cells =3D <1>; > + #size-cells =3D <1>; > + ranges =3D <0x0 0x0 0xff858000 0x4000>; > + > + pl081_dma: dma-controller@1000 { > + compatible =3D "arm,pl081", "arm,primecell"; > + // The magic B105F00D info is missing > + arm,primecell-periphid =3D <0x00041081>; > + reg =3D <0x1000 0x1000>; > + interrupts =3D ; > + memcpy-burst-size =3D <256>; > + memcpy-bus-width =3D <32>; > + clocks =3D <&periph_clk>; > + clock-names =3D "apb_pclk"; > + #dma-cells =3D <2>; > + }; > + }; > }; > > -- > 2.49.0 --00000000000096a1400633a428f0 Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature 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 YDZuuBJwnyCzevMoPtVYPharioL5H3BRnQi8YoTXH7/uRo33dewYFm474yFjwwnt82TFtveVZkVq 6h4WIQ4wTcwFfET8zMkELnGzS5SHCl8sPD+lNxxJ1JDZYwIDAQABo4IB2zCCAdcwDgYDVR0PAQH/ BAQDAgWgMIGjBggrBgEFBQcBAQSBljCBkzBOBggrBgEFBQcwAoZCaHR0cDovL3NlY3VyZS5nbG9i YWxzaWduLmNvbS9jYWNlcnQvZ3NnY2NyM3BlcnNvbmFsc2lnbjJjYTIwMjAuY3J0MEEGCCsGAQUF BzABhjVodHRwOi8vb2NzcC5nbG9iYWxzaWduLmNvbS9nc2djY3IzcGVyc29uYWxzaWduMmNhMjAy MDBNBgNVHSAERjBEMEIGCisGAQQBoDIBKAowNDAyBggrBgEFBQcCARYmaHR0cHM6Ly93d3cuZ2xv YmFsc2lnbi5jb20vcmVwb3NpdG9yeS8wCQYDVR0TBAIwADBJBgNVHR8EQjBAMD6gPKA6hjhodHRw Oi8vY3JsLmdsb2JhbHNpZ24uY29tL2dzZ2NjcjNwZXJzb25hbHNpZ24yY2EyMDIwLmNybDAlBgNV HREEHjAcgRp3aWxsaWFtLnpoYW5nQGJyb2FkY29tLmNvbTATBgNVHSUEDDAKBggrBgEFBQcDBDAf BgNVHSMEGDAWgBSWM9HmWBdbNHWKgVZk1b5I3qGPzzAdBgNVHQ4EFgQUq65GzwZxydFHjjYEU/9h xHhPWlwwDQYJKoZIhvcNAQELBQADggEBAA2hGG3JPAdGPH0ZdohGUCIVjKz+U+EFuIDbS6A/5jqX VhYAxZlzj7tSjUIM7G7IhyfqPC46GKJ/4x+Amz1Z6YxNGy71L68kYD6hIbBcA5AM42QBUufly6Oa /ppSz3WoflVyFFQ5YXniZ+eU+2/cdnYZg4aVUnFjimOF5o3NfMLzOkhQNxbaDjFUfUYD8hKmU6v4 0vUBj8KZ9Gi1LIagLKUREn8jku0lcLsRbnJ5Ey5ScajC/FESPyYWasOW8j8/1EoJksmhbYGKNS6C urb/KlmDGfVrIRYDbL0ckhGQIP5c6L+kSQZ2sHnQK0e0WgIaZYxaPYeY5u0GLCOze+3vyRMxggJg MIICXAIBATBrMFsxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMTEwLwYD VQQDEyhHbG9iYWxTaWduIEdDQyBSMyBQZXJzb25hbFNpZ24gMiBDQSAyMDIwAgwxuh2XG3FXRL1W JOEwDQYJYIZIAWUDBAIBBQCggccwLwYJKoZIhvcNAQkEMSIEIJrmI2z2LbBrzUE0qnleq+Y8uDqK 0RyI2iprr0TgGS+UMBgGCSqGSIb3DQEJAzELBgkqhkiG9w0BBwEwHAYJKoZIhvcNAQkFMQ8XDTI1 MDQyNjAxMTMyOFowXAYJKoZIhvcNAQkPMU8wTTALBglghkgBZQMEASowCwYJYIZIAWUDBAEWMAsG CWCGSAFlAwQBAjAKBggqhkiG9w0DBzALBgkqhkiG9w0BAQcwCwYJYIZIAWUDBAIBMA0GCSqGSIb3 DQEBAQUABIIBAGOPr5TdI8Hg0rksQ99eKEZsdkP7Hba/Tu1w+Q53OAms6LQUk/tp5yMeDiRlXxuG 8scRk4maaoaeZxK2JVmdHUuvsc2ATBuwXz97TzjVakBn9Q2Dv4ElKgGVdtsJn9ODjPIX/6OaJLY2 uvzx3LP7fRwHXYjMSQDQSEsbm0w3yMUv6S1ukT6X9Ks0Ttl1A7fKJYXUi/HsLl9kAj4zT7cZ7Kc4 lDHzHooGYLxhYTruJwJDt1I1vKS1P8kbttx8GD29+Q7fgJltKY55l42uEwhCYfnmQoYQpTTM/qvk 9NxXBLD6fp5b8TCLZQyi716qaml71AL3b7hEdGiF6jcd3PUfQ48= --00000000000096a1400633a428f0--