46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
| #include <_ansi.h>
 | |
| #include <sys/types.h>
 | |
| #include <sys/stat.h>
 | |
| 
 | |
| #include "regs.S"
 | |
| 
 | |
| extern char _end[];
 | |
| 
 | |
| /* FIXME: This is not ideal, since we do a get_mem_info() call for
 | |
|    every sbrk() call. */
 | |
| char *
 | |
| sbrk (nbytes)
 | |
|      int nbytes;
 | |
| {
 | |
|   static char *heap_ptr = _end;
 | |
|   static char *heap_start = _end;
 | |
|   char        *base;
 | |
|   struct s_mem {
 | |
|     unsigned int size;
 | |
|     unsigned int icsize;
 | |
|     unsigned int dcsize;
 | |
|   } mem;
 | |
|   unsigned int avail = 0;
 | |
| 
 | |
|   /* The sizeof (s_mem.size) must be 4 bytes.  The compiler should be
 | |
|      able to eliminate this check */
 | |
|   if (sizeof (unsigned int) != 4)
 | |
|     return (char *)-1;
 | |
| 
 | |
|   get_mem_info(&mem);
 | |
|   /* NOTE: The value returned from the get_mem_info call is the amount
 | |
|      of memory, and not the address of the (last byte + 1) */
 | |
| 
 | |
|   if (((size_t)heap_ptr >= heap_start) && ((size_t)heap_ptr < (heap_start + mem.size))) {
 | |
|     avail = (heap_start + mem.size) - (size_t)heap_ptr;
 | |
|     base = heap_ptr;
 | |
|   } /* else will fail since "nbytes" will be greater than zeroed "avail" value */
 | |
| 
 | |
|   if ((nbytes > avail) || (heap_ptr + nbytes < _end))
 | |
|    base = (char *)-1;
 | |
|   else
 | |
|    heap_ptr += nbytes;
 | |
| 
 | |
|   return base;
 | |
| }
 |