X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/76827d8679d1d2bd46e8cddf7da2ce4178e1d676..318d106300102c19d114a4ea89265b0a4060d9cb:/cgit.c diff --git a/cgit.c b/cgit.c index 110face..dc91125 100644 --- a/cgit.c +++ b/cgit.c @@ -31,6 +31,7 @@ char *cgit_virtual_root = NULL; char *cgit_cache_root = "/var/cache/cgit"; +int cgit_max_lock_attempts = 5; int cgit_cache_root_ttl = 5; int cgit_cache_repo_ttl = 5; int cgit_cache_dynamic_ttl = 5; @@ -465,20 +466,26 @@ static void cgit_fill_cache(struct cacheitem *item) static void cgit_refresh_cache(struct cacheitem *item) { + int i = 0; + + cache_prepare(item); top: - if (!cache_lookup(item)) { - if (cache_lock(item)) { - cgit_fill_cache(item); - cache_unlock(item); - } else { - sched_yield(); + if (++i > cgit_max_lock_attempts) { + die("cgit_refresh_cache: unable to lock %s: %s", + item->name, strerror(errno)); + } + if (!cache_exist(item)) { + if (!cache_lock(item)) { + sleep(1); goto top; } - } else if (cache_expired(item)) { - if (cache_lock(item)) { + if (!cache_exist(item)) cgit_fill_cache(item); - cache_unlock(item); - } + cache_unlock(item); + } else if (cache_expired(item) && cache_lock(item)) { + if (cache_expired(item)) + cgit_fill_cache(item); + cache_unlock(item); } }