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

📄 emulos.c

📁 这个是LINUX下的GDB调度工具的源码
💻 C
字号:
/* emulos.c -- Small OS emulation   Copyright 1999, 2000 Free Software Foundation, Inc.   Written by Stephane Carrez (stcarrez@worldnet.fr)This file is part of GDB, GAS, and the GNU binutils.GDB, GAS, and the GNU binutils are free software; you can redistributethem and/or modify them under the terms of the GNU General PublicLicense as published by the Free Software Foundation; either version1, or (at your option) any later version.GDB, GAS, and the GNU binutils are distributed in the hope that theywill be useful, but WITHOUT ANY WARRANTY; without even the impliedwarranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  Seethe GNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this file; see the file COPYING.  If not, write to the FreeSoftware Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */#include "sim-main.h"#ifdef HAVE_UNISTD_H#include <unistd.h>#endif#ifndef WIN32#include <sys/types.h>#include <sys/time.h>/* This file emulates some OS system calls.   It's basically used to give access to the host OS facilities   like: stdin, stdout, files, time of day.  */static int bench_mode = -1;static struct timeval bench_start;static struct timeval bench_stop;voidemul_bench (struct _sim_cpu* cpu){  int op;  op = cpu_get_d (cpu);  switch (op)    {    case 0:      bench_mode = 0;      gettimeofday (&bench_start, 0);      break;    case 1:      gettimeofday (&bench_stop, 0);      if (bench_mode != 0)        printf ("bench start not called...\n");      bench_mode = 1;      break;    case 2:      {        int sz = 0;        int addr = cpu_get_x (cpu);        double t_start, t_stop, t;        char buf[1024];        op = cpu_get_y (cpu);        t_start = (double) (bench_start.tv_sec) * 1.0e6;        t_start += (double) (bench_start.tv_usec);        t_stop  = (double) (bench_stop.tv_sec) * 1.0e6;        t_stop  += (double) (bench_stop.tv_usec);                while (sz < 1024)          {            buf[sz] = memory_read8 (cpu, addr);            if (buf[sz] == 0)              break;            sz ++;            addr++;          }        buf[1023] = 0;        if (bench_mode != 1)          printf ("bench_stop not called");        bench_mode = -1;        t = t_stop - t_start;        printf ("%-40.40s [%6d] %3.3f us\n", buf,                op, t / (double) (op));        break;      }    }}#endifvoidemul_write(struct _sim_cpu* state){  int addr = cpu_get_x (state) & 0x0FFFF;  int size = cpu_get_d (state) & 0x0FFFF;  if (addr + size > 0x0FFFF) {    size = 0x0FFFF - addr;  }  state->cpu_running = 0;  while (size)    {      uint8 val = memory_read8 (state, addr);              write(0, &val, 1);      addr ++;      size--;    }}/* emul_exit () is used by the default startup code of GCC to implement   the exit ().  For a real target, this will create an ILLEGAL fault.   But doing an exit () on a real target is really a non-sense.   exit () is important for the validation of GCC.  The exit status   is passed in 'D' register.  */voidemul_exit (sim_cpu *cpu){  sim_engine_halt (CPU_STATE (cpu), cpu,		   NULL, NULL_CIA, sim_exited,		   cpu_get_d (cpu));}voidemul_os (int code, sim_cpu *proc){  proc->cpu_current_cycle = 8;  switch (code)    {    case 0x0:      break;      /* 0xCD 0x01 */    case 0x01:      emul_write (proc);      break;      /* 0xCD 0x02 */    case 0x02:      break;      /* 0xCD 0x03 */    case 0x03:      emul_exit (proc);      break;      /* 0xCD 0x04 */    case 0x04:#ifndef WIN32      emul_bench (proc);#endif      break;            default:      break;    }}

⌨️ 快捷键说明

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