diff options
author | Nicolai Hähnle <[email protected]> | 2016-04-25 21:40:53 -0500 |
---|---|---|
committer | Nicolai Hähnle <[email protected]> | 2016-06-01 22:37:20 +0200 |
commit | be82065fbe8095ce3146f7480b3202aca336aebf (patch) | |
tree | dd4d639f974315103876cf23ac440a257ae48898 /src | |
parent | 4ecc32b0e12d0a86f15beec1dd8b45063e7b2e20 (diff) |
st/mesa: move PBO vertex and geometry shader creation to st_pbo.c
Reviewed-by: Brian Paul <[email protected]>
Reviewed-by: Marek Olšák <[email protected]>
Diffstat (limited to 'src')
-rw-r--r-- | src/mesa/state_tracker/st_cb_texture.c | 92 | ||||
-rw-r--r-- | src/mesa/state_tracker/st_pbo.c | 88 | ||||
-rw-r--r-- | src/mesa/state_tracker/st_pbo.h | 6 |
3 files changed, 97 insertions, 89 deletions
diff --git a/src/mesa/state_tracker/st_cb_texture.c b/src/mesa/state_tracker/st_cb_texture.c index 048240d6708..0736b96aaf4 100644 --- a/src/mesa/state_tracker/st_cb_texture.c +++ b/src/mesa/state_tracker/st_cb_texture.c @@ -53,6 +53,7 @@ #include "state_tracker/st_cb_texture.h" #include "state_tracker/st_cb_bufferobjects.h" #include "state_tracker/st_format.h" +#include "state_tracker/st_pbo.h" #include "state_tracker/st_texture.h" #include "state_tracker/st_gen_mipmap.h" #include "state_tracker/st_atom.h" @@ -1070,93 +1071,6 @@ reinterpret_formats(enum pipe_format *src_format, enum pipe_format *dst_format) } static void * -create_pbo_upload_vs(struct st_context *st) -{ - struct ureg_program *ureg; - struct ureg_src in_pos; - struct ureg_src in_instanceid; - struct ureg_dst out_pos; - struct ureg_dst out_layer; - - ureg = ureg_create(PIPE_SHADER_VERTEX); - if (!ureg) - return NULL; - - in_pos = ureg_DECL_vs_input(ureg, TGSI_SEMANTIC_POSITION); - - out_pos = ureg_DECL_output(ureg, TGSI_SEMANTIC_POSITION, 0); - - if (st->pbo_upload.upload_layers) { - in_instanceid = ureg_DECL_system_value(ureg, TGSI_SEMANTIC_INSTANCEID, 0); - - if (!st->pbo_upload.use_gs) - out_layer = ureg_DECL_output(ureg, TGSI_SEMANTIC_LAYER, 0); - } - - /* out_pos = in_pos */ - ureg_MOV(ureg, out_pos, in_pos); - - if (st->pbo_upload.upload_layers) { - if (st->pbo_upload.use_gs) { - /* out_pos.z = i2f(gl_InstanceID) */ - ureg_I2F(ureg, ureg_writemask(out_pos, TGSI_WRITEMASK_Z), - ureg_scalar(in_instanceid, TGSI_SWIZZLE_X)); - } else { - /* out_layer = gl_InstanceID */ - ureg_MOV(ureg, out_layer, in_instanceid); - } - } - - ureg_END(ureg); - - return ureg_create_shader_and_destroy(ureg, st->pipe); -} - -static void * -create_pbo_upload_gs(struct st_context *st) -{ - static const int zero = 0; - struct ureg_program *ureg; - struct ureg_dst out_pos; - struct ureg_dst out_layer; - struct ureg_src in_pos; - struct ureg_src imm; - unsigned i; - - ureg = ureg_create(PIPE_SHADER_GEOMETRY); - if (!ureg) - return NULL; - - ureg_property(ureg, TGSI_PROPERTY_GS_INPUT_PRIM, PIPE_PRIM_TRIANGLES); - ureg_property(ureg, TGSI_PROPERTY_GS_OUTPUT_PRIM, PIPE_PRIM_TRIANGLE_STRIP); - ureg_property(ureg, TGSI_PROPERTY_GS_MAX_OUTPUT_VERTICES, 3); - - out_pos = ureg_DECL_output(ureg, TGSI_SEMANTIC_POSITION, 0); - out_layer = ureg_DECL_output(ureg, TGSI_SEMANTIC_LAYER, 0); - - in_pos = ureg_DECL_input(ureg, TGSI_SEMANTIC_POSITION, 0, 0, 1); - - imm = ureg_DECL_immediate_int(ureg, &zero, 1); - - for (i = 0; i < 3; ++i) { - struct ureg_src in_pos_vertex = ureg_src_dimension(in_pos, i); - - /* out_pos = in_pos[i] */ - ureg_MOV(ureg, out_pos, in_pos_vertex); - - /* out_layer.x = f2i(in_pos[i].z) */ - ureg_F2I(ureg, ureg_writemask(out_layer, TGSI_WRITEMASK_X), - ureg_scalar(in_pos_vertex, TGSI_SWIZZLE_Z)); - - ureg_EMIT(ureg, ureg_scalar(imm, TGSI_SWIZZLE_X)); - } - - ureg_END(ureg); - - return ureg_create_shader_and_destroy(ureg, st->pipe); -} - -static void * create_pbo_upload_fs(struct st_context *st) { struct pipe_context *pipe = st->pipe; @@ -1265,13 +1179,13 @@ try_pbo_upload_common(struct gl_context *ctx, /* Create the shaders */ if (!st->pbo_upload.vs) { - st->pbo_upload.vs = create_pbo_upload_vs(st); + st->pbo_upload.vs = st_pbo_create_vs(st); if (!st->pbo_upload.vs) return false; } if (depth != 1 && st->pbo_upload.use_gs && !st->pbo_upload.gs) { - st->pbo_upload.gs = create_pbo_upload_gs(st); + st->pbo_upload.gs = st_pbo_create_gs(st); if (!st->pbo_upload.gs) return false; } diff --git a/src/mesa/state_tracker/st_pbo.c b/src/mesa/state_tracker/st_pbo.c index 2e6d2361497..75c5d1eec51 100644 --- a/src/mesa/state_tracker/st_pbo.c +++ b/src/mesa/state_tracker/st_pbo.c @@ -35,6 +35,94 @@ #include "pipe/p_defines.h" #include "pipe/p_screen.h" #include "cso_cache/cso_context.h" +#include "tgsi/tgsi_ureg.h" + +void * +st_pbo_create_vs(struct st_context *st) +{ + struct ureg_program *ureg; + struct ureg_src in_pos; + struct ureg_src in_instanceid; + struct ureg_dst out_pos; + struct ureg_dst out_layer; + + ureg = ureg_create(PIPE_SHADER_VERTEX); + if (!ureg) + return NULL; + + in_pos = ureg_DECL_vs_input(ureg, TGSI_SEMANTIC_POSITION); + + out_pos = ureg_DECL_output(ureg, TGSI_SEMANTIC_POSITION, 0); + + if (st->pbo_upload.upload_layers) { + in_instanceid = ureg_DECL_system_value(ureg, TGSI_SEMANTIC_INSTANCEID, 0); + + if (!st->pbo_upload.use_gs) + out_layer = ureg_DECL_output(ureg, TGSI_SEMANTIC_LAYER, 0); + } + + /* out_pos = in_pos */ + ureg_MOV(ureg, out_pos, in_pos); + + if (st->pbo_upload.upload_layers) { + if (st->pbo_upload.use_gs) { + /* out_pos.z = i2f(gl_InstanceID) */ + ureg_I2F(ureg, ureg_writemask(out_pos, TGSI_WRITEMASK_Z), + ureg_scalar(in_instanceid, TGSI_SWIZZLE_X)); + } else { + /* out_layer = gl_InstanceID */ + ureg_MOV(ureg, out_layer, in_instanceid); + } + } + + ureg_END(ureg); + + return ureg_create_shader_and_destroy(ureg, st->pipe); +} + +void * +st_pbo_create_gs(struct st_context *st) +{ + static const int zero = 0; + struct ureg_program *ureg; + struct ureg_dst out_pos; + struct ureg_dst out_layer; + struct ureg_src in_pos; + struct ureg_src imm; + unsigned i; + + ureg = ureg_create(PIPE_SHADER_GEOMETRY); + if (!ureg) + return NULL; + + ureg_property(ureg, TGSI_PROPERTY_GS_INPUT_PRIM, PIPE_PRIM_TRIANGLES); + ureg_property(ureg, TGSI_PROPERTY_GS_OUTPUT_PRIM, PIPE_PRIM_TRIANGLE_STRIP); + ureg_property(ureg, TGSI_PROPERTY_GS_MAX_OUTPUT_VERTICES, 3); + + out_pos = ureg_DECL_output(ureg, TGSI_SEMANTIC_POSITION, 0); + out_layer = ureg_DECL_output(ureg, TGSI_SEMANTIC_LAYER, 0); + + in_pos = ureg_DECL_input(ureg, TGSI_SEMANTIC_POSITION, 0, 0, 1); + + imm = ureg_DECL_immediate_int(ureg, &zero, 1); + + for (i = 0; i < 3; ++i) { + struct ureg_src in_pos_vertex = ureg_src_dimension(in_pos, i); + + /* out_pos = in_pos[i] */ + ureg_MOV(ureg, out_pos, in_pos_vertex); + + /* out_layer.x = f2i(in_pos[i].z) */ + ureg_F2I(ureg, ureg_writemask(out_layer, TGSI_WRITEMASK_X), + ureg_scalar(in_pos_vertex, TGSI_SWIZZLE_Z)); + + ureg_EMIT(ureg, ureg_scalar(imm, TGSI_SWIZZLE_X)); + } + + ureg_END(ureg); + + return ureg_create_shader_and_destroy(ureg, st->pipe); +} void st_init_pbo_helpers(struct st_context *st) diff --git a/src/mesa/state_tracker/st_pbo.h b/src/mesa/state_tracker/st_pbo.h index 0ce30958410..9533b669d5b 100644 --- a/src/mesa/state_tracker/st_pbo.h +++ b/src/mesa/state_tracker/st_pbo.h @@ -26,6 +26,12 @@ struct st_context; +void * +st_pbo_create_vs(struct st_context *st); + +void * +st_pbo_create_gs(struct st_context *st); + extern void st_init_pbo_helpers(struct st_context *st); |