openwrt/target/linux/ipq40xx/files/arch/arm/boot/dts
Glen Lee 74e7f8ebbd ipq40xx: add support for Extreme Networks WS-AP391x series APs
This in a single image to run many types of hardware in the AP391x
series (AP3912/AP3915/AP3916/AP3917/AP7662).

Hardware
--------
Qualcomm IPQ4029 WiSoC
2T2R 802.11 abgn
2T2R 802.11 nac
Macronix MX25L25635E SPI-NOR (32M)
512M DDR3 RAM
1-4x Gigabit Ethernet
Senao EXT1025 HD Camera (AP3916 only)
USB 2.0 Port (AP3915e only)

1x Cisco RJ-45 Console port
  - except for AP3916 and AP3912 where there is no external serial
    console and it is TDB how to solder one. Possibly J12 is UART with
    pin1 = 3.3V, pin2 = GND, pin3 = TXD, pin4 = RXD.
  - Settings: 115200 8N1

Installation With Serial Console
--------------------------------

1. Attach to the Console port. Power up the device and press the s key
   to interrupt autoboot.

2. The default username / password to the bootloader is admin / new2day

3. Check uboot variables using printenv, and update if necessary:

   $ setenv AP_MODE 0
   $ setenv WATCHDOG_COUNT 0
   $ setenv WATCHDOG_LIMIT 0
   $ setenv AP_PERSONALITY identifi
   $ setenv serverip <SERVER_IPADDR>
   $ setenv ipaddr <UNIQUE_IPADDR>
   $ setenv MOSTRECENTKERNEL 0; ## OpenWRT only uses the primary image
   $ saveenv
   $ saveenv ## 2nd time to write the secondary copy

4. On the TFTP server located at <SERVER_IPADDR>, download the OpenWrt
   initramfs image. Rename and serve it as vmlinux.gz.uImage.3912

5. TFTP boot the OpenWrt initramfs image from the AP serial console:

   $ run boot_net

6. Wait for OpenWrt to start. Internet port sw-eth5 is assiged to LAN
   bridge and sw-eth4 (if available) is assigned to WAN.  The LAN port
   will use default IP address 192.168.1.1 and run a DHCP server.

   If you already have a working DHCP server or already have 192.168.1.1
   on your network you MUST DISCONNECT the LAN cable from your active
   network immediately after the power/status LED turns green!

   At this point, you need to temporarily reconfigure the AP to have
   a way to transfer the OpenWRT sysupgrade image to it.

   Reconfigure the newly converted OpenWRT AP using serial console or
   plug in a PC to a sw-eth5 as a separate network. Note -- the LAN/WAN
   port assignments were designed to make it possible to convert to
   OpenWRT without serial console and using a common firmware
   image for many AP models -- they may not make the most sense when
   fully deployed.

7. Download and transfer the sysupgrade image to the device using e.g.
   SCP.

8. Install OpenWrt to the device using "sysupgrade"

   $ sysupgrade -n /path/to/openwrt.bin

9. After it boots up again, as in step 6, connect to AP and reconfigure
   for final deployment.

This build supports APs in the AP391x series and similar such as WiNG
AP7662.

Ethernet devices within OpenWRT are named "sw-eth1" thru "sw-eth5".
Mapping from OpenWRT internal naming to external naming on the case is
as follows:

```
            |sw-eth1|sw-eth2|sw-eth3|sw-eth4|sw-eth5
------------+-------+-------+-------+-------+-------
AP3917      |       |       |       |  GE2  |  GE1
------------+-------+-------+-------+-------+-------
AP7662      |       |       |       |  GE2  |  GE1
------------+-------+-------+-------+-------+-------
AP3916      |       |       |       |  CAM* |  GE1
------------+-------+-------+-------+-------+-------
AP3915      |       |       |       |       |  GE1
------------+-------+-------+-------+-------+-------
AP3912      |       |  P1   |  P2   |  P3   | LAN1
------------+-------+-------+-------+-------+-------
```

By default sw-eth4 is mapped to WAN. All others are assigned to the
LAN.

CAM* - On AP3916, sw-eth4 is the camera's interface.  You should
reconfigure this to be on LAN after OpenWRT boots from flash.

