summaryrefslogtreecommitdiffstats
path: root/target/linux/brcm63xx/files/arch/mips/pci/pci-bcm96348.c
blob: bea3b7ba08c45b8a05096106c7a903adba98ce3f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/*
<:copyright-gpl
 Copyright 2002 Broadcom Corp. All Rights Reserved.

 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.
:>
*/
#include <linux/types.h>
#include <linux/pci.h>
#include <linux/kernel.h>
#include <linux/init.h>

#include <bcmpci.h>

static struct resource bcm_pci_io_resource = {
	.name   = "bcm96348 pci IO space",
	.start  = BCM_PCI_IO_BASE,
	.end    = BCM_PCI_IO_BASE + BCM_PCI_IO_SIZE_64KB - 1,
	.flags  = IORESOURCE_IO
};

static struct resource bcm_pci_mem_resource = {
	.name   = "bcm96348 pci memory space",
	.start  = BCM_PCI_MEM_BASE,
	.end    = BCM_PCI_MEM_BASE + BCM_PCI_MEM_SIZE_16MB - 1,
	.flags  = IORESOURCE_MEM
};

extern struct pci_ops bcm96348_pci_ops;

struct pci_controller bcm96348_controller = {
	.pci_ops   	= &bcm96348_pci_ops,
	.io_resource	= &bcm_pci_io_resource,
	.mem_resource	= &bcm_pci_mem_resource,
};

static __init int bcm96348_pci_init(void)
{
	/* Avoid ISA compat ranges.  */
	PCIBIOS_MIN_IO = 0x00000000;
	PCIBIOS_MIN_MEM = 0x00000000;

	/* Set I/O resource limits.  */
	ioport_resource.end = 0x1fffffff;
	iomem_resource.end = 0xffffffff;

	register_pci_controller(&bcm96348_controller);
        return 0;
}

arch_initcall(bcm96348_pci_init);