| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * include/asm-mips/vr41xx/vr41xx.h | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Include file for NEC VR4100 series. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 1999 Michael Klar | 
					
						
							|  |  |  |  * Copyright (C) 2001, 2002 Paul Mundt | 
					
						
							|  |  |  |  * Copyright (C) 2002 MontaVista Software, Inc. | 
					
						
							|  |  |  |  * Copyright (C) 2002 TimeSys Corp. | 
					
						
							| 
									
										
										
										
											2009-07-03 00:39:38 +09:00
										 |  |  |  * Copyright (C) 2003-2008 Yoichi Yuasa <yuasa@linux-mips.org> | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify it | 
					
						
							|  |  |  |  * under the terms of the GNU General Public License as published by the | 
					
						
							|  |  |  |  * Free Software Foundation; either version 2 of the License, or (at your | 
					
						
							|  |  |  |  * option) any later version. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifndef __NEC_VR41XX_H
 | 
					
						
							|  |  |  | #define __NEC_VR41XX_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/interrupt.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CPU Revision | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | /* VR4122 0x00000c70-0x00000c72 */ | 
					
						
							|  |  |  | #define PRID_VR4122_REV1_0	0x00000c70
 | 
					
						
							|  |  |  | #define PRID_VR4122_REV2_0	0x00000c70
 | 
					
						
							|  |  |  | #define PRID_VR4122_REV2_1	0x00000c70
 | 
					
						
							|  |  |  | #define PRID_VR4122_REV3_0	0x00000c71
 | 
					
						
							|  |  |  | #define PRID_VR4122_REV3_1	0x00000c72
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* VR4181A 0x00000c73-0x00000c7f */ | 
					
						
							|  |  |  | #define PRID_VR4181A_REV1_0	0x00000c73
 | 
					
						
							|  |  |  | #define PRID_VR4181A_REV1_1	0x00000c74
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* VR4131 0x00000c80-0x00000c83 */ | 
					
						
							|  |  |  | #define PRID_VR4131_REV1_2	0x00000c80
 | 
					
						
							|  |  |  | #define PRID_VR4131_REV2_0	0x00000c81
 | 
					
						
							|  |  |  | #define PRID_VR4131_REV2_1	0x00000c82
 | 
					
						
							|  |  |  | #define PRID_VR4131_REV2_2	0x00000c83
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* VR4133 0x00000c84- */ | 
					
						
							|  |  |  | #define PRID_VR4133		0x00000c84
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Bus Control Uint | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern unsigned long vr41xx_calculate_clock_frequency(void); | 
					
						
							|  |  |  | extern unsigned long vr41xx_get_vtclock_frequency(void); | 
					
						
							|  |  |  | extern unsigned long vr41xx_get_tclock_frequency(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Clock Mask Unit | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef enum { | 
					
						
							|  |  |  | 	PIU_CLOCK, | 
					
						
							|  |  |  | 	SIU_CLOCK, | 
					
						
							|  |  |  | 	AIU_CLOCK, | 
					
						
							|  |  |  | 	KIU_CLOCK, | 
					
						
							|  |  |  | 	FIR_CLOCK, | 
					
						
							|  |  |  | 	DSIU_CLOCK, | 
					
						
							|  |  |  | 	CSI_CLOCK, | 
					
						
							|  |  |  | 	PCIU_CLOCK, | 
					
						
							|  |  |  | 	HSP_CLOCK, | 
					
						
							|  |  |  | 	PCI_CLOCK, | 
					
						
							|  |  |  | 	CEU_CLOCK, | 
					
						
							|  |  |  | 	ETHER0_CLOCK, | 
					
						
							|  |  |  | 	ETHER1_CLOCK | 
					
						
							|  |  |  | } vr41xx_clock_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_supply_clock(vr41xx_clock_t clock); | 
					
						
							|  |  |  | extern void vr41xx_mask_clock(vr41xx_clock_t clock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Interrupt Control Unit | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern int vr41xx_set_intassign(unsigned int irq, unsigned char intassign); | 
					
						
							| 
									
										
										
										
											2006-10-18 23:27:29 +09:00
										 |  |  | extern int cascade_irq(unsigned int irq, int (*get_irq)(unsigned int)); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PIUINT_COMMAND		0x0040
 | 
					
						
							|  |  |  | #define PIUINT_DATA		0x0020
 | 
					
						
							|  |  |  | #define PIUINT_PAGE1		0x0010
 | 
					
						
							|  |  |  | #define PIUINT_PAGE0		0x0008
 | 
					
						
							|  |  |  | #define PIUINT_DATALOST		0x0004
 | 
					
						
							|  |  |  | #define PIUINT_STATUSCHANGE	0x0001
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_piuint(uint16_t mask); | 
					
						
							|  |  |  | extern void vr41xx_disable_piuint(uint16_t mask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AIUINT_INPUT_DMAEND	0x0800
 | 
					
						
							|  |  |  | #define AIUINT_INPUT_DMAHALT	0x0400
 | 
					
						
							|  |  |  | #define AIUINT_INPUT_DATALOST	0x0200
 | 
					
						
							|  |  |  | #define AIUINT_INPUT_DATA	0x0100
 | 
					
						
							|  |  |  | #define AIUINT_OUTPUT_DMAEND	0x0008
 | 
					
						
							|  |  |  | #define AIUINT_OUTPUT_DMAHALT	0x0004
 | 
					
						
							|  |  |  | #define AIUINT_OUTPUT_NODATA	0x0002
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_aiuint(uint16_t mask); | 
					
						
							|  |  |  | extern void vr41xx_disable_aiuint(uint16_t mask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define KIUINT_DATALOST		0x0004
 | 
					
						
							|  |  |  | #define KIUINT_DATAREADY	0x0002
 | 
					
						
							|  |  |  | #define KIUINT_SCAN		0x0001
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_kiuint(uint16_t mask); | 
					
						
							|  |  |  | extern void vr41xx_disable_kiuint(uint16_t mask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DSIUINT_CTS		0x0800
 | 
					
						
							|  |  |  | #define DSIUINT_RXERR		0x0400
 | 
					
						
							|  |  |  | #define DSIUINT_RX		0x0200
 | 
					
						
							|  |  |  | #define DSIUINT_TX		0x0100
 | 
					
						
							|  |  |  | #define DSIUINT_ALL		0x0f00
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_dsiuint(uint16_t mask); | 
					
						
							|  |  |  | extern void vr41xx_disable_dsiuint(uint16_t mask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FIRINT_UNIT		0x0010
 | 
					
						
							|  |  |  | #define FIRINT_RX_DMAEND	0x0008
 | 
					
						
							|  |  |  | #define FIRINT_RX_DMAHALT	0x0004
 | 
					
						
							|  |  |  | #define FIRINT_TX_DMAEND	0x0002
 | 
					
						
							|  |  |  | #define FIRINT_TX_DMAHALT	0x0001
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_firint(uint16_t mask); | 
					
						
							|  |  |  | extern void vr41xx_disable_firint(uint16_t mask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_pciint(void); | 
					
						
							|  |  |  | extern void vr41xx_disable_pciint(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_scuint(void); | 
					
						
							|  |  |  | extern void vr41xx_disable_scuint(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CSIINT_TX_DMAEND	0x0040
 | 
					
						
							|  |  |  | #define CSIINT_TX_DMAHALT	0x0020
 | 
					
						
							|  |  |  | #define CSIINT_TX_DATA		0x0010
 | 
					
						
							|  |  |  | #define CSIINT_TX_FIFOEMPTY	0x0008
 | 
					
						
							|  |  |  | #define CSIINT_RX_DMAEND	0x0004
 | 
					
						
							|  |  |  | #define CSIINT_RX_DMAHALT	0x0002
 | 
					
						
							|  |  |  | #define CSIINT_RX_FIFOEMPTY	0x0001
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_csiint(uint16_t mask); | 
					
						
							|  |  |  | extern void vr41xx_disable_csiint(uint16_t mask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void vr41xx_enable_bcuint(void); | 
					
						
							|  |  |  | extern void vr41xx_disable_bcuint(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-28 02:14:08 -07:00
										 |  |  | #ifdef CONFIG_SERIAL_VR41XX_CONSOLE
 | 
					
						
							|  |  |  | extern void vr41xx_siu_setup(void); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | static inline void vr41xx_siu_setup(void) {} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif /* __NEC_VR41XX_H */
 |