Installation Without Serial Console
-----------------------------------

The main premise is to set u-boot environment variables using the
Extreme Networks firmware's rdwr_boot_cfg program.

$ rdwr_boot_cfg

Utility to manipulate the boot ROM config blocks
All errors are written to the sytem log file (/tmp/log/ap.log)

```
Usage: rdwr_boot_cfg <read_all|read_var|read_var_f|write_var|rm_var> ...
   read_all             read the entire active block
   read_var <var>       read a single variable from the active block
   read_var_f <var>     read a single variable from the active block
(formatted)
   write_var <var=val>  write a single variable/value pair to both
blocks
   rm_var <var>         delete a single variable from both blocks
```

WARNING: Be very sure you have set the u-boot environment correctly.
If not, it can only be fixed by attaching serial console!

Be aware that the Extreme Networks shell environment will automatically
reboot every 5 minutes if there is no controller present.

Read and understand these steps fully before attempting.  It is easy
to make mistakes!

1. Place the OpenWRT initramfs on the TFTP server and name it as
   vmlinux.gz.uImage.3912

2. Boot up to Extreme Networks WING-Campus mode OS.  Port GE1/LAN1
   will be a DHCP **client**.  Find out the IP address from your DHCP
   server and SSH in.  Default user/passwd is admin/new2day or
   admin/admin123.

   If it is booting to WING-Distributed mode, use this command to
   convert to Campus mode.

   $ operational-mode centralized

3. Upon bootup you have about 5mins to changed these u-boot variables
   if necessary using the rdwr_boot_cfg command in Linux shell:

   $ rdwr_boot_cfg write_var AP_MODE=0
   $ rdwr_boot_cfg write_var MOSTRECENTKERNEL=0
   $ rdwr_boot_cfg write_var WATCHDOG_COUNT=0
   $ rdwr_boot_cfg write_var WATCHDOG_LIMIT=0
   $ rdwr_boot_cfg write_var AP_PERSONALITY=identifi
   $ rdwr_boot_cfg write_var serverip=<SERVER_IPADDR>
   $ rdwr_boot_cfg write_var ipaddr=<UNIQUE_IPADDR>
   $ rdwr_boot_cfg write_var bootcmd="run boot_net"

4. Reboot AP.

5. Connect PC with ethernet to GE1/LAN1 port.  You should get a
   DHCP address in the 192.168.1.x range and should be able to
   SSH to the new OpenWRT TFTP recovery/installation shell.

6. At this point, u-boot is still set to TFTP boot, so you have to
   replace the TFTP image with the original Extreme Networks image so
   that you can change the u-boot environment.

   See the instructions for Extracting Extreme Networks firmware
   image.

   DON'T REBOOT YET!

7. Next you must follow steps 6 thru 8 from the Installation with serial
   console.  After which you should have OpenWRT installed to primary
   flash firmware.

8. Now Reboot.  This time it will boot using TFTP into Extreme Networks
   image.  You may need to reconnect cables at this point -- GE1/LAN1
   will be a DHCP **client** and you can SSH in -- just like step 2.
   Get the IP address from you own DHCP server.

9. Set u-boot env as follows:

   $ rdwr_boot_cfg write_var MOSTRECENTKERNEL=0
   $ rdwr_boot_cfg write_var WATCHDOG_COUNT=0
   $ rdwr_boot_cfg write_var bootcmd="run boot_flash"

10. Reboot AP.  This time it should be into OpenWRT.  GE1/LAN1 will be
   a DHCP **server** and have static IP 192.168.1.1 -- just like step 5.

11. SSH into the LAN port and reconfigure to final configuration. Don't
   make any changes that prevent you from SSH or Luci access!

Restoring Extreme Networks firmware
-----------------------------------

Assuming you have the original Extreme Networks image:

1. Login to OpenWRT shell

2. scp the Extreme Networks packaged firmware image file AP391x-*.img to
   /tmp

3. Extract the firmware uimage file:

   $ tar xjf AP391x-*.img vmlinux.gz.uImage

4. Force run sysupgrade:

   $ sysupgrade -F /tmp/AP391x-*.img /

