|
@@ -979,7 +979,6 @@ static void push_to_pool(struct work_struct *work)
|
|
|
static size_t account(struct entropy_store *r, size_t nbytes, int min,
|
|
|
int reserved)
|
|
|
{
|
|
|
- int have_bytes;
|
|
|
int entropy_count, orig;
|
|
|
size_t ibytes;
|
|
|
|
|
@@ -988,17 +987,19 @@ static size_t account(struct entropy_store *r, size_t nbytes, int min,
|
|
|
/* Can we pull enough? */
|
|
|
retry:
|
|
|
entropy_count = orig = ACCESS_ONCE(r->entropy_count);
|
|
|
- have_bytes = entropy_count >> (ENTROPY_SHIFT + 3);
|
|
|
ibytes = nbytes;
|
|
|
/* If limited, never pull more than available */
|
|
|
- if (r->limit)
|
|
|
- ibytes = min_t(size_t, ibytes, have_bytes - reserved);
|
|
|
+ if (r->limit) {
|
|
|
+ int have_bytes = entropy_count >> (ENTROPY_SHIFT + 3);
|
|
|
+
|
|
|
+ if ((have_bytes -= reserved) < 0)
|
|
|
+ have_bytes = 0;
|
|
|
+ ibytes = min_t(size_t, ibytes, have_bytes);
|
|
|
+ }
|
|
|
if (ibytes < min)
|
|
|
ibytes = 0;
|
|
|
- if (have_bytes >= ibytes + reserved)
|
|
|
- entropy_count -= ibytes << (ENTROPY_SHIFT + 3);
|
|
|
- else
|
|
|
- entropy_count = reserved << (ENTROPY_SHIFT + 3);
|
|
|
+ if ((entropy_count -= ibytes << (ENTROPY_SHIFT + 3)) < 0)
|
|
|
+ entropy_count = 0;
|
|
|
|
|
|
if (cmpxchg(&r->entropy_count, orig, entropy_count) != orig)
|
|
|
goto retry;
|