/* $NetBSD: biosmemx.S,v 1.10 2016/12/04 08:21:08 maxv Exp $ */
/*
* Copyright (c) 1997, 1999
* Matthias Drochner. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/
#include <machine/asm.h>
.text
/*
* int getextmem2(int buffer[2])
*
* return: 0=OK, -1=error
* buffer[0]: extmem kBytes below 16M (max 15M/1024)
* buffer[1]: extmem above 16M, in 64k units
*/
ENTRY(getextmem2)
pushl %ebp
movl %esp,%ebp
pushl %ebx
pushl %ecx
pushl %edx
push %esi
push %edi
call _C_LABEL(prot_to_real)
.code16
xorl %ebx,%ebx
movl $0xe801,%eax
int $0x15
pushf
movw %si,%ax
orw %si,%bx
jz 1f /* if zero use configured values */
movw %cx,%ax /* k below 16M (max 0x3c00 = 15MB) */
movw %dx,%bx /* 64k above 16M */
1:
popf
setc %bl
calll _C_LABEL(real_to_prot)
.code32
movl 8(%ebp),%edi
xorl %eax,%eax
movw %cx,%ax
stosl
movw %dx,%ax
stosl
movb %bl,%al
cbw
pop %edi
pop %esi
popl %edx
popl %ecx
popl %ebx
popl %ebp
ret
/*
* int getmementry(int *iterator, int buffer[5])
*
* return: 0=ok, else error
* buffer[0]: start of memory chunk
* buffer[2]: length (bytes)
* buffer[4]: type
*/
ENTRY(getmementry)
pushl %ebp
movl %esp,%ebp
pushl %ebx
pushl %ecx
pushl %edx
push %esi
push %edi
movl 8(%ebp),%eax
movl 0(%eax),%ebx /* index */
movl $20,%ecx /* Buffer size */
movl $0x534d4150,%edx /* "SMAP" */
movl 12(%ebp),%edi /* buffer address */
call _C_LABEL(prot_to_real)
.code16
push %di
shrl $4,%edi
mov %ds,%ax
add %di,%ax
mov %ax,%es
pop %di
and $0xf,%di /* buffer addres now in ES:DI */
movl $0xe820,%eax /* Some BIOS check EAX value */
int $0x15
setc %cl
calll _C_LABEL(real_to_prot)
.code32
movl 8(%ebp),%eax
movl %ebx,0(%eax) /* updated index */
xorl %eax,%eax
movb %cl,%al
pop %edi
pop %esi
popl %edx
popl %ecx
popl %ebx
popl %ebp
ret
/*
* int biosA20(void)
*
* return: 0=ok, else error
*/
ENTRY(biosA20)
pushl %ebp
movl %esp,%ebp
pushl %ebx
pushl %ecx
pushl %edx
push %esi
push %edi
call _C_LABEL(prot_to_real)
.code16
movl $0x2401,%eax
int $0x15
setc %cl
calll _C_LABEL(real_to_prot)
.code32
movzbl %cl,%eax
pop %edi
pop %esi
popl %edx
popl %ecx
popl %ebx
popl %ebp
ret