Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 1 | #ifndef __VGAHW_H |
| 2 | #define __VGAHW_H |
| 3 | |
| 4 | #include "types.h" // u8 |
| 5 | #include "config.h" // CONFIG_* |
| 6 | |
Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 7 | #include "bochsvga.h" // bochsvga_set_mode |
| 8 | #include "stdvga.h" // stdvga_set_mode |
Kevin O'Connor | d83c87b | 2013-01-21 01:14:12 -0500 | [diff] [blame] | 9 | #include "geodevga.h" // geodevga_setup |
Kevin O'Connor | c682ffe | 2016-08-05 11:48:20 -0400 | [diff] [blame] | 10 | #include "vgautil.h" // stdvga_list_modes |
Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 11 | |
Kevin O'Connor | 10dff3d | 2012-01-09 19:19:44 -0500 | [diff] [blame] | 12 | static inline struct vgamode_s *vgahw_find_mode(int mode) { |
Kevin O'Connor | c4a0b97 | 2012-01-09 20:21:31 -0500 | [diff] [blame] | 13 | if (CONFIG_VGA_CIRRUS) |
| 14 | return clext_find_mode(mode); |
| 15 | if (CONFIG_VGA_BOCHS) |
| 16 | return bochsvga_find_mode(mode); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 17 | if (CONFIG_VGA_COREBOOT) |
| 18 | return cbvga_find_mode(mode); |
Kevin O'Connor | 10dff3d | 2012-01-09 19:19:44 -0500 | [diff] [blame] | 19 | return stdvga_find_mode(mode); |
| 20 | } |
| 21 | |
Kevin O'Connor | e6bc4c1 | 2012-01-21 11:26:37 -0500 | [diff] [blame] | 22 | static inline int vgahw_set_mode(struct vgamode_s *vmode_g, int flags) { |
Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 23 | if (CONFIG_VGA_CIRRUS) |
Kevin O'Connor | e6bc4c1 | 2012-01-21 11:26:37 -0500 | [diff] [blame] | 24 | return clext_set_mode(vmode_g, flags); |
Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 25 | if (CONFIG_VGA_BOCHS) |
Kevin O'Connor | e6bc4c1 | 2012-01-21 11:26:37 -0500 | [diff] [blame] | 26 | return bochsvga_set_mode(vmode_g, flags); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 27 | if (CONFIG_VGA_COREBOOT) |
| 28 | return cbvga_set_mode(vmode_g, flags); |
Kevin O'Connor | e6bc4c1 | 2012-01-21 11:26:37 -0500 | [diff] [blame] | 29 | return stdvga_set_mode(vmode_g, flags); |
Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 30 | } |
| 31 | |
Kevin O'Connor | 34203cd | 2012-01-09 20:55:31 -0500 | [diff] [blame] | 32 | static inline void vgahw_list_modes(u16 seg, u16 *dest, u16 *last) { |
| 33 | if (CONFIG_VGA_CIRRUS) |
| 34 | clext_list_modes(seg, dest, last); |
| 35 | else if (CONFIG_VGA_BOCHS) |
| 36 | bochsvga_list_modes(seg, dest, last); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 37 | else if (CONFIG_VGA_COREBOOT) |
| 38 | cbvga_list_modes(seg, dest, last); |
Kevin O'Connor | 34203cd | 2012-01-09 20:55:31 -0500 | [diff] [blame] | 39 | else |
| 40 | stdvga_list_modes(seg, dest, last); |
| 41 | } |
| 42 | |
Kevin O'Connor | d83c87b | 2013-01-21 01:14:12 -0500 | [diff] [blame] | 43 | static inline int vgahw_setup(void) { |
Kevin O'Connor | 161d201 | 2011-12-31 19:42:21 -0500 | [diff] [blame] | 44 | if (CONFIG_VGA_CIRRUS) |
Kevin O'Connor | d83c87b | 2013-01-21 01:14:12 -0500 | [diff] [blame] | 45 | return clext_setup(); |
Kevin O'Connor | 161d201 | 2011-12-31 19:42:21 -0500 | [diff] [blame] | 46 | if (CONFIG_VGA_BOCHS) |
Kevin O'Connor | d83c87b | 2013-01-21 01:14:12 -0500 | [diff] [blame] | 47 | return bochsvga_setup(); |
Nils | 24ddd86 | 2012-01-14 12:15:14 -0500 | [diff] [blame] | 48 | if (CONFIG_VGA_GEODEGX2 || CONFIG_VGA_GEODELX) |
Kevin O'Connor | d83c87b | 2013-01-21 01:14:12 -0500 | [diff] [blame] | 49 | return geodevga_setup(); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 50 | if (CONFIG_VGA_COREBOOT) |
| 51 | return cbvga_setup(); |
Kevin O'Connor | d83c87b | 2013-01-21 01:14:12 -0500 | [diff] [blame] | 52 | return stdvga_setup(); |
Kevin O'Connor | 161d201 | 2011-12-31 19:42:21 -0500 | [diff] [blame] | 53 | } |
| 54 | |
Kevin O'Connor | 9961f99 | 2012-01-21 11:53:44 -0500 | [diff] [blame] | 55 | static inline int vgahw_get_window(struct vgamode_s *vmode_g, int window) { |
| 56 | if (CONFIG_VGA_CIRRUS) |
| 57 | return clext_get_window(vmode_g, window); |
| 58 | if (CONFIG_VGA_BOCHS) |
| 59 | return bochsvga_get_window(vmode_g, window); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 60 | if (CONFIG_VGA_COREBOOT) |
| 61 | return cbvga_get_window(vmode_g, window); |
Kevin O'Connor | 9961f99 | 2012-01-21 11:53:44 -0500 | [diff] [blame] | 62 | return stdvga_get_window(vmode_g, window); |
| 63 | } |
| 64 | |
| 65 | static inline int vgahw_set_window(struct vgamode_s *vmode_g, int window |
| 66 | , int val) { |
| 67 | if (CONFIG_VGA_CIRRUS) |
| 68 | return clext_set_window(vmode_g, window, val); |
| 69 | if (CONFIG_VGA_BOCHS) |
| 70 | return bochsvga_set_window(vmode_g, window, val); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 71 | if (CONFIG_VGA_COREBOOT) |
| 72 | return cbvga_set_window(vmode_g, window, val); |
Kevin O'Connor | 9961f99 | 2012-01-21 11:53:44 -0500 | [diff] [blame] | 73 | return stdvga_set_window(vmode_g, window, val); |
| 74 | } |
| 75 | |
Kevin O'Connor | 3876b53 | 2012-01-24 00:07:44 -0500 | [diff] [blame] | 76 | static inline int vgahw_get_linelength(struct vgamode_s *vmode_g) { |
| 77 | if (CONFIG_VGA_CIRRUS) |
| 78 | return clext_get_linelength(vmode_g); |
| 79 | if (CONFIG_VGA_BOCHS) |
| 80 | return bochsvga_get_linelength(vmode_g); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 81 | if (CONFIG_VGA_COREBOOT) |
| 82 | return cbvga_get_linelength(vmode_g); |
Kevin O'Connor | 3876b53 | 2012-01-24 00:07:44 -0500 | [diff] [blame] | 83 | return stdvga_get_linelength(vmode_g); |
| 84 | } |
| 85 | |
| 86 | static inline int vgahw_set_linelength(struct vgamode_s *vmode_g, int val) { |
| 87 | if (CONFIG_VGA_CIRRUS) |
| 88 | return clext_set_linelength(vmode_g, val); |
| 89 | if (CONFIG_VGA_BOCHS) |
| 90 | return bochsvga_set_linelength(vmode_g, val); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 91 | if (CONFIG_VGA_COREBOOT) |
| 92 | return cbvga_set_linelength(vmode_g, val); |
Kevin O'Connor | 3876b53 | 2012-01-24 00:07:44 -0500 | [diff] [blame] | 93 | return stdvga_set_linelength(vmode_g, val); |
| 94 | } |
| 95 | |
Kevin O'Connor | d61fc53 | 2012-01-27 20:37:45 -0500 | [diff] [blame] | 96 | static inline int vgahw_get_displaystart(struct vgamode_s *vmode_g) { |
| 97 | if (CONFIG_VGA_CIRRUS) |
| 98 | return clext_get_displaystart(vmode_g); |
| 99 | if (CONFIG_VGA_BOCHS) |
| 100 | return bochsvga_get_displaystart(vmode_g); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 101 | if (CONFIG_VGA_COREBOOT) |
| 102 | return cbvga_get_displaystart(vmode_g); |
Kevin O'Connor | d61fc53 | 2012-01-27 20:37:45 -0500 | [diff] [blame] | 103 | return stdvga_get_displaystart(vmode_g); |
| 104 | } |
| 105 | |
| 106 | static inline int vgahw_set_displaystart(struct vgamode_s *vmode_g, int val) { |
| 107 | if (CONFIG_VGA_CIRRUS) |
| 108 | return clext_set_displaystart(vmode_g, val); |
| 109 | if (CONFIG_VGA_BOCHS) |
| 110 | return bochsvga_set_displaystart(vmode_g, val); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 111 | if (CONFIG_VGA_COREBOOT) |
| 112 | return cbvga_set_displaystart(vmode_g, val); |
Kevin O'Connor | d61fc53 | 2012-01-27 20:37:45 -0500 | [diff] [blame] | 113 | return stdvga_set_displaystart(vmode_g, val); |
| 114 | } |
| 115 | |
Kevin O'Connor | e737b17 | 2012-02-04 11:08:39 -0500 | [diff] [blame] | 116 | static inline int vgahw_get_dacformat(struct vgamode_s *vmode_g) { |
| 117 | if (CONFIG_VGA_BOCHS) |
| 118 | return bochsvga_get_dacformat(vmode_g); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 119 | if (CONFIG_VGA_COREBOOT) |
| 120 | return cbvga_get_dacformat(vmode_g); |
Kevin O'Connor | e737b17 | 2012-02-04 11:08:39 -0500 | [diff] [blame] | 121 | return stdvga_get_dacformat(vmode_g); |
| 122 | } |
| 123 | |
| 124 | static inline int vgahw_set_dacformat(struct vgamode_s *vmode_g, int val) { |
| 125 | if (CONFIG_VGA_BOCHS) |
| 126 | return bochsvga_set_dacformat(vmode_g, val); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 127 | if (CONFIG_VGA_COREBOOT) |
| 128 | return cbvga_set_dacformat(vmode_g, val); |
Kevin O'Connor | e737b17 | 2012-02-04 11:08:39 -0500 | [diff] [blame] | 129 | return stdvga_set_dacformat(vmode_g, val); |
| 130 | } |
| 131 | |
Kevin O'Connor | 20dc419 | 2014-02-05 20:52:25 -0500 | [diff] [blame] | 132 | static inline int vgahw_save_restore(int cmd, u16 seg, void *data) { |
Kevin O'Connor | 2469f89 | 2012-02-04 12:40:02 -0500 | [diff] [blame] | 133 | if (CONFIG_VGA_CIRRUS) |
Kevin O'Connor | 20dc419 | 2014-02-05 20:52:25 -0500 | [diff] [blame] | 134 | return clext_save_restore(cmd, seg, data); |
Kevin O'Connor | 2469f89 | 2012-02-04 12:40:02 -0500 | [diff] [blame] | 135 | if (CONFIG_VGA_BOCHS) |
Kevin O'Connor | 20dc419 | 2014-02-05 20:52:25 -0500 | [diff] [blame] | 136 | return bochsvga_save_restore(cmd, seg, data); |
Kevin O'Connor | 7c79029 | 2014-02-11 15:34:58 -0500 | [diff] [blame] | 137 | if (CONFIG_VGA_COREBOOT) |
| 138 | return cbvga_save_restore(cmd, seg, data); |
Kevin O'Connor | 20dc419 | 2014-02-05 20:52:25 -0500 | [diff] [blame] | 139 | return stdvga_save_restore(cmd, seg, data); |
Kevin O'Connor | 2469f89 | 2012-02-04 12:40:02 -0500 | [diff] [blame] | 140 | } |
| 141 | |
Kevin O'Connor | 5108c69 | 2011-12-31 19:13:45 -0500 | [diff] [blame] | 142 | #endif // vgahw.h |