assert-r0drv-os2.cpp revision 5eda82e218d35ae0691febd531e1bfc0324cc4a6
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/* $Id$ */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/** @file
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * IPRT - Assertion Workers, Ring-0 Drivers, OS/2.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/*
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * Copyright (c) 2007 knut st. osmundsen <bird-src-spam@anduin.net>
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * Permission is hereby granted, free of charge, to any person
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * obtaining a copy of this software and associated documentation
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * files (the "Software"), to deal in the Software without
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * restriction, including without limitation the rights to use,
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * copy, modify, merge, publish, distribute, sublicense, and/or sell
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * copies of the Software, and to permit persons to whom the
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * Software is furnished to do so, subject to the following
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * conditions:
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * The above copyright notice and this permission notice shall be
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * included in all copies or substantial portions of the Software.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * OTHER DEALINGS IN THE SOFTWARE.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/*******************************************************************************
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync* Header Files *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync*******************************************************************************/
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#include <iprt/assert.h>
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#include <iprt/log.h>
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#include <iprt/string.h>
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#include <iprt/stdarg.h>
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#include <VBox/log.h>
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#include "internal/assert.h"
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/*******************************************************************************
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync* Global Variables *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync*******************************************************************************/
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/** The last assert message. (in DATA16) */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsyncextern char g_szRTAssertMsg[2048];
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/** The length of the last assert message. (in DATA16) */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsyncextern size_t g_cchRTAssertMsg;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/*******************************************************************************
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync* Internal Functions *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync*******************************************************************************/
1b33c96954667ba382fa595baf7b31290bfdd517vboxsyncstatic DECLCALLBACK(size_t) rtR0Os2AssertOutputCB(void *pvArg, const char *pachChars, size_t cbChars);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsyncDECLHIDDEN(void) rtR0AssertNativeMsg1(const char *pszExpr, unsigned uLine, const char *pszFile, const char *pszFunction)
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync{
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#if defined(DEBUG_bird)
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync RTLogComPrintf("\n!!Assertion Failed!!\n"
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync "Expression: %s\n"
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync "Location : %s(%d) %s\n",
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync pszExpr, pszFile, uLine, pszFunction);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#endif
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync g_cchRTAssertMsg = RTStrPrintf(g_szRTAssertMsg, sizeof(g_szRTAssertMsg),
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync "\r\n!!Assertion Failed!!\r\n"
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync "Expression: %s\r\n"
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync "Location : %s(%d) %s\r\n",
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync pszExpr, pszFile, uLine, pszFunction);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync}
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsyncDECLHIDDEN(void) rtR0AssertNativeMsg2V(bool fInitial, const char *pszFormat, va_list va)
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync{
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#if defined(DEBUG_bird)
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync va_list vaCopy;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync va_copy(vaCopy, va);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync RTLogComPrintfV(pszFormat, vaCopy);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync va_end(vaCopy);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync#endif
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync size_t cch = g_cchRTAssertMsg;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync char *pch = &g_szRTAssertMsg[cch];
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync cch += RTStrFormatV(rtR0Os2AssertOutputCB, &pch, NULL, NULL, pszFormat, va);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync g_cchRTAssertMsg = cch;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync NOREF(fInitial);
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync}
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/**
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * Output callback.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * @returns number of bytes written.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * @param pvArg Pointer to a char pointer with the current output position.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * @param pachChars Pointer to an array of utf-8 characters.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync * @param cbChars Number of bytes in the character array pointed to by pachChars.
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsyncstatic DECLCALLBACK(size_t) rtR0Os2AssertOutputCB(void *pvArg, const char *pachChars, size_t cbChars)
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync{
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync char **ppch = (char **)pvArg;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync char *pch = *ppch;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync while (cbChars-- > 0)
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync {
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync const char ch = *pachChars++;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync if (ch == '\r')
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync continue;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync if (ch == '\n')
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync {
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync if (pch + 1 >= &g_szRTAssertMsg[sizeof(g_szRTAssertMsg)])
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync break;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *pch++ = '\r';
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync }
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync if (pch + 1 >= &g_szRTAssertMsg[sizeof(g_szRTAssertMsg)])
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync break;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *pch++ = ch;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync }
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *pch = '\0';
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync size_t cbWritten = pch - *ppch;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync *ppch = pch;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync return cbWritten;
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync}
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync/* RTR0AssertPanicSystem is implemented in RTR0AssertPanicSystem-r0drv-os2.asm */
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync
1b33c96954667ba382fa595baf7b31290bfdd517vboxsync