mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-12-23 23:29:53 +02:00
252 lines
6.8 KiB
Diff
252 lines
6.8 KiB
Diff
|
From da8e8fe3d6ad5eb9589c8e77e7716e4f7e1a7499 Mon Sep 17 00:00:00 2001
|
||
|
From: Kurt Mahan <kmahan@freescale.com>
|
||
|
Date: Mon, 10 Dec 2007 03:36:05 -0700
|
||
|
Subject: [PATCH] Coldfire M5445x PCI Bits.
|
||
|
|
||
|
LTIBName: m5445x-pci
|
||
|
Signed-off-by: Kurt Mahan <kmahan@freescale.com>
|
||
|
---
|
||
|
arch/m68k/Kconfig | 12 ++++++++++--
|
||
|
arch/m68k/Makefile | 4 ++++
|
||
|
arch/m68k/coldfire/config.c | 2 +-
|
||
|
arch/m68k/coldfire/iomap.c | 2 ++
|
||
|
arch/m68k/coldfire/mcf5445x-devices.c | 9 +++++++++
|
||
|
arch/m68k/coldfire/mcf5445x-pci.c | 5 +++--
|
||
|
arch/m68k/coldfire/pci.c | 6 +++---
|
||
|
arch/m68k/kernel/Makefile | 2 +-
|
||
|
drivers/macintosh/Kconfig | 1 -
|
||
|
drivers/pci/Makefile | 1 +
|
||
|
include/asm-m68k/io.h | 13 ++++++++++++-
|
||
|
include/asm-m68k/pci.h | 2 ++
|
||
|
12 files changed, 48 insertions(+), 11 deletions(-)
|
||
|
|
||
|
--- a/arch/m68k/Kconfig
|
||
|
+++ b/arch/m68k/Kconfig
|
||
|
@@ -11,6 +11,14 @@ config MMU
|
||
|
bool
|
||
|
default y
|
||
|
|
||
|
+config GENERIC_TIME
|
||
|
+ bool
|
||
|
+ default n
|
||
|
+
|
||
|
+config GENERIC_CLOCKEVENTS
|
||
|
+ bool
|
||
|
+ default n
|
||
|
+
|
||
|
config RWSEM_GENERIC_SPINLOCK
|
||
|
bool
|
||
|
default y
|
||
|
@@ -48,7 +56,7 @@ config ARCH_MAY_HAVE_PC_FDC
|
||
|
default y
|
||
|
|
||
|
config NO_IOPORT
|
||
|
- def_bool y
|
||
|
+ def_bool !M54455
|
||
|
|
||
|
config NO_DMA
|
||
|
def_bool SUN3
|
||
|
@@ -159,7 +167,7 @@ config HADES
|
||
|
|
||
|
config PCI
|
||
|
bool
|
||
|
- depends on HADES
|
||
|
+ depends on HADES || M54455
|
||
|
default y
|
||
|
help
|
||
|
Find out whether you have a PCI motherboard. PCI is the name of a
|
||
|
--- a/arch/m68k/Makefile
|
||
|
+++ b/arch/m68k/Makefile
|
||
|
@@ -32,6 +32,10 @@ ifdef CONFIG_SUN3
|
||
|
LDFLAGS_vmlinux = -N
|
||
|
endif
|
||
|
|
||
|
+ifdef CONFIG_COLDFIRE
|
||
|
+# LDFLAGS_vmlinux = --verbose
|
||
|
+endif
|
||
|
+
|
||
|
CHECKFLAGS += -D__mc68000__
|
||
|
|
||
|
# without -fno-strength-reduce the 53c7xx.c driver fails ;-(
|
||
|
--- a/arch/m68k/coldfire/config.c
|
||
|
+++ b/arch/m68k/coldfire/config.c
|
||
|
@@ -252,7 +252,7 @@ void __init coldfire_sched_init(irq_hand
|
||
|
MCF_DTIM_DTMR_FRR | MCF_DTIM_DTMR_RST_EN, \
|
||
|
MCF_DTIM0_DTMR);
|
||
|
|
||
|
- request_irq(mcf_timervector, handler, SA_INTERRUPT, \
|
||
|
+ request_irq(mcf_timervector, handler, IRQF_DISABLED, \
|
||
|
"timer", (void *)MCF_DTIM0_DTMR);
|
||
|
|
||
|
settimericr(1, mcf_timerlevel);
|
||
|
--- a/arch/m68k/coldfire/iomap.c
|
||
|
+++ b/arch/m68k/coldfire/iomap.c
|
||
|
@@ -12,6 +12,7 @@
|
||
|
#include <linux/pci.h>
|
||
|
#include <asm/io.h>
|
||
|
|
||
|
+#if 0
|
||
|
void __iomem *__attribute__ ((weak))
|
||
|
ioport_map(unsigned long port, unsigned int len)
|
||
|
{
|
||
|
@@ -52,3 +53,4 @@ void pci_iounmap(struct pci_dev *dev, vo
|
||
|
/* Nothing .. */
|
||
|
}
|
||
|
EXPORT_SYMBOL(ioport_unmap);
|
||
|
+#endif
|
||
|
--- a/arch/m68k/coldfire/mcf5445x-devices.c
|
||
|
+++ b/arch/m68k/coldfire/mcf5445x-devices.c
|
||
|
@@ -75,10 +75,19 @@ static int ata_get_clk_rate(void)
|
||
|
return MCF_BUSCLK;
|
||
|
}
|
||
|
|
||
|
+/* JKM -- move these to a header file */
|
||
|
+#define MCF_IDE_DMA_WATERMARK 32 /* DMA watermark level in bytes */
|
||
|
+#define MCF_IDE_DMA_BD_NR (512/3/4) /* number of BDs per channel */
|
||
|
+
|
||
|
static struct fsl_ata_platform_data ata_data = {
|
||
|
.init = ata_init,
|
||
|
.exit = ata_exit,
|
||
|
.get_clk_rate = ata_get_clk_rate,
|
||
|
+#ifdef CONFIG_PATA_FSL_USE_DMA
|
||
|
+ .udma_mask = 0x0F, /* the board handles up to UDMA3 */
|
||
|
+ .fifo_alarm = MCF_IDE_DMA_WATERMARK / 2,
|
||
|
+ .max_sg = MCF_IDE_DMA_BD_NR,
|
||
|
+#endif
|
||
|
};
|
||
|
|
||
|
static struct resource pata_fsl_resources[] = {
|
||
|
--- a/arch/m68k/coldfire/mcf5445x-pci.c
|
||
|
+++ b/arch/m68k/coldfire/mcf5445x-pci.c
|
||
|
@@ -8,6 +8,7 @@
|
||
|
*/
|
||
|
|
||
|
#include <linux/delay.h>
|
||
|
+#include <linux/interrupt.h>
|
||
|
#include <linux/pci.h>
|
||
|
|
||
|
#include <asm/mcfsim.h>
|
||
|
@@ -76,7 +77,7 @@ void mcf5445x_pci_dumpregs(void);
|
||
|
#endif
|
||
|
|
||
|
/*
|
||
|
- * static void mcf5445x_conf_device(struct pci_dev *dev)
|
||
|
+ * mcf5445x_conf_device(struct pci_dev *dev)
|
||
|
*
|
||
|
* Machine dependent Configure the given device.
|
||
|
*
|
||
|
@@ -84,7 +85,7 @@ void mcf5445x_pci_dumpregs(void);
|
||
|
*
|
||
|
* dev - the pci device.
|
||
|
*/
|
||
|
-void __init
|
||
|
+void
|
||
|
mcf5445x_conf_device(struct pci_dev *dev)
|
||
|
{
|
||
|
set_fpga(FPGA_PCI_IRQ_ENABLE, 0x0f);
|
||
|
--- a/arch/m68k/coldfire/pci.c
|
||
|
+++ b/arch/m68k/coldfire/pci.c
|
||
|
@@ -56,7 +56,7 @@ struct pci_ops pci_root_ops = {
|
||
|
*
|
||
|
* Initialize the pcibios based on cmd line params.
|
||
|
*/
|
||
|
-char * __init
|
||
|
+char *
|
||
|
pcibios_setup(char *str)
|
||
|
{
|
||
|
if (!strcmp(str, "debug")) {
|
||
|
@@ -124,7 +124,7 @@ pcibios_map_irq(struct pci_dev *dev, u8
|
||
|
*
|
||
|
* Update a PCI interrupt.
|
||
|
*/
|
||
|
-void __init
|
||
|
+void
|
||
|
pcibios_update_irq(struct pci_dev *dev, int irq)
|
||
|
{
|
||
|
pci_write_config_byte(dev, PCI_INTERRUPT_LINE, irq);
|
||
|
@@ -171,7 +171,7 @@ pcibios_enable_device(struct pci_dev *de
|
||
|
/*
|
||
|
* pcibios_fixup_bus(struct pci_bus *bus)
|
||
|
*/
|
||
|
-void __init
|
||
|
+void
|
||
|
pcibios_fixup_bus(struct pci_bus *bus)
|
||
|
{
|
||
|
struct pci_dev *dev = bus->self;
|
||
|
--- a/arch/m68k/kernel/Makefile
|
||
|
+++ b/arch/m68k/kernel/Makefile
|
||
|
@@ -9,6 +9,7 @@ else
|
||
|
ifndef CONFIG_COLDFIRE
|
||
|
extra-y := head.o vmlinux.lds
|
||
|
obj-y := entry.o signal.o traps.o ints.o
|
||
|
+ obj-$(CONFIG_PCI) += bios32.o
|
||
|
else # CONFIG_COLDFIRE
|
||
|
extra-y := ../coldfire/head.o vmlinux.lds
|
||
|
endif
|
||
|
@@ -19,7 +20,6 @@ obj-y += process.o ptrace.o module.o \
|
||
|
|
||
|
devres-y = ../../../kernel/irq/devres.o
|
||
|
|
||
|
-obj-$(CONFIG_PCI) += bios32.o
|
||
|
obj-y$(CONFIG_MMU_SUN3) += dma.o # no, it's not a typo
|
||
|
|
||
|
EXTRA_AFLAGS := -traditional
|
||
|
--- a/drivers/macintosh/Kconfig
|
||
|
+++ b/drivers/macintosh/Kconfig
|
||
|
@@ -118,7 +118,6 @@ config PMAC_SMU
|
||
|
|
||
|
config PMAC_APM_EMU
|
||
|
tristate "APM emulation"
|
||
|
- select APM_EMULATION
|
||
|
depends on ADB_PMU && PM && PPC32
|
||
|
|
||
|
config PMAC_MEDIABAY
|
||
|
--- a/drivers/pci/Makefile
|
||
|
+++ b/drivers/pci/Makefile
|
||
|
@@ -39,6 +39,7 @@ obj-$(CONFIG_PPC) += setup-bus.o
|
||
|
obj-$(CONFIG_MIPS) += setup-bus.o setup-irq.o
|
||
|
obj-$(CONFIG_X86_VISWS) += setup-irq.o
|
||
|
obj-$(CONFIG_MN10300) += setup-bus.o
|
||
|
+obj-$(CONFIG_M54455) += setup-bus.o setup-irq.o
|
||
|
|
||
|
#
|
||
|
# ACPI Related PCI FW Functions
|
||
|
--- a/include/asm-m68k/io.h
|
||
|
+++ b/include/asm-m68k/io.h
|
||
|
@@ -306,7 +306,18 @@ static inline void isa_delay(void)
|
||
|
#define outw(val,port) out_le16((port),(val))
|
||
|
#define inl(port) in_le32(port)
|
||
|
#define outl(val,port) out_le32((port),(val))
|
||
|
-
|
||
|
+#define insb(port, buf, nr) \
|
||
|
+ raw_insb((u8 *)(port), (u8 *)(buf), (nr))
|
||
|
+#define outsb(port, buf, nr) \
|
||
|
+ raw_outsb((u8 *)(port), (u8 *)(buf), (nr))
|
||
|
+#define insw(port, buf, nr) \
|
||
|
+ raw_insw_swapw((u16 *)(port), (u16 *)(buf), (nr))
|
||
|
+#define outsw(port, buf, nr) \
|
||
|
+ raw_outsw_swapw((u16 *)(port), (u16 *)(buf), (nr))
|
||
|
+#define insl(port, buf, nr) \
|
||
|
+ raw_insw_swapw((u16 *)(port), (u16 *)(buf), (nr)<<1)
|
||
|
+#define outsl(port, buf, nr) \
|
||
|
+ raw_outsw_swapw((u16 *)(port), (u16 *)(buf), (nr)<<1)
|
||
|
#else
|
||
|
/*
|
||
|
* kernel with both ISA and PCI compiled in, those have
|
||
|
--- a/include/asm-m68k/pci.h
|
||
|
+++ b/include/asm-m68k/pci.h
|
||
|
@@ -42,11 +42,13 @@ pcibios_penalize_isa_irq(int irq, int ac
|
||
|
/* no dynamic PCI IRQ allocation */
|
||
|
}
|
||
|
|
||
|
+#if 0
|
||
|
static inline void
|
||
|
pcibios_add_platform_entries(struct pci_dev *dev)
|
||
|
{
|
||
|
/* no special handling */
|
||
|
}
|
||
|
+#endif
|
||
|
|
||
|
static inline void
|
||
|
pcibios_resource_to_bus(struct pci_dev *dev, struct pci_bus_region *region,
|