From 07d455634689a48ad5e3c1289dd6773a274e58bd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Axel=20D=C3=B6rfler?= Date: Mon, 16 Nov 2009 13:08:36 +0000 Subject: [PATCH] * Change get_next_sem_info() to be index based, not ID based - the semaphore IDs aren't monotonically increasing which this code was assuming. This fixes bug #4917. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@34074 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/system/kernel/sem.cpp | 34 +++++++++++++--------------------- 1 file changed, 13 insertions(+), 21 deletions(-) diff --git a/src/system/kernel/sem.cpp b/src/system/kernel/sem.cpp index e350a2d357..043984f44b 100644 --- a/src/system/kernel/sem.cpp +++ b/src/system/kernel/sem.cpp @@ -1123,47 +1123,39 @@ _get_next_sem_info(team_id teamID, int32 *_cookie, struct sem_info *info, if (team == NULL) return B_BAD_TEAM_ID; - int32 id = *_cookie; - sem_entry* sem = NULL; - - if (id != 0) { - // shortcut to the first entry - sem = &sSems[id % sMaxSems]; - GRAB_SEM_LOCK(*sem); - - // Check if the semaphore got deleted or reused in the mean time - if (sem->id != id) - sem = NULL; - - RELEASE_SEM_LOCK(*sem); - } - if (sem == NULL) - sem = (sem_entry*)list_get_first_item(&team->sem_list); - + // TODO: find a way to iterate the list that is more reliable + sem_entry* sem = (sem_entry*)list_get_first_item(&team->sem_list); + int32 newIndex = *_cookie; + int32 index = 0; bool found = false; while (!found) { // find the next entry to be returned - while (sem != NULL && id >= sem->id) + while (sem != NULL && index < newIndex) { sem = (sem_entry*)list_get_next_item(&team->sem_list, sem); + index++; + } if (sem == NULL) return B_BAD_VALUE; GRAB_SEM_LOCK(*sem); + if (sem->id != -1 && sem->u.used.owner == team) { // found one! fill_sem_info(sem, info, size); - id = sem->id; + newIndex = index + 1; found = true; - } + } else + newIndex++; + RELEASE_SEM_LOCK(*sem); } if (!found) return B_BAD_VALUE; - *_cookie = id; + *_cookie = newIndex; return B_OK; }