Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 112647
b: refs/heads/master
c: 0c81c74
h: refs/heads/master
i:
  112645: 9a520fd
  112643: 6dd1378
  112639: 6447e5a
v: v3
  • Loading branch information
Suresh Siddha authored and Ingo Molnar committed Jul 12, 2008
1 parent 17e2ce5 commit e47a853
Show file tree
Hide file tree
Showing 9 changed files with 37 additions and 18 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 4dc2f96cacd1e74c688f94348a3bfd0a980817d5
refs/heads/master: 0c81c746f9bdbfaafe64322d540c8b7b59c27314
5 changes: 5 additions & 0 deletions trunk/arch/x86/kernel/apic_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -1096,6 +1096,11 @@ void __cpuinit generic_processor_info(int apicid, int version)
cpu_set(cpu, cpu_present_map);
}

int hard_smp_processor_id(void)
{
return read_apic_id();
}

/*
* Power management
*/
Expand Down
11 changes: 0 additions & 11 deletions trunk/arch/x86/kernel/genapic_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -79,17 +79,6 @@ int __init acpi_madt_oem_check(char *oem_id, char *oem_table_id)
return 0;
}

unsigned int read_apic_id(void)
{
unsigned int id;

WARN_ON(preemptible() && num_online_cpus() > 1);
id = apic_read(APIC_ID);
if (uv_system_type >= UV_X2APIC)
id |= __get_cpu_var(x2apic_extra_bits);
return id;
}

enum uv_system_type get_uv_system_type(void)
{
return uv_system_type;
Expand Down
14 changes: 13 additions & 1 deletion trunk/arch/x86/kernel/genapic_flat_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,11 @@
#include <linux/kernel.h>
#include <linux/ctype.h>
#include <linux/init.h>
#include <linux/hardirq.h>
#include <asm/smp.h>
#include <asm/ipi.h>
#include <asm/genapic.h>
#include <mach_apicdef.h>

static cpumask_t flat_target_cpus(void)
{
Expand Down Expand Up @@ -95,9 +97,17 @@ static void flat_send_IPI_all(int vector)
__send_IPI_shortcut(APIC_DEST_ALLINC, vector, APIC_DEST_LOGICAL);
}

static unsigned int read_xapic_id(void)
{
unsigned int id;

id = GET_XAPIC_ID(apic_read(APIC_ID));
return id;
}

static int flat_apic_id_registered(void)
{
return physid_isset(GET_APIC_ID(read_apic_id()), phys_cpu_present_map);
return physid_isset(read_xapic_id(), phys_cpu_present_map);
}

static unsigned int flat_cpu_mask_to_apicid(cpumask_t cpumask)
Expand All @@ -123,6 +133,7 @@ struct genapic apic_flat = {
.send_IPI_mask = flat_send_IPI_mask,
.cpu_mask_to_apicid = flat_cpu_mask_to_apicid,
.phys_pkg_id = phys_pkg_id,
.read_apic_id = read_xapic_id,
};

/*
Expand Down Expand Up @@ -187,4 +198,5 @@ struct genapic apic_physflat = {
.send_IPI_mask = physflat_send_IPI_mask,
.cpu_mask_to_apicid = physflat_cpu_mask_to_apicid,
.phys_pkg_id = phys_pkg_id,
.read_apic_id = read_xapic_id,
};
14 changes: 13 additions & 1 deletion trunk/arch/x86/kernel/genx2apic_uv_x.c
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
#include <linux/sched.h>
#include <linux/bootmem.h>
#include <linux/module.h>
#include <linux/hardirq.h>
#include <asm/smp.h>
#include <asm/ipi.h>
#include <asm/genapic.h>
Expand Down Expand Up @@ -134,9 +135,19 @@ static unsigned int uv_cpu_mask_to_apicid(cpumask_t cpumask)
return BAD_APICID;
}

static unsigned int uv_read_apic_id(void)
{
unsigned int id;

WARN_ON(preemptible() && num_online_cpus() > 1);
id = apic_read(APIC_ID) | __get_cpu_var(x2apic_extra_bits);

return id;
}

static unsigned int phys_pkg_id(int index_msb)
{
return GET_APIC_ID(read_apic_id()) >> index_msb;
return uv_read_apic_id() >> index_msb;
}

#ifdef ZZZ /* Needs x2apic patch */
Expand All @@ -159,6 +170,7 @@ struct genapic apic_x2apic_uv_x = {
/* ZZZ.send_IPI_self = uv_send_IPI_self, */
.cpu_mask_to_apicid = uv_cpu_mask_to_apicid,
.phys_pkg_id = phys_pkg_id, /* Fixme ZZZ */
.read_apic_id = uv_read_apic_id,
};

static __cpuinit void set_x2apic_extra_bits(int pnode)
Expand Down
1 change: 1 addition & 0 deletions trunk/include/asm-x86/genapic_64.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ struct genapic {
/* */
unsigned int (*cpu_mask_to_apicid)(cpumask_t cpumask);
unsigned int (*phys_pkg_id)(int index_msb);
unsigned int (*read_apic_id)(void);
};

extern struct genapic *genapic;
Expand Down
1 change: 1 addition & 0 deletions trunk/include/asm-x86/mach-default/mach_apic.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ static inline cpumask_t target_cpus(void)
#define cpu_mask_to_apicid (genapic->cpu_mask_to_apicid)
#define phys_pkg_id (genapic->phys_pkg_id)
#define vector_allocation_domain (genapic->vector_allocation_domain)
#define read_apic_id (genapic->read_apic_id)
extern void setup_apic_routing(void);
#else
#define INT_DELIVERY_MODE dest_LowestPrio
Expand Down
3 changes: 2 additions & 1 deletion trunk/include/asm-x86/mach-default/mach_apicdef.h
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,9 @@

#ifdef CONFIG_X86_64
#define APIC_ID_MASK (0xFFu<<24)
#define GET_APIC_ID(x) (((x)>>24)&0xFFu)
#define GET_APIC_ID(x) (x)
#define SET_APIC_ID(x) (((x)<<24))
#define GET_XAPIC_ID(x) (((x) >> 24) & 0xFFu)
#else
#define APIC_ID_MASK (0xF<<24)
static inline unsigned get_apic_id(unsigned long x)
Expand Down
4 changes: 1 addition & 3 deletions trunk/include/asm-x86/smp.h
Original file line number Diff line number Diff line change
Expand Up @@ -169,12 +169,10 @@ static inline unsigned int read_apic_id(void)
{
return *(u32 *)(APIC_BASE + APIC_ID);
}
#else
extern unsigned int read_apic_id(void);
#endif


# ifdef APIC_DEFINITION
# if defined(APIC_DEFINITION) || defined(CONFIG_X86_64)
extern int hard_smp_processor_id(void);
# else
# include <mach_apicdef.h>
Expand Down

0 comments on commit e47a853

Please sign in to comment.