X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FIntrinsics.td;h=e76362d36f732b3f28a221d4ba8f7777db18fff9;hb=c651e4c51e11feb58e6c12fee8a8f85631269f2f;hp=05a5a68edccaf4e4da6fa7fcad623d932bae0253;hpb=9d6565a5b1fbc4286d6ee638d8f47a3171a9ed7e;p=oota-llvm.git diff --git a/include/llvm/Intrinsics.td b/include/llvm/Intrinsics.td index 05a5a68edcc..e76362d36f7 100644 --- a/include/llvm/Intrinsics.td +++ b/include/llvm/Intrinsics.td @@ -78,7 +78,8 @@ class LLVMEmptyStructType } def llvm_void_ty : LLVMType; -def llvm_bool_ty : LLVMIntegerType; +def llvm_int_ty : LLVMIntegerType; +def llvm_i1_ty : LLVMIntegerType; def llvm_i8_ty : LLVMIntegerType; def llvm_i16_ty : LLVMIntegerType; def llvm_i32_ty : LLVMIntegerType; @@ -94,10 +95,15 @@ def llvm_v16i8_ty : LLVMVectorType; // 16 x i8 def llvm_v8i16_ty : LLVMVectorType; // 8 x i16 def llvm_v2i64_ty : LLVMVectorType; // 2 x i64 def llvm_v2i32_ty : LLVMVectorType; // 2 x i32 +def llvm_v1i64_ty : LLVMVectorType; // 1 x i64 def llvm_v4i32_ty : LLVMVectorType; // 4 x i32 def llvm_v4f32_ty : LLVMVectorType; // 4 x float def llvm_v2f64_ty : LLVMVectorType;// 2 x double +// MMX Vector Types +def llvm_v8i8_ty : LLVMVectorType; // 8 x i8 +def llvm_v4i16_ty : LLVMVectorType; // 4 x i16 + def llvm_vararg_ty : LLVMType; // vararg //===----------------------------------------------------------------------===// @@ -197,25 +203,16 @@ def int_siglongjmp : Intrinsic<[llvm_void_ty, llvm_ptr_ty, llvm_i32_ty]>; // None of these intrinsics accesses memory at all. let Properties = [IntrNoMem] in { - def int_bswap_i16 : Intrinsic<[llvm_i16_ty, llvm_i16_ty]>; - def int_bswap_i32 : Intrinsic<[llvm_i32_ty, llvm_i32_ty]>; - def int_bswap_i64 : Intrinsic<[llvm_i64_ty, llvm_i64_ty]>; - - def int_ctpop_i8 : Intrinsic<[llvm_i8_ty, llvm_i8_ty]>; - def int_ctpop_i16 : Intrinsic<[llvm_i16_ty, llvm_i16_ty]>; - def int_ctpop_i32 : Intrinsic<[llvm_i32_ty, llvm_i32_ty]>; - def int_ctpop_i64 : Intrinsic<[llvm_i64_ty, llvm_i64_ty]>; - - def int_ctlz_i8 : Intrinsic<[llvm_i8_ty, llvm_i8_ty]>; - def int_ctlz_i16 : Intrinsic<[llvm_i16_ty, llvm_i16_ty]>; - def int_ctlz_i32 : Intrinsic<[llvm_i32_ty, llvm_i32_ty]>; - def int_ctlz_i64 : Intrinsic<[llvm_i64_ty, llvm_i64_ty]>; - - def int_cttz_i8 : Intrinsic<[llvm_i8_ty, llvm_i8_ty]>; - def int_cttz_i16 : Intrinsic<[llvm_i16_ty, llvm_i16_ty]>; - def int_cttz_i32 : Intrinsic<[llvm_i32_ty, llvm_i32_ty]>; - def int_cttz_i64 : Intrinsic<[llvm_i64_ty, llvm_i64_ty]>; -} + def int_bswap: Intrinsic<[llvm_int_ty, llvm_int_ty]>; + def int_ctpop: Intrinsic<[llvm_i32_ty, llvm_int_ty]>; + def int_ctlz : Intrinsic<[llvm_i32_ty, llvm_int_ty]>; + def int_cttz : Intrinsic<[llvm_i32_ty, llvm_int_ty]>; + def int_part_select : + Intrinsic<[llvm_int_ty, llvm_int_ty, llvm_i32_ty, llvm_i32_ty]>; + def int_part_set : + Intrinsic<[llvm_int_ty, llvm_int_ty, llvm_int_ty, llvm_i32_ty, + llvm_i32_ty]>; +} //===------------------------ Debugger Intrinsics -------------------------===// // @@ -231,8 +228,12 @@ def int_dbg_declare : Intrinsic<[llvm_void_ty, llvm_descriptor_ty, //===------------------ Exception Handling Intrinsics----------------------===// // -def int_eh_exception : Intrinsic<[llvm_ptr_ty]>; -def int_eh_handlers : Intrinsic<[llvm_i32_ty, llvm_ptr_ty, llvm_vararg_ty]>; +def int_eh_exception : Intrinsic<[llvm_ptr_ty]>; +def int_eh_selector : Intrinsic<[llvm_i32_ty, llvm_ptr_ty, llvm_ptr_ty, + llvm_vararg_ty]>; +def int_eh_filter : Intrinsic<[llvm_i32_ty, llvm_ptr_ty, llvm_ptr_ty, + llvm_vararg_ty]>; +def int_eh_typeid_for : Intrinsic<[llvm_i32_ty, llvm_ptr_ty]>; //===----------------------------------------------------------------------===// // Target-specific intrinsics