minix/kernel/arch/i386/do_readbios.c
Ben Gras cfb2d7bca5 retire BIOS_SEG and umap_bios
. readbios call is now a physical copy with range check in
	  the kernel call instead of BIOS_SEG+umap_bios
	. requires all access to physical memory in bios range to go
	  through sys_readbios
	. drivers/dpeth: wasn't using it
	. adjusted printer
2012-05-09 19:03:59 +02:00

40 lines
1.2 KiB
C

/* The kernel call implemented in this file:
* m_type: SYS_READBIOS
*
* The parameters for this kernel call are:
* m2_i1: RDB_SIZE number of bytes to copy
* m2_l1: RDB_ADDR absolute address in BIOS area
* m2_p1: RDB_BUF buffer address in requesting process
*/
#include "kernel/system.h"
#include <minix/type.h>
/*===========================================================================*
* do_readbios *
*===========================================================================*/
int do_readbios(struct proc * caller, message * m_ptr)
{
struct vir_addr src, dst;
vir_bytes len = m_ptr->RDB_SIZE, limit;
src.segment = PHYS_SEG;
dst.segment = D;
src.offset = m_ptr->RDB_ADDR;
dst.offset = (vir_bytes) m_ptr->RDB_BUF;
src.proc_nr_e = NONE;
dst.proc_nr_e = m_ptr->m_source;
limit = src.offset + len - 1;
#define VINRANGE(v, a, b) ((a) <= (v) && (v) <= (b))
#define SUBRANGE(a,b,c,d) (VINRANGE((a), (c), (d)) && VINRANGE((b),(c),(d)))
#define USERRANGE(a, b) SUBRANGE(src.offset, limit, (a), (b))
if(!USERRANGE(BIOS_MEM_BEGIN, BIOS_MEM_END) &&
!USERRANGE(BASE_MEM_TOP, UPPER_MEM_END))
return EPERM;
return virtual_copy_vmcheck(caller, &src, &dst, m_ptr->RDB_SIZE);
}