llvm/clang/test/CodeGenCXX/finegrain-bitfield-type.cpp

// RUN: %clang_cc1 -triple x86_64-linux-gnu -ffine-grained-bitfield-accesses \
// RUN:   -emit-llvm -o - %s | FileCheck %s
// RUN: %clang_cc1 -triple riscv64-linux-gnu -ffine-grained-bitfield-accesses \
// RUN:   -emit-llvm -o - %s | FileCheck %s

// Note: This test checks the X86-64 and RISC-V targets in order to explore
// behaviour when i8/i16 are native integer widths (X86-64) and when they're
// not (RISC-V).

struct S4 {
  unsigned long f1:28;
  unsigned long f2:4;
  unsigned long f3:12;
};
struct S4 a4;

struct S5 {
  unsigned long f1:28;
  unsigned long f2:4;
  unsigned long f3:28;
  unsigned long f4:4;
  unsigned long f5:12;
};
struct S5 a5;

// CHECK: %struct.S4 = type { i32, i16 }
// CHECK-NOT: %struct.S4 = type { i48 }
// CHECK: %struct.S5 = type { i32, i32, i16, [6 x i8] }
// CHECK-NOT: %struct.S5 = type { i80 }