Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Adding a function in LLVM (haskell bindings) when the number of parameters is not known at compile time

Background: I have written a toy Lisp interpreter that I am trying to add LLVM JIT functionality to. For the moment, have imposed the following limitations:

  • Only integer values are allowed in functions
  • Variables may only reference formal parameters

Given:

compile :: [Value] -- List of Formal Parameters
        -> [Value] -- Body of function
        -> CodeGenModule(Function a)`

Question: How do I generate a function where the number of parameters equals the length of the Formal Parameters list?

like image 954
John F. Miller Avatar asked Jun 23 '11 02:06

John F. Miller


1 Answers

I don't know if it's possible to do this with just the EDSL from LLVM.Core (the types are indeed quite hairy), but if you look at LLVM.FFI.Core, you'll find the lower-level functionality for manipulating LLVM function types and creating LLVM functions. This leads to the following plan of action:

  • Create a TypeRef for your function with functionType.
  • Add this function to your module using addFunction.
  • Populate it with basic blocks by using appendBasicBlock/insertBasicBlock. Use getParam to reference function arguments inside your basic blocks.

It should be possible to utilise the nice monadic EDSL syntax for constructing the basic blocks. Also, look at LLVM.Core.Util, it contains some helper functions for working with the FFI layer.

like image 158
Mikhail Glushenkov Avatar answered Nov 11 '22 09:11

Mikhail Glushenkov