完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
电子发烧友论坛|
你好
现在遇到一个问题,MPC5644A芯片的时钟配置方式是从同事那里学来的,发现如果要将MPC5644A系统配置为80M,必须先配置为40M,想知道这个过程是否合理? 如果我直接把系统时钟配置成80M而不是先配置成40M,会不会有什么问题? 下面是MPC5644A芯片系统时钟配置流程 void sysclk_init_fnc(void) { /*------------------------禁用时钟监控标志---------------- */ FMPLL.ESYNCR2.R = 0x00000000; /* 确保丢失锁重置被禁用*/ /* 确保丢失时钟重置被禁用*/ /* 确保丢失锁 IRQ 被禁用*/ /*-------------------------------------------- ----------------------*/ /* 系统时钟设置 */ /*---------------- ---------------------------------------------- -*/ /*------------时钟配置模式---------------------------- */ FMPLL.ESYNCR1.B.EMODE = 0x0; /* 时钟配置模式:传统模式 */ FMPLL.ESYNCR1.B.CLKCFG = 0x07; /* 时钟模式:正常 w/ Crystal Ref */ /*-------------------------------------------- ------------------*/ /* PLL 斜坡 */ /*-------------------- ----------------------------------------------*/ /* - - - - - - - - - - - - - 阶段1 - - - - - - - - - - - --------------*/ FMPLL.SYNCR.B.RFD = 0x2; /* PLL 斜坡 1 分频器:4 */ FMPLL.SYNCR.B.PREDIV = 0x00; /* 预分频器选择:1 */ FMPLL.SYNCR.B.MFD = 0x6; /* PLL 斜坡第 1 步乘数:10 */ while (0 == FMPLL.SYNSR.B.LOCK){}; /* 等待 FMPLL 获取锁 */ FMPLL.SYNSR.B.LOLF = 0x1; /* 清除失锁标志 */ /*------------------------ 阶段 2-------------------- --------------*/ FMPLL.SYNCR.B.RFD = 0x2; /* PLL Ramping Step 2 分频器:4 */ FMPLL.SYNCR.B.PREDIV = 0x00; /* 预分频器选择:1 */ FMPLL.SYNCR.B.MFD = 0x10; /* PLL 斜坡第 2 步乘数:20 */ while (0 == FMPLL.SYNSR.B.LOCK){}; /* 等待 FMPLL 获取锁 */ FMPLL.SYNSR.B.LOLF = 0x1; /* 清除失锁标志 */ /*-------------------------------------------- ------------------*/ /* FMPLL 设置 */ /*-------------------- ----------------------------------------------*/ FMPLL.SYNFMMR.R = 0x00000000; /* 频率调制:禁用 */ /* 传播类型选择:中心传播 */ /* 调制周期:0*/ /* 调制增量步长:0*/ while(1 == FMPLL.SYNFMMR.B.BSY){} ; /* 等待 FMPLL 处理完成 */ /*------------系统时钟分频器设置----------------------------*/ SIU.SYSDIV.R = 0x00000010; /* FlexCAN 时钟分频器:1*/ /* 系统时钟分频器旁路:启用 */ /* 系统时钟分频器:1*/ /*-------------------------------------------- ------------------*/ /* 时钟监控标志 */ /*---------------- ----------------------------------------------* / FMPLL.ESYNCR2.R = 0x00000003; /* 时钟丢失功能:禁用 */ /* 锁定丢失时复位:禁用 */ /* 时钟丢失时复位:禁用 */ /* 锁定丢失中断请求:禁用*/ /* 时钟丢失中断请求:禁用 */ } |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
2135个成员聚集在这个小组
加入小组我的项目我做主,使用GN+Ninja来完成构建系统(VSCode开发RT106X)
37376 浏览 0 评论
NXP IMX8应用处理器快速入门必备:技巧、使用、设计指南
6775 浏览 1 评论
7793 浏览 1 评论
7642 浏览 0 评论
NXP i.MX6UL开发板(linux系统烧录+规格+硬件+模块移植)使用手册
5071 浏览 0 评论
1556浏览 2评论
关于NINA-W132 Wi-Fi模块SPI通信遇到的疑问求解
1208浏览 2评论
如何在MPC PowerPC MCU上首次刷写后禁用BDM?
749浏览 1评论
将HFREFR和LFREFR寄存器值设置为错误的值来将故障注入CMU,但CMU_ISR值始终为零,为什么?
735浏览 1评论
将SPSDK for FRDM-MCX-W71 SDK与VS一起安装时出现hidapi构建错误怎么解决?
678浏览 1评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 01:53 , Processed in 0.627150 second(s), Total 68, Slave 51 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
783