X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/3903760236c30e3b5ace7a4eefac3a269d68957c..4ba76501152d51ccb5647018f3192c6096367d48:/libkern/os/log.h?ds=sidebyside diff --git a/libkern/os/log.h b/libkern/os/log.h index a26a129a1..2972daca7 100644 --- a/libkern/os/log.h +++ b/libkern/os/log.h @@ -48,8 +48,26 @@ __BEGIN_DECLS extern void *__dso_handle; -OS_ALWAYS_INLINE static inline void _os_log_verify_format_str(__unused const char *msg, ...) __attribute__((format(os_trace, 1, 2))); -OS_ALWAYS_INLINE static inline void _os_log_verify_format_str(__unused const char *msg, ...) { /* placeholder */ } +#ifdef XNU_KERNEL_PRIVATE +extern bool startup_serial_logging_active; +extern uint64_t startup_serial_num_procs; +#endif /* XNU_KERNEL_PRIVATE */ + +#ifdef KERNEL +#define OS_LOG_BUFFER_MAX_SIZE 256 +#else +#define OS_LOG_BUFFER_MAX_SIZE 1024 +#endif + +// The OS_LOG_BUFFER_MAX_SIZE limit includes the metadata that +// must be included in the os_log firehose buffer +#define OS_LOG_DATA_MAX_SIZE (OS_LOG_BUFFER_MAX_SIZE - 16) + +OS_ALWAYS_INLINE static inline void _os_log_verify_format_str(__unused const char *msg, ...) __attribute__((format(os_log, 1, 2))); +OS_ALWAYS_INLINE static inline void +_os_log_verify_format_str(__unused const char *msg, ...) /* placeholder */ +{ +} #if OS_OBJECT_USE_OBJC OS_OBJECT_DECL(os_log); @@ -72,7 +90,7 @@ typedef struct os_log_s *os_log_t; * Use this to log a message in accordance with current system settings. */ #define OS_LOG_DEFAULT OS_OBJECT_GLOBAL_OBJECT(os_log_t, _os_log_default) -__OSX_AVAILABLE_STARTING(__MAC_10_12,__IPHONE_10_0) +__OSX_AVAILABLE_STARTING(__MAC_10_12, __IPHONE_10_0) OS_EXPORT struct os_log_s _os_log_default; @@ -100,11 +118,11 @@ struct os_log_s _os_log_default; * potentially more than one process, usually used by daemons and services. */ OS_ENUM(os_log_type, uint8_t, - OS_LOG_TYPE_DEFAULT = 0x00, - OS_LOG_TYPE_INFO = 0x01, - OS_LOG_TYPE_DEBUG = 0x02, - OS_LOG_TYPE_ERROR = 0x10, - OS_LOG_TYPE_FAULT = 0x11); + OS_LOG_TYPE_DEFAULT = 0x00, + OS_LOG_TYPE_INFO = 0x01, + OS_LOG_TYPE_DEBUG = 0x02, + OS_LOG_TYPE_ERROR = 0x10, + OS_LOG_TYPE_FAULT = 0x11); /*! * @function os_log_create @@ -119,7 +137,7 @@ OS_ENUM(os_log_type, uint8_t, * behavior for messages. * * A log object may customize logging system behavior for its messages by - * adding a configuration file in /Library/LogPreferences. Most options + * adding a configuration file in /Library/LogPreferences. Most options * accept 3 values: "Default", "Yes" or "No" as strings, where "Default" * signifies follow system behavior for the level of messages. * @@ -138,7 +156,7 @@ OS_ENUM(os_log_type, uint8_t, * Default * Persist * No - * TTL + * TTL * Default * * @@ -160,7 +178,7 @@ OS_ENUM(os_log_type, uint8_t, * * Persist * Yes - * TTL + * TTL * 2d * * @@ -193,7 +211,7 @@ OS_ENUM(os_log_type, uint8_t, * * A value will always be returned to allow for dynamic enablement. */ -__OSX_AVAILABLE_STARTING(__MAC_10_12,__IPHONE_10_0) +__OSX_AVAILABLE_STARTING(__MAC_10_12, __IPHONE_10_0) OS_EXPORT OS_NOTHROW OS_WARN_RESULT OS_OBJECT_RETURNS_RETAINED os_log_t os_log_create(const char *subsystem, const char *category); @@ -245,7 +263,7 @@ os_log_debug_enabled(os_log_t log); * Insert a log message into the Unified Logging and Tracing system. * * @discussion - * Insert a log message into the Unified Logging and Tracing system in + * Insert a log message into the Unified Logging and Tracing system in * accordance with the preferences specified by the provided log object. * These messages cannot be disabled and therefore always captured either * to memory or disk. @@ -282,7 +300,7 @@ os_log_debug_enabled(os_log_t log); * Insert a development log message into the Unified Logging and Tracing system. * * @discussion - * Insert a log message into the Unified Logging and Tracing system in + * Insert a log message into the Unified Logging and Tracing system in * accordance with the preferences specified by the provided log object. * * When an os_activity_id_t is present, the log message will also be scoped by @@ -388,7 +406,7 @@ os_log_debug_enabled(os_log_t log); * @discussion * Log a fault message issue into the Unified Logging and Tracing system * signifying a multi-process (i.e., system error) related issue, either - * due to interaction via IPC or some other. Faults will gather information + * due to interaction via IPC or some other. Faults will gather information * from the entire process chain and record it for later inspection. * * When an os_activity_id_t is present, the log message will also be scoped by @@ -444,6 +462,38 @@ os_log_debug_enabled(os_log_t log); __asm__(""); /* avoid tailcall */ \ }) +/*! + * @function os_log_driverKit + * + * @abstract + * Log a message using a specific type. This variant should be called only from dexts. + * + * @discussion + * Will log a message with the provided os_log_type_t. + * + * @param log + * Pass OS_LOG_DEFAULT or a log object previously created with os_log_create. + * + * @param type + * Pass a valid type from os_log_type_t. + * + * @param format + * A format string to generate a human-readable log message when the log + * line is decoded. This string must be a constant string, not dynamically + * generated. Supports all standard printf types and %@ (objects). + * + * @result + * Returns EPERM if the caller is not a driverKit process, 0 in case of success. + */ +#define os_log_driverKit(out, log, type, format, ...) __extension__({ \ + _Static_assert(__builtin_constant_p(format), "format string must be constant"); \ + __attribute__((section("__TEXT,__os_log"))) static const char _os_log_fmt[] = format; \ + _os_log_verify_format_str(format, ##__VA_ARGS__); \ + (*(out)) = _os_log_internal_driverKit(&__dso_handle, log, type, _os_log_fmt, ##__VA_ARGS__); \ + __asm__(""); /* avoid tailcall */ \ +}) + + /*! * @function os_log_sensitive_debug * @@ -485,6 +535,13 @@ os_log_debug_enabled(os_log_t log); __asm__(""); /* avoid tailcall */ \ }) +#ifdef XNU_KERNEL_PRIVATE +#define os_log_with_startup_serial(log, format, ...) __extension__({ \ + if (startup_serial_logging_active) { printf(format, ##__VA_ARGS__); } \ + else { os_log(log, format, ##__VA_ARGS__); } \ +}) +#endif /* XNU_KERNEL_PRIVATE */ + /*! * @function _os_log_internal * @@ -496,6 +553,16 @@ OS_EXPORT OS_NOTHROW void _os_log_internal(void *dso, os_log_t log, os_log_type_t type, const char *message, ...); +/*! + * @function _os_log_internal_driverKit + * + * @abstract + * Internal function used by macros. + */ +__WATCHOS_AVAILABLE(6.0) __OSX_AVAILABLE(10.15) __IOS_AVAILABLE(13.0) __TVOS_AVAILABLE(13.0) +OS_EXPORT OS_NOTHROW +int +_os_log_internal_driverKit(void *dso, os_log_t log, os_log_type_t type, const char *message, ...); __END_DECLS #endif /* __os_log_h */