do the correct thing for the "cpu" config definition, and require
options "MATH_EMULATE" for math emulation
This commit is contained in:
parent
c13e0190b7
commit
42ff6b7e23
@ -33,7 +33,8 @@
|
|||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* @(#)locore.s 7.3 (Berkeley) 5/13/91
|
* from: @(#)locore.s 7.3 (Berkeley) 5/13/91
|
||||||
|
* $Id: locore.s,v 1.10 1993/05/20 14:33:41 cgd Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@ -141,6 +142,28 @@ start: movw $0x1234,%ax
|
|||||||
movl 12(%esp),%eax
|
movl 12(%esp),%eax
|
||||||
movl %eax, _cyloffset-SYSTEM
|
movl %eax, _cyloffset-SYSTEM
|
||||||
|
|
||||||
|
/* find out our CPU type. */
|
||||||
|
pushfl
|
||||||
|
popl %eax
|
||||||
|
movl %eax, %ecx
|
||||||
|
xorl $0x40000, %eax
|
||||||
|
pushl %eax
|
||||||
|
popfl
|
||||||
|
pushfl
|
||||||
|
popl %eax
|
||||||
|
xorl %ecx, %eax
|
||||||
|
shrl $18, %eax
|
||||||
|
andl $1, %eax
|
||||||
|
push %ecx
|
||||||
|
popfl
|
||||||
|
|
||||||
|
cmpl $0, %eax
|
||||||
|
jne 1f
|
||||||
|
movl $CPU_386, _cpu-SYSTEM
|
||||||
|
jmp 2f
|
||||||
|
1: movl $CPU_486, _cpu-SYSTEM
|
||||||
|
2:
|
||||||
|
|
||||||
#ifdef garbage
|
#ifdef garbage
|
||||||
/* count up memory */
|
/* count up memory */
|
||||||
|
|
||||||
@ -293,8 +316,6 @@ begin: /* now running relocated at SYSTEM where the system is linked to run */
|
|||||||
lea 7*NBPG(%esi),%esi # skip past stack.
|
lea 7*NBPG(%esi),%esi # skip past stack.
|
||||||
pushl %esi
|
pushl %esi
|
||||||
|
|
||||||
call _set_cpu_type # get kind of cpu
|
|
||||||
|
|
||||||
call _init386 # wire 386 chip for unix operation
|
call _init386 # wire 386 chip for unix operation
|
||||||
|
|
||||||
movl $0,_PTD
|
movl $0,_PTD
|
||||||
@ -1853,30 +1874,6 @@ IDTVEC(syscall)
|
|||||||
pushl $0
|
pushl $0
|
||||||
jmp doreti
|
jmp doreti
|
||||||
|
|
||||||
ALIGN32
|
|
||||||
ENTRY(set_cpu_type)
|
|
||||||
pushfl
|
|
||||||
popl %eax
|
|
||||||
movl %eax, %ecx
|
|
||||||
xorl $0x40000, %eax
|
|
||||||
pushl %eax
|
|
||||||
popfl
|
|
||||||
pushfl
|
|
||||||
popl %eax
|
|
||||||
xorl %ecx, %eax
|
|
||||||
shrl $18, %eax
|
|
||||||
andl $1, %eax
|
|
||||||
push %ecx
|
|
||||||
popfl
|
|
||||||
|
|
||||||
movl $_cpu, %ecx
|
|
||||||
cmpl $0, %eax
|
|
||||||
jne 1f
|
|
||||||
movl $CPU_386, (%ecx)
|
|
||||||
ret
|
|
||||||
1: movl $CPU_486, (%ecx)
|
|
||||||
ret
|
|
||||||
|
|
||||||
ALIGN32
|
ALIGN32
|
||||||
ENTRY(htonl)
|
ENTRY(htonl)
|
||||||
ENTRY(ntohl)
|
ENTRY(ntohl)
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* from: @(#)machdep.c 7.4 (Berkeley) 6/3/91
|
* from: @(#)machdep.c 7.4 (Berkeley) 6/3/91
|
||||||
* $Id: machdep.c,v 1.15 1993/05/20 02:14:49 cgd Exp $
|
* $Id: machdep.c,v 1.16 1993/05/20 14:33:44 cgd Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "param.h"
|
#include "param.h"
|
||||||
@ -140,6 +140,7 @@ cpu_startup()
|
|||||||
* Good {morning,afternoon,evening,night}.
|
* Good {morning,afternoon,evening,night}.
|
||||||
*/
|
*/
|
||||||
printf(version);
|
printf(version);
|
||||||
|
identifycpu();
|
||||||
printf("real mem = %d\n", ctob(physmem));
|
printf("real mem = %d\n", ctob(physmem));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -256,6 +257,37 @@ again:
|
|||||||
configure();
|
configure();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
identifycpu() /* translated from hp300 -- cgd */
|
||||||
|
{
|
||||||
|
if (cpu < CPU_MINTYPE || cpu > CPU_MAXTYPE) {
|
||||||
|
printf("unknown cpu type %d\n", cpu);
|
||||||
|
panic("startup: bad cpu id");
|
||||||
|
}
|
||||||
|
printf("CPU: %s\n", cpu_typenames[cpu]);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Now that we have told the user what they have,
|
||||||
|
* let them know if that machine type isn't configured.
|
||||||
|
*/
|
||||||
|
switch (cpu) {
|
||||||
|
case -1: /* keep compilers happy */
|
||||||
|
#if !defined(I386_CPU)
|
||||||
|
case CPU_386:
|
||||||
|
case CPU_386SX:
|
||||||
|
#endif
|
||||||
|
#if !defined(I486_CPU)
|
||||||
|
case CPU_486:
|
||||||
|
case CPU_486SX:
|
||||||
|
#endif
|
||||||
|
#if !defined(I586_CPU)
|
||||||
|
case CPU_586:
|
||||||
|
#endif
|
||||||
|
panic("CPU type not configured");
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef PGINPROF
|
#ifdef PGINPROF
|
||||||
/*
|
/*
|
||||||
* Return the difference (in microseconds)
|
* Return the difference (in microseconds)
|
||||||
|
@ -1,4 +1,9 @@
|
|||||||
/* [expediant "port" of linux 8087 emulator to 386BSD, with apologies -wfj] */
|
/*
|
||||||
|
* expediant "port" of linux 8087 emulator to 386BSD, with apologies -wfj
|
||||||
|
*
|
||||||
|
* $Id: math_emulate.c,v 1.3 1993/05/20 14:33:45 cgd Exp $
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* linux/kernel/math/math_emulate.c
|
* linux/kernel/math/math_emulate.c
|
||||||
*
|
*
|
||||||
@ -29,16 +34,6 @@
|
|||||||
* The other files also don't care about ST(x) etc - they just get addresses
|
* The other files also don't care about ST(x) etc - they just get addresses
|
||||||
* to 80-bit temporary reals, and do with them as they please. I wanted to
|
* to 80-bit temporary reals, and do with them as they please. I wanted to
|
||||||
* hide most of the 387-specific things here.
|
* hide most of the 387-specific things here.
|
||||||
*
|
|
||||||
* PATCHES MAGIC LEVEL PATCH THAT GOT US HERE
|
|
||||||
* -------------------- ----- ----------------------
|
|
||||||
* CURRENT PATCH LEVEL: 2 00060
|
|
||||||
* -------------------- ----- ----------------------
|
|
||||||
*
|
|
||||||
* 19 Sep 92 Ishii Masahiro Fix 0x1fd instruction
|
|
||||||
* kym@bingsuns.cc.binghamton.edu Fix fscale
|
|
||||||
* 28 Nov 92 Poul-Henning Kamp Reduce kernel size if you have
|
|
||||||
* a 387 or 486 chip
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "machine/cpu.h"
|
#include "machine/cpu.h"
|
||||||
@ -78,10 +73,6 @@ put_fs_long(unsigned long val, unsigned long *adr) { (void)suword(adr,val); }
|
|||||||
|
|
||||||
math_emulate(struct trapframe * info)
|
math_emulate(struct trapframe * info)
|
||||||
{
|
{
|
||||||
#if defined(i486) || defined(i387)
|
|
||||||
panic("math_emulate(), shouldn't happen with -Di486 or -Di387");
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
unsigned short code;
|
unsigned short code;
|
||||||
temp_real tmp;
|
temp_real tmp;
|
||||||
char * address;
|
char * address;
|
||||||
@ -1484,4 +1475,3 @@ void int_to_real(const temp_int * a, temp_real * b)
|
|||||||
:"0" (b->a),"1" (b->b));
|
:"0" (b->a),"1" (b->b));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* defined(i486) || defined(i387) */
|
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
*
|
*
|
||||||
* @(#)trap.c 7.4 (Berkeley) 5/13/91
|
* @(#)trap.c 7.4 (Berkeley) 5/13/91
|
||||||
*/
|
*/
|
||||||
static char rcsid[] = "$Header: /cvsroot/src/sys/arch/i386/i386/trap.c,v 1.4 1993/05/13 21:39:38 deraadt Exp $";
|
static char rcsid[] = "$Header: /cvsroot/src/sys/arch/i386/i386/trap.c,v 1.5 1993/05/20 14:33:47 cgd Exp $";
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 386 Trap and System call handleing
|
* 386 Trap and System call handleing
|
||||||
@ -170,8 +170,12 @@ copyfault:
|
|||||||
/* if a transparent fault (due to context switch "late") */
|
/* if a transparent fault (due to context switch "late") */
|
||||||
if (npxdna()) return;
|
if (npxdna()) return;
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef MATH_EMULATE
|
||||||
i = math_emulate(&frame);
|
i = math_emulate(&frame);
|
||||||
if (i == 0) return;
|
if (i == 0) return;
|
||||||
|
#else
|
||||||
|
panic("trap: math emulation necessary!");
|
||||||
|
#endif
|
||||||
ucode = FPE_FPU_NP_TRAP;
|
ucode = FPE_FPU_NP_TRAP;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user