mirror of
https://gitlab.rtems.org/rtems/rtos/rtems.git
synced 2025-11-16 12:34:45 +00:00
2000-11-28 Chris Johns <ccj@acm.org>
* src/heapallocate.c: Do not allow the size to overflow when adjusting it. A test allocated a stack of -1 (~0). This actually resulted in a stack being allocated but with a size of 0xb. The allocator did not test the size to see if it rolled through 0 and so allowed the allocation to happen, the thread to get created. The task crashed as you would expect.
This commit is contained in:
@@ -44,6 +44,14 @@ void *_Heap_Allocate(
|
||||
void *ptr;
|
||||
unsigned32 offset;
|
||||
|
||||
/*
|
||||
* Catch the case of a user allocating close to the limit of the
|
||||
* unsigned32.
|
||||
*/
|
||||
|
||||
if ( size >= (-1 - HEAP_BLOCK_USED_OVERHEAD) )
|
||||
return( NULL );
|
||||
|
||||
excess = size % the_heap->page_size;
|
||||
the_size = size + the_heap->page_size + HEAP_BLOCK_USED_OVERHEAD;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user