diff --git a/target/linux/ipq40xx/base-files/etc/init.d/poe_switch b/target/linux/ipq40xx/base-files/etc/init.d/poe_switch new file mode 100755 index 0000000000..2dd99825b7 --- /dev/null +++ b/target/linux/ipq40xx/base-files/etc/init.d/poe_switch @@ -0,0 +1,22 @@ +#!/bin/sh /etc/rc.common + +START=21 +STOP=10 + +boot() { + case $(board_name) in + meraki,mr30h) + if [ $(cat /sys/class/gpio/poeaf_det/value) -eq 0 ]; then + echo "1" > /sys/class/gpio/pse_en/value + fi + ;; + esac +} + +shutdown() { + case $(board_name) in + meraki,mr30h) + echo "0" > /sys/class/gpio/pse_en/value + ;; + esac +} diff --git a/target/linux/ipq40xx/files-6.12/arch/arm/boot/dts/qcom/qcom-ipq4029-mr30h.dts b/target/linux/ipq40xx/files-6.12/arch/arm/boot/dts/qcom/qcom-ipq4029-mr30h.dts index 8b21736d00..3655238eb9 100644 --- a/target/linux/ipq40xx/files-6.12/arch/arm/boot/dts/qcom/qcom-ipq4029-mr30h.dts +++ b/target/linux/ipq40xx/files-6.12/arch/arm/boot/dts/qcom/qcom-ipq4029-mr30h.dts @@ -79,6 +79,24 @@ qcom,ess-interface-select = ; }; }; + + gpio_export { + compatible = "gpio-export"; + #size-cells = <0>; + + pse_en { + gpio-export,name = "pse_en"; + gpio-export,output = <1>; + gpios = <&tlmm 28 GPIO_ACTIVE_LOW>; + }; + + poeaf_det { + gpio-export,name = "poeaf_det"; + gpio-export,input = <0>; + gpios = <&tlmm 29 GPIO_ACTIVE_HIGH>; + }; + + }; }; &tricolor {