DOS updates
This commit is contained in:
199
src/mesa/drivers/dos/vesa/blit.S
Normal file
199
src/mesa/drivers/dos/vesa/blit.S
Normal file
@@ -0,0 +1,199 @@
|
|||||||
|
/*
|
||||||
|
* Mesa 3-D graphics library
|
||||||
|
* Version: 4.0
|
||||||
|
*
|
||||||
|
* Copyright (C) 1999 Brian Paul All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included
|
||||||
|
* in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
||||||
|
* AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DOS/DJGPP device driver v1.3 for Mesa 5.0
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002 - Borca Daniel
|
||||||
|
* Email : dborca@yahoo.com
|
||||||
|
* Web : http://www.geocities.com/dborca
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
.file "blit.S"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* extern unsigned int vesa_gran_mask, vesa_gran_shift;
|
||||||
|
* extern int vl_video_selector;
|
||||||
|
|
||||||
|
* extern void *vl_current_draw_buffer;
|
||||||
|
* extern int vl_current_stride, vl_current_height;
|
||||||
|
* extern int vl_current_offset, vl_current_delta;
|
||||||
|
*/
|
||||||
|
|
||||||
|
.text
|
||||||
|
|
||||||
|
/* Desc: VESA bank switching routine (BIOS)
|
||||||
|
*
|
||||||
|
* In : EBX=0, EDX = bank number
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: thrashes EAX
|
||||||
|
*/
|
||||||
|
.p2align 5,,31
|
||||||
|
_vesa_swbankBIOS:
|
||||||
|
movw $0x4f05, %ax
|
||||||
|
int $0x10
|
||||||
|
ret
|
||||||
|
|
||||||
|
.p2align 2,,3
|
||||||
|
.global _vesa_swbank
|
||||||
|
_vesa_swbank: .long _vesa_swbankBIOS
|
||||||
|
|
||||||
|
/* Desc: void vesa_b_dump_virtual (void);
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: uses current draw buffer
|
||||||
|
*/
|
||||||
|
.p2align 5,,31
|
||||||
|
.global _vesa_b_dump_virtual
|
||||||
|
_vesa_b_dump_virtual:
|
||||||
|
cld
|
||||||
|
pushl %es
|
||||||
|
pushl %ebx
|
||||||
|
pushl %esi
|
||||||
|
pushl %edi
|
||||||
|
pushl %ebp
|
||||||
|
movl _vl_video_selector, %es
|
||||||
|
movl _vl_current_draw_buffer, %esi
|
||||||
|
movl _vl_current_offset, %edi
|
||||||
|
movl _vesa_gran_shift, %ecx
|
||||||
|
movl _vesa_gran_mask, %ebp
|
||||||
|
movl %edi, %edx
|
||||||
|
xorl %ebx, %ebx
|
||||||
|
andl %ebp, %edi
|
||||||
|
shrl %cl, %edx
|
||||||
|
incl %ebp
|
||||||
|
call *_vesa_swbank
|
||||||
|
movl _vl_current_stride, %ecx
|
||||||
|
movl _vl_current_height, %eax
|
||||||
|
movl _vl_current_delta, %ebx
|
||||||
|
shrl $2, %ecx
|
||||||
|
.balign 4
|
||||||
|
0:
|
||||||
|
pushl %ecx
|
||||||
|
.balign 4
|
||||||
|
1:
|
||||||
|
cmpl %ebp, %edi
|
||||||
|
jb 2f
|
||||||
|
pushl %eax
|
||||||
|
pushl %ebx
|
||||||
|
incl %edx
|
||||||
|
xorl %ebx, %ebx
|
||||||
|
call *_vesa_swbank
|
||||||
|
popl %ebx
|
||||||
|
popl %eax
|
||||||
|
subl %ebp, %edi
|
||||||
|
.balign 4
|
||||||
|
2:
|
||||||
|
movsl
|
||||||
|
decl %ecx
|
||||||
|
jnz 1b
|
||||||
|
popl %ecx
|
||||||
|
addl %ebx, %edi
|
||||||
|
decl %eax
|
||||||
|
jnz 0b
|
||||||
|
popl %ebp
|
||||||
|
popl %edi
|
||||||
|
popl %esi
|
||||||
|
popl %ebx
|
||||||
|
popl %es
|
||||||
|
ret
|
||||||
|
|
||||||
|
/* Desc: void vesa_l_dump_virtual (void);
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: uses current draw buffer
|
||||||
|
*/
|
||||||
|
.p2align 5,,31
|
||||||
|
.global _vesa_l_dump_virtual
|
||||||
|
_vesa_l_dump_virtual:
|
||||||
|
cld
|
||||||
|
pushl %es
|
||||||
|
pushl %esi
|
||||||
|
pushl %edi
|
||||||
|
movl _vl_video_selector, %es
|
||||||
|
movl _vl_current_draw_buffer, %esi
|
||||||
|
movl _vl_current_offset, %edi
|
||||||
|
movl _vl_current_stride, %ecx
|
||||||
|
movl _vl_current_height, %edx
|
||||||
|
movl _vl_current_delta, %eax
|
||||||
|
shrl $2, %ecx
|
||||||
|
.balign 4
|
||||||
|
0:
|
||||||
|
pushl %ecx
|
||||||
|
rep; movsl
|
||||||
|
popl %ecx
|
||||||
|
addl %eax, %edi
|
||||||
|
decl %edx
|
||||||
|
jnz 0b
|
||||||
|
popl %edi
|
||||||
|
popl %esi
|
||||||
|
popl %es
|
||||||
|
ret
|
||||||
|
|
||||||
|
/* Desc: void vesa_l_dump_virtual_mmx (void);
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: uses current draw buffer
|
||||||
|
*/
|
||||||
|
.p2align 5,,31
|
||||||
|
.global _vesa_l_dump_virtual_mmx
|
||||||
|
_vesa_l_dump_virtual_mmx:
|
||||||
|
#ifdef USE_MMX_ASM
|
||||||
|
pushl %esi
|
||||||
|
pushl %edi
|
||||||
|
movl _vl_video_selector, %fs
|
||||||
|
movl _vl_current_draw_buffer, %esi
|
||||||
|
movl _vl_current_offset, %edi
|
||||||
|
movl _vl_current_stride, %ecx
|
||||||
|
movl _vl_current_height, %edx
|
||||||
|
movl _vl_current_delta, %eax
|
||||||
|
shrl $3, %ecx
|
||||||
|
.balign 4
|
||||||
|
0:
|
||||||
|
pushl %ecx
|
||||||
|
.balign 4
|
||||||
|
1:
|
||||||
|
movq (%esi), %mm0
|
||||||
|
addl $8, %esi
|
||||||
|
movq %mm0, %fs:(%edi)
|
||||||
|
addl $8, %edi
|
||||||
|
decl %ecx
|
||||||
|
jnz 1b
|
||||||
|
popl %ecx
|
||||||
|
addl %eax, %edi
|
||||||
|
decl %edx
|
||||||
|
jnz 0b
|
||||||
|
popl %edi
|
||||||
|
popl %esi
|
||||||
|
emms
|
||||||
|
#endif
|
||||||
|
ret
|
226
src/mesa/drivers/dos/vga/vga.c
Normal file
226
src/mesa/drivers/dos/vga/vga.c
Normal file
@@ -0,0 +1,226 @@
|
|||||||
|
/*
|
||||||
|
* Mesa 3-D graphics library
|
||||||
|
* Version: 4.1
|
||||||
|
*
|
||||||
|
* Copyright (C) 1999 Brian Paul All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included
|
||||||
|
* in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
||||||
|
* AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DOS/DJGPP device driver v1.3 for Mesa 5.0
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002 - Borca Daniel
|
||||||
|
* Email : dborca@yahoo.com
|
||||||
|
* Web : http://www.geocities.com/dborca
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include "vga.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static vl_mode modes[4] = {
|
||||||
|
{0x13 | 0x4000, 320, 200, 320, 8, -1, 320*200},
|
||||||
|
{0xffff, -1, -1, -1, -1, -1, -1}
|
||||||
|
};
|
||||||
|
|
||||||
|
static word16 vga_ver;
|
||||||
|
static int linear_selector;
|
||||||
|
static int oldmode = -1;
|
||||||
|
|
||||||
|
#define vga_color_precision 6
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: Attempts to detect VGA, check video modes and create selectors.
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : mode array
|
||||||
|
*
|
||||||
|
* Note: -
|
||||||
|
*/
|
||||||
|
static vl_mode *vga_init (void)
|
||||||
|
{
|
||||||
|
int rv = 0;
|
||||||
|
|
||||||
|
if (vga_ver) {
|
||||||
|
return modes;
|
||||||
|
}
|
||||||
|
|
||||||
|
__asm("\n\
|
||||||
|
movw $0x1a00, %%ax \n\
|
||||||
|
int $0x10 \n\
|
||||||
|
cmpb $0x1a, %%al \n\
|
||||||
|
jne 0f \n\
|
||||||
|
cmpb $0x07, %%bl \n\
|
||||||
|
jb 0f \n\
|
||||||
|
andl $0xff, %%ebx \n\
|
||||||
|
movl %%ebx, %0 \n\
|
||||||
|
0:":"=g"(rv)::"%eax", "%ebx");
|
||||||
|
if (rv == 0) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_create_selector(&linear_selector, 0xa0000, 0x10000)) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
modes[0].sel = linear_selector;
|
||||||
|
|
||||||
|
vga_ver = rv;
|
||||||
|
return modes;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: Frees all resources allocated by VGA init code.
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: -
|
||||||
|
*/
|
||||||
|
static void vga_finit (void)
|
||||||
|
{
|
||||||
|
if (vga_ver) {
|
||||||
|
_remove_selector(&linear_selector);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: Attempts to enter specified video mode.
|
||||||
|
*
|
||||||
|
* In : ptr to mode structure, refresh rate
|
||||||
|
* Out : 0 if success
|
||||||
|
*
|
||||||
|
* Note: -
|
||||||
|
*/
|
||||||
|
static int vga_entermode (vl_mode *p, int refresh)
|
||||||
|
{
|
||||||
|
if (!(p->mode & 0x4000)) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
VGA.blit = vl_can_mmx() ? vesa_l_dump_virtual_mmx : vesa_l_dump_virtual;
|
||||||
|
|
||||||
|
if (oldmode == -1) {
|
||||||
|
__asm("\n\
|
||||||
|
movb $0x0f, %%ah \n\
|
||||||
|
int $0x10 \n\
|
||||||
|
andl $0xff, %%eax \n\
|
||||||
|
movl %%eax, %0 \n\
|
||||||
|
":"=g"(oldmode)::"%eax", "%ebx");
|
||||||
|
}
|
||||||
|
|
||||||
|
__asm("int $0x10"::"a"(p->mode&0xff));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: Restores to the mode prior to first call to vga_entermode.
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: -
|
||||||
|
*/
|
||||||
|
static void vga_restore (void)
|
||||||
|
{
|
||||||
|
if (oldmode != -1) {
|
||||||
|
__asm("int $0x10"::"a"(oldmode));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: set one palette entry
|
||||||
|
*
|
||||||
|
* In : color index, R, G, B
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: uses normalized values
|
||||||
|
*/
|
||||||
|
static void vga_setCI_f (int index, float red, float green, float blue)
|
||||||
|
{
|
||||||
|
float max = (1 << vga_color_precision) - 1;
|
||||||
|
|
||||||
|
int _red = red * max;
|
||||||
|
int _green = green * max;
|
||||||
|
int _blue = blue * max;
|
||||||
|
|
||||||
|
__asm("\n\
|
||||||
|
movw $0x1010, %%ax \n\
|
||||||
|
movb %1, %%dh \n\
|
||||||
|
movb %2, %%ch \n\
|
||||||
|
int $0x10 \n\
|
||||||
|
"::"b"(index), "m"(_red), "m"(_green), "c"(_blue):"%eax", "%edx");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: set one palette entry
|
||||||
|
*
|
||||||
|
* In : color index, R, G, B
|
||||||
|
* Out : -
|
||||||
|
*
|
||||||
|
* Note: uses integer values
|
||||||
|
*/
|
||||||
|
static void vga_setCI_i (int index, int red, int green, int blue)
|
||||||
|
{
|
||||||
|
__asm("\n\
|
||||||
|
movw $0x1010, %%ax \n\
|
||||||
|
movb %1, %%dh \n\
|
||||||
|
movb %2, %%ch \n\
|
||||||
|
int $0x10 \n\
|
||||||
|
"::"b"(index), "m"(red), "m"(green), "c"(blue):"%eax", "%edx");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Desc: retrieve CI precision
|
||||||
|
*
|
||||||
|
* In : -
|
||||||
|
* Out : precision in bits
|
||||||
|
*
|
||||||
|
* Note: -
|
||||||
|
*/
|
||||||
|
static int vga_getCIprec (void)
|
||||||
|
{
|
||||||
|
return vga_color_precision;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* the driver
|
||||||
|
*/
|
||||||
|
vl_driver VGA = {
|
||||||
|
vga_init,
|
||||||
|
vga_entermode,
|
||||||
|
NULL,
|
||||||
|
vga_setCI_f,
|
||||||
|
vga_setCI_i,
|
||||||
|
vga_getCIprec,
|
||||||
|
vga_restore,
|
||||||
|
vga_finit
|
||||||
|
};
|
42
src/mesa/drivers/dos/vga/vga.h
Normal file
42
src/mesa/drivers/dos/vga/vga.h
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
/*
|
||||||
|
* Mesa 3-D graphics library
|
||||||
|
* Version: 4.0
|
||||||
|
*
|
||||||
|
* Copyright (C) 1999 Brian Paul All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included
|
||||||
|
* in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||||
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
||||||
|
* AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DOS/DJGPP device driver v1.3 for Mesa 5.0
|
||||||
|
*
|
||||||
|
* Copyright (C) 2002 - Borca Daniel
|
||||||
|
* Email : dborca@yahoo.com
|
||||||
|
* Web : http://www.geocities.com/dborca
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef VGA_H_included
|
||||||
|
#define VGA_H_included
|
||||||
|
|
||||||
|
#include "../internal.h"
|
||||||
|
#include "../vesa/vesa.h"
|
||||||
|
|
||||||
|
extern vl_driver VGA;
|
||||||
|
|
||||||
|
#endif
|
Reference in New Issue
Block a user