/** $Id: Builtins.cpp 229 2007-01-22 19:51:37Z vboxsync $ */ /** @file * Built-in drivers & devices (part 1) */ /* * Copyright (C) 2006 InnoTek Systemberatung GmbH * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License as published by the Free Software Foundation, * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE * distribution. VirtualBox OSE is distributed in the hope that it will * be useful, but WITHOUT ANY WARRANTY of any kind. * * If you received this file as part of a commercial VirtualBox * distribution, then only the terms of your commercial VirtualBox * license agreement apply instead of the previous paragraph. */ /******************************************************************************* * Header Files * *******************************************************************************/ #define LOG_GROUP LOG_GROUP_DEV #include #include #include #include #include #include #include "Builtins.h" /******************************************************************************* * Global Variables * *******************************************************************************/ const void *g_apvVBoxDDDependencies[] = { NULL, }; /** * Register builtin devices. * * @returns VBox status code. * @param pCallbacks Pointer to the callback table. * @param u32Version VBox version number. */ extern "C" DECLEXPORT(int) VBoxDevicesRegister(PPDMDEVREGCB pCallbacks, uint32_t u32Version) { LogFlow(("VBoxDevicesRegister: u32Version=%#x\n", u32Version)); AssertReleaseMsg(u32Version == VBOX_VERSION, ("u32Version=%#x VBOX_VERSION=%#x\n", u32Version, VBOX_VERSION)); int rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePCI); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePcArch); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePcBios); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePS2KeyboardMouse); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePIIX3IDE); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceI8254); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceI8259); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceMC146818); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceVga); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceVMMDev); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DevicePCNet); if (VBOX_FAILURE(rc)) return rc; #if 0 rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceNE2000); if (VBOX_FAILURE(rc)) return rc; #endif rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceICHAC97); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceAudioSniffer); if (VBOX_FAILURE(rc)) return rc; #if 0 /** @todo remove this, see #1407. */ rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceUSBBackend); if (VBOX_FAILURE(rc)) return rc; #endif #if defined(VBOX_WITH_USB) && (defined(__WIN__) || defined(__LINUX__) || defined(__L4ENV__)) rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceOHCI); if (VBOX_FAILURE(rc)) return rc; #endif #ifdef VBOX_ACPI rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceACPI); if (VBOX_FAILURE(rc)) return rc; #endif rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceDMA); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceFloppyController); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DeviceSerialPort); if (VBOX_FAILURE(rc)) return rc; return VINF_SUCCESS; } /** * Register builtin drivers. * * @returns VBox status code. * @param pCallbacks Pointer to the callback table. * @param u32Version VBox version number. */ extern "C" DECLEXPORT(int) VBoxDriversRegister(PCPDMDRVREGCB pCallbacks, uint32_t u32Version) { LogFlow(("VBoxDriversRegister: u32Version=%#x\n", u32Version)); AssertReleaseMsg(u32Version == VBOX_VERSION, ("u32Version=%#x VBOX_VERSION=%#x\n", u32Version, VBOX_VERSION)); int rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvMouseQueue); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvKeyboardQueue); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvBlock); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvVBoxHDD); if (VBOX_FAILURE(rc)) return rc; #if !defined(__L4ENV__) && !defined(__DARWIN__) && !defined(__OS2__) rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvHostDVD); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvHostFloppy); if (VBOX_FAILURE(rc)) return rc; #endif rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvMediaISO); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvRawImage); if (VBOX_FAILURE(rc)) return rc; #ifdef VBOX_WITH_ISCSI rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvISCSI); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvISCSITransportTcp); if (VBOX_FAILURE(rc)) return rc; #endif #ifndef __L4ENV__ rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvNAT); if (VBOX_FAILURE(rc)) return rc; #endif #if !defined(__DARWIN__) && !defined(__OS2__) rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvHostInterface); if (VBOX_FAILURE(rc)) return rc; #endif rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvIntNet); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvNetSniffer); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvAUDIO); if (VBOX_FAILURE(rc)) return rc; rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvACPI); if (VBOX_FAILURE(rc)) return rc; #if defined(VBOX_WITH_USB) && (defined(__WIN__) || defined(__LINUX__) || defined(__L4ENV__)) rc = pCallbacks->pfnRegister(pCallbacks, &g_DrvVUSBRootHub); if (VBOX_FAILURE(rc)) return rc; #endif return VINF_SUCCESS; }