123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269 |
- // SPDX-License-Identifier: GPL-3.0-or-later
- #ifndef NETDATA_INLINED_H
- #define NETDATA_INLINED_H 1
- #include "libnetdata.h"
- #ifdef KERNEL_32BIT
- typedef uint32_t kernel_uint_t;
- #define str2kernel_uint_t(string) str2uint32_t(string)
- #define KERNEL_UINT_FORMAT "%u"
- #else
- typedef uint64_t kernel_uint_t;
- #define str2kernel_uint_t(string) str2uint64_t(string)
- #define KERNEL_UINT_FORMAT "%" PRIu64
- #endif
- #define str2pid_t(string) str2uint32_t(string)
- // for faster execution, allow the compiler to inline
- // these functions that are called thousands of times per second
- static inline uint32_t simple_hash(const char *name) {
- unsigned char *s = (unsigned char *) name;
- uint32_t hval = 0x811c9dc5;
- while (*s) {
- hval *= 16777619;
- hval ^= (uint32_t) *s++;
- }
- return hval;
- }
- static inline uint32_t simple_uhash(const char *name) {
- unsigned char *s = (unsigned char *) name;
- uint32_t hval = 0x811c9dc5, c;
- while ((c = *s++)) {
- if (unlikely(c >= 'A' && c <= 'Z')) c += 'a' - 'A';
- hval *= 16777619;
- hval ^= c;
- }
- return hval;
- }
- static inline int str2i(const char *s) {
- int n = 0;
- char c, negative = (char)(*s == '-');
- const char *e = s + 30; // max number of character to iterate
- for(c = (char)((negative)?*(++s):*s); c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- if(unlikely(negative))
- return -n;
- return n;
- }
- static inline long str2l(const char *s) {
- long n = 0;
- char c, negative = (*s == '-');
- const char *e = &s[30]; // max number of character to iterate
- for(c = (negative)?*(++s):*s; c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- if(unlikely(negative))
- return -n;
- return n;
- }
- static inline uint32_t str2uint32_t(const char *s) {
- uint32_t n = 0;
- char c;
- const char *e = &s[30]; // max number of character to iterate
- for(c = *s; c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- return n;
- }
- static inline uint64_t str2uint64_t(const char *s) {
- uint64_t n = 0;
- char c;
- const char *e = &s[30]; // max number of character to iterate
- for(c = *s; c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- return n;
- }
- static inline unsigned long str2ul(const char *s) {
- unsigned long n = 0;
- char c;
- const char *e = &s[30]; // max number of character to iterate
- for(c = *s; c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- return n;
- }
- static inline unsigned long long str2ull(const char *s) {
- unsigned long long n = 0;
- char c;
- const char *e = &s[30]; // max number of character to iterate
- for(c = *s; c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- return n;
- }
- static inline long long str2ll(const char *s, char **endptr) {
- int negative = 0;
- if(unlikely(*s == '-')) {
- s++;
- negative = 1;
- }
- else if(unlikely(*s == '+'))
- s++;
- long long n = 0;
- char c;
- const char *e = &s[30]; // max number of character to iterate
- for(c = *s; c >= '0' && c <= '9' && s < e ; c = *(++s)) {
- n *= 10;
- n += c - '0';
- }
- if(unlikely(endptr))
- *endptr = (char *)s;
- if(unlikely(negative))
- return -n;
- else
- return n;
- }
- static inline char *strncpyz(char *dst, const char *src, size_t n) {
- char *p = dst;
- while (*src && n--)
- *dst++ = *src++;
- *dst = '\0';
- return p;
- }
- static inline void sanitize_json_string(char *dst, const char *src, size_t dst_size) {
- while (*src != '\0' && dst_size > 1) {
- if (*src < 0x1F) {
- *dst++ = '_';
- src++;
- dst_size--;
- }
- else if (*src == '\\' || *src == '\"') {
- *dst++ = '\\';
- *dst++ = *src++;
- dst_size -= 2;
- }
- else {
- *dst++ = *src++;
- dst_size--;
- }
- }
- *dst = '\0';
- }
- static inline bool sanitize_command_argument_string(char *dst, const char *src, size_t dst_size) {
- // skip leading dashes
- while (src[0] == '-')
- src++;
- // escape single quotes
- while (src[0] != '\0') {
- if (src[0] == '\'') {
- if (dst_size < 4)
- return false;
- dst[0] = '\''; dst[1] = '\\'; dst[2] = '\''; dst[3] = '\'';
- dst += 4;
- dst_size -= 4;
- } else {
- if (dst_size < 1)
- return false;
- dst[0] = src[0];
- dst += 1;
- dst_size -= 1;
- }
- src++;
- }
- // make sure we have space to terminate the string
- if (dst_size == 0)
- return false;
- *dst = '\0';
- return true;
- }
- static inline int read_file(const char *filename, char *buffer, size_t size) {
- if(unlikely(!size)) return 3;
- int fd = open(filename, O_RDONLY, 0666);
- if(unlikely(fd == -1)) {
- buffer[0] = '\0';
- return 1;
- }
- ssize_t r = read(fd, buffer, size);
- if(unlikely(r == -1)) {
- buffer[0] = '\0';
- close(fd);
- return 2;
- }
- buffer[r] = '\0';
- close(fd);
- return 0;
- }
- static inline int read_single_number_file(const char *filename, unsigned long long *result) {
- char buffer[30 + 1];
- int ret = read_file(filename, buffer, 30);
- if(unlikely(ret)) {
- *result = 0;
- return ret;
- }
- buffer[30] = '\0';
- *result = str2ull(buffer);
- return 0;
- }
- static inline int read_single_signed_number_file(const char *filename, long long *result) {
- char buffer[30 + 1];
- int ret = read_file(filename, buffer, 30);
- if(unlikely(ret)) {
- *result = 0;
- return ret;
- }
- buffer[30] = '\0';
- *result = atoll(buffer);
- return 0;
- }
- #endif //NETDATA_INLINED_H
|