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

📄 sl811hst.c

📁 该原码包含有wince 和 linux 的移植和应用原码
💻 C
📖 第 1 页 / 共 4 页
字号:
////////////////////////////////////////////////////////////////////////////////
// Cypress Semiconductor - Customer Design Center 
////////////////////////////////////////////////////////////////////////////////
// File:		host_811.c
// Purpose:	    8051 firmware to master SL811 Embedded Host. 
//              Contains SL811-related control firmware. 
//              Based on SL811HST code written by cxn.
// H/W Target:  SL811HST(Rev 1.5) + EZUSB DEV KIT
// IMPORTANT :  Turn ON SW4 of S6-DIP-SWITCH 
//              to enable upper 32K memory on EZUSB Dev Kit
//
// $Header: /USB/ez811/firmware/Emb_Host/host_811.c 8     5/14/02 8:30p Tpm $
// Copyright (c) 2002 Cypress Semiconductor. May not be reproduced without permission.
// See the license agreement for more details.
////////////////////////////////////////////////////////////////////////////////

#include "ezusb.h"
#include "ezregs.h"
#include "host_811.h"
#include "def.h"
//#include "44blib.h"
#include "utils.h"

/* Register Assignments 3/18/99 TPM */
#define	EXTERN

EXTERN xdata volatile BYTE OUT7BUF[64];
EXTERN xdata volatile BYTE IN7BUF[64];
EXTERN xdata volatile BYTE OUT6BUF[64];
EXTERN xdata volatile BYTE IN6BUF[64];
EXTERN xdata volatile BYTE OUT5BUF[64];
EXTERN xdata volatile BYTE IN5BUF[64];
EXTERN xdata volatile BYTE OUT4BUF[64];
EXTERN xdata volatile BYTE IN4BUF[64];
EXTERN xdata volatile BYTE OUT3BUF[64];
EXTERN xdata volatile BYTE IN3BUF[64];
EXTERN xdata volatile BYTE OUT2BUF[64];
EXTERN xdata volatile BYTE IN2BUF[64];
EXTERN xdata volatile BYTE OUT1BUF[64];
EXTERN xdata volatile BYTE IN1BUF[64];
EXTERN xdata volatile BYTE OUT0BUF[64];
EXTERN xdata volatile BYTE IN0BUF[64];

EXTERN xdata volatile BYTE OUT8DATA;
EXTERN xdata volatile BYTE OUT9DATA;
EXTERN xdata volatile BYTE OUT10DATA;
EXTERN xdata volatile BYTE OUT11DATA;
EXTERN xdata volatile BYTE OUT12DATA;
EXTERN xdata volatile BYTE OUT13DATA;
EXTERN xdata volatile BYTE OUT14DATA;
EXTERN xdata volatile BYTE OUT15DATA;
EXTERN xdata volatile BYTE IN8DATA;
EXTERN xdata volatile BYTE IN9DATA;
EXTERN xdata volatile BYTE IN10DATA;
EXTERN xdata volatile BYTE IN11DATA;
EXTERN xdata volatile BYTE IN12DATA;
EXTERN xdata volatile BYTE IN13DATA;
EXTERN xdata volatile BYTE IN14DATA;
EXTERN xdata volatile BYTE IN15DATA;
EXTERN xdata volatile BYTE OUT8BCH;
EXTERN xdata volatile BYTE OUT8BCL;
EXTERN xdata volatile BYTE OUT9BCH;
EXTERN xdata volatile BYTE OUT9BCL;
EXTERN xdata volatile BYTE OUT10BCH;
EXTERN xdata volatile BYTE OUT10BCL;
EXTERN xdata volatile BYTE OUT11BCH;
EXTERN xdata volatile BYTE OUT11BCL;
EXTERN xdata volatile BYTE OUT12BCH;
EXTERN xdata volatile BYTE OUT12BCL;
EXTERN xdata volatile BYTE OUT13BCH;
EXTERN xdata volatile BYTE OUT13BCL;
EXTERN xdata volatile BYTE OUT14BCH;
EXTERN xdata volatile BYTE OUT14BCL;
EXTERN xdata volatile BYTE OUT15BCH;
EXTERN xdata volatile BYTE OUT15BCL;
EXTERN xdata volatile BYTE CPUCS;
EXTERN xdata volatile BYTE PORTACFG;
EXTERN xdata volatile BYTE PORTBCFG;
EXTERN xdata volatile BYTE PORTCCFG;
EXTERN xdata volatile BYTE OUTA;
EXTERN xdata volatile BYTE OUTB;
EXTERN xdata volatile BYTE OUTC;
EXTERN xdata volatile BYTE PINSA;
EXTERN xdata volatile BYTE PINSB;
EXTERN xdata volatile BYTE PINSC;
EXTERN xdata volatile BYTE OEA;
EXTERN xdata volatile BYTE OEB;
EXTERN xdata volatile BYTE OEC;
EXTERN xdata volatile BYTE UART230;
EXTERN xdata volatile BYTE ISOERR;
EXTERN xdata volatile BYTE ISOCTL;
EXTERN xdata volatile BYTE ZBCOUT;
EXTERN xdata volatile BYTE ZBCIN;
EXTERN xdata volatile BYTE I2CS;
EXTERN xdata volatile BYTE I2DAT;
EXTERN xdata volatile BYTE IVEC;
EXTERN xdata volatile BYTE IN07IRQ;
EXTERN xdata volatile BYTE OUT07IRQ;
EXTERN xdata volatile BYTE USBIRQ;
EXTERN xdata volatile BYTE IN07IEN;
EXTERN xdata volatile BYTE OUT07IEN;
EXTERN xdata volatile BYTE USBIEN;
EXTERN xdata volatile BYTE USBBAV;
EXTERN xdata volatile DWORD BPADDR;
//volatile EXTERN xdata BYTE BPADDRL	_AT_	0x7FB3;
EXTERN xdata volatile EPIOC EPIO[16];
//EXTERN xdata volatile BYTE SUDPTRH;
//EXTERN xdata volatile BYTE SUDPTRL;
EXTERN xdata volatile BYTE USBCS;
EXTERN xdata volatile BYTE TOGCTL;
EXTERN xdata volatile BYTE USBFRAMEL;
EXTERN xdata volatile BYTE USBFRAMEH;
EXTERN xdata volatile BYTE FNADDR;
EXTERN xdata volatile BYTE USBPAIR;
EXTERN xdata volatile BYTE IN07VAL;
EXTERN xdata volatile BYTE OUT07VAL;
EXTERN xdata volatile BYTE INISOVAL;
EXTERN xdata volatile BYTE OUTISOVAL;
EXTERN xdata volatile BYTE FASTXFR;
EXTERN xdata volatile BYTE AUTOPTRH;
EXTERN xdata volatile BYTE AUTOPTRL;
EXTERN xdata volatile BYTE AUTODATA;
EXTERN xdata volatile BYTE SETUPDAT[8];
EXTERN xdata volatile BYTE OUT8ADDR;
EXTERN xdata volatile BYTE OUT9ADDR;
EXTERN xdata volatile BYTE OUT10ADDR;
EXTERN xdata volatile BYTE OUT11ADDR;
EXTERN xdata volatile BYTE OUT12ADDR;
EXTERN xdata volatile BYTE OUT13ADDR;
EXTERN xdata volatile BYTE OUT14ADDR;
EXTERN xdata volatile BYTE OUT15ADDR;
EXTERN xdata volatile BYTE IN8ADDR;
EXTERN xdata volatile BYTE IN9ADDR;
EXTERN xdata volatile BYTE IN10ADDR;
EXTERN xdata volatile BYTE IN11ADDR;
EXTERN xdata volatile BYTE IN12ADDR;
EXTERN xdata volatile BYTE IN13ADDR;
EXTERN xdata volatile BYTE IN14ADDR;
EXTERN xdata volatile BYTE IN15ADDR;

