mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 04:30:23 +00:00
Add the new builder arthmetic instructions to llvm-c and ocaml.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97372 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1940dd10dd
commit
19f047f5f6
@ -270,14 +270,21 @@ external const_union : lltype -> llvalue -> llvalue = "LLVMConstUnion"
|
|||||||
external align_of : lltype -> llvalue = "LLVMAlignOf"
|
external align_of : lltype -> llvalue = "LLVMAlignOf"
|
||||||
external size_of : lltype -> llvalue = "LLVMSizeOf"
|
external size_of : lltype -> llvalue = "LLVMSizeOf"
|
||||||
external const_neg : llvalue -> llvalue = "LLVMConstNeg"
|
external const_neg : llvalue -> llvalue = "LLVMConstNeg"
|
||||||
|
external const_nsw_neg : llvalue -> llvalue = "LLVMConstNSWNeg"
|
||||||
|
external const_nuw_neg : llvalue -> llvalue = "LLVMConstNUWNeg"
|
||||||
external const_fneg : llvalue -> llvalue = "LLVMConstFNeg"
|
external const_fneg : llvalue -> llvalue = "LLVMConstFNeg"
|
||||||
external const_not : llvalue -> llvalue = "LLVMConstNot"
|
external const_not : llvalue -> llvalue = "LLVMConstNot"
|
||||||
external const_add : llvalue -> llvalue -> llvalue = "LLVMConstAdd"
|
external const_add : llvalue -> llvalue -> llvalue = "LLVMConstAdd"
|
||||||
external const_nsw_add : llvalue -> llvalue -> llvalue = "LLVMConstNSWAdd"
|
external const_nsw_add : llvalue -> llvalue -> llvalue = "LLVMConstNSWAdd"
|
||||||
|
external const_nuw_add : llvalue -> llvalue -> llvalue = "LLVMConstNUWAdd"
|
||||||
external const_fadd : llvalue -> llvalue -> llvalue = "LLVMConstFAdd"
|
external const_fadd : llvalue -> llvalue -> llvalue = "LLVMConstFAdd"
|
||||||
external const_sub : llvalue -> llvalue -> llvalue = "LLVMConstSub"
|
external const_sub : llvalue -> llvalue -> llvalue = "LLVMConstSub"
|
||||||
|
external const_nsw_sub : llvalue -> llvalue -> llvalue = "LLVMConstNSWSub"
|
||||||
|
external const_nuw_sub : llvalue -> llvalue -> llvalue = "LLVMConstNUWSub"
|
||||||
external const_fsub : llvalue -> llvalue -> llvalue = "LLVMConstFSub"
|
external const_fsub : llvalue -> llvalue -> llvalue = "LLVMConstFSub"
|
||||||
external const_mul : llvalue -> llvalue -> llvalue = "LLVMConstMul"
|
external const_mul : llvalue -> llvalue -> llvalue = "LLVMConstMul"
|
||||||
|
external const_nsw_mul : llvalue -> llvalue -> llvalue = "LLVMConstNSWMul"
|
||||||
|
external const_nuw_mul : llvalue -> llvalue -> llvalue = "LLVMConstNUWMul"
|
||||||
external const_fmul : llvalue -> llvalue -> llvalue = "LLVMConstFMul"
|
external const_fmul : llvalue -> llvalue -> llvalue = "LLVMConstFMul"
|
||||||
external const_udiv : llvalue -> llvalue -> llvalue = "LLVMConstUDiv"
|
external const_udiv : llvalue -> llvalue -> llvalue = "LLVMConstUDiv"
|
||||||
external const_sdiv : llvalue -> llvalue -> llvalue = "LLVMConstSDiv"
|
external const_sdiv : llvalue -> llvalue -> llvalue = "LLVMConstSDiv"
|
||||||
@ -711,14 +718,24 @@ external build_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
|||||||
= "llvm_build_add"
|
= "llvm_build_add"
|
||||||
external build_nsw_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_nsw_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_nsw_add"
|
= "llvm_build_nsw_add"
|
||||||
|
external build_nuw_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_add"
|
||||||
external build_fadd : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_fadd : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_fadd"
|
= "llvm_build_fadd"
|
||||||
external build_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_sub"
|
= "llvm_build_sub"
|
||||||
|
external build_nsw_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nsw_sub"
|
||||||
|
external build_nuw_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_sub"
|
||||||
external build_fsub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_fsub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_fsub"
|
= "llvm_build_fsub"
|
||||||
external build_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_mul"
|
= "llvm_build_mul"
|
||||||
|
external build_nsw_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nsw_mul"
|
||||||
|
external build_nuw_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_mul"
|
||||||
external build_fmul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_fmul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_fmul"
|
= "llvm_build_fmul"
|
||||||
external build_udiv : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_udiv : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
@ -749,6 +766,12 @@ external build_xor : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
|||||||
= "llvm_build_xor"
|
= "llvm_build_xor"
|
||||||
external build_neg : llvalue -> string -> llbuilder -> llvalue
|
external build_neg : llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_neg"
|
= "llvm_build_neg"
|
||||||
|
external build_nsw_neg : llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nsw_neg"
|
||||||
|
external build_nuw_neg : llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_neg"
|
||||||
|
external build_fneg : llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_fneg"
|
||||||
external build_not : llvalue -> string -> llbuilder -> llvalue
|
external build_not : llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_not"
|
= "llvm_build_not"
|
||||||
|
|
||||||
|
@ -615,6 +615,16 @@ external size_of : lltype -> llvalue = "LLVMSizeOf"
|
|||||||
See the method [llvm::ConstantExpr::getNeg]. *)
|
See the method [llvm::ConstantExpr::getNeg]. *)
|
||||||
external const_neg : llvalue -> llvalue = "LLVMConstNeg"
|
external const_neg : llvalue -> llvalue = "LLVMConstNeg"
|
||||||
|
|
||||||
|
(** [const_nsw_neg c] returns the arithmetic negation of the constant [c] with
|
||||||
|
no signed wrapping. The result is undefined if the negation overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNSWNeg]. *)
|
||||||
|
external const_nsw_neg : llvalue -> llvalue = "LLVMConstNSWNeg"
|
||||||
|
|
||||||
|
(** [const_nuw_neg c] returns the arithmetic negation of the constant [c] with
|
||||||
|
no unsigned wrapping. The result is undefined if the negation overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNUWNeg]. *)
|
||||||
|
external const_nuw_neg : llvalue -> llvalue = "LLVMConstNUWNeg"
|
||||||
|
|
||||||
(** [const_fneg c] returns the arithmetic negation of the constant float [c].
|
(** [const_fneg c] returns the arithmetic negation of the constant float [c].
|
||||||
See the method [llvm::ConstantExpr::getFNeg]. *)
|
See the method [llvm::ConstantExpr::getFNeg]. *)
|
||||||
external const_fneg : llvalue -> llvalue = "LLVMConstFNeg"
|
external const_fneg : llvalue -> llvalue = "LLVMConstFNeg"
|
||||||
@ -632,6 +642,11 @@ external const_add : llvalue -> llvalue -> llvalue = "LLVMConstAdd"
|
|||||||
See the method [llvm::ConstantExpr::getNSWAdd]. *)
|
See the method [llvm::ConstantExpr::getNSWAdd]. *)
|
||||||
external const_nsw_add : llvalue -> llvalue -> llvalue = "LLVMConstNSWAdd"
|
external const_nsw_add : llvalue -> llvalue -> llvalue = "LLVMConstNSWAdd"
|
||||||
|
|
||||||
|
(** [const_nuw_add c1 c2] returns the constant sum of two constants with no
|
||||||
|
unsigned wrapping. The result is undefined if the sum overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNSWAdd]. *)
|
||||||
|
external const_nuw_add : llvalue -> llvalue -> llvalue = "LLVMConstNUWAdd"
|
||||||
|
|
||||||
(** [const_fadd c1 c2] returns the constant sum of two constant floats.
|
(** [const_fadd c1 c2] returns the constant sum of two constant floats.
|
||||||
See the method [llvm::ConstantExpr::getFAdd]. *)
|
See the method [llvm::ConstantExpr::getFAdd]. *)
|
||||||
external const_fadd : llvalue -> llvalue -> llvalue = "LLVMConstFAdd"
|
external const_fadd : llvalue -> llvalue -> llvalue = "LLVMConstFAdd"
|
||||||
@ -640,6 +655,16 @@ external const_fadd : llvalue -> llvalue -> llvalue = "LLVMConstFAdd"
|
|||||||
constants. See the method [llvm::ConstantExpr::getSub]. *)
|
constants. See the method [llvm::ConstantExpr::getSub]. *)
|
||||||
external const_sub : llvalue -> llvalue -> llvalue = "LLVMConstSub"
|
external const_sub : llvalue -> llvalue -> llvalue = "LLVMConstSub"
|
||||||
|
|
||||||
|
(** [const_nsw_sub c1 c2] returns the constant difference of two constants with
|
||||||
|
no signed wrapping. The result is undefined if the sum overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNSWSub]. *)
|
||||||
|
external const_nsw_sub : llvalue -> llvalue -> llvalue = "LLVMConstNSWSub"
|
||||||
|
|
||||||
|
(** [const_nuw_sub c1 c2] returns the constant difference of two constants with
|
||||||
|
no unsigned wrapping. The result is undefined if the sum overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNSWSub]. *)
|
||||||
|
external const_nuw_sub : llvalue -> llvalue -> llvalue = "LLVMConstNUWSub"
|
||||||
|
|
||||||
(** [const_fsub c1 c2] returns the constant difference, [c1 - c2], of two
|
(** [const_fsub c1 c2] returns the constant difference, [c1 - c2], of two
|
||||||
constant floats. See the method [llvm::ConstantExpr::getFSub]. *)
|
constant floats. See the method [llvm::ConstantExpr::getFSub]. *)
|
||||||
external const_fsub : llvalue -> llvalue -> llvalue = "LLVMConstFSub"
|
external const_fsub : llvalue -> llvalue -> llvalue = "LLVMConstFSub"
|
||||||
@ -648,6 +673,16 @@ external const_fsub : llvalue -> llvalue -> llvalue = "LLVMConstFSub"
|
|||||||
See the method [llvm::ConstantExpr::getMul]. *)
|
See the method [llvm::ConstantExpr::getMul]. *)
|
||||||
external const_mul : llvalue -> llvalue -> llvalue = "LLVMConstMul"
|
external const_mul : llvalue -> llvalue -> llvalue = "LLVMConstMul"
|
||||||
|
|
||||||
|
(** [const_nsw_mul c1 c2] returns the constant product of two constants with
|
||||||
|
no signed wrapping. The result is undefined if the sum overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNSWMul]. *)
|
||||||
|
external const_nsw_mul : llvalue -> llvalue -> llvalue = "LLVMConstNSWMul"
|
||||||
|
|
||||||
|
(** [const_nuw_mul c1 c2] returns the constant product of two constants with
|
||||||
|
no unsigned wrapping. The result is undefined if the sum overflows.
|
||||||
|
See the method [llvm::ConstantExpr::getNSWMul]. *)
|
||||||
|
external const_nuw_mul : llvalue -> llvalue -> llvalue = "LLVMConstNUWMul"
|
||||||
|
|
||||||
(** [const_fmul c1 c2] returns the constant product of two constants floats.
|
(** [const_fmul c1 c2] returns the constant product of two constants floats.
|
||||||
See the method [llvm::ConstantExpr::getFMul]. *)
|
See the method [llvm::ConstantExpr::getFMul]. *)
|
||||||
external const_fmul : llvalue -> llvalue -> llvalue = "LLVMConstFMul"
|
external const_fmul : llvalue -> llvalue -> llvalue = "LLVMConstFMul"
|
||||||
@ -1502,6 +1537,13 @@ external build_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
|||||||
external build_nsw_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_nsw_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_nsw_add"
|
= "llvm_build_nsw_add"
|
||||||
|
|
||||||
|
(** [build_nuw_add x y name b] creates a
|
||||||
|
[%name = nuw add %x, %y]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNUWAdd]. *)
|
||||||
|
external build_nuw_add : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_add"
|
||||||
|
|
||||||
(** [build_fadd x y name b] creates a
|
(** [build_fadd x y name b] creates a
|
||||||
[%name = fadd %x, %y]
|
[%name = fadd %x, %y]
|
||||||
instruction at the position specified by the instruction builder [b].
|
instruction at the position specified by the instruction builder [b].
|
||||||
@ -1516,6 +1558,20 @@ external build_fadd : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
|||||||
external build_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_sub"
|
= "llvm_build_sub"
|
||||||
|
|
||||||
|
(** [build_nsw_sub x y name b] creates a
|
||||||
|
[%name = nsw sub %x, %y]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNSWSub]. *)
|
||||||
|
external build_nsw_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nsw_sub"
|
||||||
|
|
||||||
|
(** [build_nuw_sub x y name b] creates a
|
||||||
|
[%name = nuw sub %x, %y]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNUWSub]. *)
|
||||||
|
external build_nuw_sub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_sub"
|
||||||
|
|
||||||
(** [build_fsub x y name b] creates a
|
(** [build_fsub x y name b] creates a
|
||||||
[%name = fsub %x, %y]
|
[%name = fsub %x, %y]
|
||||||
instruction at the position specified by the instruction builder [b].
|
instruction at the position specified by the instruction builder [b].
|
||||||
@ -1530,6 +1586,20 @@ external build_fsub : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
|||||||
external build_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
external build_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_mul"
|
= "llvm_build_mul"
|
||||||
|
|
||||||
|
(** [build_nsw_mul x y name b] creates a
|
||||||
|
[%name = nsw mul %x, %y]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNSWMul]. *)
|
||||||
|
external build_nsw_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nsw_mul"
|
||||||
|
|
||||||
|
(** [build_nuw_mul x y name b] creates a
|
||||||
|
[%name = nuw mul %x, %y]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNUWMul]. *)
|
||||||
|
external build_nuw_mul : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_mul"
|
||||||
|
|
||||||
(** [build_fmul x y name b] creates a
|
(** [build_fmul x y name b] creates a
|
||||||
[%name = fmul %x, %y]
|
[%name = fmul %x, %y]
|
||||||
instruction at the position specified by the instruction builder [b].
|
instruction at the position specified by the instruction builder [b].
|
||||||
@ -1636,6 +1706,30 @@ external build_xor : llvalue -> llvalue -> string -> llbuilder -> llvalue
|
|||||||
external build_neg : llvalue -> string -> llbuilder -> llvalue
|
external build_neg : llvalue -> string -> llbuilder -> llvalue
|
||||||
= "llvm_build_neg"
|
= "llvm_build_neg"
|
||||||
|
|
||||||
|
(** [build_nsw_neg x name b] creates a
|
||||||
|
[%name = nsw sub 0, %x]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
[-0.0] is used for floating point types to compute the correct sign.
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNeg]. *)
|
||||||
|
external build_nsw_neg : llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nsw_neg"
|
||||||
|
|
||||||
|
(** [build_nuw_neg x name b] creates a
|
||||||
|
[%name = nuw sub 0, %x]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
[-0.0] is used for floating point types to compute the correct sign.
|
||||||
|
See the method [llvm::LLVMBuilder::CreateNeg]. *)
|
||||||
|
external build_nuw_neg : llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_nuw_neg"
|
||||||
|
|
||||||
|
(** [build_fneg x name b] creates a
|
||||||
|
[%name = fsub 0, %x]
|
||||||
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
[-0.0] is used for floating point types to compute the correct sign.
|
||||||
|
See the method [llvm::LLVMBuilder::CreateFNeg]. *)
|
||||||
|
external build_fneg : llvalue -> string -> llbuilder -> llvalue
|
||||||
|
= "llvm_build_fneg"
|
||||||
|
|
||||||
(** [build_xor x name b] creates a
|
(** [build_xor x name b] creates a
|
||||||
[%name = xor %x, -1]
|
[%name = xor %x, -1]
|
||||||
instruction at the position specified by the instruction builder [b].
|
instruction at the position specified by the instruction builder [b].
|
||||||
|
@ -1095,6 +1095,12 @@ CAMLprim LLVMValueRef llvm_build_nsw_add(LLVMValueRef LHS, LLVMValueRef RHS,
|
|||||||
return LLVMBuildNSWAdd(Builder_val(B), LHS, RHS, String_val(Name));
|
return LLVMBuildNSWAdd(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nuw_add(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNUWAdd(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
CAMLprim LLVMValueRef llvm_build_fadd(LLVMValueRef LHS, LLVMValueRef RHS,
|
CAMLprim LLVMValueRef llvm_build_fadd(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
value Name, value B) {
|
value Name, value B) {
|
||||||
@ -1107,6 +1113,18 @@ CAMLprim LLVMValueRef llvm_build_sub(LLVMValueRef LHS, LLVMValueRef RHS,
|
|||||||
return LLVMBuildSub(Builder_val(B), LHS, RHS, String_val(Name));
|
return LLVMBuildSub(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nsw_sub(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNSWSub(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nuw_sub(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNUWSub(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
CAMLprim LLVMValueRef llvm_build_fsub(LLVMValueRef LHS, LLVMValueRef RHS,
|
CAMLprim LLVMValueRef llvm_build_fsub(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
value Name, value B) {
|
value Name, value B) {
|
||||||
@ -1119,6 +1137,18 @@ CAMLprim LLVMValueRef llvm_build_mul(LLVMValueRef LHS, LLVMValueRef RHS,
|
|||||||
return LLVMBuildMul(Builder_val(B), LHS, RHS, String_val(Name));
|
return LLVMBuildMul(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nsw_mul(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNSWMul(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nuw_mul(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNUWMul(Builder_val(B), LHS, RHS, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
/* llvalue -> llvalue -> string -> llbuilder -> llvalue */
|
||||||
CAMLprim LLVMValueRef llvm_build_fmul(LLVMValueRef LHS, LLVMValueRef RHS,
|
CAMLprim LLVMValueRef llvm_build_fmul(LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
value Name, value B) {
|
value Name, value B) {
|
||||||
@ -1209,6 +1239,24 @@ CAMLprim LLVMValueRef llvm_build_neg(LLVMValueRef X,
|
|||||||
return LLVMBuildNeg(Builder_val(B), X, String_val(Name));
|
return LLVMBuildNeg(Builder_val(B), X, String_val(Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nsw_neg(LLVMValueRef X,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNSWNeg(Builder_val(B), X, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_nuw_neg(LLVMValueRef X,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildNUWNeg(Builder_val(B), X, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* llvalue -> string -> llbuilder -> llvalue */
|
||||||
|
CAMLprim LLVMValueRef llvm_build_fneg(LLVMValueRef X,
|
||||||
|
value Name, value B) {
|
||||||
|
return LLVMBuildFNeg(Builder_val(B), X, String_val(Name));
|
||||||
|
}
|
||||||
|
|
||||||
/* llvalue -> string -> llbuilder -> llvalue */
|
/* llvalue -> string -> llbuilder -> llvalue */
|
||||||
CAMLprim LLVMValueRef llvm_build_not(LLVMValueRef X,
|
CAMLprim LLVMValueRef llvm_build_not(LLVMValueRef X,
|
||||||
value Name, value B) {
|
value Name, value B) {
|
||||||
|
@ -558,14 +558,21 @@ LLVMOpcode LLVMGetConstOpcode(LLVMValueRef ConstantVal);
|
|||||||
LLVMValueRef LLVMAlignOf(LLVMTypeRef Ty);
|
LLVMValueRef LLVMAlignOf(LLVMTypeRef Ty);
|
||||||
LLVMValueRef LLVMSizeOf(LLVMTypeRef Ty);
|
LLVMValueRef LLVMSizeOf(LLVMTypeRef Ty);
|
||||||
LLVMValueRef LLVMConstNeg(LLVMValueRef ConstantVal);
|
LLVMValueRef LLVMConstNeg(LLVMValueRef ConstantVal);
|
||||||
|
LLVMValueRef LLVMConstNSWNeg(LLVMValueRef ConstantVal);
|
||||||
|
LLVMValueRef LLVMConstNUWNeg(LLVMValueRef ConstantVal);
|
||||||
LLVMValueRef LLVMConstFNeg(LLVMValueRef ConstantVal);
|
LLVMValueRef LLVMConstFNeg(LLVMValueRef ConstantVal);
|
||||||
LLVMValueRef LLVMConstNot(LLVMValueRef ConstantVal);
|
LLVMValueRef LLVMConstNot(LLVMValueRef ConstantVal);
|
||||||
LLVMValueRef LLVMConstAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstNSWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstNSWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
|
LLVMValueRef LLVMConstNUWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstFAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstFAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
|
LLVMValueRef LLVMConstNSWSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
|
LLVMValueRef LLVMConstNUWSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstFSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstFSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
|
LLVMValueRef LLVMConstNSWMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
|
LLVMValueRef LLVMConstNUWMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstFMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstFMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstUDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstUDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
LLVMValueRef LLVMConstSDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
LLVMValueRef LLVMConstSDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
|
||||||
@ -792,14 +799,24 @@ LLVMValueRef LLVMBuildAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
|||||||
const char *Name);
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildNSWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildNSWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNUWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNSWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNUWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildFSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildFSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNSWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNUWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildFMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildFMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildUDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildUDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
@ -832,6 +849,10 @@ LLVMValueRef LLVMBuildBinOp(LLVMBuilderRef B, LLVMOpcode Op,
|
|||||||
LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name);
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
|
LLVMValueRef LLVMBuildNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNSWNeg(LLVMBuilderRef B, LLVMValueRef V,
|
||||||
|
const char *Name);
|
||||||
|
LLVMValueRef LLVMBuildNUWNeg(LLVMBuilderRef B, LLVMValueRef V,
|
||||||
|
const char *Name);
|
||||||
LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
|
LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
|
||||||
LLVMValueRef LLVMBuildNot(LLVMBuilderRef, LLVMValueRef V, const char *Name);
|
LLVMValueRef LLVMBuildNot(LLVMBuilderRef, LLVMValueRef V, const char *Name);
|
||||||
|
|
||||||
|
@ -594,6 +594,17 @@ LLVMValueRef LLVMConstNeg(LLVMValueRef ConstantVal) {
|
|||||||
unwrap<Constant>(ConstantVal)));
|
unwrap<Constant>(ConstantVal)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNSWNeg(LLVMValueRef ConstantVal) {
|
||||||
|
return wrap(ConstantExpr::getNSWNeg(
|
||||||
|
unwrap<Constant>(ConstantVal)));
|
||||||
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNUWNeg(LLVMValueRef ConstantVal) {
|
||||||
|
return wrap(ConstantExpr::getNUWNeg(
|
||||||
|
unwrap<Constant>(ConstantVal)));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
LLVMValueRef LLVMConstFNeg(LLVMValueRef ConstantVal) {
|
LLVMValueRef LLVMConstFNeg(LLVMValueRef ConstantVal) {
|
||||||
return wrap(ConstantExpr::getFNeg(
|
return wrap(ConstantExpr::getFNeg(
|
||||||
unwrap<Constant>(ConstantVal)));
|
unwrap<Constant>(ConstantVal)));
|
||||||
@ -617,6 +628,13 @@ LLVMValueRef LLVMConstNSWAdd(LLVMValueRef LHSConstant,
|
|||||||
unwrap<Constant>(RHSConstant)));
|
unwrap<Constant>(RHSConstant)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNUWAdd(LLVMValueRef LHSConstant,
|
||||||
|
LLVMValueRef RHSConstant) {
|
||||||
|
return wrap(ConstantExpr::getNUWAdd(
|
||||||
|
unwrap<Constant>(LHSConstant),
|
||||||
|
unwrap<Constant>(RHSConstant)));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMConstFAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
LLVMValueRef LLVMConstFAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
||||||
return wrap(ConstantExpr::getFAdd(
|
return wrap(ConstantExpr::getFAdd(
|
||||||
unwrap<Constant>(LHSConstant),
|
unwrap<Constant>(LHSConstant),
|
||||||
@ -629,6 +647,20 @@ LLVMValueRef LLVMConstSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
|||||||
unwrap<Constant>(RHSConstant)));
|
unwrap<Constant>(RHSConstant)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNSWSub(LLVMValueRef LHSConstant,
|
||||||
|
LLVMValueRef RHSConstant) {
|
||||||
|
return wrap(ConstantExpr::getNSWSub(
|
||||||
|
unwrap<Constant>(LHSConstant),
|
||||||
|
unwrap<Constant>(RHSConstant)));
|
||||||
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNUWSub(LLVMValueRef LHSConstant,
|
||||||
|
LLVMValueRef RHSConstant) {
|
||||||
|
return wrap(ConstantExpr::getNUWSub(
|
||||||
|
unwrap<Constant>(LHSConstant),
|
||||||
|
unwrap<Constant>(RHSConstant)));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMConstFSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
LLVMValueRef LLVMConstFSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
||||||
return wrap(ConstantExpr::getFSub(unwrap<Constant>(LHSConstant),
|
return wrap(ConstantExpr::getFSub(unwrap<Constant>(LHSConstant),
|
||||||
unwrap<Constant>(RHSConstant)));
|
unwrap<Constant>(RHSConstant)));
|
||||||
@ -640,6 +672,20 @@ LLVMValueRef LLVMConstMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
|||||||
unwrap<Constant>(RHSConstant)));
|
unwrap<Constant>(RHSConstant)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNSWMul(LLVMValueRef LHSConstant,
|
||||||
|
LLVMValueRef RHSConstant) {
|
||||||
|
return wrap(ConstantExpr::getNSWMul(
|
||||||
|
unwrap<Constant>(LHSConstant),
|
||||||
|
unwrap<Constant>(RHSConstant)));
|
||||||
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMConstNUWMul(LLVMValueRef LHSConstant,
|
||||||
|
LLVMValueRef RHSConstant) {
|
||||||
|
return wrap(ConstantExpr::getNUWMul(
|
||||||
|
unwrap<Constant>(LHSConstant),
|
||||||
|
unwrap<Constant>(RHSConstant)));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMConstFMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
LLVMValueRef LLVMConstFMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant) {
|
||||||
return wrap(ConstantExpr::getFMul(
|
return wrap(ConstantExpr::getFMul(
|
||||||
unwrap<Constant>(LHSConstant),
|
unwrap<Constant>(LHSConstant),
|
||||||
@ -1628,6 +1674,11 @@ LLVMValueRef LLVMBuildNSWAdd(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RH
|
|||||||
return wrap(unwrap(B)->CreateNSWAdd(unwrap(LHS), unwrap(RHS), Name));
|
return wrap(unwrap(B)->CreateNSWAdd(unwrap(LHS), unwrap(RHS), Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNUWAdd(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNUWAdd(unwrap(LHS), unwrap(RHS), Name));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name) {
|
const char *Name) {
|
||||||
return wrap(unwrap(B)->CreateFAdd(unwrap(LHS), unwrap(RHS), Name));
|
return wrap(unwrap(B)->CreateFAdd(unwrap(LHS), unwrap(RHS), Name));
|
||||||
@ -1638,6 +1689,16 @@ LLVMValueRef LLVMBuildSub(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
|||||||
return wrap(unwrap(B)->CreateSub(unwrap(LHS), unwrap(RHS), Name));
|
return wrap(unwrap(B)->CreateSub(unwrap(LHS), unwrap(RHS), Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNSWSub(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNSWSub(unwrap(LHS), unwrap(RHS), Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNUWSub(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNUWSub(unwrap(LHS), unwrap(RHS), Name));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMBuildFSub(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildFSub(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name) {
|
const char *Name) {
|
||||||
return wrap(unwrap(B)->CreateFSub(unwrap(LHS), unwrap(RHS), Name));
|
return wrap(unwrap(B)->CreateFSub(unwrap(LHS), unwrap(RHS), Name));
|
||||||
@ -1648,6 +1709,16 @@ LLVMValueRef LLVMBuildMul(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
|||||||
return wrap(unwrap(B)->CreateMul(unwrap(LHS), unwrap(RHS), Name));
|
return wrap(unwrap(B)->CreateMul(unwrap(LHS), unwrap(RHS), Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNSWMul(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNSWMul(unwrap(LHS), unwrap(RHS), Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNUWMul(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNUWMul(unwrap(LHS), unwrap(RHS), Name));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMBuildFMul(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
LLVMValueRef LLVMBuildFMul(LLVMBuilderRef B, LLVMValueRef LHS, LLVMValueRef RHS,
|
||||||
const char *Name) {
|
const char *Name) {
|
||||||
return wrap(unwrap(B)->CreateFMul(unwrap(LHS), unwrap(RHS), Name));
|
return wrap(unwrap(B)->CreateFMul(unwrap(LHS), unwrap(RHS), Name));
|
||||||
@ -1729,6 +1800,16 @@ LLVMValueRef LLVMBuildNeg(LLVMBuilderRef B, LLVMValueRef V, const char *Name) {
|
|||||||
return wrap(unwrap(B)->CreateNeg(unwrap(V), Name));
|
return wrap(unwrap(B)->CreateNeg(unwrap(V), Name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNSWNeg(LLVMBuilderRef B, LLVMValueRef V,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNSWNeg(unwrap(V), Name));
|
||||||
|
}
|
||||||
|
|
||||||
|
LLVMValueRef LLVMBuildNUWNeg(LLVMBuilderRef B, LLVMValueRef V,
|
||||||
|
const char *Name) {
|
||||||
|
return wrap(unwrap(B)->CreateNUWNeg(unwrap(V), Name));
|
||||||
|
}
|
||||||
|
|
||||||
LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef B, LLVMValueRef V, const char *Name) {
|
LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef B, LLVMValueRef V, const char *Name) {
|
||||||
return wrap(unwrap(B)->CreateFNeg(unwrap(V), Name));
|
return wrap(unwrap(B)->CreateFNeg(unwrap(V), Name));
|
||||||
}
|
}
|
||||||
|
@ -292,7 +292,7 @@ let test_constants () =
|
|||||||
group "union";
|
group "union";
|
||||||
let t = union_type context [| i1_type; i16_type; i64_type; double_type |] in
|
let t = union_type context [| i1_type; i16_type; i64_type; double_type |] in
|
||||||
let c = const_union t one in
|
let c = const_union t one in
|
||||||
ignore (define_global "Const_union" c m);
|
ignore (define_global "const_union" c m);
|
||||||
insist (t = (type_of c));
|
insist (t = (type_of c));
|
||||||
|
|
||||||
(* RUN: grep {const_null.*zeroinit} < %t.ll
|
(* RUN: grep {const_null.*zeroinit} < %t.ll
|
||||||
@ -318,12 +318,25 @@ let test_constants () =
|
|||||||
|
|
||||||
group "constant arithmetic";
|
group "constant arithmetic";
|
||||||
(* RUN: grep {@const_neg = global i64 sub} < %t.ll
|
(* RUN: grep {@const_neg = global i64 sub} < %t.ll
|
||||||
|
* RUN: grep {@const_nsw_neg = global i64 sub nsw } < %t.ll
|
||||||
|
* RUN: grep {@const_nuw_neg = global i64 sub nuw } < %t.ll
|
||||||
|
* RUN: grep {@const_fneg = global double fsub } < %t.ll
|
||||||
* RUN: grep {@const_not = global i64 xor } < %t.ll
|
* RUN: grep {@const_not = global i64 xor } < %t.ll
|
||||||
* RUN: grep {@const_add = global i64 add } < %t.ll
|
* RUN: grep {@const_add = global i64 add } < %t.ll
|
||||||
|
* RUN: grep {@const_nsw_add = global i64 add nsw } < %t.ll
|
||||||
|
* RUN: grep {@const_nuw_add = global i64 add nuw } < %t.ll
|
||||||
|
* RUN: grep {@const_fadd = global double fadd } < %t.ll
|
||||||
* RUN: grep {@const_sub = global i64 sub } < %t.ll
|
* RUN: grep {@const_sub = global i64 sub } < %t.ll
|
||||||
|
* RUN: grep {@const_nsw_sub = global i64 sub nsw } < %t.ll
|
||||||
|
* RUN: grep {@const_nuw_sub = global i64 sub nuw } < %t.ll
|
||||||
|
* RUN: grep {@const_fsub = global double fsub } < %t.ll
|
||||||
* RUN: grep {@const_mul = global i64 mul } < %t.ll
|
* RUN: grep {@const_mul = global i64 mul } < %t.ll
|
||||||
|
* RUN: grep {@const_nsw_mul = global i64 mul nsw } < %t.ll
|
||||||
|
* RUN: grep {@const_nuw_mul = global i64 mul nuw } < %t.ll
|
||||||
|
* RUN: grep {@const_fmul = global double fmul } < %t.ll
|
||||||
* RUN: grep {@const_udiv = global i64 udiv } < %t.ll
|
* RUN: grep {@const_udiv = global i64 udiv } < %t.ll
|
||||||
* RUN: grep {@const_sdiv = global i64 sdiv } < %t.ll
|
* RUN: grep {@const_sdiv = global i64 sdiv } < %t.ll
|
||||||
|
* RUN: grep {@const_exact_sdiv = global i64 sdiv exact } < %t.ll
|
||||||
* RUN: grep {@const_fdiv = global double fdiv } < %t.ll
|
* RUN: grep {@const_fdiv = global double fdiv } < %t.ll
|
||||||
* RUN: grep {@const_urem = global i64 urem } < %t.ll
|
* RUN: grep {@const_urem = global i64 urem } < %t.ll
|
||||||
* RUN: grep {@const_srem = global i64 srem } < %t.ll
|
* RUN: grep {@const_srem = global i64 srem } < %t.ll
|
||||||
@ -341,12 +354,25 @@ let test_constants () =
|
|||||||
let foldbomb = const_ptrtoint foldbomb_gv i64_type in
|
let foldbomb = const_ptrtoint foldbomb_gv i64_type in
|
||||||
let ffoldbomb = const_uitofp foldbomb double_type in
|
let ffoldbomb = const_uitofp foldbomb double_type in
|
||||||
ignore (define_global "const_neg" (const_neg foldbomb) m);
|
ignore (define_global "const_neg" (const_neg foldbomb) m);
|
||||||
|
ignore (define_global "const_nsw_neg" (const_nsw_neg foldbomb) m);
|
||||||
|
ignore (define_global "const_nuw_neg" (const_nuw_neg foldbomb) m);
|
||||||
|
ignore (define_global "const_fneg" (const_fneg ffoldbomb) m);
|
||||||
ignore (define_global "const_not" (const_not foldbomb) m);
|
ignore (define_global "const_not" (const_not foldbomb) m);
|
||||||
ignore (define_global "const_add" (const_add foldbomb five) m);
|
ignore (define_global "const_add" (const_add foldbomb five) m);
|
||||||
|
ignore (define_global "const_nsw_add" (const_nsw_add foldbomb five) m);
|
||||||
|
ignore (define_global "const_nuw_add" (const_nuw_add foldbomb five) m);
|
||||||
|
ignore (define_global "const_fadd" (const_fadd ffoldbomb ffive) m);
|
||||||
ignore (define_global "const_sub" (const_sub foldbomb five) m);
|
ignore (define_global "const_sub" (const_sub foldbomb five) m);
|
||||||
|
ignore (define_global "const_nsw_sub" (const_nsw_sub foldbomb five) m);
|
||||||
|
ignore (define_global "const_nuw_sub" (const_nuw_sub foldbomb five) m);
|
||||||
|
ignore (define_global "const_fsub" (const_fsub ffoldbomb ffive) m);
|
||||||
ignore (define_global "const_mul" (const_mul foldbomb five) m);
|
ignore (define_global "const_mul" (const_mul foldbomb five) m);
|
||||||
|
ignore (define_global "const_nsw_mul" (const_nsw_mul foldbomb five) m);
|
||||||
|
ignore (define_global "const_nuw_mul" (const_nuw_mul foldbomb five) m);
|
||||||
|
ignore (define_global "const_fmul" (const_fmul ffoldbomb ffive) m);
|
||||||
ignore (define_global "const_udiv" (const_udiv foldbomb five) m);
|
ignore (define_global "const_udiv" (const_udiv foldbomb five) m);
|
||||||
ignore (define_global "const_sdiv" (const_sdiv foldbomb five) m);
|
ignore (define_global "const_sdiv" (const_sdiv foldbomb five) m);
|
||||||
|
ignore (define_global "const_exact_sdiv" (const_exact_sdiv foldbomb five) m);
|
||||||
ignore (define_global "const_fdiv" (const_fdiv ffoldbomb ffive) m);
|
ignore (define_global "const_fdiv" (const_fdiv ffoldbomb ffive) m);
|
||||||
ignore (define_global "const_urem" (const_urem foldbomb five) m);
|
ignore (define_global "const_urem" (const_urem foldbomb five) m);
|
||||||
ignore (define_global "const_srem" (const_srem foldbomb five) m);
|
ignore (define_global "const_srem" (const_srem foldbomb five) m);
|
||||||
@ -902,10 +928,20 @@ let test_builder () =
|
|||||||
let b = builder_at_end context bb07 in
|
let b = builder_at_end context bb07 in
|
||||||
|
|
||||||
(* RUN: grep {%build_add = add i32 %P1, %P2} < %t.ll
|
(* RUN: grep {%build_add = add i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_nsw_add = add nsw i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_nuw_add = add nuw i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_fadd = fadd float %F1, %F2} < %t.ll
|
||||||
* RUN: grep {%build_sub = sub i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_sub = sub i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_nsw_sub = sub nsw i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_nuw_sub = sub nuw i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_fsub = fsub float %F1, %F2} < %t.ll
|
||||||
* RUN: grep {%build_mul = mul i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_mul = mul i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_nsw_mul = mul nsw i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_nuw_mul = mul nuw i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_fmul = fmul float %F1, %F2} < %t.ll
|
||||||
* RUN: grep {%build_udiv = udiv i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_udiv = udiv i32 %P1, %P2} < %t.ll
|
||||||
* RUN: grep {%build_sdiv = sdiv i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_sdiv = sdiv i32 %P1, %P2} < %t.ll
|
||||||
|
* RUN: grep {%build_exact_sdiv = sdiv exact i32 %P1, %P2} < %t.ll
|
||||||
* RUN: grep {%build_fdiv = fdiv float %F1, %F2} < %t.ll
|
* RUN: grep {%build_fdiv = fdiv float %F1, %F2} < %t.ll
|
||||||
* RUN: grep {%build_urem = urem i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_urem = urem i32 %P1, %P2} < %t.ll
|
||||||
* RUN: grep {%build_srem = srem i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_srem = srem i32 %P1, %P2} < %t.ll
|
||||||
@ -917,13 +953,26 @@ let test_builder () =
|
|||||||
* RUN: grep {%build_or = or i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_or = or i32 %P1, %P2} < %t.ll
|
||||||
* RUN: grep {%build_xor = xor i32 %P1, %P2} < %t.ll
|
* RUN: grep {%build_xor = xor i32 %P1, %P2} < %t.ll
|
||||||
* RUN: grep {%build_neg = sub i32 0, %P1} < %t.ll
|
* RUN: grep {%build_neg = sub i32 0, %P1} < %t.ll
|
||||||
|
* RUN: grep {%build_nsw_neg = sub nsw i32 0, %P1} < %t.ll
|
||||||
|
* RUN: grep {%build_nuw_neg = sub nuw i32 0, %P1} < %t.ll
|
||||||
|
* RUN: grep {%build_fneg = fsub float .*0.*, %F1} < %t.ll
|
||||||
* RUN: grep {%build_not = xor i32 %P1, -1} < %t.ll
|
* RUN: grep {%build_not = xor i32 %P1, -1} < %t.ll
|
||||||
*)
|
*)
|
||||||
ignore (build_add p1 p2 "build_add" b);
|
ignore (build_add p1 p2 "build_add" b);
|
||||||
|
ignore (build_nsw_add p1 p2 "build_nsw_add" b);
|
||||||
|
ignore (build_nuw_add p1 p2 "build_nuw_add" b);
|
||||||
|
ignore (build_fadd f1 f2 "build_fadd" b);
|
||||||
ignore (build_sub p1 p2 "build_sub" b);
|
ignore (build_sub p1 p2 "build_sub" b);
|
||||||
|
ignore (build_nsw_sub p1 p2 "build_nsw_sub" b);
|
||||||
|
ignore (build_nuw_sub p1 p2 "build_nuw_sub" b);
|
||||||
|
ignore (build_fsub f1 f2 "build_fsub" b);
|
||||||
ignore (build_mul p1 p2 "build_mul" b);
|
ignore (build_mul p1 p2 "build_mul" b);
|
||||||
|
ignore (build_nsw_mul p1 p2 "build_nsw_mul" b);
|
||||||
|
ignore (build_nuw_mul p1 p2 "build_nuw_mul" b);
|
||||||
|
ignore (build_fmul f1 f2 "build_fmul" b);
|
||||||
ignore (build_udiv p1 p2 "build_udiv" b);
|
ignore (build_udiv p1 p2 "build_udiv" b);
|
||||||
ignore (build_sdiv p1 p2 "build_sdiv" b);
|
ignore (build_sdiv p1 p2 "build_sdiv" b);
|
||||||
|
ignore (build_exact_sdiv p1 p2 "build_exact_sdiv" b);
|
||||||
ignore (build_fdiv f1 f2 "build_fdiv" b);
|
ignore (build_fdiv f1 f2 "build_fdiv" b);
|
||||||
ignore (build_urem p1 p2 "build_urem" b);
|
ignore (build_urem p1 p2 "build_urem" b);
|
||||||
ignore (build_srem p1 p2 "build_srem" b);
|
ignore (build_srem p1 p2 "build_srem" b);
|
||||||
@ -935,6 +984,9 @@ let test_builder () =
|
|||||||
ignore (build_or p1 p2 "build_or" b);
|
ignore (build_or p1 p2 "build_or" b);
|
||||||
ignore (build_xor p1 p2 "build_xor" b);
|
ignore (build_xor p1 p2 "build_xor" b);
|
||||||
ignore (build_neg p1 "build_neg" b);
|
ignore (build_neg p1 "build_neg" b);
|
||||||
|
ignore (build_nsw_neg p1 "build_nsw_neg" b);
|
||||||
|
ignore (build_nuw_neg p1 "build_nuw_neg" b);
|
||||||
|
ignore (build_fneg f1 "build_fneg" b);
|
||||||
ignore (build_not p1 "build_not" b);
|
ignore (build_not p1 "build_not" b);
|
||||||
ignore (build_unreachable b)
|
ignore (build_unreachable b)
|
||||||
end;
|
end;
|
||||||
|
Loading…
Reference in New Issue
Block a user