summaryrefslogtreecommitdiff
path: root/include/VBox/DevPCNet.h
blob: 52e357ad24ff0dc66ad6cd04a0b1aea2f00f295f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/** @file
 * DevPCNet - Private guest interface for the PCNet device. (DEV)
 */

/*
 * Copyright (C) 2008 Oracle Corporation
 *
 * 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 <iprt/types.h>

/** @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        _512K
#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 that's being used.
     * (This is <= PCNET_GUEST_SHARED_MEMORY_SIZE.) */
    uint32_t cbUsed;
    /** Version (PCNET_GUEST_INTERFACE_VERSION). */
    uint32_t u32Version;
    /** Flags (See PCNET_GUEST_FLAGS_*). */
    uint32_t fFlags;
    /** Align the following members to 64 bit. */
    uint32_t u32Alignment;

    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. */
            uint32_t    offTxDescriptors;
            /** Offset of the receive descriptors relative to this header. */
            uint32_t    offRxDescriptors;
            /** Offset of the transmit buffers relative to this header. */
            uint32_t    offTxBuffers;
            /** Offset of the receive buffers relative to this header. */
            uint32_t    offRxBuffers;
        } 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