#undef EXTERN

////////////////////////////////////////////////////////////////////////////////
// Code and Xdata Memory Space
////////////////////////////////////////////////////////////////////////////////
//
// ** Upper 32K external memory **
// (PROGRAM'S CODE/XDATA MEMORY ALLOCATION)
// Program xdata Space	: 0x2000 ~ 0x23FF -> ALL XDATA (size:0x0400,1K)(ISO unused data mem)
// Program Code Space1	: 0x8000 ~ 0x9EFF -> ?FW, ?EZ811 (size:0x1F00,7K) (ext. code memory) 
// Program Code Space2	: 0xA000 ~ 0xDFFF -> ?SL811H (size:0x4000,16K)(ext. code memory) 
// (MONITOR'S CODE/XDATA MEMORY ALLOCATION) (SHOULD NEVER BE USED)
// Monitor xdata Space	: 0x9F00 ~ 0x9FFF (size:0x0100,256)(ext. code memory) 
// Monitor Code Space	: 0xE000 ~ 0xFFFF (size:0x2000,8K) (ext. code memory) 
//
// ** Lower 32K external memory **
// SL811H_ADDR address	: 0x4000
// SL811H_DATA address	: 0x4001
//
// ** Internal 8K EZUSB code/xdata memory **
// Both USBJmpTb.a51 and Dscr.a51 code are located to EZUSB internal 8K memory
//
// (See Project -> Options for Target 'Target 1' for detail settings)
//
//*****************************************************************************************
// SL811H Modules (major routines only): 
//*****************************************************************************************
// 1) usbXfer()		: handles usd data transfer, SETUP,IN, OUT
// 2) ep0Xfer()		: handles endpoint zero control pipe
// 3) DataRW()		: handles data endpoint transfer pipe
// 4) EnumUsbDev() 	: device enum(HID/HUB), excl. multi-interface
// 5) HubPortEnum()	: hub port device enum, incl. dynamic USB address
// 6) speed_detect(): SL811H slave device attach/speed detect
// 7) slave_detect(): Main loop control between SL811H & EZUSB & GUI
// 8) host_811.c	: Entire code size

