From 1bbbac7f62d71f0d0c4c71d429aeb2cfdf96e5ac Mon Sep 17 00:00:00 2001 From: "Matthias P. Braendli" Date: Fri, 13 Jan 2017 16:33:33 +0100 Subject: EDI: add protection against runaway memory usage --- src/EtiReader.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/EtiReader.cpp b/src/EtiReader.cpp index f0a1793..de23142 100644 --- a/src/EtiReader.cpp +++ b/src/EtiReader.cpp @@ -545,7 +545,14 @@ void EdiUdpInput::Open(const std::string& uri) m_port = std::stoi(m[1].str()); etiLog.level(info) << "EDI port :" << m_port; - m_udp_rx.start(m_port); + + // The max_fragments_queued is only a protection against a runaway + // memory usage. + // Rough calculation: + // 300 seconds, 24ms per frame, up to 20 fragments per frame + const size_t max_fragments_queued = 20 * 300 * 1000 / 24; + + m_udp_rx.start(m_port, max_fragments_queued); m_enabled = true; } } -- cgit v1.2.3