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
  • After connecting a BAttery the charger status changed:

    Charger Status: 5, Error: 0, VBUS: connected
    V: 4.165 I: 0.0001 T: 24.79
    Charger Status: 5, Error: 0, VBUS: connected
    V: 4.165 I: 0.0001 T: 24.79
    Charger Status: 5, Error: 0, VBUS: connected
    V: 4.145 I: 0.1590 T: 24.79
    Charger Status: 9, Error: 0, VBUS: connected
    V: 4.145 I: 0.1590 T: 24.79
    Charger Status: 9, Error: 0, VBUS: connected
    V: 4.145 I: 0.1590 T: 24.79
    Charger Status: 9, Error: 0, VBUS: connected

Children
  • Hi,

     

    Good, this means that the setup is working with the precompiled .hex that I shared.

    Then I suspect the issue is how your firmware is setup, ie. built.

     

    Try to delete your build folder, do not add any specific overlays or .conf files; and only set the SHIELD parameter, similar to this:

     

    Since we cannot overload the west cmd switch here, we just set the EK directly in CMakeLists.txt:

    # Copyright (c) 2023 Nordic Semiconductor ASA
    # SPDX-License-Identifier: Apache-2.0
    
    cmake_minimum_required(VERSION 3.20.0)
    
    set(EXTRA_DTC_OVERLAY_FILE npm1300.overlay)
    
    find_package(Zephyr REQUIRED HINTS $ENV{ZEPHYR_BASE})
    
    project(npm13xx_ek)
    target_sources(app PRIVATE src/main.c)

     

    Kind regards,

    Håkon

  • Hi, build/compiling works with that setup. Situation stays, only the LED2 (amber) is blinking. despite turning on all 3 LEDs.

    "led_off(leds, 2U);"

    works. disabling it makes the LED2 light up constantly. Strange.

    #include <dt-bindings/regulator/npm13xx.h>
    
    &npm1300_ek_ldo1 {
    	regulator-initial-mode = <NPM13XX_LDSW_MODE_LDSW>;
    };
    
    &npm1300_ek_pmic {
    	host-int-gpios = <&gpio0 4 0>;
    	pmic-int-pin = <3>;
    
    	/*
    	npm1300_ek_leds: leds {
    		compatible = "nordic,npm1300-led";
    		status="okay";
    		//nordic,led0-mode = "error";
    		//nordic,led1-mode = "charging";
    		nordic,led0-mode = "host";
    		nordic,led1-mode = "host";
    		nordic,led2-mode = "host";
    	};*/
    };
    
    &npm1300_ek_leds {
    		compatible = "nordic,npm1300-led";
    		status="okay";
    		//nordic,led0-mode = "error";
    		//nordic,led1-mode = "charging";
    		nordic,led0-mode = "host";
    		nordic,led1-mode = "host";
    		nordic,led2-mode = "host";
    	};

    See the C-code and my npm1300.overlay attached.

    Additional, with USB-C in USB PMIC and without Battery the LED1 "CHG" is constantly on. Adding a battery, led1 turns off.

  • Hi,

     

    Can you please share your full project, including your build-folder?

    Based on your description, it sounds like you have not overridden the default led setup of the EK.

     

    Kind regards,

    Håkon

  • Hi,

     

    Build shows:

    				npm1300_ek_leds: leds {
    					compatible = "nordic,npm1300-led"; /* in zephyr/boards/shields/npm1300_ek/npm1300_ek.overlay:69 */
    					nordic,led0-mode = "error";        /* in zephyr/boards/shields/npm1300_ek/npm1300_ek.overlay:70 */
    					nordic,led1-mode = "charging";     /* in zephyr/boards/shields/npm1300_ek/npm1300_ek.overlay:71 */
    					nordic,led2-mode = "host";         /* in zephyr/boards/shields/npm1300_ek/npm1300_ek.overlay:72 */
    				};

    but I cannot see that your overlay includes this sequence either?

     

    &npm1300_ek_leds {
    		compatible = "nordic,npm1300-led";
    		status="okay";
    		//nordic,led0-mode = "error";
    		//nordic,led1-mode = "charging";
    		nordic,led0-mode = "host";
    		nordic,led1-mode = "host";
    		nordic,led2-mode = "host";
    	};

     

    Try deleting your build folder, adding the sequence to npm1300.overlay, and remember to add this as an extra DTC overlay file when configuring your build.

     

    Afterwards, go into build-folder/application-name/zephyr/zephyr.dts and check that it is set as intended:

    				/* node '/soc/i2c@40003000/pmic@6b/leds' defined in zephyr/boards/shields/npm1300_ek/npm1300_ek.overlay:68 */
    				npm1300_ek_leds: leds {
    					compatible = "nordic,npm1300-led"; /* in ../../Users/hkn/Downloads/npm13xx_one_button/build2/npm13xx_one_button/zephyr/npm1300.overlay:61 */
    					status = "okay";                   /* in ../../Users/hkn/Downloads/npm13xx_one_button/build2/npm13xx_one_button/zephyr/npm1300.overlay:62 */
    					nordic,led0-mode = "host";         /* in ../../Users/hkn/Downloads/npm13xx_one_button/build2/npm13xx_one_button/zephyr/npm1300.overlay:65 */
    					nordic,led1-mode = "host";         /* in ../../Users/hkn/Downloads/npm13xx_one_button/build2/npm13xx_one_button/zephyr/npm1300.overlay:66 */
    					nordic,led2-mode = "host";         /* in ../../Users/hkn/Downloads/npm13xx_one_button/build2/npm13xx_one_button/zephyr/npm1300.overlay:67 */
    				};

     

    Kind regards,

    Håkon

Related