2017-08-16 04:29:24 +08:00
|
|
|
(* RUN: rm -rf %t && mkdir -p %t && cp %s %t/analysis.ml
|
|
|
|
* RUN: %ocamlc -g -w +A -package llvm.analysis -linkpkg %t/analysis.ml -o %t/executable
|
|
|
|
* RUN: %t/executable
|
|
|
|
* RUN: %ocamlopt -g -w +A -package llvm.analysis -linkpkg %t/analysis.ml -o %t/executable
|
|
|
|
* RUN: %t/executable
|
2010-09-09 23:50:19 +08:00
|
|
|
* XFAIL: vg_leak
|
2007-10-07 05:00:36 +08:00
|
|
|
*)
|
|
|
|
|
|
|
|
open Llvm
|
|
|
|
open Llvm_analysis
|
|
|
|
|
|
|
|
(* Note that this takes a moment to link, so it's best to keep the number of
|
|
|
|
individual tests low. *)
|
|
|
|
|
2009-08-20 01:32:24 +08:00
|
|
|
let context = global_context ()
|
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
let test x = if not x then exit 1 else ()
|
|
|
|
|
|
|
|
let bomb msg =
|
|
|
|
prerr_endline msg;
|
|
|
|
exit 2
|
|
|
|
|
|
|
|
let _ =
|
2009-08-20 01:32:24 +08:00
|
|
|
let fty = function_type (void_type context) [| |] in
|
|
|
|
let m = create_module context "valid_m" in
|
2007-10-07 05:00:36 +08:00
|
|
|
let fn = define_function "valid_fn" fty m in
|
2009-08-20 01:32:24 +08:00
|
|
|
let at_entry = builder_at_end context (entry_block fn) in
|
2007-10-07 05:00:36 +08:00
|
|
|
ignore (build_ret_void at_entry);
|
2014-10-29 06:39:42 +08:00
|
|
|
|
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
(* Test that valid constructs verify. *)
|
2007-12-02 04:59:23 +08:00
|
|
|
begin match verify_module m with
|
2007-10-07 05:00:36 +08:00
|
|
|
Some msg -> bomb "valid module failed verification!"
|
2007-12-02 04:59:23 +08:00
|
|
|
| None -> ()
|
|
|
|
end;
|
2014-10-29 06:39:42 +08:00
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
if not (verify_function fn) then bomb "valid function failed verification!";
|
2014-10-29 06:39:42 +08:00
|
|
|
|
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
(* Test that invalid constructs do not verify.
|
|
|
|
A basic block can contain only one terminator instruction. *)
|
|
|
|
ignore (build_ret_void at_entry);
|
2014-10-29 06:39:42 +08:00
|
|
|
|
2007-12-02 04:59:23 +08:00
|
|
|
begin match verify_module m with
|
2007-10-07 05:00:36 +08:00
|
|
|
Some msg -> ()
|
2007-12-02 04:59:23 +08:00
|
|
|
| None -> bomb "invalid module passed verification!"
|
|
|
|
end;
|
2014-10-29 06:39:42 +08:00
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
if verify_function fn then bomb "invalid function passed verification!";
|
2014-10-29 06:39:42 +08:00
|
|
|
|
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
dispose_module m
|
2014-10-29 06:39:42 +08:00
|
|
|
|
2007-10-07 05:00:36 +08:00
|
|
|
(* Don't bother to test assert_valid_{module,function}. *)
|