diff options
author | Ron Yorston <rmy@frippery.org> | 2015-07-19 23:05:20 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2015-07-19 23:05:20 +0200 |
commit | d840c5d139cfa50fbe4f6f67c178b0edf0c690c8 (patch) | |
tree | e75010ca3ce7769f53a6170ebe940f37c6a94dc1 | |
parent | 78cfa00154dca18a1326d2064121bf65cd081781 (diff) | |
download | busybox-w32-d840c5d139cfa50fbe4f6f67c178b0edf0c690c8.tar.gz busybox-w32-d840c5d139cfa50fbe4f6f67c178b0edf0c690c8.tar.bz2 busybox-w32-d840c5d139cfa50fbe4f6f67c178b0edf0c690c8.zip |
libbb: add a function to make a copy of a region of memory
Introduce a library routine to package the idiom:
p = xmalloc(b, n);
memcpy(p, b, n);
and use it where possible. The example in traceroute used xzalloc
but it didn't need to.
function old new delta
xmemdup - 32 +32
last_main 834 826 -8
make_device 2321 2311 -10
common_traceroute_main 3698 3685 -13
readtoken1 3182 3168 -14
procps_scan 1222 1206 -16
forkchild 655 638 -17
------------------------------------------------------------------------------
(add/remove: 1/0 grow/shrink: 0/6 up/down: 32/-78) Total: -46 bytes
Signed-off-by: Ron Yorston <rmy@frippery.org>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | include/libbb.h | 1 | ||||
-rw-r--r-- | libbb/procps.c | 3 | ||||
-rw-r--r-- | libbb/xfuncs_printf.c | 5 | ||||
-rw-r--r-- | miscutils/last_fancy.c | 4 | ||||
-rw-r--r-- | networking/traceroute.c | 11 | ||||
-rw-r--r-- | networking/udhcp/d6_dhcpc.c | 2 | ||||
-rw-r--r-- | shell/ash.c | 2 | ||||
-rw-r--r-- | util-linux/mdev.c | 2 |
8 files changed, 13 insertions, 17 deletions
diff --git a/include/libbb.h b/include/libbb.h index f0ac1f50d..54d01b75a 100644 --- a/include/libbb.h +++ b/include/libbb.h | |||
@@ -673,6 +673,7 @@ uint16_t inet_cksum(uint16_t *addr, int len) FAST_FUNC; | |||
673 | 673 | ||
674 | char *xstrdup(const char *s) FAST_FUNC RETURNS_MALLOC; | 674 | char *xstrdup(const char *s) FAST_FUNC RETURNS_MALLOC; |
675 | char *xstrndup(const char *s, int n) FAST_FUNC RETURNS_MALLOC; | 675 | char *xstrndup(const char *s, int n) FAST_FUNC RETURNS_MALLOC; |
676 | void *xmemdup(const void *s, int n) FAST_FUNC RETURNS_MALLOC; | ||
676 | void overlapping_strcpy(char *dst, const char *src) FAST_FUNC; | 677 | void overlapping_strcpy(char *dst, const char *src) FAST_FUNC; |
677 | char *safe_strncpy(char *dst, const char *src, size_t size) FAST_FUNC; | 678 | char *safe_strncpy(char *dst, const char *src, size_t size) FAST_FUNC; |
678 | char *strncpy_IFNAMSIZ(char *dst, const char *src) FAST_FUNC; | 679 | char *strncpy_IFNAMSIZ(char *dst, const char *src) FAST_FUNC; |
diff --git a/libbb/procps.c b/libbb/procps.c index 3d335b37b..71ad071e6 100644 --- a/libbb/procps.c +++ b/libbb/procps.c | |||
@@ -554,8 +554,7 @@ procps_status_t* FAST_FUNC procps_scan(procps_status_t* sp, int flags) | |||
554 | break; | 554 | break; |
555 | if (flags & PSSCAN_ARGVN) { | 555 | if (flags & PSSCAN_ARGVN) { |
556 | sp->argv_len = n; | 556 | sp->argv_len = n; |
557 | sp->argv0 = xmalloc(n + 1); | 557 | sp->argv0 = xmemdup(buf, n + 1); |
558 | memcpy(sp->argv0, buf, n + 1); | ||
559 | /* sp->argv0[n] = '\0'; - buf has it */ | 558 | /* sp->argv0[n] = '\0'; - buf has it */ |
560 | } else { | 559 | } else { |
561 | sp->argv_len = 0; | 560 | sp->argv_len = 0; |
diff --git a/libbb/xfuncs_printf.c b/libbb/xfuncs_printf.c index e4ac6a002..73488908d 100644 --- a/libbb/xfuncs_printf.c +++ b/libbb/xfuncs_printf.c | |||
@@ -112,6 +112,11 @@ char* FAST_FUNC xstrndup(const char *s, int n) | |||
112 | return memcpy(t, s, n); | 112 | return memcpy(t, s, n); |
113 | } | 113 | } |
114 | 114 | ||
115 | void* FAST_FUNC xmemdup(const void *s, int n) | ||
116 | { | ||
117 | return memcpy(xmalloc(n), s, n); | ||
118 | } | ||
119 | |||
115 | // Die if we can't open a file and return a FILE* to it. | 120 | // Die if we can't open a file and return a FILE* to it. |
116 | // Notice we haven't got xfread(), This is for use with fscanf() and friends. | 121 | // Notice we haven't got xfread(), This is for use with fscanf() and friends. |
117 | FILE* FAST_FUNC xfopen(const char *path, const char *mode) | 122 | FILE* FAST_FUNC xfopen(const char *path, const char *mode) |
diff --git a/miscutils/last_fancy.c b/miscutils/last_fancy.c index 8194e31b5..e56e0ba85 100644 --- a/miscutils/last_fancy.c +++ b/miscutils/last_fancy.c | |||
@@ -233,7 +233,7 @@ int last_main(int argc UNUSED_PARAM, char **argv) | |||
233 | break; | 233 | break; |
234 | } | 234 | } |
235 | /* add_entry */ | 235 | /* add_entry */ |
236 | llist_add_to(&zlist, memcpy(xmalloc(sizeof(ut)), &ut, sizeof(ut))); | 236 | llist_add_to(&zlist, xmemdup(&ut, sizeof(ut))); |
237 | break; | 237 | break; |
238 | case USER_PROCESS: { | 238 | case USER_PROCESS: { |
239 | int show; | 239 | int show; |
@@ -275,7 +275,7 @@ int last_main(int argc UNUSED_PARAM, char **argv) | |||
275 | show_entry(&ut, state, boot_time); | 275 | show_entry(&ut, state, boot_time); |
276 | } | 276 | } |
277 | /* add_entry */ | 277 | /* add_entry */ |
278 | llist_add_to(&zlist, memcpy(xmalloc(sizeof(ut)), &ut, sizeof(ut))); | 278 | llist_add_to(&zlist, xmemdup(&ut, sizeof(ut))); |
279 | break; | 279 | break; |
280 | } | 280 | } |
281 | } | 281 | } |
diff --git a/networking/traceroute.c b/networking/traceroute.c index 97a7a19e0..12ba614e8 100644 --- a/networking/traceroute.c +++ b/networking/traceroute.c | |||
@@ -387,15 +387,6 @@ struct globals { | |||
387 | #define outudp ((struct udphdr *)(outip + 1)) | 387 | #define outudp ((struct udphdr *)(outip + 1)) |
388 | 388 | ||
389 | 389 | ||
390 | /* libbb candidate? tftp uses this idiom too */ | ||
391 | static len_and_sockaddr* dup_sockaddr(const len_and_sockaddr *lsa) | ||
392 | { | ||
393 | len_and_sockaddr *new_lsa = xzalloc(LSA_LEN_SIZE + lsa->len); | ||
394 | memcpy(new_lsa, lsa, LSA_LEN_SIZE + lsa->len); | ||
395 | return new_lsa; | ||
396 | } | ||
397 | |||
398 | |||
399 | static int | 390 | static int |
400 | wait_for_reply(len_and_sockaddr *from_lsa, struct sockaddr *to, unsigned *timestamp_us, int *left_ms) | 391 | wait_for_reply(len_and_sockaddr *from_lsa, struct sockaddr *to, unsigned *timestamp_us, int *left_ms) |
401 | { | 392 | { |
@@ -1074,7 +1065,7 @@ common_traceroute_main(int op, char **argv) | |||
1074 | printf(" from %s", source); | 1065 | printf(" from %s", source); |
1075 | printf(", %d hops max, %d byte packets\n", max_ttl, packlen); | 1066 | printf(", %d hops max, %d byte packets\n", max_ttl, packlen); |
1076 | 1067 | ||
1077 | from_lsa = dup_sockaddr(dest_lsa); | 1068 | from_lsa = xmemdup(dest_lsa, LSA_LEN_SIZE + dest_lsa->len); |
1078 | lastaddr = xzalloc(dest_lsa->len); | 1069 | lastaddr = xzalloc(dest_lsa->len); |
1079 | to = xzalloc(dest_lsa->len); | 1070 | to = xzalloc(dest_lsa->len); |
1080 | seq = 0; | 1071 | seq = 0; |
diff --git a/networking/udhcp/d6_dhcpc.c b/networking/udhcp/d6_dhcpc.c index 044f04673..4e9b705b9 100644 --- a/networking/udhcp/d6_dhcpc.c +++ b/networking/udhcp/d6_dhcpc.c | |||
@@ -118,7 +118,7 @@ static void *d6_copy_option(uint8_t *option, uint8_t *option_end, unsigned code) | |||
118 | uint8_t *opt = d6_find_option(option, option_end, code); | 118 | uint8_t *opt = d6_find_option(option, option_end, code); |
119 | if (!opt) | 119 | if (!opt) |
120 | return opt; | 120 | return opt; |
121 | return memcpy(xmalloc(opt[3] + 4), opt, opt[3] + 4); | 121 | return xmemdup(opt, opt[3] + 4); |
122 | } | 122 | } |
123 | 123 | ||
124 | static void *d6_store_blob(void *dst, const void *src, unsigned len) | 124 | static void *d6_store_blob(void *dst, const void *src, unsigned len) |
diff --git a/shell/ash.c b/shell/ash.c index f4779ee2b..f6190c3e2 100644 --- a/shell/ash.c +++ b/shell/ash.c | |||
@@ -4751,7 +4751,7 @@ forkchild(struct job *jp, union node *n, int mode) | |||
4751 | * Our solution: ONLY bare $(trap) or `trap` is special. | 4751 | * Our solution: ONLY bare $(trap) or `trap` is special. |
4752 | */ | 4752 | */ |
4753 | /* Save trap handler strings for trap builtin to print */ | 4753 | /* Save trap handler strings for trap builtin to print */ |
4754 | trap_ptr = memcpy(xmalloc(sizeof(trap)), trap, sizeof(trap)); | 4754 | trap_ptr = xmemdup(trap, sizeof(trap)); |
4755 | /* Fall through into clearing traps */ | 4755 | /* Fall through into clearing traps */ |
4756 | } | 4756 | } |
4757 | clear_traps(); | 4757 | clear_traps(); |
diff --git a/util-linux/mdev.c b/util-linux/mdev.c index ca4b91510..662e8ab38 100644 --- a/util-linux/mdev.c +++ b/util-linux/mdev.c | |||
@@ -471,7 +471,7 @@ static const struct rule *next_rule(void) | |||
471 | if (G.parser) { | 471 | if (G.parser) { |
472 | parse_next_rule(); | 472 | parse_next_rule(); |
473 | if (G.rule_vec) { /* mdev -s */ | 473 | if (G.rule_vec) { /* mdev -s */ |
474 | rule = memcpy(xmalloc(sizeof(G.cur_rule)), &G.cur_rule, sizeof(G.cur_rule)); | 474 | rule = xmemdup(&G.cur_rule, sizeof(G.cur_rule)); |
475 | G.rule_vec = xrealloc_vector(G.rule_vec, 4, G.rule_idx); | 475 | G.rule_vec = xrealloc_vector(G.rule_vec, 4, G.rule_idx); |
476 | G.rule_vec[G.rule_idx++] = rule; | 476 | G.rule_vec[G.rule_idx++] = rule; |
477 | dbg3("> G.rule_vec[G.rule_idx:%d]=%p", G.rule_idx, G.rule_vec[G.rule_idx]); | 477 | dbg3("> G.rule_vec[G.rule_idx:%d]=%p", G.rule_idx, G.rule_vec[G.rule_idx]); |