344|0

1013

帖子

0

资源

纯净的硅(中级)

MSP430F5529 时钟 25MHz 设置方法 [复制链接]

        MSP430F5529的launchpad是 TI送的比较多的一款开发套件,至少我们实验室就是人手一块,很多人都嫌他慢,确实相比较于STM32F103(72MHz) 和STM32F407(168MHz)的速度而言  默认状态下主频只有1MHz的 MSP430F5529就是个弟弟,而且处理位宽也是只有16位,,, 还不支持位带操作  ,但是就超低功耗这一点就足以让他在单片机界立足 ,废话少说,来正题。

这次跟大家分享的是标题所说的  MSP430F5529的升频方案。

要升频,首先我们得能‘看见’系统的频率,TI的工程师们充分考虑到了这个问题,他们有得引脚可以直接输出时钟信号!!!

在芯片datesheet中 的Terminal Functions  里有如下说明

image.png

所以我们可以通过设置相应的 状态来输出时钟信号, IO配置成输出+ 功能复用

image.png image.png

以上 我们实现了 时钟的输出 ,通过测量上述的三个IO ,我们可以得到系统的不同时钟。 接下来就是对时钟的配置

主要就是配置UCS(Unified Clock System (UCS))的一些寄存器。 不过 在这之前  我们要先把核心电压升上去,430为了省电默认状态下核心电压默认设置为1.8V来节省功耗。 在用户手册的2.2.4节提到了升核心电压的方法

开启PMM管理的操作  第一步是解锁  向PMMCTL0 寄存器高8位写入 0xA5 然后设置核心电压等级是三级(官方手册有提到频率和核心电压的关系)

image.png

这里要提一下 ,我调用官方的 SetVcore()函数并不能实现效果不知道为什么 。。。。有知道的大佬还望不吝赐教

到这里 我们的核心的电压已经设置完成了,接下来就是时钟的配置了,其他大佬们也提到了很多,我这里就是按照一位大佬的做法实现的,不是原创! 只是对前人思路的理解.. 代码如下

image.png

第一步是 令 SR寄存器里面的 SCG0=1, 我猜测这里的目的应该是

image.png image.png

猜测这一步的作用应该是关闭锁相环,同时 关闭了这个时钟以后系统时钟应该会自动切换到备用时钟。 关闭了这个以后就可以开始对时钟进行设置了。  UCSCTL0 是直接关闭了DCO的输出

image.png image.png

查看芯片的技术手册发现0x60(DCORSEL_6)确实是最优解!  同时0x50(DCORSEL_5)和 0x70(DCORSEL_7)也是可以选择的!

接着理解下一步  UCSCTL2 = FLLD_1 | 380;

image.png

接下来我们看一下这些bit到底是设置了什么

image.png image.png

通过 这些默认的设置

image.png image.png

初步判断时钟是从XT1CLK 来的

image.png

XT1 也就是我们先前使能的 外部晶振    P5.4 P5.5

image.png

然后我们打开launchpad的手册 在clock相关的部分也确实证实了  XTL1 是32.768KHz的晶振

image.png

XT1 的 bypass是 默认置0的  完整的时钟信号走向应该是这样的

image.png

实现效果是这样的  

image.png

这里的示波器选用的是 Loto 的虚拟示波器 OSC802 

示波器的引脚接到了 P2.2脚 我也是最近才开始捡起 430的 ,很多东西都不是很熟,出错在所难免,请各位大佬们不吝赐教!


回复
您需要登录后才可以回帖 登录 | 注册

最新文章 更多>>
    关闭
    站长推荐上一条 1/5 下一条

    About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

    站点相关: 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

    北京市海淀区知春路23号集成电路设计园量子银座1305 电话:(010)82350740 邮编:100191

    电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved
    快速回复 返回顶部 返回列表