上一篇文章介绍了rdtsc指令的精确计时,不过由于CPU的频率不能保证是固定的,所以这样的方式还是有限制。其实linux下还有一种高精度的定时器,那就是posix_timer。我记得以前看代码的时候CLOCK_REALTIME的定时器似乎用的就是rdtsc指令,不过现在不确定了,先放到一边。原理上来说,可以在变频的时候也使用rdtsc指令,因为CPU的频率我们也是知道的,变频的时候内核也是知道的。

下面是我的timer_create的例子,编译的时候要加上rt库,这是linux的realtime库:

gcc -o test test.c -lrt

#include <stdio.h>
#include 
<unistd.h>
#include 
<signal.h>
#include 
<stdlib.h>
#include 
<time.h>

#define rdtsc(low,high) __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high))

timer_t tt;

void handler (int sig, siginfo_t * extra, void *cruft)
{
  
static last_i=0;
  unsigned 
int i, j;
  rdtsc(i,j);
  printf (
"time:%u, %u, [%u] %uHZ ", j, i, i-last_i, (i-last_i)*10/1000000);
  last_i 
= i;
}


int main ()
{
  
int i=0;
  sigset_t sigset;

  sigfillset (
&sigset);
  sigdelset (
&sigset, SIGRTMIN);
  sigprocmask (SIG_SETMASK, 
&sigset, NULL);

  
struct sigaction sa;
  sigfillset (
&sa.sa_mask);
  sa.sa_flags 
= SA_SIGINFO;
  sa.sa_sigaction 
= handler;

  
if (sigaction (SIGRTMIN, &sa, NULL) < 0)
  
{
    perror (
"sigaction failed ");
    exit (
-1);
  }


  
struct sigevent timer_event;
  
struct itimerspec timer;

  timer.it_interval.tv_sec 
= 0;
  timer.it_interval.tv_nsec 
= 100 * 1000 * 1000;
  timer.it_value 
= timer.it_interval;

  timer_event.sigev_notify 
= SIGEV_SIGNAL;
  timer_event.sigev_signo 
= SIGRTMIN;
  timer_event.sigev_value.sival_ptr 
= (void *&tt;

  
if (timer_create (CLOCK_REALTIME, &timer_event, &tt) < 0)
  
{
    perror (
"timer_create failed");
    exit (
-1);
  }


  
if (timer_settime (tt, 0&timer, NULL) < 0)
  
{
    perror (
"timer_settime failed");
    exit (
-1);
  }


  
while (i++ < 10)
  
{
    pause ();
  }


  
return 0;
}

输出结果:

time:166081, 1934350847, [1934350847] 2163HZ
time:166081, 2120528291, [186177444] 1861HZ
time:166081, 2306679576, [186151285] 1861HZ
time:166081, 2494695630, [188016054] 1880HZ
time:166081, 2680865389, [186169759] 1861HZ
time:166081, 2867018473, [186153084] 1861HZ
time:166081, 3053152230, [186133757] 1861HZ
time:166081, 3239309935, [186157705] 1861HZ
time:166081, 3425467261, [186157326] 1861HZ
time:166081, 3611639266, [186172005] 1861HZ
 

GitHub 加速计划 / li / linux-dash
13
2
下载
A beautiful web dashboard for Linux
最近提交(Master分支:4 个月前 )
186a802e added ecosystem file for PM2 5 年前
5def40a3 Add host customization support for the NodeJS version 5 年前
Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