summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h
diff options
context:
space:
mode:
authorTerje Bergstrom <tbergstrom@nvidia.com>2015-01-29 14:29:56 -0500
committerDeepak Nibade <dnibade@nvidia.com>2016-12-27 04:52:05 -0500
commitac0cd782ab539d3a89ac2cc50955f80b8be456d1 (patch)
treee7feacdff08a9798db8ff9bf343f6895eb6d3035 /drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h
parent1fcd7fd547daac5374993f243fad77a822a5a048 (diff)
gpu: nvgpu: gp10b: Implement new page table format
Implement the 5-level Pascal page table format. It is enabled only for simulation. Change-Id: I6767fac8b52fe0f6a2e2f86312de5fc93af6518e Signed-off-by: Terje Bergstrom <tbergstrom@nvidia.com> Reviewed-on: http://git-master/r/682114
Diffstat (limited to 'drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h')
-rw-r--r--drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h168
1 files changed, 106 insertions, 62 deletions
diff --git a/drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h b/drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h
index 5a0f9fe2..fc65f57d 100644
--- a/drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h
+++ b/drivers/gpu/nvgpu/gp10b/hw_gmmu_gp10b.h
@@ -1,5 +1,5 @@
1/* 1/*
2 * Copyright (c) 2014, NVIDIA CORPORATION. All rights reserved. 2 * Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved.
3 * 3 *
4 * This program is free software; you can redistribute it and/or modify it 4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms and conditions of the GNU General Public License, 5 * under the terms and conditions of the GNU General Public License,
@@ -50,163 +50,207 @@
50#ifndef _hw_gmmu_gp10b_h_ 50#ifndef _hw_gmmu_gp10b_h_
51#define _hw_gmmu_gp10b_h_ 51#define _hw_gmmu_gp10b_h_
52 52
53static inline u32 gmmu_pde_aperture_big_w(void) 53static inline u32 gmmu_new_pde_is_pte_w(void)
54{ 54{
55 return 0; 55 return 0;
56} 56}
57static inline u32 gmmu_pde_aperture_big_invalid_f(void) 57static inline u32 gmmu_new_pde_is_pte_false_f(void)
58{ 58{
59 return 0x0; 59 return 0x0;
60} 60}
61static inline u32 gmmu_pde_aperture_big_video_memory_f(void) 61static inline u32 gmmu_new_pde_aperture_w(void)
62{ 62{
63 return 0x1; 63 return 0;
64}
65static inline u32 gmmu_new_pde_aperture_invalid_f(void)
66{
67 return 0x0;
68}
69static inline u32 gmmu_new_pde_aperture_video_memory_f(void)
70{
71 return 0x2;
72}
73static inline u32 gmmu_new_pde_address_sys_f(u32 v)
74{
75 return (v & 0xffffff) << 8;
76}
77static inline u32 gmmu_new_pde_address_sys_w(void)
78{
79 return 0;
80}
81static inline u32 gmmu_new_pde_vol_w(void)
82{
83 return 0;
84}
85static inline u32 gmmu_new_pde_vol_true_f(void)
86{
87 return 0x8;
88}
89static inline u32 gmmu_new_pde_vol_false_f(void)
90{
91 return 0x0;
92}
93static inline u32 gmmu_new_pde_address_shift_v(void)
94{
95 return 0x0000000c;
96}
97static inline u32 gmmu_new_pde__size_v(void)
98{
99 return 0x00000008;
100}
101static inline u32 gmmu_new_dual_pde_is_pte_w(void)
102{
103 return 0;
104}
105static inline u32 gmmu_new_dual_pde_is_pte_false_f(void)
106{
107 return 0x0;
64} 108}
65static inline u32 gmmu_pde_size_w(void) 109static inline u32 gmmu_new_dual_pde_aperture_big_w(void)
66{ 110{
67 return 0; 111 return 0;
68} 112}
69static inline u32 gmmu_pde_size_full_f(void) 113static inline u32 gmmu_new_dual_pde_aperture_big_invalid_f(void)
70{ 114{
71 return 0x0; 115 return 0x0;
72} 116}
73static inline u32 gmmu_pde_address_big_sys_f(u32 v) 117static inline u32 gmmu_new_dual_pde_aperture_big_video_memory_f(void)
118{
119 return 0x2;
120}
121static inline u32 gmmu_new_dual_pde_address_big_sys_f(u32 v)
74{ 122{
75 return (v & 0xfffffff) << 4; 123 return (v & 0xfffffff) << 4;
76} 124}
77static inline u32 gmmu_pde_address_big_sys_w(void) 125static inline u32 gmmu_new_dual_pde_address_big_sys_w(void)
78{ 126{
79 return 0; 127 return 0;
80} 128}
81static inline u32 gmmu_pde_aperture_small_w(void) 129static inline u32 gmmu_new_dual_pde_aperture_small_w(void)
82{ 130{
83 return 1; 131 return 2;
84} 132}
85static inline u32 gmmu_pde_aperture_small_invalid_f(void) 133static inline u32 gmmu_new_dual_pde_aperture_small_invalid_f(void)
86{ 134{
87 return 0x0; 135 return 0x0;
88} 136}
89static inline u32 gmmu_pde_aperture_small_video_memory_f(void) 137static inline u32 gmmu_new_dual_pde_aperture_small_video_memory_f(void)
90{ 138{
91 return 0x1; 139 return 0x2;
92} 140}
93static inline u32 gmmu_pde_vol_small_w(void) 141static inline u32 gmmu_new_dual_pde_vol_small_w(void)
94{ 142{
95 return 1; 143 return 2;
96} 144}
97static inline u32 gmmu_pde_vol_small_true_f(void) 145static inline u32 gmmu_new_dual_pde_vol_small_true_f(void)
98{ 146{
99 return 0x4; 147 return 0x8;
100} 148}
101static inline u32 gmmu_pde_vol_small_false_f(void) 149static inline u32 gmmu_new_dual_pde_vol_small_false_f(void)
102{ 150{
103 return 0x0; 151 return 0x0;
104} 152}
105static inline u32 gmmu_pde_vol_big_w(void) 153static inline u32 gmmu_new_dual_pde_vol_big_w(void)
106{ 154{
107 return 1; 155 return 0;
108} 156}
109static inline u32 gmmu_pde_vol_big_true_f(void) 157static inline u32 gmmu_new_dual_pde_vol_big_true_f(void)
110{ 158{
111 return 0x8; 159 return 0x8;
112} 160}
113static inline u32 gmmu_pde_vol_big_false_f(void) 161static inline u32 gmmu_new_dual_pde_vol_big_false_f(void)
114{ 162{
115 return 0x0; 163 return 0x0;
116} 164}
117static inline u32 gmmu_pde_address_small_sys_f(u32 v) 165static inline u32 gmmu_new_dual_pde_address_small_sys_f(u32 v)
118{ 166{
119 return (v & 0xfffffff) << 4; 167 return (v & 0xffffff) << 8;
120} 168}
121static inline u32 gmmu_pde_address_small_sys_w(void) 169static inline u32 gmmu_new_dual_pde_address_small_sys_w(void)
122{ 170{
123 return 1; 171 return 2;
124} 172}
125static inline u32 gmmu_pde_address_shift_v(void) 173static inline u32 gmmu_new_dual_pde_address_shift_v(void)
126{ 174{
127 return 0x0000000c; 175 return 0x0000000c;
128} 176}
129static inline u32 gmmu_pde__size_v(void) 177static inline u32 gmmu_new_dual_pde_address_big_shift_v(void)
130{ 178{
131 return 0x00000008; 179 return 0x00000008;
132} 180}
133static inline u32 gmmu_pte__size_v(void) 181static inline u32 gmmu_new_dual_pde__size_v(void)
182{
183 return 0x00000010;
184}
185static inline u32 gmmu_new_pte__size_v(void)
134{ 186{
135 return 0x00000008; 187 return 0x00000008;
136} 188}
137static inline u32 gmmu_pte_valid_w(void) 189static inline u32 gmmu_new_pte_valid_w(void)
138{ 190{
139 return 0; 191 return 0;
140} 192}
141static inline u32 gmmu_pte_valid_true_f(void) 193static inline u32 gmmu_new_pte_valid_true_f(void)
142{ 194{
143 return 0x1; 195 return 0x1;
144} 196}
145static inline u32 gmmu_pte_valid_false_f(void) 197static inline u32 gmmu_new_pte_valid_false_f(void)
146{ 198{
147 return 0x0; 199 return 0x0;
148} 200}
149static inline u32 gmmu_pte_address_sys_f(u32 v) 201static inline u32 gmmu_new_pte_address_sys_f(u32 v)
150{ 202{
151 return (v & 0xfffffff) << 4; 203 return (v & 0xffffff) << 8;
152} 204}
153static inline u32 gmmu_pte_address_sys_w(void) 205static inline u32 gmmu_new_pte_address_sys_w(void)
154{ 206{
155 return 0; 207 return 0;
156} 208}
157static inline u32 gmmu_pte_vol_w(void) 209static inline u32 gmmu_new_pte_vol_w(void)
158{ 210{
159 return 1; 211 return 0;
160} 212}
161static inline u32 gmmu_pte_vol_true_f(void) 213static inline u32 gmmu_new_pte_vol_true_f(void)
162{ 214{
163 return 0x1; 215 return 0x8;
164} 216}
165static inline u32 gmmu_pte_vol_false_f(void) 217static inline u32 gmmu_new_pte_vol_false_f(void)
166{ 218{
167 return 0x0; 219 return 0x0;
168} 220}
169static inline u32 gmmu_pte_aperture_w(void) 221static inline u32 gmmu_new_pte_aperture_w(void)
170{ 222{
171 return 1; 223 return 0;
172} 224}
173static inline u32 gmmu_pte_aperture_video_memory_f(void) 225static inline u32 gmmu_new_pte_aperture_video_memory_f(void)
174{ 226{
175 return 0x0; 227 return 0x0;
176} 228}
177static inline u32 gmmu_pte_read_only_w(void) 229static inline u32 gmmu_new_pte_read_only_w(void)
178{ 230{
179 return 0; 231 return 0;
180} 232}
181static inline u32 gmmu_pte_read_only_true_f(void) 233static inline u32 gmmu_new_pte_read_only_true_f(void)
182{ 234{
183 return 0x4; 235 return 0x40;
184} 236}
185static inline u32 gmmu_pte_write_disable_w(void) 237static inline u32 gmmu_new_pte_comptagline_f(u32 v)
186{ 238{
187 return 1; 239 return (v & 0x3ffff) << 4;
188} 240}
189static inline u32 gmmu_pte_write_disable_true_f(void) 241static inline u32 gmmu_new_pte_comptagline_w(void)
190{
191 return 0x80000000;
192}
193static inline u32 gmmu_pte_read_disable_w(void)
194{ 242{
195 return 1; 243 return 1;
196} 244}
197static inline u32 gmmu_pte_read_disable_true_f(void) 245static inline u32 gmmu_new_pte_kind_f(u32 v)
198{
199 return 0x40000000;
200}
201static inline u32 gmmu_pte_comptagline_f(u32 v)
202{ 246{
203 return (v & 0x3ffff) << 12; 247 return (v & 0xff) << 24;
204} 248}
205static inline u32 gmmu_pte_comptagline_w(void) 249static inline u32 gmmu_new_pte_kind_w(void)
206{ 250{
207 return 1; 251 return 1;
208} 252}
209static inline u32 gmmu_pte_address_shift_v(void) 253static inline u32 gmmu_new_pte_address_shift_v(void)
210{ 254{
211 return 0x0000000c; 255 return 0x0000000c;
212} 256}