3031
- 收藏
- 点赞
- 分享
- 举报
HISI3531A定时精度很不准确
各位好:
本人在使用定时操作时发现其定时的精度很不准确,下面是本人的测试例子:
include
#include
#include
#include
#include
#include
#define user_gettimeofday(a, b) do{struct timespec res;clock_gettime(CLOCK_MONOTONIC, &res); (a)->tv_sec = res.tv_sec; (a)->tv_usec = res.tv_nsec/1000;}while(0)
int delay(unsigned ms)
{
struct timeval tv;
tv.tv_sec = ms/1000;
tv.tv_usec = (ms%1000)*1000;
return select(0, NULL, NULL, NULL, &tv);
}
int main(int argc, char **argv)
{
unsigned int InterlaceTime = atoi(argv[1]);
printf("InterlaceTime %u\n", InterlaceTime);
struct timeval CurTime;
while(1) {
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int a = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("select return %d\n", delay(InterlaceTime));
//usleep(InterlaceTime);
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int b = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("%u - %u = %u\n", b, a, b-a);
}
return 0;
}
测试结果:
定时30毫秒,实际通过计算得到的定时间隔是40ms;
经多次验证,发现其精度仅10毫秒;
问题:
该芯片的精度这么低???
本人在使用定时操作时发现其定时的精度很不准确,下面是本人的测试例子:
include
#include
#include
#include
#include
#include
#define user_gettimeofday(a, b) do{struct timespec res;clock_gettime(CLOCK_MONOTONIC, &res); (a)->tv_sec = res.tv_sec; (a)->tv_usec = res.tv_nsec/1000;}while(0)
int delay(unsigned ms)
{
struct timeval tv;
tv.tv_sec = ms/1000;
tv.tv_usec = (ms%1000)*1000;
return select(0, NULL, NULL, NULL, &tv);
}
int main(int argc, char **argv)
{
unsigned int InterlaceTime = atoi(argv[1]);
printf("InterlaceTime %u\n", InterlaceTime);
struct timeval CurTime;
while(1) {
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int a = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("select return %d\n", delay(InterlaceTime));
//usleep(InterlaceTime);
//gettimeofday(&CurTime, NULL);
user_gettimeofday(&CurTime, NULL);
unsigned int b = CurTime.tv_sec*1000 + CurTime.tv_usec/1000;
printf("%u - %u = %u\n", b, a, b-a);
}
return 0;
}
测试结果:
定时30毫秒,实际通过计算得到的定时间隔是40ms;
经多次验证,发现其精度仅10毫秒;
问题:
该芯片的精度这么低???
我来回答
回答10个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2016-07-20 11:45:40
-
2016-07-20 11:41:30
-
2016-11-28 16:33:39
-
2019-01-03 09:38:05
-
42018-06-09 15:31:27
-
2019-01-03 15:23:22
-
2023-07-13 15:58:31
-
2018-12-10 13:49:22
-
2019-01-22 14:19:32
-
2016-04-15 14:46:24
-
2019-07-23 17:25:48
-
2017-05-19 16:28:28
-
2021-01-04 10:51:51
-
2018-12-24 10:56:36
-
2013-08-26 23:31:11
-
2016-10-19 15:12:58
-
2020-11-06 11:35:39
-
2020-07-09 19:17:48
-
2008-09-18 14:26:02
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
10海思IVP928
-
522AP10支持F35SQA001G spi nand flash
-
20如何将自有训练的RAW降噪模型应用于AIBNR?
-
10RV1106的低功耗和休眠唤醒功能
-
10海思平台(Hi3516DV500),设置完ldc参数后 工作异常
-
5rv1126-dc-201 安装hi3881.ko wifi驱动成功后 启动connmand服务,系统就崩了
-
10ss928编码的h264帧流,用RTSP传输到电脑,VLC播放不了是什么情况?
-
10我运行rv1126的开发环境后,编译demo提示没有opencv,自行编译安装后没有解决,请问这个怎么处理呢?板子是easy eai nano
-
50CPS-1848 link不上FPGA。
-
10想问一下各位大佬们,关于VI配置成8Lan LVDS模式的相关问题
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认