开发者

g++ alignment problem

开发者 https://www.devze.com 2022-12-18 06:09 出处:网络
I have the following code: #include <stdio.h> int main(void) { int x __attribute__ ((aligned (16))) = 0;

I have the following code:

#include <stdio.h>

int main(void)
{
    int x __attribute__ ((aligned (16))) = 0;
    printf("%lX\n", &x);
    return 0;
}

Compiling and running this code using mingw32-c++.exe (GCC) 3.4.5 (mingw-vista special r3) prints 0x22FF24 which is 0b1000101111111100100100. Compiling and running this code using g++ (Debian 4.3.2-1.1) 4.3.2 prints 0x7FFFF470EE90 which is 0b11111111111111111110100011100001110111010010000.

Due to the alignment I expect the last 7 bits of the variable's address to be zero. Do I make an error in reasoni开发者_如何学运维ng here? What's going on?

Thanks in advance,

Sebastian


16=24, so I would expect the last 4 bits of the address to be zero if the address was aligned to a 16-byte boundary.

The stack is generally not guaranteed to have any sort of alignment on x86, see Bug 16660. Also, GCC is dependent on the linker for alignment of global/common variables, and binutils prior to 2.20 were not really capable of doing so on Windows.


Check the answer to question GCC __attribute__((aligned(x)) explanation which says:

Because the stack pointer could be anything when the function starts, there is no way to align the array without allocating a lot more than you need and adjusting it

0

精彩评论

暂无评论...
验证码 换一张
取 消