亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cs8900sw.h

?? windows ce 50 drive program
?? H
字號:
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) 1998 Samsung Electronics.

Module Name:

    cs8900sw.h

Abstract:

    The main header for an Cirrus Logic CS8900 Miniport driver.

Notes:

--*/

#ifndef _CS8900SFT_
#define _CS8900SFT_


#define DRIVER_MAJOR_VERSION        0x01
#define DRIVER_MINOR_VERSION        0x00

#define CS8900_NDIS_MAJOR_VERSION 5
#define CS8900_NDIS_MINOR_VERSION 1

#define	MAXLOOP						0x8888

//
// This macro is used along with the flags to selectively
// turn on debugging.
//

#if DBG

#define IF_CS8900DEBUG(f) if (Ne2000DebugFlag & (f))
extern ULONG Ne2000DebugFlag;

#define CS8900_DEBUG_LOUD               0x00000001  // debugging info
#define CS8900_DEBUG_VERY_LOUD          0x00000002  // excessive debugging info
#define CS8900_DEBUG_LOG                0x00000004  // enable Ne2000Log
#define CS8900_DEBUG_CHECK_DUP_SENDS    0x00000008  // check for duplicate sends
#define CS8900_DEBUG_TRACK_PACKET_LENS  0x00000010  // track directed packet lens
#define CS8900_DEBUG_WORKAROUND1        0x00000020  // drop DFR/DIS packets
#define CS8900_DEBUG_CARD_BAD           0x00000040  // dump data if CARD_BAD
#define CS8900_DEBUG_CARD_TESTS         0x00000080  // print reason for failing

//
// Macro for deciding whether to print a lot of debugging information.
//

#define IF_LOUD(A) IF_CS8900DEBUG( CS8900_DEBUG_LOUD ) { A }
#define IF_VERY_LOUD(A) IF_CS8900DEBUG( CS8900_DEBUG_VERY_LOUD ) { A }

//
// Whether to use the Ne2000Log buffer to record a trace of the driver.
//
#define IF_LOG(A) IF_CS8900DEBUG( CS8900_DEBUG_LOG ) { A }
extern VOID Ne2000Log(UCHAR);

//
// Whether to do loud init failure
//
#define IF_INIT(A) A

//
// Whether to do loud card test failures
//
#define IF_TEST(A) IF_CS8900DEBUG( CS8900_DEBUG_CARD_TESTS ) { A }

//
// Windows CE debug zones
//
#define ZONE_ERROR      DEBUGZONE(0)
#define ZONE_WARN       DEBUGZONE(1)
#define ZONE_FUNCTION   DEBUGZONE(2)
#define ZONE_INIT       DEBUGZONE(3)
#define ZONE_INTR       DEBUGZONE(4)
#define ZONE_RCV        DEBUGZONE(5)
#define ZONE_XMIT       DEBUGZONE(6)

#else

//
// This is not a debug build, so make everything quiet.
//
#define IF_LOUD(A)
#define IF_VERY_LOUD(A)
#define IF_LOG(A)
#define IF_INIT(A)
#define IF_TEST(A)

#endif

//
// Create a macro for moving memory from place to place.  Makes
// the code more readable and portable in case we ever support
// a shared memory CS8900 adapter.
//
#define CS8900_MOVE_MEM(dest,src,size) NdisMoveMemory(dest,src,size)

//
// The status of transmit buffers.
//

typedef enum {
    EMPTY = 0x00,
    FULL = 0x02
} BUFFER_STATUS;

//
// Type of an interrupt.
//

typedef enum {
    RECEIVE     = 0x01,
    TRANSMIT    = 0x02,
    BUFOVERFLOW = 0x04,
    COUNTER     = 0x08,
    UNKNOWN     = 0x10
} INTERRUPT_TYPE;

//
// Size of the ethernet header
//
#define	CS8900_HEADER_SIZE		14

//
// Size of the ethernet address
//
#define	CS8900_LENGTH_OF_ADDRESS 6

//
// Number of bytes allowed in a lookahead (max)
//
#define CS8900_MAX_LOOKAHEAD (1518 - CS8900_HEADER_SIZE)

//
// Maximum number of transmit buffers on the card.
//
//#define MAX_XMIT_BUFS   12

//
// Definition of a transmit buffer.
//
//typedef UINT XMIT_BUF;

