/** * @file efilib.h * * @date Feb 21, 2014 * @author Andrey Belomutskiy, (c) 2012-2015 */ #ifndef EFILIB_H_ #define EFILIB_H_ #include #include "global.h" // http://en.wikipedia.org/wiki/Endianness #define SWAP_UINT16(x) ((x) << 8) | ((x) >> 8) #define SWAP_UINT32(x) (((x) >> 24) & 0xff) | (((x) << 8) & 0xff0000) | (((x) >> 8) & 0xff00) | (((x) << 24) & 0xff000000) // number of milliseconds in one period of given frequency (per second) #define frequency2periodMs(freq) ((1000.0f) / (freq)) // number of microseconds in one period of given frequency (per second) #define frequency2periodUs(freq) ((1000000.0f) / (freq)) #ifndef FALSE #define FALSE 0 #endif #ifndef TRUE #define TRUE (!FALSE) #endif #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ #define ERROR_CODE 311223344 const char * boolToString(bool value); uint32_t efiStrlen(const char *param); int efiPow10(int param); bool startsWith(const char *line, const char *prefix); int indexOf(const char *string, char ch); float atoff(const char *string); int atoi(const char *string); /** * there is some BS related to isnan in MinGW, so let's have all the issues in one place */ #define cisnan(f) (*(((int*) (&f))) == 0x7FC00000) int absI(int32_t value); float absF(float value); float efiRound(float value, float precision); int maxI(int i1, int i2); int minI(int i1, int i2); float maxF(float i1, float i2); float minF(float i1, float i2); char* itoa10(char *p, int num); bool isSameF(float v1, float v2); bool strEqualCaseInsensitive(const char *str1, const char *str2); bool strEqual(const char *str1, const char *str2); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* EFILIB_H_ */