⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cs8900.h

📁 国外牛人公开的AVR代码
💻 H
📖 第 1 页 / 共 2 页
字号:
/*! \file cs8900.h \brief Crystal CS8900 Ethernet Interface Driver. */
//*****************************************************************************
//
// File Name	: 'cs8900.h'
// Title		: Crystal CS8900 Ethernet Interface Driver
// Author		: Pascal Stang
// Created		: 11/7/2004
// Revised		: 8/22/2005
// Version		: 0.1
// Target MCU	: Atmel AVR series
// Editor Tabs	: 4
//
///	\ingroup network
///	\defgroup cs8900 Crystal CS8900 Ethernet Interface Driver (cs8900.c)
///	\code #include "net/cs8900.h" \endcode
///	\par Overview
///		This driver provides initialization and transmit/receive
///	functions for the Crystal CS8900 10Mb Ethernet Controller and PHY.
//
//*****************************************************************************
//@{

#ifndef CS8900_H
#define CS8900_H

#include "global.h"

#define nop()	asm volatile ("nop")


// Crystal ESIA product ID
#define CS8900_ESIA_ID				(0x630e)

// CS8900 IO Registers
#define CS8900_IO_RXTX_DATA_PORT0	(0x0000)
#define CS8900_IO_RXTX_DATA_PORT1	(0x0002)
#define CS8900_IO_TXCMD				(0x0004)
#define CS8900_IO_TXLENGTH			(0x0006)
#define CS8900_IO_ISQ				(0x0008)
#define CS8900_IO_PP_PTR			(0x000a)
#define CS8900_IO_PP_DATA_PORT0		(0x000c)
#define CS8900_IO_PP_DATA_PORT1		(0x000e)

