diff options
Diffstat (limited to 'mlir/test/Conversion/GPUToROCDL/gpu-to-rocdl.mlir')
| -rw-r--r-- | mlir/test/Conversion/GPUToROCDL/gpu-to-rocdl.mlir | 163 |
1 files changed, 102 insertions, 61 deletions
diff --git a/mlir/test/Conversion/GPUToROCDL/gpu-to-rocdl.mlir b/mlir/test/Conversion/GPUToROCDL/gpu-to-rocdl.mlir index eb065cbab867..0d3e9f4ea2bf 100644 --- a/mlir/test/Conversion/GPUToROCDL/gpu-to-rocdl.mlir +++ b/mlir/test/Conversion/GPUToROCDL/gpu-to-rocdl.mlir @@ -162,11 +162,12 @@ gpu.module @test_module { // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_exp_f16(f16) -> f16 // CHECK: llvm.func @__ocml_exp_f64(f64) -> f64 // CHECK-LABEL: func @gpu_exp func.func @gpu_exp(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { %result16 = math.exp %arg_f16 : f16 - // CHECK: llvm.intr.exp(%{{.*}}) : (f16) -> f16 + // CHECK: llvm.call @__ocml_exp_f16(%{{.*}}) : (f16) -> f16 %result32 = math.exp %arg_f32 : f32 // CHECK: llvm.intr.exp(%{{.*}}) : (f32) -> f32 %result64 = math.exp %arg_f64 : f64 @@ -178,11 +179,12 @@ gpu.module @test_module { // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_log_f16(f16) -> f16 // CHECK: llvm.func @__ocml_log_f64(f64) -> f64 // CHECK-LABEL: func @gpu_log func.func @gpu_log(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { %result16 = math.log %arg_f16 : f16 - // CHECK: llvm.intr.log(%{{.*}}) : (f16) -> f16 + // CHECK: llvm.call @__ocml_log_f16(%{{.*}}) : (f16) -> f16 %result32 = math.log %arg_f32 : f32 // CHECK: llvm.intr.log(%{{.*}}) : (f32) -> f32 %result64 = math.log %arg_f64 : f64 @@ -194,108 +196,113 @@ gpu.module @test_module { // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_cbrt_f16(f16) -> f16 // CHECK: llvm.func @__ocml_cbrt_f32(f32) -> f32 // CHECK: llvm.func @__ocml_cbrt_f64(f64) -> f64 // CHECK-LABEL: func @gpu_cbrt - func.func @gpu_cbrt(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_cbrt(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.cbrt %arg_f16 : f16 + // CHECK: llvm.call @__ocml_cbrt_f16(%{{.*}}) : (f16) -> f16 %result32 = math.cbrt %arg_f32 : f32 // CHECK: llvm.call @__ocml_cbrt_f32(%{{.*}}) : (f32) -> f32 %result64 = math.cbrt %arg_f64 : f64 // CHECK: llvm.call @__ocml_cbrt_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_ceil_f16(f16) -> f16 // CHECK: llvm.func @__ocml_ceil_f32(f32) -> f32 // CHECK: llvm.func @__ocml_ceil_f64(f64) -> f64 // CHECK-LABEL: func @gpu_ceil - func.func @gpu_ceil(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_ceil(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.ceil %arg_f16 : f16 + // CHECK: llvm.call @__ocml_ceil_f16(%{{.*}}) : (f16) -> f16 %result32 = math.ceil %arg_f32 : f32 // CHECK: llvm.call @__ocml_ceil_f32(%{{.*}}) : (f32) -> f32 %result64 = math.ceil %arg_f64 : f64 // CHECK: llvm.call @__ocml_ceil_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_floor_f16(f16) -> f16 // CHECK: llvm.func @__ocml_floor_f32(f32) -> f32 // CHECK: llvm.func @__ocml_floor_f64(f64) -> f64 // CHECK-LABEL: func @gpu_floor - func.func @gpu_floor(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_floor(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.floor %arg_f16 : f16 + // CHECK: llvm.call @__ocml_floor_f16(%{{.*}}) : (f16) -> f16 %result32 = math.floor %arg_f32 : f32 // CHECK: llvm.call @__ocml_floor_f32(%{{.*}}) : (f32) -> f32 %result64 = math.floor %arg_f64 : f64 // CHECK: llvm.call @__ocml_floor_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_cos_f16(f16) -> f16 // CHECK: llvm.func @__ocml_cos_f32(f32) -> f32 // CHECK: llvm.func @__ocml_cos_f64(f64) -> f64 // CHECK-LABEL: func @gpu_cos - func.func @gpu_cos(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_cos(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.cos %arg_f16 : f16 + // CHECK: llvm.call @__ocml_cos_f16(%{{.*}}) : (f16) -> f16 %result32 = math.cos %arg_f32 : f32 // CHECK: llvm.call @__ocml_cos_f32(%{{.*}}) : (f32) -> f32 %result64 = math.cos %arg_f64 : f64 // CHECK: llvm.call @__ocml_cos_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 - } -} - -// ----- - -gpu.module @test_module { - // CHECK: llvm.func @__ocml_exp_f64(f64) -> f64 - // CHECK-LABEL: func @gpu_exp - func.func @gpu_exp(%arg_f64 : f64) -> (f64) { - %result64 = math.exp %arg_f64 : f64 - // CHECK: llvm.call @__ocml_exp_f64(%{{.*}}) : (f64) -> f64 - func.return %result64 : f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_exp2_f16(f16) -> f16 // CHECK: llvm.func @__ocml_exp2_f32(f32) -> f32 // CHECK: llvm.func @__ocml_exp2_f64(f64) -> f64 // CHECK-LABEL: func @gpu_exp2 - func.func @gpu_exp2(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_exp2(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.exp2 %arg_f16 : f16 + // CHECK: llvm.call @__ocml_exp2_f16(%{{.*}}) : (f16) -> f16 %exp2_f32 = math.exp2 %arg_f32 : f32 // CHECK: llvm.call @__ocml_exp2_f32(%{{.*}}) : (f32) -> f32 %result32 = math.exp2 %exp2_f32 : f32 // CHECK: llvm.call @__ocml_exp2_f32(%{{.*}}) : (f32) -> f32 %result64 = math.exp2 %arg_f64 : f64 // CHECK: llvm.call @__ocml_exp2_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- + // Test that we handled properly operation with SymbolTable other than module op gpu.module @test_module { "test.symbol_scope"() ({ // CHECK: test.symbol_scope + // CHECK: llvm.func @__ocml_sin_f16(f16) -> f16 // CHECK: llvm.func @__ocml_sin_f32(f32) -> f32 // CHECK: llvm.func @__ocml_sin_f64(f64) -> f64 // CHECK-LABEL: func @gpu_sin - func.func @gpu_sin(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { - %sin_f32 = math.sin %arg_f32 : f32 + func.func @gpu_sin(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + // CHECK: llvm.call @__ocml_sin_f16(%{{.*}}) : (f16) -> f16 + %result16 = math.sin %arg_f16 : f16 // CHECK: llvm.call @__ocml_sin_f32(%{{.*}}) : (f32) -> f32 - %result32 = math.sin %sin_f32 : f32 - // CHECK: llvm.call @__ocml_sin_f32(%{{.*}}) : (f32) -> f32 - %result64 = math.sin %arg_f64 : f64 + %result32 = math.sin %arg_f32 : f32 // CHECK: llvm.call @__ocml_sin_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + %result64 = math.sin %arg_f64 : f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } "test.finish" () : () -> () }) : () -> () @@ -304,89 +311,102 @@ gpu.module @test_module { // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_expm1_f16(f16) -> f16 // CHECK: llvm.func @__ocml_expm1_f32(f32) -> f32 // CHECK: llvm.func @__ocml_expm1_f64(f64) -> f64 // CHECK-LABEL: func @gpu_expm1 - func.func @gpu_expm1(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_expm1(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.expm1 %arg_f16 : f16 + // CHECK: llvm.call @__ocml_expm1_f16(%{{.*}}) : (f16) -> f16 %expm1_f32 = math.expm1 %arg_f32 : f32 // CHECK: llvm.call @__ocml_expm1_f32(%{{.*}}) : (f32) -> f32 %result32 = math.expm1 %expm1_f32 : f32 // CHECK: llvm.call @__ocml_expm1_f32(%{{.*}}) : (f32) -> f32 %result64 = math.expm1 %arg_f64 : f64 // CHECK: llvm.call @__ocml_expm1_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_log_f16(f16) -> f16 // CHECK: llvm.func @__ocml_log_f64(f64) -> f64 // CHECK-LABEL: func @gpu_log - func.func @gpu_log(%arg_f64 : f64) -> (f64) { + func.func @gpu_log(%arg_f16 : f16, %arg_f64 : f64) -> (f16, f64) { + %result16 = math.log %arg_f16 : f16 + // CHECK: llvm.call @__ocml_log_f16(%{{.*}}) : (f16) -> f16 %result64 = math.log %arg_f64 : f64 // CHECK: llvm.call @__ocml_log_f64(%{{.*}}) : (f64) -> f64 - func.return %result64 : f64 + func.return %result16, %result64 : f16, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_log1p_f16(f16) -> f16 // CHECK: llvm.func @__ocml_log1p_f32(f32) -> f32 // CHECK: llvm.func @__ocml_log1p_f64(f64) -> f64 // CHECK-LABEL: func @gpu_log1p - func.func @gpu_log1p(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_log1p(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.log1p %arg_f16 : f16 + // CHECK: llvm.call @__ocml_log1p_f16(%{{.*}}) : (f16) -> f16 %result32 = math.log1p %arg_f32 : f32 // CHECK: llvm.call @__ocml_log1p_f32(%{{.*}}) : (f32) -> f32 %result64 = math.log1p %arg_f64 : f64 // CHECK: llvm.call @__ocml_log1p_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_log10_f16(f16) -> f16 // CHECK: llvm.func @__ocml_log10_f32(f32) -> f32 // CHECK: llvm.func @__ocml_log10_f64(f64) -> f64 // CHECK-LABEL: func @gpu_log10 - func.func @gpu_log10(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_log10(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.log10 %arg_f16 : f16 + // CHECK: llvm.call @__ocml_log10_f16(%{{.*}}) : (f16) -> f16 %result32 = math.log10 %arg_f32 : f32 // CHECK: llvm.call @__ocml_log10_f32(%{{.*}}) : (f32) -> f32 %result64 = math.log10 %arg_f64 : f64 // CHECK: llvm.call @__ocml_log10_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_log2_f16(f16) -> f16 // CHECK: llvm.func @__ocml_log2_f32(f32) -> f32 // CHECK: llvm.func @__ocml_log2_f64(f64) -> f64 // CHECK-LABEL: func @gpu_log2 - func.func @gpu_log2(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_log2(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.log2 %arg_f16 : f16 + // CHECK: llvm.call @__ocml_log2_f16(%{{.*}}) : (f16) -> f16 %result32 = math.log2 %arg_f32 : f32 // CHECK: llvm.call @__ocml_log2_f32(%{{.*}}) : (f32) -> f32 %result64 = math.log2 %arg_f64 : f64 // CHECK: llvm.call @__ocml_log2_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_rsqrt_f16(f16) -> f16 // CHECK: llvm.func @__ocml_rsqrt_f32(f32) -> f32 // CHECK: llvm.func @__ocml_rsqrt_f64(f64) -> f64 // CHECK-LABEL: func @gpu_rsqrt - func.func @gpu_rsqrt(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) - -> (f16, f32, f64) { + func.func @gpu_rsqrt(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { %result16 = math.rsqrt %arg_f16 : f16 - // CHECK: llvm.fpext %{{.*}} : f16 to f32 - // CHECK-NEXT: llvm.call @__ocml_rsqrt_f32(%{{.*}}) : (f32) -> f32 - // CHECK-NEXT: llvm.fptrunc %{{.*}} : f32 to f16 + // CHECK: llvm.call @__ocml_rsqrt_f16(%{{.*}}) : (f16) -> f16 %result32 = math.rsqrt %arg_f32 : f32 // CHECK: llvm.call @__ocml_rsqrt_f32(%{{.*}}) : (f32) -> f32 %result64 = math.rsqrt %arg_f64 : f64 @@ -398,90 +418,108 @@ gpu.module @test_module { // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_tan_f16(f16) -> f16 // CHECK: llvm.func @__ocml_tan_f32(f32) -> f32 // CHECK: llvm.func @__ocml_tan_f64(f64) -> f64 // CHECK-LABEL: func @gpu_tan - func.func @gpu_tan(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_tan(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.tan %arg_f16 : f16 + // CHECK: llvm.call @__ocml_tan_f16(%{{.*}}) : (f16) -> f16 %result32 = math.tan %arg_f32 : f32 // CHECK: llvm.call @__ocml_tan_f32(%{{.*}}) : (f32) -> f32 %result64 = math.tan %arg_f64 : f64 // CHECK: llvm.call @__ocml_tan_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_tanh_f16(f16) -> f16 // CHECK: llvm.func @__ocml_tanh_f32(f32) -> f32 // CHECK: llvm.func @__ocml_tanh_f64(f64) -> f64 // CHECK-LABEL: func @gpu_tanh - func.func @gpu_tanh(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_tanh(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.tanh %arg_f16 : f16 + // CHECK: llvm.call @__ocml_tanh_f16(%{{.*}}) : (f16) -> f16 %result32 = math.tanh %arg_f32 : f32 // CHECK: llvm.call @__ocml_tanh_f32(%{{.*}}) : (f32) -> f32 %result64 = math.tanh %arg_f64 : f64 // CHECK: llvm.call @__ocml_tanh_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_atan_f16(f16) -> f16 // CHECK: llvm.func @__ocml_atan_f32(f32) -> f32 // CHECK: llvm.func @__ocml_atan_f64(f64) -> f64 // CHECK-LABEL: func @gpu_atan - func.func @gpu_atan(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_atan(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.atan %arg_f16 : f16 + // CHECK: llvm.call @__ocml_atan_f16(%{{.*}}) : (f16) -> f16 %result32 = math.atan %arg_f32 : f32 // CHECK: llvm.call @__ocml_atan_f32(%{{.*}}) : (f32) -> f32 %result64 = math.atan %arg_f64 : f64 // CHECK: llvm.call @__ocml_atan_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_atan2_f16(f16, f16) -> f16 // CHECK: llvm.func @__ocml_atan2_f32(f32, f32) -> f32 // CHECK: llvm.func @__ocml_atan2_f64(f64, f64) -> f64 // CHECK-LABEL: func @gpu_atan2 - func.func @gpu_atan2(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_atan2(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.atan2 %arg_f16, %arg_f16 : f16 + // CHECK: llvm.call @__ocml_atan2_f16(%{{.*}}) : (f16, f16) -> f16 %result32 = math.atan2 %arg_f32, %arg_f32 : f32 // CHECK: llvm.call @__ocml_atan2_f32(%{{.*}}) : (f32, f32) -> f32 %result64 = math.atan2 %arg_f64, %arg_f64 : f64 // CHECK: llvm.call @__ocml_atan2_f64(%{{.*}}) : (f64, f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_pow_f16(f16, f16) -> f16 // CHECK: llvm.func @__ocml_pow_f32(f32, f32) -> f32 // CHECK: llvm.func @__ocml_pow_f64(f64, f64) -> f64 // CHECK-LABEL: func @gpu_pow - func.func @gpu_pow(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_pow(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.powf %arg_f16, %arg_f16 : f16 + // CHECK: llvm.call @__ocml_pow_f16(%{{.*}}, %{{.*}}) : (f16, f16) -> f16 %result32 = math.powf %arg_f32, %arg_f32 : f32 // CHECK: llvm.call @__ocml_pow_f32(%{{.*}}, %{{.*}}) : (f32, f32) -> f32 %result64 = math.powf %arg_f64, %arg_f64 : f64 // CHECK: llvm.call @__ocml_pow_f64(%{{.*}}, %{{.*}}) : (f64, f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_erf_f16(f16) -> f16 // CHECK: llvm.func @__ocml_erf_f32(f32) -> f32 // CHECK: llvm.func @__ocml_erf_f64(f64) -> f64 // CHECK-LABEL: func @gpu_erf - func.func @gpu_erf(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_erf(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = math.erf %arg_f16 : f16 + // CHECK: llvm.call @__ocml_erf_f16(%{{.*}}) : (f16) -> f16 %result32 = math.erf %arg_f32 : f32 // CHECK: llvm.call @__ocml_erf_f32(%{{.*}}) : (f32) -> f32 %result64 = math.erf %arg_f64 : f64 // CHECK: llvm.call @__ocml_erf_f64(%{{.*}}) : (f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } @@ -543,9 +581,9 @@ gpu.module @test_module { // ----- gpu.module @module { -// CHECK-LABEL: @spirv_exp +// CHECK-LABEL: @spirv_sin // CHECK: llvm.call @__ocml_sin_f32 - spirv.func @spirv_exp(%arg0: vector<4xf32>) -> vector<4xf32> "None" { + spirv.func @spirv_sin(%arg0: vector<4xf32>) -> vector<4xf32> "None" { %0 = math.sin %arg0 : vector<4xf32> spirv.ReturnValue %0 : vector<4xf32> } @@ -602,15 +640,18 @@ gpu.module @test_module { // ----- gpu.module @test_module { + // CHECK: llvm.func @__ocml_fmod_f16(f16, f16) -> f16 // CHECK: llvm.func @__ocml_fmod_f32(f32, f32) -> f32 // CHECK: llvm.func @__ocml_fmod_f64(f64, f64) -> f64 // CHECK-LABEL: func @gpu_fmod - func.func @gpu_fmod(%arg_f32 : f32, %arg_f64 : f64) -> (f32, f64) { + func.func @gpu_fmod(%arg_f16 : f16, %arg_f32 : f32, %arg_f64 : f64) -> (f16, f32, f64) { + %result16 = arith.remf %arg_f16, %arg_f16 : f16 + // CHECK: llvm.call @__ocml_fmod_f16(%{{.*}}, %{{.*}}) : (f16, f16) -> f16 %result32 = arith.remf %arg_f32, %arg_f32 : f32 // CHECK: llvm.call @__ocml_fmod_f32(%{{.*}}, %{{.*}}) : (f32, f32) -> f32 %result64 = arith.remf %arg_f64, %arg_f64 : f64 // CHECK: llvm.call @__ocml_fmod_f64(%{{.*}}, %{{.*}}) : (f64, f64) -> f64 - func.return %result32, %result64 : f32, f64 + func.return %result16, %result32, %result64 : f16, f32, f64 } } |
