2021-02-10 13:52:34 +00:00
|
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
2018-03-07 21:10:01 +00:00
|
|
|
#
|
|
|
|
# Copyright (C) 2012-2016 OpenWrt.org
|
|
|
|
# Copyright (C) 2016 LEDE-project.org
|
|
|
|
|
mvebu: add support for Fortinet FortiGate 50E
Fortinet FortiGate 50E (FG-50E) is a UTM, based on Armada 385 (88F6820).
Specification:
- SoC : Marvell Armada 385 88F6820
- RAM : DDR3 2 GiB (4x Micron MT41K512M8DA-107, "D9SGQ")
- Flash : SPI-NOR 128 MiB (Macronix MX66L1G45GMI-10G)
- Ethernet : 7x 10/100/1000 Mbps
- LAN 1-5 : Marvell 88E6176
- WAN 1, 2 : Marvell 88E1512 (2x)
- LEDs/Keys : 18x/1x
- UART : "CONSOLE" port (RJ-45, RS-232C level)
- port : ttyS0
- settings : 9600bps 8n1
- assignment : 1:NC , 2:NC , 3:TXD, 4:GND,
5:GND, 6:RXD, 7:NC , 8:NC
- note : compatible with Cisco console cable
- HW Monitoring: nuvoTon NCT7802Y
- Power : 12 VDC, 2 A
- plug : Molex 5557-02R
Flash instruction using initramfs image:
1. Power on FG-50E and interrupt to show bootmenu
2. Call "[R]: Review TFTP parameters.", check TFTP parameters and
connect computer to "Image download port" in the parameters
3. Prepare TFTP server with the parameters obtained above
4. Rename OpenWrt initramfs image to "image.out" and put to TFTP
directory
5. Call "[T]: Initiate TFTP firmware transfer." to download initramfs
image from TFTP server
6. Type "r" key when the following message is showed, to boot initramfs
image without flashing to spi-nor flash
"Save as Default firmware/Backup firmware/Run image without saving:[D/B/R]?"
7. On initramfs image, backup mtd if needed
minimum:
- "firmware-info"
- "kernel"
- "rootfs"
7. On initramfs image, upload sysupgrade image to the device and perform
sysupgrade
8. Wait ~200 seconds to complete flashing and rebooting.
If the device is booted with stock firmware, login to bootmenu and
call "[B]: Boot with backup firmware and set as default." to set the
first OS image as default and boot it.
Notes:
- All "SPEED" LEDs(Green/Amber) of LAN and 1000M "SPEED" LEDs(Green) of
WAN1/2 are connected to GPIO expander. There is no way to indicate
link speed of networking device on Linux Kernel/OpenWrt, so those LEDs
cannot be handled like stock firmware.
On OpenWrt, use netdev(link) trigger instead.
- Both colors of Bi-color LEDs on the front panel cannot be turned on at
the same time.
- "PWR" and "Logo" LEDs are connected to power source directly.
- The following partitions are added for OpenWrt.
These partitions are contained in "uboot" partition (0x0-0x1fffff) on
stock firmware.
- "firmware-info"
- "dtb"
- "u-boot-env"
- "board-info"
Image header for bootmenu tftp:
0x0 - 0xf : ?
0x10 - 0x2f : Image Name
0x30 - 0x17f: ?
0x180 - 0x183: Kernel Offset*
0x184 - 0x187: Kernel Length*
0x188 - 0x18b: RootFS Offset (ext2)*
0x18c - 0x18f: RootFS Length (ext2)*
0x190 - 0x193: DTB Offset
0x194 - 0x197: DTB Length
0x198 - 0x19b: Data Offset (jffs2)
0x19c - 0x19f: Data Length (jffs2)
0x1a0 - 0x1ff: ?
*: required for initramfs image
MAC addresses:
(eth0): 70:4C:A5:xx:xx:7C (board-info, 0xd880 (hex))
WAN 1 : 70:4C:A5:xx:xx:7D
WAN 2 : 70:4C:A5:xx:xx:7E
LAN 1 : 70:4C:A5:xx:xx:7F
LAN 2 : 70:4C:A5:xx:xx:80
LAN 3 : 70:4C:A5:xx:xx:81
LAN 4 : 70:4C:A5:xx:xx:82
LAN 5 : 70:4C:A5:xx:xx:83
Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>
2023-03-08 12:54:14 +00:00
|
|
|
define Build/fortigate-header
|
|
|
|
( \
|
|
|
|
dd if=/dev/zero bs=384 count=1 2>/dev/null; \
|
|
|
|
datalen=$$(wc -c $@ | cut -d' ' -f1); \
|
|
|
|
datalen=$$(printf "%08x" $$datalen); \
|
|
|
|
datalen="$${datalen:6:2}$${datalen:4:2}$${datalen:2:2}$${datalen:0:2}"; \
|
|
|
|
printf $$(echo "00020000$${datalen}ffff0000ffff0000" | sed 's/../\\x&/g'); \
|
|
|
|
dd if=/dev/zero bs=112 count=1 2>/dev/null; \
|
|
|
|
cat $@; \
|
|
|
|
) > $@.new
|
|
|
|
mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
mvebu: add support for IIJ SA-W2
Internet Initiative Japan Inc. (IIJ) SA-W2 is a network appliance with
11ac (Wi-Fi 5) wlan, based on 88F6810.
Specification:
- SoC : Marvell Armada 380 88F6810
- RAM : DDR3 256 MiB (Micron MT41K64M16TW-107:J x2)
- Flash : SPI-NOR 32 MiB (Winbond W25Q256JVFIQ)
- WLAN : 2.4/5 GHz, Mini PCI-E
- 2.4 GHz : Silex SX-PCEGN (Atheros AR9287 (2T2R))
- 5 GHz : Silex SX-PCEAC (Qualcomm Atheros QCA9880 (3T3R))
- Ethernet : 10/100/1000 Mbps x5
- Switch : Marvell 88E6172
- LEDs/Keys : 12x/1x
- UART : "CONSOLE" port (RJ-45, RS-232C)
- settings : 115200n8
- assignment: 1:NC, 2:NC, 3:TXD, 4:GND,
5:GND, 6:RXD, 7:NC, 8:NC
- note : compatible with Cisco console cable
- Power : DC Input or PoE
- DC Input : 12 VDC, 3 A
- PoE : 802.3af
- module : Silvertel Ag9712-2BR
- note : USB ports shouldn't be used when powered by PoE
- Bootloader : PMON2000 based
- Stock : NetBSD based
Flash instruction using sysupgrade image:
1. Prepare TFTP server with IP address 192.168.0.10 and put sysupgrade
image to TFTP directory
2. Connect PC to "GE0/PoE" port on SA-W2
3. Power on SA-W2, interrupt count-down by Esc and enter to bootloader
CLI
4. Set IP address of the device
address 192.168.0.1
5. Download sysupgrade image and flash to storage
tftpload 192.168.0.10 <image name>
firmwrite
example:
#tftpload 192.168.0.10 openwrt-mvebu-cortexa9-iij_sa-w2-squashfs-sysupgrade.bin
Loading openwrt-mvebu-cortexa9-iij_sa-w2-squashfs-sysupgrade.bin
loaded 8127268 byte(s)
#firmwrite
Erasing FLASH block 32 Done 0x00200000.
Erasing FLASH block 33 Done 0x00210000.
...
Erasing FLASH block 155 Done 0x009b0000.
Erasing FLASH block 156 Done 0x009c0000.
Programming FLASH. Done.
Verifying FLASH. No Errors found.
6. Check the flashed firmware
firmcheck
example:
#firmcheck
[Normal firmware]
ident: 'SEIL2015'
copyright: 'ARM OpenWrt Linux-5.15.93'
version format: 1
version major: 9
version minor: 99
version release: 'r22060+36-5163bb5e54'
body size: 3578524
checksum: 0x8a083cb8
[Rescue firmware]
ident: 'SEIL2015'
copyright: 'Copyright (c) 2017 Internet Initiative Japan Inc. All rights reserved.'
version format: 1
version major: 3
version minor: 70
version release: 'Release'
body size: 10152458
checksum: 0x8f9518c2
7. Boot with the flashed firmware
boot
Note:
- The bootloader on this device is not U-Boot and it's environment space
("bootloader-env") has no compatibility with U-Boot tools.
- eth1 is connected to port6 of 88E6172 switch, but multi-cpu port can't
be handled on Linux Kernel and not defined.
- Powering by PoE hasn't been tested yet.
- This device has 2x OS images on flash and they can be switched by
setting "BOOTDEV" variable on bootloader CLI.
That variable supports the following values:
- "flash" : primary image on flash ("firmware")
- "rescue": secondary image on flash ("rescue")
- "usb" : usb storage (broken?)
- "lan0/1": network
command to set:
set BOOTDEV=<dev>
example:
set BOOTDEV=rescue
This commit also supports booting from secondary partition.
- To execute initramfs image on bootloader CLI, use "go" command.
("go" command is not listed on the output of "help", but available)
example (download and execute):
address 192.168.0.1
tftpload 192.168.0.10 openwrt-mvebu-cortexa9-iij_sa-w2-initramfs-kernel.bin
go
MAC addresses:
LAN : 00:E0:4D:xx:xx:19 (none)
WAN : 00:E0:4D:xx:xx:18 (board_info, 0x6 (hex))
2.4 GHz: 84:25:3F:xx:xx:xx (Mini PCI-E card)
5 GHz : 84:25:3F:xx:xx:xx (Mini PCI-E card)
Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>
2022-11-13 08:22:26 +00:00
|
|
|
define Build/seil-header
|
|
|
|
( \
|
|
|
|
data_size_crc="$$(gzip -c $@ | tail -c8 | \
|
|
|
|
od -An -tx8 --endian little | tr -d ' \n')"; \
|
|
|
|
printf "SEIL2015"; \
|
|
|
|
printf "$(call toupper,$(LINUX_KARCH)) $(VERSION_DIST) Linux-$(LINUX_VERSION)" | \
|
|
|
|
dd bs=80 count=1 conv=sync 2>/dev/null; \
|
|
|
|
printf "$$(echo $${data_size_crc:8:8} | sed 's/../\\x&/g')"; \
|
|
|
|
printf "\x00\x00\x00\x01\x00\x00\x00\x09\x00\x00\x00\x63"; \
|
|
|
|
printf "$(REVISION)" | dd bs=32 count=1 conv=sync 2>/dev/null; \
|
|
|
|
printf "\x00\x00\x00\x00"; \
|
|
|
|
printf "$$(echo $${data_size_crc:0:8} | sed 's/../\\x&/g')"; \
|
|
|
|
cat $@; \
|
|
|
|
) > $@.new
|
|
|
|
mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
2020-07-14 14:11:22 +00:00
|
|
|
define Device/dsa-migration
|
|
|
|
DEVICE_COMPAT_VERSION := 1.1
|
2020-08-08 19:30:44 +00:00
|
|
|
DEVICE_COMPAT_MESSAGE := Config cannot be migrated from swconfig to DSA
|
2020-07-14 14:11:22 +00:00
|
|
|
endef
|
|
|
|
|
2021-02-06 03:38:03 +00:00
|
|
|
define Device/kernel-size-migration
|
|
|
|
DEVICE_COMPAT_VERSION := 2.0
|
|
|
|
DEVICE_COMPAT_MESSAGE := Partition design has changed compared to older versions (up to 19.07) due to kernel size restrictions. \
|
|
|
|
Upgrade via sysupgrade mechanism is not possible, so new installation via factory style image is required.
|
|
|
|
endef
|
|
|
|
|
2023-02-20 23:43:55 +00:00
|
|
|
define Device/buffalo_ls220de
|
|
|
|
$(Device/NAND-128K)
|
|
|
|
DEVICE_VENDOR := Buffalo
|
|
|
|
DEVICE_MODEL := LinkStation LS220DE
|
|
|
|
KERNEL_UBIFS_OPTS = -m $$(PAGESIZE) -e 124KiB -c 172 -x none
|
|
|
|
KERNEL := kernel-bin | append-dtb | uImage none | buffalo-kernel-ubifs
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | uImage none
|
|
|
|
DEVICE_DTS := armada-370-buffalo-ls220de
|
|
|
|
DEVICE_PACKAGES := \
|
|
|
|
kmod-hwmon-gpiofan kmod-hwmon-drivetemp kmod-linkstation-poweroff \
|
|
|
|
kmod-md-mod kmod-md-raid0 kmod-md-raid1 kmod-md-raid10 kmod-fs-xfs \
|
|
|
|
mdadm mkf2fs e2fsprogs partx-utils
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += buffalo_ls220de
|
|
|
|
|
mvebu: add support for Buffalo LinkStation LS421DE
Buffalo LinkStation LS421DE is a dual bay NAS, based on Marvell Armada 370
Hardware:
SoC: Marvell Armada 88F6707-A1
CPU: Cortex-A9 1200 MHz, 1 core
Flash: SPI-NOR 1 MiB, NAND 512 MiB
RAM: DDR3 512 MiB
Ethernet: 1x 10/100/1000 Mbps
USB: 1x 2.0, 1x 3.0
SATA: 2x 3.0 Gbps
LEDs/Input : 5x / 2x (1x button, 1x slide-switch)
RTC: Ricoh RS5C372A, I2C, no battery
Flash instruction (UART+TFTP):
1. Downgrade the OEM firmware to 1.34 version (BUFFALO_BOOTVER=0.13)
2. Remove any hard drive from inside the bays.
3. Boot the Openwrt initramfs image using the U-Boot serial console:
tftpboot 0x1200000 buffalo_ls421de-initramfs-kernel.bin
bootm 0x1200000
4. Flash the sysupgrade image using the Openwrt console:
sysupgrade -n buffalo_ls421de-squashfs-sysupgrade.bin
5. Wait until it finish, the device will reboot with Openwrt installed
on the NAND flash.
Note:
- Device shuting down doesn't work, even if the power slide switch is
used. We must first, via MDIO, set the unused LED2 at the ethernet
phy0 to off state. Reboot works ok.
Signed-off-by: Daniel González Cabanelas <dgcbueu@gmail.com>
Reviewed-by: Tomasz Maciej Nowak <tomek_n@o2.pl>
2020-04-07 12:35:26 +00:00
|
|
|
define Device/buffalo_ls421de
|
|
|
|
$(Device/NAND-128K)
|
|
|
|
DEVICE_VENDOR := Buffalo
|
|
|
|
DEVICE_MODEL := LinkStation LS421DE
|
|
|
|
SUBPAGESIZE :=
|
|
|
|
KERNEL_SIZE := 33554432
|
|
|
|
FILESYSTEMS := squashfs ubifs
|
|
|
|
KERNEL := kernel-bin | append-dtb | uImage none | buffalo-kernel-jffs2
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | uImage none
|
|
|
|
DEVICE_DTS := armada-370-buffalo-ls421de
|
|
|
|
DEVICE_PACKAGES := \
|
2020-06-28 21:52:10 +00:00
|
|
|
kmod-rtc-rs5c372a kmod-hwmon-gpiofan kmod-hwmon-drivetemp kmod-usb3 \
|
2020-08-28 09:20:46 +00:00
|
|
|
kmod-linkstation-poweroff kmod-md-raid0 kmod-md-raid1 kmod-md-mod \
|
|
|
|
kmod-fs-xfs mkf2fs e2fsprogs partx-utils
|
mvebu: add support for Buffalo LinkStation LS421DE
Buffalo LinkStation LS421DE is a dual bay NAS, based on Marvell Armada 370
Hardware:
SoC: Marvell Armada 88F6707-A1
CPU: Cortex-A9 1200 MHz, 1 core
Flash: SPI-NOR 1 MiB, NAND 512 MiB
RAM: DDR3 512 MiB
Ethernet: 1x 10/100/1000 Mbps
USB: 1x 2.0, 1x 3.0
SATA: 2x 3.0 Gbps
LEDs/Input : 5x / 2x (1x button, 1x slide-switch)
RTC: Ricoh RS5C372A, I2C, no battery
Flash instruction (UART+TFTP):
1. Downgrade the OEM firmware to 1.34 version (BUFFALO_BOOTVER=0.13)
2. Remove any hard drive from inside the bays.
3. Boot the Openwrt initramfs image using the U-Boot serial console:
tftpboot 0x1200000 buffalo_ls421de-initramfs-kernel.bin
bootm 0x1200000
4. Flash the sysupgrade image using the Openwrt console:
sysupgrade -n buffalo_ls421de-squashfs-sysupgrade.bin
5. Wait until it finish, the device will reboot with Openwrt installed
on the NAND flash.
Note:
- Device shuting down doesn't work, even if the power slide switch is
used. We must first, via MDIO, set the unused LED2 at the ethernet
phy0 to off state. Reboot works ok.
Signed-off-by: Daniel González Cabanelas <dgcbueu@gmail.com>
Reviewed-by: Tomasz Maciej Nowak <tomek_n@o2.pl>
2020-04-07 12:35:26 +00:00
|
|
|
endef
|
|
|
|
TARGET_DEVICES += buffalo_ls421de
|
|
|
|
|
2021-12-11 22:23:22 +00:00
|
|
|
define Device/ctera_c200-v2
|
|
|
|
PAGESIZE := 2048
|
|
|
|
SUBPAGESIZE := 512
|
|
|
|
BLOCKSIZE := 128k
|
|
|
|
DEVICE_VENDOR := Ctera
|
|
|
|
DEVICE_MODEL := C200
|
|
|
|
DEVICE_VARIANT := V2
|
|
|
|
SOC := armada-370
|
|
|
|
KERNEL := kernel-bin | append-dtb | uImage none | ctera-firmware
|
|
|
|
KERNEL_IN_UBI :=
|
|
|
|
KERNEL_SUFFIX := -factory.firm
|
|
|
|
DEVICE_PACKAGES := \
|
|
|
|
kmod-gpio-button-hotplug kmod-hwmon-drivetemp kmod-hwmon-nct7802 \
|
|
|
|
kmod-rtc-s35390a kmod-usb3 kmod-usb-ledtrig-usbport
|
|
|
|
IMAGES := sysupgrade.bin
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += ctera_c200-v2
|
|
|
|
|
2020-01-31 15:46:13 +00:00
|
|
|
define Device/cznic_turris-omnia
|
|
|
|
DEVICE_VENDOR := CZ.NIC
|
|
|
|
DEVICE_MODEL := Turris Omnia
|
|
|
|
KERNEL_INSTALL := 1
|
2021-01-30 12:32:43 +00:00
|
|
|
SOC := armada-385
|
2020-12-22 12:17:32 +00:00
|
|
|
KERNEL := kernel-bin
|
2021-01-30 12:32:43 +00:00
|
|
|
KERNEL_INITRAMFS := kernel-bin | gzip | fit gzip $$(KDIR)/image-$$(DEVICE_DTS).dtb
|
2020-01-31 15:46:13 +00:00
|
|
|
DEVICE_PACKAGES := \
|
|
|
|
mkf2fs e2fsprogs kmod-fs-vfat kmod-nls-cp437 kmod-nls-iso8859-1 \
|
2022-12-28 04:44:11 +00:00
|
|
|
wpad-basic-mbedtls kmod-ath9k kmod-ath10k-ct ath10k-firmware-qca988x-ct \
|
2022-05-19 19:10:34 +00:00
|
|
|
partx-utils kmod-i2c-mux-pca954x kmod-leds-turris-omnia
|
2022-02-26 08:37:26 +00:00
|
|
|
IMAGES := sysupgrade.img.gz
|
|
|
|
IMAGE/sysupgrade.img.gz := boot-scr | boot-img | sdcard-img | gzip | append-metadata
|
2020-01-31 15:46:13 +00:00
|
|
|
SUPPORTED_DEVICES += armada-385-turris-omnia
|
2019-12-23 07:34:49 +00:00
|
|
|
BOOT_SCRIPT := turris-omnia
|
2020-01-31 15:46:13 +00:00
|
|
|
endef
|
|
|
|
TARGET_DEVICES += cznic_turris-omnia
|
|
|
|
|
mvebu: add support for Fortinet FortiGate 30E
Fortinet FortiGate 30E (FG-30E) is a UTM, based on Armada 385 (88F6820).
Specification:
- SoC : Marvell Armada 385 88F6820
- RAM : DDR3 1 GiB (4x Micron MT41K256M8DA-125, "D9PSH")
- Flash : SPI-NOR 128 MiB (Macronix MX66L1G45GMI-10G)
- Ethernet : 5x 10/100/1000 Mbps
- Switch : Marvell 88E6176
- LEDs/Keys : 16x/1x
- UART : "CONSOLE" port (RJ-45, RS-232C level)
- port : ttyS0
- settings : 9600bps 8n1
- assignment : 1:NC , 2:NC , 3:TXD, 4:GND,
5:GND, 6:RXD, 7:NC , 8:NC
- note : compatible with Cisco console cable
- HW Monitoring: nuvoTon NCT7802Y
- Power : 12 VDC, 2 A
- plug : Modex 5557-02R
Flash instruction using initramfs image:
1. Power on FG-30E and interrupt to show bootmenu
2. Call "[I]: System information." -> "[S]: Set serial port baudrate."
and set baudrate to 9600 bps
3. Call "[R]: Review TFTP parameters.", check TFTP parameters and
connect computer to "Image download port" in the parameters
4. Prepare TFTP server with the parameters obtained above
5. Rename OpenWrt initramfs image to "image.out" and put to TFTP
directory
6. Call "[T]: Initiate TFTP firmware transfer." to download initramfs
image from TFTP server
7. Type "r" key when the following message is showed, to boot initramfs
image without flashing to spi-nor flash
"Save as Default firmware/Backup firmware/Run image without saving:[D/B/R]?"
8. On initramfs image, backup mtd if needed
minimum:
- "firmware-info"
- "kernel"
- "rootfs"
9. On initramfs image, upload sysupgrade image to the device and perform
sysupgrade
10. Wait ~200 seconds to complete flashing and rebooting.
If the device is booted with stock firmware, login to bootmenu and
call "[B]: Boot with backup firmware and set as default." to set the
first OS image as default and boot it.
Notes:
- Both colors of Bi-color LEDs on the front panel cannot be turned on at
the same time.
- "PWR" and "Logo" LEDs are connected to power source directly.
- The following partitions are added for OpenWrt.
These partitions are contained in "uboot" partition (0x0-0x1fffff) on
stock firmware.
- "firmware-info"
- "dtb"
- "u-boot-env"
- "board-info"
Image header for bootmenu tftp:
0x0 - 0xf : ?
0x10 - 0x2f : Image Name
0x30 - 0x17f: ?
0x180 - 0x183: Kernel Offset*
0x184 - 0x187: Kernel Length*
0x188 - 0x18b: RootFS Offset (ext2)*
0x18c - 0x18f: RootFS Length (ext2)*
0x190 - 0x193: DTB Offset
0x194 - 0x197: DTB Length
0x198 - 0x19b: Data Offset (jffs2)
0x19c - 0x19f: Data Length (jffs2)
0x1a0 - 0x1ff: ?
*: required for initramfs image
MAC addresses:
(eth0): 70:4C:A5:xx:xx:CE (board-info, 0xd880 (hex))
WAN : 70:4C:A5:xx:xx:CF
LAN 1 : 70:4C:A5:xx:xx:D0
LAN 2 : 70:4C:A5:xx:xx:D1
LAN 3 : 70:4C:A5:xx:xx:D2
LAN 4 : 70:4C:A5:xx:xx:D3
Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>
2023-03-21 06:23:56 +00:00
|
|
|
define Device/fortinet_fg-30e
|
|
|
|
DEVICE_VENDOR := Fortinet
|
|
|
|
DEVICE_MODEL := FortiGate 30E
|
|
|
|
SOC := armada-385
|
|
|
|
KERNEL := kernel-bin | append-dtb
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | fortigate-header | \
|
|
|
|
gzip-filename FGT30E
|
|
|
|
KERNEL_SIZE := 6144k
|
|
|
|
DEVICE_DTS := armada-385-fortinet-fg-30e
|
|
|
|
IMAGE/sysupgrade.bin := append-rootfs | pad-rootfs | \
|
|
|
|
sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
|
|
DEVICE_PACKAGES := kmod-hwmon-nct7802
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += fortinet_fg-30e
|
|
|
|
|
mvebu: add support for Fortinet FortiGate 50E
Fortinet FortiGate 50E (FG-50E) is a UTM, based on Armada 385 (88F6820).
Specification:
- SoC : Marvell Armada 385 88F6820
- RAM : DDR3 2 GiB (4x Micron MT41K512M8DA-107, "D9SGQ")
- Flash : SPI-NOR 128 MiB (Macronix MX66L1G45GMI-10G)
- Ethernet : 7x 10/100/1000 Mbps
- LAN 1-5 : Marvell 88E6176
- WAN 1, 2 : Marvell 88E1512 (2x)
- LEDs/Keys : 18x/1x
- UART : "CONSOLE" port (RJ-45, RS-232C level)
- port : ttyS0
- settings : 9600bps 8n1
- assignment : 1:NC , 2:NC , 3:TXD, 4:GND,
5:GND, 6:RXD, 7:NC , 8:NC
- note : compatible with Cisco console cable
- HW Monitoring: nuvoTon NCT7802Y
- Power : 12 VDC, 2 A
- plug : Molex 5557-02R
Flash instruction using initramfs image:
1. Power on FG-50E and interrupt to show bootmenu
2. Call "[R]: Review TFTP parameters.", check TFTP parameters and
connect computer to "Image download port" in the parameters
3. Prepare TFTP server with the parameters obtained above
4. Rename OpenWrt initramfs image to "image.out" and put to TFTP
directory
5. Call "[T]: Initiate TFTP firmware transfer." to download initramfs
image from TFTP server
6. Type "r" key when the following message is showed, to boot initramfs
image without flashing to spi-nor flash
"Save as Default firmware/Backup firmware/Run image without saving:[D/B/R]?"
7. On initramfs image, backup mtd if needed
minimum:
- "firmware-info"
- "kernel"
- "rootfs"
7. On initramfs image, upload sysupgrade image to the device and perform
sysupgrade
8. Wait ~200 seconds to complete flashing and rebooting.
If the device is booted with stock firmware, login to bootmenu and
call "[B]: Boot with backup firmware and set as default." to set the
first OS image as default and boot it.
Notes:
- All "SPEED" LEDs(Green/Amber) of LAN and 1000M "SPEED" LEDs(Green) of
WAN1/2 are connected to GPIO expander. There is no way to indicate
link speed of networking device on Linux Kernel/OpenWrt, so those LEDs
cannot be handled like stock firmware.
On OpenWrt, use netdev(link) trigger instead.
- Both colors of Bi-color LEDs on the front panel cannot be turned on at
the same time.
- "PWR" and "Logo" LEDs are connected to power source directly.
- The following partitions are added for OpenWrt.
These partitions are contained in "uboot" partition (0x0-0x1fffff) on
stock firmware.
- "firmware-info"
- "dtb"
- "u-boot-env"
- "board-info"
Image header for bootmenu tftp:
0x0 - 0xf : ?
0x10 - 0x2f : Image Name
0x30 - 0x17f: ?
0x180 - 0x183: Kernel Offset*
0x184 - 0x187: Kernel Length*
0x188 - 0x18b: RootFS Offset (ext2)*
0x18c - 0x18f: RootFS Length (ext2)*
0x190 - 0x193: DTB Offset
0x194 - 0x197: DTB Length
0x198 - 0x19b: Data Offset (jffs2)
0x19c - 0x19f: Data Length (jffs2)
0x1a0 - 0x1ff: ?
*: required for initramfs image
MAC addresses:
(eth0): 70:4C:A5:xx:xx:7C (board-info, 0xd880 (hex))
WAN 1 : 70:4C:A5:xx:xx:7D
WAN 2 : 70:4C:A5:xx:xx:7E
LAN 1 : 70:4C:A5:xx:xx:7F
LAN 2 : 70:4C:A5:xx:xx:80
LAN 3 : 70:4C:A5:xx:xx:81
LAN 4 : 70:4C:A5:xx:xx:82
LAN 5 : 70:4C:A5:xx:xx:83
Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>
2023-03-08 12:54:14 +00:00
|
|
|
define Device/fortinet_fg-50e
|
|
|
|
DEVICE_VENDOR := Fortinet
|
|
|
|
DEVICE_MODEL := FortiGate 50E
|
|
|
|
SOC := armada-385
|
|
|
|
KERNEL := kernel-bin | append-dtb
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | fortigate-header | \
|
|
|
|
gzip-filename FGT50E
|
|
|
|
KERNEL_SIZE := 6144k
|
|
|
|
DEVICE_DTS := armada-385-fortinet-fg-50e
|
|
|
|
IMAGE/sysupgrade.bin := append-rootfs | pad-rootfs | \
|
|
|
|
sysupgrade-tar rootfs=$$$$@ | append-metadata
|
|
|
|
DEVICE_PACKAGES := kmod-hwmon-nct7802
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += fortinet_fg-50e
|
|
|
|
|
2020-01-31 15:46:13 +00:00
|
|
|
define Device/globalscale_mirabox
|
|
|
|
$(Device/NAND-512K)
|
|
|
|
DEVICE_VENDOR := Globalscale
|
|
|
|
DEVICE_MODEL := Mirabox
|
|
|
|
SOC := armada-370
|
|
|
|
SUPPORTED_DEVICES += mirabox
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += globalscale_mirabox
|
|
|
|
|
mvebu: add support for IIJ SA-W2
Internet Initiative Japan Inc. (IIJ) SA-W2 is a network appliance with
11ac (Wi-Fi 5) wlan, based on 88F6810.
Specification:
- SoC : Marvell Armada 380 88F6810
- RAM : DDR3 256 MiB (Micron MT41K64M16TW-107:J x2)
- Flash : SPI-NOR 32 MiB (Winbond W25Q256JVFIQ)
- WLAN : 2.4/5 GHz, Mini PCI-E
- 2.4 GHz : Silex SX-PCEGN (Atheros AR9287 (2T2R))
- 5 GHz : Silex SX-PCEAC (Qualcomm Atheros QCA9880 (3T3R))
- Ethernet : 10/100/1000 Mbps x5
- Switch : Marvell 88E6172
- LEDs/Keys : 12x/1x
- UART : "CONSOLE" port (RJ-45, RS-232C)
- settings : 115200n8
- assignment: 1:NC, 2:NC, 3:TXD, 4:GND,
5:GND, 6:RXD, 7:NC, 8:NC
- note : compatible with Cisco console cable
- Power : DC Input or PoE
- DC Input : 12 VDC, 3 A
- PoE : 802.3af
- module : Silvertel Ag9712-2BR
- note : USB ports shouldn't be used when powered by PoE
- Bootloader : PMON2000 based
- Stock : NetBSD based
Flash instruction using sysupgrade image:
1. Prepare TFTP server with IP address 192.168.0.10 and put sysupgrade
image to TFTP directory
2. Connect PC to "GE0/PoE" port on SA-W2
3. Power on SA-W2, interrupt count-down by Esc and enter to bootloader
CLI
4. Set IP address of the device
address 192.168.0.1
5. Download sysupgrade image and flash to storage
tftpload 192.168.0.10 <image name>
firmwrite
example:
#tftpload 192.168.0.10 openwrt-mvebu-cortexa9-iij_sa-w2-squashfs-sysupgrade.bin
Loading openwrt-mvebu-cortexa9-iij_sa-w2-squashfs-sysupgrade.bin
loaded 8127268 byte(s)
#firmwrite
Erasing FLASH block 32 Done 0x00200000.
Erasing FLASH block 33 Done 0x00210000.
...
Erasing FLASH block 155 Done 0x009b0000.
Erasing FLASH block 156 Done 0x009c0000.
Programming FLASH. Done.
Verifying FLASH. No Errors found.
6. Check the flashed firmware
firmcheck
example:
#firmcheck
[Normal firmware]
ident: 'SEIL2015'
copyright: 'ARM OpenWrt Linux-5.15.93'
version format: 1
version major: 9
version minor: 99
version release: 'r22060+36-5163bb5e54'
body size: 3578524
checksum: 0x8a083cb8
[Rescue firmware]
ident: 'SEIL2015'
copyright: 'Copyright (c) 2017 Internet Initiative Japan Inc. All rights reserved.'
version format: 1
version major: 3
version minor: 70
version release: 'Release'
body size: 10152458
checksum: 0x8f9518c2
7. Boot with the flashed firmware
boot
Note:
- The bootloader on this device is not U-Boot and it's environment space
("bootloader-env") has no compatibility with U-Boot tools.
- eth1 is connected to port6 of 88E6172 switch, but multi-cpu port can't
be handled on Linux Kernel and not defined.
- Powering by PoE hasn't been tested yet.
- This device has 2x OS images on flash and they can be switched by
setting "BOOTDEV" variable on bootloader CLI.
That variable supports the following values:
- "flash" : primary image on flash ("firmware")
- "rescue": secondary image on flash ("rescue")
- "usb" : usb storage (broken?)
- "lan0/1": network
command to set:
set BOOTDEV=<dev>
example:
set BOOTDEV=rescue
This commit also supports booting from secondary partition.
- To execute initramfs image on bootloader CLI, use "go" command.
("go" command is not listed on the output of "help", but available)
example (download and execute):
address 192.168.0.1
tftpload 192.168.0.10 openwrt-mvebu-cortexa9-iij_sa-w2-initramfs-kernel.bin
go
MAC addresses:
LAN : 00:E0:4D:xx:xx:19 (none)
WAN : 00:E0:4D:xx:xx:18 (board_info, 0x6 (hex))
2.4 GHz: 84:25:3F:xx:xx:xx (Mini PCI-E card)
5 GHz : 84:25:3F:xx:xx:xx (Mini PCI-E card)
Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>
2022-11-13 08:22:26 +00:00
|
|
|
define Device/iij_sa-w2
|
|
|
|
DEVICE_VENDOR := IIJ
|
|
|
|
DEVICE_MODEL := SA-W2
|
|
|
|
SOC := armada-380
|
|
|
|
KERNEL := kernel-bin | append-dtb | seil-header
|
|
|
|
DEVICE_DTS := armada-380-iij-sa-w2
|
|
|
|
IMAGE_SIZE := 15360k
|
|
|
|
IMAGE/sysupgrade.bin := append-kernel | pad-to 64k | \
|
|
|
|
append-rootfs | pad-rootfs | check-size | append-metadata
|
|
|
|
DEVICE_PACKAGES := kmod-ath9k kmod-ath10k-ct ath10k-firmware-qca988x-ct \
|
|
|
|
wpad-basic-mbedtls
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += iij_sa-w2
|
|
|
|
|
2022-01-01 14:47:43 +00:00
|
|
|
define Device/iptime_nas1dual
|
|
|
|
DEVICE_VENDOR := ipTIME
|
|
|
|
DEVICE_MODEL := NAS1dual
|
|
|
|
DEVICE_PACKAGES := kmod-hwmon-drivetemp kmod-hwmon-gpiofan kmod-usb3
|
|
|
|
SOC := armada-385
|
|
|
|
KERNEL := kernel-bin | append-dtb | iptime-naspkg nas1dual
|
|
|
|
KERNEL_SIZE := 6144k
|
|
|
|
IMAGES := sysupgrade.bin
|
|
|
|
IMAGE_SIZE := 64256k
|
|
|
|
IMAGE/sysupgrade.bin := append-kernel | pad-to $$(KERNEL_SIZE) | \
|
|
|
|
append-rootfs | pad-rootfs | check-size | append-metadata
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += iptime_nas1dual
|
|
|
|
|
2020-07-12 13:35:54 +00:00
|
|
|
define Device/kobol_helios4
|
|
|
|
DEVICE_VENDOR := Kobol
|
|
|
|
DEVICE_MODEL := Helios4
|
|
|
|
KERNEL_INSTALL := 1
|
|
|
|
KERNEL := kernel-bin
|
|
|
|
DEVICE_PACKAGES := mkf2fs e2fsprogs partx-utils
|
|
|
|
IMAGES := sdcard.img.gz
|
|
|
|
IMAGE/sdcard.img.gz := boot-scr | boot-img-ext4 | sdcard-img-ext4 | gzip | append-metadata
|
|
|
|
SOC := armada-388
|
2023-01-19 08:10:41 +00:00
|
|
|
UBOOT := helios4-u-boot-with-spl.kwb
|
2020-07-12 13:35:54 +00:00
|
|
|
BOOT_SCRIPT := clearfog
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += kobol_helios4
|
|
|
|
|
2018-03-07 21:10:01 +00:00
|
|
|
define Device/linksys
|
|
|
|
$(Device/NAND-128K)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_VENDOR := Linksys
|
2022-12-28 04:44:11 +00:00
|
|
|
DEVICE_PACKAGES := kmod-mwlwifi wpad-basic-mbedtls
|
2019-05-11 17:37:31 +00:00
|
|
|
IMAGES += factory.img
|
2020-06-24 17:56:23 +00:00
|
|
|
IMAGE/factory.img := append-kernel | pad-to $$$$(KERNEL_SIZE) | \
|
|
|
|
append-ubi | pad-to $$$$(PAGESIZE)
|
2018-03-07 21:10:01 +00:00
|
|
|
KERNEL_SIZE := 6144k
|
|
|
|
endef
|
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/linksys_wrt1200ac
|
2019-09-09 22:13:30 +00:00
|
|
|
$(call Device/linksys)
|
2020-07-14 14:11:22 +00:00
|
|
|
$(Device/dsa-migration)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_MODEL := WRT1200AC
|
|
|
|
DEVICE_ALT0_VENDOR := Linksys
|
|
|
|
DEVICE_ALT0_MODEL := Caiman
|
2018-03-07 21:10:01 +00:00
|
|
|
DEVICE_DTS := armada-385-linksys-caiman
|
|
|
|
DEVICE_PACKAGES += mwlwifi-firmware-88w8864
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-385-linksys-caiman linksys,caiman
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += linksys_wrt1200ac
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2020-01-31 15:46:13 +00:00
|
|
|
define Device/linksys_wrt1900acs
|
|
|
|
$(call Device/linksys)
|
2020-07-14 14:11:22 +00:00
|
|
|
$(Device/dsa-migration)
|
2020-01-31 15:46:13 +00:00
|
|
|
DEVICE_MODEL := WRT1900ACS
|
|
|
|
DEVICE_VARIANT := v1
|
|
|
|
DEVICE_ALT0_VENDOR := Linksys
|
|
|
|
DEVICE_ALT0_MODEL := WRT1900ACS
|
|
|
|
DEVICE_ALT0_VARIANT := v2
|
|
|
|
DEVICE_ALT1_VENDOR := Linksys
|
|
|
|
DEVICE_ALT1_MODEL := Shelby
|
|
|
|
DEVICE_DTS := armada-385-linksys-shelby
|
|
|
|
DEVICE_PACKAGES += mwlwifi-firmware-88w8864
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-385-linksys-shelby linksys,shelby
|
2020-01-31 15:46:13 +00:00
|
|
|
endef
|
|
|
|
TARGET_DEVICES += linksys_wrt1900acs
|
|
|
|
|
mvebu: rename Linksys devices based on their common names
The Linksys devices in mvebu target feature a mixed naming,
where parts are based on the official product name (device
node, image; e.g. WRT3200ACM) and parts are based on the
internal code name (DTS file name, compatible, LED labels;
e.g. rango). This inconsistent naming has been perceived
as quite confusing.
A recent attempt by Paul Spooren to harmonize this naming
in kernel has been declined there. However, for us it still
makes sense to apply at least a part of these changes
locally.
Primarily, this patch changes the compatible in DTS and thus
the board name used in various scripts to have them in line
with the device, model and image names. Due to the recent
switch from swconfig to DSA, this allows us to drop
SUPPORTED_DEVICES and thus prevent seamless upgrade between
these incompatible setups.
However, this does not include the LED label rename from
Paul's initial patch: I don't think it's worth keeping the
enormous diff locally for this case, as we can implement
this much easier in 01_leds if we have to live with the
inconsistency anyway.
Signed-off-by: Paul Spooren <mail@aparcar.org>
[rebase, extend to all devices, drop DT LED changes]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-04-10 10:14:21 +00:00
|
|
|
define Device/linksys_wrt1900ac-v1
|
2020-01-31 15:46:13 +00:00
|
|
|
$(call Device/linksys)
|
2021-02-06 03:38:03 +00:00
|
|
|
$(Device/kernel-size-migration)
|
2020-01-31 15:46:13 +00:00
|
|
|
DEVICE_MODEL := WRT1900AC
|
|
|
|
DEVICE_VARIANT := v1
|
|
|
|
DEVICE_ALT0_VENDOR := Linksys
|
|
|
|
DEVICE_ALT0_MODEL := Mamba
|
|
|
|
DEVICE_DTS := armada-xp-linksys-mamba
|
|
|
|
DEVICE_PACKAGES += mwlwifi-firmware-88w8864
|
2021-02-06 03:38:03 +00:00
|
|
|
KERNEL_SIZE := 4096k
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-xp-linksys-mamba linksys,mamba
|
2020-01-31 15:46:13 +00:00
|
|
|
endef
|
2020-07-27 09:05:25 +00:00
|
|
|
TARGET_DEVICES += linksys_wrt1900ac-v1
|
2020-01-31 15:46:13 +00:00
|
|
|
|
mvebu: rename Linksys devices based on their common names
The Linksys devices in mvebu target feature a mixed naming,
where parts are based on the official product name (device
node, image; e.g. WRT3200ACM) and parts are based on the
internal code name (DTS file name, compatible, LED labels;
e.g. rango). This inconsistent naming has been perceived
as quite confusing.
A recent attempt by Paul Spooren to harmonize this naming
in kernel has been declined there. However, for us it still
makes sense to apply at least a part of these changes
locally.
Primarily, this patch changes the compatible in DTS and thus
the board name used in various scripts to have them in line
with the device, model and image names. Due to the recent
switch from swconfig to DSA, this allows us to drop
SUPPORTED_DEVICES and thus prevent seamless upgrade between
these incompatible setups.
However, this does not include the LED label rename from
Paul's initial patch: I don't think it's worth keeping the
enormous diff locally for this case, as we can implement
this much easier in 01_leds if we have to live with the
inconsistency anyway.
Signed-off-by: Paul Spooren <mail@aparcar.org>
[rebase, extend to all devices, drop DT LED changes]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-04-10 10:14:21 +00:00
|
|
|
define Device/linksys_wrt1900ac-v2
|
2019-09-09 22:13:30 +00:00
|
|
|
$(call Device/linksys)
|
2020-07-14 14:11:22 +00:00
|
|
|
$(Device/dsa-migration)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_MODEL := WRT1900AC
|
|
|
|
DEVICE_VARIANT := v2
|
|
|
|
DEVICE_ALT0_VENDOR := Linksys
|
|
|
|
DEVICE_ALT0_MODEL := Cobra
|
2018-03-07 21:10:01 +00:00
|
|
|
DEVICE_DTS := armada-385-linksys-cobra
|
|
|
|
DEVICE_PACKAGES += mwlwifi-firmware-88w8864
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-385-linksys-cobra linksys,cobra
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
mvebu: rename Linksys devices based on their common names
The Linksys devices in mvebu target feature a mixed naming,
where parts are based on the official product name (device
node, image; e.g. WRT3200ACM) and parts are based on the
internal code name (DTS file name, compatible, LED labels;
e.g. rango). This inconsistent naming has been perceived
as quite confusing.
A recent attempt by Paul Spooren to harmonize this naming
in kernel has been declined there. However, for us it still
makes sense to apply at least a part of these changes
locally.
Primarily, this patch changes the compatible in DTS and thus
the board name used in various scripts to have them in line
with the device, model and image names. Due to the recent
switch from swconfig to DSA, this allows us to drop
SUPPORTED_DEVICES and thus prevent seamless upgrade between
these incompatible setups.
However, this does not include the LED label rename from
Paul's initial patch: I don't think it's worth keeping the
enormous diff locally for this case, as we can implement
this much easier in 01_leds if we have to live with the
inconsistency anyway.
Signed-off-by: Paul Spooren <mail@aparcar.org>
[rebase, extend to all devices, drop DT LED changes]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-04-10 10:14:21 +00:00
|
|
|
TARGET_DEVICES += linksys_wrt1900ac-v2
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/linksys_wrt3200acm
|
2019-09-09 22:13:30 +00:00
|
|
|
$(call Device/linksys)
|
2020-07-14 14:11:22 +00:00
|
|
|
$(Device/dsa-migration)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_MODEL := WRT3200ACM
|
|
|
|
DEVICE_ALT0_VENDOR := Linksys
|
|
|
|
DEVICE_ALT0_MODEL := Rango
|
2018-03-07 21:10:01 +00:00
|
|
|
DEVICE_DTS := armada-385-linksys-rango
|
|
|
|
DEVICE_PACKAGES += kmod-btmrvl kmod-mwifiex-sdio mwlwifi-firmware-88w8964
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-385-linksys-rango linksys,rango
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += linksys_wrt3200acm
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/linksys_wrt32x
|
2019-09-09 22:13:30 +00:00
|
|
|
$(call Device/linksys)
|
2021-02-06 03:42:47 +00:00
|
|
|
$(Device/kernel-size-migration)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_MODEL := WRT32X
|
|
|
|
DEVICE_ALT0_VENDOR := Linksys
|
|
|
|
DEVICE_ALT0_MODEL := Venom
|
2018-05-13 13:29:30 +00:00
|
|
|
DEVICE_DTS := armada-385-linksys-venom
|
|
|
|
DEVICE_PACKAGES += kmod-btmrvl kmod-mwifiex-sdio mwlwifi-firmware-88w8964
|
2021-02-06 03:42:47 +00:00
|
|
|
KERNEL_SIZE := 6144k
|
2018-05-13 13:29:30 +00:00
|
|
|
KERNEL := kernel-bin | append-dtb
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-385-linksys-venom linksys,venom
|
2018-05-13 13:29:30 +00:00
|
|
|
endef
|
2020-07-27 09:05:25 +00:00
|
|
|
TARGET_DEVICES += linksys_wrt32x
|
2018-05-13 13:29:30 +00:00
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/marvell_a370-db
|
2019-05-11 17:37:31 +00:00
|
|
|
$(Device/NAND-512K)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_VENDOR := Marvell
|
|
|
|
DEVICE_MODEL := Armada 370 Development Board (DB-88F6710-BP-DDR3)
|
2019-05-11 17:37:33 +00:00
|
|
|
DEVICE_DTS := armada-370-db
|
2019-05-11 17:37:34 +00:00
|
|
|
SUPPORTED_DEVICES += armada-370-db
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += marvell_a370-db
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/marvell_a370-rd
|
2019-05-11 17:37:31 +00:00
|
|
|
$(Device/NAND-512K)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_VENDOR := Marvell
|
|
|
|
DEVICE_MODEL := Armada 370 RD (RD-88F6710-A1)
|
2019-05-11 17:37:33 +00:00
|
|
|
DEVICE_DTS := armada-370-rd
|
2019-05-11 17:37:34 +00:00
|
|
|
SUPPORTED_DEVICES += armada-370-rd
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += marvell_a370-rd
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2020-01-31 15:46:13 +00:00
|
|
|
define Device/marvell_a385-db-ap
|
|
|
|
$(Device/NAND-256K)
|
|
|
|
DEVICE_VENDOR := Marvell
|
|
|
|
DEVICE_MODEL := Armada 385 Development Board AP (DB-88F6820-AP)
|
|
|
|
DEVICE_DTS := armada-385-db-ap
|
|
|
|
IMAGES += factory.img
|
2020-06-24 17:56:23 +00:00
|
|
|
IMAGE/factory.img := append-kernel | pad-to $$$$(KERNEL_SIZE) | \
|
|
|
|
append-ubi | pad-to $$$$(PAGESIZE)
|
2020-01-31 15:46:13 +00:00
|
|
|
KERNEL_SIZE := 8192k
|
|
|
|
SUPPORTED_DEVICES += armada-385-db-ap
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += marvell_a385-db-ap
|
|
|
|
|
|
|
|
define Device/marvell_a388-rd
|
|
|
|
DEVICE_VENDOR := Marvell
|
|
|
|
DEVICE_MODEL := Armada 388 RD (RD-88F6820-AP)
|
|
|
|
DEVICE_DTS := armada-388-rd
|
|
|
|
IMAGES := firmware.bin
|
|
|
|
IMAGE/firmware.bin := append-kernel | pad-to 256k | append-rootfs | pad-rootfs
|
|
|
|
SUPPORTED_DEVICES := armada-388-rd marvell,a385-rd
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += marvell_a388-rd
|
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/marvell_axp-db
|
2019-05-11 17:37:31 +00:00
|
|
|
$(Device/NAND-512K)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_VENDOR := Marvell
|
|
|
|
DEVICE_MODEL := Armada XP Development Board (DB-78460-BP)
|
2019-05-11 17:37:33 +00:00
|
|
|
DEVICE_DTS := armada-xp-db
|
2019-05-11 17:37:34 +00:00
|
|
|
SUPPORTED_DEVICES += armada-xp-db
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += marvell_axp-db
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/marvell_axp-gp
|
2019-05-11 17:37:31 +00:00
|
|
|
$(Device/NAND-512K)
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_VENDOR := Marvell
|
|
|
|
DEVICE_MODEL := Armada Armada XP GP (DB-MV784MP-GP)
|
2019-05-11 17:37:33 +00:00
|
|
|
DEVICE_DTS := armada-xp-gp
|
2019-05-11 17:37:34 +00:00
|
|
|
SUPPORTED_DEVICES += armada-xp-gp
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += marvell_axp-gp
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2020-01-31 15:46:13 +00:00
|
|
|
define Device/plathome_openblocks-ax3-4
|
|
|
|
DEVICE_VENDOR := Plat'Home
|
|
|
|
DEVICE_MODEL := OpenBlocks AX3
|
|
|
|
DEVICE_VARIANT := 4 ports
|
|
|
|
SOC := armada-xp
|
|
|
|
SUPPORTED_DEVICES += openblocks-ax3-4
|
|
|
|
BLOCKSIZE := 128k
|
|
|
|
PAGESIZE := 1
|
|
|
|
IMAGES += factory.img
|
|
|
|
IMAGE/factory.img := append-kernel | pad-to $$(BLOCKSIZE) | append-ubi
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2020-01-31 15:46:13 +00:00
|
|
|
TARGET_DEVICES += plathome_openblocks-ax3-4
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2019-05-11 17:37:33 +00:00
|
|
|
define Device/solidrun_clearfog-base-a1
|
2019-09-09 22:13:30 +00:00
|
|
|
DEVICE_VENDOR := SolidRun
|
|
|
|
DEVICE_MODEL := ClearFog Base
|
2018-03-07 21:10:01 +00:00
|
|
|
KERNEL_INSTALL := 1
|
|
|
|
KERNEL := kernel-bin
|
2019-03-28 17:07:09 +00:00
|
|
|
DEVICE_PACKAGES := mkf2fs e2fsprogs partx-utils
|
2018-03-07 21:10:01 +00:00
|
|
|
IMAGES := sdcard.img.gz
|
2019-03-28 17:07:06 +00:00
|
|
|
IMAGE/sdcard.img.gz := boot-scr | boot-img-ext4 | sdcard-img-ext4 | gzip | append-metadata
|
2019-05-11 17:37:30 +00:00
|
|
|
DEVICE_DTS := armada-388-clearfog-base armada-388-clearfog-pro
|
2023-01-19 08:10:41 +00:00
|
|
|
UBOOT := clearfog-u-boot-with-spl.kwb
|
2019-05-11 17:37:30 +00:00
|
|
|
BOOT_SCRIPT := clearfog
|
2020-07-31 09:21:34 +00:00
|
|
|
SUPPORTED_DEVICES += armada-388-clearfog-base
|
|
|
|
DEVICE_COMPAT_VERSION := 1.1
|
|
|
|
DEVICE_COMPAT_MESSAGE := Ethernet interface rename has been dropped
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2019-05-11 17:37:33 +00:00
|
|
|
TARGET_DEVICES += solidrun_clearfog-base-a1
|
2018-03-07 21:10:01 +00:00
|
|
|
|
2020-01-31 15:46:13 +00:00
|
|
|
define Device/solidrun_clearfog-pro-a1
|
2020-07-14 14:11:22 +00:00
|
|
|
$(Device/dsa-migration)
|
2020-01-31 15:46:13 +00:00
|
|
|
DEVICE_VENDOR := SolidRun
|
|
|
|
DEVICE_MODEL := ClearFog Pro
|
2018-03-07 21:10:01 +00:00
|
|
|
KERNEL_INSTALL := 1
|
|
|
|
KERNEL := kernel-bin
|
2020-04-19 08:16:32 +00:00
|
|
|
DEVICE_PACKAGES := mkf2fs e2fsprogs partx-utils
|
2020-01-31 15:46:13 +00:00
|
|
|
IMAGES := sdcard.img.gz
|
|
|
|
IMAGE/sdcard.img.gz := boot-scr | boot-img-ext4 | sdcard-img-ext4 | gzip | append-metadata
|
|
|
|
DEVICE_DTS := armada-388-clearfog-pro armada-388-clearfog-base
|
2023-01-19 08:10:41 +00:00
|
|
|
UBOOT := clearfog-u-boot-with-spl.kwb
|
2020-01-31 15:46:13 +00:00
|
|
|
BOOT_SCRIPT := clearfog
|
2020-07-14 14:11:22 +00:00
|
|
|
SUPPORTED_DEVICES += armada-388-clearfog armada-388-clearfog-pro
|
2018-03-07 21:10:01 +00:00
|
|
|
endef
|
2020-01-31 15:46:13 +00:00
|
|
|
TARGET_DEVICES += solidrun_clearfog-pro-a1
|
mvebu: add support for Synology DS213j
The Synology DS213j is a rather dated dual-bay SATA NAS based on on the
Marvell Armada-370 SoC. It has long been supported in vanilla Linux,
however, flash partitioning there didn't match with reality (ie. the
bootloaders expectations) and nobody cared to wrap up OpenWrt support
for the device.
CPU: Marvell Armada-370 ARMv7 SoC @ 1200 MHz
RAM: 512 MB DDR3
Flash: 8 MB (Micron Technology N25Q064)
Network: 1x 1000M/100M/10M Ethernet (Marvell 88E1510)
SATA: 2x 3.0Gbps
USB: 2x USB 2.0
As OS options are becoming limited on that still quite useful hardware,
patch the flash partitions to be able to get the most out of it when
using OpenWrt.
The vendor firmware loads kernel and initrd from fixed addresses in
the flash, not making use of a modifyable environment stored in flash
which is stored at a location right in the middle of the vendor's
zImage partition (at 0x100000).
Stock firmware flash layout:
0x000000 ~ 0x0c0000 : "RedBoot" (actually U-Boot)
0x0c0000 ~ 0x390000 : "zImage"
0x390000 ~ 0x7d0000 : "rd.gz"
0x7d0000 ~ 0x7e0000 : "vendor" (contains MAC address, serial no)
0x7e0000 ~ 0x7f0000 : "RedBoot Config" (unused? legacy left-over)
0x7f0000 ~ 0x800000 : "FIS directory" (unused? legacy left-over)
OpenWrt flash layout:
0x000000 ~ 0x0c0000 : "u-boot"
0x0c0000 ~ 0x100000 : "gap"
0x100000 ~ 0x110000 : "u-boot-env"
0x110000 ~ 0x7d0000 : "kernel"
0x7d0000 ~ 0x7e0000 : "vendor" (contains MAC address, serial no)
0x7e0000 ~ 0x800000 : "gap2"
"kernel", "gap" and "gap2" are concatenated using the mtd-concat
virtual MTD driver, resulting in a partition "firmware" used by
OpenWrt for kernel, rootfs and rootfs-overlay, 0x720000 (7296kiB) in
total.
Installation:
1. Connect to internal serial console port and Ethernet port,
providing a TFTP server at a static IPv4 address, e.g.
192.168.1.254/24.
2. Interrupt bootloader using CTRL+C
3. Configure bootloader to load OpenWrt on future boot:
setenv bootcmd "bootm f4110000"
saveenv
4. Load and boot initramfs image via TFTP:
setenv ipaddr 192.168.1.1
setenv serverip 192.168.1.254
tftpboot openwrt-mvebu-cortexa9-synology_ds213j-initramfs-kernel.bin
bootm
5. Use sysupgrade to load final image.
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
2023-11-19 22:01:47 +00:00
|
|
|
|
|
|
|
define Device/synology_ds213j
|
|
|
|
DEVICE_VENDOR := Synology
|
|
|
|
DEVICE_MODEL := DS213j
|
|
|
|
KERNEL_SIZE := 6912k
|
|
|
|
IMAGE_SIZE := 7168k
|
|
|
|
FILESYSTEMS := squashfs ubifs
|
|
|
|
KERNEL := kernel-bin | append-dtb | uImage none
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | uImage none
|
|
|
|
DEVICE_DTS := armada-370-synology-ds213j
|
|
|
|
IMAGES := sysupgrade.bin
|
|
|
|
IMAGE/sysupgrade.bin := append-kernel | append-rootfs | pad-rootfs | \
|
|
|
|
check-size | append-metadata
|
|
|
|
DEVICE_PACKAGES := \
|
|
|
|
kmod-rtc-s35390a kmod-hwmon-gpiofan kmod-hwmon-drivetemp \
|
|
|
|
kmod-md-raid0 kmod-md-raid1 kmod-md-mod e2fsprogs mdadm \
|
|
|
|
-ppp -kmod-nft-offload -firewall4 -dnsmasq -odhcpd-ipv6only
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += synology_ds213j
|