在STM32cubeMX建立的工程里手动添加IWDG

最近半年在用STM32做些东西。发现使用cubeMX初始化程序框架简直太好使了。但是,如果要加入外设,就需要重新配置并生成工程文件。这本来也没什么,但是,实际开发中偷懒了,比如离散量输入的中断由上跳沿改为下跳沿触发什么的,一般也就自己在非用户程序部分手改一下了事。
但这并不是好习惯,因为当你不得不重新生成工程文件时,痛苦就来了。
扯远了,回主题。
为啥要手动加IWDG,因为手懒了,没有规范开发……各种理由吧。也是想顺便验证一下HAL库函数的引用路径。
下面看怎么做:
1-在main.c文件的system_clock_config()函数检查一下LSI是否启动了,如果没有启动,手动加入启动代码:

LL_RCC_LSI_Enable();
   /* Wait till LSI is ready */
  while(LL_RCC_LSI_IsReady() != 1)
  {
    
  }

2-在main.c加上IWDG的控制变量:
IWDG_HandleTypeDef hiwdg;
IWDG_HandleTypeDef 这个结构体在stm32f4xx_hal_iwdg.h内定义,如果你之前没有将stm32f4xx_hal_iwdg.c加入到工程文件中,参考3手动加一下。

3.1-将stm32f4xx_hal_iwdg.h和stm32f4xx_hal_iwdg.c分别放入你工程目录的“\Drivers\STM32F4xx_HAL_Driver”目录内inc和src两个文件夹内(PS:各放一个)
3.2-打开工程根目录下Inc文件夹内的stm32f4xx_hal_conf.h找到下面语句:

/* #define HAL_IWDG_MODULE_ENABLED*/

把他从注释状态释放出来

#define HAL_IWDG_MODULE_ENABLED

这样,你的IWDG的HAL库就加入进来了。

4-在main.c定义IWDG的初始化函数

static void MX_IWDG_Init(void){
	hiwdg.Instance = IWDG;
  	hiwdg.Init.Prescaler = IWDG_PRESCALER_16;
  	hiwdg.Init.Reload = 1023;
  	if (HAL_IWDG_Init(&hiwdg) != HAL_OK)
  	{
    	Error_Handler();
  	}
}

如果你一开始就在MX里启用了IWDG的话,你会发现自动生成的代码就是这些语句。没错,这是大搬运~~
其中hiwdg.Init.Prescaler指定了IWDG使用的LSI时钟分频参数,这里我设定的是16分频,
hiwdg.Init.Reload指定的是计时器的初始值,这里是1023,也就是计数1024次被触发。
我LSI设定的是32Khz,理论上说这里IWDG需要0.5秒内喂一次。

5-在main.c文件合适位置调用IWDG初始函数MX_IWDG_Init和喂狗HAL_IWDG_Refresh(&hiwdg);

基本就完成了。

最后,简单说一下这里体现出来MX生成工程内的HAL库调用逻辑:
main.h中会引入stm32f4xx_hal.h,这个文件里很多条件编译
那么Inc文件夹内的stm32f4xx_hal_conf.h内的宏定义就开始起作用了
当然,记得把源文件放入到driver文件夹里!!
另外,看到main.h里直接引用了很多LL库的头文件,所以如果你使用LL库来手动加IWDG,应该只需要把源文件copy到drive然后在main.h加入include引用就可以了。【MDK下别忘了加到工程文件里,其他开发工具应该也要调整,具体不熟悉,暂时只用了MDK做开发工具】

手动加这种东西并不是一个好的选择,应该尽量避免,实际上MX生成工程文件的架构很清晰,养成好习惯对工程开发绝对是事半功倍的。祝各位看这片文章只是问了了解一下,不是被迫参考使用~~~

