历史上的今天
今天是:2025年03月09日(星期日)
2020年03月09日 | PIC16位单片机——彻底弄懂时钟
2020-03-09 来源:eefocus
一直以来写程序都是看参考资料和书,这次的16位单片劫dsPIC33EP32GP502没有一点资料。因此趁机也好好深入学习一下!首先看振荡器的选择吧。
我们使用的是外部晶振,所以配置为HS,FCY是CPU时钟,FP是外设时钟,FCY=FP(除打盹模式外)。FCY=Fosc/2。也就是cpu时钟是晶振频率的1/2。下面还有分频。DOZE<2:0>:011 = FCY 被 8 分频 (默认)处理器时钟分频比选择位。
因此实际的FCY=0.5MHz(使用8M的外部晶振,并八分频8/2/8=0.5MHz)。
看一下振荡器选择配置位的说明:
这里我们需要看的是FOSCSEL配置位 第二列是寄存器地址,需要设置的是IESO<7>和FNOSC<2:0>
看一下头文件p33EP32GP502.h里面的说明:
/* Register FOSCSEL (0x57f8) */
extern __attribute__((space(prog))) int _FOSCSEL;
#define _FOSCSEL(x) __attribute__((section("__FOSCSEL.sec"),space(prog))) int _FOSCSEL = (x);
/*
** Only one invocation of FOSCSEL should appear in a project,
** at the top of a C source file (outside of any function).
**
** The following constants can be used to set FOSCSEL.
** Multiple options may be combined, as shown:
**
** _FOSCSEL( OPT1_ON & OPT2_OFF & OPT3_PLL )
**
** Oscillator Source Selection:
** FNOSC_FRC Internal Fast RC (FRC)
** FNOSC_FRCPLL Fast RC Oscillator with divide-by-N with PLL module (FRCPLL)
** FNOSC_PRI Primary Oscillator (XT, HS, EC)
** FNOSC_PRIPLL Primary Oscillator with PLL module (XT + PLL, HS + PLL, EC + PLL)
** FNOSC_LPRC Low-Power RC Oscillator (LPRC)
** FNOSC_FRCDIVN Internal Fast RC (FRC) Oscillator with postscaler
**
** Two-speed Oscillator Start-up Enable bit:
** IESO_OFF Start up with user-selected oscillator source
** IESO_ON Start up device with FRC, then switch to user-selected oscillator source
**
*/
#define FNOSC_FRC 0xFFF8
#define FNOSC_FRCPLL 0xFFF9
#define FNOSC_PRI 0xFFFA
#define FNOSC_PRIPLL 0xFFFB
#define FNOSC_LPRC 0xFFFD
#define FNOSC_FRCDIVN 0xFFFF
#define IESO_OFF 0xFF7F
#define IESO_ON 0xFFFF
由头文件得知
1:Register FOSCSEL (0x57f8),也就是寄存器地址是0x57f8,和表格一致。
2:_FOSCSEL(FNOSC_PRI&IESO_OFF); 我们在程序开头由此句来声明我们的配置位是0XFFFA&0XFF7F=0XFF7A
也就是FOSCSEL=0XFF7A 根据寄存器说明得知我们的配置是外部HS振荡器并使用用户选择的振荡器源启动器件
3:配置位只是说明使用的振荡器,并不设置分频比DOZE。因此DOZE还是默认的8分频。
总结:配置时钟有以下几个方面:
1:配置相应的配置位选择时钟源是内部时钟还是外部晶振等。
2:配置相应的寄存器选择分频比。
史海拾趣
|
【ISSCC】美国UCLA新型软件无线RF芯片,融合宽带电路与离散时间处理功能 美国UCLA(University of California, Los Angeles,加利福尼亚大学洛杉矶分校)和美国WiLinx公司在日前召开的“ISSCC 2006”会议上发表了面向软件无线设备的宽带接收IC。该芯片支持800MHz频带~5GHz频带,可满足IEEE802.11g、GSM、CDMA和W-CDMA等 ...… 查看全部问答> |
|
倒车雷达的超声波测距最简单的单芯片控制方案 GM3101 是专用于倒车雷达的超声波测距芯片,该芯片提供4 路超声波探头的驱动,并根据超声波特性和倒车雷达的使用环境进行了一系列智能化处理,在保证超声波测距精确性的基础上,更加强了报警功能的准 ...… 查看全部问答> |
|
工程师在FPGA设计中面临的挑战?大家来谈谈吧!市场需要?绿色设计? 最近的新闻常看到Xilix出了65ns工艺的FPGA,Altera也推出40ns的收发器FPGA,工艺不断提高,容量不断扩大,加入的IP核也越来越多,但实际FPGA设计中,工程师选择FPGA中考虑的是什么呢? 第一个个应该是市场吧,市场需要 ...… 查看全部问答> |
|
Searl Effect Technology and the inventor of the Searl Effect Generator (SEG) 塞尔效应技术及塞尔效应发电机的发明者 PART 1: The Searl Effect Generator (SEG) has the functional resemblance to a linear induction motor (LIM) designed on a vertical track, rounded and joined at the ends for continuous motion ...… 查看全部问答> |
|
有谁做过marvell 8688 wifi的驱动,我用的是SPI接口,平台是三星的2440,怎么加载上GSPI8688_WLAN.dll后。winCE上不能正确出现正常的网络连接。… 查看全部问答> |
|
哪位大虾能给指点一下?谢谢! 我现在修改了bsp_cfg.h中的S3C2440A_FCLK和startup.s中的MPLL,结果内核启动到初始化NandFlash之前就挂了.… 查看全部问答> |
|
新人提问,,请大家帮帮忙,关于windows Embedded 我用的是华为的MAS.里面采用的是Windows Embedded sp1 问题有几个 第一个是 我想装一下IIS,可是添加删除里面无法安装.我应该怎么操作 第二个是 华为MAS的某些自带的程序可能组件化了.我该如何停止掉呢 第三个是 我打SP2补丁上去好像 ...… 查看全部问答> |
|
CCSv4.0.2,32k限制版安装完成后,说是此版本没有自带XDSv2的驱动。之后给出更新方法,但是在URL的框输入http://software-dl.ti.com/dsps/dsps_public_sw/sdo_ccstudio/CCSv4/Updates/XDS100V2/site.xml,更新提示说URL错误。 谁能提供一个正确的UR ...… 查看全部问答> |






