Path: blob/21.2-virgl/src/gallium/auxiliary/driver_noop/noop_pipe.c
4565 views
/*1* Copyright 2010 Red Hat Inc.2*3* Permission is hereby granted, free of charge, to any person obtaining a4* copy of this software and associated documentation files (the "Software"),5* to deal in the Software without restriction, including without limitation6* on the rights to use, copy, modify, merge, publish, distribute, sub7* license, and/or sell copies of the Software, and to permit persons to whom8* the Software is furnished to do so, subject to the following conditions:9*10* The above copyright notice and this permission notice (including the next11* paragraph) shall be included in all copies or substantial portions of the12* Software.13*14* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR15* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,16* FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL17* THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,18* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR19* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE20* USE OR OTHER DEALINGS IN THE SOFTWARE.21*/22#include <stdio.h>23#include <errno.h>24#include "pipe/p_defines.h"25#include "pipe/p_state.h"26#include "pipe/p_context.h"27#include "pipe/p_screen.h"28#include "util/u_memory.h"29#include "util/u_inlines.h"30#include "util/format/u_format.h"31#include "util/u_upload_mgr.h"32#include "noop_public.h"3334DEBUG_GET_ONCE_BOOL_OPTION(noop, "GALLIUM_NOOP", false)3536void noop_init_state_functions(struct pipe_context *ctx);3738struct noop_pipe_screen {39struct pipe_screen pscreen;40struct pipe_screen *oscreen;41};4243/*44* query45*/46struct noop_query {47unsigned query;48};49static struct pipe_query *noop_create_query(struct pipe_context *ctx, unsigned query_type, unsigned index)50{51struct noop_query *query = CALLOC_STRUCT(noop_query);5253return (struct pipe_query *)query;54}5556static void noop_destroy_query(struct pipe_context *ctx, struct pipe_query *query)57{58FREE(query);59}6061static bool noop_begin_query(struct pipe_context *ctx, struct pipe_query *query)62{63return true;64}6566static bool noop_end_query(struct pipe_context *ctx, struct pipe_query *query)67{68return true;69}7071static bool noop_get_query_result(struct pipe_context *ctx,72struct pipe_query *query,73bool wait,74union pipe_query_result *vresult)75{76uint64_t *result = (uint64_t*)vresult;7778*result = 0;79return true;80}8182static void83noop_set_active_query_state(struct pipe_context *pipe, bool enable)84{85}868788/*89* resource90*/91struct noop_resource {92struct pipe_resource base;93unsigned size;94char *data;95struct sw_displaytarget *dt;96};9798static struct pipe_resource *noop_resource_create(struct pipe_screen *screen,99const struct pipe_resource *templ)100{101struct noop_resource *nresource;102unsigned stride;103104nresource = CALLOC_STRUCT(noop_resource);105if (!nresource)106return NULL;107108stride = util_format_get_stride(templ->format, templ->width0);109nresource->base = *templ;110nresource->base.screen = screen;111nresource->size = stride * templ->height0 * templ->depth0;112nresource->data = MALLOC(nresource->size);113pipe_reference_init(&nresource->base.reference, 1);114if (nresource->data == NULL) {115FREE(nresource);116return NULL;117}118return &nresource->base;119}120121static struct pipe_resource *noop_resource_from_handle(struct pipe_screen *screen,122const struct pipe_resource *templ,123struct winsys_handle *handle,124unsigned usage)125{126struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)screen;127struct pipe_screen *oscreen = noop_screen->oscreen;128struct pipe_resource *result;129struct pipe_resource *noop_resource;130131result = oscreen->resource_from_handle(oscreen, templ, handle, usage);132noop_resource = noop_resource_create(screen, result);133pipe_resource_reference(&result, NULL);134return noop_resource;135}136137static bool noop_resource_get_handle(struct pipe_screen *pscreen,138struct pipe_context *ctx,139struct pipe_resource *resource,140struct winsys_handle *handle,141unsigned usage)142{143struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)pscreen;144struct pipe_screen *screen = noop_screen->oscreen;145struct pipe_resource *tex;146bool result;147148/* resource_get_handle musn't fail. Just create something and return it. */149tex = screen->resource_create(screen, resource);150if (!tex)151return false;152153result = screen->resource_get_handle(screen, NULL, tex, handle, usage);154pipe_resource_reference(&tex, NULL);155return result;156}157158static bool noop_resource_get_param(struct pipe_screen *pscreen,159struct pipe_context *ctx,160struct pipe_resource *resource,161unsigned plane,162unsigned layer,163unsigned level,164enum pipe_resource_param param,165unsigned handle_usage,166uint64_t *value)167{168struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)pscreen;169struct pipe_screen *screen = noop_screen->oscreen;170struct pipe_resource *tex;171bool result;172173/* resource_get_param mustn't fail. Just create something and return it. */174tex = screen->resource_create(screen, resource);175if (!tex)176return false;177178result = screen->resource_get_param(screen, NULL, tex, 0, 0, 0, param,179handle_usage, value);180pipe_resource_reference(&tex, NULL);181return result;182}183184static void noop_resource_destroy(struct pipe_screen *screen,185struct pipe_resource *resource)186{187struct noop_resource *nresource = (struct noop_resource *)resource;188189FREE(nresource->data);190FREE(resource);191}192193194/*195* transfer196*/197static void *noop_transfer_map(struct pipe_context *pipe,198struct pipe_resource *resource,199unsigned level,200unsigned usage,201const struct pipe_box *box,202struct pipe_transfer **ptransfer)203{204struct pipe_transfer *transfer;205struct noop_resource *nresource = (struct noop_resource *)resource;206207transfer = CALLOC_STRUCT(pipe_transfer);208if (!transfer)209return NULL;210pipe_resource_reference(&transfer->resource, resource);211transfer->level = level;212transfer->usage = usage;213transfer->box = *box;214transfer->stride = 1;215transfer->layer_stride = 1;216*ptransfer = transfer;217218return nresource->data;219}220221static void noop_transfer_flush_region(struct pipe_context *pipe,222struct pipe_transfer *transfer,223const struct pipe_box *box)224{225}226227static void noop_transfer_unmap(struct pipe_context *pipe,228struct pipe_transfer *transfer)229{230pipe_resource_reference(&transfer->resource, NULL);231FREE(transfer);232}233234static void noop_buffer_subdata(struct pipe_context *pipe,235struct pipe_resource *resource,236unsigned usage, unsigned offset,237unsigned size, const void *data)238{239}240241static void noop_texture_subdata(struct pipe_context *pipe,242struct pipe_resource *resource,243unsigned level,244unsigned usage,245const struct pipe_box *box,246const void *data,247unsigned stride,248unsigned layer_stride)249{250}251252253/*254* clear/copy255*/256static void noop_clear(struct pipe_context *ctx, unsigned buffers, const struct pipe_scissor_state *scissor_state,257const union pipe_color_union *color, double depth, unsigned stencil)258{259}260261static void noop_clear_render_target(struct pipe_context *ctx,262struct pipe_surface *dst,263const union pipe_color_union *color,264unsigned dstx, unsigned dsty,265unsigned width, unsigned height,266bool render_condition_enabled)267{268}269270static void noop_clear_depth_stencil(struct pipe_context *ctx,271struct pipe_surface *dst,272unsigned clear_flags,273double depth,274unsigned stencil,275unsigned dstx, unsigned dsty,276unsigned width, unsigned height,277bool render_condition_enabled)278{279}280281static void noop_resource_copy_region(struct pipe_context *ctx,282struct pipe_resource *dst,283unsigned dst_level,284unsigned dstx, unsigned dsty, unsigned dstz,285struct pipe_resource *src,286unsigned src_level,287const struct pipe_box *src_box)288{289}290291292static void noop_blit(struct pipe_context *ctx,293const struct pipe_blit_info *info)294{295}296297298static void299noop_flush_resource(struct pipe_context *ctx,300struct pipe_resource *resource)301{302}303304305/*306* context307*/308static void noop_flush(struct pipe_context *ctx,309struct pipe_fence_handle **fence,310unsigned flags)311{312if (fence)313*fence = NULL;314}315316static void noop_destroy_context(struct pipe_context *ctx)317{318if (ctx->stream_uploader)319u_upload_destroy(ctx->stream_uploader);320321FREE(ctx);322}323324static bool noop_generate_mipmap(struct pipe_context *ctx,325struct pipe_resource *resource,326enum pipe_format format,327unsigned base_level,328unsigned last_level,329unsigned first_layer,330unsigned last_layer)331{332return true;333}334335static void noop_invalidate_resource(struct pipe_context *ctx,336struct pipe_resource *resource)337{338}339340static void noop_set_context_param(struct pipe_context *ctx,341enum pipe_context_param param,342unsigned value)343{344}345346static void noop_set_frontend_noop(struct pipe_context *ctx, bool enable)347{348}349350static struct pipe_context *noop_create_context(struct pipe_screen *screen,351void *priv, unsigned flags)352{353struct pipe_context *ctx = CALLOC_STRUCT(pipe_context);354355if (!ctx)356return NULL;357358ctx->screen = screen;359ctx->priv = priv;360361ctx->stream_uploader = u_upload_create_default(ctx);362if (!ctx->stream_uploader) {363FREE(ctx);364return NULL;365}366ctx->const_uploader = ctx->stream_uploader;367368ctx->destroy = noop_destroy_context;369ctx->flush = noop_flush;370ctx->clear = noop_clear;371ctx->clear_render_target = noop_clear_render_target;372ctx->clear_depth_stencil = noop_clear_depth_stencil;373ctx->resource_copy_region = noop_resource_copy_region;374ctx->generate_mipmap = noop_generate_mipmap;375ctx->blit = noop_blit;376ctx->flush_resource = noop_flush_resource;377ctx->create_query = noop_create_query;378ctx->destroy_query = noop_destroy_query;379ctx->begin_query = noop_begin_query;380ctx->end_query = noop_end_query;381ctx->get_query_result = noop_get_query_result;382ctx->set_active_query_state = noop_set_active_query_state;383ctx->buffer_map = noop_transfer_map;384ctx->texture_map = noop_transfer_map;385ctx->transfer_flush_region = noop_transfer_flush_region;386ctx->buffer_unmap = noop_transfer_unmap;387ctx->texture_unmap = noop_transfer_unmap;388ctx->buffer_subdata = noop_buffer_subdata;389ctx->texture_subdata = noop_texture_subdata;390ctx->invalidate_resource = noop_invalidate_resource;391ctx->set_context_param = noop_set_context_param;392ctx->set_frontend_noop = noop_set_frontend_noop;393noop_init_state_functions(ctx);394395return ctx;396}397398399/*400* pipe_screen401*/402static void noop_flush_frontbuffer(struct pipe_screen *_screen,403struct pipe_context *ctx,404struct pipe_resource *resource,405unsigned level, unsigned layer,406void *context_private, struct pipe_box *box)407{408}409410static const char *noop_get_vendor(struct pipe_screen* pscreen)411{412return "X.Org";413}414415static const char *noop_get_device_vendor(struct pipe_screen* pscreen)416{417return "NONE";418}419420static const char *noop_get_name(struct pipe_screen* pscreen)421{422return "NOOP";423}424425static int noop_get_param(struct pipe_screen* pscreen, enum pipe_cap param)426{427struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;428429return screen->get_param(screen, param);430}431432static float noop_get_paramf(struct pipe_screen* pscreen,433enum pipe_capf param)434{435struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;436437return screen->get_paramf(screen, param);438}439440static int noop_get_shader_param(struct pipe_screen* pscreen,441enum pipe_shader_type shader,442enum pipe_shader_cap param)443{444struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;445446return screen->get_shader_param(screen, shader, param);447}448449static int noop_get_compute_param(struct pipe_screen *pscreen,450enum pipe_shader_ir ir_type,451enum pipe_compute_cap param,452void *ret)453{454struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;455456return screen->get_compute_param(screen, ir_type, param, ret);457}458459static bool noop_is_format_supported(struct pipe_screen* pscreen,460enum pipe_format format,461enum pipe_texture_target target,462unsigned sample_count,463unsigned storage_sample_count,464unsigned usage)465{466struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;467468return screen->is_format_supported(screen, format, target, sample_count,469storage_sample_count, usage);470}471472static uint64_t noop_get_timestamp(struct pipe_screen *pscreen)473{474return 0;475}476477static void noop_destroy_screen(struct pipe_screen *screen)478{479struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)screen;480struct pipe_screen *oscreen = noop_screen->oscreen;481482oscreen->destroy(oscreen);483FREE(screen);484}485486static void noop_fence_reference(struct pipe_screen *screen,487struct pipe_fence_handle **ptr,488struct pipe_fence_handle *fence)489{490}491492static bool noop_fence_finish(struct pipe_screen *screen,493struct pipe_context *ctx,494struct pipe_fence_handle *fence,495uint64_t timeout)496{497return true;498}499500static void noop_query_memory_info(struct pipe_screen *pscreen,501struct pipe_memory_info *info)502{503struct noop_pipe_screen *noop_screen = (struct noop_pipe_screen*)pscreen;504struct pipe_screen *screen = noop_screen->oscreen;505506screen->query_memory_info(screen, info);507}508509static struct disk_cache *noop_get_disk_shader_cache(struct pipe_screen *pscreen)510{511struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;512513return screen->get_disk_shader_cache(screen);514}515516static const void *noop_get_compiler_options(struct pipe_screen *pscreen,517enum pipe_shader_ir ir,518enum pipe_shader_type shader)519{520struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;521522return screen->get_compiler_options(screen, ir, shader);523}524525static void noop_finalize_nir(struct pipe_screen *pscreen, void *nir, bool optimize)526{527struct pipe_screen *screen = ((struct noop_pipe_screen*)pscreen)->oscreen;528529screen->finalize_nir(screen, nir, optimize);530}531532struct pipe_screen *noop_screen_create(struct pipe_screen *oscreen)533{534struct noop_pipe_screen *noop_screen;535struct pipe_screen *screen;536537if (!debug_get_option_noop()) {538return oscreen;539}540541noop_screen = CALLOC_STRUCT(noop_pipe_screen);542if (!noop_screen) {543return NULL;544}545noop_screen->oscreen = oscreen;546screen = &noop_screen->pscreen;547548screen->destroy = noop_destroy_screen;549screen->get_name = noop_get_name;550screen->get_vendor = noop_get_vendor;551screen->get_device_vendor = noop_get_device_vendor;552screen->get_param = noop_get_param;553screen->get_shader_param = noop_get_shader_param;554screen->get_compute_param = noop_get_compute_param;555screen->get_paramf = noop_get_paramf;556screen->is_format_supported = noop_is_format_supported;557screen->context_create = noop_create_context;558screen->resource_create = noop_resource_create;559screen->resource_from_handle = noop_resource_from_handle;560screen->resource_get_handle = noop_resource_get_handle;561if (oscreen->resource_get_param)562screen->resource_get_param = noop_resource_get_param;563screen->resource_destroy = noop_resource_destroy;564screen->flush_frontbuffer = noop_flush_frontbuffer;565screen->get_timestamp = noop_get_timestamp;566screen->fence_reference = noop_fence_reference;567screen->fence_finish = noop_fence_finish;568screen->query_memory_info = noop_query_memory_info;569screen->get_disk_shader_cache = noop_get_disk_shader_cache;570screen->get_compiler_options = noop_get_compiler_options;571screen->finalize_nir = noop_finalize_nir;572573return screen;574}575576577