diff options
author | Giacomo Gabrielli <Giacomo.Gabrielli@arm.com> | 2014-01-24 15:29:30 -0600 |
---|---|---|
committer | Giacomo Gabrielli <Giacomo.Gabrielli@arm.com> | 2014-01-24 15:29:30 -0600 |
commit | aefe9cc624902fe26535028f86ba3a45f555bcf0 (patch) | |
tree | 4d775f34b34eeafc0c596b95aa071cc52fb94283 /src/mem/cache/prefetch/ghb.cc | |
parent | 7f835a59f1c342eb1c170973ad53c493cc38e978 (diff) | |
download | gem5-aefe9cc624902fe26535028f86ba3a45f555bcf0.tar.xz |
mem: Add support for a security bit in the memory system
This patch adds the basic building blocks required to support e.g. ARM
TrustZone by discerning secure and non-secure memory accesses.
Diffstat (limited to 'src/mem/cache/prefetch/ghb.cc')
-rw-r--r-- | src/mem/cache/prefetch/ghb.cc | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/src/mem/cache/prefetch/ghb.cc b/src/mem/cache/prefetch/ghb.cc index 9ceb051a7..e153c777d 100644 --- a/src/mem/cache/prefetch/ghb.cc +++ b/src/mem/cache/prefetch/ghb.cc @@ -1,4 +1,16 @@ /* + * Copyright (c) 2012-2013 ARM Limited + * All rights reserved + * + * The license below extends only to copyright in the software and shall + * not be construed as granting a license to any other intellectual + * property including but not limited to intellectual property relating + * to a hardware implementation of the functionality of the software + * licensed hereunder. You may use the software subject to the license + * terms below provided that you ensure that this notice is replicated + * unmodified and in its entirety in all distributions of the software, + * modified or unmodified, in source code or in binary form. + * * Copyright (c) 2005 The Regents of The University of Michigan * All rights reserved. * @@ -43,16 +55,26 @@ GHBPrefetcher::calculatePrefetch(PacketPtr &pkt, std::list<Addr> &addresses, std::list<Cycles> &delays) { Addr blk_addr = pkt->getAddr() & ~(Addr)(blkSize-1); + bool is_secure = pkt->isSecure(); int master_id = useMasterId ? pkt->req->masterId() : 0; assert(master_id < Max_Masters); + bool same_sec_state = true; + // Avoid activating prefetch if the security state is not + // consistent across requests + if (is_secure != lastMissIsSecure[master_id] || + is_secure != secondLastMissIsSecure[master_id]) + same_sec_state = false; + int new_stride = blk_addr - lastMissAddr[master_id]; int old_stride = lastMissAddr[master_id] - secondLastMissAddr[master_id]; secondLastMissAddr[master_id] = lastMissAddr[master_id]; + secondLastMissIsSecure[master_id] = lastMissIsSecure[master_id]; lastMissAddr[master_id] = blk_addr; + lastMissIsSecure[master_id] = is_secure; - if (new_stride == old_stride) { + if (same_sec_state && new_stride == old_stride) { for (int d = 1; d <= degree; d++) { Addr new_addr = blk_addr + d * new_stride; if (pageStop && !samePage(blk_addr, new_addr)) { |