//
// Number of 256-byte buffers in a transmit buffer.
//
#define BUFS_PER_TX 1

//
// Size of a single transmit buffer.
//
#define TX_BUF_SIZE (BUFS_PER_TX*256)

//
// This structure contains information about the driver
// itself.  There is only have one of these structures.
//
typedef struct _DRIVER_BLOCK {

    //
    // NDIS wrapper information.
    //
    NDIS_HANDLE NdisMacHandle;          // returned from NdisRegisterMac
    NDIS_HANDLE NdisWrapperHandle;      // returned from NdisInitializeWrapper

    //
    // Adapters registered for this Miniport driver.
    //
    struct _CS8900_ADAPTER * AdapterQueue;

} DRIVER_BLOCK, * PDRIVER_BLOCK;



//
// This structure contains all the information about a single
// adapter that this driver is controlling.
//
typedef struct _CS8900_ADAPTER {

    //
    // This is the handle given by the wrapper for calling ndis
    // functions.
    //
    NDIS_HANDLE MiniportAdapterHandle;

    //
    // Interrupt object.
    //
    NDIS_MINIPORT_INTERRUPT Interrupt;

    //
    // used by DriverBlock->AdapterQueue
    //
    struct _CS8900_ADAPTER * NextAdapter;

    //
    // This is a count of the number of receives that have been
    // indicated in a row.  This is used to limit the number
    // of sequential receives so that one can periodically check
    // for transmit complete interrupts.
    //
    ULONG ReceivePacketCount;

    //
    // Configuration information
    //

    //
    // Physical address of the IoBaseAddress
    //
    PVOID IoBaseAddr;

    //
    // Interrupt number this adapter is using.
    //
    CHAR InterruptNumber;

    //
    // Number of multicast addresses that this adapter is to support.
    //
    UINT MulticastListMax;

    //
    // The type of bus that this adapter is running on.  Either ISA or
    // MCA.
    //
    UCHAR BusType;

    //
    // InterruptType is the next interrupt that should be serviced.
    //
    UCHAR InterruptType;

    //
    //  Type of CS8900 card.
    //
    UINT    CardType;

    //
    //  Address of the memory window.
    //
    ULONG   AttributeMemoryAddress;
    ULONG   AttributeMemorySize;

    //
    // Operational information.
    //

    //
    // Mapped address of the base io port.
    //
    ULONG IoPAddr;
  
    //
    // InterruptStatus tracks interrupt sources that still need to be serviced,
    // it is the logical OR of all card interrupts that have been received and not
    // processed and cleared. (see also INTERRUPT_TYPE definition in cs8900.h)
    //
    UCHAR InterruptStatus;

    //
    // The ethernet address currently in use.
    //
    UCHAR StationAddress[CS8900_LENGTH_OF_ADDRESS];

    //
    // The ethernet address that is burned into the adapter.
    //
    UCHAR PermanentAddress[CS8900_LENGTH_OF_ADDRESS];

    //
    // The current packet filter in use.
    //
    ULONG PacketFilter;

    //
    // Flag that is set when we are shutting down the interface
    //
	BOOLEAN ShuttingDown;
    
    //
    // Statistics used by Set/QueryInformation.
    //

    ULONG FramesXmitGood;               // Good Frames Transmitted
    ULONG FramesRcvGood;                // Good Frames Received
    ULONG FramesXmitBad;                // Bad Frames Transmitted
    ULONG FramesXmitOneCollision;       // Frames Transmitted with one collision
    ULONG FramesXmitManyCollisions;     // Frames Transmitted with > 1 collision
    ULONG FrameAlignmentErrors;         // FAE errors counted
    ULONG CrcErrors;                    // CRC errors counted
    ULONG MissedPackets;                // missed packet counted

    //
    // Reset information.
    //

    UCHAR NicMulticastRegs[8];          // contents of card multicast registers
    UCHAR NicReceiveConfig;             // contents of NIC RCR
    UCHAR NicInterruptMask;             // contents of NIC IMR

    //
    // The lookahead buffer size in use.
    //
    ULONG MaxLookAhead;

    //
    // CS8900 address of the beginning of the packet.
    //
    PUCHAR PacketHeaderLoc;

    //
    // Lookahead buffer
    //
    UCHAR Lookahead[CS8900_MAX_LOOKAHEAD + CS8900_HEADER_SIZE];

    //
    // List of multicast addresses in use.
    //
    CHAR Addresses[DEFAULT_MULTICASTLISTMAX][CS8900_LENGTH_OF_ADDRESS];

} CS8900_ADAPTER, * PCS8900_ADAPTER;



