can't boot mpc5200, powerpc: Enable AT_BASE_PLATFORM aux vector
Jon Smirl
jonsmirl at gmail.com
Sat Jul 26 08:46:38 EST 2008
On 7/25/08, Benjamin Herrenschmidt <benh at kernel.crashing.org> wrote:
> On Fri, 2008-07-25 at 17:00 -0500, Nathan Lynch wrote:
> > Jon Smirl wrote:
> > > I've lost my ability to boot on the mpc5200. Reverting this patch fixes it.
> >
> > How does it fail?
> >
> >
> > > @@ -1652,6 +1655,14 @@ struct cpu_spec * __init identify_cpu(unsigned
> > > long offset, unsigned int pvr)
> > > } else
> > > *t = *s;
> > > *PTRRELOC(&cur_cpu_spec) = &the_cpu_spec;
> > > +
> > > + /*
> > > + * Set the base platform string once; assumes
> > > + * we're called with real pvr first.
> > > + */
> > > + if (powerpc_base_platform == NULL)
> > > + powerpc_base_platform = t->platform;
> > > +
> >
> > Hmm, maybe this needs RELOC/PTRRELOC tricks?
>
>
> Hrm... indeed.
>
> if (RELOC(powerpc_base_platform))
> RELOC(powerpc_base_platform) = t->platform;
It completely fails booting, no console or anything.
Where is RELOC defined, prom_init.c?
#ifdef CONFIG_PPC64
#define RELOC(x) (*PTRRELOC(&(x)))
#define ADDR(x) (u32) add_reloc_offset((unsigned long)(x))
#define OF_WORKAROUNDS 0
#else
#define RELOC(x) (x)
#define ADDR(x) (u32) (x)
#define OF_WORKAROUNDS of_workarounds
int of_workarounds;
#endif
>
> try that.
>
> Ben.
>
>
>
--
Jon Smirl
jonsmirl at gmail.com
More information about the Linuxppc-dev
mailing list