diff options
| author | Garrett D'Amore <garrett@damore.org> | 2020-01-03 18:03:57 -0800 |
|---|---|---|
| committer | Garrett D'Amore <garrett@damore.org> | 2020-01-03 18:09:08 -0800 |
| commit | bcc3814b58e9b198344bdaf6e7a916a354841275 (patch) | |
| tree | 795ce060fa8b4356bb4d17457abccdaf6fed8883 /src/protocol/pair1 | |
| parent | d4cb4abccaa8a3bf319d19f97345c04ebd755053 (diff) | |
| download | nng-bcc3814b58e9b198344bdaf6e7a916a354841275.tar.gz nng-bcc3814b58e9b198344bdaf6e7a916a354841275.tar.bz2 nng-bcc3814b58e9b198344bdaf6e7a916a354841275.zip | |
fixes #1104 move allocation of protocol objects to common core
fixes #1103 respondent could inline backtrace
Diffstat (limited to 'src/protocol/pair1')
| -rw-r--r-- | src/protocol/pair1/pair.c | 34 |
1 files changed, 12 insertions, 22 deletions
diff --git a/src/protocol/pair1/pair.c b/src/protocol/pair1/pair.c index 051bc8f3..df24d77b 100644 --- a/src/protocol/pair1/pair.c +++ b/src/protocol/pair1/pair.c @@ -9,7 +9,6 @@ // #include <stdlib.h> -#include <string.h> #include "core/nng_impl.h" #include "nng/protocol/pair1/pair.h" @@ -73,21 +72,15 @@ pair1_sock_fini(void *arg) nni_aio_fini(s->aio_getq); nni_idhash_fini(s->pipes); nni_mtx_fini(&s->mtx); - - NNI_FREE_STRUCT(s); } static int -pair1_sock_init_impl(void **sp, nni_sock *nsock, bool raw) +pair1_sock_init_impl(void *arg, nni_sock *nsock, bool raw) { - pair1_sock *s; + pair1_sock *s = arg; int rv; - if ((s = NNI_ALLOC_STRUCT(s)) == NULL) { - return (NNG_ENOMEM); - } - if ((rv = nni_idhash_init(&s->pipes)) != 0) { - NNI_FREE_STRUCT(s); + if (nni_idhash_init(&s->pipes) != 0) { return (NNG_ENOMEM); } NNI_LIST_INIT(&s->plist, pair1_pipe, node); @@ -122,21 +115,20 @@ pair1_sock_init_impl(void **sp, nni_sock *nsock, bool raw) s->uwq = nni_sock_sendq(nsock); s->urq = nni_sock_recvq(nsock); s->ttl = 8; - *sp = s; return (0); } static int -pair1_sock_init(void **sp, nni_sock *nsock) +pair1_sock_init(void *arg, nni_sock *nsock) { - return (pair1_sock_init_impl(sp, nsock, false)); + return (pair1_sock_init_impl(arg, nsock, false)); } static int -pair1_sock_init_raw(void **sp, nni_sock *nsock) +pair1_sock_init_raw(void *arg, nni_sock *nsock) { - return (pair1_sock_init_impl(sp, nsock, true)); + return (pair1_sock_init_impl(arg, nsock, true)); } static void @@ -160,18 +152,14 @@ pair1_pipe_fini(void *arg) nni_aio_fini(p->aio_putq); nni_aio_fini(p->aio_getq); nni_msgq_fini(p->sendq); - NNI_FREE_STRUCT(p); } static int -pair1_pipe_init(void **pp, nni_pipe *npipe, void *psock) +pair1_pipe_init(void *arg, nni_pipe *npipe, void *psock) { - pair1_pipe *p; + pair1_pipe *p = arg; int rv; - if ((p = NNI_ALLOC_STRUCT(p)) == NULL) { - return (NNG_ENOMEM); - } if (((rv = nni_msgq_init(&p->sendq, 2)) != 0) || ((rv = nni_aio_init(&p->aio_send, pair1_pipe_send_cb, p)) != 0) || ((rv = nni_aio_init(&p->aio_recv, pair1_pipe_recv_cb, p)) != 0) || @@ -183,7 +171,6 @@ pair1_pipe_init(void **pp, nni_pipe *npipe, void *psock) p->npipe = npipe; p->psock = psock; - *pp = p; return (rv); } @@ -512,6 +499,7 @@ pair1_sock_recv(void *arg, nni_aio *aio) } static nni_proto_pipe_ops pair1_pipe_ops = { + .pipe_size = sizeof(pair1_pipe), .pipe_init = pair1_pipe_init, .pipe_fini = pair1_pipe_fini, .pipe_start = pair1_pipe_start, @@ -537,6 +525,7 @@ static nni_option pair1_sock_options[] = { }; static nni_proto_sock_ops pair1_sock_ops = { + .sock_size = sizeof(pair1_sock), .sock_init = pair1_sock_init, .sock_fini = pair1_sock_fini, .sock_open = pair1_sock_open, @@ -562,6 +551,7 @@ nng_pair1_open(nng_socket *sidp) } static nni_proto_sock_ops pair1_sock_ops_raw = { + .sock_size = sizeof(pair1_sock), .sock_init = pair1_sock_init_raw, .sock_fini = pair1_sock_fini, .sock_open = pair1_sock_open, |
