Home | History | Annotate | Download | only in Library
      1 /** @file
      2   Load/boot UEFI Linux.
      3 
      4   Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR>
      5   This program and the accompanying materials
      6   are licensed and made available under the terms and conditions of the BSD License
      7   which accompanies this distribution.  The full text of the license may be found at
      8   http://opensource.org/licenses/bsd-license.php
      9 
     10   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
     11   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
     12 
     13 **/
     14 
     15 #ifndef __LOAD_LINUX_LIB__
     16 #define __LOAD_LINUX_LIB__
     17 
     18 
     19 /**
     20   Verifies that the kernel setup image is valid and supported.
     21   The kernel setup image should be checked before using other library
     22   routines which take the kernel setup as an input.
     23 
     24   @param[in]     KernelSetup - The kernel setup image
     25   @param[in]     KernelSetupSize - The kernel setup size
     26 
     27   @retval    EFI_SUCCESS - The Linux kernel setup is valid and supported
     28   @retval    EFI_INVALID_PARAMETER - KernelSetup was NULL
     29   @retval    EFI_UNSUPPORTED - The Linux kernel is not supported
     30 
     31 **/
     32 EFI_STATUS
     33 EFIAPI
     34 LoadLinuxCheckKernelSetup (
     35   IN VOID        *KernelSetup,
     36   IN UINTN       KernelSetupSize
     37   );
     38 
     39 
     40 /**
     41   Gets the initial runtime size of the Linux kernel image by examining
     42   the kernel setup image.
     43 
     44   @param[in]     KernelSetup - The kernel setup image
     45   @param[in]     KernelSize - The kernel size on disk.
     46 
     47   @retval    0                An error occured
     48   @retval    !0               The initial size required by the kernel to
     49                               begin execution.
     50 
     51 **/
     52 UINTN
     53 EFIAPI
     54 LoadLinuxGetKernelSize (
     55   IN VOID        *KernelSetup,
     56   IN UINTN       KernelSize
     57   );
     58 
     59 
     60 /**
     61   Loads and boots UEFI Linux.
     62 
     63   Note: If successful, then this routine will not return
     64 
     65   @param[in]     Kernel - The main kernel image
     66   @param[in,out] KernelSetup - The kernel setup image
     67 
     68   @retval    EFI_NOT_FOUND - The Linux kernel was not found
     69   @retval    EFI_INVALID_PARAMETER - Kernel or KernelSetup was NULL
     70   @retval    EFI_UNSUPPORTED - The Linux kernel version is not supported
     71 
     72 **/
     73 EFI_STATUS
     74 EFIAPI
     75 LoadLinux (
     76   IN VOID      *Kernel,
     77   IN OUT VOID  *KernelSetup
     78   );
     79 
     80 
     81 /**
     82   Allocates pages for the kernel setup image.
     83 
     84   @param[in]     Pages - The number of pages
     85 
     86   @retval    NULL - Unable to allocate pages
     87   @retval    !NULL - The address of the pages allocated
     88 
     89 **/
     90 VOID*
     91 EFIAPI
     92 LoadLinuxAllocateKernelSetupPages (
     93   IN UINTN                  Pages
     94   );
     95 
     96 
     97 /**
     98   Clears the uninitialised space before and after the struct setup_header
     99   in the kernel setup image. The kernel requires that these be zeroed
    100   unless explicitly initialised, so this function should be called after
    101   the setup_header has been copied in from a bzImage, before setting up
    102   anything else.
    103 
    104   @param[in]     KernelSetup - The kernel setup image
    105 
    106   @retval    EFI_SUCCESS - The Linux kernel setup was successfully initialized
    107   @retval    EFI_INVALID_PARAMETER - KernelSetup was NULL
    108   @retval    EFI_UNSUPPORTED - The Linux kernel is not supported
    109 
    110 **/
    111 EFI_STATUS
    112 EFIAPI
    113 LoadLinuxInitializeKernelSetup (
    114   IN VOID        *KernelSetup
    115   );
    116 
    117 /**
    118   Allocates pages for the kernel.
    119 
    120   @param[in]     KernelSetup - The kernel setup image
    121   @param[in]     Pages - The number of pages. (It is recommended to use the
    122                          size returned from LoadLinuxGetKernelSize.)
    123 
    124   @retval    NULL - Unable to allocate pages
    125   @retval    !NULL - The address of the pages allocated
    126 
    127 **/
    128 VOID*
    129 EFIAPI
    130 LoadLinuxAllocateKernelPages (
    131   IN VOID                   *KernelSetup,
    132   IN UINTN                  Pages
    133   );
    134 
    135 
    136 /**
    137   Allocates pages for the kernel command line.
    138 
    139   @param[in]     Pages - The number of pages.
    140 
    141   @retval    NULL - Unable to allocate pages
    142   @retval    !NULL - The address of the pages allocated
    143 
    144 **/
    145 VOID*
    146 EFIAPI
    147 LoadLinuxAllocateCommandLinePages (
    148   IN UINTN                  Pages
    149   );
    150 
    151 
    152 /**
    153   Allocates pages for the initrd image.
    154 
    155   @param[in,out] KernelSetup - The kernel setup image
    156   @param[in]     Pages - The number of pages.
    157 
    158   @retval    NULL - Unable to allocate pages
    159   @retval    !NULL - The address of the pages allocated
    160 
    161 **/
    162 VOID*
    163 EFIAPI
    164 LoadLinuxAllocateInitrdPages (
    165   IN VOID                   *KernelSetup,
    166   IN UINTN                  Pages
    167   );
    168 
    169 
    170 /**
    171   Sets the kernel command line parameter within the setup image.
    172 
    173   @param[in,out] KernelSetup - The kernel setup image
    174   @param[in]     CommandLine - The kernel command line
    175 
    176   @retval    EFI_SUCCESS - The Linux kernel setup is valid and supported
    177   @retval    EFI_INVALID_PARAMETER - KernelSetup was NULL
    178   @retval    EFI_UNSUPPORTED - The Linux kernel is not supported
    179 
    180 **/
    181 EFI_STATUS
    182 EFIAPI
    183 LoadLinuxSetCommandLine (
    184   IN OUT VOID    *KernelSetup,
    185   IN CHAR8       *CommandLine
    186   );
    187 
    188 
    189 /**
    190   Sets the kernel initial ram disk pointer within the setup image.
    191 
    192   @param[in,out] KernelSetup - The kernel setup image
    193   @param[in]     Initrd - Pointer to the initial ram disk
    194   @param[in]     InitrdSize - The initial ram disk image size
    195 
    196   @retval    EFI_SUCCESS - The Linux kernel setup is valid and supported
    197   @retval    EFI_INVALID_PARAMETER - KernelSetup was NULL
    198   @retval    EFI_UNSUPPORTED - The Linux kernel is not supported
    199 
    200 **/
    201 EFI_STATUS
    202 EFIAPI
    203 LoadLinuxSetInitrd (
    204   IN OUT VOID    *KernelSetup,
    205   IN VOID        *Initrd,
    206   IN UINTN       InitrdSize
    207   );
    208 
    209 
    210 #endif
    211 
    212