Blame view

include/bootm.h 2.22 KB
83d290c56   Tom Rini   SPDX: Convert all...
1
  /* SPDX-License-Identifier: GPL-2.0+ */
b63964037   Simon Glass   bootm: Split out ...
2
3
4
  /*
   * (C) Copyright 2000-2009
   * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
b63964037   Simon Glass   bootm: Split out ...
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
   */
  
  #ifndef _BOOTM_H
  #define _BOOTM_H
  
  #include <command.h>
  #include <image.h>
  
  #define BOOTM_ERR_RESET		(-1)
  #define BOOTM_ERR_OVERLAP		(-2)
  #define BOOTM_ERR_UNIMPLEMENTED	(-3)
  
  /*
   *  Continue booting an OS image; caller already has:
   *  - copied image header to global variable `header'
   *  - checked header magic number, checksums (both header & image),
   *  - verified image architecture (PPC) and type (KERNEL or MULTI),
   *  - loaded (first part of) image to header load address,
   *  - disabled interrupts.
   *
   * @flag: Flags indicating what to do (BOOTM_STATE_...)
   * @argc: Number of arguments. Note that the arguments are shifted down
   *	 so that 0 is the first argument not processed by U-Boot, and
   *	 argc is adjusted accordingly. This avoids confusion as to how
   *	 many arguments are available for the OS.
   * @images: Pointers to os/initrd/fdt
   * @return 1 on error. On success the OS boots so this function does
   * not return.
   */
  typedef int boot_os_fn(int flag, int argc, char * const argv[],
  			bootm_headers_t *images);
  
  extern boot_os_fn do_bootm_linux;
f2a53c766   Bin Meng   bootm: vxworks: M...
38
  extern boot_os_fn do_bootm_vxworks;
b63964037   Simon Glass   bootm: Split out ...
39
40
41
42
  int do_bootelf(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
  void lynxkdi_boot(image_header_t *hdr);
  
  boot_os_fn *bootm_os_get_boot_func(int os);
93e078807   Fabrice Fontaine   Make FIT support ...
43
  #if defined(CONFIG_FIT_SIGNATURE)
ce1400f69   Simon Glass   Enhance fit_check...
44
  int bootm_host_load_images(const void *fit, int cfg_noffset);
93e078807   Fabrice Fontaine   Make FIT support ...
45
  #endif
ce1400f69   Simon Glass   Enhance fit_check...
46

b63964037   Simon Glass   bootm: Split out ...
47
48
49
50
  int boot_selected_os(int argc, char * const argv[], int state,
  		     bootm_headers_t *images, boot_os_fn *boot_fn);
  
  ulong bootm_disable_interrupts(void);
d2b2ffe31   Tom Rini   cmd_bootm.c: Add ...
51
  /* This is a special function used by booti/bootz */
d52e8575d   Karl Apsite   Combine bootm_fin...
52
  int bootm_find_images(int flag, int argc, char * const argv[]);
b63964037   Simon Glass   bootm: Split out ...
53
54
55
  
  int do_bootm_states(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[],
  		    int states, bootm_headers_t *images, int boot_progress);
f1bd871ad   Jeroen Hofstee   bootm: add protot...
56
  void arch_preboot_os(void);
896019b18   Simon Glass   Add a comment for...
57
58
59
60
61
62
  /*
   * boards should define this to disable devices when EFI exits from boot
   * services.
   *
   * TODO(sjg@chromium.org>): Update this to use driver model's device_remove().
   */
329da4850   Simon Glass   Define board_quie...
63
  void board_quiesce_devices(void);
f6c6df7eb   Heinrich Schuchardt   efi_loader: refac...
64
65
66
67
  /**
   * switch_to_non_secure_mode() - switch to non-secure mode
   */
  void switch_to_non_secure_mode(void);
b63964037   Simon Glass   bootm: Split out ...
68
  #endif