mirror of
git://git.gnupg.org/gnupg.git
synced 2024-12-22 10:19:57 +01:00
agent: Fix double free.
* agent/cache.c (agent_store_cache_hit): Make sure the update is atomic. -- Previously, the function freed the last key, and duplicated the new key after doing that. There is a chance, however, that calling the allocator surrenders control to a different thread, causing a double free if a different thread also calls this function. To make sure the update is atomic under the non-preemptive thread model, we must make sure not to surrender control to a different thread. Therefore, we avoid calling the allocator during the update. Signed-off-by: Justus Winter <justus@g10code.com>
This commit is contained in:
parent
5f2da5d439
commit
e175152ef7
@ -475,6 +475,19 @@ agent_get_cache (const char *key, cache_mode_t cache_mode)
|
|||||||
void
|
void
|
||||||
agent_store_cache_hit (const char *key)
|
agent_store_cache_hit (const char *key)
|
||||||
{
|
{
|
||||||
xfree (last_stored_cache_key);
|
char *new;
|
||||||
last_stored_cache_key = key? xtrystrdup (key) : NULL;
|
char *old;
|
||||||
|
|
||||||
|
/* To make sure the update is atomic under the non-preemptive thread
|
||||||
|
* model, we must make sure not to surrender control to a different
|
||||||
|
* thread. Therefore, we avoid calling the allocator during the
|
||||||
|
* update. */
|
||||||
|
new = key ? xtrystrdup (key) : NULL;
|
||||||
|
|
||||||
|
/* Atomic update. */
|
||||||
|
old = last_stored_cache_key;
|
||||||
|
last_stored_cache_key = new;
|
||||||
|
/* Done. */
|
||||||
|
|
||||||
|
xfree (old);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user