// RUN: %target-sil-opt %s -o - | %target-sil-opt // Just make sure we can parse polymorphic builtins, recognize them, round trip // them. sil_stage raw import Builtin sil @generic_add_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_add"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_add_indirect_param_test : $@convention(thin) (@in Builtin.Vec4xInt32, @in Builtin.Vec4xInt32) -> @out Builtin.Vec4xInt32 { bb0(%0 : $*Builtin.Vec4xInt32, %1 : $*Builtin.Vec4xInt32, %2 : $*Builtin.Vec4xInt32): %3 = builtin "generic_add"(%0 : $*Builtin.Vec4xInt32, %1 : $*Builtin.Vec4xInt32, %2 : $*Builtin.Vec4xInt32) : $() %9999 = tuple() return %9999 : $() } sil @generic_fadd_test : $@convention(thin) (Builtin.Vec4xFPIEEE32, Builtin.Vec4xFPIEEE32) -> Builtin.Vec4xFPIEEE32 { bb0(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32): %2 = builtin "generic_fadd"(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32) : $Builtin.Vec4xFPIEEE32 return %2 : $Builtin.Vec4xFPIEEE32 } sil @generic_and_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_and"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_ashr_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_ashr"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_lshr_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_lshr"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_or_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_or"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_fdiv_test : $@convention(thin) (Builtin.Vec4xFPIEEE32, Builtin.Vec4xFPIEEE32) -> Builtin.Vec4xFPIEEE32 { bb0(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32): %2 = builtin "generic_fdiv"(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32) : $Builtin.Vec4xFPIEEE32 return %2 : $Builtin.Vec4xFPIEEE32 } sil @generic_mul_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_mul"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_fmul_test : $@convention(thin) (Builtin.Vec4xFPIEEE32, Builtin.Vec4xFPIEEE32) -> Builtin.Vec4xFPIEEE32 { bb0(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32): %2 = builtin "generic_fmul"(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32) : $Builtin.Vec4xFPIEEE32 return %2 : $Builtin.Vec4xFPIEEE32 } sil @generic_sdiv_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_sdiv"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_sdiv_exact_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_sdiv_exact"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_shl_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_shl"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_srem_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_srem"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_sub_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_sub"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_udiv_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_udiv"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_udiv_exact_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_udiv_exact"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_xor_test : $@convention(thin) (Builtin.Vec4xInt32, Builtin.Vec4xInt32) -> Builtin.Vec4xInt32 { bb0(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32): %2 = builtin "generic_xor"(%0 : $Builtin.Vec4xInt32, %1 : $Builtin.Vec4xInt32) : $Builtin.Vec4xInt32 return %2 : $Builtin.Vec4xInt32 } sil @generic_fsub_test : $@convention(thin) (Builtin.Vec4xFPIEEE32, Builtin.Vec4xFPIEEE32) -> Builtin.Vec4xFPIEEE32 { bb0(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32): %2 = builtin "generic_fsub"(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32) : $Builtin.Vec4xFPIEEE32 return %2 : $Builtin.Vec4xFPIEEE32 } sil @generic_frem_test : $@convention(thin) (Builtin.Vec4xFPIEEE32, Builtin.Vec4xFPIEEE32) -> Builtin.Vec4xFPIEEE32 { bb0(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32): %2 = builtin "generic_frem"(%0 : $Builtin.Vec4xFPIEEE32, %1 : $Builtin.Vec4xFPIEEE32) : $Builtin.Vec4xFPIEEE32 return %2 : $Builtin.Vec4xFPIEEE32 } sil @generic_urem_test : $@convention(thin) (Builtin.Int64, Builtin.Int64) -> Builtin.Int64 { bb0(%0 : $Builtin.Int64, %1 : $Builtin.Int64): %2 = builtin "generic_urem"(%0 : $Builtin.Int64, %1 : $Builtin.Int64) : $Builtin.Int64 return %2 : $Builtin.Int64 }