xref: /netbsd-src/sys/arch/i386/stand/lib/getextmemx.c (revision d710132b4b8ce7f7cccaaf660cb16aa16b4077a0)
1 /*	$NetBSD: getextmemx.c,v 1.4 2003/04/16 15:03:59 dsl Exp $	*/
2 
3 /*
4  * Copyright (c) 1997, 1999
5  *	Matthias Drochner.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *    must display the following acknowledgement:
17  *	This product includes software developed for the NetBSD Project
18  *	by Matthias Drochner.
19  * 4. The name of the author may not be used to endorse or promote products
20  *    derived from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  */
34 
35 /*
36  * Try 2 more fancy BIOS calls to get the size of extended
37  * memory besides the classical int15/88, take maximum.
38  * needs lowlevel parts from biosmemx.S and biosmem.S
39  */
40 
41 #include <lib/libsa/stand.h>
42 #include "libi386.h"
43 
44 extern int getextmem2 __P((int *));
45 extern int getmementry __P((int *, int *));
46 extern int getextmemps2 __P((void *));
47 
48 int
49 getextmemx()
50 {
51 	int buf[5], i;
52 	int extmem = getextmem1();
53 #ifdef SUPPORT_PS2
54 	struct {
55 		uint16_t len;
56 		uint32_t dta[8];
57 		/* pad to 64 bytes - without this, machine would reset */
58 		uint8_t __pad[30];
59 	} __attribute__((__packed__)) bufps2;
60 #endif
61 
62 #ifdef DEBUG_MEMSIZE
63 	printf("extmem1: %x\n", extmem);
64 #endif
65 	if (!getextmem2(buf) && buf[0] <= 15 * 1024) {
66 		int help = buf[0];
67 		if (help == 15 * 1024)
68 			help += buf[1] * 64;
69 #ifdef DEBUG_MEMSIZE
70 		printf("extmem2: %x\n", help);
71 #endif
72 		if (extmem < help)
73 			extmem = help;
74 	}
75 
76 	i = 0;
77 	do {
78 		if (getmementry(&i, buf))
79 			break;
80 #ifdef DEBUG_MEMSIZE
81 		printf("mementry: (%d) %x %x %x %x %x\n",
82 			i, buf[0], buf[1], buf[2], buf[3], buf[4]);
83 #endif
84 		if ((buf[4] == 1 && buf[0] == 0x100000)
85 		    && extmem < buf[2] / 1024)
86 			extmem = buf[2] / 1024;
87 	} while (i);
88 
89 #ifdef SUPPORT_PS2
90 	/* use local memory information from RETURN MEMORY-MAP INFORMATION */
91 	if (!getextmemps2((void *) &bufps2)) {
92 		int help = bufps2.dta[0];
93 		if (help == 15 * 1024)
94 			help += bufps2.dta[1];
95 		if (extmem < help)
96 			extmem = help;
97 	}
98 #endif
99 
100 	return (extmem);
101 }
102