| // SPDX-License-Identifier: GPL-2.0 |
| /* |
| * Check Point L-50 Board Description |
| * Copyright 2020 Pawel Dembicki <paweldembicki@gmail.com> |
| */ |
| |
| /dts-v1/; |
| |
| #include "kirkwood.dtsi" |
| #include "kirkwood-6281.dtsi" |
| |
| / { |
| model = "Check Point L-50"; |
| compatible = "checkpoint,l-50", "marvell,kirkwood-88f6281", "marvell,kirkwood"; |
| |
| memory { |
| device_type = "memory"; |
| reg = <0x00000000 0x20000000>; |
| }; |
| |
| chosen { |
| bootargs = "console=ttyS0,115200n8"; |
| stdout-path = &uart0; |
| }; |
| |
| ocp@f1000000 { |
| pinctrl: pin-controller@10000 { |
| pinctrl-0 = <&pmx_led38 &pmx_sysrst &pmx_button29>; |
| pinctrl-names = "default"; |
| |
| pmx_sysrst: pmx-sysrst { |
| marvell,pins = "mpp6"; |
| marvell,function = "sysrst"; |
| }; |
| |
| pmx_button29: pmx_button29 { |
| marvell,pins = "mpp29"; |
| marvell,function = "gpio"; |
| }; |
| |
| pmx_led38: pmx_led38 { |
| marvell,pins = "mpp38"; |
| marvell,function = "gpio"; |
| }; |
| |
| pmx_sdio_cd: pmx-sdio-cd { |
| marvell,pins = "mpp46"; |
| marvell,function = "gpio"; |
| }; |
| }; |
| |
| serial@12000 { |
| status = "okay"; |
| }; |
| |
| mvsdio@90000 { |
| status = "okay"; |
| cd-gpios = <&gpio1 14 9>; |
| }; |
| |
| i2c@11000 { |
| status = "okay"; |
| clock-frequency = <400000>; |
| |
| gpio2: gpio-expander@20 { |
| #gpio-cells = <2>; |
| #interrupt-cells = <2>; |
| interrupt-controller; |
| compatible = "semtech,sx1505q"; |
| reg = <0x20>; |
| |
| gpio-controller; |
| }; |
| |
| /* Three GPIOs from 0x21 exp. are undescribed in dts: |
| * 1: DSL module reset (active low) |
| * 5: mPCIE reset (active low) |
| * 6: Express card reset (active low) |
| */ |
| gpio3: gpio-expander@21 { |
| #gpio-cells = <2>; |
| #interrupt-cells = <2>; |
| interrupt-controller; |
| compatible = "semtech,sx1505q"; |
| reg = <0x21>; |
| |
| gpio-controller; |
| }; |
| |
| rtc@30 { |
| compatible = "s35390a"; |
| reg = <0x30>; |
| }; |
| }; |
| }; |
| |
| leds { |
| compatible = "gpio-leds"; |
| |
| status_green { |
| label = "l-50:green:status"; |
| gpios = <&gpio1 6 GPIO_ACTIVE_LOW>; |
| }; |
| |
| status_red { |
| label = "l-50:red:status"; |
| gpios = <&gpio3 2 GPIO_ACTIVE_LOW>; |
| }; |
| |
| wifi { |
| label = "l-50:green:wifi"; |
| gpios = <&gpio2 7 GPIO_ACTIVE_LOW>; |
| linux,default-trigger = "phy0tpt"; |
| }; |
| |
| internet_green { |
| label = "l-50:green:internet"; |
| gpios = <&gpio2 3 GPIO_ACTIVE_LOW>; |
| }; |
| |
| internet_red { |
| label = "l-50:red:internet"; |
| gpios = <&gpio2 1 GPIO_ACTIVE_LOW>; |
| }; |
| |
| usb1_green { |
| label = "l-50:green:usb1"; |
| gpios = <&gpio2 0 GPIO_ACTIVE_LOW>; |
| linux,default-trigger = "usbport"; |
| trigger-sources = <&hub_port3>; |
| }; |
| |
| usb1_red { |
| label = "l-50:red:usb1"; |
| gpios = <&gpio2 4 GPIO_ACTIVE_LOW>; |
| }; |
| |
| usb2_green { |
| label = "l-50:green:usb2"; |
| gpios = <&gpio2 2 GPIO_ACTIVE_LOW>; |
| linux,default-trigger = "usbport"; |
| trigger-sources = <&hub_port1>; |
| }; |
| |
| usb2_red { |
| label = "l-50:red:usb2"; |
| gpios = <&gpio2 5 GPIO_ACTIVE_LOW>; |
| }; |
| }; |
| |
| usb2_pwr { |
| compatible = "regulator-fixed"; |
| regulator-name = "usb2_pwr"; |
| |
| regulator-min-microvolt = <5000000>; |
| regulator-max-microvolt = <5000000>; |
| gpio = <&gpio3 3 GPIO_ACTIVE_LOW>; |
| regulator-always-on; |
| }; |
| |
| usb1_pwr { |
| compatible = "regulator-fixed"; |
| regulator-name = "usb1_pwr"; |
| |
| regulator-min-microvolt = <5000000>; |
| regulator-max-microvolt = <5000000>; |
| gpio = <&gpio3 4 GPIO_ACTIVE_LOW>; |
| regulator-always-on; |
| }; |
| |
| mpcie_pwr { |
| compatible = "regulator-fixed"; |
| regulator-name = "mpcie_pwr"; |
| |
| regulator-min-microvolt = <3300000>; |
| regulator-max-microvolt = <3300000>; |
| gpio = <&gpio3 5 GPIO_ACTIVE_HIGH>; |
| enable-active-high; |
| regulator-always-on; |
| }; |
| |
| express_card_pwr { |
| compatible = "regulator-fixed"; |
| regulator-name = "express_card_pwr"; |
| |
| regulator-min-microvolt = <3300000>; |
| regulator-max-microvolt = <3300000>; |
| gpio = <&gpio3 7 GPIO_ACTIVE_HIGH>; |
| enable-active-high; |
| regulator-always-on; |
| }; |
| |
| keys { |
| compatible = "gpio-keys"; |
| |
| factory_defaults { |
| label = "factory_defaults"; |
| gpios = <&gpio0 29 GPIO_ACTIVE_LOW>; |
| linux,code = <KEY_RESTART>; |
| }; |
| }; |
| }; |
| |
| &mdio { |
| status = "okay"; |
| |
| ethphy8: ethernet-phy@8 { |
| reg = <0x08>; |
| }; |
| |
| switch0: switch@10 { |
| compatible = "marvell,mv88e6085"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| reg = <0x10>; |
| dsa,member = <0 0>; |
| |
| ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| label = "lan5"; |
| }; |
| |
| port@1 { |
| reg = <1>; |
| label = "lan1"; |
| }; |
| |
| port@2 { |
| reg = <2>; |
| label = "lan6"; |
| }; |
| |
| port@3 { |
| reg = <3>; |
| label = "lan2"; |
| }; |
| |
| port@4 { |
| reg = <4>; |
| label = "lan7"; |
| }; |
| |
| switch0port5: port@5 { |
| reg = <5>; |
| phy-mode = "rgmii-txid"; |
| link = <&switch1port5>; |
| fixed-link { |
| speed = <1000>; |
| full-duplex; |
| }; |
| }; |
| |
| port@6 { |
| reg = <6>; |
| phy-mode = "rgmii-id"; |
| ethernet = <ð1port>; |
| fixed-link { |
| speed = <1000>; |
| full-duplex; |
| }; |
| }; |
| }; |
| }; |
| |
| switch@11 { |
| compatible = "marvell,mv88e6085"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| reg = <0x11>; |
| dsa,member = <0 1>; |
| |
| ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| label = "lan3"; |
| }; |
| |
| port@1 { |
| reg = <1>; |
| label = "lan8"; |
| }; |
| |
| port@2 { |
| reg = <2>; |
| label = "lan4"; |
| }; |
| |
| port@3 { |
| reg = <3>; |
| label = "dmz"; |
| }; |
| |
| switch1port5: port@5 { |
| reg = <5>; |
| phy-mode = "rgmii-txid"; |
| link = <&switch0port5>; |
| fixed-link { |
| speed = <1000>; |
| full-duplex; |
| }; |
| }; |
| |
| port@6 { |
| reg = <6>; |
| label = "dsl"; |
| fixed-link { |
| speed = <100>; |
| full-duplex; |
| }; |
| }; |
| }; |
| }; |
| }; |
| |
| ð0 { |
| status = "okay"; |
| ethernet0-port@0 { |
| phy-handle = <ðphy8>; |
| }; |
| }; |
| |
| ð1 { |
| status = "okay"; |
| ethernet1-port@0 { |
| speed = <1000>; |
| duplex = <1>; |
| phy-mode = "rgmii"; |
| }; |
| }; |
| |
| &nand { |
| status = "okay"; |
| pinctrl-0 = <&pmx_nand>; |
| pinctrl-names = "default"; |
| |
| partition@0 { |
| label = "u-boot"; |
| reg = <0x00000000 0x000c0000>; |
| }; |
| |
| partition@a0000 { |
| label = "bootldr-env"; |
| reg = <0x000c0000 0x00040000>; |
| }; |
| |
| partition@100000 { |
| label = "kernel-1"; |
| reg = <0x00100000 0x00800000>; |
| }; |
| |
| partition@900000 { |
| label = "rootfs-1"; |
| reg = <0x00900000 0x07100000>; |
| }; |
| |
| partition@7a00000 { |
| label = "kernel-2"; |
| reg = <0x07a00000 0x00800000>; |
| }; |
| |
| partition@8200000 { |
| label = "rootfs-2"; |
| reg = <0x08200000 0x07100000>; |
| }; |
| |
| partition@f300000 { |
| label = "default_sw"; |
| reg = <0x0f300000 0x07900000>; |
| }; |
| |
| partition@16c00000 { |
| label = "logs"; |
| reg = <0x16c00000 0x01800000>; |
| }; |
| |
| partition@18400000 { |
| label = "preset_cfg"; |
| reg = <0x18400000 0x00100000>; |
| }; |
| |
| partition@18500000 { |
| label = "adsl"; |
| reg = <0x18500000 0x00100000>; |
| }; |
| |
| partition@18600000 { |
| label = "storage"; |
| reg = <0x18600000 0x07a00000>; |
| }; |
| }; |
| |
| &rtc { |
| status = "disabled"; |
| }; |
| |
| &pciec { |
| status = "okay"; |
| }; |
| |
| &pcie0 { |
| status = "okay"; |
| }; |
| |
| &sata_phy0 { |
| status = "disabled"; |
| }; |
| |
| &sata_phy1 { |
| status = "disabled"; |
| }; |
| |
| &usb0 { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| status = "okay"; |
| |
| port@1 { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| reg = <1>; |
| #trigger-source-cells = <0>; |
| |
| hub_port1: port@1 { |
| reg = <1>; |
| #trigger-source-cells = <0>; |
| }; |
| |
| hub_port3: port@3 { |
| reg = <3>; |
| #trigger-source-cells = <0>; |
| }; |
| }; |
| }; |