aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRon Yorston <rmy@frippery.org>2015-07-19 23:05:20 +0200
committerDenys Vlasenko <vda.linux@googlemail.com>2015-07-19 23:05:20 +0200
commitd840c5d139cfa50fbe4f6f67c178b0edf0c690c8 (patch)
treee75010ca3ce7769f53a6170ebe940f37c6a94dc1
parent78cfa00154dca18a1326d2064121bf65cd081781 (diff)
downloadbusybox-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.h1
-rw-r--r--libbb/procps.c3
-rw-r--r--libbb/xfuncs_printf.c5
-rw-r--r--miscutils/last_fancy.c4
-rw-r--r--networking/traceroute.c11
-rw-r--r--networking/udhcp/d6_dhcpc.c2
-rw-r--r--shell/ash.c2
-rw-r--r--util-linux/mdev.c2
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
674char *xstrdup(const char *s) FAST_FUNC RETURNS_MALLOC; 674char *xstrdup(const char *s) FAST_FUNC RETURNS_MALLOC;
675char *xstrndup(const char *s, int n) FAST_FUNC RETURNS_MALLOC; 675char *xstrndup(const char *s, int n) FAST_FUNC RETURNS_MALLOC;
676void *xmemdup(const void *s, int n) FAST_FUNC RETURNS_MALLOC;
676void overlapping_strcpy(char *dst, const char *src) FAST_FUNC; 677void overlapping_strcpy(char *dst, const char *src) FAST_FUNC;
677char *safe_strncpy(char *dst, const char *src, size_t size) FAST_FUNC; 678char *safe_strncpy(char *dst, const char *src, size_t size) FAST_FUNC;
678char *strncpy_IFNAMSIZ(char *dst, const char *src) FAST_FUNC; 679char *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
115void* 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.
117FILE* FAST_FUNC xfopen(const char *path, const char *mode) 122FILE* 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 */
391static 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
399static int 390static int
400wait_for_reply(len_and_sockaddr *from_lsa, struct sockaddr *to, unsigned *timestamp_us, int *left_ms) 391wait_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
124static void *d6_store_blob(void *dst, const void *src, unsigned len) 124static 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]);