From 5b3703bf58d4ba8a7570689629bfa706f93486c8 Mon Sep 17 00:00:00 2001 From: Luca Guerra Date: Tue, 17 Dec 2024 17:07:29 +0000 Subject: [PATCH] fix(falco): prevent use-after-return in webserver Signed-off-by: Luca Guerra --- userspace/falco/webserver.cpp | 11 +++++------ userspace/falco/webserver.h | 1 + 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/userspace/falco/webserver.cpp b/userspace/falco/webserver.cpp index c08f02687ce..37d63d21f4b 100644 --- a/userspace/falco/webserver.cpp +++ b/userspace/falco/webserver.cpp @@ -69,9 +69,8 @@ void falco_webserver::start(const falco::app::state &state, throw falco_exception("invalid webserver configuration"); } - std::atomic failed; - failed.store(false, std::memory_order_release); - m_server_thread = std::thread([this, webserver_config, &failed] { + m_failed.store(false, std::memory_order_release); + m_server_thread = std::thread([this, webserver_config] { try { this->m_server->listen(webserver_config.m_listen_address, webserver_config.m_listen_port); @@ -79,16 +78,16 @@ void falco_webserver::start(const falco::app::state &state, falco_logger::log(falco_logger::level::ERR, "falco_webserver: " + std::string(e.what()) + "\n"); } - failed.store(true, std::memory_order_release); + this->m_failed.store(true, std::memory_order_release); }); // wait for the server to actually start up // note: is_running() is atomic - while(!m_server->is_running() && !failed.load(std::memory_order_acquire)) { + while(!m_server->is_running() && !m_failed.load(std::memory_order_acquire)) { std::this_thread::yield(); } m_running = true; - if(failed.load(std::memory_order_acquire)) { + if(m_failed.load(std::memory_order_acquire)) { stop(); throw falco_exception("an error occurred while starting webserver"); } diff --git a/userspace/falco/webserver.h b/userspace/falco/webserver.h index 8e3b4ba215e..2c5c08b00ef 100644 --- a/userspace/falco/webserver.h +++ b/userspace/falco/webserver.h @@ -45,4 +45,5 @@ class falco_webserver { bool m_running = false; std::unique_ptr m_server = nullptr; std::thread m_server_thread; + std::atomic m_failed; };