18 #include "fsl_debug_console.h" 20 #include "clock_config.h" 24 #include "fsl_i2c_cmsis.h" 25 #include "fsl_dspi_cmsis.h" 40 #include "event_groups.h" 51 .functionParam = NULL,
55 static void read_task(
void *pvParameters);
56 static void fusion_task(
void *pvParameters);
67 I2Cdrv->PowerControl(ARM_POWER_FULL);
68 I2Cdrv->Control(ARM_I2C_BUS_SPEED, ARM_I2C_BUS_SPEED_FAST);
80 xTaskCreate(read_task,
"READ", configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY + 2, NULL);
81 xTaskCreate(fusion_task,
"FUSION", configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY + 1, NULL);
84 vTaskStartScheduler();
89 static void read_task(
void *pvParameters)
92 portTickType lastWakeTime;
93 const portTickType frequency = 1;
94 lastWakeTime = xTaskGetTickCount();
98 vTaskDelayUntil(&lastWakeTime, frequency);
105 static void fusion_task(
void *pvParameters)
readSensors_t * readSensors
read all physical sensors
This structure defines the device specific info required by register I/O.
initializeFusionEngine_t * initializeFusionEngine
set sensor fusion structures to initial values
Provides function prototypes for driver level interfaces.
EventGroupHandle_t event_group
An instance of PhysicalSensor structure type should be allocated for each physical sensors (combo dev...
setStatus_t * queueStatus
queue status change for next regular interval
int8_t MAG3110_Read(struct PhysicalSensor *sensor, SensorFusionGlobals *sfg)
int8_t MMA8652_Init(struct PhysicalSensor *sensor, SensorFusionGlobals *sfg)
ControlSubsystem controlSubsystem
used for serial communications
StatusSubsystem statusSubsystem
provides visual (usually LED) status indicator
int8_t MAG3110_Init(struct PhysicalSensor *sensor, SensorFusionGlobals *sfg)
Application-specific status subsystem.
conditionSensorReadings_t * conditionSensorReadings
preprocessing step for sensor fusion
Defines control sub-system.
The top level fusion structure.
registerDeviceInfo_t i2cBusInfo
void initSensorFusionGlobals(SensorFusionGlobals *sfg, StatusSubsystem *pStatusSubsystem, ControlSubsystem *pControlSubsystem)
utility function to insert default values in the top level structure
int8_t FXAS21002_Init(struct PhysicalSensor *sensor, SensorFusionGlobals *sfg)
#define I2C_S_SIGNAL_EVENT
The register_io_i2c.h file declares low-level interface functions for reading and writing sensor regi...
he ControlSubsystem encapsulates command and data streaming functions.
#define BOARD_BootClockRUN
int main(void)
This is a FreeRTOS (dual task) implementation of the NXP sensor fusion demo build.
runFusion_t * runFusion
run the fusion routines
#define FXAS21002_I2C_ADDR
Non-recoverable FAULT = something went very wrong.
int8_t MMA8652_Read(struct PhysicalSensor *sensor, SensorFusionGlobals *sfg)
The sensor_fusion.h file implements the top level programming interface.
setStatus_t * setStatus
change status indicator immediately
struct PhysicalSensor sensors[3]
This implementation uses three physical sensors.
uint8_t sUARTOutputBuffer[256]
main output buffer defined in control.c
updateStatus_t * updateStatus
status=next status
installSensor_t * installSensor
function for installing a new sensor into t
struct ControlSubsystem * pControlSubsystem
int8_t initializeControlPort(ControlSubsystem *pComm)
Initialize the control subsystem and all related hardware.
#define I2C_S_DEVICE_INDEX
int8_t FXAS21002_Read(struct PhysicalSensor *sensor, SensorFusionGlobals *sfg)
void BOARD_InitDebugConsole(void)
void initializeStatusSubsystem(StatusSubsystem *pStatus)
SensorFusionGlobals sfg
This is the primary sensor fusion data structure.
void BOARD_InitPins(void)
Configures pin routing and optionally pin electrical features.
streamData_t * stream
function to create packets for serial stream
applyPerturbation_t * applyPerturbation
apply step function for testing purposes
StatusSubsystem() provides an object-like interface for communicating status to the user...
int32_t loopcounter
counter incrementing each iteration of sensor fusion (typically 25Hz)
Provides a simple abstraction for a periodic interval timer.