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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
|
/*++
Copyright (c) 1990 Microsoft Corporation
Module Name:
ndis.h
Abstract:
This is the ndis header file for the Ungermann Bass Ethernet Controller.
It contains the various definitions, macros and function declarations
of the NDIS3.0 specification implemented in the Ungermann Bass Ethernet
Controller.
Author:
Sanjeev Katariya (sanjeevk) 03-05-92
Environment:
Kernel Mode Operating Systems : NT and other lesser OS's
Revision History:
Brian Lieuallen BrianLie 07/21/92
Made it work.
Brian Lieuallen BrianLie 12/15/93
Made it a mini-port
--*/
#define STATIC static
//
// This constant is used for places where NdisAllocateMemory
// needs to be called and the HighestAcceptableAddress does
// not matter.
//
extern NDIS_PHYSICAL_ADDRESS HighestAcceptableMax;
//
// NDIS 3.0 entry functions
//
VOID
UbneiAdjustMaxLookAhead(
IN PUBNEI_ADAPTER pAdapter
);
BOOLEAN
Ubnei_InterruptServiceRoutine(
IN PVOID DefferedContext
);
BOOLEAN
UbneiSetInitInterruptSync(
PVOID Context
);
BOOLEAN
UbneiSetNormalInterruptSync(
PVOID Context
);
//
// Contained in CARD.C
//
BOOLEAN
CardTest (
OUT PUBNEI_ADAPTER pAdapter
);
BOOLEAN
CardSetup (
OUT PUBNEI_ADAPTER pAdapter
);
BOOLEAN
CardStartNIU(
OUT PUBNEI_ADAPTER pNewAdapt
);
BOOLEAN
NIU_General_Request3(
IN NIU_GEN_REQ_DPC pDPCCallback,
IN PVOID pContext,
IN USHORT RequestCode,
IN USHORT param1,
IN PUCHAR param2
);
VOID
NIU_General_Req_Result_Hand(
IN PUBNEI_ADAPTER pAdapt
);
VOID
NIU_Send_Request_To_Card(
IN PUBNEI_ADAPTER pAdapt
);
VOID
NIU_Abort_General_Req(
IN PUBNEI_ADAPTER pAdapter
);
VOID
OpenAdapterDPC(
IN NDIS_STATUS status,
IN PVOID pContext
);
VOID
ChangeAddressDPC(
IN NDIS_STATUS status,
IN PVOID pContext
);
VOID
ResetAdapterDPC(
IN NDIS_STATUS status,
IN PVOID pContext
);
VOID
DummyDPC(
IN NDIS_STATUS status,
IN PVOID pContext
);
VOID
CloseAdapterDPC(
IN NDIS_STATUS status,
IN PVOID pContext
);
//
// Contained in send.c
//
VOID
CheckForSends(
PUBNEI_ADAPTER pAdapt
);
//
// Contained in receive.c
//
BOOLEAN
CheckForReceives(
IN PUBNEI_ADAPTER pAdapter
);
//
// Contained in registry.c
//
NDIS_STATUS
UbneiReadRegistry(
IN PUBNEI_ADAPTER pAdapter,
IN NDIS_HANDLE ConfigurationHandle
);
BOOLEAN
UbneiCheckForHang(
IN NDIS_HANDLE MiniportAdapterContext
);
NDIS_STATUS
UbneiQueryInformation(
IN NDIS_HANDLE MiniportContext,
IN NDIS_OID Oid,
IN PVOID InfoBuffer,
IN ULONG BytesLeft,
OUT PULONG BytesNeeded,
OUT PULONG BytesWritten
);
NDIS_STATUS
UbneiSetInformation(
IN NDIS_HANDLE MiniportAdapterContext,
IN NDIS_OID Oid,
IN PVOID InformationBuffer,
IN ULONG InformationBufferLength,
OUT PULONG BytesRead,
OUT PULONG BytesNeeded
);
NDIS_STATUS
UbneiInitialize(
OUT PNDIS_STATUS OpenErrorStatus,
OUT PUINT SelectedMediumIndex,
IN PNDIS_MEDIUM MediumArray,
IN UINT MediumArraySize,
IN NDIS_HANDLE MiniportAdapterHandle,
IN NDIS_HANDLE WrapperConfigurationContext
);
VOID
UbneiHalt(
IN NDIS_HANDLE MiniportAdapterContext
);
NDIS_STATUS
UbneiReset(
OUT PBOOLEAN AddressResetting,
IN NDIS_HANDLE MacBindingHandle
);
NDIS_STATUS
UbneiMacSend(
IN NDIS_HANDLE MacBindingHandle,
IN PNDIS_PACKET pPacket,
IN UINT Flags
);
NDIS_STATUS
UbneiTransferData(
OUT PNDIS_PACKET Packet,
OUT PUINT BytesTransferred,
IN NDIS_HANDLE MacBindingHandle,
IN NDIS_HANDLE MacReceiveContext,
IN UINT ByteOffset,
IN UINT BytesToTransfer
);
NDIS_STATUS
UbneiReconfigure(
OUT PNDIS_STATUS OpenErrorStatus,
IN NDIS_HANDLE MiniportAdapterContext,
IN NDIS_HANDLE ConfigurationHanel
);
VOID
UbneiIsr(
OUT PBOOLEAN InterruptRecognized,
OUT PBOOLEAN QueueDpc,
IN NDIS_HANDLE Context
);
VOID
UbneiIsrDpc(
IN NDIS_HANDLE DeferredContext // will be a pointer to the adapter block
);
VOID
UbneiEnableInterrupts(
IN NDIS_HANDLE Context
);
VOID
UbneiDisableInterrupts(
IN NDIS_HANDLE Context
);
VOID
UbneiMapRegisterChangeSync(
PSYNC_CONTEXT Context
);
NDIS_STATUS
UbneiAddressChangeAction(
IN UINT NewFilterCount,
IN PUCHAR NewAddresses,
IN NDIS_HANDLE MacBindingHandle
);
NDIS_STATUS
UbneiFilterChangeAction(
IN UINT NewFilterClasses,
IN NDIS_HANDLE MacBindingHandle
);
|