Почему мой дебоузер не работает?

Я пытаюсь написать debouncer, который будет возвращать действительный аргумент (>0), если он был опровергнут (-1 четыре подпрыгивая). Я придумал это до сих пор, но он всегда возвращает -1, почему я задаюсь вопросом:

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

#define BOUNCETIME  500000000 //(500ms)

#define SetTime(x)     clock_gettime(CLOCK_REALTIME, (x));  // set time

static struct timespec tset;
struct timespec tnow;

int DeBounce(unsigned int arg)
{  
  static int val = -1;
  long long nsec = 0;
  if (val < 0) {
    val = arg;
    SetTime(&tset);  
    return arg;    
  } else {
    SetTime(&tnow);
    if (tnow.tv_nsec < tset.tv_nsec)
      nsec = tnow.tv_nsec + 1000000000;
    else
      nsec = tnow.tv_nsec;
    if (tnow.tv_nsec - tset.tv_nsec > BOUNCETIME) {
      printf("arg okay\n"); 
      val = -1;
      return arg;
    }
    else 
      printf("bounce, ignore!\n");
      return -1;
  }

}

int main (void) 
{
  printf("#1 %d\n",DeBounce(0));
  usleep(1);
  printf("#2 %d\n",DeBounce(1));
  usleep(200);
  printf("#3 %d\n",DeBounce(1));
  sleep(1);
  printf("#4 %d\n",DeBounce(1));
}

результат, который я получаю:

$ ./debounce 
#1 0
bounce, ignore!
#2 -1
bounce, ignore!
#3 -1
bounce, ignore!
#4 -1
$

1 ответ

usleep(600); составляет 600 микросекунд. Но ваш период отката составляет 500 миллисекунд.

более того tnow.tv_nsec - tset.tv_nsec не правильно как tv_nsec не полное значение времени, а только число наносекунд после секунды. Правильный способ подсчета истекшего времени в наносекундах примерно такой:

(tnow.tv_sec * 1.0e-9 + tnow.tv_nsec) - (tset.tv_sec * 1.0e-9 + tset.tv_nsec)
Другие вопросы по тегам