//
// Given a MiniportContextHandle return the PCS8900_ADAPTER
// it represents.
//
#define PCS8900_ADAPTER_FROM_CONTEXT_HANDLE(Handle) \
    ((PCS8900_ADAPTER)(Handle))

//
// Given a pointer to a CS8900_ADAPTER return the
// proper MiniportContextHandle.
//
#define CONTEXT_HANDLE_FROM_PCS8900_ADAPTER(Ptr) \
    ((NDIS_HANDLE)(Ptr))

//
// Macros to extract high and low bytes of a word.
//
#define MSB(Value) ((UCHAR)((((ULONG)Value) >> 8) & 0xff))
#define LSB(Value) ((UCHAR)(((ULONG)Value) & 0xff))

//
// What we map into the reserved section of a packet.
// Cannot be more than 8 bytes (see ASSERT in cs8900.c).
//
typedef struct _MINIPORT_RESERVED {
    PNDIS_PACKET Next;    // used to link in the queues (4 bytes)
} MINIPORT_RESERVED, * PMINIPORT_RESERVED;


//
// Retrieve the MINIPORT_RESERVED structure from a packet.
//
#define RESERVED(Packet) ((PMINIPORT_RESERVED)((Packet)->MiniportReserved))

//
// Procedures which log errors.
//

typedef enum _CS8900_PROC_ID {
    cardReset,
    cardCopyDownPacket,
    cardCopyDownBuffer,
    cardCopyUp
} CS8900_PROC_ID;


//
// Special error log codes.
//
#define CS8900_ERRMSG_CARD_SETUP          (ULONG)0x01
#define CS8900_ERRMSG_DATA_PORT_READY     (ULONG)0x02
#define CS8900_ERRMSG_HANDLE_XMIT_COMPLETE (ULONG)0x04

//
// Declarations for functions in cs8900.c.
//

NDIS_STATUS
CS8900SetInformation(
    IN NDIS_HANDLE MiniportAdapterContext,
    IN NDIS_OID Oid,
    IN PVOID InformationBuffer,
    IN ULONG InformationBufferLength,
    OUT PULONG BytesRead,
    OUT PULONG BytesNeeded
    );

VOID
CS8900Shutdown(
    IN NDIS_HANDLE MiniportAdapterContext
    );

VOID
CS8900Halt(
    IN NDIS_HANDLE MiniportAdapterContext
    );

NDIS_STATUS
CS8900RegisterAdapter(
    IN PCS8900_ADAPTER Adapter,
    IN NDIS_HANDLE ConfigurationHandle,
    IN BOOLEAN ConfigError,
    IN ULONG ConfigErrorValue
    );

NDIS_STATUS
MiniportInitialize(
    OUT PNDIS_STATUS OpenErrorStatus,
    OUT PUINT SelectedMediumIndex,
    IN PNDIS_MEDIUM MediumArray,
    IN UINT MediumArraySize,
    IN NDIS_HANDLE MiniportAdapterHandle,
    IN NDIS_HANDLE ConfigurationHandle
    );

NDIS_STATUS
CS8900TransferData(
    OUT PNDIS_PACKET Packet,
    OUT PUINT BytesTransferred,
    IN NDIS_HANDLE MiniportAdapterContext,
    IN NDIS_HANDLE MiniportReceiveContext,
    IN UINT ByteOffset,
    IN UINT BytesToTransfer
    );

NDIS_STATUS
CS8900Send(
    IN NDIS_HANDLE MiniportAdapterContext,
    IN PNDIS_PACKET Packet,
    IN UINT Flags
    );

NDIS_STATUS
CS8900Reset(
    OUT PBOOLEAN AddressingReset,
    IN NDIS_HANDLE MiniportAdapterContext
    );

NDIS_STATUS
CS8900QueryInformation(
    IN NDIS_HANDLE MiniportAdapterContext,
    IN NDIS_OID Oid,
    IN PVOID InformationBuffer,
    IN ULONG InformationBufferLength,
    OUT PULONG BytesWritten,
    OUT PULONG BytesNeeded
    );

VOID
CS8900Halt(
    IN NDIS_HANDLE MiniportAdapterContext
    );

