113 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 *  linux/drivers/video/mfb.c -- Low level frame buffer operations for
 | 
						|
 *				 monochrome
 | 
						|
 *
 | 
						|
 *	Created 5 Apr 1997 by Geert Uytterhoeven
 | 
						|
 *
 | 
						|
 *  This file is subject to the terms and conditions of the GNU General Public
 | 
						|
 *  License.  See the file COPYING in the main directory of this archive for
 | 
						|
 *  more details.
 | 
						|
 */
 | 
						|
 | 
						|
#include <linux/module.h>
 | 
						|
#include <linux/string.h>
 | 
						|
#include <linux/fb.h>
 | 
						|
 | 
						|
#include "atafb.h"
 | 
						|
#include "atafb_utils.h"
 | 
						|
 | 
						|
 | 
						|
    /*
 | 
						|
     *  Monochrome
 | 
						|
     */
 | 
						|
 | 
						|
void atafb_mfb_copyarea(struct fb_info *info, u_long next_line,
 | 
						|
			int sy, int sx, int dy, int dx,
 | 
						|
			int height, int width)
 | 
						|
{
 | 
						|
	u8 *src, *dest;
 | 
						|
	u_int rows;
 | 
						|
 | 
						|
	if (sx == 0 && dx == 0 && width == next_line) {
 | 
						|
		src = (u8 *)info->screen_base + sy * (width >> 3);
 | 
						|
		dest = (u8 *)info->screen_base + dy * (width >> 3);
 | 
						|
		fb_memmove(dest, src, height * (width >> 3));
 | 
						|
	} else if (dy <= sy) {
 | 
						|
		src = (u8 *)info->screen_base + sy * next_line + (sx >> 3);
 | 
						|
		dest = (u8 *)info->screen_base + dy * next_line + (dx >> 3);
 | 
						|
		for (rows = height; rows--;) {
 | 
						|
			fb_memmove(dest, src, width >> 3);
 | 
						|
			src += next_line;
 | 
						|
			dest += next_line;
 | 
						|
		}
 | 
						|
	} else {
 | 
						|
		src = (u8 *)info->screen_base + (sy + height - 1) * next_line + (sx >> 3);
 | 
						|
		dest = (u8 *)info->screen_base + (dy + height - 1) * next_line + (dx >> 3);
 | 
						|
		for (rows = height; rows--;) {
 | 
						|
			fb_memmove(dest, src, width >> 3);
 | 
						|
			src -= next_line;
 | 
						|
			dest -= next_line;
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
void atafb_mfb_fillrect(struct fb_info *info, u_long next_line, u32 color,
 | 
						|
			int sy, int sx, int height, int width)
 | 
						|
{
 | 
						|
	u8 *dest;
 | 
						|
	u_int rows;
 | 
						|
 | 
						|
	dest = (u8 *)info->screen_base + sy * next_line + (sx >> 3);
 | 
						|
 | 
						|
	if (sx == 0 && width == next_line) {
 | 
						|
		if (color)
 | 
						|
			fb_memset255(dest, height * (width >> 3));
 | 
						|
		else
 | 
						|
			fb_memclear(dest, height * (width >> 3));
 | 
						|
	} else {
 | 
						|
		for (rows = height; rows--; dest += next_line) {
 | 
						|
			if (color)
 | 
						|
				fb_memset255(dest, width >> 3);
 | 
						|
			else
 | 
						|
				fb_memclear_small(dest, width >> 3);
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
void atafb_mfb_linefill(struct fb_info *info, u_long next_line,
 | 
						|
			int dy, int dx, u32 width,
 | 
						|
			const u8 *data, u32 bgcolor, u32 fgcolor)
 | 
						|
{
 | 
						|
	u8 *dest;
 | 
						|
	u_int rows;
 | 
						|
 | 
						|
	dest = (u8 *)info->screen_base + dy * next_line + (dx >> 3);
 | 
						|
 | 
						|
	for (rows = width / 8; rows--; /* check margins */ ) {
 | 
						|
		// use fast_memmove or fb_memmove
 | 
						|
		*dest++ = *data++;
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
#ifdef MODULE
 | 
						|
MODULE_LICENSE("GPL");
 | 
						|
 | 
						|
int init_module(void)
 | 
						|
{
 | 
						|
	return 0;
 | 
						|
}
 | 
						|
 | 
						|
void cleanup_module(void)
 | 
						|
{
 | 
						|
}
 | 
						|
#endif /* MODULE */
 | 
						|
 | 
						|
 | 
						|
    /*
 | 
						|
     *  Visible symbols for modules
 | 
						|
     */
 | 
						|
 | 
						|
EXPORT_SYMBOL(atafb_mfb_copyarea);
 | 
						|
EXPORT_SYMBOL(atafb_mfb_fillrect);
 | 
						|
EXPORT_SYMBOL(atafb_mfb_linefill);
 |