Example of pedometer for LSM6DSL in X-NUCLEO-IKS01A2
Dependencies: X_NUCLEO_IKS01A2 mbed
Fork of Pedometer_IKS01A2 by
Pedometer Demo Application based on sensor expansion board X-NUCLEO-IKS01A2
Main function is to show how to count steps using the sensor expansion board and send a notification using UART to a connected PC or Desktop and display it on terminal applications like TeraTerm.
After connection has been established:
- the user can try to shake the board to simulate the steps and then view the notification using an hyper terminal. When a new step is detected, the LED is switched on for a while.
- the user button can be used to reset the step counter.
Diff: X_NUCLEO_IKS01A2/Components/LSM6DSLSensor/LSM6DSLSensor.h
- Revision:
- 6:153ff83ae370
- Parent:
- 4:b9467a8f2bcc
- Child:
- 7:3c8564ed9986
--- a/X_NUCLEO_IKS01A2/Components/LSM6DSLSensor/LSM6DSLSensor.h Wed Nov 23 15:54:12 2016 +0000
+++ b/X_NUCLEO_IKS01A2/Components/LSM6DSLSensor/LSM6DSLSensor.h Wed Nov 23 16:45:55 2016 +0000
@@ -119,8 +119,8 @@
class LSM6DSLSensor : public MotionSensor, public GyroSensor
{
public:
- LSM6DSLSensor(DevI2C &i2c);
- LSM6DSLSensor(DevI2C &i2c, uint8_t address);
+ LSM6DSLSensor(DevI2C &i2c, PinName INT1_pin, PinName INT2_pin);
+ LSM6DSLSensor(DevI2C &i2c, PinName INT1_pin, PinName INT2_pin, uint8_t address);
virtual int Init(void *init);
virtual int ReadID(uint8_t *id);
virtual int Get_X_Axes(int32_t *pData);
@@ -175,6 +175,66 @@
int WriteReg(uint8_t reg, uint8_t data);
/**
+ * @brief Attaching an interrupt handler to the INT1 interrupt.
+ * @param fptr An interrupt handler.
+ * @retval None.
+ */
+ void AttachINT1IRQ(void (*fptr)(void))
+ {
+ INT1_irq.rise(fptr);
+ }
+
+ /**
+ * @brief Enabling the INT1 interrupt handling.
+ * @param None.
+ * @retval None.
+ */
+ void EnableINT1IRQ(void)
+ {
+ INT1_irq.enable_irq();
+ }
+
+ /**
+ * @brief Disabling the INT1 interrupt handling.
+ * @param None.
+ * @retval None.
+ */
+ void DisableINT1IRQ(void)
+ {
+ INT1_irq.disable_irq();
+ }
+
+ /**
+ * @brief Attaching an interrupt handler to the INT2 interrupt.
+ * @param fptr An interrupt handler.
+ * @retval None.
+ */
+ void AttachINT2IRQ(void (*fptr)(void))
+ {
+ INT2_irq.rise(fptr);
+ }
+
+ /**
+ * @brief Enabling the INT2 interrupt handling.
+ * @param None.
+ * @retval None.
+ */
+ void EnableINT2IRQ(void)
+ {
+ INT2_irq.enable_irq();
+ }
+
+ /**
+ * @brief Disabling the INT2 interrupt handling.
+ * @param None.
+ * @retval None.
+ */
+ void DisableINT2IRQ(void)
+ {
+ INT2_irq.disable_irq();
+ }
+
+ /**
* @brief Utility function to read data.
* @param pBuffer: pointer to data to be read.
* @param RegisterAddr: specifies internal address register to be read.
@@ -206,7 +266,10 @@
/* Helper classes. */
DevI2C &dev_i2c;
-
+
+ InterruptIn INT1_irq;
+ InterruptIn INT2_irq;
+
/* Configuration */
uint8_t address;
