*: introduce and use FAST_FUNC: regparm on i386, otherwise no-on
text data bss dec hex filename 808035 611 6868 815514 c719a busybox_old 804472 611 6868 811951 c63af busybox_unstripped
This commit is contained in:
@@ -44,9 +44,9 @@ typedef struct _fs { /* format strings */
|
||||
int bcnt;
|
||||
} FS;
|
||||
|
||||
extern void bb_dump_add(const char *fmt);
|
||||
extern int bb_dump_dump(char **argv);
|
||||
extern int bb_dump_size(FS * fs);
|
||||
extern void bb_dump_add(const char *fmt) FAST_FUNC;
|
||||
extern int bb_dump_dump(char **argv) FAST_FUNC;
|
||||
extern int bb_dump_size(FS * fs) FAST_FUNC;
|
||||
|
||||
extern FS *bb_dump_fshead; /* head of format strings */
|
||||
extern int bb_dump_blocksize; /* data block size */
|
||||
|
@@ -12,15 +12,15 @@
|
||||
/* hostfirst!=0 If we expect this to be a hostname,
|
||||
try hostname database first
|
||||
*/
|
||||
int INET_resolve(const char *name, struct sockaddr_in *s_in, int hostfirst);
|
||||
int INET_resolve(const char *name, struct sockaddr_in *s_in, int hostfirst) FAST_FUNC;
|
||||
|
||||
/* numeric: & 0x8000: "default" instead of "*",
|
||||
* & 0x4000: host instead of net,
|
||||
* & 0x0fff: don't resolve
|
||||
*/
|
||||
|
||||
int INET6_resolve(const char *name, struct sockaddr_in6 *sin6);
|
||||
int INET6_resolve(const char *name, struct sockaddr_in6 *sin6) FAST_FUNC;
|
||||
|
||||
/* These return malloced string */
|
||||
char *INET_rresolve(struct sockaddr_in *s_in, int numeric, uint32_t netmask);
|
||||
char *INET6_rresolve(struct sockaddr_in6 *sin6, int numeric);
|
||||
char *INET_rresolve(struct sockaddr_in *s_in, int numeric, uint32_t netmask) FAST_FUNC;
|
||||
char *INET6_rresolve(struct sockaddr_in6 *sin6, int numeric) FAST_FUNC;
|
||||
|
628
include/libbb.h
628
include/libbb.h
File diff suppressed because it is too large
Load Diff
@@ -97,6 +97,13 @@
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if __GNUC_PREREQ(3,0) && defined(i386)
|
||||
/* || defined(__x86_64__)? */
|
||||
# define FAST_FUNC __attribute__((regparm(3)))
|
||||
#else
|
||||
# define FAST_FUNC
|
||||
#endif
|
||||
|
||||
/* ---- Endian Detection ------------------------------------ */
|
||||
|
||||
#if (defined __digital__ && defined __unix__)
|
||||
|
@@ -13,9 +13,9 @@
|
||||
# pragma GCC visibility push(hidden)
|
||||
#endif
|
||||
|
||||
extern int rtc_adjtime_is_utc(void);
|
||||
extern int rtc_xopen(const char **default_rtc, int flags);
|
||||
extern time_t rtc_read_time(int fd, int utc);
|
||||
extern int rtc_adjtime_is_utc(void) FAST_FUNC;
|
||||
extern int rtc_xopen(const char **default_rtc, int flags) FAST_FUNC;
|
||||
extern time_t rtc_read_time(int fd, int utc) FAST_FUNC;
|
||||
|
||||
/*
|
||||
* Everything below this point has been copied from linux/rtc.h
|
||||
|
@@ -31,7 +31,7 @@ typedef struct file_header_t {
|
||||
|
||||
typedef struct archive_handle_t {
|
||||
/* define if the header and data component should be processed */
|
||||
char (*filter)(struct archive_handle_t *);
|
||||
char FAST_FUNC (*filter)(struct archive_handle_t *);
|
||||
llist_t *accept;
|
||||
/* List of files that have been rejected */
|
||||
llist_t *reject;
|
||||
@@ -42,13 +42,13 @@ typedef struct archive_handle_t {
|
||||
file_header_t *file_header;
|
||||
|
||||
/* process the header component, e.g. tar -t */
|
||||
void (*action_header)(const file_header_t *);
|
||||
void FAST_FUNC (*action_header)(const file_header_t *);
|
||||
|
||||
/* process the data component, e.g. extract to filesystem */
|
||||
void (*action_data)(struct archive_handle_t *);
|
||||
void FAST_FUNC (*action_data)(struct archive_handle_t *);
|
||||
|
||||
/* How to process any sub archive, e.g. get_header_tar_gz */
|
||||
char (*action_data_subarchive)(struct archive_handle_t *);
|
||||
char FAST_FUNC (*action_data_subarchive)(struct archive_handle_t *);
|
||||
|
||||
/* Contains the handle to a sub archive */
|
||||
struct archive_handle_t *sub_archive;
|
||||
@@ -60,7 +60,7 @@ typedef struct archive_handle_t {
|
||||
off_t offset;
|
||||
|
||||
/* Function that skips data: read_by_char or read_by_skip */
|
||||
void (*seek)(const struct archive_handle_t *archive_handle, const unsigned amount);
|
||||
void FAST_FUNC (*seek)(const struct archive_handle_t *archive_handle, const unsigned amount);
|
||||
|
||||
/* Temporary storage */
|
||||
char *buffer;
|
||||
@@ -71,62 +71,62 @@ typedef struct archive_handle_t {
|
||||
} archive_handle_t;
|
||||
|
||||
|
||||
extern archive_handle_t *init_handle(void);
|
||||
extern archive_handle_t *init_handle(void) FAST_FUNC;
|
||||
|
||||
extern char filter_accept_all(archive_handle_t *archive_handle);
|
||||
extern char filter_accept_list(archive_handle_t *archive_handle);
|
||||
extern char filter_accept_list_reassign(archive_handle_t *archive_handle);
|
||||
extern char filter_accept_reject_list(archive_handle_t *archive_handle);
|
||||
extern char filter_accept_all(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char filter_accept_list(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char filter_accept_list_reassign(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char filter_accept_reject_list(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
|
||||
extern void unpack_ar_archive(archive_handle_t *ar_archive);
|
||||
extern void unpack_ar_archive(archive_handle_t *ar_archive) FAST_FUNC;
|
||||
|
||||
extern void data_skip(archive_handle_t *archive_handle);
|
||||
extern void data_extract_all(archive_handle_t *archive_handle);
|
||||
extern void data_extract_to_stdout(archive_handle_t *archive_handle);
|
||||
extern void data_extract_to_buffer(archive_handle_t *archive_handle);
|
||||
extern void data_skip(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern void data_extract_all(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern void data_extract_to_stdout(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern void data_extract_to_buffer(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
|
||||
extern void header_skip(const file_header_t *file_header);
|
||||
extern void header_list(const file_header_t *file_header);
|
||||
extern void header_verbose_list(const file_header_t *file_header);
|
||||
extern void header_skip(const file_header_t *file_header) FAST_FUNC;
|
||||
extern void header_list(const file_header_t *file_header) FAST_FUNC;
|
||||
extern void header_verbose_list(const file_header_t *file_header) FAST_FUNC;
|
||||
|
||||
extern char get_header_ar(archive_handle_t *archive_handle);
|
||||
extern char get_header_cpio(archive_handle_t *archive_handle);
|
||||
extern char get_header_tar(archive_handle_t *archive_handle);
|
||||
extern char get_header_tar_bz2(archive_handle_t *archive_handle);
|
||||
extern char get_header_tar_lzma(archive_handle_t *archive_handle);
|
||||
extern char get_header_tar_gz(archive_handle_t *archive_handle);
|
||||
extern char get_header_ar(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char get_header_cpio(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char get_header_tar(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char get_header_tar_bz2(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char get_header_tar_lzma(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
extern char get_header_tar_gz(archive_handle_t *archive_handle) FAST_FUNC;
|
||||
|
||||
extern void seek_by_jump(const archive_handle_t *archive_handle, unsigned amount);
|
||||
extern void seek_by_read(const archive_handle_t *archive_handle, unsigned amount);
|
||||
extern void seek_by_jump(const archive_handle_t *archive_handle, unsigned amount) FAST_FUNC;
|
||||
extern void seek_by_read(const archive_handle_t *archive_handle, unsigned amount) FAST_FUNC;
|
||||
|
||||
extern ssize_t archive_xread_all_eof(archive_handle_t *archive_handle, unsigned char *buf, size_t count);
|
||||
extern ssize_t archive_xread_all_eof(archive_handle_t *archive_handle, unsigned char *buf, size_t count) FAST_FUNC;
|
||||
|
||||
extern void data_align(archive_handle_t *archive_handle, unsigned boundary);
|
||||
extern const llist_t *find_list_entry(const llist_t *list, const char *filename);
|
||||
extern const llist_t *find_list_entry2(const llist_t *list, const char *filename);
|
||||
extern void data_align(archive_handle_t *archive_handle, unsigned boundary) FAST_FUNC;
|
||||
extern const llist_t *find_list_entry(const llist_t *list, const char *filename) FAST_FUNC;
|
||||
extern const llist_t *find_list_entry2(const llist_t *list, const char *filename) FAST_FUNC;
|
||||
|
||||
/* A bit of bunzip2 internals are exposed for compressed help support: */
|
||||
typedef struct bunzip_data bunzip_data;
|
||||
int start_bunzip(bunzip_data **bdp, int in_fd, const unsigned char *inbuf, int len);
|
||||
int read_bunzip(bunzip_data *bd, char *outbuf, int len);
|
||||
void dealloc_bunzip(bunzip_data *bd);
|
||||
int start_bunzip(bunzip_data **bdp, int in_fd, const unsigned char *inbuf, int len) FAST_FUNC;
|
||||
int read_bunzip(bunzip_data *bd, char *outbuf, int len) FAST_FUNC;
|
||||
void dealloc_bunzip(bunzip_data *bd) FAST_FUNC;
|
||||
|
||||
typedef struct inflate_unzip_result {
|
||||
off_t bytes_out;
|
||||
uint32_t crc;
|
||||
} inflate_unzip_result;
|
||||
|
||||
extern USE_DESKTOP(long long) int unpack_bz2_stream(int src_fd, int dst_fd);
|
||||
extern USE_DESKTOP(long long) int inflate_unzip(inflate_unzip_result *res, off_t compr_size, int src_fd, int dst_fd);
|
||||
extern USE_DESKTOP(long long) int unpack_gz_stream(int src_fd, int dst_fd);
|
||||
extern USE_DESKTOP(long long) int unpack_lzma_stream(int src_fd, int dst_fd);
|
||||
extern USE_DESKTOP(long long) int unpack_bz2_stream(int src_fd, int dst_fd) FAST_FUNC;
|
||||
extern USE_DESKTOP(long long) int inflate_unzip(inflate_unzip_result *res, off_t compr_size, int src_fd, int dst_fd) FAST_FUNC;
|
||||
extern USE_DESKTOP(long long) int unpack_gz_stream(int src_fd, int dst_fd) FAST_FUNC;
|
||||
extern USE_DESKTOP(long long) int unpack_lzma_stream(int src_fd, int dst_fd) FAST_FUNC;
|
||||
|
||||
#if BB_MMU
|
||||
extern int open_transformer(int src_fd,
|
||||
USE_DESKTOP(long long) int (*transformer)(int src_fd, int dst_fd));
|
||||
USE_DESKTOP(long long) int FAST_FUNC (*transformer)(int src_fd, int dst_fd)) FAST_FUNC;
|
||||
#define open_transformer(src_fd, transformer, transform_prog) open_transformer(src_fd, transformer)
|
||||
#else
|
||||
extern int open_transformer(int src_fd, const char *transform_prog);
|
||||
extern int open_transformer(int src_fd, const char *transform_prog) FAST_FUNC;
|
||||
#define open_transformer(src_fd, transformer, transform_prog) open_transformer(src_fd, transform_prog)
|
||||
#endif
|
||||
|
||||
|
@@ -14,20 +14,20 @@
|
||||
/* Provides extern declarations of functions */
|
||||
#define DECLARE_STR_CONV(type, T, UT) \
|
||||
\
|
||||
unsigned type xstrto##UT##_range_sfx(const char *str, int b, unsigned type l, unsigned type u, const struct suffix_mult *sfx); \
|
||||
unsigned type xstrto##UT##_range(const char *str, int b, unsigned type l, unsigned type u); \
|
||||
unsigned type xstrto##UT##_sfx(const char *str, int b, const struct suffix_mult *sfx); \
|
||||
unsigned type xstrto##UT(const char *str, int b); \
|
||||
unsigned type xato##UT##_range_sfx(const char *str, unsigned type l, unsigned type u, const struct suffix_mult *sfx); \
|
||||
unsigned type xato##UT##_range(const char *str, unsigned type l, unsigned type u); \
|
||||
unsigned type xato##UT##_sfx(const char *str, const struct suffix_mult *sfx); \
|
||||
unsigned type xato##UT(const char *str); \
|
||||
type xstrto##T##_range_sfx(const char *str, int b, type l, type u, const struct suffix_mult *sfx); \
|
||||
type xstrto##T##_range(const char *str, int b, type l, type u); \
|
||||
type xato##T##_range_sfx(const char *str, type l, type u, const struct suffix_mult *sfx); \
|
||||
type xato##T##_range(const char *str, type l, type u); \
|
||||
type xato##T##_sfx(const char *str, const struct suffix_mult *sfx); \
|
||||
type xato##T(const char *str); \
|
||||
unsigned type xstrto##UT##_range_sfx(const char *str, int b, unsigned type l, unsigned type u, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
unsigned type xstrto##UT##_range(const char *str, int b, unsigned type l, unsigned type u) FAST_FUNC; \
|
||||
unsigned type xstrto##UT##_sfx(const char *str, int b, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
unsigned type xstrto##UT(const char *str, int b) FAST_FUNC; \
|
||||
unsigned type xato##UT##_range_sfx(const char *str, unsigned type l, unsigned type u, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
unsigned type xato##UT##_range(const char *str, unsigned type l, unsigned type u) FAST_FUNC; \
|
||||
unsigned type xato##UT##_sfx(const char *str, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
unsigned type xato##UT(const char *str) FAST_FUNC; \
|
||||
type xstrto##T##_range_sfx(const char *str, int b, type l, type u, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
type xstrto##T##_range(const char *str, int b, type l, type u) FAST_FUNC; \
|
||||
type xato##T##_range_sfx(const char *str, type l, type u, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
type xato##T##_range(const char *str, type l, type u) FAST_FUNC; \
|
||||
type xato##T##_sfx(const char *str, const struct suffix_mult *sfx) FAST_FUNC; \
|
||||
type xato##T(const char *str) FAST_FUNC; \
|
||||
|
||||
/* Unsigned long long functions always exist */
|
||||
DECLARE_STR_CONV(long long, ll, ull)
|
||||
@@ -122,8 +122,8 @@ static ALWAYS_INLINE uint32_t xatou32(const char *numstr)
|
||||
* return value is all-ones in this case.
|
||||
*/
|
||||
|
||||
unsigned long long bb_strtoull(const char *arg, char **endp, int base);
|
||||
long long bb_strtoll(const char *arg, char **endp, int base);
|
||||
unsigned long long bb_strtoull(const char *arg, char **endp, int base) FAST_FUNC;
|
||||
long long bb_strtoll(const char *arg, char **endp, int base) FAST_FUNC;
|
||||
|
||||
#if ULONG_MAX == ULLONG_MAX
|
||||
static ALWAYS_INLINE
|
||||
@@ -133,8 +133,8 @@ static ALWAYS_INLINE
|
||||
long bb_strtol(const char *arg, char **endp, int base)
|
||||
{ return bb_strtoll(arg, endp, base); }
|
||||
#else
|
||||
unsigned long bb_strtoul(const char *arg, char **endp, int base);
|
||||
long bb_strtol(const char *arg, char **endp, int base);
|
||||
unsigned long bb_strtoul(const char *arg, char **endp, int base) FAST_FUNC;
|
||||
long bb_strtol(const char *arg, char **endp, int base) FAST_FUNC;
|
||||
#endif
|
||||
|
||||
#if UINT_MAX == ULLONG_MAX
|
||||
@@ -152,8 +152,8 @@ static ALWAYS_INLINE
|
||||
int bb_strtoi(const char *arg, char **endp, int base)
|
||||
{ return bb_strtol(arg, endp, base); }
|
||||
#else
|
||||
unsigned bb_strtou(const char *arg, char **endp, int base);
|
||||
int bb_strtoi(const char *arg, char **endp, int base);
|
||||
unsigned bb_strtou(const char *arg, char **endp, int base) FAST_FUNC;
|
||||
int bb_strtoi(const char *arg, char **endp, int base) FAST_FUNC;
|
||||
#endif
|
||||
|
||||
int BUG_bb_strtou32_unimplemented(void);
|
||||
|
@@ -17,8 +17,8 @@
|
||||
# pragma GCC visibility push(hidden)
|
||||
#endif
|
||||
|
||||
char* regcomp_or_errmsg(regex_t *preg, const char *regex, int cflags);
|
||||
void xregcomp(regex_t *preg, const char *regex, int cflags);
|
||||
char* regcomp_or_errmsg(regex_t *preg, const char *regex, int cflags) FAST_FUNC;
|
||||
void xregcomp(regex_t *preg, const char *regex, int cflags) FAST_FUNC;
|
||||
|
||||
#if __GNUC_PREREQ(4,1)
|
||||
# pragma GCC visibility pop
|
||||
|
Reference in New Issue
Block a user