no device npm1300_ek (one button sample) with nRF52 DK on I2C Bus

I try to get the one button sample to work. There were several details missing to be able to compile and run this sample, which was very frustrating. After editing/updating the

prj.conf: CONFIG_I2C=y

CMakeLists.txt: set(SHIELD npm1300_ek)

nrf52dk_nrf52832.overlay:

 #include <zephyr/dt-bindings/pinctrl/nrf-pinctrl.h>

 &i2c1 {
 status = "okay";
 pinctrl-0 = <&i2c1_default>;
 pinctrl-1 = <&i2c1_sleep>;
 pinctrl-names = "default", "sleep";
 clock-frequency = <I2C_BITRATE_STANDARD>; 
 //clock-frequency = <10000>;
 };
 
 &i2c1_default {
 group1 {
 psels = <NRF_PSEL(TWIM_SDA, 0, 26)>,
 <NRF_PSEL(TWIM_SCL, 0, 27)>;
 bias-pull-up;
 };
};

&i2c1_sleep {
 group1 {
 psels = <NRF_PSEL(TWIM_SDA, 0, 26)>,
 <NRF_PSEL(TWIM_SCL, 0, 27)>;
 low-power-enable;
 };
};

My zephyr.dts i2c1 snippet:

/* node '/soc/i2c@40004000' defined in zephyr/dts/arm/nordic/nrf52832.dtsi:172 */
		i2c1: i2c@40004000 {
			#address-cells = < 0x1 >;      /* in zephyr/dts/arm/nordic/nrf52832.dtsi:181 */
			#size-cells = < 0x0 >;         /* in zephyr/dts/arm/nordic/nrf52832.dtsi:182 */
			reg = < 0x40004000 0x1000 >;   /* in zephyr/dts/arm/nordic/nrf52832.dtsi:183 */
			interrupts = < 0x4 0x1 >;      /* in zephyr/dts/arm/nordic/nrf52832.dtsi:184 */
			easydma-maxcnt-bits = < 0x8 >; /* in zephyr/dts/arm/nordic/nrf52832.dtsi:185 */
			zephyr,pm-device-runtime-auto; /* in zephyr/dts/arm/nordic/nrf52832.dtsi:187 */
			compatible = "nordic,nrf-twi"; /* in zephyr/boards/nordic/nrf52dk/nrf52dk_nrf52832.dts:188 */
			status = "okay";               /* in ../../../../mnt/df01dc22-f3bf-40d5-9858-752a58c9832d/devprojects/nordicsemi/npm13xx_one_button/build/npm13xx_one_button/zephyr/boards/nrf52dk_nrf52832.overlay:9 */
			pinctrl-0 = < &i2c1_default >; /* in ../../../../mnt/df01dc22-f3bf-40d5-9858-752a58c9832d/devprojects/nordicsemi/npm13xx_one_button/build/npm13xx_one_button/zephyr/boards/nrf52dk_nrf52832.overlay:10 */
			pinctrl-1 = < &i2c1_sleep >;   /* in ../../../../mnt/df01dc22-f3bf-40d5-9858-752a58c9832d/devprojects/nordicsemi/npm13xx_one_button/build/npm13xx_one_button/zephyr/boards/nrf52dk_nrf52832.overlay:11 */
			pinctrl-names = "default",
			                "sleep";       /* in ../../../../mnt/df01dc22-f3bf-40d5-9858-752a58c9832d/devprojects/nordicsemi/npm13xx_one_button/build/npm13xx_one_button/zephyr/boards/nrf52dk_nrf52832.overlay:12 */
			clock-frequency = < 0x186a0 >; /* in ../../../../mnt/df01dc22-f3bf-40d5-9858-752a58c9832d/devprojects/nordicsemi/npm13xx_one_button/build/npm13xx_one_button/zephyr/boards/nrf52dk_nrf52832.overlay:13 */
		};

with claudes assistance/support i got it to compile and run. But an i2c scan i2c0 shows no device at all.

