2022-10-20 17:13:02 +08:00
|
|
|
#ifndef BSP_CAN_H
|
|
|
|
#define BSP_CAN_H
|
|
|
|
|
|
|
|
#include "struct_typedef.h"
|
|
|
|
#include "can.h"
|
|
|
|
|
|
|
|
#define MX_REGISTER_DEVICE_CNT 12 // maximum number of device can be registered to CAN service
|
|
|
|
// this number depends on the load of CAN bus.
|
2022-11-11 21:00:02 +08:00
|
|
|
#define MX_CAN_FILTER_CNT (2 * 14) // temporarily useless
|
2022-10-20 17:13:02 +08:00
|
|
|
#define DEVICE_CAN_CNT 2 // CAN1,CAN2
|
|
|
|
|
2022-10-30 22:19:13 +08:00
|
|
|
|
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
/* can instance typedef, every module registered to CAN should have this variable */
|
2022-10-30 22:19:13 +08:00
|
|
|
typedef struct _
|
2022-10-20 17:13:02 +08:00
|
|
|
{
|
|
|
|
CAN_HandleTypeDef* can_handle;
|
2022-10-30 22:19:13 +08:00
|
|
|
CAN_TxHeaderTypeDef txconf;
|
2022-10-20 17:13:02 +08:00
|
|
|
uint32_t tx_id;
|
|
|
|
uint32_t tx_mailbox;
|
2022-10-29 23:14:19 +08:00
|
|
|
uint8_t tx_buff[8];
|
|
|
|
uint8_t rx_buff[8];
|
2022-10-20 17:13:02 +08:00
|
|
|
uint32_t rx_id;
|
2022-10-30 22:19:13 +08:00
|
|
|
void (*can_module_callback)(struct _*); // callback needs an instance to tell among registered ones
|
2022-10-20 17:13:02 +08:00
|
|
|
} can_instance;
|
|
|
|
|
2022-10-30 22:19:13 +08:00
|
|
|
|
|
|
|
/* this structure is used as initialization*/
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
CAN_HandleTypeDef* can_handle;
|
|
|
|
uint32_t tx_id;
|
|
|
|
uint32_t rx_id;
|
|
|
|
void (*can_module_callback)(can_instance*);
|
|
|
|
} can_instance_config;
|
|
|
|
|
2022-10-20 21:38:48 +08:00
|
|
|
/* module callback,which resolve protocol when new mesg arrives*/
|
|
|
|
typedef void (*can_callback)(can_instance*);
|
|
|
|
|
2022-10-30 22:19:13 +08:00
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
/**
|
|
|
|
* @brief transmit mesg through CAN device
|
|
|
|
*
|
|
|
|
* @param _instance can instance owned by module
|
|
|
|
*/
|
|
|
|
void CANTransmit(can_instance* _instance);
|
|
|
|
|
2022-10-30 22:19:13 +08:00
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
/**
|
|
|
|
* @brief Register a module to CAN service,remember to call this before using a CAN device
|
|
|
|
*
|
2022-10-30 22:19:13 +08:00
|
|
|
* @param config init config
|
|
|
|
* @return can_instance* can instance owned by module
|
2022-10-20 17:13:02 +08:00
|
|
|
*/
|
2022-10-31 20:20:16 +08:00
|
|
|
void CANRegister(can_instance* instance, can_instance_config config);
|
2022-10-20 17:13:02 +08:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|