diff options
author | Andreas Sandberg <andreas.sandberg@arm.com> | 2016-11-07 18:16:51 +0000 |
---|---|---|
committer | Andreas Sandberg <andreas.sandberg@arm.com> | 2017-04-03 16:36:15 +0000 |
commit | ba00d7449df87c99bf8aca97a877b493c14f4866 (patch) | |
tree | af6e8b32972ddfe6a874b0b9e9ffaf90aded973d /src/dev/virtio | |
parent | cd9ca71b25e0b119c04eb87d4d1d74cfc90587e9 (diff) | |
download | gem5-ba00d7449df87c99bf8aca97a877b493c14f4866.tar.xz |
dev: Add a dummy VirtIO device
VirtIO transport interfaces always expect a VirtIO device
pointer. However, there are cases (in particular when using VirtIO's
MMIO interface) where we want to instantiate an interface without a
device. Add a dummy device using VirtIO device ID 0 and no queues to
handle this use case.
Change-Id: I6cbe12fd403903ef585be40279c3b1321fde48ff
Signed-off-by: Andreas Sandberg <andreas.sandberg@arm.com>
Reviewed-by: Nikos Nikoleris <nikos.nikoleris@arm.com>
Reviewed-by: Sudhanshu Jha <sudhanshu.jha@arm.com>
Reviewed-by: Rekai Gonzalez Alberquilla <rekai.gonzalezalberquilla@arm.com>
Reviewed-on: https://gem5-review.googlesource.com/2325
Reviewed-by: Weiping Liao <weipingliao@google.com>
Reviewed-by: Jason Lowe-Power <jason@lowepower.com>
Diffstat (limited to 'src/dev/virtio')
-rw-r--r-- | src/dev/virtio/VirtIO.py | 8 | ||||
-rw-r--r-- | src/dev/virtio/base.cc | 15 | ||||
-rw-r--r-- | src/dev/virtio/base.hh | 14 |
3 files changed, 33 insertions, 4 deletions
diff --git a/src/dev/virtio/VirtIO.py b/src/dev/virtio/VirtIO.py index 1345c7603..bf050fd47 100644 --- a/src/dev/virtio/VirtIO.py +++ b/src/dev/virtio/VirtIO.py @@ -1,6 +1,6 @@ # -*- mode:python -*- -# Copyright (c) 2014 ARM Limited +# Copyright (c) 2014, 2016 ARM Limited # All rights reserved. # # The license below extends only to copyright in the software and shall @@ -53,11 +53,15 @@ class VirtIODeviceBase(SimObject): system = Param.System(Parent.any, "system object") +class VirtIODummyDevice(VirtIODeviceBase): + type = 'VirtIODummyDevice' + cxx_header = 'dev/virtio/base.hh' + class PciVirtIO(PciDevice): type = 'PciVirtIO' cxx_header = 'dev/virtio/pci.hh' - vio = Param.VirtIODeviceBase("VirtIO device") + vio = Param.VirtIODeviceBase(VirtIODummyDevice(), "VirtIO device") VendorID = 0x1AF4 SubsystemVendorID = VendorID; diff --git a/src/dev/virtio/base.cc b/src/dev/virtio/base.cc index f098784d0..61dd3069f 100644 --- a/src/dev/virtio/base.cc +++ b/src/dev/virtio/base.cc @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014 ARM Limited + * Copyright (c) 2014, 2016 ARM Limited * All rights reserved * * The license below extends only to copyright in the software and shall @@ -41,6 +41,7 @@ #include "debug/VIO.hh" #include "params/VirtIODeviceBase.hh" +#include "params/VirtIODummyDevice.hh" VirtDescriptor::VirtDescriptor(PortProxy &_memProxy, VirtQueue &_queue, Index descIndex) @@ -477,3 +478,15 @@ VirtIODeviceBase::registerQueue(VirtQueue &queue) { _queues.push_back(&queue); } + + +VirtIODummyDevice::VirtIODummyDevice(VirtIODummyDeviceParams *params) + : VirtIODeviceBase(params, ID_INVALID, 0, 0) +{ +} + +VirtIODummyDevice * +VirtIODummyDeviceParams::create() +{ + return new VirtIODummyDevice(this); +} diff --git a/src/dev/virtio/base.hh b/src/dev/virtio/base.hh index 4d4c16536..89c281f21 100644 --- a/src/dev/virtio/base.hh +++ b/src/dev/virtio/base.hh @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014 ARM Limited + * Copyright (c) 2014, 2016 ARM Limited * All rights reserved * * The license below extends only to copyright in the software and shall @@ -48,6 +48,8 @@ #include "sim/sim_object.hh" struct VirtIODeviceBaseParams; +struct VirtIODummyDeviceParams; + class VirtQueue; /** @{ @@ -875,4 +877,14 @@ class VirtIODeviceBase : public SimObject Callback *transKick; }; +class VirtIODummyDevice : public VirtIODeviceBase +{ + public: + VirtIODummyDevice(VirtIODummyDeviceParams *params); + + protected: + /** VirtIO device ID */ + static const DeviceId ID_INVALID = 0x00; +}; + #endif // __DEV_VIRTIO_BASE_HH__ |