NCS v2.0.0 - aws_iot sample - No UART output when using an overlay file

Hi,

I'm working with the NCS v2.0.0 - aws_iot sample and an nRF9160 on a custom board.

I have tested the aws_iot sample on an nRF9160DK and have confirmed that it works.

It appears that when I attempt to use an overlay file to change the TX and RX pins of UART_0, the UART output stops working.

I have tested this overlay file using hello world sample on my custom board and it outputs as expected.

I have attached my overlay file below, could you let me know what might be happening?

Thanks,

Alvin

6431.nrf9160dk_nrf9160_ns.overlay

Parents
  • If you look at GPIO interfaces and Virtual COM port you can see that P0.00 and P0.01 are connected to the Interface MCU. So when changing to these pins, the output should go out to another COM port when using P0.00 and P0.01.

    I tested this myself. First I connected the nRF9160 DK to the computer, and then I ran nrfjprog --com, and got the following output:

    $ nrfjprog --com
    960013235 COM37 VCOM1
    960013235 COM38 VCOM2
    960013235 COM39 VCOM0

    I then tried to program the hello_world sample to the nRF9160 DK, and the UART log was output on COM39. Then I applied your overlay file, and UART log was now output on COM38. See the below image.

    Do you see the same behaviour on your side? If not, could you upload your project here?

    Best regards,

    Simon

  • Hi Simon,

    I can confirm that using the overlay file with the hello_world sample works on my custom board. I was getting UART communication on P0.00 and P0.01.

    However when I attempt to use the same overlay file on the aws_iot sample, it no longer outputs anything on the UART.

    The aws_iot sample I'm using was found in the NCS v2.0.0 toolchain nrf > samples > nrf9160 > aws_iot

    Thanks,

    Alvin

Reply
  • Hi Simon,

    I can confirm that using the overlay file with the hello_world sample works on my custom board. I was getting UART communication on P0.00 and P0.01.

    However when I attempt to use the same overlay file on the aws_iot sample, it no longer outputs anything on the UART.

    The aws_iot sample I'm using was found in the NCS v2.0.0 toolchain nrf > samples > nrf9160 > aws_iot

    Thanks,

    Alvin

