post.h 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * Copyright (c) 2014 Google, Inc
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef _post_h
  7. #define _post_h
  8. /* port to use for post codes */
  9. #define POST_PORT 0x80
  10. /* post codes which represent various stages of init */
  11. #define POST_START 0x1e
  12. #define POST_CAR_START 0x1f
  13. #define POST_CAR_SIPI 0x20
  14. #define POST_CAR_MTRR 0x21
  15. #define POST_CAR_UNCACHEABLE 0x22
  16. #define POST_CAR_BASE_ADDRESS 0x23
  17. #define POST_CAR_MASK 0x24
  18. #define POST_CAR_FILL 0x25
  19. #define POST_CAR_ROM_CACHE 0x26
  20. #define POST_CAR_MRC_CACHE 0x27
  21. #define POST_CAR_CPU_CACHE 0x28
  22. #define POST_START_STACK 0x29
  23. #define POST_START_DONE 0x2a
  24. #define POST_CPU_INIT 0x2b
  25. #define POST_EARLY_INIT 0x2c
  26. #define POST_CPU_INFO 0x2d
  27. #define POST_PRE_MRC 0x2e
  28. #define POST_MRC 0x2f
  29. #define POST_DRAM 0x2f
  30. #define POST_LAPIC 0x30
  31. #define POST_RAM_FAILURE 0xea
  32. /* Output a post code using al - value must be 0 to 0xff */
  33. #ifdef __ASSEMBLY__
  34. #define post_code(value) \
  35. movb $value, %al; \
  36. outb %al, $POST_PORT
  37. #else
  38. #include <asm/io.h>
  39. static inline void post_code(int code)
  40. {
  41. outb(code, POST_PORT);
  42. }
  43. #endif
  44. #endif