Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mesa
Path: blob/21.2-virgl/src/gallium/auxiliary/driver_noop/noop_pipe.c
4565 views
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/format/u_format.h"
32
#include "util/u_upload_mgr.h"
33
#include "noop_public.h"
34
35
DEBUG_GET_ONCE_BOOL_OPTION(noop, "GALLIUM_NOOP", false)
36
37
void noop_init_state_functions(struct pipe_context *ctx);
38
39
struct noop_pipe_screen {
40
struct pipe_screen pscreen;
41
struct pipe_screen *oscreen;
42
};
43
44
/*
45
* query
46
*/
47
struct noop_query {
48
unsigned query;
49
};
50
static struct pipe_query *noop_create_query(struct pipe_context *ctx, unsigned query_type, unsigned index)
51
{
52
struct noop_query *query = CALLOC_STRUCT(noop_query);
53
54
return (struct pipe_query *)query;
55
}
56
57
static void noop_destroy_query(struct pipe_context *ctx, struct pipe_query *query)
58
{
59
FREE(query);
60
}
61
62
static bool noop_begin_query(struct pipe_context *ctx, struct pipe_query *query)
63
{
64
return true;
65
}
66
67
static bool noop_end_query(struct pipe_context *ctx, struct pipe_query *query)
68
{
69
return true;
70
}
71
72
static bool noop_get_query_result(struct pipe_context *ctx,
73
struct pipe_query *query,
74
bool wait,
75
union pipe_query_result *vresult)
76
{
77
uint64_t *result = (uint64_t*)vresult;
78
79
*result = 0;
80
return true;
81
}
82
83
static void
84
noop_set_active_query_state(struct pipe_context *pipe, bool enable)
85
{
86
}
87
88
89
/*
90
* resource
91
*/
92
struct noop_resource {
93
struct pipe_resource base;
94
unsigned size;
95
char *data;
96
struct sw_displaytarget *dt;
97
};
98
99
static struct pipe_resource *noop_resource_create(struct pipe_screen *screen,
100
const struct pipe_resource *templ)
101
{
102
struct noop_resource *nresource;
103
unsigned stride;
104
105
nresource = CALLOC_STRUCT(noop_resource);
106
if (!nresource)
107
return NULL;
108
109
stride = util_format_get_stride(templ->format, templ->width0);
110
nresource->base = *templ;
111
nresource->base.screen = screen;
112
nresource->size = stride * templ->height0 * templ->depth0;
113
nresource->data = MALLOC(nresource->size);
114
pipe_reference_init(&nresource->base.reference, 1);
115
if (nresource->data == NULL) {
116
FREE(nresource);
117
return NULL;
118
}
119
return &nresource->base;
120
}
121
122
static struct pipe_resource *noop_resource_from_handle(struct pipe_screen *screen,
123
const struct pipe_resource *templ,
124
struct winsys_handle *handle,
125
unsigned usage)
126
{
127
struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)screen;
128
struct pipe_screen *oscreen = noop_screen->oscreen;
129
struct pipe_resource *result;
130
struct pipe_resource *noop_resource;
131
132
result = oscreen->resource_from_handle(oscreen, templ, handle, usage);
133
noop_resource = noop_resource_create(screen, result);
134
pipe_resource_reference(&result, NULL);
135
return noop_resource;
136
}
137
138
static bool noop_resource_get_handle(struct pipe_screen *pscreen,
139
struct pipe_context *ctx,
140
struct pipe_resource *resource,
141
struct winsys_handle *handle,
142
unsigned usage)
143
{
144
struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)pscreen;
145
struct pipe_screen *screen = noop_screen->oscreen;
146
struct pipe_resource *tex;
147
bool result;
148
149
/* resource_get_handle musn't fail. Just create something and return it. */
150
tex = screen->resource_create(screen, resource);
151
if (!tex)
152
return false;
153
154
result = screen->resource_get_handle(screen, NULL, tex, handle, usage);
155
pipe_resource_reference(&tex, NULL);
156
return result;
157
}
158
159
static bool noop_resource_get_param(struct pipe_screen *pscreen,
160
struct pipe_context *ctx,
161
struct pipe_resource *resource,
162
unsigned plane,
163
unsigned layer,
164
unsigned level,
165
enum pipe_resource_param param,
166
unsigned handle_usage,
167
uint64_t *value)
168
{
169
struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)pscreen;
170
struct pipe_screen *screen = noop_screen->oscreen;
171
struct pipe_resource *tex;
172
bool result;
173
174
/* resource_get_param mustn't fail. Just create something and return it. */
175
tex = screen->resource_create(screen, resource);
176
if (!tex)
177
return false;
178
179
result = screen->resource_get_param(screen, NULL, tex, 0, 0, 0, param,
180
handle_usage, value);
181
pipe_resource_reference(&tex, NULL);
182
return result;
183
}
184
185
static void noop_resource_destroy(struct pipe_screen *screen,
186
struct pipe_resource *resource)
187
{
188
struct noop_resource *nresource = (struct noop_resource *)resource;
189
190
FREE(nresource->data);
191
FREE(resource);
192
}
193
194
195
/*
196
* transfer
197
*/
198
static void *noop_transfer_map(struct pipe_context *pipe,
199
struct pipe_resource *resource,
200
unsigned level,
201
unsigned usage,
202
const struct pipe_box *box,
203
struct pipe_transfer **ptransfer)
204
{
205
struct pipe_transfer *transfer;
206
struct noop_resource *nresource = (struct noop_resource *)resource;
207
208
transfer = CALLOC_STRUCT(pipe_transfer);
209
if (!transfer)
210
return NULL;
211
pipe_resource_reference(&transfer->resource, resource);
212
transfer->level = level;
213
transfer->usage = usage;
214
transfer->box = *box;
215
transfer->stride = 1;
216
transfer->layer_stride = 1;
217
*ptransfer = transfer;
218
219
return nresource->data;
220
}
221
222
static void noop_transfer_flush_region(struct pipe_context *pipe,
223
struct pipe_transfer *transfer,
224
const struct pipe_box *box)
225
{
226
}
227
228
static void noop_transfer_unmap(struct pipe_context *pipe,
229
struct pipe_transfer *transfer)
230
{
231
pipe_resource_reference(&transfer->resource, NULL);
232
FREE(transfer);
233
}
234
235
static void noop_buffer_subdata(struct pipe_context *pipe,
236
struct pipe_resource *resource,
237
unsigned usage, unsigned offset,
238
unsigned size, const void *data)
239
{
240
}
241
242
static void noop_texture_subdata(struct pipe_context *pipe,
243
struct pipe_resource *resource,
244
unsigned level,
245
unsigned usage,
246
const struct pipe_box *box,
247
const void *data,
248
unsigned stride,
249
unsigned layer_stride)
250
{
251
}
252
253
254
/*
255
* clear/copy
256
*/
257
static void noop_clear(struct pipe_context *ctx, unsigned buffers, const struct pipe_scissor_state *scissor_state,
258
const union pipe_color_union *color, double depth, unsigned stencil)
259
{
260
}
261
262
static void noop_clear_render_target(struct pipe_context *ctx,
263
struct pipe_surface *dst,
264
const union pipe_color_union *color,
265
unsigned dstx, unsigned dsty,
266
unsigned width, unsigned height,
267
bool render_condition_enabled)
268
{
269
}
270
271
static void noop_clear_depth_stencil(struct pipe_context *ctx,
272
struct pipe_surface *dst,
273
unsigned clear_flags,
274
double depth,
275
unsigned stencil,
276
unsigned dstx, unsigned dsty,
277
unsigned width, unsigned height,
278
bool render_condition_enabled)
279
{
280
}
281
282
static void noop_resource_copy_region(struct pipe_context *ctx,
283
struct pipe_resource *dst,
284
unsigned dst_level,
285
unsigned dstx, unsigned dsty, unsigned dstz,
286
struct pipe_resource *src,
287
unsigned src_level,
288
const struct pipe_box *src_box)
289
{
290
}
291
292
293
static void noop_blit(struct pipe_context *ctx,
294
const struct pipe_blit_info *info)
295
{
296
}
297
298
299
static void
300
noop_flush_resource(struct pipe_context *ctx,
301
struct pipe_resource *resource)
302
{
303
}
304
305
306
/*
307
* context
308
*/
309
static void noop_flush(struct pipe_context *ctx,
310
struct pipe_fence_handle **fence,
311
unsigned flags)
312
{
313
if (fence)
314
*fence = NULL;
315
}
316
317
static void noop_destroy_context(struct pipe_context *ctx)
318
{
319
if (ctx->stream_uploader)
320
u_upload_destroy(ctx->stream_uploader);
321
322
FREE(ctx);
323
}
324
325
static bool noop_generate_mipmap(struct pipe_context *ctx,
326
struct pipe_resource *resource,
327
enum pipe_format format,
328
unsigned base_level,
329
unsigned last_level,
330
unsigned first_layer,
331
unsigned last_layer)
332
{
333
return true;
334
}
335
336
static void noop_invalidate_resource(struct pipe_context *ctx,
337
struct pipe_resource *resource)
338
{
339
}
340
341
static void noop_set_context_param(struct pipe_context *ctx,
342
enum pipe_context_param param,
343
unsigned value)
344
{
345
}
346
347
static void noop_set_frontend_noop(struct pipe_context *ctx, bool enable)
348
{
349
}
350
351
static struct pipe_context *noop_create_context(struct pipe_screen *screen,
352
void *priv, unsigned flags)
353
{
354
struct pipe_context *ctx = CALLOC_STRUCT(pipe_context);
355
356
if (!ctx)
357
return NULL;
358
359
ctx->screen = screen;
360
ctx->priv = priv;
361
362
ctx->stream_uploader = u_upload_create_default(ctx);
363
if (!ctx->stream_uploader) {
364
FREE(ctx);
365
return NULL;
366
}
367
ctx->const_uploader = ctx->stream_uploader;
368
369
ctx->destroy = noop_destroy_context;
370
ctx->flush = noop_flush;
371
ctx->clear = noop_clear;
372
ctx->clear_render_target = noop_clear_render_target;
373
ctx->clear_depth_stencil = noop_clear_depth_stencil;
374
ctx->resource_copy_region = noop_resource_copy_region;
375
ctx->generate_mipmap = noop_generate_mipmap;
376
ctx->blit = noop_blit;
377
ctx->flush_resource = noop_flush_resource;
378
ctx->create_query = noop_create_query;
379
ctx->destroy_query = noop_destroy_query;
380
ctx->begin_query = noop_begin_query;
381
ctx->end_query = noop_end_query;
382
ctx->get_query_result = noop_get_query_result;
383
ctx->set_active_query_state = noop_set_active_query_state;
384
ctx->buffer_map = noop_transfer_map;
385
ctx->texture_map = noop_transfer_map;
386
ctx->transfer_flush_region = noop_transfer_flush_region;
387
ctx->buffer_unmap = noop_transfer_unmap;
388
ctx->texture_unmap = noop_transfer_unmap;
389
ctx->buffer_subdata = noop_buffer_subdata;
390
ctx->texture_subdata = noop_texture_subdata;
391
ctx->invalidate_resource = noop_invalidate_resource;
392
ctx->set_context_param = noop_set_context_param;
393
ctx->set_frontend_noop = noop_set_frontend_noop;
394
noop_init_state_functions(ctx);
395
396
return ctx;
397
}
398
399
400
/*
401
* pipe_screen
402
*/
403
static void noop_flush_frontbuffer(struct pipe_screen *_screen,
404
struct pipe_context *ctx,
405
struct pipe_resource *resource,
406
unsigned level, unsigned layer,
407
void *context_private, struct pipe_box *box)
408
{
409
}
410
411
static const char *noop_get_vendor(struct pipe_screen* pscreen)
412
{
413
return "X.Org";
414
}
415
416
static const char *noop_get_device_vendor(struct pipe_screen* pscreen)
417
{
418
return "NONE";
419
}
420
421
static const char *noop_get_name(struct pipe_screen* pscreen)
422
{
423
return "NOOP";
424
}
425
426
static int noop_get_param(struct pipe_screen* pscreen, enum pipe_cap param)
427
{
428
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
429
430
return screen->get_param(screen, param);
431
}
432
433
static float noop_get_paramf(struct pipe_screen* pscreen,
434
enum pipe_capf param)
435
{
436
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
437
438
return screen->get_paramf(screen, param);
439
}
440
441
static int noop_get_shader_param(struct pipe_screen* pscreen,
442
enum pipe_shader_type shader,
443
enum pipe_shader_cap param)
444
{
445
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
446
447
return screen->get_shader_param(screen, shader, param);
448
}
449
450
static int noop_get_compute_param(struct pipe_screen *pscreen,
451
enum pipe_shader_ir ir_type,
452
enum pipe_compute_cap param,
453
void *ret)
454
{
455
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
456
457
return screen->get_compute_param(screen, ir_type, param, ret);
458
}
459
460
static bool noop_is_format_supported(struct pipe_screen* pscreen,
461
enum pipe_format format,
462
enum pipe_texture_target target,
463
unsigned sample_count,
464
unsigned storage_sample_count,
465
unsigned usage)
466
{
467
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
468
469
return screen->is_format_supported(screen, format, target, sample_count,
470
storage_sample_count, usage);
471
}
472
473
static uint64_t noop_get_timestamp(struct pipe_screen *pscreen)
474
{
475
return 0;
476
}
477
478
static void noop_destroy_screen(struct pipe_screen *screen)
479
{
480
struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)screen;
481
struct pipe_screen *oscreen = noop_screen->oscreen;
482
483
oscreen->destroy(oscreen);
484
FREE(screen);
485
}
486
487
static void noop_fence_reference(struct pipe_screen *screen,
488
struct pipe_fence_handle **ptr,
489
struct pipe_fence_handle *fence)
490
{
491
}
492
493
static bool noop_fence_finish(struct pipe_screen *screen,
494
struct pipe_context *ctx,
495
struct pipe_fence_handle *fence,
496
uint64_t timeout)
497
{
498
return true;
499
}
500
501
static void noop_query_memory_info(struct pipe_screen *pscreen,
502
struct pipe_memory_info *info)
503
{
504
struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)pscreen;
505
struct pipe_screen *screen = noop_screen->oscreen;
506
507
screen->query_memory_info(screen, info);
508
}
509
510
static struct disk_cache *noop_get_disk_shader_cache(struct pipe_screen *pscreen)
511
{
512
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
513
514
return screen->get_disk_shader_cache(screen);
515
}
516
517
static const void *noop_get_compiler_options(struct pipe_screen *pscreen,
518
enum pipe_shader_ir ir,
519
enum pipe_shader_type shader)
520
{
521
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
522
523
return screen->get_compiler_options(screen, ir, shader);
524
}
525
526
static void noop_finalize_nir(struct pipe_screen *pscreen, void *nir, bool optimize)
527
{
528
struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;
529
530
screen->finalize_nir(screen, nir, optimize);
531
}
532
533
struct pipe_screen *noop_screen_create(struct pipe_screen *oscreen)
534
{
535
struct noop_pipe_screen *noop_screen;
536
struct pipe_screen *screen;
537
538
if (!debug_get_option_noop()) {
539
return oscreen;
540
}
541
542
noop_screen = CALLOC_STRUCT(noop_pipe_screen);
543
if (!noop_screen) {
544
return NULL;
545
}
546
noop_screen->oscreen = oscreen;
547
screen = &noop_screen->pscreen;
548
549
screen->destroy = noop_destroy_screen;
550
screen->get_name = noop_get_name;
551
screen->get_vendor = noop_get_vendor;
552
screen->get_device_vendor = noop_get_device_vendor;
553
screen->get_param = noop_get_param;
554
screen->get_shader_param = noop_get_shader_param;
555
screen->get_compute_param = noop_get_compute_param;
556
screen->get_paramf = noop_get_paramf;
557
screen->is_format_supported = noop_is_format_supported;
558
screen->context_create = noop_create_context;
559
screen->resource_create = noop_resource_create;
560
screen->resource_from_handle = noop_resource_from_handle;
561
screen->resource_get_handle = noop_resource_get_handle;
562
if (oscreen->resource_get_param)
563
screen->resource_get_param = noop_resource_get_param;
564
screen->resource_destroy = noop_resource_destroy;
565
screen->flush_frontbuffer = noop_flush_frontbuffer;
566
screen->get_timestamp = noop_get_timestamp;
567
screen->fence_reference = noop_fence_reference;
568
screen->fence_finish = noop_fence_finish;
569
screen->query_memory_info = noop_query_memory_info;
570
screen->get_disk_shader_cache = noop_get_disk_shader_cache;
571
screen->get_compiler_options = noop_get_compiler_options;
572
screen->finalize_nir = noop_finalize_nir;
573
574
return screen;
575
}
576
577