Don't access init_regs directly. This does not affect newmem; Steve already changed...
authorKevin Lim <ktlim@umich.edu>
Wed, 15 Mar 2006 20:38:14 +0000 (15:38 -0500)
committerKevin Lim <ktlim@umich.edu>
Wed, 15 Mar 2006 20:38:14 +0000 (15:38 -0500)
--HG--
extra : convert_revision : 19b1ed0bb2c8bcde72843e62f73635e84adf95b5

sim/process.cc

index df76e4ddcf6c81b9a365f8d705ee2a2f2aa195e5..a84a4f7ba8a1b44698b07c4d05fdf5f2854c8353 100644 (file)
@@ -148,6 +148,7 @@ Process::registerExecContext(ExecContext *xc)
 
     if (myIndex == 0) {
         // copy process's initial regs struct
+        // Hack for now to copy init regs
         xc->copyArchRegs(cpuXC->getProxy());
     }
 
@@ -343,12 +344,12 @@ LiveProcess::LiveProcess(const string &nm, ObjectFile *objFile,
     copyStringArray(argv, argv_array_base, arg_data_base, memory);
     copyStringArray(envp, envp_array_base, env_data_base, memory);
 
-    init_regs->intRegFile[ArgumentReg0] = argc;
-    init_regs->intRegFile[ArgumentReg1] = argv_array_base;
-    init_regs->intRegFile[StackPointerReg] = stack_min;
-    init_regs->intRegFile[GlobalPointerReg] = objFile->globalPointer();
-    init_regs->pc = prog_entry;
-    init_regs->npc = prog_entry + sizeof(MachInst);
+    cpuXC->setIntReg(ArgumentReg0, argc);
+    cpuXC->setIntReg(ArgumentReg1, argv_array_base);
+    cpuXC->setIntReg(StackPointerReg, stack_min);
+    cpuXC->setIntReg(GlobalPointerReg, objFile->globalPointer());
+    cpuXC->setPC(prog_entry);
+    cpuXC->setNextPC(prog_entry + sizeof(MachInst));
 }
 
 void