VOID
CS8900CancelSendPackets(
   IN NDIS_HANDLE hMiniportAdapterContext,
   IN PVOID pvCancelId
);

VOID
CS8900DevicePnPEvent(
   IN NDIS_HANDLE hMiniportAdapterContext,
   IN NDIS_DEVICE_PNP_EVENT  devicePnPEvent,
   IN PVOID pvInformationBuffer,
   IN ULONG ulInformationBufferLength
);

VOID
CS8900AdapterShutdown(
   IN NDIS_HANDLE hMiniportAdapterContext
);

//
// Interrup.c
//

void CS8900ReceiveEvent(PCS8900_ADAPTER Adapter, unsigned short RxEvent);

//VOID
//CS8900EnableInterrupt(
//    IN NDIS_HANDLE MiniportAdapterContext
//    );

//VOID
//CS8900DisableInterrupt(
//    IN NDIS_HANDLE MiniportAdapterContext
//    );

VOID
CS8900Isr(
    OUT PBOOLEAN InterruptRecognized,
    OUT PBOOLEAN QueueDpc,
    IN PVOID Context
    );

VOID
CS8900HandleInterrupt(
    IN NDIS_HANDLE MiniportAdapterContext
    );

//
// Declarations of functions in cs8900.c.
//

unsigned short
CS8900ReadRegister(
	unsigned short offset
	);

void
CS8900WriteRegister(
	unsigned short offset,
	unsigned short data
	);

BOOLEAN
CS8900Initialize(
    IN PCS8900_ADAPTER Adapter
    );

BOOLEAN
CS8900ReadEthernetAddress(
    IN PCS8900_ADAPTER Adapter
    );

unsigned short CS8900RequestTransmit
(
	UINT PacketLength
    );

void CS8900CopyTxFrame
(
	PCHAR pPacket,
	UINT PacketLength
    );

