| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	Access to VGA videoram | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	(c) 1998 Martin Mares <mj@ucw.cz> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #ifndef _ASM_VGA_H
 | 
					
						
							|  |  |  | #define _ASM_VGA_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-10 19:36:04 -05:00
										 |  |  | #include <asm/addrspace.h>
 | 
					
						
							| 
									
										
										
										
											2005-07-11 10:37:51 +00:00
										 |  |  | #include <asm/byteorder.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	On the PC, we can just recalculate addresses and then | 
					
						
							|  |  |  |  *	access the videoram directly without any black magic. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-10 19:36:04 -05:00
										 |  |  | #define VGA_MAP_MEM(x, s)	CKSEG1ADDR(0x10000000L + (unsigned long)(x))
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define vga_readb(x)	(*(x))
 | 
					
						
							| 
									
										
										
										
											2007-10-11 23:46:15 +01:00
										 |  |  | #define vga_writeb(x, y)	(*(y) = (x))
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 10:37:51 +00:00
										 |  |  | #define VT_BUF_HAVE_RW
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  These are only needed for supporting VGA or MDA text mode, which use little | 
					
						
							|  |  |  |  *  endian byte ordering. | 
					
						
							|  |  |  |  *  In other cases, we can optimize by using native byte ordering and | 
					
						
							|  |  |  |  *  <linux/vt_buffer.h> has already done the right job for us. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-08 16:04:32 +00:00
										 |  |  | #undef scr_writew
 | 
					
						
							|  |  |  | #undef scr_readw
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 10:37:51 +00:00
										 |  |  | static inline void scr_writew(u16 val, volatile u16 *addr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	*addr = cpu_to_le16(val); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline u16 scr_readw(volatile const u16 *addr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return le16_to_cpu(*addr); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define scr_memcpyw(d, s, c) memcpy(d, s, c)
 | 
					
						
							|  |  |  | #define scr_memmovew(d, s, c) memmove(d, s, c)
 | 
					
						
							|  |  |  | #define VT_BUF_HAVE_MEMCPYW
 | 
					
						
							|  |  |  | #define VT_BUF_HAVE_MEMMOVEW
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif /* _ASM_VGA_H */
 |