-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-…
…linus * 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus: MIPS: Avoid spurious make includecheck message MIPS: VPE: Get rid of BKL. MIPS: VPE: Fix build after the credential changes a while ago. MIPS: Excite: Get rid of BKL. MIPS: Sibyte: Get rid of BKL. MIPS: BCM63xx: Add PCMCIA & Cardbus support. MIPS: MSP71xx: request_irq() failure ignored in msp_pcibios_config_access() MIPS: Decrease size of au1xxx_dbdma_pm_regs[][] MIPS: SMP: Inline arch_send_call_function_{single_ipi,ipi_mask} MIPS: SMP: Fix build. MIPS: MIPSxx SC: Avoid destructive invalidation on partial L2 cachelines. MIPS: Sibyte: Fix compilation error. MIPS: BCM1480: Re-apply patch lost due to bad resolution of merge conflict. MIPS: BCM63xx: Add serial driver for bcm63xx integrated UART. MIPS: Loongson2: Fix typo "enalbe" -> "enable" MIPS: SMTC: Remove duplicate structure field initialization MIPS: Remove duplicated #include MIPS: BCM63xx: Remove duplicated #include
- Loading branch information
Showing
30 changed files
with
1,852 additions
and
114 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,144 @@ | ||
/* | ||
* 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) 2008 Maxime Bizon <mbizon@freebox.fr> | ||
*/ | ||
|
||
#include <linux/init.h> | ||
#include <linux/kernel.h> | ||
#include <asm/bootinfo.h> | ||
#include <linux/platform_device.h> | ||
#include <bcm63xx_cs.h> | ||
#include <bcm63xx_cpu.h> | ||
#include <bcm63xx_dev_pcmcia.h> | ||
#include <bcm63xx_io.h> | ||
#include <bcm63xx_regs.h> | ||
|
||
static struct resource pcmcia_resources[] = { | ||
/* pcmcia registers */ | ||
{ | ||
/* start & end filled at runtime */ | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
|
||
/* pcmcia memory zone resources */ | ||
{ | ||
.start = BCM_PCMCIA_COMMON_BASE_PA, | ||
.end = BCM_PCMCIA_COMMON_END_PA, | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
{ | ||
.start = BCM_PCMCIA_ATTR_BASE_PA, | ||
.end = BCM_PCMCIA_ATTR_END_PA, | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
{ | ||
.start = BCM_PCMCIA_IO_BASE_PA, | ||
.end = BCM_PCMCIA_IO_END_PA, | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
|
||
/* PCMCIA irq */ | ||
{ | ||
/* start filled at runtime */ | ||
.flags = IORESOURCE_IRQ, | ||
}, | ||
|
||
/* declare PCMCIA IO resource also */ | ||
{ | ||
.start = BCM_PCMCIA_IO_BASE_PA, | ||
.end = BCM_PCMCIA_IO_END_PA, | ||
.flags = IORESOURCE_IO, | ||
}, | ||
}; | ||
|
||
static struct bcm63xx_pcmcia_platform_data pd; | ||
|
||
static struct platform_device bcm63xx_pcmcia_device = { | ||
.name = "bcm63xx_pcmcia", | ||
.id = 0, | ||
.num_resources = ARRAY_SIZE(pcmcia_resources), | ||
.resource = pcmcia_resources, | ||
.dev = { | ||
.platform_data = &pd, | ||
}, | ||
}; | ||
|
||
static int __init config_pcmcia_cs(unsigned int cs, | ||
u32 base, unsigned int size) | ||
{ | ||
int ret; | ||
|
||
ret = bcm63xx_set_cs_status(cs, 0); | ||
if (!ret) | ||
ret = bcm63xx_set_cs_base(cs, base, size); | ||
if (!ret) | ||
ret = bcm63xx_set_cs_status(cs, 1); | ||
return ret; | ||
} | ||
|
||
static const __initdata struct { | ||
unsigned int cs; | ||
unsigned int base; | ||
unsigned int size; | ||
} pcmcia_cs[3] = { | ||
{ | ||
.cs = MPI_CS_PCMCIA_COMMON, | ||
.base = BCM_PCMCIA_COMMON_BASE_PA, | ||
.size = BCM_PCMCIA_COMMON_SIZE | ||
}, | ||
{ | ||
.cs = MPI_CS_PCMCIA_ATTR, | ||
.base = BCM_PCMCIA_ATTR_BASE_PA, | ||
.size = BCM_PCMCIA_ATTR_SIZE | ||
}, | ||
{ | ||
.cs = MPI_CS_PCMCIA_IO, | ||
.base = BCM_PCMCIA_IO_BASE_PA, | ||
.size = BCM_PCMCIA_IO_SIZE | ||
}, | ||
}; | ||
|
||
int __init bcm63xx_pcmcia_register(void) | ||
{ | ||
int ret, i; | ||
|
||
if (!BCMCPU_IS_6348() && !BCMCPU_IS_6358()) | ||
return 0; | ||
|
||
/* use correct pcmcia ready gpio depending on processor */ | ||
switch (bcm63xx_get_cpu_id()) { | ||
case BCM6348_CPU_ID: | ||
pd.ready_gpio = 22; | ||
break; | ||
|
||
case BCM6358_CPU_ID: | ||
pd.ready_gpio = 18; | ||
break; | ||
|
||
default: | ||
return -ENODEV; | ||
} | ||
|
||
pcmcia_resources[0].start = bcm63xx_regset_address(RSET_PCMCIA); | ||
pcmcia_resources[0].end = pcmcia_resources[0].start + | ||
RSET_PCMCIA_SIZE - 1; | ||
pcmcia_resources[4].start = bcm63xx_get_irq_number(IRQ_PCMCIA); | ||
|
||
/* configure pcmcia chip selects */ | ||
for (i = 0; i < 3; i++) { | ||
ret = config_pcmcia_cs(pcmcia_cs[i].cs, | ||
pcmcia_cs[i].base, | ||
pcmcia_cs[i].size); | ||
if (ret) | ||
goto out_err; | ||
} | ||
|
||
return platform_device_register(&bcm63xx_pcmcia_device); | ||
|
||
out_err: | ||
printk(KERN_ERR "unable to set pcmcia chip select\n"); | ||
return ret; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
/* | ||
* 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) 2008 Maxime Bizon <mbizon@freebox.fr> | ||
*/ | ||
|
||
#include <linux/init.h> | ||
#include <linux/kernel.h> | ||
#include <linux/platform_device.h> | ||
#include <bcm63xx_cpu.h> | ||
#include <bcm63xx_dev_uart.h> | ||
|
||
static struct resource uart_resources[] = { | ||
{ | ||
.start = -1, /* filled at runtime */ | ||
.end = -1, /* filled at runtime */ | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
{ | ||
.start = -1, /* filled at runtime */ | ||
.flags = IORESOURCE_IRQ, | ||
}, | ||
}; | ||
|
||
static struct platform_device bcm63xx_uart_device = { | ||
.name = "bcm63xx_uart", | ||
.id = 0, | ||
.num_resources = ARRAY_SIZE(uart_resources), | ||
.resource = uart_resources, | ||
}; | ||
|
||
int __init bcm63xx_uart_register(void) | ||
{ | ||
uart_resources[0].start = bcm63xx_regset_address(RSET_UART0); | ||
uart_resources[0].end = uart_resources[0].start; | ||
uart_resources[0].end += RSET_UART_SIZE - 1; | ||
uart_resources[1].start = bcm63xx_get_irq_number(IRQ_UART0); | ||
return platform_device_register(&bcm63xx_uart_device); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
#ifndef BCM63XX_DEV_PCMCIA_H_ | ||
#define BCM63XX_DEV_PCMCIA_H_ | ||
|
||
/* | ||
* PCMCIA driver platform data | ||
*/ | ||
struct bcm63xx_pcmcia_platform_data { | ||
unsigned int ready_gpio; | ||
}; | ||
|
||
int bcm63xx_pcmcia_register(void); | ||
|
||
#endif /* BCM63XX_DEV_PCMCIA_H_ */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
#ifndef BCM63XX_DEV_UART_H_ | ||
#define BCM63XX_DEV_UART_H_ | ||
|
||
int bcm63xx_uart_register(void); | ||
|
||
#endif /* BCM63XX_DEV_UART_H_ */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.