diff options
-rw-r--r-- | src/dev/CopyEngine.py | 1 | ||||
-rw-r--r-- | src/dev/copy_engine.cc | 40 | ||||
-rw-r--r-- | src/dev/copy_engine.hh | 17 |
3 files changed, 42 insertions, 16 deletions
diff --git a/src/dev/CopyEngine.py b/src/dev/CopyEngine.py index 29d9a23dd..b89486be8 100644 --- a/src/dev/CopyEngine.py +++ b/src/dev/CopyEngine.py @@ -33,6 +33,7 @@ from Pci import PciDevice class CopyEngine(PciDevice): type = 'CopyEngine' + dma = VectorMasterPort("Copy engine DMA port") VendorID = 0x8086 DeviceID = 0x1a38 Revision = 0xA2 # CM2 stepping (newest listed) diff --git a/src/dev/copy_engine.cc b/src/dev/copy_engine.cc index 33994cfde..a3958127b 100644 --- a/src/dev/copy_engine.cc +++ b/src/dev/copy_engine.cc @@ -1,4 +1,16 @@ /* + * Copyright (c) 2012 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) 2008 The Regents of The University of Michigan * All rights reserved. * @@ -65,7 +77,7 @@ CopyEngine::CopyEngine(const Params *p) CopyEngine::CopyEngineChannel::CopyEngineChannel(CopyEngine *_ce, int cid) - : ce(_ce), channelId(cid), busy(false), underReset(false), + : cePort(NULL), ce(_ce), channelId(cid), busy(false), underReset(false), refreshNext(false), latBeforeBegin(ce->params()->latBeforeBegin), latAfterCompletion(ce->params()->latAfterCompletion), completionDataReg(0), nextState(Idle), drainEvent(NULL), @@ -97,24 +109,24 @@ CopyEngine::CopyEngineChannel::~CopyEngineChannel() delete cePort; } -void -CopyEngine::init() +Port * +CopyEngine::getPort(const std::string &if_name, int idx) { - PciDev::init(); - for (int x = 0; x < chan.size(); x++) - chan[x]->init(); + if (if_name == "dma") { + if (idx < chan.size()) + return chan[idx]->getPort(); + } + return PciDev::getPort(if_name, idx); } -void -CopyEngine::CopyEngineChannel::init() -{ - Port *peer; +Port * +CopyEngine::CopyEngineChannel::getPort() +{ + assert(cePort == NULL); cePort = new DmaPort(ce, ce->sys, ce->params()->min_backoff_delay, - ce->params()->max_backoff_delay); - peer = ce->dmaPort->getPeer()->getOwner()->getPort(""); - peer->setPeer(cePort); - cePort->setPeer(peer); + ce->params()->max_backoff_delay); + return cePort; } void diff --git a/src/dev/copy_engine.hh b/src/dev/copy_engine.hh index 581d3c80b..65a3ac82d 100644 --- a/src/dev/copy_engine.hh +++ b/src/dev/copy_engine.hh @@ -1,4 +1,16 @@ /* + * Copyright (c) 2012 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) 2008 The Regents of The University of Michigan * All rights reserved. * @@ -82,7 +94,7 @@ class CopyEngine : public PciDev public: CopyEngineChannel(CopyEngine *_ce, int cid); virtual ~CopyEngineChannel(); - void init(); + Port *getPort(); std::string name() { assert(ce); return ce->name() + csprintf("-chan%d", channelId); } virtual Tick read(PacketPtr pkt) @@ -183,7 +195,8 @@ class CopyEngine : public PciDev ~CopyEngine(); void regStats(); - void init(); + + virtual Port *getPort(const std::string &if_name, int idx = -1); virtual Tick read(PacketPtr pkt); virtual Tick write(PacketPtr pkt); |