00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 #include <sys/tss.h>
00031 #include <ubixos/sched.h>
00032 #include <vmm/vmm.h>
00033 #include <lib/kmalloc.h>
00034 #include <lib/bioscall.h>
00035 #include <lib/string.h>
00036 #include <sys/video.h>
00037 #include <assert.h>
00038
00039
00040 asm(
00041 ".globl bios16Code\n"
00042 ".code16 \n"
00043 "bios16Code: \n"
00044 "int $0x10 \n"
00045 "int $0x69 \n"
00046 ".code32 \n"
00047 );
00048
00049
00050 void biosCall(int biosInt,int eax,int ebx,int ecx,int edx,int esi,int edi,int es,int ds) {
00051 short segment = 0x0,offset = 0x0;
00052 uInt32 tmpAddr = (uInt32)&bios16Code;
00053 kTask_t *newProcess = 0x0;
00054
00055 offset = tmpAddr & 0xF;
00056 segment = tmpAddr >> 4;
00057
00058 newProcess = schedNewTask();
00059 assert(newProcess);
00060
00061
00062 newProcess->tss.back_link = 0x0;
00063 newProcess->tss.esp0 = (uInt32)kmalloc(0x2000)+0x2000;
00064 newProcess->tss.ss0 = 0x10;
00065 newProcess->tss.esp1 = 0x0;
00066 newProcess->tss.ss1 = 0x0;
00067 newProcess->tss.esp2 = 0x0;
00068 newProcess->tss.ss2 = 0x0;
00069 newProcess->tss.cr3 = (uInt32)_current->tss.cr3;
00070 newProcess->tss.eip = offset & 0xFFFF;
00071 newProcess->tss.eflags = 2 | EFLAG_IF | EFLAG_VM;
00072 newProcess->tss.eax = eax & 0xFFFF;
00073 newProcess->tss.ebx = ebx & 0xFFFF;
00074 newProcess->tss.ecx = ecx & 0xFFFF;
00075 newProcess->tss.edx = edx & 0xFFFF;
00076 newProcess->tss.esp = 0x1000 & 0xFFFF;
00077 newProcess->tss.ebp = 0x1000 & 0xFFFF;
00078 newProcess->tss.esi = esi & 0xFFFF;
00079 newProcess->tss.edi = edi & 0xFFFF;
00080 newProcess->tss.es = es & 0xFFFF;
00081 newProcess->tss.cs = segment & 0xFFFF;
00082 newProcess->tss.ss = 0x1000 & 0xFFFF;
00083 newProcess->tss.ds = ds & 0xFFFF;
00084 newProcess->tss.fs = 0x0 & 0xFFFF;
00085 newProcess->tss.gs = 0x0 & 0xFFFF;
00086 newProcess->tss.ldt = 0x0 & 0xFFFF;
00087 newProcess->tss.trace_bitmap = 0x0 & 0xFFFF;
00088 newProcess->tss.io_map = 0x0 & 0xFFFF;
00089 newProcess->tss.io_map = sizeof(struct tssStruct)-8192;
00090 newProcess->oInfo.v86Task = 0x1;
00091
00092 newProcess->state = READY;
00093
00094 while (newProcess->state > 0);
00095
00096 return;
00097 }
00098
00099
00100
00101
00102