Mercurial > repos > rliterman > csp2
comparison CSP2/CSP2_env/env-d9b9114564458d9d-741b3de822f2aaca6c6caa4325c4afce/include/lzma/hardware.h @ 69:33d812a61356
planemo upload commit 2e9511a184a1ca667c7be0c6321a36dc4e3d116d
author | jpayne |
---|---|
date | Tue, 18 Mar 2025 17:55:14 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
67:0e9998148a16 | 69:33d812a61356 |
---|---|
1 /* SPDX-License-Identifier: 0BSD */ | |
2 | |
3 /** | |
4 * \file lzma/hardware.h | |
5 * \brief Hardware information | |
6 * \note Never include this file directly. Use <lzma.h> instead. | |
7 * | |
8 * Since liblzma can consume a lot of system resources, it also provides | |
9 * ways to limit the resource usage. Applications linking against liblzma | |
10 * need to do the actual decisions how much resources to let liblzma to use. | |
11 * To ease making these decisions, liblzma provides functions to find out | |
12 * the relevant capabilities of the underlying hardware. Currently there | |
13 * is only a function to find out the amount of RAM, but in the future there | |
14 * will be also a function to detect how many concurrent threads the system | |
15 * can run. | |
16 * | |
17 * \note On some operating systems, these function may temporarily | |
18 * load a shared library or open file descriptor(s) to find out | |
19 * the requested hardware information. Unless the application | |
20 * assumes that specific file descriptors are not touched by | |
21 * other threads, this should have no effect on thread safety. | |
22 * Possible operations involving file descriptors will restart | |
23 * the syscalls if they return EINTR. | |
24 */ | |
25 | |
26 /* | |
27 * Author: Lasse Collin | |
28 */ | |
29 | |
30 #ifndef LZMA_H_INTERNAL | |
31 # error Never include this file directly. Use <lzma.h> instead. | |
32 #endif | |
33 | |
34 | |
35 /** | |
36 * \brief Get the total amount of physical memory (RAM) in bytes | |
37 * | |
38 * This function may be useful when determining a reasonable memory | |
39 * usage limit for decompressing or how much memory it is OK to use | |
40 * for compressing. | |
41 * | |
42 * \return On success, the total amount of physical memory in bytes | |
43 * is returned. If the amount of RAM cannot be determined, | |
44 * zero is returned. This can happen if an error occurs | |
45 * or if there is no code in liblzma to detect the amount | |
46 * of RAM on the specific operating system. | |
47 */ | |
48 extern LZMA_API(uint64_t) lzma_physmem(void) lzma_nothrow; | |
49 | |
50 | |
51 /** | |
52 * \brief Get the number of processor cores or threads | |
53 * | |
54 * This function may be useful when determining how many threads to use. | |
55 * If the hardware supports more than one thread per CPU core, the number | |
56 * of hardware threads is returned if that information is available. | |
57 * | |
58 * \return On success, the number of available CPU threads or cores is | |
59 * returned. If this information isn't available or an error | |
60 * occurs, zero is returned. | |
61 */ | |
62 extern LZMA_API(uint32_t) lzma_cputhreads(void) lzma_nothrow; |