2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file mpu_util.h
|
|
|
|
*
|
|
|
|
* @date Jul 27, 2014
|
2017-01-03 03:05:22 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2017
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
#ifndef MPU_UTIL_H_
|
|
|
|
#define MPU_UTIL_H_
|
|
|
|
|
2017-02-14 15:02:36 -08:00
|
|
|
#include "stm32f4xx_hal_flash_ex.h"
|
|
|
|
|
|
|
|
typedef enum {
|
2017-02-14 18:01:56 -08:00
|
|
|
BOR_Level_None = OB_BOR_OFF, // 0x0C=12 Supply voltage ranges from 1.62 to 2.10 V
|
|
|
|
BOR_Level_1 = OB_BOR_LEVEL1, // 0x08 Supply voltage ranges from 2.10 to 2.40 V
|
|
|
|
BOR_Level_2 = OB_BOR_LEVEL2, // 0x04 Supply voltage ranges from 2.40 to 2.70 V
|
|
|
|
BOR_Level_3 = OB_BOR_LEVEL3 // 0x00 Supply voltage ranges from 2.70 to 3.60 V
|
2017-02-14 15:02:36 -08:00
|
|
|
} BOR_Level_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
BOR_Result_Ok = 0x00,
|
|
|
|
BOR_Result_Error
|
|
|
|
} BOR_Result_t;
|
|
|
|
|
|
|
|
BOR_Level_t BOR_Get(void);
|
2017-02-14 18:01:56 -08:00
|
|
|
BOR_Result_t BOR_Set(BOR_Level_t BORValue);
|
2017-02-14 15:02:36 -08:00
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
#ifndef GPIO_AF_TIM1
|
|
|
|
#define GPIO_AF_TIM1 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef GPIO_AF_TIM2
|
|
|
|
#define GPIO_AF_TIM2 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef GPIO_AF_TIM3
|
|
|
|
#define GPIO_AF_TIM3 2
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef GPIO_AF_TIM4
|
|
|
|
#define GPIO_AF_TIM4 2
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef GPIO_AF_TIM5
|
|
|
|
#define GPIO_AF_TIM5 2
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef GPIO_AF_TIM9
|
|
|
|
#define GPIO_AF_TIM9 3
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ADC_TwoSamplingDelay_5Cycles
|
|
|
|
#define ADC_TwoSamplingDelay_5Cycles ((uint32_t)0x00000000)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ADC_TwoSamplingDelay_20Cycles
|
|
|
|
#define ADC_TwoSamplingDelay_20Cycles ((uint32_t)0x00000F00)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ADC_CR2_SWSTART
|
|
|
|
#define ADC_CR2_SWSTART ((uint32_t)0x40000000)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void baseHardwareInit(void);
|
|
|
|
void turnOnSpi(spi_device_e device);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
// these need to be declared C style for the linker magic to work
|
|
|
|
|
|
|
|
void DebugMonitorVector(void);
|
|
|
|
void UsageFaultVector(void);
|
|
|
|
void BusFaultVector(void);
|
|
|
|
void HardFaultVector(void);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
#endif /* MPU_UTIL_H_ */
|
2015-07-12 19:03:34 -07:00
|
|
|
|
|
|
|
void initSpiModule(SPIDriver *driver, brain_pin_e sck, brain_pin_e miso,
|
|
|
|
brain_pin_e mosi,
|
|
|
|
int sckMode,
|
|
|
|
int mosiMode,
|
|
|
|
int misoMode);
|
|
|
|
void initSpiCs(SPIConfig *spiConfig, brain_pin_e csPin);
|
2017-04-12 06:17:06 -07:00
|
|
|
|
|
|
|
bool isValidCanTxPin(brain_pin_e pin);
|
|
|
|
bool isValidCanRxPin(brain_pin_e pin);
|
|
|
|
CANDriver * detectCanDevice(brain_pin_e pinRx, brain_pin_e pinTx);
|