aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86
diff options
context:
space:
mode:
authorJack Steiner <steiner@sgi.com>2008-07-01 15:45:38 -0400
committerIngo Molnar <mingo@elte.hu>2008-07-09 01:43:23 -0400
commit83f5d894ca5280bfcd904dfeb1347c2da2b19aac (patch)
tree63c8ff85f0144a645137bebd0961fc25fce82a03 /include/asm-x86
parent3a9e189d69479736a0d0901c87ad08c9e328b389 (diff)
x86: map UV chipset space - UV support
Create page table entries to map the SGI UV chipset GRU. local MMR & global MMR ranges. Signed-off-by: Jack Steiner <steiner@sgi.com> Cc: linux-mm@kvack.org Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include/asm-x86')
-rw-r--r--include/asm-x86/uv/uv_hub.h2
-rw-r--r--include/asm-x86/uv/uv_mmrs.h46
2 files changed, 48 insertions, 0 deletions
diff --git a/include/asm-x86/uv/uv_hub.h b/include/asm-x86/uv/uv_hub.h
index 65004881de5f..a4ef26e5850b 100644
--- a/include/asm-x86/uv/uv_hub.h
+++ b/include/asm-x86/uv/uv_hub.h
@@ -149,6 +149,8 @@ DECLARE_PER_CPU(struct uv_hub_info_s, __uv_hub_info);
149#define UV_LOCAL_MMR_BASE 0xf4000000UL 149#define UV_LOCAL_MMR_BASE 0xf4000000UL
150#define UV_GLOBAL_MMR32_BASE 0xf8000000UL 150#define UV_GLOBAL_MMR32_BASE 0xf8000000UL
151#define UV_GLOBAL_MMR64_BASE (uv_hub_info->global_mmr_base) 151#define UV_GLOBAL_MMR64_BASE (uv_hub_info->global_mmr_base)
152#define UV_LOCAL_MMR_SIZE (64UL * 1024 * 1024)
153#define UV_GLOBAL_MMR32_SIZE (64UL * 1024 * 1024)
152 154
153#define UV_GLOBAL_MMR32_PNODE_SHIFT 15 155#define UV_GLOBAL_MMR32_PNODE_SHIFT 15
154#define UV_GLOBAL_MMR64_PNODE_SHIFT 26 156#define UV_GLOBAL_MMR64_PNODE_SHIFT 26
diff --git a/include/asm-x86/uv/uv_mmrs.h b/include/asm-x86/uv/uv_mmrs.h
index ac9846076521..37113f554a97 100644
--- a/include/asm-x86/uv/uv_mmrs.h
+++ b/include/asm-x86/uv/uv_mmrs.h
@@ -713,6 +713,26 @@ union uvh_rh_gam_alias210_redirect_config_2_mmr_u {
713}; 713};
714 714
715/* ========================================================================= */ 715/* ========================================================================= */
716/* UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR */
717/* ========================================================================= */
718#define UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR 0x1600020UL
719
720#define UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR_BASE_SHFT 26
721#define UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR_BASE_MASK 0x00003ffffc000000UL
722#define UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR_ENABLE_SHFT 63
723#define UVH_RH_GAM_CFG_OVERLAY_CONFIG_MMR_ENABLE_MASK 0x8000000000000000UL
724
725union uvh_rh_gam_cfg_overlay_config_mmr_u {
726 unsigned long v;
727 struct uvh_rh_gam_cfg_overlay_config_mmr_s {
728 unsigned long rsvd_0_25: 26; /* */
729 unsigned long base : 20; /* RW */
730 unsigned long rsvd_46_62: 17; /* */
731 unsigned long enable : 1; /* RW */
732 } s;
733};
734
735/* ========================================================================= */
716/* UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR */ 736/* UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR */
717/* ========================================================================= */ 737/* ========================================================================= */
718#define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR 0x1600010UL 738#define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR 0x1600010UL
@@ -740,6 +760,32 @@ union uvh_rh_gam_gru_overlay_config_mmr_u {
740}; 760};
741 761
742/* ========================================================================= */ 762/* ========================================================================= */
763/* UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR */
764/* ========================================================================= */
765#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR 0x1600030UL
766
767#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_BASE_SHFT 30
768#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_BASE_MASK 0x00003fffc0000000UL
769#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_M_IO_SHFT 46
770#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_M_IO_MASK 0x000fc00000000000UL
771#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_N_IO_SHFT 52
772#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_N_IO_MASK 0x00f0000000000000UL
773#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_ENABLE_SHFT 63
774#define UVH_RH_GAM_MMIOH_OVERLAY_CONFIG_MMR_ENABLE_MASK 0x8000000000000000UL
775
776union uvh_rh_gam_mmioh_overlay_config_mmr_u {
777 unsigned long v;
778 struct uvh_rh_gam_mmioh_overlay_config_mmr_s {
779 unsigned long rsvd_0_29: 30; /* */
780 unsigned long base : 16; /* RW */
781 unsigned long m_io : 6; /* RW */
782 unsigned long n_io : 4; /* RW */
783 unsigned long rsvd_56_62: 7; /* */
784 unsigned long enable : 1; /* RW */
785 } s;
786};
787
788/* ========================================================================= */
743/* UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR */ 789/* UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR */
744/* ========================================================================= */ 790/* ========================================================================= */
745#define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR 0x1600028UL 791#define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR 0x1600028UL