1 /*
2  * Copyright (c) 2015-2016, Freescale Semiconductor, Inc.
3  * Copyright 2016-2017 NXP
4  * All rights reserved.
5  *
6  * SPDX-License-Identifier: BSD-3-Clause
7  */
8 
9 /**
10  * @file mpl3115_altitude.c
11  * @brief The mpl3115_altitude.c file implements the ISSDK MPL3115 sensor driver
12  *        example demonstration for Altitude mode.
13  */
14 
15 //-----------------------------------------------------------------------
16 // SDK Includes
17 //-----------------------------------------------------------------------
18 #include "pin_mux.h"
19 #include "clock_config.h"
20 #include "board.h"
21 #include "fsl_debug_console.h"
22 
23 //-----------------------------------------------------------------------
24 // CMSIS Includes
25 //-----------------------------------------------------------------------
26 #include "Driver_I2C.h"
27 
28 /* ISSDK Includes */
29 #include "issdk_hal.h"
30 #include "mpl3115_drv.h"
31 
32 //-----------------------------------------------------------------------
33 // Macros
34 //-----------------------------------------------------------------------
35 #define MPL3115_DATA_SIZE (5) /* 3 byte Pressure/Altitude and 2 byte Temperature. */
36 /*! In MPL3115 the Auto Acquisition Time Step (ODR) can be set only in powers of 2 (i.e. 2^x, where x is the
37  *  SAMPLING_EXPONENT).
38  *  This gives a range of 1 second to 2^15 seconds (9 hours). */
39 #define MPL3115_SAMPLING_EXPONENT (1) /* 2 seconds */
40 
41 //-----------------------------------------------------------------------
42 // Constants
43 //-----------------------------------------------------------------------
44 /*! @brief Register settings for Altitude readings in Normal (non buffered) mode. */
45 const registerwritelist_t cMpl3115ConfigAltitude[] = {
46     /* Enable Data Ready and Event flags for Altitude, Temperature or either. */
47     {MPL3115_PT_DATA_CFG,
48      MPL3115_PT_DATA_CFG_TDEFE_ENABLED | MPL3115_PT_DATA_CFG_PDEFE_ENABLED | MPL3115_PT_DATA_CFG_DREM_ENABLED,
49      MPL3115_PT_DATA_CFG_TDEFE_MASK | MPL3115_PT_DATA_CFG_PDEFE_MASK | MPL3115_PT_DATA_CFG_DREM_MASK},
50     /* Enable Altitude output and set Over Sampling Ratio to 128. */
51     {MPL3115_CTRL_REG1, MPL3115_CTRL_REG1_ALT_ALT | MPL3115_CTRL_REG1_OS_OSR_128,
52      MPL3115_CTRL_REG1_ALT_MASK | MPL3115_CTRL_REG1_OS_MASK},
53     /* Set Auto acquisition time step. */
54     {MPL3115_CTRL_REG2, MPL3115_SAMPLING_EXPONENT, MPL3115_CTRL_REG2_ST_MASK},
55     __END_WRITE_DATA__};
56 
57 /*! @brief Address of Status Register. */
58 const registerreadlist_t cMpl3115Status[] = {{.readFrom = MPL3115_STATUS, .numBytes = 1}, __END_READ_DATA__};
59 
60 /*! @brief Address and size of Raw Altitude+Temperature Data in Normal Mode. */
61 const registerreadlist_t cMpl3115OutputNormal[] = {{.readFrom = MPL3115_OUT_P_MSB, .numBytes = MPL3115_DATA_SIZE},
62                                                    __END_READ_DATA__};
63 
64 //-----------------------------------------------------------------------
65 // Functions
66 //-----------------------------------------------------------------------
67 /*!
68  * @brief Main function
69  */
main(void)70 int main(void)
71 {
72     int16_t tempInDegrees;
73     int32_t altitudeInMeters;
74     int32_t status;
75     uint8_t dataReady;
76     uint8_t data[MPL3115_DATA_SIZE];
77     mpl3115_altitudedata_t rawData;
78 
79     ARM_DRIVER_I2C *I2Cdrv = &I2C_S_DRIVER; // Now using the shield.h value!!!
80     mpl3115_i2c_sensorhandle_t mpl3115Driver;
81 
82     BOARD_InitPins();
83     BOARD_BootClockRUN();
84     BOARD_InitDebugConsole();
85 
86     PRINTF("\r\n ISSDK MPL3115 sensor driver example demonstration with poll mode\r\n");
87 
88     /*! Initialize the I2C driver. */
89     status = I2Cdrv->Initialize(I2C_S_SIGNAL_EVENT);
90     if (ARM_DRIVER_OK != status)
91     {
92         PRINTF("\r\n I2C Initialization Failed\r\n");
93         return -1;
94     }
95 
96     /*! Set the I2C Power mode. */
97     status = I2Cdrv->PowerControl(ARM_POWER_FULL);
98     if (ARM_DRIVER_OK != status)
99     {
100         PRINTF("\r\n I2C Power Mode setting Failed\r\n");
101         return -1;
102     }
103 
104     /*! Set the I2C bus speed. */
105     status = I2Cdrv->Control(ARM_I2C_BUS_SPEED, ARM_I2C_BUS_SPEED_FAST);
106     if (ARM_DRIVER_OK != status)
107     {
108         PRINTF("\r\n I2C Control Mode setting Failed\r\n");
109         return -1;
110     }
111 
112     /*! Initialize MPL3115 sensor driver. */
113     status = MPL3115_I2C_Initialize(&mpl3115Driver, &I2C_S_DRIVER, I2C_S_DEVICE_INDEX, MPL3115_I2C_ADDR,
114                                     MPL3115_WHOAMI_VALUE);
115     if (SENSOR_ERROR_NONE != status)
116     {
117         PRINTF("\r\n Sensor Initialization Failed\r\n");
118         return -1;
119     }
120     PRINTF("\r\n Successfully Initiliazed Sensor\r\n");
121 
122     /*!  Set the task to be executed while waiting for I2C transactions to complete. */
123     MPL3115_I2C_SetIdleTask(&mpl3115Driver, (registeridlefunction_t)SMC_SetPowerModeVlpr, SMC);
124 
125     /*! Configure the MPL3115 sensor. */
126     status = MPL3115_I2C_Configure(&mpl3115Driver, cMpl3115ConfigAltitude);
127     if (SENSOR_ERROR_NONE != status)
128     {
129         PRINTF("\r\nMPL3115 configuration failed...\r\n");
130         return -1;
131     }
132     PRINTF("\r\n Successfully Applied MPL3115 Sensor Configuration\r\n");
133 
134     for (;;) /* Forever loop */
135     {
136         /*! Wait for data ready from the MPL3115. */
137         status = MPL3115_I2C_ReadData(&mpl3115Driver, cMpl3115Status, &dataReady);
138         if (0 == (dataReady & MPL3115_DR_STATUS_PTDR_MASK))
139         { /* Loop, if new sample is not available. */
140             continue;
141         }
142 
143         /*! Read new raw sensor data from the MPL3115. */
144         status = MPL3115_I2C_ReadData(&mpl3115Driver, cMpl3115OutputNormal, data);
145         if (ARM_DRIVER_OK != status)
146         {
147             PRINTF("\r\n Read Failed. \r\n");
148             return -1;
149         }
150 
151         /*! Process the sample and convert the raw sensor data. */
152         rawData.altitude = (int32_t)((data[0]) << 24) | ((data[1]) << 16) | ((data[2]) << 8);
153         altitudeInMeters = rawData.altitude / MPL3115_ALTITUDE_CONV_FACTOR;
154 
155         rawData.temperature = (int16_t)((data[3]) << 8) | (data[4]);
156         tempInDegrees = rawData.temperature / MPL3115_TEMPERATURE_CONV_FACTOR;
157 
158         PRINTF("\r\nAltitude    = %d Meters\r\n", altitudeInMeters);
159         PRINTF("\r\nTemperature = %d degC\r\n", tempInDegrees);
160         ASK_USER_TO_RESUME(8); /* Ask for user input after processing 8 samples. */
161     }
162 }
163