From e2936c1a54053611d411ba5e19ac9fa11994a141 Mon Sep 17 00:00:00 2001 From: Josh Berdine Date: Fri, 9 Apr 2021 08:12:43 -0700 Subject: [PATCH] [sledge][llvm] Code simplification using option allocation functions Summary: Using the `caml_alloc_some` and `ptr_to_option` functions that allocate OCaml `option` values enables simplifications in many cases. These simplifications also result in avoiding unnecessary double initialization in many cases, so yield a minor optimization as well. Also, change to avoid using the old unprefixed functions such as `alloc_small` and instead use the current `caml_alloc_small`. A few of the changed functions were slightly rewritten in the early-return style. Upstream Differential Revision: https://reviews.llvm.org/D99473 Reviewed By: ngorogiannis Differential Revision: D27564884 fbshipit-source-id: 17883785c --- .../llvm/bindings/ocaml/llvm/llvm_ocaml.c | 154 +++++------------- 1 file changed, 37 insertions(+), 117 deletions(-) diff --git a/sledge/vendor/llvm-dune/llvm-project/llvm/bindings/ocaml/llvm/llvm_ocaml.c b/sledge/vendor/llvm-dune/llvm-project/llvm/bindings/ocaml/llvm/llvm_ocaml.c index 799b76d28..e9fa052d8 100644 --- a/sledge/vendor/llvm-dune/llvm-project/llvm/bindings/ocaml/llvm/llvm_ocaml.c +++ b/sledge/vendor/llvm-dune/llvm-project/llvm/bindings/ocaml/llvm/llvm_ocaml.c @@ -121,7 +121,7 @@ CAMLprim value llvm_parse_command_line_options(value Overview, value Args) { } static value alloc_variant(int tag, void *Value) { - value Iter = alloc_small(1, tag); + value Iter = caml_alloc_small(1, tag); Field(Iter, 0) = Val_op(Value); return Iter; } @@ -191,7 +191,7 @@ static void llvm_remove_diagnostic_handler(LLVMContextRef C) { /* llcontext -> (Diagnostic.t -> unit) option -> unit */ CAMLprim value llvm_set_diagnostic_handler(LLVMContextRef C, value Handler) { llvm_remove_diagnostic_handler(C); - if (Handler == Val_int(0)) { + if (Handler == Val_none) { LLVMContextSetDiagnosticHandler(C, NULL, NULL); } else { value *DiagnosticContext = malloc(sizeof(value)); @@ -556,7 +556,7 @@ CAMLprim value llvm_struct_name(LLVMTypeRef Ty) { const char *CStr = LLVMGetStructName(Ty); size_t Len; if (!CStr) - return Val_int(0); + return Val_none; Len = strlen(CStr); return cstr_to_string_option(CStr, Len); } @@ -652,16 +652,10 @@ CAMLprim LLVMTypeRef llvm_x86_mmx_type(LLVMContextRef Context) { return LLVMX86MMXTypeInContext(Context); } -CAMLprim value llvm_type_by_name(LLVMModuleRef M, value Name) -{ +CAMLprim value llvm_type_by_name(LLVMModuleRef M, value Name) { CAMLparam1(Name); LLVMTypeRef Ty = LLVMGetTypeByName(M, String_val(Name)); - if (Ty) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) Ty; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + CAMLreturn(ptr_to_option(Ty)); } /*===-- VALUES ------------------------------------------------------------===*/ @@ -846,13 +840,7 @@ CAMLprim value llvm_has_metadata(LLVMValueRef Val) { /* llvalue -> int -> llvalue option */ CAMLprim value llvm_metadata(LLVMValueRef Val, value MDKindID) { CAMLparam1(MDKindID); - LLVMValueRef MD; - if ((MD = LLVMGetMetadata(Val, Int_val(MDKindID)))) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) MD; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + CAMLreturn(ptr_to_option(LLVMGetMetadata(Val, Int_val(MDKindID)))); } /* llvalue -> int -> llvalue -> unit */ @@ -1053,16 +1041,11 @@ CAMLprim LLVMValueRef llvm_const_of_int64(LLVMTypeRef IntTy, value N, } /* llvalue -> Int64.t */ -CAMLprim value llvm_int64_of_const(LLVMValueRef Const) -{ - CAMLparam0(); - if (LLVMIsAConstantInt(Const) && - LLVMGetIntTypeWidth(LLVMTypeOf(Const)) <= 64) { - value Option = alloc(1, 0); - Field(Option, 0) = caml_copy_int64(LLVMConstIntGetSExtValue(Const)); - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); +CAMLprim value llvm_int64_of_const(LLVMValueRef Const) { + if (!(LLVMIsAConstantInt(Const)) || + !(LLVMGetIntTypeWidth(LLVMTypeOf(Const)) <= 64)) + return Val_none; + return caml_alloc_some(caml_copy_int64(LLVMConstIntGetSExtValue(Const))); } /* lltype -> string -> int -> llvalue */ @@ -1077,26 +1060,19 @@ CAMLprim LLVMValueRef llvm_const_float(LLVMTypeRef RealTy, value N) { return LLVMConstReal(RealTy, Double_val(N)); } - /* llvalue -> float */ -CAMLprim value llvm_float_of_const(LLVMValueRef Const) -{ - CAMLparam0(); - CAMLlocal1(Option); +CAMLprim value llvm_float_of_const(LLVMValueRef Const) { LLVMBool LosesInfo; double Result; - if (LLVMIsAConstantFP(Const)) { - Result = LLVMConstRealGetDouble(Const, &LosesInfo); - if (LosesInfo) - CAMLreturn(Val_int(0)); + if (!LLVMIsAConstantFP(Const)) + return Val_none; - Option = alloc(1, 0); - Field(Option, 0) = caml_copy_double(Result); - CAMLreturn(Option); - } + Result = LLVMConstRealGetDouble(Const, &LosesInfo); + if (LosesInfo) + return Val_none; - CAMLreturn(Val_int(0)); + return caml_alloc_some(caml_copy_double(Result)); } /* lltype -> string -> llvalue */ @@ -1157,7 +1133,7 @@ CAMLprim value llvm_string_of_const(LLVMValueRef Const) { size_t Len; const char *CStr; if (!LLVMIsAConstantDataSequential(Const) || !LLVMIsConstantString(Const)) - return Val_int(0); + return Val_none; CStr = LLVMGetAsString(Const, &Len); return cstr_to_string_option(CStr, Len); } @@ -1341,26 +1317,12 @@ CAMLprim value llvm_global_copy_all_metadata(LLVMValueRef Global) { /* llvalue -> lluse option */ CAMLprim value llvm_use_begin(LLVMValueRef Val) { - CAMLparam0(); - LLVMUseRef First; - if ((First = LLVMGetFirstUse(Val))) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) First; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + return ptr_to_option(LLVMGetFirstUse(Val)); } /* lluse -> lluse option */ CAMLprim value llvm_use_succ(LLVMUseRef U) { - CAMLparam0(); - LLVMUseRef Next; - if ((Next = LLVMGetNextUse(U))) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) Next; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + return ptr_to_option(LLVMGetNextUse(U)); } /* lluse -> llvalue */ @@ -1408,13 +1370,7 @@ CAMLprim LLVMValueRef llvm_declare_qualified_global(LLVMTypeRef Ty, value Name, /* string -> llmodule -> llvalue option */ CAMLprim value llvm_lookup_global(value Name, LLVMModuleRef M) { CAMLparam1(Name); - LLVMValueRef GlobalVar; - if ((GlobalVar = LLVMGetNamedGlobal(M, String_val(Name)))) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) GlobalVar; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + CAMLreturn(ptr_to_option(LLVMGetNamedGlobal(M, String_val(Name)))); } /* string -> llvalue -> llmodule -> llvalue */ @@ -1537,13 +1493,7 @@ CAMLprim LLVMValueRef llvm_declare_function(value Name, LLVMTypeRef Ty, /* string -> llmodule -> llvalue option */ CAMLprim value llvm_lookup_function(value Name, LLVMModuleRef M) { CAMLparam1(Name); - LLVMValueRef Fn; - if ((Fn = LLVMGetNamedFunction(M, String_val(Name)))) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) Fn; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + CAMLreturn(ptr_to_option(LLVMGetNamedFunction(M, String_val(Name)))); } /* string -> lltype -> llmodule -> llvalue */ @@ -1578,24 +1528,17 @@ CAMLprim value llvm_set_function_call_conv(value Id, LLVMValueRef Fn) { /* llvalue -> string option */ CAMLprim value llvm_gc(LLVMValueRef Fn) { - const char *GC; - CAMLparam0(); - CAMLlocal2(Name, Option); + const char *GC = LLVMGetGC(Fn); - if ((GC = LLVMGetGC(Fn))) { - Name = caml_copy_string(GC); + if (!GC) + return Val_none; - Option = alloc(1, 0); - Field(Option, 0) = Name; - CAMLreturn(Option); - } else { - CAMLreturn(Val_int(0)); - } + return caml_alloc_some(caml_copy_string(GC)); } /* string option -> llvalue -> unit */ CAMLprim value llvm_set_gc(value GC, LLVMValueRef Fn) { - LLVMSetGC(Fn, GC == Val_int(0)? 0 : String_val(Field(GC, 0))); + LLVMSetGC(Fn, GC == Val_none ? 0 : String_val(Field(GC, 0))); return Val_unit; } @@ -1652,16 +1595,8 @@ DEFINE_ITERATORS( block, BasicBlock, LLVMValueRef, LLVMBasicBlockRef, LLVMGetBasicBlockParent) /* llbasicblock -> llvalue option */ -CAMLprim value llvm_block_terminator(LLVMBasicBlockRef Block) -{ - CAMLparam0(); - LLVMValueRef Term = LLVMGetBasicBlockTerminator(Block); - if (Term) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) Term; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); +CAMLprim value llvm_block_terminator(LLVMBasicBlockRef Block) { + return ptr_to_option(LLVMGetBasicBlockTerminator(Block)); } /* llvalue -> llbasicblock array */ @@ -1729,26 +1664,18 @@ CAMLprim value llvm_instr_get_opcode(LLVMValueRef Inst) { /* llvalue -> ICmp.t option */ CAMLprim value llvm_instr_icmp_predicate(LLVMValueRef Val) { - CAMLparam0(); int x = LLVMGetICmpPredicate(Val); - if (x) { - value Option = alloc(1, 0); - Field(Option, 0) = Val_int(x - LLVMIntEQ); - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + if (!x) + return Val_none; + return caml_alloc_some(Val_int(x - LLVMIntEQ)); } /* llvalue -> FCmp.t option */ CAMLprim value llvm_instr_fcmp_predicate(LLVMValueRef Val) { - CAMLparam0(); int x = LLVMGetFCmpPredicate(Val); - if (x) { - value Option = alloc(1, 0); - Field(Option, 0) = Val_int(x - LLVMRealPredicateFalse); - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + if (!x) + return Val_none; + return caml_alloc_some(Val_int(x - LLVMRealPredicateFalse)); } /* llvalue -> llvalue */ @@ -1983,14 +1910,7 @@ CAMLprim value llvm_clear_current_debug_location(value B) { /* llbuilder -> llvalue option */ CAMLprim value llvm_current_debug_location(value B) { - CAMLparam0(); - LLVMValueRef L; - if ((L = LLVMGetCurrentDebugLocation(Builder_val(B)))) { - value Option = alloc(1, 0); - Field(Option, 0) = (value) L; - CAMLreturn(Option); - } - CAMLreturn(Val_int(0)); + return ptr_to_option(LLVMGetCurrentDebugLocation(Builder_val(B))); } /* llbuilder -> llvalue -> unit */