Children
  • Did you see the bootup message *** Booting Zephyr OS build v3.1.99-ncs1 *** and nothing else after that ??

  • I tested your overlay with the aws_iot sample as well, and it worked fine:

    As you can see, the MCUboot log (which the overlay file don't apply to) outputs the log to one COM port, while the output from the aws_iot sample are ouput on another.

    • Have you done any other modifications to the aws_iot sample?
    • What nRF9160DK version are you using?
    • What terminal program are you using?
    • What firmware do you have on the Interface MCU? 

    Best regards,

    Simon 

  • That is different than what I'm experiencing - here are my observations so far. I am using NCS v2.0.0 and MFW v1.3.1. The board selected in the build configuration in Visual Studio Code is nrf9160dk_nrf9160_ns.

    I'm using nRF9160DK PCA10090 1.0.0 - Date code 2021.11

    I'm using LTE Link Monitor v2.0.2 launched from nRF Connect for Desktop v3.12.0

    Here is a screenshot of the Interface MCU firmware version

    -----

    1. Here is my output when running the aws_iot sample from NCS v2.0.0 with no changes.

    2. It looks like the application was getting stuck at "Jumping to the first image slot" and I found this thread on the forums https://devzone.nordicsemi.com/f/nordic-q-a/88878/9160dk-boot-stuck-at-jumping-to-the-first-image-slot-sample-http_update-with-ncs-2-0-0. Adding the following lines to the proj.conf file resulted in the output below. No overlay file. This seemed to work as the application was now starting.

    Added to the end of prj.conf:

    # SPM
    CONFIG_SPM=y
    CONFIG_BUILD_WITH_TFM=n

    Last lines of output - full output below (2022-09-19 aws_iot Output - SPM - No Overlay.txt)

    *** Booting Zephyr OS build v3.0.99-ncs1  ***
    
    
    
    
    The AWS IoT sample started, version: v1.0.0
    
    
    
    
    +CEREG: 90
    
    
    LTE cell changed: Cell ID: -1, Tracking area: -1

    *** Booting Zephyr OS build v3.0.99-ncs1  ***I: Starting bootloaderI: Primary image: magic=unset, swap_type=0x1, copy_done=0x3, image_ok=0x3I: Secondary image: magic=unset, swap_type=0x1, copy_done=0x3, image_ok=0x3I: Boot source: noneI: Swap type: noneI: Bootloader chainload address offset: 0x10000I: Jumping to the first image slot*** Booting Zephyr OS build v3.0.99-ncs1  ***Flash regionsDomainPermissions00 03 0x00000 0x20000 Securerwxl04 31 0x20000 0x100000 Non-SecurerwxlNon-secure callable region 0 placed in flash region 3 with size 32.SRAM regionDomainPermissions00 03 0x00000 0x08000 Securerwxl04 31 0x08000 0x40000 Non-SecurerwxlPeripheralDomainStatus00 NRF_P0               Non-SecureOK01 NRF_CLOCK            Non-SecureOK02 NRF_RTC0             Non-SecureOK03 NRF_RTC1             Non-SecureOK04 NRF_NVMC             Non-SecureOK05 NRF_UARTE1           Non-SecureOK06 NRF_UARTE2           SecureSKIP07 NRF_TWIM2            Non-SecureOK08 NRF_SPIM3            Non-SecureOK09 NRF_TIMER0           Non-SecureOK10 NRF_TIMER1           Non-SecureOK11 NRF_TIMER2           Non-SecureOK12 NRF_SAADC            Non-SecureOK13 NRF_PWM0             Non-SecureOK14 NRF_PWM1             Non-SecureOK15 NRF_PWM2             Non-SecureOK16 NRF_PWM3             Non-SecureOK17 NRF_WDT              Non-SecureOK18 NRF_IPC              Non-SecureOK19 NRF_VMC              Non-SecureOK20 NRF_FPU              Non-SecureOK21 NRF_EGU0             Non-SecureOK22 NRF_EGU1             Non-SecureOK23 NRF_EGU2             Non-SecureOK24 NRF_EGU3             Non-SecureOK25 NRF_EGU4             Non-SecureOK26 NRF_EGU5             Non-SecureOK27 NRF_DPPIC            Non-SecureOK28 NRF_REGULATORS       Non-SecureOK29 NRF_PDM              Non-SecureOK30 NRF_I2S              Non-SecureOK31 NRF_GPIOTE1          Non-SecureOKSPM: NS image at 0x20200SPM: NS MSP at 0x20014d60SPM: NS reset vector at 0x26169SPM: prepare to jump to Non-Secure image.*** Booting Zephyr OS build v3.0.99-ncs1  ***The AWS IoT sample started, version: v1.0.0+CEREG: 90LTE cell changed: Cell ID: -1, Tracking area: -1

    3. After this, I added the overlay file from above to set UART0 TX to P0.01. I connected an oscilloscope probe to P0.01 on the DK, but was unable to see any activity on this pin.

    Here is the output from this setup, I would expect to see the message "*** Booting Zephyr OS" etc show up on P0.01 like in your screenshots above, but I am seeing nothing on P0.01.

    *** Booting Zephyr OS build v3.0.99-ncs1  ***I: Starting bootloaderI: Primary image: magic=unset, swap_type=0x1, copy_done=0x3, image_ok=0x3I: Secondary image: magic=unset, swap_type=0x1, copy_done=0x3, image_ok=0x3I: Boot source: noneI: Swap type: noneI: Bootloader chainload address offset: 0x10000I: Jumping to the first image slot*** Booting Zephyr OS build v3.0.99-ncs1  ***Flash regionsDomainPermissions00 03 0x00000 0x20000 Securerwxl04 31 0x20000 0x100000 Non-SecurerwxlNon-secure callable region 0 placed in flash region 3 with size 32.SRAM regionDomainPermissions00 03 0x00000 0x08000 Securerwxl04 31 0x08000 0x40000 Non-SecurerwxlPeripheralDomainStatus00 NRF_P0               Non-SecureOK01 NRF_CLOCK            Non-SecureOK02 NRF_RTC0             Non-SecureOK03 NRF_RTC1             Non-SecureOK04 NRF_NVMC             Non-SecureOK05 NRF_UARTE1           Non-SecureOK06 NRF_UARTE2           SecureSKIP07 NRF_TWIM2            Non-SecureOK08 NRF_SPIM3            Non-SecureOK09 NRF_TIMER0           Non-SecureOK10 NRF_TIMER1           Non-SecureOK11 NRF_TIMER2           Non-SecureOK12 NRF_SAADC            Non-SecureOK13 NRF_PWM0             Non-SecureOK14 NRF_PWM1             Non-SecureOK15 NRF_PWM2             Non-SecureOK16 NRF_PWM3             Non-SecureOK17 NRF_WDT              Non-SecureOK18 NRF_IPC              Non-SecureOK19 NRF_VMC              Non-SecureOK20 NRF_FPU              Non-SecureOK21 NRF_EGU0             Non-SecureOK22 NRF_EGU1             Non-SecureOK23 NRF_EGU2             Non-SecureOK24 NRF_EGU3             Non-SecureOK25 NRF_EGU4             Non-SecureOK26 NRF_EGU5             Non-SecureOK27 NRF_DPPIC            Non-SecureOK28 NRF_REGULATORS       Non-SecureOK29 NRF_PDM              Non-SecureOK30 NRF_I2S              Non-SecureOK31 NRF_GPIOTE1          Non-SecureOKSPM: NS image at 0x20200SPM: NS MSP at 0x20014d60SPM: NS reset vector at 0x26169SPM: prepare to jump to Non-Secure image.

  • When I add in the overlay file and use SPM (CONFIG_SPM=y and CONFIG_BUILD_WITH_TFM=n) in the prj.conf file, I do not see *** Booting Zephyr OS build v3.1.99-ncs1 ***. The last thing I see is:

    SPM: prepare to jump to Non-Secure image.
    
    
  • I may be facing a different problem.  I am using the peripheral_lbs example with NCS V2.1.0 .  It works on nRF5340DK, but if I change the overlay file.  Only "*** Booting Zephyr OS build v3.1.99-ncs1 *** message received on my custom board which indicates the MCUBoot works with my overlay file, but stepping thru printk() in the peripheral_lbs main.c not seeing more messages printed.  The application is running fine with the debugger.   I am debugging, but it may be different from your problem.

Related