共2条
1/1 1 跳转至页
2407 请教各位高手关于2407实际运行速度的问题。
问
我用12M晶振,2倍频,锁相环滤波器电容电阻按照Datasheet上的数据配置。目的想测量IOPC5产生方波的频率以计算实际运行速度。但是测得频率值仅有140k(反汇编后发现while循环一共有8周期的指令),居然比单片机还慢……
希望各位高手指教。
程序如下:
#include "regs240x.h"
void PHANTOM();
void initiate()
{
SCSR1 &= 0xf2ff;
PCDATDIR |= 0x2000;
}
void main()
{
initiate();
while (1)
{
PCDATDIR ^= 0x0020;
};
}
void PHANTOM()
{
while(1); /* a place to hang if illegal trap */
} 答 1: 我20M主频可以输出1.66M方波如果头文件没有特别定义,应该*PCDATDIR ^= 0x0020;
答 2: 好像是仿真器的问题。刚刚试着将程序烧进DSP中,然后拔掉仿真器再执行,就可以产生1.16MHz的方波。难道说带着仿真器执行与实际速度相差这么大?这个仿真也太不真了吧。而且CLKOUT还输出22MHz……我用的是闻亭的TDS510。
头文件是这样定义的:
#define PCDATDIR *((volatile int *)0x709C) /* I/O port C Data & Direction reg. */
答 3: 我用SEED仿真下得到的结果 答 4: 这个比较奇怪了……用2407我最高跑过48M,很稳定, 答 5: WSGR的问题。已经解决了,我是把程序下载到片外RAM中,而没有设置等待周期。
初始化程序里加上这一句就可以了。
WSGR &= 0xffc0;
希望各位高手指教。
程序如下:
#include "regs240x.h"
void PHANTOM();
void initiate()
{
SCSR1 &= 0xf2ff;
PCDATDIR |= 0x2000;
}
void main()
{
initiate();
while (1)
{
PCDATDIR ^= 0x0020;
};
}
void PHANTOM()
{
while(1); /* a place to hang if illegal trap */
} 答 1: 我20M主频可以输出1.66M方波如果头文件没有特别定义,应该*PCDATDIR ^= 0x0020;
答 2: 好像是仿真器的问题。刚刚试着将程序烧进DSP中,然后拔掉仿真器再执行,就可以产生1.16MHz的方波。难道说带着仿真器执行与实际速度相差这么大?这个仿真也太不真了吧。而且CLKOUT还输出22MHz……我用的是闻亭的TDS510。
头文件是这样定义的:
#define PCDATDIR *((volatile int *)0x709C) /* I/O port C Data & Direction reg. */
答 3: 我用SEED仿真下得到的结果 答 4: 这个比较奇怪了……用2407我最高跑过48M,很稳定, 答 5: WSGR的问题。已经解决了,我是把程序下载到片外RAM中,而没有设置等待周期。
初始化程序里加上这一句就可以了。
WSGR &= 0xffc0;
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
vscode+cmake搭建雅特力AT32L021开发环境被打赏30分 | |
【换取逻辑分析仪】自制底板并驱动ArduinoNanoRP2040ConnectLCD扩展板被打赏47分 | |
【分享评测,赢取加热台】RISC-V GCC 内嵌汇编使用被打赏38分 | |
【换取逻辑分析仪】-基于ADI单片机MAX78000的简易MP3音乐播放器被打赏48分 | |
我想要一部加热台+树莓派PICO驱动AHT10被打赏38分 | |
【换取逻辑分析仪】-硬件SPI驱动OLED屏幕被打赏36分 | |
换逻辑分析仪+上下拉与多路选择器被打赏29分 | |
Let'sdo第3期任务合集被打赏50分 | |
换逻辑分析仪+Verilog三态门被打赏27分 | |
换逻辑分析仪+Verilog多输出门被打赏24分 |