46 #include "clock_config.h" 51 #include "Driver_I2C.h" 52 #include "Driver_USART.h" 57 #include "issdk_hal.h" 58 #include "gpio_driver.h" 62 #include "auto_detection_service.h" 67 #define FXAS21002_STREAM_DATA_SIZE 12 70 #define APPLICATION_NAME "FXAS21002 Gyroscope Demo" 72 #define APPLICATION_VERSION "2.5" 74 #define SKIP_PACKET_COUNT 5 134 uint8_t tag, uint8_t *hostCommand, uint8_t *hostResponse,
size_t *hostMsgSize,
size_t respBufferSize)
136 bool success =
false;
151 if (respBufferSize >= boardNameLen + shieldNameLen + appNameLen + 3)
160 hostResponse[*hostMsgSize] = appNameLen;
163 memcpy(hostResponse + *hostMsgSize,
embAppName, appNameLen);
164 *hostMsgSize += appNameLen;
166 hostResponse[*hostMsgSize] = boardNameLen;
169 memcpy(hostResponse + *hostMsgSize,
boardString, boardNameLen);
170 *hostMsgSize += boardNameLen;
172 hostResponse[*hostMsgSize] = shieldNameLen;
175 memcpy(hostResponse + *hostMsgSize,
shieldString, shieldNameLen);
176 *hostMsgSize += shieldNameLen;
186 switch (hostCommand[0])
249 if (ARM_DRIVER_OK != status)
255 status = pI2Cdriver->PowerControl(ARM_POWER_FULL);
256 if (ARM_DRIVER_OK != status)
262 status = pI2Cdriver->Control(ARM_I2C_BUS_SPEED, ARM_I2C_BUS_SPEED_FAST);
263 if (ARM_DRIVER_OK != status)
270 if (ARM_DRIVER_OK != status)
276 status = pUartDriver->PowerControl(ARM_POWER_FULL);
277 if (ARM_DRIVER_OK != status)
284 if (ARM_DRIVER_OK != status)
340 if (ARM_DRIVER_OK != status)
347 if (ARM_DRIVER_OK != status)
353 if (ARM_DRIVER_OK != status)
362 rawData.
gyro[0] = ((int16_t)data[0] << 8) | data[1];
363 rawData.
gyro[1] = ((int16_t)data[2] << 8) | data[3];
364 rawData.
gyro[2] = ((int16_t)data[4] << 8) | data[5];
365 rawData.
temp = tempOut;
uint32_t BOARD_SystickElapsedTime_us(int32_t *pStart)
Function to compute the Elapsed Time.
#define FXAS21002_CTRL_REG2_INT_EN_DRDY_MASK
#define FXAS21002_CTRL_REG2_INT_CFG_DRDY_INT1
#define FXAS21002_CTRL_REG2_INT_EN_RT_ENABLE
#define FXAS21002_CTRL_REG2_IPOL_MASK
#define __END_WRITE_DATA__
#define HOST_PRO_CMD_W_CFG_TAG
GENERIC_DRIVER_GPIO * pGpioDriver
#define HOST_S_SIGNAL_EVENT
void Host_IO_Receive(host_cmd_proc_fn_t process_host_command, uint8_t encoding)
void(* pin_init)(pinID_t aPinId, gpio_direction_t dir, void *apPinConfig, gpio_isr_handler_t aIsrHandler, void *apUserData)
#define BOARD_BootClockRUN
#define FXAS21002_CTRL_REG1_DR_MASK
#define SKIP_PACKET_COUNT
volatile bool bFxas21002DataReady
uint8_t data[FXLS8962_DATA_SIZE]
#define APPLICATION_VERSION
Version to distinguish between instances the same application based on target Shield and updates...
#define FXAS21002_CTRL_REG2_INT_EN_DRDY_ENABLE
void(* toggle_pin)(pinID_t aPinId)
void fxas21002_int_data_ready_callback(void *pUserData)
char shieldString[ADS_MAX_STRING_LENGTH]
#define FXAS21002_STREAM_DATA_SIZE
#define ADS_MAX_STRING_LENGTH
#define HOST_PRO_INT_DEV_TAG
uint8_t streamingPacket[STREAMING_HEADER_LEN+FXLS8962_STREAM_DATA_SIZE]
void(* registeridlefunction_t)(void *userParam)
This is the register idle function type.
The fxas21002_drv.h file describes the fxas21002 driver interface and structures. ...
#define HOST_PRO_INT_CMD_TAG
Bit aligned values for Host Protocol Interface IDs (Bits 5-6).
#define __END_READ_DATA__
volatile bool bStreamingEnabled
const registerreadlist_t fxas21002_Reg[]
#define FXAS21002_CTRL_REG2_INT_CFG_DRDY_MASK
#define APPLICATION_NAME
Unique Name for this application which should match the target GUI pkg name.
gpioHandleKSDK_t GREEN_LED
volatile uint8_t bSkipPacket
This defines the sensor specific information for I2C.
volatile bool bFxas21002Ready
char embAppName[ADS_MAX_STRING_LENGTH]
void Host_IO_Add_ISO_Header(uint8_t streamID, uint8_t *pStreamingPacket, size_t sizePayload)
void Host_IO_Send(uint8_t *pMsg, size_t size, uint8_t encoding)
void(* clr_pin)(pinID_t aPinId)
int32_t FXAS21002_I2C_ReadData(fxas21002_i2c_sensorhandle_t *pSensorHandle, const registerreadlist_t *pReadList, uint8_t *pBuffer)
The interface function to read the sensor data.
void BOARD_SystickEnable(void)
Function to enable systicks framework.
#define I2C_S_DEVICE_INDEX
#define FXAS21002_WHO_AM_I_WHOAMI_PROD_VALUE
#define FXAS21002_I2C_ADDR
int32_t FXAS21002_I2C_Configure(fxas21002_i2c_sensorhandle_t *pSensorHandle, const registerwritelist_t *pRegWriteList)
The interface function to configure he sensor.
GENERIC_DRIVER_GPIO Driver_GPIO_KSDK
void FXAS21002_I2C_SetIdleTask(fxas21002_i2c_sensorhandle_t *pSensorHandle, registeridlefunction_t idleTask, void *userParam)
: The interface function to set the I2C Idle Task.
#define FXAS21002_CTRL_REG2_INT_EN_RT_MASK
#define BOARD_DEBUG_UART_BAUDRATE
const registerreadlist_t fxas21002_Temp[]
Access structure of the GPIO Driver.
void BOARD_SystickStart(int32_t *pStart)
Function to Record the Start systick.
void BOARD_RunADS(const char *appName, char *boardString, char *shieldString, size_t bufferLength)
The function to register Application Name and initialte ADS.
fxls8962_acceldataUser_t rawData
int main(void)
Main function.
uint8_t Host_IO_Init(ARM_DRIVER_USART *pDrv, void *pBus, void *pDevInfo, void *spiSlaveParams, uint16_t slaveAddress)
This structure defines the fxas21002 raw data buffer.
This structure defines the Write command List.
const registerwritelist_t fxas21002_Config_Isr[]
This structure defines the Read command List.
The host_io_uart.h file contains the Host Protocol interface definitions and configuration.
#define STREAMING_HEADER_LEN
#define FXAS21002_GYRO_DATA_SIZE
The size of the FXAS21002 gyro data.
status_t SMC_SetPowerModeWait(void *arg)
Configures the system to WAIT power mode. API name used from Kinetis family to maintain compatibility...
#define FXAS21002_CTRL_REG2_IPOL_ACTIVE_HIGH
bool process_host_command(uint8_t tag, uint8_t *hostCommand, uint8_t *hostResponse, size_t *hostMsgSize, size_t respBufferSize)
#define FXAS21002_CTRL_REG1_DR_12_5HZ
#define I2C_S_SIGNAL_EVENT
const registerreadlist_t fxas21002_Output_Values[]
int32_t FXAS21002_I2C_Initialize(fxas21002_i2c_sensorhandle_t *pSensorHandle, ARM_DRIVER_I2C *pBus, uint8_t index, uint16_t sAddress, uint8_t whoAmi)
The interface function to initialize the sensor.
ARM_DRIVER_I2C * pCommDrv
char boardString[ADS_MAX_STRING_LENGTH]
registerDeviceInfo_t deviceInfo