From: Tim Rowley Date: Thu, 28 Dec 2017 23:56:03 +0000 (-0600) Subject: swr/rast: autogenerate named structs instead of literal structs X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f5f1bbcb5c66c55a45e47c71685ca6709b714390;p=mesa.git swr/rast: autogenerate named structs instead of literal structs Results in far smaller and useful IR output. Reviewed-by: Bruce Cherniak --- 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']: