mirror of
https://git.kernel.org/pub/scm/utils/kernel/kmod/kmod.git
synced 2024-12-03 16:54:03 +08:00
8ab15eceaf
Add simple functions to put the current thread to sleep using exponential backoff to split the interval in smaller pieces. Signed-off-by: Lucas De Marchi <lucas.de.marchi@gmail.com>
108 lines
4.1 KiB
C
108 lines
4.1 KiB
C
#pragma once
|
|
|
|
#include <inttypes.h>
|
|
#include <limits.h>
|
|
#include <stdbool.h>
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <time.h>
|
|
|
|
#include <shared/macro.h>
|
|
|
|
/* string handling functions and memory allocations */
|
|
/* ************************************************************************ */
|
|
#define streq(a, b) (strcmp((a), (b)) == 0)
|
|
#define strstartswith(a, b) (strncmp(a, b, strlen(b)) == 0)
|
|
char *strchr_replace(char *s, char c, char r);
|
|
void *memdup(const void *p, size_t n) __attribute__((nonnull(1)));
|
|
|
|
/* module-related functions */
|
|
/* ************************************************************************ */
|
|
#define KMOD_EXTENSION_UNCOMPRESSED ".ko"
|
|
|
|
int alias_normalize(const char *alias, char buf[static PATH_MAX], size_t *len) _must_check_ __attribute__((nonnull(1,2)));
|
|
int underscores(char *s) _must_check_;
|
|
char *modname_normalize(const char *modname, char buf[static PATH_MAX], size_t *len) __attribute__((nonnull(1, 2)));
|
|
char *path_to_modname(const char *path, char buf[static PATH_MAX], size_t *len) __attribute__((nonnull(2)));
|
|
bool path_ends_with_kmod_ext(const char *path, size_t len) __attribute__((nonnull(1)));
|
|
|
|
/* read-like and fread-like functions */
|
|
/* ************************************************************************ */
|
|
ssize_t read_str_safe(int fd, char *buf, size_t buflen) _must_check_ __attribute__((nonnull(2)));
|
|
ssize_t write_str_safe(int fd, const char *buf, size_t buflen) __attribute__((nonnull(2)));
|
|
int read_str_long(int fd, long *value, int base) _must_check_ __attribute__((nonnull(2)));
|
|
int read_str_ulong(int fd, unsigned long *value, int base) _must_check_ __attribute__((nonnull(2)));
|
|
char *freadline_wrapped(FILE *fp, unsigned int *linenum) __attribute__((nonnull(1)));
|
|
|
|
/* path handling functions */
|
|
/* ************************************************************************ */
|
|
bool path_is_absolute(const char *p) _must_check_ __attribute__((nonnull(1)));
|
|
char *path_make_absolute_cwd(const char *p) _must_check_ __attribute__((nonnull(1)));
|
|
int mkdir_p(const char *path, int len, mode_t mode);
|
|
int mkdir_parents(const char *path, mode_t mode);
|
|
unsigned long long stat_mstamp(const struct stat *st);
|
|
|
|
/* time-related functions
|
|
* ************************************************************************ */
|
|
#define USEC_PER_SEC 1000000ULL
|
|
#define USEC_PER_MSEC 1000ULL
|
|
#define MSEC_PER_SEC 1000ULL
|
|
#define NSEC_PER_MSEC 1000000ULL
|
|
|
|
unsigned long long ts_usec(const struct timespec *ts);
|
|
unsigned long long ts_msec(const struct timespec *ts);
|
|
unsigned long long now_usec(void);
|
|
unsigned long long now_msec(void);
|
|
int sleep_until_msec(unsigned long long msec);
|
|
unsigned long long get_backoff_delta_msec(unsigned long long t0,
|
|
unsigned long long tend,
|
|
unsigned long long *delta);
|
|
|
|
|
|
/* endianess and alignments */
|
|
/* ************************************************************************ */
|
|
#define get_unaligned(ptr) \
|
|
({ \
|
|
struct __attribute__((packed)) { \
|
|
typeof(*(ptr)) __v; \
|
|
} *__p = (typeof(__p)) (ptr); \
|
|
__p->__v; \
|
|
})
|
|
|
|
#define put_unaligned(val, ptr) \
|
|
do { \
|
|
struct __attribute__((packed)) { \
|
|
typeof(*(ptr)) __v; \
|
|
} *__p = (typeof(__p)) (ptr); \
|
|
__p->__v = (val); \
|
|
} while(0)
|
|
|
|
static _always_inline_ unsigned int ALIGN_POWER2(unsigned int u)
|
|
{
|
|
return 1 << ((sizeof(u) * 8) - __builtin_clz(u - 1));
|
|
}
|
|
|
|
/* misc */
|
|
/* ************************************************************************ */
|
|
static inline void freep(void *p) {
|
|
free(*(void**) p);
|
|
}
|
|
#define _cleanup_free_ _cleanup_(freep)
|
|
|
|
static inline bool addu64_overflow(uint64_t a, uint64_t b, uint64_t *res)
|
|
{
|
|
#if (HAVE___BUILTIN_UADDL_OVERFLOW && HAVE___BUILTIN_UADDLL_OVERFLOW)
|
|
#if __SIZEOF_LONG__ == 8
|
|
return __builtin_uaddl_overflow(a, b, res);
|
|
#elif __SIZEOF_LONG_LONG__ == 8
|
|
return __builtin_uaddll_overflow(a, b, res);
|
|
#else
|
|
#error "sizeof(long long) != 8"
|
|
#endif
|
|
#endif
|
|
*res = a + b;
|
|
return UINT64_MAX - a < b;
|
|
}
|