STM32F4 HAL库使用CAN总线

HAL库使用CAN总线

CAN.c

CAN_HandleTypeDef hcan1;
void CAN1_User_Init(CAN_HandleTypeDef* hcan );
/* CAN1 init function */
void MX_CAN1_Init(void)
{

  hcan1.Instance = CAN1;
  hcan1.Init.Prescaler = 6;
  hcan1.Init.Mode = CAN_MODE_NORMAL;
  hcan1.Init.SyncJumpWidth = CAN_SJW_1TQ;
  hcan1.Init.TimeSeg1 = CAN_BS1_3TQ;
  hcan1.Init.TimeSeg2 = CAN_BS2_3TQ;
  hcan1.Init.TimeTriggeredMode = DISABLE;
  hcan1.Init.AutoBusOff = DISABLE;
  hcan1.Init.AutoWakeUp = DISABLE;
  hcan1.Init.AutoRetransmission = DISABLE;
  hcan1.Init.ReceiveFifoLocked = DISABLE;
  hcan1.Init.TransmitFifoPriority = DISABLE;
  if (HAL_CAN_Init(&hcan1) != HAL_OK)
  {
    Error_Handler();
  }
    CAN1_User_Init(&hcan1);
}

void HAL_CAN_MspInit(CAN_HandleTypeDef* canHandle)
{

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  if(canHandle->Instance==CAN1)
  {
  /* USER CODE BEGIN CAN1_MspInit 0 */

  /* USER CODE END CAN1_MspInit 0 */
    /* CAN1 clock enable */
    __HAL_RCC_CAN1_CLK_ENABLE();
  
    __HAL_RCC_GPIOD_CLK_ENABLE();
    /**CAN1 GPIO Configuration    
    PD0     ------> CAN1_RX
    PD1     ------> CAN1_TX 
    */
    GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1;
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
    GPIO_InitStruct.Alternate = GPIO_AF9_CAN1;
    HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);

    /* CAN1 interrupt Init */
    HAL_NVIC_SetPriority(CAN1_TX_IRQn, 0, 0);
    HAL_NVIC_EnableIRQ(CAN1_TX_IRQn);
    HAL_NVIC_SetPriority(CAN1_RX0_IRQn, 0, 0);
    HAL_NVIC_EnableIRQ(CAN1_RX0_IRQn);
  /* USER CODE BEGIN CAN1_MspInit 1 */

  /* USER CODE END CAN1_MspInit 1 */
  }
}

void HAL_CAN_MspDeInit(CAN_HandleTypeDef* canHandle)
{

  if(canHandle->Instance==CAN1)
  {
  /* USER CODE BEGIN CAN1_MspDeInit 0 */

  /* USER CODE END CAN1_MspDeInit 0 */
    /* Peripheral clock disable */
    __HAL_RCC_CAN1_CLK_DISABLE();
  
    /**CAN1 GPIO Configuration    
    PD0     ------> CAN1_RX
    PD1     ------> CAN1_TX 
    */
    HAL_GPIO_DeInit(GPIOD, GPIO_PIN_0|GPIO_PIN_1);

    /* CAN1 interrupt Deinit */
    HAL_NVIC_DisableIRQ(CAN1_TX_IRQn);
    HAL_NVIC_DisableIRQ(CAN1_RX0_IRQn);
  /* USER CODE BEGIN CAN1_MspDeInit 1 */

  /* USER CODE END CAN1_MspDeInit 1 */
  }
} 

/* USER CODE BEGIN 1 */
void CAN1_User_Init(CAN_HandleTypeDef* hcan )
{
    CAN_FilterTypeDef  sFilterConfig;
    HAL_StatusTypeDef  HAL_Status;

    sFilterConfig. FilterIdHigh = 0;
    sFilterConfig. FilterIdLow = 0;
    sFilterConfig. FilterMaskIdHigh = 0;
    sFilterConfig. FilterMaskIdLow = 0;
    sFilterConfig. FilterFIFOAssignment = CAN_FILTER_FIFO0;
    sFilterConfig. FilterBank = 0;
    sFilterConfig. FilterMode = CAN_FILTERMODE_IDMASK; 
    sFilterConfig. FilterScale = CAN_FILTERSCALE_32BIT;  
    sFilterConfig. FilterActivation = ENABLE;
    sFilterConfig. SlaveStartFilterBank = 14; 
    HAL_Status = HAL_CAN_ConfigFilter(hcan, &sFilterConfig);
    HAL_Status = HAL_CAN_Start(hcan);  
    if(HAL_Status != HAL_OK){
        Error_Handler();
    }	
    HAL_Status = HAL_CAN_ActivateNotification(hcan, CAN_IT_RX_FIFO0_MSG_PENDING | CAN_IT_TX_MAILBOX_EMPTY);
    if(HAL_Status != HAL_OK){
        Error_Handler();
    }
}

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
STMicroelectronics的STM32F4系列微控制器是一款高性能、低功耗的MCU芯片。HAL(Hardware Abstraction Layer)STMicroelectronics提供的一种软件,用于简化STM32系列微控制器的开发流程。 SPI(Serial Peripheral Interface)是一种通信协议,可以用于在微控制器和外设之间进行串行数据传输。LCD(Liquid Crystal Display)是一种常见的显示器件,用于显示图像和文本。使用STM32F4 HAL驱动SPI LCD可以实现在STM32F4微控制器上控制LCD屏幕的功能。 首先,我们需要在STM32F4的硬件上连接SPI总线和LCD屏幕。通过阅读相关的硬件文档,我们可以了解到哪些引脚是SPI总线的主线和从线,以及如何正确连接LCD屏幕。 接下来,我们需要编写代码来初始化SPI总线和LCD屏幕。使用HAL的相关函数,我们可以在代码中初始化SPI总线和配置相关的参数,如数据传输速率、时钟相位、数据位宽等。 在SPI总线初始化完成后,我们可以使用HAL的函数来发送和接收数据。通过编写相应的代码,我们可以将需要显示的图像数据或文本发送到LCD屏幕上。 最后,我们需要编写代码来进行LCD屏幕的控制。这包括设置显示模式(如亮度、对比度等)、光标位置和显示字符等。HAL提供了一系列函数,可以简化这些操作的实现。 总之,使用STM32F4 HAL驱动SPI LCD可以方便地在STM32F4微控制器上控制LCD屏幕显示。我们只需要正确连接硬件,并编写相应的代码来初始化SPI总线和LCD屏幕,然后使用HAL的函数进行数据传输和屏幕控制即可。这样可以大大简化LCD驱动的开发流程,节省开发时间和提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值