VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-cmn-TestPrintf.c@ 106560

Last change on this file since 106560 was 106061, checked in by vboxsync, 4 months ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.9 KB
Line 
1/* $Id: bs3-cmn-TestPrintf.c 106061 2024-09-16 14:03:52Z vboxsync $ */
2/** @file
3 * BS3Kit - BS3TestPrintf, BS3TestPrintfV
4 */
5
6/*
7 * Copyright (C) 2007-2024 Oracle and/or its affiliates.
8 *
9 * This file is part of VirtualBox base platform packages, as
10 * available from https://www.virtualbox.org.
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation, in version 3 of the
15 * License.
16 *
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, see <https://www.gnu.org/licenses>.
24 *
25 * The contents of this file may alternatively be used under the terms
26 * of the Common Development and Distribution License Version 1.0
27 * (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
28 * in the VirtualBox distribution, in which case the provisions of the
29 * CDDL are applicable instead of those of the GPL.
30 *
31 * You may elect to license modified versions of this file under the
32 * terms and conditions of either the GPL or the CDDL or both.
33 *
34 * SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
35 */
36
37
38/*********************************************************************************************************************************
39* Header Files *
40*********************************************************************************************************************************/
41#include "bs3kit-template-header.h"
42#include "bs3-cmn-test.h"
43
44#include <iprt/asm-amd64-x86.h>
45
46
47/*********************************************************************************************************************************
48* Defined Constants And Macros *
49*********************************************************************************************************************************/
50#define SMALL_BUFFER 1
51
52
53/*********************************************************************************************************************************
54* Structures and Typedefs *
55*********************************************************************************************************************************/
56/** Output buffering for Bs3TestPrintfV. */
57typedef struct BS3TESTPRINTBUF
58{
59 bool fNewCmd;
60#if SMALL_BUFFER
61 uint8_t cchBuf;
62 char achBuf[78];
63#else
64 uint16_t cchBuf;
65 char achBuf[512];
66#endif
67} BS3TESTPRINTBUF;
68
69
70/**
71 * @callback_method_impl{FNBS3STRFORMATOUTPUT, Prints to screen and VMMDev}
72 */
73static BS3_DECL_CALLBACK(size_t) bs3TestPrintfStrOutput(char ch, void BS3_FAR *pvUser)
74{
75 BS3TESTPRINTBUF BS3_FAR *pBuf = (BS3TESTPRINTBUF BS3_FAR *)pvUser;
76
77 /*
78 * VMMDev first. We do line by line processing to avoid running out of
79 * string buffer on the host side.
80 */
81 if (g_fbBs3VMMDevTesting)
82 {
83 if (ch != '\n' && !pBuf->fNewCmd)
84 ASMOutU8(VMMDEV_TESTING_IOPORT_DATA, ch);
85 else if (ch != '\0')
86 {
87 if (pBuf->fNewCmd)
88 {
89#if ARCH_BITS == 16
90 ASMOutU16(VMMDEV_TESTING_IOPORT_CMD, (uint16_t)VMMDEV_TESTING_CMD_PRINT);
91#else
92 ASMOutU32(VMMDEV_TESTING_IOPORT_CMD, VMMDEV_TESTING_CMD_PRINT);
93#endif
94 pBuf->fNewCmd = false;
95 }
96 ASMOutU8(VMMDEV_TESTING_IOPORT_DATA, ch);
97 if (ch == '\n')
98 {
99 ASMOutU8(VMMDEV_TESTING_IOPORT_DATA, '\0');
100 pBuf->fNewCmd = true;
101 }
102 }
103 }
104
105 /*
106 * Console next.
107 */
108 if (ch != '\0')
109 {
110 BS3_ASSERT(pBuf->cchBuf < RT_ELEMENTS(pBuf->achBuf));
111 pBuf->achBuf[pBuf->cchBuf++] = ch;
112
113 /* Whether to flush the buffer. We do line flushing here to avoid
114 dropping too much info when the formatter crashes on bad input. */
115 if ( pBuf->cchBuf < RT_ELEMENTS(pBuf->achBuf)
116 && (!SMALL_BUFFER || ch != '\n') )
117 return 1;
118 }
119 BS3_ASSERT(pBuf->cchBuf <= RT_ELEMENTS(pBuf->achBuf));
120 Bs3PrintStrN(&pBuf->achBuf[0], pBuf->cchBuf);
121 pBuf->cchBuf = 0;
122 return ch != '\0';
123}
124
125
126
127#undef Bs3TestPrintfV
128BS3_CMN_DEF(void, Bs3TestPrintfV,(const char BS3_FAR *pszFormat, va_list BS3_FAR va))
129{
130 BS3TESTPRINTBUF Buf;
131 Buf.fNewCmd = true;
132 Buf.cchBuf = 0;
133 Bs3StrFormatV(pszFormat, va, bs3TestPrintfStrOutput, &Buf);
134}
135
136
137
138#undef Bs3TestPrintf
139BS3_CMN_DEF(void, Bs3TestPrintf,(const char BS3_FAR *pszFormat, ...))
140{
141 va_list va;
142 va_start(va, pszFormat);
143 BS3_CMN_NM(Bs3TestPrintfV)(pszFormat, va);
144 va_end(va);
145}
146
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