提交 d38bb135 编写于 作者: M Mike Travis 提交者: Ingo Molnar

x86/platform/UV: Move scir info to the per cpu info struct

Change the references to the SCIR fields to the new per cpu info structs.
Tested-by: NJohn Estabrook <estabrook@sgi.com>
Tested-by: NGary Kroening <gfk@sgi.com>
Tested-by: NNathan Zimmer <nzimmer@sgi.com>
Signed-off-by: NMike Travis <travis@sgi.com>
Reviewed-by: NDimitri Sivanich <sivanich@sgi.com>
Cc: Andrew Banman <abanman@sgi.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Andy Lutomirski <luto@amacapital.net>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Brian Gerst <brgerst@gmail.com>
Cc: Denys Vlasenko <dvlasenk@redhat.com>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Len Brown <len.brown@intel.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Russ Anderson <rja@sgi.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/20160429215404.452538234@asylum.americas.sgi.comSigned-off-by: NIngo Molnar <mingo@kernel.org>
上级 0045ddd2
...@@ -127,6 +127,7 @@ ...@@ -127,6 +127,7 @@
*/ */
#define UV_MAX_NASID_VALUE (UV_MAX_NUMALINK_BLADES * 2) #define UV_MAX_NASID_VALUE (UV_MAX_NUMALINK_BLADES * 2)
/* System Controller Interface Reg info */
struct uv_scir_s { struct uv_scir_s {
struct timer_list timer; struct timer_list timer;
unsigned long offset; unsigned long offset;
...@@ -161,7 +162,6 @@ struct uv_hub_info_s { ...@@ -161,7 +162,6 @@ struct uv_hub_info_s {
unsigned char blade_processor_id; unsigned char blade_processor_id;
unsigned char m_val; unsigned char m_val;
unsigned char n_val; unsigned char n_val;
struct uv_scir_s scir;
}; };
DECLARE_PER_CPU(struct uv_hub_info_s, __uv_hub_info); DECLARE_PER_CPU(struct uv_hub_info_s, __uv_hub_info);
...@@ -179,6 +179,9 @@ DECLARE_PER_CPU(struct uv_cpu_info_s, __uv_cpu_info); ...@@ -179,6 +179,9 @@ DECLARE_PER_CPU(struct uv_cpu_info_s, __uv_cpu_info);
#define uv_cpu_info this_cpu_ptr(&__uv_cpu_info) #define uv_cpu_info this_cpu_ptr(&__uv_cpu_info)
#define uv_cpu_info_per(cpu) (&per_cpu(__uv_cpu_info, cpu)) #define uv_cpu_info_per(cpu) (&per_cpu(__uv_cpu_info, cpu))
#define uv_scir_info (&uv_cpu_info->scir)
#define uv_cpu_scir_info(cpu) (&uv_cpu_info_per(cpu)->scir)
/* /*
* HUB revision ranges for each UV HUB architecture. * HUB revision ranges for each UV HUB architecture.
* This is a software convention - NOT the hardware revision numbers in * This is a software convention - NOT the hardware revision numbers in
...@@ -686,9 +689,9 @@ DECLARE_PER_CPU(struct uv_cpu_nmi_s, uv_cpu_nmi); ...@@ -686,9 +689,9 @@ DECLARE_PER_CPU(struct uv_cpu_nmi_s, uv_cpu_nmi);
/* Update SCIR state */ /* Update SCIR state */
static inline void uv_set_scir_bits(unsigned char value) static inline void uv_set_scir_bits(unsigned char value)
{ {
if (uv_hub_info->scir.state != value) { if (uv_scir_info->state != value) {
uv_hub_info->scir.state = value; uv_scir_info->state = value;
uv_write_local_mmr8(uv_hub_info->scir.offset, value); uv_write_local_mmr8(uv_scir_info->offset, value);
} }
} }
...@@ -699,10 +702,10 @@ static inline unsigned long uv_scir_offset(int apicid) ...@@ -699,10 +702,10 @@ static inline unsigned long uv_scir_offset(int apicid)
static inline void uv_set_cpu_scir_bits(int cpu, unsigned char value) static inline void uv_set_cpu_scir_bits(int cpu, unsigned char value)
{ {
if (uv_cpu_hub_info(cpu)->scir.state != value) { if (uv_cpu_scir_info(cpu)->state != value) {
uv_write_global_mmr8(uv_cpu_to_pnode(cpu), uv_write_global_mmr8(uv_cpu_to_pnode(cpu),
uv_cpu_hub_info(cpu)->scir.offset, value); uv_cpu_scir_info(cpu)->offset, value);
uv_cpu_hub_info(cpu)->scir.state = value; uv_cpu_scir_info(cpu)->state = value;
} }
} }
......
...@@ -756,8 +756,8 @@ static __init void uv_rtc_init(void) ...@@ -756,8 +756,8 @@ static __init void uv_rtc_init(void)
*/ */
static void uv_heartbeat(unsigned long ignored) static void uv_heartbeat(unsigned long ignored)
{ {
struct timer_list *timer = &uv_hub_info->scir.timer; struct timer_list *timer = &uv_scir_info->timer;
unsigned char bits = uv_hub_info->scir.state; unsigned char bits = uv_scir_info->state;
/* flip heartbeat bit */ /* flip heartbeat bit */
bits ^= SCIR_CPU_HEARTBEAT; bits ^= SCIR_CPU_HEARTBEAT;
...@@ -777,14 +777,14 @@ static void uv_heartbeat(unsigned long ignored) ...@@ -777,14 +777,14 @@ static void uv_heartbeat(unsigned long ignored)
static void uv_heartbeat_enable(int cpu) static void uv_heartbeat_enable(int cpu)
{ {
while (!uv_cpu_hub_info(cpu)->scir.enabled) { while (!uv_cpu_scir_info(cpu)->enabled) {
struct timer_list *timer = &uv_cpu_hub_info(cpu)->scir.timer; struct timer_list *timer = &uv_cpu_scir_info(cpu)->timer;
uv_set_cpu_scir_bits(cpu, SCIR_CPU_HEARTBEAT|SCIR_CPU_ACTIVITY); uv_set_cpu_scir_bits(cpu, SCIR_CPU_HEARTBEAT|SCIR_CPU_ACTIVITY);
setup_timer(timer, uv_heartbeat, cpu); setup_timer(timer, uv_heartbeat, cpu);
timer->expires = jiffies + SCIR_CPU_HB_INTERVAL; timer->expires = jiffies + SCIR_CPU_HB_INTERVAL;
add_timer_on(timer, cpu); add_timer_on(timer, cpu);
uv_cpu_hub_info(cpu)->scir.enabled = 1; uv_cpu_scir_info(cpu)->enabled = 1;
/* also ensure that boot cpu is enabled */ /* also ensure that boot cpu is enabled */
cpu = 0; cpu = 0;
...@@ -794,9 +794,9 @@ static void uv_heartbeat_enable(int cpu) ...@@ -794,9 +794,9 @@ static void uv_heartbeat_enable(int cpu)
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
static void uv_heartbeat_disable(int cpu) static void uv_heartbeat_disable(int cpu)
{ {
if (uv_cpu_hub_info(cpu)->scir.enabled) { if (uv_cpu_scir_info(cpu)->enabled) {
uv_cpu_hub_info(cpu)->scir.enabled = 0; uv_cpu_scir_info(cpu)->enabled = 0;
del_timer(&uv_cpu_hub_info(cpu)->scir.timer); del_timer(&uv_cpu_scir_info(cpu)->timer);
} }
uv_set_cpu_scir_bits(cpu, 0xff); uv_set_cpu_scir_bits(cpu, 0xff);
} }
...@@ -1055,13 +1055,13 @@ void __init uv_system_init(void) ...@@ -1055,13 +1055,13 @@ void __init uv_system_init(void)
uv_cpu_hub_info(cpu)->numa_blade_id = blade; uv_cpu_hub_info(cpu)->numa_blade_id = blade;
uv_cpu_hub_info(cpu)->pnode = pnode; uv_cpu_hub_info(cpu)->pnode = pnode;
uv_cpu_hub_info(cpu)->scir.offset = uv_scir_offset(apicid);
uv_cpu_hub_info(cpu)->blade_processor_id = lcpu; uv_cpu_hub_info(cpu)->blade_processor_id = lcpu;
uv_node_to_blade[nodeid] = blade; uv_node_to_blade[nodeid] = blade;
uv_cpu_to_blade[cpu] = blade; uv_cpu_to_blade[cpu] = blade;
/* Initialize per cpu info list */ /* Initialize per cpu info list */
uv_cpu_info_per(cpu)->p_uv_hub_info = uv_cpu_hub_info(cpu); uv_cpu_info_per(cpu)->p_uv_hub_info = uv_cpu_hub_info(cpu);
uv_cpu_info_per(cpu)->scir.offset = uv_scir_offset(apicid);
} }
/* Add blade/pnode info for nodes without cpus */ /* Add blade/pnode info for nodes without cpus */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册