32bit Alignment
If I had a function:
size_t size;
byte *p, *newp;
newp = p + size;
how can I guarantee that newp is 32bit aligned?
newp = ((newp >> 2) << 2);
That will put you on a 4 byte alignment.
That will put you on a 4 byte alignment.
My Gamedev Journal: 2D Game Making, the Easy Way
---(Old Blog, still has good info): 2dGameMaking
-----
"No one ever posts on that message board; it's too crowded." - Yoga Berra (sorta)
I think the fact that size_t and byte* are (almost certainly) 32-bit variables will mean that they are aligned on a 32-bit boundary anyway. But I don''t technically know how to force this.
Kylotan,
While (byte *) is a 4 byte value (since it holds an address), it''s the address that needs to be on a 4-byte alignment. It''s a big deal for anyone who has done any MIPS low-level programming (since all Longs must be on 4 byte boundary, Words on 2 byte boundary, etc.).
While (byte *) is a 4 byte value (since it holds an address), it''s the address that needs to be on a 4-byte alignment. It''s a big deal for anyone who has done any MIPS low-level programming (since all Longs must be on 4 byte boundary, Words on 2 byte boundary, etc.).
My Gamedev Journal: 2D Game Making, the Easy Way
---(Old Blog, still has good info): 2dGameMaking
-----
"No one ever posts on that message board; it's too crowded." - Yoga Berra (sorta)
BeerNutts, I know what you''re getting at, but I was just making the point that compilers tend to start 4-byte variables on 4-byte boundaries anyway (they are just as conscious of speed as assembly programmers
). For example, I don''t think Visual C++ puts any data across a 4-byte boundary by default: you have to use #pragma pack to get it to do so, otherwise it uses empty padding inbetween.
data:image/s3,"s3://crabby-images/720a3/720a3c876447dbf8337dbc24336bd1830dded3e8" alt=""
This topic is closed to new replies.
Advertisement
Popular Topics
Advertisement
Recommended Tutorials
Advertisement