GPIO state not retained after FOTA reboot on nRF54L15 (Zephyr SDK 3.0.2)

Hi,

I am using nRF54L15 with Zephyr RTOS in nRF Connect SDK v3.0.2.

After performing a FOTA update, the device reboots. I need to retain the state of a GPIO pin across this reboot.

The GPIO I am trying to retain is P1.06. I attempted to configure it with retention using the following code:

#define PIN_P1_06 38
#define P1_INDEX  6

void configure_retained_gpio(void) {
    // Configure the pin as output with retention enabled
    nrf_gpio_cfg_output(PIN_P1_06);
 
    NRF_P1->PIN_CNF[P1_INDEX] &= ~GPIO_PIN_CNF_CTRLSEL_Msk;
    NRF_P1->PIN_CNF[P1_INDEX] |= (GPIO_PIN_CNF_CTRLSEL_GPIO << GPIO_PIN_CNF_CTRLSEL_Pos);
}

However, after the OTA update and subsequent reboot, the GPIO state is cleared and does not retain the previous value.

My questions:

  1. Is there any additional configuration required in nRF54L15 to retain GPIO states across a reboot after FOTA?

  2. Is GPIO retention supported across MCU reset triggered by FOTA, or is it only supported for specific low-power modes?

Any guidance or recommended approach to preserve the GPIO state across OTA reboot would be greatly appreciated.

Thanks.

Parents
  • Hello,

    GPIO configs are  only retained through a system off reset. For other reset sources they are cleared. So after the OTA update and reboot, the GPIO returning to its default/reset state is the expected behavior. Could you give some more context on what exactly is the use case here? See the section reset behavior.


    Kind Regards,

    Abhijith

  • Hello Abhijith,

    Thank you for the clarification.

    In our design, P1.06 (SYS_EN) is used as the power enable pin. It is initially set high to keep the system powered on. If this pin goes low, the system powers off.

    We also have a power button in the circuit. The firmware detects the button press by reading P1.05 (SYS_OUT) and then toggles P1.06 (SYS_EN) to control the system power.

    However, after performing FOTA, the device reboots and the state of P1.06 returns to its default value. As a result, SYS_EN becomes low and the system powers off. The device can only power on again when the button is pressed manually to power up the controller.

    I have attached the relevant part of the schematic for reference.

    Best regards,
    Jishnu K J

Reply
  • Hello Abhijith,

    Thank you for the clarification.

    In our design, P1.06 (SYS_EN) is used as the power enable pin. It is initially set high to keep the system powered on. If this pin goes low, the system powers off.

    We also have a power button in the circuit. The firmware detects the button press by reading P1.05 (SYS_OUT) and then toggles P1.06 (SYS_EN) to control the system power.

    However, after performing FOTA, the device reboots and the state of P1.06 returns to its default value. As a result, SYS_EN becomes low and the system powers off. The device can only power on again when the button is pressed manually to power up the controller.

    I have attached the relevant part of the schematic for reference.

    Best regards,
    Jishnu K J

Children
No Data
Related