summaryrefslogtreecommitdiff
path: root/sys/arch/i386/stand/libsa
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1999-05-09 15:09:06 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1999-05-09 15:09:06 +0000
commit65c685cc9e31308678e954366ced0d603d0b2cc8 (patch)
treed9739c78725e68fb38f9aa79df5284abf4812f62 /sys/arch/i386/stand/libsa
parent47621de23dc4f5e28083422aa7ee1fd696ec207a (diff)
provide suport for an apm data segemnt in the lower memory bios
data segment area, also calculate the apm segment lenghts. niklas@ - ok
Diffstat (limited to 'sys/arch/i386/stand/libsa')
-rw-r--r--sys/arch/i386/stand/libsa/apmprobe.c34
1 files changed, 26 insertions, 8 deletions
diff --git a/sys/arch/i386/stand/libsa/apmprobe.c b/sys/arch/i386/stand/libsa/apmprobe.c
index 049c503f8f1..0760c376563 100644
--- a/sys/arch/i386/stand/libsa/apmprobe.c
+++ b/sys/arch/i386/stand/libsa/apmprobe.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: apmprobe.c,v 1.5 1998/04/18 07:39:40 deraadt Exp $ */
+/* $OpenBSD: apmprobe.c,v 1.6 1999/05/09 15:09:05 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -56,10 +56,15 @@
* FAX: (916)356-6100.
*/
+#include <sys/param.h>
#include "libsa.h"
#include <stand/boot/bootarg.h>
+
+#include <dev/isa/isareg.h>
+
#include <machine/apmvar.h>
#include <machine/biosvar.h>
+
#include "debug.h"
extern int debug;
@@ -117,15 +122,28 @@ apm_connect(ai)
"=d" (ai->apm_data_base)
: "0" (APM_PROT32_CONNECT), "1" (APM_DEV_APM_BIOS)
: "cc");
+ if (f & 0xff)
+ return f >> 8;
+
ai->apm_entry = BIOS_regs.biosr_bx;
-#if 0
- ai->apm_code_len = BIOS_regs.biosr_si & 0xffff;
- ai->apm_data_len = BIOS_regs.biosr_di & 0xffff;
-#else
- ai->apm_code_len = 0x10000;
ai->apm_data_len = 0x10000;
-#endif
- return (f & 0xff)? f >> 8 : 0;
+ ai->apm_code_len = 0x10000 - (ai->apm_code16_base & 0xffff);
+
+ /*
+ * this is a hack to make all those weird boxes keeping
+ * apm data in low mem work.
+ */
+ if (!ai->apm_data_len ||
+ ai->apm_data_base + ai->apm_data_len > IOM_END ||
+ (ai->apm_data_base < IOM_BEGIN &&
+ ai->apm_data_base + ai->apm_data_len > IOM_BEGIN))
+ ai->apm_data_len =
+ 0x10000 - (ai->apm_data_base & 0xffff);
+ if (ai->apm_data_base < BOOTARG_OFF)
+ ai->apm_data_len =
+ NBPG - (ai->apm_data_base & PGOFSET);
+
+ return 0;
}
void