xref: /aosp_15_r20/external/lzma/C/BwtSort.h (revision f6dc9357d832569d4d1f5d24eacdb3935a1ae8e6)
1 /* BwtSort.h -- BWT block sorting
2 2023-03-03 : Igor Pavlov : Public domain */
3 
4 #ifndef ZIP7_INC_BWT_SORT_H
5 #define ZIP7_INC_BWT_SORT_H
6 
7 #include "7zTypes.h"
8 
9 EXTERN_C_BEGIN
10 
11 /* use BLOCK_SORT_EXTERNAL_FLAGS if blockSize can be > 1M */
12 /* #define BLOCK_SORT_EXTERNAL_FLAGS */
13 
14 #ifdef BLOCK_SORT_EXTERNAL_FLAGS
15 #define BLOCK_SORT_EXTERNAL_SIZE(blockSize) ((((blockSize) + 31) >> 5))
16 #else
17 #define BLOCK_SORT_EXTERNAL_SIZE(blockSize) 0
18 #endif
19 
20 #define BLOCK_SORT_BUF_SIZE(blockSize) ((blockSize) * 2 + BLOCK_SORT_EXTERNAL_SIZE(blockSize) + (1 << 16))
21 
22 UInt32 BlockSort(UInt32 *indices, const Byte *data, UInt32 blockSize);
23 
24 EXTERN_C_END
25 
26 #endif
27