VirtualBox

source: vbox/trunk/src/VBox/Devices/Samples/VBoxSampleDevice.cpp@ 63910

Last change on this file since 63910 was 63886, checked in by vboxsync, 8 years ago

Devices/Samples: more version paranoia (solves unused parameters and is more safe)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.4 KB
Line 
1/* $Id: VBoxSampleDevice.cpp 63886 2016-09-19 13:02:14Z vboxsync $ */
2/** @file
3 * VBox Sample Device.
4 */
5
6/*
7 * Copyright (C) 2009-2016 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
18
19/*********************************************************************************************************************************
20* Header Files *
21*********************************************************************************************************************************/
22#define LOG_GROUP LOG_GROUP_MISC
23#include <VBox/vmm/pdmdev.h>
24#include <VBox/version.h>
25#include <VBox/err.h>
26#include <VBox/log.h>
27
28#include <iprt/assert.h>
29
30
31/*********************************************************************************************************************************
32* Structures and Typedefs *
33*********************************************************************************************************************************/
34/**
35 * Device Instance Data.
36 */
37typedef struct VBOXSAMPLEDEVICE
38{
39 uint32_t Whatever;
40} VBOXSAMPLEDEVICE;
41typedef VBOXSAMPLEDEVICE *PVBOXSAMPLEDEVICE;
42
43
44
45static DECLCALLBACK(int) devSampleDestruct(PPDMDEVINS pDevIns)
46{
47 /*
48 * Check the versions here as well since the destructor is *always* called.
49 */
50 AssertMsgReturn(pDevIns->u32Version == PDM_DEVINS_VERSION, ("%#x, expected %#x\n", pDevIns->u32Version, PDM_DEVINS_VERSION), VERR_VERSION_MISMATCH);
51 AssertMsgReturn(pDevIns->pHlpR3->u32Version == PDM_DEVHLPR3_VERSION, ("%#x, expected %#x\n", pDevIns->pHlpR3->u32Version, PDM_DEVHLPR3_VERSION), VERR_VERSION_MISMATCH);
52
53 return VINF_SUCCESS;
54}
55
56
57static DECLCALLBACK(int) devSampleConstruct(PPDMDEVINS pDevIns, int iInstance, PCFGMNODE pCfg)
58{
59 /*
60 * Check that the device instance and device helper structures are compatible.
61 */
62 AssertLogRelMsgReturn(pDevIns->u32Version == PDM_DEVINS_VERSION, ("%#x, expected %#x\n", pDevIns->u32Version, PDM_DEVINS_VERSION), VERR_VERSION_MISMATCH);
63 AssertLogRelMsgReturn(pDevIns->pHlpR3->u32Version == PDM_DEVHLPR3_VERSION, ("%#x, expected %#x\n", pDevIns->pHlpR3->u32Version, PDM_DEVHLPR3_VERSION), VERR_VERSION_MISMATCH);
64
65 /*
66 * Initialize the instance data so that the destructor won't mess up.
67 */
68 PVBOXSAMPLEDEVICE pThis = PDMINS_2_DATA(pDevIns, PVBOXSAMPLEDEVICE);
69 pThis->Whatever = 0;
70
71 /*
72 * Validate and read the configuration.
73 */
74 if (!CFGMR3AreValuesValid(pCfg,
75 "Whatever1\0"
76 "Whatever2\0"))
77 return VERR_PDM_DEVINS_UNKNOWN_CFG_VALUES;
78
79 /*
80 * Use the instance number if necessary (not for this device, which in
81 * g_DeviceSample below declares a maximum instance count of 1).
82 */
83 NOREF(iInstance);
84
85 return VINF_SUCCESS;
86}
87
88
89/**
90 * The device registration structure.
91 */
92static const PDMDEVREG g_DeviceSample =
93{
94 /* u32Version */
95 PDM_DEVREG_VERSION,
96 /* szName */
97 "sample",
98 /* szRCMod */
99 "",
100 /* szR0Mod */
101 "",
102 /* pszDescription */
103 "VBox Sample Device.",
104 /* fFlags */
105 PDM_DEVREG_FLAGS_DEFAULT_BITS,
106 /* fClass */
107 PDM_DEVREG_CLASS_MISC,
108 /* cMaxInstances */
109 1,
110 /* cbInstance */
111 sizeof(VBOXSAMPLEDEVICE),
112 /* pfnConstruct */
113 devSampleConstruct,
114 /* pfnDestruct */
115 devSampleDestruct,
116 /* pfnRelocate */
117 NULL,
118 /* pfnMemSetup */
119 NULL,
120 /* pfnPowerOn */
121 NULL,
122 /* pfnReset */
123 NULL,
124 /* pfnSuspend */
125 NULL,
126 /* pfnResume */
127 NULL,
128 /* pfnAttach */
129 NULL,
130 /* pfnDetach */
131 NULL,
132 /* pfnQueryInterface */
133 NULL,
134 /* pfnInitComplete */
135 NULL,
136 /* pfnPowerOff */
137 NULL,
138 /* pfnSoftReset */
139 NULL,
140 /* u32VersionEnd */
141 PDM_DEVREG_VERSION
142};
143
144
145/**
146 * Register devices provided by the plugin.
147 *
148 * @returns VBox status code.
149 * @param pCallbacks Pointer to the callback table.
150 * @param u32Version VBox version number.
151 */
152extern "C" DECLEXPORT(int) VBoxDevicesRegister(PPDMDEVREGCB pCallbacks, uint32_t u32Version)
153{
154 LogFlow(("VBoxSampleDevice::VBoxDevicesRegister: u32Version=%#x pCallbacks->u32Version=%#x\n", u32Version, pCallbacks->u32Version));
155
156 AssertLogRelMsgReturn(u32Version >= VBOX_VERSION,
157 ("VirtualBox version %#x, expected %#x or higher\n", u32Version, VBOX_VERSION),
158 VERR_VERSION_MISMATCH);
159 AssertLogRelMsgReturn(pCallbacks->u32Version == PDM_DEVREG_CB_VERSION,
160 ("callback version %#x, expected %#x\n", pCallbacks->u32Version, PDM_DEVREG_CB_VERSION),
161 VERR_VERSION_MISMATCH);
162
163 /* Two devices in this module. */
164 extern const PDMDEVREG g_DevicePlayground;
165 int rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceSample);
166 if (RT_SUCCESS(rc))
167 rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePlayground);
168 return rc;
169}
170
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