gem5  v19.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
arguments.hh
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2003-2005 The Regents of The University of Michigan
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are
7  * met: redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer;
9  * redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution;
12  * neither the name of the copyright holders nor the names of its
13  * contributors may be used to endorse or promote products derived from
14  * this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  *
28  * Authors: Nathan Binkert
29  */
30 
31 #ifndef __SIM_ARGUMENTS_HH__
32 #define __SIM_ARGUMENTS_HH__
33 
34 #include <cassert>
35 #include <memory>
36 
37 #include "cpu/thread_context.hh"
39 
40 class Arguments
41 {
42  protected:
44  int number;
45  uint64_t getArg(uint16_t size = (uint16_t)(-1), bool fp = false);
46 
47  protected:
48  class Data
49  {
50  public:
51  Data(){}
52  ~Data();
53 
54  private:
56 
57  public:
58  char *alloc(size_t size);
59  };
60 
61  std::shared_ptr<Data> data;
62 
63  public:
64  Arguments(ThreadContext *ctx, int n = 0)
65  : tc(ctx), number(n), data(new Data())
66  { assert(number >= 0); }
67  Arguments(const Arguments &args)
68  : tc(args.tc), number(args.number), data(args.data) {}
70 
71  ThreadContext *getThreadContext() const { return tc; }
72 
73  const Arguments &operator=(const Arguments &args) {
74  if (this != &args) {
75  tc = args.tc;
76  number = args.number;
77  data = args.data;
78  }
79  return *this;
80  }
81 
82  // for checking if an argument is NULL
83  bool operator!() {
84  return getArg() == 0;
85  }
86 
88  ++number;
89  assert(number >= 0);
90  return *this;
91  }
92 
94  Arguments args = *this;
95  ++number;
96  assert(number >= 0);
97  return args;
98  }
99 
101  --number;
102  assert(number >= 0);
103  return *this;
104  }
105 
107  Arguments args = *this;
108  --number;
109  assert(number >= 0);
110  return args;
111  }
112 
113  const Arguments &operator+=(int index) {
114  number += index;
115  assert(number >= 0);
116  return *this;
117  }
118 
119  const Arguments &operator-=(int index) {
120  number -= index;
121  assert(number >= 0);
122  return *this;
123  }
124 
126  return Arguments(tc, index);
127  }
128 
129  template <class T>
130  operator T() {
131  assert(sizeof(T) <= sizeof(uint64_t));
132  T d = static_cast<T>(getArg(sizeof(T)));
133  return d;
134  }
135 
136  template <class T>
137  operator T *() {
138  T *buf = (T *)data->alloc(sizeof(T));
139  tc->getVirtProxy().readBlob(getArg(sizeof(T)), buf, sizeof(T));
140  return buf;
141  }
142 
143  operator char *() {
144  char *buf = data->alloc(2048);
145  tc->getVirtProxy().readString(buf, getArg(), 2048);
146  return buf;
147  }
148 };
149 
150 #endif // __SIM_ARGUMENTS_HH__
Bitfield< 30, 0 > index
ThreadContext * getThreadContext() const
Definition: arguments.hh:71
Arguments operator[](int index)
Definition: arguments.hh:125
virtual PortProxy & getVirtProxy()=0
int number
Definition: arguments.hh:44
~Arguments()
Definition: arguments.hh:69
ThreadContext is the external interface to all thread state for anything outside of the CPU...
Bitfield< 31 > n
Arguments operator++(int)
Definition: arguments.hh:93
Arguments(const Arguments &args)
Definition: arguments.hh:67
char * alloc(size_t size)
Definition: arguments.cc:45
Arguments(ThreadContext *ctx, int n=0)
Definition: arguments.hh:64
Bitfield< 9 > d
Arguments operator--(int)
Definition: arguments.hh:106
std::shared_ptr< Data > data
Definition: arguments.hh:61
STL list class.
Definition: stl.hh:54
void readBlob(Addr addr, void *p, int size) const
Higher level interfaces based on the above.
Definition: port_proxy.hh:179
const Arguments & operator-=(int index)
Definition: arguments.hh:119
void readString(std::string &str, Addr addr) const
Same as tryReadString, but insists on success.
Definition: port_proxy.hh:257
Arguments & operator--()
Definition: arguments.hh:100
std::list< char * > data
Definition: arguments.hh:55
TranslatingPortProxy Object Declaration for FS.
const Arguments & operator=(const Arguments &args)
Definition: arguments.hh:73
bool operator!()
Definition: arguments.hh:83
const Arguments & operator+=(int index)
Definition: arguments.hh:113
Bitfield< 19, 16 > fp
ThreadContext * tc
Definition: arguments.hh:43
uint64_t getArg(uint16_t size=(uint16_t)(-1), bool fp=false)
Definition: arguments.cc:53
Arguments & operator++()
Definition: arguments.hh:87

Generated on Fri Feb 28 2020 16:27:02 for gem5 by doxygen 1.8.13