mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 643c5705bc
			
		
	
	
		643c5705bc
		
	
	
	
	
		
			
			This patch simply adds definitions for some I/O registers in the PIIX4 PM device, and the magic data for a special cycle which must occur on the PCI bus in order for the PIIX4 to enter a suspend state. Signed-off-by: Paul Burton <paul.burton@imgtec.com> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/6903/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Carsten Langgaard, carstenl@mips.com
 | |
|  * Copyright (C) 2000 MIPS Technologies, Inc.  All rights reserved.
 | |
|  * Copyright (C) 2013 Imagination Technologies Ltd.
 | |
|  *
 | |
|  *  This program is free software; you can distribute it and/or modify it
 | |
|  *  under the terms of the GNU General Public License (Version 2) as
 | |
|  *  published by the Free Software Foundation.
 | |
|  *
 | |
|  *  This program is distributed in the hope it will be useful, but WITHOUT
 | |
|  *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 | |
|  *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 | |
|  *  for more details.
 | |
|  *
 | |
|  *  You should have received a copy of the GNU General Public License along
 | |
|  *  with this program; if not, write to the Free Software Foundation, Inc.,
 | |
|  *  59 Temple Place - Suite 330, Boston MA 02111-1307, USA.
 | |
|  *
 | |
|  * Register definitions for Intel PIIX4 South Bridge Device.
 | |
|  */
 | |
| #ifndef __ASM_MIPS_BOARDS_PIIX4_H
 | |
| #define __ASM_MIPS_BOARDS_PIIX4_H
 | |
| 
 | |
| /* PIRQX Route Control */
 | |
| #define PIIX4_FUNC0_PIRQRC			0x60
 | |
| #define   PIIX4_FUNC0_PIRQRC_IRQ_ROUTING_DISABLE	(1 << 7)
 | |
| #define   PIIX4_FUNC0_PIRQRC_IRQ_ROUTING_MASK		0xf
 | |
| #define   PIIX4_FUNC0_PIRQRC_IRQ_ROUTING_MAX		16
 | |
| /* SERIRQ Control */
 | |
| #define PIIX4_FUNC0_SERIRQC			0x64
 | |
| #define   PIIX4_FUNC0_SERIRQC_EN			(1 << 7)
 | |
| #define   PIIX4_FUNC0_SERIRQC_CONT			(1 << 6)
 | |
| /* Top Of Memory */
 | |
| #define PIIX4_FUNC0_TOM				0x69
 | |
| #define   PIIX4_FUNC0_TOM_TOP_OF_MEMORY_MASK		0xf0
 | |
| /* Deterministic Latency Control */
 | |
| #define PIIX4_FUNC0_DLC				0x82
 | |
| #define   PIIX4_FUNC0_DLC_USBPR_EN			(1 << 2)
 | |
| #define   PIIX4_FUNC0_DLC_PASSIVE_RELEASE_EN		(1 << 1)
 | |
| #define   PIIX4_FUNC0_DLC_DELAYED_TRANSACTION_EN	(1 << 0)
 | |
| /* General Configuration */
 | |
| #define PIIX4_FUNC0_GENCFG			0xb0
 | |
| #define   PIIX4_FUNC0_GENCFG_SERIRQ			(1 << 16)
 | |
| 
 | |
| /* IDE Timing */
 | |
| #define PIIX4_FUNC1_IDETIM_PRIMARY_LO		0x40
 | |
| #define PIIX4_FUNC1_IDETIM_PRIMARY_HI		0x41
 | |
| #define   PIIX4_FUNC1_IDETIM_PRIMARY_HI_IDE_DECODE_EN	(1 << 7)
 | |
| #define PIIX4_FUNC1_IDETIM_SECONDARY_LO		0x42
 | |
| #define PIIX4_FUNC1_IDETIM_SECONDARY_HI		0x43
 | |
| #define   PIIX4_FUNC1_IDETIM_SECONDARY_HI_IDE_DECODE_EN	(1 << 7)
 | |
| 
 | |
| /* Power Management Configuration Space */
 | |
| #define PIIX4_FUNC3_PMBA			0x40
 | |
| #define PIIX4_FUNC3_PMREGMISC			0x80
 | |
| #define   PIIX4_FUNC3_PMREGMISC_EN			(1 << 0)
 | |
| 
 | |
| /* Power Management IO Space */
 | |
| #define PIIX4_FUNC3IO_PMSTS			0x00
 | |
| #define   PIIX4_FUNC3IO_PMSTS_PWRBTN_STS		(1 << 8)
 | |
| #define PIIX4_FUNC3IO_PMCNTRL			0x04
 | |
| #define   PIIX4_FUNC3IO_PMCNTRL_SUS_EN			(1 << 13)
 | |
| #define   PIIX4_FUNC3IO_PMCNTRL_SUS_TYP			(0x7 << 10)
 | |
| #define   PIIX4_FUNC3IO_PMCNTRL_SUS_TYP_SOFF		(0x0 << 10)
 | |
| #define   PIIX4_FUNC3IO_PMCNTRL_SUS_TYP_STR		(0x1 << 10)
 | |
| 
 | |
| /* Data for magic special PCI cycle */
 | |
| #define PIIX4_SUSPEND_MAGIC			0x00120002
 | |
| 
 | |
| #endif /* __ASM_MIPS_BOARDS_PIIX4_H */
 |