bootboot.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * aarch64-cb/bootboot.c
  3. *
  4. * Copyright (C) 2017 - 2021 bzt (bztsrc@gitlab)
  5. *
  6. * Permission is hereby granted, free of charge, to any person
  7. * obtaining a copy of this software and associated documentation
  8. * files (the "Software"), to deal in the Software without
  9. * restriction, including without limitation the rights to use, copy,
  10. * modify, merge, publish, distribute, sublicense, and/or sell copies
  11. * of the Software, and to permit persons to whom the Software is
  12. * furnished to do so, subject to the following conditions:
  13. *
  14. * The above copyright notice and this permission notice shall be
  15. * included in all copies or substantial portions of the Software.
  16. *
  17. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  18. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  19. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  20. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
  21. * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
  22. * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  24. * DEALINGS IN THE SOFTWARE.
  25. *
  26. * This file is part of the BOOTBOOT Protocol package.
  27. * @brief Boot loader for the AArch64 coreboot payload
  28. *
  29. */
  30. #define BBDEBUG 1
  31. /*
  32. unfortunately currently you cannot compile libpayload for ARM64. It gives this error:
  33. $ cd libpayload
  34. $ make
  35. CC arch/arm64/main.libc.o
  36. <command-line>: error: "_LP64" redefined [-Werror]
  37. <built-in>: note: this is the location of the previous definition
  38. cc1: error: unrecognized command line option '-Wno-address-of-packed-member' [-Werror]
  39. cc1: all warnings being treated as errors
  40. make: *** [Makefile:270: build/arch/arm64/main.libc.o] Error 1
  41. */
  42. #include <libpayload-config.h>
  43. #include <libpayload.h>
  44. extern struct sysinfo_t lib_sysinfo;
  45. int main(void)
  46. {
  47. int ret, i;
  48. printf("Hello World!\n");
  49. ret = lib_get_sysinfo();
  50. if (ret) halt();
  51. printf("Number of memory ranges: %d\n", lib_sysinfo.n_memranges);
  52. for (i = 0; i < lib_sysinfo.n_memranges; i++) {
  53. printf("%d: base 0x%08llx size 0x%08llx type 0x%x\n", i, lib_sysinfo.memrange[i].base, lib_sysinfo.memrange[i].size, lib_sysinfo.memrange[i].type);
  54. }
  55. printf("Now we will halt. Bye\n");
  56. halt();
  57. return 0;
  58. }