vesa.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /* ----------------------------------------------------------------------- *
  3. *
  4. * Copyright 1999-2007 H. Peter Anvin - All Rights Reserved
  5. *
  6. * ----------------------------------------------------------------------- */
  7. #ifndef BOOT_VESA_H
  8. #define BOOT_VESA_H
  9. typedef struct {
  10. u16 off, seg;
  11. } far_ptr;
  12. /* VESA General Information table */
  13. struct vesa_general_info {
  14. u32 signature; /* 0 Magic number = "VESA" */
  15. u16 version; /* 4 */
  16. far_ptr vendor_string; /* 6 */
  17. u32 capabilities; /* 10 */
  18. far_ptr video_mode_ptr; /* 14 */
  19. u16 total_memory; /* 18 */
  20. u8 reserved[236]; /* 20 */
  21. } __attribute__ ((packed));
  22. #define VESA_MAGIC ('V' + ('E' << 8) + ('S' << 16) + ('A' << 24))
  23. struct vesa_mode_info {
  24. u16 mode_attr; /* 0 */
  25. u8 win_attr[2]; /* 2 */
  26. u16 win_grain; /* 4 */
  27. u16 win_size; /* 6 */
  28. u16 win_seg[2]; /* 8 */
  29. far_ptr win_scheme; /* 12 */
  30. u16 logical_scan; /* 16 */
  31. u16 h_res; /* 18 */
  32. u16 v_res; /* 20 */
  33. u8 char_width; /* 22 */
  34. u8 char_height; /* 23 */
  35. u8 memory_planes; /* 24 */
  36. u8 bpp; /* 25 */
  37. u8 banks; /* 26 */
  38. u8 memory_layout; /* 27 */
  39. u8 bank_size; /* 28 */
  40. u8 image_planes; /* 29 */
  41. u8 page_function; /* 30 */
  42. u8 rmask; /* 31 */
  43. u8 rpos; /* 32 */
  44. u8 gmask; /* 33 */
  45. u8 gpos; /* 34 */
  46. u8 bmask; /* 35 */
  47. u8 bpos; /* 36 */
  48. u8 resv_mask; /* 37 */
  49. u8 resv_pos; /* 38 */
  50. u8 dcm_info; /* 39 */
  51. u32 lfb_ptr; /* 40 Linear frame buffer address */
  52. u32 offscreen_ptr; /* 44 Offscreen memory address */
  53. u16 offscreen_size; /* 48 */
  54. u8 reserved[206]; /* 50 */
  55. } __attribute__ ((packed));
  56. #endif /* LIB_SYS_VESA_H */