1*9880d681SAndroid Build Coastguard Worker(* RUN: cp %s %T/bitreader.ml 2*9880d681SAndroid Build Coastguard Worker * RUN: %ocamlc -g -w +A -package llvm.bitreader -package llvm.bitwriter -linkpkg %T/bitreader.ml -o %t 3*9880d681SAndroid Build Coastguard Worker * RUN: %t %t.bc 4*9880d681SAndroid Build Coastguard Worker * RUN: %ocamlopt -g -w +A -package llvm.bitreader -package llvm.bitwriter -linkpkg %T/bitreader.ml -o %t 5*9880d681SAndroid Build Coastguard Worker * RUN: %t %t.bc 6*9880d681SAndroid Build Coastguard Worker * RUN: llvm-dis < %t.bc 7*9880d681SAndroid Build Coastguard Worker * XFAIL: vg_leak 8*9880d681SAndroid Build Coastguard Worker *) 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker(* Note that this takes a moment to link, so it's best to keep the number of 11*9880d681SAndroid Build Coastguard Worker individual tests low. *) 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerlet context = Llvm.global_context () 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workerlet diagnostic_handler _ = () 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerlet test x = if not x then exit 1 else () 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Workerlet _ = 20*9880d681SAndroid Build Coastguard Worker Llvm.set_diagnostic_handler context (Some diagnostic_handler); 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker let fn = Sys.argv.(1) in 23*9880d681SAndroid Build Coastguard Worker let m = Llvm.create_module context "ocaml_test_module" in 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker test (Llvm_bitwriter.write_bitcode_file m fn); 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Worker Llvm.dispose_module m; 28*9880d681SAndroid Build Coastguard Worker 29*9880d681SAndroid Build Coastguard Worker (* parse_bitcode *) 30*9880d681SAndroid Build Coastguard Worker begin 31*9880d681SAndroid Build Coastguard Worker let mb = Llvm.MemoryBuffer.of_file fn in 32*9880d681SAndroid Build Coastguard Worker begin try 33*9880d681SAndroid Build Coastguard Worker let m = Llvm_bitreader.parse_bitcode context mb in 34*9880d681SAndroid Build Coastguard Worker Llvm.dispose_module m 35*9880d681SAndroid Build Coastguard Worker with x -> 36*9880d681SAndroid Build Coastguard Worker Llvm.MemoryBuffer.dispose mb; 37*9880d681SAndroid Build Coastguard Worker raise x 38*9880d681SAndroid Build Coastguard Worker end 39*9880d681SAndroid Build Coastguard Worker end; 40*9880d681SAndroid Build Coastguard Worker 41*9880d681SAndroid Build Coastguard Worker (* MemoryBuffer.of_file *) 42*9880d681SAndroid Build Coastguard Worker test begin try 43*9880d681SAndroid Build Coastguard Worker let mb = Llvm.MemoryBuffer.of_file (fn ^ ".bogus") in 44*9880d681SAndroid Build Coastguard Worker Llvm.MemoryBuffer.dispose mb; 45*9880d681SAndroid Build Coastguard Worker false 46*9880d681SAndroid Build Coastguard Worker with Llvm.IoError _ -> 47*9880d681SAndroid Build Coastguard Worker true 48*9880d681SAndroid Build Coastguard Worker end; 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Worker (* get_module *) 51*9880d681SAndroid Build Coastguard Worker begin 52*9880d681SAndroid Build Coastguard Worker let mb = Llvm.MemoryBuffer.of_file fn in 53*9880d681SAndroid Build Coastguard Worker let m = begin try 54*9880d681SAndroid Build Coastguard Worker Llvm_bitreader.get_module context mb 55*9880d681SAndroid Build Coastguard Worker with x -> 56*9880d681SAndroid Build Coastguard Worker Llvm.MemoryBuffer.dispose mb; 57*9880d681SAndroid Build Coastguard Worker raise x 58*9880d681SAndroid Build Coastguard Worker end in 59*9880d681SAndroid Build Coastguard Worker Llvm.dispose_module m 60*9880d681SAndroid Build Coastguard Worker end; 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker (* corrupt the bitcode *) 63*9880d681SAndroid Build Coastguard Worker let fn = fn ^ ".txt" in 64*9880d681SAndroid Build Coastguard Worker begin let oc = open_out fn in 65*9880d681SAndroid Build Coastguard Worker output_string oc "not a bitcode file\n"; 66*9880d681SAndroid Build Coastguard Worker close_out oc 67*9880d681SAndroid Build Coastguard Worker end; 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker (* test get_module exceptions *) 70*9880d681SAndroid Build Coastguard Worker test begin 71*9880d681SAndroid Build Coastguard Worker try 72*9880d681SAndroid Build Coastguard Worker let mb = Llvm.MemoryBuffer.of_file fn in 73*9880d681SAndroid Build Coastguard Worker let m = begin try 74*9880d681SAndroid Build Coastguard Worker Llvm_bitreader.get_module context mb 75*9880d681SAndroid Build Coastguard Worker with x -> 76*9880d681SAndroid Build Coastguard Worker Llvm.MemoryBuffer.dispose mb; 77*9880d681SAndroid Build Coastguard Worker raise x 78*9880d681SAndroid Build Coastguard Worker end in 79*9880d681SAndroid Build Coastguard Worker Llvm.dispose_module m; 80*9880d681SAndroid Build Coastguard Worker false 81*9880d681SAndroid Build Coastguard Worker with Llvm_bitreader.Error _ -> 82*9880d681SAndroid Build Coastguard Worker true 83*9880d681SAndroid Build Coastguard Worker end 84