canbus adding filters
This commit is contained in:
@ -139,9 +139,9 @@ BOOL ANPO_boInitializeModule( VOID )
|
||||
BOOL ANPO_boSetVoltage( FLOAT Voltage ){
|
||||
BOOL boOK = TRUE;
|
||||
|
||||
U32 RawData = u32ConvertVoltagetoRaw( Voltage );
|
||||
U32 u32RawData = u32ConvertVoltagetoRaw( Voltage );
|
||||
|
||||
boOK &= HAL_DAC_SetValue( &hdac1, DAC_CHANNEL_1, DAC_ALIGN_12B_R, RawDatab );
|
||||
boOK &= HAL_DAC_SetValue( &hdac1, DAC_CHANNEL_1, DAC_ALIGN_12B_R, u32RawData );
|
||||
|
||||
return( boOK );
|
||||
}
|
||||
|
@ -7,7 +7,7 @@
|
||||
//-------------------------------------------------------------------------------------------------
|
||||
//
|
||||
// Project: Peltier Controller V2
|
||||
// Author: Noah Piqu<EFBFBD> (noah.pique@psi.ch)
|
||||
// Author: Noah Piqué (noah.pique@psi.ch)
|
||||
//
|
||||
//-------------------------------------------------------------------------------------------------
|
||||
//
|
||||
@ -36,6 +36,9 @@
|
||||
// Toolbox
|
||||
#include "../Toolbox/UTIL_Utility.h"
|
||||
|
||||
// Driver
|
||||
#include "DIPO_DigitalPorts.h"
|
||||
|
||||
// include STM32 drivers
|
||||
#include "stm32l4xx_hal.h"
|
||||
|
||||
@ -46,7 +49,11 @@
|
||||
// Description: Definition of local constants (visible by this module only).
|
||||
//=================================================================================================
|
||||
|
||||
#define CAND_SHIFT 0x0 // Shift address space (0-3)
|
||||
#define CAND_BOARD_GROUP 0x03 // Board group (0-127 / 0x00-0x7F)
|
||||
|
||||
#define CAND_PRIVATE 1
|
||||
#define CAND_PUBLIC 0
|
||||
|
||||
//=================================================================================================
|
||||
// Section: MACROS
|
||||
@ -61,14 +68,10 @@
|
||||
//=================================================================================================
|
||||
|
||||
|
||||
|
||||
|
||||
//=================================================================================================
|
||||
// Section: STRUCTURES
|
||||
// Description: Definition of local Structures (visible by this module only).
|
||||
//=================================================================================================
|
||||
|
||||
|
||||
|
||||
|
||||
//=================================================================================================
|
||||
@ -77,6 +80,19 @@
|
||||
//=================================================================================================
|
||||
CAND_pfnRxCallback m_pfnRxCallback = NULL;
|
||||
|
||||
CAN_FilterTypeDef stFilter = {
|
||||
(CAND_SHIFT<<6)|(CAND_PUBLIC<<5)|(CAND_BOARD_GROUP<<1), // FilterIdHigh
|
||||
0x00, // FilterIdLow
|
||||
(CAND_SHIFT<<6)|(CAND_PRIVATE<<5)|(CAND_BOARD_GROUP<<1), // FilterMaskIdHigh
|
||||
0x00, // FilterMaskIdLow
|
||||
CAN_FILTER_FIFO0, // FilterFIFOAssignment
|
||||
0x00, // FilterBank
|
||||
CAN_FILTERMODE_IDLIST, // FilterMode
|
||||
CAN_FILTERSCALE_32BIT, // FilterScale
|
||||
CAN_FILTER_ENABLE, // FilterActivation
|
||||
0x00 // SlaveStartFilterBank
|
||||
};
|
||||
|
||||
//=================================================================================================
|
||||
// Section: LOCAL CONSTANTS
|
||||
// Description: Definition of local constants (visible by this module only).
|
||||
@ -117,6 +133,17 @@ extern CAN_HandleTypeDef hcan1;
|
||||
BOOL CAND_boInitializeModule( VOID )
|
||||
{
|
||||
BOOL boOK = TRUE;
|
||||
|
||||
U8 u8BoardId = 0x00;
|
||||
u8BoardId |= DIPO_boGetInput(DIPO_eADR0) << 0;
|
||||
u8BoardId |= DIPO_boGetInput(DIPO_eADR1) << 1;
|
||||
u8BoardId |= DIPO_boGetInput(DIPO_eADR2) << 2;
|
||||
//u8BoardId |= DIPO_boGetInput(DIPO_eADR0) << 3; // TODO: New HW
|
||||
|
||||
stFilter.FilterIdHigh |= u8BoardId >> 3;
|
||||
stFilter.FilterIdLow |= u8BoardId << 5;
|
||||
|
||||
HAL_CAN_ConfigFilter(&hcan1, &stFilter);
|
||||
|
||||
boOK &= ( HAL_CAN_Start(&hcan1) == HAL_OK ) ? TRUE : FALSE;
|
||||
|
||||
@ -161,7 +188,6 @@ BOOL CAND_boSendMessage( U8 u8Id, U8 u8Len, PU8 pu8Buffer ){
|
||||
// Returns: none
|
||||
//-------------------------------------------------------------------------------------------------
|
||||
VOID CAND_vSetRxCallback( CAND_pfnRxCallback pfnRxCallback ){
|
||||
|
||||
m_pfnRxCallback = pfnRxCallback;
|
||||
}
|
||||
|
||||
@ -188,7 +214,6 @@ void HAL_CAN_RxFifo0MsgPendingCallback( CAN_HandleTypeDef *hcan ){
|
||||
|
||||
CAND_Message stMessage;
|
||||
|
||||
stMessage.u8Id = header.StdId;
|
||||
stMessage.u8Len = header.DLC;
|
||||
UTIL_vMemCopy( au8Data,stMessage.au8Data,stMessage.u8Len );
|
||||
|
||||
|
@ -62,7 +62,6 @@ extern "C" {
|
||||
//=================================================================================================
|
||||
|
||||
typedef struct {
|
||||
U8 u8Id;
|
||||
U8 au8Data[8];
|
||||
U8 u8Len;
|
||||
} CAND_Message;
|
||||
|
Reference in New Issue
Block a user