[PATCH] add restart function for mpc52xx

Sascha Hauer s.hauer at pengutronix.de
Fri Jan 12 19:46:12 EST 2007


On Fri, Jan 12, 2007 at 02:37:23PM +1100, Paul Mackerras wrote:
> Sascha Hauer writes:
> 
> > > This suffers from the same bug mpc83xx_restart has.  We can NOT do an  
> > > ioremap inside the restart function.  We may get called from  
> > > interrupt context on a panic and will not be able to do the ioremap 
> > > ().  The simplest thing is to do the mapping earlier in an init call  
> > > and save the pointer, its not perfect, but better.
> > > 
> > 
> > I'm beginning to hate this whole pseudo OF thing for embedded systems.
> 
> Not being able to ioremap at interrupt time has absolutely _nothing_
> to do with the device tree.

No, not directly..

> 
> > All we need to know is that we have a mpc52xx processor.
> 
> ... until we get a system with a mpc52xx and some extra stuff.  Then
> you say "OK, we just need a boardinfo_t" and then we get 57 different
> variants of boardinfo_t and then we're back in the mess that arch/ppc
> got into.

OK, nobody wants that. I can only compare to arm where we have one
single number per board (not per SoC, I misrepresented that). This
number is perfectly enough to know what SoC we are on (to map the
register space and select timing/irq code and the like). The rest of a
particular board is described in one single board file.
On system with real open firmware it's surely the way to go to use it,
but on systems without OF it's just painful. Not being able to implement
a restart function without changing the device tree shows that.

Sascha

-- 
 Dipl.-Ing. Sascha Hauer | http://www.pengutronix.de
  Pengutronix - Linux Solutions for Science and Industry
    Handelsregister: Amtsgericht Hildesheim, HRA 2686
      Hannoversche Str. 2, 31134 Hildesheim, Germany
    Phone: +49-5121-206917-0 |  Fax: +49-5121-206917-9



More information about the Linuxppc-dev mailing list