diff options
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/defs.h | 16 | ||||
| -rw-r--r-- | src/core/message.c | 6 |
2 files changed, 18 insertions, 4 deletions
diff --git a/src/core/defs.h b/src/core/defs.h index 9e320e1d..eaba7428 100644 --- a/src/core/defs.h +++ b/src/core/defs.h @@ -1,5 +1,5 @@ // -// Copyright 2019 Staysail Systems, Inc. <info@staysail.tech> +// Copyright 2020 Staysail Systems, Inc. <info@staysail.tech> // Copyright 2018 Capitar IT Group BV <info@capitoar.com> // // This software is supplied under the terms of the MIT License, a @@ -161,4 +161,18 @@ typedef enum { typedef nni_type nni_opt_type; +// NNI_MAX_MAX_TTL is the maximum value that MAX_TTL can be set to - +// i.e. the number of nng_device boundaries that a message can traverse. +// This value drives the size of pre-allocated headers and back-trace +// buffers -- we need 4 bytes for each hop, plus 4 bytes for the request +// identifier. Thus, it is recommended not to set this value too large. +// (It is possible to scale out to inconceivably large networks with +// only a few hops - we have yet to see more than 4 in practice.) +#ifndef NNI_MAX_MAX_TTL +#define NNI_MAX_MAX_TTL 15 +#endif + +// NNI_MAX_HEADER_SIZE is our header size. +#define NNI_MAX_HEADER_SIZE ((NNI_MAX_MAX_TTL + 1) * sizeof(uint32_t)) + #endif // CORE_DEFS_H diff --git a/src/core/message.c b/src/core/message.c index 888585ad..00b23a55 100644 --- a/src/core/message.c +++ b/src/core/message.c @@ -470,9 +470,9 @@ nni_msg_alloc(nni_msg **mp, size_t sz) return (NNG_ENOMEM); } - // 64-bytes of header, including room for 32 bytes - // of headroom and 32 bytes of trailer. - if ((rv = nni_chunk_grow(&m->m_header, 32, 32)) != 0) { + // Header size is strictly limited. We need max hops plus one for + // the request or survey ID. TODO: Inline the header (no chunk). + if ((rv = nni_chunk_grow(&m->m_header, NNI_MAX_HEADER_SIZE, 0)) != 0) { NNI_FREE_STRUCT(m); return (rv); } |
