PERFORCE change 128680 for review
Oleksandr Tymoshenko
gonzo at FreeBSD.org
Mon Nov 5 05:29:53 PST 2007
http://perforce.freebsd.org/chv.cgi?CH=128680
Change 128680 by gonzo at gonzo_jeeves on 2007/11/05 13:29:17
o Make new interface for platform_start. Now this function
accepts for arguments of __register_t which correspond
to a0..a3 registers respectively. It's up to platform_start
implementation to use them in a machine-dependent fashion.
o MALTA board obtaines memory size from a3 register
Affected files ...
.. //depot/projects/mips2/src/sys/mips/include/hwfunc.h#2 edit
.. //depot/projects/mips2/src/sys/mips/mips32/adm5120/adm5120_machdep.c#2 edit
.. //depot/projects/mips2/src/sys/mips/mips32/idt/idt_machdep.c#5 edit
.. //depot/projects/mips2/src/sys/mips/mips32/malta/malta_machdep.c#4 edit
.. //depot/projects/mips2/src/sys/mips/mips32/sentry5/s5_machdep.c#3 edit
Differences ...
==== //depot/projects/mips2/src/sys/mips/include/hwfunc.h#2 (text+ko) ====
@@ -37,6 +37,6 @@
void platform_halt(void);
void platform_intr(struct trapframe *);
void platform_reset(void);
-void platform_start(int, char *[]);
+void platform_start(__register_t, __register_t, __register_t, __register_t);
#endif /* !_MACHINE_HWFUNC_H_ */
==== //depot/projects/mips2/src/sys/mips/mips32/adm5120/adm5120_machdep.c#2 (text+ko) ====
@@ -146,7 +146,8 @@
}
void
-platform_start(int argc, char **argv)
+platform_start(__register_t a0 __unused, __register_t a1 __unused,
+ __register_t a2 __unused, __register_t a3 __unused)
{
vm_offset_t kernend;
uint64_t platform_counter_freq = 175 * 1000 * 1000;
==== //depot/projects/mips2/src/sys/mips/mips32/idt/idt_machdep.c#5 (text+ko) ====
@@ -109,7 +109,8 @@
}
void
-platform_start(int argc, char **argv)
+platform_start(__register_t a0 __unused, __register_t a1 __unused,
+ __register_t a2 __unused, __register_t a3 __unused)
{
uint64_t platform_counter_freq;
vm_offset_t kernend;
==== //depot/projects/mips2/src/sys/mips/mips32/malta/malta_machdep.c#4 (text+ko) ====
@@ -159,16 +159,11 @@
}
#endif
-void
+static void
mips_init(void)
{
int i;
- printf("entry: mips_init()\n");
-
- bootverbose = 1;
- realmem = btoc(64 << 20);
-
for (i = 0; i < 10; i++) {
phys_avail[i] = 0;
}
@@ -238,18 +233,41 @@
}
void
-platform_start(int argc, char **argv)
+platform_start(__register_t a0, __register_t a1, __register_t a2,
+ __register_t a3)
{
vm_offset_t kernend;
uint64_t platform_counter_freq;
+ int argc = a0;
+ char **argv = (char **)a1;
+ char **envp = (char **)a2;
+ unsigned int memsize = a3;
+ int i;
/* clear the BSS and SBSS segments */
kernend = round_page((vm_offset_t)&end);
memset(&edata, 0, kernend - (vm_offset_t)(&edata));
cninit();
+ printf("entry: platform_start()\n");
+ bootverbose = 1;
+ if (bootverbose) {
+ printf("cmd line: ");
+ for (i = 0; i < argc; i++)
+ printf("%s ", argv[i]);
+ printf("\n");
+
+ printf("envp:\n");
+ for (i = 0; envp[i]; i += 2)
+ printf("\t%s = %s\n", envp[i], envp[i+1]);
+
+ printf("memsize = %08x\n", memsize);
+ }
+
+ realmem = btoc(memsize);
mips_init();
+
do {
#if defined(TICK_USE_YAMON_FREQ)
/*
==== //depot/projects/mips2/src/sys/mips/mips32/sentry5/s5_machdep.c#3 (text+ko) ====
@@ -187,7 +187,8 @@
}
void
-platform_start(int argc, char **argv)
+platform_start(__register_t a0 __unused, __register_t a1 __unused,
+ __register_t a2 __unused, __register_t a3 __unused)
{
vm_offset_t kernend;
uint64_t platform_counter_freq;
More information about the p4-projects
mailing list