自学内容网 自学内容网

mcu 测试

7132_RST_B 对应于 STM32F103 的 PC15 引脚,需要设置为低电平有效,并且上电默认为复位状态,上电完成后解除复位。

  1. 定义引脚
    首先,使用 HAL_GPIO 宏来定义 7132_RST_B 引脚:
#define PIN_7132_RST_B     HAL_GPIO(PORTC, IO15)  // PC15 对应于 PORTC 和 IO15
  1. GPIO 初始化和控制函数
    接下来,编写函数来初始化这个引脚,并在上电时默认设置为低电平(复位状态),然后解除复位。
#include "stm32f10x.h"

// 初始化7132_RST_B引脚
void init_7132_RST_B(void) {
    GPIO_InitTypeDef GPIO_InitStructure;

    // 使能GPIOC时钟
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);

    // 配置PC15为推挽输出模式
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_15;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOC, &GPIO_InitStructure);

    // 默认设置为低电平,触发复位
    GPIO_ResetBits(GPIOC, GPIO_Pin_15);
}

// 延迟函数(根据您的实际实现)
void delay(uint32_t count) {
    for (; count != 0; count--);
}

// 延迟后解除复位
void release_7132_RST_B(void) {
    // 延迟一段时间以确保设备稳定
    delay(0x1000);  // 适当调整延迟时间

    // 设置为高电平,解除复位
    GPIO_SetBits(GPIOC, GPIO_Pin_15);
}

int main(void) {
    // 初始化7132_RST_B引脚,并默认触发复位
    init_7132_RST_B();

    // 执行其他初始化代码...

    // 延迟后解除复位
    release_7132_RST_B();

    // 其他代码...
    while (1) {
        // 主循环
    }
}
  1. 代码说明
    init_7132_RST_B 函数:
    使能 GPIOC 的时钟。
    将 PC15 配置为推挽输出模式。
    默认将 PC15 设置为低电平,触发复位状态。

    release_7132_RST_B 函数:
    延迟一段时间以确保设备稳定。
    将 PC15 设置为高电平,解除复位状态。

    main 函数:
    调用初始化函数和解除复位函数。

  2. 注意事项
    引脚定义:确保 PIN_7132_RST_B 的定义与您的硬件连接相匹配。
    延时实现:在实际应用中,您可能需要使用更精确的延时函数,而不是简单的循环。您可以使用 SysTick 或其他定时器来实现更准确的延时。
    复位时序:根据系统需求,可能需要调整复位信号的持续时间。
    通过以上步骤,您可以成功地将 7132_RST_B 引脚配置为低电平有效的复位信号,并在 STM32F103 微控制器上实现上电默认复位,上电完成后解除复位的功能。


原文地址:https://blog.csdn.net/weixin_45939263/article/details/144053840

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!