1 /*
2 * Copyright 2010 Red Hat Inc.
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * on the rights to use, copy, modify, merge, publish, distribute, sub
8 * license, and/or sell copies of the Software, and to permit persons to whom
9 * the Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
13 * Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
19 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
20 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
21 * USE OR OTHER DEALINGS IN THE SOFTWARE.
22 */
23 #include <stdio.h>
24 #include <errno.h>
25 #include "pipe/p_defines.h"
26 #include "pipe/p_state.h"
27 #include "pipe/p_context.h"
28 #include "pipe/p_screen.h"
29 #include "util/u_memory.h"
30 #include "util/u_inlines.h"
31 #include "util/u_transfer.h"
32
noop_draw_vbo(struct pipe_context * ctx,const struct pipe_draw_info * info,unsigned drawid_offset,const struct pipe_draw_indirect_info * indirect,const struct pipe_draw_start_count_bias * draws,unsigned num_draws)33 static void noop_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info *info,
34 unsigned drawid_offset,
35 const struct pipe_draw_indirect_info *indirect,
36 const struct pipe_draw_start_count_bias *draws,
37 unsigned num_draws)
38 {
39 }
40
noop_draw_vertex_state(struct pipe_context * ctx,struct pipe_vertex_state * state,uint32_t partial_velem_mask,struct pipe_draw_vertex_state_info info,const struct pipe_draw_start_count_bias * draws,unsigned num_draws)41 static void noop_draw_vertex_state(struct pipe_context *ctx,
42 struct pipe_vertex_state *state,
43 uint32_t partial_velem_mask,
44 struct pipe_draw_vertex_state_info info,
45 const struct pipe_draw_start_count_bias *draws,
46 unsigned num_draws)
47 {
48 }
49
noop_launch_grid(struct pipe_context * ctx,const struct pipe_grid_info * info)50 static void noop_launch_grid(struct pipe_context *ctx,
51 const struct pipe_grid_info *info)
52 {
53 }
54
noop_set_blend_color(struct pipe_context * ctx,const struct pipe_blend_color * state)55 static void noop_set_blend_color(struct pipe_context *ctx,
56 const struct pipe_blend_color *state)
57 {
58 }
59
noop_create_blend_state(struct pipe_context * ctx,const struct pipe_blend_state * state)60 static void *noop_create_blend_state(struct pipe_context *ctx,
61 const struct pipe_blend_state *state)
62 {
63 return MALLOC(1);
64 }
65
noop_create_dsa_state(struct pipe_context * ctx,const struct pipe_depth_stencil_alpha_state * state)66 static void *noop_create_dsa_state(struct pipe_context *ctx,
67 const struct pipe_depth_stencil_alpha_state *state)
68 {
69 return MALLOC(1);
70 }
71
noop_create_rs_state(struct pipe_context * ctx,const struct pipe_rasterizer_state * state)72 static void *noop_create_rs_state(struct pipe_context *ctx,
73 const struct pipe_rasterizer_state *state)
74 {
75 return MALLOC(1);
76 }
77
noop_create_sampler_state(struct pipe_context * ctx,const struct pipe_sampler_state * state)78 static void *noop_create_sampler_state(struct pipe_context *ctx,
79 const struct pipe_sampler_state *state)
80 {
81 return MALLOC(1);
82 }
83
noop_create_sampler_view(struct pipe_context * ctx,struct pipe_resource * texture,const struct pipe_sampler_view * state)84 static struct pipe_sampler_view *noop_create_sampler_view(struct pipe_context *ctx,
85 struct pipe_resource *texture,
86 const struct pipe_sampler_view *state)
87 {
88 struct pipe_sampler_view *sampler_view = CALLOC_STRUCT(pipe_sampler_view);
89
90 if (!sampler_view)
91 return NULL;
92
93 /* initialize base object */
94 *sampler_view = *state;
95 sampler_view->texture = NULL;
96 pipe_resource_reference(&sampler_view->texture, texture);
97 pipe_reference_init(&sampler_view->reference, 1);
98 sampler_view->context = ctx;
99 return sampler_view;
100 }
101
noop_create_surface(struct pipe_context * ctx,struct pipe_resource * texture,const struct pipe_surface * surf_tmpl)102 static struct pipe_surface *noop_create_surface(struct pipe_context *ctx,
103 struct pipe_resource *texture,
104 const struct pipe_surface *surf_tmpl)
105 {
106 struct pipe_surface *surface = CALLOC_STRUCT(pipe_surface);
107
108 if (!surface)
109 return NULL;
110 pipe_reference_init(&surface->reference, 1);
111 pipe_resource_reference(&surface->texture, texture);
112 surface->context = ctx;
113 surface->format = surf_tmpl->format;
114 surface->width = texture->width0;
115 surface->height = texture->height0;
116 surface->texture = texture;
117 surface->u.tex.first_layer = surf_tmpl->u.tex.first_layer;
118 surface->u.tex.last_layer = surf_tmpl->u.tex.last_layer;
119 surface->u.tex.level = surf_tmpl->u.tex.level;
120
121 return surface;
122 }
123
noop_set_sampler_views(struct pipe_context * ctx,enum pipe_shader_type shader,unsigned start,unsigned count,unsigned unbind_num_trailing_slots,bool take_ownership,struct pipe_sampler_view ** views)124 static void noop_set_sampler_views(struct pipe_context *ctx,
125 enum pipe_shader_type shader,
126 unsigned start, unsigned count,
127 unsigned unbind_num_trailing_slots,
128 bool take_ownership,
129 struct pipe_sampler_view **views)
130 {
131 if (take_ownership && views) {
132 for (unsigned i = 0; i < count; i++) {
133 struct pipe_sampler_view *view = views[i];
134 pipe_sampler_view_reference(&view, NULL);
135 }
136 }
137 }
138
noop_bind_sampler_states(struct pipe_context * ctx,enum pipe_shader_type shader,unsigned start,unsigned count,void ** states)139 static void noop_bind_sampler_states(struct pipe_context *ctx,
140 enum pipe_shader_type shader,
141 unsigned start, unsigned count,
142 void **states)
143 {
144 }
145
noop_set_clip_state(struct pipe_context * ctx,const struct pipe_clip_state * state)146 static void noop_set_clip_state(struct pipe_context *ctx,
147 const struct pipe_clip_state *state)
148 {
149 }
150
noop_set_polygon_stipple(struct pipe_context * ctx,const struct pipe_poly_stipple * state)151 static void noop_set_polygon_stipple(struct pipe_context *ctx,
152 const struct pipe_poly_stipple *state)
153 {
154 }
155
noop_set_sample_mask(struct pipe_context * pipe,unsigned sample_mask)156 static void noop_set_sample_mask(struct pipe_context *pipe, unsigned sample_mask)
157 {
158 }
159
noop_set_scissor_states(struct pipe_context * ctx,unsigned start_slot,unsigned num_scissors,const struct pipe_scissor_state * state)160 static void noop_set_scissor_states(struct pipe_context *ctx,
161 unsigned start_slot,
162 unsigned num_scissors,
163 const struct pipe_scissor_state *state)
164 {
165 }
166
noop_set_stencil_ref(struct pipe_context * ctx,const struct pipe_stencil_ref state)167 static void noop_set_stencil_ref(struct pipe_context *ctx,
168 const struct pipe_stencil_ref state)
169 {
170 }
171
noop_set_viewport_states(struct pipe_context * ctx,unsigned start_slot,unsigned num_viewports,const struct pipe_viewport_state * state)172 static void noop_set_viewport_states(struct pipe_context *ctx,
173 unsigned start_slot,
174 unsigned num_viewports,
175 const struct pipe_viewport_state *state)
176 {
177 }
178
noop_set_framebuffer_state(struct pipe_context * ctx,const struct pipe_framebuffer_state * state)179 static void noop_set_framebuffer_state(struct pipe_context *ctx,
180 const struct pipe_framebuffer_state *state)
181 {
182 }
183
noop_set_constant_buffer(struct pipe_context * ctx,enum pipe_shader_type shader,uint index,bool take_ownership,const struct pipe_constant_buffer * cb)184 static void noop_set_constant_buffer(struct pipe_context *ctx,
185 enum pipe_shader_type shader, uint index,
186 bool take_ownership,
187 const struct pipe_constant_buffer *cb)
188 {
189 if (take_ownership && cb) {
190 struct pipe_resource *buf = cb->buffer;
191 pipe_resource_reference(&buf, NULL);
192 }
193 }
194
noop_set_inlinable_constants(struct pipe_context * ctx,enum pipe_shader_type shader,uint num_values,uint32_t * values)195 static void noop_set_inlinable_constants(struct pipe_context *ctx,
196 enum pipe_shader_type shader,
197 uint num_values, uint32_t *values)
198 {
199 }
200
201
noop_sampler_view_destroy(struct pipe_context * ctx,struct pipe_sampler_view * state)202 static void noop_sampler_view_destroy(struct pipe_context *ctx,
203 struct pipe_sampler_view *state)
204 {
205 pipe_resource_reference(&state->texture, NULL);
206 FREE(state);
207 }
208
209
noop_surface_destroy(struct pipe_context * ctx,struct pipe_surface * surface)210 static void noop_surface_destroy(struct pipe_context *ctx,
211 struct pipe_surface *surface)
212 {
213 pipe_resource_reference(&surface->texture, NULL);
214 FREE(surface);
215 }
216
noop_bind_state(struct pipe_context * ctx,void * state)217 static void noop_bind_state(struct pipe_context *ctx, void *state)
218 {
219 }
220
noop_delete_state(struct pipe_context * ctx,void * state)221 static void noop_delete_state(struct pipe_context *ctx, void *state)
222 {
223 FREE(state);
224 }
225
noop_set_vertex_buffers(struct pipe_context * ctx,unsigned count,const struct pipe_vertex_buffer * buffers)226 static void noop_set_vertex_buffers(struct pipe_context *ctx,
227 unsigned count,
228 const struct pipe_vertex_buffer *buffers)
229 {
230 for (unsigned i = 0; i < count; i++) {
231 if (!buffers[i].is_user_buffer) {
232 struct pipe_resource *buf = buffers[i].buffer.resource;
233 pipe_resource_reference(&buf, NULL);
234 }
235 }
236 }
237
noop_create_vertex_elements(struct pipe_context * ctx,unsigned count,const struct pipe_vertex_element * state)238 static void *noop_create_vertex_elements(struct pipe_context *ctx,
239 unsigned count,
240 const struct pipe_vertex_element *state)
241 {
242 return MALLOC(1);
243 }
244
noop_create_shader_state(struct pipe_context * ctx,const struct pipe_shader_state * state)245 static void *noop_create_shader_state(struct pipe_context *ctx,
246 const struct pipe_shader_state *state)
247 {
248 return MALLOC(1);
249 }
250
noop_create_compute_state(struct pipe_context * ctx,const struct pipe_compute_state * state)251 static void *noop_create_compute_state(struct pipe_context *ctx,
252 const struct pipe_compute_state *state)
253 {
254 return MALLOC(1);
255 }
256
noop_create_stream_output_target(struct pipe_context * ctx,struct pipe_resource * res,unsigned buffer_offset,unsigned buffer_size)257 static struct pipe_stream_output_target *noop_create_stream_output_target(
258 struct pipe_context *ctx,
259 struct pipe_resource *res,
260 unsigned buffer_offset,
261 unsigned buffer_size)
262 {
263 struct pipe_stream_output_target *t = CALLOC_STRUCT(pipe_stream_output_target);
264 if (!t)
265 return NULL;
266
267 pipe_reference_init(&t->reference, 1);
268 pipe_resource_reference(&t->buffer, res);
269 t->buffer_offset = buffer_offset;
270 t->buffer_size = buffer_size;
271 return t;
272 }
273
noop_stream_output_target_destroy(struct pipe_context * ctx,struct pipe_stream_output_target * t)274 static void noop_stream_output_target_destroy(struct pipe_context *ctx,
275 struct pipe_stream_output_target *t)
276 {
277 pipe_resource_reference(&t->buffer, NULL);
278 FREE(t);
279 }
280
noop_set_stream_output_targets(struct pipe_context * ctx,unsigned num_targets,struct pipe_stream_output_target ** targets,const unsigned * offsets)281 static void noop_set_stream_output_targets(struct pipe_context *ctx,
282 unsigned num_targets,
283 struct pipe_stream_output_target **targets,
284 const unsigned *offsets)
285 {
286 }
287
noop_set_window_rectangles(struct pipe_context * ctx,bool include,unsigned num_rectangles,const struct pipe_scissor_state * rects)288 static void noop_set_window_rectangles(struct pipe_context *ctx,
289 bool include,
290 unsigned num_rectangles,
291 const struct pipe_scissor_state *rects)
292 {
293 }
294
noop_set_shader_buffers(struct pipe_context * ctx,enum pipe_shader_type shader,unsigned start_slot,unsigned count,const struct pipe_shader_buffer * buffers,unsigned writable_bitmask)295 static void noop_set_shader_buffers(struct pipe_context *ctx,
296 enum pipe_shader_type shader,
297 unsigned start_slot, unsigned count,
298 const struct pipe_shader_buffer *buffers,
299 unsigned writable_bitmask)
300 {
301 }
302
noop_set_shader_images(struct pipe_context * ctx,enum pipe_shader_type shader,unsigned start_slot,unsigned count,unsigned unbind_num_trailing_slots,const struct pipe_image_view * images)303 static void noop_set_shader_images(struct pipe_context *ctx,
304 enum pipe_shader_type shader,
305 unsigned start_slot, unsigned count,
306 unsigned unbind_num_trailing_slots,
307 const struct pipe_image_view *images)
308 {
309 }
310
noop_render_condition(struct pipe_context * pipe,struct pipe_query * query,bool condition,enum pipe_render_cond_flag mode)311 static void noop_render_condition( struct pipe_context *pipe,
312 struct pipe_query *query,
313 bool condition,
314 enum pipe_render_cond_flag mode )
315 {
316 }
317
noop_get_query_result_resource(struct pipe_context * pipe,struct pipe_query * q,enum pipe_query_flags flags,enum pipe_query_value_type result_type,int index,struct pipe_resource * resource,unsigned offset)318 static void noop_get_query_result_resource(struct pipe_context *pipe,
319 struct pipe_query *q,
320 enum pipe_query_flags flags,
321 enum pipe_query_value_type result_type,
322 int index,
323 struct pipe_resource *resource,
324 unsigned offset)
325 {
326 }
327
noop_set_min_samples(struct pipe_context * ctx,unsigned min_samples)328 static void noop_set_min_samples( struct pipe_context *ctx,
329 unsigned min_samples )
330 {
331 }
332
noop_set_sample_locations(struct pipe_context * ctx,size_t size,const uint8_t * locations)333 static void noop_set_sample_locations( struct pipe_context *ctx,
334 size_t size, const uint8_t *locations )
335 {
336 }
337
noop_set_tess_state(struct pipe_context * ctx,const float default_outer_level[4],const float default_inner_level[2])338 static void noop_set_tess_state(struct pipe_context *ctx,
339 const float default_outer_level[4],
340 const float default_inner_level[2])
341 {
342 }
343
noop_clear_texture(struct pipe_context * pipe,struct pipe_resource * res,unsigned level,const struct pipe_box * box,const void * data)344 static void noop_clear_texture(struct pipe_context *pipe,
345 struct pipe_resource *res,
346 unsigned level,
347 const struct pipe_box *box,
348 const void *data)
349 {
350 }
351
noop_clear_buffer(struct pipe_context * pipe,struct pipe_resource * res,unsigned offset,unsigned size,const void * clear_value,int clear_value_size)352 static void noop_clear_buffer(struct pipe_context *pipe,
353 struct pipe_resource *res,
354 unsigned offset,
355 unsigned size,
356 const void *clear_value,
357 int clear_value_size)
358 {
359 }
360
noop_fence_server_sync(struct pipe_context * pipe,struct pipe_fence_handle * fence)361 static void noop_fence_server_sync(struct pipe_context *pipe,
362 struct pipe_fence_handle *fence)
363 {
364 }
365
noop_texture_barrier(struct pipe_context * ctx,unsigned flags)366 static void noop_texture_barrier(struct pipe_context *ctx, unsigned flags)
367 {
368 }
369
noop_memory_barrier(struct pipe_context * ctx,unsigned flags)370 static void noop_memory_barrier(struct pipe_context *ctx, unsigned flags)
371 {
372 }
373
noop_resource_commit(struct pipe_context * ctx,struct pipe_resource * res,unsigned level,struct pipe_box * box,bool commit)374 static bool noop_resource_commit(struct pipe_context *ctx, struct pipe_resource *res,
375 unsigned level, struct pipe_box *box, bool commit)
376 {
377 return true;
378 }
379
noop_get_sample_position(struct pipe_context * context,unsigned sample_count,unsigned sample_index,float * out_value)380 static void noop_get_sample_position(struct pipe_context *context,
381 unsigned sample_count,
382 unsigned sample_index,
383 float *out_value)
384 {
385 }
386
noop_get_device_reset_status(struct pipe_context * ctx)387 static enum pipe_reset_status noop_get_device_reset_status(struct pipe_context *ctx)
388 {
389 return PIPE_NO_RESET;
390 }
391
noop_create_texture_handle(struct pipe_context * ctx,struct pipe_sampler_view * view,const struct pipe_sampler_state * state)392 static uint64_t noop_create_texture_handle(struct pipe_context *ctx,
393 struct pipe_sampler_view *view,
394 const struct pipe_sampler_state *state)
395 {
396 return 1;
397 }
398
noop_delete_texture_handle(struct pipe_context * ctx,uint64_t handle)399 static void noop_delete_texture_handle(struct pipe_context *ctx, uint64_t handle)
400 {
401 }
402
noop_make_texture_handle_resident(struct pipe_context * ctx,uint64_t handle,bool resident)403 static void noop_make_texture_handle_resident(struct pipe_context *ctx,
404 uint64_t handle, bool resident)
405 {
406 }
407
noop_create_image_handle(struct pipe_context * ctx,const struct pipe_image_view * image)408 static uint64_t noop_create_image_handle(struct pipe_context *ctx,
409 const struct pipe_image_view *image)
410 {
411 return 2;
412 }
413
noop_delete_image_handle(struct pipe_context * ctx,uint64_t handle)414 static void noop_delete_image_handle(struct pipe_context *ctx, uint64_t handle)
415 {
416 }
417
noop_make_image_handle_resident(struct pipe_context * ctx,uint64_t handle,unsigned access,bool resident)418 static void noop_make_image_handle_resident(struct pipe_context *ctx, uint64_t handle,
419 unsigned access, bool resident)
420 {
421 }
422
noop_set_patch_vertices(struct pipe_context * ctx,uint8_t patch_vertices)423 static void noop_set_patch_vertices(struct pipe_context *ctx,
424 uint8_t patch_vertices)
425 {
426 }
427
428 void noop_init_state_functions(struct pipe_context *ctx);
429
noop_init_state_functions(struct pipe_context * ctx)430 void noop_init_state_functions(struct pipe_context *ctx)
431 {
432 ctx->create_blend_state = noop_create_blend_state;
433 ctx->create_depth_stencil_alpha_state = noop_create_dsa_state;
434 ctx->create_fs_state = noop_create_shader_state;
435 ctx->create_rasterizer_state = noop_create_rs_state;
436 ctx->create_sampler_state = noop_create_sampler_state;
437 ctx->create_sampler_view = noop_create_sampler_view;
438 ctx->create_surface = noop_create_surface;
439 ctx->create_vertex_elements_state = noop_create_vertex_elements;
440 ctx->create_compute_state = noop_create_compute_state;
441 ctx->create_tcs_state = noop_create_shader_state;
442 ctx->create_tes_state = noop_create_shader_state;
443 ctx->create_gs_state = noop_create_shader_state;
444 ctx->create_vs_state = noop_create_shader_state;
445 ctx->bind_blend_state = noop_bind_state;
446 ctx->bind_depth_stencil_alpha_state = noop_bind_state;
447 ctx->bind_sampler_states = noop_bind_sampler_states;
448 ctx->bind_fs_state = noop_bind_state;
449 ctx->bind_rasterizer_state = noop_bind_state;
450 ctx->bind_vertex_elements_state = noop_bind_state;
451 ctx->bind_compute_state = noop_bind_state;
452 ctx->bind_tcs_state = noop_bind_state;
453 ctx->bind_tes_state = noop_bind_state;
454 ctx->bind_gs_state = noop_bind_state;
455 ctx->bind_vs_state = noop_bind_state;
456 ctx->delete_blend_state = noop_delete_state;
457 ctx->delete_depth_stencil_alpha_state = noop_delete_state;
458 ctx->delete_fs_state = noop_delete_state;
459 ctx->delete_rasterizer_state = noop_delete_state;
460 ctx->delete_sampler_state = noop_delete_state;
461 ctx->delete_vertex_elements_state = noop_delete_state;
462 ctx->delete_compute_state = noop_delete_state;
463 ctx->delete_tcs_state = noop_delete_state;
464 ctx->delete_tes_state = noop_delete_state;
465 ctx->delete_gs_state = noop_delete_state;
466 ctx->delete_vs_state = noop_delete_state;
467 ctx->set_blend_color = noop_set_blend_color;
468 ctx->set_clip_state = noop_set_clip_state;
469 ctx->set_constant_buffer = noop_set_constant_buffer;
470 ctx->set_inlinable_constants = noop_set_inlinable_constants;
471 ctx->set_sampler_views = noop_set_sampler_views;
472 ctx->set_shader_buffers = noop_set_shader_buffers;
473 ctx->set_shader_images = noop_set_shader_images;
474 ctx->set_framebuffer_state = noop_set_framebuffer_state;
475 ctx->set_polygon_stipple = noop_set_polygon_stipple;
476 ctx->set_sample_mask = noop_set_sample_mask;
477 ctx->set_scissor_states = noop_set_scissor_states;
478 ctx->set_stencil_ref = noop_set_stencil_ref;
479 ctx->set_vertex_buffers = noop_set_vertex_buffers;
480 ctx->set_viewport_states = noop_set_viewport_states;
481 ctx->set_window_rectangles = noop_set_window_rectangles;
482 ctx->sampler_view_destroy = noop_sampler_view_destroy;
483 ctx->surface_destroy = noop_surface_destroy;
484 ctx->draw_vbo = noop_draw_vbo;
485 ctx->draw_vertex_state = noop_draw_vertex_state;
486 ctx->launch_grid = noop_launch_grid;
487 ctx->create_stream_output_target = noop_create_stream_output_target;
488 ctx->stream_output_target_destroy = noop_stream_output_target_destroy;
489 ctx->set_stream_output_targets = noop_set_stream_output_targets;
490 ctx->render_condition = noop_render_condition;
491 ctx->get_query_result_resource = noop_get_query_result_resource;
492 ctx->set_min_samples = noop_set_min_samples;
493 ctx->set_sample_locations = noop_set_sample_locations;
494 ctx->set_tess_state = noop_set_tess_state;
495 ctx->clear_texture = noop_clear_texture;
496 ctx->clear_buffer = noop_clear_buffer;
497 ctx->fence_server_sync = noop_fence_server_sync;
498 ctx->texture_barrier = noop_texture_barrier;
499 ctx->memory_barrier = noop_memory_barrier;
500 ctx->resource_commit = noop_resource_commit;
501 ctx->get_sample_position = noop_get_sample_position;
502 ctx->get_device_reset_status = noop_get_device_reset_status;
503 ctx->create_texture_handle = noop_create_texture_handle;
504 ctx->delete_texture_handle = noop_delete_texture_handle;
505 ctx->make_texture_handle_resident = noop_make_texture_handle_resident;
506 ctx->create_image_handle = noop_create_image_handle;
507 ctx->delete_image_handle = noop_delete_image_handle;
508 ctx->make_image_handle_resident = noop_make_image_handle_resident;
509 ctx->set_patch_vertices = noop_set_patch_vertices;
510 }
511