mirror of
https://github.com/adulau/aha.git
synced 2025-01-01 05:36:24 +00:00
sh: pci: Kill off platform-specific multi-window mappings.
Commit 68b42d1b54
("sh: sh7785lcr: Map
whole PCI address space.") changed around the semantics of how various
chip-selects are made accessible to PCI. Now that there is a single
large mapping covering from CS0-CS6, there is no longer any need to
do multi-window mapping. Subsequently, all of the differing
implementations can be consolidated in to pci-sh7780.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
parent
ab1363a892
commit
4c7a47de89
7 changed files with 33 additions and 95 deletions
|
@ -49,4 +49,21 @@ void __init init_se7780_IRQ(void)
|
||||||
|
|
||||||
/* ICR1: detect low level(for 2ndcut) */
|
/* ICR1: detect low level(for 2ndcut) */
|
||||||
ctrl_outl(0xAAAA0000, INTC_ICR1);
|
ctrl_outl(0xAAAA0000, INTC_ICR1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* FPGA PCISEL register initialize
|
||||||
|
*
|
||||||
|
* CPU || SLOT1 | SLOT2 | S-ATA | USB
|
||||||
|
* -------------------------------------
|
||||||
|
* INTA || INTA | INTD | -- | INTB
|
||||||
|
* -------------------------------------
|
||||||
|
* INTB || INTB | INTA | -- | INTC
|
||||||
|
* -------------------------------------
|
||||||
|
* INTC || INTC | INTB | INTA | --
|
||||||
|
* -------------------------------------
|
||||||
|
* INTD || INTD | INTC | -- | INTA
|
||||||
|
* -------------------------------------
|
||||||
|
*/
|
||||||
|
ctrl_outw(0x0013, FPGA_PCI_INTSEL1);
|
||||||
|
ctrl_outw(0xE402, FPGA_PCI_INTSEL2);
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,20 +25,3 @@ int __init pcibios_map_platform_irq(struct pci_dev *pdev, u8 slot, u8 pin)
|
||||||
{
|
{
|
||||||
return irq_tab[slot];
|
return irq_tab[slot];
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sh4_pci_address_map sh7780_pci_map = {
|
|
||||||
.window0 = {
|
|
||||||
.base = SH7780_CS2_BASE_ADDR,
|
|
||||||
.size = 0x04000000,
|
|
||||||
},
|
|
||||||
|
|
||||||
.window1 = {
|
|
||||||
.base = SH7780_CS3_BASE_ADDR,
|
|
||||||
.size = 0x04000000,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
int __init pcibios_init_platform(void)
|
|
||||||
{
|
|
||||||
return sh7780_pcic_init(&sh7780_pci_map);
|
|
||||||
}
|
|
||||||
|
|
|
@ -33,20 +33,3 @@ int __init pcibios_map_platform_irq(struct pci_dev *pdev, u8 slot, u8 pin)
|
||||||
{
|
{
|
||||||
return sdk7780_irq_tab[pin-1][slot];
|
return sdk7780_irq_tab[pin-1][slot];
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sh4_pci_address_map sdk7780_pci_map = {
|
|
||||||
.window0 = {
|
|
||||||
.base = SH7780_CS2_BASE_ADDR,
|
|
||||||
.size = 0x04000000,
|
|
||||||
},
|
|
||||||
.window1 = {
|
|
||||||
.base = SH7780_CS3_BASE_ADDR,
|
|
||||||
.size = 0x04000000,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
int __init pcibios_init_platform(void)
|
|
||||||
{
|
|
||||||
printk(KERN_INFO "SH7780 PCI: Finished initializing PCI controller\n");
|
|
||||||
return sh7780_pcic_init(&sdk7780_pci_map);
|
|
||||||
}
|
|
||||||
|
|
|
@ -40,34 +40,3 @@ int __init pcibios_map_platform_irq(struct pci_dev *pdev, u8 slot, u8 pin)
|
||||||
{
|
{
|
||||||
return se7780_irq_tab[pin-1][slot];
|
return se7780_irq_tab[pin-1][slot];
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sh4_pci_address_map se7780_pci_map = {
|
|
||||||
.window0 = {
|
|
||||||
.base = SH7780_CS2_BASE_ADDR,
|
|
||||||
.size = 0x04000000,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
int __init pcibios_init_platform(void)
|
|
||||||
{
|
|
||||||
printk("SH7780 PCI: Finished initialization of the PCI controller\n");
|
|
||||||
|
|
||||||
/*
|
|
||||||
* FPGA PCISEL register initialize
|
|
||||||
*
|
|
||||||
* CPU || SLOT1 | SLOT2 | S-ATA | USB
|
|
||||||
* -------------------------------------
|
|
||||||
* INTA || INTA | INTD | -- | INTB
|
|
||||||
* -------------------------------------
|
|
||||||
* INTB || INTB | INTA | -- | INTC
|
|
||||||
* -------------------------------------
|
|
||||||
* INTC || INTC | INTB | INTA | --
|
|
||||||
* -------------------------------------
|
|
||||||
* INTD || INTD | INTC | -- | INTA
|
|
||||||
* -------------------------------------
|
|
||||||
*/
|
|
||||||
ctrl_outw(0x0013, FPGA_PCI_INTSEL1);
|
|
||||||
ctrl_outw(0xE402, FPGA_PCI_INTSEL2);
|
|
||||||
|
|
||||||
return sh7780_pcic_init(&se7780_pci_map);
|
|
||||||
}
|
|
||||||
|
|
|
@ -25,20 +25,3 @@ int __init pcibios_map_platform_irq(struct pci_dev *pdev, u8 slot, u8 pin)
|
||||||
{
|
{
|
||||||
return irq_tab[slot];
|
return irq_tab[slot];
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sh4_pci_address_map sh7785_pci_map = {
|
|
||||||
.window0 = {
|
|
||||||
#if defined(CONFIG_32BIT)
|
|
||||||
.base = SH7780_32BIT_DDR_BASE_ADDR,
|
|
||||||
.size = 0x40000000,
|
|
||||||
#else
|
|
||||||
.base = SH7780_CS0_BASE_ADDR,
|
|
||||||
.size = 0x20000000,
|
|
||||||
#endif
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
int __init pcibios_init_platform(void)
|
|
||||||
{
|
|
||||||
return sh7780_pcic_init(&sh7785_pci_map);
|
|
||||||
}
|
|
||||||
|
|
|
@ -90,7 +90,19 @@ struct pci_channel board_pci_channels[] = {
|
||||||
{ NULL, NULL, NULL, 0, 0 },
|
{ NULL, NULL, NULL, 0, 0 },
|
||||||
};
|
};
|
||||||
|
|
||||||
int __init sh7780_pcic_init(struct sh4_pci_address_map *map)
|
static struct sh4_pci_address_map sh7780_pci_map = {
|
||||||
|
.window0 = {
|
||||||
|
#if defined(CONFIG_32BIT)
|
||||||
|
.base = SH7780_32BIT_DDR_BASE_ADDR,
|
||||||
|
.size = 0x40000000,
|
||||||
|
#else
|
||||||
|
.base = SH7780_CS0_BASE_ADDR,
|
||||||
|
.size = 0x20000000,
|
||||||
|
#endif
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
int __init pcibios_init_platform(void)
|
||||||
{
|
{
|
||||||
struct pci_channel *chan = &board_pci_channels[0];
|
struct pci_channel *chan = &board_pci_channels[0];
|
||||||
u32 word;
|
u32 word;
|
||||||
|
@ -114,14 +126,10 @@ int __init sh7780_pcic_init(struct sh4_pci_address_map *map)
|
||||||
/* Set IO and Mem windows to local address
|
/* Set IO and Mem windows to local address
|
||||||
* Make PCI and local address the same for easy 1 to 1 mapping
|
* Make PCI and local address the same for easy 1 to 1 mapping
|
||||||
*/
|
*/
|
||||||
pci_write_reg(chan, map->window0.size - 0xfffff, SH4_PCILSR0);
|
pci_write_reg(chan, sh7780_pci_map.window0.size - 0xfffff, SH4_PCILSR0);
|
||||||
pci_write_reg(chan, map->window1.size - 0xfffff, SH4_PCILSR1);
|
|
||||||
/* Set the values on window 0 PCI config registers */
|
/* Set the values on window 0 PCI config registers */
|
||||||
pci_write_reg(chan, map->window0.base, SH4_PCILAR0);
|
pci_write_reg(chan, sh7780_pci_map.window0.base, SH4_PCILAR0);
|
||||||
pci_write_reg(chan, map->window0.base, SH7780_PCIMBAR0);
|
pci_write_reg(chan, sh7780_pci_map.window0.base, SH7780_PCIMBAR0);
|
||||||
/* Set the values on window 1 PCI config registers */
|
|
||||||
pci_write_reg(chan, map->window1.base, SH4_PCILAR1);
|
|
||||||
pci_write_reg(chan, map->window1.base, SH7780_PCIMBAR1);
|
|
||||||
|
|
||||||
/* Apply any last-minute PCIC fixups */
|
/* Apply any last-minute PCIC fixups */
|
||||||
pci_fixup_pcic(chan);
|
pci_fixup_pcic(chan);
|
||||||
|
|
|
@ -104,9 +104,4 @@
|
||||||
|
|
||||||
#define SH7780_32BIT_DDR_BASE_ADDR 0x40000000
|
#define SH7780_32BIT_DDR_BASE_ADDR 0x40000000
|
||||||
|
|
||||||
struct sh4_pci_address_map;
|
|
||||||
|
|
||||||
/* arch/sh/drivers/pci/pci-sh7780.c */
|
|
||||||
int sh7780_pcic_init(struct sh4_pci_address_map *map);
|
|
||||||
|
|
||||||
#endif /* _PCI_SH7780_H_ */
|
#endif /* _PCI_SH7780_H_ */
|
||||||
|
|
Loading…
Reference in a new issue