Lines Matching refs:es
60 #define SWAPINIT(TYPE, a, es) swaptype_ ## TYPE = \
62 es % sizeof(TYPE) ? 2 : es == sizeof(TYPE) ? 0 : 1;
85 swapfunc(a, b, es, swaptype_long, swaptype_int)
110 qsort_r(void *a, size_t n, size_t es, void *thunk, cmp_t *cmp)
114 qsort(void *a, size_t n, size_t es, cmp_t *cmp)
122 loop: SWAPINIT(long, a, es);
123 SWAPINIT(int, a, es);
126 for (pm = (char *)a + es; pm < (char *)a + n * es; pm += es)
128 pl > (char *)a && CMP(thunk, pl - es, pl) > 0;
129 pl -= es)
130 swap(pl, pl - es);
133 pm = (char *)a + (n / 2) * es;
136 pn = (char *)a + (n - 1) * es;
138 size_t d = (n / 8) * es;
147 pa = pb = (char *)a + es;
149 pc = pd = (char *)a + (n - 1) * es;
155 pa += es;
157 pb += es;
163 pd -= es;
165 pc -= es;
171 pb += es;
172 pc -= es;
175 for (pm = (char *)a + es; pm < (char *)a + n * es; pm += es)
177 pl > (char *)a && CMP(thunk, pl - es, pl) > 0;
178 pl -= es)
179 swap(pl, pl - es);
183 pn = (char *)a + n * es;
186 d1 = MIN(pd - pc, pn - pd - es);
193 if (d1 > es) {
195 qsort_r(a, d1 / es, es, thunk, cmp);
197 qsort(a, d1 / es, es, cmp);
200 if (d2 > es) {
202 /* qsort(pn - d2, d2 / es, es, cmp); */
204 n = d2 / es;
209 if (d2 > es) {
211 qsort_r(pn - d2, d2 / es, es, thunk, cmp);
213 qsort(pn - d2, d2 / es, es, cmp);
216 if (d1 > es) {
218 /* qsort(a, d1 / es, es, cmp); */
219 n = d1 / es;