#endif // CS8900SFT

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩视频免费观看高清完整版在线观看| 国产香蕉久久精品综合网| 欧美激情中文不卡| 国产精品自在在线| 国产亚洲精品资源在线26u| 亚洲精品乱码久久久久| 成人黄色免费短视频| 中文字幕一区二区三区不卡在线| kk眼镜猥琐国模调教系列一区二区| 亚洲色图.com| 欧美裸体bbwbbwbbw| 韩国精品一区二区| 国产精品久久久久影院色老大| 色偷偷久久一区二区三区| 日本不卡一区二区三区高清视频| 久久午夜免费电影| 不卡的电影网站| 亚洲妇熟xx妇色黄| 久久综合九色综合欧美98| 9久草视频在线视频精品| 亚洲风情在线资源站| 久久尤物电影视频在线观看| 91蜜桃免费观看视频| 肉肉av福利一精品导航| 亚洲国产精品99久久久久久久久 | 精品国产麻豆免费人成网站| 青草av.久久免费一区| 欧美国产1区2区| 91国偷自产一区二区使用方法| 免费的成人av| 中文字幕一区在线观看视频| 中文字幕高清不卡| 在线观看成人小视频| 精品在线一区二区| 亚洲日本在线视频观看| 欧美www视频| 日本伦理一区二区| 国产99精品国产| 亚洲狠狠爱一区二区三区| 国产亚洲va综合人人澡精品| 欧美视频自拍偷拍| 成人高清在线视频| 蜜桃av一区二区三区电影| 国产精品久久久久久久久搜平片 | 国产成人在线免费| 亚洲综合偷拍欧美一区色| 国产亚洲精品久| 日韩一级免费观看| 色噜噜狠狠一区二区三区果冻| 国产在线视频精品一区| 日韩成人一区二区三区在线观看| 中文字幕综合网| 26uuu亚洲| 欧美一级专区免费大片| 欧美亚洲一区二区在线| 91网站在线播放| 国产精品资源网| 美女精品一区二区| 五月激情丁香一区二区三区| 一区2区3区在线看| 中文字幕佐山爱一区二区免费| 久久久噜噜噜久久人人看 | 色天天综合色天天久久| 国产乱对白刺激视频不卡| 麻豆专区一区二区三区四区五区| 午夜不卡av在线| 亚洲国产欧美在线| 一区二区三区中文在线| 亚洲欧美电影院| 亚洲欧洲性图库| 1024成人网色www| 国产精品第一页第二页第三页| 国产日韩精品一区二区三区| 久久久www免费人成精品| 精品理论电影在线| 精品国产一区二区亚洲人成毛片| 欧美一区二区二区| 日韩欧美中文字幕制服| 日韩一区二区三区视频在线观看| 欧美一级片在线观看| 日韩一区二区在线看| 日韩免费观看2025年上映的电影| 欧美一区二区播放| 欧美精品一区二区在线观看| 久久这里只有精品首页| 欧美韩国日本不卡| **网站欧美大片在线观看| 成人欧美一区二区三区视频网页| 日韩一区在线免费观看| 亚洲午夜久久久久中文字幕久| 亚洲午夜激情网站| 蜜臀久久久99精品久久久久久| 麻豆国产精品视频| 国产成人av一区二区三区在线 | 丁香啪啪综合成人亚洲小说 | 亚洲自拍与偷拍| 亚洲成a天堂v人片| 狠狠色丁香婷婷综合| 国产精品一区在线观看你懂的| 成人黄色网址在线观看| 欧美中文字幕一区二区三区 | 久久av中文字幕片| 国产一区二区三区香蕉| 不卡的看片网站| 欧美午夜在线观看| 日韩欧美亚洲国产另类| 国产精品午夜久久| 亚洲国产精品一区二区www在线 | 成人免费黄色在线| 在线亚洲免费视频| 精品福利一区二区三区| 国产精品高潮久久久久无| 亚洲丶国产丶欧美一区二区三区| 激情六月婷婷久久| 色综合久久九月婷婷色综合| 欧美一级午夜免费电影| 亚洲欧洲精品一区二区精品久久久| 天天操天天色综合| 国产一区二区在线看| 欧美性淫爽ww久久久久无| 精品蜜桃在线看| 亚洲午夜久久久久久久久久久| 狠狠狠色丁香婷婷综合久久五月| 91女人视频在线观看| 日韩欧美黄色影院| 亚洲免费av高清| 国产剧情av麻豆香蕉精品| 欧美性生活一区| 国产精品青草综合久久久久99| 亚瑟在线精品视频| 不卡一区二区中文字幕| 欧美不卡一区二区三区| 亚洲一二三四在线观看| 国产凹凸在线观看一区二区| 7777精品伊人久久久大香线蕉| 中文字幕乱码日本亚洲一区二区| 日韩二区三区在线观看| 91免费小视频| 国产精品久久久久久久久免费丝袜 | 成人永久看片免费视频天堂| 91精品久久久久久久99蜜桃| 最新欧美精品一区二区三区| 国内精品免费**视频| 911国产精品| 亚洲电影视频在线| 色一区在线观看| 自拍偷拍国产亚洲| 成人免费观看av| 久久先锋影音av| 精品综合久久久久久8888| 欧美日韩中文一区| 亚洲在线免费播放| 色哟哟亚洲精品| 亚洲欧美另类图片小说| 不卡的av电影| 国产精品久久看| 成人网页在线观看| 久久精品亚洲国产奇米99| 久久99久久99| 日韩精品一区二区三区中文精品| 婷婷夜色潮精品综合在线| 欧美日韩免费观看一区二区三区| 亚洲免费在线观看视频| av在线不卡电影| 综合色中文字幕| 91蝌蚪porny九色| 亚洲三级在线免费观看| 色综合婷婷久久| 亚洲黄色在线视频| 欧美在线综合视频| 亚洲国产成人高清精品| 欧美视频一二三区| 亚洲国产欧美日韩另类综合| 欧美日韩电影在线| 日韩vs国产vs欧美| 欧美刺激午夜性久久久久久久| 老汉av免费一区二区三区| 久久午夜电影网| 成人av在线电影| 夜夜嗨av一区二区三区| 欧美丰满美乳xxx高潮www| 麻豆免费精品视频| 久久九九影视网| 色综合久久中文综合久久牛| 亚洲一区二区三区视频在线| 在线电影一区二区三区| 黑人精品欧美一区二区蜜桃| 国产精品美女一区二区在线观看| 99久久er热在这里只有精品15| 亚洲精品大片www| 69精品人人人人| 国产乱子轮精品视频| 亚洲精选一二三| 91精品在线一区二区| 国产成人8x视频一区二区| 亚洲色图另类专区| 欧美一区二区三区视频在线 | 精品污污网站免费看| 韩国中文字幕2020精品| 亚洲美女区一区|