From 8dd1688ca741422d34abcdececf829a03e4d2e51 Mon Sep 17 00:00:00 2001 From: Exzap <13877693+Exzap@users.noreply.github.com> Date: Sat, 3 Sep 2022 23:53:45 +0200 Subject: [PATCH] coreinit: Make OSReport and OSConsoleWrite thread-safe --- src/Cafe/OS/libs/coreinit/coreinit_Misc.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/Cafe/OS/libs/coreinit/coreinit_Misc.cpp b/src/Cafe/OS/libs/coreinit/coreinit_Misc.cpp index 50c6f758..b8a964ce 100644 --- a/src/Cafe/OS/libs/coreinit/coreinit_Misc.cpp +++ b/src/Cafe/OS/libs/coreinit/coreinit_Misc.cpp @@ -264,11 +264,13 @@ namespace coreinit return "Unknown"; } + std::mutex sCafeConsoleMutex; + void WriteCafeConsole(CafeLogType cafeLogType, const char* msg, sint32 len) { - // once a line is full or \n is written it will be posted to log + std::unique_lock _l(sCafeConsoleMutex); CafeLogBuffer& logBuffer = getLogBuffer(cafeLogType); - + // once a line is full or \n is written it will be posted to log auto flushLine = [](CafeLogBuffer& cafeLogBuffer, std::string_view cafeLogName) -> void { cemuLog_log(LogType::CoreinitLogging, "[{0}] {1}", cafeLogName, std::basic_string_view(cafeLogBuffer.lineBuffer.data(), cafeLogBuffer.lineLength)); @@ -354,4 +356,4 @@ namespace coreinit cafeExportRegister("coreinit", OSEnableHomeButtonMenu, LogType::CoreinitThread); } -}; \ No newline at end of file +};