Skip to content

Commit

Permalink
crucible-llvm-syntax: Concrete syntax for loading function handles
Browse files Browse the repository at this point in the history
  • Loading branch information
langston-barrett committed Nov 9, 2023
1 parent de339d4 commit 8fda40b
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 1 deletion.
12 changes: 12 additions & 0 deletions crucible-llvm-syntax/src/Lang/Crucible/LLVM/Syntax.hs
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,18 @@ llvmAtomParser mvar =
let stmt = Ext.LLVM_Load mvar ptr tyRep storTy align
Some <$> Parse.freshAtom loc (Reg.EvalExt stmt)

Atom.AtomName "load-handle" -> Parse.describe "LLVM load-handle arguments" $ do
loc <- Parse.position
(Some ret, (Some args, assign)) <-
Parse.cons
Parse.isType
(Parse.cons
(Parse.someAssign "list of argument types" Parse.isType)
(Parse.operands (Ctx.Empty Ctx.:> LLVMPointerRepr ?ptrWidth)))
let (Ctx.Empty, ptr) = Ctx.decompose assign
let stmt = Ext.LLVM_LoadHandle mvar ptr args ret
Some <$> Parse.freshAtom loc (Reg.EvalExt stmt)

Atom.AtomName "store" -> Parse.describe "LLVM store arguments" $ do
loc <- Parse.position
Parse.depCons parseAlign $ \align ->
Expand Down
1 change: 1 addition & 0 deletions crucible-llvm-syntax/test-data/ptr.cbl
Original file line number Diff line number Diff line change
Expand Up @@ -20,5 +20,6 @@
(let voff (ptr-offset 8 v))
(assert! (equal? vblk0 vblk) "stored block numbers equal")
(assert! (equal? voff0 voff) "stored offsets equal")
(let h (load-handle (Ptr 64) ((Ptr 64)) a))

(return p)))
5 changes: 4 additions & 1 deletion crucible-llvm-syntax/test-data/ptr.out.good
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
(let voff (ptr-offset 8 v))
(assert! (equal? vblk0 vblk) "stored block numbers equal")
(assert! (equal? voff0 voff) "stored offsets equal")
(let h (load-handle (Ptr 64) ((Ptr 64)) a))
(return p)))

test-ptr
Expand Down Expand Up @@ -77,6 +78,8 @@ test-ptr
$22 = stringLit("stored offsets equal")
% 22:5
assert($21, $22)
% 24:5
% 23:12
$23 = loadFunctionHandle crucible-llvm-syntax-test-memory $12
% 25:5
return $4
% no postdom

0 comments on commit 8fda40b

Please sign in to comment.