projects
/
gem5.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
arch,cpu,mem: Replace the mmmapped IPR mechanism with local accesses.
[gem5.git]
/
src
/
gpu-compute
/
shader.cc
diff --git
a/src/gpu-compute/shader.cc
b/src/gpu-compute/shader.cc
index 8e7ba9ad589bc71d2359de4f430fc4c09ab7ba0f..2a445204d6164db93dc6c95240248bfafe8f417e 100644
(file)
--- a/
src/gpu-compute/shader.cc
+++ b/
src/gpu-compute/shader.cc
@@
-29,8
+29,6
@@
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
- *
- * Authors: Steve Reinhardt
*/
#include "gpu-compute/shader.hh"
*/
#include "gpu-compute/shader.hh"
@@
-226,7
+224,7
@@
Shader::handshake(GpuDispatcher *_dispatcher)
}
void
}
void
-Shader::doFunctionalAccess(
RequestPtr
req, MemCmd cmd, void *data,
+Shader::doFunctionalAccess(
const RequestPtr &
req, MemCmd cmd, void *data,
bool suppress_func_errors, int cu_id)
{
int block_size = cuList.at(cu_id)->cacheLineSize();
bool suppress_func_errors, int cu_id)
{
int block_size = cuList.at(cu_id)->cacheLineSize();
@@
-338,12
+336,13
@@
Shader::AccessMem(uint64_t address, void *ptr, uint32_t size, int cu_id,
for (ChunkGenerator gen(address, size, cuList.at(cu_id)->cacheLineSize());
!gen.done(); gen.next()) {
for (ChunkGenerator gen(address, size, cuList.at(cu_id)->cacheLineSize());
!gen.done(); gen.next()) {
- RequestPtr req = new Request(0, gen.addr(), gen.size(), 0,
- cuList[0]->masterId(), 0, 0, 0);
+
+ RequestPtr req = std::make_shared<Request>(
+ 0, gen.addr(), gen.size(), 0,
+ cuList[0]->masterId(), 0, 0, nullptr);
doFunctionalAccess(req, cmd, data_buf, suppress_func_errors, cu_id);
data_buf += gen.size();
doFunctionalAccess(req, cmd, data_buf, suppress_func_errors, cu_id);
data_buf += gen.size();
- delete req;
}
}
}
}