From: Tim Rowley Date: Tue, 26 Apr 2016 16:22:24 +0000 (-0500) Subject: swr: autogenerate swr_context_llvm.h X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=18d1658633d5ca5147e0b1a2cd22ea7ffa1b5093;p=mesa.git swr: autogenerate swr_context_llvm.h Reviewed-by: Bruce Cherniak --- diff --git a/src/gallium/drivers/swr/.gitignore b/src/gallium/drivers/swr/.gitignore index c5b6416ee30..6b4de9e2e31 100644 --- a/src/gallium/drivers/swr/.gitignore +++ b/src/gallium/drivers/swr/.gitignore @@ -1,3 +1,4 @@ +swr_context_llvm.h rasterizer/jitter/builder_gen.cpp rasterizer/jitter/builder_gen.h rasterizer/jitter/builder_x86.cpp diff --git a/src/gallium/drivers/swr/Makefile.am b/src/gallium/drivers/swr/Makefile.am index b1ff4233b56..6915aae356c 100644 --- a/src/gallium/drivers/swr/Makefile.am +++ b/src/gallium/drivers/swr/Makefile.am @@ -47,6 +47,7 @@ COMMON_SOURCES = \ $(BUILT_SOURCES) BUILT_SOURCES = \ + swr_context_llvm.h \ rasterizer/scripts/gen_knobs.cpp \ rasterizer/scripts/gen_knobs.h \ rasterizer/jitter/state_llvm.h \ @@ -55,6 +56,12 @@ BUILT_SOURCES = \ rasterizer/jitter/builder_x86.h \ rasterizer/jitter/builder_x86.cpp +swr_context_llvm.h: rasterizer/jitter/scripts/gen_llvm_types.py swr_context.h + $(PYTHON2) $(PYTHON_FLAGS) \ + $(srcdir)/rasterizer/jitter/scripts/gen_llvm_types.py \ + --input $(srcdir)/swr_context.h \ + --output swr_context_llvm.h + rasterizer/scripts/gen_knobs.cpp rasterizer/scripts/gen_knobs.h: rasterizer/scripts/gen_knobs.py rasterizer/scripts/knob_defs.py rasterizer/scripts/templates/knobs.template $(PYTHON2) $(PYTHON_FLAGS) \ $(srcdir)/rasterizer/scripts/gen_knobs.py \ diff --git a/src/gallium/drivers/swr/Makefile.sources b/src/gallium/drivers/swr/Makefile.sources index be3d8f027f8..d8be0f5cca4 100644 --- a/src/gallium/drivers/swr/Makefile.sources +++ b/src/gallium/drivers/swr/Makefile.sources @@ -26,7 +26,6 @@ CXX_SOURCES := \ swr_clear.cpp \ swr_context.cpp \ swr_context.h \ - swr_context_llvm.h \ swr_draw.cpp \ swr_public.h \ swr_resource.h \ diff --git a/src/gallium/drivers/swr/rasterizer/jitter/scripts/gen_llvm_types.py b/src/gallium/drivers/swr/rasterizer/jitter/scripts/gen_llvm_types.py index 0b53a929e6c..d6babd39b6b 100644 --- a/src/gallium/drivers/swr/rasterizer/jitter/scripts/gen_llvm_types.py +++ b/src/gallium/drivers/swr/rasterizer/jitter/scripts/gen_llvm_types.py @@ -135,6 +135,9 @@ def gen_llvm_types(input_file, output_file): for idx in range(len(lines)): line = lines[idx].rstrip() + if "gen_llvm_types FINI" in line: + break + match = re.match(r"(\s*)struct(\s*)(\w+)", line) if match: llvm_args = [] diff --git a/src/gallium/drivers/swr/swr_context.h b/src/gallium/drivers/swr/swr_context.h index 73a8e8ddda1..a7383bbad28 100644 --- a/src/gallium/drivers/swr/swr_context.h +++ b/src/gallium/drivers/swr/swr_context.h @@ -65,7 +65,7 @@ struct swr_jit_texture { uint32_t depth; // doubles as array size uint32_t first_level; uint32_t last_level; - const void *base_ptr; + const uint8_t *base_ptr; uint32_t row_stride[PIPE_MAX_TEXTURE_LEVELS]; uint32_t img_stride[PIPE_MAX_TEXTURE_LEVELS]; uint32_t mip_offsets[PIPE_MAX_TEXTURE_LEVELS]; @@ -80,9 +80,9 @@ struct swr_jit_sampler { struct swr_draw_context { const float *constantVS[PIPE_MAX_CONSTANT_BUFFERS]; - unsigned num_constantsVS[PIPE_MAX_CONSTANT_BUFFERS]; + uint32_t num_constantsVS[PIPE_MAX_CONSTANT_BUFFERS]; const float *constantFS[PIPE_MAX_CONSTANT_BUFFERS]; - unsigned num_constantsFS[PIPE_MAX_CONSTANT_BUFFERS]; + uint32_t num_constantsFS[PIPE_MAX_CONSTANT_BUFFERS]; swr_jit_texture texturesVS[PIPE_MAX_SHADER_SAMPLER_VIEWS]; swr_jit_sampler samplersVS[PIPE_MAX_SAMPLERS]; @@ -92,6 +92,8 @@ struct swr_draw_context { SWR_SURFACE_STATE renderTargets[SWR_NUM_ATTACHMENTS]; }; +/* gen_llvm_types FINI */ + struct swr_context { struct pipe_context pipe; /**< base class */ diff --git a/src/gallium/drivers/swr/swr_context_llvm.h b/src/gallium/drivers/swr/swr_context_llvm.h deleted file mode 100644 index 58da813123f..00000000000 --- a/src/gallium/drivers/swr/swr_context_llvm.h +++ /dev/null @@ -1,124 +0,0 @@ -/**************************************************************************** - * Copyright (C) 2015 Intel Corporation. All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice (including the next - * paragraph) shall be included in all copies or substantial portions of the - * Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING - * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS - * IN THE SOFTWARE. - ***************************************************************************/ - -#pragma once - -////////////////////////////////////////////////////////////////////////// -/// Generate LLVM type information for swr_jit_texture -INLINE static StructType * -Gen_swr_jit_texture(JitManager *pShG) -{ - LLVMContext &ctx = pShG->mContext; - std::vector members; - - members.push_back(Type::getInt32Ty(ctx)); // width - members.push_back(Type::getInt32Ty(ctx)); // height - members.push_back(Type::getInt32Ty(ctx)); // depth - members.push_back(Type::getInt32Ty(ctx)); // first_level - members.push_back(Type::getInt32Ty(ctx)); // last_level - members.push_back(PointerType::get(Type::getInt8Ty(ctx), 0)); // base_ptr - members.push_back(ArrayType::get(Type::getInt32Ty(ctx), - PIPE_MAX_TEXTURE_LEVELS)); // row_stride - members.push_back(ArrayType::get(Type::getInt32Ty(ctx), - PIPE_MAX_TEXTURE_LEVELS)); // img_stride - members.push_back(ArrayType::get(Type::getInt32Ty(ctx), - PIPE_MAX_TEXTURE_LEVELS)); // mip_offsets - - return StructType::get(ctx, members, false); -} - -static const UINT swr_jit_texture_width = 0; -static const UINT swr_jit_texture_height = 1; -static const UINT swr_jit_texture_depth = 2; -static const UINT swr_jit_texture_first_level = 3; -static const UINT swr_jit_texture_last_level = 4; -static const UINT swr_jit_texture_base_ptr = 5; -static const UINT swr_jit_texture_row_stride = 6; -static const UINT swr_jit_texture_img_stride = 7; -static const UINT swr_jit_texture_mip_offsets = 8; - -////////////////////////////////////////////////////////////////////////// -/// Generate LLVM type information for swr_jit_sampler -INLINE static StructType * -Gen_swr_jit_sampler(JitManager *pShG) -{ - LLVMContext &ctx = pShG->mContext; - std::vector members; - - members.push_back(Type::getFloatTy(ctx)); // min_lod - members.push_back(Type::getFloatTy(ctx)); // max_lod - members.push_back(Type::getFloatTy(ctx)); // lod_bias - members.push_back( - ArrayType::get(Type::getFloatTy(ctx), 4)); // border_color - - return StructType::get(ctx, members, false); -} - -static const UINT swr_jit_sampler_min_lod = 0; -static const UINT swr_jit_sampler_max_lod = 1; -static const UINT swr_jit_sampler_lod_bias = 2; -static const UINT swr_jit_sampler_border_color = 3; - -////////////////////////////////////////////////////////////////////////// -/// Generate LLVM type information for swr_draw_context -INLINE static StructType * -Gen_swr_draw_context(JitManager *pShG) -{ - LLVMContext &ctx = pShG->mContext; - std::vector members; - - members.push_back( - ArrayType::get(PointerType::get(Type::getFloatTy(ctx), 0), - PIPE_MAX_CONSTANT_BUFFERS)); // constantVS - members.push_back(ArrayType::get( - Type::getInt32Ty(ctx), PIPE_MAX_CONSTANT_BUFFERS)); // num_constantsVS - members.push_back( - ArrayType::get(PointerType::get(Type::getFloatTy(ctx), 0), - PIPE_MAX_CONSTANT_BUFFERS)); // constantFS - members.push_back(ArrayType::get( - Type::getInt32Ty(ctx), PIPE_MAX_CONSTANT_BUFFERS)); // num_constantsFS - members.push_back( - ArrayType::get(Gen_swr_jit_texture(pShG), - PIPE_MAX_SHADER_SAMPLER_VIEWS)); // texturesVS - members.push_back(ArrayType::get(Gen_swr_jit_sampler(pShG), - PIPE_MAX_SAMPLERS)); // samplersVS - members.push_back( - ArrayType::get(Gen_swr_jit_texture(pShG), - PIPE_MAX_SHADER_SAMPLER_VIEWS)); // texturesFS - members.push_back(ArrayType::get(Gen_swr_jit_sampler(pShG), - PIPE_MAX_SAMPLERS)); // samplersFS - members.push_back(ArrayType::get(Gen_SWR_SURFACE_STATE(pShG), - SWR_NUM_ATTACHMENTS)); // renderTargets - - return StructType::get(ctx, members, false); -} - -static const UINT swr_draw_context_constantVS = 0; -static const UINT swr_draw_context_num_constantsVS = 1; -static const UINT swr_draw_context_constantFS = 2; -static const UINT swr_draw_context_num_constantsFS = 3; -static const UINT swr_draw_context_texturesVS = 4; -static const UINT swr_draw_context_samplersVS = 5; -static const UINT swr_draw_context_texturesFS = 6; -static const UINT swr_draw_context_samplersFS = 7; -static const UINT swr_draw_context_renderTargets = 8;