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

📄 trivkpr.c

📁 C++ 编写的EROS RTOS
💻 C
字号:
/* * 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. *//* * TrivKpr -- a trivial domain keeper, just (about) smart enough to * dump the information it was passed by the kernel onto the * console. It makes no attempt to fix the busted process. * * The keeper receives (from the kernel) a DomCtlInfo structure, plus * a fault key to the process and also a process key to the process. */#include <eros/target.h>#include <eros/Invoke.h>#include <eros/ReturnerKey.h>#include <eros/NodeKey.h>#include <domain/domdbg.h>#include <domain/Runtime.h>/* #include <eros/DomCtlInfo.h> */#ifdef __REGISTERS_I486_H__#error "registers anti-macro defined"#endif#include <eros/machine/Registers.h>#include "constituents.h"#define KR_OSTREAM     KR_APP(0)#define KR_RK0         KR_ARG(0)#define KR_RK1         KR_ARG(1)#define KR_PROCESS     KR_ARG(2)typedef struct DomCtlInfo32_s DomCtlInfo;intProcessRequest(Message *msg){  /* We don't bother with the usual request dispatch logic here,   * because we are only ever going to receive one request: the   * "somebody faulted" request which is synthesized by the kernel.   *   * Also, this keeper never exits!   */  struct Registers * regs = (struct Registers *) msg->rcv_data;  kprintf(KR_OSTREAM, "faultCode: 0x%08x\n", regs->faultCode);  kprintf(KR_OSTREAM, "faultInfo: 0x%08x\n", regs->faultInfo);  kprintf(KR_OSTREAM, "fault PC:  0x%08x\n", regs->pc);  kprintf(KR_OSTREAM, "fault SP:  0x%08x\n", regs->sp);  /* If (hypothetically), we had "fixed" the fault condition, then we   * should:   *   *   msg.snd_invKey = KR_RETURN;   *   msg.snd_code   = RC_OK;   *   * The first causes the process to be restarted. The second resets   * the fault code within the process.   */  /* Return 1 so that we will continue processing further requests: */  return 1;}struct Registers rcvData;intmain (){  Message msg;  node_copy(KR_CONSTIT, KC_OSTREAM, KR_OSTREAM);  msg.snd_invKey = KR_VOID;  msg.snd_key0 = KR_VOID;  msg.snd_key1 = KR_VOID;  msg.snd_key2 = KR_VOID;  msg.snd_key3 = KR_VOID;  msg.snd_data = 0;  msg.snd_len = 0;  msg.snd_code = 0;  msg.snd_w1 = 0;  msg.snd_w2 = 0;  msg.snd_w3 = 0;       msg.rcv_key0 = KR_RK0;  msg.rcv_key1 = KR_RK1;  msg.rcv_key2 = KR_PROCESS;  msg.rcv_key3 = KR_RETURN;  msg.rcv_data = &rcvData;  msg.rcv_code = 0;  msg.rcv_w1 = 0;  msg.rcv_w2 = 0;  msg.rcv_w3 = 0;       kprintf(KR_OSTREAM, "Keeper is initialized\n");  do {    msg.rcv_len = sizeof (struct Registers);    RETURN(&msg);    /* If the ProcessRequest routine is actually able to correct the     * fault, it should override msg.snd_invKey with KR_RETURN. If we     * do not return to the faulter, the faulter will remain "stuck"     * in the waiting state, showing in its fault code and fault info     * pseudo-registers the fault code and fault info that the kernel     * just delivered to us (on its behalf).     *     * Note that we don't have the authority to kill the process in     * the absence of prior knowledge about its runtime environment.     */    msg.snd_invKey = KR_VOID;  } while ( ProcessRequest(&msg) );  return 0;}

⌨️ 快捷键说明

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