Path: blob/21.2-virgl/src/gallium/drivers/nouveau/nvc0/nvc0_resource.c
4574 views
#include "drm-uapi/drm_fourcc.h"12#include "pipe/p_context.h"3#include "nvc0/nvc0_resource.h"4#include "nouveau_screen.h"567static struct pipe_resource *8nvc0_resource_create(struct pipe_screen *screen,9const struct pipe_resource *templ)10{11switch (templ->target) {12case PIPE_BUFFER:13return nouveau_buffer_create(screen, templ);14default:15return nvc0_miptree_create(screen, templ, NULL, 0);16}17}1819static struct pipe_resource *20nvc0_resource_create_with_modifiers(struct pipe_screen *screen,21const struct pipe_resource *templ,22const uint64_t *modifiers, int count)23{24switch (templ->target) {25case PIPE_BUFFER:26return nouveau_buffer_create(screen, templ);27default:28return nvc0_miptree_create(screen, templ, modifiers, count);29}30}3132static void33nvc0_resource_destroy(struct pipe_screen *pscreen, struct pipe_resource *res)34{35if (res->target == PIPE_BUFFER)36nouveau_buffer_destroy(pscreen, res);37else38nv50_miptree_destroy(pscreen, res);39}4041static void42nvc0_query_dmabuf_modifiers(struct pipe_screen *screen,43enum pipe_format format, int max,44uint64_t *modifiers, unsigned int *external_only,45int *count)46{47const int s = nouveau_screen(screen)->tegra_sector_layout ? 0 : 1;48const uint32_t uc_kind =49nvc0_choose_tiled_storage_type(screen, format, 0, false);50const uint32_t num_uc = uc_kind ? 6 : 0; /* max block height = 32 GOBs */51const int num_supported = num_uc + 1; /* LINEAR is always supported */52const uint32_t kind_gen = nvc0_get_kind_generation(screen);53int i, num = 0;5455if (max > num_supported)56max = num_supported;5758if (!max) {59max = num_supported;60external_only = NULL;61modifiers = NULL;62}6364#define NVC0_ADD_MOD(m) do { \65if (modifiers) modifiers[num] = m; \66if (external_only) external_only[num] = 0; \67num++; \68} while (0)6970for (i = 0; i < max && i < num_uc; i++)71NVC0_ADD_MOD(DRM_FORMAT_MOD_NVIDIA_BLOCK_LINEAR_2D(0, s, kind_gen,72uc_kind, 5 - i));7374if (i < max)75NVC0_ADD_MOD(DRM_FORMAT_MOD_LINEAR);7677#undef NVC0_ADD_MOD7879*count = num;80}8182static bool83nvc0_is_dmabuf_modifier_supported(struct pipe_screen *screen,84uint64_t modifier, enum pipe_format format,85bool *external_only)86{87const int s = nouveau_screen(screen)->tegra_sector_layout ? 0 : 1;88const uint32_t uc_kind =89nvc0_choose_tiled_storage_type(screen, format, 0, false);90const uint32_t num_uc = uc_kind ? 6 : 0; /* max block height = 32 GOBs */91const uint32_t kind_gen = nvc0_get_kind_generation(screen);92int i;9394if (modifier == DRM_FORMAT_MOD_LINEAR) {95if (external_only)96*external_only = false;9798return true;99}100101for (i = 0; i < num_uc; i++) {102if (DRM_FORMAT_MOD_NVIDIA_BLOCK_LINEAR_2D(0, s, kind_gen, uc_kind, i) == modifier) {103if (external_only)104*external_only = false;105106return true;107}108}109110return false;111}112113static struct pipe_resource *114nvc0_resource_from_handle(struct pipe_screen * screen,115const struct pipe_resource *templ,116struct winsys_handle *whandle,117unsigned usage)118{119if (templ->target == PIPE_BUFFER) {120return NULL;121} else {122struct pipe_resource *res = nv50_miptree_from_handle(screen,123templ, whandle);124return res;125}126}127128static struct pipe_surface *129nvc0_surface_create(struct pipe_context *pipe,130struct pipe_resource *pres,131const struct pipe_surface *templ)132{133if (unlikely(pres->target == PIPE_BUFFER))134return nv50_surface_from_buffer(pipe, pres, templ);135return nvc0_miptree_surface_new(pipe, pres, templ);136}137138static struct pipe_resource *139nvc0_resource_from_user_memory(struct pipe_screen *pipe,140const struct pipe_resource *templ,141void *user_memory)142{143ASSERTED struct nouveau_screen *screen = nouveau_screen(pipe);144145assert(screen->has_svm);146assert(templ->target == PIPE_BUFFER);147148return nouveau_buffer_create_from_user(pipe, templ, user_memory);149}150151void152nvc0_init_resource_functions(struct pipe_context *pcontext)153{154pcontext->buffer_map = nouveau_buffer_transfer_map;155pcontext->texture_map = nvc0_miptree_transfer_map;156pcontext->transfer_flush_region = nouveau_buffer_transfer_flush_region;157pcontext->buffer_unmap = nouveau_buffer_transfer_unmap;158pcontext->texture_unmap = nvc0_miptree_transfer_unmap;159pcontext->buffer_subdata = u_default_buffer_subdata;160pcontext->texture_subdata = u_default_texture_subdata;161pcontext->create_surface = nvc0_surface_create;162pcontext->surface_destroy = nv50_surface_destroy;163pcontext->invalidate_resource = nv50_invalidate_resource;164}165166void167nvc0_screen_init_resource_functions(struct pipe_screen *pscreen)168{169pscreen->resource_create = nvc0_resource_create;170pscreen->resource_create_with_modifiers = nvc0_resource_create_with_modifiers;171pscreen->query_dmabuf_modifiers = nvc0_query_dmabuf_modifiers;172pscreen->is_dmabuf_modifier_supported = nvc0_is_dmabuf_modifier_supported;173pscreen->resource_from_handle = nvc0_resource_from_handle;174pscreen->resource_get_handle = nvc0_miptree_get_handle;175pscreen->resource_destroy = nvc0_resource_destroy;176pscreen->resource_from_user_memory = nvc0_resource_from_user_memory;177}178179180