aboutsummaryrefslogtreecommitdiff
path: root/procps
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2008-07-08 05:14:36 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2008-07-08 05:14:36 +0000
commitdeeed59de0a9bcc068ebd14d7496a6b26e45b890 (patch)
tree7dafd469e9f6bca107adbf930fe77fff9958a0b6 /procps
parent493829207c1c2a36d55aaa13abf806533d0cb87f (diff)
downloadbusybox-w32-deeed59de0a9bcc068ebd14d7496a6b26e45b890.tar.gz
busybox-w32-deeed59de0a9bcc068ebd14d7496a6b26e45b890.tar.bz2
busybox-w32-deeed59de0a9bcc068ebd14d7496a6b26e45b890.zip
libbb: introduce and use xrealloc_vector
function old new delta xrealloc_vector_helper - 51 +51 create_list 84 99 +15 getopt_main 690 695 +5 passwd_main 1049 1053 +4 get_cached 85 89 +4 msh_main 1377 1380 +3 add_match 42 41 -1 read_lines 720 718 -2 grave 1068 1066 -2 fill_match_lines 143 141 -2 add_to_dirlist 67 65 -2 add_input_file 49 47 -2 act 252 250 -2 fsck_main 2252 2246 -6 man_main 765 757 -8 bb_internal_initgroups 228 220 -8 cut_main 1052 1041 -11 add_edge_to_node 55 43 -12 dpkg_main 3851 3835 -16 ifupdown_main 2202 2178 -24 sort_main 838 812 -26 ------------------------------------------------------------------------------ (add/remove: 1/0 grow/shrink: 5/15 up/down: 82/-124) Total: -42 bytes
Diffstat (limited to 'procps')
-rw-r--r--procps/ps.c5
-rw-r--r--procps/top.c5
2 files changed, 5 insertions, 5 deletions
diff --git a/procps/ps.c b/procps/ps.c
index c5dff1814..d7ea9fbbf 100644
--- a/procps/ps.c
+++ b/procps/ps.c
@@ -303,9 +303,8 @@ static const ps_out_t out_spec[] = {
303 303
304static ps_out_t* new_out_t(void) 304static ps_out_t* new_out_t(void)
305{ 305{
306 int i = out_cnt++; 306 out = xrealloc_vector(out, 2, out_cnt);
307 out = xrealloc(out, out_cnt * sizeof(*out)); 307 return &out[out_cnt++];
308 return &out[i];
309} 308}
310 309
311static const ps_out_t* find_out_spec(const char *name) 310static const ps_out_t* find_out_spec(const char *name)
diff --git a/procps/top.c b/procps/top.c
index e13cd1521..392a3c82b 100644
--- a/procps/top.c
+++ b/procps/top.c
@@ -814,7 +814,7 @@ int top_main(int argc UNUSED_PARAM, char **argv)
814 int n; 814 int n;
815 if (scan_mask == TOP_MASK) { 815 if (scan_mask == TOP_MASK) {
816 n = ntop; 816 n = ntop;
817 top = xrealloc(top, (++ntop) * sizeof(*top)); 817 top = xrealloc_vector(top, 2, ntop++);
818 top[n].pid = p->pid; 818 top[n].pid = p->pid;
819 top[n].ppid = p->ppid; 819 top[n].ppid = p->ppid;
820 top[n].vsz = p->vsz; 820 top[n].vsz = p->vsz;
@@ -829,7 +829,8 @@ int top_main(int argc UNUSED_PARAM, char **argv)
829 if (!(p->mapped_ro | p->mapped_rw)) 829 if (!(p->mapped_ro | p->mapped_rw))
830 continue; /* kernel threads are ignored */ 830 continue; /* kernel threads are ignored */
831 n = ntop; 831 n = ntop;
832 top = xrealloc(topmem, (++ntop) * sizeof(*topmem)); 832 /* No bug here - top and topmem are the same */
833 top = xrealloc_vector(topmem, 2, ntop++);
833 strcpy(topmem[n].comm, p->comm); 834 strcpy(topmem[n].comm, p->comm);
834 topmem[n].pid = p->pid; 835 topmem[n].pid = p->pid;
835 topmem[n].vsz = p->mapped_rw + p->mapped_ro; 836 topmem[n].vsz = p->mapped_rw + p->mapped_ro;