mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 7034228792
			
		
	
	
		7034228792
		
	
	
	
	
		
			
			Having received another series of whitespace patches I decided to do this once and for all rather than dealing with this kind of patches trickling in forever. Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * This file is subject to the terms and conditions of the GNU General Public
 | |
|  * License.  See the file "COPYING" in the main directory of this archive
 | |
|  * for more details.
 | |
|  *
 | |
|  * Copyright (C) 2000, 2001, 04 Keith M Wesolowski
 | |
|  */
 | |
| #include <linux/init.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/pci.h>
 | |
| #include <linux/types.h>
 | |
| 
 | |
| #include <asm/lasat/lasat.h>
 | |
| 
 | |
| #include <irq.h>
 | |
| 
 | |
| extern struct pci_ops nile4_pci_ops;
 | |
| extern struct pci_ops gt64xxx_pci0_ops;
 | |
| static struct resource lasat_pci_mem_resource = {
 | |
| 	.name	= "LASAT PCI MEM",
 | |
| 	.start	= 0x18000000,
 | |
| 	.end	= 0x19ffffff,
 | |
| 	.flags	= IORESOURCE_MEM,
 | |
| };
 | |
| 
 | |
| static struct resource lasat_pci_io_resource = {
 | |
| 	.name	= "LASAT PCI IO",
 | |
| 	.start	= 0x1a000000,
 | |
| 	.end	= 0x1bffffff,
 | |
| 	.flags	= IORESOURCE_IO,
 | |
| };
 | |
| 
 | |
| static struct pci_controller lasat_pci_controller = {
 | |
| 	.mem_resource	= &lasat_pci_mem_resource,
 | |
| 	.io_resource	= &lasat_pci_io_resource,
 | |
| };
 | |
| 
 | |
| static int __init lasat_pci_setup(void)
 | |
| {
 | |
| 	printk(KERN_DEBUG "PCI: starting\n");
 | |
| 
 | |
| 	if (IS_LASAT_200())
 | |
| 		lasat_pci_controller.pci_ops = &nile4_pci_ops;
 | |
| 	else
 | |
| 		lasat_pci_controller.pci_ops = >64xxx_pci0_ops;
 | |
| 
 | |
| 	register_pci_controller(&lasat_pci_controller);
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| arch_initcall(lasat_pci_setup);
 | |
| 
 | |
| #define LASAT_IRQ_ETH1	 (LASAT_IRQ_BASE + 0)
 | |
| #define LASAT_IRQ_ETH0	 (LASAT_IRQ_BASE + 1)
 | |
| #define LASAT_IRQ_HDC	 (LASAT_IRQ_BASE + 2)
 | |
| #define LASAT_IRQ_COMP	 (LASAT_IRQ_BASE + 3)
 | |
| #define LASAT_IRQ_HDLC	 (LASAT_IRQ_BASE + 4)
 | |
| #define LASAT_IRQ_PCIA	 (LASAT_IRQ_BASE + 5)
 | |
| #define LASAT_IRQ_PCIB	 (LASAT_IRQ_BASE + 6)
 | |
| #define LASAT_IRQ_PCIC	 (LASAT_IRQ_BASE + 7)
 | |
| #define LASAT_IRQ_PCID	 (LASAT_IRQ_BASE + 8)
 | |
| 
 | |
| int __init pcibios_map_irq(const struct pci_dev *dev, u8 slot, u8 pin)
 | |
| {
 | |
| 	switch (slot) {
 | |
| 	case 1:
 | |
| 	case 2:
 | |
| 	case 3:
 | |
| 		return LASAT_IRQ_PCIA + (((slot-1) + (pin-1)) % 4);
 | |
| 	case 4:
 | |
| 		return LASAT_IRQ_ETH1;	 /* Ethernet 1 (LAN 2) */
 | |
| 	case 5:
 | |
| 		return LASAT_IRQ_ETH0;	 /* Ethernet 0 (LAN 1) */
 | |
| 	case 6:
 | |
| 		return LASAT_IRQ_HDC;	 /* IDE controller */
 | |
| 	default:
 | |
| 		return 0xff;		/* Illegal */
 | |
| 	}
 | |
| 
 | |
| 	return -1;
 | |
| }
 | |
| 
 | |
| /* Do platform specific device initialization at pci_enable_device() time */
 | |
| int pcibios_plat_dev_init(struct pci_dev *dev)
 | |
| {
 | |
| 	return 0;
 | |
| }
 |