mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-09 02:43:53 +08:00
mediatek: add iKuai-Q3000 model support; (#291)
Co-authored-by: seer300 <youremail@eg.com> Co-authored-by: hanwckf <hanwckf@vip.qq.com>
This commit is contained in:
parent
5cdd9218b2
commit
7a0b5b83c2
@ -0,0 +1,330 @@
|
|||||||
|
/dts-v1/;
|
||||||
|
#include "mt7981.dtsi"
|
||||||
|
/ {
|
||||||
|
compatible = "ikuai,q3000", "mediatek,mt7981-spim-snand-rfb";
|
||||||
|
model = "q3000";
|
||||||
|
|
||||||
|
aliases {
|
||||||
|
led-boot = &red_led;
|
||||||
|
led-failsafe = &red_led;
|
||||||
|
led-running = &green_led;
|
||||||
|
led-upgrade = &blue_led;
|
||||||
|
};
|
||||||
|
|
||||||
|
chosen {
|
||||||
|
bootargs = "console=ttyS0,115200n1 loglevel=8 earlycon=uart8250,mmio32,0x11002000 clk_ignore_unused";
|
||||||
|
};
|
||||||
|
|
||||||
|
gpio-keys {
|
||||||
|
compatible = "gpio-keys";
|
||||||
|
reset {
|
||||||
|
label = "reset";
|
||||||
|
linux,code = <KEY_RESTART>;
|
||||||
|
gpios = <&pio 1 GPIO_ACTIVE_LOW>;
|
||||||
|
};
|
||||||
|
|
||||||
|
wps {
|
||||||
|
label = "wps";
|
||||||
|
linux,code = <KEY_WPS_BUTTON>;
|
||||||
|
gpios = <&pio 0 GPIO_ACTIVE_LOW>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
leds {
|
||||||
|
compatible = "gpio-leds";
|
||||||
|
|
||||||
|
green_led: green {
|
||||||
|
label = "q3000:green";
|
||||||
|
gpios = <&pio 11 1>;
|
||||||
|
};
|
||||||
|
|
||||||
|
red_led: red {
|
||||||
|
label = "q3000:red";
|
||||||
|
gpios = <&pio 10 1>;
|
||||||
|
};
|
||||||
|
|
||||||
|
blue_led: blue {
|
||||||
|
label = "q3000:blue";
|
||||||
|
gpios = <&pio 12 1>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nmbm_spim_nand {
|
||||||
|
compatible = "generic,nmbm";
|
||||||
|
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
|
||||||
|
lower-mtd-device = <&spi_nand>;
|
||||||
|
forced-create;
|
||||||
|
|
||||||
|
partitions {
|
||||||
|
compatible = "fixed-partitions";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
|
||||||
|
partition@0 {
|
||||||
|
label = "BL2";
|
||||||
|
reg = <0x00000 0x0100000>;
|
||||||
|
read-only;
|
||||||
|
};
|
||||||
|
|
||||||
|
partition@100000 {
|
||||||
|
label = "u-boot-env";
|
||||||
|
reg = <0x0100000 0x0080000>;
|
||||||
|
};
|
||||||
|
|
||||||
|
partition@180000 {
|
||||||
|
label = "Factory";
|
||||||
|
reg = <0x180000 0x0200000>;
|
||||||
|
};
|
||||||
|
|
||||||
|
partition@380000 {
|
||||||
|
label = "FIP";
|
||||||
|
reg = <0x380000 0x0200000>;
|
||||||
|
};
|
||||||
|
|
||||||
|
partition@580000 {
|
||||||
|
label = "ubi";
|
||||||
|
reg = <0x580000 0x4000000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
sound_wm8960 {
|
||||||
|
compatible = "mediatek,mt79xx-wm8960-machine";
|
||||||
|
mediatek,platform = <&afe>;
|
||||||
|
audio-routing = "Headphone", "HP_L",
|
||||||
|
"Headphone", "HP_R",
|
||||||
|
"LINPUT1", "AMIC",
|
||||||
|
"RINPUT1", "AMIC";
|
||||||
|
mediatek,audio-codec = <&wm8960>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
|
||||||
|
sound_si3218x {
|
||||||
|
compatible = "mediatek,mt79xx-si3218x-machine";
|
||||||
|
mediatek,platform = <&afe>;
|
||||||
|
mediatek,ext-codec = <&proslic_spi>;
|
||||||
|
status = "disabled";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&afe {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&pcm_pins>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&i2c0 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&i2c_pins>;
|
||||||
|
status = "disabled";
|
||||||
|
|
||||||
|
wm8960: wm8960@1a {
|
||||||
|
compatible = "wlf,wm8960";
|
||||||
|
reg = <0x1a>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&uart0 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&watchdog {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
ð {
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
gmac0: mac@0 {
|
||||||
|
compatible = "mediatek,eth-mac";
|
||||||
|
reg = <0>;
|
||||||
|
phy-mode = "2500base-x";
|
||||||
|
|
||||||
|
fixed-link {
|
||||||
|
speed = <2500>;
|
||||||
|
full-duplex;
|
||||||
|
pause;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
mdio: mdio-bus {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
|
||||||
|
switch@0 {
|
||||||
|
compatible = "mediatek,mt7531";
|
||||||
|
reg = <31>;
|
||||||
|
reset-gpios = <&pio 39 0>;
|
||||||
|
|
||||||
|
ports {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
|
||||||
|
port@0 {
|
||||||
|
reg = <0>;
|
||||||
|
label = "lan1";
|
||||||
|
};
|
||||||
|
|
||||||
|
port@1 {
|
||||||
|
reg = <1>;
|
||||||
|
label = "lan2";
|
||||||
|
};
|
||||||
|
|
||||||
|
port@2 {
|
||||||
|
reg = <2>;
|
||||||
|
label = "lan3";
|
||||||
|
};
|
||||||
|
|
||||||
|
port@3 {
|
||||||
|
reg = <3>;
|
||||||
|
label = "wan";
|
||||||
|
};
|
||||||
|
|
||||||
|
port@6 {
|
||||||
|
reg = <6>;
|
||||||
|
label = "cpu";
|
||||||
|
ethernet = <&gmac0>;
|
||||||
|
phy-mode = "2500base-x";
|
||||||
|
|
||||||
|
fixed-link {
|
||||||
|
speed = <2500>;
|
||||||
|
full-duplex;
|
||||||
|
pause;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&hnat {
|
||||||
|
mtketh-wan = "wan";
|
||||||
|
mtketh-lan = "lan";
|
||||||
|
mtketh-max-gmac = <2>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&spi0 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&spi0_flash_pins>;
|
||||||
|
status = "okay";
|
||||||
|
spi_nand: spi_nand@0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
compatible = "spi-nand";
|
||||||
|
reg = <0>;
|
||||||
|
spi-max-frequency = <52000000>;
|
||||||
|
spi-tx-buswidth = <4>;
|
||||||
|
spi-rx-buswidth = <4>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&spi1 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&spic_pins>;
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
proslic_spi: proslic_spi@0 {
|
||||||
|
compatible = "silabs,proslic_spi";
|
||||||
|
reg = <0>;
|
||||||
|
spi-max-frequency = <10000000>;
|
||||||
|
spi-cpha = <1>;
|
||||||
|
spi-cpol = <1>;
|
||||||
|
channel_count = <1>;
|
||||||
|
debug_level = <4>; /* 1 = TRC, 2 = DBG, 4 = ERR */
|
||||||
|
reset_gpio = <&pio 15 0>;
|
||||||
|
ig,enable-spi = <1>; /* 1: Enable, 0: Disable */
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&pio {
|
||||||
|
i2c_pins: i2c-pins-g0 {
|
||||||
|
mux {
|
||||||
|
function = "i2c";
|
||||||
|
groups = "i2c0_0";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
pcm_pins: pcm-pins-g0 {
|
||||||
|
mux {
|
||||||
|
function = "pcm";
|
||||||
|
groups = "pcm";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
pwm0_pin: pwm0-pin-g0 {
|
||||||
|
mux {
|
||||||
|
function = "pwm";
|
||||||
|
groups = "pwm0_0";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
pwm1_pin: pwm1-pin-g0 {
|
||||||
|
mux {
|
||||||
|
function = "pwm";
|
||||||
|
groups = "pwm1_0";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
pwm2_pin: pwm2-pin {
|
||||||
|
mux {
|
||||||
|
function = "pwm";
|
||||||
|
groups = "pwm2";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
spi0_flash_pins: spi0-pins {
|
||||||
|
mux {
|
||||||
|
function = "spi";
|
||||||
|
groups = "spi0", "spi0_wp_hold";
|
||||||
|
};
|
||||||
|
|
||||||
|
conf-pu {
|
||||||
|
pins = "SPI0_CS", "SPI0_HOLD", "SPI0_WP";
|
||||||
|
drive-strength = <MTK_DRIVE_8mA>;
|
||||||
|
bias-pull-up = <MTK_PUPD_SET_R1R0_11>;
|
||||||
|
};
|
||||||
|
|
||||||
|
conf-pd {
|
||||||
|
pins = "SPI0_CLK", "SPI0_MOSI", "SPI0_MISO";
|
||||||
|
drive-strength = <MTK_DRIVE_8mA>;
|
||||||
|
bias-pull-down = <MTK_PUPD_SET_R1R0_11>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
spic_pins: spi1-pins {
|
||||||
|
mux {
|
||||||
|
function = "spi";
|
||||||
|
groups = "spi1_1";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
uart1_pins: uart1-pins-g1 {
|
||||||
|
mux {
|
||||||
|
function = "uart";
|
||||||
|
groups = "uart1_1";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
uart2_pins: uart2-pins-g1 {
|
||||||
|
mux {
|
||||||
|
function = "uart";
|
||||||
|
groups = "uart2_1";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&xhci {
|
||||||
|
mediatek,u3p-dis-msk = <0x0>;
|
||||||
|
phys = <&u2port0 PHY_TYPE_USB2>,
|
||||||
|
<&u3port0 PHY_TYPE_USB3>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&trng {
|
||||||
|
status = "disabled";
|
||||||
|
};
|
@ -501,6 +501,23 @@ define Device/jcg_q30
|
|||||||
endef
|
endef
|
||||||
TARGET_DEVICES += jcg_q30
|
TARGET_DEVICES += jcg_q30
|
||||||
|
|
||||||
|
define Device/ikuai_q3000
|
||||||
|
DEVICE_VENDOR := iKuai
|
||||||
|
DEVICE_MODEL := Q3000
|
||||||
|
DEVICE_DTS := mt7981-ikuai-q3000
|
||||||
|
DEVICE_DTS_DIR := $(DTS_DIR)/mediatek
|
||||||
|
SUPPORTED_DEVICES := ikuai,q3000
|
||||||
|
UBINIZE_OPTS := -E 5
|
||||||
|
BLOCKSIZE := 128k
|
||||||
|
PAGESIZE := 2048
|
||||||
|
IMAGE_SIZE := 114816k
|
||||||
|
KERNEL_IN_UBI := 1
|
||||||
|
IMAGES += factory.bin
|
||||||
|
IMAGE/factory.bin := append-ubi | check-size $$$$(IMAGE_SIZE)
|
||||||
|
IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
||||||
|
endef
|
||||||
|
TARGET_DEVICES += ikuai_q3000
|
||||||
|
|
||||||
define Device/livinet_zr-3020
|
define Device/livinet_zr-3020
|
||||||
DEVICE_VENDOR := Livinet
|
DEVICE_VENDOR := Livinet
|
||||||
DEVICE_MODEL := ZR-3020
|
DEVICE_MODEL := ZR-3020
|
||||||
|
@ -43,6 +43,11 @@ h3c,nx30pro)
|
|||||||
ucidef_set_led_default "green" "GREEN" "nx30pro:green" "1"
|
ucidef_set_led_default "green" "GREEN" "nx30pro:green" "1"
|
||||||
ucidef_set_led_default "red" "RED" "nx30pro:red" "0"
|
ucidef_set_led_default "red" "RED" "nx30pro:red" "0"
|
||||||
;;
|
;;
|
||||||
|
ikuai,q3000)
|
||||||
|
ucidef_set_led_default "green" "GREEN" "q3000:green" "1"
|
||||||
|
ucidef_set_led_default "blue" "BLUE" "q3000:blue" "0"
|
||||||
|
ucidef_set_led_default "red" "RED" "q3000:red" "0"
|
||||||
|
;;
|
||||||
konka,komi-a31)
|
konka,komi-a31)
|
||||||
ucidef_set_led_netdev "blue" "BLUE" "blue:status" "eth1" "link"
|
ucidef_set_led_netdev "blue" "BLUE" "blue:status" "eth1" "link"
|
||||||
;;
|
;;
|
||||||
|
@ -82,6 +82,7 @@ mediatek_setup_interfaces()
|
|||||||
nradio,wt9103)
|
nradio,wt9103)
|
||||||
ucidef_set_interfaces_lan_wan "lan1 lan2 lan3 lan4" eth1
|
ucidef_set_interfaces_lan_wan "lan1 lan2 lan3 lan4" eth1
|
||||||
;;
|
;;
|
||||||
|
ikuai,q3000 |\
|
||||||
ruijie,rg-x30e*)
|
ruijie,rg-x30e*)
|
||||||
ucidef_set_interfaces_lan_wan "lan1 lan2 lan3" wan
|
ucidef_set_interfaces_lan_wan "lan1 lan2 lan3" wan
|
||||||
;;
|
;;
|
||||||
@ -241,6 +242,10 @@ mediatek_setup_macs()
|
|||||||
label_mac=$wan_mac
|
label_mac=$wan_mac
|
||||||
local wifi_mac="$(mtd_get_mac_binary $part_name 0x04)"
|
local wifi_mac="$(mtd_get_mac_binary $part_name 0x04)"
|
||||||
;;
|
;;
|
||||||
|
ikuai,q3000)
|
||||||
|
wan_mac=$(mtd_get_mac_binary $part_name 0x10048)
|
||||||
|
lan_mac=$(macaddr_add $wan_mac 1)
|
||||||
|
;;
|
||||||
ruijie,rg-x30e*)
|
ruijie,rg-x30e*)
|
||||||
label_mac=$(mtd_get_mac_ascii product_info ethaddr)
|
label_mac=$(mtd_get_mac_ascii product_info ethaddr)
|
||||||
wan_mac=$label_mac
|
wan_mac=$label_mac
|
||||||
|
Loading…
x
Reference in New Issue
Block a user