fixed_point_same_fbits.c 1.2 KB

12345678910111213141516171819202122232425262728
  1. // RUN: %clang -ffixed-point -S -emit-llvm -o - %s | FileCheck %s -check-prefix=DEFAULT
  2. // RUN: %clang_cc1 -ffixed-point -fpadding-on-unsigned-fixed-point -S -emit-llvm -o - %s | FileCheck %s -check-prefix=SAME
  3. /* The scale for unsigned fixed point types should be the same as that of signed
  4. * fixed point types when -fsame-fbits is enabled. */
  5. void func() {
  6. unsigned short _Accum u_short_accum = 0.5uhk;
  7. unsigned _Accum u_accum = 0.5uk;
  8. unsigned long _Accum u_long_accum = 0.5ulk;
  9. unsigned short _Fract u_short_fract = 0.5uhr;
  10. unsigned _Fract u_fract = 0.5ur;
  11. unsigned long _Fract u_long_fract = 0.5ulr;
  12. // DEFAULT: store i16 128, i16* {{.*}}, align 2
  13. // DEFAULT: store i32 32768, i32* {{.*}}, align 4
  14. // DEFAULT: store i64 2147483648, i64* {{.*}}, align 8
  15. // DEFAULT: store i8 -128, i8* {{.*}}, align 1
  16. // DEFAULT: store i16 -32768, i16* {{.*}}, align 2
  17. // DEFAULT: store i32 -2147483648, i32* {{.*}}, align 4
  18. // SAME: store i16 64, i16* {{.*}}, align 2
  19. // SAME: store i32 16384, i32* {{.*}}, align 4
  20. // SAME: store i64 1073741824, i64* {{.*}}, align 8
  21. // SAME: store i8 64, i8* {{.*}}, align 1
  22. // SAME: store i16 16384, i16* {{.*}}, align 2
  23. // SAME: store i32 1073741824, i32* {{.*}}, align 4
  24. }