mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-23 08:35:19 -05:00
- A couple of changes enabling SGI UV5 support
-----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEzv7L6UO9uDPlPSfHEsHwGGHeVUoFAmKL1CkACgkQEsHwGGHe VUpA6Q//QmHDD5GIDkGOjp2BvZfFL/Lb/NqM6k5/1koKbxvWg3zge6w1DH4s2Ai3 U+QmGdHpbVY3Xag7RPru9Kuyh7f3GNPeXIw6JQ78NOAdoEpceSPTAs9r6GzHYLfH n27hsSWrJQT3PLNUr+/ii/fXpypHCzAPpgpr8sYkY+TEYXuInWP18BrVIMBNRVV0 e9IhtkEL3wJh0FN9LtXWcfjzpTNArloFe204rVpzznpUIgHqK39WwhyRp0ppmhhX uK9s2XJTD9DBszYZb/NjsxFAoDoB8MS7fVPmdnAKo2P/SzznVOC5TJQiMI/zCXpX ShhKPJHsbXf//N4HxjbAuAUwYhwBp9nIvruosudZTXiqRwDUxCXRGipsBMQY8l/L dUAgh3fmF4uw5wEZ6PNiKJ0m0VDgSbusZliLr1o//36/ZqyLf4vSx81K7J7p5u2U HkP+GAvtWvNXGAAasiVL+D9wOWwgwXFsI44JrWnuTCCiWWdmAHc52b/PAC3bpxNH f/X2OiA14UzYeV2oO9gznZlM8NFCfekKc/ND/aT3rYrvLqxMJcPg2YHKmgI4U7GO m5Dfl+69iN22QzEQiMIe/s78zfBaPT0dVX+xjFGusR5V4RnKUUZ6D2oOzrIJ6ans nx89vEHnudBF95loYrKlJiZqacUJOxPBZ3Z51CeMWfBBTkiHOHU= =s0mT -----END PGP SIGNATURE----- Merge tag 'x86_platform_for_v5.19_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull x86 platform updates from Borislav Petkov: - A couple of changes enabling SGI UV5 support * tag 'x86_platform_for_v5.19_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: x86/platform/uv: Log gap hole end size x86/platform/uv: Update TSC sync state for UV5 x86/platform/uv: Update NMI Handler for UV5
This commit is contained in:
commit
1abcb10d6e
2 changed files with 24 additions and 13 deletions
|
@ -199,7 +199,13 @@ static void __init uv_tsc_check_sync(void)
|
||||||
int mmr_shift;
|
int mmr_shift;
|
||||||
char *state;
|
char *state;
|
||||||
|
|
||||||
/* Different returns from different UV BIOS versions */
|
/* UV5 guarantees synced TSCs; do not zero TSC_ADJUST */
|
||||||
|
if (!is_uv(UV2|UV3|UV4)) {
|
||||||
|
mark_tsc_async_resets("UV5+");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* UV2,3,4, UV BIOS TSC sync state available */
|
||||||
mmr = uv_early_read_mmr(UVH_TSC_SYNC_MMR);
|
mmr = uv_early_read_mmr(UVH_TSC_SYNC_MMR);
|
||||||
mmr_shift =
|
mmr_shift =
|
||||||
is_uv2_hub() ? UVH_TSC_SYNC_SHIFT_UV2K : UVH_TSC_SYNC_SHIFT;
|
is_uv2_hub() ? UVH_TSC_SYNC_SHIFT_UV2K : UVH_TSC_SYNC_SHIFT;
|
||||||
|
@ -1340,7 +1346,7 @@ static void __init decode_gam_params(unsigned long ptr)
|
||||||
static void __init decode_gam_rng_tbl(unsigned long ptr)
|
static void __init decode_gam_rng_tbl(unsigned long ptr)
|
||||||
{
|
{
|
||||||
struct uv_gam_range_entry *gre = (struct uv_gam_range_entry *)ptr;
|
struct uv_gam_range_entry *gre = (struct uv_gam_range_entry *)ptr;
|
||||||
unsigned long lgre = 0;
|
unsigned long lgre = 0, gend = 0;
|
||||||
int index = 0;
|
int index = 0;
|
||||||
int sock_min = 999999, pnode_min = 99999;
|
int sock_min = 999999, pnode_min = 99999;
|
||||||
int sock_max = -1, pnode_max = -1;
|
int sock_max = -1, pnode_max = -1;
|
||||||
|
@ -1374,6 +1380,9 @@ static void __init decode_gam_rng_tbl(unsigned long ptr)
|
||||||
flag, size, suffix[order],
|
flag, size, suffix[order],
|
||||||
gre->type, gre->nasid, gre->sockid, gre->pnode);
|
gre->type, gre->nasid, gre->sockid, gre->pnode);
|
||||||
|
|
||||||
|
if (gre->type == UV_GAM_RANGE_TYPE_HOLE)
|
||||||
|
gend = (unsigned long)gre->limit << UV_GAM_RANGE_SHFT;
|
||||||
|
|
||||||
/* update to next range start */
|
/* update to next range start */
|
||||||
lgre = gre->limit;
|
lgre = gre->limit;
|
||||||
if (sock_min > gre->sockid)
|
if (sock_min > gre->sockid)
|
||||||
|
@ -1391,7 +1400,8 @@ static void __init decode_gam_rng_tbl(unsigned long ptr)
|
||||||
_max_pnode = pnode_max;
|
_max_pnode = pnode_max;
|
||||||
_gr_table_len = index;
|
_gr_table_len = index;
|
||||||
|
|
||||||
pr_info("UV: GRT: %d entries, sockets(min:%x,max:%x) pnodes(min:%x,max:%x)\n", index, _min_socket, _max_socket, _min_pnode, _max_pnode);
|
pr_info("UV: GRT: %d entries, sockets(min:%x,max:%x), pnodes(min:%x,max:%x), gap_end(%d)\n",
|
||||||
|
index, _min_socket, _max_socket, _min_pnode, _max_pnode, fls64(gend));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Walk through UVsystab decoding the fields */
|
/* Walk through UVsystab decoding the fields */
|
||||||
|
|
|
@ -244,8 +244,10 @@ static inline bool uv_nmi_action_is(const char *action)
|
||||||
/* Setup which NMI support is present in system */
|
/* Setup which NMI support is present in system */
|
||||||
static void uv_nmi_setup_mmrs(void)
|
static void uv_nmi_setup_mmrs(void)
|
||||||
{
|
{
|
||||||
|
bool new_nmi_method_only = false;
|
||||||
|
|
||||||
/* First determine arch specific MMRs to handshake with BIOS */
|
/* First determine arch specific MMRs to handshake with BIOS */
|
||||||
if (UVH_EVENT_OCCURRED0_EXTIO_INT0_MASK) {
|
if (UVH_EVENT_OCCURRED0_EXTIO_INT0_MASK) { /* UV2,3,4 setup */
|
||||||
uvh_nmi_mmrx = UVH_EVENT_OCCURRED0;
|
uvh_nmi_mmrx = UVH_EVENT_OCCURRED0;
|
||||||
uvh_nmi_mmrx_clear = UVH_EVENT_OCCURRED0_ALIAS;
|
uvh_nmi_mmrx_clear = UVH_EVENT_OCCURRED0_ALIAS;
|
||||||
uvh_nmi_mmrx_shift = UVH_EVENT_OCCURRED0_EXTIO_INT0_SHFT;
|
uvh_nmi_mmrx_shift = UVH_EVENT_OCCURRED0_EXTIO_INT0_SHFT;
|
||||||
|
@ -255,26 +257,25 @@ static void uv_nmi_setup_mmrs(void)
|
||||||
uvh_nmi_mmrx_req = UVH_BIOS_KERNEL_MMR_ALIAS_2;
|
uvh_nmi_mmrx_req = UVH_BIOS_KERNEL_MMR_ALIAS_2;
|
||||||
uvh_nmi_mmrx_req_shift = 62;
|
uvh_nmi_mmrx_req_shift = 62;
|
||||||
|
|
||||||
} else if (UVH_EVENT_OCCURRED1_EXTIO_INT0_MASK) {
|
} else if (UVH_EVENT_OCCURRED1_EXTIO_INT0_MASK) { /* UV5+ setup */
|
||||||
uvh_nmi_mmrx = UVH_EVENT_OCCURRED1;
|
uvh_nmi_mmrx = UVH_EVENT_OCCURRED1;
|
||||||
uvh_nmi_mmrx_clear = UVH_EVENT_OCCURRED1_ALIAS;
|
uvh_nmi_mmrx_clear = UVH_EVENT_OCCURRED1_ALIAS;
|
||||||
uvh_nmi_mmrx_shift = UVH_EVENT_OCCURRED1_EXTIO_INT0_SHFT;
|
uvh_nmi_mmrx_shift = UVH_EVENT_OCCURRED1_EXTIO_INT0_SHFT;
|
||||||
uvh_nmi_mmrx_type = "OCRD1-EXTIO_INT0";
|
uvh_nmi_mmrx_type = "OCRD1-EXTIO_INT0";
|
||||||
|
|
||||||
uvh_nmi_mmrx_supported = UVH_EXTIO_INT0_BROADCAST;
|
new_nmi_method_only = true; /* Newer nmi always valid on UV5+ */
|
||||||
uvh_nmi_mmrx_req = UVH_BIOS_KERNEL_MMR_ALIAS_2;
|
uvh_nmi_mmrx_req = 0; /* no request bit to clear */
|
||||||
uvh_nmi_mmrx_req_shift = 62;
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
pr_err("UV:%s:cannot find EVENT_OCCURRED*_EXTIO_INT0\n",
|
pr_err("UV:%s:NMI support not available on this system\n", __func__);
|
||||||
__func__);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Then find out if new NMI is supported */
|
/* Then find out if new NMI is supported */
|
||||||
if (likely(uv_read_local_mmr(uvh_nmi_mmrx_supported))) {
|
if (new_nmi_method_only || uv_read_local_mmr(uvh_nmi_mmrx_supported)) {
|
||||||
uv_write_local_mmr(uvh_nmi_mmrx_req,
|
if (uvh_nmi_mmrx_req)
|
||||||
1UL << uvh_nmi_mmrx_req_shift);
|
uv_write_local_mmr(uvh_nmi_mmrx_req,
|
||||||
|
1UL << uvh_nmi_mmrx_req_shift);
|
||||||
nmi_mmr = uvh_nmi_mmrx;
|
nmi_mmr = uvh_nmi_mmrx;
|
||||||
nmi_mmr_clear = uvh_nmi_mmrx_clear;
|
nmi_mmr_clear = uvh_nmi_mmrx_clear;
|
||||||
nmi_mmr_pending = 1UL << uvh_nmi_mmrx_shift;
|
nmi_mmr_pending = 1UL << uvh_nmi_mmrx_shift;
|
||||||
|
|
Loading…
Add table
Reference in a new issue