X-Git-Url: https://wimlib.net/git/?a=blobdiff_plain;f=src%2Futil.h;h=08b15636acdcc66ae0c440755bfc45bf276ec13e;hb=9a23ab0c8f362ca68a45e8b4a9a973b418972cb6;hp=dd564f5d6af1809d36f2f4e9df41e6f35fb67e56;hpb=0541069de2f74283d44ebb02372b60fb608795f2;p=wimlib diff --git a/src/util.h b/src/util.h index dd564f5d..08b15636 100644 --- a/src/util.h +++ b/src/util.h @@ -10,24 +10,21 @@ #ifdef __GNUC__ # define WIMLIBAPI __attribute__((visibility("default"))) -# define NOINLINE __attribute__((noinline)) # define ALWAYS_INLINE inline __attribute__((always_inline)) +# define PACKED __attribute__((packed)) # define FORMAT(type, format_str, args_start) \ __attribute__((format(type, format_str, args_start))) # if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4) # define COLD __attribute__((cold)) -# define HOT __attribute__((hot)) # else # define COLD -# define HOT # endif #else # define WIMLIBAPI -# define NOINLINE # define ALWAYS_INLINE inline # define FORMAT(type, format_str, args_start) # define COLD -# define HOT +# define PACKED #endif /* __GNUC__ */ @@ -158,12 +155,14 @@ extern char *wimlib_strdup(const char *str); #endif /* ENABLE_CUSTOM_MEMORY_ALLOCATOR */ -extern char *utf16_to_utf8(const char *utf16_str, size_t utf16_len, - size_t *utf8_len_ret); +/* encoding.c */ +extern int utf16_to_utf8(const char *utf16_str, size_t utf16_nbytes, + char **utf8_str_ret, size_t *utf8_nbytes_ret); -extern char *utf8_to_utf16(const char *utf8_str, size_t utf8_len, - size_t *utf16_len_ret); +extern int utf8_to_utf16(const char *utf8_str, size_t utf8_nbytes, + char **utf16_str_ret, size_t *utf16_nbytes_ret); +/* util.c */ extern void randomize_byte_array(u8 *p, size_t n); extern void randomize_char_array_with_alnum(char p[], size_t n); @@ -181,13 +180,25 @@ extern void print_string(const void *string, size_t len); extern int get_num_path_components(const char *path); -extern ssize_t full_write(int fd, const void *buf, size_t n); - static inline void print_byte_field(const u8 field[], size_t len) { while (len--) printf("%02hhx", *field++); } +static inline u32 bsr32(u32 n) +{ +#if defined(__x86__) || defined(__x86_64__) + asm("bsrl %0, %0;" + : "=r"(n) + : "0" (n)); + return n; +#else + u32 pow = 0; + while ((n >>= 1) != 0) + pow++; + return pow; +#endif +} #endif /* _WIMLIB_UTIL_H */