Welcome! Log In Create A New Profile

Advanced

[nginx] Slab: simplified some math.

December 07, 2016 02:30PM
details: http://hg.nginx.org/nginx/rev/0e61510c56c4
branches:
changeset: 6827:0e61510c56c4
user: Ruslan Ermilov <ru@nginx.com>
date: Wed Dec 07 22:25:37 2016 +0300
description:
Slab: simplified some math.

No functional changes.

diffstat:

src/core/ngx_slab.c | 29 ++++++++++++-----------------
1 files changed, 12 insertions(+), 17 deletions(-)

diffs (94 lines):

diff -r d0404c9a7675 -r 0e61510c56c4 src/core/ngx_slab.c
--- a/src/core/ngx_slab.c Wed Dec 07 22:25:37 2016 +0300
+++ b/src/core/ngx_slab.c Wed Dec 07 22:25:37 2016 +0300
@@ -217,8 +217,7 @@ ngx_slab_alloc_locked(ngx_slab_pool_t *p

bitmap = (uintptr_t *) ngx_slab_page_addr(pool, page);

- map = (1 << (ngx_pagesize_shift - shift))
- / (sizeof(uintptr_t) * 8);
+ map = (ngx_pagesize >> shift) / (sizeof(uintptr_t) * 8);

for (n = 0; n < map; n++) {

@@ -231,8 +230,7 @@ ngx_slab_alloc_locked(ngx_slab_pool_t *p

bitmap[n] |= m;

- i = ((n * sizeof(uintptr_t) * 8) << shift)
- + (i << shift);
+ i = (n * sizeof(uintptr_t) * 8 + i) << shift;

if (bitmap[n] == NGX_SLAB_BUSY) {
for (n = n + 1; n < map; n++) {
@@ -283,10 +281,8 @@ ngx_slab_alloc_locked(ngx_slab_pool_t *p

} else { /* shift > ngx_slab_exact_shift */

- n = ngx_pagesize_shift - (page->slab & NGX_SLAB_SHIFT_MASK);
- n = 1 << n;
- n = ((uintptr_t) 1 << n) - 1;
- mask = n << NGX_SLAB_MAP_SHIFT;
+ mask = ((uintptr_t) 1 << (ngx_pagesize >> shift)) - 1;
+ mask <<= NGX_SLAB_MAP_SHIFT;

for (m = (uintptr_t) 1 << NGX_SLAB_MAP_SHIFT, i = 0;
m & mask;
@@ -323,16 +319,15 @@ ngx_slab_alloc_locked(ngx_slab_pool_t *p
if (shift < ngx_slab_exact_shift) {
bitmap = (uintptr_t *) ngx_slab_page_addr(pool, page);

- s = 1 << shift;
- n = (1 << (ngx_pagesize_shift - shift)) / 8 / s;
+ n = (ngx_pagesize >> shift) / ((1 << shift) * 8);

if (n == 0) {
n = 1;
}

- bitmap[0] = (2 << n) - 1;
+ bitmap[0] = ((uintptr_t) 2 << n) - 1;

- map = (1 << (ngx_pagesize_shift - shift)) / (sizeof(uintptr_t) * 8);
+ map = (ngx_pagesize >> shift) / (sizeof(uintptr_t) * 8);

for (i = 1; i < map; i++) {
bitmap[i] = 0;
@@ -344,7 +339,7 @@ ngx_slab_alloc_locked(ngx_slab_pool_t *p

slots[slot].next = page;

- p = ngx_slab_page_addr(pool, page) + s * n;
+ p = ngx_slab_page_addr(pool, page) + (n << shift);

goto done;

@@ -457,8 +452,8 @@ ngx_slab_free_locked(ngx_slab_pool_t *po
}

n = ((uintptr_t) p & (ngx_pagesize - 1)) >> shift;
- m = (uintptr_t) 1 << (n & (sizeof(uintptr_t) * 8 - 1));
- n /= (sizeof(uintptr_t) * 8);
+ m = (uintptr_t) 1 << (n % (sizeof(uintptr_t) * 8));
+ n /= sizeof(uintptr_t) * 8;
bitmap = (uintptr_t *)
((uintptr_t) p & ~((uintptr_t) ngx_pagesize - 1));

@@ -477,7 +472,7 @@ ngx_slab_free_locked(ngx_slab_pool_t *po

bitmap[n] &= ~m;

- n = (1 << (ngx_pagesize_shift - shift)) / 8 / (1 << shift);
+ n = (ngx_pagesize >> shift) / ((1 << shift) * 8);

if (n == 0) {
n = 1;
@@ -487,7 +482,7 @@ ngx_slab_free_locked(ngx_slab_pool_t *po
goto done;
}

- map = (1 << (ngx_pagesize_shift - shift)) / (sizeof(uintptr_t) * 8);
+ map = (ngx_pagesize >> shift) / (sizeof(uintptr_t) * 8);

for (n = 1; n < map; n++) {
if (bitmap[n]) {
_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[nginx] Slab: simplified some math.

ru@nginx.com 376 December 07, 2016 02:30PM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 94
Record Number of Users: 6 on February 13, 2018
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready