mirror of
https://github.com/torvalds/linux.git
synced 2026-05-28 17:13:52 +02:00
arm64: dts: qcom: lemans-evk: Add IFP Mezzanine
The Interface Plus [IFP] Mezzanine is an hardware expansion add-on
board designed to be stacked on top of Lemans EVK.
It has following peripherals :
- 4x Type A USB ports in host mode.
- TC9563 PCIe switch, which has following three downstream ports (DSP) :
- 1st DSP is routed to an M.2 E-key connector, intended for
WLAN modules.
- 2nd DSP is routed to an M.2 B-key connector, intended for
cellular modems.
- 3rd DSP with support for Dual Ethernet ports.
- eMMC.
- Additional 2.5GbE Ethernet PHY connected to native EMAC with support for
MAC Address configuration via NVMEM.
- EEPROM.
- LVDS Display.
- 2*mini DP.
Add support for following peripherals :
- TC9563 PCIe Switch.
- Additional 2.5GbE Ethernet Port.
- EEPROM.
Enable support for USB hub, LVDS display and mini-DP later once
dependent changes are available in lemans-evk core-kit.
Written with inputs from :
Mohd Ayaan Anwar <mohd.anwar@oss.qualcomm.com> - Ethernet.
Krishna Chaitanya Chundru <krishna.chundru@oss.qualcomm.com> - PCIe
Monish Chunara <monish.chunara@oss.qualcomm.com> - EEPROM.
Signed-off-by: Umang Chheda <umang.chheda@oss.qualcomm.com>
Reviewed-by: Konrad Dybcio <konrad.dybcio@oss.qualcomm.com>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
Link: https://lore.kernel.org/r/20260304165925.1535938-2-umang.chheda@oss.qualcomm.com
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
This commit is contained in:
parent
5a67924d2f
commit
b64abb26a2
|
|
@ -50,6 +50,8 @@ dtb-$(CONFIG_ARCH_QCOM) += lemans-evk-camera.dtb
|
|||
lemans-evk-el2-dtbs := lemans-evk.dtb lemans-el2.dtbo
|
||||
|
||||
dtb-$(CONFIG_ARCH_QCOM) += lemans-evk-el2.dtb
|
||||
lemans-evk-ifp-mezzanine-dtbs := lemans-evk.dtb lemans-evk-ifp-mezzanine.dtbo
|
||||
dtb-$(CONFIG_ARCH_QCOM) += lemans-evk-ifp-mezzanine.dtb
|
||||
dtb-$(CONFIG_ARCH_QCOM) += mahua-crd.dtb
|
||||
dtb-$(CONFIG_ARCH_QCOM) += milos-fairphone-fp6.dtb
|
||||
dtb-$(CONFIG_ARCH_QCOM) += monaco-arduino-monza.dtb
|
||||
|
|
|
|||
263
arch/arm64/boot/dts/qcom/lemans-evk-ifp-mezzanine.dtso
Normal file
263
arch/arm64/boot/dts/qcom/lemans-evk-ifp-mezzanine.dtso
Normal file
|
|
@ -0,0 +1,263 @@
|
|||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
/*
|
||||
* Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
|
||||
*/
|
||||
|
||||
/dts-v1/;
|
||||
/plugin/;
|
||||
|
||||
#include <dt-bindings/gpio/gpio.h>
|
||||
|
||||
&{/} {
|
||||
model = "Qualcomm Technologies, Inc. Lemans-evk IFP Mezzanine";
|
||||
|
||||
vreg_0p9: regulator-0v9 {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "VREG_0P9";
|
||||
|
||||
regulator-min-microvolt = <900000>;
|
||||
regulator-max-microvolt = <900000>;
|
||||
regulator-always-on;
|
||||
regulator-boot-on;
|
||||
};
|
||||
|
||||
vreg_1p8: regulator-1v8 {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "VREG_1P8";
|
||||
|
||||
regulator-min-microvolt = <1800000>;
|
||||
regulator-max-microvolt = <1800000>;
|
||||
regulator-always-on;
|
||||
regulator-boot-on;
|
||||
};
|
||||
};
|
||||
|
||||
ðernet1 {
|
||||
phy-handle = <&hsgmii_phy1>;
|
||||
phy-mode = "2500base-x";
|
||||
|
||||
pinctrl-0 = <ðernet1_default>;
|
||||
pinctrl-names = "default";
|
||||
|
||||
snps,mtl-rx-config = <&mtl_rx_setup1>;
|
||||
snps,mtl-tx-config = <&mtl_tx_setup1>;
|
||||
|
||||
nvmem-cells = <&mac_addr1>;
|
||||
nvmem-cell-names = "mac-address";
|
||||
|
||||
status = "okay";
|
||||
|
||||
mdio {
|
||||
compatible = "snps,dwmac-mdio";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
|
||||
hsgmii_phy1: ethernet-phy@18 {
|
||||
compatible = "ethernet-phy-id004d.d101";
|
||||
reg = <0x18>;
|
||||
reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>;
|
||||
reset-assert-us = <11000>;
|
||||
reset-deassert-us = <70000>;
|
||||
};
|
||||
};
|
||||
|
||||
mtl_rx_setup1: rx-queues-config {
|
||||
snps,rx-queues-to-use = <4>;
|
||||
snps,rx-sched-sp;
|
||||
|
||||
queue0 {
|
||||
snps,dcb-algorithm;
|
||||
snps,map-to-dma-channel = <0x0>;
|
||||
snps,route-up;
|
||||
snps,priority = <0x1>;
|
||||
};
|
||||
|
||||
queue1 {
|
||||
snps,dcb-algorithm;
|
||||
snps,map-to-dma-channel = <0x1>;
|
||||
snps,route-ptp;
|
||||
};
|
||||
|
||||
queue2 {
|
||||
snps,avb-algorithm;
|
||||
snps,map-to-dma-channel = <0x2>;
|
||||
snps,route-avcp;
|
||||
};
|
||||
|
||||
queue3 {
|
||||
snps,avb-algorithm;
|
||||
snps,map-to-dma-channel = <0x3>;
|
||||
snps,priority = <0xc>;
|
||||
};
|
||||
};
|
||||
|
||||
mtl_tx_setup1: tx-queues-config {
|
||||
snps,tx-queues-to-use = <4>;
|
||||
|
||||
queue0 {
|
||||
snps,dcb-algorithm;
|
||||
};
|
||||
|
||||
queue1 {
|
||||
snps,dcb-algorithm;
|
||||
};
|
||||
|
||||
queue2 {
|
||||
snps,avb-algorithm;
|
||||
snps,send_slope = <0x1000>;
|
||||
snps,idle_slope = <0x1000>;
|
||||
snps,high_credit = <0x3e800>;
|
||||
snps,low_credit = <0xffc18000>;
|
||||
};
|
||||
|
||||
queue3 {
|
||||
snps,avb-algorithm;
|
||||
snps,send_slope = <0x1000>;
|
||||
snps,idle_slope = <0x1000>;
|
||||
snps,high_credit = <0x3e800>;
|
||||
snps,low_credit = <0xffc18000>;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
&i2c18 {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
|
||||
eeprom@52 {
|
||||
compatible = "giantec,gt24c256c", "atmel,24c256";
|
||||
reg = <0x52>;
|
||||
pagesize = <64>;
|
||||
|
||||
nvmem-layout {
|
||||
compatible = "fixed-layout";
|
||||
#address-cells = <1>;
|
||||
#size-cells = <1>;
|
||||
|
||||
mac_addr1: mac-addr@0 {
|
||||
reg = <0x0 0x6>;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
&pcie0 {
|
||||
iommu-map = <0x0 &pcie_smmu 0x0 0x1>,
|
||||
<0x100 &pcie_smmu 0x1 0x1>,
|
||||
<0x208 &pcie_smmu 0x2 0x1>,
|
||||
<0x210 &pcie_smmu 0x3 0x1>,
|
||||
<0x218 &pcie_smmu 0x4 0x1>,
|
||||
<0x300 &pcie_smmu 0x5 0x1>,
|
||||
<0x400 &pcie_smmu 0x6 0x1>,
|
||||
<0x500 &pcie_smmu 0x7 0x1>,
|
||||
<0x501 &pcie_smmu 0x8 0x1>;
|
||||
};
|
||||
|
||||
&pcieport0 {
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
|
||||
pcie@0,0 {
|
||||
compatible = "pci1179,0623";
|
||||
reg = <0x10000 0x0 0x0 0x0 0x0>;
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
|
||||
device_type = "pci";
|
||||
ranges;
|
||||
bus-range = <0x2 0xff>;
|
||||
|
||||
vddc-supply = <&vreg_0p9>;
|
||||
vdd18-supply = <&vreg_1p8>;
|
||||
vdd09-supply = <&vreg_0p9>;
|
||||
vddio1-supply = <&vreg_1p8>;
|
||||
vddio2-supply = <&vreg_1p8>;
|
||||
vddio18-supply = <&vreg_1p8>;
|
||||
|
||||
i2c-parent = <&i2c18 0x77>;
|
||||
|
||||
resx-gpios = <&tlmm 140 GPIO_ACTIVE_LOW>;
|
||||
|
||||
pinctrl-0 = <&tc9563_resx_n>;
|
||||
pinctrl-names = "default";
|
||||
|
||||
pcie@1,0 {
|
||||
reg = <0x20800 0x0 0x0 0x0 0x0>;
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
|
||||
device_type = "pci";
|
||||
ranges;
|
||||
bus-range = <0x3 0xff>;
|
||||
};
|
||||
|
||||
pcie@2,0 {
|
||||
reg = <0x21000 0x0 0x0 0x0 0x0>;
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
|
||||
device_type = "pci";
|
||||
ranges;
|
||||
bus-range = <0x4 0xff>;
|
||||
};
|
||||
|
||||
pcie@3,0 {
|
||||
reg = <0x21800 0x0 0x0 0x0 0x0>;
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
device_type = "pci";
|
||||
ranges;
|
||||
bus-range = <0x5 0xff>;
|
||||
|
||||
pci@0,0 {
|
||||
reg = <0x50000 0x0 0x0 0x0 0x0>;
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
device_type = "pci";
|
||||
ranges;
|
||||
};
|
||||
|
||||
pci@0,1 {
|
||||
reg = <0x50100 0x0 0x0 0x0 0x0>;
|
||||
#address-cells = <3>;
|
||||
#size-cells = <2>;
|
||||
device_type = "pci";
|
||||
ranges;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
&serdes1 {
|
||||
phy-supply = <&vreg_l5a>;
|
||||
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&tlmm {
|
||||
ethernet1_default: ethernet1-default-state {
|
||||
ethernet1-mdc-pins {
|
||||
pins = "gpio20";
|
||||
function = "emac1_mdc";
|
||||
drive-strength = <16>;
|
||||
bias-pull-up;
|
||||
};
|
||||
|
||||
ethernet1-mdio-pins {
|
||||
pins = "gpio21";
|
||||
function = "emac1_mdio";
|
||||
drive-strength = <16>;
|
||||
bias-pull-up;
|
||||
};
|
||||
};
|
||||
|
||||
tc9563_resx_n: tc9563-resx-state {
|
||||
pins = "gpio140";
|
||||
function = "gpio";
|
||||
bias-disable;
|
||||
/* Reset pin of tc9563 is active low hence set default
|
||||
* state of this pin to output-high.
|
||||
*/
|
||||
output-high;
|
||||
};
|
||||
};
|
||||
Loading…
Reference in New Issue
Block a user