// definitions for Crystal CS8900 ethernet-controller// based on linux-header by Russel Nelson#define PP_ChipID            0x0000              // offset 0h -> Corp-ID                                                 // offset 2h -> Model/Product Number                                                 // offset 3h -> Chip Revision Number#define PP_ISAIOB            0x0020              // IO base address#define PP_CS8900_ISAINT     0x0022              // ISA interrupt select#define PP_CS8900_ISADMA     0x0024              // ISA Rec DMA channel#define PP_ISASOF            0x0026              // ISA DMA offset#define PP_DmaFrameCnt       0x0028              // ISA DMA Frame count#define PP_DmaByteCnt        0x002A              // ISA DMA Byte count#define PP_CS8900_ISAMemB    0x002C              // Memory base#define PP_ISABootBase       0x0030              // Boot Prom base#define PP_ISABootMask       0x0034              // Boot Prom Mask
#define PP_RxFrameByteCnt	0x0050// EEPROM data and command registers#define PP_EECMD             0x0040              // NVR Interface Command register#define PP_EEData            0x0042              // NVR Interface Data Register// Configuration and control registers#define PP_RxCFG             0x0102              // Rx Bus config#define PP_RxCTL             0x0104              // Receive Control Register#define PP_TxCFG             0x0106              // Transmit Config Register#define PP_TxCMD             0x0108              // Transmit Command Register#define PP_BufCFG            0x010A              // Bus configuration Register#define PP_LineCTL           0x0112              // Line Config Register#define PP_SelfCTL           0x0114              // Self Command Register#define PP_BusCTL            0x0116              // ISA bus control Register#define PP_TestCTL           0x0118              // Test Register// Status and Event Registers#define PP_ISQ               0x0120              // Interrupt Status#define PP_RxEvent           0x0124              // Rx Event Register#define PP_TxEvent           0x0128              // Tx Event Register#define PP_BufEvent          0x012C              // Bus Event Register#define PP_RxMiss            0x0130              // Receive Miss Count#define PP_TxCol             0x0132              // Transmit Collision Count#define PP_LineST            0x0134              // Line State Register#define PP_SelfST            0x0136              // Self State register#define PP_BusST             0x0138              // Bus Status#define PP_TDR               0x013C              // Time Domain Reflectometry// Initiate Transmit Registers#define PP_TxCommand         0x0144              // Tx Command#define PP_TxLength          0x0146              // Tx Length// Address Filter Registers#define PP_LAF               0x0150              // Hash Table#define PP_IA                0x0158              // Physical Address Register// Frame Location#define PP_RxStatus          0x0400              // Receive start of frame#define PP_RxLength          0x0402              // Receive Length of frame#define PP_RxFrame           0x0404              // Receive frame pointer#define PP_TxFrame           0x0A00              // Transmit frame pointer// Primary I/O Base Address. If no I/O base is supplied by the user, then this// can be used as the default I/O base to access the PacketPage Area.#define DEFAULTIOBASE				0x0300// PP_RxCFG - Receive  Configuration and Interrupt Mask bit definition - Read/write#define SKIP_1						0x0040#define RX_STREAM_ENBL				0x0080#define RX_OK_ENBL					0x0100#define RX_DMA_ONLY					0x0200#define AUTO_RX_DMA					0x0400#define BUFFER_CRC					0x0800#define RX_CRC_ERROR_ENBL			0x1000#define RX_RUNT_ENBL				0x2000#define RX_EXTRA_DATA_ENBL			0x4000// PP_RxCTL - Receive Control bit definition - Read/write#define RX_IA_HASH_ACCEPT			0x0040#define RX_PROM_ACCEPT				0x0080#define RX_OK_ACCEPT				0x0100#define RX_MULTCAST_ACCEPT			0x0200#define RX_IA_ACCEPT				0x0400#define RX_BROADCAST_ACCEPT			0x0800#define RX_BAD_CRC_ACCEPT			0x1000#define RX_RUNT_ACCEPT				0x2000#define RX_EXTRA_DATA_ACCEPT		0x4000// PP_TxCFG - Transmit Configuration Interrupt Mask bit definition - Read/write#define TX_LOST_CRS_ENBL			0x0040#define TX_SQE_ERROR_ENBL			0x0080#define TX_OK_ENBL					0x0100#define TX_LATE_COL_ENBL			0x0200#define TX_JBR_ENBL					0x0400#define TX_ANY_COL_ENBL				0x0800#define TX_16_COL_ENBL				0x8000// PP_TxCMD - Transmit Command bit definition - Read-only and// PP_TxCommand - Write-only#define TX_START_5_BYTES			0x0000#define TX_START_381_BYTES			0x0040#define TX_START_1021_BYTES			0x0080#define TX_START_ALL_BYTES			0x00C0#define TX_FORCE					0x0100#define TX_ONE_COL					0x0200#define TX_NO_CRC					0x1000#define TX_RUNT						0x2000// PP_BufCFG - Buffer Configuration Interrupt Mask bit definition - Read/write#define GENERATE_SW_INTERRUPT		0x0040#define RX_DMA_ENBL					0x0080#define READY_FOR_TX_ENBL			0x0100#define TX_UNDERRUN_ENBL			0x0200#define RX_MISS_ENBL				0x0400#define RX_128_BYTE_ENBL			0x0800#define TX_COL_COUNT_OVRFLOW_ENBL	0x1000#define RX_MISS_COUNT_OVRFLOW_ENBL	0x2000#define RX_DEST_MATCH_ENBL			0x8000// PP_LineCTL - Line Control bit definition - Read/write#define SERIAL_RX_ON				0x0040#define SERIAL_TX_ON				0x0080#define AUI_ONLY					0x0100#define AUTO_AUI_10BASET			0x0200#define MODIFIED_BACKOFF			0x0800#define NO_AUTO_POLARITY			0x1000#define TWO_PART_DEFDIS				0x2000#define LOW_RX_SQUELCH				0x4000// PP_SelfCTL - Software Self Control bit definition - Read/write#define POWER_ON_RESET				0x0040#define SW_STOP						0x0100#define SLEEP_ON					0x0200#define AUTO_WAKEUP					0x0400#define HCB0_ENBL					0x1000#define HCB1_ENBL					0x2000#define HCB0						0x4000#define HCB1						0x8000// PP_BusCTL - ISA Bus Control bit definition - Read/write#define RESET_RX_DMA				0x0040#define MEMORY_ON					0x0400#define DMA_BURST_MODE				0x0800#define IO_CHANNEL_READY_ON			0x1000#define RX_DMA_SIZE_64K				0x2000#define ENABLE_IRQ					0x8000// PP_TestCTL - Test Control bit definition - Read/write#define LINK_OFF             0x0080#define ENDEC_LOOPBACK       0x0200#define AUI_LOOPBACK         0x0400#define BACKOFF_OFF          0x0800#define FDX_8900             0x4000// PP_RxEvent - Receive Event Bit definition - Read-only#define RX_IA_HASHED         0x0040#define RX_DRIBBLE           0x0080#define RX_OK                0x0100#define RX_HASHED            0x0200#define RX_IA                0x0400#define RX_BROADCAST         0x0800#define RX_CRC_ERROR         0x1000#define RX_RUNT              0x2000#define RX_EXTRA_DATA        0x4000#define HASH_INDEX_MASK      0xFC00              // Hash-Table Index Mask (6 Bit)// PP_TxEvent - Transmit Event Bit definition - Read-only#define TX_LOST_CRS          0x0040#define TX_SQE_ERROR         0x0080#define TX_OK                0x0100#define TX_LATE_COL          0x0200#define TX_JBR               0x0400#define TX_16_COL            0x8000#define TX_COL_COUNT_MASK    0x7800// PP_BufEvent - Buffer Event Bit definition - Read-only#define SW_INTERRUPT         0x0040#define RX_DMA               0x0080#define READY_FOR_TX         0x0100#define TX_UNDERRUN          0x0200#define RX_MISS              0x0400#define RX_128_BYTE          0x0800#define TX_COL_OVRFLW        0x1000#define RX_MISS_OVRFLW       0x2000#define RX_DEST_MATCH        0x8000// PP_LineST - Ethernet Line Status bit definition - Read-only#define LINK_OK              0x0080#define AUI_ON               0x0100#define TENBASET_ON          0x0200#define POLARITY_OK          0x1000#define CRS_OK               0x4000// PP_SelfST - Chip Software Status bit definition#define ACTIVE_33V           0x0040#define INIT_DONE            0x0080#define SI_BUSY              0x0100#define EEPROM_PRESENT       0x0200#define EEPROM_OK            0x0400#define EL_PRESENT           0x0800#define EE_SIZE_64           0x1000// PP_BusST - ISA Bus Status bit definition#define TX_BID_ERROR         0x0080#define READY_FOR_TX_NOW     0x0100// The following block defines the ISQ event types#define ISQ_RX_EVENT         0x0004#define ISQ_TX_EVENT         0x0008#define ISQ_BUFFER_EVENT     0x000C#define ISQ_RX_MISS_EVENT    0x0010#define ISQ_TX_COL_EVENT     0x0012#define ISQ_EVENT_MASK       0x003F              // ISQ mask to find out type of event#define AUTOINCREMENT        0x8000              // Bit mask to set Bit-15 for autoincrement// EEProm Commands

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -