From f5f1bbcb5c66c55a45e47c71685ca6709b714390 Mon Sep 17 00:00:00 2001 From: Tim Rowley Date: Thu, 28 Dec 2017 17:56:03 -0600 Subject: [PATCH] swr/rast: autogenerate named structs instead of literal structs Results in far smaller and useful IR output. Reviewed-by: Bruce Cherniak --- .../rasterizer/codegen/templates/gen_llvm.hpp | 23 ++++++++++++------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/src/gallium/drivers/swr/rasterizer/codegen/templates/gen_llvm.hpp b/src/gallium/drivers/swr/rasterizer/codegen/templates/gen_llvm.hpp index 18ea7817137..574ee5aaa79 100644 --- a/src/gallium/drivers/swr/rasterizer/codegen/templates/gen_llvm.hpp +++ b/src/gallium/drivers/swr/rasterizer/codegen/templates/gen_llvm.hpp @@ -40,15 +40,22 @@ namespace SwrJit INLINE static StructType *Gen_${type['name']}(JitManager* pJitMgr) { LLVMContext& ctx = pJitMgr->mContext; - std::vector members; - <% - (max_type_len, max_name_len) = calc_max_len(type['members']) - %> - %for member in type['members']: - /* ${member['name']} ${pad(len(member['name']), max_name_len)}*/ members.push_back( ${member['type']} ); - %endfor - return StructType::get(ctx, members, false); + StructType* pRetType = pJitMgr->mpCurrentModule->getTypeByName("${type['name']}"); + if (pRetType == nullptr) + { + std::vector members; + <% + (max_type_len, max_name_len) = calc_max_len(type['members']) + %> + %for member in type['members']: + /* ${member['name']} ${pad(len(member['name']), max_name_len)}*/ members.push_back(${ member['type'] }); + %endfor + + pRetType = StructType::create(members, "${type['name']}", false); + } + + return pRetType; } %for member in type['members']: -- 2.30.2