gem5 v24.0.0.0
Loading...
Searching...
No Matches
se_workload.hh
Go to the documentation of this file.
1/*
2 * Copyright 2020 Google Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met: redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer;
8 * redistributions in binary form must reproduce the above copyright
9 * notice, this list of conditions and the following disclaimer in the
10 * documentation and/or other materials provided with the distribution;
11 * neither the name of the copyright holders nor the names of its
12 * contributors may be used to endorse or promote products derived from
13 * this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
28#ifndef __SIM_SE_WORKLOAD_HH__
29#define __SIM_SE_WORKLOAD_HH__
30
31#include "params/SEWorkload.hh"
32#include "sim/mem_pool.hh"
33#include "sim/workload.hh"
34
35namespace gem5
36{
37
38class SEWorkload : public Workload
39{
40 protected:
43
44 public:
45 using Params = SEWorkloadParams;
46
47 SEWorkload(const Params &p, Addr page_shift=0);
48
49 void setSystem(System *sys) override;
50
51 Addr
52 getEntry() const override
53 {
54 // This object represents the OS, not the individual processes running
55 // within it.
56 panic("No workload entry point for syscall emulation mode.");
57 }
58
60 getArch() const override
61 {
62 // ISA specific subclasses should implement this method.
63 // This implemenetation is just to avoid having to implement those for
64 // now, and will be removed in the future.
65 panic("SEWorkload::getArch() not implemented.");
66 }
67
70 {
71 // This object represents the OS, not the individual processes running
72 // within it.
73 panic("No workload symbol table for syscall emulation mode.");
74 }
75
76 bool
77 insertSymbol(const loader::Symbol &symbol) override
78 {
79 // This object represents the OS, not the individual processes running
80 // within it.
81 panic("No workload symbol table for syscall emulation mode.");
82 }
83
84 void serialize(CheckpointOut &cp) const override;
85 void unserialize(CheckpointIn &cp) override;
86
87 void syscall(ThreadContext *tc) override;
88
89 // For now, assume the only type of events are system calls.
90 void event(ThreadContext *tc) override { syscall(tc); }
91
92 Addr allocPhysPages(int npages, int pool_id=0);
93 Addr memSize(int pool_id=0) const;
94 Addr freeMemSize(int pool_id=0) const;
95};
96
97} // namespace gem5
98
99#endif // __SIM_SE_WORKLOAD_HH__
SEWorkloadParams Params
Addr getEntry() const override
void syscall(ThreadContext *tc) override
Addr allocPhysPages(int npages, int pool_id=0)
SEWorkload(const Params &p, Addr page_shift=0)
Addr freeMemSize(int pool_id=0) const
MemPools memPools
Memory allocation objects for all physical memories in the system.
void serialize(CheckpointOut &cp) const override
Serialize an object.
loader::Arch getArch() const override
void event(ThreadContext *tc) override
void setSystem(System *sys) override
const loader::SymbolTable & symtab(ThreadContext *) override
Addr memSize(int pool_id=0) const
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool insertSymbol(const loader::Symbol &symbol) override
ThreadContext is the external interface to all thread state for anything outside of the CPU.
#define panic(...)
This implements a cprintf based panic() function.
Definition logging.hh:188
Bitfield< 0 > p
Copyright (c) 2024 - Pranith Kumar Copyright (c) 2020 Inria All rights reserved.
Definition binary32.hh:36
std::ostream CheckpointOut
Definition serialize.hh:66
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition types.hh:147

Generated on Tue Jun 18 2024 16:23:57 for gem5 by doxygen 1.11.0