Robert,

There is a problem with this part of the patch.
It modifies heavily smpboot_64.c and cpufeature_32.h.
Perfmon patches those files but the changes proposed here
are beyond the changes made by perfmon. I think you should
first submit the cleanup for the unmodified files, Then I will pick
them up. Otherwise, I be maintaining a file that is way out-of-sync
with mainline.

Thanks.



On Fri, May 16, 2008 at 8:14 PM, Robert Richter <[EMAIL PROTECTED]> wrote:
> Signed-off-by: Robert Richter <[EMAIL PROTECTED]>
> ---
>  arch/x86/kernel/cpu/common.c     |    1 -
>  arch/x86/kernel/process_32.c     |    2 +-
>  arch/x86/kernel/smpboot_64.c     | 1110 
> --------------------------------------
>  include/asm-x86/cpufeature_32.h  |  177 ------
>  include/asm-x86/thread_info_32.h |    7 +-
>  include/asm-x86/thread_info_64.h |    2 +-
>  6 files changed, 6 insertions(+), 1293 deletions(-)
>  delete mode 100644 arch/x86/kernel/smpboot_64.c
>  delete mode 100644 include/asm-x86/cpufeature_32.h
>
> diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c
> index cfc524d..316e6b1 100644
> --- a/arch/x86/kernel/cpu/common.c
> +++ b/arch/x86/kernel/cpu/common.c
> @@ -6,7 +6,6 @@
>  #include <linux/percpu.h>
>  #include <linux/bootmem.h>
>  #include <linux/perfmon_kern.h>
> -#include <asm/semaphore.h>
>  #include <asm/processor.h>
>  #include <asm/i387.h>
>  #include <asm/msr.h>
> diff --git a/arch/x86/kernel/process_32.c b/arch/x86/kernel/process_32.c
> index 526378d..957c3bd 100644
> --- a/arch/x86/kernel/process_32.c
> +++ b/arch/x86/kernel/process_32.c
> @@ -527,7 +527,6 @@ __switch_to_xtra(struct task_struct *prev_p, struct 
> task_struct *next_p,
>                        hard_enable_TSC();
>        }
>
> -
>  #ifdef X86_BTS
>        if (test_tsk_thread_flag(prev_p, TIF_BTS_TRACE_TS))
>                ptrace_bts_take_timestamp(prev_p, BTS_TASK_DEPARTS);
> @@ -536,6 +535,7 @@ __switch_to_xtra(struct task_struct *prev_p, struct 
> task_struct *next_p,
>                ptrace_bts_take_timestamp(next_p, BTS_TASK_ARRIVES);
>  #endif
>
> +
>        if (!test_tsk_thread_flag(next_p, TIF_IO_BITMAP)) {
>                /*
>                 * Disable the bitmap via an invalid offset. We still cache
> diff --git a/arch/x86/kernel/smpboot_64.c b/arch/x86/kernel/smpboot_64.c
> deleted file mode 100644
> index 1955c99..0000000
> --- a/arch/x86/kernel/smpboot_64.c
> +++ /dev/null
> @@ -1,1110 +0,0 @@
> -/*
> - *     x86 SMP booting functions
> - *
> - *     (c) 1995 Alan Cox, Building #3 <[EMAIL PROTECTED]>
> - *     (c) 1998, 1999, 2000 Ingo Molnar <[EMAIL PROTECTED]>
> - *     Copyright 2001 Andi Kleen, SuSE Labs.
> - *
> - *     Much of the core SMP work is based on previous work by Thomas Radke, 
> to
> - *     whom a great many thanks are extended.
> - *
> - *     Thanks to Intel for making available several different Pentium,
> - *     Pentium Pro and Pentium-II/Xeon MP machines.
> - *     Original development of Linux SMP code supported by Caldera.
> - *
> - *     This code is released under the GNU General Public License version 2
> - *
> - *     Fixes
> - *             Felix Koop      :       NR_CPUS used properly
> - *             Jose Renau      :       Handle single CPU case.
> - *             Alan Cox        :       By repeated request 8) - Total 
> BogoMIP report.
> - *             Greg Wright     :       Fix for kernel stacks panic.
> - *             Erich Boleyn    :       MP v1.4 and additional changes.
> - *     Matthias Sattler        :       Changes for 2.1 kernel map.
> - *     Michel Lespinasse       :       Changes for 2.1 kernel map.
> - *     Michael Chastain        :       Change trampoline.S to gnu as.
> - *             Alan Cox        :       Dumb bug: 'B' step PPro's are fine
> - *             Ingo Molnar     :       Added APIC timers, based on code
> - *                                     from Jose Renau
> - *             Ingo Molnar     :       various cleanups and rewrites
> - *             Tigran Aivazian :       fixed "0.00 in /proc/uptime on SMP" 
> bug.
> - *     Maciej W. Rozycki       :       Bits for genuine 82489DX APICs
> - *     Andi Kleen              :       Changed for SMP boot into long mode.
> - *             Rusty Russell   :       Hacked into shape for new "hotplug" 
> boot process.
> - *      Andi Kleen              :       Converted to new state machine.
> - *                                     Various cleanups.
> - *                                     Probably mostly hotplug CPU ready now.
> - *     Ashok Raj                       : CPU hotplug support
> - */
> -
> -
> -#include <linux/init.h>
> -
> -#include <linux/mm.h>
> -#include <linux/kernel_stat.h>
> -#include <linux/bootmem.h>
> -#include <linux/thread_info.h>
> -#include <linux/module.h>
> -#include <linux/delay.h>
> -#include <linux/mc146818rtc.h>
> -#include <linux/smp.h>
> -#include <linux/kdebug.h>
> -#include <linux/perfmon_kern.h>
> -
> -#include <asm/mtrr.h>
> -#include <asm/pgalloc.h>
> -#include <asm/desc.h>
> -#include <asm/tlbflush.h>
> -#include <asm/proto.h>
> -#include <asm/nmi.h>
> -#include <asm/irq.h>
> -#include <asm/hw_irq.h>
> -#include <asm/numa.h>
> -
> -/* Number of siblings per CPU package */
> -int smp_num_siblings = 1;
> -EXPORT_SYMBOL(smp_num_siblings);
> -
> -/* Last level cache ID of each logical CPU */
> -DEFINE_PER_CPU(u16, cpu_llc_id) = BAD_APICID;
> -
> -/* Bitmask of currently online CPUs */
> -cpumask_t cpu_online_map __read_mostly;
> -
> -EXPORT_SYMBOL(cpu_online_map);
> -
> -/*
> - * Private maps to synchronize booting between AP and BP.
> - * Probably not needed anymore, but it makes for easier debugging. -AK
> - */
> -cpumask_t cpu_callin_map;
> -cpumask_t cpu_callout_map;
> -cpumask_t cpu_possible_map;
> -EXPORT_SYMBOL(cpu_possible_map);
> -
> -/* Per CPU bogomips and other parameters */
> -DEFINE_PER_CPU_SHARED_ALIGNED(struct cpuinfo_x86, cpu_info);
> -EXPORT_PER_CPU_SYMBOL(cpu_info);
> -
> -/* Set when the idlers are all forked */
> -int smp_threads_ready;
> -
> -/* representing HT siblings of each logical CPU */
> -DEFINE_PER_CPU(cpumask_t, cpu_sibling_map);
> -EXPORT_PER_CPU_SYMBOL(cpu_sibling_map);
> -
> -/* representing HT and core siblings of each logical CPU */
> -DEFINE_PER_CPU(cpumask_t, cpu_core_map);
> -EXPORT_PER_CPU_SYMBOL(cpu_core_map);
> -
> -/*
> - * Trampoline 80x86 program as an array.
> - */
> -
> -extern const unsigned char trampoline_data[];
> -extern const unsigned char trampoline_end[];
> -
> -/* State of each CPU */
> -DEFINE_PER_CPU(int, cpu_state) = { 0 };
> -
> -/*
> - * Store all idle threads, this can be reused instead of creating
> - * a new thread. Also avoids complicated thread destroy functionality
> - * for idle threads.
> - */
> -#ifdef CONFIG_HOTPLUG_CPU
> -/*
> - * Needed only for CONFIG_HOTPLUG_CPU because __cpuinitdata is
> - * removed after init for !CONFIG_HOTPLUG_CPU.
> - */
> -static DEFINE_PER_CPU(struct task_struct *, idle_thread_array);
> -#define get_idle_for_cpu(x)     (per_cpu(idle_thread_array, x))
> -#define set_idle_for_cpu(x,p)   (per_cpu(idle_thread_array, x) = (p))
> -#else
> -struct task_struct *idle_thread_array[NR_CPUS] __cpuinitdata ;
> -#define get_idle_for_cpu(x)     (idle_thread_array[(x)])
> -#define set_idle_for_cpu(x,p)   (idle_thread_array[(x)] = (p))
> -#endif
> -
> -
> -/*
> - * Currently trivial. Write the real->protected mode
> - * bootstrap into the page concerned. The caller
> - * has made sure it's suitably aligned.
> - */
> -
> -static unsigned long __cpuinit setup_trampoline(void)
> -{
> -       void *tramp = __va(SMP_TRAMPOLINE_BASE);
> -       memcpy(tramp, trampoline_data, trampoline_end - trampoline_data);
> -       return virt_to_phys(tramp);
> -}
> -
> -/*
> - * The bootstrap kernel entry code has set these up. Save them for
> - * a given CPU
> - */
> -
> -static void __cpuinit smp_store_cpu_info(int id)
> -{
> -       struct cpuinfo_x86 *c = &cpu_data(id);
> -
> -       *c = boot_cpu_data;
> -       c->cpu_index = id;
> -       identify_cpu(c);
> -       print_cpu_info(c);
> -}
> -
> -static atomic_t init_deasserted __cpuinitdata;
> -
> -/*
> - * Report back to the Boot Processor.
> - * Running on AP.
> - */
> -void __cpuinit smp_callin(void)
> -{
> -       int cpuid, phys_id;
> -       unsigned long timeout;
> -
> -       /*
> -        * If waken up by an INIT in an 82489DX configuration
> -        * we may get here before an INIT-deassert IPI reaches
> -        * our local APIC.  We have to wait for the IPI or we'll
> -        * lock up on an APIC access.
> -        */
> -       while (!atomic_read(&init_deasserted))
> -               cpu_relax();
> -
> -       /*
> -        * (This works even if the APIC is not enabled.)
> -        */
> -       phys_id = GET_APIC_ID(apic_read(APIC_ID));
> -       cpuid = smp_processor_id();
> -       if (cpu_isset(cpuid, cpu_callin_map)) {
> -               panic("smp_callin: phys CPU#%d, CPU#%d already present??\n",
> -                                       phys_id, cpuid);
> -       }
> -       Dprintk("CPU#%d (phys ID: %d) waiting for CALLOUT\n", cpuid, phys_id);
> -
> -       /*
> -        * STARTUP IPIs are fragile beasts as they might sometimes
> -        * trigger some glue motherboard logic. Complete APIC bus
> -        * silence for 1 second, this overestimates the time the
> -        * boot CPU is spending to send the up to 2 STARTUP IPIs
> -        * by a factor of two. This should be enough.
> -        */
> -
> -       /*
> -        * Waiting 2s total for startup (udelay is not yet working)
> -        */
> -       timeout = jiffies + 2*HZ;
> -       while (time_before(jiffies, timeout)) {
> -               /*
> -                * Has the boot CPU finished it's STARTUP sequence?
> -                */
> -               if (cpu_isset(cpuid, cpu_callout_map))
> -                       break;
> -               cpu_relax();
> -       }
> -
> -       if (!time_before(jiffies, timeout)) {
> -               panic("smp_callin: CPU%d started up but did not get a 
> callout!\n",
> -                       cpuid);
> -       }
> -
> -       /*
> -        * the boot CPU has finished the init stage and is spinning
> -        * on callin_map until we finish. We are free to set up this
> -        * CPU, first the APIC. (this is probably redundant on most
> -        * boards)
> -        */
> -
> -       Dprintk("CALLIN, before setup_local_APIC().\n");
> -       setup_local_APIC();
> -       end_local_APIC_setup();
> -
> -       /*
> -        * Get our bogomips.
> -        *
> -        * Need to enable IRQs because it can take longer and then
> -        * the NMI watchdog might kill us.
> -        */
> -       local_irq_enable();
> -       calibrate_delay();
> -       local_irq_disable();
> -       Dprintk("Stack at about %p\n",&cpuid);
> -
> -       /*
> -        * Save our processor parameters
> -        */
> -       smp_store_cpu_info(cpuid);
> -
> -       /*
> -        * Allow the master to continue.
> -        */
> -       cpu_set(cpuid, cpu_callin_map);
> -}
> -
> -/* maps the cpu to the sched domain representing multi-core */
> -cpumask_t cpu_coregroup_map(int cpu)
> -{
> -       struct cpuinfo_x86 *c = &cpu_data(cpu);
> -       /*
> -        * For perf, we return last level cache shared map.
> -        * And for power savings, we return cpu_core_map
> -        */
> -       if (sched_mc_power_savings || sched_smt_power_savings)
> -               return per_cpu(cpu_core_map, cpu);
> -       else
> -               return c->llc_shared_map;
> -}
> -
> -/* representing cpus for which sibling maps can be computed */
> -static cpumask_t cpu_sibling_setup_map;
> -
> -static inline void set_cpu_sibling_map(int cpu)
> -{
> -       int i;
> -       struct cpuinfo_x86 *c = &cpu_data(cpu);
> -
> -       cpu_set(cpu, cpu_sibling_setup_map);
> -
> -       if (smp_num_siblings > 1) {
> -               for_each_cpu_mask(i, cpu_sibling_setup_map) {
> -                       if (c->phys_proc_id == cpu_data(i).phys_proc_id &&
> -                           c->cpu_core_id == cpu_data(i).cpu_core_id) {
> -                               cpu_set(i, per_cpu(cpu_sibling_map, cpu));
> -                               cpu_set(cpu, per_cpu(cpu_sibling_map, i));
> -                               cpu_set(i, per_cpu(cpu_core_map, cpu));
> -                               cpu_set(cpu, per_cpu(cpu_core_map, i));
> -                               cpu_set(i, c->llc_shared_map);
> -                               cpu_set(cpu, cpu_data(i).llc_shared_map);
> -                       }
> -               }
> -       } else {
> -               cpu_set(cpu, per_cpu(cpu_sibling_map, cpu));
> -       }
> -
> -       cpu_set(cpu, c->llc_shared_map);
> -
> -       if (current_cpu_data.x86_max_cores == 1) {
> -               per_cpu(cpu_core_map, cpu) = per_cpu(cpu_sibling_map, cpu);
> -               c->booted_cores = 1;
> -               return;
> -       }
> -
> -       for_each_cpu_mask(i, cpu_sibling_setup_map) {
> -               if (per_cpu(cpu_llc_id, cpu) != BAD_APICID &&
> -                   per_cpu(cpu_llc_id, cpu) == per_cpu(cpu_llc_id, i)) {
> -                       cpu_set(i, c->llc_shared_map);
> -                       cpu_set(cpu, cpu_data(i).llc_shared_map);
> -               }
> -               if (c->phys_proc_id == cpu_data(i).phys_proc_id) {
> -                       cpu_set(i, per_cpu(cpu_core_map, cpu));
> -                       cpu_set(cpu, per_cpu(cpu_core_map, i));
> -                       /*
> -                        *  Does this new cpu bringup a new core?
> -                        */
> -                       if (cpus_weight(per_cpu(cpu_sibling_map, cpu)) == 1) {
> -                               /*
> -                                * for each core in package, increment
> -                                * the booted_cores for this new cpu
> -                                */
> -                               if (first_cpu(per_cpu(cpu_sibling_map, i)) == 
> i)
> -                                       c->booted_cores++;
> -                               /*
> -                                * increment the core count for all
> -                                * the other cpus in this package
> -                                */
> -                               if (i != cpu)
> -                                       cpu_data(i).booted_cores++;
> -                       } else if (i != cpu && !c->booted_cores)
> -                               c->booted_cores = cpu_data(i).booted_cores;
> -               }
> -       }
> -}
> -
> -/*
> - * Setup code on secondary processor (after comming out of the trampoline)
> - */
> -void __cpuinit start_secondary(void)
> -{
> -       /*
> -        * Dont put anything before smp_callin(), SMP
> -        * booting is too fragile that we want to limit the
> -        * things done here to the most necessary things.
> -        */
> -       cpu_init();
> -       preempt_disable();
> -       smp_callin();
> -
> -       /* otherwise gcc will move up the smp_processor_id before the 
> cpu_init */
> -       barrier();
> -
> -       /*
> -        * Check TSC sync first:
> -        */
> -       check_tsc_sync_target();
> -
> -       if (nmi_watchdog == NMI_IO_APIC) {
> -               disable_8259A_irq(0);
> -               enable_NMI_through_LVT0();
> -               enable_8259A_irq(0);
> -       }
> -
> -       /*
> -        * The sibling maps must be set before turing the online map on for
> -        * this cpu
> -        */
> -       set_cpu_sibling_map(smp_processor_id());
> -
> -       /*
> -        * We need to hold call_lock, so there is no inconsistency
> -        * between the time smp_call_function() determines number of
> -        * IPI recipients, and the time when the determination is made
> -        * for which cpus receive the IPI in genapic_flat.c. Holding this
> -        * lock helps us to not include this cpu in a currently in progress
> -        * smp_call_function().
> -        */
> -       lock_ipi_call_lock();
> -       spin_lock(&vector_lock);
> -
> -       /* Setup the per cpu irq handling data structures */
> -       __setup_vector_irq(smp_processor_id());
> -       /*
> -        * Allow the master to continue.
> -        */
> -       cpu_set(smp_processor_id(), cpu_online_map);
> -       per_cpu(cpu_state, smp_processor_id()) = CPU_ONLINE;
> -       spin_unlock(&vector_lock);
> -
> -       unlock_ipi_call_lock();
> -
> -       setup_secondary_clock();
> -
> -       cpu_idle();
> -}
> -
> -extern volatile unsigned long init_rsp;
> -extern void (*initial_code)(void);
> -
> -#ifdef APIC_DEBUG
> -static void inquire_remote_apic(int apicid)
> -{
> -       unsigned i, regs[] = { APIC_ID >> 4, APIC_LVR >> 4, APIC_SPIV >> 4 };
> -       char *names[] = { "ID", "VERSION", "SPIV" };
> -       int timeout;
> -       u32 status;
> -
> -       printk(KERN_INFO "Inquiring remote APIC #%d...\n", apicid);
> -
> -       for (i = 0; i < ARRAY_SIZE(regs); i++) {
> -               printk(KERN_INFO "... APIC #%d %s: ", apicid, names[i]);
> -
> -               /*
> -                * Wait for idle.
> -                */
> -               status = safe_apic_wait_icr_idle();
> -               if (status)
> -                       printk(KERN_CONT
> -                              "a previous APIC delivery may have failed\n");
> -
> -               apic_write(APIC_ICR2, SET_APIC_DEST_FIELD(apicid));
> -               apic_write(APIC_ICR, APIC_DM_REMRD | regs[i]);
> -
> -               timeout = 0;
> -               do {
> -                       udelay(100);
> -                       status = apic_read(APIC_ICR) & APIC_ICR_RR_MASK;
> -               } while (status == APIC_ICR_RR_INPROG && timeout++ < 1000);
> -
> -               switch (status) {
> -               case APIC_ICR_RR_VALID:
> -                       status = apic_read(APIC_RRR);
> -                       printk(KERN_CONT "%08x\n", status);
> -                       break;
> -               default:
> -                       printk(KERN_CONT "failed\n");
> -               }
> -       }
> -}
> -#endif
> -
> -/*
> - * Kick the secondary to wake up.
> - */
> -static int __cpuinit wakeup_secondary_via_INIT(int phys_apicid, unsigned int 
> start_rip)
> -{
> -       unsigned long send_status, accept_status = 0;
> -       int maxlvt, num_starts, j;
> -
> -       Dprintk("Asserting INIT.\n");
> -
> -       /*
> -        * Turn INIT on target chip
> -        */
> -       apic_write(APIC_ICR2, SET_APIC_DEST_FIELD(phys_apicid));
> -
> -       /*
> -        * Send IPI
> -        */
> -       apic_write(APIC_ICR, APIC_INT_LEVELTRIG | APIC_INT_ASSERT
> -                               | APIC_DM_INIT);
> -
> -       Dprintk("Waiting for send to finish...\n");
> -       send_status = safe_apic_wait_icr_idle();
> -
> -       mdelay(10);
> -
> -       Dprintk("Deasserting INIT.\n");
> -
> -       /* Target chip */
> -       apic_write(APIC_ICR2, SET_APIC_DEST_FIELD(phys_apicid));
> -
> -       /* Send IPI */
> -       apic_write(APIC_ICR, APIC_INT_LEVELTRIG | APIC_DM_INIT);
> -
> -       Dprintk("Waiting for send to finish...\n");
> -       send_status = safe_apic_wait_icr_idle();
> -
> -       mb();
> -       atomic_set(&init_deasserted, 1);
> -
> -       num_starts = 2;
> -
> -       /*
> -        * Run STARTUP IPI loop.
> -        */
> -       Dprintk("#startup loops: %d.\n", num_starts);
> -
> -       maxlvt = lapic_get_maxlvt();
> -
> -       for (j = 1; j <= num_starts; j++) {
> -               Dprintk("Sending STARTUP #%d.\n",j);
> -               apic_write(APIC_ESR, 0);
> -               apic_read(APIC_ESR);
> -               Dprintk("After apic_write.\n");
> -
> -               /*
> -                * STARTUP IPI
> -                */
> -
> -               /* Target chip */
> -               apic_write(APIC_ICR2, SET_APIC_DEST_FIELD(phys_apicid));
> -
> -               /* Boot on the stack */
> -               /* Kick the second */
> -               apic_write(APIC_ICR, APIC_DM_STARTUP | (start_rip >> 12));
> -
> -               /*
> -                * Give the other CPU some time to accept the IPI.
> -                */
> -               udelay(300);
> -
> -               Dprintk("Startup point 1.\n");
> -
> -               Dprintk("Waiting for send to finish...\n");
> -               send_status = safe_apic_wait_icr_idle();
> -
> -               /*
> -                * Give the other CPU some time to accept the IPI.
> -                */
> -               udelay(200);
> -               /*
> -                * Due to the Pentium erratum 3AP.
> -                */
> -               if (maxlvt > 3) {
> -                       apic_write(APIC_ESR, 0);
> -               }
> -               accept_status = (apic_read(APIC_ESR) & 0xEF);
> -               if (send_status || accept_status)
> -                       break;
> -       }
> -       Dprintk("After Startup.\n");
> -
> -       if (send_status)
> -               printk(KERN_ERR "APIC never delivered???\n");
> -       if (accept_status)
> -               printk(KERN_ERR "APIC delivery error (%lx).\n", 
> accept_status);
> -
> -       return (send_status | accept_status);
> -}
> -
> -struct create_idle {
> -       struct work_struct work;
> -       struct task_struct *idle;
> -       struct completion done;
> -       int cpu;
> -};
> -
> -static void __cpuinit do_fork_idle(struct work_struct *work)
> -{
> -       struct create_idle *c_idle =
> -               container_of(work, struct create_idle, work);
> -
> -       c_idle->idle = fork_idle(c_idle->cpu);
> -       complete(&c_idle->done);
> -}
> -
> -/*
> - * Boot one CPU.
> - */
> -static int __cpuinit do_boot_cpu(int cpu, int apicid)
> -{
> -       unsigned long boot_error;
> -       int timeout;
> -       unsigned long start_rip;
> -       struct create_idle c_idle = {
> -               .cpu = cpu,
> -               .done = COMPLETION_INITIALIZER_ONSTACK(c_idle.done),
> -       };
> -       INIT_WORK(&c_idle.work, do_fork_idle);
> -
> -       /* allocate memory for gdts of secondary cpus. Hotplug is considered 
> */
> -       if (!cpu_gdt_descr[cpu].address &&
> -               !(cpu_gdt_descr[cpu].address = get_zeroed_page(GFP_KERNEL))) {
> -               printk(KERN_ERR "Failed to allocate GDT for CPU %d\n", cpu);
> -               return -1;
> -       }
> -
> -       /* Allocate node local memory for AP pdas */
> -       if (cpu_pda(cpu) == &boot_cpu_pda[cpu]) {
> -               struct x8664_pda *newpda, *pda;
> -               int node = cpu_to_node(cpu);
> -               pda = cpu_pda(cpu);
> -               newpda = kmalloc_node(sizeof (struct x8664_pda), GFP_ATOMIC,
> -                                     node);
> -               if (newpda) {
> -                       memcpy(newpda, pda, sizeof (struct x8664_pda));
> -                       cpu_pda(cpu) = newpda;
> -               } else
> -                       printk(KERN_ERR
> -               "Could not allocate node local PDA for CPU %d on node %d\n",
> -                               cpu, node);
> -       }
> -
> -       alternatives_smp_switch(1);
> -
> -       c_idle.idle = get_idle_for_cpu(cpu);
> -
> -       if (c_idle.idle) {
> -               c_idle.idle->thread.sp = (unsigned long) (((struct pt_regs *)
> -                       (THREAD_SIZE +  task_stack_page(c_idle.idle))) - 1);
> -               init_idle(c_idle.idle, cpu);
> -               goto do_rest;
> -       }
> -
> -       /*
> -        * During cold boot process, keventd thread is not spun up yet.
> -        * When we do cpu hot-add, we create idle threads on the fly, we 
> should
> -        * not acquire any attributes from the calling context. Hence the 
> clean
> -        * way to create kernel_threads() is to do that from keventd().
> -        * We do the current_is_keventd() due to the fact that ACPI notifier
> -        * was also queuing to keventd() and when the caller is already 
> running
> -        * in context of keventd(), we would end up with locking up the 
> keventd
> -        * thread.
> -        */
> -       if (!keventd_up() || current_is_keventd())
> -               c_idle.work.func(&c_idle.work);
> -       else {
> -               schedule_work(&c_idle.work);
> -               wait_for_completion(&c_idle.done);
> -       }
> -
> -       if (IS_ERR(c_idle.idle)) {
> -               printk("failed fork for CPU %d\n", cpu);
> -               return PTR_ERR(c_idle.idle);
> -       }
> -
> -       set_idle_for_cpu(cpu, c_idle.idle);
> -
> -do_rest:
> -
> -       cpu_pda(cpu)->pcurrent = c_idle.idle;
> -
> -       start_rip = setup_trampoline();
> -
> -       init_rsp = c_idle.idle->thread.sp;
> -       load_sp0(&per_cpu(init_tss, cpu), &c_idle.idle->thread);
> -       initial_code = start_secondary;
> -       clear_tsk_thread_flag(c_idle.idle, TIF_FORK);
> -
> -       printk(KERN_INFO "Booting processor %d/%d APIC 0x%x\n", cpu,
> -               cpus_weight(cpu_present_map),
> -               apicid);
> -
> -       /*
> -        * This grunge runs the startup process for
> -        * the targeted processor.
> -        */
> -
> -       atomic_set(&init_deasserted, 0);
> -
> -       Dprintk("Setting warm reset code and vector.\n");
> -
> -       CMOS_WRITE(0xa, 0xf);
> -       local_flush_tlb();
> -       Dprintk("1.\n");
> -       *((volatile unsigned short *) phys_to_virt(0x469)) = start_rip >> 4;
> -       Dprintk("2.\n");
> -       *((volatile unsigned short *) phys_to_virt(0x467)) = start_rip & 0xf;
> -       Dprintk("3.\n");
> -
> -       /*
> -        * Be paranoid about clearing APIC errors.
> -        */
> -       apic_write(APIC_ESR, 0);
> -       apic_read(APIC_ESR);
> -
> -       /*
> -        * Status is now clean
> -        */
> -       boot_error = 0;
> -
> -       /*
> -        * Starting actual IPI sequence...
> -        */
> -       boot_error = wakeup_secondary_via_INIT(apicid, start_rip);
> -
> -       if (!boot_error) {
> -               /*
> -                * allow APs to start initializing.
> -                */
> -               Dprintk("Before Callout %d.\n", cpu);
> -               cpu_set(cpu, cpu_callout_map);
> -               Dprintk("After Callout %d.\n", cpu);
> -
> -               /*
> -                * Wait 5s total for a response
> -                */
> -               for (timeout = 0; timeout < 50000; timeout++) {
> -                       if (cpu_isset(cpu, cpu_callin_map))
> -                               break;  /* It has booted */
> -                       udelay(100);
> -               }
> -
> -               if (cpu_isset(cpu, cpu_callin_map)) {
> -                       /* number CPUs logically, starting from 1 (BSP is 0) 
> */
> -                       Dprintk("CPU has booted.\n");
> -               } else {
> -                       boot_error = 1;
> -                       if (*((volatile unsigned char 
> *)phys_to_virt(SMP_TRAMPOLINE_BASE))
> -                                       == 0xA5)
> -                               /* trampoline started but...? */
> -                               printk("Stuck ??\n");
> -                       else
> -                               /* trampoline code not run */
> -                               printk("Not responding.\n");
> -#ifdef APIC_DEBUG
> -                       inquire_remote_apic(apicid);
> -#endif
> -               }
> -       }
> -       if (boot_error) {
> -               cpu_clear(cpu, cpu_callout_map); /* was set here 
> (do_boot_cpu()) */
> -               clear_bit(cpu, (unsigned long *)&cpu_initialized); /* was set 
> by cpu_init() */
> -               clear_node_cpumask(cpu); /* was set by numa_add_cpu */
> -               cpu_clear(cpu, cpu_present_map);
> -               cpu_clear(cpu, cpu_possible_map);
> -               per_cpu(x86_cpu_to_apicid, cpu) = BAD_APICID;
> -               return -EIO;
> -       }
> -
> -       return 0;
> -}
> -
> -cycles_t cacheflush_time;
> -unsigned long cache_decay_ticks;
> -
> -/*
> - * Cleanup possible dangling ends...
> - */
> -static __cpuinit void smp_cleanup_boot(void)
> -{
> -       /*
> -        * Paranoid:  Set warm reset code and vector here back
> -        * to default values.
> -        */
> -       CMOS_WRITE(0, 0xf);
> -
> -       /*
> -        * Reset trampoline flag
> -        */
> -       *((volatile int *) phys_to_virt(0x467)) = 0;
> -}
> -
> -/*
> - * Fall back to non SMP mode after errors.
> - *
> - * RED-PEN audit/test this more. I bet there is more state messed up here.
> - */
> -static __init void disable_smp(void)
> -{
> -       cpu_present_map = cpumask_of_cpu(0);
> -       cpu_possible_map = cpumask_of_cpu(0);
> -       if (smp_found_config)
> -               phys_cpu_present_map = physid_mask_of_physid(boot_cpu_id);
> -       else
> -               phys_cpu_present_map = physid_mask_of_physid(0);
> -       cpu_set(0, per_cpu(cpu_sibling_map, 0));
> -       cpu_set(0, per_cpu(cpu_core_map, 0));
> -}
> -
> -#ifdef CONFIG_HOTPLUG_CPU
> -
> -int additional_cpus __initdata = -1;
> -
> -/*
> - * cpu_possible_map should be static, it cannot change as cpu's
> - * are onlined, or offlined. The reason is per-cpu data-structures
> - * are allocated by some modules at init time, and dont expect to
> - * do this dynamically on cpu arrival/departure.
> - * cpu_present_map on the other hand can change dynamically.
> - * In case when cpu_hotplug is not compiled, then we resort to current
> - * behaviour, which is cpu_possible == cpu_present.
> - * - Ashok Raj
> - *
> - * Three ways to find out the number of additional hotplug CPUs:
> - * - If the BIOS specified disabled CPUs in ACPI/mptables use that.
> - * - The user can overwrite it with additional_cpus=NUM
> - * - Otherwise don't reserve additional CPUs.
> - * We do this because additional CPUs waste a lot of memory.
> - * -AK
> - */
> -__init void prefill_possible_map(void)
> -{
> -       int i;
> -       int possible;
> -
> -       if (additional_cpus == -1) {
> -               if (disabled_cpus > 0)
> -                       additional_cpus = disabled_cpus;
> -               else
> -                       additional_cpus = 0;
> -       }
> -       possible = num_processors + additional_cpus;
> -       if (possible > NR_CPUS)
> -               possible = NR_CPUS;
> -
> -       printk(KERN_INFO "SMP: Allowing %d CPUs, %d hotplug CPUs\n",
> -               possible,
> -               max_t(int, possible - num_processors, 0));
> -
> -       for (i = 0; i < possible; i++)
> -               cpu_set(i, cpu_possible_map);
> -}
> -#endif
> -
> -/*
> - * Various sanity checks.
> - */
> -static int __init smp_sanity_check(unsigned max_cpus)
> -{
> -       if (!physid_isset(hard_smp_processor_id(), phys_cpu_present_map)) {
> -               printk("weird, boot CPU (#%d) not listed by the BIOS.\n",
> -                      hard_smp_processor_id());
> -               physid_set(hard_smp_processor_id(), phys_cpu_present_map);
> -       }
> -
> -       /*
> -        * If we couldn't find an SMP configuration at boot time,
> -        * get out of here now!
> -        */
> -       if (!smp_found_config) {
> -               printk(KERN_NOTICE "SMP motherboard not detected.\n");
> -               disable_smp();
> -               if (APIC_init_uniprocessor())
> -                       printk(KERN_NOTICE "Local APIC not detected."
> -                                          " Using dummy APIC emulation.\n");
> -               return -1;
> -       }
> -
> -       /*
> -        * Should not be necessary because the MP table should list the boot
> -        * CPU too, but we do it for the sake of robustness anyway.
> -        */
> -       if (!physid_isset(boot_cpu_id, phys_cpu_present_map)) {
> -               printk(KERN_NOTICE "weird, boot CPU (#%d) not listed by the 
> BIOS.\n",
> -                                                                boot_cpu_id);
> -               physid_set(hard_smp_processor_id(), phys_cpu_present_map);
> -       }
> -
> -       /*
> -        * If we couldn't find a local APIC, then get out of here now!
> -        */
> -       if (!cpu_has_apic) {
> -               printk(KERN_ERR "BIOS bug, local APIC #%d not detected!...\n",
> -                       boot_cpu_id);
> -               printk(KERN_ERR "... forcing use of dummy APIC emulation. 
> (tell your hw vendor)\n");
> -               nr_ioapics = 0;
> -               return -1;
> -       }
> -
> -       /*
> -        * If SMP should be disabled, then really disable it!
> -        */
> -       if (!max_cpus) {
> -               printk(KERN_INFO "SMP mode deactivated, forcing use of dummy 
> APIC emulation.\n");
> -               nr_ioapics = 0;
> -               return -1;
> -       }
> -
> -       return 0;
> -}
> -
> -static void __init smp_cpu_index_default(void)
> -{
> -       int i;
> -       struct cpuinfo_x86 *c;
> -
> -       for_each_cpu_mask(i, cpu_possible_map) {
> -               c = &cpu_data(i);
> -               /* mark all to hotplug */
> -               c->cpu_index = NR_CPUS;
> -       }
> -}
> -
> -/*
> - * Prepare for SMP bootup.  The MP table or ACPI has been read
> - * earlier.  Just do some sanity checking here and enable APIC mode.
> - */
> -void __init smp_prepare_cpus(unsigned int max_cpus)
> -{
> -       nmi_watchdog_default();
> -       smp_cpu_index_default();
> -       current_cpu_data = boot_cpu_data;
> -       current_thread_info()->cpu = 0;  /* needed? */
> -       set_cpu_sibling_map(0);
> -
> -       if (smp_sanity_check(max_cpus) < 0) {
> -               printk(KERN_INFO "SMP disabled\n");
> -               disable_smp();
> -               return;
> -       }
> -
> -
> -       /*
> -        * Switch from PIC to APIC mode.
> -        */
> -       setup_local_APIC();
> -
> -       /*
> -        * Enable IO APIC before setting up error vector
> -        */
> -       if (!skip_ioapic_setup && nr_ioapics)
> -               enable_IO_APIC();
> -       end_local_APIC_setup();
> -
> -       if (GET_APIC_ID(apic_read(APIC_ID)) != boot_cpu_id) {
> -               panic("Boot APIC ID in local APIC unexpected (%d vs %d)",
> -                     GET_APIC_ID(apic_read(APIC_ID)), boot_cpu_id);
> -               /* Or can we switch back to PIC here? */
> -       }
> -
> -       /*
> -        * Now start the IO-APICs
> -        */
> -       if (!skip_ioapic_setup && nr_ioapics)
> -               setup_IO_APIC();
> -       else
> -               nr_ioapics = 0;
> -
> -       /*
> -        * Set up local APIC timer on boot CPU.
> -        */
> -
> -       setup_boot_clock();
> -}
> -
> -/*
> - * Early setup to make printk work.
> - */
> -void __init smp_prepare_boot_cpu(void)
> -{
> -       int me = smp_processor_id();
> -       /* already set me in cpu_online_map in boot_cpu_init() */
> -       cpu_set(me, cpu_callout_map);
> -       per_cpu(cpu_state, me) = CPU_ONLINE;
> -}
> -
> -/*
> - * Entry point to boot a CPU.
> - */
> -int __cpuinit __cpu_up(unsigned int cpu)
> -{
> -       int apicid = cpu_present_to_apicid(cpu);
> -       unsigned long flags;
> -       int err;
> -
> -       WARN_ON(irqs_disabled());
> -
> -       Dprintk("++++++++++++++++++++=_---CPU UP  %u\n", cpu);
> -
> -       if (apicid == BAD_APICID || apicid == boot_cpu_id ||
> -           !physid_isset(apicid, phys_cpu_present_map)) {
> -               printk("__cpu_up: bad cpu %d\n", cpu);
> -               return -EINVAL;
> -       }
> -
> -       /*
> -        * Already booted CPU?
> -        */
> -       if (cpu_isset(cpu, cpu_callin_map)) {
> -               Dprintk("do_boot_cpu %d Already started\n", cpu);
> -               return -ENOSYS;
> -       }
> -
> -       /*
> -        * Save current MTRR state in case it was changed since early boot
> -        * (e.g. by the ACPI SMI) to initialize new CPUs with MTRRs in sync:
> -        */
> -       mtrr_save_state();
> -
> -       per_cpu(cpu_state, cpu) = CPU_UP_PREPARE;
> -       /* Boot it! */
> -       err = do_boot_cpu(cpu, apicid);
> -       if (err < 0) {
> -               Dprintk("do_boot_cpu failed %d\n", err);
> -               return err;
> -       }
> -
> -       /* Unleash the CPU! */
> -       Dprintk("waiting for cpu %d\n", cpu);
> -
> -       /*
> -        * Make sure and check TSC sync:
> -        */
> -       local_irq_save(flags);
> -       check_tsc_sync_source(cpu);
> -       local_irq_restore(flags);
> -
> -       while (!cpu_isset(cpu, cpu_online_map))
> -               cpu_relax();
> -       err = 0;
> -
> -       return err;
> -}
> -
> -/*
> - * Finish the SMP boot.
> - */
> -void __init smp_cpus_done(unsigned int max_cpus)
> -{
> -       smp_cleanup_boot();
> -       setup_ioapic_dest();
> -       check_nmi_watchdog();
> -}
> -
> -#ifdef CONFIG_HOTPLUG_CPU
> -
> -static void remove_siblinginfo(int cpu)
> -{
> -       int sibling;
> -       struct cpuinfo_x86 *c = &cpu_data(cpu);
> -
> -       for_each_cpu_mask(sibling, per_cpu(cpu_core_map, cpu)) {
> -               cpu_clear(cpu, per_cpu(cpu_core_map, sibling));
> -               /*
> -                * last thread sibling in this cpu core going down
> -                */
> -               if (cpus_weight(per_cpu(cpu_sibling_map, cpu)) == 1)
> -                       cpu_data(sibling).booted_cores--;
> -       }
> -
> -       for_each_cpu_mask(sibling, per_cpu(cpu_sibling_map, cpu))
> -               cpu_clear(cpu, per_cpu(cpu_sibling_map, sibling));
> -       cpus_clear(per_cpu(cpu_sibling_map, cpu));
> -       cpus_clear(per_cpu(cpu_core_map, cpu));
> -       c->phys_proc_id = 0;
> -       c->cpu_core_id = 0;
> -       cpu_clear(cpu, cpu_sibling_setup_map);
> -}
> -
> -static void __ref remove_cpu_from_maps(void)
> -{
> -       int cpu = smp_processor_id();
> -
> -       cpu_clear(cpu, cpu_callout_map);
> -       cpu_clear(cpu, cpu_callin_map);
> -       clear_bit(cpu, (unsigned long *)&cpu_initialized); /* was set by 
> cpu_init() */
> -       clear_node_cpumask(cpu);
> -}
> -
> -int __cpu_disable(void)
> -{
> -       int cpu = smp_processor_id();
> -
> -       /*
> -        * Perhaps use cpufreq to drop frequency, but that could go
> -        * into generic code.
> -        *
> -        * We won't take down the boot processor on i386 due to some
> -        * interrupts only being able to be serviced by the BSP.
> -        * Especially so if we're not using an IOAPIC   -zwane
> -        */
> -       if (cpu == 0)
> -               return -EBUSY;
> -
> -       if (nmi_watchdog == NMI_LOCAL_APIC)
> -               stop_apic_nmi_watchdog(NULL);
> -       clear_local_APIC();
> -
> -       /*
> -        * HACK:
> -        * Allow any queued timer interrupts to get serviced
> -        * This is only a temporary solution until we cleanup
> -        * fixup_irqs as we do for IA64.
> -        */
> -       local_irq_enable();
> -       mdelay(1);
> -
> -       local_irq_disable();
> -       remove_siblinginfo(cpu);
> -
> -       spin_lock(&vector_lock);
> -       /* It's now safe to remove this processor from the online map */
> -       cpu_clear(cpu, cpu_online_map);
> -       spin_unlock(&vector_lock);
> -       remove_cpu_from_maps();
> -       fixup_irqs(cpu_online_map);
> -       pfm_cpu_disable();
> -       return 0;
> -}
> -
> -void __cpu_die(unsigned int cpu)
> -{
> -       /* We don't do anything here: idle task is faking death itself. */
> -       unsigned int i;
> -
> -       for (i = 0; i < 10; i++) {
> -               /* They ack this in play_dead by setting CPU_DEAD */
> -               if (per_cpu(cpu_state, cpu) == CPU_DEAD) {
> -                       printk ("CPU %d is now offline\n", cpu);
> -                       if (1 == num_online_cpus())
> -                               alternatives_smp_switch(0);
> -                       return;
> -               }
> -               msleep(100);
> -       }
> -       printk(KERN_ERR "CPU %u didn't die...\n", cpu);
> -}
> -
> -static __init int setup_additional_cpus(char *s)
> -{
> -       return s && get_option(&s, &additional_cpus) ? 0 : -EINVAL;
> -}
> -early_param("additional_cpus", setup_additional_cpus);
> -
> -#else /* ... !CONFIG_HOTPLUG_CPU */
> -
> -int __cpu_disable(void)
> -{
> -       return -ENOSYS;
> -}
> -
> -void __cpu_die(unsigned int cpu)
> -{
> -       /* We said "no" in __cpu_disable */
> -       BUG();
> -}
> -#endif /* CONFIG_HOTPLUG_CPU */
> diff --git a/include/asm-x86/cpufeature_32.h b/include/asm-x86/cpufeature_32.h
> deleted file mode 100644
> index 96378f8..0000000
> --- a/include/asm-x86/cpufeature_32.h
> +++ /dev/null
> @@ -1,177 +0,0 @@
> -/*
> - * cpufeature.h
> - *
> - * Defines x86 CPU feature bits
> - */
> -
> -#ifndef __ASM_I386_CPUFEATURE_H
> -#define __ASM_I386_CPUFEATURE_H
> -
> -#ifndef __ASSEMBLY__
> -#include <linux/bitops.h>
> -#endif
> -#include <asm/required-features.h>
> -
> -#define NCAPINTS       8       /* N 32-bit words worth of info */
> -
> -/* Intel-defined CPU features, CPUID level 0x00000001 (edx), word 0 */
> -#define X86_FEATURE_FPU                (0*32+ 0) /* Onboard FPU */
> -#define X86_FEATURE_VME                (0*32+ 1) /* Virtual Mode Extensions 
> */
> -#define X86_FEATURE_DE         (0*32+ 2) /* Debugging Extensions */
> -#define X86_FEATURE_PSE        (0*32+ 3) /* Page Size Extensions */
> -#define X86_FEATURE_TSC                (0*32+ 4) /* Time Stamp Counter */
> -#define X86_FEATURE_MSR                (0*32+ 5) /* Model-Specific 
> Registers, RDMSR, WRMSR */
> -#define X86_FEATURE_PAE                (0*32+ 6) /* Physical Address 
> Extensions */
> -#define X86_FEATURE_MCE                (0*32+ 7) /* Machine Check 
> Architecture */
> -#define X86_FEATURE_CX8                (0*32+ 8) /* CMPXCHG8 instruction */
> -#define X86_FEATURE_APIC       (0*32+ 9) /* Onboard APIC */
> -#define X86_FEATURE_SEP                (0*32+11) /* SYSENTER/SYSEXIT */
> -#define X86_FEATURE_MTRR       (0*32+12) /* Memory Type Range Registers */
> -#define X86_FEATURE_PGE                (0*32+13) /* Page Global Enable */
> -#define X86_FEATURE_MCA                (0*32+14) /* Machine Check 
> Architecture */
> -#define X86_FEATURE_CMOV       (0*32+15) /* CMOV instruction (FCMOVCC and 
> FCOMI too if FPU present) */
> -#define X86_FEATURE_PAT                (0*32+16) /* Page Attribute Table */
> -#define X86_FEATURE_PSE36      (0*32+17) /* 36-bit PSEs */
> -#define X86_FEATURE_PN         (0*32+18) /* Processor serial number */
> -#define X86_FEATURE_CLFLSH     (0*32+19) /* Supports the CLFLUSH instruction 
> */
> -#define X86_FEATURE_DS         (0*32+21) /* Debug Store */
> -#define X86_FEATURE_ACPI       (0*32+22) /* ACPI via MSR */
> -#define X86_FEATURE_MMX                (0*32+23) /* Multimedia Extensions */
> -#define X86_FEATURE_FXSR       (0*32+24) /* FXSAVE and FXRSTOR instructions 
> (fast save and restore */
> -                                         /* of FPU context), and CR4.OSFXSR 
> available */
> -#define X86_FEATURE_XMM                (0*32+25) /* Streaming SIMD 
> Extensions */
> -#define X86_FEATURE_XMM2       (0*32+26) /* Streaming SIMD Extensions-2 */
> -#define X86_FEATURE_SELFSNOOP  (0*32+27) /* CPU self snoop */
> -#define X86_FEATURE_HT         (0*32+28) /* Hyper-Threading */
> -#define X86_FEATURE_ACC                (0*32+29) /* Automatic clock control 
> */
> -#define X86_FEATURE_IA64       (0*32+30) /* IA-64 processor */
> -
> -/* AMD-defined CPU features, CPUID level 0x80000001, word 1 */
> -/* Don't duplicate feature flags which are redundant with Intel! */
> -#define X86_FEATURE_SYSCALL    (1*32+11) /* SYSCALL/SYSRET */
> -#define X86_FEATURE_MP         (1*32+19) /* MP Capable. */
> -#define X86_FEATURE_NX         (1*32+20) /* Execute Disable */
> -#define X86_FEATURE_MMXEXT     (1*32+22) /* AMD MMX extensions */
> -#define X86_FEATURE_RDTSCP     (1*32+27) /* RDTSCP */
> -#define X86_FEATURE_LM         (1*32+29) /* Long Mode (x86-64) */
> -#define X86_FEATURE_3DNOWEXT   (1*32+30) /* AMD 3DNow! extensions */
> -#define X86_FEATURE_3DNOW      (1*32+31) /* 3DNow! */
> -
> -/* Transmeta-defined CPU features, CPUID level 0x80860001, word 2 */
> -#define X86_FEATURE_RECOVERY   (2*32+ 0) /* CPU in recovery mode */
> -#define X86_FEATURE_LONGRUN    (2*32+ 1) /* Longrun power control */
> -#define X86_FEATURE_LRTI       (2*32+ 3) /* LongRun table interface */
> -
> -/* Other features, Linux-defined mapping, word 3 */
> -/* This range is used for feature bits which conflict or are synthesized */
> -#define X86_FEATURE_CXMMX      (3*32+ 0) /* Cyrix MMX extensions */
> -#define X86_FEATURE_K6_MTRR    (3*32+ 1) /* AMD K6 nonstandard MTRRs */
> -#define X86_FEATURE_CYRIX_ARR  (3*32+ 2) /* Cyrix ARRs (= MTRRs) */
> -#define X86_FEATURE_CENTAUR_MCR        (3*32+ 3) /* Centaur MCRs (= MTRRs) */
> -/* cpu types for specific tunings: */
> -#define X86_FEATURE_K8         (3*32+ 4) /* Opteron, Athlon64 */
> -#define X86_FEATURE_K7         (3*32+ 5) /* Athlon */
> -#define X86_FEATURE_P3         (3*32+ 6) /* P3 */
> -#define X86_FEATURE_P4         (3*32+ 7) /* P4 */
> -#define X86_FEATURE_CONSTANT_TSC (3*32+ 8) /* TSC ticks at a constant rate */
> -#define X86_FEATURE_UP         (3*32+ 9) /* smp kernel running on up */
> -#define X86_FEATURE_FXSAVE_LEAK (3*32+10) /* FXSAVE leaks FOP/FIP/FOP */
> -#define X86_FEATURE_ARCH_PERFMON (3*32+11) /* Intel Architectural PerfMon */
> -#define X86_FEATURE_PEBS       (3*32+12)  /* Precise-Event Based Sampling */
> -#define X86_FEATURE_BTS                (3*32+13)  /* Branch Trace Store */
> -/* 14 free */
> -#define X86_FEATURE_SYNC_RDTSC (3*32+15)  /* RDTSC synchronizes the CPU */
> -#define X86_FEATURE_REP_GOOD   (3*32+16) /* rep microcode works well on this 
> CPU */
> -
> -/* Intel-defined CPU features, CPUID level 0x00000001 (ecx), word 4 */
> -#define X86_FEATURE_XMM3       (4*32+ 0) /* Streaming SIMD Extensions-3 */
> -#define X86_FEATURE_MWAIT      (4*32+ 3) /* Monitor/Mwait support */
> -#define X86_FEATURE_DSCPL      (4*32+ 4) /* CPL Qualified Debug Store */
> -#define X86_FEATURE_EST                (4*32+ 7) /* Enhanced SpeedStep */
> -#define X86_FEATURE_TM2                (4*32+ 8) /* Thermal Monitor 2 */
> -#define X86_FEATURE_CID                (4*32+10) /* Context ID */
> -#define X86_FEATURE_CX16        (4*32+13) /* CMPXCHG16B */
> -#define X86_FEATURE_XTPR       (4*32+14) /* Send Task Priority Messages */
> -#define X86_FEATURE_DCA                (4*32+18) /* Direct Cache Access */
> -
> -/* VIA/Cyrix/Centaur-defined CPU features, CPUID level 0xC0000001, word 5 */
> -#define X86_FEATURE_XSTORE     (5*32+ 2) /* on-CPU RNG present (xstore insn) 
> */
> -#define X86_FEATURE_XSTORE_EN  (5*32+ 3) /* on-CPU RNG enabled */
> -#define X86_FEATURE_XCRYPT     (5*32+ 6) /* on-CPU crypto (xcrypt insn) */
> -#define X86_FEATURE_XCRYPT_EN  (5*32+ 7) /* on-CPU crypto enabled */
> -#define X86_FEATURE_ACE2       (5*32+ 8) /* Advanced Cryptography Engine v2 
> */
> -#define X86_FEATURE_ACE2_EN    (5*32+ 9) /* ACE v2 enabled */
> -#define X86_FEATURE_PHE                (5*32+ 10) /* PadLock Hash Engine */
> -#define X86_FEATURE_PHE_EN     (5*32+ 11) /* PHE enabled */
> -#define X86_FEATURE_PMM                (5*32+ 12) /* PadLock Montgomery 
> Multiplier */
> -#define X86_FEATURE_PMM_EN     (5*32+ 13) /* PMM enabled */
> -
> -/* More extended AMD flags: CPUID level 0x80000001, ecx, word 6 */
> -#define X86_FEATURE_LAHF_LM    (6*32+ 0) /* LAHF/SAHF in long mode */
> -#define X86_FEATURE_CMP_LEGACY (6*32+ 1) /* If yes HyperThreading not valid 
> */
> -
> -/*
> - * Auxiliary flags: Linux defined - For features scattered in various
> - * CPUID levels like 0x6, 0xA etc
> - */
> -#define X86_FEATURE_IDA                (7*32+ 0) /* Intel Dynamic 
> Acceleration */
> -
> -#define cpu_has(c, bit)                                                      
>   \
> -       (__builtin_constant_p(bit) &&                                   \
> -        ( (((bit)>>5)==0 && (1UL<<((bit)&31) & REQUIRED_MASK0)) ||     \
> -          (((bit)>>5)==1 && (1UL<<((bit)&31) & REQUIRED_MASK1)) ||     \
> -          (((bit)>>5)==2 && (1UL<<((bit)&31) & REQUIRED_MASK2)) ||     \
> -          (((bit)>>5)==3 && (1UL<<((bit)&31) & REQUIRED_MASK3)) ||     \
> -          (((bit)>>5)==4 && (1UL<<((bit)&31) & REQUIRED_MASK4)) ||     \
> -          (((bit)>>5)==5 && (1UL<<((bit)&31) & REQUIRED_MASK5)) ||     \
> -          (((bit)>>5)==6 && (1UL<<((bit)&31) & REQUIRED_MASK6)) ||     \
> -          (((bit)>>5)==7 && (1UL<<((bit)&31) & REQUIRED_MASK7)) )      \
> -         ? 1 :                                                         \
> -         test_bit(bit, (c)->x86_capability))
> -#define boot_cpu_has(bit)      cpu_has(&boot_cpu_data, bit)
> -
> -#define cpu_has_fpu            boot_cpu_has(X86_FEATURE_FPU)
> -#define cpu_has_vme            boot_cpu_has(X86_FEATURE_VME)
> -#define cpu_has_de             boot_cpu_has(X86_FEATURE_DE)
> -#define cpu_has_pse            boot_cpu_has(X86_FEATURE_PSE)
> -#define cpu_has_tsc            boot_cpu_has(X86_FEATURE_TSC)
> -#define cpu_has_pae            boot_cpu_has(X86_FEATURE_PAE)
> -#define cpu_has_pge            boot_cpu_has(X86_FEATURE_PGE)
> -#define cpu_has_apic           boot_cpu_has(X86_FEATURE_APIC)
> -#define cpu_has_sep            boot_cpu_has(X86_FEATURE_SEP)
> -#define cpu_has_mtrr           boot_cpu_has(X86_FEATURE_MTRR)
> -#define cpu_has_mmx            boot_cpu_has(X86_FEATURE_MMX)
> -#define cpu_has_fxsr           boot_cpu_has(X86_FEATURE_FXSR)
> -#define cpu_has_xmm            boot_cpu_has(X86_FEATURE_XMM)
> -#define cpu_has_xmm2           boot_cpu_has(X86_FEATURE_XMM2)
> -#define cpu_has_xmm3           boot_cpu_has(X86_FEATURE_XMM3)
> -#define cpu_has_ht             boot_cpu_has(X86_FEATURE_HT)
> -#define cpu_has_mp             boot_cpu_has(X86_FEATURE_MP)
> -#define cpu_has_nx             boot_cpu_has(X86_FEATURE_NX)
> -#define cpu_has_k6_mtrr                boot_cpu_has(X86_FEATURE_K6_MTRR)
> -#define cpu_has_cyrix_arr      boot_cpu_has(X86_FEATURE_CYRIX_ARR)
> -#define cpu_has_centaur_mcr    boot_cpu_has(X86_FEATURE_CENTAUR_MCR)
> -#define cpu_has_xstore         boot_cpu_has(X86_FEATURE_XSTORE)
> -#define cpu_has_xstore_enabled boot_cpu_has(X86_FEATURE_XSTORE_EN)
> -#define cpu_has_xcrypt         boot_cpu_has(X86_FEATURE_XCRYPT)
> -#define cpu_has_xcrypt_enabled boot_cpu_has(X86_FEATURE_XCRYPT_EN)
> -#define cpu_has_ace2           boot_cpu_has(X86_FEATURE_ACE2)
> -#define cpu_has_ace2_enabled   boot_cpu_has(X86_FEATURE_ACE2_EN)
> -#define cpu_has_phe            boot_cpu_has(X86_FEATURE_PHE)
> -#define cpu_has_phe_enabled    boot_cpu_has(X86_FEATURE_PHE_EN)
> -#define cpu_has_pmm            boot_cpu_has(X86_FEATURE_PMM)
> -#define cpu_has_pmm_enabled    boot_cpu_has(X86_FEATURE_PMM_EN)
> -#define cpu_has_ds             boot_cpu_has(X86_FEATURE_DS)
> -#define cpu_has_pebs           boot_cpu_has(X86_FEATURE_PEBS)
> -#define cpu_has_clflush                boot_cpu_has(X86_FEATURE_CLFLSH)
> -#define cpu_has_bts            boot_cpu_has(X86_FEATURE_BTS)
> -#define cpu_has_arch_perfmon   boot_cpu_has(X86_FEATURE_ARCH_PERFMON)
> -
> -#endif /* __ASM_I386_CPUFEATURE_H */
> -
> -/*
> - * Local Variables:
> - * mode:c
> - * comment-column:42
> - * End:
> - */
> diff --git a/include/asm-x86/thread_info_32.h 
> b/include/asm-x86/thread_info_32.h
> index 4709b12..9a0e784 100644
> --- a/include/asm-x86/thread_info_32.h
> +++ b/include/asm-x86/thread_info_32.h
> @@ -172,12 +172,13 @@ static inline struct thread_info 
> *current_thread_info(void)
>  #define _TIF_ALLWORK_MASK      (0x0000FFFF & ~_TIF_SECCOMP)
>
>  /* flags to check in __switch_to() */
> -#define _TIF_WORK_CTXSW \
> -    (_TIF_IO_BITMAP | _TIF_NOTSC | _TIF_DEBUGCTLMSR | \
> -     _TIF_DS_AREA_MSR | _TIF_BTS_TRACE_TS | _TIF_PERFMON_CTXSW)
> +#define _TIF_WORK_CTXSW                                                \
> +       (_TIF_IO_BITMAP | _TIF_NOTSC | _TIF_DEBUGCTLMSR |       \
> +        _TIF_DS_AREA_MSR | _TIF_BTS_TRACE_TS | _TIF_PERFMON_CTXSW)
>  #define _TIF_WORK_CTXSW_PREV _TIF_WORK_CTXSW
>  #define _TIF_WORK_CTXSW_NEXT (_TIF_WORK_CTXSW | _TIF_DEBUG)
>
> +
>  /*
>  * Thread-synchronous status.
>  *
> diff --git a/include/asm-x86/thread_info_64.h 
> b/include/asm-x86/thread_info_64.h
> index 4056ee5..4d4832f 100644
> --- a/include/asm-x86/thread_info_64.h
> +++ b/include/asm-x86/thread_info_64.h
> @@ -157,7 +157,7 @@ static inline struct thread_info *stack_thread_info(void)
>  /* work to do on any return to user space */
>  #define _TIF_ALLWORK_MASK (0x0000FFFF & ~_TIF_SECCOMP)
>
> -#define _TIF_DO_NOTIFY_MASK \
> +#define _TIF_DO_NOTIFY_MASK                                            \
>        (_TIF_SIGPENDING|_TIF_SINGLESTEP|_TIF_MCE_NOTIFY|_TIF_HRTICK_RESCHED|\
>         _TIF_PERFMON_WORK)
>
> --
> 1.5.3.7
>
>
>

-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft 
Defy all challenges. Microsoft(R) Visual Studio 2008. 
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
perfmon2-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/perfmon2-devel

Reply via email to