Henning Thielemann
2012-May-23 22:38 UTC
[LLVMdev] tblgen for generation of Haskell bindings to LLVM intrinsics
I want to generate Haskell bindings to LLVM intrinsics. In a first attempt I wrote a little parser that reads IntrinsicsX86.td and outputs a Haskell module. E.g. the definition def int_x86_avx_max_ps_256 : GCCBuiltin<"__builtin_ia32_maxps256">, Intrinsic<[llvm_v8f32_ty], [llvm_v8f32_ty, llvm_v8f32_ty], [IntrNoMem]>; is turned into maxpd256 :: Ext.T (V4Double -> V4Double -> LLVM.CodeGenFunction r V4Double) maxpd256 = Ext.intrinsic ExtX86.avx "max.pd.256" This works for the flat structure of IntrinsicsX86.td, but e.g. IntrinsicsPowerPC.td uses tablegen classes. Now I wonder whether it is better to use tablegen to generate the Haskell code. The tblgen man page says, that tablegen emits C++. This would not be a big problem, since I could let it write C++ code that in turn writes Haskell code. Unfortunately the section "llvm.org/docs/TableGenFundamentals.html#backends" is not yet written. Is it possible to use the llvm-tblgen binary without modification or do I have to extend llvm-tblgen or do I have to write my own C++ code that uses some of the functions from the tblgen library? Are there any (simple) examples of custom tblgen backends?
Sebastian Redl
2012-May-24 08:37 UTC
[LLVMdev] tblgen for generation of Haskell bindings to LLVM intrinsics
On 24.05.2012 00:38, Henning Thielemann wrote:> I want to generate Haskell bindings to LLVM intrinsics. In a first attempt I > wrote a little parser that reads IntrinsicsX86.td and outputs a Haskell module. > > E.g. the definition > > def int_x86_avx_max_ps_256 : GCCBuiltin<"__builtin_ia32_maxps256">, > Intrinsic<[llvm_v8f32_ty], [llvm_v8f32_ty, > llvm_v8f32_ty], [IntrNoMem]>; > > is turned into > > maxpd256 :: Ext.T (V4Double -> V4Double -> LLVM.CodeGenFunction r V4Double) > maxpd256 = Ext.intrinsic ExtX86.avx "max.pd.256" > > > This works for the flat structure of IntrinsicsX86.td, but e.g. > IntrinsicsPowerPC.td uses tablegen classes. > > Now I wonder whether it is better to use tablegen to generate the Haskell code. > The tblgen man page says, that tablegen emits C++.It emits whatever text a particular backend decides to spit out. You would have to write your own backend anyway, so you can just make it emit Haskell code. Writing a backend isn't hard - a rather simple one to look at would be Clang's diagnostic generator (it's in the Clang tree). Sebastian