|
SDL
2.0
|
Include dependency graph for SDL_qsort.c:Go to the source code of this file.
Data Structures | |
| struct | stack_entry |
Macros | |
| #define | assert SDL_assert |
| #define | malloc SDL_malloc |
| #define | free SDL_free |
| #define | memcpy SDL_memcpy |
| #define | memmove SDL_memmove |
| #define | qsortG SDL_qsort |
| #define | WORD_BYTES sizeof(int) |
| #define | STACK_SIZE (8*sizeof(size_t)) |
| #define | TRUNC_nonaligned 12 |
| #define | TRUNC_aligned 12 |
| #define | TRUNC_words 12*WORD_BYTES /* nb different meaning */ |
| #define | PIVOT_THRESHOLD 40 |
| #define | pushLeft {stack[stacktop].first=ffirst;stack[stacktop++].last=last;} |
| #define | pushRight {stack[stacktop].first=first;stack[stacktop++].last=llast;} |
| #define | doLeft {first=ffirst;llast=last;continue;} |
| #define | doRight {ffirst=first;last=llast;continue;} |
| #define | pop |
| #define | Recurse(Trunc) |
| #define | Pivot(swapper, sz) |
| #define | Partition(swapper, sz) |
| #define | PreInsertion(swapper, limit, sz) |
| #define | Insertion(swapper) |
| #define | SWAP_nonaligned(a, b) |
| #define | SWAP_aligned(a, b) |
| #define | SWAP_words(a, b) |
Functions | |
| static char * | pivot_big (char *first, char *mid, char *last, size_t size, int compare(const void *, const void *)) |
| static void | qsort_nonaligned (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
| static void | qsort_aligned (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
| static void | qsort_words (void *base, size_t nmemb, int(*compare)(const void *, const void *)) |
| void | qsortG (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
| #define assert SDL_assert |
Definition at line 43 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define doLeft {first=ffirst;llast=last;continue;} |
Definition at line 190 of file SDL_qsort.c.
| #define doRight {ffirst=first;last=llast;continue;} |
Definition at line 191 of file SDL_qsort.c.
| #define free SDL_free |
Definition at line 51 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define Insertion | ( | swapper | ) |
Definition at line 330 of file SDL_qsort.c.
Referenced by qsort_aligned(), and qsort_nonaligned().
| #define malloc SDL_malloc |
Definition at line 47 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define memcpy SDL_memcpy |
Definition at line 55 of file SDL_qsort.c.
Referenced by qsort_aligned(), and qsort_nonaligned().
| #define memmove SDL_memmove |
Definition at line 59 of file SDL_qsort.c.
Referenced by SDL_memmove().
| #define Partition | ( | swapper, | |
| sz | |||
| ) |
Definition at line 301 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define Pivot | ( | swapper, | |
| sz | |||
| ) |
Definition at line 277 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define PIVOT_THRESHOLD 40 |
Definition at line 185 of file SDL_qsort.c.
| #define pop |
Definition at line 192 of file SDL_qsort.c.
Referenced by CPU_haveCPUID(), SDL_SoftStretch(), and SDL_tolower().
| #define PreInsertion | ( | swapper, | |
| limit, | |||
| sz | |||
| ) |
Definition at line 321 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define pushLeft {stack[stacktop].first=ffirst;stack[stacktop++].last=last;} |
Definition at line 188 of file SDL_qsort.c.
Definition at line 189 of file SDL_qsort.c.
| #define qsortG SDL_qsort |
Definition at line 63 of file SDL_qsort.c.
| #define Recurse | ( | Trunc | ) |
Definition at line 265 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define STACK_SIZE (8*sizeof(size_t)) |
Definition at line 168 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
Definition at line 353 of file SDL_qsort.c.
Referenced by qsort_aligned().
Definition at line 348 of file SDL_qsort.c.
Referenced by qsort_nonaligned().
| #define TRUNC_aligned 12 |
Definition at line 178 of file SDL_qsort.c.
Referenced by qsort_aligned().
| #define TRUNC_nonaligned 12 |
Definition at line 177 of file SDL_qsort.c.
Referenced by qsort_nonaligned().
| #define TRUNC_words 12*WORD_BYTES /* nb different meaning */ |
Definition at line 179 of file SDL_qsort.c.
Referenced by qsort_words().
| #define WORD_BYTES sizeof(int) |
Definition at line 163 of file SDL_qsort.c.
Referenced by qsort_words(), and qsortG().
|
static |
Definition at line 363 of file SDL_qsort.c.
References d.
|
static |
Definition at line 435 of file SDL_qsort.c.
References assert, free, Insertion, malloc, memcpy, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_aligned, and TRUNC_aligned.
Referenced by qsortG().
|
static |
Definition at line 404 of file SDL_qsort.c.
References assert, free, Insertion, malloc, memcpy, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_nonaligned, and TRUNC_nonaligned.
Referenced by qsortG().
|
static |
Definition at line 466 of file SDL_qsort.c.
References assert, free, malloc, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_words, TRUNC_words, and WORD_BYTES.
Referenced by qsortG().
Definition at line 518 of file SDL_qsort.c.
References qsort_aligned(), qsort_nonaligned(), qsort_words(), and WORD_BYTES.