Thanks, Erik, your guess is absolutely right... Richard, do you mind
updating /n/sources/xen/xen3/9/xen3/main.c?

term% diff -c /n/sources/xen/xen3/9/xen3/main.c
/n/sources/contrib/yk/xen3/main.c
/n/sources/xen/xen3/9/xen3/main.c:8,13 - /n/sources/contrib/yk/xen3/main.c:8,14
  #include "init.h"
  #include "pool.h"
  #include "reboot.h"
+ #include <tos.h>

  Mach *m;

/n/sources/xen/xen3/9/xen3/main.c:15,20 -
/n/sources/contrib/yk/xen3/main.c:16,26
  #define BOOTARGSLEN (sizeof xenstart->cmd_line)
  #define MAXCONF 64

+ enum {
+ /* space for syscall args, return PC, top-of-stack struct */
+ Ustkheadroom = sizeof(Sargs) + sizeof(uintptr) + sizeof(Tos),
+ };
+
  char bootdisk[KNAMELEN];
  Conf conf;
  char *confname[MAXCONF];
/n/sources/xen/xen3/9/xen3/main.c:270,276 -
/n/sources/contrib/yk/xen3/main.c:276,282
  uchar *av[32];
  uchar **lsp;

- sp = (uchar*)base + BY2PG - MAXSYSARG*BY2WD;
+ sp = (uchar*)base + BY2PG - Ustkheadroom;

  ac = 0;
  av[ac++] = pusharg("/386/9dos");

2013/9/12 erik quanstrom <quans...@quanstro.net>:
> On Thu Sep 12 09:49:19 EDT 2013, yari...@gmail.com wrote:
>> > The crash seems to be in init, not the kernel.  Are you sure
>> > your file system image is good?
>>
>> it doesn't get far enough for "root from:", so it seems to fail
>> somewhere in the initcode blob
>
> this may be related to the change put in for the routerboard.
>
> it increased the size of Tos, and thus shifted everything around
> on the stack.  but the old pc kernel didn't account for this, and
> 386 kernels failed with bad arg in syscall.  this never affected the
> pae kernel, or the other architectures.  here's the fix as it went
> into 9atom.
>
> ; 9fs atom
> ; cd /n/atom/plan9/sys/src/9/pc
> ; history -D main.c
> Aug  3 15:30:45 EDT 2013 main.c 16439 [quanstro]
> Aug  3 15:30:45 EDT 2013 /n/atomdump/2013/0912/plan9/sys/src/9/pc/main.c 
> 16439 [quanstro]
> 10a11
>> #include      <tos.h>
> 25a27,31
>> enum {
>>       /* space for syscall args, return PC, top-of-stack struct */
>>       Ustkheadroom    = sizeof(Sargs) + sizeof(uintptr) + sizeof(Tos),
>> };
>>
> 294c300
> <       sp = (uchar*)base + BY2PG - MAXSYSARG*BY2WD;
> ---
>>       sp = (uchar*)base + BY2PG - Ustkheadroom;
>
> - erik



-- 
- Yaroslav

Reply via email to