gem5 v23.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
vec_reg.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2015-2018 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Redistribution and use in source and binary forms, with or without
15 * modification, are permitted provided that the following conditions are
16 * met: redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer;
18 * redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution;
21 * neither the name of the copyright holders nor the names of its
22 * contributors may be used to endorse or promote products derived from
23 * this software without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36 */
37
97#ifndef __ARCH_GENERIC_VEC_REG_HH__
98#define __ARCH_GENERIC_VEC_REG_HH__
99
100#include <array>
101#include <cstdint>
102#include <iostream>
103#include <string>
104
105#include "base/cprintf.hh"
106#include "base/logging.hh"
107#include "base/types.hh"
109
110namespace gem5
111{
112
113constexpr unsigned MaxVecRegLenInBytes = 1ULL << 16; // 2^16 bytes
114
122template <size_t SIZE>
124{
125 private:
126 static_assert(SIZE > 0,
127 "Cannot create Vector Register Container of zero size");
128 static_assert(SIZE <= MaxVecRegLenInBytes,
129 "Vector Register size limit exceeded");
130 public:
131 static constexpr inline size_t size() { return SIZE; };
132 using Container = std::array<uint8_t, SIZE>;
133 private:
134 // 16-byte aligned to support 128bit element view
135 alignas(16) Container container;
136
137 public:
140
142 void zero() { memset(container.data(), 0, SIZE); }
143
149 {
150 if (&that != this)
151 std::memcpy(container.data(), that.container.data(), SIZE);
152 return *this;
153 }
159 template<size_t S2>
160 inline bool
162 {
163 return SIZE == S2 &&
164 !memcmp(container.data(), that.container.data(), SIZE);
165 }
169 template<size_t S2>
170 bool
172 {
173 return !operator==(that);
174 }
175
187 template <typename VecElem>
188 VecElem *
190 {
191 static_assert(SIZE % sizeof(VecElem) == 0,
192 "VecElem does not evenly divide the register size");
193 return (VecElem *)container.data();
194 }
195
196 template <typename VecElem>
197 const VecElem *
198 as() const
199 {
200 static_assert(SIZE % sizeof(VecElem) == 0,
201 "VecElem does not evenly divide the register size");
202 return (VecElem *)container.data();
203 }
204
205 friend std::ostream&
206 operator<<(std::ostream& os, const VecRegContainer<SIZE>& v)
207 {
208 // When printing for human consumption, break into 4 byte chunks.
209 ccprintf(os, "[");
210 size_t count = 0;
211 for (auto& b: v.container) {
212 if (count && (count % 4) == 0)
213 os << "_";
214 ccprintf(os, "%02x", b);
215 count++;
216 }
217 ccprintf(os, "]");
218 return os;
219 }
220
226};
227
232template <size_t Sz>
234{
235 static bool
236 parse(const std::string &str, VecRegContainer<Sz> &value)
237 {
238 fatal_if(str.size() > 2 * Sz,
239 "Vector register value overflow at unserialize");
240
241 for (int i = 0; i < Sz; i++) {
242 uint8_t b = 0;
243 if (2 * i < str.size())
244 b = stoul(str.substr(i * 2, 2), nullptr, 16);
245 value.template as<uint8_t>()[i] = b;
246 }
247 return true;
248 }
249};
250
251template <size_t Sz>
253{
254 static void
255 show(std::ostream &os, const VecRegContainer<Sz> &value)
256 {
257 for (auto& b: value.container)
258 ccprintf(os, "%02x", b);
259 }
260};
269{
271 bool operator == (const DummyVecRegContainer &d) const { return true; }
272 bool operator != (const DummyVecRegContainer &d) const { return true; }
273 template <typename VecElem>
274 VecElem *as() { return nullptr; }
275};
276template <>
278{
279 static bool
280 parse(const std::string &s, DummyVecRegContainer &value)
281 {
282 return false;
283 }
284};
285static_assert(sizeof(DummyVecRegContainer) == sizeof(RegVal));
286static inline std::ostream &
287operator<<(std::ostream &os, const DummyVecRegContainer &d)
288{
289 return os;
290}
293} // namespace gem5
294
295#endif /* __ARCH_GENERIC_VEC_REG_HH__ */
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
Vector Register Abstraction This generic class is the model in a particularization of MVC,...
Definition vec_reg.hh:124
const VecElem * as() const
Definition vec_reg.hh:198
bool operator==(const VecRegContainer< S2 > &that) const
Equality operator.
Definition vec_reg.hh:161
friend std::ostream & operator<<(std::ostream &os, const VecRegContainer< SIZE > &v)
Definition vec_reg.hh:206
static constexpr size_t size()
Definition vec_reg.hh:131
VecRegContainer(const VecRegContainer &)=default
VecElem * as()
View interposers.
Definition vec_reg.hh:189
VecRegContainer< SIZE > & operator=(const VecRegContainer< SIZE > &that)
Assignment operators.
Definition vec_reg.hh:148
void zero()
Zero the container.
Definition vec_reg.hh:142
bool operator!=(const VecRegContainer< S2 > &that) const
Inequality operator.
Definition vec_reg.hh:171
std::array< uint8_t, SIZE > Container
Definition vec_reg.hh:132
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Definition logging.hh:236
Bitfield< 28 > v
Definition misc_types.hh:54
Bitfield< 4 > s
Bitfield< 7 > b
Bitfield< 7 > i
Definition misc_types.hh:67
Bitfield< 9 > d
Definition misc_types.hh:64
uint32_t VecElem
Definition vec.hh:63
Bitfield< 17 > os
Definition misc.hh:810
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::ostream & operator<<(std::ostream &os, const ArmSemihosting::InPlaceArg &ipa)
uint64_t RegVal
Definition types.hh:173
constexpr unsigned MaxVecRegLenInBytes
Definition vec_reg.hh:113
void ccprintf(cp::Print &print)
Definition cprintf.hh:130
Dummy type aliases and constants for architectures that do not implement vector registers.
Definition vec_reg.hh:269
bool operator==(const DummyVecRegContainer &d) const
Definition vec_reg.hh:271
bool operator!=(const DummyVecRegContainer &d) const
Definition vec_reg.hh:272
static bool parse(const std::string &s, DummyVecRegContainer &value)
Definition vec_reg.hh:280
static bool parse(const std::string &str, VecRegContainer< Sz > &value)
Definition vec_reg.hh:236
static void show(std::ostream &os, const VecRegContainer< Sz > &value)
Definition vec_reg.hh:255

Generated on Mon Jul 10 2023 14:24:26 for gem5 by doxygen 1.9.7