管理后台HTML页面是Web开发中一种常见的实践,主要用于构建企业或组织内部的管理界面,具备数据监控、用户管理、内容编辑等功能。本文将探讨一套美观易用的二级菜单目录设计,帮助开发者创建高效且直观的后台管理系统。 HTML5:作为超文本标记语言的最新版本,HTML5增强了网页的互动性和可访问性,提供了更多语义元素,如<header>、<nav>、<section>、<article>等,有助于清晰地定义网页结构。在管理后台中,HTML5可用于构建页面布局,划分功能区域,并集成多媒体内容,如图像、音频和视频。 界面设计:良好的管理后台界面应具备清晰的导航、一致的布局和易于理解的图标。二级菜单目录设计能够有效组织信息,主菜单涵盖大类功能,次级菜单则提供更具体的操作选项,通过展开和折叠实现层次感,降低用户认知负担。 CSS:CSS是用于控制网页外观和布局的语言,可对HTML元素进行样式设置,包括颜色、字体、布局等。在管理后台中,CSS能够实现响应式设计,使页面在不同设备上具有良好的显示效果。借助CSS预处理器(如Sass或Less),可以编写更高效、模块化的样式代码,便于维护。 文件结构: guanli.html:可能是管理页面的主入口,包含后台的主要功能和布局。 xitong.html:可能是系统设置或配置页面,用于管理员调整系统参数。 denglu.html:登录页面,通常包含用户名和密码输入框、登录按钮,以及注册或忘记密码的链接。 image文件夹:存放页面使用的图片资源,如图标、背景图等。 css文件夹:包含后台系统的样式文件,如全局样式表style.css或按模块划分的样式文件。 响应式设计:在移动设备普及的背景下,管理后台需要支持多种屏幕尺寸。通过媒体查询(Media Queries)和流式布局(Fluid Grids),可以确保后台在桌面、平板和手机上都能良好展示。
双闭环直流电机调速系统是一种高效且应用广泛的直流调速技术。通过设置转速环和电流环两个闭环,系统能够对电机的转速和电流进行精准控制,从而提升动态响应能力和稳定性,广泛应用于工业自动化领域。 主电路设计:主电路采用三相全控桥整流电路,将交流电转换为可调节的直流电,为电机供电。晶闸管作为核心元件,通过调节控制角α实现输出电压的调节。 元部件设计:包括整流变压器、晶闸管、电抗器等元件的设计参数计算,这些元件的性能直接影响系统的稳定性和效率。 保护电路:设计过载保护、短路保护等保护电路,确保系统安全运行。 驱动电路:设计触发电路和脉冲变压器,触发电路用于触发晶闸管导通,脉冲变压器用于传递触发信号。 控制器设计:系统核心为转速调节器(ASR)和电流调节器(ACR),分别对转速和电流进行调控。检测电路用于采集实际转速和电流值并反馈给调节器。 仿真分析:利用MATLAB/SIMULINK等工具对系统进行仿真分析,验证其稳定性和性能指标是否达标。 方案确定框图绘制:明确系统构成及各模块连接方式。 主电路设计:选择整流电路形式,设计整流变压器、晶闸管等元部件并计算参数。 驱动电路设计:设计触发电路和脉冲变压器,确保晶闸管准确触发。 控制器设计: 转速调节器(ASR):根据转速指令调整实际转速。 电流调节器(ACR):根据ASR输出指令调整电流,实现快速响应。 参数计算:计算给定电压、调节器、检测电路、触发电路和稳压电路的参数。 仿真分析:通过软件模拟系统运行状态,评估性能。 电气原理图绘制:完成调速控制电路的电气原理图绘制。 双闭环控制策略:转速环在外,电流环在内,形成嵌套结构,提升动态响应能力。 晶闸管控制角调节:通过改变控制角α调节输出电压,实现转速平滑调节。 仿真分析:借助专业软件验证设计的合理性和有效性。 双闭环直流电机调速系统设计涉及主电路、驱动电路和控制器设计等多个环节,通过仿
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值