From a2719c9f15fff1422374255d205d80282629b363 Mon Sep 17 00:00:00 2001 From: Michael Shalayeff Date: Sun, 21 Jan 2001 20:23:23 +0000 Subject: map the bios rom at both it's real address and zero offset corresponding to the base of the rom. this solves a problem for roms referring to their internal tables by real addresses. brad@ testing, 10x --- sys/arch/i386/i386/bios.c | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/sys/arch/i386/i386/bios.c b/sys/arch/i386/i386/bios.c index a75f17f00b4..102271112ef 100644 --- a/sys/arch/i386/i386/bios.c +++ b/sys/arch/i386/i386/bios.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bios.c,v 1.38 2000/10/25 19:13:11 mickey Exp $ */ +/* $OpenBSD: bios.c,v 1.39 2001/01/21 20:23:22 mickey Exp $ */ /* * Copyright (c) 1997-2000 Michael Shalayeff @@ -322,7 +322,7 @@ bios32_service(service, e, ei) extern int gdt_get_slot __P((void)); u_long pa, endpa; - vm_offset_t va; + vaddr_t va, sva; u_int32_t base, count, off, ent; int slot; @@ -346,9 +346,9 @@ bios32_service(service, e, ei) endpa = i386_round_page(BIOS32_END); #if defined(UVM) - va = uvm_km_valloc(kernel_map, endpa); + sva = va = uvm_km_valloc(kernel_map, endpa); #else - va = kmem_alloc_pageable(kernel_map, endpa); + sva = va = kmem_alloc_pageable(kernel_map, endpa); #endif if (va == 0) return (0); @@ -359,11 +359,20 @@ bios32_service(service, e, ei) for (pa = i386_trunc_page(BIOS32_START), va += i386_trunc_page(BIOS32_START); - pa < endpa; pa += NBPG, va += NBPG) + pa < endpa; pa += NBPG, va += NBPG) { pmap_enter(pmap_kernel(), va, pa, VM_PROT_READ | VM_PROT_WRITE, TRUE, VM_PROT_READ | VM_PROT_WRITE); + /* for all you, broken hearted */ + if (pa >= i386_trunc_page(base)) { + pmap_enter(pmap_kernel(), sva, pa, + VM_PROT_READ | VM_PROT_WRITE, TRUE, + VM_PROT_READ | VM_PROT_WRITE); + sva += NBPG; + } + } + e->segment = GSEL(slot, SEL_KPL); e->offset = (vaddr_t)ent; -- cgit v1.2.3