wangzhengquan
2021-02-02 cb85aa8a8d02a3d6dc16e3f32e78da9e70f9c7f5
src/psem.cpp
@@ -1,26 +1,11 @@
#include "psem.h"
#include <semaphore.h>
#include "time_util.h"
#define NANO 1000000000
static struct timespec psem_calc_abs_timeout(const struct timespec *ts) {
   struct timespec res;
  struct timespec timeout;
  if (clock_gettime(CLOCK_REALTIME, &timeout) == -1)
      err_exit(errno, "clock_gettime");
  res.tv_sec = timeout.tv_sec + ts->tv_sec;
  res.tv_nsec = timeout.tv_nsec + ts->tv_nsec;
  res.tv_sec = res.tv_sec + floor(res.tv_nsec / NANO);
  res.tv_nsec = res.tv_nsec % NANO;
  return res;
}
int psem_timedwait(sem_t *sem, const struct timespec *ts) {
   struct timespec abs_timeout = psem_calc_abs_timeout(ts);
   struct timespec abs_timeout = TimeUtil::calc_abs_time(ts);
  int rv ;
  while ( (rv = sem_timedwait(sem, &abs_timeout)) == -1) {
@@ -28,7 +13,7 @@
          continue;
      else {
         // LoggerFactory::getLogger()->error(errno, "LockFreeQueue push_timeout");
         return rv;
         return -1;
      }
  }
  return 0;
@@ -42,7 +27,7 @@
          continue;
      else {
         // LoggerFactory::getLogger()->error(errno, "LockFreeQueue push_timeout");
         return rv;
         return -1;
      }
  }
  return 0;