Beware that this post is related to an SDK in maintenance mode
More Info: Consider nRF Connect SDK for new designs
This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

merging 2 or 3 i2c devices using NRF5340dk

Hello everybody,
i succeeded to get the output from BME280 and MPU6060 sensors 
I need to merge them together 

Kindly, I need help to Setup prj.conf file

Thanks & Regards

Parents Reply
  • Rihab said:
    yeah but how do i put them together in the same project ?
    i just put the 2 project in the same file and then i create the dts ?

    If you want to merge two projects, you simply merge both of the corresponding files into one file. E.g. merge bme280/prj.conf and mpu6060/prj.conf into bme280_mpu_6060/prj.conf. Do the same with the .c/.h, overlay files, CMakeLists.txt and so on...

    Best regards,

    Simon

Children
  • thanks Simon

    i think you got what i want to do 
    now i' trying to combine the 3 projects i created and merge them in only one 
    i posted a ticket about my button issue, and you helped me with it 
    i'm very thankful for that 
    i' stuck since  days with the global project that I'm trying to merge i have config errors in the overlay 
    it's not taking in consideration all the sensors 
    do you have a useful link for merging 2 or more projects into one
    it can help me alot 
    kindly reply me as fast as you can, i'm one day away from the deadline delivery 
    thank you in advance 

  • I don't think I can give you any other advice from what I stated earlier:

    Simon said:
    If you want to merge two projects, you simply merge both of the corresponding files into one file. E.g. merge bme280/prj.conf and mpu6060/prj.conf into bme280_mpu_6060/prj.conf. Do the same with the .c/.h, overlay files, CMakeLists.txt and so on...

    Just do it one step at the time and rebuild the project (pristine) after every addition. If it fails, read the error log, understand the error and try to fix it.

    Be aware that some Kconfigs are dependent on others. E.g. if CONFIG_OPTION_1 depends on CONFIG_OTPION_2, you need to add both.

    Could you upload the error logs here?

  • i have plenty of errors that i' not familiar with
    Knowing that i'm new for development, i'm a bit lost 
    i'm seeking hep from you 

    i will post below my overlay, Main and sample.yaml

    &i2c1 {
    	status = "okay";
    	sda-pin = < 25 >;
    	scl-pin = < 26 >;
        clock-frequency = <100000>; 
    	
    	mpu6050@68 {
    		compatible = "invensense,mpu6050";
    		reg = <0x68>;
    		status = "okay";
    		label = "MPU6050";
    		int-gpios = <&gpio0 11 GPIO_ACTIVE_HIGH>;
    	};
    };
    
    &i2c1 {
    	status = "okay";
    	sda-pin = < 34 >;
    	scl-pin = < 35 >;
        clock-frequency = <100000>; 
    	
    	bme280: bme280@76 {
    	    status = "okay";
    		compatible = "bosch,bme280";
    		reg = <0x76>;
    		label = "BME280";
    	};
    };
    
    &uart1 {
        status = "disabled";
    };
    
    &gpio27 {
    	compatible = "gpio-keys, nordic";
        status = "okay";
    	GPIO_DETECT: gpio_detect{
    		gpio-pin = < 27 >;
    		int-gpios = <&gpio0 0x27 (GPIO_PULL_UP|GPIO_ACTIVE_LOW)>;
    	};
        clock-frequency = <100000>; 
    };
    {
    	buttons {
    		compatible = "gpio-keys";
    		button27: button_27 {
    			gpios = <&gpio0 27 (GPIO_PULL_UP | GPIO_ACTIVE_LOW)>;
    			label = "GPIO P0.27";
    		};
    	};
    
    	aliases {
    		sw27 = &button27;
    	};
    };

    #include <zephyr.h>
    #include <device.h>
    #include <drivers/sensor.h>
    #include <stdio.h>
    #include <sys/util.h>
    #include <sys/printk.h>
    #include <inttypes.h>
    
    #define SLEEP_TIME_MS	1
    
    /*
     * Get button configuration from the devicetree sw0 alias. This is mandatory.
     */
    #define SW0_NODE	DT_ALIAS(sw27)
    #if !DT_NODE_HAS_STATUS(SW0_NODE, okay)
    #error "Unsupported board: sw0 devicetree alias is not defined"
    #endif
    static const struct gpio_dt_spec button = GPIO_DT_SPEC_GET_OR(SW0_NODE, gpios,
    							      {0});
    static struct gpio_callback button_cb_data;
    static struct gpio_dt_spec led = GPIO_DT_SPEC_GET_OR(DT_ALIAS(led0), gpios,
    						     {0});
    							 
    							 
    
    static const char *now_str(void)
    {
    	static char buf[16]; /* ...HH:MM:SS.MMM */
    	uint32_t now = k_uptime_get_32();
    	unsigned int ms = now % MSEC_PER_SEC;
    	unsigned int s;
    	unsigned int min;
    	unsigned int h;
    
    	now /= MSEC_PER_SEC;
    	s = now % 60U;
    	now /= 60U;
    	min = now % 60U;
    	now /= 60U;
    	h = now;
    
    	snprintf(buf, sizeof(buf), "%u:%02u:%02u.%03u",
    		 h, min, s, ms);
    	return buf;
    }
    static const struct device *get_bme280_device(void)
    {
    	const struct device *dev = DEVICE_DT_GET_ANY(bosch_bme280);
    
    	if (dev == NULL) {
    		/* No such node, or the node does not have status "okay". */
    		printk("\nError: no device found.\n");
    		return NULL;
    	}
    
    	if (!device_is_ready(dev)) {
    		printk("\nError: Device \"%s\" is not ready; "
    		       "check the driver initialization logs for errors.\n",
    		       dev->name);
    		return NULL;
    	}
    
    	printk("Found device \"%s\", getting sensor data\n", dev->name);
    	return dev;
    }
    static int process_mpu6050(const struct device *dev)
    {
    	struct sensor_value temperature;
    	struct sensor_value accel[3];
    	struct sensor_value gyro[3];
    	int rc = sensor_sample_fetch(dev);
    
    	if (rc == 0) {
    		rc = sensor_channel_get(dev, SENSOR_CHAN_ACCEL_XYZ,
    					accel);
    	}
    	if (rc == 0) {
    		rc = sensor_channel_get(dev, SENSOR_CHAN_GYRO_XYZ,
    					gyro);
    	}
    	if (rc == 0) {
    		rc = sensor_channel_get(dev, SENSOR_CHAN_AMBIENT_TEMP,
    					&temperature);
    	}
    	if (rc == 0) {
    		printf("[%s]:%g Cel\n"
    		       "  accel %f %f %f m/s/s\n"
    		       "  gyro  %f %f %f rad/s\n",
    		       now_str(),
    		       sensor_value_to_double(&temperature),
    		       sensor_value_to_double(&accel[0]),
    		       sensor_value_to_double(&accel[1]),
    		       sensor_value_to_double(&accel[2]),
    		       sensor_value_to_double(&gyro[0]),
    		       sensor_value_to_double(&gyro[1]),
    		       sensor_value_to_double(&gyro[2]));
    	} else {
    		printf("sample fetch/get failed: %d\n", rc);
    	}
    
    	return rc;
    }
    
    #ifdef CONFIG_MPU6050_TRIGGER
    static struct sensor_trigger trigger;
    
    static void handle_mpu6050_drdy(const struct device *dev,
    				struct sensor_trigger *trig)
    {
    	int rc = process_mpu6050(dev);
    
    	if (rc != 0) {
    		printf("cancelling trigger due to failure: %d\n", rc);
    		(void)sensor_trigger_set(dev, trig, NULL);
    		return;
    	}
    }
    #endif /* CONFIG_MPU6050_TRIGGER */
    void button_pressed(const struct device *dev, struct gpio_callback *cb,
    		    uint32_t pins)
    {
    	printk("Button pressed at %" PRIu32 "\n", k_cycle_get_32());
    }
    void main(void)
    {
    	int ret;
    
    	if (!device_is_ready(button.port)) {
    		printk("Error: button device %s is not ready\n",
    		       button.port->name);
    		return;
    	}
    
    	ret = gpio_pin_configure_dt(&button, GPIO_INPUT);
    	if (ret != 0) {
    		printk("Error %d: failed to configure %s pin %d\n",
    		       ret, button.port->name, button.pin);
    		return;
    	}
    
    	ret = gpio_pin_interrupt_configure_dt(&button,
    					      GPIO_INT_EDGE_TO_ACTIVE);
    	if (ret != 0) {
    		printk("Error %d: failed to configure interrupt on %s pin %d\n",
    			ret, button.port->name, button.pin);
    		return;
    	}
    
    	gpio_init_callback(&button_cb_data, button_pressed, BIT(button.pin));
    	gpio_add_callback(button.port, &button_cb_data);
    	printk("Set up button at %s pin %d\n", button.port->name, button.pin);
    
    	if (led.port && !device_is_ready(led.port)) {
    		printk("Error %d: LED device %s is not ready; ignoring it\n",
    		       ret, led.port->name);
    		led.port = NULL;
    	}
    	if (led.port) {
    		ret = gpio_pin_configure_dt(&led, GPIO_OUTPUT);
    		if (ret != 0) {
    			printk("Error %d: failed to configure LED device %s pin %d\n",
    			       ret, led.port->name, led.pin);
    			led.port = NULL;
    		} else {
    			printk("Set up LED at %s pin %d\n", led.port->name, led.pin);
    		}
    	}
    
    	printk("Press the button\n");
    	if (led.port) {
    		while (1) {
    			/* If we have an LED, match its state to the button's. */
    			int val = gpio_pin_get_dt(&button);
    
    			if (val >= 0) {
    				gpio_pin_set_dt(&led, val);
    			}
    			k_msleep(SLEEP_TIME_MS);
    		}
    	}
    	
    	const char *const label = DT_LABEL(DT_INST(0, invensense_mpu6050));
    	const struct device *mpu6050 = device_get_binding(label);
    
    	if (!mpu6050) {
    		printf("Failed to find sensor %s\n", label);
    		return;
    	}
    
    #ifdef CONFIG_MPU6050_TRIGGER
    	trigger = (struct sensor_trigger) {
    		.type = SENSOR_TRIG_DATA_READY,
    		.chan = SENSOR_CHAN_ALL,
    	};
    	if (sensor_trigger_set(mpu6050, &trigger,
    			       handle_mpu6050_drdy) < 0) {
    		printf("Cannot configure trigger\n");
    		return;
    	}
    	printk("Configured for triggered sampling.\n");
    #endif
    
    	while (!IS_ENABLED(CONFIG_MPU6050_TRIGGER)) {
    		int rc = process_mpu6050(mpu6050);
    
    		if (rc != 0) {
    			break;
    		}
    		k_sleep(K_SECONDS(2));
    	}
    	const struct device *dev = get_bme280_device();
    	
    	if (dev == NULL) {
    		return;
    	}
    
    	while (1) {
    		struct sensor_value temp, press, humidity;
    
    		sensor_sample_fetch(dev);
    		sensor_channel_get(dev, SENSOR_CHAN_AMBIENT_TEMP, &temp);
    		sensor_channel_get(dev, SENSOR_CHAN_PRESS, &press);
    		sensor_channel_get(dev, SENSOR_CHAN_HUMIDITY, &humidity);
    
    		printk("temp: %d.%06d; press: %d.%06d; humidity: %d.%06d\n",
    		      temp.val1, temp.val2, press.val1, press.val2,
    		      humidity.val1, humidity.val2);
    
    		k_sleep(K_MSEC(1000));
    	}
    
    	/* triggered runs with its own thread after exit */
    }
    

    sample:
      name: BME280 Sensor sample
    tests:
      sample.sensor.bme280:
        harness: console
        tags: sensors
        platform_allow: nrf5340dk_nrf5340cpuapp adafruit_feather_m0_basic_proto
        harness_config:
            type: one_line
            regex:
                - "temp: (.*); press: (.*); humidity: (.*)"
            fixture: fixture_i2c_bme280
      sample.sensor.bme280.spi:
        harness: console
        tags: sensors
        depends_on: spi bme280
        extra_args: "CONF_FILE=prj_spi.conf"
        harness_config:
            type: one_line
            regex:
                - "temp: (.*); press: (.*); humidity: (.*)"
            fixture: fixture_spi_bme280
            
    sample:
      name: MPU6050 Sensor Sample
    tests:
      sample.sensor.mpu6050:
        build_only: true
        platform_allow: nrf5340dk_nrf5340_cpuapp
        tags: sensors
        integration_platforms:
        - nrf5340dk_nrf5340_cpuapp
        
        
    sample:
      name: Button Sample
    tests:
      sample.basic.button:
        tags: button gpio
        filter: dt_enabled_alias_with_parent_compat("sw0", "gpio-keys")
        depends_on: gpio
        harness: button
    

    pease feel free to correct me
    i'm still learning 
    i'm very thankful in advance 

  • i will put the project below 
    so you can see how it looks like
    commun.zip
    Kindly, help me please

  • Test this project:

    3146.commun.zip

    Build with the board nrf5340dk_nrf5340_cpuapp_ns (not nrf5340dk_nrf5340_cpuappns).

    Best regards,

    Simon

Related