I-O DATA WN-AX1167GR is a 2.4/5 GHz band 11ac router, based on MediaTek MT7621A. Specification: - MT7621A (2-Cores, 4-Threads) - 64 MB of RAM (DDR2) - 16 MB of Flash (SPI) - 2T2R 2.4/5 GHz - 5x 10/100/1000 Mbps Ethernet - 2x LEDs, 4x keys (2x buttons, 1x slide switch) - UART header on PCB - Vcc, GND, TX, RX from ethernet port side - baudrate: 115200 bps (U-Boot, OpenWrt) Stock firmware: In the stock firmware, WN-AX1167GR has two os images each composed of Linux kernel and rootfs. These images are stored in "Kernel" and "app" partition of the following partitions, respectively. (excerpt from dmesg): MX25L12805D(c2 2018c220) (16384 Kbytes) mtd .name = raspi, .size = 0x01000000 (16M) .erasesize = 0x00010000 (64K) .numeraseregions = 0 Creating 10 MTD partitions on "raspi": 0x000000000000-0x000001000000 : "ALL" 0x000000000000-0x000000030000 : "Bootloader" 0x000000030000-0x000000040000 : "Config " 0x000000040000-0x000000050000 : "Factory" 0x000000050000-0x000000060000 : "iNIC_rf" 0x000000060000-0x0000007e0000 : "Kernel" 0x000000800000-0x000000f80000 : "app" 0x000000f90000-0x000000fa0000 : "Key" 0x000000fa0000-0x000000fb0000 : "backup" 0x000000fb0000-0x000001000000 : "storage" The flag for boot partition is stored in "Key" partition, and U-Boot reads this and determines the partition to boot. If the image that U-Boot first reads according to the flag is "Bad Magic Number", U-Boot then tries to boot from the other image. If the second image is correct, change the flag to the number corresponding to that image and boot from that image. (example): ## Booting image at bc800000 ... Bad Magic Number,FFFFFFFF Boot from KERNEL 1 !! ## Booting image at bc060000 ... Image Name: MIPS OpenWrt Linux-4.14.50 Image Type: MIPS Linux kernel Image (lzma compressed) Data Size: 1865917 Bytes = 1.8 MB Load Address: 80001000 Entry Point: 80001000 Verifying Checksum ... OK Uncompressing Kernel Image ... OK raspi_erase_write: offs:f90000, count:34 . . Done! Starting kernel ... Flash instruction using factory image: 1. Connect the computer to the LAN port of WN-AX1167GR 2. Connect power cable to WN-AX1167GR and turn on it 3. Access to "192.168.0.1" on the web browser and open firmware update page ("ファームウェア") 4. Select the OpenWrt factory image and perform firmware update 5. On the initramfs image, execute "mtd erase firmware" to erase stock firmware and execute sysupgrade with sysupgrade image for WN-AX1167GR 6. Wait ~180 seconds to complete flasing Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>master
parent
f715d816b7
commit
0b83a23560
@ -0,0 +1,165 @@ |
||||
/dts-v1/; |
||||
|
||||
#include "mt7621.dtsi" |
||||
|
||||
#include <dt-bindings/gpio/gpio.h> |
||||
#include <dt-bindings/input/input.h> |
||||
|
||||
/ { |
||||
compatible = "iodata,wn-ax1167gr", "mediatek,mt7621-soc"; |
||||
model = "I-O DATA WN-AX1167GR"; |
||||
|
||||
memory@0 { |
||||
device_type = "memory"; |
||||
reg = <0x0 0x4000000>; |
||||
}; |
||||
|
||||
chosen { |
||||
bootargs = "console=ttyS0,115200"; |
||||
}; |
||||
|
||||
gpio-leds { |
||||
compatible = "gpio-leds"; |
||||
|
||||
power { |
||||
label = "wn-ax1167gr:green:power"; |
||||
gpios = <&gpio0 7 GPIO_ACTIVE_LOW>; |
||||
}; |
||||
|
||||
wps { |
||||
label = "wn-ax1167gr:green:wps"; |
||||
gpios = <&gpio0 17 GPIO_ACTIVE_LOW>; |
||||
}; |
||||
}; |
||||
|
||||
gpio-keys-polled { |
||||
compatible = "gpio-keys-polled"; |
||||
#address-cells = <1>; |
||||
#size-cells = <0>; |
||||
poll-interval = <20>; |
||||
|
||||
reset { |
||||
label = "reset"; |
||||
gpios = <&gpio0 10 GPIO_ACTIVE_LOW>; |
||||
linux,code = <KEY_RESTART>; |
||||
}; |
||||
|
||||
wps { |
||||
label = "wps"; |
||||
gpios = <&gpio0 14 GPIO_ACTIVE_LOW>; |
||||
linux,code = <KEY_WPS_BUTTON>; |
||||
}; |
||||
|
||||
auto { |
||||
label = "auto"; |
||||
gpios = <&gpio0 15 GPIO_ACTIVE_LOW>; |
||||
linux,code = <BTN_0>; |
||||
linux,input-type = <EV_SW>; |
||||
}; |
||||
|
||||
custom { |
||||
label = "custom"; |
||||
gpios = <&gpio0 16 GPIO_ACTIVE_LOW>; |
||||
linux,code = <BTN_0>; |
||||
linux,input-type = <EV_SW>; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&spi0 { |
||||
status = "okay"; |
||||
|
||||
m25p80@0 { |
||||
#address-cells = <1>; |
||||
#size-cells = <1>; |
||||
compatible = "jedec,spi-nor"; |
||||
reg = <0>; |
||||
spi-max-frequency = <10000000>; |
||||
m25p,chunked-io = <32>; |
||||
|
||||
partition@0 { |
||||
label = "Bootloader"; |
||||
reg = <0x0 0x30000>; |
||||
read-only; |
||||
}; |
||||
|
||||
partition@30000 { |
||||
label = "Config"; |
||||
reg = <0x30000 0x10000>; |
||||
read-only; |
||||
}; |
||||
|
||||
Factory: partition@40000 { |
||||
label = "Factory"; |
||||
reg = <0x40000 0x10000>; |
||||
read-only; |
||||
}; |
||||
|
||||
iNIC_rf: partition@50000 { |
||||
label = "iNIC_rf"; |
||||
reg = <0x50000 0x10000>; |
||||
read-only; |
||||
}; |
||||
|
||||
partition@60000 { |
||||
label = "firmware"; |
||||
reg = <0x60000 0xf30000>; |
||||
}; |
||||
|
||||
partition@f90000 { |
||||
label = "Key"; |
||||
reg = <0xf90000 0x10000>; |
||||
read-only; |
||||
}; |
||||
|
||||
partition@fa0000 { |
||||
label = "backup"; |
||||
reg = <0xfa0000 0x10000>; |
||||
read-only; |
||||
}; |
||||
|
||||
partition@fb0000 { |
||||
label = "storage"; |
||||
reg = <0xfb0000 0x50000>; |
||||
read-only; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
ðernet { |
||||
mtd-mac-address = <&iNIC_rf 0x4>; |
||||
}; |
||||
|
||||
&pinctrl { |
||||
state_default: pinctrl0 { |
||||
gpio { |
||||
ralink,group = "uart2", "uart3", "jtag"; |
||||
ralink,function = "gpio"; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&pcie { |
||||
status = "okay"; |
||||
|
||||
pcie0 { |
||||
mt76@0,0 { |
||||
reg = <0x0000 0 0 0 0>; |
||||
device_type = "pci"; |
||||
mediatek,mtd-eeprom = <&iNIC_rf 0x0>; |
||||
}; |
||||
}; |
||||
|
||||
pcie1 { |
||||
mt76@1,0 { |
||||
reg = <0x0000 0 0 0 0>; |
||||
device_type = "pci"; |
||||
mediatek,mtd-eeprom = <&Factory 0x0>; |
||||
ieee80211-freq-limit = <5000000 6000000>; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
&xhci { |
||||
status = "disabled"; |
||||
}; |
Loading…
Reference in new issue