xref: /llvm-project/clang/test/Frontend/fixed_point_div_const.c (revision 79382eb97adff71dbc9d4969431dd4a0967ee7ad)
1c5de4dd1SFangrui Song // RUN: %clang_cc1 -ffixed-point -triple x86_64-unknown-linux-gnu -emit-llvm %s -o - | FileCheck %s --check-prefixes=CHECK,SIGNED
2c5de4dd1SFangrui Song // RUN: %clang_cc1 -ffixed-point -triple x86_64-unknown-linux-gnu -fpadding-on-unsigned-fixed-point -emit-llvm %s -o - | FileCheck %s --check-prefixes=CHECK,UNSIGNED
344ebc2c8SBevin Hansson 
4*79382eb9STimm Baeder // RUN: %clang_cc1 -ffixed-point -triple x86_64-unknown-linux-gnu -emit-llvm %s -o - -fexperimental-new-constant-interpreter | FileCheck %s --check-prefixes=CHECK,SIGNED
5*79382eb9STimm Baeder // RUN: %clang_cc1 -ffixed-point -triple x86_64-unknown-linux-gnu -fpadding-on-unsigned-fixed-point -emit-llvm %s -o - -fexperimental-new-constant-interpreter | FileCheck %s --check-prefixes=CHECK,UNSIGNED
6*79382eb9STimm Baeder 
744ebc2c8SBevin Hansson // Division between different fixed point types
844ebc2c8SBevin Hansson short _Accum sa_const = 1.0hk / 2.0hk;
944ebc2c8SBevin Hansson // CHECK-DAG: @sa_const  = {{.*}}global i16 64, align 2
1044ebc2c8SBevin Hansson _Accum a_const = 1.0hk / 2.0k;
1144ebc2c8SBevin Hansson // CHECK-DAG: @a_const   = {{.*}}global i32 16384, align 4
1244ebc2c8SBevin Hansson long _Accum la_const = 1.0hk / 2.0lk;
1344ebc2c8SBevin Hansson // CHECK-DAG: @la_const  = {{.*}}global i64 1073741824, align 8
1444ebc2c8SBevin Hansson short _Accum sa_const2 = 0.5hr / 2.0hk;
1544ebc2c8SBevin Hansson // CHECK-DAG: @sa_const2  = {{.*}}global i16 32, align 2
1644ebc2c8SBevin Hansson short _Accum sa_const3 = 0.5r / 2.0hk;
1744ebc2c8SBevin Hansson // CHECK-DAG: @sa_const3  = {{.*}}global i16 32, align 2
1844ebc2c8SBevin Hansson short _Accum sa_const4 = 0.5lr / 2.0hk;
1944ebc2c8SBevin Hansson // CHECK-DAG: @sa_const4  = {{.*}}global i16 32, align 2
2044ebc2c8SBevin Hansson short _Accum sa_const5 = 2.0hk / 0.5lr;
2144ebc2c8SBevin Hansson // CHECK-DAG: @sa_const5  = {{.*}}global i16 512, align 2
2244ebc2c8SBevin Hansson 
2344ebc2c8SBevin Hansson // Unsigned division
2444ebc2c8SBevin Hansson unsigned short _Accum usa_const = 3.0uhk / 2.0uhk;
2544ebc2c8SBevin Hansson // SIGNED-DAG:   @usa_const = {{.*}}global i16 384, align 2
2644ebc2c8SBevin Hansson // UNSIGNED-DAG: @usa_const = {{.*}}global i16 192, align 2
2744ebc2c8SBevin Hansson 
2844ebc2c8SBevin Hansson // Unsigned / signed
2944ebc2c8SBevin Hansson short _Accum sa_const6 = 1.0uhk / 2.0hk;
3044ebc2c8SBevin Hansson // CHECK-DAG: @sa_const6 = {{.*}}global i16 64, align 2
3144ebc2c8SBevin Hansson 
3244ebc2c8SBevin Hansson // Division with negative number
3344ebc2c8SBevin Hansson short _Accum sa_const7 = 0.5hr / (-2.0hk);
3444ebc2c8SBevin Hansson // CHECK-DAG: @sa_const7 = {{.*}}global i16 -32, align 2
3544ebc2c8SBevin Hansson 
3644ebc2c8SBevin Hansson // Int division
3744ebc2c8SBevin Hansson unsigned short _Accum usa_const2 = 2 / 0.5uhk;
3844ebc2c8SBevin Hansson // SIGNED-DAG:   @usa_const2 = {{.*}}global i16 1024, align 2
3944ebc2c8SBevin Hansson // UNSIGNED-DAG: @usa_const2 = {{.*}}global i16 512, align 2
4044ebc2c8SBevin Hansson short _Accum sa_const8 = 2 / (-0.5hk);
4144ebc2c8SBevin Hansson // CHECK-DAG: @sa_const8 = {{.*}}global i16 -512, align 2
4244ebc2c8SBevin Hansson short _Accum sa_const9 = 256 / 2.0hk;
4344ebc2c8SBevin Hansson // CHECK-DAG: @sa_const9 = {{.*}}global i16 16384, align 2
4444ebc2c8SBevin Hansson long _Fract lf_const = 0.5lr / -1;
4544ebc2c8SBevin Hansson // CHECK-DAG: @lf_const  = {{.*}}global i32 -1073741824, align 4
4644ebc2c8SBevin Hansson 
4744ebc2c8SBevin Hansson // Saturated division
4844ebc2c8SBevin Hansson _Sat short _Accum sat_sa_const = (_Sat short _Accum)128.0hk / (-0.25hk);
4944ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const = {{.*}}global i16 -32768, align 2
5044ebc2c8SBevin Hansson _Sat unsigned short _Accum sat_usa_const = (_Sat unsigned short _Accum)128.0uhk / (0.25uhk);
5144ebc2c8SBevin Hansson // SIGNED-DAG:   @sat_usa_const = {{.*}}global i16 -1, align 2
5244ebc2c8SBevin Hansson // UNSIGNED-DAG: @sat_usa_const = {{.*}}global i16 32767, align 2
5344ebc2c8SBevin Hansson _Sat short _Accum sat_sa_const2 = (_Sat short _Accum)-128.0hk / (-0.0125hr);
5444ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const2 = {{.*}}global i16 32767, align 2
5544ebc2c8SBevin Hansson _Sat unsigned short _Accum sat_usa_const2 = (_Sat unsigned short _Accum)128.0uhk / (-128);
5644ebc2c8SBevin Hansson // CHECK-DAG:   @sat_usa_const2 = {{.*}}global i16 0, align 2
5744ebc2c8SBevin Hansson _Sat unsigned short _Accum sat_usa_const3 = (_Sat unsigned short _Accum)0.5uhk / -1;
5844ebc2c8SBevin Hansson // CHECK-DAG:   @sat_usa_const3 = {{.*}}global i16 0, align 2
5944ebc2c8SBevin Hansson _Sat short _Accum sat_sa_const3 = (_Sat short _Accum)-128.0hk / 128;
6044ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const3 = {{.*}}global i16 -128, align 2
6144ebc2c8SBevin Hansson _Sat short _Accum sat_sa_const4 = (_Sat short _Accum)-25.7hk / 0.1lk;
6244ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const4 = {{.*}}global i16 -32768, align 2
6344ebc2c8SBevin Hansson 
6444ebc2c8SBevin Hansson // Some more cases
6544ebc2c8SBevin Hansson short _Accum sa_const10 = 255.9921875hk / 255.9921875hk;
6644ebc2c8SBevin Hansson // CHECK-DAG: @sa_const10 = {{.*}}global i16 128, align 2
6744ebc2c8SBevin Hansson short _Accum sat_sa_const5 = (_Sat short _Accum)(-255.0hk - 1.0hk) / 0.0078125hk;
6844ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const5 = {{.*}}global i16 -32768, align 2
6944ebc2c8SBevin Hansson _Sat short _Accum sat_sa_const6 = (_Sat short _Accum)(-255.0hk - 1.0hk) / -0.0078125hk;
7044ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const6 = {{.*}}global i16 32767, align 2
7144ebc2c8SBevin Hansson short _Accum sa_const12 = 255.9921875hk / -1.0hk;
7244ebc2c8SBevin Hansson // CHECK-DAG: @sa_const12 = {{.*}}global i16 -32767, align 2
7344ebc2c8SBevin Hansson _Sat short _Accum sat_sa_const7 = (_Sat short _Accum)(-255.0hk - 1.0hk) / -1.0hk;
7444ebc2c8SBevin Hansson // CHECK-DAG: @sat_sa_const7 = {{.*}}global i16 32767, align 2
7544ebc2c8SBevin Hansson short _Accum sa_const13 = 0.0234375hk / 2.0hk;
7644ebc2c8SBevin Hansson // CHECK-DAG: @sa_const13 = {{.*}}global i16 1, align 2
7744ebc2c8SBevin Hansson short _Accum sa_const14 = -0.0234375hk / 2.0hk;
7844ebc2c8SBevin Hansson // CHECK-DAG: @sa_const14 = {{.*}}global i16 -2, align 2
7944ebc2c8SBevin Hansson short _Accum sa_const15 = -0.0078125hk / 255.28125hk;
8044ebc2c8SBevin Hansson // CHECK-DAG: @sa_const15 = {{.*}}global i16 -1, align 2
81