diff options
Diffstat (limited to 'drivers/gpu/drm/nouveau/nv20_graph.c')
-rw-r--r-- | drivers/gpu/drm/nouveau/nv20_graph.c | 506 |
1 files changed, 251 insertions, 255 deletions
diff --git a/drivers/gpu/drm/nouveau/nv20_graph.c b/drivers/gpu/drm/nouveau/nv20_graph.c index 17f309b36c91..12ab9cd56eca 100644 --- a/drivers/gpu/drm/nouveau/nv20_graph.c +++ b/drivers/gpu/drm/nouveau/nv20_graph.c | |||
@@ -37,49 +37,49 @@ nv20_graph_context_init(struct drm_device *dev, struct nouveau_gpuobj *ctx) | |||
37 | { | 37 | { |
38 | int i; | 38 | int i; |
39 | 39 | ||
40 | nv_wo32(dev, ctx, 0x033c/4, 0xffff0000); | 40 | nv_wo32(ctx, 0x033c, 0xffff0000); |
41 | nv_wo32(dev, ctx, 0x03a0/4, 0x0fff0000); | 41 | nv_wo32(ctx, 0x03a0, 0x0fff0000); |
42 | nv_wo32(dev, ctx, 0x03a4/4, 0x0fff0000); | 42 | nv_wo32(ctx, 0x03a4, 0x0fff0000); |
43 | nv_wo32(dev, ctx, 0x047c/4, 0x00000101); | 43 | nv_wo32(ctx, 0x047c, 0x00000101); |
44 | nv_wo32(dev, ctx, 0x0490/4, 0x00000111); | 44 | nv_wo32(ctx, 0x0490, 0x00000111); |
45 | nv_wo32(dev, ctx, 0x04a8/4, 0x44400000); | 45 | nv_wo32(ctx, 0x04a8, 0x44400000); |
46 | for (i = 0x04d4; i <= 0x04e0; i += 4) | 46 | for (i = 0x04d4; i <= 0x04e0; i += 4) |
47 | nv_wo32(dev, ctx, i/4, 0x00030303); | 47 | nv_wo32(ctx, i, 0x00030303); |
48 | for (i = 0x04f4; i <= 0x0500; i += 4) | 48 | for (i = 0x04f4; i <= 0x0500; i += 4) |
49 | nv_wo32(dev, ctx, i/4, 0x00080000); | 49 | nv_wo32(ctx, i, 0x00080000); |
50 | for (i = 0x050c; i <= 0x0518; i += 4) | 50 | for (i = 0x050c; i <= 0x0518; i += 4) |
51 | nv_wo32(dev, ctx, i/4, 0x01012000); | 51 | nv_wo32(ctx, i, 0x01012000); |
52 | for (i = 0x051c; i <= 0x0528; i += 4) | 52 | for (i = 0x051c; i <= 0x0528; i += 4) |
53 | nv_wo32(dev, ctx, i/4, 0x000105b8); | 53 | nv_wo32(ctx, i, 0x000105b8); |
54 | for (i = 0x052c; i <= 0x0538; i += 4) | 54 | for (i = 0x052c; i <= 0x0538; i += 4) |
55 | nv_wo32(dev, ctx, i/4, 0x00080008); | 55 | nv_wo32(ctx, i, 0x00080008); |
56 | for (i = 0x055c; i <= 0x0598; i += 4) | 56 | for (i = 0x055c; i <= 0x0598; i += 4) |
57 | nv_wo32(dev, ctx, i/4, 0x07ff0000); | 57 | nv_wo32(ctx, i, 0x07ff0000); |
58 | nv_wo32(dev, ctx, 0x05a4/4, 0x4b7fffff); | 58 | nv_wo32(ctx, 0x05a4, 0x4b7fffff); |
59 | nv_wo32(dev, ctx, 0x05fc/4, 0x00000001); | 59 | nv_wo32(ctx, 0x05fc, 0x00000001); |
60 | nv_wo32(dev, ctx, 0x0604/4, 0x00004000); | 60 | nv_wo32(ctx, 0x0604, 0x00004000); |
61 | nv_wo32(dev, ctx, 0x0610/4, 0x00000001); | 61 | nv_wo32(ctx, 0x0610, 0x00000001); |
62 | nv_wo32(dev, ctx, 0x0618/4, 0x00040000); | 62 | nv_wo32(ctx, 0x0618, 0x00040000); |
63 | nv_wo32(dev, ctx, 0x061c/4, 0x00010000); | 63 | nv_wo32(ctx, 0x061c, 0x00010000); |
64 | for (i = 0x1c1c; i <= 0x248c; i += 16) { | 64 | for (i = 0x1c1c; i <= 0x248c; i += 16) { |
65 | nv_wo32(dev, ctx, (i + 0)/4, 0x10700ff9); | 65 | nv_wo32(ctx, (i + 0), 0x10700ff9); |
66 | nv_wo32(dev, ctx, (i + 4)/4, 0x0436086c); | 66 | nv_wo32(ctx, (i + 4), 0x0436086c); |
67 | nv_wo32(dev, ctx, (i + 8)/4, 0x000c001b); | 67 | nv_wo32(ctx, (i + 8), 0x000c001b); |
68 | } | 68 | } |
69 | nv_wo32(dev, ctx, 0x281c/4, 0x3f800000); | 69 | nv_wo32(ctx, 0x281c, 0x3f800000); |
70 | nv_wo32(dev, ctx, 0x2830/4, 0x3f800000); | 70 | nv_wo32(ctx, 0x2830, 0x3f800000); |
71 | nv_wo32(dev, ctx, 0x285c/4, 0x40000000); | 71 | nv_wo32(ctx, 0x285c, 0x40000000); |
72 | nv_wo32(dev, ctx, 0x2860/4, 0x3f800000); | 72 | nv_wo32(ctx, 0x2860, 0x3f800000); |
73 | nv_wo32(dev, ctx, 0x2864/4, 0x3f000000); | 73 | nv_wo32(ctx, 0x2864, 0x3f000000); |
74 | nv_wo32(dev, ctx, 0x286c/4, 0x40000000); | 74 | nv_wo32(ctx, 0x286c, 0x40000000); |
75 | nv_wo32(dev, ctx, 0x2870/4, 0x3f800000); | 75 | nv_wo32(ctx, 0x2870, 0x3f800000); |
76 | nv_wo32(dev, ctx, 0x2878/4, 0xbf800000); | 76 | nv_wo32(ctx, 0x2878, 0xbf800000); |
77 | nv_wo32(dev, ctx, 0x2880/4, 0xbf800000); | 77 | nv_wo32(ctx, 0x2880, 0xbf800000); |
78 | nv_wo32(dev, ctx, 0x34a4/4, 0x000fe000); | 78 | nv_wo32(ctx, 0x34a4, 0x000fe000); |
79 | nv_wo32(dev, ctx, 0x3530/4, 0x000003f8); | 79 | nv_wo32(ctx, 0x3530, 0x000003f8); |
80 | nv_wo32(dev, ctx, 0x3540/4, 0x002fe000); | 80 | nv_wo32(ctx, 0x3540, 0x002fe000); |
81 | for (i = 0x355c; i <= 0x3578; i += 4) | 81 | for (i = 0x355c; i <= 0x3578; i += 4) |
82 | nv_wo32(dev, ctx, i/4, 0x001c527c); | 82 | nv_wo32(ctx, i, 0x001c527c); |
83 | } | 83 | } |
84 | 84 | ||
85 | static void | 85 | static void |
@@ -87,58 +87,58 @@ nv25_graph_context_init(struct drm_device *dev, struct nouveau_gpuobj *ctx) | |||
87 | { | 87 | { |
88 | int i; | 88 | int i; |
89 | 89 | ||
90 | nv_wo32(dev, ctx, 0x035c/4, 0xffff0000); | 90 | nv_wo32(ctx, 0x035c, 0xffff0000); |
91 | nv_wo32(dev, ctx, 0x03c0/4, 0x0fff0000); | 91 | nv_wo32(ctx, 0x03c0, 0x0fff0000); |
92 | nv_wo32(dev, ctx, 0x03c4/4, 0x0fff0000); | 92 | nv_wo32(ctx, 0x03c4, 0x0fff0000); |
93 | nv_wo32(dev, ctx, 0x049c/4, 0x00000101); | 93 | nv_wo32(ctx, 0x049c, 0x00000101); |
94 | nv_wo32(dev, ctx, 0x04b0/4, 0x00000111); | 94 | nv_wo32(ctx, 0x04b0, 0x00000111); |
95 | nv_wo32(dev, ctx, 0x04c8/4, 0x00000080); | 95 | nv_wo32(ctx, 0x04c8, 0x00000080); |
96 | nv_wo32(dev, ctx, 0x04cc/4, 0xffff0000); | 96 | nv_wo32(ctx, 0x04cc, 0xffff0000); |
97 | nv_wo32(dev, ctx, 0x04d0/4, 0x00000001); | 97 | nv_wo32(ctx, 0x04d0, 0x00000001); |
98 | nv_wo32(dev, ctx, 0x04e4/4, 0x44400000); | 98 | nv_wo32(ctx, 0x04e4, 0x44400000); |
99 | nv_wo32(dev, ctx, 0x04fc/4, 0x4b800000); | 99 | nv_wo32(ctx, 0x04fc, 0x4b800000); |
100 | for (i = 0x0510; i <= 0x051c; i += 4) | 100 | for (i = 0x0510; i <= 0x051c; i += 4) |
101 | nv_wo32(dev, ctx, i/4, 0x00030303); | 101 | nv_wo32(ctx, i, 0x00030303); |
102 | for (i = 0x0530; i <= 0x053c; i += 4) | 102 | for (i = 0x0530; i <= 0x053c; i += 4) |
103 | nv_wo32(dev, ctx, i/4, 0x00080000); | 103 | nv_wo32(ctx, i, 0x00080000); |
104 | for (i = 0x0548; i <= 0x0554; i += 4) | 104 | for (i = 0x0548; i <= 0x0554; i += 4) |
105 | nv_wo32(dev, ctx, i/4, 0x01012000); | 105 | nv_wo32(ctx, i, 0x01012000); |
106 | for (i = 0x0558; i <= 0x0564; i += 4) | 106 | for (i = 0x0558; i <= 0x0564; i += 4) |
107 | nv_wo32(dev, ctx, i/4, 0x000105b8); | 107 | nv_wo32(ctx, i, 0x000105b8); |
108 | for (i = 0x0568; i <= 0x0574; i += 4) | 108 | for (i = 0x0568; i <= 0x0574; i += 4) |
109 | nv_wo32(dev, ctx, i/4, 0x00080008); | 109 | nv_wo32(ctx, i, 0x00080008); |
110 | for (i = 0x0598; i <= 0x05d4; i += 4) | 110 | for (i = 0x0598; i <= 0x05d4; i += 4) |
111 | nv_wo32(dev, ctx, i/4, 0x07ff0000); | 111 | nv_wo32(ctx, i, 0x07ff0000); |
112 | nv_wo32(dev, ctx, 0x05e0/4, 0x4b7fffff); | 112 | nv_wo32(ctx, 0x05e0, 0x4b7fffff); |
113 | nv_wo32(dev, ctx, 0x0620/4, 0x00000080); | 113 | nv_wo32(ctx, 0x0620, 0x00000080); |
114 | nv_wo32(dev, ctx, 0x0624/4, 0x30201000); | 114 | nv_wo32(ctx, 0x0624, 0x30201000); |
115 | nv_wo32(dev, ctx, 0x0628/4, 0x70605040); | 115 | nv_wo32(ctx, 0x0628, 0x70605040); |
116 | nv_wo32(dev, ctx, 0x062c/4, 0xb0a09080); | 116 | nv_wo32(ctx, 0x062c, 0xb0a09080); |
117 | nv_wo32(dev, ctx, 0x0630/4, 0xf0e0d0c0); | 117 | nv_wo32(ctx, 0x0630, 0xf0e0d0c0); |
118 | nv_wo32(dev, ctx, 0x0664/4, 0x00000001); | 118 | nv_wo32(ctx, 0x0664, 0x00000001); |
119 | nv_wo32(dev, ctx, 0x066c/4, 0x00004000); | 119 | nv_wo32(ctx, 0x066c, 0x00004000); |
120 | nv_wo32(dev, ctx, 0x0678/4, 0x00000001); | 120 | nv_wo32(ctx, 0x0678, 0x00000001); |
121 | nv_wo32(dev, ctx, 0x0680/4, 0x00040000); | 121 | nv_wo32(ctx, 0x0680, 0x00040000); |
122 | nv_wo32(dev, ctx, 0x0684/4, 0x00010000); | 122 | nv_wo32(ctx, 0x0684, 0x00010000); |
123 | for (i = 0x1b04; i <= 0x2374; i += 16) { | 123 | for (i = 0x1b04; i <= 0x2374; i += 16) { |
124 | nv_wo32(dev, ctx, (i + 0)/4, 0x10700ff9); | 124 | nv_wo32(ctx, (i + 0), 0x10700ff9); |
125 | nv_wo32(dev, ctx, (i + 4)/4, 0x0436086c); | 125 | nv_wo32(ctx, (i + 4), 0x0436086c); |
126 | nv_wo32(dev, ctx, (i + 8)/4, 0x000c001b); | 126 | nv_wo32(ctx, (i + 8), 0x000c001b); |
127 | } | 127 | } |
128 | nv_wo32(dev, ctx, 0x2704/4, 0x3f800000); | 128 | nv_wo32(ctx, 0x2704, 0x3f800000); |
129 | nv_wo32(dev, ctx, 0x2718/4, 0x3f800000); | 129 | nv_wo32(ctx, 0x2718, 0x3f800000); |
130 | nv_wo32(dev, ctx, 0x2744/4, 0x40000000); | 130 | nv_wo32(ctx, 0x2744, 0x40000000); |
131 | nv_wo32(dev, ctx, 0x2748/4, 0x3f800000); | 131 | nv_wo32(ctx, 0x2748, 0x3f800000); |
132 | nv_wo32(dev, ctx, 0x274c/4, 0x3f000000); | 132 | nv_wo32(ctx, 0x274c, 0x3f000000); |
133 | nv_wo32(dev, ctx, 0x2754/4, 0x40000000); | 133 | nv_wo32(ctx, 0x2754, 0x40000000); |
134 | nv_wo32(dev, ctx, 0x2758/4, 0x3f800000); | 134 | nv_wo32(ctx, 0x2758, 0x3f800000); |
135 | nv_wo32(dev, ctx, 0x2760/4, 0xbf800000); | 135 | nv_wo32(ctx, 0x2760, 0xbf800000); |
136 | nv_wo32(dev, ctx, 0x2768/4, 0xbf800000); | 136 | nv_wo32(ctx, 0x2768, 0xbf800000); |
137 | nv_wo32(dev, ctx, 0x308c/4, 0x000fe000); | 137 | nv_wo32(ctx, 0x308c, 0x000fe000); |
138 | nv_wo32(dev, ctx, 0x3108/4, 0x000003f8); | 138 | nv_wo32(ctx, 0x3108, 0x000003f8); |
139 | nv_wo32(dev, ctx, 0x3468/4, 0x002fe000); | 139 | nv_wo32(ctx, 0x3468, 0x002fe000); |
140 | for (i = 0x3484; i <= 0x34a0; i += 4) | 140 | for (i = 0x3484; i <= 0x34a0; i += 4) |
141 | nv_wo32(dev, ctx, i/4, 0x001c527c); | 141 | nv_wo32(ctx, i, 0x001c527c); |
142 | } | 142 | } |
143 | 143 | ||
144 | static void | 144 | static void |
@@ -146,49 +146,49 @@ nv2a_graph_context_init(struct drm_device *dev, struct nouveau_gpuobj *ctx) | |||
146 | { | 146 | { |
147 | int i; | 147 | int i; |
148 | 148 | ||
149 | nv_wo32(dev, ctx, 0x033c/4, 0xffff0000); | 149 | nv_wo32(ctx, 0x033c, 0xffff0000); |
150 | nv_wo32(dev, ctx, 0x03a0/4, 0x0fff0000); | 150 | nv_wo32(ctx, 0x03a0, 0x0fff0000); |
151 | nv_wo32(dev, ctx, 0x03a4/4, 0x0fff0000); | 151 | nv_wo32(ctx, 0x03a4, 0x0fff0000); |
152 | nv_wo32(dev, ctx, 0x047c/4, 0x00000101); | 152 | nv_wo32(ctx, 0x047c, 0x00000101); |
153 | nv_wo32(dev, ctx, 0x0490/4, 0x00000111); | 153 | nv_wo32(ctx, 0x0490, 0x00000111); |
154 | nv_wo32(dev, ctx, 0x04a8/4, 0x44400000); | 154 | nv_wo32(ctx, 0x04a8, 0x44400000); |
155 | for (i = 0x04d4; i <= 0x04e0; i += 4) | 155 | for (i = 0x04d4; i <= 0x04e0; i += 4) |
156 | nv_wo32(dev, ctx, i/4, 0x00030303); | 156 | nv_wo32(ctx, i, 0x00030303); |
157 | for (i = 0x04f4; i <= 0x0500; i += 4) | 157 | for (i = 0x04f4; i <= 0x0500; i += 4) |
158 | nv_wo32(dev, ctx, i/4, 0x00080000); | 158 | nv_wo32(ctx, i, 0x00080000); |
159 | for (i = 0x050c; i <= 0x0518; i += 4) | 159 | for (i = 0x050c; i <= 0x0518; i += 4) |
160 | nv_wo32(dev, ctx, i/4, 0x01012000); | 160 | nv_wo32(ctx, i, 0x01012000); |
161 | for (i = 0x051c; i <= 0x0528; i += 4) | 161 | for (i = 0x051c; i <= 0x0528; i += 4) |
162 | nv_wo32(dev, ctx, i/4, 0x000105b8); | 162 | nv_wo32(ctx, i, 0x000105b8); |
163 | for (i = 0x052c; i <= 0x0538; i += 4) | 163 | for (i = 0x052c; i <= 0x0538; i += 4) |
164 | nv_wo32(dev, ctx, i/4, 0x00080008); | 164 | nv_wo32(ctx, i, 0x00080008); |
165 | for (i = 0x055c; i <= 0x0598; i += 4) | 165 | for (i = 0x055c; i <= 0x0598; i += 4) |
166 | nv_wo32(dev, ctx, i/4, 0x07ff0000); | 166 | nv_wo32(ctx, i, 0x07ff0000); |
167 | nv_wo32(dev, ctx, 0x05a4/4, 0x4b7fffff); | 167 | nv_wo32(ctx, 0x05a4, 0x4b7fffff); |
168 | nv_wo32(dev, ctx, 0x05fc/4, 0x00000001); | 168 | nv_wo32(ctx, 0x05fc, 0x00000001); |
169 | nv_wo32(dev, ctx, 0x0604/4, 0x00004000); | 169 | nv_wo32(ctx, 0x0604, 0x00004000); |
170 | nv_wo32(dev, ctx, 0x0610/4, 0x00000001); | 170 | nv_wo32(ctx, 0x0610, 0x00000001); |
171 | nv_wo32(dev, ctx, 0x0618/4, 0x00040000); | 171 | nv_wo32(ctx, 0x0618, 0x00040000); |
172 | nv_wo32(dev, ctx, 0x061c/4, 0x00010000); | 172 | nv_wo32(ctx, 0x061c, 0x00010000); |
173 | for (i = 0x1a9c; i <= 0x22fc; i += 16) { /*XXX: check!! */ | 173 | for (i = 0x1a9c; i <= 0x22fc; i += 16) { /*XXX: check!! */ |
174 | nv_wo32(dev, ctx, (i + 0)/4, 0x10700ff9); | 174 | nv_wo32(ctx, (i + 0), 0x10700ff9); |
175 | nv_wo32(dev, ctx, (i + 4)/4, 0x0436086c); | 175 | nv_wo32(ctx, (i + 4), 0x0436086c); |
176 | nv_wo32(dev, ctx, (i + 8)/4, 0x000c001b); | 176 | nv_wo32(ctx, (i + 8), 0x000c001b); |
177 | } | 177 | } |
178 | nv_wo32(dev, ctx, 0x269c/4, 0x3f800000); | 178 | nv_wo32(ctx, 0x269c, 0x3f800000); |
179 | nv_wo32(dev, ctx, 0x26b0/4, 0x3f800000); | 179 | nv_wo32(ctx, 0x26b0, 0x3f800000); |
180 | nv_wo32(dev, ctx, 0x26dc/4, 0x40000000); | 180 | nv_wo32(ctx, 0x26dc, 0x40000000); |
181 | nv_wo32(dev, ctx, 0x26e0/4, 0x3f800000); | 181 | nv_wo32(ctx, 0x26e0, 0x3f800000); |
182 | nv_wo32(dev, ctx, 0x26e4/4, 0x3f000000); | 182 | nv_wo32(ctx, 0x26e4, 0x3f000000); |
183 | nv_wo32(dev, ctx, 0x26ec/4, 0x40000000); | 183 | nv_wo32(ctx, 0x26ec, 0x40000000); |
184 | nv_wo32(dev, ctx, 0x26f0/4, 0x3f800000); | 184 | nv_wo32(ctx, 0x26f0, 0x3f800000); |
185 | nv_wo32(dev, ctx, 0x26f8/4, 0xbf800000); | 185 | nv_wo32(ctx, 0x26f8, 0xbf800000); |
186 | nv_wo32(dev, ctx, 0x2700/4, 0xbf800000); | 186 | nv_wo32(ctx, 0x2700, 0xbf800000); |
187 | nv_wo32(dev, ctx, 0x3024/4, 0x000fe000); | 187 | nv_wo32(ctx, 0x3024, 0x000fe000); |
188 | nv_wo32(dev, ctx, 0x30a0/4, 0x000003f8); | 188 | nv_wo32(ctx, 0x30a0, 0x000003f8); |
189 | nv_wo32(dev, ctx, 0x33fc/4, 0x002fe000); | 189 | nv_wo32(ctx, 0x33fc, 0x002fe000); |
190 | for (i = 0x341c; i <= 0x3438; i += 4) | 190 | for (i = 0x341c; i <= 0x3438; i += 4) |
191 | nv_wo32(dev, ctx, i/4, 0x001c527c); | 191 | nv_wo32(ctx, i, 0x001c527c); |
192 | } | 192 | } |
193 | 193 | ||
194 | static void | 194 | static void |
@@ -196,57 +196,57 @@ nv30_31_graph_context_init(struct drm_device *dev, struct nouveau_gpuobj *ctx) | |||
196 | { | 196 | { |
197 | int i; | 197 | int i; |
198 | 198 | ||
199 | nv_wo32(dev, ctx, 0x0410/4, 0x00000101); | 199 | nv_wo32(ctx, 0x0410, 0x00000101); |
200 | nv_wo32(dev, ctx, 0x0424/4, 0x00000111); | 200 | nv_wo32(ctx, 0x0424, 0x00000111); |
201 | nv_wo32(dev, ctx, 0x0428/4, 0x00000060); | 201 | nv_wo32(ctx, 0x0428, 0x00000060); |
202 | nv_wo32(dev, ctx, 0x0444/4, 0x00000080); | 202 | nv_wo32(ctx, 0x0444, 0x00000080); |
203 | nv_wo32(dev, ctx, 0x0448/4, 0xffff0000); | 203 | nv_wo32(ctx, 0x0448, 0xffff0000); |
204 | nv_wo32(dev, ctx, 0x044c/4, 0x00000001); | 204 | nv_wo32(ctx, 0x044c, 0x00000001); |
205 | nv_wo32(dev, ctx, 0x0460/4, 0x44400000); | 205 | nv_wo32(ctx, 0x0460, 0x44400000); |
206 | nv_wo32(dev, ctx, 0x048c/4, 0xffff0000); | 206 | nv_wo32(ctx, 0x048c, 0xffff0000); |
207 | for (i = 0x04e0; i < 0x04e8; i += 4) | 207 | for (i = 0x04e0; i < 0x04e8; i += 4) |
208 | nv_wo32(dev, ctx, i/4, 0x0fff0000); | 208 | nv_wo32(ctx, i, 0x0fff0000); |
209 | nv_wo32(dev, ctx, 0x04ec/4, 0x00011100); | 209 | nv_wo32(ctx, 0x04ec, 0x00011100); |
210 | for (i = 0x0508; i < 0x0548; i += 4) | 210 | for (i = 0x0508; i < 0x0548; i += 4) |
211 | nv_wo32(dev, ctx, i/4, 0x07ff0000); | 211 | nv_wo32(ctx, i, 0x07ff0000); |
212 | nv_wo32(dev, ctx, 0x0550/4, 0x4b7fffff); | 212 | nv_wo32(ctx, 0x0550, 0x4b7fffff); |
213 | nv_wo32(dev, ctx, 0x058c/4, 0x00000080); | 213 | nv_wo32(ctx, 0x058c, 0x00000080); |
214 | nv_wo32(dev, ctx, 0x0590/4, 0x30201000); | 214 | nv_wo32(ctx, 0x0590, 0x30201000); |
215 | nv_wo32(dev, ctx, 0x0594/4, 0x70605040); | 215 | nv_wo32(ctx, 0x0594, 0x70605040); |
216 | nv_wo32(dev, ctx, 0x0598/4, 0xb8a89888); | 216 | nv_wo32(ctx, 0x0598, 0xb8a89888); |
217 | nv_wo32(dev, ctx, 0x059c/4, 0xf8e8d8c8); | 217 | nv_wo32(ctx, 0x059c, 0xf8e8d8c8); |
218 | nv_wo32(dev, ctx, 0x05b0/4, 0xb0000000); | 218 | nv_wo32(ctx, 0x05b0, 0xb0000000); |
219 | for (i = 0x0600; i < 0x0640; i += 4) | 219 | for (i = 0x0600; i < 0x0640; i += 4) |
220 | nv_wo32(dev, ctx, i/4, 0x00010588); | 220 | nv_wo32(ctx, i, 0x00010588); |
221 | for (i = 0x0640; i < 0x0680; i += 4) | 221 | for (i = 0x0640; i < 0x0680; i += 4) |
222 | nv_wo32(dev, ctx, i/4, 0x00030303); | 222 | nv_wo32(ctx, i, 0x00030303); |
223 | for (i = 0x06c0; i < 0x0700; i += 4) | 223 | for (i = 0x06c0; i < 0x0700; i += 4) |
224 | nv_wo32(dev, ctx, i/4, 0x0008aae4); | 224 | nv_wo32(ctx, i, 0x0008aae4); |
225 | for (i = 0x0700; i < 0x0740; i += 4) | 225 | for (i = 0x0700; i < 0x0740; i += 4) |
226 | nv_wo32(dev, ctx, i/4, 0x01012000); | 226 | nv_wo32(ctx, i, 0x01012000); |
227 | for (i = 0x0740; i < 0x0780; i += 4) | 227 | for (i = 0x0740; i < 0x0780; i += 4) |
228 | nv_wo32(dev, ctx, i/4, 0x00080008); | 228 | nv_wo32(ctx, i, 0x00080008); |
229 | nv_wo32(dev, ctx, 0x085c/4, 0x00040000); | 229 | nv_wo32(ctx, 0x085c, 0x00040000); |
230 | nv_wo32(dev, ctx, 0x0860/4, 0x00010000); | 230 | nv_wo32(ctx, 0x0860, 0x00010000); |
231 | for (i = 0x0864; i < 0x0874; i += 4) | 231 | for (i = 0x0864; i < 0x0874; i += 4) |
232 | nv_wo32(dev, ctx, i/4, 0x00040004); | 232 | nv_wo32(ctx, i, 0x00040004); |
233 | for (i = 0x1f18; i <= 0x3088 ; i += 16) { | 233 | for (i = 0x1f18; i <= 0x3088 ; i += 16) { |
234 | nv_wo32(dev, ctx, i/4 + 0, 0x10700ff9); | 234 | nv_wo32(ctx, i + 0, 0x10700ff9); |
235 | nv_wo32(dev, ctx, i/4 + 1, 0x0436086c); | 235 | nv_wo32(ctx, i + 1, 0x0436086c); |
236 | nv_wo32(dev, ctx, i/4 + 2, 0x000c001b); | 236 | nv_wo32(ctx, i + 2, 0x000c001b); |
237 | } | 237 | } |
238 | for (i = 0x30b8; i < 0x30c8; i += 4) | 238 | for (i = 0x30b8; i < 0x30c8; i += 4) |
239 | nv_wo32(dev, ctx, i/4, 0x0000ffff); | 239 | nv_wo32(ctx, i, 0x0000ffff); |
240 | nv_wo32(dev, ctx, 0x344c/4, 0x3f800000); | 240 | nv_wo32(ctx, 0x344c, 0x3f800000); |
241 | nv_wo32(dev, ctx, 0x3808/4, 0x3f800000); | 241 | nv_wo32(ctx, 0x3808, 0x3f800000); |
242 | nv_wo32(dev, ctx, 0x381c/4, 0x3f800000); | 242 | nv_wo32(ctx, 0x381c, 0x3f800000); |
243 | nv_wo32(dev, ctx, 0x3848/4, 0x40000000); | 243 | nv_wo32(ctx, 0x3848, 0x40000000); |
244 | nv_wo32(dev, ctx, 0x384c/4, 0x3f800000); | 244 | nv_wo32(ctx, 0x384c, 0x3f800000); |
245 | nv_wo32(dev, ctx, 0x3850/4, 0x3f000000); | 245 | nv_wo32(ctx, 0x3850, 0x3f000000); |
246 | nv_wo32(dev, ctx, 0x3858/4, 0x40000000); | 246 | nv_wo32(ctx, 0x3858, 0x40000000); |
247 | nv_wo32(dev, ctx, 0x385c/4, 0x3f800000); | 247 | nv_wo32(ctx, 0x385c, 0x3f800000); |
248 | nv_wo32(dev, ctx, 0x3864/4, 0xbf800000); | 248 | nv_wo32(ctx, 0x3864, 0xbf800000); |
249 | nv_wo32(dev, ctx, 0x386c/4, 0xbf800000); | 249 | nv_wo32(ctx, 0x386c, 0xbf800000); |
250 | } | 250 | } |
251 | 251 | ||
252 | static void | 252 | static void |
@@ -254,57 +254,57 @@ nv34_graph_context_init(struct drm_device *dev, struct nouveau_gpuobj *ctx) | |||
254 | { | 254 | { |
255 | int i; | 255 | int i; |
256 | 256 | ||
257 | nv_wo32(dev, ctx, 0x040c/4, 0x01000101); | 257 | nv_wo32(ctx, 0x040c, 0x01000101); |
258 | nv_wo32(dev, ctx, 0x0420/4, 0x00000111); | 258 | nv_wo32(ctx, 0x0420, 0x00000111); |
259 | nv_wo32(dev, ctx, 0x0424/4, 0x00000060); | 259 | nv_wo32(ctx, 0x0424, 0x00000060); |
260 | nv_wo32(dev, ctx, 0x0440/4, 0x00000080); | 260 | nv_wo32(ctx, 0x0440, 0x00000080); |
261 | nv_wo32(dev, ctx, 0x0444/4, 0xffff0000); | 261 | nv_wo32(ctx, 0x0444, 0xffff0000); |
262 | nv_wo32(dev, ctx, 0x0448/4, 0x00000001); | 262 | nv_wo32(ctx, 0x0448, 0x00000001); |
263 | nv_wo32(dev, ctx, 0x045c/4, 0x44400000); | 263 | nv_wo32(ctx, 0x045c, 0x44400000); |
264 | nv_wo32(dev, ctx, 0x0480/4, 0xffff0000); | 264 | nv_wo32(ctx, 0x0480, 0xffff0000); |
265 | for (i = 0x04d4; i < 0x04dc; i += 4) | 265 | for (i = 0x04d4; i < 0x04dc; i += 4) |
266 | nv_wo32(dev, ctx, i/4, 0x0fff0000); | 266 | nv_wo32(ctx, i, 0x0fff0000); |
267 | nv_wo32(dev, ctx, 0x04e0/4, 0x00011100); | 267 | nv_wo32(ctx, 0x04e0, 0x00011100); |
268 | for (i = 0x04fc; i < 0x053c; i += 4) | 268 | for (i = 0x04fc; i < 0x053c; i += 4) |
269 | nv_wo32(dev, ctx, i/4, 0x07ff0000); | 269 | nv_wo32(ctx, i, 0x07ff0000); |
270 | nv_wo32(dev, ctx, 0x0544/4, 0x4b7fffff); | 270 | nv_wo32(ctx, 0x0544, 0x4b7fffff); |
271 | nv_wo32(dev, ctx, 0x057c/4, 0x00000080); | 271 | nv_wo32(ctx, 0x057c, 0x00000080); |
272 | nv_wo32(dev, ctx, 0x0580/4, 0x30201000); | 272 | nv_wo32(ctx, 0x0580, 0x30201000); |
273 | nv_wo32(dev, ctx, 0x0584/4, 0x70605040); | 273 | nv_wo32(ctx, 0x0584, 0x70605040); |
274 | nv_wo32(dev, ctx, 0x0588/4, 0xb8a89888); | 274 | nv_wo32(ctx, 0x0588, 0xb8a89888); |
275 | nv_wo32(dev, ctx, 0x058c/4, 0xf8e8d8c8); | 275 | nv_wo32(ctx, 0x058c, 0xf8e8d8c8); |
276 | nv_wo32(dev, ctx, 0x05a0/4, 0xb0000000); | 276 | nv_wo32(ctx, 0x05a0, 0xb0000000); |
277 | for (i = 0x05f0; i < 0x0630; i += 4) | 277 | for (i = 0x05f0; i < 0x0630; i += 4) |
278 | nv_wo32(dev, ctx, i/4, 0x00010588); | 278 | nv_wo32(ctx, i, 0x00010588); |
279 | for (i = 0x0630; i < 0x0670; i += 4) | 279 | for (i = 0x0630; i < 0x0670; i += 4) |
280 | nv_wo32(dev, ctx, i/4, 0x00030303); | 280 | nv_wo32(ctx, i, 0x00030303); |
281 | for (i = 0x06b0; i < 0x06f0; i += 4) | 281 | for (i = 0x06b0; i < 0x06f0; i += 4) |
282 | nv_wo32(dev, ctx, i/4, 0x0008aae4); | 282 | nv_wo32(ctx, i, 0x0008aae4); |
283 | for (i = 0x06f0; i < 0x0730; i += 4) | 283 | for (i = 0x06f0; i < 0x0730; i += 4) |
284 | nv_wo32(dev, ctx, i/4, 0x01012000); | 284 | nv_wo32(ctx, i, 0x01012000); |
285 | for (i = 0x0730; i < 0x0770; i += 4) | 285 | for (i = 0x0730; i < 0x0770; i += 4) |
286 | nv_wo32(dev, ctx, i/4, 0x00080008); | 286 | nv_wo32(ctx, i, 0x00080008); |
287 | nv_wo32(dev, ctx, 0x0850/4, 0x00040000); | 287 | nv_wo32(ctx, 0x0850, 0x00040000); |
288 | nv_wo32(dev, ctx, 0x0854/4, 0x00010000); | 288 | nv_wo32(ctx, 0x0854, 0x00010000); |
289 | for (i = 0x0858; i < 0x0868; i += 4) | 289 | for (i = 0x0858; i < 0x0868; i += 4) |
290 | nv_wo32(dev, ctx, i/4, 0x00040004); | 290 | nv_wo32(ctx, i, 0x00040004); |
291 | for (i = 0x15ac; i <= 0x271c ; i += 16) { | 291 | for (i = 0x15ac; i <= 0x271c ; i += 16) { |
292 | nv_wo32(dev, ctx, i/4 + 0, 0x10700ff9); | 292 | nv_wo32(ctx, i + 0, 0x10700ff9); |
293 | nv_wo32(dev, ctx, i/4 + 1, 0x0436086c); | 293 | nv_wo32(ctx, i + 1, 0x0436086c); |
294 | nv_wo32(dev, ctx, i/4 + 2, 0x000c001b); | 294 | nv_wo32(ctx, i + 2, 0x000c001b); |
295 | } | 295 | } |
296 | for (i = 0x274c; i < 0x275c; i += 4) | 296 | for (i = 0x274c; i < 0x275c; i += 4) |
297 | nv_wo32(dev, ctx, i/4, 0x0000ffff); | 297 | nv_wo32(ctx, i, 0x0000ffff); |
298 | nv_wo32(dev, ctx, 0x2ae0/4, 0x3f800000); | 298 | nv_wo32(ctx, 0x2ae0, 0x3f800000); |
299 | nv_wo32(dev, ctx, 0x2e9c/4, 0x3f800000); | 299 | nv_wo32(ctx, 0x2e9c, 0x3f800000); |
300 | nv_wo32(dev, ctx, 0x2eb0/4, 0x3f800000); | 300 | nv_wo32(ctx, 0x2eb0, 0x3f800000); |
301 | nv_wo32(dev, ctx, 0x2edc/4, 0x40000000); | 301 | nv_wo32(ctx, 0x2edc, 0x40000000); |
302 | nv_wo32(dev, ctx, 0x2ee0/4, 0x3f800000); | 302 | nv_wo32(ctx, 0x2ee0, 0x3f800000); |
303 | nv_wo32(dev, ctx, 0x2ee4/4, 0x3f000000); | 303 | nv_wo32(ctx, 0x2ee4, 0x3f000000); |
304 | nv_wo32(dev, ctx, 0x2eec/4, 0x40000000); | 304 | nv_wo32(ctx, 0x2eec, 0x40000000); |
305 | nv_wo32(dev, ctx, 0x2ef0/4, 0x3f800000); | 305 | nv_wo32(ctx, 0x2ef0, 0x3f800000); |
306 | nv_wo32(dev, ctx, 0x2ef8/4, 0xbf800000); | 306 | nv_wo32(ctx, 0x2ef8, 0xbf800000); |
307 | nv_wo32(dev, ctx, 0x2f00/4, 0xbf800000); | 307 | nv_wo32(ctx, 0x2f00, 0xbf800000); |
308 | } | 308 | } |
309 | 309 | ||
310 | static void | 310 | static void |
@@ -312,57 +312,57 @@ nv35_36_graph_context_init(struct drm_device *dev, struct nouveau_gpuobj *ctx) | |||
312 | { | 312 | { |
313 | int i; | 313 | int i; |
314 | 314 | ||
315 | nv_wo32(dev, ctx, 0x040c/4, 0x00000101); | 315 | nv_wo32(ctx, 0x040c, 0x00000101); |
316 | nv_wo32(dev, ctx, 0x0420/4, 0x00000111); | 316 | nv_wo32(ctx, 0x0420, 0x00000111); |
317 | nv_wo32(dev, ctx, 0x0424/4, 0x00000060); | 317 | nv_wo32(ctx, 0x0424, 0x00000060); |
318 | nv_wo32(dev, ctx, 0x0440/4, 0x00000080); | 318 | nv_wo32(ctx, 0x0440, 0x00000080); |
319 | nv_wo32(dev, ctx, 0x0444/4, 0xffff0000); | 319 | nv_wo32(ctx, 0x0444, 0xffff0000); |
320 | nv_wo32(dev, ctx, 0x0448/4, 0x00000001); | 320 | nv_wo32(ctx, 0x0448, 0x00000001); |
321 | nv_wo32(dev, ctx, 0x045c/4, 0x44400000); | 321 | nv_wo32(ctx, 0x045c, 0x44400000); |
322 | nv_wo32(dev, ctx, 0x0488/4, 0xffff0000); | 322 | nv_wo32(ctx, 0x0488, 0xffff0000); |
323 | for (i = 0x04dc; i < 0x04e4; i += 4) | 323 | for (i = 0x04dc; i < 0x04e4; i += 4) |
324 | nv_wo32(dev, ctx, i/4, 0x0fff0000); | 324 | nv_wo32(ctx, i, 0x0fff0000); |
325 | nv_wo32(dev, ctx, 0x04e8/4, 0x00011100); | 325 | nv_wo32(ctx, 0x04e8, 0x00011100); |
326 | for (i = 0x0504; i < 0x0544; i += 4) | 326 | for (i = 0x0504; i < 0x0544; i += 4) |
327 | nv_wo32(dev, ctx, i/4, 0x07ff0000); | 327 | nv_wo32(ctx, i, 0x07ff0000); |
328 | nv_wo32(dev, ctx, 0x054c/4, 0x4b7fffff); | 328 | nv_wo32(ctx, 0x054c, 0x4b7fffff); |
329 | nv_wo32(dev, ctx, 0x0588/4, 0x00000080); | 329 | nv_wo32(ctx, 0x0588, 0x00000080); |
330 | nv_wo32(dev, ctx, 0x058c/4, 0x30201000); | 330 | nv_wo32(ctx, 0x058c, 0x30201000); |
331 | nv_wo32(dev, ctx, 0x0590/4, 0x70605040); | 331 | nv_wo32(ctx, 0x0590, 0x70605040); |
332 | nv_wo32(dev, ctx, 0x0594/4, 0xb8a89888); | 332 | nv_wo32(ctx, 0x0594, 0xb8a89888); |
333 | nv_wo32(dev, ctx, 0x0598/4, 0xf8e8d8c8); | 333 | nv_wo32(ctx, 0x0598, 0xf8e8d8c8); |
334 | nv_wo32(dev, ctx, 0x05ac/4, 0xb0000000); | 334 | nv_wo32(ctx, 0x05ac, 0xb0000000); |
335 | for (i = 0x0604; i < 0x0644; i += 4) | 335 | for (i = 0x0604; i < 0x0644; i += 4) |
336 | nv_wo32(dev, ctx, i/4, 0x00010588); | 336 | nv_wo32(ctx, i, 0x00010588); |
337 | for (i = 0x0644; i < 0x0684; i += 4) | 337 | for (i = 0x0644; i < 0x0684; i += 4) |
338 | nv_wo32(dev, ctx, i/4, 0x00030303); | 338 | nv_wo32(ctx, i, 0x00030303); |
339 | for (i = 0x06c4; i < 0x0704; i += 4) | 339 | for (i = 0x06c4; i < 0x0704; i += 4) |
340 | nv_wo32(dev, ctx, i/4, 0x0008aae4); | 340 | nv_wo32(ctx, i, 0x0008aae4); |
341 | for (i = 0x0704; i < 0x0744; i += 4) | 341 | for (i = 0x0704; i < 0x0744; i += 4) |
342 | nv_wo32(dev, ctx, i/4, 0x01012000); | 342 | nv_wo32(ctx, i, 0x01012000); |
343 | for (i = 0x0744; i < 0x0784; i += 4) | 343 | for (i = 0x0744; i < 0x0784; i += 4) |
344 | nv_wo32(dev, ctx, i/4, 0x00080008); | 344 | nv_wo32(ctx, i, 0x00080008); |
345 | nv_wo32(dev, ctx, 0x0860/4, 0x00040000); | 345 | nv_wo32(ctx, 0x0860, 0x00040000); |
346 | nv_wo32(dev, ctx, 0x0864/4, 0x00010000); | 346 | nv_wo32(ctx, 0x0864, 0x00010000); |
347 | for (i = 0x0868; i < 0x0878; i += 4) | 347 | for (i = 0x0868; i < 0x0878; i += 4) |
348 | nv_wo32(dev, ctx, i/4, 0x00040004); | 348 | nv_wo32(ctx, i, 0x00040004); |
349 | for (i = 0x1f1c; i <= 0x308c ; i += 16) { | 349 | for (i = 0x1f1c; i <= 0x308c ; i += 16) { |
350 | nv_wo32(dev, ctx, i/4 + 0, 0x10700ff9); | 350 | nv_wo32(ctx, i + 0, 0x10700ff9); |
351 | nv_wo32(dev, ctx, i/4 + 1, 0x0436086c); | 351 | nv_wo32(ctx, i + 4, 0x0436086c); |
352 | nv_wo32(dev, ctx, i/4 + 2, 0x000c001b); | 352 | nv_wo32(ctx, i + 8, 0x000c001b); |
353 | } | 353 | } |
354 | for (i = 0x30bc; i < 0x30cc; i += 4) | 354 | for (i = 0x30bc; i < 0x30cc; i += 4) |
355 | nv_wo32(dev, ctx, i/4, 0x0000ffff); | 355 | nv_wo32(ctx, i, 0x0000ffff); |
356 | nv_wo32(dev, ctx, 0x3450/4, 0x3f800000); | 356 | nv_wo32(ctx, 0x3450, 0x3f800000); |
357 | nv_wo32(dev, ctx, 0x380c/4, 0x3f800000); | 357 | nv_wo32(ctx, 0x380c, 0x3f800000); |
358 | nv_wo32(dev, ctx, 0x3820/4, 0x3f800000); | 358 | nv_wo32(ctx, 0x3820, 0x3f800000); |
359 | nv_wo32(dev, ctx, 0x384c/4, 0x40000000); | 359 | nv_wo32(ctx, 0x384c, 0x40000000); |
360 | nv_wo32(dev, ctx, 0x3850/4, 0x3f800000); | 360 | nv_wo32(ctx, 0x3850, 0x3f800000); |
361 | nv_wo32(dev, ctx, 0x3854/4, 0x3f000000); | 361 | nv_wo32(ctx, 0x3854, 0x3f000000); |
362 | nv_wo32(dev, ctx, 0x385c/4, 0x40000000); | 362 | nv_wo32(ctx, 0x385c, 0x40000000); |
363 | nv_wo32(dev, ctx, 0x3860/4, 0x3f800000); | 363 | nv_wo32(ctx, 0x3860, 0x3f800000); |
364 | nv_wo32(dev, ctx, 0x3868/4, 0xbf800000); | 364 | nv_wo32(ctx, 0x3868, 0xbf800000); |
365 | nv_wo32(dev, ctx, 0x3870/4, 0xbf800000); | 365 | nv_wo32(ctx, 0x3870, 0xbf800000); |
366 | } | 366 | } |
367 | 367 | ||
368 | int | 368 | int |
@@ -372,7 +372,7 @@ nv20_graph_create_context(struct nouveau_channel *chan) | |||
372 | struct drm_nouveau_private *dev_priv = dev->dev_private; | 372 | struct drm_nouveau_private *dev_priv = dev->dev_private; |
373 | struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; | 373 | struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; |
374 | void (*ctx_init)(struct drm_device *, struct nouveau_gpuobj *); | 374 | void (*ctx_init)(struct drm_device *, struct nouveau_gpuobj *); |
375 | unsigned int idoffs = 0x28/4; | 375 | unsigned int idoffs = 0x28; |
376 | int ret; | 376 | int ret; |
377 | 377 | ||
378 | switch (dev_priv->chipset) { | 378 | switch (dev_priv->chipset) { |
@@ -403,21 +403,19 @@ nv20_graph_create_context(struct nouveau_channel *chan) | |||
403 | BUG_ON(1); | 403 | BUG_ON(1); |
404 | } | 404 | } |
405 | 405 | ||
406 | ret = nouveau_gpuobj_new_ref(dev, chan, NULL, 0, pgraph->grctx_size, | 406 | ret = nouveau_gpuobj_new(dev, chan, pgraph->grctx_size, 16, |
407 | 16, NVOBJ_FLAG_ZERO_ALLOC, | 407 | NVOBJ_FLAG_ZERO_ALLOC, &chan->ramin_grctx); |
408 | &chan->ramin_grctx); | ||
409 | if (ret) | 408 | if (ret) |
410 | return ret; | 409 | return ret; |
411 | 410 | ||
412 | /* Initialise default context values */ | 411 | /* Initialise default context values */ |
413 | ctx_init(dev, chan->ramin_grctx->gpuobj); | 412 | ctx_init(dev, chan->ramin_grctx); |
414 | 413 | ||
415 | /* nv20: nv_wo32(dev, chan->ramin_grctx->gpuobj, 10, chan->id<<24); */ | 414 | /* nv20: nv_wo32(dev, chan->ramin_grctx->gpuobj, 10, chan->id<<24); */ |
416 | nv_wo32(dev, chan->ramin_grctx->gpuobj, idoffs, | 415 | nv_wo32(chan->ramin_grctx, idoffs, |
417 | (chan->id << 24) | 0x1); /* CTX_USER */ | 416 | (chan->id << 24) | 0x1); /* CTX_USER */ |
418 | 417 | ||
419 | nv_wo32(dev, pgraph->ctx_table->gpuobj, chan->id, | 418 | nv_wo32(pgraph->ctx_table, chan->id * 4, chan->ramin_grctx->pinst >> 4); |
420 | chan->ramin_grctx->instance >> 4); | ||
421 | return 0; | 419 | return 0; |
422 | } | 420 | } |
423 | 421 | ||
@@ -428,10 +426,8 @@ nv20_graph_destroy_context(struct nouveau_channel *chan) | |||
428 | struct drm_nouveau_private *dev_priv = dev->dev_private; | 426 | struct drm_nouveau_private *dev_priv = dev->dev_private; |
429 | struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; | 427 | struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; |
430 | 428 | ||
431 | if (chan->ramin_grctx) | 429 | nouveau_gpuobj_ref(NULL, &chan->ramin_grctx); |
432 | nouveau_gpuobj_ref_del(dev, &chan->ramin_grctx); | 430 | nv_wo32(pgraph->ctx_table, chan->id * 4, 0); |
433 | |||
434 | nv_wo32(dev, pgraph->ctx_table->gpuobj, chan->id, 0); | ||
435 | } | 431 | } |
436 | 432 | ||
437 | int | 433 | int |
@@ -442,7 +438,7 @@ nv20_graph_load_context(struct nouveau_channel *chan) | |||
442 | 438 | ||
443 | if (!chan->ramin_grctx) | 439 | if (!chan->ramin_grctx) |
444 | return -EINVAL; | 440 | return -EINVAL; |
445 | inst = chan->ramin_grctx->instance >> 4; | 441 | inst = chan->ramin_grctx->pinst >> 4; |
446 | 442 | ||
447 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_POINTER, inst); | 443 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_POINTER, inst); |
448 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_XFER, | 444 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_XFER, |
@@ -465,7 +461,7 @@ nv20_graph_unload_context(struct drm_device *dev) | |||
465 | chan = pgraph->channel(dev); | 461 | chan = pgraph->channel(dev); |
466 | if (!chan) | 462 | if (!chan) |
467 | return 0; | 463 | return 0; |
468 | inst = chan->ramin_grctx->instance >> 4; | 464 | inst = chan->ramin_grctx->pinst >> 4; |
469 | 465 | ||
470 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_POINTER, inst); | 466 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_POINTER, inst); |
471 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_XFER, | 467 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_XFER, |
@@ -552,15 +548,15 @@ nv20_graph_init(struct drm_device *dev) | |||
552 | 548 | ||
553 | if (!pgraph->ctx_table) { | 549 | if (!pgraph->ctx_table) { |
554 | /* Create Context Pointer Table */ | 550 | /* Create Context Pointer Table */ |
555 | ret = nouveau_gpuobj_new_ref(dev, NULL, NULL, 0, 32 * 4, 16, | 551 | ret = nouveau_gpuobj_new(dev, NULL, 32 * 4, 16, |
556 | NVOBJ_FLAG_ZERO_ALLOC, | 552 | NVOBJ_FLAG_ZERO_ALLOC, |
557 | &pgraph->ctx_table); | 553 | &pgraph->ctx_table); |
558 | if (ret) | 554 | if (ret) |
559 | return ret; | 555 | return ret; |
560 | } | 556 | } |
561 | 557 | ||
562 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_TABLE, | 558 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_TABLE, |
563 | pgraph->ctx_table->instance >> 4); | 559 | pgraph->ctx_table->pinst >> 4); |
564 | 560 | ||
565 | nv20_graph_rdi(dev); | 561 | nv20_graph_rdi(dev); |
566 | 562 | ||
@@ -646,7 +642,7 @@ nv20_graph_takedown(struct drm_device *dev) | |||
646 | struct drm_nouveau_private *dev_priv = dev->dev_private; | 642 | struct drm_nouveau_private *dev_priv = dev->dev_private; |
647 | struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; | 643 | struct nouveau_pgraph_engine *pgraph = &dev_priv->engine.graph; |
648 | 644 | ||
649 | nouveau_gpuobj_ref_del(dev, &pgraph->ctx_table); | 645 | nouveau_gpuobj_ref(NULL, &pgraph->ctx_table); |
650 | } | 646 | } |
651 | 647 | ||
652 | int | 648 | int |
@@ -681,15 +677,15 @@ nv30_graph_init(struct drm_device *dev) | |||
681 | 677 | ||
682 | if (!pgraph->ctx_table) { | 678 | if (!pgraph->ctx_table) { |
683 | /* Create Context Pointer Table */ | 679 | /* Create Context Pointer Table */ |
684 | ret = nouveau_gpuobj_new_ref(dev, NULL, NULL, 0, 32 * 4, 16, | 680 | ret = nouveau_gpuobj_new(dev, NULL, 32 * 4, 16, |
685 | NVOBJ_FLAG_ZERO_ALLOC, | 681 | NVOBJ_FLAG_ZERO_ALLOC, |
686 | &pgraph->ctx_table); | 682 | &pgraph->ctx_table); |
687 | if (ret) | 683 | if (ret) |
688 | return ret; | 684 | return ret; |
689 | } | 685 | } |
690 | 686 | ||
691 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_TABLE, | 687 | nv_wr32(dev, NV20_PGRAPH_CHANNEL_CTX_TABLE, |
692 | pgraph->ctx_table->instance >> 4); | 688 | pgraph->ctx_table->pinst >> 4); |
693 | 689 | ||
694 | nv_wr32(dev, NV03_PGRAPH_INTR , 0xFFFFFFFF); | 690 | nv_wr32(dev, NV03_PGRAPH_INTR , 0xFFFFFFFF); |
695 | nv_wr32(dev, NV03_PGRAPH_INTR_EN, 0xFFFFFFFF); | 691 | nv_wr32(dev, NV03_PGRAPH_INTR_EN, 0xFFFFFFFF); |