diff options
| author | Yaniv Kaul <ykaul@redhat.com> | 2018-10-13 00:56:42 +0300 | 
|---|---|---|
| committer | Amar Tumballi <amarts@redhat.com> | 2018-10-16 06:33:29 +0000 | 
| commit | 98f68cf115a30a101d3be2252ecbe1391720ed88 (patch) | |
| tree | 4a9da66f8833a936eba95fc078a4605acd632f4f | |
| parent | fd70a7d790710da01a8ddd56785a28ab54e07550 (diff) | |
Multiple xlators: perform gettimeofday() not under lock
While it may slightly reduce accuracy, I think it's better to
acquire the time outside a lock and then memcpy the value while
under lock.
Compile-tested only!
updates: bz#1193929
Signed-off-by: Yaniv Kaul <ykaul@redhat.com>
Change-Id: Ic8fb94a56c4fa2d3b13e59767e13646fb39342ba
| -rw-r--r-- | xlators/debug/io-stats/src/io-stats.c | 7 | ||||
| -rw-r--r-- | xlators/features/locks/src/entrylk.c | 6 | ||||
| -rw-r--r-- | xlators/features/locks/src/inodelk.c | 6 | ||||
| -rw-r--r-- | xlators/features/quota/src/quota.c | 12 | ||||
| -rw-r--r-- | xlators/performance/io-cache/src/io-cache.c | 12 | ||||
| -rw-r--r-- | xlators/performance/io-cache/src/page.c | 6 | ||||
| -rw-r--r-- | xlators/performance/quick-read/src/quick-read.c | 6 | 
7 files changed, 42 insertions, 13 deletions
diff --git a/xlators/debug/io-stats/src/io-stats.c b/xlators/debug/io-stats/src/io-stats.c index 6f6104033d8..3c7e7cf1ea4 100644 --- a/xlators/debug/io-stats/src/io-stats.c +++ b/xlators/debug/io-stats/src/io-stats.c @@ -275,6 +275,9 @@ is_fop_latency_started(call_frame_t *frame)          struct timespec *begin, *end;                                          \          double throughput;                                                     \          int flag = 0;                                                          \ +        struct timeval tv = {                                                  \ +            0,                                                                 \ +        };                                                                     \                                                                                 \          begin = &frame->begin;                                                 \          end = &frame->end;                                                     \ @@ -285,11 +288,13 @@ is_fop_latency_started(call_frame_t *frame)          throughput = op_ret / elapsed;                                         \                                                                                 \          conf = this->private;                                                  \ +        gettimeofday(&tv, NULL);                                               \          LOCK(&iosstat->lock);                                                  \          {                                                                      \              if (iosstat->thru_counters[type].throughput <= throughput) {       \                  iosstat->thru_counters[type].throughput = throughput;          \ -                gettimeofday(&iosstat->thru_counters[type].time, NULL);        \ +                memcpy(&iosstat->thru_counters[type].time, &tv,                \ +                       sizeof(struct timeval));                                \                  flag = 1;                                                      \              }                                                                  \          }                                                                      \ diff --git a/xlators/features/locks/src/entrylk.c b/xlators/features/locks/src/entrylk.c index ea78f92d200..60e7bed2a44 100644 --- a/xlators/features/locks/src/entrylk.c +++ b/xlators/features/locks/src/entrylk.c @@ -115,7 +115,6 @@ __stale_entrylk(xlator_t *this, pl_entry_lock_t *candidate_lock,  {      posix_locks_private_t *priv = NULL;      struct timeval curr; -    gettimeofday(&curr, NULL);      priv = this->private; @@ -123,6 +122,7 @@ __stale_entrylk(xlator_t *this, pl_entry_lock_t *candidate_lock,       * chance?  Or just the locks we are attempting to acquire?       */      if (names_conflict(candidate_lock->basename, requested_lock->basename)) { +        gettimeofday(&curr, NULL);          *lock_age_sec = curr.tv_sec - candidate_lock->granted_time.tv_sec;          if (*lock_age_sec > priv->revocation_secs)              return _gf_true; @@ -541,11 +541,11 @@ __lock_blocked_add(xlator_t *this, pl_inode_t *pinode, pl_dom_list_t *dom,  {      struct timeval now; -    gettimeofday(&now, NULL); -      if (nonblock)          goto out; +    gettimeofday(&now, NULL); +      lock->blkd_time = now;      list_add_tail(&lock->blocked_locks, &dom->blocked_entrylks); diff --git a/xlators/features/locks/src/inodelk.c b/xlators/features/locks/src/inodelk.c index eff58a79569..b8e005038d8 100644 --- a/xlators/features/locks/src/inodelk.c +++ b/xlators/features/locks/src/inodelk.c @@ -145,11 +145,11 @@ __stale_inodelk(xlator_t *this, pl_inode_lock_t *candidate_lock,      struct timeval curr;      priv = this->private; -    gettimeofday(&curr, NULL);      /* Question: Should we just prune them all given the       * chance?  Or just the locks we are attempting to acquire?       */      if (inodelk_conflict(candidate_lock, requested_lock)) { +        gettimeofday(&curr, NULL);          *lock_age_sec = curr.tv_sec - candidate_lock->granted_time.tv_sec;          if (*lock_age_sec > priv->revocation_secs)              return _gf_true; @@ -403,12 +403,12 @@ __lock_blocked_add(xlator_t *this, pl_dom_list_t *dom, pl_inode_lock_t *lock,  {      struct timeval now; -    gettimeofday(&now, NULL); -      if (can_block == 0) {          goto out;      } +    gettimeofday(&now, NULL); +      lock->blkd_time = now;      list_add_tail(&lock->blocked_locks, &dom->blocked_inodelks); diff --git a/xlators/features/quota/src/quota.c b/xlators/features/quota/src/quota.c index 6310967fc0d..0b81e370e43 100644 --- a/xlators/features/quota/src/quota.c +++ b/xlators/features/quota/src/quota.c @@ -591,6 +591,9 @@ quota_validate_cbk(call_frame_t *frame, void *cookie, xlator_t *this,      quota_meta_t size = {          0,      }; +    struct timeval tv = { +        0, +    };      local = frame->local; @@ -628,12 +631,13 @@ quota_validate_cbk(call_frame_t *frame, void *cookie, xlator_t *this,                                  * loop of validation and checking                                  * limit when timeout is zero.                                  */ +    gettimeofday(&tv, NULL);      LOCK(&ctx->lock);      {          ctx->size = size.size;          ctx->file_count = size.file_count;          ctx->dir_count = size.dir_count; -        gettimeofday(&ctx->tv, NULL); +        memcpy(&ctx->tv, &tv, sizeof(struct timeval));      }      UNLOCK(&ctx->lock); @@ -4306,6 +4310,9 @@ quota_statfs_validate_cbk(call_frame_t *frame, void *cookie, xlator_t *this,      quota_meta_t size = {          0,      }; +    struct timeval tv = { +        0, +    };      local = frame->local; @@ -4337,12 +4344,13 @@ quota_statfs_validate_cbk(call_frame_t *frame, void *cookie, xlator_t *this,          op_errno = EINVAL;      } +    gettimeofday(&tv, NULL);      LOCK(&ctx->lock);      {          ctx->size = size.size;          ctx->file_count = size.file_count;          ctx->dir_count = size.dir_count; -        gettimeofday(&ctx->tv, NULL); +        memcpy(&ctx->tv, &tv, sizeof(struct timeval));      }      UNLOCK(&ctx->lock); diff --git a/xlators/performance/io-cache/src/io-cache.c b/xlators/performance/io-cache/src/io-cache.c index e8e04c03434..6ffad7d1a64 100644 --- a/xlators/performance/io-cache/src/io-cache.c +++ b/xlators/performance/io-cache/src/io-cache.c @@ -360,6 +360,9 @@ ioc_cache_validate_cbk(call_frame_t *frame, void *cookie, xlator_t *this,      ioc_inode_t *ioc_inode = NULL;      size_t destroy_size = 0;      struct iatt *local_stbuf = NULL; +    struct timeval tv = { +        0, +    };      local = frame->local;      ioc_inode = local->inode; @@ -397,9 +400,10 @@ ioc_cache_validate_cbk(call_frame_t *frame, void *cookie, xlator_t *this,      if (op_ret < 0)          local_stbuf = NULL; +    gettimeofday(&tv, NULL);      ioc_inode_lock(ioc_inode);      { -        gettimeofday(&ioc_inode->cache.tv, NULL); +        memcpy(&ioc_inode->cache.tv, &tv, sizeof(struct timeval));      }      ioc_inode_unlock(ioc_inode); @@ -1338,6 +1342,9 @@ ioc_lk(call_frame_t *frame, xlator_t *this, fd_t *fd, int32_t cmd,  {      ioc_inode_t *ioc_inode = NULL;      uint64_t tmp_inode = 0; +    struct timeval tv = { +        0, +    };      inode_ctx_get(fd->inode, this, &tmp_inode);      ioc_inode = (ioc_inode_t *)(long)tmp_inode; @@ -1348,9 +1355,10 @@ ioc_lk(call_frame_t *frame, xlator_t *this, fd_t *fd, int32_t cmd,          return 0;      } +    gettimeofday(&tv, NULL);      ioc_inode_lock(ioc_inode);      { -        gettimeofday(&ioc_inode->cache.tv, NULL); +        memcpy(&ioc_inode->cache.tv, &tv, sizeof(struct timeval));      }      ioc_inode_unlock(ioc_inode); diff --git a/xlators/performance/io-cache/src/page.c b/xlators/performance/io-cache/src/page.c index dada4ebc55b..c376ade0fba 100644 --- a/xlators/performance/io-cache/src/page.c +++ b/xlators/performance/io-cache/src/page.c @@ -413,6 +413,9 @@ ioc_fault_cbk(call_frame_t *frame, void *cookie, xlator_t *this, int32_t op_ret,      ioc_waitq_t *waitq = NULL;      size_t iobref_page_size = 0;      char zero_filled = 0; +    struct timeval tv = { +        0, +    };      GF_ASSERT(frame); @@ -428,6 +431,7 @@ ioc_fault_cbk(call_frame_t *frame, void *cookie, xlator_t *this, int32_t op_ret,      zero_filled = ((op_ret >= 0) && (stbuf->ia_mtime == 0)); +    gettimeofday(&tv, NULL);      ioc_inode_lock(ioc_inode);      {          if (op_ret == -1 || @@ -444,7 +448,7 @@ ioc_fault_cbk(call_frame_t *frame, void *cookie, xlator_t *this, int32_t op_ret,              ioc_inode->cache.mtime_nsec = stbuf->ia_mtime_nsec;          } -        gettimeofday(&ioc_inode->cache.tv, NULL); +        memcpy(&ioc_inode->cache.tv, &tv, sizeof(struct timeval));          if (op_ret < 0) {              /* error, readv returned -1 */ diff --git a/xlators/performance/quick-read/src/quick-read.c b/xlators/performance/quick-read/src/quick-read.c index ec545ba6193..21734607390 100644 --- a/xlators/performance/quick-read/src/quick-read.c +++ b/xlators/performance/quick-read/src/quick-read.c @@ -421,6 +421,9 @@ qr_content_update(xlator_t *this, qr_inode_t *qr_inode, void *data,      qr_private_t *priv = NULL;      qr_inode_table_t *table = NULL;      uint32_t rollover = 0; +    struct timeval tv = { +        0, +    };      rollover = gen >> 32;      gen = gen & 0xffffffff; @@ -428,6 +431,7 @@ qr_content_update(xlator_t *this, qr_inode_t *qr_inode, void *data,      priv = this->private;      table = &priv->table; +    gettimeofday(&tv, NULL);      LOCK(&table->lock);      {          if ((rollover != qr_inode->gen_rollover) || @@ -450,7 +454,7 @@ qr_content_update(xlator_t *this, qr_inode_t *qr_inode, void *data,          qr_inode->buf = *buf; -        gettimeofday(&qr_inode->last_refresh, NULL); +        memcpy(&qr_inode->last_refresh, &tv, sizeof(struct timeval));          __qr_inode_register(this, table, qr_inode);      }  | 
