Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp6625236rwb; Tue, 15 Nov 2022 01:02:37 -0800 (PST) X-Google-Smtp-Source: AA0mqf55qM5k8WntTZidDFvKjEN4V0+C/6vtAFr6B9CU9gPms9Ba+vqzgNBTL30zqwwSmopQIu0h X-Received: by 2002:a17:903:25c1:b0:188:64b7:e433 with SMTP id jc1-20020a17090325c100b0018864b7e433mr3148513plb.17.1668502957338; Tue, 15 Nov 2022 01:02:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668502957; cv=none; d=google.com; s=arc-20160816; b=fO+lvItlq+iyF0jW9ah4k/sZxqOLfKaYx9Hqm/a8K8wTalVooHf/ttd4Q0XHajMRKf tHrNYP40sX1c9kM+BShalRA3lytvcEzMMouKE8R259wBdW3K4UYPNWhxDY8IeZsy6D3v XEsYsZnLE+o/7NMNwQArhCUiKnlFkkwVlBrOUMvEDs864RqYe9iAdvSg6UBo5HWfbRpc 3GXK1SppMSwforXOfHFNExIpUZVVARR9sbYHgxQw6HlGQWWs85ERw+CqrgEoWrJ4ItJO QT1eYMM1D7z+q23Qr60accRM2Vfwd+UrWW1AU+ENM8ddQhmkQIhY6M0WbRCeEHPJ50HU 5m1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:references:in-reply-to:user-agent:subject:cc:to:from :date; bh=QXo2OUk4JDrl6pd0iwMEzX19Rr9PG+q0CJ7W5ZiNBIU=; b=EuX2D6v1M9wXgd3wdk4O//GIaFEizgOSZ/FLNAnZ0PTST2c2GJt8BKlf/5nb1f/KFx APEHjckNlje5IPu/5zru0BkE9odoT60ZW36ephHEBKfi8Q5PibOLnMCNa707Z+QdbvcW t3IEyAe13CWchYx3LbQulW3FRA/kSWdb+yqb3ulgT9GTJD3tOZHIQKWe3r03m/R8OgUO L2ojHv6To+82sX7tty8tP1jKEBHSUgOZM9DiYC7+B7p4De3qQ1aYKGt7fYjoIprIxDx2 0JwVZSlhxcfHFoqkjeN16UonbPdqH8tK8A+jaFQfEaxBqflUTsPDhpISg/GnvaF/U9qu ZsCg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z4-20020a656644000000b004706a2c7d4fsi11695894pgv.611.2022.11.15.01.02.18; Tue, 15 Nov 2022 01:02:37 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232284AbiKOIYX convert rfc822-to-8bit (ORCPT + 88 others); Tue, 15 Nov 2022 03:24:23 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44992 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229585AbiKOIYL (ORCPT ); Tue, 15 Nov 2022 03:24:11 -0500 Received: from relay03.th.seeweb.it (relay03.th.seeweb.it [IPv6:2001:4b7a:2000:18::164]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3BE08E01C for ; Tue, 15 Nov 2022 00:24:10 -0800 (PST) Received: from [127.0.0.1] (85-237-234-20.dynamic.orange.sk [85.237.234.20]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by m-r1.th.seeweb.it (Postfix) with ESMTPSA id D248920088; Tue, 15 Nov 2022 09:24:06 +0100 (CET) Date: Tue, 15 Nov 2022 09:24:04 +0100 From: Martin Botka To: Andre Przywara , Martin Botka CC: ~postmarketos/upstreaming@lists.sr.ht, Konrad Dybcio , AngeloGioacchino Del Regno , Marijn Suijten , Jami Kettunen , Paul Bouchara , Jan Trmal , Tom , Rob Herring , Krzysztof Kozlowski , Chen-Yu Tsai , Jernej Skrabec , Samuel Holland , Maxime Ripard , Conley Lee , Andrew Lunn , devicetree , linux-arm-kernel@lists.infradead.org, linux-sunxi@lists.linux.dev, Linux Kernel Mailing List Subject: Re: [PATCH v3 2/2] arm64: dts: Add basic support for BIQU CB1 User-Agent: K-9 Mail for Android In-Reply-To: <20221115005429.57d72f64@slackpad.lan> References: <20221114214452.1993744-1-martin.botka@somainline.org> <20221114214452.1993744-2-martin.botka@somainline.org> <20221114233102.3b1f96cc@slackpad.lan> <20221115005429.57d72f64@slackpad.lan> Message-ID: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8BIT X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On November 15, 2022 1:54:29 AM GMT+01:00, Andre Przywara wrote: >On Tue, 15 Nov 2022 00:44:46 +0100 >Martin Botka wrote: > >Hi Martin, > >> I can totally understand how this can get confusing. >> >> Basically because of the Rpi shortage biqu decided to make an Rpi >> alternative. >> >> So they made CB1 which is compute module style board. >> >> And they made 3 other boards where CB1 or Rpi CM4 can be plugged in. The 3 >> boards are: >> >> Rpi adapter which takes the Compute module style boards and turns them into >> SBC style with basically identical size and etc to Rpi 4. >> >> Then we have Manta M8P and M4P. These boards are MCUs for a 3D printer. But >> they were made for Klipper use case which requires a computer or SBC >> (Usually Rpi4). They combined it into 1 board. >> Where you get the MCU and you can plug in CM4 or CB1 > >Thanks for the explanations! I was guessing along those shortage lines, >since the H616 is quite a step down from the RPi4CM, though probably >still enough for driving a 3D printer. Mostly yes > >> All these boards are basically taking the pins and routing them to ports. > >Yes, this is what those SoM carrier boards do ;-) :) > >> There is nearly 0 chips for conversion or processing of the pins from CB1 >> or CM4 thus i do not see a reason for having parent dtsi and dts for the >> adapter and Manta boards. > >And the DT does not need to describe "chips" only, a lot of DT nodes >are about connectors, and which ports and which exact pins (out of the >possible pinmuxes) are actually used. The SoM itself mostly exposes >just pins, and the board DT describes how these pins are used (GPIO or >special function, for instance). > >So did you try to split this up? How would that look? The main difference between adapter and Manta boards is that adapter has 4x USB. Manta only has 3 and 1 otg. But it has a switch to disable or enable otg. Im not opposed to splitting it up. It is probably a good idea. I dont see how to resolve that switch on manta boards tho. Regards, Martin > >Cheers, >Andre > >> The only exception to conversion are the LEDs on the boards but since both >> adapter and manta boards have them this yet again eliminates need for >> parent style DT. >> >> Best regards, >> Martin >> >> On Tue, Nov 15, 2022, 12:32 AM Andre Przywara >> wrote: >> >> > On Mon, 14 Nov 2022 22:44:49 +0100 >> > Martin Botka wrote: >> > >> > > CB1 is Compute Module style board that plugs into Rpi board style >> > adapter or >> > > Manta 3D printer boards (M4P/M8P). >> > > >> > > The board has: >> > > H616 SoC >> > > 1GB of RAM >> > > AXP313A PMIC >> > > >> > > And the actual boards that CB1 plugs in are just extension to it with >> > ports and >> > > thus are not split in DT. >> > >> > I don't really understand that sentence. There is some precedent for a >> > SoM/board split, look at the sun50i-a64-sopine or >> > sun50i-h5-emlid-neutis-n5 files. And if I see this correctly, then >> > there are *two* boards available for the same CB1 SoM, the PI4B and the >> > Manta board? Which would a strong case for a SoM .dtsi, plus the one >> > or two board .dts files. >> > I am just not sure whether that relation to the Pi4-CM is helpful or >> > just complicates things... >> > >> > Cheers, >> > Andre >> > >> > > >> > > Boards have: >> > > 4x (3x for Manta boards) USB and 1 USB OTG. >> > > SDcard slot for loading images. >> > > Ethernet port wired to the internal PHY. >> > > 2x HDMI 2.0. >> > > Power and Status LEDs. >> > > >> > > Currently working: >> > > Booting >> > > USB >> > > UART >> > > >> > > Signed-off-by: Martin Botka >> > > --- >> > > Changes in V2: >> > > Add proper board compatible >> > > Add regulator prefix for vcc5v >> > > Drop okay status from PMIC >> > > Drop standby_param >> > > Changes in V3: >> > > Change copyright to me >> > > regulator_vcc5v to regulator-vcc5v >> > > Drop ehci0 and ohci0 >> > > arch/arm64/boot/dts/allwinner/Makefile | 1 + >> > > .../dts/allwinner/sun50i-h616-biqu-cb1.dts | 178 ++++++++++++++++++ >> > > 2 files changed, 179 insertions(+) >> > > create mode 100644 >> > arch/arm64/boot/dts/allwinner/sun50i-h616-biqu-cb1.dts >> > > >> > > diff --git a/arch/arm64/boot/dts/allwinner/Makefile >> > b/arch/arm64/boot/dts/allwinner/Makefile >> > > index 6a96494a2e0a..223f1be73541 100644 >> > > --- a/arch/arm64/boot/dts/allwinner/Makefile >> > > +++ b/arch/arm64/boot/dts/allwinner/Makefile >> > > @@ -38,5 +38,6 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-pine-h64.dtb >> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-pine-h64-model-b.dtb >> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-tanix-tx6.dtb >> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-tanix-tx6-mini.dtb >> > > +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h616-biqu-cb1.dtb >> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h616-orangepi-zero2.dtb >> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h616-x96-mate.dtb >> > > diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h616-biqu-cb1.dts >> > b/arch/arm64/boot/dts/allwinner/sun50i-h616-biqu-cb1.dts >> > > new file mode 100644 >> > > index 000000000000..86b5aca9b53e >> > > --- /dev/null >> > > +++ b/arch/arm64/boot/dts/allwinner/sun50i-h616-biqu-cb1.dts >> > > @@ -0,0 +1,178 @@ >> > > +// SPDX-License-Identifier: (GPL-2.0+ or MIT) >> > > +/* >> > > + * Copyright (C) 2022 Martin Botka . >> > > + */ >> > > + >> > > +/dts-v1/; >> > > + >> > > +#include "sun50i-h616.dtsi" >> > > + >> > > +#include >> > > +#include >> > > +#include >> > > + >> > > +/ { >> > > + model = "BIQU CB1"; >> > > + compatible = "biqu,cb1", "allwinner,sun50i-h616"; >> > > + >> > > + aliases { >> > > + serial0 = &uart0; >> > > + }; >> > > + >> > > + chosen { >> > > + stdout-path = "serial0:115200n8"; >> > > + }; >> > > + >> > > + leds { >> > > + compatible = "gpio-leds"; >> > > + >> > > + led-0 { >> > > + function = LED_FUNCTION_POWER; >> > > + color = ; >> > > + gpios = <&pio 2 12 GPIO_ACTIVE_HIGH>; /* PC12 */ >> > > + default-state = "on"; >> > > + }; >> > > + >> > > + led-1 { >> > > + function = LED_FUNCTION_STATUS; >> > > + color = ; >> > > + gpios = <&pio 2 13 GPIO_ACTIVE_HIGH>; /* PC13 */ >> > > + }; >> > > + }; >> > > + >> > > + reg_vcc5v: regulator-vcc5v { >> > > + /* board wide 5V supply directly from the USB-C socket */ >> > > + compatible = "regulator-fixed"; >> > > + regulator-name = "vcc-5v"; >> > > + regulator-min-microvolt = <5000000>; >> > > + regulator-max-microvolt = <5000000>; >> > > + regulator-always-on; >> > > + }; >> > > + >> > > + reg_usb1_vbus: regulator-usb1-vbus { >> > > + compatible = "regulator-fixed"; >> > > + regulator-name = "usb1-vbus"; >> > > + regulator-min-microvolt = <5000000>; >> > > + regulator-max-microvolt = <5000000>; >> > > + vin-supply = <®_vcc5v>; >> > > + enable-active-high; >> > > + gpio = <&pio 2 16 GPIO_ACTIVE_HIGH>; /* PC16 */ >> > > + }; >> > > +}; >> > > + >> > > +&ehci1 { >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&ehci2 { >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&ehci3 { >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&mmc0 { >> > > + vmmc-supply = <®_dldo1>; >> > > + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */ >> > > + no-1-8-v; >> > > + bus-width = <4>; >> > > + status = "disabled"; >> > > +}; >> > > + >> > > +&ohci1 { >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&ohci2 { >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&ohci3 { >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&r_i2c { >> > > + status = "okay"; >> > > + >> > > + axp1530: pmic@36 { >> > > + compatible = "x-powers,axp1530"; >> > > + reg = <0x36>; >> > > + wakeup-source; >> > > + >> > > + regulators{ >> > > + reg_dcdc1: dcdc1 { >> > > + regulator-name = "axp1530-dcdc1"; >> > > + regulator-min-microvolt = <500000>; >> > > + regulator-max-microvolt = <3400000>; >> > > + regulator-step-delay-us = <25>; >> > > + regulator-final-delay-us = <50>; >> > > + regulator-always-on; >> > > + }; >> > > + >> > > + reg_dcdc2: dcdc2 { >> > > + regulator-name = "axp1530-dcdc2"; >> > > + regulator-min-microvolt = <500000>; >> > > + regulator-max-microvolt = <1540000>; >> > > + regulator-step-delay-us = <25>; >> > > + regulator-final-delay-us = <50>; >> > > + regulator-ramp-delay = <200>; >> > > + regulator-always-on; >> > > + }; >> > > + >> > > + reg_dcdc3: dcdc3 { >> > > + regulator-name = "axp1530-dcdc3"; >> > > + regulator-min-microvolt = <500000>; >> > > + regulator-max-microvolt = <1840000>; >> > > + regulator-step-delay-us = <25>; >> > > + regulator-final-delay-us = <50>; >> > > + regulator-always-on; >> > > + }; >> > > + >> > > + reg_aldo1: ldo1 { >> > > + regulator-name = "axp1530-aldo1"; >> > > + regulator-min-microvolt = <1800000>; >> > > + regulator-max-microvolt = <1800000>; >> > > + regulator-step-delay-us = <25>; >> > > + regulator-final-delay-us = <50>; >> > > + regulator-always-on; >> > > + }; >> > > + >> > > + reg_dldo1: ldo2 { >> > > + regulator-name = "axp1530-dldo1"; >> > > + regulator-min-microvolt = <3300000>; >> > > + regulator-max-microvolt = <3300000>; >> > > + regulator-step-delay-us = <25>; >> > > + regulator-final-delay-us = <50>; >> > > + regulator-always-on; >> > > + }; >> > > + }; >> > > + }; >> > > +}; >> > > + >> > > +&uart0 { >> > > + pinctrl-names = "default"; >> > > + pinctrl-0 = <&uart0_ph_pins>; >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&usbotg { >> > > + /* >> > > + * PHY0 pins are connected to a USB-C socket, but a role switch >> > > + * is not implemented: both CC pins are pulled to GND. >> > > + * The VBUS pins power the device, so a fixed peripheral mode >> > > + * is the best choice. >> > > + * The board can be powered via GPIOs, in this case port0 *can* >> > > + * act as a host (with a cable/adapter ignoring CC), as VBUS is >> > > + * then provided by the GPIOs. Any user of this setup would >> > > + * need to adjust the DT accordingly: dr_mode set to "host", >> > > + * enabling OHCI0 and EHCI0. >> > > + */ >> > > + dr_mode = "peripheral"; >> > > + status = "okay"; >> > > +}; >> > > + >> > > +&usbphy { >> > > + usb1_vbus-supply = <®_usb1_vbus>; >> > > + status = "okay"; >> > > +}; >> > >> > >