101 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef SMSC_SIO_H
 | 
						|
#define SMSC_SIO_H
 | 
						|
 | 
						|
/******************************************
 | 
						|
 Keys. They should work with every SMsC SIO
 | 
						|
 ******************************************/
 | 
						|
 | 
						|
#define SMSCSIO_CFGACCESSKEY		0x55
 | 
						|
#define SMSCSIO_CFGEXITKEY			0xaa
 | 
						|
 | 
						|
/*****************************
 | 
						|
 * Generic SIO Flat (!?)     *
 | 
						|
 *****************************/
 | 
						|
 
 | 
						|
/* Register 0x0d */
 | 
						|
#define SMSCSIOFLAT_DEVICEID_REG				0x0d
 | 
						|
 | 
						|
/* Register 0x0c */
 | 
						|
#define SMSCSIOFLAT_UARTMODE0C_REG				0x0c
 | 
						|
#define 	SMSCSIOFLAT_UART2MODE_MASK			0x38
 | 
						|
#define 	SMSCSIOFLAT_UART2MODE_VAL_COM		0x00
 | 
						|
#define 	SMSCSIOFLAT_UART2MODE_VAL_IRDA		0x08
 | 
						|
#define 	SMSCSIOFLAT_UART2MODE_VAL_ASKIR		0x10
 | 
						|
 | 
						|
/* Register 0x25 */
 | 
						|
#define SMSCSIOFLAT_UART2BASEADDR_REG			0x25
 | 
						|
 | 
						|
/* Register 0x2b */
 | 
						|
#define SMSCSIOFLAT_FIRBASEADDR_REG				0x2b
 | 
						|
 | 
						|
/* Register 0x2c */
 | 
						|
#define SMSCSIOFLAT_FIRDMASELECT_REG			0x2c
 | 
						|
#define 	SMSCSIOFLAT_FIRDMASELECT_MASK		0x0f
 | 
						|
 | 
						|
/* Register 0x28 */
 | 
						|
#define SMSCSIOFLAT_UARTIRQSELECT_REG			0x28
 | 
						|
#define 	SMSCSIOFLAT_UART2IRQSELECT_MASK		0x0f
 | 
						|
#define 	SMSCSIOFLAT_UART1IRQSELECT_MASK		0xf0
 | 
						|
#define 	SMSCSIOFLAT_UARTIRQSELECT_VAL_NONE	0x00
 | 
						|
 | 
						|
 | 
						|
/*********************
 | 
						|
 * LPC47N227         *
 | 
						|
 *********************/
 | 
						|
 | 
						|
#define LPC47N227_CFGACCESSKEY		0x55
 | 
						|
#define LPC47N227_CFGEXITKEY		0xaa
 | 
						|
 | 
						|
/* Register 0x00 */
 | 
						|
#define LPC47N227_FDCPOWERVALIDCONF_REG		0x00
 | 
						|
#define 	LPC47N227_FDCPOWER_MASK			0x08
 | 
						|
#define 	LPC47N227_VALID_MASK				0x80
 | 
						|
 | 
						|
/* Register 0x02 */
 | 
						|
#define LPC47N227_UART12POWER_REG				0x02
 | 
						|
#define 	LPC47N227_UART1POWERDOWN_MASK		0x08
 | 
						|
#define 	LPC47N227_UART2POWERDOWN_MASK		0x80
 | 
						|
 | 
						|
/* Register 0x07 */
 | 
						|
#define LPC47N227_APMBOOTDRIVE_REG				0x07
 | 
						|
#define 	LPC47N227_PARPORT2AUTOPWRDOWN_MASK	0x10 /* auto power down on if set */
 | 
						|
#define 	LPC47N227_UART2AUTOPWRDOWN_MASK	0x20 /* auto power down on if set */
 | 
						|
#define 	LPC47N227_UART1AUTOPWRDOWN_MASK	0x40 /* auto power down on if set */
 | 
						|
 | 
						|
/* Register 0x0c */
 | 
						|
#define LPC47N227_UARTMODE0C_REG				0x0c
 | 
						|
#define 	LPC47N227_UART2MODE_MASK			0x38
 | 
						|
#define 	LPC47N227_UART2MODE_VAL_COM		0x00
 | 
						|
#define 	LPC47N227_UART2MODE_VAL_IRDA		0x08
 | 
						|
#define 	LPC47N227_UART2MODE_VAL_ASKIR		0x10
 | 
						|
 | 
						|
/* Register 0x0d */
 | 
						|
#define LPC47N227_DEVICEID_REG					0x0d
 | 
						|
#define 	LPC47N227_DEVICEID_DEFVAL			0x5a
 | 
						|
 | 
						|
/* Register 0x0e */
 | 
						|
#define LPC47N227_REVISIONID_REG				0x0e
 | 
						|
 | 
						|
/* Register 0x25 */
 | 
						|
#define LPC47N227_UART2BASEADDR_REG			0x25
 | 
						|
 | 
						|
/* Register 0x28 */
 | 
						|
#define LPC47N227_UARTIRQSELECT_REG			0x28
 | 
						|
#define 	LPC47N227_UART2IRQSELECT_MASK		0x0f
 | 
						|
#define 	LPC47N227_UART1IRQSELECT_MASK		0xf0
 | 
						|
#define 	LPC47N227_UARTIRQSELECT_VAL_NONE	0x00
 | 
						|
 | 
						|
/* Register 0x2b */
 | 
						|
#define LPC47N227_FIRBASEADDR_REG				0x2b
 | 
						|
 | 
						|
/* Register 0x2c */
 | 
						|
#define LPC47N227_FIRDMASELECT_REG				0x2c
 | 
						|
#define 	LPC47N227_FIRDMASELECT_MASK		0x0f
 | 
						|
#define 	LPC47N227_FIRDMASELECT_VAL_DMA1	0x01 /* 47n227 has three dma channels */
 | 
						|
#define 	LPC47N227_FIRDMASELECT_VAL_DMA2	0x02
 | 
						|
#define 	LPC47N227_FIRDMASELECT_VAL_DMA3	0x03
 | 
						|
#define 	LPC47N227_FIRDMASELECT_VAL_NONE	0x0f
 | 
						|
 | 
						|
 | 
						|
#endif
 |