/** * @file loggingcentral.h * * @date Mar 8, 2015 * @author Andrey Belomutskiy, (c) 2012-2020 */ #pragma once #include #include "generated_lookup_meta.h" class Logging; void startLoggingProcessor(); const char* swapOutputBuffers(size_t *actualOutputBufferSize); namespace priv { // internal implementation, use efiPrintf below void efiPrintfInternal(const char *fmt, ...) #if EFI_PROD_CODE __attribute__ ((format (printf, 1, 2))) #endif ; } // "normal" logging messages need a header and footer, so put them in // the format string at compile time #define efiPrintfProto(proto, fmt, ...) priv::efiPrintfInternal(proto LOG_DELIMITER fmt LOG_DELIMITER, ##__VA_ARGS__) #define efiPrintf(fmt, ...) efiPrintfProto(PROTOCOL_MSG, fmt, ##__VA_ARGS__) /** * This is the legacy function to copy the contents of a local Logging object in to the output buffer */ void scheduleLogging(Logging *logging); // Stores the result of one call to efiPrintfInternal in the queue to be copied out to the output buffer struct LogLineBuffer { char buffer[256]; }; template class LogBuffer { public: void writeLine(LogLineBuffer* line); void writeLogger(Logging* logging); size_t length() const; void reset(); const char* get() const; #if !EFI_UNIT_TEST private: #endif void writeInternal(const char* buffer); char m_buffer[TBufferSize]; char* m_writePtr = m_buffer; };