Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Welcome to Software Development on Codidact!

Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.

Post History

60%
+1 −0
Q&A What is malloc's standard-defined behavior with respect to the amount of memory it allocates?

Here's a relevant bit from the standard (C89, section 7.20.3): The pointer returned if the allocation succeeds is suitably aligned so that it may be assigned to a pointer to any type of object...

posted 3y ago by bta‭

Answer
#1: Initial revision by user avatar bta‭ · 2022-01-12T01:13:35Z (almost 3 years ago)
Here's a relevant bit from the standard ([C89](http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1256.pdf), section 7.20.3):


 > The pointer returned if the allocation succeeds is
 > suitably aligned so that it may be assigned to a pointer
 > to any type of object and then used to access such an
 > object or an array of such objects in the space allocated

In other words, the compiler/library has to ensure that the pointer that `malloc` returns is aligned to whatever alignment requirements the current platform has.  If your platform requires 32-bit I/O to be aligned to 4-byte boundaries, then `malloc` is going to give you a pointer that's aligned to a 4-byte boundary.  The pointer has to work with "any type" of object (since you can't pass type information to `malloc`), so that means it will be aligned to whatever the strictest boundary for your platform is.  In a lot of cases this corresponds to the word size of the machine.

In your specific case, you only saw the problem when `N` was a multiple of 8.  Most likely, your platform's alignment rules required `malloc` to return pointers aligned to 8-byte boundaries.  When your allocation wasn't a multiple of 8 bytes, the `size % 8` bytes of space between the end of your buffer and the next 8-byte boundary were unused.  You could write into these bytes because there was no way for `malloc` to allocate them for someone else without generating a pointer that didn't meet the requirement above.  When `N` is indeed a multiple of 8, then the very next byte after the array is allocatable, and writing into it risks overwriting someone else's memory.  An interesting side effect is that code that appears to work on your machine might not work on a hardware platform that has different alignment requirements.