STM32G431是ST公司推出的一款高性能微控制器,凭借其强大的性能、丰富的外设和较低的功耗,在工业控制、通信和电机控制领域备受欢迎。本篇文章将基于STM32G431,带大家实现以下两个功能:
- 配置CAN接口,用于主从通信;
- 配置GPIO,实现基本的LED控制功能。
硬件与软件准备- 硬件
- STM32G431开发板
- CAN收发器模块(如MCP2551或TJA1050)
- LED和适配电阻
- PC,用于通过CAN调试工具与MCU通信
- 软件
- STM32CubeMX:用于生成初始代码
- Keil或STM32CubeIDE:用于编写和调试程序
CAN通信配置与实现配置步骤- 打开STM3总结本文基于STM32G431的CAN通信和GPIO控制功能进行了演示。从基础配置到代码实现,我们一步步探索了如何让STM32G431成为高效的嵌入式开发工具。希望本文对你的开发有所帮助!2CubeMX,选择STM32G431的芯片型号。
- 在引脚图中,将CAN接口(FDCAN1)启用。
- 配置CAN的波特率,比如500 kbps,同时开启接收和发送功能。
- 生成代码,并使用CubeIDE导入。
代码实现以下代码实现了一个简单的CAN接收和发送功能:
#include "main.h"
// CAN消息接收/发送定义
FDCAN_HandleTypeDef hfdcan1;
FDCAN_RxHeaderTypeDef RxHeader;
FDCAN_TxHeaderTypeDef TxHeader;
uint8_t RxData[8];
uint8_t TxData[8] = {0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88};
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
static void MX_FDCAN1_Init(void);
int main(void) {
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
MX_FDCAN1_Init();
// 配置CAN
if (HAL_FDCAN_Start(&hfdcan1) != HAL_OK) {
Error_Handler();
}
if (HAL_FDCAN_ActivateNotification(&hfdcan1, FDCAN_IT_RX_FIFO0_NEW_MESSAGE, 0) != HAL_OK) {
Error_Handler();
}
// 配置发送消息的头部
TxHeader.Identifier = 0x123;
TxHeader.IdType = FDCAN_STANDARD_ID;
TxHeader.TxFrameType = FDCAN_DATA_FRAME;
TxHeader.DataLength = FDCAN_DLC_BYTES_8;
TxHeader.ErrorStateIndicator = FDCAN_ESI_ACTIVE;
TxHeader.BitRateSwitch = FDCAN_BRS_OFF;
TxHeader.FDFormat = FDCAN_CLASSIC_CAN;
TxHeader.TxEventFifoControl = FDCAN_NO_TX_EVENTS;
while (1) {
// 发送CAN消息
if (HAL_FDCAN_AddMessageToTxFifoQ(&hfdcan1, &TxHeader, TxData) != HAL_OK) {
Error_Handler();
}
HAL_Delay(1000);
}
}
// CAN中断回调函数
void HAL_FDCAN_RxFifo0Callback(FDCAN_HandleTypeDef *hfdcan, uint32_t RxFifo0ITs) {
if ((RxFifo0ITs & FDCAN_IT_RX_FIFO0_NEW_MESSAGE) != 0) {
HAL_FDCAN_GetRxMessage(hfdcan, FDCAN_RX_FIFO0, &RxHeader, RxData);
// 简单打印接收到的数据
printf("Received Data: ");
for (int i = 0; i < 8; i++) {
printf("%02X ", RxData[i]);
}
printf("\n");
}
}
static void MX_FDCAN1_Init(void) {
hfdcan1.Instance = FDCAN1;
hfdcan1.Init.ClockDivider = FDCAN_CLOCK_DIV1;
hfdcan1.Init.FrameFormat = FDCAN_FRAME_CLASSIC;
hfdcan1.Init.Mode = FDCAN_MODE_NORMAL;
hfdcan1.Init.AutoRetransmission = ENABLE;
hfdcan1.Init.TransmitPause = DISABLE;
hfdcan1.Init.ProtocolException = DISABLE;
hfdcan1.Init.NominalPrescaler = 5;
hfdcan1.Init.NominalSyncJumpWidth = 1;
hfdcan1.Init.NominalTimeSeg1 = 13;
hfdcan1.Init.NominalTimeSeg2 = 2;
if (HAL_FDCAN_Init(&hfdcan1) != HAL_OK) {
Error_Handler();
}
}
GPIO控制LED实现配置步骤- 在STM32CubeMX中将对应引脚配置为GPIO_Output模式,用于控制LED。
- 生成代码,初始化GPIO。
代码实现static void MX_GPIO_Init(void) {
GPIO_InitTypeDef GPIO_InitStruct = {0};
// GPIO时钟使能
__HAL_RCC_GPIOA_CLK_ENABLE();
// 配置引脚PA5为输出模式
GPIO_InitStruct.Pin = GPIO_PIN_5;
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}
int main(void) {
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
while (1) {
// 点亮LED
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
HAL_Delay(500);
// 熄灭LED
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET);
HAL_Delay(500);
}
}
|