aboutsummaryrefslogtreecommitdiff
path: root/modutils
diff options
context:
space:
mode:
Diffstat (limited to 'modutils')
-rw-r--r--modutils/insmod.c10
-rw-r--r--modutils/modprobe-small.c4
-rw-r--r--modutils/modprobe.c6
3 files changed, 9 insertions, 11 deletions
diff --git a/modutils/insmod.c b/modutils/insmod.c
index d928be27d..df6bf10a0 100644
--- a/modutils/insmod.c
+++ b/modutils/insmod.c
@@ -2201,7 +2201,7 @@ static struct obj_section *obj_create_alloced_section(struct obj_file *f,
2201 int newidx = f->header.e_shnum++; 2201 int newidx = f->header.e_shnum++;
2202 struct obj_section *sec; 2202 struct obj_section *sec;
2203 2203
2204 f->sections = xrealloc(f->sections, (newidx + 1) * sizeof(sec)); 2204 f->sections = xrealloc_vector(f->sections, 2, newidx);
2205 f->sections[newidx] = sec = arch_new_section(); 2205 f->sections[newidx] = sec = arch_new_section();
2206 2206
2207 sec->header.sh_type = SHT_PROGBITS; 2207 sec->header.sh_type = SHT_PROGBITS;
@@ -2250,7 +2250,8 @@ static void *obj_extend_section(struct obj_section *sec, unsigned long more)
2250{ 2250{
2251 unsigned long oldsize = sec->header.sh_size; 2251 unsigned long oldsize = sec->header.sh_size;
2252 if (more) { 2252 if (more) {
2253 sec->contents = xrealloc(sec->contents, sec->header.sh_size += more); 2253 sec->header.sh_size += more;
2254 sec->contents = xrealloc(sec->contents, sec->header.sh_size);
2254 } 2255 }
2255 return sec->contents + oldsize; 2256 return sec->contents + oldsize;
2256} 2257}
@@ -2736,7 +2737,8 @@ static void new_get_kernel_symbols(void)
2736 retry_kern_sym_load: 2737 retry_kern_sym_load:
2737 if (query_module(NULL, QM_SYMBOLS, syms, bufsize, &ret)) { 2738 if (query_module(NULL, QM_SYMBOLS, syms, bufsize, &ret)) {
2738 if (errno == ENOSPC && bufsize < ret) { 2739 if (errno == ENOSPC && bufsize < ret) {
2739 syms = xrealloc(syms, bufsize = ret); 2740 bufsize = ret;
2741 syms = xrealloc(syms, bufsize);
2740 goto retry_kern_sym_load; 2742 goto retry_kern_sym_load;
2741 } 2743 }
2742 bb_perror_msg_and_die("kernel: QM_SYMBOLS"); 2744 bb_perror_msg_and_die("kernel: QM_SYMBOLS");
@@ -3080,7 +3082,7 @@ static void obj_allocate_commons(struct obj_file *f)
3080 if (i == f->header.e_shnum) { 3082 if (i == f->header.e_shnum) {
3081 struct obj_section *sec; 3083 struct obj_section *sec;
3082 3084
3083 f->sections = xrealloc(f->sections, (i + 1) * sizeof(sec)); 3085 f->sections = xrealloc(f->sections, 2, i);
3084 f->sections[i] = sec = arch_new_section(); 3086 f->sections[i] = sec = arch_new_section();
3085 f->header.e_shnum = i + 1; 3087 f->header.e_shnum = i + 1;
3086 3088
diff --git a/modutils/modprobe-small.c b/modutils/modprobe-small.c
index e82ee4cef..4f073536a 100644
--- a/modutils/modprobe-small.c
+++ b/modutils/modprobe-small.c
@@ -317,9 +317,7 @@ static FAST_FUNC int fileAction(const char *pathname,
317 } 317 }
318 318
319 cur = module_count++; 319 cur = module_count++;
320 if (!(cur & 0xfff)) { 320 modinfo = xrealloc_vector(modinfo, 12, cur);
321 modinfo = xrealloc(modinfo, sizeof(modinfo[0]) * (cur + 0x1001));
322 }
323 modinfo[cur].pathname = xstrdup(pathname); 321 modinfo[cur].pathname = xstrdup(pathname);
324 modinfo[cur].desc = NULL; 322 modinfo[cur].desc = NULL;
325 modinfo[cur+1].pathname = NULL; 323 modinfo[cur+1].pathname = NULL;
diff --git a/modutils/modprobe.c b/modutils/modprobe.c
index 3ac5a81a5..1a4f5d4d4 100644
--- a/modutils/modprobe.c
+++ b/modutils/modprobe.c
@@ -482,10 +482,8 @@ static struct dep_t *build_dep(void)
482 dep = xstrndup(deps, next - deps - ext + 1); 482 dep = xstrndup(deps, next - deps - ext + 1);
483 483
484 /* Add the new dependable module name */ 484 /* Add the new dependable module name */
485 current->m_depcnt++; 485 current->m_deparr = xrealloc_vector(current->m_deparr, 2, current->m_depcnt);
486 current->m_deparr = xrealloc(current->m_deparr, 486 current->m_deparr[current->m_depcnt++] = dep;
487 sizeof(char *) * current->m_depcnt);
488 current->m_deparr[current->m_depcnt - 1] = dep;
489 487
490 p = next + 2; 488 p = next + 2;
491 } while (next < end); 489 } while (next < end);