共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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 基于MCP23S17的输入输出功能模块控制被打赏¥20元 | |
| 【S32K3XX】SPD 软件包使用Link文件修改被打赏¥22元 | |
| Switch-Case局部变量定义问题被打赏¥23元 | |
| 基于米尔TIAM62L开发板的串口通信及应用被打赏¥20元 | |
| PCF8574功能模块及其使用被打赏¥20元 | |
| 传感器LSM6DSO及LIS3MDL的功能检测被打赏¥18元 | |
| LPS25HB气压传感器及其检测被打赏¥18元 | |
| HTS221温湿度传感器及其检测被打赏¥18元 | |
| 【S32K3XX】HSE FW 版本更新被打赏¥21元 | |
| 基于ArduinoUNO开发板的AT24C02读写测试被打赏¥16元 | |
我要赚赏金
