mirror of
https://github.com/torvalds/linux.git
synced 2024-11-15 00:21:59 +00:00
gru: function to generate chipset IPI values
Create a function to generate the value that is written to the UV hub MMR to cause an IPI interrupt to be sent. The function will be used in the GRU message queue error recovery code that sends IPIs to nodes in remote partitions. Signed-off-by: Jack Steiner <steiner@sgi.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
e5ae6e82bf
commit
56abcf24ff
@ -172,6 +172,8 @@ DECLARE_PER_CPU(struct uv_hub_info_s, __uv_hub_info);
|
|||||||
#define UV_LOCAL_MMR_SIZE (64UL * 1024 * 1024)
|
#define UV_LOCAL_MMR_SIZE (64UL * 1024 * 1024)
|
||||||
#define UV_GLOBAL_MMR32_SIZE (64UL * 1024 * 1024)
|
#define UV_GLOBAL_MMR32_SIZE (64UL * 1024 * 1024)
|
||||||
|
|
||||||
|
#define UV_GLOBAL_GRU_MMR_BASE 0x4000000
|
||||||
|
|
||||||
#define UV_GLOBAL_MMR32_PNODE_SHIFT 15
|
#define UV_GLOBAL_MMR32_PNODE_SHIFT 15
|
||||||
#define UV_GLOBAL_MMR64_PNODE_SHIFT 26
|
#define UV_GLOBAL_MMR64_PNODE_SHIFT 26
|
||||||
|
|
||||||
@ -327,6 +329,15 @@ static inline unsigned long uv_read_global_mmr64(int pnode,
|
|||||||
return readq(uv_global_mmr64_address(pnode, offset));
|
return readq(uv_global_mmr64_address(pnode, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Global MMR space addresses when referenced by the GRU. (GRU does
|
||||||
|
* NOT use socket addressing).
|
||||||
|
*/
|
||||||
|
static inline unsigned long uv_global_gru_mmr_address(int pnode, unsigned long offset)
|
||||||
|
{
|
||||||
|
return UV_GLOBAL_GRU_MMR_BASE | offset | (pnode << uv_hub_info->m_val);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Access hub local MMRs. Faster than using global space but only local MMRs
|
* Access hub local MMRs. Faster than using global space but only local MMRs
|
||||||
* are accessible.
|
* are accessible.
|
||||||
@ -454,6 +465,14 @@ static inline void uv_set_cpu_scir_bits(int cpu, unsigned char value)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned long uv_hub_ipi_value(int apicid, int vector, int mode)
|
||||||
|
{
|
||||||
|
return (1UL << UVH_IPI_INT_SEND_SHFT) |
|
||||||
|
((apicid) << UVH_IPI_INT_APIC_ID_SHFT) |
|
||||||
|
(mode << UVH_IPI_INT_DELIVERY_MODE_SHFT) |
|
||||||
|
(vector << UVH_IPI_INT_VECTOR_SHFT);
|
||||||
|
}
|
||||||
|
|
||||||
static inline void uv_hub_send_ipi(int pnode, int apicid, int vector)
|
static inline void uv_hub_send_ipi(int pnode, int apicid, int vector)
|
||||||
{
|
{
|
||||||
unsigned long val;
|
unsigned long val;
|
||||||
@ -462,10 +481,7 @@ static inline void uv_hub_send_ipi(int pnode, int apicid, int vector)
|
|||||||
if (vector == NMI_VECTOR)
|
if (vector == NMI_VECTOR)
|
||||||
dmode = dest_NMI;
|
dmode = dest_NMI;
|
||||||
|
|
||||||
val = (1UL << UVH_IPI_INT_SEND_SHFT) |
|
val = uv_hub_ipi_value(apicid, vector, dmode);
|
||||||
((apicid) << UVH_IPI_INT_APIC_ID_SHFT) |
|
|
||||||
(dmode << UVH_IPI_INT_DELIVERY_MODE_SHFT) |
|
|
||||||
(vector << UVH_IPI_INT_VECTOR_SHFT);
|
|
||||||
uv_write_global_mmr64(pnode, UVH_IPI_INT, val);
|
uv_write_global_mmr64(pnode, UVH_IPI_INT, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user