Skip to main content Link Search Menu Expand Document Warning Info Success Info (external link) Copy Copied Following system colour scheme Selected dark colour scheme Selected light colour scheme Telegram GitHub Edit

Hardware Specifications

Ā  EX5601-T0
Vendor Zyxel
Model EX5601-T0
SoC MT7986a (filogic 830)
Ram 1G
SFP 1 2.5 GbE 1
Ethernet 3 1GbE, 1 2.5GbE LAN, 1 2.5GbE WAN1
XGMII No
HSGMII āœ…
SGMII āœ…
Type Router

Zyxel EX5601-T0

List of partitions

dev size erasesize name
mtd0 20000000 00040000 ā€œspi0.1ā€
mtd1 00100000 00040000 ā€œBL2ā€
mtd2 00080000 00040000 ā€œu-boot-envā€
mtd3 00200000 00040000 ā€œFactoryā€
mtd4 001c0000 00040000 ā€œFIPā€
mtd5 00040000 00040000 ā€œzloaderā€
mtd6 04000000 00040000 ā€œubiā€
mtd7 04000000 00040000 ā€œubi2ā€
mtd8 15a80000 00040000 ā€œzyubiā€

This router supports dual boot, and has two partitions for the firmware, ubi and ubi2.

To check the current active partition you can use the following command:

cat /proc/cmdline

The result will be something like the following:

console=ttyS0,115200n1 loglevel=8 earlycon=uart8250,mmio32,0x11002000 rootubi=ubi

If rootubi=ubi, the active partition is mtd6.

If rootubi=ubi2, the active partition is mtd7.

Serial interface

This router has the serial interface pins directly accessible on the board:

EX5601T0 Serial interface
EX5601T0 Serial interface

The serial console speed is 115200 bauds.

ZHAL (Zloader) access

The boot process of this router has multiple stages, long story short we have both u-boot and zloader (ZHAL).

When the router is powered-up u-boot is loaded and it will load zloader, the Zyxel proprietary boot manager.

Zloader allows to manually swap boot partitions (ubi and ubi2), recover the supervisor password and many additional useful (and dangerous) things.

By default zloader access is blocked.

Unlocking zloader

  1. Open the router case and connect your usb-ttl adapter to the router as show in the picture.
  2. Open putty or any other serial capable software and configure it to use your COMX port with 115200 speed.
  3. Power up the router.
  4. While the router is booting at some point you will read the following: Please press Enter to activate this console.
  5. As soon as you read that press enter, type root and than press enter again (just do it, donā€™t care about the logs scrolling).
  6. Most likely the router is still printing the boot log, leave it boot until it stops.
  7. If everything went ok you should have full root access:
    root@EX5601-T0:/#
    
  8. type the following command and press enter:
    fw_setenv EngDebugFlag 0x1
    
  9. Reboot the router.
  10. As soon as you read Hit any key to stop autoboot: press Enter.
  11. If everything went ok you should have the following prompt:
    ZHAL>
    

    You have successfully unlocked zloader access, this procedure must be done only once.

Dumping supervisor password

  1. Open the router case and connect your usb to serial adapter.
  2. Open putty or any other serial capable software and configure it to use your COMX port with 115200 speed.
  3. Power up the router.
  4. As soon as you read Hit any key to stop autoboot: press Enter.
  5. Type the following command and press enter to read the supervisor password:
    atck
    
  6. The supervisor password will be printed in clear text and can be used on the zyxel webgui.
  7. You can reboot the router by typing the following command and press Enter:
    atsr
    

Manually swapping the boot partition

  1. Open the router case and connect your usb to serial adapter.
  2. Open putty or any other serial capable software and configure it to use your COMX port with 115200 speed.
  3. Power up the router.
  4. As soon as you read Hit any key to stop autoboot: press Enter.
  5. Type the following command sequence to swap the boot partition.
    atbt 1  # unlock zhal write 
    atsw    # swap boot partition
    atsr    # reboot the router
    
  6. The router will boot from the new active partition (ubi or ubi2 depending on the previous active partition).
  7. Check if the active partition has changed with the following command:
    cat /proc/cmdline
    

