[cfe-dev] Alignment of bitfield structs

Ahmed Bougacha ahmed.bougacha at gmail.com
Mon Apr 20 11:45:56 PDT 2015


On Mon, Apr 20, 2015 at 6:57 AM, Bradley Smith <bradley.smith at arm.com> wrote:
> Hi,
>
> I'm trying to fix what appears to be incorrect codegen to do with alignment
> of bitfield structs, but have hit a wall as to how to approach this. With
> the following testcase:
>
> extern struct T {
>   int b0 : 8;
>   int b1 : 24;
>   int b2 : 1;
> } g;
>
> int foo() {
>   return g.b1;
> }
>
> before optimization, Clang produces the following (for ARM, but I believe
> this is just as valid elsewhere):
>
> %struct.T = type { i40 }
>
> @g = external global %struct.T
>
> define arm_aapcscc i32 @foo() #0 {
> entry:
>   %bf.load = load i64, i64* bitcast (%struct.T* @g to i64*), align 4
>    ...
>
> This in itself seems correct, Clang has combined the bitfields into an i40
> but also noted an alignment of 4 to preserve the ABI alignment on the
> bitfield. The record layout being as below, which again, seems correct.
>
> Layout: <CGRecordLayout
>   LLVMType:%struct.T = type { i40 }
>   IsZeroInitializable:1
>   BitFields:[
>     <CGBitFieldInfo Offset:0 Size:8 IsSigned:1 StorageSize:64
> StorageAlignment:4>
>     <CGBitFieldInfo Offset:8 Size:24 IsSigned:1 StorageSize:64
> StorageAlignment:4>
>     <CGBitFieldInfo Offset:32 Size:1 IsSigned:1 StorageSize:64
> StorageAlignment:4>
> ]>
>
> However, when this IR goes down to LLVM there is no context of the bitfields
> left so LLVM just sees an i64 load from an i40. InstCombine sees this and
> blindly (but correctly I believe, based on the information it has) converts
> this load to the ABI alignment of i64, which is now incorrect.

Why is this incorrect?  It's only done because @g doesn't have an
explicit alignment, and will thus have the i64 ABI alignment.  If
that's not the expected behavior, would adding an explicit ", align 4"
to @g solve the issue?

-Ahmed

> From what I can tell there are only 2 ways to fix this, either have clang
> not combine the bitfield into an i40, or somehow pass the bitfield layout
> down to LLVM. Neither of these seem particularly easy to do, what are others
> thoughts on this, have I missed something? Thanks.
>
> Regards,
> Bradley Smith
>
>
>
> _______________________________________________
> cfe-dev mailing list
> cfe-dev at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev



More information about the cfe-dev mailing list