我用g++编译了下面的测试,这个时间间隔太长了
60微秒完成,我预计它只需要不到1微秒:

int main()
{
    gettimeofday(&startx, NULL);
    struct timespec req={0};
    req.tv_sec=0;
    req.tv_nsec=100 ;
    nanosleep(&req,NULL) ;
    gettimeofday(&endx, NULL);
    printf("(%d)(%d)\n",startx.tv_sec,startx.tv_usec);
    printf("(%d)(%d)\n",endx.tv_sec,endx.tv_usec);
    return 0 ;
}

我的环境:uname-r显示:
3.10.0-123.el7.x86_64

猫/启动/配置-uname -r| grep赫兹
CONFIG_NO_HZ_COMMON=y
# CONFIG_HZ_PERIODIC is not set
# CONFIG_NO_HZ_IDLE is not set
CONFIG_NO_HZ_FULL=y
# CONFIG_NO_HZ_FULL_ALL is not set
CONFIG_NO_HZ=y
# CONFIG_RCU_FAST_NO_HZ is not set
# CONFIG_HZ_100 is not set
# CONFIG_HZ_250 is not set
# CONFIG_HZ_300 is not set
CONFIG_HZ_1000=y
CONFIG_HZ=1000
CONFIG_MACHZ_WDT=m

我应该在HZ配置中做些什么,这样nanosleep就可以完全满足我的期望吗?!
我的cpu信息:
Architecture:          x86_64
CPU op-mode(s):        32-bit, 64-bit
Byte Order:            Little Endian
CPU(s):                24
On-line CPU(s) list:   0-23
Thread(s) per core:    2
Core(s) per socket:    6
Socket(s):             2
NUMA node(s):          2
Vendor ID:             GenuineIntel
CPU family:            6
Model:                 63
Model name:            Intel(R) Xeon(R) CPU E5-2643 v3 @ 3.40GHz
Stepping:              2
CPU MHz:               3600.015
BogoMIPS:              6804.22
Virtualization:        VT-x
L1d cache:             32K
L1i cache:             32K
L2 cache:              256K
L3 cache:              20480K
NUMA node0 CPU(s):     0,2,4,6,8,10,12,14,16,18,20,22
NUMA node1 CPU(s):     1,3,5,7,9,11,13,15,17,19,21,23

编辑:
#ifdef SYS_gettid
    pid_t tid = syscall(SYS_gettid);
    printf("thread1...tid=(%d)\n",tid);
#else
    #error "SYS_gettid unavailable on this system"
#endif

这将得到我喜欢的高优先级线程的tid,然后
chrt-v-r-p 99 tid实现这一目标,感谢Johan Boule
好心的帮助,非常感谢!!!
编辑2:
#ifdef SYS_gettid
    const char *sched_policy[] = {
    "SCHED_OTHER",
    "SCHED_FIFO",
    "SCHED_RR",
    "SCHED_BATCH"
    };
    struct sched_param sp = {
        .sched_priority = 99
    };
    pid_t tid = syscall(SYS_gettid);
    printf("thread1...tid=(%d)\n",tid);
    sched_setscheduler(tid, SCHED_RR, &sp);
    printf("Scheduler Policy is %s.\n", sched_policy[sched_getscheduler(0)]);
#else
    #error "SYS_gettid unavailable on this system"
#endif

如果没有chrt的帮助,我会做我想做的事情

最佳答案

(这不是答案)
值得一提的是,使用更现代化的功能会得到同样的结果:

#include <stddef.h>
#include <time.h>
#include <stdio.h>

int main()
{
    struct timespec startx, endx;
    clock_gettime(CLOCK_MONOTONIC, &startx);
    struct timespec req={0};
    req.tv_sec=0;
    req.tv_nsec=100 ;
    clock_nanosleep(CLOCK_MONOTONIC, 0, &req, NULL);
    clock_gettime(CLOCK_MONOTONIC, &endx);
    printf("(%d)(%d)\n",startx.tv_sec,startx.tv_nsec);
    printf("(%d)(%d)\n",endx.tv_sec,endx.tv_nsec);
    return 0 ;
}

输出:
(296441)(153832940)
(296441)(153888488)

关于linux - nanosleep sleep 时间太长60微秒,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/37105964/

10-10 06:47