Unlocking u-boot access

Up to today a strange combination of actions must be completed in a special sequence to access the u-boot CLI:

  1. Open the router case and connect your usb to serial adapter.
  2. Open putty or any other serial capable software and configure it to use your COMX port with 115200 speed.
  3. Power up the router.
  4. As soon as you read Hit any key to stop autoboot: press Enter to access the ZHAL command line.
  5. Type the following command and press enter:
    atgu
    
  6. Apparently that command doesnā€™t do anything and the router will reboot itself.
  7. Again for the second time you will read Hit any key to stop autoboot:, press Enter again to access ZHAL again.
  8. Type the following command again and press enter:
    atgu
    
  9. You should now have entered the u-boot command line interface:
    MT7986>
    

Flashing a firmware or downgrading firmware

  1. Access the router via ssh or telnet with admin user (admin password is printed on the back of the router).
  2. Disable firmware version check and model check by running the following commands.
    zycli fwidcheck off
    zycli modelcheck off
    
  3. You can close the ssh console, do not reboot the router.
  4. Open the router web interface and in the maintenance/firmware upgrade section select the ā€œRestore Default Settings After Firmware Upgradeā€ option.
  5. Select ā€œChoose fileā€ to select the firmware file you want to upload and click Upload.
  6. The router will automatically reboot and should get back up on 192.168.1.1

Firmware Version V5.70(ACDZ.0)C0 no-brand

Here is a no-brand firmware compiled starting from Zyxel provided OpenSource package under GPL license (link at the bottom of this page) plus the following modifications that you can track on the following repo: https://github.com/pameruoso/zyxel-ex5601t0

  1. Added start-up script to reset and enable root access via ssh. The script reads the device serial number and resets the root password with that. Do not try to reset the root password because that will last until next reboot.
  2. the /bin path contains sfp_wan.sh_wind and check_sfp_link.sh_wind scripts which are very similar to the standard sfp_wan.sh and check_sfp_link.sh scripts. If everything works with the original ones do not swap them. If you want to allow 2.5gbit HSGMII with the Technicolor AFM0003 SFP stick you need to swap and enable the _wind scripts.
  3. Additional packages installed: mtr, htop, openvpn, wireguard.

OpenWrt firmware

This router has native OpenWrt support starting from the following git commit

You are free to clone the git code and build your own OpenWrt firmware or use the OpenWrt firmware builder.

The OpenWrt firmware has the following working features out of the box:

  • 3 Gbit LAN ports
  • Wi-Fi AX6000: 5Ghz 4x4 ax + 2.4GHz 4x4 ax
  • Zyxel partitioning for coexistance with Zloader and dual boot
  • Leds
  • Reset button
  • Serial interface
  • USB port
  • LAN RJ45 2.5 Gbit port
  • WAN RJ45 2.5 Gbit port
  • WAN SFP port only works after exporting pins 57 and 10 (gpiobase411). There must also be a cable with a link active on the WAN 2.5 Gbe port to make the SFP work. This is due to missing support into the phy-link code of the Mediatek ethernet SoC.

To workaround the missing phy-link support, some modifications to the DTS are needed. Setting the gmac1 node to fixed link 2500Base-X gives the possibility to hot-swap the SFP/RJ45 port.

The following repo contains a proper example: EX5601-T0 fixed SFP link git repo you can apply the patch to the official OpenWrt repo.

Here is a flashable bin file based on OpenWrt v23.05.0 Stable with the mod to swap SFP/RJ45. This sysupgrade.bin already contains the zyfwinfo file for flashing with zloader.

EX5601-T0_Openwrt-v23.05.0-stable_fixedlink

Miscellaneous Links


  1. the Ethernet and SFP WAN ports are in XOR, i.e. either one or the other is usable, not both at the same time.Ā Ā 2