Automatic Copyright Year update after running gdb/copyright.py
[deliverable/binutils-gdb.git] / sim / common / sim-run.c
CommitLineData
c906108c 1/* Generic simulator run.
88b9d363 2 Copyright (C) 1997-2022 Free Software Foundation, Inc.
c906108c
SS
3 Contributed by Cygnus Support.
4
5This file is part of GDB, the GNU debugger.
6
7This program is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
4744ac1b
JB
9the Free Software Foundation; either version 3 of the License, or
10(at your option) any later version.
c906108c
SS
11
12This program is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
4744ac1b
JB
17You should have received a copy of the GNU General Public License
18along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c 19
6df01ab8
MF
20/* This must come before any other includes. */
21#include "defs.h"
22
c906108c
SS
23#include "sim-main.h"
24#include "sim-assert.h"
25
26/* Generic implementation of sim_engine_run that works within the
27 sim_engine setjmp/longjmp framework. */
28
29#define IMEM XCONCAT
30
31void
32sim_engine_run (SIM_DESC sd,
33 int next_cpu_nr, /* ignore */
34 int nr_cpus, /* ignore */
35 int siggnal) /* ignore */
36{
37 sim_cia cia;
38 sim_cpu *cpu;
39 SIM_ASSERT (STATE_MAGIC (sd) == SIM_MAGIC_NUMBER);
40 cpu = STATE_CPU (sd, 0);
034685f9 41 cia = CPU_PC_GET (cpu);
c906108c
SS
42 while (1)
43 {
44 instruction_word insn = IMEM32 (cia);
45 cia = idecode_issue (sd, insn, cia);
46 /* process any events */
47 if (sim_events_tick (sd))
48 {
034685f9 49 CPU_PC_SET (cpu, cia);
c906108c
SS
50 sim_events_process (sd);
51 }
52 }
53}
This page took 1.16051 seconds and 4 git commands to generate.