gem5 v24.1.0.1
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
DataBlock.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2021 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 * Copyright (c) 1999-2008 Mark D. Hill and David A. Wood
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 */
40
41#ifndef __MEM_RUBY_COMMON_DATABLOCK_HH__
42#define __MEM_RUBY_COMMON_DATABLOCK_HH__
43
44#include <inttypes.h>
45
46#include <cassert>
47#include <deque>
48#include <iomanip>
49#include <iostream>
50
51#include "mem/packet.hh"
52
53namespace gem5
54{
55
56namespace ruby
57{
58
59class WriteMask;
60
62{
63 public:
64 // Ideally this should nost be called. We allow default so that protocols
65 // do not need to be changed.
66 DataBlock() = default;
67
68 DataBlock(int blk_size)
69 {
70 assert(!m_alloc);
71 m_block_size = blk_size;
72 alloc();
73 }
74
75 DataBlock(const DataBlock &cp);
76
78 {
79 if (m_alloc)
80 delete [] m_data;
81
82 // If data block involved in atomic
83 // operations, free all meta data
84 for (auto log : m_atomicLog) {
85 delete [] log;
86 }
87 }
88
89 DataBlock& operator=(const DataBlock& obj);
90
91 void assign(uint8_t *data);
92
93 void clear();
94 uint8_t getByte(int whichByte) const;
95 const uint8_t *getData(int offset, int len) const;
96 uint8_t* popAtomicLogEntryFront();
97 int numAtomicLogEntries() const;
99 uint8_t *getDataMod(int offset);
100 void setByte(int whichByte, uint8_t data);
101 void setData(const uint8_t *data, int offset, int len);
102 void setData(PacketPtr pkt);
103 void copyPartial(const DataBlock &dblk, int offset, int len);
104 void copyPartial(const DataBlock &dblk, const WriteMask &mask);
105 void atomicPartial(const DataBlock & dblk, const WriteMask & mask,
106 bool isAtomicNoReturn=true);
107 bool equal(const DataBlock& obj) const;
108 void print(std::ostream& out) const;
109
110 int getBlockSize() const { return m_block_size; }
111 void setBlockSize(int block_size) { realloc(block_size); }
112 bool isAlloc() const { return m_alloc; }
113 void realloc(int blk_size);
114
115 private:
116 void alloc();
117 uint8_t *m_data = nullptr;
118 bool m_alloc = false;
120
121 // Tracks block changes when atomic ops are applied
123};
124
125inline void
127{
128 assert(data != NULL);
129 if (m_alloc) {
130 delete [] m_data;
131 }
132 m_data = data;
133 m_alloc = false;
134}
135
136inline uint8_t
137DataBlock::getByte(int whichByte) const
138{
139 assert(m_alloc);
140 return m_data[whichByte];
141}
142
143inline void
144DataBlock::setByte(int whichByte, uint8_t data)
145{
146 assert(m_alloc);
147 m_data[whichByte] = data;
148}
149
150inline void
152{
153 assert(m_alloc);
154 setData(&dblk.m_data[offset], offset, len);
155}
156
157inline std::ostream&
158operator<<(std::ostream& out, const DataBlock& obj)
159{
160 obj.print(out);
161 out << std::flush;
162 return out;
163}
164
165inline bool
166operator==(const DataBlock& obj1,const DataBlock& obj2)
167{
168 return obj1.equal(obj2);
169}
170
171} // namespace ruby
172} // namespace gem5
173
174#endif // __MEM_RUBY_COMMON_DATABLOCK_HH__
const char data[]
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition packet.hh:295
DataBlock(int blk_size)
Definition DataBlock.hh:68
void atomicPartial(const DataBlock &dblk, const WriteMask &mask, bool isAtomicNoReturn=true)
Definition DataBlock.cc:142
uint8_t getByte(int whichByte) const
Definition DataBlock.hh:137
void assign(uint8_t *data)
Definition DataBlock.hh:126
const uint8_t * getData(int offset, int len) const
Definition DataBlock.cc:191
uint8_t * popAtomicLogEntryFront()
Definition DataBlock.cc:173
void copyPartial(const DataBlock &dblk, int offset, int len)
Definition DataBlock.hh:151
uint8_t * getDataMod(int offset)
Definition DataBlock.cc:200
bool isAlloc() const
Definition DataBlock.hh:112
int numAtomicLogEntries() const
Definition DataBlock.cc:168
DataBlock & operator=(const DataBlock &obj)
Definition DataBlock.cc:224
bool equal(const DataBlock &obj) const
Definition DataBlock.cc:109
void realloc(int blk_size)
Definition DataBlock.cc:88
int getBlockSize() const
Definition DataBlock.hh:110
void setByte(int whichByte, uint8_t data)
Definition DataBlock.hh:144
std::deque< uint8_t * > m_atomicLog
Definition DataBlock.hh:122
void setBlockSize(int block_size)
Definition DataBlock.hh:111
void print(std::ostream &out) const
Definition DataBlock.cc:154
void setData(const uint8_t *data, int offset, int len)
Definition DataBlock.cc:207
STL deque class.
Definition stl.hh:44
Bitfield< 3, 0 > mask
Definition pcstate.hh:63
Bitfield< 18, 16 > len
Bitfield< 23, 0 > offset
Definition types.hh:144
bool operator==(const DataBlock &obj1, const DataBlock &obj2)
Definition DataBlock.hh:166
Copyright (c) 2024 Arm Limited All rights reserved.
Definition binary32.hh:36
std::ostream & operator<<(std::ostream &os, const BaseSemihosting::InPlaceArg &ipa)
Declaration of the Packet class.

Generated on Mon Jan 13 2025 04:28:40 for gem5 by doxygen 1.9.8