summaryrefslogtreecommitdiff
path: root/init/init.c
diff options
context:
space:
mode:
authorEric Andersen2001-03-15 21:04:18 +0000
committerEric Andersen2001-03-15 21:04:18 +0000
commita4edd0e946f47dfca4fe0d5ed410743bdcda131c (patch)
tree284f05cae6a302008084d96e134cb4f9ac7ffa30 /init/init.c
parentf9ff8a7d90855a2131b2da0ec379e8e58ab07b37 (diff)
downloadbusybox-a4edd0e946f47dfca4fe0d5ed410743bdcda131c.zip
busybox-a4edd0e946f47dfca4fe0d5ed410743bdcda131c.tar.gz
A better fix. Read nextPtr before mem gets freed.
-Erik
Diffstat (limited to 'init/init.c')
-rw-r--r--init/init.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/init/init.c b/init/init.c
index eb1b2c5..64c7768 100644
--- a/init/init.c
+++ b/init/init.c
@@ -599,7 +599,8 @@ static void check_memory()
static void run_lastAction(void)
{
initAction *a, *tmp;
- for (a = tmp = initActionList; a; a = tmp = tmp->nextPtr) {
+ for (a = initActionList; a; a = tmp) {
+ tmp = a->nextPtr;
if (a->action == CTRLALTDEL) {
waitfor(a->process, a->console, FALSE);
delete_initAction(a);
@@ -938,7 +939,8 @@ extern int init_main(int argc, char **argv)
/* Now run everything that needs to be run */
/* First run the sysinit command */
- for (a = tmp = initActionList; a; a = tmp = tmp->nextPtr) {
+ for (a = initActionList; a; a = tmp) {
+ tmp = a->nextPtr;
if (a->action == SYSINIT) {
waitfor(a->process, a->console, FALSE);
/* Now remove the "sysinit" entry from the list */
@@ -946,7 +948,8 @@ extern int init_main(int argc, char **argv)
}
}
/* Next run anything that wants to block */
- for (a = tmp = initActionList; a; a = tmp = tmp->nextPtr) {
+ for (a = initActionList; a; a = tmp) {
+ tmp = a->nextPtr;
if (a->action == WAIT) {
waitfor(a->process, a->console, FALSE);
/* Now remove the "wait" entry from the list */
@@ -954,7 +957,8 @@ extern int init_main(int argc, char **argv)
}
}
/* Next run anything to be run only once */
- for (a = tmp = initActionList; a; a = tmp = tmp->nextPtr) {
+ for (a = initActionList; a; a = tmp) {
+ tmp = a->nextPtr;
if (a->action == ONCE) {
run(a->process, a->console, FALSE);
/* Now remove the "once" entry from the list */