VirtualBox

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

Last change on this file since 60961 was 56295, checked in by vboxsync, 10 years ago

ValidationKit: Updated (C) year.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.3 KB
Line 
1/* $Id: TestExecServiceInternal.h 56295 2015-06-09 14:29:55Z vboxsync $ */
2/** @file
3 * TestExecServ - Basic Remote Execution Service, Internal Header.
4 */
5
6/*
7 * Copyright (C) 2010-2015 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 pThis Pointer to the transport layer descriptor.
80 * @param pStream The stream to print the usage info to.
81 *
82 * @remarks This is only required if TXSTRANSPORT::cOpts is greater than 0.
83 */
84 DECLR3CALLBACKMEMBER(void, pfnUsage,(PRTSTREAM pStream));
85
86 /**
87 * Handle an option.
88 *
89 * When encountering an options that is not part of the base options, we'll call
90 * this method for each transport layer until one handles it.
91 *
92 * @retval VINF_SUCCESS if handled.
93 * @retval VERR_TRY_AGAIN if not handled.
94 * @retval VERR_INVALID_PARAMETER if we should exit with a non-zero status.
95 *
96 * @param pThis Pointer to the transport layer descriptor.
97 * @param ch The short option value.
98 * @param pVal Pointer to the value union.
99 *
100 * @remarks This is only required if TXSTRANSPORT::cOpts is greater than 0.
101 */
102 DECLR3CALLBACKMEMBER(int, pfnOption,(int ch, PCRTGETOPTUNION pVal));
103
104 /**
105 * Initializes the transport layer.
106 *
107 * @returns IPRT status code. On errors, the transport layer shall call
108 * RTMsgError to display the error details to the user.
109 */
110 DECLR3CALLBACKMEMBER(int, pfnInit,(void));
111
112 /**
113 * Terminate the transport layer, closing and freeing resources.
114 *
115 * On errors, the transport layer shall call RTMsgError to display the error
116 * details to the user.
117 */
118 DECLR3CALLBACKMEMBER(void, pfnTerm,(void));
119
120 /**
121 * Polls for incoming packets.
122 *
123 * @returns true if there are pending packets, false if there isn't.
124 */
125 DECLR3CALLBACKMEMBER(bool, pfnPollIn,(void));
126
127 /**
128 * Adds any pollable handles to the poll set.
129 *
130 * This is optional and layers that doesn't have anything that can be polled
131 * shall set this method pointer to NULL to indicate that pfnPollIn must be used
132 * instead.
133 *
134 * @returns IPRT status code.
135 * @param hPollSet The poll set to add them to.
136 * @param idStart The handle ID to start at.
137 */
138 DECLR3CALLBACKMEMBER(int, pfnPollSetAdd,(RTPOLLSET hPollSet, uint32_t idStart));
139
140 /**
141 * Receives an incoming packet.
142 *
143 * This will block until the data becomes available or we're interrupted by a
144 * signal or something.
145 *
146 * @returns IPRT status code. On error conditions other than VERR_INTERRUPTED,
147 * the current operation will be aborted when applicable. When
148 * interrupted, the transport layer will store the data until the next
149 * receive call.
150 *
151 * @param ppPktHdr Where to return the pointer to the packet we've
152 * read. This is allocated from the heap using
153 * RTMemAlloc (w/ TXSPKT_ALIGNMENT) and must be
154 * free by calling RTMemFree.
155 */
156 DECLR3CALLBACKMEMBER(int, pfnRecvPkt,(PPTXSPKTHDR ppPktHdr));
157
158 /**
159 * Sends an outgoing packet.
160 *
161 * This will block until the data has been written.
162 *
163 * @returns IPRT status code.
164 * @retval VERR_INTERRUPTED if interrupted before anything was sent.
165 *
166 * @param pPktHdr The packet to send. The size is given by
167 * aligning the size in the header by
168 * TXSPKT_ALIGNMENT.
169 */
170 DECLR3CALLBACKMEMBER(int, pfnSendPkt,(PCTXSPKTHDR pPktHdr));
171
172 /**
173 * Sends a babble packet and disconnects the client (if applicable).
174 *
175 * @param pPktHdr The packet to send. The size is given by
176 * aligning the size in the header by
177 * TXSPKT_ALIGNMENT.
178 * @param cMsSendTimeout The send timeout measured in milliseconds.
179 */
180 DECLR3CALLBACKMEMBER(void, pfnBabble,(PCTXSPKTHDR pPktHdr, RTMSINTERVAL cMsSendTimeout));
181
182 /**
183 * Notification about a client HOWDY.
184 */
185 DECLR3CALLBACKMEMBER(void, pfnNotifyHowdy,(void));
186
187 /**
188 * Notification about a client BYE.
189 *
190 * For connection oriented transport layers, it would be good to disconnect the
191 * client at this point.
192 */
193 DECLR3CALLBACKMEMBER(void, pfnNotifyBye,(void));
194
195 /**
196 * Notification about a REBOOT or SHUTDOWN.
197 *
198 * For connection oriented transport layers, stop listening for and
199 * accepting at this point.
200 */
201 DECLR3CALLBACKMEMBER(void, pfnNotifyReboot,(void));
202
203 /** Non-zero end marker. */
204 uint32_t u32EndMarker;
205} TXSTRANSPORT;
206/** Pointer to a const transport layer descriptor. */
207typedef const struct TXSTRANSPORT *PCTXSTRANSPORT;
208
209
210extern TXSTRANSPORT const g_TcpTransport;
211extern TXSTRANSPORT const g_SerialTransport;
212extern TXSTRANSPORT const g_FileSysTransport;
213extern TXSTRANSPORT const g_GuestPropTransport;
214extern TXSTRANSPORT const g_TestDevTransport;
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