OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6798|回复: 9

delay_ms()函数失效

[复制链接]

8

主题

54

帖子

0

精华

初级会员

Rank: 2

积分
135
金钱
135
注册时间
2012-10-18
在线时间
7 小时
发表于 2013-10-3 00:18:12 | 显示全部楼层 |阅读模式
    程序很简单, 就是通过ADC1_CH1连续采集n个值储存在数组中,然后通过串口一次过送到电脑去,然后使用delay_ms(1000);延时1S。调试中发现只要n>=449,delay_ms函数就工作不正常了,本来应该延时1000ms的,实际延时了估计只有几十ms,但是n<449就一切都正常。
    MCU用的是RBT6, 20K的SRAM,肯定没溢出,但是看.map文件无论n是几内存占用都是
1 397 bytes of readwrite data memory.

#define TIME 449

int main(void)
{
u16 dat[TIME];
u16 i;

delay_init();     //延时函数初始化  
NVIC_Configuration(); //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
uart_init(9600); //串口初始化为9600
ADC_CaptureInit();

while(1)
{    
for(i=0;i<TIME;i++)
{
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));
dat = ADC_GetConversionValue(ADC1);
}
printf("------------------------\r\n");
for(i=0;i<TIME;i++)
{
printf("%d\r\n",dat);
}
printf("------------------------\r\n");
delay_ms(1000);
}
}
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

68

主题

212

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
312
金钱
312
注册时间
2013-5-7
在线时间
28 小时
发表于 2013-10-3 09:59:33 | 显示全部楼层
我也碰到过delay函数失效的问题。后来改改程序就好了
回复 支持 反对

使用道具 举报

54

主题

1008

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
2385
金钱
2385
注册时间
2012-11-22
在线时间
403 小时
发表于 2013-10-3 14:50:46 | 显示全部楼层
这个貌似不是delay的问题,是串口打印的数量有限制。。。
态度决定一切
回复 支持 反对

使用道具 举报

57

主题

431

帖子

1

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
886
金钱
886
注册时间
2011-12-25
在线时间
12 小时
发表于 2013-10-3 15:10:22 | 显示全部楼层
回复【楼主位】散装805:
---------------------------------
这个工程有用到中断吗??
如果有,中断里面有delay吗?
很喜爱电子行业
回复 支持 反对

使用道具 举报

8

主题

54

帖子

0

精华

初级会员

Rank: 2

积分
135
金钱
135
注册时间
2012-10-18
在线时间
7 小时
 楼主| 发表于 2013-10-3 18:37:03 | 显示全部楼层
回复【4楼】冰是睡着的水:
---------------------------------
没有任何中断
回复 支持 反对

使用道具 举报

8

主题

54

帖子

0

精华

初级会员

Rank: 2

积分
135
金钱
135
注册时间
2012-10-18
在线时间
7 小时
 楼主| 发表于 2013-10-3 18:38:27 | 显示全部楼层
回复【3楼】冰封嗜魔:
---------------------------------
循环printf打印而已啊,单次打印的内容并不多啊、?
回复 支持 反对

使用道具 举报

8

主题

54

帖子

0

精华

初级会员

Rank: 2

积分
135
金钱
135
注册时间
2012-10-18
在线时间
7 小时
 楼主| 发表于 2013-10-3 18:45:05 | 显示全部楼层
回复【2楼】maxuejia:
---------------------------------
请问还记得是怎么调的么?这问题真的奇怪死了
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-10-3 23:08:59 | 显示全部楼层
回复【7楼】散装805:
---------------------------------
把dat数组放到外面试试。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

8

主题

54

帖子

0

精华

初级会员

Rank: 2

积分
135
金钱
135
注册时间
2012-10-18
在线时间
7 小时
 楼主| 发表于 2013-10-4 10:26:40 | 显示全部楼层
回复【8楼】正点原子:
---------------------------------
还真解决了.谢谢原子!可是这是为什么呢?没想懂。
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-10-4 11:12:36 | 显示全部楼层
回复【9楼】散装805:
---------------------------------
局部变量太多,堆栈溢出。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-12 10:59

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表