• Eric W. Biederman's avatar
    [PATCH] kexec: kexec ppc support · 70765aa4
    Eric W. Biederman authored
    I have tweaked this patch slightly to handle an empty list
    of pages to relocate passed to relocate_new_kernel.  And
    I have added ppc_md.machine_crash_shutdown.  To keep up with
    the changes in the generic kexec infrastructure.
    
    From: Albert Herranz <albert_herranz@yahoo.es>
    
    The following patch adds support for kexec on the ppc32 platform.
    
    Non-OpenFirmware based platforms are likely to work directly without
    additional changes on the kernel side.  The kexec-tools userland package
    may need to be slightly updated, though.
    
    For OpenFirmware based machines, additional work is still needed on the
    kernel side before kexec support is ready.  Benjamin Herrenschmidt is
    kindly working on that part.
    
    In order for a ppc platform to use the kexec kernel services it must
    implement some ppc_md hooks.  Otherwise, kexec will be explicitly disabled,
    as suggested by benh.
    
    There are 3+1 new ppc_md hooks that a platform supporting kexec may
    implement.  Two of them are mandatory for kexec to work.  See
    include/asm-ppc/machdep.h for details.
    
    - machine_kexec_prepare(image)
    
      This function is called to make any arrangements to the image before it
      is loaded.
    
      This hook _MUST_ be provided by a platform in order to activate kexec
      support for that platform.  Otherwise, the platform is considered to not
      support kexec and the kexec_load system call will fail (that makes all
      existing platforms by default non-kexec'able).
    
    - machine_kexec_cleanup(image)
    
      This function is called to make any cleanups on image after the loaded
      image data it is freed.  This hook is optional.  A platform may or may
      not provide this hook.
    
    - machine_kexec(image)
    
      This function is called to perform the _actual_ kexec.  This hook
      _MUST_ be provided by a platform in order to activate kexec support for
      that platform.
    
      If a platform provides machine_kexec_prepare but forgets to provide
      machine_kexec, a kexec will fall back to a reboot.
    
      A ready-to-use machine_kexec_simple() generic function is provided to,
      hopefully, simplify kexec adoption for embedded platforms.  A platform
      may call this function from its specific machine_kexec hook, like this:
    
    void myplatform_kexec(struct kimage *image)
    {
            machine_kexec_simple(image);
    }
    
    - machine_shutdown()
    
      This function is called to perform any machine specific shutdowns, not
      already done by drivers.  This hook is optional.  A platform may or may
      not provide this hook.
    
    An example (trimmed) platform specific module for a platform supporting
    kexec through the existing machine_kexec_simple follows:
    
    /* ... */
    
    #ifdef CONFIG_KEXEC
    int myplatform_kexec_prepare(struct kimage *image)
    {
            /* here, we can place additional preparations
    */
            return 0; /* yes, we support kexec */
    }
    
    void myplatform_kexec(struct kimage *image)
    {
            machine_kexec_simple(image);
    }
    #endif /* CONFIG_KEXEC */
    
    /* ... */
    
    void __init
    platform_init(unsigned long r3, unsigned long r4,
    unsigned long r5,
                  unsigned long r6, unsigned long r7)
    {
    
    /* ... */
    
    #ifdef CONFIG_KEXEC
            ppc_md.machine_kexec_prepare =
    myplatform_kexec_prepare;
            ppc_md.machine_kexec         =
    myplatform_kexec;
    #endif /* CONFIG_KEXEC */
    
    /* ... */
    
    }
    
    The kexec ppc kernel support has been heavily tested on the GameCube Linux
    port, and, as reported in the fastboot mailing list, it has been tested too
    on a Moto 82xx ppc by Rick Richardson.
    Signed-off-by: default avatarAlbert Herranz <albert_herranz@yahoo.es>
    Signed-off-by: default avatarEric Biederman <ebiederm@xmission.com>
    Acked-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
    Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
    70765aa4
relocate_kernel.S 2.49 KB