2007-12-08 23:42:33 +01:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2009-02-05 08:12:57 +01:00
|
|
|
/// \file hardware.h
|
2007-12-08 23:42:33 +01:00
|
|
|
/// \brief Detection of available hardware resources
|
|
|
|
//
|
2009-04-13 10:27:40 +02:00
|
|
|
// Author: Lasse Collin
|
2007-12-08 23:42:33 +01:00
|
|
|
//
|
2009-04-13 10:27:40 +02:00
|
|
|
// This file has been put into the public domain.
|
|
|
|
// You can do whatever you want with this file.
|
2007-12-08 23:42:33 +01:00
|
|
|
//
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Initialize some hardware-specific variables, which are needed by other
|
|
|
|
/// hardware_* functions.
|
2007-12-08 23:42:33 +01:00
|
|
|
extern void hardware_init(void);
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
|
2009-02-13 23:45:29 +01:00
|
|
|
/// Set custom value for maximum number of coder threads.
|
|
|
|
extern void hardware_threadlimit_set(uint32_t threadlimit);
|
|
|
|
|
|
|
|
/// Get the maximum number of coder threads. Some additional helper threads
|
|
|
|
/// are allowed on top of this).
|
|
|
|
extern uint32_t hardware_threadlimit_get(void);
|
|
|
|
|
|
|
|
|
2008-11-19 19:46:52 +01:00
|
|
|
/// Set custom memory usage limit. This is used for both encoding and
|
|
|
|
/// decoding. Zero indicates resetting the limit back to defaults.
|
|
|
|
extern void hardware_memlimit_set(uint64_t memlimit);
|
|
|
|
|
2009-05-22 10:29:50 +02:00
|
|
|
/// Set custom memory usage limit as a percentage of installed RAM.
|
|
|
|
/// The percentage must be in the range [1, 100].
|
|
|
|
extern void hardware_memlimit_set_percentage(uint32_t percentage);
|
2008-11-19 19:46:52 +01:00
|
|
|
|
2009-05-22 10:29:50 +02:00
|
|
|
/// Get the current memory usage limit.
|
|
|
|
extern uint64_t hardware_memlimit_get(void);
|