[haskell-llvm] [Haskell-cafe] LLVM, getElementPtr?

Lally Singh lally.singh at gmail.com
Sun Dec 5 15:35:55 EST 2010


Thanks for your help.  Replying inline

On Sun, Dec 5, 2010 at 1:28 PM, Henning Thielemann
<lemming at henning-thielemann.de> wrote:
>
> On Sun, 5 Dec 2010, Lally Singh wrote:
>
>> Hey all, I'm trying to get started generating LLVM code, but I'm
>> getting a rather cryptic error.
>
> Btw. there is haskell-llvm at projects.haskell.org
>
>> buildReaderFun :: String -> CodeGenModule (Function (IO ()))
>> buildReaderFun nm = do
>>  puts <- newNamedFunction ExternalLinkage "puts" :: TFunction (Ptr
>> Word8 -> IO Word32)
>>  greetz <- createStringNul nm
>>  func <- createFunction ExternalLinkage $ do
>>   tmp <- getElementPtr0 greetz (0 :: Word32, ())
>
> You have to add a type annotation to greetz like
>   (greetz :: Array D42 Word8)
>  which limits your string to a length of 42 bytes.
>
> If you do not know the length, better use withStringNul.
> I implemented the current behavior, because the former implementation was
> unsafe.

I'm sorry, the type signature for withStringNul is over my head.
withStringNul ::
   String ->
   (forall n. (Nat n) => Global (Array n Word8) -> CodeGenModule a) ->
   CodeGenModule a

On the LLVM side, I'm looking to simply create a string constant I can
pass in, such as ConstantArray::get(..).

I *think* withStringNul will generate code to build a runtime-length
determined string?   Sorry, I'm a little thick.

>>   call puts  tmp -- Throw away return value.
>>   ret ()
>>  return func
>>
>> My attempts at figuring out what type-level has to do with this, and
>> how to satisfy it have so far proven unsuccessful.
>
> type-level provides type level integers, and thus allows for static checking
> of sizes, such as the number of bits of an integer type.

Thanks -- sorry -- I'm guessing it's to make sure we're generating valid code?

Cheers,
-Lally



More information about the Haskell-llvm mailing list