2 EFI internal structures for the EFI UNDI driver.
4 Copyright (c) 2006 - 2007, Intel Corporation.
5 All rights reserved. This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
20 #include <Guid/EventGroup.h>
21 #include <Protocol/PciIo.h>
22 #include <Protocol/NetworkInterfaceIdentifier.h>
23 #include <Protocol/DevicePath.h>
25 #include <Library/UefiDriverEntryPoint.h>
26 #include <Library/UefiRuntimeLib.h>
27 #include <Library/DebugLib.h>
28 #include <Library/BaseMemoryLib.h>
29 #include <Library/UefiBootServicesTableLib.h>
30 #include <Library/UefiLib.h>
32 #include <IndustryStandard/Pci.h>
37 #define MAX_NIC_INTERFACES 16
39 #define EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_REVISION_31 0x00010001
40 #define PXE_ROMID_MINORVER_31 0x10
41 #define PXE_STATFLAGS_DB_WRITE_TRUNCATED 0x2000
44 // UNDI_CALL_TABLE.state can have the following values
48 #define MUST_BE_STARTED 1
49 #define MUST_BE_INITIALIZED 2
51 #define UNDI_DEV_SIGNATURE EFI_SIGNATURE_32('u','n','d','i')
52 #define UNDI_DEV_FROM_THIS(a) CR(a, UNDI32_DEV, NIIProtocol_31, UNDI_DEV_SIGNATURE)
53 #define UNDI_DEV_FROM_NIC(a) CR(a, UNDI32_DEV, NicInfo, UNDI_DEV_SIGNATURE)
57 EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL NIIProtocol_31
;
58 EFI_HANDLE DeviceHandle
;
59 EFI_DEVICE_PATH_PROTOCOL
*Undi32BaseDevPath
;
60 EFI_DEVICE_PATH_PROTOCOL
*Undi32DevPath
;
61 NIC_DATA_INSTANCE NicInfo
;
73 EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL
*InterfacePointer
;
74 EFI_DEVICE_PATH_PROTOCOL
*DevicePathPointer
;
77 typedef struct NII_CONFIG_ENTRY
{
79 UINT32 Reserved
; // padding for alignment
80 struct NII_CONFIG_ENTRY
*NextLink
;
81 NII_ENTRY NiiEntry
[1];
84 typedef VOID (*ptr
)(VOID
);
85 typedef VOID (*bsptr_30
)(UINTN
);
86 typedef VOID (*virtphys_30
)(UINT64
, UINT64
);
87 typedef VOID (*block_30
)(UINT32
);
88 typedef VOID (*mem_io_30
)(UINT8
, UINT8
, UINT64
, UINT64
);
90 typedef VOID (*bsptr
)(UINT64
, UINTN
);
91 typedef VOID (*virtphys
)(UINT64
, UINT64
, UINT64
);
92 typedef VOID (*block
)(UINT64
, UINT32
);
93 typedef VOID (*mem_io
)(UINT64
, UINT8
, UINT8
, UINT64
, UINT64
);
95 typedef VOID (*map_mem
)(UINT64
, UINT64
, UINT32
, UINT32
, UINT64
);
96 typedef VOID (*unmap_mem
)(UINT64
, UINT64
, UINT32
, UINT32
, UINT64
);
97 typedef VOID (*sync_mem
)(UINT64
, UINT64
, UINT32
, UINT32
, UINT64
);
99 extern UNDI_CALL_TABLE api_table
[];
100 extern PXE_SW_UNDI
*pxe_31
; // !pxe structure for 3.1 drivers
101 extern UNDI32_DEV
*UNDI32DeviceList
[MAX_NIC_INTERFACES
];
104 // functions defined in e100b.c
106 UINT8
InByte (NIC_DATA_INSTANCE
*AdapterInfo
, UINT32 Port
);
107 UINT16
InWord (NIC_DATA_INSTANCE
*AdapterInfo
, UINT32 Port
);
108 UINT32
InLong (NIC_DATA_INSTANCE
*AdapterInfo
, UINT32 Port
);
109 VOID
OutByte (NIC_DATA_INSTANCE
*AdapterInfo
, UINT8 Data
, UINT32 Port
);
110 VOID
OutWord (NIC_DATA_INSTANCE
*AdapterInfo
, UINT16 Data
, UINT32 Port
);
111 VOID
OutLong (NIC_DATA_INSTANCE
*AdapterInfo
, UINT32 Data
, UINT32 Port
);
113 UINTN
E100bInit (NIC_DATA_INSTANCE
*AdapterInfo
);
114 UINTN
E100bReset (NIC_DATA_INSTANCE
*AdapterInfo
, INT32 OpFlags
);
115 UINTN
E100bShutdown (NIC_DATA_INSTANCE
*AdapterInfo
);
116 UINTN
E100bTransmit (NIC_DATA_INSTANCE
*AdapterInfo
, UINT64 cpb
, UINT16 opflags
);
117 UINTN
E100bReceive (NIC_DATA_INSTANCE
*AdapterInfo
, UINT64 cpb
, UINT64 db
);
118 UINTN
E100bSetfilter (NIC_DATA_INSTANCE
*AdapterInfo
, UINT16 New_filter
,
119 UINT64 cpb
, UINT32 cpbsize
);
120 UINTN
E100bStatistics(NIC_DATA_INSTANCE
*AdapterInfo
, UINT64 db
, UINT16 dbsize
);
121 UINT8
E100bSetupIAAddr (NIC_DATA_INSTANCE
*AdapterInfo
);
122 UINT8
E100bSetInterruptState (NIC_DATA_INSTANCE
*AdapterInfo
);
124 UINT8
E100bGetEepromAddrLen (NIC_DATA_INSTANCE
*AdapterInfo
);
125 UINT16
E100bReadEeprom (NIC_DATA_INSTANCE
*AdapterInfo
, INT32 Location
, UINT8 address_len
);
126 INT16
E100bReadEepromAndStationAddress (NIC_DATA_INSTANCE
*AdapterInfo
);
129 UINT8
SetupCBlink (NIC_DATA_INSTANCE
*AdapterInfo
);
130 VOID
SetFreeCB (NIC_DATA_INSTANCE
*AdapterInfo
,TxCB
*);
131 TxCB
*GetFreeCB (NIC_DATA_INSTANCE
*AdapterInfo
);
132 UINT16
CheckCBList (NIC_DATA_INSTANCE
*AdapterInfo
);
134 UINT8
SelectiveReset (NIC_DATA_INSTANCE
*AdapterInfo
);
135 UINT16
InitializeChip (NIC_DATA_INSTANCE
*AdapterInfo
);
136 UINT8
SetupReceiveQueues (NIC_DATA_INSTANCE
*AdapterInfo
);
137 VOID
Recycle_RFD (NIC_DATA_INSTANCE
*AdapterInfo
, UINT16
);
138 VOID
XmitWaitForCompletion (NIC_DATA_INSTANCE
*AdapterInfo
);
139 INT8
CommandWaitForCompletion (TxCB
*cmd_ptr
, NIC_DATA_INSTANCE
*AdapterInfo
);
141 BOOLEAN
PhyDetect (NIC_DATA_INSTANCE
*AdapterInfo
);
142 VOID
PhyReset (NIC_DATA_INSTANCE
*AdapterInfo
);
145 IN NIC_DATA_INSTANCE
*AdapterInfo
,
153 IN NIC_DATA_INSTANCE
*AdapterInfo
,
156 IN OUT UINT16
*DataValue
159 BOOLEAN
SetupPhy (NIC_DATA_INSTANCE
*AdapterInfo
);
160 VOID
FindPhySpeedAndDpx (NIC_DATA_INSTANCE
*AdapterInfo
, UINT32 PhyId
);
165 // functions defined in init.c
174 InitializeUNDIDriver (
175 IN EFI_HANDLE ImageHandle
,
176 IN EFI_SYSTEM_TABLE
*SystemTable
180 UNDI_notify_virtual (
194 UndiDriverSupported (
195 IN EFI_DRIVER_BINDING_PROTOCOL
*This
,
196 IN EFI_HANDLE Controller
,
197 IN EFI_DEVICE_PATH_PROTOCOL
*RemainingDevicePath
203 IN EFI_DRIVER_BINDING_PROTOCOL
*This
,
204 IN EFI_HANDLE Controller
,
205 IN EFI_DEVICE_PATH_PROTOCOL
*RemainingDevicePath
211 IN EFI_DRIVER_BINDING_PROTOCOL
*This
,
212 IN EFI_HANDLE Controller
,
213 IN UINTN NumberOfChildren
,
214 IN EFI_HANDLE
*ChildHandleBuffer
219 IN OUT EFI_DEVICE_PATH_PROTOCOL
**DevPtr
,
220 IN EFI_DEVICE_PATH_PROTOCOL
*BaseDevPtr
,
221 IN NIC_DATA_INSTANCE
*AdapterInfo
227 IN UINTN MicroSeconds
240 // functions defined in decode.c
245 IN NIC_DATA_INSTANCE
*AdapterInfo
251 IN NIC_DATA_INSTANCE
*AdapterInfo
257 IN NIC_DATA_INSTANCE
*AdapterInfo
263 IN NIC_DATA_INSTANCE
*AdapterInfo
269 IN NIC_DATA_INSTANCE
*AdapterInfo
275 NIC_DATA_INSTANCE
*AdapterInfo
281 IN NIC_DATA_INSTANCE
*AdapterInfo
287 IN NIC_DATA_INSTANCE
*AdapterInfo
293 IN NIC_DATA_INSTANCE
*AdapterInfo
299 IN NIC_DATA_INSTANCE
*AdapterInfo
305 IN NIC_DATA_INSTANCE
*AdapterInfo
311 IN NIC_DATA_INSTANCE
*AdapterInfo
317 IN NIC_DATA_INSTANCE
*AdapterInfo
323 IN NIC_DATA_INSTANCE
*AdapterInfo
329 IN NIC_DATA_INSTANCE
*AdapterInfo
335 IN NIC_DATA_INSTANCE
*AdapterInfo
341 IN NIC_DATA_INSTANCE
*AdapterInfo
347 IN NIC_DATA_INSTANCE
*AdapterInfo
350 VOID
UNDI_APIEntry_new(UINT64
);
351 VOID
UNDI_APIEntry_Common(UINT64
);
353 PXE_IPV4
convert_mcip(PXE_MAC_ADDR
*);
354 INT32
validate_mcip (PXE_MAC_ADDR
*MCastAddr
);
356 VOID
PxeStructInit (PXE_SW_UNDI
*PxePtr
);
357 VOID
PxeUpdate (NIC_DATA_INSTANCE
*NicPtr
, PXE_SW_UNDI
*PxePtr
);