/* $Id: logrel.cpp 13832 2008-11-05 02:01:12Z vboxsync $ */ /** @file * Runtime VBox - Logger. */ /* * Copyright (C) 2006-2007 Sun Microsystems, Inc. * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. * * The contents of this file may alternatively be used under the terms * of the Common Development and Distribution License Version 1.0 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the * VirtualBox OSE distribution, in which case the provisions of the * CDDL are applicable instead of those of the GPL. * * You may elect to license modified versions of this file under the * terms and conditions of either the GPL or the CDDL or both. * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 USA or visit http://www.sun.com if you need * additional information or have any questions. */ /******************************************************************************* * Header Files * *******************************************************************************/ #include #ifndef IN_RC # include # include # include # include # include #endif #ifdef IN_RING3 # include # include #endif #include #include #include #include #include #include #include #include #ifdef IN_RING3 # include # include #endif /******************************************************************************* * Global Variables * *******************************************************************************/ #ifdef IN_RC /** Default relese logger instance. */ extern "C" DECLIMPORT(RTLOGGERRC) g_RelLogger; #else /* !IN_RC */ /** Default release logger instance. */ static PRTLOGGER g_pRelLogger; #endif /* !IN_RC */ /** * Gets the default release logger instance. * * @returns Pointer to default release logger instance. * @returns NULL if no default release logger instance available. */ RTDECL(PRTLOGGER) RTLogRelDefaultInstance(void) { #ifdef IN_RC return &g_RelLogger; #else /* !IN_RC */ return g_pRelLogger; #endif /* !IN_RC */ } #ifndef IN_RC /** * Sets the default logger instance. * * @returns iprt status code. * @param pLogger The new default release logger instance. */ RTDECL(PRTLOGGER) RTLogRelSetDefaultInstance(PRTLOGGER pLogger) { return (PRTLOGGER)ASMAtomicXchgPtr((void * volatile *)&g_pRelLogger, pLogger); } #endif /* !IN_RC */ /** * Write to a logger instance, defaulting to the release one. * * This function will check whether the instance, group and flags makes up a * logging kind which is currently enabled before writing anything to the log. * * @param pLogger Pointer to logger instance. If NULL the default release instance is attempted. * @param fFlags The logging flags. * @param iGroup The group. * The value ~0U is reserved for compatability with RTLogLogger[V] and is * only for internal usage! * @param pszFormat Format string. * @param args Format arguments. */ RTDECL(void) RTLogRelLoggerV(PRTLOGGER pLogger, unsigned fFlags, unsigned iGroup, const char *pszFormat, va_list args) { /* * A NULL logger means default instance. */ if (!pLogger) { pLogger = RTLogRelDefaultInstance(); if (!pLogger) return; } RTLogLoggerExV(pLogger, fFlags, iGroup, pszFormat, args); } /** * vprintf like function for writing to the default release log. * * @param pszFormat Printf like format string. * @param args Optional arguments as specified in pszFormat. * * @remark The API doesn't support formatting of floating point numbers at the moment. */ RTDECL(void) RTLogRelPrintfV(const char *pszFormat, va_list args) { RTLogRelLoggerV(NULL, 0, ~0U, pszFormat, args); }