ST / X_NUCLEO_6180XA1

Dependencies:   X_NUCLEO_COMMON ST_INTERFACES

Dependents:   HelloWorld_6180XA1 SunTracker_BLE Servo_6180XA1 BLE_HR_Light ... more

Fork of X_NUCLEO_6180XA1 by ST Expansion SW Team

X-NUCLEO-6180XA1 Proximity and Ambient Light Sensor Expansion Board Firmware Package

Introduction

This firmware package includes Components Device Drivers and Board Support Package for STMicroelectronics' X-NUCLEO-6180XA1 Proximity and ambient light sensor expansion board based on VL6180X.

Firmware Library

Class X_NUCLEO_6180XA1 is intended to represent the Proximity and ambient light sensor expansion board with the same name.

The expansion board is providing the support of the following components:

  1. on-board VL6180X proximity and ambient light sensor,
  2. up to three additional VL6180X Satellites,
  3. on-board 4-digit display

It is intentionally implemented as a singleton because only one X-NUCLEO-VL6180XA1 at a time might be deployed in a HW component stack. In order to get the singleton instance you have to call class method `Instance()`, e.g.:

// Sensors expansion board singleton instance
static X_NUCLEO_6180XA1 *6180X_expansion_board = X_NUCLEO_6180XA1::Instance();

Arduino Connector Compatibility Warning

Using the X-NUCLEO-6180XA1 expansion board with the NUCLEO-F429ZI requires adopting the following patch:

  • to remove R46 resistor connected to A3 pin;
  • to solder R47 resistor connected to A5 pin.

Alternatively, you can route the Nucleo board’s A5 pin directly to the expansion board’s A3 pin with a wire. In case you patch your expansion board or route the pin, the interrupt signal for the front sensor will be driven on A5 pin rather than on A3 pin.


Example Applications

Revision:
16:0d4776564733
Parent:
15:454710d17358
Child:
20:dd8390d615bf
--- a/x_nucleo_6180xa1.cpp	Tue Oct 20 16:44:28 2015 +0200
+++ b/x_nucleo_6180xa1.cpp	Tue Oct 27 15:25:11 2015 +0100
@@ -45,82 +45,82 @@
 
 X_NUCLEO_6180XA1* X_NUCLEO_6180XA1::Instance(DevI2C *ext_i2c)
 {
-	if(_instance==NULL)
-	   _instance=new X_NUCLEO_6180XA1(ext_i2c);
-	else
-	   VL6180x_ErrLog("Failed to init X_NUCLEO_6180XA1 board!\n");
-	return _instance;
+   if(_instance==NULL)
+      _instance=new X_NUCLEO_6180XA1(ext_i2c);
+   else
+      VL6180x_ErrLog("Failed to init X_NUCLEO_6180XA1 board!\n");
+   return _instance;
 }
 
 
 int X_NUCLEO_6180XA1::InitBoard() //FIXME sistemare le stampe degli errori
 {	
-	int status, n_dev=0;
+   int status, n_dev=0;
 	
-	sensor_top->VL6180x_Off();
-	sensor_bottom->VL6180x_Off();
-	sensor_left->VL6180x_Off();
-	sensor_right->VL6180x_Off();
-	status=sensor_top->InitSensor(NEW_SENSOR_TOP_ADDRESS);
-	if(status)
-	{
-	   delete sensor_top;
-		 delete gpio0_top;
-		 sensor_top=NULL;
- 		 gpio0_top=NULL;
-		 //VL6180x_ErrLog("Fail to init sensor_top\n\r");
-		 printf("Failure to init sensor_top\n\r");
-	}
-	else
-	{
-		 n_dev++;
-	}
-	status=sensor_bottom->InitSensor(NEW_SENSOR_BOTTOM_ADDRESS);
-	if(status)
-	{
-	   delete sensor_bottom;
-		 delete gpio0_bottom;
-		 sensor_bottom=NULL;
- 		 gpio0_bottom=NULL;
-		 //VL6180x_ErrLog("Fail to init sensor_bottom\n\r");
-		 printf("Failed to init sensor_bottom\n\r");
-	}
-	else
-	{
-		 n_dev++;
-	}
-	status=sensor_left->InitSensor(NEW_SENSOR_LEFT_ADDRESS);
-	if(status)
-	{
-	   delete sensor_left;
-		 delete gpio0_left;
-		 sensor_left=NULL;
- 		 gpio0_left=NULL;
-		 //VL6180x_ErrLog("Fail to init sensor_left\n\r");
-		 printf("Failed to init sensor_left\n\r");
-	}
-	else
-	{
-		 n_dev++;
-	}
-	status=sensor_right->InitSensor(NEW_SENSOR_RIGHT_ADDRESS);
-	if(status)
-	{
-	   delete sensor_right;
-		 delete gpio0_right;
-		 sensor_right=NULL;
- 		 gpio0_right=NULL;
-		 //VL6180x_ErrLog("Fail to init sensor_right\n\r");
-		 printf("Failed to init sensor_right\n\r");
-	}
-	else
-	{
-		 n_dev++;
-	}
-	if(n_dev==0)
-		 return 1;
-	else
-		 return 0;
+   sensor_top->VL6180x_Off();
+   sensor_bottom->VL6180x_Off();
+   sensor_left->VL6180x_Off();
+   sensor_right->VL6180x_Off();
+   status=sensor_top->InitSensor(NEW_SENSOR_TOP_ADDRESS);
+   if(status)
+   {
+      delete sensor_top;
+      delete gpio0_top;
+      sensor_top=NULL;
+      gpio0_top=NULL;
+      //VL6180x_ErrLog("Failed to init sensor_top\n\r");
+      printf("Failed to init sensor_top\n\r");
+   }
+   else
+   {
+      n_dev++;
+   }
+   status=sensor_bottom->InitSensor(NEW_SENSOR_BOTTOM_ADDRESS);
+   if(status)
+   {
+      delete sensor_bottom;
+      delete gpio0_bottom;
+      sensor_bottom=NULL;
+      gpio0_bottom=NULL;
+      //VL6180x_ErrLog("Failed to init sensor_bottom\n\r");
+      printf("Failed to init sensor_bottom\n\r");
+   }
+   else
+   {
+      n_dev++;
+   }
+   status=sensor_left->InitSensor(NEW_SENSOR_LEFT_ADDRESS);
+   if(status)
+   {
+      delete sensor_left;
+      delete gpio0_left;
+      sensor_left=NULL;
+      gpio0_left=NULL;
+      //VL6180x_ErrLog("Failed to init sensor_left\n\r");
+      printf("Failed to init sensor_left\n\r");
+   }
+   else
+   {
+      n_dev++;
+   }
+   status=sensor_right->InitSensor(NEW_SENSOR_RIGHT_ADDRESS);
+   if(status)
+   {
+      delete sensor_right;
+      delete gpio0_right;
+      sensor_right=NULL;
+       gpio0_right=NULL;
+      //VL6180x_ErrLog("Failed to init sensor_right\n\r");
+      printf("Failed to init sensor_right\n\r");
+   }
+   else
+   {
+      n_dev++;
+   }
+   if(n_dev==0)
+      return 1;
+   else
+      return 0;
 }