27 lines
797 B
C
27 lines
797 B
C
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||
|
/*
|
||
|
* Copyright 2023 Red Hat
|
||
|
*/
|
||
|
|
||
|
#ifndef UDS_RADIX_SORT_H
|
||
|
#define UDS_RADIX_SORT_H
|
||
|
|
||
|
/*
|
||
|
* Radix sort is implemented using an American Flag sort, an unstable, in-place 8-bit radix
|
||
|
* exchange sort. This is adapted from the algorithm in the paper by Peter M. McIlroy, Keith
|
||
|
* Bostic, and M. Douglas McIlroy, "Engineering Radix Sort".
|
||
|
*
|
||
|
* http://www.usenix.org/publications/compsystems/1993/win_mcilroy.pdf
|
||
|
*/
|
||
|
|
||
|
struct radix_sorter;
|
||
|
|
||
|
int __must_check uds_make_radix_sorter(unsigned int count, struct radix_sorter **sorter);
|
||
|
|
||
|
void uds_free_radix_sorter(struct radix_sorter *sorter);
|
||
|
|
||
|
int __must_check uds_radix_sort(struct radix_sorter *sorter, const unsigned char *keys[],
|
||
|
unsigned int count, unsigned short length);
|
||
|
|
||
|
#endif /* UDS_RADIX_SORT_H */
|