diff options
author | Vladislav Grishenko <themiron@yandex-team.ru> | 2021-03-13 20:48:35 +0500 |
---|---|---|
committer | Florin Coras <florin.coras@gmail.com> | 2024-03-03 18:47:41 +0000 |
commit | eb5a08e91d3d7d0f9fc97aeedcbcc02b7a8b753a (patch) | |
tree | e0b2c11aaebb8e242012354a207cc838687aab6e /src/svm | |
parent | 7f5f21ebc4c2c81722c8e219b7107cc3aacc0052 (diff) |
svm: fix svm queue overwrite while adding 2 elements
Adding two elements to the full svm queue passes exact
bounds check, therefore tail gets overwritten w/o any
waiting. Fix it with requiring at lease two free slots.
Type: fix
Signed-off-by: Vladislav Grishenko <themiron@yandex-team.ru>
Change-Id: I704ee606c47b523952cb965f848339ae1988cb60
Diffstat (limited to 'src/svm')
-rw-r--r-- | src/svm/queue.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/svm/queue.c b/src/svm/queue.c index 864d97e3de4..78444d8ede4 100644 --- a/src/svm/queue.c +++ b/src/svm/queue.c @@ -323,14 +323,14 @@ svm_queue_add2 (svm_queue_t * q, u8 * elem, u8 * elem2, int nowait) else svm_queue_lock (q); - if (PREDICT_FALSE (q->cursize + 1 == q->maxsize)) + if (PREDICT_FALSE (q->cursize + 1 >= q->maxsize)) { if (nowait) { svm_queue_unlock (q); return (-2); } - while (q->cursize + 1 == q->maxsize) + while (q->cursize + 1 >= q->maxsize) svm_queue_wait_inline (q); } |