Packet: Remove NACKs from packet and its use in endpoints
authorAndreas Hansson <andreas.hansson@arm.com>
Wed, 22 Aug 2012 15:39:59 +0000 (11:39 -0400)
committerAndreas Hansson <andreas.hansson@arm.com>
Wed, 22 Aug 2012 15:39:59 +0000 (11:39 -0400)
commitc60db56741631b03e3431d03c26c9114c27ba6c6
tree646cb63e6a355ca2e61569c7e8ce150b7776f12e
parenta6074016e211276e47238d0d708288527ace0aef
Packet: Remove NACKs from packet and its use in endpoints

This patch removes the NACK frrom the packet as there is no longer any
module in the system that issues them (the bridge was the only one and
the previous patch removes that).

The handling of NACKs was mostly avoided throughout the code base, by
using e.g. panic or assert false, but in a few locations the NACKs
were actually dealt with (although NACKs never occured in any of the
regressions). Most notably, the DMA port will now never receive a NACK
and the backoff time is thus never changed. As a consequence, the
entire backoff mechanism (similar to a PCI bus) is now removed and the
DMA port entirely relies on the bus performing the arbitration and
issuing a retry when appropriate. This is more in line with e.g. PCIe.

Surprisingly, this patch has no impact on any of the regressions. As
mentioned in the patch that removes the NACK from the bridge, a
follow-up patch should change the request and response buffer size for
at least one regression to also verify that the system behaves as
expected when the bridge fills up.
14 files changed:
src/arch/arm/ArmTLB.py
src/arch/arm/table_walker.cc
src/arch/arm/table_walker.hh
src/arch/x86/pagetable_walker.cc
src/cpu/o3/fetch_impl.hh
src/cpu/o3/lsq_unit_impl.hh
src/cpu/simple/timing.cc
src/dev/Device.py
src/dev/copy_engine.cc
src/dev/dma_device.cc
src/dev/dma_device.hh
src/mem/cache/cache_impl.hh
src/mem/packet.cc
src/mem/packet.hh