专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
F4-SysTick中断需要配置那些寄存?
2019-07-21 04:16
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
10743
2
1467
F4-SysTick中断需要配置那些寄存?
除了--
SysTick->CTRL |= ((uint32_t)0x1 << 1); // 启用中断方式
还有其他的么?
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
2条回答
tangerine
1楼-- · 2019-07-21 05:24
SysTick_Init()在main中没有调用,另外F4SysTick中断无需使能SYSCFG时钟
加载中...
tangerine
2楼-- · 2019-07-21 08:09
我现在是中断进不去,想必是有什么我没注意到的问题,这里贴代码,大家帮我看看,谢谢啦
先用库函数写,然后都改成寄存器了,感觉这样学习挺好的。。。各位可以直接跟我说寄存器,我觉得这样更加直观 [mw_shl_code=c,true]#include "stm32f4xx.h" #include "stm32f4xx_rcc.h" #include "stm32f4xx_gpio.h" #define NOBEEP void SysTickDelay(uint32_t nus) { if(nus == 0) return; // SysTick->LOAD = nus * 16 / 8; // HSI is about 16 MHz, and FCLK = SYSCLK / 8 SysTick->LOAD = nus * 8 / 8; // HSI equ 8 MHz, and FCLK = SYSCLK / 8 // SysTick->LOAD = nus * 5376 / 100 / 8; // PLL equ PLLsrc / 25 * 336 / 2 MHz SysTick->VAL = 0x00; SysTick->CTRL |= 0x01; while(!(SysTick->CTRL & ((uint32_t)0x1 << 16))); SysTick->CTRL &= ~(uint32_t)0x1; } void LED_BEEP_Init(void) { // 1.配置时钟 RCC->AHB1ENR |= (uint32_t)0x01 << 5; // 启用GPIOF的时钟 // 2.配置模式 GPIOF->MODER |= (uint32_t)0x01 << (8 * 2); // 设置GPIOF8的模式为输出 GPIOF->MODER |= (uint32_t)0x01 << (9 * 2); // 设置GPIOF9的模式为输出 GPIOF->MODER |= (uint32_t)0x01 << (10 * 2); // 设置GPIOF10的模式为输出 // 3.配置输出模式 GPIOF->OTYPER &= ~((uint32_t)0x0 << 8); // 0 推挽输出 GPIOF->OTYPER &= ~((uint32_t)0x0 << 9); // 0 推挽输出 GPIOF->OTYPER &= ~((uint32_t)0x0 << 10); // 0 推挽输出 // 4.配置上下拉 GPIOF->
UPDR |= (uint32_t)0x01 << (8 * 2); // 01 上拉 GPIOF->
UPDR |= (uint32_t)0x01 << (9 * 2); // 01 上拉 GPIOF->
UPDR |= (uint32_t)0x01 << (10 * 2); // 01 上拉 // 5.配置速度 GPIOF->OSPEEDR |= (uint32_t)0x01 << (8 * 2); // 01 25MHz GPIOF->OSPEEDR |= (uint32_t)0x01 << (9 * 2); // 01 25MHz GPIOF->OSPEEDR |= (uint32_t)0x01 << (10 * 2); // 01 25MHz // 6.锁定模式(可选,锁定之后引脚模式便不可以更改) GPIO_PinLockConfig(GPIOF, GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10); // 对LCKR按说明写入即可 // 7.配置完成,给定初始输出 GPIOF->ODR = (uint32_t)0xFFFFFFFF; // 输出数据寄存给定 GPIOF->BSRRH = (uint16_t)((uint16_t)0x1 << 8); // 复位寄存给定,关闭蜂鸣器 GPIOF->BSRRL = (uint16_t)((uint16_t)0x1 << 9); // 置位寄存给定,关闭红灯 GPIOF->BSRRH = (uint16_t)((uint16_t)0x1 << 10); // 复位寄存给定,打开绿灯 } void RCC_SetSYSCLK_HSI() { __IO uint32_t cfgr = 0; cfgr = RCC->CFGR; cfgr &= ~(uint32_t)0x3; // SET HSI AS SYSTEM CLOCK RCC->CFGR = cfgr; } void RCC_SetSYSCLK_HSE() { __IO uint32_t cfgr = 0; cfgr = RCC->CFGR; cfgr &= ~(uint32_t)0x03; cfgr |= (uint32_t)0x1; // SET HSE AS SYSTEM CLOCK RCC->CFGR = cfgr; } void RCC_SetSYSCLK_PLL() { __IO uint32_t cfgr = 0; cfgr = RCC->CFGR; cfgr &= ~(uint32_t)0x3; cfgr |= (uint32_t)0x2; // SET PLL AS SYSTEM CLOCK RCC->CFGR = cfgr; } void SysTick_Init() { SysTick->CTRL &= ~((uint32_t)0x1 << 2); // CLKSOURCE, =1--FCLK, =0--STCLK(外部时钟源) SysTick->CTRL |= ((uint32_t)0x1 << 1); // 启用中断方式 } void RCC_Init() { // RCC_SetSYSCLK_HSI(); // 配置HSI为SYSCLK,16MHz // RCC_SetSYSCLK_PLL(); // 配置PLL为SYSCLK RCC_SetSYSCLK_HSE(); // 配置HSE为SYSCLK } void main() { RCC->APB2ENR|=1<<14; //使能SYSCFG时钟 RCC_Init(); LED_BEEP_Init(); #ifdef NOBEEP GPIOF->BSRRH = (uint16_t)((uint16_t)0x1 << 8); #define MASK 0x6 #else #define MASK 0x7 #endif uint32_t delayms = 500; while(1) { GPIOF->ODR ^= (uint16_t)MASK << 8; SysTickDelay(1000 * delayms); } } void SysTick_Handler(void) { GPIOF->BSRRL = (uint16_t)((uint16_t)0x1 << 8); return; } [/mw_shl_code]
加载中...
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
STM32开发板免费用活动
7 个回答
stm32 处理 DHT11占用太多时间,大家程序是怎么设计的
8 个回答
分享一个STM32单片机做的离线编程器代码
9 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
先用库函数写,然后都改成寄存器了,感觉这样学习挺好的。。。各位可以直接跟我说寄存器,我觉得这样更加直观 [mw_shl_code=c,true]#include "stm32f4xx.h" #include "stm32f4xx_rcc.h" #include "stm32f4xx_gpio.h" #define NOBEEP void SysTickDelay(uint32_t nus) { if(nus == 0) return; // SysTick->LOAD = nus * 16 / 8; // HSI is about 16 MHz, and FCLK = SYSCLK / 8 SysTick->LOAD = nus * 8 / 8; // HSI equ 8 MHz, and FCLK = SYSCLK / 8 // SysTick->LOAD = nus * 5376 / 100 / 8; // PLL equ PLLsrc / 25 * 336 / 2 MHz SysTick->VAL = 0x00; SysTick->CTRL |= 0x01; while(!(SysTick->CTRL & ((uint32_t)0x1 << 16))); SysTick->CTRL &= ~(uint32_t)0x1; } void LED_BEEP_Init(void) { // 1.配置时钟 RCC->AHB1ENR |= (uint32_t)0x01 << 5; // 启用GPIOF的时钟 // 2.配置模式 GPIOF->MODER |= (uint32_t)0x01 << (8 * 2); // 设置GPIOF8的模式为输出 GPIOF->MODER |= (uint32_t)0x01 << (9 * 2); // 设置GPIOF9的模式为输出 GPIOF->MODER |= (uint32_t)0x01 << (10 * 2); // 设置GPIOF10的模式为输出 // 3.配置输出模式 GPIOF->OTYPER &= ~((uint32_t)0x0 << 8); // 0 推挽输出 GPIOF->OTYPER &= ~((uint32_t)0x0 << 9); // 0 推挽输出 GPIOF->OTYPER &= ~((uint32_t)0x0 << 10); // 0 推挽输出 // 4.配置上下拉 GPIOF->UPDR |= (uint32_t)0x01 << (8 * 2); // 01 上拉 GPIOF->UPDR |= (uint32_t)0x01 << (9 * 2); // 01 上拉 GPIOF->UPDR |= (uint32_t)0x01 << (10 * 2); // 01 上拉 // 5.配置速度 GPIOF->OSPEEDR |= (uint32_t)0x01 << (8 * 2); // 01 25MHz GPIOF->OSPEEDR |= (uint32_t)0x01 << (9 * 2); // 01 25MHz GPIOF->OSPEEDR |= (uint32_t)0x01 << (10 * 2); // 01 25MHz // 6.锁定模式(可选,锁定之后引脚模式便不可以更改) GPIO_PinLockConfig(GPIOF, GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10); // 对LCKR按说明写入即可 // 7.配置完成,给定初始输出 GPIOF->ODR = (uint32_t)0xFFFFFFFF; // 输出数据寄存给定 GPIOF->BSRRH = (uint16_t)((uint16_t)0x1 << 8); // 复位寄存给定,关闭蜂鸣器 GPIOF->BSRRL = (uint16_t)((uint16_t)0x1 << 9); // 置位寄存给定,关闭红灯 GPIOF->BSRRH = (uint16_t)((uint16_t)0x1 << 10); // 复位寄存给定,打开绿灯 } void RCC_SetSYSCLK_HSI() { __IO uint32_t cfgr = 0; cfgr = RCC->CFGR; cfgr &= ~(uint32_t)0x3; // SET HSI AS SYSTEM CLOCK RCC->CFGR = cfgr; } void RCC_SetSYSCLK_HSE() { __IO uint32_t cfgr = 0; cfgr = RCC->CFGR; cfgr &= ~(uint32_t)0x03; cfgr |= (uint32_t)0x1; // SET HSE AS SYSTEM CLOCK RCC->CFGR = cfgr; } void RCC_SetSYSCLK_PLL() { __IO uint32_t cfgr = 0; cfgr = RCC->CFGR; cfgr &= ~(uint32_t)0x3; cfgr |= (uint32_t)0x2; // SET PLL AS SYSTEM CLOCK RCC->CFGR = cfgr; } void SysTick_Init() { SysTick->CTRL &= ~((uint32_t)0x1 << 2); // CLKSOURCE, =1--FCLK, =0--STCLK(外部时钟源) SysTick->CTRL |= ((uint32_t)0x1 << 1); // 启用中断方式 } void RCC_Init() { // RCC_SetSYSCLK_HSI(); // 配置HSI为SYSCLK,16MHz // RCC_SetSYSCLK_PLL(); // 配置PLL为SYSCLK RCC_SetSYSCLK_HSE(); // 配置HSE为SYSCLK } void main() { RCC->APB2ENR|=1<<14; //使能SYSCFG时钟 RCC_Init(); LED_BEEP_Init(); #ifdef NOBEEP GPIOF->BSRRH = (uint16_t)((uint16_t)0x1 << 8); #define MASK 0x6 #else #define MASK 0x7 #endif uint32_t delayms = 500; while(1) { GPIOF->ODR ^= (uint16_t)MASK << 8; SysTickDelay(1000 * delayms); } } void SysTick_Handler(void) { GPIOF->BSRRL = (uint16_t)((uint16_t)0x1 << 8); return; } [/mw_shl_code]
一周热门 更多>