2022-10-20 17:13:02 +08:00
|
|
|
#ifndef BSP_CAN_H
|
|
|
|
#define BSP_CAN_H
|
|
|
|
|
2022-11-19 15:40:38 +08:00
|
|
|
#include <stdint-gcc.h>
|
2022-10-20 17:13:02 +08:00
|
|
|
#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-11-28 16:17:30 +08:00
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
/* can instance typedef, every module registered to CAN should have this variable */
|
2022-11-28 16:17:30 +08:00
|
|
|
#pragma pack(1)
|
2022-10-30 22:19:13 +08:00
|
|
|
typedef struct _
|
2022-10-20 17:13:02 +08:00
|
|
|
{
|
2022-11-12 12:39:36 +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-11-12 12:39:36 +08:00
|
|
|
uint8_t tx_buff[8];
|
2022-10-29 23:14:19 +08:00
|
|
|
uint8_t rx_buff[8];
|
2022-10-20 17:13:02 +08:00
|
|
|
uint32_t rx_id;
|
2022-11-27 23:06:45 +08:00
|
|
|
uint8_t rx_len;
|
2022-11-12 12:39:36 +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-11-28 16:17:30 +08:00
|
|
|
#pragma pack()
|
2022-10-20 17:13:02 +08:00
|
|
|
|
2022-10-30 22:19:13 +08:00
|
|
|
/* this structure is used as initialization*/
|
2022-11-12 12:39:36 +08:00
|
|
|
typedef struct
|
2022-10-30 22:19:13 +08:00
|
|
|
{
|
2022-11-12 12:39:36 +08:00
|
|
|
CAN_HandleTypeDef *can_handle;
|
2022-10-30 22:19:13 +08:00
|
|
|
uint32_t tx_id;
|
|
|
|
uint32_t rx_id;
|
2022-11-12 12:39:36 +08:00
|
|
|
void (*can_module_callback)(can_instance *);
|
|
|
|
} can_instance_config_s;
|
2022-10-30 22:19:13 +08:00
|
|
|
|
2022-11-28 16:17:30 +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
|
2022-11-12 12:39:36 +08:00
|
|
|
*
|
2022-10-20 17:13:02 +08:00
|
|
|
* @param _instance can instance owned by module
|
|
|
|
*/
|
2022-11-12 12:39:36 +08:00
|
|
|
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-11-12 12:39:36 +08:00
|
|
|
*
|
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-11-28 17:54:07 +08:00
|
|
|
can_instance* CANRegister(can_instance_config_s *config);
|
2022-10-20 17:13:02 +08:00
|
|
|
|
2022-11-27 23:06:45 +08:00
|
|
|
/**
|
|
|
|
* @brief 修改CAN发送报文的数据帧长度;注意最大长度为8,在没有进行修改的时候,默认长度为8
|
2022-11-28 16:17:30 +08:00
|
|
|
*
|
2022-11-27 23:06:45 +08:00
|
|
|
* @param _instance 要修改长度的can实例
|
|
|
|
* @param length 设定长度
|
|
|
|
*/
|
2022-11-28 16:17:30 +08:00
|
|
|
void CANSetDLC(can_instance *_instance, uint8_t length);
|
2022-11-27 23:06:45 +08:00
|
|
|
|
2022-10-20 17:13:02 +08:00
|
|
|
#endif
|