1 /*
2  * Copyright 2023 NXP
3  * All rights reserved.
4  *
5  * SPDX-License-Identifier: BSD-3-Clause
6  */
7 
8 /**
9  * @file fxls8971_drv.h
10  * @brief The fxls8971_drv.h file describes the FXLS8974CF driver interface and structures.
11  */
12 
13 #ifndef FXLS8971_DRV_H_
14 #define FXLS8971_DRV_H_
15 
16 /* Standard C Includes */
17 #include <stdint.h>
18 
19 /* ISSDK Includes */
20 #include "fxls8971.h"
21 #include "sensor_io_i2c.h"
22 #include "sensor_io_spi.h"
23 #include "register_io_i2c.h"
24 #include "register_io_spi.h"
25 
26 /*******************************************************************************
27  * Definitions
28  ******************************************************************************/
29 /*!
30  * @brief This defines the sensor specific information for SPI.
31  */
32 typedef struct
33 {
34     registerDeviceInfo_t deviceInfo;      /*!< SPI device context. */
35     ARM_DRIVER_SPI *pCommDrv;             /*!< Pointer to the spi driver. */
36     bool isInitialized;                   /*!< Whether sensor is intialized or not.*/
37     spiSlaveSpecificParams_t slaveParams; /*!< Slave Specific Params.*/
38 } fxls8971_spi_sensorhandle_t;
39 
40 /*!
41  * @brief This defines the sensor specific information for I2C.
42  */
43 typedef struct
44 {
45     registerDeviceInfo_t deviceInfo; /*!< I2C device context. */
46     ARM_DRIVER_I2C *pCommDrv;        /*!< Pointer to the i2c driver. */
47     bool isInitialized;              /*!< whether sensor is intialized or not.*/
48     uint16_t slaveAddress;           /*!< slave address.*/
49 } fxls8971_i2c_sensorhandle_t;
50 
51 /*! @brief This structure defines the fxls8971 raw data buffer.*/
52 typedef struct
53 {
54     uint32_t timestamp; /*! The time, this sample was recorded.  */
55     int16_t accel[3];   /*!< The accel data */
56 } fxls8971_acceldata_t;
57 
58 /*! @def    fxls8971_SPI_MAX_MSG_SIZE
59  *  @brief  The MAX size of SPI message. */
60 #define FXLS8971_SPI_MAX_MSG_SIZE (64)
61 
62 /*! @def    FXLS8971_SPI_CMD_LEN
63  *  @brief  The size of the Sensor specific SPI Header. */
64 #define FXLS8971_SPI_CMD_LEN (2)
65 
66 /*! @def    FXLS8971_SS_ACTIVE_VALUE
67  *  @brief  Is the Slave Select Pin Active Low or High. */
68 #define FXLS8971_SS_ACTIVE_VALUE SPI_SS_ACTIVE_LOW
69 
70 /*******************************************************************************
71  * APIs
72  ******************************************************************************/
73 /*! @brief       The interface function to initialize the sensor.
74  *  @details     This function initialize the sensor and sensor handle.
75  *  @param[in]   pSensorHandle  handle to the sensor.
76  *  @param[in]   pBus           pointer to the CMSIS API compatible I2C bus object.
77  *  @param[in]   index          the I2C device number.
78  *  @param[in]   sAddress       slave address of the device on the bus.
79  *  @param[in]   whoami         WHO_AM_I value of the device.
80  *  @constraints This should be the first API to be called.
81  *               Application has to ensure that previous instances of these APIs have exited before invocation.
82  *  @reeentrant  No
83  *  @return      ::FXLS8971_I2C_Initialize() returns the status .
84  */
85 int32_t FXLS8971_I2C_Initialize(
86     fxls8971_i2c_sensorhandle_t *pSensorHandle, ARM_DRIVER_I2C *pBus, uint8_t index, uint16_t sAddress, uint8_t *whoAmi);
87 
88 /*! @brief      :  The interface function to set the I2C Idle Task.
89  *  @param[in]  :  fxls8971_i2c_sensorhandle_t *pSensorHandle, handle to the sensor handle.
90  *  @param[in]  :  registeridlefunction_t idleTask, function pointer to the function to execute on I2C Idle Time.
91  *  @param[in]  :  void *userParam, the pointer to the user idle ftask parameters.
92  *  @return        void.
93  *  @constraints   This can be called any number of times only after FXLS8971_I2C_Initialize().
94  *                 Application has to ensure that previous instances of these APIs have exited before invocation.
95  *  @reeentrant    No
96  */
97 void FXLS8971_I2C_SetIdleTask(fxls8971_i2c_sensorhandle_t *pSensorHandle,
98                               registeridlefunction_t idleTask,
99                               void *userParam);
100 
101 /*! @brief       The interface function to configure he sensor.
102  *  @details     This function configure the sensor with requested ODR, Range and registers in the regsiter pair array.
103  *  @param[in]   pSensorHandle handle to the sensor.
104  *  @param[in]   pRegWriteList pointer to the register list.
105  *  @constraints This can be called any number of times only after FXLS8971_I2C_Initialize().
106  *               Application has to ensure that previous instances of these APIs have exited before invocation.
107  *  @reeentrant  No
108  *  @return      ::FXLS8971_I2C_Configure() returns the status .
109  */
110 int32_t FXLS8971_I2C_Configure(fxls8971_i2c_sensorhandle_t *pSensorHandle, const registerwritelist_t *pRegWriteList);
111 
112 /*! @brief       The interface function to read the sensor data.
113  *  @details     This function read the sensor data out from the device and returns raw data in a byte stream.
114  *  @param[in]   pSensorHandle handle to the sensor.
115  *  @param[in]   pReadList     pointer to the list of device registers and values to read.
116  *  @param[out]  pBuffer       buffer which holds raw sensor data.This buffer may be back to back databuffer based
117  *                             command read in the list.
118  *  @constraints This can be called any number of times only after FXLS8971_I2C_Initialize().
119  *               Application has to ensure that previous instances of these APIs have exited before invocation.
120  *  @reeentrant  No
121  *  @return      ::FXLS8971_I2C_ReadData() returns the status .
122  */
123 int32_t FXLS8971_I2C_ReadData(fxls8971_i2c_sensorhandle_t *pSensorHandle,
124                               const registerreadlist_t *pReadList,
125                               uint8_t *pBuffer);
126 
127 /*! @brief       The interface function to De Initialize sensor..
128  *  @details     This function made sensor in a power safe state and de initialize its handle.
129  *  @param[in]   pSensorHandle handle to the sensor.
130  *  @constraints This can be called only after FXLS8971_I2C_Initialize().
131  *               Application has to ensure that previous instances of these APIs have exited before invocation.
132  *  @reeentrant  No
133  *  @return      ::FXLS8971_I2C_DeInit() returns the status .
134  */
135 int32_t FXLS8971_I2C_DeInit(fxls8971_i2c_sensorhandle_t *pSensorHandle);
136 
137 /*! @brief       The interface function to initialize the sensor.
138  *  @details     This function initializes the sensor and sensor handle.
139  *  @param[in]   pSensorHandle handle to the sensor.
140  *  @param[in]   pBus          pointer to the CMSIS API compatible SPI bus object.
141  *  @param[in]   index         the I2C device number.
142  *  @param[in]   pSlaveSelect  slave select hndle of the device on the bus.
143  *  @param[in]   whoami        WHO_AM_I value of the device.
144  *  @constraints This should be the first API to be called.
145  *               Application has to ensure that previous instances of these APIs have exited before invocation.
146  *  @reeentrant  No
147  *  @return      ::FXLS8971_SPI_Initialize() returns the status .
148  */
149 int32_t FXLS8971_SPI_Initialize(fxls8971_spi_sensorhandle_t *pSensorHandle,
150                                 ARM_DRIVER_SPI *pBus,
151                                 uint8_t index,
152                                 void *pSlaveSelect,
153                                 uint8_t *whoAmi);
154 
155 /*! @brief      :  The interface function to set the SPI Idle Task.
156  *  @param[in]  :  fxls8971_spi_sensorhandle_t *pSensorHandle, handle to the sensor handle.
157  *  @param[in]  :  registeridlefunction_t idleTask, function pointer to the function to execute on SPI Idle Time.
158  *  @param[in]  :  void *userParam, the pointer to the user idle ftask parameters.
159  *  @return        void.
160  *  @constraints   This can be called any number of times only after FXLS8971_SPI_Initialize().
161  *                 Application has to ensure that previous instances of these APIs have exited before invocation.
162  *  @reeentrant    No
163  */
164 void FXLS8971_SPI_SetIdleTask(fxls8971_spi_sensorhandle_t *pSensorHandle,
165                               registeridlefunction_t idleTask,
166                               void *userParam);
167 
168 /*! @brief       The interface function to configure he sensor.
169  *  @details     This function configure the sensor with requested ODR, Range and registers in the regsiter pair array.
170  *  @param[in]   pSensorHandle handle to the sensor.
171  *  @param[in]   pRegWriteList pointer to the register list.
172  *  @constraints This can be called any number of times only after FXLS8971_SPI_Initialize().
173  *               Application has to ensure that previous instances of these APIs have exited before invocation.
174  *  @reeentrant  No
175  *  @return      ::FXLS8971_SPI_Configure() returns the status .
176  */
177 int32_t FXLS8971_SPI_Configure(fxls8971_spi_sensorhandle_t *pSensorHandle, const registerwritelist_t *pRegWriteList);
178 
179 /*! @brief       The interface function to read the sensor data.
180  *  @details     This function read the sensor data out from the device and returns raw data in a byte stream.
181  *  @param[in]   pSensorHandle handle to the sensor.
182  *  @param[in]   pReadList     pointer to the list of device registers and values to read.
183  *  @param[out]  pBuffer       buffer which holds raw sensor data.This buffer may be back to back databuffer based
184  *               command read in the list.
185  *  @constraints This can be called any number of times only after FXLS8971_SPI_Initialize().
186  *               Application has to ensure that previous instances of these APIs have exited before invocation.
187  *  @reeentrant  No
188  *  @return      ::FXLS8971_SPI_ReadData() returns the status .
189  */
190 int32_t FXLS8971_SPI_ReadData(fxls8971_spi_sensorhandle_t *pSensorHandle,
191                               const registerreadlist_t *pReadList,
192                               uint8_t *pBuffer);
193 
194 /*! @brief       The interface function to De Initialize sensor..
195  *  @details     This function made sensor in a power safe state and de initialize its handle.
196  *  @param[in]   pSensorHandle      handle to the sensor.
197  *  @constraints This can be called only after after FXLS8971_SPI_Initialize().
198  *               Application has to ensure that previous instances of these APIs have exited before invocation.
199  *  @reeentrant  No
200  *  @return      ::FXLS8971_SPI_Deinit() returns the status .
201  */
202 int32_t FXLS8971_SPI_Deinit(fxls8971_spi_sensorhandle_t *pSensorHandle);
203 
204 /*! @brief       The SPI Read Pre-Process function to generate Sensor specific SPI Message Header.
205  *  @details     This function prepares the SPI Read Command Header with register address and
206  *               R/W bit encoded as the Sensor.
207  *  @param[out]  pCmdOut  handle to the output buffer.
208  *  @param[in]   offset   the address of the register to start reading from.
209  *  @param[in]   size     number of bytes to read.
210  *  @constraints None
211  *               Application has to ensure that previous instances of these APIs have exited before invocation.
212  *  @reeentrant  No
213  *  @return      :: None.
214  */
215 void FXLS8971_SPI_ReadPreprocess(void *pCmdOut, uint32_t offset, uint32_t size);
216 
217 /*! @brief       The SPI Write Pre-Process function to generate Sensor specific SPI Message Header.
218  *  @details     This function prepares the SPI Write Command Header with register address and
219  *               R/W bit encoded as the Sensor.
220  *  @param[out]  pCmdOut  handle to the output buffer.
221  *  @param[in]   offset   the address of the register to start writing from.
222  *  @param[in]   size     number of bytes to write.
223  *  @constraints None
224  *               Application has to ensure that previous instances of these APIs have exited before invocation.
225  *  @reeentrant  No
226  *  @return      :: None.
227  */
228 void FXLS8971_SPI_WritePreprocess(void *pCmdOut, uint32_t offset, uint32_t size, void *pWritebuffer);
229 
230 #endif // FXLS8971_DRV_H_
231