123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211 |
- #include <features.h>
- #include <bits/uClibc_mutex.h>
- #ifdef __UCLIBC_HAS_THREADS__
- # define HEAP_USE_LOCKING
- #endif
- #define __heap_lock(heap_lock) __UCLIBC_MUTEX_LOCK_CANCEL_UNSAFE(*(heap_lock))
- #define __heap_unlock(heap_lock) __UCLIBC_MUTEX_UNLOCK_CANCEL_UNSAFE(*(heap_lock))
- #define HEAP_GRANULARITY_TYPE double __attribute_aligned__ (HEAP_GRANULARITY)
- #define HEAP_GRANULARITY \
- (__alignof__ (double) > sizeof (size_t) ? __alignof__ (double) : sizeof (size_t))
- # define HEAP_INIT_WITH_FA(fa) &fa._fa
- struct heap_free_area
- {
- size_t size;
- struct heap_free_area *next, *prev;
- };
- #define HEAP_FREE_AREA_END(fa) ((void *)(fa + 1))
- #define HEAP_FREE_AREA_START(fa) ((void *)((char *)(fa + 1) - (fa)->size))
- #define HEAP_FREE_AREA_SIZE(fa) ((fa)->size)
- #define HEAP_DECLARE_STATIC_FREE_AREA(name, size) \
- static struct \
- { \
- HEAP_GRANULARITY_TYPE aligned_space; \
- char space[HEAP_ADJUST_SIZE(size) \
- - sizeof (struct heap_free_area) \
- - HEAP_GRANULARITY]; \
- struct heap_free_area _fa; \
- } name = { (HEAP_GRANULARITY_TYPE)0, "", { HEAP_ADJUST_SIZE(size), 0, 0 } }
- #define HEAP_ADJUST_SIZE(sz) \
- (((sz) + HEAP_GRANULARITY - 1) & ~(HEAP_GRANULARITY - 1))
- #define HEAP_MIN_SIZE HEAP_ADJUST_SIZE (sizeof (struct heap_free_area))
- #define HEAP_MIN_FREE_AREA_SIZE \
- HEAP_ADJUST_SIZE (sizeof (struct heap_free_area) + 32)
- #ifdef HEAP_DEBUGGING
- extern int __heap_debug attribute_hidden;
- #define HEAP_DEBUG(heap, str) (__heap_debug ? __heap_dump (heap, str) : 0)
- #else
- #define HEAP_DEBUG(heap, str) (void)0
- #endif
- extern void __heap_dump (struct heap_free_area *heap, const char *str) attribute_hidden;
- extern void __heap_check (struct heap_free_area *heap, const char *str) attribute_hidden;
- static __inline__ void
- __heap_delete (struct heap_free_area **heap, struct heap_free_area *fa)
- {
- if (fa->next)
- fa->next->prev = fa->prev;
- if (fa->prev)
- fa->prev->next = fa->next;
- else
- *heap = fa->next;
- }
- static __inline__ void
- __heap_link_free_area (struct heap_free_area **heap, struct heap_free_area *fa,
- struct heap_free_area *prev,
- struct heap_free_area *next)
- {
- fa->next = next;
- fa->prev = prev;
- if (prev)
- prev->next = fa;
- else
- *heap = fa;
- if (next)
- next->prev = fa;
- }
- static __inline__ void
- __heap_link_free_area_after (struct heap_free_area **heap,
- struct heap_free_area *fa,
- struct heap_free_area *prev)
- {
- if (prev)
- prev->next = fa;
- else
- *heap = fa;
- fa->prev = prev;
- }
- static __inline__ struct heap_free_area *
- __heap_add_free_area (struct heap_free_area **heap, void *mem, size_t size,
- struct heap_free_area *prev,
- struct heap_free_area *next)
- {
- struct heap_free_area *fa = (struct heap_free_area *)
- ((char *)mem + size - sizeof (struct heap_free_area));
- fa->size = size;
- __heap_link_free_area (heap, fa, prev, next);
- return fa;
- }
- static __inline__ size_t
- __heap_free_area_alloc (struct heap_free_area **heap,
- struct heap_free_area *fa, size_t size)
- {
- size_t fa_size = fa->size;
- if (fa_size < size + HEAP_MIN_FREE_AREA_SIZE)
-
- {
- __heap_delete (heap, fa);
-
- size = fa_size;
- }
- else
-
- fa->size = fa_size - size;
- return size;
- }
- extern void *__heap_alloc (struct heap_free_area **heap, size_t *size) attribute_hidden;
- extern size_t __heap_alloc_at (struct heap_free_area **heap, void *mem, size_t size) attribute_hidden;
- extern struct heap_free_area *__heap_free (struct heap_free_area **heap,
- void *mem, size_t size) attribute_hidden;
- #define __heap_is_empty(heap) (! (heap))
|