summaryrefslogtreecommitdiff
path: root/src/cache.c
diff options
context:
space:
mode:
authorEdward Thomson <ethomson@edwardthomson.com>2013-04-25 11:52:17 -0500
committerEdward Thomson <ethomson@edwardthomson.com>2013-04-25 12:40:33 -0500
commiteb63fda2e24d007e31742587984a30e086249d43 (patch)
tree79d98a9ec5fae1586ab777c80e3d4f164f03a578 /src/cache.c
parentb4117e19b7a968f8e6b878d81c58a462093cf1b3 (diff)
downloadlibgit2-eb63fda2e24d007e31742587984a30e086249d43.tar.gz
git_atomic_ssize for 64-bit atomics only on 64-bit platforms
Diffstat (limited to 'src/cache.c')
-rw-r--r--src/cache.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/src/cache.c b/src/cache.c
index be4b037a3..1360cc976 100644
--- a/src/cache.c
+++ b/src/cache.c
@@ -18,8 +18,8 @@
GIT__USE_OIDMAP
bool git_cache__enabled = true;
-int64_t git_cache__max_storage = (256 * 1024 * 1024);
-git_atomic64 git_cache__current_storage = {0};
+ssize_t git_cache__max_storage = (256 * 1024 * 1024);
+git_atomic_ssize git_cache__current_storage = {0};
static size_t git_cache__max_object_size[8] = {
0, /* GIT_OBJ__EXT1 */
@@ -85,7 +85,7 @@ static void clear_cache(git_cache *cache)
});
kh_clear(oid, cache->map);
- git_atomic64_add(&git_cache__current_storage, -cache->used_memory);
+ git_atomic_ssize_add(&git_cache__current_storage, -cache->used_memory);
cache->used_memory = 0;
}
@@ -111,7 +111,8 @@ void git_cache_free(git_cache *cache)
static void cache_evict_entries(git_cache *cache)
{
uint32_t seed = rand();
- int64_t evicted_memory = 0, evict_count = 8;
+ size_t evict_count = 8;
+ ssize_t evicted_memory = 0;
/* do not infinite loop if there's not enough entries to evict */
if (evict_count > kh_size(cache->map)) {
@@ -134,7 +135,7 @@ static void cache_evict_entries(git_cache *cache)
}
cache->used_memory -= evicted_memory;
- git_atomic64_add(&git_cache__current_storage, -evicted_memory);
+ git_atomic_ssize_add(&git_cache__current_storage, -evicted_memory);
}
static bool cache_should_store(git_otype object_type, size_t object_size)
@@ -195,7 +196,7 @@ static void *cache_store(git_cache *cache, git_cached_obj *entry)
kh_val(cache->map, pos) = entry;
git_cached_obj_incref(entry);
cache->used_memory += entry->size;
- git_atomic64_add(&git_cache__current_storage, (int64_t)entry->size);
+ git_atomic_ssize_add(&git_cache__current_storage, (ssize_t)entry->size);
}
}
/* found */