What minimal required steps/configuration have to setup to get I2C enabled and detect devices on the bus should be?

Trying with the nrf-connect (Ubuntu) Linux-Desktop app (2x USB -C, 1x LiPo Battery) i get NPM detected, the LiPo Battery to and can change parameters for ex. the LED's live, so the BOARD is working.

Any support/hint/help is appreciated.

Parents Reply Children
  • Hi,

    USB-C is connected to "USB PMIC" and the Battery to /P1-header,

    VBATIN & VBAT are connected via Jumper.

    On the nrf52 DK i use VDD (between RESET and 5V) on P1 header connected to VDDIO ot the TWI npm1300_EK header.

    (P2) NTC & 10k are connected via jumper.

    SDA -> P0.26

    SCL->P0.27

    Compiling the mentioned example, after manually adding set(SHIELD npm1300_ek) in CMakeLists.txt) results in the folllowing output:

    *** Booting nRF Connect SDK v3.2.0-5dcc6bd39b0f ***
    *** Using Zephyr OS v4.2.99-a57ad913cf4e ***
    Set up button at gpio@50000000 pin 13
    Error: led device is not ready
    Pmic device not ready.
    Charger device not ready.

  • My console output:

    Building npm13xx_ek
    west build --build-dir /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek --pristine --board nrf52dk/nrf52832 -- -DCONF_FILE="prj.conf" -DEXTRA_DTC_OVERLAY_FILE=npm1300.overlay -DDTC_OVERLAY_FILE=boards/nrf52dk_nrf52832.overlay -DDEBUG_THREAD_INFO=On -DCONFIG_DEBUG_THREAD_INFO=y -DSHIELD=npm1300_ek -Dnpm13xx_ek_DEBUG_THREAD_INFO=Off
    
    -- west build: generating a build system
    Loading Zephyr module(s) (Zephyr base): sysbuild_default
    -- Found Python3: /home/thomas/ncs/toolchains/43683a87ea/usr/local/bin/python3.12 (found suitable version "3.12.4", minimum required is "3.10") found components: Interpreter 
    -- Cache files will be written to: /home/thomas/.cache/zephyr
    -- Found west (found suitable version "1.4.0", minimum required is "0.14.0")
    -- Board: nrf52dk, qualifiers: nrf52832
    -- Shield(s): npm1300_ek
    Parsing /home/thomas/ncs/v3.2.0/zephyr/share/sysbuild/Kconfig
    Loaded configuration '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/_sysbuild/empty.conf'
    Merged configuration '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/_sysbuild/empty.conf'
    Configuration saved to '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/zephyr/.config'
    Kconfig header saved to '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/_sysbuild/autoconf.h'
    -- 
       ********************************
       * Running CMake for npm13xx_ek *
       ********************************
    Loading Zephyr default modules (Zephyr base).
    -- Application: /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek
    -- CMake version: 3.21.0
    -- Found Python3: /home/thomas/ncs/toolchains/43683a87ea/usr/local/bin/python (found suitable version "3.12.4", minimum required is "3.10") found components: Interpreter 
    -- Cache files will be written to: /home/thomas/.cache/zephyr
    -- Zephyr version: 4.2.99 (/home/thomas/ncs/v3.2.0/zephyr)
    -- Found west (found suitable version "1.4.0", minimum required is "0.14.0")
    -- Board: nrf52dk, qualifiers: nrf52832
    -- Shield(s): npm1300_ek
    -- Found host-tools: zephyr 0.17.0 (/home/thomas/ncs/toolchains/43683a87ea/opt/zephyr-sdk)
    -- Found toolchain: zephyr 0.17.0 (/home/thomas/ncs/toolchains/43683a87ea/opt/zephyr-sdk)
    -- Found Dtc: /home/thomas/ncs/toolchains/43683a87ea/usr/bin/dtc (found suitable version "1.5.0", minimum required is "1.4.6") 
    -- Found BOARD.dts: /home/thomas/ncs/v3.2.0/zephyr/boards/nordic/nrf52dk/nrf52dk_nrf52832.dts
    -- Found devicetree overlay: /home/thomas/ncs/v3.2.0/zephyr/boards/shields/npm1300_ek/npm1300_ek.overlay
    -- Found devicetree overlay: boards/nrf52dk_nrf52832.overlay
    -- Found devicetree overlay: npm1300.overlay
    -- Generated zephyr.dts: /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/zephyr.dts
    -- Generated pickled edt: /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/edt.pickle
    -- Generated devicetree_generated.h: /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/include/generated/zephyr/devicetree_generated.h
    Parsing /home/thomas/ncs/v3.2.0/zephyr/Kconfig
    Loaded configuration '/home/thomas/ncs/v3.2.0/zephyr/boards/nordic/nrf52dk/nrf52dk_nrf52832_defconfig'
    Merged configuration '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/prj.conf'
    Merged configuration '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/misc/generated/extra_kconfig_options.conf'
    Merged configuration '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/.config.sysbuild'
    Configuration saved to '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/.config'
    Kconfig header saved to '/home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/include/generated/zephyr/autoconf.h'
    -- Found GnuLd: /home/thomas/ncs/toolchains/43683a87ea/opt/zephyr-sdk/arm-zephyr-eabi/arm-zephyr-eabi/bin/ld.bfd (found version "2.38") 
    -- The C compiler identification is GNU 12.2.0
    -- The CXX compiler identification is GNU 12.2.0
    -- The ASM compiler identification is GNU
    -- Found assembler: /home/thomas/ncs/toolchains/43683a87ea/opt/zephyr-sdk/arm-zephyr-eabi/bin/arm-zephyr-eabi-gcc
    -- Using ccache: /home/thomas/ncs/toolchains/43683a87ea/usr/bin/ccache
    -- Found gen_kobject_list: /home/thomas/ncs/v3.2.0/zephyr/scripts/build/gen_kobject_list.py
    -- Configuring done
    -- Generating done
    -- Build files have been written to: /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek
    -- Configuring done
    -- Generating done
    -- Build files have been written to: /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build
    -- west build: building application
    [5/234] Generating include/generated/zephyr/version.h
    -- Zephyr version: 4.2.99 (/home/thomas/ncs/v3.2.0/zephyr), build: ncs-v3.2.0
    [234/234] Linking C executable zephyr/zephyr.elf
    Memory region         Used Size  Region Size  %age Used
               FLASH:      109680 B       512 KB     20.92%
                 RAM:       19488 B        64 KB     29.74%
            IDT_LIST:          0 GB        32 KB      0.00%
    Generating files from /home/thomas/ncs/v3.2.0/zephyr/samples/shields/npm13xx_ek/build/npm13xx_ek/zephyr/zephyr.elf for board: nrf52dk
    [10/10] Generating ../merged.hex

  • Hi,

    the lower Version(s) of nRF Connect and Zeohyr shouldn't be an issue?

  • Hi,

     

    nRF52_DK_usr said:

    USB-C is connected to "USB PMIC" and the Battery to /P1-header,

    VBATIN & VBAT are connected via Jumper.

    On the nrf52 DK i use VDD (between RESET and 5V) on P1 header connected to VDDIO ot the TWI npm1300_EK header.

    (P2) NTC & 10k are connected via jumper.

    SDA -> P0.26

    SCL->P0.27

    Compiling the mentioned example, after manually adding set(SHIELD npm1300_ek) in CMakeLists.txt) results in the folllowing output:

    This is the same setup as I have.

    What about P18? Is there a jumper present on this header?

    This one should not be present if the voltages differs between the NPM EK and nRF DK.

     

    Could you share a picture of how the jumpers are setup on your NPM1300-EK?

     

    Kind regards,

    Håkon

     

  • On P18 is no jumper. See my jumper configuration picture attached.

Related