]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
[POWERPC] Remove APUS support from arch/ppc
authorAdrian Bunk <bunk@kernel.org>
Mon, 27 Aug 2007 21:29:53 +0000 (23:29 +0200)
committerPaul Mackerras <paulus@samba.org>
Mon, 17 Sep 2007 05:15:04 +0000 (15:15 +1000)
Current status of APUS:
- arch/powerpc/: removed in 2.6.23
- arch/ppc/: marked BROKEN since 2 years

This therefore removes the remaining parts of APUS support from
arch/ppc, include/asm-ppc, arch/powerpc and include/asm-powerpc.

Signed-off-by: Adrian Bunk <bunk@stusta.de>
Signed-off-by: Paul Mackerras <paulus@samba.org>
32 files changed:
arch/ppc/Kconfig
arch/ppc/Makefile
arch/ppc/amiga/Makefile [deleted file]
arch/ppc/amiga/amiga_ksyms.c [deleted file]
arch/ppc/amiga/amiints.c [deleted file]
arch/ppc/amiga/amisound.c [deleted file]
arch/ppc/amiga/bootinfo.c [deleted file]
arch/ppc/amiga/chipram.c [deleted file]
arch/ppc/amiga/cia.c [deleted file]
arch/ppc/amiga/config.c [deleted file]
arch/ppc/amiga/ints.c [deleted file]
arch/ppc/amiga/pcmcia.c [deleted file]
arch/ppc/amiga/time.c [deleted file]
arch/ppc/configs/apus_defconfig [deleted file]
arch/ppc/kernel/head.S
arch/ppc/kernel/ppc_ksyms.c
arch/ppc/kernel/setup.c
arch/ppc/mm/pgtable.c
arch/ppc/platforms/Makefile
arch/ppc/platforms/apus_pci.c [deleted file]
arch/ppc/platforms/apus_pci.h [deleted file]
arch/ppc/platforms/apus_setup.c [deleted file]
include/asm-powerpc/ide.h
include/asm-powerpc/reg.h
include/asm-ppc/amigahw.h [deleted file]
include/asm-ppc/amigaints.h [deleted file]
include/asm-ppc/amigappc.h [deleted file]
include/asm-ppc/bootinfo.h
include/asm-ppc/io.h
include/asm-ppc/machdep.h
include/asm-ppc/page.h
include/asm-ppc/pgtable.h

index 6bdeeb70b157856a00b6ce22c397a74abeb0d803..c1b34eb383cf165a385ba5bc21f0ddaee589c04f 100644 (file)
@@ -573,24 +573,9 @@ choice
 
          Select PReP if configuring for a PReP machine.
 
-         Select Gemini if configuring for a Synergy Microsystems' Gemini
-         series Single Board Computer.  More information is available at:
-         <http://www.synergymicro.com/PressRel/97_10_15.html>.
-
-         Select APUS if configuring for a PowerUP Amiga.  More information is
-         available at: <http://linux-apus.sourceforge.net/>.
-
 config PPC_PREP
        bool "PReP"
 
-config APUS
-       bool "Amiga-APUS"
-       depends on BROKEN
-       help
-         Select APUS if configuring for a PowerUP Amiga.
-         More information is available at:
-         <http://linux-apus.sourceforge.net/>.
-
 config KATANA
        bool "Artesyn-Katana"
        help
@@ -1027,132 +1012,6 @@ config CMDLINE
          some command-line options at build time by entering them here.  In
          most cases you will need to specify the root device here.
 
-config AMIGA
-       bool
-       depends on APUS
-       default y
-       help
-         This option enables support for the Amiga series of computers.
-
-config ZORRO
-       bool
-       depends on APUS
-       default y
-       help
-         This enables support for the Zorro bus in the Amiga. If you have
-         expansion cards in your Amiga that conform to the Amiga
-         AutoConfig(tm) specification, say Y, otherwise N. Note that even
-         expansion cards that do not fit in the Zorro slots but fit in e.g.
-         the CPU slot may fall in this category, so you have to say Y to let
-         Linux use these.
-
-config ABSTRACT_CONSOLE
-       bool
-       depends on APUS
-       default y
-
-config APUS_FAST_EXCEPT
-       bool
-       depends on APUS
-       default y
-
-config AMIGA_PCMCIA
-       bool "Amiga 1200/600 PCMCIA support"
-       depends on APUS && EXPERIMENTAL
-       help
-         Include support in the kernel for pcmcia on Amiga 1200 and Amiga
-         600. If you intend to use pcmcia cards say Y; otherwise say N.
-
-config AMIGA_BUILTIN_SERIAL
-       tristate "Amiga builtin serial support"
-       depends on APUS
-       help
-         If you want to use your Amiga's built-in serial port in Linux,
-         answer Y.
-
-         To compile this driver as a module, choose M here.
-
-config GVPIOEXT
-       tristate "GVP IO-Extender support"
-       depends on APUS
-       help
-         If you want to use a GVP IO-Extender serial card in Linux, say Y.
-         Otherwise, say N.
-
-config GVPIOEXT_LP
-       tristate "GVP IO-Extender parallel printer support"
-       depends on GVPIOEXT
-       help
-         Say Y to enable driving a printer from the parallel port on your
-         GVP IO-Extender card, N otherwise.
-
-config GVPIOEXT_PLIP
-       tristate "GVP IO-Extender PLIP support"
-       depends on GVPIOEXT
-       help
-         Say Y to enable doing IP over the parallel port on your GVP
-         IO-Extender card, N otherwise.
-
-config MULTIFACE_III_TTY
-       tristate "Multiface Card III serial support"
-       depends on APUS
-       help
-         If you want to use a Multiface III card's serial port in Linux,
-         answer Y.
-
-         To compile this driver as a module, choose M here.
-
-config A2232
-       tristate "Commodore A2232 serial support (EXPERIMENTAL)"
-       depends on EXPERIMENTAL && APUS
-       ---help---
-         This option supports the 2232 7-port serial card shipped with the
-         Amiga 2000 and other Zorro-bus machines, dating from 1989.  At
-         a max of 19,200 bps, the ports are served by a 6551 ACIA UART chip
-         each, plus a 8520 CIA, and a master 6502 CPU and buffer as well. The
-         ports were connected with 8 pin DIN connectors on the card bracket,
-         for which 8 pin to DB25 adapters were supplied. The card also had
-         jumpers internally to toggle various pinning configurations.
-
-         This driver can be built as a module; but then "generic_serial"
-         will also be built as a module. This has to be loaded before
-         "ser_a2232". If you want to do this, answer M here.
-
-config WHIPPET_SERIAL
-       tristate "Hisoft Whippet PCMCIA serial support"
-       depends on AMIGA_PCMCIA
-       help
-         HiSoft has a web page at <http://www.hisoft.co.uk/>, but there
-         is no listing for the Whippet in their Amiga section.
-
-config APNE
-       tristate "PCMCIA NE2000 support"
-       depends on AMIGA_PCMCIA
-       help
-         If you have a PCMCIA NE2000 compatible adapter, say Y.  Otherwise,
-         say N.
-
-         To compile this driver as a module, choose M here: the
-         module will be called apne.
-
-config SERIAL_CONSOLE
-       bool "Support for serial port console"
-       depends on APUS && (AMIGA_BUILTIN_SERIAL=y || GVPIOEXT=y || MULTIFACE_III_TTY=y)
-
-config HEARTBEAT
-       bool "Use power LED as a heartbeat"
-       depends on APUS
-       help
-         Use the power-on LED on your machine as a load meter.  The exact
-         behavior is platform-dependent, but normally the flash frequency is
-         a hyperbolic function of the 5-minute load average.
-
-config PROC_HARDWARE
-       bool "/proc/hardware support"
-       depends on APUS
-
-source "drivers/zorro/Kconfig"
-
 if !44x || BROKEN
 source kernel/power/Kconfig
 endif
@@ -1227,8 +1086,7 @@ config MCA
 
 config PCI
        bool "PCI support" if 40x || CPM2 || 83xx || 85xx || PPC_MPC52xx
-       default y if !40x && !CPM2 && !8xx && !APUS && !83xx && !85xx
-       default PCI_PERMEDIA if !4xx && !CPM2 && !8xx && APUS
+       default y if !40x && !CPM2 && !8xx && !83xx && !85xx
        default PCI_QSPAN if !4xx && !CPM2 && 8xx
        help
          Find out whether your system includes a PCI bus. PCI is the name of
@@ -1284,10 +1142,6 @@ config 8260_PCI9_IDMA4
 
 endchoice
 
-config PCI_PERMEDIA
-       bool "PCI for Permedia2"
-       depends on !4xx && !8xx && APUS
-
 source "drivers/pci/Kconfig"
 
 source "drivers/pcmcia/Kconfig"
index 0db66dcf072378a4deacf0ea9d8d9f4cf5884d20..eee6264e8a043a027db7d929fec792d8188c442e 100644 (file)
@@ -69,7 +69,6 @@ core-$(CONFIG_83xx)           += arch/ppc/platforms/83xx/
 core-$(CONFIG_85xx)            += arch/ppc/platforms/85xx/
 core-$(CONFIG_MATH_EMULATION)  += arch/powerpc/math-emu/
 core-$(CONFIG_XMON)            += arch/ppc/xmon/
-core-$(CONFIG_APUS)            += arch/ppc/amiga/
 drivers-$(CONFIG_8xx)          += arch/ppc/8xx_io/
 drivers-$(CONFIG_4xx)          += arch/ppc/4xx_io/
 drivers-$(CONFIG_CPM2)         += arch/ppc/8260_io/
diff --git a/arch/ppc/amiga/Makefile b/arch/ppc/amiga/Makefile
deleted file mode 100644 (file)
index 59fec0a..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-#
-# Makefile for Linux arch/m68k/amiga source directory
-#
-
-obj-y          := config.o amiints.o cia.o time.o bootinfo.o amisound.o \
-                       chipram.o amiga_ksyms.o
-
-obj-$(CONFIG_AMIGA_PCMCIA) += pcmcia.o
diff --git a/arch/ppc/amiga/amiga_ksyms.c b/arch/ppc/amiga/amiga_ksyms.c
deleted file mode 100644 (file)
index ec74e5b..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#include "../../m68k/amiga/amiga_ksyms.c"
diff --git a/arch/ppc/amiga/amiints.c b/arch/ppc/amiga/amiints.c
deleted file mode 100644 (file)
index 265fcd3..0000000
+++ /dev/null
@@ -1,322 +0,0 @@
-/*
- * Amiga Linux interrupt handling code
- *
- * 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.
- *
- * 11/07/96: rewritten interrupt handling, irq lists are exists now only for
- *           this sources where it makes sense (VERTB/PORTS/EXTER) and you must
- *           be careful that dev_id for this sources is unique since this the
- *           only possibility to distinguish between different handlers for
- *           free_irq. irq lists also have different irq flags:
- *           - IRQ_FLG_FAST: handler is inserted at top of list (after other
- *                           fast handlers)
- *           - IRQ_FLG_SLOW: handler is inserted at bottom of list and before
- *                           they're executed irq level is set to the previous
- *                           one, but handlers don't need to be reentrant, if
- *                           reentrance occurred, slow handlers will be just
- *                           called again.
- *           The whole interrupt handling for CIAs is moved to cia.c
- *           /Roman Zippel
- *
- * 07/08/99: rewamp of the interrupt handling - we now have two types of
- *           interrupts, normal and fast handlers, fast handlers being
- *           marked with SA_INTERRUPT and runs with all other interrupts
- *           disabled. Normal interrupts disable their own source but
- *           run with all other interrupt sources enabled.
- *           PORTS and EXTER interrupts are always shared even if the
- *           drivers do not explicitly mark this when calling
- *           request_irq which they really should do.
- *           This is similar to the way interrupts are handled on all
- *           other architectures and makes a ton of sense besides
- *           having the advantage of making it easier to share
- *           drivers.
- *           /Jes
- */
-
-#include <linux/types.h>
-#include <linux/kernel.h>
-#include <linux/sched.h>
-#include <linux/interrupt.h>
-#include <linux/irq.h>
-#include <linux/kernel_stat.h>
-#include <linux/init.h>
-
-#include <asm/system.h>
-#include <asm/irq.h>
-#include <asm/traps.h>
-#include <asm/amigahw.h>
-#include <asm/amigaints.h>
-#include <asm/amipcmcia.h>
-
-#ifdef CONFIG_APUS
-#include <asm/amigappc.h>
-#endif
-
-extern void cia_init_IRQ(struct ciabase *base);
-
-unsigned short ami_intena_vals[AMI_STD_IRQS] = {
-       IF_VERTB, IF_COPER, IF_AUD0, IF_AUD1, IF_AUD2, IF_AUD3, IF_BLIT,
-       IF_DSKSYN, IF_DSKBLK, IF_RBF, IF_TBE, IF_SOFT, IF_PORTS, IF_EXTER
-};
-static const unsigned char ami_servers[AMI_STD_IRQS] = {
-       1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1
-};
-
-static short ami_ablecount[AMI_IRQS];
-
-static void ami_badint(int irq, void *dev_id, struct pt_regs *fp)
-{
-/*     num_spurious += 1;*/
-}
-
-/*
- * void amiga_init_IRQ(void)
- *
- * Parameters: None
- *
- * Returns:    Nothing
- *
- * This function should be called during kernel startup to initialize
- * the amiga IRQ handling routines.
- */
-
-__init
-void amiga_init_IRQ(void)
-{
-       int i;
-
-       for (i = 0; i < AMI_IRQS; i++)
-               ami_ablecount[i] = 0;
-
-       /* turn off PCMCIA interrupts */
-       if (AMIGAHW_PRESENT(PCMCIA))
-               gayle.inten = GAYLE_IRQ_IDE;
-
-       /* turn off all interrupts... */
-       amiga_custom.intena = 0x7fff;
-       amiga_custom.intreq = 0x7fff;
-
-#ifdef CONFIG_APUS
-       /* Clear any inter-CPU interrupt requests. Circumvents bug in
-           Blizzard IPL emulation HW (or so it appears). */
-       APUS_WRITE(APUS_INT_LVL, INTLVL_SETRESET | INTLVL_MASK);
-
-       /* Init IPL emulation. */
-       APUS_WRITE(APUS_REG_INT, REGINT_INTMASTER | REGINT_ENABLEIPL);
-       APUS_WRITE(APUS_IPL_EMU, IPLEMU_DISABLEINT);
-       APUS_WRITE(APUS_IPL_EMU, IPLEMU_SETRESET | IPLEMU_IPLMASK);
-#endif
-       /* ... and enable the master interrupt bit */
-       amiga_custom.intena = IF_SETCLR | IF_INTEN;
-
-       cia_init_IRQ(&ciaa_base);
-       cia_init_IRQ(&ciab_base);
-}
-
-/*
- * Enable/disable a particular machine specific interrupt source.
- * Note that this may affect other interrupts in case of a shared interrupt.
- * This function should only be called for a _very_ short time to change some
- * internal data, that may not be changed by the interrupt at the same time.
- * ami_(enable|disable)_irq calls may also be nested.
- */
-
-void amiga_enable_irq(unsigned int irq)
-{
-       if (irq >= AMI_IRQS) {
-               printk("%s: Unknown IRQ %d\n", __FUNCTION__, irq);
-               return;
-       }
-
-       ami_ablecount[irq]--;
-       if (ami_ablecount[irq]<0)
-               ami_ablecount[irq]=0;
-       else if (ami_ablecount[irq])
-               return;
-
-       /* No action for auto-vector interrupts */
-       if (irq >= IRQ_AMIGA_AUTO){
-               printk("%s: Trying to enable auto-vector IRQ %i\n",
-                      __FUNCTION__, irq - IRQ_AMIGA_AUTO);
-               return;
-       }
-
-       if (irq >= IRQ_AMIGA_CIAA) {
-               cia_set_irq(irq, 0);
-               cia_able_irq(irq, 1);
-               return;
-       }
-
-       /* enable the interrupt */
-       amiga_custom.intena = IF_SETCLR | ami_intena_vals[irq];
-}
-
-void amiga_disable_irq(unsigned int irq)
-{
-       if (irq >= AMI_IRQS) {
-               printk("%s: Unknown IRQ %d\n", __FUNCTION__, irq);
-               return;
-       }
-
-       if (ami_ablecount[irq]++)
-               return;
-
-       /* No action for auto-vector interrupts */
-       if (irq >= IRQ_AMIGA_AUTO) {
-               printk("%s: Trying to disable auto-vector IRQ %i\n",
-                      __FUNCTION__, irq - IRQ_AMIGA_AUTO);
-               return;
-       }
-
-       if (irq >= IRQ_AMIGA_CIAA) {
-               cia_able_irq(irq, 0);
-               return;
-       }
-
-       /* disable the interrupt */
-       amiga_custom.intena = ami_intena_vals[irq];
-}
-
-inline void amiga_do_irq(int irq, struct pt_regs *fp)
-{
-       irq_desc_t *desc = irq_desc + irq;
-       struct irqaction *action = desc->action;
-
-       kstat_cpu(0).irqs[irq]++;
-       action->handler(irq, action->dev_id, fp);
-}
-
-void amiga_do_irq_list(int irq, struct pt_regs *fp)
-{
-       irq_desc_t *desc = irq_desc + irq;
-       struct irqaction *action;
-
-       kstat_cpu(0).irqs[irq]++;
-
-       amiga_custom.intreq = ami_intena_vals[irq];
-
-       for (action = desc->action; action; action = action->next)
-               action->handler(irq, action->dev_id, fp);
-}
-
-/*
- * The builtin Amiga hardware interrupt handlers.
- */
-
-static void ami_int1(int irq, void *dev_id, struct pt_regs *fp)
-{
-       unsigned short ints = amiga_custom.intreqr & amiga_custom.intenar;
-
-       /* if serial transmit buffer empty, interrupt */
-       if (ints & IF_TBE) {
-               amiga_custom.intreq = IF_TBE;
-               amiga_do_irq(IRQ_AMIGA_TBE, fp);
-       }
-
-       /* if floppy disk transfer complete, interrupt */
-       if (ints & IF_DSKBLK) {
-               amiga_custom.intreq = IF_DSKBLK;
-               amiga_do_irq(IRQ_AMIGA_DSKBLK, fp);
-       }
-
-       /* if software interrupt set, interrupt */
-       if (ints & IF_SOFT) {
-               amiga_custom.intreq = IF_SOFT;
-               amiga_do_irq(IRQ_AMIGA_SOFT, fp);
-       }
-}
-
-static void ami_int3(int irq, void *dev_id, struct pt_regs *fp)
-{
-       unsigned short ints = amiga_custom.intreqr & amiga_custom.intenar;
-
-       /* if a blitter interrupt */
-       if (ints & IF_BLIT) {
-               amiga_custom.intreq = IF_BLIT;
-               amiga_do_irq(IRQ_AMIGA_BLIT, fp);
-       }
-
-       /* if a copper interrupt */
-       if (ints & IF_COPER) {
-               amiga_custom.intreq = IF_COPER;
-               amiga_do_irq(IRQ_AMIGA_COPPER, fp);
-       }
-
-       /* if a vertical blank interrupt */
-       if (ints & IF_VERTB)
-               amiga_do_irq_list(IRQ_AMIGA_VERTB, fp);
-}
-
-static void ami_int4(int irq, void *dev_id, struct pt_regs *fp)
-{
-       unsigned short ints = amiga_custom.intreqr & amiga_custom.intenar;
-
-       /* if audio 0 interrupt */
-       if (ints & IF_AUD0) {
-               amiga_custom.intreq = IF_AUD0;
-               amiga_do_irq(IRQ_AMIGA_AUD0, fp);
-       }
-
-       /* if audio 1 interrupt */
-       if (ints & IF_AUD1) {
-               amiga_custom.intreq = IF_AUD1;
-               amiga_do_irq(IRQ_AMIGA_AUD1, fp);
-       }
-
-       /* if audio 2 interrupt */
-       if (ints & IF_AUD2) {
-               amiga_custom.intreq = IF_AUD2;
-               amiga_do_irq(IRQ_AMIGA_AUD2, fp);
-       }
-
-       /* if audio 3 interrupt */
-       if (ints & IF_AUD3) {
-               amiga_custom.intreq = IF_AUD3;
-               amiga_do_irq(IRQ_AMIGA_AUD3, fp);
-       }
-}
-
-static void ami_int5(int irq, void *dev_id, struct pt_regs *fp)
-{
-       unsigned short ints = amiga_custom.intreqr & amiga_custom.intenar;
-
-       /* if serial receive buffer full interrupt */
-       if (ints & IF_RBF) {
-               /* acknowledge of IF_RBF must be done by the serial interrupt */
-               amiga_do_irq(IRQ_AMIGA_RBF, fp);
-       }
-
-       /* if a disk sync interrupt */
-       if (ints & IF_DSKSYN) {
-               amiga_custom.intreq = IF_DSKSYN;
-               amiga_do_irq(IRQ_AMIGA_DSKSYN, fp);
-       }
-}
-
-static void ami_int7(int irq, void *dev_id, struct pt_regs *fp)
-{
-       panic ("level 7 interrupt received\n");
-}
-
-#ifdef CONFIG_APUS
-/* The PPC irq handling links all handlers requested on the same vector
-   and executes them in a loop. Having ami_badint at the end of the chain
-   is a bad idea. */
-struct irqaction amiga_sys_irqaction[AUTO_IRQS] = {
-       { .handler = ami_badint, .name = "spurious int" },
-       { .handler = ami_int1, .name = "int1 handler" },
-       { 0, /* CIAA */ },
-       { .handler = ami_int3, .name = "int3 handler" },
-       { .handler = ami_int4, .name = "int4 handler" },
-       { .handler = ami_int5, .name = "int5 handler" },
-       { 0, /* CIAB */ },
-       { .handler = ami_int7, .name = "int7 handler" },
-};
-#else
-void (*amiga_default_handler[SYS_IRQS])(int, void *, struct pt_regs *) = {
-       ami_badint, ami_int1, ami_badint, ami_int3,
-       ami_int4, ami_int5, ami_badint, ami_int7
-};
-#endif
diff --git a/arch/ppc/amiga/amisound.c b/arch/ppc/amiga/amisound.c
deleted file mode 100644 (file)
index 2b86cbe..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#include "../../m68k/amiga/amisound.c"
diff --git a/arch/ppc/amiga/bootinfo.c b/arch/ppc/amiga/bootinfo.c
deleted file mode 100644 (file)
index efd869a..0000000
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- *  Extracted from arch/m68k/kernel/setup.c.
- *  Should be properly generalized and put somewhere else.
- *                              Jesper
- */
-
-#include <linux/types.h>
-#include <linux/kernel.h>
-#include <linux/string.h>
-#include <linux/init.h>
-
-#include <asm/setup.h>
-#include <asm/bootinfo.h>
-
-extern char cmd_line[CL_SIZE];
-
-extern int num_memory;
-extern int m68k_realnum_memory;
-extern struct mem_info memory[NUM_MEMINFO];
-extern struct mem_info m68k_memory[NUM_MEMINFO];
-extern struct mem_info ramdisk;
-
-extern int amiga_parse_bootinfo(const struct bi_record *);
-extern int atari_parse_bootinfo(const struct bi_record *);
-extern int mac_parse_bootinfo(const struct bi_record *);
-
-void __init parse_bootinfo(const struct bi_record *record)
-{
-    while (record->tag != BI_LAST) {
-       int unknown = 0;
-       const u_long *data = record->data;
-       switch (record->tag) {
-           case BI_MACHTYPE:
-           case BI_CPUTYPE:
-           case BI_FPUTYPE:
-           case BI_MMUTYPE:
-               /* Already set up by head.S */
-               break;
-
-           case BI_MEMCHUNK:
-               if (num_memory < NUM_MEMINFO) {
-                   memory[num_memory].addr = data[0];
-                   memory[num_memory].size = data[1];
-                   num_memory++;
-
-                   /* FIXME: duplicate for m68k drivers. */
-                   m68k_memory[m68k_realnum_memory].addr = data[0];
-                   m68k_memory[m68k_realnum_memory].size = data[1];
-                   m68k_realnum_memory++;
-               } else
-                   printk("parse_bootinfo: too many memory chunks\n");
-               break;
-
-           case BI_RAMDISK:
-               ramdisk.addr = data[0];
-               ramdisk.size = data[1];
-               break;
-
-           case BI_COMMAND_LINE:
-               strlcpy(cmd_line, (const char *)data, sizeof(cmd_line));
-               break;
-
-           default:
-               if (MACH_IS_AMIGA)
-                   unknown = amiga_parse_bootinfo(record);
-               else if (MACH_IS_ATARI)
-                   unknown = atari_parse_bootinfo(record);
-               else if (MACH_IS_MAC)
-                   unknown = mac_parse_bootinfo(record);
-               else
-                   unknown = 1;
-       }
-       if (unknown)
-           printk("parse_bootinfo: unknown tag 0x%04x ignored\n",
-                  record->tag);
-       record = (struct bi_record *)((u_long)record+record->size);
-    }
-}
diff --git a/arch/ppc/amiga/chipram.c b/arch/ppc/amiga/chipram.c
deleted file mode 100644 (file)
index e6ab3c6..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#include "../../m68k/amiga/chipram.c"
diff --git a/arch/ppc/amiga/cia.c b/arch/ppc/amiga/cia.c
deleted file mode 100644 (file)
index 9558f2f..0000000
+++ /dev/null
@@ -1,176 +0,0 @@
-/*
- *  Copyright (C) 1996 Roman Zippel
- *
- *  The concept of some functions bases on the original Amiga OS function
- *
- * 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.
- */
-
-#include <linux/types.h>
-#include <linux/kernel.h>
-#include <linux/sched.h>
-#include <linux/interrupt.h>
-#include <linux/irq.h>
-#include <linux/kernel_stat.h>
-#include <linux/init.h>
-
-#include <asm/irq.h>
-#include <asm/amigahw.h>
-#include <asm/amigaints.h>
-
-struct ciabase {
-       volatile struct CIA *cia;
-       u_char icr_mask, icr_data;
-       u_short int_mask;
-       int handler_irq, cia_irq, server_irq;
-       char *name;
-} ciaa_base = {
-       &ciaa, 0, 0, IF_PORTS,
-       IRQ_AMIGA_AUTO_2, IRQ_AMIGA_CIAA,
-       IRQ_AMIGA_PORTS,
-       "CIAA handler"
-}, ciab_base = {
-       &ciab, 0, 0, IF_EXTER,
-       IRQ_AMIGA_AUTO_6, IRQ_AMIGA_CIAB,
-       IRQ_AMIGA_EXTER,
-       "CIAB handler"
-};
-
-#define CIA_SET_BASE_ADJUST_IRQ(base, irq)     \
-do {                                           \
-       if (irq >= IRQ_AMIGA_CIAB) {            \
-               base = &ciab_base;              \
-               irq -= IRQ_AMIGA_CIAB;          \
-       } else {                                \
-               base = &ciaa_base;              \
-               irq -= IRQ_AMIGA_CIAA;          \
-       }                                       \
-} while (0)
-
-/*
- *  Cause or clear CIA interrupts, return old interrupt status.
- */
-
-static unsigned char cia_set_irq_private(struct ciabase *base,
-                                        unsigned char mask)
-{
-       u_char old;
-
-       old = (base->icr_data |= base->cia->icr);
-       if (mask & CIA_ICR_SETCLR)
-               base->icr_data |= mask;
-       else
-               base->icr_data &= ~mask;
-       if (base->icr_data & base->icr_mask)
-               amiga_custom.intreq = IF_SETCLR | base->int_mask;
-       return old & base->icr_mask;
-}
-
-unsigned char cia_set_irq(unsigned int irq, int set)
-{
-       struct ciabase *base;
-       unsigned char mask;
-
-       if (irq >= IRQ_AMIGA_CIAB)
-               mask = (1 << (irq - IRQ_AMIGA_CIAB));
-       else
-               mask = (1 << (irq - IRQ_AMIGA_CIAA));
-       mask |= (set) ? CIA_ICR_SETCLR : 0;
-
-       CIA_SET_BASE_ADJUST_IRQ(base, irq);
-
-       return cia_set_irq_private(base, mask);
-}
-
-unsigned char cia_get_irq_mask(unsigned int irq)
-{
-       struct ciabase *base;
-
-       CIA_SET_BASE_ADJUST_IRQ(base, irq);
-
-       return base->cia->icr;
-}
-
-/*
- *  Enable or disable CIA interrupts, return old interrupt mask.
- */
-
-static unsigned char cia_able_irq_private(struct ciabase *base,
-                                         unsigned char mask)
-{
-       u_char old;
-
-       old = base->icr_mask;
-       base->icr_data |= base->cia->icr;
-       base->cia->icr = mask;
-       if (mask & CIA_ICR_SETCLR)
-               base->icr_mask |= mask;
-       else
-               base->icr_mask &= ~mask;
-       base->icr_mask &= CIA_ICR_ALL;
-
-       if (base->icr_data & base->icr_mask)
-               amiga_custom.intreq = IF_SETCLR | base->int_mask;
-       return old;
-}
-
-unsigned char cia_able_irq(unsigned int irq, int enable)
-{
-       struct ciabase *base;
-       unsigned char mask;
-
-       if (irq >= IRQ_AMIGA_CIAB)
-               mask = (1 << (irq - IRQ_AMIGA_CIAB));
-       else
-               mask = (1 << (irq - IRQ_AMIGA_CIAA));
-       mask |= (enable) ? CIA_ICR_SETCLR : 0;
-
-       CIA_SET_BASE_ADJUST_IRQ(base, irq);
-
-       return cia_able_irq_private(base, mask);
-}
-
-static void cia_handler(int irq, void *dev_id, struct pt_regs *fp)
-{
-       struct ciabase *base = (struct ciabase *)dev_id;
-       irq_desc_t *desc;
-       struct irqaction *action;
-       int i;
-       unsigned char ints;
-
-       irq = base->cia_irq;
-       desc = irq_desc + irq;
-       ints = cia_set_irq_private(base, CIA_ICR_ALL);
-       amiga_custom.intreq = base->int_mask;
-       for (i = 0; i < CIA_IRQS; i++, irq++) {
-               if (ints & 1) {
-                       kstat_cpu(0).irqs[irq]++;
-                       action = desc->action;
-                       action->handler(irq, action->dev_id, fp);
-               }
-               ints >>= 1;
-               desc++;
-       }
-       amiga_do_irq_list(base->server_irq, fp);
-}
-
-void __init cia_init_IRQ(struct ciabase *base)
-{
-       extern struct irqaction amiga_sys_irqaction[AUTO_IRQS];
-       struct irqaction *action;
-
-       /* clear any pending interrupt and turn off all interrupts */
-       cia_set_irq_private(base, CIA_ICR_ALL);
-       cia_able_irq_private(base, CIA_ICR_ALL);
-
-       /* install CIA handler */
-       action = &amiga_sys_irqaction[base->handler_irq-IRQ_AMIGA_AUTO];
-       action->handler = cia_handler;
-       action->dev_id = base;
-       action->name = base->name;
-       setup_irq(base->handler_irq, &amiga_sys_irqaction[base->handler_irq-IRQ_AMIGA_AUTO]);
-
-       amiga_custom.intena = IF_SETCLR | base->int_mask;
-}
diff --git a/arch/ppc/amiga/config.c b/arch/ppc/amiga/config.c
deleted file mode 100644 (file)
index bc50ed1..0000000
+++ /dev/null
@@ -1,953 +0,0 @@
-#define m68k_debug_device debug_device
-
-/*
- *  Copyright (C) 1993 Hamish Macdonald
- *
- * 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.
- */
-
-/*
- * Miscellaneous Amiga stuff
- */
-
-#include <linux/types.h>
-#include <linux/kernel.h>
-#include <linux/mm.h>
-#include <linux/kd.h>
-#include <linux/tty.h>
-#include <linux/console.h>
-#include <linux/init.h>
-#ifdef CONFIG_ZORRO
-#include <linux/zorro.h>
-#endif
-
-#include <asm/bootinfo.h>
-#include <asm/setup.h>
-#include <asm/system.h>
-#include <asm/pgtable.h>
-#include <asm/amigahw.h>
-#include <asm/amigaints.h>
-#include <asm/irq.h>
-#include <asm/machdep.h>
-#include <asm/io.h>
-
-unsigned long powerup_PCI_present;
-unsigned long powerup_BPPCPLUS_present;
-unsigned long amiga_model;
-unsigned long amiga_eclock;
-unsigned long amiga_masterclock;
-unsigned long amiga_colorclock;
-unsigned long amiga_chipset;
-unsigned char amiga_vblank;
-unsigned char amiga_psfreq;
-struct amiga_hw_present amiga_hw_present;
-
-static char s_a500[] __initdata = "A500";
-static char s_a500p[] __initdata = "A500+";
-static char s_a600[] __initdata = "A600";
-static char s_a1000[] __initdata = "A1000";
-static char s_a1200[] __initdata = "A1200";
-static char s_a2000[] __initdata = "A2000";
-static char s_a2500[] __initdata = "A2500";
-static char s_a3000[] __initdata = "A3000";
-static char s_a3000t[] __initdata = "A3000T";
-static char s_a3000p[] __initdata = "A3000+";
-static char s_a4000[] __initdata = "A4000";
-static char s_a4000t[] __initdata = "A4000T";
-static char s_cdtv[] __initdata = "CDTV";
-static char s_cd32[] __initdata = "CD32";
-static char s_draco[] __initdata = "Draco";
-static char *amiga_models[] __initdata = {
-    s_a500, s_a500p, s_a600, s_a1000, s_a1200, s_a2000, s_a2500, s_a3000,
-    s_a3000t, s_a3000p, s_a4000, s_a4000t, s_cdtv, s_cd32, s_draco,
-};
-
-static char amiga_model_name[13] = "Amiga ";
-
-extern char m68k_debug_device[];
-
-static void amiga_sched_init(irqreturn_t (*handler)(int, void *, struct pt_regs *));
-/* amiga specific irq functions */
-extern void amiga_init_IRQ (void);
-extern void (*amiga_default_handler[]) (int, void *, struct pt_regs *);
-extern int amiga_request_irq (unsigned int irq,
-                             void (*handler)(int, void *, struct pt_regs *),
-                              unsigned long flags, const char *devname,
-                             void *dev_id);
-extern void amiga_free_irq (unsigned int irq, void *dev_id);
-extern void amiga_enable_irq (unsigned int);
-extern void amiga_disable_irq (unsigned int);
-static void amiga_get_model(char *model);
-static int amiga_get_hardware_list(char *buffer);
-/* amiga specific timer functions */
-static unsigned long amiga_gettimeoffset (void);
-static void a3000_gettod (int *, int *, int *, int *, int *, int *);
-static void a2000_gettod (int *, int *, int *, int *, int *, int *);
-static int amiga_hwclk (int, struct hwclk_time *);
-static int amiga_set_clock_mmss (unsigned long);
-static void amiga_reset (void);
-extern void amiga_init_sound(void);
-static void amiga_savekmsg_init(void);
-static void amiga_mem_console_write(struct console *co, const char *b,
-                                   unsigned int count);
-void amiga_serial_console_write(struct console *co, const char *s,
-                               unsigned int count);
-static void amiga_debug_init(void);
-#ifdef CONFIG_HEARTBEAT
-static void amiga_heartbeat(int on);
-#endif
-
-static struct console amiga_console_driver = {
-       .name =         "debug",
-       .flags =        CON_PRINTBUFFER,
-       .index =        -1,
-};
-
-
-    /*
-     *  Motherboard Resources present in all Amiga models
-     */
-
-static struct {
-    struct resource _ciab, _ciaa, _custom, _kickstart;
-} mb_resources = {
-//    { "Ranger Memory", 0x00c00000, 0x00c7ffff },
-    ._ciab =     { "CIA B", 0x00bfd000, 0x00bfdfff },
-    ._ciaa =     { "CIA A", 0x00bfe000, 0x00bfefff },
-    ._custom =   { "Custom I/O", 0x00dff000, 0x00dfffff },
-    ._kickstart = { "Kickstart ROM", 0x00f80000, 0x00ffffff }
-};
-
-static struct resource rtc_resource = {
-    NULL, 0x00dc0000, 0x00dcffff
-};
-
-static struct resource ram_resource[NUM_MEMINFO];
-
-
-    /*
-     *  Parse an Amiga-specific record in the bootinfo
-     */
-
-int amiga_parse_bootinfo(const struct bi_record *record)
-{
-    int unknown = 0;
-    const unsigned long *data = record->data;
-
-    switch (record->tag) {
-       case BI_AMIGA_MODEL:
-       {
-               unsigned long d = *data;
-
-               powerup_PCI_present = d & 0x100;
-               amiga_model = d & 0xff;
-       }
-       break;
-
-       case BI_AMIGA_ECLOCK:
-           amiga_eclock = *data;
-           break;
-
-       case BI_AMIGA_CHIPSET:
-           amiga_chipset = *data;
-           break;
-
-       case BI_AMIGA_CHIP_SIZE:
-           amiga_chip_size = *(const int *)data;
-           break;
-
-       case BI_AMIGA_VBLANK:
-           amiga_vblank = *(const unsigned char *)data;
-           break;
-
-       case BI_AMIGA_PSFREQ:
-           amiga_psfreq = *(const unsigned char *)data;
-           break;
-
-       case BI_AMIGA_AUTOCON:
-#ifdef CONFIG_ZORRO
-           if (zorro_num_autocon < ZORRO_NUM_AUTO) {
-               const struct ConfigDev *cd = (struct ConfigDev *)data;
-               struct zorro_dev *dev = &zorro_autocon[zorro_num_autocon++];
-               dev->rom = cd->cd_Rom;
-               dev->slotaddr = cd->cd_SlotAddr;
-               dev->slotsize = cd->cd_SlotSize;
-               dev->resource.start = (unsigned long)cd->cd_BoardAddr;
-               dev->resource.end = dev->resource.start+cd->cd_BoardSize-1;
-           } else
-               printk("amiga_parse_bootinfo: too many AutoConfig devices\n");
-#endif /* CONFIG_ZORRO */
-           break;
-
-       case BI_AMIGA_SERPER:
-           /* serial port period: ignored here */
-           break;
-
-       case BI_AMIGA_PUP_BRIDGE:
-           powerup_PCI_present = *(const unsigned short *)data;
-           break;
-
-       case BI_AMIGA_BPPC_SCSI:
-           powerup_BPPCPLUS_present = *(const unsigned short *)data;
-           break;
-
-       default:
-           unknown = 1;
-    }
-    return(unknown);
-}
-
-    /*
-     *  Identify builtin hardware
-     */
-
-static void __init amiga_identify(void)
-{
-  /* Fill in some default values, if necessary */
-  if (amiga_eclock == 0)
-    amiga_eclock = 709379;
-
-  memset(&amiga_hw_present, 0, sizeof(amiga_hw_present));
-
-  printk("Amiga hardware found: ");
-  if (amiga_model >= AMI_500 && amiga_model <= AMI_DRACO) {
-    printk("[%s] ", amiga_models[amiga_model-AMI_500]);
-    strcat(amiga_model_name, amiga_models[amiga_model-AMI_500]);
-  }
-
-  switch(amiga_model) {
-  case AMI_UNKNOWN:
-    goto Generic;
-
-  case AMI_600:
-  case AMI_1200:
-    AMIGAHW_SET(A1200_IDE);
-    AMIGAHW_SET(PCMCIA);
-  case AMI_500:
-  case AMI_500PLUS:
-  case AMI_1000:
-  case AMI_2000:
-  case AMI_2500:
-    AMIGAHW_SET(A2000_CLK);    /* Is this correct for all models? */
-    goto Generic;
-
-  case AMI_3000:
-  case AMI_3000T:
-    AMIGAHW_SET(AMBER_FF);
-    AMIGAHW_SET(MAGIC_REKICK);
-    /* fall through */
-  case AMI_3000PLUS:
-    AMIGAHW_SET(A3000_SCSI);
-    AMIGAHW_SET(A3000_CLK);
-    AMIGAHW_SET(ZORRO3);
-    goto Generic;
-
-  case AMI_4000T:
-    AMIGAHW_SET(A4000_SCSI);
-    /* fall through */
-  case AMI_4000:
-    AMIGAHW_SET(A4000_IDE);
-    AMIGAHW_SET(A3000_CLK);
-    AMIGAHW_SET(ZORRO3);
-    goto Generic;
-
-  case AMI_CDTV:
-  case AMI_CD32:
-    AMIGAHW_SET(CD_ROM);
-    AMIGAHW_SET(A2000_CLK);             /* Is this correct? */
-    goto Generic;
-
-  Generic:
-    AMIGAHW_SET(AMI_VIDEO);
-    AMIGAHW_SET(AMI_BLITTER);
-    AMIGAHW_SET(AMI_AUDIO);
-    AMIGAHW_SET(AMI_FLOPPY);
-    AMIGAHW_SET(AMI_KEYBOARD);
-    AMIGAHW_SET(AMI_MOUSE);
-    AMIGAHW_SET(AMI_SERIAL);
-    AMIGAHW_SET(AMI_PARALLEL);
-    AMIGAHW_SET(CHIP_RAM);
-    AMIGAHW_SET(PAULA);
-
-    switch(amiga_chipset) {
-    case CS_OCS:
-    case CS_ECS:
-    case CS_AGA:
-      switch (amiga_custom.deniseid & 0xf) {
-      case 0x0c:
-       AMIGAHW_SET(DENISE_HR);
-       break;
-      case 0x08:
-       AMIGAHW_SET(LISA);
-       break;
-      }
-      break;
-    default:
-      AMIGAHW_SET(DENISE);
-      break;
-    }
-    switch ((amiga_custom.vposr>>8) & 0x7f) {
-    case 0x00:
-      AMIGAHW_SET(AGNUS_PAL);
-      break;
-    case 0x10:
-      AMIGAHW_SET(AGNUS_NTSC);
-      break;
-    case 0x20:
-    case 0x21:
-      AMIGAHW_SET(AGNUS_HR_PAL);
-      break;
-    case 0x30:
-    case 0x31:
-      AMIGAHW_SET(AGNUS_HR_NTSC);
-      break;
-    case 0x22:
-    case 0x23:
-      AMIGAHW_SET(ALICE_PAL);
-      break;
-    case 0x32:
-    case 0x33:
-      AMIGAHW_SET(ALICE_NTSC);
-      break;
-    }
-    AMIGAHW_SET(ZORRO);
-    break;
-
-  case AMI_DRACO:
-    panic("No support for Draco yet");
-
-  default:
-    panic("Unknown Amiga Model");
-  }
-
-#define AMIGAHW_ANNOUNCE(name, str)                    \
-  if (AMIGAHW_PRESENT(name))                           \
-    printk(str)
-
-  AMIGAHW_ANNOUNCE(AMI_VIDEO, "VIDEO ");
-  AMIGAHW_ANNOUNCE(AMI_BLITTER, "BLITTER ");
-  AMIGAHW_ANNOUNCE(AMBER_FF, "AMBER_FF ");
-  AMIGAHW_ANNOUNCE(AMI_AUDIO, "AUDIO ");
-  AMIGAHW_ANNOUNCE(AMI_FLOPPY, "FLOPPY ");
-  AMIGAHW_ANNOUNCE(A3000_SCSI, "A3000_SCSI ");
-  AMIGAHW_ANNOUNCE(A4000_SCSI, "A4000_SCSI ");
-  AMIGAHW_ANNOUNCE(A1200_IDE, "A1200_IDE ");
-  AMIGAHW_ANNOUNCE(A4000_IDE, "A4000_IDE ");
-  AMIGAHW_ANNOUNCE(CD_ROM, "CD_ROM ");
-  AMIGAHW_ANNOUNCE(AMI_KEYBOARD, "KEYBOARD ");
-  AMIGAHW_ANNOUNCE(AMI_MOUSE, "MOUSE ");
-  AMIGAHW_ANNOUNCE(AMI_SERIAL, "SERIAL ");
-  AMIGAHW_ANNOUNCE(AMI_PARALLEL, "PARALLEL ");
-  AMIGAHW_ANNOUNCE(A2000_CLK, "A2000_CLK ");
-  AMIGAHW_ANNOUNCE(A3000_CLK, "A3000_CLK ");
-  AMIGAHW_ANNOUNCE(CHIP_RAM, "CHIP_RAM ");
-  AMIGAHW_ANNOUNCE(PAULA, "PAULA ");
-  AMIGAHW_ANNOUNCE(DENISE, "DENISE ");
-  AMIGAHW_ANNOUNCE(DENISE_HR, "DENISE_HR ");
-  AMIGAHW_ANNOUNCE(LISA, "LISA ");
-  AMIGAHW_ANNOUNCE(AGNUS_PAL, "AGNUS_PAL ");
-  AMIGAHW_ANNOUNCE(AGNUS_NTSC, "AGNUS_NTSC ");
-  AMIGAHW_ANNOUNCE(AGNUS_HR_PAL, "AGNUS_HR_PAL ");
-  AMIGAHW_ANNOUNCE(AGNUS_HR_NTSC, "AGNUS_HR_NTSC ");
-  AMIGAHW_ANNOUNCE(ALICE_PAL, "ALICE_PAL ");
-  AMIGAHW_ANNOUNCE(ALICE_NTSC, "ALICE_NTSC ");
-  AMIGAHW_ANNOUNCE(MAGIC_REKICK, "MAGIC_REKICK ");
-  AMIGAHW_ANNOUNCE(PCMCIA, "PCMCIA ");
-  if (AMIGAHW_PRESENT(ZORRO))
-    printk("ZORRO%s ", AMIGAHW_PRESENT(ZORRO3) ? "3" : "");
-  printk("\n");
-
-#undef AMIGAHW_ANNOUNCE
-}
-
-    /*
-     *  Setup the Amiga configuration info
-     */
-
-void __init config_amiga(void)
-{
-  int i;
-
-  amiga_debug_init();
-  amiga_identify();
-
-  /* Some APUS boxes may have PCI memory, but ... */
-  iomem_resource.name = "Memory";
-  for (i = 0; i < 4; i++)
-    request_resource(&iomem_resource, &((struct resource *)&mb_resources)[i]);
-
-  mach_sched_init      = amiga_sched_init;
-  mach_init_IRQ        = amiga_init_IRQ;
-#ifndef CONFIG_APUS
-  mach_default_handler = &amiga_default_handler;
-  mach_request_irq     = amiga_request_irq;
-  mach_free_irq        = amiga_free_irq;
-  enable_irq           = amiga_enable_irq;
-  disable_irq          = amiga_disable_irq;
-#endif
-  mach_get_model       = amiga_get_model;
-  mach_get_hardware_list = amiga_get_hardware_list;
-  mach_gettimeoffset   = amiga_gettimeoffset;
-  if (AMIGAHW_PRESENT(A3000_CLK)){
-    mach_gettod  = a3000_gettod;
-    rtc_resource.name = "A3000 RTC";
-    request_resource(&iomem_resource, &rtc_resource);
-  }
-  else{ /* if (AMIGAHW_PRESENT(A2000_CLK)) */
-    mach_gettod  = a2000_gettod;
-    rtc_resource.name = "A2000 RTC";
-    request_resource(&iomem_resource, &rtc_resource);
-  }
-
-  mach_max_dma_address = 0xffffffff; /*
-                                     * default MAX_DMA=0xffffffff
-                                     * on all machines. If we don't
-                                     * do so, the SCSI code will not
-                                     * be able to allocate any mem
-                                     * for transfers, unless we are
-                                     * dealing with a Z2 mem only
-                                     * system.                  /Jes
-                                     */
-
-  mach_hwclk           = amiga_hwclk;
-  mach_set_clock_mmss  = amiga_set_clock_mmss;
-  mach_reset           = amiga_reset;
-#ifdef CONFIG_HEARTBEAT
-  mach_heartbeat = amiga_heartbeat;
-#endif
-
-  /* Fill in the clock values (based on the 700 kHz E-Clock) */
-  amiga_masterclock = 40*amiga_eclock; /* 28 MHz */
-  amiga_colorclock = 5*amiga_eclock;   /* 3.5 MHz */
-
-  /* clear all DMA bits */
-  amiga_custom.dmacon = DMAF_ALL;
-  /* ensure that the DMA master bit is set */
-  amiga_custom.dmacon = DMAF_SETCLR | DMAF_MASTER;
-
-  /* request all RAM */
-  for (i = 0; i < m68k_num_memory; i++) {
-    ram_resource[i].name =
-      (m68k_memory[i].addr >= 0x01000000) ? "32-bit Fast RAM" :
-      (m68k_memory[i].addr < 0x00c00000) ? "16-bit Fast RAM" :
-      "16-bit Slow RAM";
-    ram_resource[i].start = m68k_memory[i].addr;
-    ram_resource[i].end = m68k_memory[i].addr+m68k_memory[i].size-1;
-    request_resource(&iomem_resource, &ram_resource[i]);
-  }
-
-  /* initialize chipram allocator */
-  amiga_chip_init ();
-
-  /* debugging using chipram */
-  if (!strcmp( m68k_debug_device, "mem" )){
-         if (!AMIGAHW_PRESENT(CHIP_RAM))
-                 printk("Warning: no chipram present for debugging\n");
-         else {
-                 amiga_savekmsg_init();
-                 amiga_console_driver.write = amiga_mem_console_write;
-                 register_console(&amiga_console_driver);
-         }
-  }
-
-  /* our beloved beeper */
-  if (AMIGAHW_PRESENT(AMI_AUDIO))
-         amiga_init_sound();
-
-  /*
-   * if it is an A3000, set the magic bit that forces
-   * a hard rekick
-   */
-  if (AMIGAHW_PRESENT(MAGIC_REKICK))
-         *(unsigned char *)ZTWO_VADDR(0xde0002) |= 0x80;
-}
-
-static unsigned short jiffy_ticks;
-
-static void __init amiga_sched_init(irqreturn_t (*timer_routine)(int, void *,
-                                               struct pt_regs *))
-{
-       static struct resource sched_res = {
-           "timer", 0x00bfd400, 0x00bfd5ff,
-       };
-       jiffy_ticks = (amiga_eclock+HZ/2)/HZ;
-
-       if (request_resource(&mb_resources._ciab, &sched_res))
-           printk("Cannot allocate ciab.ta{lo,hi}\n");
-       ciab.cra &= 0xC0;   /* turn off timer A, continuous mode, from Eclk */
-       ciab.talo = jiffy_ticks % 256;
-       ciab.tahi = jiffy_ticks / 256;
-
-       /* install interrupt service routine for CIAB Timer A
-        *
-        * Please don't change this to use ciaa, as it interferes with the
-        * SCSI code. We'll have to take a look at this later
-        */
-       request_irq(IRQ_AMIGA_CIAB_TA, timer_routine, 0, "timer", NULL);
-       /* start timer */
-       ciab.cra |= 0x11;
-}
-
-#define TICK_SIZE 10000
-
-extern unsigned char cia_get_irq_mask(unsigned int irq);
-
-/* This is always executed with interrupts disabled.  */
-static unsigned long amiga_gettimeoffset (void)
-{
-       unsigned short hi, lo, hi2;
-       unsigned long ticks, offset = 0;
-
-       /* read CIA B timer A current value */
-       hi  = ciab.tahi;
-       lo  = ciab.talo;
-       hi2 = ciab.tahi;
-
-       if (hi != hi2) {
-               lo = ciab.talo;
-               hi = hi2;
-       }
-
-       ticks = hi << 8 | lo;
-
-       if (ticks > jiffy_ticks / 2)
-               /* check for pending interrupt */
-               if (cia_get_irq_mask(IRQ_AMIGA_CIAB) & CIA_ICR_TA)
-                       offset = 10000;
-
-       ticks = jiffy_ticks - ticks;
-       ticks = (10000 * ticks) / jiffy_ticks;
-
-       return ticks + offset;
-}
-
-static void a3000_gettod (int *yearp, int *monp, int *dayp,
-                         int *hourp, int *minp, int *secp)
-{
-       volatile struct tod3000 *tod = TOD_3000;
-
-       tod->cntrl1 = TOD3000_CNTRL1_HOLD;
-
-       *secp  = tod->second1 * 10 + tod->second2;
-       *minp  = tod->minute1 * 10 + tod->minute2;
-       *hourp = tod->hour1   * 10 + tod->hour2;
-       *dayp  = tod->day1    * 10 + tod->day2;
-       *monp  = tod->month1  * 10 + tod->month2;
-       *yearp = tod->year1   * 10 + tod->year2;
-
-       tod->cntrl1 = TOD3000_CNTRL1_FREE;
-}
-
-static void a2000_gettod (int *yearp, int *monp, int *dayp,
-                         int *hourp, int *minp, int *secp)
-{
-       volatile struct tod2000 *tod = TOD_2000;
-
-       tod->cntrl1 = TOD2000_CNTRL1_HOLD;
-
-       while (tod->cntrl1 & TOD2000_CNTRL1_BUSY)
-               ;
-
-       *secp  = tod->second1     * 10 + tod->second2;
-       *minp  = tod->minute1     * 10 + tod->minute2;
-       *hourp = (tod->hour1 & 3) * 10 + tod->hour2;
-       *dayp  = tod->day1        * 10 + tod->day2;
-       *monp  = tod->month1      * 10 + tod->month2;
-       *yearp = tod->year1       * 10 + tod->year2;
-
-       if (!(tod->cntrl3 & TOD2000_CNTRL3_24HMODE)){
-               if (!(tod->hour1 & TOD2000_HOUR1_PM) && *hourp == 12)
-                       *hourp = 0;
-               else if ((tod->hour1 & TOD2000_HOUR1_PM) && *hourp != 12)
-                       *hourp += 12;
-       }
-
-       tod->cntrl1 &= ~TOD2000_CNTRL1_HOLD;
-}
-
-static int amiga_hwclk(int op, struct hwclk_time *t)
-{
-       if (AMIGAHW_PRESENT(A3000_CLK)) {
-               volatile struct tod3000 *tod = TOD_3000;
-
-               tod->cntrl1 = TOD3000_CNTRL1_HOLD;
-
-               if (!op) { /* read */
-                       t->sec  = tod->second1 * 10 + tod->second2;
-                       t->min  = tod->minute1 * 10 + tod->minute2;
-                       t->hour = tod->hour1   * 10 + tod->hour2;
-                       t->day  = tod->day1    * 10 + tod->day2;
-                       t->wday = tod->weekday;
-                       t->mon  = tod->month1  * 10 + tod->month2 - 1;
-                       t->year = tod->year1   * 10 + tod->year2;
-                       if (t->year <= 69)
-                               t->year += 100;
-               } else {
-                       tod->second1 = t->sec / 10;
-                       tod->second2 = t->sec % 10;
-                       tod->minute1 = t->min / 10;
-                       tod->minute2 = t->min % 10;
-                       tod->hour1   = t->hour / 10;
-                       tod->hour2   = t->hour % 10;
-                       tod->day1    = t->day / 10;
-                       tod->day2    = t->day % 10;
-                       if (t->wday != -1)
-                               tod->weekday = t->wday;
-                       tod->month1  = (t->mon + 1) / 10;
-                       tod->month2  = (t->mon + 1) % 10;
-                       if (t->year >= 100)
-                               t->year -= 100;
-                       tod->year1   = t->year / 10;
-                       tod->year2   = t->year % 10;
-               }
-
-               tod->cntrl1 = TOD3000_CNTRL1_FREE;
-       } else /* if (AMIGAHW_PRESENT(A2000_CLK)) */ {
-               volatile struct tod2000 *tod = TOD_2000;
-
-               tod->cntrl1 = TOD2000_CNTRL1_HOLD;
-       
-               while (tod->cntrl1 & TOD2000_CNTRL1_BUSY)
-                       ;
-
-               if (!op) { /* read */
-                       t->sec  = tod->second1     * 10 + tod->second2;
-                       t->min  = tod->minute1     * 10 + tod->minute2;
-                       t->hour = (tod->hour1 & 3) * 10 + tod->hour2;
-                       t->day  = tod->day1        * 10 + tod->day2;
-                       t->wday = tod->weekday;
-                       t->mon  = tod->month1      * 10 + tod->month2 - 1;
-                       t->year = tod->year1       * 10 + tod->year2;
-                       if (t->year <= 69)
-                               t->year += 100;
-
-                       if (!(tod->cntrl3 & TOD2000_CNTRL3_24HMODE)){
-                               if (!(tod->hour1 & TOD2000_HOUR1_PM) && t->hour == 12)
-                                       t->hour = 0;
-                               else if ((tod->hour1 & TOD2000_HOUR1_PM) && t->hour != 12)
-                                       t->hour += 12;
-                       }
-               } else {
-                       tod->second1 = t->sec / 10;
-                       tod->second2 = t->sec % 10;
-                       tod->minute1 = t->min / 10;
-                       tod->minute2 = t->min % 10;
-                       if (tod->cntrl3 & TOD2000_CNTRL3_24HMODE)
-                               tod->hour1 = t->hour / 10;
-                       else if (t->hour >= 12)
-                               tod->hour1 = TOD2000_HOUR1_PM +
-                                       (t->hour - 12) / 10;
-                       else
-                               tod->hour1 = t->hour / 10;
-                       tod->hour2   = t->hour % 10;
-                       tod->day1    = t->day / 10;
-                       tod->day2    = t->day % 10;
-                       if (t->wday != -1)
-                               tod->weekday = t->wday;
-                       tod->month1  = (t->mon + 1) / 10;
-                       tod->month2  = (t->mon + 1) % 10;
-                       if (t->year >= 100)
-                               t->year -= 100;
-                       tod->year1   = t->year / 10;
-                       tod->year2   = t->year % 10;
-               }
-
-               tod->cntrl1 &= ~TOD2000_CNTRL1_HOLD;
-       }
-
-       return 0;
-}
-
-static int amiga_set_clock_mmss (unsigned long nowtime)
-{
-       short real_seconds = nowtime % 60, real_minutes = (nowtime / 60) % 60;
-
-       if (AMIGAHW_PRESENT(A3000_CLK)) {
-               volatile struct tod3000 *tod = TOD_3000;
-
-               tod->cntrl1 = TOD3000_CNTRL1_HOLD;
-
-               tod->second1 = real_seconds / 10;
-               tod->second2 = real_seconds % 10;
-               tod->minute1 = real_minutes / 10;
-               tod->minute2 = real_minutes % 10;
-
-               tod->cntrl1 = TOD3000_CNTRL1_FREE;
-       } else /* if (AMIGAHW_PRESENT(A2000_CLK)) */ {
-               volatile struct tod2000 *tod = TOD_2000;
-
-               tod->cntrl1 = TOD2000_CNTRL1_HOLD;
-       
-               while (tod->cntrl1 & TOD2000_CNTRL1_BUSY)
-                       ;
-
-               tod->second1 = real_seconds / 10;
-               tod->second2 = real_seconds % 10;
-               tod->minute1 = real_minutes / 10;
-               tod->minute2 = real_minutes % 10;
-
-               tod->cntrl1 &= ~TOD2000_CNTRL1_HOLD;
-       }
-
-       return 0;
-}
-
-static NORET_TYPE void amiga_reset( void )
-    ATTRIB_NORET;
-
-static void amiga_reset (void)
-{
-  for (;;);
-}
-
-
-    /*
-     *  Debugging
-     */
-
-#define SAVEKMSG_MAXMEM                128*1024
-
-#define SAVEKMSG_MAGIC1                0x53415645      /* 'SAVE' */
-#define SAVEKMSG_MAGIC2                0x4B4D5347      /* 'KMSG' */
-
-struct savekmsg {
-    unsigned long magic1;              /* SAVEKMSG_MAGIC1 */
-    unsigned long magic2;              /* SAVEKMSG_MAGIC2 */
-    unsigned long magicptr;            /* address of magic1 */
-    unsigned long size;
-    char data[0];
-};
-
-static struct savekmsg *savekmsg = NULL;
-
-static void amiga_mem_console_write(struct console *co, const char *s,
-                                   unsigned int count)
-{
-    if (savekmsg->size+count <= SAVEKMSG_MAXMEM-sizeof(struct savekmsg)) {
-        memcpy(savekmsg->data+savekmsg->size, s, count);
-        savekmsg->size += count;
-    }
-}
-
-static void amiga_savekmsg_init(void)
-{
-    static struct resource debug_res = { "Debug" };
-
-    savekmsg = amiga_chip_alloc_res(SAVEKMSG_MAXMEM, &debug_res);
-    savekmsg->magic1 = SAVEKMSG_MAGIC1;
-    savekmsg->magic2 = SAVEKMSG_MAGIC2;
-    savekmsg->magicptr = virt_to_phys(savekmsg);
-    savekmsg->size = 0;
-}
-
-static void amiga_serial_putc(char c)
-{
-    amiga_custom.serdat = (unsigned char)c | 0x100;
-    mb();
-    while (!(amiga_custom.serdatr & 0x2000))
-       ;
-}
-
-void amiga_serial_console_write(struct console *co, const char *s,
-                                      unsigned int count)
-{
-#if 0 /* def CONFIG_KGDB */
-       /* FIXME:APUS GDB doesn't seem to like O-packages before it is
-           properly connected with the target. */
-       __gdb_output_string (s, count);
-#else
-       while (count--) {
-               if (*s == '\n')
-                       amiga_serial_putc('\r');
-               amiga_serial_putc(*s++);
-       }
-#endif
-}
-
-#ifdef CONFIG_SERIAL_CONSOLE
-void amiga_serial_puts(const char *s)
-{
-    amiga_serial_console_write(NULL, s, strlen(s));
-}
-
-int amiga_serial_console_wait_key(struct console *co)
-{
-    int ch;
-
-    while (!(amiga_custom.intreqr & IF_RBF))
-       barrier();
-    ch = amiga_custom.serdatr & 0xff;
-    /* clear the interrupt, so that another character can be read */
-    amiga_custom.intreq = IF_RBF;
-    return ch;
-}
-
-void amiga_serial_gets(struct console *co, char *s, int len)
-{
-    int ch, cnt = 0;
-
-    while (1) {
-       ch = amiga_serial_console_wait_key(co);
-
-       /* Check for backspace. */
-       if (ch == 8 || ch == 127) {
-           if (cnt == 0) {
-               amiga_serial_putc('\007');
-               continue;
-           }
-           cnt--;
-           amiga_serial_puts("\010 \010");
-           continue;
-       }
-
-       /* Check for enter. */
-       if (ch == 10 || ch == 13)
-           break;
-
-       /* See if line is too long. */
-       if (cnt >= len + 1) {
-           amiga_serial_putc(7);
-           cnt--;
-           continue;
-       }
-
-       /* Store and echo character. */
-       s[cnt++] = ch;
-       amiga_serial_putc(ch);
-    }
-    /* Print enter. */
-    amiga_serial_puts("\r\n");
-    s[cnt] = 0;
-}
-#endif
-
-static void __init amiga_debug_init(void)
-{
-       if (!strcmp( m68k_debug_device, "ser" )) {
-               /* no initialization required (?) */
-               amiga_console_driver.write = amiga_serial_console_write;
-               register_console(&amiga_console_driver);
-       }
-}
-
-#ifdef CONFIG_HEARTBEAT
-static void amiga_heartbeat(int on)
-{
-    if (on)
-       ciaa.pra &= ~2;
-    else
-       ciaa.pra |= 2;
-}
-#endif
-
-    /*
-     *  Amiga specific parts of /proc
-     */
-
-static void amiga_get_model(char *model)
-{
-    strcpy(model, amiga_model_name);
-}
-
-
-static int amiga_get_hardware_list(char *buffer)
-{
-    int len = 0;
-
-    if (AMIGAHW_PRESENT(CHIP_RAM))
-       len += sprintf(buffer+len, "Chip RAM:\t%ldK\n", amiga_chip_size>>10);
-    len += sprintf(buffer+len, "PS Freq:\t%dHz\nEClock Freq:\t%ldHz\n",
-                  amiga_psfreq, amiga_eclock);
-    if (AMIGAHW_PRESENT(AMI_VIDEO)) {
-       char *type;
-       switch(amiga_chipset) {
-           case CS_OCS:
-               type = "OCS";
-               break;
-           case CS_ECS:
-               type = "ECS";
-               break;
-           case CS_AGA:
-               type = "AGA";
-               break;
-           default:
-               type = "Old or Unknown";
-               break;
-       }
-       len += sprintf(buffer+len, "Graphics:\t%s\n", type);
-    }
-
-#define AMIGAHW_ANNOUNCE(name, str)                    \
-    if (AMIGAHW_PRESENT(name))                         \
-       len += sprintf (buffer+len, "\t%s\n", str)
-
-    len += sprintf (buffer + len, "Detected hardware:\n");
-
-    AMIGAHW_ANNOUNCE(AMI_VIDEO, "Amiga Video");
-    AMIGAHW_ANNOUNCE(AMI_BLITTER, "Blitter");
-    AMIGAHW_ANNOUNCE(AMBER_FF, "Amber Flicker Fixer");
-    AMIGAHW_ANNOUNCE(AMI_AUDIO, "Amiga Audio");
-    AMIGAHW_ANNOUNCE(AMI_FLOPPY, "Floppy Controller");
-    AMIGAHW_ANNOUNCE(A3000_SCSI, "SCSI Controller WD33C93 (A3000 style)");
-    AMIGAHW_ANNOUNCE(A4000_SCSI, "SCSI Controller NCR53C710 (A4000T style)");
-    AMIGAHW_ANNOUNCE(A1200_IDE, "IDE Interface (A1200 style)");
-    AMIGAHW_ANNOUNCE(A4000_IDE, "IDE Interface (A4000 style)");
-    AMIGAHW_ANNOUNCE(CD_ROM, "Internal CD ROM drive");
-    AMIGAHW_ANNOUNCE(AMI_KEYBOARD, "Keyboard");
-    AMIGAHW_ANNOUNCE(AMI_MOUSE, "Mouse Port");
-    AMIGAHW_ANNOUNCE(AMI_SERIAL, "Serial Port");
-    AMIGAHW_ANNOUNCE(AMI_PARALLEL, "Parallel Port");
-    AMIGAHW_ANNOUNCE(A2000_CLK, "Hardware Clock (A2000 style)");
-    AMIGAHW_ANNOUNCE(A3000_CLK, "Hardware Clock (A3000 style)");
-    AMIGAHW_ANNOUNCE(CHIP_RAM, "Chip RAM");
-    AMIGAHW_ANNOUNCE(PAULA, "Paula 8364");
-    AMIGAHW_ANNOUNCE(DENISE, "Denise 8362");
-    AMIGAHW_ANNOUNCE(DENISE_HR, "Denise 8373");
-    AMIGAHW_ANNOUNCE(LISA, "Lisa 8375");
-    AMIGAHW_ANNOUNCE(AGNUS_PAL, "Normal/Fat PAL Agnus 8367/8371");
-    AMIGAHW_ANNOUNCE(AGNUS_NTSC, "Normal/Fat NTSC Agnus 8361/8370");
-    AMIGAHW_ANNOUNCE(AGNUS_HR_PAL, "Fat Hires PAL Agnus 8372");
-    AMIGAHW_ANNOUNCE(AGNUS_HR_NTSC, "Fat Hires NTSC Agnus 8372");
-    AMIGAHW_ANNOUNCE(ALICE_PAL, "PAL Alice 8374");
-    AMIGAHW_ANNOUNCE(ALICE_NTSC, "NTSC Alice 8374");
-    AMIGAHW_ANNOUNCE(MAGIC_REKICK, "Magic Hard Rekick");
-    AMIGAHW_ANNOUNCE(PCMCIA, "PCMCIA Slot");
-    if (AMIGAHW_PRESENT(ZORRO))
-       len += sprintf(buffer+len, "\tZorro II%s AutoConfig: %d Expansion "
-                                  "Device%s\n",
-                      AMIGAHW_PRESENT(ZORRO3) ? "I" : "",
-                      zorro_num_autocon, zorro_num_autocon == 1 ? "" : "s");
-
-#undef AMIGAHW_ANNOUNCE
-
-    return(len);
-}
-
-#ifdef CONFIG_APUS
-int get_hardware_list(char *buffer)
-{
-       extern int get_cpuinfo(char *buffer);
-       int len = 0;
-       char model[80];
-       u_long mem;
-       int i;
-
-       if (mach_get_model)
-               mach_get_model(model);
-       else
-               strcpy(model, "Unknown PowerPC");
-
-       len += sprintf(buffer+len, "Model:\t\t%s\n", model);
-       len += get_cpuinfo(buffer+len);
-       for (mem = 0, i = 0; i < m68k_realnum_memory; i++)
-               mem += m68k_memory[i].size;
-       len += sprintf(buffer+len, "System Memory:\t%ldK\n", mem>>10);
-
-       if (mach_get_hardware_list)
-               len += mach_get_hardware_list(buffer+len);
-
-       return(len);
-}
-#endif
diff --git a/arch/ppc/amiga/ints.c b/arch/ppc/amiga/ints.c
deleted file mode 100644 (file)
index 083a174..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- *  Linux/m68k general interrupt handling code from arch/m68k/kernel/ints.c
- *  Needed to drive the m68k emulating IRQ hardware on the PowerUp boards.
- */
-
-#include <linux/types.h>
-#include <linux/sched.h>
-#include <linux/kernel_stat.h>
-#include <linux/errno.h>
-#include <linux/init.h>
-#include <linux/seq_file.h>
-
-#include <asm/setup.h>
-#include <asm/system.h>
-#include <asm/irq.h>
-#include <asm/traps.h>
-#include <asm/page.h>
-#include <asm/machdep.h>
-
-/* table for system interrupt handlers */
-static irq_handler_t irq_list[SYS_IRQS];
-
-static const char *default_names[SYS_IRQS] = {
-       "spurious int", "int1 handler", "int2 handler", "int3 handler",
-       "int4 handler", "int5 handler", "int6 handler", "int7 handler"
-};
-
-/* The number of spurious interrupts */
-volatile unsigned int num_spurious;
-
-#define NUM_IRQ_NODES 100
-static irq_node_t nodes[NUM_IRQ_NODES];
-
-
-/*
- * void init_IRQ(void)
- *
- * Parameters: None
- *
- * Returns:    Nothing
- *
- * This function should be called during kernel startup to initialize
- * the IRQ handling routines.
- */
-
-__init
-void m68k_init_IRQ(void)
-{
-       int i;
-
-       for (i = 0; i < SYS_IRQS; i++) {
-               if (mach_default_handler)
-                       irq_list[i].handler = (*mach_default_handler)[i];
-               irq_list[i].flags   = 0;
-               irq_list[i].dev_id  = NULL;
-               irq_list[i].devname = default_names[i];
-       }
-
-       for (i = 0; i < NUM_IRQ_NODES; i++)
-               nodes[i].handler = NULL;
-
-       mach_init_IRQ ();
-}
-
-irq_node_t *new_irq_node(void)
-{
-       irq_node_t *node;
-       short i;
-
-       for (node = nodes, i = NUM_IRQ_NODES-1; i >= 0; node++, i--)
-               if (!node->handler)
-                       return node;
-
-       printk ("new_irq_node: out of nodes\n");
-       return NULL;
-}
-
-int sys_request_irq(unsigned int irq,
-                    void (*handler)(int, void *, struct pt_regs *),
-                    unsigned long flags, const char *devname, void *dev_id)
-{
-       if (irq < IRQ1 || irq > IRQ7) {
-               printk("%s: Incorrect IRQ %d from %s\n",
-                      __FUNCTION__, irq, devname);
-               return -ENXIO;
-       }
-
-#if 0
-       if (!(irq_list[irq].flags & IRQ_FLG_STD)) {
-               if (irq_list[irq].flags & IRQ_FLG_LOCK) {
-                       printk("%s: IRQ %d from %s is not replaceable\n",
-                              __FUNCTION__, irq, irq_list[irq].devname);
-                       return -EBUSY;
-               }
-               if (!(flags & IRQ_FLG_REPLACE)) {
-                       printk("%s: %s can't replace IRQ %d from %s\n",
-                              __FUNCTION__, devname, irq, irq_list[irq].devname);
-                       return -EBUSY;
-               }
-       }
-#endif
-
-       irq_list[irq].handler = handler;
-       irq_list[irq].flags   = flags;
-       irq_list[irq].dev_id  = dev_id;
-       irq_list[irq].devname = devname;
-       return 0;
-}
-
-void sys_free_irq(unsigned int irq, void *dev_id)
-{
-       if (irq < IRQ1 || irq > IRQ7) {
-               printk("%s: Incorrect IRQ %d\n", __FUNCTION__, irq);
-               return;
-       }
-
-       if (irq_list[irq].dev_id != dev_id)
-               printk("%s: Removing probably wrong IRQ %d from %s\n",
-                      __FUNCTION__, irq, irq_list[irq].devname);
-
-       irq_list[irq].handler = (*mach_default_handler)[irq];
-       irq_list[irq].flags   = 0;
-       irq_list[irq].dev_id  = NULL;
-       irq_list[irq].devname = default_names[irq];
-}
-
-asmlinkage void process_int(unsigned long vec, struct pt_regs *fp)
-{
-       if (vec >= VEC_INT1 && vec <= VEC_INT7 && !MACH_IS_BVME6000) {
-               vec -= VEC_SPUR;
-               kstat_cpu(0).irqs[vec]++;
-               irq_list[vec].handler(vec, irq_list[vec].dev_id, fp);
-       } else {
-               if (mach_process_int)
-                       mach_process_int(vec, fp);
-               else
-                       panic("Can't process interrupt vector %ld\n", vec);
-               return;
-       }
-}
-
-int m68k_get_irq_list(struct seq_file *p, void *v)
-{
-       int i;
-
-       /* autovector interrupts */
-       if (mach_default_handler) {
-               for (i = 0; i < SYS_IRQS; i++) {
-                       seq_printf(p, "auto %2d: %10u ", i,
-                                      i ? kstat_cpu(0).irqs[i] : num_spurious);
-                       seq_puts(p, "  ");
-                       seq_printf(p, "%s\n", irq_list[i].devname);
-               }
-       }
-
-       mach_get_irq_list(p, v);
-       return 0;
-}
diff --git a/arch/ppc/amiga/pcmcia.c b/arch/ppc/amiga/pcmcia.c
deleted file mode 100644 (file)
index 5d29dc6..0000000
+++ /dev/null
@@ -1 +0,0 @@
-#include "../../m68k/amiga/pcmcia.c"
diff --git a/arch/ppc/amiga/time.c b/arch/ppc/amiga/time.c
deleted file mode 100644 (file)
index 8c880c0..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-#include <linux/errno.h>
-#include <linux/sched.h>
-#include <linux/kernel.h>
-#include <linux/param.h>
-#include <linux/string.h>
-#include <linux/mm.h>
-
-#include <asm/machdep.h>
-#include <asm/io.h>
-
-#include <linux/timex.h>
-
-unsigned long m68k_get_rtc_time(void)
-{
-       unsigned int year, mon, day, hour, min, sec;
-
-       extern void arch_gettod(int *year, int *mon, int *day, int *hour,
-                               int *min, int *sec);
-
-       arch_gettod (&year, &mon, &day, &hour, &min, &sec);
-
-       if ((year += 1900) < 1970)
-               year += 100;
-
-       return mktime(year, mon, day, hour, min, sec);
-}
-
-int m68k_set_rtc_time(unsigned long nowtime)
-{
-  if (mach_set_clock_mmss)
-    return mach_set_clock_mmss (nowtime);
-  return -1;
-}
-
-void apus_heartbeat (void)
-{
-#ifdef CONFIG_HEARTBEAT
-       static unsigned cnt = 0, period = 0, dist = 0;
-
-       if (cnt == 0 || cnt == dist)
-                mach_heartbeat( 1 );
-       else if (cnt == 7 || cnt == dist+7)
-                mach_heartbeat( 0 );
-
-       if (++cnt > period) {
-                cnt = 0;
-                /* The hyperbolic function below modifies the heartbeat period
-                 * length in dependency of the current (5min) load. It goes
-                 * through the points f(0)=126, f(1)=86, f(5)=51,
-                 * f(inf)->30. */
-                period = ((672<<FSHIFT)/(5*avenrun[0]+(7<<FSHIFT))) + 30;
-                dist = period / 4;
-       }
-#endif
-       /* should be made smarter */
-       ppc_md.heartbeat_count = 1;
-}
diff --git a/arch/ppc/configs/apus_defconfig b/arch/ppc/configs/apus_defconfig
deleted file mode 100644 (file)
index e224525..0000000
+++ /dev/null
@@ -1,920 +0,0 @@
-#
-# Automatically generated make config: don't edit
-#
-CONFIG_MMU=y
-CONFIG_RWSEM_XCHGADD_ALGORITHM=y
-CONFIG_HAVE_DEC_LOCK=y
-
-#
-# Code maturity level options
-#
-CONFIG_EXPERIMENTAL=y
-
-#
-# General setup
-#
-CONFIG_SWAP=y
-CONFIG_SYSVIPC=y
-# CONFIG_BSD_PROCESS_ACCT is not set
-CONFIG_SYSCTL=y
-CONFIG_LOG_BUF_SHIFT=14
-# CONFIG_EMBEDDED is not set
-CONFIG_FUTEX=y
-CONFIG_EPOLL=y
-
-#
-# Loadable module support
-#
-CONFIG_MODULES=y
-CONFIG_MODULE_UNLOAD=y
-CONFIG_MODULE_FORCE_UNLOAD=y
-CONFIG_OBSOLETE_MODPARM=y
-# CONFIG_MODVERSIONS is not set
-CONFIG_KMOD=y
-
-#
-# Platform support
-#
-CONFIG_PPC=y
-CONFIG_PPC32=y
-CONFIG_6xx=y
-# CONFIG_40x is not set
-# CONFIG_POWER3 is not set
-# CONFIG_8xx is not set
-
-#
-# IBM 4xx options
-#
-# CONFIG_8260 is not set
-CONFIG_GENERIC_ISA_DMA=y
-CONFIG_PPC_STD_MMU=y
-CONFIG_SERIAL_CONSOLE=y
-# CONFIG_PPC_MULTIPLATFORM is not set
-CONFIG_APUS=y
-# CONFIG_WILLOW_2 is not set
-# CONFIG_PCORE is not set
-# CONFIG_POWERPMC250 is not set
-# CONFIG_EV64260 is not set
-# CONFIG_SPRUCE is not set
-# CONFIG_LOPEC is not set
-# CONFIG_MCPN765 is not set
-# CONFIG_MVME5100 is not set
-# CONFIG_PPLUS is not set
-# CONFIG_PRPMC750 is not set
-# CONFIG_PRPMC800 is not set
-# CONFIG_SANDPOINT is not set
-# CONFIG_ADIR is not set
-# CONFIG_K2 is not set
-# CONFIG_PAL4 is not set
-# CONFIG_GEMINI is not set
-# CONFIG_SMP is not set
-# CONFIG_PREEMPT is not set
-# CONFIG_ALTIVEC is not set
-# CONFIG_TAU is not set
-# CONFIG_CPU_FREQ is not set
-
-#
-# General setup
-#
-# CONFIG_HIGHMEM is not set
-CONFIG_PCI=y
-CONFIG_PCI_DOMAINS=y
-CONFIG_PCI_PERMEDIA=y
-CONFIG_KCORE_ELF=y
-CONFIG_BINFMT_ELF=y
-CONFIG_KERNEL_ELF=y
-CONFIG_BINFMT_MISC=m
-CONFIG_PCI_LEGACY_PROC=y
-CONFIG_PCI_NAMES=y
-# CONFIG_HOTPLUG is not set
-
-#
-# Parallel port support
-#
-CONFIG_PARPORT=m
-# CONFIG_PARPORT_PC is not set
-CONFIG_PARPORT_AMIGA=m
-# CONFIG_PARPORT_MFC3 is not set
-# CONFIG_PARPORT_OTHER is not set
-# CONFIG_PARPORT_1284 is not set
-CONFIG_PPC601_SYNC_FIX=y
-# CONFIG_CMDLINE_BOOL is not set
-CONFIG_AMIGA=y
-CONFIG_ZORRO=y
-CONFIG_ABSTRACT_CONSOLE=y
-CONFIG_APUS_FAST_EXCEPT=y
-CONFIG_AMIGA_PCMCIA=y
-CONFIG_AMIGA_BUILTIN_SERIAL=y
-CONFIG_GVPIOEXT=y
-CONFIG_GVPIOEXT_LP=m
-CONFIG_GVPIOEXT_PLIP=m
-CONFIG_MULTIFACE_III_TTY=y
-CONFIG_A2232=y
-CONFIG_WHIPPET_SERIAL=y
-CONFIG_APNE=y
-CONFIG_HEARTBEAT=y
-CONFIG_PROC_HARDWARE=y
-CONFIG_ZORRO_NAMES=y
-
-#
-# Advanced setup
-#
-# CONFIG_ADVANCED_OPTIONS is not set
-
-#
-# Default settings for advanced configuration options are used
-#
-CONFIG_HIGHMEM_START=0xfe000000
-CONFIG_LOWMEM_SIZE=0x30000000
-CONFIG_KERNEL_START=0xc0000000
-CONFIG_TASK_SIZE=0x80000000
-CONFIG_BOOT_LOAD=0x00800000
-
-#
-# Memory Technology Devices (MTD)
-#
-# CONFIG_MTD is not set
-
-#
-# Plug and Play support
-#
-# CONFIG_PNP is not set
-
-#
-# Block devices
-#
-# CONFIG_BLK_DEV_FD is not set
-CONFIG_AMIGA_FLOPPY=y
-CONFIG_AMIGA_Z2RAM=m
-# CONFIG_PARIDE is not set
-# CONFIG_BLK_CPQ_DA is not set
-# CONFIG_BLK_CPQ_CISS_DA is not set
-# CONFIG_BLK_DEV_DAC960 is not set
-# CONFIG_BLK_DEV_UMEM is not set
-CONFIG_BLK_DEV_LOOP=y
-CONFIG_BLK_DEV_NBD=m
-CONFIG_BLK_DEV_RAM=y
-CONFIG_BLK_DEV_RAM_SIZE=4096
-CONFIG_BLK_DEV_INITRD=y
-
-#
-# Multi-device support (RAID and LVM)
-#
-CONFIG_MD=y
-CONFIG_BLK_DEV_MD=m
-CONFIG_MD_LINEAR=m
-CONFIG_MD_RAID0=m
-CONFIG_MD_RAID1=m
-CONFIG_MD_RAID5=m
-# CONFIG_MD_MULTIPATH is not set
-CONFIG_BLK_DEV_DM=m
-
-#
-# ATA/IDE/MFM/RLL support
-#
-CONFIG_IDE=y
-
-#
-# IDE, ATA and ATAPI Block devices
-#
-CONFIG_BLK_DEV_IDE=y
-
-#
-# Please see Documentation/ide.txt for help/info on IDE drives
-#
-# CONFIG_BLK_DEV_HD is not set
-CONFIG_BLK_DEV_IDEDISK=y
-# CONFIG_IDEDISK_MULTI_MODE is not set
-# CONFIG_IDEDISK_STROKE is not set
-CONFIG_BLK_DEV_IDECD=y
-CONFIG_BLK_DEV_IDEFLOPPY=y
-CONFIG_BLK_DEV_IDESCSI=m
-# CONFIG_IDE_TASK_IOCTL is not set
-
-#
-# IDE chipset support/bugfixes
-#
-# CONFIG_BLK_DEV_IDEPCI is not set
-CONFIG_BLK_DEV_GAYLE=y
-CONFIG_BLK_DEV_IDEDOUBLER=y
-CONFIG_BLK_DEV_BUDDHA=y
-
-#
-# SCSI support
-#
-CONFIG_SCSI=y
-
-#
-# SCSI support type (disk, tape, CD-ROM)
-#
-CONFIG_BLK_DEV_SD=y
-CONFIG_CHR_DEV_ST=m
-CONFIG_CHR_DEV_OSST=m
-CONFIG_BLK_DEV_SR=y
-CONFIG_BLK_DEV_SR_VENDOR=y
-CONFIG_CHR_DEV_SG=m
-
-#
-# Some SCSI devices (e.g. CD jukebox) support multiple LUNs
-#
-# CONFIG_SCSI_MULTI_LUN is not set
-# CONFIG_SCSI_REPORT_LUNS is not set
-CONFIG_SCSI_CONSTANTS=y
-CONFIG_SCSI_LOGGING=y
-
-#
-# SCSI low-level drivers
-#
-# CONFIG_BLK_DEV_3W_XXXX_RAID is not set
-# CONFIG_SCSI_ACARD is not set
-# CONFIG_SCSI_AACRAID is not set
-# CONFIG_SCSI_AIC7XXX is not set
-# CONFIG_SCSI_AIC7XXX_OLD is not set
-# CONFIG_SCSI_AIC79XX is not set
-# CONFIG_SCSI_DPT_I2O is not set
-# CONFIG_SCSI_ADVANSYS is not set
-# CONFIG_SCSI_IN2000 is not set
-# CONFIG_SCSI_AM53C974 is not set
-# CONFIG_SCSI_MEGARAID is not set
-# CONFIG_SCSI_BUSLOGIC is not set
-# CONFIG_SCSI_CPQFCTS is not set
-# CONFIG_SCSI_DMX3191D is not set
-# CONFIG_SCSI_EATA is not set
-# CONFIG_SCSI_EATA_PIO is not set
-# CONFIG_SCSI_FUTURE_DOMAIN is not set
-# CONFIG_SCSI_GDTH is not set
-# CONFIG_SCSI_GENERIC_NCR5380 is not set
-# CONFIG_SCSI_GENERIC_NCR5380_MMIO is not set
-# CONFIG_SCSI_INITIO is not set
-# CONFIG_SCSI_INIA100 is not set
-# CONFIG_SCSI_PPA is not set
-# CONFIG_SCSI_IMM is not set
-# CONFIG_SCSI_NCR53C7xx is not set
-# CONFIG_SCSI_SYM53C8XX_2 is not set
-# CONFIG_SCSI_NCR53C8XX is not set
-# CONFIG_SCSI_SYM53C8XX is not set
-# CONFIG_SCSI_PCI2000 is not set
-# CONFIG_SCSI_PCI2220I is not set
-# CONFIG_SCSI_QLOGIC_ISP is not set
-# CONFIG_SCSI_QLOGIC_FC is not set
-# CONFIG_SCSI_QLOGIC_1280 is not set
-# CONFIG_SCSI_DC395x is not set
-# CONFIG_SCSI_DC390T is not set
-# CONFIG_SCSI_U14_34F is not set
-# CONFIG_SCSI_NSP32 is not set
-# CONFIG_SCSI_DEBUG is not set
-CONFIG_A3000_SCSI=y
-CONFIG_A4000T_SCSI=y
-CONFIG_A2091_SCSI=y
-CONFIG_GVP11_SCSI=y
-CONFIG_CYBERSTORM_SCSI=y
-CONFIG_CYBERSTORMII_SCSI=y
-CONFIG_BLZ2060_SCSI=y
-CONFIG_BLZ1230_SCSI=y
-CONFIG_FASTLANE_SCSI=y
-CONFIG_A4091_SCSI=y
-CONFIG_WARPENGINE_SCSI=y
-CONFIG_BLZ603EPLUS_SCSI=y
-CONFIG_OKTAGON_SCSI=y
-
-#
-# Fusion MPT device support
-#
-# CONFIG_FUSION is not set
-
-#
-# IEEE 1394 (FireWire) support (EXPERIMENTAL)
-#
-# CONFIG_IEEE1394 is not set
-
-#
-# I2O device support
-#
-# CONFIG_I2O is not set
-
-#
-# Networking support
-#
-CONFIG_NET=y
-
-#
-# Networking options
-#
-CONFIG_PACKET=m
-CONFIG_PACKET_MMAP=y
-CONFIG_NETLINK_DEV=m
-CONFIG_NETFILTER=y
-# CONFIG_NETFILTER_DEBUG is not set
-CONFIG_UNIX=y
-# CONFIG_NET_KEY is not set
-CONFIG_INET=y
-# CONFIG_IP_MULTICAST is not set
-# CONFIG_IP_ADVANCED_ROUTER is not set
-# CONFIG_IP_PNP is not set
-# CONFIG_NET_IPIP is not set
-# CONFIG_NET_IPGRE is not set
-# CONFIG_ARPD is not set
-# CONFIG_INET_ECN is not set
-CONFIG_SYN_COOKIES=y
-# CONFIG_INET_AH is not set
-# CONFIG_INET_ESP is not set
-# CONFIG_INET_IPCOMP is not set
-
-#
-# IP: Netfilter Configuration
-#
-CONFIG_IP_NF_CONNTRACK=m
-CONFIG_IP_NF_FTP=m
-CONFIG_IP_NF_IRC=m
-CONFIG_IP_NF_TFTP=m
-CONFIG_IP_NF_AMANDA=m
-CONFIG_IP_NF_QUEUE=m
-CONFIG_IP_NF_IPTABLES=m
-CONFIG_IP_NF_MATCH_LIMIT=m
-CONFIG_IP_NF_MATCH_MAC=m
-# CONFIG_IP_NF_MATCH_PKTTYPE is not set
-CONFIG_IP_NF_MATCH_MARK=m
-CONFIG_IP_NF_MATCH_MULTIPORT=m
-CONFIG_IP_NF_MATCH_TOS=m
-# CONFIG_IP_NF_MATCH_ECN is not set
-# CONFIG_IP_NF_MATCH_DSCP is not set
-# CONFIG_IP_NF_MATCH_AH_ESP is not set
-CONFIG_IP_NF_MATCH_LENGTH=m
-CONFIG_IP_NF_MATCH_TTL=m
-CONFIG_IP_NF_MATCH_TCPMSS=m
-CONFIG_IP_NF_MATCH_HELPER=m
-CONFIG_IP_NF_MATCH_STATE=m
-CONFIG_IP_NF_MATCH_CONNTRACK=m
-CONFIG_IP_NF_MATCH_UNCLEAN=m
-CONFIG_IP_NF_MATCH_OWNER=m
-CONFIG_IP_NF_FILTER=m
-CONFIG_IP_NF_TARGET_REJECT=m
-CONFIG_IP_NF_TARGET_MIRROR=m
-CONFIG_IP_NF_NAT=m
-CONFIG_IP_NF_NAT_NEEDED=y
-CONFIG_IP_NF_TARGET_MASQUERADE=m
-CONFIG_IP_NF_TARGET_REDIRECT=m
-CONFIG_IP_NF_NAT_SNMP_BASIC=m
-CONFIG_IP_NF_NAT_IRC=m
-CONFIG_IP_NF_NAT_FTP=m
-CONFIG_IP_NF_NAT_TFTP=m
-CONFIG_IP_NF_NAT_AMANDA=m
-CONFIG_IP_NF_MANGLE=m
-CONFIG_IP_NF_TARGET_TOS=m
-CONFIG_IP_NF_TARGET_ECN=m
-CONFIG_IP_NF_TARGET_DSCP=m
-CONFIG_IP_NF_TARGET_MARK=m
-CONFIG_IP_NF_TARGET_LOG=m
-CONFIG_IP_NF_TARGET_ULOG=m
-CONFIG_IP_NF_TARGET_TCPMSS=m
-CONFIG_IP_NF_ARPTABLES=m
-CONFIG_IP_NF_ARPFILTER=m
-CONFIG_IP_NF_COMPAT_IPCHAINS=m
-# CONFIG_IP_NF_COMPAT_IPFWADM is not set
-# CONFIG_IPV6 is not set
-# CONFIG_XFRM_USER is not set
-
-#
-# SCTP Configuration (EXPERIMENTAL)
-#
-CONFIG_IPV6_SCTP__=y
-# CONFIG_IP_SCTP is not set
-# CONFIG_ATM is not set
-# CONFIG_VLAN_8021Q is not set
-# CONFIG_LLC is not set
-# CONFIG_DECNET is not set
-# CONFIG_BRIDGE is not set
-# CONFIG_X25 is not set
-# CONFIG_LAPB is not set
-# CONFIG_NET_DIVERT is not set
-# CONFIG_ECONET is not set
-# CONFIG_WAN_ROUTER is not set
-# CONFIG_NET_HW_FLOWCONTROL is not set
-
-#
-# QoS and/or fair queueing
-#
-# CONFIG_NET_SCHED is not set
-
-#
-# Network testing
-#
-# CONFIG_NET_PKTGEN is not set
-CONFIG_NETDEVICES=y
-
-#
-# ARCnet devices
-#
-# CONFIG_ARCNET is not set
-CONFIG_DUMMY=m
-# CONFIG_BONDING is not set
-# CONFIG_EQUALIZER is not set
-CONFIG_TUN=m
-# CONFIG_ETHERTAP is not set
-
-#
-# Ethernet (10 or 100Mbit)
-#
-CONFIG_NET_ETHERNET=y
-# CONFIG_MII is not set
-# CONFIG_OAKNET is not set
-CONFIG_ARIADNE=y
-# CONFIG_ZORRO8390 is not set
-CONFIG_A2065=y
-CONFIG_HYDRA=y
-# CONFIG_HAPPYMEAL is not set
-# CONFIG_SUNGEM is not set
-# CONFIG_NET_VENDOR_3COM is not set
-
-#
-# Tulip family network device support
-#
-# CONFIG_NET_TULIP is not set
-# CONFIG_HP100 is not set
-# CONFIG_NET_PCI is not set
-
-#
-# Ethernet (1000 Mbit)
-#
-# CONFIG_ACENIC is not set
-# CONFIG_DL2K is not set
-# CONFIG_E1000 is not set
-# CONFIG_NS83820 is not set
-# CONFIG_HAMACHI is not set
-# CONFIG_YELLOWFIN is not set
-# CONFIG_R8169 is not set
-# CONFIG_SK98LIN is not set
-# CONFIG_TIGON3 is not set
-
-#
-# Ethernet (10000 Mbit)
-#
-# CONFIG_IXGB is not set
-# CONFIG_FDDI is not set
-# CONFIG_HIPPI is not set
-CONFIG_PLIP=m
-CONFIG_PPP=y
-CONFIG_PPP_MULTILINK=y
-CONFIG_PPP_FILTER=y
-CONFIG_PPP_ASYNC=y
-CONFIG_PPP_SYNC_TTY=y
-CONFIG_PPP_DEFLATE=y
-CONFIG_PPP_BSDCOMP=y
-CONFIG_PPPOE=y
-CONFIG_SLIP=y
-CONFIG_SLIP_COMPRESSED=y
-CONFIG_SLIP_SMART=y
-CONFIG_SLIP_MODE_SLIP6=y
-
-#
-# Wireless LAN (non-hamradio)
-#
-# CONFIG_NET_RADIO is not set
-
-#
-# Token Ring devices (depends on LLC=y)
-#
-# CONFIG_NET_FC is not set
-# CONFIG_RCPCI is not set
-# CONFIG_SHAPER is not set
-
-#
-# Wan interfaces
-#
-# CONFIG_WAN is not set
-
-#
-# Amateur Radio support
-#
-# CONFIG_HAMRADIO is not set
-
-#
-# IrDA (infrared) support
-#
-# CONFIG_IRDA is not set
-
-#
-# ISDN subsystem
-#
-# CONFIG_ISDN_BOOL is not set
-
-#
-# Graphics support
-#
-CONFIG_FB=y
-# CONFIG_FB_CIRRUS is not set
-CONFIG_FB_PM2=y
-# CONFIG_FB_PM2_FIFO_DISCONNECT is not set
-# CONFIG_FB_PM2_PCI is not set
-CONFIG_FB_PM2_CVPPC=y
-CONFIG_FB_CYBER2000=y
-CONFIG_FB_AMIGA=y
-CONFIG_FB_AMIGA_OCS=y
-CONFIG_FB_AMIGA_ECS=y
-CONFIG_FB_AMIGA_AGA=y
-CONFIG_FB_CYBER=y
-CONFIG_FB_VIRGE=y
-CONFIG_FB_RETINAZ3=y
-CONFIG_FB_FM2=y
-# CONFIG_FB_CT65550 is not set
-# CONFIG_FB_IMSTT is not set
-# CONFIG_FB_S3TRIO is not set
-# CONFIG_FB_VGA16 is not set
-# CONFIG_FB_RIVA is not set
-# CONFIG_FB_MATROX is not set
-# CONFIG_FB_RADEON is not set
-# CONFIG_FB_ATY128 is not set
-# CONFIG_FB_ATY is not set
-# CONFIG_FB_SIS is not set
-# CONFIG_FB_NEOMAGIC is not set
-# CONFIG_FB_3DFX is not set
-# CONFIG_FB_VOODOO1 is not set
-# CONFIG_FB_TRIDENT is not set
-# CONFIG_FB_PM3 is not set
-# CONFIG_FB_VIRTUAL is not set
-
-#
-# Logo configuration
-#
-CONFIG_LOGO=y
-CONFIG_LOGO_LINUX_MONO=y
-CONFIG_LOGO_LINUX_VGA16=y
-CONFIG_LOGO_LINUX_CLUT224=y
-
-#
-# Old CD-ROM drivers (not SCSI, not IDE)
-#
-# CONFIG_CD_NO_IDESCSI is not set
-
-#
-# Input device support
-#
-CONFIG_INPUT=m
-
-#
-# Userland interfaces
-#
-CONFIG_INPUT_MOUSEDEV=m
-CONFIG_INPUT_MOUSEDEV_PSAUX=y
-CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024
-CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768
-CONFIG_INPUT_JOYDEV=m
-# CONFIG_INPUT_TSDEV is not set
-CONFIG_INPUT_EVDEV=m
-CONFIG_INPUT_EVBUG=m
-
-#
-# Input I/O drivers
-#
-# CONFIG_GAMEPORT is not set
-CONFIG_SOUND_GAMEPORT=y
-CONFIG_SERIO=y
-# CONFIG_SERIO_I8042 is not set
-CONFIG_SERIO_SERPORT=y
-# CONFIG_SERIO_CT82C710 is not set
-# CONFIG_SERIO_PARKBD is not set
-
-#
-# Input Device Drivers
-#
-CONFIG_INPUT_KEYBOARD=y
-CONFIG_KEYBOARD_ATKBD=m
-# CONFIG_KEYBOARD_SUNKBD is not set
-# CONFIG_KEYBOARD_XTKBD is not set
-# CONFIG_KEYBOARD_NEWTON is not set
-CONFIG_KEYBOARD_AMIGA=m
-CONFIG_INPUT_MOUSE=y
-CONFIG_MOUSE_PS2=m
-CONFIG_MOUSE_SERIAL=m
-CONFIG_MOUSE_AMIGA=m
-# CONFIG_INPUT_JOYSTICK is not set
-# CONFIG_INPUT_TOUCHSCREEN is not set
-CONFIG_INPUT_MISC=y
-# CONFIG_INPUT_PCSPKR is not set
-CONFIG_INPUT_UINPUT=m
-
-#
-# Macintosh device drivers
-#
-
-#
-# Character devices
-#
-# CONFIG_SERIAL_NONSTANDARD is not set
-
-#
-# Serial drivers
-#
-# CONFIG_SERIAL_8250 is not set
-
-#
-# Non-8250 serial port support
-#
-CONFIG_UNIX98_PTYS=y
-CONFIG_UNIX98_PTY_COUNT=256
-CONFIG_PRINTER=m
-# CONFIG_LP_CONSOLE is not set
-# CONFIG_PPDEV is not set
-# CONFIG_TIPAR is not set
-
-#
-# I2C support
-#
-# CONFIG_I2C is not set
-
-#
-# I2C Hardware Sensors Mainboard support
-#
-
-#
-# I2C Hardware Sensors Chip support
-#
-# CONFIG_I2C_SENSOR is not set
-
-#
-# Mice
-#
-CONFIG_BUSMOUSE=y
-# CONFIG_QIC02_TAPE is not set
-
-#
-# IPMI
-#
-# CONFIG_IPMI_HANDLER is not set
-
-#
-# Watchdog Cards
-#
-# CONFIG_WATCHDOG is not set
-# CONFIG_NVRAM is not set
-CONFIG_GEN_RTC=y
-# CONFIG_GEN_RTC_X is not set
-# CONFIG_DTLK is not set
-# CONFIG_R3964 is not set
-# CONFIG_APPLICOM is not set
-
-#
-# Ftape, the floppy tape device driver
-#
-# CONFIG_FTAPE is not set
-# CONFIG_AGP is not set
-# CONFIG_DRM is not set
-# CONFIG_RAW_DRIVER is not set
-# CONFIG_HANGCHECK_TIMER is not set
-
-#
-# Multimedia devices
-#
-# CONFIG_VIDEO_DEV is not set
-
-#
-# Digital Video Broadcasting Devices
-#
-# CONFIG_DVB is not set
-
-#
-# File systems
-#
-CONFIG_EXT2_FS=y
-# CONFIG_EXT2_FS_XATTR is not set
-CONFIG_EXT3_FS=y
-CONFIG_EXT3_FS_XATTR=y
-# CONFIG_EXT3_FS_POSIX_ACL is not set
-# CONFIG_EXT3_FS_SECURITY is not set
-CONFIG_JBD=y
-# CONFIG_JBD_DEBUG is not set
-CONFIG_FS_MBCACHE=y
-# CONFIG_REISERFS_FS is not set
-# CONFIG_JFS_FS is not set
-# CONFIG_XFS_FS is not set
-CONFIG_MINIX_FS=y
-CONFIG_ROMFS_FS=y
-# CONFIG_QUOTA is not set
-CONFIG_AUTOFS_FS=m
-CONFIG_AUTOFS4_FS=m
-
-#
-# CD-ROM/DVD Filesystems
-#
-CONFIG_ISO9660_FS=y
-CONFIG_JOLIET=y
-# CONFIG_ZISOFS is not set
-# CONFIG_UDF_FS is not set
-
-#
-# DOS/FAT/NT Filesystems
-#
-CONFIG_FAT_FS=y
-CONFIG_MSDOS_FS=y
-CONFIG_VFAT_FS=y
-# CONFIG_NTFS_FS is not set
-
-#
-# Pseudo filesystems
-#
-CONFIG_PROC_FS=y
-# CONFIG_DEVFS_FS is not set
-CONFIG_DEVPTS_FS=y
-# CONFIG_DEVPTS_FS_XATTR is not set
-CONFIG_TMPFS=y
-CONFIG_RAMFS=y
-
-#
-# Miscellaneous filesystems
-#
-# CONFIG_ADFS_FS is not set
-CONFIG_AFFS_FS=y
-CONFIG_HFS_FS=y
-# CONFIG_BEFS_FS is not set
-# CONFIG_BFS_FS is not set
-# CONFIG_EFS_FS is not set
-CONFIG_CRAMFS=y
-# CONFIG_VXFS_FS is not set
-# CONFIG_HPFS_FS is not set
-# CONFIG_QNX4FS_FS is not set
-# CONFIG_SYSV_FS is not set
-# CONFIG_UFS_FS is not set
-
-#
-# Network File Systems
-#
-CONFIG_NFS_FS=y
-CONFIG_NFS_V3=y
-# CONFIG_NFS_V4 is not set
-CONFIG_NFSD=m
-CONFIG_NFSD_V3=y
-# CONFIG_NFSD_V4 is not set
-# CONFIG_NFSD_TCP is not set
-CONFIG_LOCKD=y
-CONFIG_LOCKD_V4=y
-CONFIG_EXPORTFS=m
-CONFIG_SUNRPC=y
-# CONFIG_SUNRPC_GSS is not set
-CONFIG_SMB_FS=m
-# CONFIG_SMB_NLS_DEFAULT is not set
-# CONFIG_CIFS is not set
-# CONFIG_NCP_FS is not set
-CONFIG_CODA_FS=m
-# CONFIG_INTERMEZZO_FS is not set
-# CONFIG_AFS_FS is not set
-
-#
-# Partition Types
-#
-CONFIG_PARTITION_ADVANCED=y
-# CONFIG_ACORN_PARTITION is not set
-# CONFIG_OSF_PARTITION is not set
-CONFIG_AMIGA_PARTITION=y
-CONFIG_ATARI_PARTITION=y
-# CONFIG_MAC_PARTITION is not set
-CONFIG_MSDOS_PARTITION=y
-CONFIG_BSD_DISKLABEL=y
-# CONFIG_MINIX_SUBPARTITION is not set
-CONFIG_SOLARIS_X86_PARTITION=y
-CONFIG_UNIXWARE_DISKLABEL=y
-# CONFIG_LDM_PARTITION is not set
-# CONFIG_NEC98_PARTITION is not set
-# CONFIG_SGI_PARTITION is not set
-# CONFIG_ULTRIX_PARTITION is not set
-# CONFIG_SUN_PARTITION is not set
-# CONFIG_EFI_PARTITION is not set
-CONFIG_SMB_NLS=y
-CONFIG_NLS=y
-
-#
-# Native Language Support
-#
-CONFIG_NLS_DEFAULT="iso8859-1"
-CONFIG_NLS_CODEPAGE_437=m
-CONFIG_NLS_CODEPAGE_737=m
-CONFIG_NLS_CODEPAGE_775=m
-CONFIG_NLS_CODEPAGE_850=m
-CONFIG_NLS_CODEPAGE_852=m
-CONFIG_NLS_CODEPAGE_855=m
-CONFIG_NLS_CODEPAGE_857=m
-CONFIG_NLS_CODEPAGE_860=m
-CONFIG_NLS_CODEPAGE_861=m
-CONFIG_NLS_CODEPAGE_862=m
-CONFIG_NLS_CODEPAGE_863=m
-CONFIG_NLS_CODEPAGE_864=m
-CONFIG_NLS_CODEPAGE_865=m
-CONFIG_NLS_CODEPAGE_866=m
-CONFIG_NLS_CODEPAGE_869=m
-CONFIG_NLS_CODEPAGE_936=m
-CONFIG_NLS_CODEPAGE_950=m
-CONFIG_NLS_CODEPAGE_932=m
-CONFIG_NLS_CODEPAGE_949=m
-CONFIG_NLS_CODEPAGE_874=m
-CONFIG_NLS_ISO8859_8=m
-# CONFIG_NLS_CODEPAGE_1250 is not set
-CONFIG_NLS_CODEPAGE_1251=m
-CONFIG_NLS_ISO8859_1=m
-CONFIG_NLS_ISO8859_2=m
-CONFIG_NLS_ISO8859_3=m
-CONFIG_NLS_ISO8859_4=m
-CONFIG_NLS_ISO8859_5=m
-CONFIG_NLS_ISO8859_6=m
-CONFIG_NLS_ISO8859_7=m
-CONFIG_NLS_ISO8859_9=m
-CONFIG_NLS_ISO8859_13=m
-CONFIG_NLS_ISO8859_14=m
-CONFIG_NLS_ISO8859_15=m
-CONFIG_NLS_KOI8_R=m
-CONFIG_NLS_KOI8_U=m
-CONFIG_NLS_UTF8=m
-
-#
-# Sound
-#
-CONFIG_SOUND=y
-CONFIG_DMASOUND_PAULA=m
-CONFIG_DMASOUND=m
-
-#
-# Advanced Linux Sound Architecture
-#
-# CONFIG_SND is not set
-
-#
-# Open Sound System
-#
-CONFIG_SOUND_PRIME=m
-# CONFIG_SOUND_BT878 is not set
-# CONFIG_SOUND_CMPCI is not set
-# CONFIG_SOUND_EMU10K1 is not set
-# CONFIG_SOUND_FUSION is not set
-# CONFIG_SOUND_CS4281 is not set
-# CONFIG_SOUND_ES1370 is not set
-# CONFIG_SOUND_ES1371 is not set
-# CONFIG_SOUND_ESSSOLO1 is not set
-# CONFIG_SOUND_MAESTRO is not set
-# CONFIG_SOUND_MAESTRO3 is not set
-# CONFIG_SOUND_ICH is not set
-# CONFIG_SOUND_RME96XX is not set
-# CONFIG_SOUND_SONICVIBES is not set
-# CONFIG_SOUND_TRIDENT is not set
-# CONFIG_SOUND_MSNDCLAS is not set
-# CONFIG_SOUND_MSNDPIN is not set
-# CONFIG_SOUND_VIA82CXXX is not set
-CONFIG_SOUND_OSS=m
-CONFIG_SOUND_TRACEINIT=y
-CONFIG_SOUND_DMAP=y
-# CONFIG_SOUND_AD1816 is not set
-# CONFIG_SOUND_SGALAXY is not set
-# CONFIG_SOUND_ADLIB is not set
-# CONFIG_SOUND_ACI_MIXER is not set
-# CONFIG_SOUND_CS4232 is not set
-# CONFIG_SOUND_SSCAPE is not set
-# CONFIG_SOUND_GUS is not set
-CONFIG_SOUND_VMIDI=m
-# CONFIG_SOUND_TRIX is not set
-# CONFIG_SOUND_MSS is not set
-# CONFIG_SOUND_MPU401 is not set
-# CONFIG_SOUND_NM256 is not set
-# CONFIG_SOUND_MAD16 is not set
-# CONFIG_SOUND_PAS is not set
-# CONFIG_SOUND_PSS is not set
-# CONFIG_SOUND_SB is not set
-# CONFIG_SOUND_AWE32_SYNTH is not set
-# CONFIG_SOUND_WAVEFRONT is not set
-# CONFIG_SOUND_MAUI is not set
-# CONFIG_SOUND_YM3812 is not set
-# CONFIG_SOUND_OPL3SA1 is not set
-# CONFIG_SOUND_OPL3SA2 is not set
-# CONFIG_SOUND_YMFPCI is not set
-# CONFIG_SOUND_UART6850 is not set
-# CONFIG_SOUND_AEDSP16 is not set
-
-#
-# USB support
-#
-# CONFIG_USB is not set
-# CONFIG_USB_GADGET is not set
-
-#
-# Bluetooth support
-#
-# CONFIG_BT is not set
-
-#
-# Library routines
-#
-# CONFIG_CRC32 is not set
-CONFIG_ZLIB_INFLATE=y
-CONFIG_ZLIB_DEFLATE=y
-
-#
-# Kernel hacking
-#
-# CONFIG_DEBUG_KERNEL is not set
-# CONFIG_KALLSYMS is not set
-
-#
-# Security options
-#
-# CONFIG_SECURITY is not set
-
-#
-# Cryptographic options
-#
-# CONFIG_CRYPTO is not set
index c7cb9d5f24a381911a85c74f78cd1bd1bb2d5ad5..1b0ec7202dd5470a939b7c9d933618f8c2c425a4 100644 (file)
 #include <asm/ppc_asm.h>
 #include <asm/asm-offsets.h>
 
-#ifdef CONFIG_APUS
-#include <asm/amigappc.h>
-#endif
-
 /* 601 only have IBAT; cr0.eq is set on 601 when using this macro */
 #define LOAD_BAT(n, reg, RA, RB)       \
        /* see the comment for clear_bats() -- Cort */ \
@@ -128,14 +124,6 @@ __start:
  */
        bl      early_init
 
-#ifdef CONFIG_APUS
-/* On APUS the __va/__pa constants need to be set to the correct
- * values before continuing.
- */
-       mr      r4,r30
-       bl      fix_mem_constants
-#endif /* CONFIG_APUS */
-
 /* Switch MMU off, clear BATs and flush TLB. At this point, r3 contains
  * the physical address we are running at, returned by early_init()
  */
@@ -145,7 +133,7 @@ __after_mmu_off:
        bl      flush_tlbs
 
        bl      initial_bats
-#if !defined(CONFIG_APUS) && defined(CONFIG_BOOTX_TEXT)
+#ifdef CONFIG_BOOTX_TEXT
        bl      setup_disp_bat
 #endif
 
@@ -161,7 +149,6 @@ __after_mmu_off:
 #endif /* CONFIG_6xx */
 
 
-#ifndef CONFIG_APUS
 /*
  * We need to run with _start at physical address 0.
  * If the MMU is already turned on, we copy stuff to KERNELBASE,
@@ -172,7 +159,7 @@ __after_mmu_off:
        addis   r4,r3,KERNELBASE@h      /* current address of _start */
        cmpwi   0,r4,0                  /* are we already running at 0? */
        bne     relocate_kernel
-#endif /* CONFIG_APUS */
+
 /*
  * we now have the 1st 16M of ram mapped with the bats.
  * prep needs the mmu to be turned on here, but pmac already has it on.
@@ -812,85 +799,6 @@ copy_and_flush:
        addi    r6,r6,4
        blr
 
-#ifdef CONFIG_APUS
-/*
- * On APUS the physical base address of the kernel is not known at compile
- * time, which means the __pa/__va constants used are incorrect. In the
- * __init section is recorded the virtual addresses of instructions using
- * these constants, so all that has to be done is fix these before
- * continuing the kernel boot.
- *
- * r4 = The physical address of the kernel base.
- */
-fix_mem_constants:
-       mr      r10,r4
-       addis   r10,r10,-KERNELBASE@h    /* virt_to_phys constant */
-       neg     r11,r10                  /* phys_to_virt constant */
-
-       lis     r12,__vtop_table_begin@h
-       ori     r12,r12,__vtop_table_begin@l
-       add     r12,r12,r10              /* table begin phys address */
-       lis     r13,__vtop_table_end@h
-       ori     r13,r13,__vtop_table_end@l
-       add     r13,r13,r10              /* table end phys address */
-       subi    r12,r12,4
-       subi    r13,r13,4
-1:     lwzu    r14,4(r12)               /* virt address of instruction */
-       add     r14,r14,r10              /* phys address of instruction */
-       lwz     r15,0(r14)               /* instruction, now insert top */
-       rlwimi  r15,r10,16,16,31         /* half of vp const in low half */
-       stw     r15,0(r14)               /* of instruction and restore. */
-       dcbst   r0,r14                   /* write it to memory */
-       sync
-       icbi    r0,r14                   /* flush the icache line */
-       cmpw    r12,r13
-       bne     1b
-       sync                            /* additional sync needed on g4 */
-       isync
-
-/*
- * Map the memory where the exception handlers will
- * be copied to when hash constants have been patched.
- */
-#ifdef CONFIG_APUS_FAST_EXCEPT
-       lis     r8,0xfff0
-#else
-       lis     r8,0
-#endif
-       ori     r8,r8,0x2               /* 128KB, supervisor */
-       mtspr   SPRN_DBAT3U,r8
-       mtspr   SPRN_DBAT3L,r8
-
-       lis     r12,__ptov_table_begin@h
-       ori     r12,r12,__ptov_table_begin@l
-       add     r12,r12,r10              /* table begin phys address */
-       lis     r13,__ptov_table_end@h
-       ori     r13,r13,__ptov_table_end@l
-       add     r13,r13,r10              /* table end phys address */
-       subi    r12,r12,4
-       subi    r13,r13,4
-1:     lwzu    r14,4(r12)               /* virt address of instruction */
-       add     r14,r14,r10              /* phys address of instruction */
-       lwz     r15,0(r14)               /* instruction, now insert top */
-       rlwimi  r15,r11,16,16,31         /* half of pv const in low half*/
-       stw     r15,0(r14)               /* of instruction and restore. */
-       dcbst   r0,r14                   /* write it to memory */
-       sync
-       icbi    r0,r14                   /* flush the icache line */
-       cmpw    r12,r13
-       bne     1b
-
-       sync                            /* additional sync needed on g4 */
-       isync                           /* No speculative loading until now */
-       blr
-
-/***********************************************************************
- *  Please note that on APUS the exception handlers are located at the
- *  physical address 0xfff0000. For this reason, the exception handlers
- *  cannot use relative branches to access the code below.
- ***********************************************************************/
-#endif /* CONFIG_APUS */
-
 #ifdef CONFIG_SMP
        .globl  __secondary_start_pmac_0
 __secondary_start_pmac_0:
@@ -1043,19 +951,6 @@ start_here:
        bl      machine_init
        bl      MMU_init
 
-#ifdef CONFIG_APUS
-       /* Copy exception code to exception vector base on APUS. */
-       lis     r4,KERNELBASE@h
-#ifdef CONFIG_APUS_FAST_EXCEPT
-       lis     r3,0xfff0               /* Copy to 0xfff00000 */
-#else
-       lis     r3,0                    /* Copy to 0x00000000 */
-#endif
-       li      r5,0x4000               /* # bytes of memory to copy */
-       li      r6,0
-       bl      copy_and_flush          /* copy the first 0x4000 bytes */
-#endif  /* CONFIG_APUS */
-
 /*
  * Go back to running unmapped so we can load up new values
  * for SDR1 (hash table pointer) and the segment registers
@@ -1232,11 +1127,7 @@ initial_bats:
 #else
        ori     r8,r8,2                 /* R/W access */
 #endif /* CONFIG_SMP */
-#ifdef CONFIG_APUS
-       ori     r11,r11,BL_8M<<2|0x2    /* set up 8MB BAT registers for 604 */
-#else
        ori     r11,r11,BL_256M<<2|0x2  /* set up BAT registers for 604 */
-#endif /* CONFIG_APUS */
 
        mtspr   SPRN_DBAT0L,r8          /* N.B. 6xx (not 601) have valid */
        mtspr   SPRN_DBAT0U,r11         /* bit in upper BAT register */
@@ -1245,7 +1136,7 @@ initial_bats:
        isync
        blr
 
-#if !defined(CONFIG_APUS) && defined(CONFIG_BOOTX_TEXT)
+#ifdef CONFIG_BOOTX_TEXT
 setup_disp_bat:
        /*
         * setup the display bat prepared for us in prom.c
@@ -1268,7 +1159,7 @@ setup_disp_bat:
        mtspr   SPRN_IBAT3U,r11
        blr
 
-#endif /* !defined(CONFIG_APUS) && defined(CONFIG_BOOTX_TEXT) */
+#endif /* defined(CONFIG_BOOTX_TEXT) */
 
 #ifdef CONFIG_8260
 /* Jump into the system reset for the rom.
index 63f0a987139b4335b2255a76f5834ea47ac5dcb5..22494ec123ea4261511e525286e9593f8a5b636c 100644 (file)
@@ -60,8 +60,6 @@ long long __ashrdi3(long long, int);
 long long __ashldi3(long long, int);
 long long __lshrdi3(long long, int);
 
-extern unsigned long mm_ptov (unsigned long paddr);
-
 EXPORT_SYMBOL(clear_pages);
 EXPORT_SYMBOL(clear_user_page);
 EXPORT_SYMBOL(transfer_to_handler);
@@ -118,7 +116,6 @@ EXPORT_SYMBOL(_outsw_ns);
 EXPORT_SYMBOL(_insl_ns);
 EXPORT_SYMBOL(_outsl_ns);
 EXPORT_SYMBOL(iopa);
-EXPORT_SYMBOL(mm_ptov);
 EXPORT_SYMBOL(ioremap);
 #ifdef CONFIG_44x
 EXPORT_SYMBOL(ioremap64);
index 967c1ef59a6bd10f91abe56c95e3f6cb97faabd0..aac88c2f3db9d7d07b9b6e63e431f4fdb6a328b1 100644 (file)
@@ -25,7 +25,6 @@
 #include <asm/pgtable.h>
 #include <asm/bootinfo.h>
 #include <asm/setup.h>
-#include <asm/amigappc.h>
 #include <asm/smp.h>
 #include <asm/elf.h>
 #include <asm/cputable.h>
index 35ebb6395ae3329d5117d4d0611d21e60d12a361..1f51e6c9450718fc8d7e47660a204d6cd587b062 100644 (file)
@@ -426,41 +426,3 @@ unsigned long iopa(unsigned long addr)
        return(pa);
 }
 
-/* This is will find the virtual address for a physical one....
- * Swiped from APUS, could be dangerous :-).
- * This is only a placeholder until I really find a way to make this
- * work.  -- Dan
- */
-unsigned long
-mm_ptov (unsigned long paddr)
-{
-       unsigned long ret;
-#if 0
-       if (paddr < 16*1024*1024)
-               ret = ZTWO_VADDR(paddr);
-       else {
-               int i;
-
-               for (i = 0; i < kmap_chunk_count;){
-                       unsigned long phys = kmap_chunks[i++];
-                       unsigned long size = kmap_chunks[i++];
-                       unsigned long virt = kmap_chunks[i++];
-                       if (paddr >= phys
-                           && paddr < (phys + size)){
-                               ret = virt + paddr - phys;
-                               goto exit;
-                       }
-               }
-       
-               ret = (unsigned long) __va(paddr);
-       }
-exit:
-#ifdef DEBUGPV
-       printk ("PTOV(%lx)=%lx\n", paddr, ret);
-#endif
-#else
-       ret = (unsigned long)paddr + KERNELBASE;
-#endif
-       return ret;
-}
-
index e17fad4706218224c41a7c21cef4748568e9acec..40f53fbe6d35c5d87978e2a40cf47a416e026e91 100644 (file)
@@ -2,10 +2,6 @@
 # Makefile for the linux kernel.
 #
 
-obj-$(CONFIG_APUS)             += apus_setup.o
-ifeq ($(CONFIG_APUS),y)
-obj-$(CONFIG_PCI)              += apus_pci.o
-endif
 obj-$(CONFIG_PPC_PREP)         += prep_pci.o prep_setup.o
 obj-$(CONFIG_PREP_RESIDUAL)    += residual.o
 obj-$(CONFIG_PQ2ADS)           += pq2ads.o
diff --git a/arch/ppc/platforms/apus_pci.c b/arch/ppc/platforms/apus_pci.c
deleted file mode 100644 (file)
index dc165f0..0000000
+++ /dev/null
@@ -1,207 +0,0 @@
-/*
- * Copyright (C) Michel Dänzer <michdaen@iiic.ethz.ch>
- *
- * APUS PCI routines.
- *
- * Currently, only B/CVisionPPC cards (Permedia2) are supported.
- *
- * Thanks to Geert Uytterhoeven for the idea:
- * Read values from given config space(s) for the first devices, -1 otherwise
- *
- */
-
-#ifdef CONFIG_AMIGA
-
-#include <linux/kernel.h>
-#include <linux/pci.h>
-#include <linux/delay.h>
-#include <linux/string.h>
-#include <linux/init.h>
-
-#include <asm/io.h>
-#include <asm/pci-bridge.h>
-#include <asm/machdep.h>
-
-#include "apus_pci.h"
-
-
-/* These definitions are mostly adapted from pm2fb.c */
-
-#undef APUS_PCI_MASTER_DEBUG
-#ifdef APUS_PCI_MASTER_DEBUG
-#define DPRINTK(a,b...)        printk(KERN_DEBUG "apus_pci: %s: " a, __FUNCTION__ , ## b)
-#else
-#define DPRINTK(a,b...)
-#endif
-
-/*
- * The _DEFINITIVE_ memory mapping/unmapping functions.
- * This is due to the fact that they're changing soooo often...
- */
-#define DEFW()         wmb()
-#define DEFR()         rmb()
-#define DEFRW()                mb()
-
-#define DEVNO(d)       ((d)>>3)
-#define FNNO(d)                ((d)&7)
-
-
-extern unsigned long powerup_PCI_present;
-
-static struct pci_controller *apus_hose;
-
-
-void *pci_io_base(unsigned int bus)
-{
-       return 0;
-}
-
-
-int
-apus_pcibios_read_config(struct pci_bus *bus, int devfn, int offset,
-                        int len, u32 *val)
-{
-       int fnno = FNNO(devfn);
-       int devno = DEVNO(devfn);
-       volatile unsigned char *cfg_data;
-
-       if (bus->number > 0 || devno != 1) {
-               *val = ~0;
-               return PCIBIOS_DEVICE_NOT_FOUND;
-       }
-       /* base address + function offset + offset ^ endianness conversion */
-       /* XXX the fnno<<5 bit seems wacky  -- paulus */
-       cfg_data = apus_hose->cfg_data + (fnno<<5) + (offset ^ (len - 1));
-       switch (len) {
-       case 1:
-               *val = readb(cfg_data);
-               break;
-       case 2:
-               *val = readw(cfg_data);
-               break;
-       default:
-               *val = readl(cfg_data);
-               break;
-       }
-
-       DPRINTK("read b: 0x%x, d: 0x%x, f: 0x%x, o: 0x%x, l: %d, v: 0x%x\n",
-               bus->number, devfn>>3, devfn&7, offset, len, *val);
-       return PCIBIOS_SUCCESSFUL;
-}
-
-int
-apus_pcibios_write_config(struct pci_bus *bus, int devfn, int offset,
-                         int len, u32 *val)
-{
-       int fnno = FNNO(devfn);
-       int devno = DEVNO(devfn);
-       volatile unsigned char *cfg_data;
-
-       if (bus->number > 0 || devno != 1) {
-               return PCIBIOS_DEVICE_NOT_FOUND;
-       }
-       /* base address + function offset + offset ^ endianness conversion */
-       /* XXX the fnno<<5 bit seems wacky  -- paulus */
-       cfg_data = apus_hose->cfg_data + (fnno<<5) + (offset ^ (len - 1));
-       switch (len) {
-       case 1:
-               writeb(val, cfg_data); DEFW();
-               break;
-       case 2:
-               writew(val, cfg_data); DEFW();
-               break;
-       default:
-               writel(val, cfg_data); DEFW();
-               break;
-       }
-
-       DPRINTK("write b: 0x%x, d: 0x%x, f: 0x%x, o: 0x%x, l: %d, v: 0x%x\n",
-               bus->number, devfn>>3, devfn&7, offset, len, val);
-       return PCIBIOS_SUCCESSFUL;
-}
-
-static struct pci_ops apus_pci_ops = {
-       apus_pcibios_read_config,
-       apus_pcibios_write_config
-};
-
-static struct resource pci_mem = { "B/CVisionPPC PCI mem", CVPPC_FB_APERTURE_ONE, CVPPC_PCI_CONFIG, IORESOURCE_MEM };
-
-void __init
-apus_pcibios_fixup(void)
-{
-/*     struct pci_dev *dev = pci_find_slot(0, 1<<3);
-       unsigned int reg, val, offset;*/
-
-       /* FIXME: interrupt? */
-       /*dev->interrupt = xxx;*/
-
-        request_resource(&iomem_resource, &pci_mem);
-       printk("%s: PCI mem resource requested\n", __FUNCTION__);
-}
-
-static void __init apus_pcibios_fixup_bus(struct pci_bus *bus)
-{
-        bus->resource[1] = &pci_mem;
-}
-
-
-/*
- * This is from pm2fb.c again
- *
- * Check if PCI (B/CVisionPPC) is available, initialize it and set up
- * the pcibios_* pointers
- */
-
-
-void __init
-apus_setup_pci_ptrs(void)
-{
-       if (!powerup_PCI_present) {
-               DPRINTK("no PCI bridge detected\n");
-               return;
-       }
-       DPRINTK("Phase5 B/CVisionPPC PCI bridge detected.\n");
-
-       apus_hose = pcibios_alloc_controller();
-       if (!apus_hose) {
-               printk("apus_pci: Can't allocate PCI controller structure\n");
-               return;
-       }
-
-       if (!(apus_hose->cfg_data = ioremap(CVPPC_PCI_CONFIG, 256))) {
-               printk("apus_pci: unable to map PCI config region\n");
-               return;
-       }
-
-       if (!(apus_hose->cfg_addr = ioremap(CSPPC_PCI_BRIDGE, 256))) {
-               printk("apus_pci: unable to map PCI bridge\n");
-               return;
-       }
-
-       writel(CSPPCF_BRIDGE_BIG_ENDIAN, apus_hose->cfg_addr + CSPPC_BRIDGE_ENDIAN);
-       DEFW();
-
-       writel(CVPPC_REGS_REGION,  apus_hose->cfg_data+ PCI_BASE_ADDRESS_0);
-       DEFW();
-       writel(CVPPC_FB_APERTURE_ONE, apus_hose->cfg_data + PCI_BASE_ADDRESS_1);
-       DEFW();
-       writel(CVPPC_FB_APERTURE_TWO, apus_hose->cfg_data + PCI_BASE_ADDRESS_2);
-       DEFW();
-       writel(CVPPC_ROM_ADDRESS, apus_hose->cfg_data + PCI_ROM_ADDRESS);
-       DEFW();
-
-       writel(0xef000000 | PCI_COMMAND_IO | PCI_COMMAND_MEMORY |
-               PCI_COMMAND_MASTER, apus_hose->cfg_data + PCI_COMMAND);
-       DEFW();
-
-       apus_hose->first_busno = 0;
-       apus_hose->last_busno = 0;
-       apus_hose->ops = &apus_pci_ops;
-       ppc_md.pcibios_fixup = apus_pcibios_fixup;
-       ppc_md.pcibios_fixup_bus = apus_pcibios_fixup_bus;
-
-       return;
-}
-
-#endif /* CONFIG_AMIGA */
diff --git a/arch/ppc/platforms/apus_pci.h b/arch/ppc/platforms/apus_pci.h
deleted file mode 100644 (file)
index f15974a..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Phase5 CybervisionPPC (TVP4020) definitions for the Permedia2 framebuffer
- * driver.
- *
- * Copyright (c) 1998-1999 Ilario Nardinocchi (nardinoc@CS.UniBO.IT)
- * --------------------------------------------------------------------------
- * This file is subject to the terms and conditions of the GNU General Public
- * License.  See the file README.legal in the main directory of this archive
- * for more details.
- */
-
-#ifndef APUS_PCI_H
-#define APUS_PCI_H
-
-
-#define CSPPC_PCI_BRIDGE               0xfffe0000
-#define CSPPC_BRIDGE_ENDIAN            0x0000
-#define CSPPC_BRIDGE_INT               0x0010
-
-#define        CVPPC_PCI_CONFIG                0xfffc0000
-#define CVPPC_ROM_ADDRESS              0xe2000001
-#define CVPPC_REGS_REGION              0xef000000
-#define CVPPC_FB_APERTURE_ONE          0xe0000000
-#define CVPPC_FB_APERTURE_TWO          0xe1000000
-#define CVPPC_FB_SIZE                  0x00800000
-
-/* CVPPC_BRIDGE_ENDIAN */
-#define CSPPCF_BRIDGE_BIG_ENDIAN       0x02
-
-/* CVPPC_BRIDGE_INT */
-#define CSPPCF_BRIDGE_ACTIVE_INT2      0x01
-
-
-#endif /* APUS_PCI_H */
diff --git a/arch/ppc/platforms/apus_setup.c b/arch/ppc/platforms/apus_setup.c
deleted file mode 100644 (file)
index 063274d..0000000
+++ /dev/null
@@ -1,798 +0,0 @@
-/*
- *  Copyright (C) 1998, 1999  Jesper Skov
- *
- *  Basically what is needed to replace functionality found in
- *  arch/m68k allowing Amiga drivers to work under APUS.
- *  Bits of code and/or ideas from arch/m68k and arch/ppc files.
- *
- * TODO:
- *  This file needs a *really* good cleanup. Restructure and optimize.
- *  Make sure it can be compiled for non-APUS configs. Begin to move
- *  Amiga specific stuff into mach/amiga.
- */
-
-#include <linux/kernel.h>
-#include <linux/sched.h>
-#include <linux/init.h>
-#include <linux/initrd.h>
-#include <linux/seq_file.h>
-
-/* Needs INITSERIAL call in head.S! */
-#undef APUS_DEBUG
-
-#include <asm/bootinfo.h>
-#include <asm/setup.h>
-#include <asm/amigahw.h>
-#include <asm/amigaints.h>
-#include <asm/amigappc.h>
-#include <asm/pgtable.h>
-#include <asm/dma.h>
-#include <asm/machdep.h>
-#include <asm/time.h>
-
-unsigned long m68k_machtype;
-char debug_device[6] = "";
-
-extern void amiga_init_IRQ(void);
-
-extern void apus_setup_pci_ptrs(void);
-
-void (*mach_sched_init) (void (*handler)(int, void *, struct pt_regs *)) __initdata = NULL;
-/* machine dependent irq functions */
-void (*mach_init_IRQ) (void) __initdata = NULL;
-void (*(*mach_default_handler)[]) (int, void *, struct pt_regs *) = NULL;
-void (*mach_get_model) (char *model) = NULL;
-int (*mach_get_hardware_list) (char *buffer) = NULL;
-int (*mach_get_irq_list) (struct seq_file *, void *) = NULL;
-void (*mach_process_int) (int, struct pt_regs *) = NULL;
-/* machine dependent timer functions */
-unsigned long (*mach_gettimeoffset) (void);
-void (*mach_gettod) (int*, int*, int*, int*, int*, int*);
-int (*mach_hwclk) (int, struct hwclk_time*) = NULL;
-int (*mach_set_clock_mmss) (unsigned long) = NULL;
-void (*mach_reset)( void );
-long mach_max_dma_address = 0x00ffffff; /* default set to the lower 16MB */
-#ifdef CONFIG_HEARTBEAT
-void (*mach_heartbeat) (int) = NULL;
-extern void apus_heartbeat (void);
-#endif
-
-extern unsigned long amiga_model;
-extern unsigned decrementer_count;/* count value for 1e6/HZ microseconds */
-extern unsigned count_period_num; /* 1 decrementer count equals */
-extern unsigned count_period_den; /* count_period_num / count_period_den us */
-
-int num_memory = 0;
-struct mem_info memory[NUM_MEMINFO];/* memory description */
-/* FIXME: Duplicate memory data to avoid conflicts with m68k shared code. */
-int m68k_realnum_memory = 0;
-struct mem_info m68k_memory[NUM_MEMINFO];/* memory description */
-
-struct mem_info ramdisk;
-
-extern void config_amiga(void);
-
-static int __60nsram = 0;
-
-/* for cpuinfo */
-static int __bus_speed = 0;
-static int __speed_test_failed = 0;
-
-/********************************************** COMPILE PROTECTION */
-/* Provide some stubs that links to Amiga specific functions.
- * This allows CONFIG_APUS to be removed from generic PPC files while
- * preventing link errors for other PPC targets.
- */
-unsigned long apus_get_rtc_time(void)
-{
-#ifdef CONFIG_APUS
-       extern unsigned long m68k_get_rtc_time(void);
-
-       return m68k_get_rtc_time ();
-#else
-       return 0;
-#endif
-}
-
-int apus_set_rtc_time(unsigned long nowtime)
-{
-#ifdef CONFIG_APUS
-       extern int m68k_set_rtc_time(unsigned long nowtime);
-
-       return m68k_set_rtc_time (nowtime);
-#else
-       return 0;
-#endif
-}
-
-/*********************************************************** SETUP */
-/* From arch/m68k/kernel/setup.c. */
-void __init apus_setup_arch(void)
-{
-#ifdef CONFIG_APUS
-       extern char cmd_line[];
-       int i;
-       char *p, *q;
-
-       /* Let m68k-shared code know it should do the Amiga thing. */
-       m68k_machtype = MACH_AMIGA;
-
-       /* Parse the command line for arch-specific options.
-        * For the m68k, this is currently only "debug=xxx" to enable printing
-        * certain kernel messages to some machine-specific device.  */
-       for( p = cmd_line; p && *p; ) {
-           i = 0;
-           if (!strncmp( p, "debug=", 6 )) {
-                   strlcpy( debug_device, p+6, sizeof(debug_device) );
-                   if ((q = strchr( debug_device, ' ' ))) *q = 0;
-                   i = 1;
-           } else if (!strncmp( p, "60nsram", 7 )) {
-                   APUS_WRITE (APUS_REG_WAITSTATE,
-                               REGWAITSTATE_SETRESET
-                               |REGWAITSTATE_PPCR
-                               |REGWAITSTATE_PPCW);
-                   __60nsram = 1;
-                   i = 1;
-           }
-
-           if (i) {
-               /* option processed, delete it */
-               if ((q = strchr( p, ' ' )))
-                   strcpy( p, q+1 );
-               else
-                   *p = 0;
-           } else {
-               if ((p = strchr( p, ' ' ))) ++p;
-           }
-       }
-
-       config_amiga();
-
-#if 0 /* Enable for logging - also include logging.o in Makefile rule */
-       {
-#define LOG_SIZE 4096
-               void* base;
-
-               /* Throw away some memory - the P5 firmare stomps on top
-                * of CHIP memory during bootup.
-                */
-               amiga_chip_alloc(0x1000);
-
-               base = amiga_chip_alloc(LOG_SIZE+sizeof(klog_data_t));
-               LOG_INIT(base, base+sizeof(klog_data_t), LOG_SIZE);
-       }
-#endif
-#endif
-}
-
-int
-apus_show_cpuinfo(struct seq_file *m)
-{
-       extern int __map_without_bats;
-       extern unsigned long powerup_PCI_present;
-
-       seq_printf(m, "machine\t\t: Amiga\n");
-       seq_printf(m, "bus speed\t: %d%s", __bus_speed,
-                  (__speed_test_failed) ? " [failed]\n" : "\n");
-       seq_printf(m, "using BATs\t: %s\n",
-                  (__map_without_bats) ? "No" : "Yes");
-       seq_printf(m, "ram speed\t: %dns\n", (__60nsram) ? 60 : 70);
-       seq_printf(m, "PCI bridge\t: %s\n",
-                  (powerup_PCI_present) ? "Yes" : "No");
-       return 0;
-}
-
-static void get_current_tb(unsigned long long *time)
-{
-       __asm __volatile ("1:mftbu 4      \n\t"
-                         "  mftb  5      \n\t"
-                         "  mftbu 6      \n\t"
-                         "  cmpw  4,6    \n\t"
-                         "  bne   1b     \n\t"
-                         "  stw   4,0(%0)\n\t"
-                         "  stw   5,4(%0)\n\t"
-                         :
-                         : "r" (time)
-                         : "r4", "r5", "r6");
-}
-
-
-void apus_calibrate_decr(void)
-{
-#ifdef CONFIG_APUS
-       unsigned long freq;
-
-       /* This algorithm for determining the bus speed was
-           contributed by Ralph Schmidt. */
-       unsigned long long start, stop;
-       int bus_speed;
-       int speed_test_failed = 0;
-
-       {
-               unsigned long loop = amiga_eclock / 10;
-
-               get_current_tb (&start);
-               while (loop--) {
-                       unsigned char tmp;
-
-                       tmp = ciaa.pra;
-               }
-               get_current_tb (&stop);
-       }
-
-       bus_speed = (((unsigned long)(stop-start))*10*4) / 1000000;
-       if (AMI_1200 == amiga_model)
-               bus_speed /= 2;
-
-       if ((bus_speed >= 47) && (bus_speed < 53)) {
-               bus_speed = 50;
-               freq = 12500000;
-       } else if ((bus_speed >= 57) && (bus_speed < 63)) {
-               bus_speed = 60;
-               freq = 15000000;
-       } else if ((bus_speed >= 63) && (bus_speed < 69)) {
-               bus_speed = 67;
-               freq = 16666667;
-       } else {
-               printk ("APUS: Unable to determine bus speed (%d). "
-                       "Defaulting to 50MHz", bus_speed);
-               bus_speed = 50;
-               freq = 12500000;
-               speed_test_failed = 1;
-       }
-
-       /* Ease diagnostics... */
-       {
-               extern int __map_without_bats;
-               extern unsigned long powerup_PCI_present;
-
-               printk ("APUS: BATs=%d, BUS=%dMHz",
-                       (__map_without_bats) ? 0 : 1,
-                       bus_speed);
-               if (speed_test_failed)
-                       printk ("[FAILED - please report]");
-
-               printk (", RAM=%dns, PCI bridge=%d\n",
-                       (__60nsram) ? 60 : 70,
-                       (powerup_PCI_present) ? 1 : 0);
-
-               /* print a bit more if asked politely... */
-               if (!(ciaa.pra & 0x40)){
-                       extern unsigned int bat_addrs[4][3];
-                       int b;
-                       for (b = 0; b < 4; ++b) {
-                               printk ("APUS: BAT%d ", b);
-                               printk ("%08x-%08x -> %08x\n",
-                                       bat_addrs[b][0],
-                                       bat_addrs[b][1],
-                                       bat_addrs[b][2]);
-                       }
-               }
-
-       }
-
-        printk("time_init: decrementer frequency = %lu.%.6lu MHz\n",
-              freq/1000000, freq%1000000);
-       tb_ticks_per_jiffy = freq / HZ;
-       tb_to_us = mulhwu_scale_factor(freq, 1000000);
-
-       __bus_speed = bus_speed;
-       __speed_test_failed = speed_test_failed;
-#endif
-}
-
-void arch_gettod(int *year, int *mon, int *day, int *hour,
-                int *min, int *sec)
-{
-#ifdef CONFIG_APUS
-       if (mach_gettod)
-               mach_gettod(year, mon, day, hour, min, sec);
-       else
-               *year = *mon = *day = *hour = *min = *sec = 0;
-#endif
-}
-
-/* for "kbd-reset" cmdline param */
-__init
-void kbd_reset_setup(char *str, int *ints)
-{
-}
-
-/*********************************************************** MEMORY */
-#define KMAP_MAX 32
-unsigned long kmap_chunks[KMAP_MAX*3];
-int kmap_chunk_count = 0;
-
-/* From pgtable.h */
-static __inline__ pte_t *my_find_pte(struct mm_struct *mm,unsigned long va)
-{
-       pgd_t *dir = 0;
-       pmd_t *pmd = 0;
-       pte_t *pte = 0;
-
-       va &= PAGE_MASK;
-
-       dir = pgd_offset( mm, va );
-       if (dir)
-       {
-               pmd = pmd_offset(dir, va & PAGE_MASK);
-               if (pmd && pmd_present(*pmd))
-               {
-                       pte = pte_offset(pmd, va);
-               }
-       }
-       return pte;
-}
-
-
-/* Again simulating an m68k/mm/kmap.c function. */
-void kernel_set_cachemode( unsigned long address, unsigned long size,
-                          unsigned int cmode )
-{
-       unsigned long mask, flags;
-
-       switch (cmode)
-       {
-       case IOMAP_FULL_CACHING:
-               mask = ~(_PAGE_NO_CACHE | _PAGE_GUARDED);
-               flags = 0;
-               break;
-       case IOMAP_NOCACHE_SER:
-               mask = ~0;
-               flags = (_PAGE_NO_CACHE | _PAGE_GUARDED);
-               break;
-       default:
-               panic ("kernel_set_cachemode() doesn't support mode %d\n",
-                      cmode);
-               break;
-       }
-
-       size /= PAGE_SIZE;
-       address &= PAGE_MASK;
-       while (size--)
-       {
-               pte_t *pte;
-
-               pte = my_find_pte(&init_mm, address);
-               if ( !pte )
-               {
-                       printk("pte NULL in kernel_set_cachemode()\n");
-                       return;
-               }
-
-                pte_val (*pte) &= mask;
-                pte_val (*pte) |= flags;
-                flush_tlb_page(find_vma(&init_mm,address),address);
-
-               address += PAGE_SIZE;
-       }
-}
-
-unsigned long mm_ptov (unsigned long paddr)
-{
-       unsigned long ret;
-       if (paddr < 16*1024*1024)
-               ret = ZTWO_VADDR(paddr);
-       else {
-               int i;
-
-               for (i = 0; i < kmap_chunk_count;){
-                       unsigned long phys = kmap_chunks[i++];
-                       unsigned long size = kmap_chunks[i++];
-                       unsigned long virt = kmap_chunks[i++];
-                       if (paddr >= phys
-                           && paddr < (phys + size)){
-                               ret = virt + paddr - phys;
-                               goto exit;
-                       }
-               }
-
-               ret = (unsigned long) __va(paddr);
-       }
-exit:
-#ifdef DEBUGPV
-       printk ("PTOV(%lx)=%lx\n", paddr, ret);
-#endif
-       return ret;
-}
-
-int mm_end_of_chunk (unsigned long addr, int len)
-{
-       if (memory[0].addr + memory[0].size == addr + len)
-               return 1;
-       return 0;
-}
-
-/*********************************************************** CACHE */
-
-#define L1_CACHE_BYTES 32
-#define MAX_CACHE_SIZE 8192
-void cache_push(__u32 addr, int length)
-{
-       addr = mm_ptov(addr);
-
-       if (MAX_CACHE_SIZE < length)
-               length = MAX_CACHE_SIZE;
-
-       while(length > 0){
-               __asm ("dcbf 0,%0\n\t"
-                      : : "r" (addr));
-               addr += L1_CACHE_BYTES;
-               length -= L1_CACHE_BYTES;
-       }
-       /* Also flush trailing block */
-       __asm ("dcbf 0,%0\n\t"
-              "sync \n\t"
-              : : "r" (addr));
-}
-
-void cache_clear(__u32 addr, int length)
-{
-       if (MAX_CACHE_SIZE < length)
-               length = MAX_CACHE_SIZE;
-
-       addr = mm_ptov(addr);
-
-       __asm ("dcbf 0,%0\n\t"
-              "sync \n\t"
-              "icbi 0,%0 \n\t"
-              "isync \n\t"
-              : : "r" (addr));
-
-       addr += L1_CACHE_BYTES;
-       length -= L1_CACHE_BYTES;
-
-       while(length > 0){
-               __asm ("dcbf 0,%0\n\t"
-                      "sync \n\t"
-                      "icbi 0,%0 \n\t"
-                      "isync \n\t"
-                      : : "r" (addr));
-               addr += L1_CACHE_BYTES;
-               length -= L1_CACHE_BYTES;
-       }
-
-       __asm ("dcbf 0,%0\n\t"
-              "sync \n\t"
-              "icbi 0,%0 \n\t"
-              "isync \n\t"
-              : : "r" (addr));
-}
-
-/****************************************************** from setup.c */
-void
-apus_restart(char *cmd)
-{
-       local_irq_disable();
-
-       APUS_WRITE(APUS_REG_LOCK,
-                  REGLOCK_BLACKMAGICK1|REGLOCK_BLACKMAGICK2);
-       APUS_WRITE(APUS_REG_LOCK,
-                  REGLOCK_BLACKMAGICK1|REGLOCK_BLACKMAGICK3);
-       APUS_WRITE(APUS_REG_LOCK,
-                  REGLOCK_BLACKMAGICK2|REGLOCK_BLACKMAGICK3);
-       APUS_WRITE(APUS_REG_SHADOW, REGSHADOW_SELFRESET);
-       APUS_WRITE(APUS_REG_RESET, REGRESET_AMIGARESET);
-       for(;;);
-}
-
-void
-apus_power_off(void)
-{
-       for (;;);
-}
-
-void
-apus_halt(void)
-{
-   apus_restart(NULL);
-}
-
-/****************************************************** IRQ stuff */
-
-static unsigned char last_ipl[8];
-
-int apus_get_irq(void)
-{
-       unsigned char ipl_emu, mask;
-       unsigned int level;
-
-       APUS_READ(APUS_IPL_EMU, ipl_emu);
-       level = (ipl_emu >> 3) & IPLEMU_IPLMASK;
-       mask = IPLEMU_SETRESET|IPLEMU_DISABLEINT|level;
-       level ^= 7;
-
-       /* Save previous IPL value */
-       if (last_ipl[level])
-               return -2;
-       last_ipl[level] = ipl_emu;
-
-       /* Set to current IPL value */
-       APUS_WRITE(APUS_IPL_EMU, mask);
-       APUS_WRITE(APUS_IPL_EMU, IPLEMU_DISABLEINT|level);
-
-
-#ifdef __INTERRUPT_DEBUG
-       printk("<%d:%d>", level, ~ipl_emu & IPLEMU_IPLMASK);
-#endif
-       return level + IRQ_AMIGA_AUTO;
-}
-
-void apus_end_irq(unsigned int irq)
-{
-       unsigned char ipl_emu;
-       unsigned int level = irq - IRQ_AMIGA_AUTO;
-#ifdef __INTERRUPT_DEBUG
-       printk("{%d}", ~last_ipl[level] & IPLEMU_IPLMASK);
-#endif
-       /* Restore IPL to the previous value */
-       ipl_emu = last_ipl[level] & IPLEMU_IPLMASK;
-       APUS_WRITE(APUS_IPL_EMU, IPLEMU_SETRESET|IPLEMU_DISABLEINT|ipl_emu);
-       last_ipl[level] = 0;
-       ipl_emu ^= 7;
-       APUS_WRITE(APUS_IPL_EMU, IPLEMU_DISABLEINT|ipl_emu);
-}
-
-/****************************************************** debugging */
-
-/* some serial hardware definitions */
-#define SDR_OVRUN   (1<<15)
-#define SDR_RBF     (1<<14)
-#define SDR_TBE     (1<<13)
-#define SDR_TSRE    (1<<12)
-
-#define AC_SETCLR   (1<<15)
-#define AC_UARTBRK  (1<<11)
-
-#define SER_DTR     (1<<7)
-#define SER_RTS     (1<<6)
-#define SER_DCD     (1<<5)
-#define SER_CTS     (1<<4)
-#define SER_DSR     (1<<3)
-
-static __inline__ void ser_RTSon(void)
-{
-    ciab.pra &= ~SER_RTS; /* active low */
-}
-
-int __debug_ser_out( unsigned char c )
-{
-       amiga_custom.serdat = c | 0x100;
-       mb();
-       while (!(amiga_custom.serdatr & 0x2000))
-               barrier();
-       return 1;
-}
-
-unsigned char __debug_ser_in( void )
-{
-       unsigned char c;
-
-       /* XXX: is that ok?? derived from amiga_ser.c... */
-       while( !(amiga_custom.intreqr & IF_RBF) )
-               barrier();
-       c = amiga_custom.serdatr;
-       /* clear the interrupt, so that another character can be read */
-       amiga_custom.intreq = IF_RBF;
-       return c;
-}
-
-int __debug_serinit( void )
-{
-       unsigned long flags;
-
-       local_irq_save(flags);
-
-       /* turn off Rx and Tx interrupts */
-       amiga_custom.intena = IF_RBF | IF_TBE;
-
-       /* clear any pending interrupt */
-       amiga_custom.intreq = IF_RBF | IF_TBE;
-
-       local_irq_restore(flags);
-
-       /*
-        * set the appropriate directions for the modem control flags,
-        * and clear RTS and DTR
-        */
-       ciab.ddra |= (SER_DTR | SER_RTS);   /* outputs */
-       ciab.ddra &= ~(SER_DCD | SER_CTS | SER_DSR);  /* inputs */
-
-#ifdef CONFIG_KGDB
-       /* turn Rx interrupts on for GDB */
-       amiga_custom.intena = IF_SETCLR | IF_RBF;
-       ser_RTSon();
-#endif
-
-       return 0;
-}
-
-void __debug_print_hex(unsigned long x)
-{
-       int i;
-       char hexchars[] = "0123456789ABCDEF";
-
-       for (i = 0; i < 8; i++) {
-               __debug_ser_out(hexchars[(x >> 28) & 15]);
-               x <<= 4;
-       }
-       __debug_ser_out('\n');
-       __debug_ser_out('\r');
-}
-
-void __debug_print_string(char* s)
-{
-       unsigned char c;
-       while((c = *s++))
-               __debug_ser_out(c);
-       __debug_ser_out('\n');
-       __debug_ser_out('\r');
-}
-
-static void apus_progress(char *s, unsigned short value)
-{
-       __debug_print_string(s);
-}
-
-/****************************************************** init */
-
-/* The number of spurious interrupts */
-volatile unsigned int num_spurious;
-
-extern struct irqaction amiga_sys_irqaction[AUTO_IRQS];
-
-
-extern void amiga_enable_irq(unsigned int irq);
-extern void amiga_disable_irq(unsigned int irq);
-
-struct hw_interrupt_type amiga_sys_irqctrl = {
-       .typename = "Amiga IPL",
-       .end = apus_end_irq,
-};
-
-struct hw_interrupt_type amiga_irqctrl = {
-       .typename = "Amiga    ",
-       .enable = amiga_enable_irq,
-       .disable = amiga_disable_irq,
-};
-
-#define HARDWARE_MAPPED_SIZE (512*1024)
-unsigned long __init apus_find_end_of_memory(void)
-{
-       int shadow = 0;
-       unsigned long total;
-
-       /* The memory size reported by ADOS excludes the 512KB
-          reserved for PPC exception registers and possibly 512KB
-          containing a shadow of the ADOS ROM. */
-       {
-               unsigned long size = memory[0].size;
-
-               /* If 2MB aligned, size was probably user
-                   specified. We can't tell anything about shadowing
-                   in this case so skip shadow assignment. */
-               if (0 != (size & 0x1fffff)){
-                       /* Align to 512KB to ensure correct handling
-                          of both memfile and system specified
-                          sizes. */
-                       size = ((size+0x0007ffff) & 0xfff80000);
-                       /* If memory is 1MB aligned, assume
-                           shadowing. */
-                       shadow = !(size & 0x80000);
-               }
-
-               /* Add the chunk that ADOS does not see. by aligning
-                   the size to the nearest 2MB limit upwards.  */
-               memory[0].size = ((size+0x001fffff) & 0xffe00000);
-       }
-
-       ppc_memstart = memory[0].addr;
-       ppc_memoffset = PAGE_OFFSET - PPC_MEMSTART;
-       total = memory[0].size;
-
-       /* Remove the memory chunks that are controlled by special
-           Phase5 hardware. */
-
-       /* Remove the upper 512KB if it contains a shadow of
-          the ADOS ROM. FIXME: It might be possible to
-          disable this shadow HW. Check the booter
-          (ppc_boot.c) */
-       if (shadow)
-               total -= HARDWARE_MAPPED_SIZE;
-
-       /* Remove the upper 512KB where the PPC exception
-          vectors are mapped. */
-       total -= HARDWARE_MAPPED_SIZE;
-
-       /* Linux/APUS only handles one block of memory -- the one on
-          the PowerUP board. Other system memory is horrible slow in
-          comparison. The user can use other memory for swapping
-          using the z2ram device. */
-       return total;
-}
-
-static void __init
-apus_map_io(void)
-{
-       /* Map PPC exception vectors. */
-       io_block_mapping(0xfff00000, 0xfff00000, 0x00020000, _PAGE_KERNEL);
-       /* Map chip and ZorroII memory */
-       io_block_mapping(zTwoBase,   0x00000000, 0x01000000, _PAGE_IO);
-}
-
-__init
-void apus_init_IRQ(void)
-{
-       struct irqaction *action;
-       int i;
-
-#ifdef CONFIG_PCI
-        apus_setup_pci_ptrs();
-#endif
-
-       for ( i = 0 ; i < AMI_IRQS; i++ ) {
-               irq_desc[i].status = IRQ_LEVEL;
-               if (i < IRQ_AMIGA_AUTO) {
-                       irq_desc[i].chip = &amiga_irqctrl;
-               } else {
-                       irq_desc[i].chip = &amiga_sys_irqctrl;
-                       action = &amiga_sys_irqaction[i-IRQ_AMIGA_AUTO];
-                       if (action->name)
-                               setup_irq(i, action);
-               }
-       }
-
-       amiga_init_IRQ();
-
-}
-
-__init
-void platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
-                  unsigned long r6, unsigned long r7)
-{
-       extern int parse_bootinfo(const struct bi_record *);
-       extern char _end[];
-
-       /* Parse bootinfo. The bootinfo is located right after
-           the kernel bss */
-       parse_bootinfo((const struct bi_record *)&_end);
-#ifdef CONFIG_BLK_DEV_INITRD
-       /* Take care of initrd if we have one. Use data from
-          bootinfo to avoid the need to initialize PPC
-          registers when kernel is booted via a PPC reset. */
-       if ( ramdisk.addr ) {
-               initrd_start = (unsigned long) __va(ramdisk.addr);
-               initrd_end = (unsigned long)
-                       __va(ramdisk.size + ramdisk.addr);
-       }
-#endif /* CONFIG_BLK_DEV_INITRD */
-
-       ISA_DMA_THRESHOLD = 0x00ffffff;
-
-       ppc_md.setup_arch     = apus_setup_arch;
-       ppc_md.show_cpuinfo   = apus_show_cpuinfo;
-       ppc_md.init_IRQ       = apus_init_IRQ;
-       ppc_md.get_irq        = apus_get_irq;
-
-#ifdef CONFIG_HEARTBEAT
-       ppc_md.heartbeat      = apus_heartbeat;
-       ppc_md.heartbeat_count = 1;
-#endif
-#ifdef APUS_DEBUG
-       __debug_serinit();
-       ppc_md.progress       = apus_progress;
-#endif
-       ppc_md.init           = NULL;
-
-       ppc_md.restart        = apus_restart;
-       ppc_md.power_off      = apus_power_off;
-       ppc_md.halt           = apus_halt;
-
-       ppc_md.time_init      = NULL;
-       ppc_md.set_rtc_time   = apus_set_rtc_time;
-       ppc_md.get_rtc_time   = apus_get_rtc_time;
-       ppc_md.calibrate_decr = apus_calibrate_decr;
-
-       ppc_md.find_end_of_memory = apus_find_end_of_memory;
-       ppc_md.setup_io_mappings = apus_map_io;
-}
index 0f66f0f82c329709f1124cabc6cfd8013c6e54ae..1644e44c8757667e575ec03268d02323b62e4145 100644 (file)
@@ -67,7 +67,7 @@ static __inline__ unsigned long ide_default_io_base(int index)
 #define ide_init_default_irq(base)     ide_default_irq(base)
 #endif
 
-#if (defined CONFIG_APUS || defined CONFIG_BLK_DEV_MPC8xx_IDE )
+#ifdef CONFIG_BLK_DEV_MPC8xx_IDE
 #define IDE_ARCH_ACK_INTR  1
 #define ide_ack_intr(hwif) (hwif->hw.ack_intr ? hwif->hw.ack_intr(hwif) : 1)
 #endif
index 347de53e49af208248b8b54923e9bc0d31e58c92..e775ff1ca413e96ff5cf8b926f1b08c6105f58bf 100644 (file)
 #else /* 32-bit */
 /* Default MSR for kernel mode. */
 #ifndef MSR_KERNEL     /* reg_booke.h also defines this */
-#ifdef CONFIG_APUS_FAST_EXCEPT
-#define MSR_KERNEL     (MSR_ME|MSR_IP|MSR_RI|MSR_IR|MSR_DR)
-#else
 #define MSR_KERNEL     (MSR_ME|MSR_RI|MSR_IR|MSR_DR)
 #endif
-#endif
 
 #define MSR_USER       (MSR_KERNEL|MSR_PR|MSR_EE)
 #endif
diff --git a/include/asm-ppc/amigahw.h b/include/asm-ppc/amigahw.h
deleted file mode 100644 (file)
index 90fd127..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-#ifdef __KERNEL__
-#ifndef __ASMPPC_AMIGAHW_H
-#define __ASMPPC_AMIGAHW_H
-
-#include <asm-m68k/amigahw.h>
-
-#undef CHIP_PHYSADDR
-#ifdef CONFIG_APUS_FAST_EXCEPT
-#define CHIP_PHYSADDR      (0x000000)
-#else
-#define CHIP_PHYSADDR      (0x004000)
-#endif
-
-
-#endif /* __ASMPPC_AMIGAHW_H */
-#endif /* __KERNEL__ */
diff --git a/include/asm-ppc/amigaints.h b/include/asm-ppc/amigaints.h
deleted file mode 100644 (file)
index aa3ff63..0000000
+++ /dev/null
@@ -1,133 +0,0 @@
-/*
-** amigaints.h -- Amiga Linux interrupt handling structs and prototypes
-**
-** Copyright 1992 by Greg Harp
-**
-** 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.
-**
-** Created 10/2/92 by Greg Harp
-*/
-
-#ifdef __KERNEL__
-#ifndef _ASMm68k_AMIGAINTS_H_
-#define _ASMm68k_AMIGAINTS_H_
-
-/*
-** Amiga Interrupt sources.
-**
-*/
-
-#define AUTO_IRQS           (8)
-#define AMI_STD_IRQS        (14)
-#define CIA_IRQS            (5)
-#define AMI_IRQS            (32) /* AUTO_IRQS+AMI_STD_IRQS+2*CIA_IRQS */
-
-/* vertical blanking interrupt */
-#define IRQ_AMIGA_VERTB     0
-
-/* copper interrupt */
-#define IRQ_AMIGA_COPPER    1
-
-/* Audio interrupts */
-#define IRQ_AMIGA_AUD0     2
-#define IRQ_AMIGA_AUD1     3
-#define IRQ_AMIGA_AUD2     4
-#define IRQ_AMIGA_AUD3     5
-
-/* Blitter done interrupt */
-#define IRQ_AMIGA_BLIT     6
-
-/* floppy disk interrupts */
-#define IRQ_AMIGA_DSKSYN    7
-#define IRQ_AMIGA_DSKBLK    8
-
-/* builtin serial port interrupts */
-#define IRQ_AMIGA_RBF      9
-#define IRQ_AMIGA_TBE      10
-
-/* software interrupts */
-#define IRQ_AMIGA_SOFT      11
-
-/* interrupts from external hardware */
-#define IRQ_AMIGA_PORTS            12
-#define IRQ_AMIGA_EXTER            13
-
-/* CIA interrupt sources */
-#define IRQ_AMIGA_CIAA      14
-#define IRQ_AMIGA_CIAA_TA   14
-#define IRQ_AMIGA_CIAA_TB   15
-#define IRQ_AMIGA_CIAA_ALRM 16
-#define IRQ_AMIGA_CIAA_SP   17
-#define IRQ_AMIGA_CIAA_FLG  18
-#define IRQ_AMIGA_CIAB      19
-#define IRQ_AMIGA_CIAB_TA   19
-#define IRQ_AMIGA_CIAB_TB   20
-#define IRQ_AMIGA_CIAB_ALRM 21
-#define IRQ_AMIGA_CIAB_SP   22
-#define IRQ_AMIGA_CIAB_FLG  23
-
-/* auto-vector interrupts */
-#define IRQ_AMIGA_AUTO      24
-#define IRQ_AMIGA_AUTO_0    24 /* This is just a dummy */
-#define IRQ_AMIGA_AUTO_1    25
-#define IRQ_AMIGA_AUTO_2    26
-#define IRQ_AMIGA_AUTO_3    27
-#define IRQ_AMIGA_AUTO_4    28
-#define IRQ_AMIGA_AUTO_5    29
-#define IRQ_AMIGA_AUTO_6    30
-#define IRQ_AMIGA_AUTO_7    31
-
-#define IRQ_FLOPPY         IRQ_AMIGA_DSKBLK
-
-/* INTREQR masks */
-#define IRQ1_MASK   0x0007     /* INTREQR mask for IRQ 1 */
-#define IRQ2_MASK   0x0008     /* INTREQR mask for IRQ 2 */
-#define IRQ3_MASK   0x0070     /* INTREQR mask for IRQ 3 */
-#define IRQ4_MASK   0x0780     /* INTREQR mask for IRQ 4 */
-#define IRQ5_MASK   0x1800     /* INTREQR mask for IRQ 5 */
-#define IRQ6_MASK   0x2000     /* INTREQR mask for IRQ 6 */
-#define IRQ7_MASK   0x4000     /* INTREQR mask for IRQ 7 */
-
-#define IF_SETCLR   0x8000      /* set/clr bit */
-#define IF_INTEN    0x4000     /* master interrupt bit in INT* registers */
-#define IF_EXTER    0x2000     /* external level 6 and CIA B interrupt */
-#define IF_DSKSYN   0x1000     /* disk sync interrupt */
-#define IF_RBF     0x0800      /* serial receive buffer full interrupt */
-#define IF_AUD3     0x0400     /* audio channel 3 done interrupt */
-#define IF_AUD2     0x0200     /* audio channel 2 done interrupt */
-#define IF_AUD1     0x0100     /* audio channel 1 done interrupt */
-#define IF_AUD0     0x0080     /* audio channel 0 done interrupt */
-#define IF_BLIT     0x0040     /* blitter done interrupt */
-#define IF_VERTB    0x0020     /* vertical blanking interrupt */
-#define IF_COPER    0x0010     /* copper interrupt */
-#define IF_PORTS    0x0008     /* external level 2 and CIA A interrupt */
-#define IF_SOFT     0x0004     /* software initiated interrupt */
-#define IF_DSKBLK   0x0002     /* diskblock DMA finished */
-#define IF_TBE     0x0001      /* serial transmit buffer empty interrupt */
-
-extern void amiga_do_irq(int irq, struct pt_regs *fp);
-extern void amiga_do_irq_list(int irq, struct pt_regs *fp);
-
-/* CIA interrupt control register bits */
-
-#define CIA_ICR_TA     0x01
-#define CIA_ICR_TB     0x02
-#define CIA_ICR_ALRM   0x04
-#define CIA_ICR_SP     0x08
-#define CIA_ICR_FLG    0x10
-#define CIA_ICR_ALL    0x1f
-#define CIA_ICR_SETCLR 0x80
-
-/* to access the interrupt control registers of CIA's use only
-** these functions, they behave exactly like the amiga os routines
-*/
-
-extern struct ciabase ciaa_base, ciab_base;
-
-extern unsigned char cia_set_irq(unsigned int irq, int set);
-extern unsigned char cia_able_irq(unsigned int irq, int enable);
-
-#endif /* asm-m68k/amigaints.h */
-#endif /* __KERNEL__ */
diff --git a/include/asm-ppc/amigappc.h b/include/asm-ppc/amigappc.h
deleted file mode 100644 (file)
index 35114ce..0000000
+++ /dev/null
@@ -1,85 +0,0 @@
-/*
-** asm-ppc/amigappc.h -- This header defines some values and pointers for
-**                        the Phase 5 PowerUp card.
-**
-** Copyright 1997, 1998 by Phase5, Germany.
-**
-** 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.
-**
-** Created: 7/22/97 by Jesper Skov
-*/
-
-#ifdef __KERNEL__
-#ifndef _M68K_AMIGAPPC_H
-#define _M68K_AMIGAPPC_H
-
-#ifndef __ASSEMBLY__
-
-/* #include <asm/system.h> */
-#define mb()  __asm__ __volatile__ ("sync" : : : "memory")
-
-#define APUS_WRITE(_a_, _v_)                           \
-do {                                                   \
-       (*((volatile unsigned char *)(_a_)) = (_v_));   \
-       mb();                                           \
-} while (0)
-
-#define APUS_READ(_a_, _v_)                            \
-do {                                                   \
-       (_v_) = (*((volatile unsigned char *)(_a_)));   \
-       mb();                                           \
-} while (0)
-#endif /* ndef __ASSEMBLY__ */
-
-/* Maybe add a [#ifdef WANT_ZTWOBASE] condition to amigahw.h? */
-#define zTwoBase (0x80000000)
-
-#define APUS_IPL_BASE          (zTwoBase + 0x00f60000)
-#define APUS_REG_RESET         (APUS_IPL_BASE + 0x00)
-#define APUS_REG_WAITSTATE     (APUS_IPL_BASE + 0x10)
-#define APUS_REG_SHADOW        (APUS_IPL_BASE + 0x18)
-#define APUS_REG_LOCK          (APUS_IPL_BASE + 0x20)
-#define APUS_REG_INT           (APUS_IPL_BASE + 0x28)
-#define APUS_IPL_EMU           (APUS_IPL_BASE + 0x30)
-#define APUS_INT_LVL           (APUS_IPL_BASE + 0x38)
-
-#define REGSHADOW_SETRESET     (0x80)
-#define REGSHADOW_SELFRESET    (0x40)
-
-#define REGLOCK_SETRESET       (0x80)
-#define REGLOCK_BLACKMAGICK1   (0x40)
-#define REGLOCK_BLACKMAGICK2   (0x20)
-#define REGLOCK_BLACKMAGICK3   (0x10)
-
-#define REGWAITSTATE_SETRESET  (0x80)
-#define REGWAITSTATE_PPCW      (0x08)
-#define REGWAITSTATE_PPCR      (0x04)
-
-#define REGRESET_SETRESET      (0x80)
-#define REGRESET_PPCRESET      (0x10)
-#define REGRESET_M68KRESET     (0x08)
-#define REGRESET_AMIGARESET    (0x04)
-#define REGRESET_AUXRESET      (0x02)
-#define REGRESET_SCSIRESET     (0x01)
-
-#define REGINT_SETRESET                (0x80)
-#define REGINT_ENABLEIPL       (0x02)
-#define REGINT_INTMASTER       (0x01)
-
-#define IPLEMU_SETRESET                (0x80)
-#define IPLEMU_DISABLEINT      (0x40)
-#define IPLEMU_IPL2            (0x20)
-#define IPLEMU_IPL1            (0x10)
-#define IPLEMU_IPL0            (0x08)
-#define IPLEMU_PPCIPL2         (0x04)
-#define IPLEMU_PPCIPL1         (0x02)
-#define IPLEMU_PPCIPL0         (0x01)
-#define IPLEMU_IPLMASK         (IPLEMU_PPCIPL2|IPLEMU_PPCIPL1|IPLEMU_PPCIPL0)
-
-#define INTLVL_SETRESET         (0x80)
-#define INTLVL_MASK             (0x7f)
-
-#endif /* _M68k_AMIGAPPC_H */
-#endif /* __KERNEL__ */
index 2ace4a74f26327cba677492f2f074a9524383b10..f6ed77aee3281c7dc046faccee5065b6d1b31088 100644 (file)
 
 #include <asm/page.h>
 
-#if defined(CONFIG_APUS) && !defined(__BOOTER__)
-#include <asm-m68k/bootinfo.h>
-#else
-
 struct bi_record {
        unsigned long tag;              /* tag ID */
        unsigned long size;             /* size of record (in bytes) */
@@ -44,7 +40,6 @@ bootinfo_addr(unsigned long offset)
        return (struct bi_record *)_ALIGN((offset) + (1 << 20) - 1,
                                          (1 << 20));
 }
-#endif /* CONFIG_APUS */
 
 
 #endif /* _PPC_BOOTINFO_H */
index f776c49f5579442f229ac2795766f68ab18ab5fe..8f58231a8bc67bdf490182294036b2e2a05733b3 100644 (file)
@@ -30,7 +30,7 @@
 #include <asm/mpc8xx.h>
 #elif defined(CONFIG_8260)
 #include <asm/mpc8260.h>
-#elif defined(CONFIG_APUS) || !defined(CONFIG_PCI)
+#elif !defined(CONFIG_PCI)
 #define _IO_BASE       0
 #define _ISA_MEM_BASE  0
 #define PCI_DRAM_OFFSET 0
@@ -145,24 +145,7 @@ static inline void writeb(__u8 b, volatile void __iomem *addr)
 }
 #endif
 
-#if defined(CONFIG_APUS)
-static inline __u16 readw(const volatile void __iomem *addr)
-{
-       return *(__force volatile __u16 *)(addr);
-}
-static inline __u32 readl(const volatile void __iomem *addr)
-{
-       return *(__force volatile __u32 *)(addr);
-}
-static inline void writew(__u16 b, volatile void __iomem *addr)
-{
-       *(__force volatile __u16 *)(addr) = b;
-}
-static inline void writel(__u32 b, volatile void __iomem *addr)
-{
-       *(__force volatile __u32 *)(addr) = b;
-}
-#elif defined (CONFIG_8260_PCI9)
+#if defined (CONFIG_8260_PCI9)
 /* Use macros if PCI9 workaround enabled */
 #define readw(addr) in_le16((volatile u16 *)(addr))
 #define readl(addr) in_le32((volatile u32 *)(addr))
@@ -185,7 +168,7 @@ static inline void writel(__u32 b, volatile void __iomem *addr)
 {
        out_le32(addr, b);
 }
-#endif /* CONFIG_APUS */
+#endif /* CONFIG_8260_PCI9 */
 
 #define readb_relaxed(addr) readb(addr)
 #define readw_relaxed(addr) readw(addr)
@@ -300,13 +283,7 @@ extern __inline__ void name(unsigned int val, unsigned int port) \
 }
 
 __do_out_asm(outb, "stbx")
-#ifdef CONFIG_APUS
-__do_in_asm(inb, "lbzx")
-__do_in_asm(inw, "lhz%U1%X1")
-__do_in_asm(inl, "lwz%U1%X1")
-__do_out_asm(outl,"stw%U0%X0")
-__do_out_asm(outw, "sth%U0%X0")
-#elif defined (CONFIG_8260_PCI9)
+#if defined (CONFIG_8260_PCI9)
 /* in asm cannot be defined if PCI9 workaround is used */
 #define inb(port)              in_8((port)+___IO_BASE)
 #define inw(port)              in_le16((port)+___IO_BASE)
@@ -371,7 +348,6 @@ extern void __iomem *ioremap64(unsigned long long address, unsigned long size);
 #define ioremap_nocache(addr, size)    ioremap((addr), (size))
 extern void iounmap(volatile void __iomem *addr);
 extern unsigned long iopa(unsigned long addr);
-extern unsigned long mm_ptov(unsigned long addr) __attribute_const__;
 extern void io_block_mapping(unsigned long virt, phys_addr_t phys,
                             unsigned int size, int flags);
 
@@ -384,24 +360,16 @@ extern void io_block_mapping(unsigned long virt, phys_addr_t phys,
  */
 extern inline unsigned long virt_to_bus(volatile void * address)
 {
-#ifndef CONFIG_APUS
         if (address == (void *)0)
                return 0;
         return (unsigned long)address - KERNELBASE + PCI_DRAM_OFFSET;
-#else
-       return iopa ((unsigned long) address);
-#endif
 }
 
 extern inline void * bus_to_virt(unsigned long address)
 {
-#ifndef CONFIG_APUS
         if (address == 0)
                return NULL;
         return (void *)(address - PCI_DRAM_OFFSET + KERNELBASE);
-#else
-       return (void*) mm_ptov (address);
-#endif
 }
 
 /*
@@ -410,20 +378,12 @@ extern inline void * bus_to_virt(unsigned long address)
  */
 extern inline unsigned long virt_to_phys(volatile void * address)
 {
-#ifndef CONFIG_APUS
        return (unsigned long) address - KERNELBASE;
-#else
-       return iopa ((unsigned long) address);
-#endif
 }
 
 extern inline void * phys_to_virt(unsigned long address)
 {
-#ifndef CONFIG_APUS
        return (void *) (address + KERNELBASE);
-#else
-       return (void*) mm_ptov (address);
-#endif
 }
 
 /*
index 293a444a1d7724d057528655336f6e96a2a943cd..a20b499b0186c6606aa8be36f5a182314c5ed0ae 100644 (file)
@@ -8,10 +8,6 @@
 #include <asm/setup.h>
 #include <asm/page.h>
 
-#ifdef CONFIG_APUS
-#include <asm-m68k/machdep.h>
-#endif
-
 struct pt_regs;
 struct pci_bus;        
 struct pci_dev;
index fe95c8258cf9f3e40397b97149fd651e61fa8c13..ad4c5a1bc9d658daab08ca0825d55cb728e1b8a2 100644 (file)
@@ -97,62 +97,22 @@ extern void clear_user_page(void *page, unsigned long vaddr, struct page *pg);
 extern void copy_user_page(void *to, void *from, unsigned long vaddr,
                           struct page *pg);
 
-#ifndef CONFIG_APUS
 #define PPC_MEMSTART   0
-#define PPC_PGSTART    0
 #define PPC_MEMOFFSET  PAGE_OFFSET
-#else
-extern unsigned long ppc_memstart;
-extern unsigned long ppc_pgstart;
-extern unsigned long ppc_memoffset;
-#define PPC_MEMSTART   ppc_memstart
-#define PPC_PGSTART    ppc_pgstart
-#define PPC_MEMOFFSET  ppc_memoffset
-#endif
 
-#if defined(CONFIG_APUS) && !defined(MODULE)
-/* map phys->virtual and virtual->phys for RAM pages */
-static inline unsigned long ___pa(unsigned long v)
-{
-       unsigned long p;
-       asm volatile ("1: addis %0, %1, %2;"
-                     ".section \".vtop_fixup\",\"aw\";"
-                     ".align  1;"
-                     ".long   1b;"
-                     ".previous;"
-                     : "=r" (p)
-                     : "b" (v), "K" (((-PAGE_OFFSET) >> 16) & 0xffff));
-
-       return p;
-}
-static inline void* ___va(unsigned long p)
-{
-       unsigned long v;
-       asm volatile ("1: addis %0, %1, %2;"
-                     ".section \".ptov_fixup\",\"aw\";"
-                     ".align  1;"
-                     ".long   1b;"
-                     ".previous;"
-                     : "=r" (v)
-                     : "b" (p), "K" (((PAGE_OFFSET) >> 16) & 0xffff));
-
-       return (void*) v;
-}
-#else
 #define ___pa(vaddr) ((vaddr)-PPC_MEMOFFSET)
 #define ___va(paddr) ((paddr)+PPC_MEMOFFSET)
-#endif
 
 extern int page_is_ram(unsigned long pfn);
 
 #define __pa(x) ___pa((unsigned long)(x))
 #define __va(x) ((void *)(___va((unsigned long)(x))))
 
-#define ARCH_PFN_OFFSET                (PPC_PGSTART)
+#define ARCH_PFN_OFFSET                0
 #define virt_to_page(kaddr)    pfn_to_page(__pa(kaddr) >> PAGE_SHIFT)
 #define page_to_virt(page)     __va(page_to_pfn(page) << PAGE_SHIFT)
 
-#define pfn_valid(pfn)         (((pfn) - PPC_PGSTART) < max_mapnr)
+#define pfn_valid(pfn)         ((pfn) < max_mapnr)
 #define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT)
 
 /* Pure 2^n version of get_order */
index c159315d2c8f0f31d5903f1805b2a2429dd38320..063ad91cbbcc273e3fa69c9b51e3c957f6fc1538 100644 (file)
@@ -765,14 +765,6 @@ extern void paging_init(void);
 #define pte_to_pgoff(pte)      (pte_val(pte) >> 3)
 #define pgoff_to_pte(off)      ((pte_t) { ((off) << 3) | _PAGE_FILE })
 
-/* CONFIG_APUS */
-/* For virtual address to physical address conversion */
-extern void cache_clear(__u32 addr, int length);
-extern void cache_push(__u32 addr, int length);
-extern int mm_end_of_chunk (unsigned long addr, int len);
-extern unsigned long iopa(unsigned long addr);
-extern unsigned long mm_ptov(unsigned long addr) __attribute_const__;
-
 /* Values for nocacheflag and cmode */
 /* These are not used by the APUS kernel_map, but prevents
    compilation errors. */