![Ethernet PHY](/img/wol/schematic.png) The Armada 388 SoC provides several trigger options from different peripherals to wake up the system out of power save modes. Some of the options are: * Wake on GPIO * Wake on LAN Currently Helios4 uses the PHY interrupt and 'Wake on GPIO' event to implement Wake-on-LAN. ## Add WoL Support !!! note Starting Armbian version **5.77** the Wake-on-LAN support has been added by default. So you might want to upgrade your system via APT to skip this section. ### Device Tree Linux provides gpio-keys driver to handle GPIO event and can be configured as wakeup source. ``` gpio-keys { compatible = "gpio-keys"; pinctrl-0 = <µsom_phy0_int_pins>; wol { label = "Wake-On-LAN"; linux,code = ; gpios = <&gpio0 18 GPIO_ACTIVE_LOW>; wakeup-source; }; }; ``` Device Tree Patch can be found [here](/files/wol/helios4-dts-add-wake-on-lan-support.patch). ### Kernel Current gpio-mvebu driver does not implement [irq_set_wake()](https://www.kernel.org/doc/html/v4.14/core-api/genericirq.html?highlight=irq_set_wake#c.irq_chip) to support GPIO as wakeup source and properly route it to upper interrupt controller (Arm GIC). This will raise following issues: - System unable to wake up from Suspend-to-RAM - System wake up from GPIO interrupts not defined as wakeup source - Kernel crash during wakeup from standby ``` [ 59.169436] ------------[ cut here ]------------ [ 59.174075] WARNING: CPU: 0 PID: 1535 at kernel/irq/manage.c:623 irq_set_irq_wake+0xe4/0x11c [ 59.182533] Unbalanced IRQ 50 wake disable [ 59.186638] Modules linked in: lz4hc lz4hc_compress marvell_cesa zram zsmalloc lm75 pwm_fan ip_tables x_tables [ 59.196690] CPU: 0 PID: 1535 Comm: bash Not tainted 4.14.94-mvebu+ #14 [ 59.203234] Hardware name: Marvell Armada 380/385 (Device Tree) [ 59.209183] [] (unwind_backtrace) from [] (show_stack+0x10/0x14) [ 59.216955] [] (show_stack) from [] (dump_stack+0x88/0x9c) [ 59.224204] [] (dump_stack) from [] (__warn+0xe8/0x100) [ 59.231188] [] (__warn) from [] (warn_slowpath_fmt+0x48/0x6c) [ 59.238696] [] (warn_slowpath_fmt) from [] (irq_set_irq_wake+0xe4/0x11c) [ 59.247160] [] (irq_set_irq_wake) from [] (gpio_keys_resume+0xb0/0x11c) [ 59.255537] [] (gpio_keys_resume) from [] (dpm_run_callback+0x54/0xec) [ 59.263826] [] (dpm_run_callback) from [] (device_resume+0xcc/0x270) [ 59.271941] [] (device_resume) from [] (dpm_resume+0x100/0x230) [ 59.279621] [] (dpm_resume) from [] (dpm_resume_end+0xc/0x18) [ 59.287128] [] (dpm_resume_end) from [] (suspend_devices_and_enter+0x210/0x5e0) [ 59.296202] [] (suspend_devices_and_enter) from [] (pm_suspend+0x2f8/0x380) [ 59.304927] [] (pm_suspend) from [] (state_store+0x70/0xcc) [ 59.312260] [] (state_store) from [] (kernfs_fop_write+0xe8/0x1c4) [ 59.320204] [] (kernfs_fop_write) from [] (vfs_write+0xa4/0x1b4) [ 59.327972] [] (vfs_write) from [] (SyS_write+0x4c/0xac) [ 59.335045] [] (SyS_write) from [] (ret_fast_syscall+0x0/0x54) [ 59.342633] ---[ end trace c725de247edb5ce9 ]--- [ 59.474369] ata2: SATA link down (SStatus 0 SControl 300) [ 59.474443] ata3: SATA link down (SStatus 0 SControl 300) [ 59.638619] ata1: SATA link down (SStatus 0 SControl 300) [ 59.647170] ata4: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 60.081905] ata1: SATA link down (SStatus 0 SControl 300) [ 60.087343] ata1: limiting SATA link speed to 1.5 Gbps [ 60.386518] mvneta f1070000.ethernet eth0: Link is Down [ 60.578411] ata1: SATA link up 1.5 Gbps (SStatus 113 SControl 310) [ 61.162892] ata4.00: configured for UDMA/100 [ 62.431232] mvneta f1070000.ethernet eth0: Link is Up - 1Gbps/Full - flow control rx/tx [ 63.087435] ata1.00: configured for UDMA/100 [ 63.159889] OOM killer enabled. [ 63.164643] Restarting tasks ... done. [ 63.181059] PM: suspend exit ``` To fix the issue, gpio-mvebu driver needs to be patched to implement [irq_set_wake()](https://www.kernel.org/doc/html/v4.14/core-api/genericirq.html?highlight=irq_set_wake#c.irq_chip) and only enable interrupt on GPIO defined as wakeup source. Patch for Linux Kernel 4.14.x can be found [here](/files/wol/lk4.14-mvebu-gpio-add_wake_on_gpio_support.patch) ## Enabling WOL !!! note Latest Armbian images, starting version **5.77**, already have the WoL enabled by default for eth0. So you may skip this step. Enable the PHY to raise an interrupt when magic packet received : ``` sudo ethtool -s eth0 wol g ``` To make it permanent, create the following file */lib/systemd/system/wol@.service* and copy the following: ``` [Unit] Description=Wake-on-LAN for %i Requires=network.target After=network.target [Service] ExecStart=/sbin/ethtool -s %i wol g Type=oneshot [Install] WantedBy=multi-user.target ``` Then enable the service for **eth0** ``` systemctl enable wol@eth0 ``` ## Suspend System Use **systemctl** command to put your system in suspend mode. ``` sudo systemctl suspend ``` !!! important Only execute this command after enabling WOL otherwise there is a risk that Helios4 will not wake up when receiving magic packet. More explanation regarding this issue on [here](/wol/#unexpected-packet). ## Wake up System To wake up your suspended Helios4 you need to send it a magic packet from a machine on the same network. Before putting Helios4 in suspend mode, you need to know its MAC address. Use **ip link** command. In the example below the MAC address is *02:fc:e7:3d:b8:c8*. ``` ip link 1: lo: mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 2: eth0: mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 532 link/ether 02:fc:e7:3d:b8:c8 brd ff:ff:ff:ff:ff:ff 3: tunl0@NONE: mtu 1480 qdisc noop state DOWN mode DEFAULT group default qlen 1000 link/ipip 0.0.0.0 brd 0.0.0.0 ``` From a Linux machine (running Debian/Ubuntu) on the same network : 1. Install **etherwake** tool ``` sudo apt-get install etherwake ``` 2. Send magic packet ``` sudo etherwake 02:fc:e7:3d:b8:c8 ``` If your system doesn't have an interface named *eth0*, you will need to specify the network interface you want to use to send out the magic packet. Example : ``` sudo etherwake -i enx00051bd1ca66 02:fc:e7:3d:b8:c8 ``` You can refer to this [guide](https://www.cyberciti.biz/tips/linux-send-wake-on-lan-wol-magic-packets.html) from *cyberciti.biz*. ## Power Consumption Measured using Sonoff POW R2 on AC side | Power state | Power (Watt) | Current (Ampere) | Remarks | |---------------|---------------|------------------|---------| | Idle | 19.87 | 0.17 | | | Standby | 8.63 | 0.10 | HDD in Standby mode | | Suspend | 7.71 | 0.08 | HDD in Standby mode | !!! note * Nominal Input Voltage: 220V * HDD: 4x WD Red 2TB (WD20EFRX) * [I2C OLED screen](/i2c/) attached to the systems ## Issues ### Unexpected Packet The PHY INT pin is supposed to be handled by the Ethernet controller so when there is an interrupt the driver can respond and acknowledge the interrupt. Without this acknowledgment, the PHY INT pin will stay active and the PHY won't trigger another interrupt. On specific case that after user enabled the WOL and magic packet received before entering suspend mode, Helios4 will not able to wake up. The reason is PHY interrupt already triggered before entering suspend mode and no other interrupt triggered during suspend mode. The Ethernet controller driver will reset PHY interrupt during resume and when enabling WOL. Therefore it is advised to always enable WOL (**sudo ethtool -s eth0 wol g**) before entering suspend. ### Thermal When system is put in suspend mode, the PWM feature controlling the fan speed is stopped. The fans will either spin at their lowest speed ([Batch 1 fan](/pwm/#old-fan-batch-1)) or stop spinning ([Batch 2 fan](/pwm/#new-fan-batch-2)). In the latest case, while this is not an issue for the SoC itself which is designed to run with passive cooling, it might have a negative impact on the HDD peripherals because the ambient temperature inside the case will rise. **Therefore it is advised to ensure that when system is suspended the case ambient temperature will not exceed the operating temperature your HDDs are rated for.**