//*****************************************************************************************
// SL811HST+EZUSB Hardware Resources :
//*****************************************************************************************
// SL811HST		<-->	AN2131QC	<-->	FUNCTIONS (looking from SL811H side)
// A0			<-->	A0			<-->	(I) Address entry for SL811H, '0'-addr, '1'-data
// D0 ~ D7		<-->	D0 ~ D7		<-->	(B) 8-bit Data Bus
// nCS			<-->	A15			<-->	(I) Enable lower 32K memory(where SL811H is mapped)
// nRD 			<-->	nRD (PC7)	<-->	(I) Read (active low)
// nWR			<-->	nWR (PC6)	<-->	(I) Write (active low)
// nRST			<-->	PB0			<-->	(I) SL811HST's reset (active low)
// MS_SEL		<-->	PB1			<-->	(I) SL811HST's master/slave select, '0'-host
// INTR			<-->	INT4 (PB4)	<-->	(O) SL811HST's interrupt (active high) not used
// ACTIVE_LED	<-->	PB6			<-->	Blink - waiting for enum, On - enumerated
//
// For Downstream Port LEDs on Hub (not present on Demo Board):
// DOWNSTREAM PORT1 LED			0x80	// PA bit 7
// DOWNSTREAM PORT2 LED			0x40	// PA bit 6
// DOWNSTREAM PORT3 LED			0x20	// PA bit 5
// DOWNSTREAM PORT4 LED			0x10	// PA bit 4
//
//*****************************************************************************************
// Monitor (Serial Port 1) Hardware Resources :
//*****************************************************************************************
// PB2 - (I) RxD1 (looking from EZUSB side)
// PB2 - (0) TxD1
// PC6 - (O) nWR
// PC7 - (O) nRD

//*****************************************************************************************
// xdata variables
//*****************************************************************************************
#define	SL811H_ADDR	0x0a000000
#define	SL811H_DATA	0x0a000001

BYTE 			DBUF[256];		// at 0x2000 for general descriptors data
BYTE 			STATUS[8];		// for status data buffer
BYTE			REGBUFF[16];    // Buffer for Register Data
BYTE 			HOSTCMD[8];		// EZUSB's OUT1 host command data
BYTE 			pHOSTCMD[8];	// previous data transfer info, during data transfer
BYTE 			HubChange[1];	// Hub port endpoint 1 data status
BYTE 			DataBufLen;		// EZUSB's IN #3 data transfer buffer length
BYTE 			pNumPort;		// Number of downstream ports on hub
BYTE			remainder;		// Remaining byte in a USB transfer
pUSBDEV  		uDev[MAX_DEV];	// Multiple USB devices attributes, Max 5 devices
pHUBDEV			uHub;			// Struct for downstream device on HUB
pDevDesc  		pDev;			// Device descriptor struct
pCfgDesc 		pCfg;			// Configuration descriptor struct
pIntfDesc 		pIfc;			// Interface descriptor struct
pEPDesc 		pEnp;			// Endpoint descriptor struct
pStrDesc 		pStr;			// String descriptor struct
pHidDesc 		pHid;			// HID class descriptor struct
pHubDesc 		pHub;			// HUD class descriptor struct
pPortStatus		pStat;			// HID ports status

//*****************************************************************************************
// Boolean Logic Defines
//*****************************************************************************************
BOOL  	SLAVE_FOUND;				// Slave USB device found
BOOL  	SLAVE_ENUMERATED;			// slave USB device enumeration done
BOOL  	FULL_SPEED;					// Full-Speed = TRUE, Low-Speed = FALSE
BOOL	HUB_DEVICE;					// HUB device = TRUE
BOOL 	BULK_OUT_DONE;				// Set when EZUSB's OUT1 hostcmd xfer is done
BOOL 	DESC_XFER;					// Set when there is data for EZUSB's IN1 desc xfer
BOOL 	DATA_XFER;					// Set when there is data for EZUSB's IN3 data xfer
BOOL 	DATA_XFER_OUT;				// Set when there is data for EZUSB's OUT3 data xfer
BOOL 	CONFIG_DONE;				// Set when EZUSB completes its enumeration process.
BOOL 	TIMEOUT_ERR;				// timeout error during data endpoint transfer
BOOL	DATA_STOP;					// device unplugged during data transfer
BOOL	DATA_INPROCESS;				// set when we are in a data pipe transfer
BOOL	pLS_HUB;					// indicate previous command is a LS device on hub

BOOL	dsPoll;				        // poll downstream port conections

BOOL bData1;

void EZUSB_Delay(WORD ms)
{
	unsigned long loop;
	
	while(ms--) {
		loop = 1200;
		while(loop--);
	}
}


//*****************************************************************************************
// Byte Read from SL811H
// a = register address
// return = data in register
//*****************************************************************************************
BYTE SL811Read(BYTE a)
{  
	outportb(a, SL811H_ADDR);
	return (inportb(SL811H_DATA));
}

//*****************************************************************************************
// Byte Write to SL811H
// a = register address
// d = data to be written to this register address
//*****************************************************************************************
void SL811Write(BYTE a, BYTE d)
{  
	outportb(a, SL811H_ADDR);
	outportb(d, SL811H_DATA);
}

//*****************************************************************************************
// Buffer Read from SL811H
// addr = buffer start address

⌨️ 快捷键说明

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