⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gpfault.cxx

📁 C++ 编写的EROS RTOS
💻 CXX
字号:
/* * Copyright (C) 1998, 1999, Jonathan S. Shapiro. * * This file is part of the EROS Operating System. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2, * or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *//* Drivers for 386 protection faults */#include <eros/target.h>#include <kerninc/kernel.hxx>#include <kerninc/Thread.hxx>#include <kerninc/Machine.hxx>#include <kerninc/Debug.hxx>#include <kerninc/util.h>#include <kerninc/Process.hxx>#include "Segment.hxx"#include "IDT.hxx"#include "lostart.hxx"boolGPFault(fixregs_t *sa){  if ( sa_IsKernel(sa) ) {    printf("Kernel GP fault. curctxt=0x%08x error=0x%x eip=0x%08x\n",		   Thread::CurContext(),		   sa->Error, sa->EIP);#if 0    printf("domRoot=0x%08x, keyRegs=0x%08x\n",    		   Thread::CurContext()		   ? ((ArchContext*)Thread::CurContext())->procRoot		   : 0,    		   Thread::CurContext()		   ? ((ArchContext*)Thread::CurContext())->keyRegs		   : 0);    printf("0x%x Ctxt hzrd=0x%08x 0x%x hzrd rlu=0x%08x\n",		   sa->EDX,		   ((ArchContext*) sa->EDX)->hazards,		   sa->EDI,		   ((ArchContext*) sa->EDI)->hazards);    printf("0x%x Ctxt rlu=0x%08x 0x%x ctxt rlu=0x%08x\n",		   sa->EDX,		   ((ArchContext*) sa->EDX)->fixRegs.ReloadUnits,		   sa->EDI,		   ((ArchContext*) sa->EDI)->fixRegs.ReloadUnits);    printf("0x%x Ctxt keys=0x%08x 0x%x ctxt keys=0x%08x\n",		   sa->EDX,		   ((ArchContext*) sa->EDX)->keyRegs,		   sa->EDI,		   ((ArchContext*) sa->EDI)->keyRegs);    printf("0x%x Ctxt EDX=0x%08x (offset %u)\n",		   sa->EDX,		   ((ArchContext*) sa->EDX)->fixRegs.EDX,		   & ((ArchContext*) 0)->fixRegs.EDX );#endif#if 1    DumpFixRegs(sa);#endif#if 0    Debug::Backtrace();#endif    halt('t');  }  /* If this is GP(0), and the domain holds the DevicePrivs key in a   * register, but it's privilege level is not appropriate for I/O   * access, escalate it's privilege level. */  fixreg_t iopl = (Thread::CurContext()->fixRegs.EFLAGS & MASK_EFLAGS_IOPL) >> SHIFT_EFLAGS_IOPL;  if ( Thread::CurContext()->fixRegs.Error == 0 &&       Thread::CurContext()->HasDevicePriveleges() &&       iopl != 3 ) {    Thread::CurContext()->fixRegs.EFLAGS |= MASK_EFLAGS_IOPL;#if 0    dprintf(true, "IO privileges now esclated. EFLAGS=0x%x\n", Thread::CurContext()->fixRegs.EFLAGS);#endif    return false;  }    /* If the general protection fault is on a domain marked as a small   * space domain, upgrade the domain to a large space domain and let   * it retry the reference before concluding that we should take this   * fault seriously.   */#ifdef OPTION_SMALL_SPACES  if (Thread::CurContext()->smallPTE) {#if 0    dprintf(true, "Small Space domain takes GP fault\n");#endif    Thread::CurContext()->SwitchToLargeSpace();    return false;  }#endif    Node *domRoot = ((Process*) Thread::CurContext())->procRoot;  printf("Domain ");  printOid(domRoot->ob.oid);  printf(" takes GP fault. error=0x%x eip=0x%08x\n",	      sa->Error, sa->EIP);#if 0  sa->Dump();#endif  if (Thread::CurContext())    ((Process*) Thread::CurContext())->SetFault(FC_GenProtection,						sa->EIP, false);  return false;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -