]> err.no Git - linux-2.6/commitdiff
Merge branch 'merge' into powerpc-next
authorPaul Mackerras <paulus@samba.org>
Fri, 23 May 2008 06:53:23 +0000 (16:53 +1000)
committerPaul Mackerras <paulus@samba.org>
Fri, 23 May 2008 06:53:23 +0000 (16:53 +1000)
67 files changed:
arch/powerpc/kernel/entry_32.S
arch/powerpc/kernel/head_booke.h
arch/powerpc/kernel/kprobes.c
arch/powerpc/kernel/lparcfg.c
arch/powerpc/kernel/machine_kexec_64.c
arch/powerpc/kernel/msi.c
arch/powerpc/kernel/of_device.c
arch/powerpc/kernel/rtas-proc.c
arch/powerpc/kernel/rtas.c
arch/powerpc/kernel/rtas_flash.c
arch/powerpc/kernel/rtas_pci.c
arch/powerpc/kernel/signal.c
arch/powerpc/kernel/signal_32.c
arch/powerpc/kernel/smp.c
arch/powerpc/kernel/time.c
arch/powerpc/kernel/vdso64/vdso64.lds.S
arch/powerpc/mm/hash_utils_64.c
arch/powerpc/mm/init_32.c
arch/powerpc/mm/init_64.c
arch/powerpc/mm/stab.c
arch/powerpc/mm/tlb_64.c
arch/powerpc/platforms/cell/axon_msi.c
arch/powerpc/platforms/chrp/setup.c
arch/powerpc/platforms/maple/time.c
arch/powerpc/platforms/powermac/pic.c
arch/powerpc/platforms/pseries/firmware.c
arch/powerpc/platforms/pseries/iommu.c
arch/powerpc/platforms/pseries/lpar.c
arch/powerpc/platforms/pseries/ras.c
arch/powerpc/platforms/pseries/rtasd.c
arch/powerpc/platforms/pseries/setup.c
arch/powerpc/sysdev/6xx-suspend.S [new file with mode: 0644]
arch/powerpc/sysdev/Makefile
arch/powerpc/sysdev/mpic.c
arch/powerpc/sysdev/mpic_msi.c
arch/powerpc/sysdev/mpic_pasemi_msi.c
arch/powerpc/sysdev/mpic_u3msi.c
arch/powerpc/sysdev/mv64x60_dev.c
arch/powerpc/xmon/xmon.c
arch/ppc/kernel/entry.S
drivers/char/hvc_console.c
drivers/char/hvc_console.h
drivers/macintosh/macio_sysfs.c
drivers/net/Kconfig
drivers/net/Makefile
drivers/net/fec_8xx/Kconfig [deleted file]
drivers/net/fec_8xx/Makefile [deleted file]
drivers/net/fec_8xx/fec_8xx-netta.c [deleted file]
drivers/net/fec_8xx/fec_8xx.h [deleted file]
drivers/net/fec_8xx/fec_main.c [deleted file]
drivers/net/fec_8xx/fec_mii.c [deleted file]
drivers/of/device.c
drivers/of/gpio.c
drivers/of/platform.c
include/asm-powerpc/ioctl.h
include/asm-powerpc/mmu-hash64.h
include/asm-powerpc/mpc6xx.h [new file with mode: 0644]
include/asm-powerpc/mpic.h
include/asm-powerpc/of_device.h
include/asm-powerpc/ppc_asm.h
include/asm-powerpc/ptrace.h
include/asm-powerpc/smp.h
include/asm-powerpc/system.h
include/asm-powerpc/thread_info.h
include/asm-powerpc/time.h
include/asm-powerpc/xmon.h
include/linux/of_device.h

index 0c8614d9875ca8b5966c148c7ad447bbcf3a987d..888a364043a83ad0d1dea405e2d6a84442ebbb2f 100644 (file)
@@ -147,6 +147,7 @@ transfer_to_handler:
        lwz     r12,TI_LOCAL_FLAGS(r9)
        mtcrf   0x01,r12
        bt-     31-TLF_NAPPING,4f
+       bt-     31-TLF_SLEEPING,7f
 #endif /* CONFIG_6xx */
        .globl transfer_to_handler_cont
 transfer_to_handler_cont:
@@ -164,6 +165,13 @@ transfer_to_handler_cont:
 4:     rlwinm  r12,r12,0,~_TLF_NAPPING
        stw     r12,TI_LOCAL_FLAGS(r9)
        b       power_save_6xx_restore
+
+7:     rlwinm  r12,r12,0,~_TLF_SLEEPING
+       stw     r12,TI_LOCAL_FLAGS(r9)
+       lwz     r9,_MSR(r11)            /* if sleeping, clear MSR.EE */
+       rlwinm  r9,r9,0,~MSR_EE
+       lwz     r12,_LINK(r11)          /* and return to address in LR */
+       b       fast_exception_return
 #endif
 
 /*
@@ -668,7 +676,7 @@ user_exc_return:            /* r10 contains MSR_KERNEL here */
        /* Check current_thread_info()->flags */
        rlwinm  r9,r1,0,0,(31-THREAD_SHIFT)
        lwz     r9,TI_FLAGS(r9)
-       andi.   r0,r9,(_TIF_SIGPENDING|_TIF_RESTORE_SIGMASK|_TIF_NEED_RESCHED)
+       andi.   r0,r9,_TIF_USER_WORK_MASK
        bne     do_work
 
 restore_user:
@@ -925,7 +933,7 @@ recheck:
        lwz     r9,TI_FLAGS(r9)
        andi.   r0,r9,_TIF_NEED_RESCHED
        bne-    do_resched
-       andi.   r0,r9,_TIF_SIGPENDING|_TIF_RESTORE_SIGMASK
+       andi.   r0,r9,_TIF_USER_WORK_MASK
        beq     restore_user
 do_user_signal:                        /* r10 contains MSR_KERNEL here */
        ori     r10,r10,MSR_EE
index aefafc6330c9497be4d7c8c8b2cf9f5e63b51749..721faef870954459ac2cafafa10397c835a95d48 100644 (file)
@@ -272,7 +272,7 @@ label:
        /* continue normal handling for a critical exception... */            \
 2:     mfspr   r4,SPRN_DBSR;                                                 \
        addi    r3,r1,STACK_FRAME_OVERHEAD;                                   \
-       EXC_XFER_TEMPLATE(DebugException, 0x2002, (MSR_KERNEL & ~(MSR_ME|MSR_DE|MSR_CE)), NOCOPY, debug_transfer_to_handler, ret_from_debug_exc)
+       EXC_XFER_TEMPLATE(DebugException, 0x2008, (MSR_KERNEL & ~(MSR_ME|MSR_DE|MSR_CE)), NOCOPY, debug_transfer_to_handler, ret_from_debug_exc)
 
 #define DEBUG_CRIT_EXCEPTION                                                 \
        START_EXCEPTION(DebugCrit);                                           \
index c176c513566b3c1a179661bae346142fa5cd4bd0..23545a2f51f34d40c02f44840eb607985c5ddc4c 100644 (file)
@@ -498,7 +498,7 @@ int __kprobes kprobe_exceptions_notify(struct notifier_block *self,
 #ifdef CONFIG_PPC64
 unsigned long arch_deref_entry_point(void *entry)
 {
-       return (unsigned long)(((func_descr_t *)entry)->entry);
+       return ((func_descr_t *)entry)->entry;
 }
 #endif
 
index 1e656b43ad7fb87f45a71c393e9f96ea5e18a504..827a5726a035c9a11d5a182b59b5c2c33f2ab618 100644 (file)
@@ -573,7 +573,7 @@ static int lparcfg_open(struct inode *inode, struct file *file)
        return single_open(file, lparcfg_data, NULL);
 }
 
-const struct file_operations lparcfg_fops = {
+static const struct file_operations lparcfg_fops = {
        .owner          = THIS_MODULE,
        .read           = seq_read,
        .write          = lparcfg_write,
@@ -581,7 +581,7 @@ const struct file_operations lparcfg_fops = {
        .release        = single_release,
 };
 
-int __init lparcfg_init(void)
+static int __init lparcfg_init(void)
 {
        struct proc_dir_entry *ent;
        mode_t mode = S_IRUSR | S_IRGRP | S_IROTH;
@@ -601,7 +601,7 @@ int __init lparcfg_init(void)
        return 0;
 }
 
-void __exit lparcfg_cleanup(void)
+static void __exit lparcfg_cleanup(void)
 {
        if (proc_ppc64_lparcfg)
                remove_proc_entry("lparcfg", proc_ppc64_lparcfg->parent);
index 704375bda73a928446bb87ba68e492659be093a0..631dfd614b218e95798ae035698bfd7d21744ced 100644 (file)
@@ -158,7 +158,7 @@ void kexec_copy_flush(struct kimage *image)
  * on calling the interrupts, but we would like to call it off irq level
  * so that the interrupt controller is clean.
  */
-void kexec_smp_down(void *arg)
+static void kexec_smp_down(void *arg)
 {
        if (ppc_md.kexec_cpu_down)
                ppc_md.kexec_cpu_down(0, 1);
@@ -249,7 +249,7 @@ static void kexec_prepare_cpus(void)
  * We could use a smaller stack if we don't care about anything using
  * current, but that audit has not been performed.
  */
-union thread_union kexec_stack
+static union thread_union kexec_stack
        __attribute__((__section__(".data.init_task"))) = { };
 
 /* Our assembly helper, in kexec_stub.S */
index c62d1012c01322354309aaaf7b78a0d689070c54..3bb7d3dd28be9e20d6e013127426e8c9c96e4861 100644 (file)
@@ -34,5 +34,5 @@ int arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type)
 
 void arch_teardown_msi_irqs(struct pci_dev *dev)
 {
-       return ppc_md.teardown_msi_irqs(dev);
+       ppc_md.teardown_msi_irqs(dev);
 }
index 5748ddb47d9f82fc332b844e56613d3a6e84a07b..e9be908f199b6fa46ee4ec2226316db2ad1702c6 100644 (file)
@@ -89,54 +89,6 @@ struct of_device *of_device_alloc(struct device_node *np,
 }
 EXPORT_SYMBOL(of_device_alloc);
 
-ssize_t of_device_get_modalias(struct of_device *ofdev,
-                               char *str, ssize_t len)
-{
-       const char *compat;
-       int cplen, i;
-       ssize_t tsize, csize, repend;
-
-       /* Name & Type */
-       csize = snprintf(str, len, "of:N%sT%s",
-                               ofdev->node->name, ofdev->node->type);
-
-       /* Get compatible property if any */
-       compat = of_get_property(ofdev->node, "compatible", &cplen);
-       if (!compat)
-               return csize;
-
-       /* Find true end (we tolerate multiple \0 at the end */
-       for (i=(cplen-1); i>=0 && !compat[i]; i--)
-               cplen--;
-       if (!cplen)
-               return csize;
-       cplen++;
-
-       /* Check space (need cplen+1 chars including final \0) */
-       tsize = csize + cplen;
-       repend = tsize;
-
-       if (csize>=len)         /* @ the limit, all is already filled */
-               return tsize;
-
-       if (tsize>=len) {               /* limit compat list */
-               cplen = len-csize-1;
-               repend = len;
-       }
-
-       /* Copy and do char replacement */
-       memcpy(&str[csize+1], compat, cplen);
-       for (i=csize; i<repend; i++) {
-               char c = str[i];
-               if (c=='\0')
-                       str[i] = 'C';
-               else if (c==' ')
-                       str[i] = '_';
-       }
-
-       return tsize;
-}
-
 int of_device_uevent(struct device *dev, struct kobj_uevent_env *env)
 {
        struct of_device *ofdev;
index f9c6abc84a9483a9fce2fb496642ec863f369fa3..1be9fe38bcb570f990f5b5f462913c3c75929ef1 100644 (file)
@@ -160,7 +160,7 @@ static int sensors_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_sensors_show, NULL);
 }
 
-const struct file_operations ppc_rtas_sensors_operations = {
+static const struct file_operations ppc_rtas_sensors_operations = {
        .open           = sensors_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
@@ -172,7 +172,7 @@ static int poweron_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_poweron_show, NULL);
 }
 
-const struct file_operations ppc_rtas_poweron_operations = {
+static const struct file_operations ppc_rtas_poweron_operations = {
        .open           = poweron_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
@@ -185,7 +185,7 @@ static int progress_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_progress_show, NULL);
 }
 
-const struct file_operations ppc_rtas_progress_operations = {
+static const struct file_operations ppc_rtas_progress_operations = {
        .open           = progress_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
@@ -198,7 +198,7 @@ static int clock_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_clock_show, NULL);
 }
 
-const struct file_operations ppc_rtas_clock_operations = {
+static const struct file_operations ppc_rtas_clock_operations = {
        .open           = clock_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
@@ -211,7 +211,7 @@ static int tone_freq_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_tone_freq_show, NULL);
 }
 
-const struct file_operations ppc_rtas_tone_freq_operations = {
+static const struct file_operations ppc_rtas_tone_freq_operations = {
        .open           = tone_freq_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
@@ -224,7 +224,7 @@ static int tone_volume_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_tone_volume_show, NULL);
 }
 
-const struct file_operations ppc_rtas_tone_volume_operations = {
+static const struct file_operations ppc_rtas_tone_volume_operations = {
        .open           = tone_volume_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
@@ -237,7 +237,7 @@ static int rmo_buf_open(struct inode *inode, struct file *file)
        return single_open(file, ppc_rtas_rmo_buf_show, NULL);
 }
 
-const struct file_operations ppc_rtas_rmo_buf_ops = {
+static const struct file_operations ppc_rtas_rmo_buf_ops = {
        .open           = rmo_buf_open,
        .read           = seq_read,
        .llseek         = seq_lseek,
index 34843c318419012e73195b8837345b232e4dca85..2a60bd3e3afa326e166dd03994d5439243b6a119 100644 (file)
@@ -340,8 +340,8 @@ int rtas_get_error_log_max(void)
 EXPORT_SYMBOL(rtas_get_error_log_max);
 
 
-char rtas_err_buf[RTAS_ERROR_LOG_MAX];
-int rtas_last_error_token;
+static char rtas_err_buf[RTAS_ERROR_LOG_MAX];
+static int rtas_last_error_token;
 
 /** Return a copy of the detailed error text associated with the
  *  most recent failed call to rtas.  Because the error text
@@ -484,7 +484,7 @@ unsigned int rtas_busy_delay(int status)
 }
 EXPORT_SYMBOL(rtas_busy_delay);
 
-int rtas_error_rc(int rtas_rc)
+static int rtas_error_rc(int rtas_rc)
 {
        int rc;
 
index 0a5e22b22729f6b70443c1b0c9fb622aca4ea26e..09ded5c424a967cdaa0c1f5817bd7e301b971f60 100644 (file)
@@ -731,7 +731,7 @@ static const struct file_operations validate_flash_operations = {
        .release        = validate_flash_release,
 };
 
-int __init rtas_flash_init(void)
+static int __init rtas_flash_init(void)
 {
        int rc;
 
@@ -817,7 +817,7 @@ cleanup:
        return rc;
 }
 
-void __exit rtas_flash_cleanup(void)
+static void __exit rtas_flash_cleanup(void)
 {
        rtas_flash_term_hook = NULL;
 
index 3ab88a9dc70dd0686c3d7c29d125fb42b753f6f7..589a2797eac2006075af50ee60e6bff836f3882c 100644 (file)
@@ -155,12 +155,12 @@ static int rtas_pci_write_config(struct pci_bus *bus,
        return PCIBIOS_DEVICE_NOT_FOUND;
 }
 
-struct pci_ops rtas_pci_ops = {
+static struct pci_ops rtas_pci_ops = {
        .read = rtas_pci_read_config,
        .write = rtas_pci_write_config,
 };
 
-int is_python(struct device_node *dev)
+static int is_python(struct device_node *dev)
 {
        const char *model = of_get_property(dev, "model", NULL);
 
index a65a44fbe52375c5b1b5ca7a8deb33305ab11536..ad55488939c376f7073b0770ca79ad1f5954ca1e 100644 (file)
@@ -120,7 +120,7 @@ int do_signal(sigset_t *oldset, struct pt_regs *regs)
        int ret;
        int is32 = is_32bit_task();
 
-       if (test_thread_flag(TIF_RESTORE_SIGMASK))
+       if (current_thread_info()->local_flags & _TLF_RESTORE_SIGMASK)
                oldset = &current->saved_sigmask;
        else if (!oldset)
                oldset = &current->blocked;
@@ -131,9 +131,10 @@ int do_signal(sigset_t *oldset, struct pt_regs *regs)
        check_syscall_restart(regs, &ka, signr > 0);
 
        if (signr <= 0) {
+               struct thread_info *ti = current_thread_info();
                /* No signal to deliver -- put the saved sigmask back */
-               if (test_thread_flag(TIF_RESTORE_SIGMASK)) {
-                       clear_thread_flag(TIF_RESTORE_SIGMASK);
+               if (ti->local_flags & _TLF_RESTORE_SIGMASK) {
+                       ti->local_flags &= ~_TLF_RESTORE_SIGMASK;
                        sigprocmask(SIG_SETMASK, &current->saved_sigmask, NULL);
                }
                return 0;               /* no signals delivered */
@@ -169,10 +170,9 @@ int do_signal(sigset_t *oldset, struct pt_regs *regs)
 
                /*
                 * A signal was successfully delivered; the saved sigmask is in
-                * its frame, and we can clear the TIF_RESTORE_SIGMASK flag.
+                * its frame, and we can clear the TLF_RESTORE_SIGMASK flag.
                 */
-               if (test_thread_flag(TIF_RESTORE_SIGMASK))
-                       clear_thread_flag(TIF_RESTORE_SIGMASK);
+               current_thread_info()->local_flags &= ~_TLF_RESTORE_SIGMASK;
        }
 
        return ret;
index ad6943468ee9f25aee853a3ded8f99271f1c3d72..4ae16d179803ef6071cd07909b86dd91ad032b62 100644 (file)
@@ -243,7 +243,7 @@ long sys_sigsuspend(old_sigset_t mask)
 
        current->state = TASK_INTERRUPTIBLE;
        schedule();
-       set_thread_flag(TIF_RESTORE_SIGMASK);
+       set_restore_sigmask();
        return -ERESTARTNOHAND;
 }
 
index 1457aa0a08f136355347adcbe122a3d2c1692ba2..ba7989ffaeeed50245562c429af4871abaca3f4c 100644 (file)
@@ -365,12 +365,8 @@ void smp_call_function_interrupt(void)
        }
 }
 
-extern struct gettimeofday_struct do_gtod;
-
 struct thread_info *current_set[NR_CPUS];
 
-DECLARE_PER_CPU(unsigned int, pvr);
-
 static void __devinit smp_store_cpu_info(int id)
 {
        per_cpu(pvr, id) = mfspr(SPRN_PVR);
index 73401e83739a09b4dcefdaecc84451c018607ca5..c73fc33aa817a93f49b682fcb999f1f5c5fe61e0 100644 (file)
@@ -129,7 +129,7 @@ static unsigned long __initdata iSeries_recal_titan;
 static signed long __initdata iSeries_recal_tb;
 
 /* Forward declaration is only needed for iSereis compiles */
-void __init clocksource_init(void);
+static void __init clocksource_init(void);
 #endif
 
 #define XSEC_PER_SEC (1024*1024)
@@ -150,8 +150,8 @@ u64 tb_to_xs;
 unsigned tb_to_us;
 
 #define TICKLEN_SCALE  NTP_SCALE_SHIFT
-u64 last_tick_len;     /* units are ns / 2^TICKLEN_SCALE */
-u64 ticklen_to_xs;     /* 0.64 fraction */
+static u64 last_tick_len;      /* units are ns / 2^TICKLEN_SCALE */
+static u64 ticklen_to_xs;      /* 0.64 fraction */
 
 /* If last_tick_len corresponds to about 1/HZ seconds, then
    last_tick_len << TICKLEN_SHIFT will be about 2^63. */
@@ -164,7 +164,7 @@ static u64 tb_to_ns_scale __read_mostly;
 static unsigned tb_to_ns_shift __read_mostly;
 static unsigned long boot_tb __read_mostly;
 
-struct gettimeofday_struct do_gtod;
+static struct gettimeofday_struct do_gtod;
 
 extern struct timezone sys_tz;
 static long timezone_offset;
@@ -832,7 +832,7 @@ void update_vsyscall_tz(void)
        ++vdso_data->tb_update_count;
 }
 
-void __init clocksource_init(void)
+static void __init clocksource_init(void)
 {
        struct clocksource *clock;
 
index 932b3fdb34b93ced7bd2c10da184f67ff906a66b..7d6585f902776dce82bebe7c018d46409101259c 100644 (file)
@@ -43,15 +43,15 @@ SECTIONS
        .rodata         : { *(.rodata .rodata.* .gnu.linkonce.r.*) }
        .rodata1        : { *(.rodata1) }
 
+       .dynamic        : { *(.dynamic) }               :text   :dynamic
+
        .eh_frame_hdr   : { *(.eh_frame_hdr) }          :text   :eh_frame_hdr
        .eh_frame       : { KEEP (*(.eh_frame)) }       :text
        .gcc_except_table : { *(.gcc_except_table) }
+       .rela.dyn ALIGN(8) : { *(.rela.dyn) }
 
        .opd ALIGN(8)   : { KEEP (*(.opd)) }
        .got ALIGN(8)   : { *(.got .toc) }
-       .rela.dyn ALIGN(8) : { *(.rela.dyn) }
-
-       .dynamic        : { *(.dynamic) }               :text   :dynamic
 
        _end = .;
        PROVIDE(end = .);
index 0f2d239d94c440608dadf79671b4b95f6cf4e0e9..bf5b6d7ed30f02de3507f62e1f586d8a4cf8bd93 100644 (file)
@@ -120,7 +120,7 @@ static DEFINE_SPINLOCK(linear_map_hash_lock);
 
 /* Pre-POWER4 CPUs (4k pages only)
  */
-struct mmu_psize_def mmu_psize_defaults_old[] = {
+static struct mmu_psize_def mmu_psize_defaults_old[] = {
        [MMU_PAGE_4K] = {
                .shift  = 12,
                .sllp   = 0,
@@ -134,7 +134,7 @@ struct mmu_psize_def mmu_psize_defaults_old[] = {
  *
  * Support for 16Mb large pages
  */
-struct mmu_psize_def mmu_psize_defaults_gp[] = {
+static struct mmu_psize_def mmu_psize_defaults_gp[] = {
        [MMU_PAGE_4K] = {
                .shift  = 12,
                .sllp   = 0,
@@ -533,8 +533,6 @@ void __init htab_initialize(void)
        unsigned long base = 0, size = 0, limit;
        int i;
 
-       extern unsigned long tce_alloc_start, tce_alloc_end;
-
        DBG(" -> htab_initialize()\n");
 
        /* Initialize segment sizes */
index 1952b4d3fa7f562eeec7d272205e4393870ab4c5..45418590b6a925587aa9bfb16c3e0c6eb9691524 100644 (file)
@@ -43,6 +43,7 @@
 #include <asm/btext.h>
 #include <asm/tlb.h>
 #include <asm/sections.h>
+#include <asm/system.h>
 
 #include "mmu_decl.h"
 
@@ -76,8 +77,6 @@ void MMU_init(void);
 /* XXX should be in current.h  -- paulus */
 extern struct task_struct *current_set[NR_CPUS];
 
-extern int init_bootmem_done;
-
 /*
  * this tells the system to map all of ram with the segregs
  * (i.e. page tables) instead of the bats.
index 6aa65375abf5919ce2b02c0efe309dd8d39c893c..6ef63caca6822bdfaa29b8884c8b06873acd33a7 100644 (file)
@@ -185,7 +185,7 @@ void pgtable_cache_init(void)
  * do this by hand as the proffered address may not be correctly aligned.
  * Subtraction of non-aligned pointers produces undefined results.
  */
-unsigned long __meminit vmemmap_section_start(unsigned long page)
+static unsigned long __meminit vmemmap_section_start(unsigned long page)
 {
        unsigned long offset = page - ((unsigned long)(vmemmap));
 
@@ -198,7 +198,7 @@ unsigned long __meminit vmemmap_section_start(unsigned long page)
  * which overlaps this vmemmap page is initialised then this page is
  * initialised already.
  */
-int __meminit vmemmap_populated(unsigned long start, int page_size)
+static int __meminit vmemmap_populated(unsigned long start, int page_size)
 {
        unsigned long end = start + page_size;
 
index efbbd13d93e519bcfd30ebb5da48f0f87b2672f0..60e6032a8088eb8197eab6c0505ec18bb5cd4e20 100644 (file)
@@ -30,8 +30,8 @@ struct stab_entry {
 };
 
 #define NR_STAB_CACHE_ENTRIES 8
-DEFINE_PER_CPU(long, stab_cache_ptr);
-DEFINE_PER_CPU(long, stab_cache[NR_STAB_CACHE_ENTRIES]);
+static DEFINE_PER_CPU(long, stab_cache_ptr);
+static DEFINE_PER_CPU(long, stab_cache[NR_STAB_CACHE_ENTRIES]);
 
 /*
  * Create a segment table entry for the given esid/vsid pair.
index e2d867ce1c7eb46fb259993ebf8f99c0a177bca9..509bc560159b6d3d395e362e2a91563d35b7cf42 100644 (file)
@@ -37,8 +37,8 @@ DEFINE_PER_CPU(struct ppc64_tlb_batch, ppc64_tlb_batch);
  * include/asm-powerpc/tlb.h file -- tgall
  */
 DEFINE_PER_CPU(struct mmu_gather, mmu_gathers);
-DEFINE_PER_CPU(struct pte_freelist_batch *, pte_freelist_cur);
-unsigned long pte_freelist_forced_free;
+static DEFINE_PER_CPU(struct pte_freelist_batch *, pte_freelist_cur);
+static unsigned long pte_freelist_forced_free;
 
 struct pte_freelist_batch
 {
@@ -47,9 +47,6 @@ struct pte_freelist_batch
        pgtable_free_t  tables[0];
 };
 
-DEFINE_PER_CPU(struct pte_freelist_batch *, pte_freelist_cur);
-unsigned long pte_freelist_forced_free;
-
 #define PTE_FREELIST_SIZE \
        ((PAGE_SIZE - sizeof(struct pte_freelist_batch)) \
          / sizeof(pgtable_free_t))
index c39f5c225f2e6420b45fc8afd1bbc2a0c379fa8b..8b055bce27fe5d1f09ecb82a5d6a5ba011f18c67 100644 (file)
@@ -14,6 +14,7 @@
 #include <linux/pci.h>
 #include <linux/msi.h>
 #include <linux/of_platform.h>
+#include <linux/debugfs.h>
 
 #include <asm/dcr.h>
 #include <asm/machdep.h>
@@ -69,8 +70,19 @@ struct axon_msic {
        dma_addr_t fifo_phys;
        dcr_host_t dcr_host;
        u32 read_offset;
+#ifdef DEBUG
+       u32 __iomem *trigger;
+#endif
 };
 
+#ifdef DEBUG
+void axon_msi_debug_setup(struct device_node *dn, struct axon_msic *msic);
+#else
+static inline void axon_msi_debug_setup(struct device_node *dn,
+                                       struct axon_msic *msic) { }
+#endif
+
+
 static void msic_dcr_write(struct axon_msic *msic, unsigned int dcr_n, u32 val)
 {
        pr_debug("axon_msi: dcr_write(0x%x, 0x%x)\n", val, dcr_n);
@@ -381,6 +393,8 @@ static int axon_msi_probe(struct of_device *device,
        ppc_md.teardown_msi_irqs = axon_msi_teardown_msi_irqs;
        ppc_md.msi_check_device = axon_msi_check_device;
 
+       axon_msi_debug_setup(dn, msic);
+
        printk(KERN_DEBUG "axon_msi: setup MSIC on %s\n", dn->full_name);
 
        return 0;
@@ -418,3 +432,47 @@ static int __init axon_msi_init(void)
        return of_register_platform_driver(&axon_msi_driver);
 }
 subsys_initcall(axon_msi_init);
+
+
+#ifdef DEBUG
+static int msic_set(void *data, u64 val)
+{
+       struct axon_msic *msic = data;
+       out_le32(msic->trigger, val);
+       return 0;
+}
+
+static int msic_get(void *data, u64 *val)
+{
+       *val = 0;
+       return 0;
+}
+
+DEFINE_SIMPLE_ATTRIBUTE(fops_msic, msic_get, msic_set, "%llu\n");
+
+void axon_msi_debug_setup(struct device_node *dn, struct axon_msic *msic)
+{
+       char name[8];
+       u64 addr;
+
+       addr = of_translate_address(dn, of_get_property(dn, "reg", NULL));
+       if (addr == OF_BAD_ADDR) {
+               pr_debug("axon_msi: couldn't translate reg property\n");
+               return;
+       }
+
+       msic->trigger = ioremap(addr, 0x4);
+       if (!msic->trigger) {
+               pr_debug("axon_msi: ioremap failed\n");
+               return;
+       }
+
+       snprintf(name, sizeof(name), "msic_%d", of_node_to_nid(dn));
+
+       if (!debugfs_create_file(name, 0600, powerpc_debugfs_root,
+                                msic, &fops_msic)) {
+               pr_debug("axon_msi: debugfs_create_file failed!\n");
+               return;
+       }
+}
+#endif /* DEBUG */
index 116babbaaf81f6ea77c6e405da8b71699f187bfd..1ba7ce5aafaed24ef6cae57e36dcd21d454c1d94 100644 (file)
@@ -63,13 +63,6 @@ static struct mpic *chrp_mpic;
 DEFINE_PER_CPU(struct timer_list, heartbeat_timer);
 unsigned long event_scan_interval;
 
-/*
- * XXX this should be in xmon.h, but putting it there means xmon.h
- * has to include <linux/interrupt.h> (to get irqreturn_t), which
- * causes all sorts of problems.  -- paulus
- */
-extern irqreturn_t xmon_irq(int, void *);
-
 extern unsigned long loops_per_jiffy;
 
 /* To be replaced by RTAS when available */
index 9f7579b38c72db2f5df5d80af6a493bbba80371e..53bca132fb484d413aa27020a8596f58a9409cf6 100644 (file)
@@ -41,8 +41,6 @@
 #define DBG(x...)
 #endif
 
-extern void GregorianDay(struct rtc_time * tm);
-
 static int maple_rtc_addr;
 
 static int maple_clock_read(int addr)
index 829b8b02527bfb4f5d2a388256687ee10a2847a0..6d149ae8ffa71c02928e3bdf52d9b6573e65283b 100644 (file)
 #include <asm/time.h>
 #include <asm/pmac_feature.h>
 #include <asm/mpic.h>
+#include <asm/xmon.h>
 
 #include "pmac.h"
 
-/*
- * XXX this should be in xmon.h, but putting it there means xmon.h
- * has to include <linux/interrupt.h> (to get irqreturn_t), which
- * causes all sorts of problems.  -- paulus
- */
-extern irqreturn_t xmon_irq(int, void *);
-
 #ifdef CONFIG_PPC32
 struct pmac_irq_hw {
         unsigned int    event;
index 9d3a40f459747c2ab8077a21a23cb794893f9652..5a707da3f5c2b037aec5654133c90dd82dba4e30 100644 (file)
@@ -26,6 +26,7 @@
 #include <asm/prom.h>
 #include <asm/udbg.h>
 
+#include "pseries.h"
 
 typedef struct {
     unsigned long val;
index 176f1f39d2d5c2f25416a651c58f2d82e267d19a..9a12908510fbaaefbb92ab2e73489b9b49f86376 100644 (file)
@@ -135,9 +135,10 @@ static void tce_buildmulti_pSeriesLP(struct iommu_table *tbl, long tcenum,
        u64 rpn;
        long l, limit;
 
-       if (npages == 1)
-               return tce_build_pSeriesLP(tbl, tcenum, npages, uaddr,
-                                          direction);
+       if (npages == 1) {
+               tce_build_pSeriesLP(tbl, tcenum, npages, uaddr, direction);
+               return;
+       }
 
        tcep = __get_cpu_var(tce_page);
 
@@ -147,9 +148,11 @@ static void tce_buildmulti_pSeriesLP(struct iommu_table *tbl, long tcenum,
        if (!tcep) {
                tcep = (u64 *)__get_free_page(GFP_ATOMIC);
                /* If allocation fails, fall back to the loop implementation */
-               if (!tcep)
-                       return tce_build_pSeriesLP(tbl, tcenum, npages,
-                                                  uaddr, direction);
+               if (!tcep) {
+                       tce_build_pSeriesLP(tbl, tcenum, npages, uaddr,
+                                           direction);
+                       return;
+               }
                __get_cpu_var(tce_page) = tcep;
        }
 
index 2cbaedb17f3ebc2396c23154153d4abf8c8badc1..3b4651b6ee0559c9d15f54cb86a816801aa8486f 100644 (file)
@@ -52,7 +52,7 @@ EXPORT_SYMBOL(plpar_hcall_norets);
 extern void pSeries_find_serial_port(void);
 
 
-int vtermno;   /* virtual terminal# for udbg  */
+static int vtermno;    /* virtual terminal# for udbg  */
 
 #define __ALIGNED__ __attribute__((__aligned__(sizeof(long))))
 static void udbg_hvsi_putc(char c)
index 2b548afd10031166166d77f58ae9939be0a6ae1a..d20b96e22c2ed763aa583cd2e387b29b1927f146 100644 (file)
@@ -55,7 +55,7 @@
 static unsigned char ras_log_buf[RTAS_ERROR_LOG_MAX];
 static DEFINE_SPINLOCK(ras_log_buf_lock);
 
-char mce_data_buf[RTAS_ERROR_LOG_MAX];
+static char mce_data_buf[RTAS_ERROR_LOG_MAX];
 
 static int ras_get_sensor_state_token;
 static int ras_check_exception_token;
index 7d3e2b0bd4d299d5f467fde2a014dec0fb835fdb..c9ffd8c225f1a7b1b2e852bf86899bd8d785e3b4 100644 (file)
@@ -32,7 +32,7 @@
 
 static DEFINE_SPINLOCK(rtasd_log_lock);
 
-DECLARE_WAIT_QUEUE_HEAD(rtas_log_wait);
+static DECLARE_WAIT_QUEUE_HEAD(rtas_log_wait);
 
 static char *rtas_log_buf;
 static unsigned long rtas_log_start;
@@ -329,7 +329,7 @@ static unsigned int rtas_log_poll(struct file *file, poll_table * wait)
        return 0;
 }
 
-const struct file_operations proc_rtas_log_operations = {
+static const struct file_operations proc_rtas_log_operations = {
        .read =         rtas_log_read,
        .poll =         rtas_log_poll,
        .open =         rtas_log_open,
index f5d29f5b13c1b0afb1ec3f67e3fb9eabd6c4a2f2..90beb444e1dd670f64836fdceff20c247b79ed07 100644 (file)
@@ -109,7 +109,7 @@ static void __init fwnmi_init(void)
                fwnmi_active = 1;
 }
 
-void pseries_8259_cascade(unsigned int irq, struct irq_desc *desc)
+static void pseries_8259_cascade(unsigned int irq, struct irq_desc *desc)
 {
        unsigned int cascade_irq = i8259_irq();
        if (cascade_irq != NO_IRQ)
@@ -482,7 +482,7 @@ static int pSeries_pci_probe_mode(struct pci_bus *bus)
  * possible with power button press. If ibm,power-off-ups token is used
  * it will allow auto poweron after power is restored.
  */
-void pSeries_power_off(void)
+static void pSeries_power_off(void)
 {
        int rc;
        int rtas_poweroff_ups_token = rtas_token("ibm,power-off-ups");
diff --git a/arch/powerpc/sysdev/6xx-suspend.S b/arch/powerpc/sysdev/6xx-suspend.S
new file mode 100644 (file)
index 0000000..21cda08
--- /dev/null
@@ -0,0 +1,52 @@
+/*
+ * Enter and leave sleep state on chips with 6xx-style HID0
+ * power management bits, which don't leave sleep state via reset.
+ *
+ * Author: Scott Wood <scottwood@freescale.com>
+ *
+ * Copyright (c) 2006-2007 Freescale Semiconductor, Inc.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 as published
+ * by the Free Software Foundation.
+ */
+
+#include <asm/ppc_asm.h>
+#include <asm/reg.h>
+#include <asm/thread_info.h>
+#include <asm/asm-offsets.h>
+
+_GLOBAL(mpc6xx_enter_standby)
+       mflr    r4
+
+       mfspr   r5, SPRN_HID0
+       rlwinm  r5, r5, 0, ~(HID0_DOZE | HID0_NAP)
+       oris    r5, r5, HID0_SLEEP@h
+       mtspr   SPRN_HID0, r5
+       isync
+
+       lis     r5, ret_from_standby@h
+       ori     r5, r5, ret_from_standby@l
+       mtlr    r5
+
+       rlwinm  r5, r1, 0, 0, 31-THREAD_SHIFT
+       lwz     r6, TI_LOCAL_FLAGS(r5)
+       ori     r6, r6, _TLF_SLEEPING
+       stw     r6, TI_LOCAL_FLAGS(r5)
+
+       mfmsr   r5
+       ori     r5, r5, MSR_EE
+       oris    r5, r5, MSR_POW@h
+       sync
+       mtmsr   r5
+       isync
+
+1:     b       1b
+
+ret_from_standby:
+       mfspr   r5, SPRN_HID0
+       rlwinm  r5, r5, 0, ~HID0_SLEEP
+       mtspr   SPRN_HID0, r5
+
+       mtlr    r4
+       blr
index 6d386d0071a07e5bb59571d57b8a46e9793ae3ed..2cc50520a6983a42aceefa96b6820bf9e5a24a39 100644 (file)
@@ -44,3 +44,7 @@ obj-$(CONFIG_PPC_DCR)         += dcr.o
 obj-$(CONFIG_8xx)              += mpc8xx_pic.o cpm1.o
 obj-$(CONFIG_UCODE_PATCH)      += micropatch.o
 endif
+
+ifeq ($(CONFIG_SUSPEND),y)
+obj-$(CONFIG_6xx)              += 6xx-suspend.o
+endif
index 7680001676a6ee076627fbc214528750c098efc6..f99f81abbd5c7f4b1a0eafc6d0a99835ff2b8f20 100644 (file)
@@ -1144,9 +1144,12 @@ struct mpic * __init mpic_alloc(struct device_node *node,
        mpic->num_cpus = ((greg_feature & MPIC_GREG_FEATURE_LAST_CPU_MASK)
                          >> MPIC_GREG_FEATURE_LAST_CPU_SHIFT) + 1;
        if (isu_size == 0)
-               mpic->num_sources =
-                       ((greg_feature & MPIC_GREG_FEATURE_LAST_SRC_MASK)
-                        >> MPIC_GREG_FEATURE_LAST_SRC_SHIFT) + 1;
+               if (flags & MPIC_BROKEN_FRR_NIRQS)
+                       mpic->num_sources = mpic->irq_count;
+               else
+                       mpic->num_sources =
+                               ((greg_feature & MPIC_GREG_FEATURE_LAST_SRC_MASK)
+                                >> MPIC_GREG_FEATURE_LAST_SRC_SHIFT) + 1;
 
        /* Map the per-CPU registers */
        for (i = 0; i < mpic->num_cpus; i++) {
index d272a52ecd24ace9af35e8f3758e60165fed9c49..de3e5e8bc3241e297ed321b240fb95edaa4350e2 100644 (file)
@@ -16,6 +16,7 @@
 #include <asm/hw_irq.h>
 #include <asm/ppc-pci.h>
 
+#include <sysdev/mpic.h>
 
 static void __mpic_msi_reserve_hwirq(struct mpic *mpic, irq_hw_number_t hwirq)
 {
index 33cbfb22ce3e3d32abf75fe8241fe05862f418fe..68aff6076675a433fe1144c20eff86e85e4c37c1 100644 (file)
@@ -95,6 +95,7 @@ static int pasemi_msi_setup_msi_irqs(struct pci_dev *pdev, int nvec, int type)
        unsigned int virq;
        struct msi_desc *entry;
        struct msi_msg msg;
+       int ret;
 
        pr_debug("pasemi_msi_setup_msi_irqs, pdev %p nvec %d type %d\n",
                 pdev, nvec, type);
@@ -108,8 +109,9 @@ static int pasemi_msi_setup_msi_irqs(struct pci_dev *pdev, int nvec, int type)
                 * few MSIs for someone, but restrictions will apply to how the
                 * sources can be changed independently.
                 */
-               hwirq = mpic_msi_alloc_hwirqs(msi_mpic, ALLOC_CHUNK);
-               if (hwirq < 0) {
+               ret = mpic_msi_alloc_hwirqs(msi_mpic, ALLOC_CHUNK);
+               hwirq = ret;
+               if (ret < 0) {
                        pr_debug("pasemi_msi: failed allocating hwirq\n");
                        return hwirq;
                }
index 1d5a40899b74fac796ac814aad3d1a1c2c805a89..6e2f8686fdfc0471946b8344f75ed70c042150e3 100644 (file)
@@ -115,17 +115,19 @@ static int u3msi_setup_msi_irqs(struct pci_dev *pdev, int nvec, int type)
        struct msi_desc *entry;
        struct msi_msg msg;
        u64 addr;
+       int ret;
 
        addr = find_ht_magic_addr(pdev);
        msg.address_lo = addr & 0xFFFFFFFF;
        msg.address_hi = addr >> 32;
 
        list_for_each_entry(entry, &pdev->msi_list, list) {
-               hwirq = mpic_msi_alloc_hwirqs(msi_mpic, 1);
-               if (hwirq < 0) {
+               ret = mpic_msi_alloc_hwirqs(msi_mpic, 1);
+               if (ret < 0) {
                        pr_debug("u3msi: failed allocating hwirq\n");
-                       return hwirq;
+                       return ret;
                }
+               hwirq = ret;
 
                virq = irq_create_mapping(msi_mpic->irqhost, hwirq);
                if (virq == NO_IRQ) {
index a132e0de8ca5a056ac1f7803c7fe5925a037cf31..32e0ad0ebea8286af9b5b3b8cc1bd18ac1a42ed0 100644 (file)
@@ -15,6 +15,7 @@
 #include <linux/console.h>
 #include <linux/mv643xx.h>
 #include <linux/platform_device.h>
+#include <linux/of_platform.h>
 
 #include <asm/prom.h>
 
  * PowerPC of_platform_bus_type.  They support platform_bus_type instead.
  */
 
+static struct of_device_id __initdata of_mv64x60_devices[] = {
+       { .compatible = "marvell,mv64306-devctrl", },
+       {}
+};
+
 /*
  * Create MPSC platform devices
  */
@@ -484,6 +490,10 @@ static int __init mv64x60_device_setup(void)
                of_node_put(np);
        }
 
+       /* Now add every node that is on the device bus */
+       for_each_compatible_node(np, NULL, "marvell,mv64360")
+               of_platform_bus_probe(np, of_mv64x60_devices, NULL);
+
        return 0;
 }
 arch_initcall(mv64x60_device_setup);
index 1702de9395eeee96b02d686e20550dbc98b8d63d..6726da07c0650eb9ac1df0f4e96840466eba7915 100644 (file)
@@ -54,7 +54,7 @@
 #define skipbl xmon_skipbl
 
 #ifdef CONFIG_SMP
-cpumask_t cpus_in_xmon = CPU_MASK_NONE;
+static cpumask_t cpus_in_xmon = CPU_MASK_NONE;
 static unsigned long xmon_taken = 1;
 static int xmon_owner;
 static int xmon_gate;
@@ -154,7 +154,7 @@ static int do_spu_cmd(void);
 static void dump_tlb_44x(void);
 #endif
 
-int xmon_no_auto_backtrace;
+static int xmon_no_auto_backtrace;
 
 extern void xmon_enter(void);
 extern void xmon_leave(void);
@@ -327,6 +327,11 @@ static void release_output_lock(void)
 {
        xmon_speaker = 0;
 }
+
+int cpus_are_in_xmon(void)
+{
+       return !cpus_empty(cpus_in_xmon);
+}
 #endif
 
 static int xmon_core(struct pt_regs *regs, int fromipi)
@@ -593,7 +598,7 @@ static int xmon_iabr_match(struct pt_regs *regs)
 {
        if ((regs->msr & (MSR_IR|MSR_PR|MSR_SF)) != (MSR_IR|MSR_SF))
                return 0;
-       if (iabr == 0)
+       if (iabr == NULL)
                return 0;
        xmon_core(regs, 0);
        return 1;
@@ -1142,7 +1147,7 @@ bpt_cmds(void)
                } else {
                        /* assume a breakpoint address */
                        bp = at_breakpoint(a);
-                       if (bp == 0) {
+                       if (bp == NULL) {
                                printf("No breakpoint at %x\n", a);
                                break;
                        }
@@ -1370,7 +1375,7 @@ static void print_bug_trap(struct pt_regs *regs)
 #endif
 }
 
-void excprint(struct pt_regs *fp)
+static void excprint(struct pt_regs *fp)
 {
        unsigned long trap;
 
@@ -1408,7 +1413,7 @@ void excprint(struct pt_regs *fp)
                print_bug_trap(fp);
 }
 
-void prregs(struct pt_regs *fp)
+static void prregs(struct pt_regs *fp)
 {
        int n, trap;
        unsigned long base;
@@ -1463,7 +1468,7 @@ void prregs(struct pt_regs *fp)
                printf("dar = "REG"   dsisr = %.8lx\n", fp->dar, fp->dsisr);
 }
 
-void cacheflush(void)
+static void cacheflush(void)
 {
        int cmd;
        unsigned long nflush;
@@ -1495,7 +1500,7 @@ void cacheflush(void)
        catch_memory_errors = 0;
 }
 
-unsigned long
+static unsigned long
 read_spr(int n)
 {
        unsigned int instrs[2];
@@ -1533,7 +1538,7 @@ read_spr(int n)
        return ret;
 }
 
-void
+static void
 write_spr(int n, unsigned long val)
 {
        unsigned int instrs[2];
@@ -1571,7 +1576,7 @@ static unsigned long regno;
 extern char exc_prolog;
 extern char dec_exc;
 
-void super_regs(void)
+static void super_regs(void)
 {
        int cmd;
        unsigned long val;
@@ -1629,7 +1634,7 @@ void super_regs(void)
 /*
  * Stuff for reading and writing memory safely
  */
-int
+static int
 mread(unsigned long adrs, void *buf, int size)
 {
        volatile int n;
@@ -1666,7 +1671,7 @@ mread(unsigned long adrs, void *buf, int size)
        return n;
 }
 
-int
+static int
 mwrite(unsigned long adrs, void *buf, int size)
 {
        volatile int n;
@@ -1731,7 +1736,7 @@ static int handle_fault(struct pt_regs *regs)
 
 #define SWAP(a, b, t)  ((t) = (a), (a) = (b), (b) = (t))
 
-void
+static void
 byterev(unsigned char *val, int size)
 {
        int t;
@@ -1793,7 +1798,7 @@ static char *memex_subcmd_help_string =
     "  x        exit this mode\n"
     "";
 
-void
+static void
 memex(void)
 {
        int cmd, inc, i, nslash;
@@ -1944,7 +1949,7 @@ memex(void)
        }
 }
 
-int
+static int
 bsesc(void)
 {
        int c;
@@ -1984,7 +1989,7 @@ static void xmon_rawdump (unsigned long adrs, long ndump)
 #define isxdigit(c)    (('0' <= (c) && (c) <= '9') \
                         || ('a' <= (c) && (c) <= 'f') \
                         || ('A' <= (c) && (c) <= 'F'))
-void
+static void
 dump(void)
 {
        int c;
@@ -2022,7 +2027,7 @@ dump(void)
        }
 }
 
-void
+static void
 prdump(unsigned long adrs, long ndump)
 {
        long n, m, c, r, nr;
@@ -2066,7 +2071,7 @@ prdump(unsigned long adrs, long ndump)
 
 typedef int (*instruction_dump_func)(unsigned long inst, unsigned long addr);
 
-int
+static int
 generic_inst_dump(unsigned long adr, long count, int praddr,
                        instruction_dump_func dump_func)
 {
@@ -2104,7 +2109,7 @@ generic_inst_dump(unsigned long adr, long count, int praddr,
        return adr - first_adr;
 }
 
-int
+static int
 ppc_inst_dump(unsigned long adr, long count, int praddr)
 {
        return generic_inst_dump(adr, count, praddr, print_insn_powerpc);
@@ -2126,7 +2131,7 @@ static unsigned long mval;                /* byte value to set memory to */
 static unsigned long mcount;           /* # bytes to affect */
 static unsigned long mdiffs;           /* max # differences to print */
 
-void
+static void
 memops(int cmd)
 {
        scanhex((void *)&mdest);
@@ -2152,7 +2157,7 @@ memops(int cmd)
        }
 }
 
-void
+static void
 memdiffs(unsigned char *p1, unsigned char *p2, unsigned nb, unsigned maxpr)
 {
        unsigned n, prt;
@@ -2170,7 +2175,7 @@ memdiffs(unsigned char *p1, unsigned char *p2, unsigned nb, unsigned maxpr)
 static unsigned mend;
 static unsigned mask;
 
-void
+static void
 memlocate(void)
 {
        unsigned a, n;
@@ -2203,7 +2208,7 @@ memlocate(void)
 static unsigned long mskip = 0x1000;
 static unsigned long mlim = 0xffffffff;
 
-void
+static void
 memzcan(void)
 {
        unsigned char v;
@@ -2230,7 +2235,7 @@ memzcan(void)
                printf("%.8x\n", a - mskip);
 }
 
-void proccall(void)
+static void proccall(void)
 {
        unsigned long args[8];
        unsigned long ret;
@@ -2388,7 +2393,7 @@ scanhex(unsigned long *vp)
        return 1;
 }
 
-void
+static void
 scannl(void)
 {
        int c;
@@ -2399,7 +2404,7 @@ scannl(void)
                c = inchar();
 }
 
-int hexdigit(int c)
+static int hexdigit(int c)
 {
        if( '0' <= c && c <= '9' )
                return c - '0';
@@ -2430,13 +2435,13 @@ getstring(char *s, int size)
 static char line[256];
 static char *lineptr;
 
-void
+static void
 flush_input(void)
 {
        lineptr = NULL;
 }
 
-int
+static int
 inchar(void)
 {
        if (lineptr == NULL || *lineptr == 0) {
@@ -2449,7 +2454,7 @@ inchar(void)
        return *lineptr++;
 }
 
-void
+static void
 take_input(char *str)
 {
        lineptr = str;
@@ -2618,7 +2623,8 @@ static void dump_tlb_44x(void)
        }
 }
 #endif /* CONFIG_44x */
-void xmon_init(int enable)
+
+static void xmon_init(int enable)
 {
 #ifdef CONFIG_PPC_ISERIES
        if (firmware_has_feature(FW_FEATURE_ISERIES))
index 5f3a5d068a5c6af9475babc8828d0e87f4290245..fcd830a292e24186ede36195ba4558d0312e2aa3 100644 (file)
@@ -647,7 +647,7 @@ user_exc_return:            /* r10 contains MSR_KERNEL here */
        /* Check current_thread_info()->flags */
        rlwinm  r9,r1,0,0,18
        lwz     r9,TI_FLAGS(r9)
-       andi.   r0,r9,(_TIF_SIGPENDING|_TIF_RESTORE_SIGMASK|_TIF_NEED_RESCHED)
+       andi.   r0,r9,_TIF_USER_WORK_MASK
        bne     do_work
 
 restore_user:
@@ -898,7 +898,7 @@ recheck:
        lwz     r9,TI_FLAGS(r9)
        andi.   r0,r9,_TIF_NEED_RESCHED
        bne-    do_resched
-       andi.   r0,r9,_TIF_SIGPENDING
+       andi.   r0,r9,_TIF_USER_WORK_MASK
        beq     restore_user
 do_user_signal:                        /* r10 contains MSR_KERNEL here */
        ori     r10,r10,MSR_EE
index 44160d5ebca06dbcd7e300c9835cbeb1763c1a4c..2f9759d625cc520b02c78d4605bbb594c4765f7e 100644 (file)
@@ -675,12 +675,6 @@ static int hvc_poll(struct hvc_struct *hp)
        return poll_mask;
 }
 
-#if defined(CONFIG_XMON) && defined(CONFIG_SMP)
-extern cpumask_t cpus_in_xmon;
-#else
-static const cpumask_t cpus_in_xmon = CPU_MASK_NONE;
-#endif
-
 /*
  * This kthread is either polling or interrupt driven.  This is determined by
  * calling hvc_poll() who determines whether a console adapter support
@@ -698,7 +692,7 @@ static int khvcd(void *unused)
                hvc_kicked = 0;
                try_to_freeze();
                wmb();
-               if (cpus_empty(cpus_in_xmon)) {
+               if (!cpus_are_in_xmon()) {
                        spin_lock(&hvc_structs_lock);
                        list_for_each_entry(hp, &hvc_structs, next) {
                                poll_mask |= hvc_poll(hp);
index 8c59818050e66d0c6c97aa8bb22351bf7bd70e5b..42ffb17e15df7d4f038f483cc16da4b1a42baf3f 100644 (file)
@@ -60,4 +60,14 @@ extern struct hvc_struct * __devinit hvc_alloc(uint32_t vtermno, int irq,
 /* remove a vterm from hvc tty operation (modele_exit or hotplug remove) */
 extern int __devexit hvc_remove(struct hvc_struct *hp);
 
+
+#if defined(CONFIG_XMON) && defined(CONFIG_SMP)
+#include <asm/xmon.h>
+#else
+static inline int cpus_are_in_xmon(void)
+{
+       return 0;
+}
+#endif
+
 #endif // HVC_CONSOLE_H
index 112e5ef728f14c9c939afdc95ca5ce604e273f4f..9e9453b584250f61b6a741861df2608e27cfb63e 100644 (file)
@@ -44,7 +44,7 @@ static ssize_t modalias_show (struct device *dev, struct device_attribute *attr,
        struct of_device *ofdev = to_of_device(dev);
        int len;
 
-       len = of_device_get_modalias(ofdev, buf, PAGE_SIZE);
+       len = of_device_get_modalias(ofdev, buf, PAGE_SIZE - 2);
 
        buf[len] = '\n';
        buf[len+1] = 0;
@@ -52,6 +52,15 @@ static ssize_t modalias_show (struct device *dev, struct device_attribute *attr,
        return len+1;
 }
 
+static ssize_t devspec_show(struct device *dev,
+                               struct device_attribute *attr, char *buf)
+{
+       struct of_device *ofdev;
+
+       ofdev = to_of_device(dev);
+       return sprintf(buf, "%s\n", ofdev->node->full_name);
+}
+
 macio_config_of_attr (name, "%s\n");
 macio_config_of_attr (type, "%s\n");
 
@@ -60,5 +69,6 @@ struct device_attribute macio_dev_attrs[] = {
        __ATTR_RO(type),
        __ATTR_RO(compatible),
        __ATTR_RO(modalias),
+       __ATTR_RO(devspec),
        __ATTR_NULL
 };
index dd0ec9ebc939a92d0bb4fadaba75648b95297359..b1ca6f2a44e80f5ba88e372e4054ccdb05898b0f 100644 (file)
@@ -1884,7 +1884,6 @@ config NE_H8300
          Say Y here if you want to use the NE2000 compatible
          controller on the Renesas H8/300 processor.
 
-source "drivers/net/fec_8xx/Kconfig"
 source "drivers/net/fs_enet/Kconfig"
 
 endif # NET_ETHERNET
index dcbfe8421154b25a83fd50ab7bf946da955eb65a..9010e58da0f2ffeccddc157082d55f631e82aac3 100644 (file)
@@ -217,7 +217,6 @@ obj-$(CONFIG_SMC91X) += smc91x.o
 obj-$(CONFIG_SMC911X) += smc911x.o
 obj-$(CONFIG_BFIN_MAC) += bfin_mac.o
 obj-$(CONFIG_DM9000) += dm9000.o
-obj-$(CONFIG_FEC_8XX) += fec_8xx/
 obj-$(CONFIG_PASEMI_MAC) += pasemi_mac_driver.o
 pasemi_mac_driver-objs := pasemi_mac.o pasemi_mac_ethtool.o
 obj-$(CONFIG_MLX4_CORE) += mlx4/
diff --git a/drivers/net/fec_8xx/Kconfig b/drivers/net/fec_8xx/Kconfig
deleted file mode 100644 (file)
index afb34de..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-config FEC_8XX
-       tristate "Motorola 8xx FEC driver"
-       depends on 8XX
-       select MII
-
-config FEC_8XX_GENERIC_PHY
-       bool "Support any generic PHY"
-       depends on FEC_8XX
-       default y
-
-config FEC_8XX_DM9161_PHY
-       bool "Support DM9161 PHY"
-       depends on FEC_8XX
-       default n
-
-config FEC_8XX_LXT971_PHY
-       bool "Support LXT971/LXT972 PHY"
-       depends on FEC_8XX
-       default n
-
diff --git a/drivers/net/fec_8xx/Makefile b/drivers/net/fec_8xx/Makefile
deleted file mode 100644 (file)
index 70c54f8..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-#
-# Makefile for the Motorola 8xx FEC ethernet controller
-#
-
-obj-$(CONFIG_FEC_8XX) += fec_8xx.o
-
-fec_8xx-objs := fec_main.o fec_mii.o
-
-# the platform instantatiation objects
-ifeq ($(CONFIG_NETTA),y)
-fec_8xx-objs   += fec_8xx-netta.o
-endif
diff --git a/drivers/net/fec_8xx/fec_8xx-netta.c b/drivers/net/fec_8xx/fec_8xx-netta.c
deleted file mode 100644 (file)
index 79deee2..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-/*
- * FEC instantatiation file for NETTA
- */
-
-#include <linux/kernel.h>
-#include <linux/types.h>
-#include <linux/string.h>
-#include <linux/ptrace.h>
-#include <linux/errno.h>
-#include <linux/ioport.h>
-#include <linux/slab.h>
-#include <linux/interrupt.h>
-#include <linux/pci.h>
-#include <linux/init.h>
-#include <linux/delay.h>
-#include <linux/netdevice.h>
-#include <linux/etherdevice.h>
-#include <linux/skbuff.h>
-#include <linux/spinlock.h>
-#include <linux/mii.h>
-#include <linux/ethtool.h>
-#include <linux/bitops.h>
-
-#include <asm/8xx_immap.h>
-#include <asm/pgtable.h>
-#include <asm/mpc8xx.h>
-#include <asm/irq.h>
-#include <asm/uaccess.h>
-#include <asm/cpm1.h>
-
-#include "fec_8xx.h"
-
-/*************************************************/
-
-static struct fec_platform_info fec1_info = {
-       .fec_no = 0,
-       .use_mdio = 1,
-       .phy_addr = 8,
-       .fec_irq = SIU_LEVEL1,
-       .phy_irq = CPM_IRQ_OFFSET + CPMVEC_PIO_PC6,
-       .rx_ring = 128,
-       .tx_ring = 16,
-       .rx_copybreak = 240,
-       .use_napi = 1,
-       .napi_weight = 17,
-};
-
-static struct fec_platform_info fec2_info = {
-       .fec_no = 1,
-       .use_mdio = 1,
-       .phy_addr = 2,
-       .fec_irq = SIU_LEVEL3,
-       .phy_irq = CPM_IRQ_OFFSET + CPMVEC_PIO_PC7,
-       .rx_ring = 128,
-       .tx_ring = 16,
-       .rx_copybreak = 240,
-       .use_napi = 1,
-       .napi_weight = 17,
-};
-
-static struct net_device *fec1_dev;
-static struct net_device *fec2_dev;
-
-/* XXX custom u-boot & Linux startup needed */
-extern const char *__fw_getenv(const char *var);
-
-/* access ports */
-#define setbits32(_addr, _v) __fec_out32(&(_addr), __fec_in32(&(_addr)) |  (_v))
-#define clrbits32(_addr, _v) __fec_out32(&(_addr), __fec_in32(&(_addr)) & ~(_v))
-
-#define setbits16(_addr, _v) __fec_out16(&(_addr), __fec_in16(&(_addr)) |  (_v))
-#define clrbits16(_addr, _v) __fec_out16(&(_addr), __fec_in16(&(_addr)) & ~(_v))
-
-int fec_8xx_platform_init(void)
-{
-       immap_t *immap = (immap_t *)IMAP_ADDR;
-       bd_t *bd = (bd_t *) __res;
-       const char *s;
-       char *e;
-       int i;
-
-       /* use MDC for MII */
-       setbits16(immap->im_ioport.iop_pdpar, 0x0080);
-       clrbits16(immap->im_ioport.iop_pddir, 0x0080);
-
-       /* configure FEC1 pins */
-       setbits16(immap->im_ioport.iop_papar, 0xe810);
-       setbits16(immap->im_ioport.iop_padir, 0x0810);
-       clrbits16(immap->im_ioport.iop_padir, 0xe000);
-
-       setbits32(immap->im_cpm.cp_pbpar, 0x00000001);
-       clrbits32(immap->im_cpm.cp_pbdir, 0x00000001);
-
-       setbits32(immap->im_cpm.cp_cptr, 0x00000100);
-       clrbits32(immap->im_cpm.cp_cptr, 0x00000050);
-
-       clrbits16(immap->im_ioport.iop_pcpar, 0x0200);
-       clrbits16(immap->im_ioport.iop_pcdir, 0x0200);
-       clrbits16(immap->im_ioport.iop_pcso, 0x0200);
-       setbits16(immap->im_ioport.iop_pcint, 0x0200);
-
-       /* configure FEC2 pins */
-       setbits32(immap->im_cpm.cp_pepar, 0x00039620);
-       setbits32(immap->im_cpm.cp_pedir, 0x00039620);
-       setbits32(immap->im_cpm.cp_peso, 0x00031000);
-       clrbits32(immap->im_cpm.cp_peso, 0x00008620);
-
-       setbits32(immap->im_cpm.cp_cptr, 0x00000080);
-       clrbits32(immap->im_cpm.cp_cptr, 0x00000028);
-
-       clrbits16(immap->im_ioport.iop_pcpar, 0x0200);
-       clrbits16(immap->im_ioport.iop_pcdir, 0x0200);
-       clrbits16(immap->im_ioport.iop_pcso, 0x0200);
-       setbits16(immap->im_ioport.iop_pcint, 0x0200);
-
-       /* fill up */
-       fec1_info.sys_clk = bd->bi_intfreq;
-       fec2_info.sys_clk = bd->bi_intfreq;
-
-       s = __fw_getenv("ethaddr");
-       if (s != NULL) {
-               for (i = 0; i < 6; i++) {
-                       fec1_info.macaddr[i] = simple_strtoul(s, &e, 16);
-                       if (*e)
-                               s = e + 1;
-               }
-       }
-
-       s = __fw_getenv("eth1addr");
-       if (s != NULL) {
-               for (i = 0; i < 6; i++) {
-                       fec2_info.macaddr[i] = simple_strtoul(s, &e, 16);
-                       if (*e)
-                               s = e + 1;
-               }
-       }
-
-       fec_8xx_init_one(&fec1_info, &fec1_dev);
-       fec_8xx_init_one(&fec2_info, &fec2_dev);
-
-       return fec1_dev != NULL && fec2_dev != NULL ? 0 : -1;
-}
-
-void fec_8xx_platform_cleanup(void)
-{
-       if (fec2_dev != NULL)
-               fec_8xx_cleanup_one(fec2_dev);
-
-       if (fec1_dev != NULL)
-               fec_8xx_cleanup_one(fec1_dev);
-}
diff --git a/drivers/net/fec_8xx/fec_8xx.h b/drivers/net/fec_8xx/fec_8xx.h
deleted file mode 100644 (file)
index f3b1c6f..0000000
+++ /dev/null
@@ -1,220 +0,0 @@
-#ifndef FEC_8XX_H
-#define FEC_8XX_H
-
-#include <linux/mii.h>
-#include <linux/netdevice.h>
-
-#include <linux/types.h>
-
-/* HW info */
-
-/* CRC polynomium used by the FEC for the multicast group filtering */
-#define FEC_CRC_POLY   0x04C11DB7
-
-#define MII_ADVERTISE_HALF     (ADVERTISE_100HALF | \
-                                ADVERTISE_10HALF | ADVERTISE_CSMA)
-#define MII_ADVERTISE_ALL      (ADVERTISE_100FULL | \
-                                ADVERTISE_10FULL | MII_ADVERTISE_HALF)
-
-/* Interrupt events/masks.
-*/
-#define FEC_ENET_HBERR 0x80000000U     /* Heartbeat error          */
-#define FEC_ENET_BABR  0x40000000U     /* Babbling receiver        */
-#define FEC_ENET_BABT  0x20000000U     /* Babbling transmitter     */
-#define FEC_ENET_GRA   0x10000000U     /* Graceful stop complete   */
-#define FEC_ENET_TXF   0x08000000U     /* Full frame transmitted   */
-#define FEC_ENET_TXB   0x04000000U     /* A buffer was transmitted */
-#define FEC_ENET_RXF   0x02000000U     /* Full frame received      */
-#define FEC_ENET_RXB   0x01000000U     /* A buffer was received    */
-#define FEC_ENET_MII   0x00800000U     /* MII interrupt            */
-#define FEC_ENET_EBERR 0x00400000U     /* SDMA bus error           */
-
-#define FEC_ECNTRL_PINMUX      0x00000004
-#define FEC_ECNTRL_ETHER_EN    0x00000002
-#define FEC_ECNTRL_RESET       0x00000001
-
-#define FEC_RCNTRL_BC_REJ      0x00000010
-#define FEC_RCNTRL_PROM                0x00000008
-#define FEC_RCNTRL_MII_MODE    0x00000004
-#define FEC_RCNTRL_DRT         0x00000002
-#define FEC_RCNTRL_LOOP                0x00000001
-
-#define FEC_TCNTRL_FDEN                0x00000004
-#define FEC_TCNTRL_HBC         0x00000002
-#define FEC_TCNTRL_GTS         0x00000001
-
-/* values for MII phy_status */
-
-#define PHY_CONF_ANE   0x0001  /* 1 auto-negotiation enabled     */
-#define PHY_CONF_LOOP  0x0002  /* 1 loopback mode enabled        */
-#define PHY_CONF_SPMASK        0x00f0  /* mask for speed                 */
-#define PHY_CONF_10HDX 0x0010  /* 10 Mbit half duplex supported  */
-#define PHY_CONF_10FDX 0x0020  /* 10 Mbit full duplex supported  */
-#define PHY_CONF_100HDX        0x0040  /* 100 Mbit half duplex supported */
-#define PHY_CONF_100FDX        0x0080  /* 100 Mbit full duplex supported */
-
-#define PHY_STAT_LINK  0x0100  /* 1 up - 0 down                  */
-#define PHY_STAT_FAULT 0x0200  /* 1 remote fault                 */
-#define PHY_STAT_ANC   0x0400  /* 1 auto-negotiation complete    */
-#define PHY_STAT_SPMASK        0xf000  /* mask for speed                 */
-#define PHY_STAT_10HDX 0x1000  /* 10 Mbit half duplex selected   */
-#define PHY_STAT_10FDX 0x2000  /* 10 Mbit full duplex selected   */
-#define PHY_STAT_100HDX        0x4000  /* 100 Mbit half duplex selected  */
-#define PHY_STAT_100FDX        0x8000  /* 100 Mbit full duplex selected  */
-
-typedef struct phy_info {
-       unsigned int id;
-       const char *name;
-       void (*startup) (struct net_device * dev);
-       void (*shutdown) (struct net_device * dev);
-       void (*ack_int) (struct net_device * dev);
-} phy_info_t;
-
-/* The FEC stores dest/src/type, data, and checksum for receive packets.
- */
-#define MAX_MTU 1508           /* Allow fullsized pppoe packets over VLAN */
-#define MIN_MTU 46             /* this is data size */
-#define CRC_LEN 4
-
-#define PKT_MAXBUF_SIZE                (MAX_MTU+ETH_HLEN+CRC_LEN)
-#define PKT_MINBUF_SIZE                (MIN_MTU+ETH_HLEN+CRC_LEN)
-
-/* Must be a multiple of 4 */
-#define PKT_MAXBLR_SIZE                ((PKT_MAXBUF_SIZE+3) & ~3)
-/* This is needed so that invalidate_xxx wont invalidate too much */
-#define ENET_RX_FRSIZE         L1_CACHE_ALIGN(PKT_MAXBUF_SIZE)
-
-/* platform interface */
-
-struct fec_platform_info {
-       int fec_no;             /* FEC index                  */
-       int use_mdio;           /* use external MII           */
-       int phy_addr;           /* the phy address            */
-       int fec_irq, phy_irq;   /* the irq for the controller */
-       int rx_ring, tx_ring;   /* number of buffers on rx    */
-       int sys_clk;            /* system clock               */
-       __u8 macaddr[6];        /* mac address                */
-       int rx_copybreak;       /* limit we copy small frames */
-       int use_napi;           /* use NAPI                   */
-       int napi_weight;        /* NAPI weight                */
-};
-
-/* forward declaration */
-struct fec;
-
-struct fec_enet_private {
-       spinlock_t lock;        /* during all ops except TX pckt processing */
-       spinlock_t tx_lock;     /* during fec_start_xmit and fec_tx         */
-       struct net_device *dev;
-       struct napi_struct napi;
-       int fecno;
-       struct fec *fecp;
-       const struct fec_platform_info *fpi;
-       int rx_ring, tx_ring;
-       dma_addr_t ring_mem_addr;
-       void *ring_base;
-       struct sk_buff **rx_skbuff;
-       struct sk_buff **tx_skbuff;
-       cbd_t *rx_bd_base;      /* Address of Rx and Tx buffers.    */
-       cbd_t *tx_bd_base;
-       cbd_t *dirty_tx;        /* ring entries to be free()ed.     */
-       cbd_t *cur_rx;
-       cbd_t *cur_tx;
-       int tx_free;
-       struct net_device_stats stats;
-       struct timer_list phy_timer_list;
-       const struct phy_info *phy;
-       unsigned int fec_phy_speed;
-       __u32 msg_enable;
-       struct mii_if_info mii_if;
-};
-
-/***************************************************************************/
-
-void fec_restart(struct net_device *dev, int duplex, int speed);
-void fec_stop(struct net_device *dev);
-
-/***************************************************************************/
-
-int fec_mii_read(struct net_device *dev, int phy_id, int location);
-void fec_mii_write(struct net_device *dev, int phy_id, int location, int value);
-
-int fec_mii_phy_id_detect(struct net_device *dev);
-void fec_mii_startup(struct net_device *dev);
-void fec_mii_shutdown(struct net_device *dev);
-void fec_mii_ack_int(struct net_device *dev);
-
-void fec_mii_link_status_change_check(struct net_device *dev, int init_media);
-
-/***************************************************************************/
-
-#define FEC1_NO        0x00
-#define FEC2_NO        0x01
-#define FEC3_NO        0x02
-
-int fec_8xx_init_one(const struct fec_platform_info *fpi,
-                    struct net_device **devp);
-int fec_8xx_cleanup_one(struct net_device *dev);
-
-/***************************************************************************/
-
-#define DRV_MODULE_NAME                "fec_8xx"
-#define PFX DRV_MODULE_NAME    ": "
-#define DRV_MODULE_VERSION     "0.1"
-#define DRV_MODULE_RELDATE     "May 6, 2004"
-
-/***************************************************************************/
-
-int fec_8xx_platform_init(void);
-void fec_8xx_platform_cleanup(void);
-
-/***************************************************************************/
-
-/* FEC access macros */
-#if defined(CONFIG_8xx)
-/* for a 8xx __raw_xxx's are sufficient */
-#define __fec_out32(addr, x)   __raw_writel(x, addr)
-#define __fec_out16(addr, x)   __raw_writew(x, addr)
-#define __fec_in32(addr)       __raw_readl(addr)
-#define __fec_in16(addr)       __raw_readw(addr)
-#else
-/* for others play it safe */
-#define __fec_out32(addr, x)   out_be32(addr, x)
-#define __fec_out16(addr, x)   out_be16(addr, x)
-#define __fec_in32(addr)       in_be32(addr)
-#define __fec_in16(addr)       in_be16(addr)
-#endif
-
-/* write */
-#define FW(_fecp, _reg, _v) __fec_out32(&(_fecp)->fec_ ## _reg, (_v))
-
-/* read */
-#define FR(_fecp, _reg)        __fec_in32(&(_fecp)->fec_ ## _reg)
-
-/* set bits */
-#define FS(_fecp, _reg, _v) FW(_fecp, _reg, FR(_fecp, _reg) | (_v))
-
-/* clear bits */
-#define FC(_fecp, _reg, _v) FW(_fecp, _reg, FR(_fecp, _reg) & ~(_v))
-
-/* buffer descriptor access macros */
-
-/* write */
-#define CBDW_SC(_cbd, _sc)             __fec_out16(&(_cbd)->cbd_sc, (_sc))
-#define CBDW_DATLEN(_cbd, _datlen)     __fec_out16(&(_cbd)->cbd_datlen, (_datlen))
-#define CBDW_BUFADDR(_cbd, _bufaddr)   __fec_out32(&(_cbd)->cbd_bufaddr, (_bufaddr))
-
-/* read */
-#define CBDR_SC(_cbd)                  __fec_in16(&(_cbd)->cbd_sc)
-#define CBDR_DATLEN(_cbd)              __fec_in16(&(_cbd)->cbd_datlen)
-#define CBDR_BUFADDR(_cbd)             __fec_in32(&(_cbd)->cbd_bufaddr)
-
-/* set bits */
-#define CBDS_SC(_cbd, _sc)             CBDW_SC(_cbd, CBDR_SC(_cbd) | (_sc))
-
-/* clear bits */
-#define CBDC_SC(_cbd, _sc)             CBDW_SC(_cbd, CBDR_SC(_cbd) & ~(_sc))
-
-/***************************************************************************/
-
-#endif
diff --git a/drivers/net/fec_8xx/fec_main.c b/drivers/net/fec_8xx/fec_main.c
deleted file mode 100644 (file)
index ca8d2e8..0000000
+++ /dev/null
@@ -1,1264 +0,0 @@
-/*
- * Fast Ethernet Controller (FEC) driver for Motorola MPC8xx.
- *
- * Copyright (c) 2003 Intracom S.A. 
- *  by Pantelis Antoniou <panto@intracom.gr>
- *
- * Heavily based on original FEC driver by Dan Malek <dan@embeddededge.com>
- * and modifications by Joakim Tjernlund <joakim.tjernlund@lumentis.se>
- *
- * Released under the GPL
- */
-
-#include <linux/module.h>
-#include <linux/kernel.h>
-#include <linux/types.h>
-#include <linux/string.h>
-#include <linux/ptrace.h>
-#include <linux/errno.h>
-#include <linux/ioport.h>
-#include <linux/slab.h>
-#include <linux/interrupt.h>
-#include <linux/init.h>
-#include <linux/delay.h>
-#include <linux/netdevice.h>
-#include <linux/etherdevice.h>
-#include <linux/skbuff.h>
-#include <linux/spinlock.h>
-#include <linux/mii.h>
-#include <linux/ethtool.h>
-#include <linux/bitops.h>
-#include <linux/dma-mapping.h>
-
-#include <asm/8xx_immap.h>
-#include <asm/pgtable.h>
-#include <asm/mpc8xx.h>
-#include <asm/irq.h>
-#include <asm/uaccess.h>
-#include <asm/cpm1.h>
-
-#include "fec_8xx.h"
-
-/*************************************************/
-
-#define FEC_MAX_MULTICAST_ADDRS        64
-
-/*************************************************/
-
-static char version[] __devinitdata =
-    DRV_MODULE_NAME ".c:v" DRV_MODULE_VERSION " (" DRV_MODULE_RELDATE ")" "\n";
-
-MODULE_AUTHOR("Pantelis Antoniou <panto@intracom.gr>");
-MODULE_DESCRIPTION("Motorola 8xx FEC ethernet driver");
-MODULE_LICENSE("GPL");
-
-int fec_8xx_debug = -1;                /* -1 == use FEC_8XX_DEF_MSG_ENABLE as value */
-module_param(fec_8xx_debug, int, 0);
-MODULE_PARM_DESC(fec_8xx_debug,
-                "FEC 8xx bitmapped debugging message enable value");
-
-
-/*************************************************/
-
-/*
- * Delay to wait for FEC reset command to complete (in us) 
- */
-#define FEC_RESET_DELAY                50
-
-/*****************************************************************************************/
-
-static void fec_whack_reset(fec_t * fecp)
-{
-       int i;
-
-       /*
-        * Whack a reset.  We should wait for this.  
-        */
-       FW(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_RESET);
-       for (i = 0;
-            (FR(fecp, ecntrl) & FEC_ECNTRL_RESET) != 0 && i < FEC_RESET_DELAY;
-            i++)
-               udelay(1);
-
-       if (i == FEC_RESET_DELAY)
-               printk(KERN_WARNING "FEC Reset timeout!\n");
-
-}
-
-/****************************************************************************/
-
-/*
- * Transmitter timeout.  
- */
-#define TX_TIMEOUT (2*HZ)
-
-/****************************************************************************/
-
-/*
- * Returns the CRC needed when filling in the hash table for
- * multicast group filtering
- * pAddr must point to a MAC address (6 bytes)
- */
-static __u32 fec_mulicast_calc_crc(char *pAddr)
-{
-       u8 byte;
-       int byte_count;
-       int bit_count;
-       __u32 crc = 0xffffffff;
-       u8 msb;
-
-       for (byte_count = 0; byte_count < 6; byte_count++) {
-               byte = pAddr[byte_count];
-               for (bit_count = 0; bit_count < 8; bit_count++) {
-                       msb = crc >> 31;
-                       crc <<= 1;
-                       if (msb ^ (byte & 0x1)) {
-                               crc ^= FEC_CRC_POLY;
-                       }
-                       byte >>= 1;
-               }
-       }
-       return (crc);
-}
-
-/*
- * Set or clear the multicast filter for this adaptor.
- * Skeleton taken from sunlance driver.
- * The CPM Ethernet implementation allows Multicast as well as individual
- * MAC address filtering.  Some of the drivers check to make sure it is
- * a group multicast address, and discard those that are not.  I guess I
- * will do the same for now, but just remove the test if you want
- * individual filtering as well (do the upper net layers want or support
- * this kind of feature?).
- */
-static void fec_set_multicast_list(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fec_t *fecp = fep->fecp;
-       struct dev_mc_list *pmc;
-       __u32 crc;
-       int temp;
-       __u32 csrVal;
-       int hash_index;
-       __u32 hthi, htlo;
-       unsigned long flags;
-
-
-       if ((dev->flags & IFF_PROMISC) != 0) {
-
-               spin_lock_irqsave(&fep->lock, flags);
-               FS(fecp, r_cntrl, FEC_RCNTRL_PROM);
-               spin_unlock_irqrestore(&fep->lock, flags);
-
-               /*
-                * Log any net taps. 
-                */
-               printk(KERN_WARNING DRV_MODULE_NAME
-                      ": %s: Promiscuous mode enabled.\n", dev->name);
-               return;
-
-       }
-
-       if ((dev->flags & IFF_ALLMULTI) != 0 ||
-           dev->mc_count > FEC_MAX_MULTICAST_ADDRS) {
-               /*
-                * Catch all multicast addresses, set the filter to all 1's.
-                */
-               hthi = 0xffffffffU;
-               htlo = 0xffffffffU;
-       } else {
-               hthi = 0;
-               htlo = 0;
-
-               /*
-                * Now populate the hash table 
-                */
-               for (pmc = dev->mc_list; pmc != NULL; pmc = pmc->next) {
-                       crc = fec_mulicast_calc_crc(pmc->dmi_addr);
-                       temp = (crc & 0x3f) >> 1;
-                       hash_index = ((temp & 0x01) << 4) |
-                                    ((temp & 0x02) << 2) |
-                                    ((temp & 0x04)) |
-                                    ((temp & 0x08) >> 2) |
-                                    ((temp & 0x10) >> 4);
-                       csrVal = (1 << hash_index);
-                       if (crc & 1)
-                               hthi |= csrVal;
-                       else
-                               htlo |= csrVal;
-               }
-       }
-
-       spin_lock_irqsave(&fep->lock, flags);
-       FC(fecp, r_cntrl, FEC_RCNTRL_PROM);
-       FW(fecp, hash_table_high, hthi);
-       FW(fecp, hash_table_low, htlo);
-       spin_unlock_irqrestore(&fep->lock, flags);
-}
-
-static int fec_set_mac_address(struct net_device *dev, void *addr)
-{
-       struct sockaddr *mac = addr;
-       struct fec_enet_private *fep = netdev_priv(dev);
-       struct fec *fecp = fep->fecp;
-       int i;
-       __u32 addrhi, addrlo;
-       unsigned long flags;
-
-       /* Get pointer to SCC area in parameter RAM. */
-       for (i = 0; i < 6; i++)
-               dev->dev_addr[i] = mac->sa_data[i];
-
-       /*
-        * Set station address. 
-        */
-       addrhi = ((__u32) dev->dev_addr[0] << 24) |
-                ((__u32) dev->dev_addr[1] << 16) |
-                ((__u32) dev->dev_addr[2] <<  8) |
-                 (__u32) dev->dev_addr[3];
-       addrlo = ((__u32) dev->dev_addr[4] << 24) |
-                ((__u32) dev->dev_addr[5] << 16);
-
-       spin_lock_irqsave(&fep->lock, flags);
-       FW(fecp, addr_low, addrhi);
-       FW(fecp, addr_high, addrlo);
-       spin_unlock_irqrestore(&fep->lock, flags);
-
-       return 0;
-}
-
-/*
- * This function is called to start or restart the FEC during a link
- * change.  This only happens when switching between half and full
- * duplex.
- */
-void fec_restart(struct net_device *dev, int duplex, int speed)
-{
-#ifdef CONFIG_DUET
-       immap_t *immap = (immap_t *) IMAP_ADDR;
-       __u32 cptr;
-#endif
-       struct fec_enet_private *fep = netdev_priv(dev);
-       struct fec *fecp = fep->fecp;
-       const struct fec_platform_info *fpi = fep->fpi;
-       cbd_t *bdp;
-       struct sk_buff *skb;
-       int i;
-       __u32 addrhi, addrlo;
-
-       fec_whack_reset(fep->fecp);
-
-       /*
-        * Set station address. 
-        */
-       addrhi = ((__u32) dev->dev_addr[0] << 24) |
-                ((__u32) dev->dev_addr[1] << 16) |
-                ((__u32) dev->dev_addr[2] <<  8) |
-                (__u32) dev->dev_addr[3];
-       addrlo = ((__u32) dev->dev_addr[4] << 24) |
-                ((__u32) dev->dev_addr[5] << 16);
-       FW(fecp, addr_low, addrhi);
-       FW(fecp, addr_high, addrlo);
-
-       /*
-        * Reset all multicast. 
-        */
-       FW(fecp, hash_table_high, 0);
-       FW(fecp, hash_table_low, 0);
-
-       /*
-        * Set maximum receive buffer size. 
-        */
-       FW(fecp, r_buff_size, PKT_MAXBLR_SIZE);
-       FW(fecp, r_hash, PKT_MAXBUF_SIZE);
-
-       /*
-        * Set receive and transmit descriptor base. 
-        */
-       FW(fecp, r_des_start, iopa((__u32) (fep->rx_bd_base)));
-       FW(fecp, x_des_start, iopa((__u32) (fep->tx_bd_base)));
-
-       fep->dirty_tx = fep->cur_tx = fep->tx_bd_base;
-       fep->tx_free = fep->tx_ring;
-       fep->cur_rx = fep->rx_bd_base;
-
-       /*
-        * Reset SKB receive buffers 
-        */
-       for (i = 0; i < fep->rx_ring; i++) {
-               if ((skb = fep->rx_skbuff[i]) == NULL)
-                       continue;
-               fep->rx_skbuff[i] = NULL;
-               dev_kfree_skb(skb);
-       }
-
-       /*
-        * Initialize the receive buffer descriptors. 
-        */
-       for (i = 0, bdp = fep->rx_bd_base; i < fep->rx_ring; i++, bdp++) {
-               skb = dev_alloc_skb(ENET_RX_FRSIZE);
-               if (skb == NULL) {
-                       printk(KERN_WARNING DRV_MODULE_NAME
-                              ": %s Memory squeeze, unable to allocate skb\n",
-                              dev->name);
-                       fep->stats.rx_dropped++;
-                       break;
-               }
-               fep->rx_skbuff[i] = skb;
-               skb->dev = dev;
-               CBDW_BUFADDR(bdp, dma_map_single(NULL, skb->data,
-                                        L1_CACHE_ALIGN(PKT_MAXBUF_SIZE),
-                                        DMA_FROM_DEVICE));
-               CBDW_DATLEN(bdp, 0);    /* zero */
-               CBDW_SC(bdp, BD_ENET_RX_EMPTY |
-                       ((i < fep->rx_ring - 1) ? 0 : BD_SC_WRAP));
-       }
-       /*
-        * if we failed, fillup remainder 
-        */
-       for (; i < fep->rx_ring; i++, bdp++) {
-               fep->rx_skbuff[i] = NULL;
-               CBDW_SC(bdp, (i < fep->rx_ring - 1) ? 0 : BD_SC_WRAP);
-       }
-
-       /*
-        * Reset SKB transmit buffers.  
-        */
-       for (i = 0; i < fep->tx_ring; i++) {
-               if ((skb = fep->tx_skbuff[i]) == NULL)
-                       continue;
-               fep->tx_skbuff[i] = NULL;
-               dev_kfree_skb(skb);
-       }
-
-       /*
-        * ...and the same for transmit.  
-        */
-       for (i = 0, bdp = fep->tx_bd_base; i < fep->tx_ring; i++, bdp++) {
-               fep->tx_skbuff[i] = NULL;
-               CBDW_BUFADDR(bdp, virt_to_bus(NULL));
-               CBDW_DATLEN(bdp, 0);
-               CBDW_SC(bdp, (i < fep->tx_ring - 1) ? 0 : BD_SC_WRAP);
-       }
-
-       /*
-        * Enable big endian and don't care about SDMA FC. 
-        */
-       FW(fecp, fun_code, 0x78000000);
-
-       /*
-        * Set MII speed. 
-        */
-       FW(fecp, mii_speed, fep->fec_phy_speed);
-
-       /*
-        * Clear any outstanding interrupt. 
-        */
-       FW(fecp, ievent, 0xffc0);
-       FW(fecp, ivec, (fpi->fec_irq / 2) << 29);
-
-       /*
-        * adjust to speed (only for DUET & RMII) 
-        */
-#ifdef CONFIG_DUET
-       cptr = in_be32(&immap->im_cpm.cp_cptr);
-       switch (fpi->fec_no) {
-       case 0:
-               /*
-                * check if in RMII mode 
-                */
-               if ((cptr & 0x100) == 0)
-                       break;
-
-               if (speed == 10)
-                       cptr |= 0x0000010;
-               else if (speed == 100)
-                       cptr &= ~0x0000010;
-               break;
-       case 1:
-               /*
-                * check if in RMII mode 
-                */
-               if ((cptr & 0x80) == 0)
-                       break;
-
-               if (speed == 10)
-                       cptr |= 0x0000008;
-               else if (speed == 100)
-                       cptr &= ~0x0000008;
-               break;
-       default:
-               break;
-       }
-       out_be32(&immap->im_cpm.cp_cptr, cptr);
-#endif
-
-       FW(fecp, r_cntrl, FEC_RCNTRL_MII_MODE); /* MII enable */
-       /*
-        * adjust to duplex mode 
-        */
-       if (duplex) {
-               FC(fecp, r_cntrl, FEC_RCNTRL_DRT);
-               FS(fecp, x_cntrl, FEC_TCNTRL_FDEN);     /* FD enable */
-       } else {
-               FS(fecp, r_cntrl, FEC_RCNTRL_DRT);
-               FC(fecp, x_cntrl, FEC_TCNTRL_FDEN);     /* FD disable */
-       }
-
-       /*
-        * Enable interrupts we wish to service. 
-        */
-       FW(fecp, imask, FEC_ENET_TXF | FEC_ENET_TXB |
-          FEC_ENET_RXF | FEC_ENET_RXB);
-
-       /*
-        * And last, enable the transmit and receive processing. 
-        */
-       FW(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN);
-       FW(fecp, r_des_active, 0x01000000);
-}
-
-void fec_stop(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fec_t *fecp = fep->fecp;
-       struct sk_buff *skb;
-       int i;
-
-       if ((FR(fecp, ecntrl) & FEC_ECNTRL_ETHER_EN) == 0)
-               return;         /* already down */
-
-       FW(fecp, x_cntrl, 0x01);        /* Graceful transmit stop */
-       for (i = 0; ((FR(fecp, ievent) & 0x10000000) == 0) &&
-            i < FEC_RESET_DELAY; i++)
-               udelay(1);
-
-       if (i == FEC_RESET_DELAY)
-               printk(KERN_WARNING DRV_MODULE_NAME
-                      ": %s FEC timeout on graceful transmit stop\n",
-                      dev->name);
-       /*
-        * Disable FEC. Let only MII interrupts. 
-        */
-       FW(fecp, imask, 0);
-       FW(fecp, ecntrl, ~FEC_ECNTRL_ETHER_EN);
-
-       /*
-        * Reset SKB transmit buffers.  
-        */
-       for (i = 0; i < fep->tx_ring; i++) {
-               if ((skb = fep->tx_skbuff[i]) == NULL)
-                       continue;
-               fep->tx_skbuff[i] = NULL;
-               dev_kfree_skb(skb);
-       }
-
-       /*
-        * Reset SKB receive buffers 
-        */
-       for (i = 0; i < fep->rx_ring; i++) {
-               if ((skb = fep->rx_skbuff[i]) == NULL)
-                       continue;
-               fep->rx_skbuff[i] = NULL;
-               dev_kfree_skb(skb);
-       }
-}
-
-/* common receive function */
-static int fec_enet_rx_common(struct fec_enet_private *ep,
-                             struct net_device *dev, int budget)
-{
-       fec_t *fecp = fep->fecp;
-       const struct fec_platform_info *fpi = fep->fpi;
-       cbd_t *bdp;
-       struct sk_buff *skb, *skbn, *skbt;
-       int received = 0;
-       __u16 pkt_len, sc;
-       int curidx;
-
-       /*
-        * First, grab all of the stats for the incoming packet.
-        * These get messed up if we get called due to a busy condition.
-        */
-       bdp = fep->cur_rx;
-
-       /* clear RX status bits for napi*/
-       if (fpi->use_napi)
-               FW(fecp, ievent, FEC_ENET_RXF | FEC_ENET_RXB);
-
-       while (((sc = CBDR_SC(bdp)) & BD_ENET_RX_EMPTY) == 0) {
-
-               curidx = bdp - fep->rx_bd_base;
-
-               /*
-                * Since we have allocated space to hold a complete frame,
-                * the last indicator should be set.
-                */
-               if ((sc & BD_ENET_RX_LAST) == 0)
-                       printk(KERN_WARNING DRV_MODULE_NAME
-                              ": %s rcv is not +last\n",
-                              dev->name);
-
-               /*
-                * Check for errors. 
-                */
-               if (sc & (BD_ENET_RX_LG | BD_ENET_RX_SH | BD_ENET_RX_CL |
-                         BD_ENET_RX_NO | BD_ENET_RX_CR | BD_ENET_RX_OV)) {
-                       fep->stats.rx_errors++;
-                       /* Frame too long or too short. */
-                       if (sc & (BD_ENET_RX_LG | BD_ENET_RX_SH))
-                               fep->stats.rx_length_errors++;
-                       /* Frame alignment */
-                       if (sc & (BD_ENET_RX_NO | BD_ENET_RX_CL))
-                               fep->stats.rx_frame_errors++;
-                       /* CRC Error */
-                       if (sc & BD_ENET_RX_CR)
-                               fep->stats.rx_crc_errors++;
-                       /* FIFO overrun */
-                       if (sc & BD_ENET_RX_OV)
-                               fep->stats.rx_crc_errors++;
-
-                       skbn = fep->rx_skbuff[curidx];
-                       BUG_ON(skbn == NULL);
-
-               } else {
-                       skb = fep->rx_skbuff[curidx];
-                       BUG_ON(skb == NULL);
-
-                       /*
-                        * Process the incoming frame.
-                        */
-                       fep->stats.rx_packets++;
-                       pkt_len = CBDR_DATLEN(bdp) - 4; /* remove CRC */
-                       fep->stats.rx_bytes += pkt_len + 4;
-
-                       if (pkt_len <= fpi->rx_copybreak) {
-                               /* +2 to make IP header L1 cache aligned */
-                               skbn = dev_alloc_skb(pkt_len + 2);
-                               if (skbn != NULL) {
-                                       skb_reserve(skbn, 2);   /* align IP header */
-                                       skb_copy_from_linear_data(skb,
-                                                                 skbn->data,
-                                                                 pkt_len);
-                                       /* swap */
-                                       skbt = skb;
-                                       skb = skbn;
-                                       skbn = skbt;
-                               }
-                       } else
-                               skbn = dev_alloc_skb(ENET_RX_FRSIZE);
-
-                       if (skbn != NULL) {
-                               skb_put(skb, pkt_len);  /* Make room */
-                               skb->protocol = eth_type_trans(skb, dev);
-                               received++;
-                               if (!fpi->use_napi)
-                                       netif_rx(skb);
-                               else
-                                       netif_receive_skb(skb);
-                       } else {
-                               printk(KERN_WARNING DRV_MODULE_NAME
-                                      ": %s Memory squeeze, dropping packet.\n",
-                                      dev->name);
-                               fep->stats.rx_dropped++;
-                               skbn = skb;
-                       }
-               }
-
-               fep->rx_skbuff[curidx] = skbn;
-               CBDW_BUFADDR(bdp, dma_map_single(NULL, skbn->data,
-                                                L1_CACHE_ALIGN(PKT_MAXBUF_SIZE),
-                                                DMA_FROM_DEVICE));
-               CBDW_DATLEN(bdp, 0);
-               CBDW_SC(bdp, (sc & ~BD_ENET_RX_STATS) | BD_ENET_RX_EMPTY);
-
-               /*
-                * Update BD pointer to next entry. 
-                */
-               if ((sc & BD_ENET_RX_WRAP) == 0)
-                       bdp++;
-               else
-                       bdp = fep->rx_bd_base;
-
-               /*
-                * Doing this here will keep the FEC running while we process
-                * incoming frames.  On a heavily loaded network, we should be
-                * able to keep up at the expense of system resources.
-                */
-               FW(fecp, r_des_active, 0x01000000);
-
-               if (received >= budget)
-                       break;
-
-       }
-
-       fep->cur_rx = bdp;
-
-       if (fpi->use_napi) {
-               if (received < budget) {
-                       netif_rx_complete(dev, &fep->napi);
-
-                       /* enable RX interrupt bits */
-                       FS(fecp, imask, FEC_ENET_RXF | FEC_ENET_RXB);
-               }
-       }
-
-       return received;
-}
-
-static void fec_enet_tx(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       cbd_t *bdp;
-       struct sk_buff *skb;
-       int dirtyidx, do_wake;
-       __u16 sc;
-
-       spin_lock(&fep->lock);
-       bdp = fep->dirty_tx;
-
-       do_wake = 0;
-       while (((sc = CBDR_SC(bdp)) & BD_ENET_TX_READY) == 0) {
-
-               dirtyidx = bdp - fep->tx_bd_base;
-
-               if (fep->tx_free == fep->tx_ring)
-                       break;
-
-               skb = fep->tx_skbuff[dirtyidx];
-
-               /*
-                * Check for errors. 
-                */
-               if (sc & (BD_ENET_TX_HB | BD_ENET_TX_LC |
-                         BD_ENET_TX_RL | BD_ENET_TX_UN | BD_ENET_TX_CSL)) {
-                       fep->stats.tx_errors++;
-                       if (sc & BD_ENET_TX_HB) /* No heartbeat */
-                               fep->stats.tx_heartbeat_errors++;
-                       if (sc & BD_ENET_TX_LC) /* Late collision */
-                               fep->stats.tx_window_errors++;
-                       if (sc & BD_ENET_TX_RL) /* Retrans limit */
-                               fep->stats.tx_aborted_errors++;
-                       if (sc & BD_ENET_TX_UN) /* Underrun */
-                               fep->stats.tx_fifo_errors++;
-                       if (sc & BD_ENET_TX_CSL)        /* Carrier lost */
-                               fep->stats.tx_carrier_errors++;
-               } else
-                       fep->stats.tx_packets++;
-
-               if (sc & BD_ENET_TX_READY)
-                       printk(KERN_WARNING DRV_MODULE_NAME
-                              ": %s HEY! Enet xmit interrupt and TX_READY.\n",
-                              dev->name);
-
-               /*
-                * Deferred means some collisions occurred during transmit,
-                * but we eventually sent the packet OK.
-                */
-               if (sc & BD_ENET_TX_DEF)
-                       fep->stats.collisions++;
-
-               /*
-                * Free the sk buffer associated with this last transmit. 
-                */
-               dev_kfree_skb_irq(skb);
-               fep->tx_skbuff[dirtyidx] = NULL;
-
-               /*
-                * Update pointer to next buffer descriptor to be transmitted. 
-                */
-               if ((sc & BD_ENET_TX_WRAP) == 0)
-                       bdp++;
-               else
-                       bdp = fep->tx_bd_base;
-
-               /*
-                * Since we have freed up a buffer, the ring is no longer
-                * full.
-                */
-               if (!fep->tx_free++)
-                       do_wake = 1;
-       }
-
-       fep->dirty_tx = bdp;
-
-       spin_unlock(&fep->lock);
-
-       if (do_wake && netif_queue_stopped(dev))
-               netif_wake_queue(dev);
-}
-
-/*
- * The interrupt handler.
- * This is called from the MPC core interrupt.
- */
-static irqreturn_t
-fec_enet_interrupt(int irq, void *dev_id)
-{
-       struct net_device *dev = dev_id;
-       struct fec_enet_private *fep;
-       const struct fec_platform_info *fpi;
-       fec_t *fecp;
-       __u32 int_events;
-       __u32 int_events_napi;
-
-       if (unlikely(dev == NULL))
-               return IRQ_NONE;
-
-       fep = netdev_priv(dev);
-       fecp = fep->fecp;
-       fpi = fep->fpi;
-
-       /*
-        * Get the interrupt events that caused us to be here.
-        */
-       while ((int_events = FR(fecp, ievent) & FR(fecp, imask)) != 0) {
-
-               if (!fpi->use_napi)
-                       FW(fecp, ievent, int_events);
-               else {
-                       int_events_napi = int_events & ~(FEC_ENET_RXF | FEC_ENET_RXB);
-                       FW(fecp, ievent, int_events_napi);
-               }
-
-               if ((int_events & (FEC_ENET_HBERR | FEC_ENET_BABR |
-                                  FEC_ENET_BABT | FEC_ENET_EBERR)) != 0)
-                       printk(KERN_WARNING DRV_MODULE_NAME
-                              ": %s FEC ERROR(s) 0x%x\n",
-                              dev->name, int_events);
-
-               if ((int_events & FEC_ENET_RXF) != 0) {
-                       if (!fpi->use_napi)
-                               fec_enet_rx_common(fep, dev, ~0);
-                       else {
-                               if (netif_rx_schedule_prep(dev, &fep->napi)) {
-                                       /* disable rx interrupts */
-                                       FC(fecp, imask, FEC_ENET_RXF | FEC_ENET_RXB);
-                                       __netif_rx_schedule(dev, &fep->napi);
-                               } else {
-                                       printk(KERN_ERR DRV_MODULE_NAME
-                                              ": %s driver bug! interrupt while in poll!\n",
-                                              dev->name);
-                                       FC(fecp, imask, FEC_ENET_RXF | FEC_ENET_RXB);
-                               }
-                       }
-               }
-
-               if ((int_events & FEC_ENET_TXF) != 0)
-                       fec_enet_tx(dev);
-       }
-
-       return IRQ_HANDLED;
-}
-
-/* This interrupt occurs when the PHY detects a link change. */
-static irqreturn_t
-fec_mii_link_interrupt(int irq, void *dev_id)
-{
-       struct net_device *dev = dev_id;
-       struct fec_enet_private *fep;
-       const struct fec_platform_info *fpi;
-
-       if (unlikely(dev == NULL))
-               return IRQ_NONE;
-
-       fep = netdev_priv(dev);
-       fpi = fep->fpi;
-
-       if (!fpi->use_mdio)
-               return IRQ_NONE;
-
-       /*
-        * Acknowledge the interrupt if possible. If we have not
-        * found the PHY yet we can't process or acknowledge the
-        * interrupt now. Instead we ignore this interrupt for now,
-        * which we can do since it is edge triggered. It will be
-        * acknowledged later by fec_enet_open().
-        */
-       if (!fep->phy)
-               return IRQ_NONE;
-
-       fec_mii_ack_int(dev);
-       fec_mii_link_status_change_check(dev, 0);
-
-       return IRQ_HANDLED;
-}
-
-
-/**********************************************************************************/
-
-static int fec_enet_start_xmit(struct sk_buff *skb, struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fec_t *fecp = fep->fecp;
-       cbd_t *bdp;
-       int curidx;
-       unsigned long flags;
-
-       spin_lock_irqsave(&fep->tx_lock, flags);
-
-       /*
-        * Fill in a Tx ring entry 
-        */
-       bdp = fep->cur_tx;
-
-       if (!fep->tx_free || (CBDR_SC(bdp) & BD_ENET_TX_READY)) {
-               netif_stop_queue(dev);
-               spin_unlock_irqrestore(&fep->tx_lock, flags);
-
-               /*
-                * Ooops.  All transmit buffers are full.  Bail out.
-                * This should not happen, since the tx queue should be stopped.
-                */
-               printk(KERN_WARNING DRV_MODULE_NAME
-                      ": %s tx queue full!.\n", dev->name);
-               return 1;
-       }
-
-       curidx = bdp - fep->tx_bd_base;
-       /*
-        * Clear all of the status flags. 
-        */
-       CBDC_SC(bdp, BD_ENET_TX_STATS);
-
-       /*
-        * Save skb pointer. 
-        */
-       fep->tx_skbuff[curidx] = skb;
-
-       fep->stats.tx_bytes += skb->len;
-
-       /*
-        * Push the data cache so the CPM does not get stale memory data. 
-        */
-       CBDW_BUFADDR(bdp, dma_map_single(NULL, skb->data,
-                                        skb->len, DMA_TO_DEVICE));
-       CBDW_DATLEN(bdp, skb->len);
-
-       dev->trans_start = jiffies;
-
-       /*
-        * If this was the last BD in the ring, start at the beginning again. 
-        */
-       if ((CBDR_SC(bdp) & BD_ENET_TX_WRAP) == 0)
-               fep->cur_tx++;
-       else
-               fep->cur_tx = fep->tx_bd_base;
-
-       if (!--fep->tx_free)
-               netif_stop_queue(dev);
-
-       /*
-        * Trigger transmission start 
-        */
-       CBDS_SC(bdp, BD_ENET_TX_READY | BD_ENET_TX_INTR |
-               BD_ENET_TX_LAST | BD_ENET_TX_TC);
-       FW(fecp, x_des_active, 0x01000000);
-
-       spin_unlock_irqrestore(&fep->tx_lock, flags);
-
-       return 0;
-}
-
-static void fec_timeout(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fep->stats.tx_errors++;
-
-       if (fep->tx_free)
-               netif_wake_queue(dev);
-
-       /* check link status again */
-       fec_mii_link_status_change_check(dev, 0);
-}
-
-static int fec_enet_open(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       const struct fec_platform_info *fpi = fep->fpi;
-       unsigned long flags;
-
-       napi_enable(&fep->napi);
-
-       /* Install our interrupt handler. */
-       if (request_irq(fpi->fec_irq, fec_enet_interrupt, 0, "fec", dev) != 0) {
-               printk(KERN_ERR DRV_MODULE_NAME
-                      ": %s Could not allocate FEC IRQ!", dev->name);
-               napi_disable(&fep->napi);
-               return -EINVAL;
-       }
-
-       /* Install our phy interrupt handler */
-       if (fpi->phy_irq != -1 && 
-               request_irq(fpi->phy_irq, fec_mii_link_interrupt, 0, "fec-phy",
-                               dev) != 0) {
-               printk(KERN_ERR DRV_MODULE_NAME
-                      ": %s Could not allocate PHY IRQ!", dev->name);
-               free_irq(fpi->fec_irq, dev);
-               napi_disable(&fep->napi);
-               return -EINVAL;
-       }
-
-       if (fpi->use_mdio) {
-               fec_mii_startup(dev);
-               netif_carrier_off(dev);
-               fec_mii_link_status_change_check(dev, 1);
-       } else {
-               spin_lock_irqsave(&fep->lock, flags);
-               fec_restart(dev, 1, 100);       /* XXX this sucks */
-               spin_unlock_irqrestore(&fep->lock, flags);
-
-               netif_carrier_on(dev);
-               netif_start_queue(dev);
-       }
-       return 0;
-}
-
-static int fec_enet_close(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       const struct fec_platform_info *fpi = fep->fpi;
-       unsigned long flags;
-
-       netif_stop_queue(dev);
-       napi_disable(&fep->napi);
-       netif_carrier_off(dev);
-
-       if (fpi->use_mdio)
-               fec_mii_shutdown(dev);
-
-       spin_lock_irqsave(&fep->lock, flags);
-       fec_stop(dev);
-       spin_unlock_irqrestore(&fep->lock, flags);
-
-       /* release any irqs */
-       if (fpi->phy_irq != -1)
-               free_irq(fpi->phy_irq, dev);
-       free_irq(fpi->fec_irq, dev);
-
-       return 0;
-}
-
-static struct net_device_stats *fec_enet_get_stats(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       return &fep->stats;
-}
-
-static int fec_enet_poll(struct napi_struct *napi, int budget)
-{
-       struct fec_enet_private *fep = container_of(napi, struct fec_enet_private, napi);
-       struct net_device *dev = fep->dev;
-
-       return fec_enet_rx_common(fep, dev, budget);
-}
-
-/*************************************************************************/
-
-static void fec_get_drvinfo(struct net_device *dev,
-                           struct ethtool_drvinfo *info)
-{
-       strcpy(info->driver, DRV_MODULE_NAME);
-       strcpy(info->version, DRV_MODULE_VERSION);
-}
-
-static int fec_get_regs_len(struct net_device *dev)
-{
-       return sizeof(fec_t);
-}
-
-static void fec_get_regs(struct net_device *dev, struct ethtool_regs *regs,
-                        void *p)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       unsigned long flags;
-
-       if (regs->len < sizeof(fec_t))
-               return;
-
-       regs->version = 0;
-       spin_lock_irqsave(&fep->lock, flags);
-       memcpy_fromio(p, fep->fecp, sizeof(fec_t));
-       spin_unlock_irqrestore(&fep->lock, flags);
-}
-
-static int fec_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       unsigned long flags;
-       int rc;
-
-       spin_lock_irqsave(&fep->lock, flags);
-       rc = mii_ethtool_gset(&fep->mii_if, cmd);
-       spin_unlock_irqrestore(&fep->lock, flags);
-
-       return rc;
-}
-
-static int fec_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       unsigned long flags;
-       int rc;
-
-       spin_lock_irqsave(&fep->lock, flags);
-       rc = mii_ethtool_sset(&fep->mii_if, cmd);
-       spin_unlock_irqrestore(&fep->lock, flags);
-
-       return rc;
-}
-
-static int fec_nway_reset(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       return mii_nway_restart(&fep->mii_if);
-}
-
-static __u32 fec_get_msglevel(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       return fep->msg_enable;
-}
-
-static void fec_set_msglevel(struct net_device *dev, __u32 value)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fep->msg_enable = value;
-}
-
-static const struct ethtool_ops fec_ethtool_ops = {
-       .get_drvinfo    = fec_get_drvinfo,
-       .get_regs_len   = fec_get_regs_len,
-       .get_settings   = fec_get_settings,
-       .set_settings   = fec_set_settings,
-       .nway_reset     = fec_nway_reset,
-       .get_link       = ethtool_op_get_link,
-       .get_msglevel   = fec_get_msglevel,
-       .set_msglevel   = fec_set_msglevel,
-       .set_tx_csum    = ethtool_op_set_tx_csum,       /* local! */
-       .set_sg         = ethtool_op_set_sg,
-       .get_regs       = fec_get_regs,
-};
-
-static int fec_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       struct mii_ioctl_data *mii = (struct mii_ioctl_data *)&rq->ifr_data;
-       unsigned long flags;
-       int rc;
-
-       if (!netif_running(dev))
-               return -EINVAL;
-
-       spin_lock_irqsave(&fep->lock, flags);
-       rc = generic_mii_ioctl(&fep->mii_if, mii, cmd, NULL);
-       spin_unlock_irqrestore(&fep->lock, flags);
-       return rc;
-}
-
-int fec_8xx_init_one(const struct fec_platform_info *fpi,
-                    struct net_device **devp)
-{
-       immap_t *immap = (immap_t *) IMAP_ADDR;
-       static int fec_8xx_version_printed = 0;
-       struct net_device *dev = NULL;
-       struct fec_enet_private *fep = NULL;
-       fec_t *fecp = NULL;
-       int i;
-       int err = 0;
-       int registered = 0;
-       __u32 siel;
-
-       *devp = NULL;
-
-       switch (fpi->fec_no) {
-       case 0:
-               fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec;
-               break;
-#ifdef CONFIG_DUET
-       case 1:
-               fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec2;
-               break;
-#endif
-       default:
-               return -EINVAL;
-       }
-
-       if (fec_8xx_version_printed++ == 0)
-               printk(KERN_INFO "%s", version);
-
-       i = sizeof(*fep) + (sizeof(struct sk_buff **) *
-                           (fpi->rx_ring + fpi->tx_ring));
-
-       dev = alloc_etherdev(i);
-       if (!dev) {
-               err = -ENOMEM;
-               goto err;
-       }
-
-       fep = netdev_priv(dev);
-       fep->dev = dev;
-
-       /* partial reset of FEC */
-       fec_whack_reset(fecp);
-
-       /* point rx_skbuff, tx_skbuff */
-       fep->rx_skbuff = (struct sk_buff **)&fep[1];
-       fep->tx_skbuff = fep->rx_skbuff + fpi->rx_ring;
-
-       fep->fecp = fecp;
-       fep->fpi = fpi;
-
-       /* init locks */
-       spin_lock_init(&fep->lock);
-       spin_lock_init(&fep->tx_lock);
-
-       /*
-        * Set the Ethernet address. 
-        */
-       for (i = 0; i < 6; i++)
-               dev->dev_addr[i] = fpi->macaddr[i];
-
-       fep->ring_base = dma_alloc_coherent(NULL,
-                                           (fpi->tx_ring + fpi->rx_ring) *
-                                           sizeof(cbd_t), &fep->ring_mem_addr,
-                                           GFP_KERNEL);
-       if (fep->ring_base == NULL) {
-               printk(KERN_ERR DRV_MODULE_NAME
-                      ": %s dma alloc failed.\n", dev->name);
-               err = -ENOMEM;
-               goto err;
-       }
-
-       /*
-        * Set receive and transmit descriptor base.
-        */
-       fep->rx_bd_base = fep->ring_base;
-       fep->tx_bd_base = fep->rx_bd_base + fpi->rx_ring;
-
-       /* initialize ring size variables */
-       fep->tx_ring = fpi->tx_ring;
-       fep->rx_ring = fpi->rx_ring;
-
-       /* SIU interrupt */
-       if (fpi->phy_irq != -1 &&
-               (fpi->phy_irq >= SIU_IRQ0 && fpi->phy_irq < SIU_LEVEL7)) {
-
-               siel = in_be32(&immap->im_siu_conf.sc_siel);
-               if ((fpi->phy_irq & 1) == 0)
-                       siel |= (0x80000000 >> fpi->phy_irq);
-               else
-                       siel &= ~(0x80000000 >> (fpi->phy_irq & ~1));
-               out_be32(&immap->im_siu_conf.sc_siel, siel);
-       }
-
-       /*
-        * The FEC Ethernet specific entries in the device structure. 
-        */
-       dev->open = fec_enet_open;
-       dev->hard_start_xmit = fec_enet_start_xmit;
-       dev->tx_timeout = fec_timeout;
-       dev->watchdog_timeo = TX_TIMEOUT;
-       dev->stop = fec_enet_close;
-       dev->get_stats = fec_enet_get_stats;
-       dev->set_multicast_list = fec_set_multicast_list;
-       dev->set_mac_address = fec_set_mac_address;
-       netif_napi_add(dev, &fec->napi,
-                      fec_enet_poll, fpi->napi_weight);
-
-       dev->ethtool_ops = &fec_ethtool_ops;
-       dev->do_ioctl = fec_ioctl;
-
-       fep->fec_phy_speed =
-           ((((fpi->sys_clk + 4999999) / 2500000) / 2) & 0x3F) << 1;
-
-       init_timer(&fep->phy_timer_list);
-
-       /* partial reset of FEC so that only MII works */
-       FW(fecp, mii_speed, fep->fec_phy_speed);
-       FW(fecp, ievent, 0xffc0);
-       FW(fecp, ivec, (fpi->fec_irq / 2) << 29);
-       FW(fecp, imask, 0);
-       FW(fecp, r_cntrl, FEC_RCNTRL_MII_MODE); /* MII enable */
-       FW(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN);
-
-       netif_carrier_off(dev);
-
-       err = register_netdev(dev);
-       if (err != 0)
-               goto err;
-       registered = 1;
-
-       if (fpi->use_mdio) {
-               fep->mii_if.dev = dev;
-               fep->mii_if.mdio_read = fec_mii_read;
-               fep->mii_if.mdio_write = fec_mii_write;
-               fep->mii_if.phy_id_mask = 0x1f;
-               fep->mii_if.reg_num_mask = 0x1f;
-               fep->mii_if.phy_id = fec_mii_phy_id_detect(dev);
-       }
-
-       *devp = dev;
-
-       return 0;
-
-      err:
-       if (dev != NULL) {
-               if (fecp != NULL)
-                       fec_whack_reset(fecp);
-
-               if (registered)
-                       unregister_netdev(dev);
-
-               if (fep != NULL) {
-                       if (fep->ring_base)
-                               dma_free_coherent(NULL,
-                                                 (fpi->tx_ring +
-                                                  fpi->rx_ring) *
-                                                 sizeof(cbd_t), fep->ring_base,
-                                                 fep->ring_mem_addr);
-               }
-               free_netdev(dev);
-       }
-       return err;
-}
-
-int fec_8xx_cleanup_one(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fec_t *fecp = fep->fecp;
-       const struct fec_platform_info *fpi = fep->fpi;
-
-       fec_whack_reset(fecp);
-
-       unregister_netdev(dev);
-
-       dma_free_coherent(NULL, (fpi->tx_ring + fpi->rx_ring) * sizeof(cbd_t),
-                         fep->ring_base, fep->ring_mem_addr);
-
-       free_netdev(dev);
-
-       return 0;
-}
-
-/**************************************************************************************/
-/**************************************************************************************/
-/**************************************************************************************/
-
-static int __init fec_8xx_init(void)
-{
-       return fec_8xx_platform_init();
-}
-
-static void __exit fec_8xx_cleanup(void)
-{
-       fec_8xx_platform_cleanup();
-}
-
-/**************************************************************************************/
-/**************************************************************************************/
-/**************************************************************************************/
-
-module_init(fec_8xx_init);
-module_exit(fec_8xx_cleanup);
diff --git a/drivers/net/fec_8xx/fec_mii.c b/drivers/net/fec_8xx/fec_mii.c
deleted file mode 100644 (file)
index 3b6ca29..0000000
+++ /dev/null
@@ -1,418 +0,0 @@
-/*
- * Fast Ethernet Controller (FEC) driver for Motorola MPC8xx.
- *
- * Copyright (c) 2003 Intracom S.A. 
- *  by Pantelis Antoniou <panto@intracom.gr>
- *
- * Heavily based on original FEC driver by Dan Malek <dan@embeddededge.com>
- * and modifications by Joakim Tjernlund <joakim.tjernlund@lumentis.se>
- *
- * Released under the GPL
- */
-
-#include <linux/module.h>
-#include <linux/types.h>
-#include <linux/kernel.h>
-#include <linux/string.h>
-#include <linux/ptrace.h>
-#include <linux/errno.h>
-#include <linux/ioport.h>
-#include <linux/slab.h>
-#include <linux/interrupt.h>
-#include <linux/init.h>
-#include <linux/delay.h>
-#include <linux/netdevice.h>
-#include <linux/etherdevice.h>
-#include <linux/skbuff.h>
-#include <linux/spinlock.h>
-#include <linux/mii.h>
-#include <linux/ethtool.h>
-#include <linux/bitops.h>
-
-#include <asm/8xx_immap.h>
-#include <asm/pgtable.h>
-#include <asm/mpc8xx.h>
-#include <asm/irq.h>
-#include <asm/uaccess.h>
-#include <asm/cpm1.h>
-
-/*************************************************/
-
-#include "fec_8xx.h"
-
-/*************************************************/
-
-/* Make MII read/write commands for the FEC.
-*/
-#define mk_mii_read(REG)       (0x60020000 | ((REG & 0x1f) << 18))
-#define mk_mii_write(REG, VAL) (0x50020000 | ((REG & 0x1f) << 18) | (VAL & 0xffff))
-#define mk_mii_end             0
-
-/*************************************************/
-
-/* XXX both FECs use the MII interface of FEC1 */
-static DEFINE_SPINLOCK(fec_mii_lock);
-
-#define FEC_MII_LOOPS  10000
-
-int fec_mii_read(struct net_device *dev, int phy_id, int location)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fec_t *fecp;
-       int i, ret = -1;
-       unsigned long flags;
-
-       /* XXX MII interface is only connected to FEC1 */
-       fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec;
-
-       spin_lock_irqsave(&fec_mii_lock, flags);
-
-       if ((FR(fecp, r_cntrl) & FEC_RCNTRL_MII_MODE) == 0) {
-               FS(fecp, r_cntrl, FEC_RCNTRL_MII_MODE); /* MII enable */
-               FS(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN);
-               FW(fecp, ievent, FEC_ENET_MII);
-       }
-
-       /* Add PHY address to register command.  */
-       FW(fecp, mii_speed, fep->fec_phy_speed);
-       FW(fecp, mii_data, (phy_id << 23) | mk_mii_read(location));
-
-       for (i = 0; i < FEC_MII_LOOPS; i++)
-               if ((FR(fecp, ievent) & FEC_ENET_MII) != 0)
-                       break;
-
-       if (i < FEC_MII_LOOPS) {
-               FW(fecp, ievent, FEC_ENET_MII);
-               ret = FR(fecp, mii_data) & 0xffff;
-       }
-
-       spin_unlock_irqrestore(&fec_mii_lock, flags);
-
-       return ret;
-}
-
-void fec_mii_write(struct net_device *dev, int phy_id, int location, int value)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       fec_t *fecp;
-       unsigned long flags;
-       int i;
-
-       /* XXX MII interface is only connected to FEC1 */
-       fecp = &((immap_t *) IMAP_ADDR)->im_cpm.cp_fec;
-
-       spin_lock_irqsave(&fec_mii_lock, flags);
-
-       if ((FR(fecp, r_cntrl) & FEC_RCNTRL_MII_MODE) == 0) {
-               FS(fecp, r_cntrl, FEC_RCNTRL_MII_MODE); /* MII enable */
-               FS(fecp, ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN);
-               FW(fecp, ievent, FEC_ENET_MII);
-       }
-
-       /* Add PHY address to register command.  */
-       FW(fecp, mii_speed, fep->fec_phy_speed);        /* always adapt mii speed */
-       FW(fecp, mii_data, (phy_id << 23) | mk_mii_write(location, value));
-
-       for (i = 0; i < FEC_MII_LOOPS; i++)
-               if ((FR(fecp, ievent) & FEC_ENET_MII) != 0)
-                       break;
-
-       if (i < FEC_MII_LOOPS)
-               FW(fecp, ievent, FEC_ENET_MII);
-
-       spin_unlock_irqrestore(&fec_mii_lock, flags);
-}
-
-/*************************************************/
-
-#ifdef CONFIG_FEC_8XX_GENERIC_PHY
-
-/*
- * Generic PHY support.
- * Should work for all PHYs, but link change is detected by polling
- */
-
-static void generic_timer_callback(unsigned long data)
-{
-       struct net_device *dev = (struct net_device *)data;
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fep->phy_timer_list.expires = jiffies + HZ / 2;
-
-       add_timer(&fep->phy_timer_list);
-
-       fec_mii_link_status_change_check(dev, 0);
-}
-
-static void generic_startup(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fep->phy_timer_list.expires = jiffies + HZ / 2; /* every 500ms */
-       fep->phy_timer_list.data = (unsigned long)dev;
-       fep->phy_timer_list.function = generic_timer_callback;
-       add_timer(&fep->phy_timer_list);
-}
-
-static void generic_shutdown(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       del_timer_sync(&fep->phy_timer_list);
-}
-
-#endif
-
-#ifdef CONFIG_FEC_8XX_DM9161_PHY
-
-/* ------------------------------------------------------------------------- */
-/* The Davicom DM9161 is used on the NETTA board                            */
-
-/* register definitions */
-
-#define MII_DM9161_ACR         16      /* Aux. Config Register         */
-#define MII_DM9161_ACSR                17      /* Aux. Config/Status Register  */
-#define MII_DM9161_10TCSR      18      /* 10BaseT Config/Status Reg.   */
-#define MII_DM9161_INTR                21      /* Interrupt Register           */
-#define MII_DM9161_RECR                22      /* Receive Error Counter Reg.   */
-#define MII_DM9161_DISCR       23      /* Disconnect Counter Register  */
-
-static void dm9161_startup(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fec_mii_write(dev, fep->mii_if.phy_id, MII_DM9161_INTR, 0x0000);
-}
-
-static void dm9161_ack_int(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fec_mii_read(dev, fep->mii_if.phy_id, MII_DM9161_INTR);
-}
-
-static void dm9161_shutdown(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fec_mii_write(dev, fep->mii_if.phy_id, MII_DM9161_INTR, 0x0f00);
-}
-
-#endif
-
-#ifdef CONFIG_FEC_8XX_LXT971_PHY
-
-/* Support for LXT971/972 PHY */
-
-#define MII_LXT971_PCR         16 /* Port Control Register */
-#define MII_LXT971_SR2         17 /* Status Register 2 */
-#define MII_LXT971_IER         18 /* Interrupt Enable Register */
-#define MII_LXT971_ISR         19 /* Interrupt Status Register */
-#define MII_LXT971_LCR         20 /* LED Control Register */
-#define MII_LXT971_TCR         30 /* Transmit Control Register */
-
-static void lxt971_startup(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fec_mii_write(dev, fep->mii_if.phy_id, MII_LXT971_IER, 0x00F2);
-}
-
-static void lxt971_ack_int(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fec_mii_read(dev, fep->mii_if.phy_id, MII_LXT971_ISR);
-}
-
-static void lxt971_shutdown(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-
-       fec_mii_write(dev, fep->mii_if.phy_id, MII_LXT971_IER, 0x0000);
-}
-#endif
-
-/**********************************************************************************/
-
-static const struct phy_info phy_info[] = {
-#ifdef CONFIG_FEC_8XX_DM9161_PHY
-       {
-        .id = 0x00181b88,
-        .name = "DM9161",
-        .startup = dm9161_startup,
-        .ack_int = dm9161_ack_int,
-        .shutdown = dm9161_shutdown,
-        },
-#endif
-#ifdef CONFIG_FEC_8XX_LXT971_PHY
-       {
-        .id = 0x0001378e,
-        .name = "LXT971/972",
-        .startup = lxt971_startup,
-        .ack_int = lxt971_ack_int,
-        .shutdown = lxt971_shutdown,
-       },
-#endif
-#ifdef CONFIG_FEC_8XX_GENERIC_PHY
-       {
-        .id = 0,
-        .name = "GENERIC",
-        .startup = generic_startup,
-        .shutdown = generic_shutdown,
-        },
-#endif
-};
-
-/**********************************************************************************/
-
-int fec_mii_phy_id_detect(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       const struct fec_platform_info *fpi = fep->fpi;
-       int i, r, start, end, phytype, physubtype;
-       const struct phy_info *phy;
-       int phy_hwid, phy_id;
-
-       /* if no MDIO */
-       if (fpi->use_mdio == 0)
-               return -1;
-
-       phy_hwid = -1;
-       fep->phy = NULL;
-
-       /* auto-detect? */
-       if (fpi->phy_addr == -1) {
-               start = 0;
-               end = 32;
-       } else {                /* direct */
-               start = fpi->phy_addr;
-               end = start + 1;
-       }
-
-       for (phy_id = start; phy_id < end; phy_id++) {
-               r = fec_mii_read(dev, phy_id, MII_PHYSID1);
-               if (r == -1 || (phytype = (r & 0xffff)) == 0xffff)
-                       continue;
-               r = fec_mii_read(dev, phy_id, MII_PHYSID2);
-               if (r == -1 || (physubtype = (r & 0xffff)) == 0xffff)
-                       continue;
-               phy_hwid = (phytype << 16) | physubtype;
-               if (phy_hwid != -1)
-                       break;
-       }
-
-       if (phy_hwid == -1) {
-               printk(KERN_ERR DRV_MODULE_NAME
-                      ": %s No PHY detected!\n", dev->name);
-               return -1;
-       }
-
-       for (i = 0, phy = phy_info; i < ARRAY_SIZE(phy_info); i++, phy++)
-               if (phy->id == (phy_hwid >> 4) || phy->id == 0)
-                       break;
-
-       if (i >= ARRAY_SIZE(phy_info)) {
-               printk(KERN_ERR DRV_MODULE_NAME
-                      ": %s PHY id 0x%08x is not supported!\n",
-                      dev->name, phy_hwid);
-               return -1;
-       }
-
-       fep->phy = phy;
-
-       printk(KERN_INFO DRV_MODULE_NAME
-              ": %s Phy @ 0x%x, type %s (0x%08x)\n",
-              dev->name, phy_id, fep->phy->name, phy_hwid);
-
-       return phy_id;
-}
-
-void fec_mii_startup(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       const struct fec_platform_info *fpi = fep->fpi;
-
-       if (!fpi->use_mdio || fep->phy == NULL)
-               return;
-
-       if (fep->phy->startup == NULL)
-               return;
-
-       (*fep->phy->startup) (dev);
-}
-
-void fec_mii_shutdown(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       const struct fec_platform_info *fpi = fep->fpi;
-
-       if (!fpi->use_mdio || fep->phy == NULL)
-               return;
-
-       if (fep->phy->shutdown == NULL)
-               return;
-
-       (*fep->phy->shutdown) (dev);
-}
-
-void fec_mii_ack_int(struct net_device *dev)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       const struct fec_platform_info *fpi = fep->fpi;
-
-       if (!fpi->use_mdio || fep->phy == NULL)
-               return;
-
-       if (fep->phy->ack_int == NULL)
-               return;
-
-       (*fep->phy->ack_int) (dev);
-}
-
-/* helper function */
-static int mii_negotiated(struct mii_if_info *mii)
-{
-       int advert, lpa, val;
-
-       if (!mii_link_ok(mii))
-               return 0;
-
-       val = (*mii->mdio_read) (mii->dev, mii->phy_id, MII_BMSR);
-       if ((val & BMSR_ANEGCOMPLETE) == 0)
-               return 0;
-
-       advert = (*mii->mdio_read) (mii->dev, mii->phy_id, MII_ADVERTISE);
-       lpa = (*mii->mdio_read) (mii->dev, mii->phy_id, MII_LPA);
-
-       return mii_nway_result(advert & lpa);
-}
-
-void fec_mii_link_status_change_check(struct net_device *dev, int init_media)
-{
-       struct fec_enet_private *fep = netdev_priv(dev);
-       unsigned int media;
-       unsigned long flags;
-
-       if (mii_check_media(&fep->mii_if, netif_msg_link(fep), init_media) == 0)
-               return;
-
-       media = mii_negotiated(&fep->mii_if);
-
-       if (netif_carrier_ok(dev)) {
-               spin_lock_irqsave(&fep->lock, flags);
-               fec_restart(dev, !!(media & ADVERTISE_FULL),
-                           (media & (ADVERTISE_100FULL | ADVERTISE_100HALF)) ?
-                           100 : 10);
-               spin_unlock_irqrestore(&fep->lock, flags);
-
-               netif_start_queue(dev);
-       } else {
-               netif_stop_queue(dev);
-
-               spin_lock_irqsave(&fep->lock, flags);
-               fec_stop(dev);
-               spin_unlock_irqrestore(&fep->lock, flags);
-
-       }
-}
index 29681c4b700b13d2fa8b4f106b40faceec403716..8a1d93a2bb815c380bb18710369912834c2d2f06 100644 (file)
@@ -48,16 +48,32 @@ void of_dev_put(struct of_device *dev)
 }
 EXPORT_SYMBOL(of_dev_put);
 
-static ssize_t dev_show_devspec(struct device *dev,
+static ssize_t devspec_show(struct device *dev,
                                struct device_attribute *attr, char *buf)
 {
        struct of_device *ofdev;
 
        ofdev = to_of_device(dev);
-       return sprintf(buf, "%s", ofdev->node->full_name);
+       return sprintf(buf, "%s\n", ofdev->node->full_name);
 }
 
-static DEVICE_ATTR(devspec, S_IRUGO, dev_show_devspec, NULL);
+static ssize_t modalias_show(struct device *dev,
+                               struct device_attribute *attr, char *buf)
+{
+       struct of_device *ofdev = to_of_device(dev);
+       ssize_t len = 0;
+
+       len = of_device_get_modalias(ofdev, buf, PAGE_SIZE - 2);
+       buf[len] = '\n';
+       buf[len+1] = 0;
+       return len+1;
+}
+
+struct device_attribute of_platform_device_attrs[] = {
+       __ATTR_RO(devspec),
+       __ATTR_RO(modalias),
+       __ATTR_NULL
+};
 
 /**
  * of_release_dev - free an of device structure when all users of it are finished.
@@ -78,25 +94,61 @@ EXPORT_SYMBOL(of_release_dev);
 
 int of_device_register(struct of_device *ofdev)
 {
-       int rc;
-
        BUG_ON(ofdev->node == NULL);
-
-       rc = device_register(&ofdev->dev);
-       if (rc)
-               return rc;
-
-       rc = device_create_file(&ofdev->dev, &dev_attr_devspec);
-       if (rc)
-               device_unregister(&ofdev->dev);
-
-       return rc;
+       return device_register(&ofdev->dev);
 }
 EXPORT_SYMBOL(of_device_register);
 
 void of_device_unregister(struct of_device *ofdev)
 {
-       device_remove_file(&ofdev->dev, &dev_attr_devspec);
        device_unregister(&ofdev->dev);
 }
 EXPORT_SYMBOL(of_device_unregister);
+
+ssize_t of_device_get_modalias(struct of_device *ofdev,
+                               char *str, ssize_t len)
+{
+       const char *compat;
+       int cplen, i;
+       ssize_t tsize, csize, repend;
+
+       /* Name & Type */
+       csize = snprintf(str, len, "of:N%sT%s",
+                               ofdev->node->name, ofdev->node->type);
+
+       /* Get compatible property if any */
+       compat = of_get_property(ofdev->node, "compatible", &cplen);
+       if (!compat)
+               return csize;
+
+       /* Find true end (we tolerate multiple \0 at the end */
+       for (i = (cplen - 1); i >= 0 && !compat[i]; i--)
+               cplen--;
+       if (!cplen)
+               return csize;
+       cplen++;
+
+       /* Check space (need cplen+1 chars including final \0) */
+       tsize = csize + cplen;
+       repend = tsize;
+
+       if (csize >= len)               /* @ the limit, all is already filled */
+               return tsize;
+
+       if (tsize >= len) {             /* limit compat list */
+               cplen = len - csize - 1;
+               repend = len;
+       }
+
+       /* Copy and do char replacement */
+       memcpy(&str[csize + 1], compat, cplen);
+       for (i = csize; i < repend; i++) {
+               char c = str[i];
+               if (c == '\0')
+                       str[i] = 'C';
+               else if (c == ' ')
+                       str[i] = '_';
+       }
+
+       return tsize;
+}
index 000681e98f2c2d8ef6df123ab8026cc0caca751f..1c9cab844f10aaa60cf80d9996b4782d0c1256e6 100644 (file)
@@ -137,38 +137,6 @@ int of_gpio_simple_xlate(struct of_gpio_chip *of_gc, struct device_node *np,
 }
 EXPORT_SYMBOL(of_gpio_simple_xlate);
 
-/* Should be sufficient for now, later we'll use dynamic bases. */
-#if defined(CONFIG_PPC32) || defined(CONFIG_SPARC32)
-#define GPIOS_PER_CHIP 32
-#else
-#define GPIOS_PER_CHIP 64
-#endif
-
-static int of_get_gpiochip_base(struct device_node *np)
-{
-       struct device_node *gc = NULL;
-       int gpiochip_base = 0;
-
-       while ((gc = of_find_all_nodes(gc))) {
-               if (!of_get_property(gc, "gpio-controller", NULL))
-                       continue;
-
-               if (gc != np) {
-                       gpiochip_base += GPIOS_PER_CHIP;
-                       continue;
-               }
-
-               of_node_put(gc);
-
-               if (gpiochip_base >= ARCH_NR_GPIOS)
-                       return -ENOSPC;
-
-               return gpiochip_base;
-       }
-
-       return -ENOENT;
-}
-
 /**
  * of_mm_gpiochip_add - Add memory mapped GPIO chip (bank)
  * @np:                device node of the GPIO chip
@@ -205,11 +173,7 @@ int of_mm_gpiochip_add(struct device_node *np,
        if (!mm_gc->regs)
                goto err1;
 
-       gc->base = of_get_gpiochip_base(np);
-       if (gc->base < 0) {
-               ret = gc->base;
-               goto err1;
-       }
+       gc->base = -1;
 
        if (!of_gc->xlate)
                of_gc->xlate = of_gpio_simple_xlate;
index ca09a63a64db7bdf66a03f0da0069518615e3d6f..298de0f95d70d24d15727ab7b54a28d438854ec2 100644 (file)
@@ -17,6 +17,8 @@
 #include <linux/of_device.h>
 #include <linux/of_platform.h>
 
+extern struct device_attribute of_platform_device_attrs[];
+
 static int of_platform_bus_match(struct device *dev, struct device_driver *drv)
 {
        struct of_device *of_dev = to_of_device(dev);
@@ -103,6 +105,7 @@ int of_bus_type_init(struct bus_type *bus, const char *name)
        bus->suspend = of_platform_device_suspend;
        bus->resume = of_platform_device_resume;
        bus->shutdown = of_platform_device_shutdown;
+       bus->dev_attrs = of_platform_device_attrs;
        return bus_register(bus);
 }
 
index 8eb99848c40247b3d86a9012b3e13de9fdff652e..57d68304218b68485da2c534ea110b571c1de631 100644 (file)
@@ -1,69 +1,13 @@
 #ifndef _ASM_POWERPC_IOCTL_H
 #define _ASM_POWERPC_IOCTL_H
 
-
-/*
- * this was copied from the alpha as it's a bit cleaner there.
- *                         -- Cort
- */
-
-#define _IOC_NRBITS    8
-#define _IOC_TYPEBITS  8
 #define _IOC_SIZEBITS  13
 #define _IOC_DIRBITS   3
 
-#define _IOC_NRMASK    ((1 << _IOC_NRBITS)-1)
-#define _IOC_TYPEMASK  ((1 << _IOC_TYPEBITS)-1)
-#define _IOC_SIZEMASK  ((1 << _IOC_SIZEBITS)-1)
-#define _IOC_DIRMASK   ((1 << _IOC_DIRBITS)-1)
-
-#define _IOC_NRSHIFT   0
-#define _IOC_TYPESHIFT (_IOC_NRSHIFT+_IOC_NRBITS)
-#define _IOC_SIZESHIFT (_IOC_TYPESHIFT+_IOC_TYPEBITS)
-#define _IOC_DIRSHIFT  (_IOC_SIZESHIFT+_IOC_SIZEBITS)
-
-/*
- * Direction bits _IOC_NONE could be 0, but OSF/1 gives it a bit.
- * And this turns out useful to catch old ioctl numbers in header
- * files for us.
- */
 #define _IOC_NONE      1U
 #define _IOC_READ      2U
 #define _IOC_WRITE     4U
 
-#define _IOC(dir,type,nr,size) \
-       (((dir)  << _IOC_DIRSHIFT) | \
-        ((type) << _IOC_TYPESHIFT) | \
-        ((nr)   << _IOC_NRSHIFT) | \
-        ((size) << _IOC_SIZESHIFT))
-
-/* provoke compile error for invalid uses of size argument */
-extern unsigned int __invalid_size_argument_for_IOC;
-#define _IOC_TYPECHECK(t) \
-       ((sizeof(t) == sizeof(t[1]) && \
-         sizeof(t) < (1 << _IOC_SIZEBITS)) ? \
-         sizeof(t) : __invalid_size_argument_for_IOC)
-
-/* used to create numbers */
-#define _IO(type,nr)           _IOC(_IOC_NONE,(type),(nr),0)
-#define _IOR(type,nr,size)     _IOC(_IOC_READ,(type),(nr),(_IOC_TYPECHECK(size)))
-#define _IOW(type,nr,size)     _IOC(_IOC_WRITE,(type),(nr),(_IOC_TYPECHECK(size)))
-#define _IOWR(type,nr,size)    _IOC(_IOC_READ|_IOC_WRITE,(type),(nr),(_IOC_TYPECHECK(size)))
-#define _IOR_BAD(type,nr,size) _IOC(_IOC_READ,(type),(nr),sizeof(size))
-#define _IOW_BAD(type,nr,size) _IOC(_IOC_WRITE,(type),(nr),sizeof(size))
-#define _IOWR_BAD(type,nr,size)        _IOC(_IOC_READ|_IOC_WRITE,(type),(nr),sizeof(size))
-
-/* used to decode them.. */
-#define _IOC_DIR(nr)           (((nr) >> _IOC_DIRSHIFT) & _IOC_DIRMASK)
-#define _IOC_TYPE(nr)          (((nr) >> _IOC_TYPESHIFT) & _IOC_TYPEMASK)
-#define _IOC_NR(nr)            (((nr) >> _IOC_NRSHIFT) & _IOC_NRMASK)
-#define _IOC_SIZE(nr)          (((nr) >> _IOC_SIZESHIFT) & _IOC_SIZEMASK)
-
-/* various drivers, such as the pcmcia stuff, need these... */
-#define IOC_IN         (_IOC_WRITE << _IOC_DIRSHIFT)
-#define IOC_OUT                (_IOC_READ << _IOC_DIRSHIFT)
-#define IOC_INOUT      ((_IOC_WRITE|_IOC_READ) << _IOC_DIRSHIFT)
-#define IOCSIZE_MASK   (_IOC_SIZEMASK << _IOC_SIZESHIFT)
-#define IOCSIZE_SHIFT  (_IOC_SIZESHIFT)
+#include <asm-generic/ioctl.h>
 
 #endif /* _ASM_POWERPC_IOCTL_H */
index 39c5c5f62bf5bd740fd92568aa030c4afaff84f3..d1dc16afb1186c4a40f374a0e2f5ba3d89ffff2f 100644 (file)
@@ -182,6 +182,7 @@ extern int mmu_io_psize;
 extern int mmu_kernel_ssize;
 extern int mmu_highuser_ssize;
 extern u16 mmu_slb_size;
+extern unsigned long tce_alloc_start, tce_alloc_end;
 
 /*
  * If the processor supports 64k normal pages but not 64k cache
diff --git a/include/asm-powerpc/mpc6xx.h b/include/asm-powerpc/mpc6xx.h
new file mode 100644 (file)
index 0000000..effc229
--- /dev/null
@@ -0,0 +1,6 @@
+#ifndef __ASM_POWERPC_MPC6xx_H
+#define __ASM_POWERPC_MPC6xx_H
+
+void mpc6xx_enter_standby(void);
+
+#endif
index a4d0f876b427d9540c4821a12fce209a8df12bd9..fe566a348a86e7e770ab014b11d96b380563183f 100644 (file)
@@ -353,6 +353,8 @@ struct mpic
 #define MPIC_ENABLE_MCK                        0x00000200
 /* Disable bias among target selection, spread interrupts evenly */
 #define MPIC_NO_BIAS                   0x00000400
+/* Ignore NIRQS as reported by FRR */
+#define MPIC_BROKEN_FRR_NIRQS          0x00000800
 
 /* MPIC HW modification ID */
 #define MPIC_REGSET_MASK               0xf0000000
index 6526e139a4636783959ee2820c078881c57b33c8..3c123990ca2e0f3db95b03c939e62a6e6050df30 100644 (file)
@@ -21,8 +21,6 @@ extern struct of_device *of_device_alloc(struct device_node *np,
                                         const char *bus_id,
                                         struct device *parent);
 
-extern ssize_t of_device_get_modalias(struct of_device *ofdev,
-                                       char *str, ssize_t len);
 extern int of_device_uevent(struct device *dev,
                            struct kobj_uevent_env *env);
 
index 2dbd4e7884faee59e96e53b391e1495bee1307e2..ef96bfd4ef4cbda90bb6827a75e6911ff7386ad0 100644 (file)
@@ -356,6 +356,12 @@ END_FTR_SECTION_IFCLR(CPU_FTR_601)
 #define toreal(rd)
 #define fromreal(rd)
 
+/*
+ * We use addis to ensure compatibility with the "classic" ppc versions of
+ * these macros, which use rs = 0 to get the tophys offset in rd, rather than
+ * converting the address in r0, and so this version has to do that too
+ * (i.e. set register rd to 0 when rs == 0).
+ */
 #define tophys(rd,rs)                          \
        addis   rd,rs,0
 
index 39023dde1cc4c869ed9d7f4ed9b8baa623206ad7..38d87e5e569d5edb79d384e6916e833e936a69eb 100644 (file)
@@ -119,6 +119,7 @@ extern int ptrace_put_reg(struct task_struct *task, int regno,
 #ifndef __powerpc64__
 #define IS_CRITICAL_EXC(regs)  (((regs)->trap & 2) != 0)
 #define IS_MCHECK_EXC(regs)    (((regs)->trap & 4) != 0)
+#define IS_DEBUG_EXC(regs)     (((regs)->trap & 8) != 0)
 #endif /* ! __powerpc64__ */
 #define TRAP(regs)             ((regs)->trap & ~0xF)
 #ifdef __powerpc64__
index 505f35bacaa913a1d339406f0be1f1599389572f..1cd43e3d94fb71f8736d31a2f4e51f2176faf7cf 100644 (file)
@@ -37,6 +37,8 @@ extern void cpu_die(void);
 extern void smp_send_debugger_break(int cpu);
 extern void smp_message_recv(int);
 
+DECLARE_PER_CPU(unsigned int, pvr);
+
 #ifdef CONFIG_HOTPLUG_CPU
 extern void fixup_irqs(cpumask_t map);
 int generic_cpu_disable(void);
index 2b6559a6d113d6e883887ff6766be4989ed54dcb..df781adac6dd02125ed0404ac941c75f6eaebac6 100644 (file)
@@ -190,6 +190,7 @@ extern struct task_struct *_switch(struct thread_struct *prev,
 
 extern unsigned int rtas_data;
 extern int mem_init_done;      /* set on boot once kmalloc can be called */
+extern int init_bootmem_done;  /* set on !NUMA once bootmem is available */
 extern unsigned long memory_limit;
 extern unsigned long klimit;
 
index d030f5ce39adafdac57aa0fd93d88bc8f985b2ea..b705c2a7651a929a42780163d6bd303a412f998b 100644 (file)
@@ -116,7 +116,6 @@ static inline struct thread_info *current_thread_info(void)
 #define TIF_SECCOMP            10      /* secure computing */
 #define TIF_RESTOREALL         11      /* Restore all regs (implies NOERROR) */
 #define TIF_NOERROR            12      /* Force successful syscall return */
-#define TIF_RESTORE_SIGMASK    13      /* Restore signal mask in do_signal */
 #define TIF_FREEZE             14      /* Freezing for suspend */
 #define TIF_RUNLATCH           15      /* Is the runlatch enabled? */
 #define TIF_ABI_PENDING                16      /* 32/64 bit switch needed */
@@ -134,21 +133,33 @@ static inline struct thread_info *current_thread_info(void)
 #define _TIF_SECCOMP           (1<<TIF_SECCOMP)
 #define _TIF_RESTOREALL                (1<<TIF_RESTOREALL)
 #define _TIF_NOERROR           (1<<TIF_NOERROR)
-#define _TIF_RESTORE_SIGMASK   (1<<TIF_RESTORE_SIGMASK)
 #define _TIF_FREEZE            (1<<TIF_FREEZE)
 #define _TIF_RUNLATCH          (1<<TIF_RUNLATCH)
 #define _TIF_ABI_PENDING       (1<<TIF_ABI_PENDING)
 #define _TIF_SYSCALL_T_OR_A    (_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT|_TIF_SECCOMP)
 
-#define _TIF_USER_WORK_MASK    ( _TIF_SIGPENDING | \
-                                _TIF_NEED_RESCHED | _TIF_RESTORE_SIGMASK)
+#define _TIF_USER_WORK_MASK    (_TIF_SIGPENDING | _TIF_NEED_RESCHED)
 #define _TIF_PERSYSCALL_MASK   (_TIF_RESTOREALL|_TIF_NOERROR)
 
 /* Bits in local_flags */
 /* Don't move TLF_NAPPING without adjusting the code in entry_32.S */
 #define TLF_NAPPING            0       /* idle thread enabled NAP mode */
+#define TLF_SLEEPING           1       /* suspend code enabled SLEEP mode */
+#define TLF_RESTORE_SIGMASK    2       /* Restore signal mask in do_signal */
 
 #define _TLF_NAPPING           (1 << TLF_NAPPING)
+#define _TLF_SLEEPING          (1 << TLF_SLEEPING)
+#define _TLF_RESTORE_SIGMASK   (1 << TLF_RESTORE_SIGMASK)
+
+#ifndef __ASSEMBLY__
+#define HAVE_SET_RESTORE_SIGMASK       1
+static inline void set_restore_sigmask(void)
+{
+       struct thread_info *ti = current_thread_info();
+       ti->local_flags |= _TLF_RESTORE_SIGMASK;
+       set_bit(TIF_SIGPENDING, &ti->flags);
+}
+#endif /* !__ASSEMBLY__ */
 
 #endif /* __KERNEL__ */
 
index ce5de6e0e6907915f0982da71afbcc8d9d6590dd..febd581ec9b047a01b1ff67425fef02375e34b50 100644 (file)
@@ -33,6 +33,7 @@ extern unsigned      tb_to_us;
 
 struct rtc_time;
 extern void to_tm(int tim, struct rtc_time * tm);
+extern void GregorianDay(struct rtc_time *tm);
 extern time_t last_rtc_update;
 
 extern void generic_calibrate_decr(void);
index 88320a05f0a8738615bc8ea62c5cc606edf9ff15..5eb8e599e5cc37413dcf1dadd076edd984135f73 100644 (file)
 
 #ifdef __KERNEL__
 
+#include <linux/irqreturn.h>
+
 #ifdef CONFIG_XMON
 extern void xmon_setup(void);
 extern void xmon_register_spus(struct list_head *list);
+struct pt_regs;
+extern int xmon(struct pt_regs *excp);
+extern irqreturn_t xmon_irq(int, void *);
 #else
 static inline void xmon_setup(void) { };
 static inline void xmon_register_spus(struct list_head *list) { };
 #endif
 
+#if defined(CONFIG_XMON) && defined(CONFIG_SMP)
+extern int cpus_are_in_xmon(void);
+#endif
+
 #endif /* __KERNEL __ */
 #endif /* __ASM_POWERPC_XMON_H */
index afe338217d91cc0b3e0166c0d9511970f4401871..d3a74e00a3e13455b7ad7f6eec81d58727e40386 100644 (file)
@@ -24,4 +24,7 @@ static inline void of_device_free(struct of_device *dev)
        of_release_dev(&dev->dev);
 }
 
+extern ssize_t of_device_get_modalias(struct of_device *ofdev,
+                                       char *str, ssize_t len);
+
 #endif /* _LINUX_OF_DEVICE_H */