VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/utils/TestExecServ/TestExecServiceInternal.h@ 74950

Last change on this file since 74950 was 70488, checked in by vboxsync, 7 years ago

ValidationKit/TestExecService: Added verbose output option. Made the txsDoUnpackFile command available on windows too.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.2 KB
Line 
1/* $Id: TestExecServiceInternal.h 70488 2018-01-08 20:40:45Z vboxsync $ */
2/** @file
3 * TestExecServ - Basic Remote Execution Service, Internal Header.
4 */
5
6/*
7 * Copyright (C) 2010-2017 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27#ifndef ___TestExecServiceInternal_h___
28#define ___TestExecServiceInternal_h___
29
30#include <iprt/getopt.h>
31#include <iprt/stream.h>
32
33RT_C_DECLS_BEGIN
34
35/**
36 * Packet header.
37 */
38typedef struct TXSPKTHDR
39{
40 /** The unpadded packet length. This include this header. */
41 uint32_t cb;
42 /** The CRC-32 for the packet starting from the opcode field. 0 if the packet
43 * hasn't been CRCed. */
44 uint32_t uCrc32;
45 /** Packet opcode, an unterminated ASCII string. */
46 uint8_t achOpcode[8];
47} TXSPKTHDR;
48AssertCompileSize(TXSPKTHDR, 16);
49/** Pointer to a packet header. */
50typedef TXSPKTHDR *PTXSPKTHDR;
51/** Pointer to a packet header. */
52typedef TXSPKTHDR const *PCTXSPKTHDR;
53/** Pointer to a packet header pointer. */
54typedef PTXSPKTHDR *PPTXSPKTHDR;
55
56/** Packet alignment. */
57#define TXSPKT_ALIGNMENT 16
58/** Max packet size. */
59#define TXSPKT_MAX_SIZE _256K
60
61
62/**
63 * Transport layer descriptor.
64 */
65typedef struct TXSTRANSPORT
66{
67 /** The name. */
68 char szName[16];
69 /** The description. */
70 const char *pszDesc;
71 /** Pointer to an array of options. */
72 PCRTGETOPTDEF paOpts;
73 /** The number of options in the array. */
74 size_t cOpts;
75
76 /**
77 * Print the usage information for this transport layer.
78 *
79 * @param pStream The stream to print the usage info to.
80 *
81 * @remarks This is only required if TXSTRANSPORT::cOpts is greater than 0.
82 */
83 DECLR3CALLBACKMEMBER(void, pfnUsage,(PRTSTREAM pStream));
84
85 /**
86 * Handle an option.
87 *
88 * When encountering an options that is not part of the base options, we'll call
89 * this method for each transport layer until one handles it.
90 *
91 * @retval VINF_SUCCESS if handled.
92 * @retval VERR_TRY_AGAIN if not handled.
93 * @retval VERR_INVALID_PARAMETER if we should exit with a non-zero status.
94 *
95 * @param ch The short option value.
96 * @param pVal Pointer to the value union.
97 *
98 * @remarks This is only required if TXSTRANSPORT::cOpts is greater than 0.
99 */
100 DECLR3CALLBACKMEMBER(int, pfnOption,(int ch, PCRTGETOPTUNION pVal));
101
102 /**
103 * Initializes the transport layer.
104 *
105 * @returns IPRT status code. On errors, the transport layer shall call
106 * RTMsgError to display the error details to the user.
107 */
108 DECLR3CALLBACKMEMBER(int, pfnInit,(void));
109
110 /**
111 * Terminate the transport layer, closing and freeing resources.
112 *
113 * On errors, the transport layer shall call RTMsgError to display the error
114 * details to the user.
115 */
116 DECLR3CALLBACKMEMBER(void, pfnTerm,(void));
117
118 /**
119 * Polls for incoming packets.
120 *
121 * @returns true if there are pending packets, false if there isn't.
122 */
123 DECLR3CALLBACKMEMBER(bool, pfnPollIn,(void));
124
125 /**
126 * Adds any pollable handles to the poll set.
127 *
128 * This is optional and layers that doesn't have anything that can be polled
129 * shall set this method pointer to NULL to indicate that pfnPollIn must be used
130 * instead.
131 *
132 * @returns IPRT status code.
133 * @param hPollSet The poll set to add them to.
134 * @param idStart The handle ID to start at.
135 */
136 DECLR3CALLBACKMEMBER(int, pfnPollSetAdd,(RTPOLLSET hPollSet, uint32_t idStart));
137
138 /**
139 * Receives an incoming packet.
140 *
141 * This will block until the data becomes available or we're interrupted by a
142 * signal or something.
143 *
144 * @returns IPRT status code. On error conditions other than VERR_INTERRUPTED,
145 * the current operation will be aborted when applicable. When
146 * interrupted, the transport layer will store the data until the next
147 * receive call.
148 *
149 * @param ppPktHdr Where to return the pointer to the packet we've
150 * read. This is allocated from the heap using
151 * RTMemAlloc (w/ TXSPKT_ALIGNMENT) and must be
152 * free by calling RTMemFree.
153 */
154 DECLR3CALLBACKMEMBER(int, pfnRecvPkt,(PPTXSPKTHDR ppPktHdr));
155
156 /**
157 * Sends an outgoing packet.
158 *
159 * This will block until the data has been written.
160 *
161 * @returns IPRT status code.
162 * @retval VERR_INTERRUPTED if interrupted before anything was sent.
163 *
164 * @param pPktHdr The packet to send. The size is given by
165 * aligning the size in the header by
166 * TXSPKT_ALIGNMENT.
167 */
168 DECLR3CALLBACKMEMBER(int, pfnSendPkt,(PCTXSPKTHDR pPktHdr));
169
170 /**
171 * Sends a babble packet and disconnects the client (if applicable).
172 *
173 * @param pPktHdr The packet to send. The size is given by
174 * aligning the size in the header by
175 * TXSPKT_ALIGNMENT.
176 * @param cMsSendTimeout The send timeout measured in milliseconds.
177 */
178 DECLR3CALLBACKMEMBER(void, pfnBabble,(PCTXSPKTHDR pPktHdr, RTMSINTERVAL cMsSendTimeout));
179
180 /**
181 * Notification about a client HOWDY.
182 */
183 DECLR3CALLBACKMEMBER(void, pfnNotifyHowdy,(void));
184
185 /**
186 * Notification about a client BYE.
187 *
188 * For connection oriented transport layers, it would be good to disconnect the
189 * client at this point.
190 */
191 DECLR3CALLBACKMEMBER(void, pfnNotifyBye,(void));
192
193 /**
194 * Notification about a REBOOT or SHUTDOWN.
195 *
196 * For connection oriented transport layers, stop listening for and
197 * accepting at this point.
198 */
199 DECLR3CALLBACKMEMBER(void, pfnNotifyReboot,(void));
200
201 /** Non-zero end marker. */
202 uint32_t u32EndMarker;
203} TXSTRANSPORT;
204/** Pointer to a const transport layer descriptor. */
205typedef const struct TXSTRANSPORT *PCTXSTRANSPORT;
206
207
208extern TXSTRANSPORT const g_TcpTransport;
209extern TXSTRANSPORT const g_SerialTransport;
210extern TXSTRANSPORT const g_FileSysTransport;
211extern TXSTRANSPORT const g_GuestPropTransport;
212extern TXSTRANSPORT const g_TestDevTransport;
213
214extern uint32_t g_cVerbose;
215
216RT_C_DECLS_END
217
218#endif
219
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