summaryrefslogtreecommitdiff
path: root/test/Bindings
diff options
context:
space:
mode:
authorTorok Edwin <edwintorok@gmail.com>2010-12-23 15:49:26 +0000
committerTorok Edwin <edwintorok@gmail.com>2010-12-23 15:49:26 +0000
commita156efdf71bc668093e31593713694cf076db895 (patch)
treeffe6ac57259009a2b3b028e9289f5f8258e91601 /test/Bindings
parent9d071cbb92e2f28be2067fdb5cf21b396e34838d (diff)
downloadllvm-a156efdf71bc668093e31593713694cf076db895.tar.gz
llvm-a156efdf71bc668093e31593713694cf076db895.tar.bz2
llvm-a156efdf71bc668093e31593713694cf076db895.tar.xz
Fix OCaml bindings crash, PR8847.
See http://caml.inria.fr/mantis/view.php?id=4166 If we call only external functions from a module, then its 'let _' bindings don't get executed, which means that the exceptions don't get registered for use in the C code. This in turn causes llvm_raise to call raise_with_arg() with a NULL pointer and cause a segmentation fault. The workaround is to declare all 'external' functions as 'val' in these .mli files. Also added a separate testcase (the testcase must call only external functions for the bug to occur). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122497 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Bindings')
-rw-r--r--test/Bindings/Ocaml/ext_exc.ml16
1 files changed, 16 insertions, 0 deletions
diff --git a/test/Bindings/Ocaml/ext_exc.ml b/test/Bindings/Ocaml/ext_exc.ml
new file mode 100644
index 0000000000..79543515df
--- /dev/null
+++ b/test/Bindings/Ocaml/ext_exc.ml
@@ -0,0 +1,16 @@
+(* RUN: %ocamlopt -warn-error A llvm.cmxa llvm_bitreader.cmxa llvm_executionengine.cmxa %s -o %t
+ * RUN: %t </dev/null
+ *)
+let context = Llvm.global_context ()
+(* this used to crash, we must not use 'external' in .mli files, but 'val' if we
+ * want the let _ bindings executed, see http://caml.inria.fr/mantis/view.php?id=4166 *)
+let _ =
+ try
+ ignore (Llvm_bitreader.get_module context (Llvm.MemoryBuffer.of_stdin ()))
+ with
+ Llvm_bitreader.Error _ -> ();;
+let _ =
+ try
+ ignore (Llvm.MemoryBuffer.of_file "/path/to/nonexistent/file")
+ with
+ Llvm.IoError _ -> ();;