/** @file * DevPCNet - Private guest interface for the PCNet device. */ /* * Copyright (C) 2008 innotek 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 (GPL) 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. * * The contents of this file may alternatively be used under the terms * of the Common Development and Distribution License Version 1.0 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the * VirtualBox OSE distribution, in which case the provisions of the * CDDL are applicable instead of those of the GPL. * * You may elect to license modified versions of this file under the * terms and conditions of either the GPL or the CDDL or both. */ #ifndef ___VBox_DevPCNet_h #define ___VBox_DevPCNet_h #include /** @defgroup grp_devpcnet AMD PCnet-PCI II / PCnet-FAST III (Am79C970A / Am79C973) Ethernet Controller Emulation. * { */ #define PCNET_GUEST_INTERFACE_VERSION (1) #define PCNET_GUEST_SHARED_MEMORY_SIZE _1M #define PCNET_GUEST_TX_DESCRIPTOR_SIZE 16 #define PCNET_GUEST_RX_DESCRIPTOR_SIZE 16 #define PCNET_GUEST_MAX_TX_DESCRIPTORS 128 #define PCNET_GUEST_MAX_RX_DESCRIPTORS 256 #define PCNET_GUEST_NIC_BUFFER_SIZE 1536 /* 256*16 + 128*16 + 256*1536 + 128*1536 = 582KB */ /** * The header of the PCNet shared memory (VBox specific). */ #pragma pack(1) /* paranoia */ typedef struct { /** The size of the shared memory. * This is sizeof(PCNETGUESTSHAREDMEMORY) not PCNET_GUEST_SHARED_MEMORY_SIZE as one would expect. * @todo r=bird: why not rename to cbHdr or something more descriptive? */ uint32_t u32Size; /** Version (PCNET_GUEST_INTERFACE_VERSION). */ uint32_t u32Version; /** Flags (See PCNET_GUEST_FLAGS_*). */ uint32_t fFlags; /** @todo r=bird: You might consider aligning this on a 8(/16) byte boundrary to * avoid future uint64_t issues. */ union { struct { /** The size (in bytes) of the transmit descriptor array. */ uint32_t cbTxDescriptors; /** The size (in bytes) of the receive descriptor array. */ uint32_t cbRxDescriptors; /** Offset of the transmit descriptors relative to this header. * @todo r=bird: offTxDescriptors is IMO a better name. */ uint32_t u32OffTxDescriptors; /** Offset of the receive descriptors relative to this header. */ uint32_t u32OffRxDescriptors; /** Offset of the transmit buffers relative to this header. */ uint32_t u32OffTxBuffers; /** Offset of the receive buffers relative to this header. */ uint32_t u32OffRxBuffers; } V1; } V; } PCNETGUESTSHAREDMEMORY; #pragma pack() /** Pointer to the PCNet shared memory header. */ typedef PCNETGUESTSHAREDMEMORY *PPCNETGUESTSHAREDMEMORY; /** Const pointer to the PCNet shared memory header. */ typedef const PCNETGUESTSHAREDMEMORY *PCPCNETGUESTSHAREDMEMORY; /** @name fFlags definitions * @{ */ /** Host admits existence private PCNet interface. */ #define PCNET_GUEST_FLAGS_ADMIT_HOST RT_BIT(0) /** Guest admits using the private PCNet interface. */ #define PCNET_GUEST_FLAGS_ADMIT_GUEST RT_BIT(1) /** @} */ /** @} */ #endif