5. Restore the u-boot varable(s):

   $ rdwr_boot_cfg write_var WATCHDOG_LIMIT=3

USB 2.0 Port on AP3915e
-----------------------
Enable this by setting LED "eth:amber_or_usb_enable" to ALWAYS ON.

Reviewed-by: Robert Marko <robimarko@gmail.com>
Signed-off-by: Glen Lee <g2lee@yahoo.com>
2023-09-25 23:21:09 +02:00
..
qcom-ipq40x9-dr40x9.dts ipq40xx: add support for Wallystech DR40x9 2023-03-21 16:38:23 +01:00
qcom-ipq4018-a42.dts ipq40xx: utilize nvmem-cells for openmesh,a42 2022-11-12 18:15:55 +01:00
qcom-ipq4018-ap120c-ac.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-cap-ac.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-cs-w3-wd1200g-eup.dts ipq40xx: convert EZVIZ CS-W3-WD1200G-EUP to DSA 2023-05-20 15:19:14 +02:00
qcom-ipq4018-dap-2610.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00
qcom-ipq4018-ea6350v3.dts ipq40xx: re-enable EA6350v3, EA8300, MR8300 builds 2022-12-31 05:02:38 -08:00
qcom-ipq4018-eap1300.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4018-ecw5211.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-emd1.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4018-emr3500.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4018-ens620ext.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4018-ex61x0v2.dtsi ipq40xx: convert Netgear EX6100/EX6150 v2 to DSA 2023-03-08 02:19:01 +01:00
qcom-ipq4018-ex6100v2.dts ipq40xx: tidy up dts-v1 statements 2020-09-25 21:10:41 +02:00
qcom-ipq4018-ex6150v2.dts ipq40xx: tidy up dts-v1 statements 2020-09-25 21:10:41 +02:00
qcom-ipq4018-fritzbox-4040.dts ipq40xx: re-add label MAC address for FritzBox 4040 2023-08-27 16:09:11 +02:00
qcom-ipq4018-gl-a1300.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00
qcom-ipq4018-gl-ap1300.dts ipq40xx: convert GL-AP1300 to DSA 2023-04-24 18:32:26 +02:00
qcom-ipq4018-hap-ac2.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-jalapeno.dts
qcom-ipq4018-jalapeno.dtsi ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-magic-2-wifi-next.dts ipq40xx: convert devolo Magic 2 WiFi next to DSA 2023-09-03 23:11:40 +02:00
qcom-ipq4018-meshpoint-one.dts ipq40xx: remove model name from LED labels 2020-10-07 01:31:37 +02:00
qcom-ipq4018-mf287_common.dtsi ipq40xx: ZTE MF287 series: move to gpio-export for modem-reset GPIO 2023-09-19 11:43:36 +02:00
qcom-ipq4018-mf287.dts ipq40xx: ZTE MF287 series: move to gpio-export for modem-reset GPIO 2023-09-19 11:43:36 +02:00
qcom-ipq4018-mf287plus.dts ipq40xx: ZTE MF287 series: move to gpio-export for modem-reset GPIO 2023-09-19 11:43:36 +02:00
qcom-ipq4018-mf287pro.dts ipq40xx: ZTE MF287 series: move to gpio-export for modem-reset GPIO 2023-09-19 11:43:36 +02:00
qcom-ipq4018-nbg6617.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-pa1200.dts ipq40xx: Convert plasmacloud,pa1200 to DSA 2022-11-13 15:26:34 +01:00
qcom-ipq4018-rt-ac58u.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-rutx10.dts ipq40xx: move Teltonika RUT STM32 IO to specific DTS 2023-07-26 01:17:08 +02:00
qcom-ipq4018-rutx50.dts ipq40xx: add support for Teltonika RUTX50 2023-07-26 01:17:08 +02:00
qcom-ipq4018-rutx.dtsi ipq40xx: Use SoC DTSI for Teltonika RUTX 2023-08-15 16:41:22 +02:00
qcom-ipq4018-sxtsq-5-ac.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00
qcom-ipq4018-wac510.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4018-wap-ac-lte.dts ipq40xx: add support for Mikrotik wAP R ac / LTE / LTE6 2022-11-27 13:28:22 +00:00
qcom-ipq4018-wap-ac.dts ipq40xx: add support for Mikrotik wAP R ac / LTE / LTE6 2022-11-27 13:28:22 +00:00
qcom-ipq4018-wap-ac.dtsi ipq40xx: add support for Mikrotik wAP R ac / LTE / LTE6 2022-11-27 13:28:22 +00:00
qcom-ipq4018-wap-r-ac.dts ipq40xx: add support for Mikrotik wAP R ac / LTE / LTE6 2022-11-27 13:28:22 +00:00
qcom-ipq4018-whw01.dts ipq40xx: migrate Linksys WHW01 to DSA and re-enable 2022-12-31 05:02:38 -08:00
qcom-ipq4018-wr-1.dts ipq40xx: pakedge_wr-1: convert to DSA 2022-10-05 19:16:52 +02:00
qcom-ipq4018-wre6606.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4018-wrtq-329acn.dts ipq40xx: luma_wrtq-329acn: convert to DSA 2022-10-05 19:10:28 +02:00
qcom-ipq4019-a62.dts ipq40xx: utilize nvmem-cells for openmesh,a62 2022-11-12 18:15:55 +01:00
qcom-ipq4019-cm520-79f.dts ipq40xx: convert to DSA and enable mobipromo,cm520-79f 2022-10-23 01:45:52 +02:00
qcom-ipq4019-e2600ac-c1.dts ipq40xx: add e2600ac c1 to dsa 2023-05-29 12:23:44 +02:00
qcom-ipq4019-e2600ac-c2.dts ipq40xx: add e2600ac c2 to dsa 2023-05-29 12:23:47 +02:00
qcom-ipq4019-e2600ac.dtsi ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4019-ea8300.dts ipq40xx: remove model name from LED labels 2020-10-07 01:31:37 +02:00
qcom-ipq4019-eap2200.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4019-fritzbox-7530.dts ipq40xx: add DSL support for FritzBox 7530 2023-01-16 23:41:41 +00:00
qcom-ipq4019-fritzrepeater-1200.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4019-fritzrepeater-3000.dts ipq4019: fix support for AVM FRITZ!Repeater 3000 2023-07-26 12:26:45 +02:00
qcom-ipq4019-gl-b2200.dts generic: fix silicon labs spidev bindings 2023-01-06 16:01:10 +01:00
qcom-ipq4019-habanero-dvk.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4019-hap-ac3-lte6-kit.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00
qcom-ipq4019-hap-ac3.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4019-le1.dts ipq40xx: add support for YYeTs LE1 2023-09-18 12:20:04 +02:00
qcom-ipq4019-lhgg-60ad.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4019-map-ac2200.dts ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4019-mf18a.dts ipq40xx: mf18a: rename wifi0 calibration variant to ZTE-MF18A 2023-03-18 12:47:48 +01:00
qcom-ipq4019-mf282plus.dts ipq4019: add support for ZTE MF282 Plus aka DreiTube 2023-09-20 14:29:20 +02:00
qcom-ipq4019-mf286d.dts ipq40xx: dts: remove leftover nodes after DSA conversion 2022-11-13 15:31:54 +01:00
qcom-ipq4019-mf289f.dts ipq40xx: Fix wrong GPIO for internal status LED on ZTE MF289F 2022-10-12 00:59:39 +02:00
qcom-ipq4019-mr8300.dts ipq40xx: remove model name from LED labels 2020-10-07 01:31:37 +02:00
qcom-ipq4019-ncp-hg100-cellular.dts ipq40xx: convert to DSA and enable Sony NCP-HG100/Cellular 2022-10-09 22:45:06 +02:00
qcom-ipq4019-oap100.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4019-orbi.dtsi ipq40xx: convert to DSA and enable Netgear Orbi devices 2022-10-25 02:34:46 +02:00
qcom-ipq4019-pa2200.dts ipq40xx: Convert plasmacloud,pa2200 to DSA 2022-11-13 15:26:34 +01:00
qcom-ipq4019-r619ac-64m.dts ipq40xx: add support for P&W R619AC (aka G-DOCK 2.0) 2021-11-14 14:28:34 +01:00
qcom-ipq4019-r619ac-128m.dts ipq40xx: add support for P&W R619AC (aka G-DOCK 2.0) 2021-11-14 14:28:34 +01:00
qcom-ipq4019-r619ac.dtsi ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4019-rbr40.dts ipq40xx: add support for Netgear RBX40 2023-09-16 12:08:03 +02:00
qcom-ipq4019-rbr50.dts ipq40xx: add support for Netgear SRR60/SRS60 and RBR50/RBS50 2021-11-01 00:56:51 +01:00
qcom-ipq4019-rbs40.dts ipq40xx: add support for Netgear RBX40 2023-09-16 12:08:03 +02:00
qcom-ipq4019-rbs50.dts ipq40xx: add support for Netgear SRR60/SRS60 and RBR50/RBS50 2021-11-01 00:56:51 +01:00
qcom-ipq4019-rt-ac42u.dts ipq40xx: convert to DSA and enable asus,rt-ac42u 2022-10-22 20:09:58 +08:00
qcom-ipq4019-rtl30vw.dts ipq40xx: fix assignment of lan port numbers for Cell C RTL30VW 2023-02-06 13:26:58 +01:00
qcom-ipq4019-srr60.dts ipq40xx: add support for Netgear SRR60/SRS60 and RBR50/RBS50 2021-11-01 00:56:51 +01:00
qcom-ipq4019-srs60.dts ipq40xx: add support for Netgear SRR60/SRS60 and RBR50/RBS50 2021-11-01 00:56:51 +01:00
qcom-ipq4019-u4019-32m.dts ipq40xx: utilize nvmem-cells for macs & (pre-)calibration data 2022-01-15 17:26:55 +01:00
qcom-ipq4019-u4019.dtsi ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4019-whw03v2.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00
qcom-ipq4019-wifi.dts ipq40xx: add LED functions for Google WiFi 2023-03-31 19:39:36 +02:00
qcom-ipq4019-wpj419.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4019-wtr-m2133hp.dts ipq40xx: convert Buffalo WTR-M2133HP to DSA 2023-06-01 23:54:20 +02:00
qcom-ipq4019-x1pro.dts ipq40xx: drop ESSEDMA + AR40xx DTS nodes 2022-10-02 23:04:38 +02:00
qcom-ipq4019-x1pro.dtsi ipq40xx: fix dts whitespace 2023-02-09 03:03:47 +01:00
qcom-ipq4019-xx8300.dtsi ipq40xx: Linksys MR8300: fix the USB port power 2023-02-25 20:33:40 +01:00
qcom-ipq4028-wpj428.dts ipq40xx: wpj428: panic on squashfs error to work around boot limbo 2023-09-24 18:55:35 +02:00
qcom-ipq4029-ap-303.dts ipq40xx: utilize nvmem-cells for macs & (pre-)calibration data 2022-01-15 17:26:55 +01:00
qcom-ipq4029-ap-303h.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00
qcom-ipq4029-ap-365.dts ipq40xx: add Aruba AP-365 specific BDF 2022-06-02 16:50:12 +02:00
qcom-ipq4029-aruba-glenmorangie.dtsi ipq40xx: convert some boards to DSA 2022-10-02 23:04:39 +02:00
qcom-ipq4029-gl-b1300.dts ipq40xx: glinet-b1300: fix LAN and WAN MAC address assigments 2022-10-03 08:06:43 +02:00
qcom-ipq4029-gl-s1300.dts generic: fix silicon labs spidev bindings 2023-01-06 16:01:10 +01:00
qcom-ipq4029-insect-common.dtsi ipq40xx: Meraki MR33: convert MAC addresses to nvmem 2022-10-02 23:04:39 +02:00
qcom-ipq4029-mr33.dts ipq40xx: add support for Meraki MR74 2022-06-19 12:31:02 +02:00
qcom-ipq4029-mr74.dts ipq40xx: add support for Meraki MR74 2022-06-19 12:31:02 +02:00
qcom-ipq4029-ws-ap391x.dts ipq40xx: add support for Extreme Networks WS-AP391x series APs 2023-09-25 23:21:09 +02:00
qcom-ipq4029-ws-ap3915i.dts ipq4019: fix dts white-space 2023-02-08 02:29:55 +01:00