Skip to content
Snippets Groups Projects
Commit 1a76cd17 authored by Nick Mathewson's avatar Nick Mathewson :game_die:
Browse files

When a struct ends with char a[1], the size of all earlier members of the...

When a struct ends with char a[1], the size of all earlier members of the struct is _not_ sizeof(st)-1;  compilers add alignment.  Problem spotted by rovv.  Backport candidate.

svn:r16302
parent 626fafe5
No related branches found
No related tags found
No related merge requests found
......@@ -52,6 +52,8 @@ Changes in version 0.2.1.3-alpha - 2008-07-xx
HiddenServiceExcludeNodes as obsolete: they never worked properly,
and nobody claims to be using them. Fixes bug 754. Bugfix on
0.1.0.1-rc. Patch from Christian Wilms.
- Fix a small alignment and memory-wasting bug on buffer chunks. Spotted
by rovv.
o Minor bugfixes (controller):
- When closing an application-side connection because its circuit
......
......@@ -69,12 +69,14 @@ typedef struct chunk_t {
* more than one byte long. */
} chunk_t;
#define CHUNK_HEADER_LEN STRUCT_OFFSET(chunk_t, mem[0])
/** Return the number of bytes needed to allocate a chunk to hold
* <b>memlen</b> bytes. */
#define CHUNK_ALLOC_SIZE(memlen) (sizeof(chunk_t) + (memlen) - 1)
#define CHUNK_ALLOC_SIZE(memlen) (CHUNK_HEADER_LEN + (memlen))
/** Return the number of usable bytes in a chunk allocated with
* malloc(<b>memlen</b>). */
#define CHUNK_SIZE_WITH_ALLOC(memlen) ((memlen) - sizeof(chunk_t) + 1)
#define CHUNK_SIZE_WITH_ALLOC(memlen) ((memlen) - CHUNK_HEADER_LEN)
/** Return the next character in <b>chunk</b> onto which data can be appended.
* If the chunk is full, this might be off the end of chunk->mem. */
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment