[sledge] Treat .bc or .ll input files as pre-linked bitcode

Summary:
If the input file has a .bc or .ll suffix, treat it as a pre-linked
bitcode file. Otherwise, treat it as before, as a file containing a
list of bitcode files to be linked. Also, perform global dead-code
elimination only when linking multiple files.

Reviewed By: kren1

Differential Revision: D15513345

fbshipit-source-id: 4c80ff9c3
master
Josh Berdine 6 years ago committed by Facebook Github Bot
parent 7ac04fa46a
commit 611fb57d3a

@ -1331,10 +1331,10 @@ let xlate_function : x -> Llvm.llvalue -> Llair.func =
|> |>
[%Trace.retn fun {pf} -> pf "@\n%a" Llair.Func.pp] [%Trace.retn fun {pf} -> pf "@\n%a" Llair.Func.pp]
let transform : Llvm.llmodule -> unit = let transform ~gdce : Llvm.llmodule -> unit =
fun llmodule -> fun llmodule ->
let pm = Llvm.PassManager.create () in let pm = Llvm.PassManager.create () in
Llvm_ipo.add_internalize pm ~all_but_main:true ; if gdce then Llvm_ipo.add_internalize pm ~all_but_main:true ;
Llvm_ipo.add_global_dce pm ; Llvm_ipo.add_global_dce pm ;
Llvm_scalar_opts.add_lower_atomic pm ; Llvm_scalar_opts.add_lower_atomic pm ;
Llvm_scalar_opts.add_scalar_repl_aggregation pm ; Llvm_scalar_opts.add_scalar_repl_aggregation pm ;
@ -1350,6 +1350,22 @@ let translate : string -> Llair.t =
; ;
Llvm.install_fatal_error_handler invalid_llvm ; Llvm.install_fatal_error_handler invalid_llvm ;
let llcontext = Llvm.global_context () in let llcontext = Llvm.global_context () in
let read_and_parse bc_file =
let llmemorybuffer =
try Llvm.MemoryBuffer.of_file bc_file
with Llvm.IoError msg -> fail "%s: %s" bc_file msg ()
in
try Llvm_irreader.parse_ir llcontext llmemorybuffer
with Llvm_irreader.Error msg -> invalid_llvm msg
in
let single_bc_input =
List.exists
~f:(fun suffix -> String.is_suffix file ~suffix)
[".bc"; ".ll"]
in
let llmodule =
if single_bc_input then read_and_parse file
else
let llmodule = let llmodule =
let model_memorybuffer = let model_memorybuffer =
Llvm.MemoryBuffer.of_string Llvm.MemoryBuffer.of_string
@ -1358,22 +1374,17 @@ let translate : string -> Llair.t =
Llvm_irreader.parse_ir llcontext model_memorybuffer Llvm_irreader.parse_ir llcontext model_memorybuffer
in in
let link_ctx = Llvm_linker.get_linker llmodule in let link_ctx = Llvm_linker.get_linker llmodule in
In_channel.with_file file let link_in bc_file =
~f:
(In_channel.iter_lines ~f:(fun bc_file ->
[%Trace.info "linking in %s" bc_file] ; [%Trace.info "linking in %s" bc_file] ;
let llmemorybuffer = let newmodule = read_and_parse bc_file in
try Llvm.MemoryBuffer.of_file bc_file Llvm_linker.link_in link_ctx newmodule
with Llvm.IoError msg -> fail "%s: %s" bc_file msg ()
in in
let newmodule = In_channel.with_file file ~f:(In_channel.iter_lines ~f:link_in) ;
try Llvm_irreader.parse_ir llcontext llmemorybuffer
with Llvm_irreader.Error msg -> invalid_llvm msg
in
Llvm_linker.link_in link_ctx newmodule )) ;
Llvm_linker.linker_dispose link_ctx ; Llvm_linker.linker_dispose link_ctx ;
llmodule
in
Llvm_analysis.verify_module llmodule |> Option.iter ~f:invalid_llvm ; Llvm_analysis.verify_module llmodule |> Option.iter ~f:invalid_llvm ;
transform llmodule ; transform ~gdce:(not single_bc_input) llmodule ;
scan_locs llmodule ; scan_locs llmodule ;
scan_names llmodule ; scan_names llmodule ;
let lldatalayout = let lldatalayout =

Loading…
Cancel
Save