diff options
Diffstat (limited to '')
-rw-r--r-- | src/nxt_main.h | 1 | ||||
-rw-r--r-- | src/nxt_port_hash.c | 139 | ||||
-rw-r--r-- | src/nxt_port_hash.h | 42 | ||||
-rw-r--r-- | src/nxt_runtime.c | 105 | ||||
-rw-r--r-- | src/nxt_runtime.h | 2 |
5 files changed, 187 insertions, 102 deletions
diff --git a/src/nxt_main.h b/src/nxt_main.h index d1230f71..0aa2192c 100644 --- a/src/nxt_main.h +++ b/src/nxt_main.h @@ -158,6 +158,7 @@ typedef struct nxt_upstream_source_s nxt_upstream_source_t; #include <nxt_http_source.h> #include <nxt_fastcgi_source.h> #include <nxt_runtime.h> +#include <nxt_port_hash.h> #if (NXT_LIB_UNIT_TEST) diff --git a/src/nxt_port_hash.c b/src/nxt_port_hash.c new file mode 100644 index 00000000..e9158f5d --- /dev/null +++ b/src/nxt_port_hash.c @@ -0,0 +1,139 @@ + +/* + * Copyright (C) Max Romanov + * Copyright (C) NGINX, Inc. + */ + +#include <nxt_port_hash.h> + + +// Explicitly using 32 bit types to avoid possible alignment. +typedef struct { + int32_t pid; + uint32_t port_id; +} nxt_pid_port_id_t; + + +static nxt_int_t +nxt_port_hash_test(nxt_lvlhsh_query_t *lhq, void *data) +{ + nxt_port_t *port; + nxt_pid_port_id_t *pid_port_id; + + port = data; + pid_port_id = (nxt_pid_port_id_t *) lhq->key.start; + + if (lhq->key.length == sizeof(nxt_pid_port_id_t) && + pid_port_id->pid == port->pid && + pid_port_id->port_id == port->id) { + return NXT_OK; + } + + return NXT_DECLINED; +} + +static const nxt_lvlhsh_proto_t lvlhsh_ports_proto nxt_aligned(64) = { + NXT_LVLHSH_DEFAULT, + nxt_port_hash_test, + nxt_lvlhsh_alloc, + nxt_lvlhsh_free, +}; + + +nxt_port_t * +nxt_port_hash_first(nxt_lvlhsh_t *port_hash, nxt_lvlhsh_each_t *lhe) +{ + nxt_memzero(lhe, sizeof(nxt_lvlhsh_each_t)); + + lhe->proto = &lvlhsh_ports_proto; + + return nxt_port_hash_next(port_hash, lhe); +} + + +void +nxt_port_hash_add(nxt_lvlhsh_t *port_hash, nxt_mp_t *mem_pool, + nxt_port_t *port) +{ + nxt_pid_port_id_t pid_port; + nxt_lvlhsh_query_t lhq; + + pid_port.pid = port->pid; + pid_port.port_id = port->id; + + lhq.key_hash = nxt_murmur_hash2(&pid_port, sizeof(pid_port)); + lhq.key.length = sizeof(pid_port); + lhq.key.start = (u_char *) &pid_port; + lhq.proto = &lvlhsh_ports_proto; + lhq.replace = 0; + lhq.value = port; + lhq.pool = mem_pool; + + switch (nxt_lvlhsh_insert(port_hash, &lhq)) { + + case NXT_OK: + break; + + default: + nxt_thread_log_error(NXT_LOG_WARN, "port #%d for pid %PI add failed", + port->id, port->pid); + break; + } +} + + +void +nxt_port_hash_remove(nxt_lvlhsh_t *port_hash, nxt_mp_t *mem_pool, + nxt_port_t *port) +{ + nxt_pid_port_id_t pid_port; + nxt_lvlhsh_query_t lhq; + + pid_port.pid = port->pid; + pid_port.port_id = port->id; + + lhq.key_hash = nxt_murmur_hash2(&pid_port, sizeof(pid_port)); + lhq.key.length = sizeof(pid_port); + lhq.key.start = (u_char *) &pid_port; + lhq.proto = &lvlhsh_ports_proto; + lhq.replace = 0; + lhq.value = port; + lhq.pool = mem_pool; + + switch (nxt_lvlhsh_delete(port_hash, &lhq)) { + + case NXT_OK: + break; + + default: + break; + } +} + + +nxt_port_t * +nxt_port_hash_find(nxt_lvlhsh_t *port_hash, nxt_pid_t pid, + nxt_port_id_t port_id) +{ + nxt_pid_port_id_t pid_port; + nxt_lvlhsh_query_t lhq; + + pid_port.pid = pid; + pid_port.port_id = port_id; + + lhq.key_hash = nxt_murmur_hash2(&pid_port, sizeof(pid_port)); + lhq.key.length = sizeof(pid_port); + lhq.key.start = (u_char *) &pid_port; + lhq.proto = &lvlhsh_ports_proto; + + /* TODO lock ports */ + + if (nxt_lvlhsh_find(port_hash, &lhq) == NXT_OK) { + nxt_thread_log_debug("process port (%PI, %d) found", pid, port_id); + return lhq.value; + } + + nxt_thread_log_debug("process port (%PI, %d) not found", pid, port_id); + + return NULL; +} diff --git a/src/nxt_port_hash.h b/src/nxt_port_hash.h new file mode 100644 index 00000000..57f9ba08 --- /dev/null +++ b/src/nxt_port_hash.h @@ -0,0 +1,42 @@ + +/* + * Copyright (C) Max Romanov + * Copyright (C) NGINX, Inc. + */ + +#ifndef _NXT_PORT_HASH_H_INCLUDED_ +#define _NXT_PORT_HASH_H_INCLUDED_ + + +#include <nxt_main.h> + + +void nxt_port_hash_add(nxt_lvlhsh_t *port_hash, nxt_mp_t *mem_pool, + nxt_port_t *port); + +void nxt_port_hash_remove(nxt_lvlhsh_t *port_hash, nxt_mp_t *mem_pool, + nxt_port_t *port); + +nxt_port_t *nxt_port_hash_find(nxt_lvlhsh_t *port_hash, nxt_pid_t pid, + nxt_port_id_t port_id); + +nxt_port_t *nxt_port_hash_first(nxt_lvlhsh_t *port_hash, + nxt_lvlhsh_each_t *lhe); + +#define nxt_port_hash_next(port_hash, lhe) \ + nxt_lvlhsh_each((port_hash), (lhe)) + +#define nxt_port_hash_each(port_hash, port) \ + do { \ + nxt_lvlhsh_each_t _lhe; \ + \ + for (port = nxt_port_hash_first((port_hash), &_lhe); \ + port != NULL; \ + port = nxt_port_hash_next((port_hash), &_lhe)) { \ + +#define nxt_port_hash_loop \ + } \ + } while(0) + + +#endif /* _NXT_PORT_HASH_H_INCLIDED_ */ diff --git a/src/nxt_runtime.c b/src/nxt_runtime.c index 8d415ce0..b4177bf0 100644 --- a/src/nxt_runtime.c +++ b/src/nxt_runtime.c @@ -1499,37 +1499,6 @@ static const nxt_lvlhsh_proto_t lvlhsh_processes_proto nxt_aligned(64) = { nxt_lvlhsh_free, }; -// Explicitly using 32 bit types to avoid possible alignment. -typedef struct { - int32_t pid; - uint32_t port_id; -} nxt_pid_port_id_t; - -static nxt_int_t -nxt_runtime_lvlhsh_port_test(nxt_lvlhsh_query_t *lhq, void *data) -{ - nxt_port_t *port; - nxt_pid_port_id_t *pid_port_id; - - port = data; - pid_port_id = (nxt_pid_port_id_t *) lhq->key.start; - - if (lhq->key.length == sizeof(nxt_pid_port_id_t) && - pid_port_id->pid == port->pid && - pid_port_id->port_id == port->id) { - return NXT_OK; - } - - return NXT_DECLINED; -} - -static const nxt_lvlhsh_proto_t lvlhsh_ports_proto nxt_aligned(64) = { - NXT_LVLHSH_DEFAULT, - nxt_runtime_lvlhsh_port_test, - nxt_lvlhsh_alloc, - nxt_lvlhsh_free, -}; - nxt_process_t * nxt_runtime_process_find(nxt_runtime_t *rt, nxt_pid_t pid) @@ -1692,73 +1661,25 @@ nxt_runtime_process_first(nxt_runtime_t *rt, nxt_lvlhsh_each_t *lhe) nxt_port_t * nxt_runtime_port_first(nxt_runtime_t *rt, nxt_lvlhsh_each_t *lhe) { - nxt_memzero(lhe, sizeof(nxt_lvlhsh_each_t)); - - lhe->proto = &lvlhsh_ports_proto; - - return nxt_runtime_port_next(rt, lhe); + return nxt_port_hash_first(&rt->ports, lhe); } void nxt_runtime_port_add(nxt_runtime_t *rt, nxt_port_t *port) { - nxt_pid_port_id_t pid_port; - nxt_lvlhsh_query_t lhq; - - pid_port.pid = port->pid; - pid_port.port_id = port->id; - - lhq.key_hash = nxt_murmur_hash2(&pid_port, sizeof(pid_port)); - lhq.key.length = sizeof(pid_port); - lhq.key.start = (u_char *) &pid_port; - lhq.proto = &lvlhsh_ports_proto; - lhq.replace = 0; - lhq.value = port; - lhq.pool = rt->mem_pool; - /* TODO lock ports */ - switch (nxt_lvlhsh_insert(&rt->ports, &lhq)) { - - case NXT_OK: - break; - - default: - nxt_thread_log_error(NXT_LOG_WARN, "port #%d for pid %PI add failed", - port->id, port->pid); - break; - } + nxt_port_hash_add(&rt->ports, rt->mem_pool, port); } void nxt_runtime_port_remove(nxt_runtime_t *rt, nxt_port_t *port) { - nxt_pid_port_id_t pid_port; - nxt_lvlhsh_query_t lhq; - - pid_port.pid = port->pid; - pid_port.port_id = port->id; - - lhq.key_hash = nxt_murmur_hash2(&pid_port, sizeof(pid_port)); - lhq.key.length = sizeof(pid_port); - lhq.key.start = (u_char *) &pid_port; - lhq.proto = &lvlhsh_ports_proto; - lhq.replace = 0; - lhq.value = port; - lhq.pool = rt->mem_pool; - /* TODO lock ports */ - switch (nxt_lvlhsh_delete(&rt->ports, &lhq)) { - - case NXT_OK: - break; - - default: - break; - } + nxt_port_hash_remove(&rt->ports, rt->mem_pool, port); } @@ -1766,25 +1687,7 @@ nxt_port_t * nxt_runtime_port_find(nxt_runtime_t *rt, nxt_pid_t pid, nxt_port_id_t port_id) { - nxt_pid_port_id_t pid_port; - nxt_lvlhsh_query_t lhq; - - pid_port.pid = pid; - pid_port.port_id = port_id; - - lhq.key_hash = nxt_murmur_hash2(&pid_port, sizeof(pid_port)); - lhq.key.length = sizeof(pid_port); - lhq.key.start = (u_char *) &pid_port; - lhq.proto = &lvlhsh_ports_proto; - /* TODO lock ports */ - if (nxt_lvlhsh_find(&rt->ports, &lhq) == NXT_OK) { - nxt_thread_log_debug("process port (%PI, %d) found", pid, port_id); - return lhq.value; - } - - nxt_thread_log_debug("process port (%PI, %d) not found", pid, port_id); - - return NULL; + return nxt_port_hash_find(&rt->ports, pid, port_id); } diff --git a/src/nxt_runtime.h b/src/nxt_runtime.h index 3ba082f9..13072021 100644 --- a/src/nxt_runtime.h +++ b/src/nxt_runtime.h @@ -112,7 +112,7 @@ nxt_port_t *nxt_runtime_port_first(nxt_runtime_t *rt, nxt_lvlhsh_each_t *lhe); #define nxt_runtime_port_next(rt, lhe) \ - nxt_lvlhsh_each(&rt->ports, lhe) + nxt_port_hash_next(&rt->ports, lhe) /* STUB */ |