gallium: add PIPE_CAP_BINDLESS_TEXTURE
Whether bindless texture operations are supported by the underlying driver. Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Reviewed-by: Marek Olšák <marek.olsak@amd.com> Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
This commit is contained in:
@@ -394,6 +394,8 @@ The integer capabilities:
|
|||||||
* ``PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION``: As the name says.
|
* ``PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION``: As the name says.
|
||||||
* ``PIPE_CAP_POST_DEPTH_COVERAGE``: whether
|
* ``PIPE_CAP_POST_DEPTH_COVERAGE``: whether
|
||||||
``TGSI_PROPERTY_FS_POST_DEPTH_COVERAGE`` is supported.
|
``TGSI_PROPERTY_FS_POST_DEPTH_COVERAGE`` is supported.
|
||||||
|
* ``PIPE_CAP_BINDLESS_TEXTURE``: Whether bindless texture operations are
|
||||||
|
supported.
|
||||||
|
|
||||||
|
|
||||||
.. _pipe_capf:
|
.. _pipe_capf:
|
||||||
|
@@ -257,6 +257,7 @@ etna_screen_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* Stream output. */
|
/* Stream output. */
|
||||||
|
@@ -316,6 +316,7 @@ fd_screen_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_MAX_VIEWPORTS:
|
case PIPE_CAP_MAX_VIEWPORTS:
|
||||||
|
@@ -309,6 +309,7 @@ i915_get_param(struct pipe_screen *screen, enum pipe_cap cap)
|
|||||||
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_MAX_VIEWPORTS:
|
case PIPE_CAP_MAX_VIEWPORTS:
|
||||||
|
@@ -355,6 +355,7 @@ llvmpipe_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/* should only get here on unhandled cases */
|
/* should only get here on unhandled cases */
|
||||||
|
@@ -219,6 +219,7 @@ nv30_screen_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_VENDOR_ID:
|
case PIPE_CAP_VENDOR_ID:
|
||||||
|
@@ -271,6 +271,7 @@ nv50_screen_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_TGSI_BALLOT:
|
case PIPE_CAP_TGSI_BALLOT:
|
||||||
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_VENDOR_ID:
|
case PIPE_CAP_VENDOR_ID:
|
||||||
|
@@ -300,6 +300,7 @@ nvc0_screen_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_GLSL_OPTIMIZE_CONSERVATIVELY:
|
case PIPE_CAP_GLSL_OPTIMIZE_CONSERVATIVELY:
|
||||||
case PIPE_CAP_INT64_DIVMOD:
|
case PIPE_CAP_INT64_DIVMOD:
|
||||||
case PIPE_CAP_SPARSE_BUFFER_PAGE_SIZE:
|
case PIPE_CAP_SPARSE_BUFFER_PAGE_SIZE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_VENDOR_ID:
|
case PIPE_CAP_VENDOR_ID:
|
||||||
|
@@ -241,6 +241,7 @@ static int r300_get_param(struct pipe_screen* pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* SWTCL-only features. */
|
/* SWTCL-only features. */
|
||||||
|
@@ -397,6 +397,7 @@ static int r600_get_param(struct pipe_screen* pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_TGSI_BALLOT:
|
case PIPE_CAP_TGSI_BALLOT:
|
||||||
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
case PIPE_CAP_TGSI_TES_LAYER_VIEWPORT:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_DOUBLES:
|
case PIPE_CAP_DOUBLES:
|
||||||
|
@@ -537,6 +537,7 @@ static int si_get_param(struct pipe_screen* pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_UMA:
|
case PIPE_CAP_UMA:
|
||||||
case PIPE_CAP_POLYGON_MODE_FILL_RECTANGLE:
|
case PIPE_CAP_POLYGON_MODE_FILL_RECTANGLE:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_QUERY_BUFFER_OBJECT:
|
case PIPE_CAP_QUERY_BUFFER_OBJECT:
|
||||||
|
@@ -305,6 +305,7 @@ softpipe_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
case PIPE_CAP_SHADER_BUFFER_OFFSET_ALIGNMENT:
|
case PIPE_CAP_SHADER_BUFFER_OFFSET_ALIGNMENT:
|
||||||
return 4;
|
return 4;
|
||||||
|
@@ -444,6 +444,7 @@ svga_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -340,6 +340,7 @@ swr_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case PIPE_CAP_VENDOR_ID:
|
case PIPE_CAP_VENDOR_ID:
|
||||||
|
@@ -256,6 +256,7 @@ vc4_screen_get_param(struct pipe_screen *pscreen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* Stream output. */
|
/* Stream output. */
|
||||||
|
@@ -264,6 +264,7 @@ virgl_get_param(struct pipe_screen *screen, enum pipe_cap param)
|
|||||||
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
case PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX:
|
||||||
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
case PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION:
|
||||||
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
case PIPE_CAP_POST_DEPTH_COVERAGE:
|
||||||
|
case PIPE_CAP_BINDLESS_TEXTURE:
|
||||||
return 0;
|
return 0;
|
||||||
case PIPE_CAP_VENDOR_ID:
|
case PIPE_CAP_VENDOR_ID:
|
||||||
return 0x1af4;
|
return 0x1af4;
|
||||||
|
@@ -773,6 +773,7 @@ enum pipe_cap
|
|||||||
PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX,
|
PIPE_CAP_CAN_BIND_CONST_BUFFER_AS_VERTEX,
|
||||||
PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION,
|
PIPE_CAP_ALLOW_MAPPED_BUFFERS_DURING_EXECUTION,
|
||||||
PIPE_CAP_POST_DEPTH_COVERAGE,
|
PIPE_CAP_POST_DEPTH_COVERAGE,
|
||||||
|
PIPE_CAP_BINDLESS_TEXTURE,
|
||||||
};
|
};
|
||||||
|
|
||||||
#define PIPE_QUIRK_TEXTURE_BORDER_COLOR_SWIZZLE_NV50 (1 << 0)
|
#define PIPE_QUIRK_TEXTURE_BORDER_COLOR_SWIZZLE_NV50 (1 << 0)
|
||||||
|
Reference in New Issue
Block a user