gem5 v23.0.0.1
Loading...
Searching...
No Matches
console.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2014 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Redistribution and use in source and binary forms, with or without
15 * modification, are permitted provided that the following conditions are
16 * met: redistributions of source code must retain the above copyright
17 * notice, this list of conditions and the following disclaimer;
18 * redistributions in binary form must reproduce the above copyright
19 * notice, this list of conditions and the following disclaimer in the
20 * documentation and/or other materials provided with the distribution;
21 * neither the name of the copyright holders nor the names of its
22 * contributors may be used to endorse or promote products derived from
23 * this software without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36 */
37
38#ifndef __DEV_VIRTIO_CONSOLE_HH__
39#define __DEV_VIRTIO_CONSOLE_HH__
40
41#include "base/compiler.hh"
42#include "dev/serial/serial.hh"
43#include "dev/virtio/base.hh"
44
45namespace gem5
46{
47
48struct VirtIOConsoleParams;
49
69{
70 public:
71 typedef VirtIOConsoleParams Params;
73 virtual ~VirtIOConsole();
74
75 void readConfig(PacketPtr pkt, Addr cfgOffset);
76
77 protected:
85 {
86 uint16_t cols;
87 uint16_t rows;
88 };
89
92
94 static const DeviceId ID_CONSOLE = 0x03;
95
100 static const FeatureBits F_SIZE = 0x01;
102 static const FeatureBits F_MULTIPORT = 0x02;
106 protected:
111 : public VirtQueue
112 {
113 public:
114 TermRecvQueue(PortProxy &proxy, ByteOrder bo,
115 uint16_t size, VirtIOConsole &_parent)
116 : VirtQueue(proxy, bo, size), parent(_parent) {}
117 virtual ~TermRecvQueue() {}
118
119 void onNotify() { trySend(); }
120
122 void trySend();
123
124 std::string name() const { return parent.name() + ".qRecv"; }
125
126 protected:
128 };
131
136 : public VirtQueue
137 {
138 public:
139 TermTransQueue(PortProxy &proxy, ByteOrder bo,
140 uint16_t size, VirtIOConsole &_parent)
141 : VirtQueue(proxy, bo, size), parent(_parent) {}
142 virtual ~TermTransQueue() {}
143
145
146 std::string name() const { return parent.name() + ".qTrans"; }
147
148 protected:
150 };
153
154 protected:
156};
157
158} // namespace gem5
159
160#endif // __DEV_VIRTIO_CONSOLE_HH__
virtual std::string name() const
Definition named.hh:47
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Definition packet.hh:295
This object is a proxy for a port or other object which implements the functional response protocol,...
Definition port_proxy.hh:87
Base class for serial devices such as terminals.
Definition serial.hh:95
VirtIO descriptor (chain) wrapper.
Definition base.hh:118
Virtqueue for data going from the host to the guest.
Definition console.hh:112
TermRecvQueue(PortProxy &proxy, ByteOrder bo, uint16_t size, VirtIOConsole &_parent)
Definition console.hh:114
void onNotify()
Notify queue of pending events.
Definition console.hh:119
void trySend()
Try to send data pending data from the terminal.
Definition console.cc:77
Virtqueue for data going from the guest to the host.
Definition console.hh:137
void onNotifyDescriptor(VirtDescriptor *desc)
Notify queue of pending incoming descriptor.
Definition console.cc:101
TermTransQueue(PortProxy &proxy, ByteOrder bo, uint16_t size, VirtIOConsole &_parent)
Definition console.hh:139
VirtIO console.
Definition console.hh:69
virtual ~VirtIOConsole()
Definition console.cc:63
VirtIOConsoleParams Params
Definition console.hh:71
TermRecvQueue qRecv
Receive queue for port 0.
Definition console.hh:130
SerialDevice & device
Definition console.hh:155
Config config
Currently active configuration (host byte order)
Definition console.hh:91
static const FeatureBits F_MULTIPORT
Supports the multi-port interface.
Definition console.hh:102
static const FeatureBits F_SIZE
Provides the size information.
Definition console.hh:100
void readConfig(PacketPtr pkt, Addr cfgOffset)
Read from the configuration space of a device.
Definition console.cc:67
static const DeviceId ID_CONSOLE
VirtIO device ID.
Definition console.hh:94
TermTransQueue qTrans
Transmit queue for port 0.
Definition console.hh:152
Base class for all VirtIO-based devices.
Definition base.hh:588
uint32_t FeatureBits
Definition base.hh:591
uint16_t DeviceId
Device Type (sometimes known as subsystem ID)
Definition base.hh:599
Base wrapper around a virtqueue.
Definition base.hh:303
const Params & params() const
Bitfield< 25, 21 > bo
Definition types.hh:82
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition types.hh:147
PM4 packets.
Console configuration structure.
Definition console.hh:85

Generated on Mon Jul 10 2023 15:32:03 for gem5 by doxygen 1.9.7