aboutsummaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
Diffstat (limited to 'src/core')
-rw-r--r--src/core/defs.h16
-rw-r--r--src/core/message.c6
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);
}