3537
- 收藏
- 点赞
- 分享
- 举报
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毫秒;
问题:
该芯片的精度这么低???
我来回答
回答11个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片
相关问答
-
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
-
2020-11-06 11:35:39
-
2016-10-19 15:12:58
-
2016-04-15 14:46:24
-
2021-01-09 16:02:40
-
2018-12-24 10:56:36
-
172025-01-06 08:50:59
-
2020-07-09 19:17:48
-
2019-07-23 17:25:48
-
2021-01-04 10:51:51
-
2017-05-19 16:28:28
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5hisi3516cv610 + gc4336p 夜晚很模糊
-
5AIISP(功能演示,SC4336P为BGGR,强制转RGGB,会导致颜色异常)
-
5rv1106使用luckfox的SDK,设备树和驱动都写好了,结果设备文件没有生成
-
5海思3516cv610中如何进行SD卡升级,根据官方文档操作,烧录进板子时,走的默认uboot,没有执行uboot升级。
-
5G610Q-IPC-38E 夜晚很暗 有什么办法解决吗 已经补光了
-
10转换模型时,SoC版本里没显示hi3516cv610芯片
-
5hisi3516cv610 使用 yolov8n 模型训练 要如何提高 这里识别的是人
-
10有人在海思平台接过SC035HGS吗
-
5关于hi3519dv500,以SD卡虚拟 U 盘操作
-
5ss928 sample_venc代码移植到openEuler24.03上执行报错 [sample_comm_vi_start_dev]-1068: vi set dev attr failed wi
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认

微信扫码分享
QQ好友