diff options
author | whitequark <whitequark@whitequark.org> | 2018-11-08 04:00:18 +0000 |
---|---|---|
committer | whitequark <whitequark@whitequark.org> | 2018-11-08 04:00:18 +0000 |
commit | 9ac4c44c949de9dbe4dc01b1d52885cc066c073b (patch) | |
tree | 895e5248392917c566bbb3cca52876a402456eb7 /bindings | |
parent | 19a9621221e759cada6a36f1f8b26840e5f23037 (diff) | |
download | llvm-9ac4c44c949de9dbe4dc01b1d52885cc066c073b.tar.gz |
[OCaml] Fix incorrect use of CAMLlocal in nested blocks
Summary:
The OCaml manual states:
> Local variables of type value must be declared with one of the
> CAMLlocal macros. [...] These macros must be used at the beginning
> of the function, not in a nested block.
This patch moves several instances of CAMLlocal macros from nested
blocks to the function beginning.
Reviewers: whitequark
Reviewed By: whitequark
Subscribers: CodaFi, llvm-commits
Differential Revision: https://reviews.llvm.org/D53841
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@346387 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'bindings')
-rw-r--r-- | bindings/ocaml/llvm/llvm_ocaml.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/bindings/ocaml/llvm/llvm_ocaml.c b/bindings/ocaml/llvm/llvm_ocaml.c index c637941d81d3..cdf6c6a1206a 100644 --- a/bindings/ocaml/llvm/llvm_ocaml.c +++ b/bindings/ocaml/llvm/llvm_ocaml.c @@ -483,9 +483,9 @@ CAMLprim value llvm_struct_set_body(LLVMTypeRef Ty, CAMLprim value llvm_struct_name(LLVMTypeRef Ty) { CAMLparam0(); + CAMLlocal1(result); const char *C = LLVMGetStructName(Ty); if (C) { - CAMLlocal1(result); result = caml_alloc_small(1, 0); Store_field(result, 0, caml_copy_string(C)); CAMLreturn(result); @@ -636,6 +636,7 @@ enum ValueKind { CAMLprim value llvm_classify_value(LLVMValueRef Val) { CAMLparam0(); + CAMLlocal1(result); if (!Val) CAMLreturn(Val_int(NullValue)); if (LLVMIsAConstant(Val)) { @@ -652,7 +653,6 @@ CAMLprim value llvm_classify_value(LLVMValueRef Val) { DEFINE_CASE(Val, ConstantVector); } if (LLVMIsAInstruction(Val)) { - CAMLlocal1(result); result = caml_alloc_small(1, 0); Store_field(result, 0, Val_int(LLVMGetInstructionOpcode(Val))); CAMLreturn(result); @@ -822,12 +822,11 @@ CAMLprim LLVMValueRef llvm_mdnull(LLVMContextRef C) { /* llvalue -> string option */ CAMLprim value llvm_get_mdstring(LLVMValueRef V) { CAMLparam0(); + CAMLlocal2(Option, Str); const char *S; unsigned Len; if ((S = LLVMGetMDString(V, &Len))) { - CAMLlocal2(Option, Str); - Str = caml_alloc_string(Len); memcpy(String_val(Str), S, Len); Option = alloc(1,0); |