VirtualBox

source: vbox/trunk/src/VBox/Runtime/r0drv/os2/assert-r0drv-os2.cpp@ 78501

Last change on this file since 78501 was 77120, checked in by vboxsync, 6 years ago

IPRT: Some license header cleanups.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 6.0 KB
Line 
1/* $Id: assert-r0drv-os2.cpp 77120 2019-02-01 15:08:46Z vboxsync $ */
2/** @file
3 * IPRT - Assertion Workers, Ring-0 Drivers, OS/2.
4 */
5
6/*
7 * Contributed by knut st. osmundsen.
8 *
9 * Copyright (C) 2007-2019 Oracle Corporation
10 *
11 * This file is part of VirtualBox Open Source Edition (OSE), as
12 * available from http://www.virtualbox.org. This file is free software;
13 * you can redistribute it and/or modify it under the terms of the GNU
14 * General Public License (GPL) as published by the Free Software
15 * Foundation, in version 2 as it comes in the "COPYING" file of the
16 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
17 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
18 *
19 * The contents of this file may alternatively be used under the terms
20 * of the Common Development and Distribution License Version 1.0
21 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
22 * VirtualBox OSE distribution, in which case the provisions of the
23 * CDDL are applicable instead of those of the GPL.
24 *
25 * You may elect to license modified versions of this file under the
26 * terms and conditions of either the GPL or the CDDL or both.
27 *
28 * --------------------------------------------------------------------
29 *
30 * This code is based on:
31 *
32 * Copyright (c) 2007 knut st. osmundsen <bird-src-spam@anduin.net>
33 *
34 * Permission is hereby granted, free of charge, to any person
35 * obtaining a copy of this software and associated documentation
36 * files (the "Software"), to deal in the Software without
37 * restriction, including without limitation the rights to use,
38 * copy, modify, merge, publish, distribute, sublicense, and/or sell
39 * copies of the Software, and to permit persons to whom the
40 * Software is furnished to do so, subject to the following
41 * conditions:
42 *
43 * The above copyright notice and this permission notice shall be
44 * included in all copies or substantial portions of the Software.
45 *
46 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
47 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
48 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
49 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
50 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
51 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
52 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
53 * OTHER DEALINGS IN THE SOFTWARE.
54 */
55
56
57/*********************************************************************************************************************************
58* Header Files *
59*********************************************************************************************************************************/
60#include <iprt/assert.h>
61#include <iprt/log.h>
62#include <iprt/string.h>
63#include <iprt/stdarg.h>
64
65#include <VBox/log.h>
66
67#include "internal/assert.h"
68
69
70/*********************************************************************************************************************************
71* Global Variables *
72*********************************************************************************************************************************/
73RT_C_DECLS_BEGIN /* for watcom */
74/** The last assert message. (in DATA16) */
75extern char g_szRTAssertMsg[2048];
76/** The length of the last assert message. (in DATA16) */
77extern size_t g_cchRTAssertMsg;
78RT_C_DECLS_END
79
80
81/*********************************************************************************************************************************
82* Internal Functions *
83*********************************************************************************************************************************/
84static DECLCALLBACK(size_t) rtR0Os2AssertOutputCB(void *pvArg, const char *pachChars, size_t cbChars);
85
86
87DECLHIDDEN(void) rtR0AssertNativeMsg1(const char *pszExpr, unsigned uLine, const char *pszFile, const char *pszFunction)
88{
89#if defined(DEBUG_bird)
90 RTLogComPrintf("\n!!Assertion Failed!!\n"
91 "Expression: %s\n"
92 "Location : %s(%d) %s\n",
93 pszExpr, pszFile, uLine, pszFunction);
94#endif
95
96 g_cchRTAssertMsg = RTStrPrintf(g_szRTAssertMsg, sizeof(g_szRTAssertMsg),
97 "\r\n!!Assertion Failed!!\r\n"
98 "Expression: %s\r\n"
99 "Location : %s(%d) %s\r\n",
100 pszExpr, pszFile, uLine, pszFunction);
101}
102
103
104DECLHIDDEN(void) rtR0AssertNativeMsg2V(bool fInitial, const char *pszFormat, va_list va)
105{
106#if defined(DEBUG_bird)
107 va_list vaCopy;
108 va_copy(vaCopy, va);
109 RTLogComPrintfV(pszFormat, vaCopy);
110 va_end(vaCopy);
111#endif
112
113 size_t cch = g_cchRTAssertMsg;
114 char *pch = &g_szRTAssertMsg[cch];
115 cch += RTStrFormatV(rtR0Os2AssertOutputCB, &pch, NULL, NULL, pszFormat, va);
116 g_cchRTAssertMsg = cch;
117
118 NOREF(fInitial);
119}
120
121
122/**
123 * Output callback.
124 *
125 * @returns number of bytes written.
126 * @param pvArg Pointer to a char pointer with the current output position.
127 * @param pachChars Pointer to an array of utf-8 characters.
128 * @param cbChars Number of bytes in the character array pointed to by pachChars.
129 */
130static DECLCALLBACK(size_t) rtR0Os2AssertOutputCB(void *pvArg, const char *pachChars, size_t cbChars)
131{
132 char **ppch = (char **)pvArg;
133 char *pch = *ppch;
134
135 while (cbChars-- > 0)
136 {
137 const char ch = *pachChars++;
138 if (ch == '\r')
139 continue;
140 if (ch == '\n')
141 {
142 if (pch + 1 >= &g_szRTAssertMsg[sizeof(g_szRTAssertMsg)])
143 break;
144 *pch++ = '\r';
145 }
146 if (pch + 1 >= &g_szRTAssertMsg[sizeof(g_szRTAssertMsg)])
147 break;
148 *pch++ = ch;
149 }
150 *pch = '\0';
151
152 size_t cbWritten = pch - *ppch;
153 *ppch = pch;
154 return cbWritten;
155}
156
157
158/* RTR0AssertPanicSystem is implemented in RTR0AssertPanicSystem-r0drv-os2.asm */
159
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette