gem5  v22.1.0.0
types.hh
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2011, 2018 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_PS2_HH__
39 #define __DEV_PS2_HH__
40 
41 #include <stdint.h>
42 
43 #include <list>
44 #include <vector>
45 
46 #include "base/bitunion.hh"
47 #include "base/compiler.hh"
48 
53 namespace gem5
54 {
55 
57 namespace ps2
58 {
59 
60 enum
61 {
62  SelfTestPass = 0xAA,
63  ReadID = 0xF2,
64  Enable = 0xF4,
65  Disable = 0xF5,
67  SelfTestFail = 0xFC,
68  Ack = 0xFA,
69  Resend = 0xFE,
70  Reset = 0xFF,
71 };
72 
73 GEM5_DEPRECATED_NAMESPACE(Keyboard, keyboard);
74 namespace keyboard
75 {
76 
77 enum
78 {
79  LEDWrite = 0xED,
82  TypematicInfo = 0xF3,
85  AllKeysToMake = 0xF9,
89  KeyToMakeOnly = 0xFD,
90 };
91 
92 extern const std::vector<uint8_t> ID;
93 
94 } // namespace keyboard
95 
97 namespace mouse
98 {
99 
100 enum
101 {
102  Scale1to1 = 0xE6,
103  Scale2to1 = 0xE7,
105  GetStatus = 0xE9,
106  ReadData = 0xEB,
108  WrapMode = 0xEE,
109  RemoteMode = 0xF0,
110  SampleRate = 0xF3,
111 };
112 
113 extern const std::vector<uint8_t> ID;
114 
115 } // namespace mouse
116 
119 BitUnion8(Ps2MouseMovement)
120  Bitfield<0> leftButton;
121  Bitfield<1> rightButton;
122  Bitfield<2> middleButton;
123  Bitfield<3> one;
124  Bitfield<4> xSign;
125  Bitfield<5> ySign;
126  Bitfield<6> xOverflow;
127  Bitfield<7> yOverflow;
128 EndBitUnion(Ps2MouseMovement)
129 
130 
136 void keySymToPs2(uint32_t key, bool down, bool &cur_shift,
137  std::list<uint8_t> &keys);
138 
139 } // namespace ps2
140 } // namespace gem5
141 
142 #endif // __DEV_PS2_HH__
const std::vector< uint8_t > ID
Definition: types.cc:52
@ AllKeysToTypematicMakeRelease
Definition: types.hh:86
const std::vector< uint8_t > ID
Definition: types.cc:53
EndBitUnion(Ps2MouseMovement) void keySymToPs2(uint32_t key
Convert an x11 key symbol into a set of ps2 charecters.
BitUnion8(Ps2MouseMovement) Bitfield< 0 > leftButton
A bitfield that represents the first byte of a mouse movement packet.
bool bool std::list< uint8_t > & keys
Definition: types.hh:137
Bitfield< 5 > ySign
Definition: types.hh:125
GEM5_DEPRECATED_NAMESPACE(Keyboard, keyboard)
Bitfield< 2 > middleButton
Definition: types.hh:122
Bitfield< 6 > xOverflow
Definition: types.hh:126
@ Resend
Definition: types.hh:69
@ DefaultsAndDisable
Definition: types.hh:66
@ ReadID
Definition: types.hh:63
@ Disable
Definition: types.hh:65
@ Enable
Definition: types.hh:64
@ Ack
Definition: types.hh:68
@ SelfTestPass
Definition: types.hh:62
@ SelfTestFail
Definition: types.hh:67
bool down
Definition: types.hh:136
Bitfield< 3 > one
Definition: types.hh:123
void keySymToPs2(uint32_t key, bool down, bool &cur_shift, std::list< uint8_t > &keys)
Definition: types.cc:88
Bitfield< 1 > rightButton
Definition: types.hh:121
Bitfield< 4 > xSign
Definition: types.hh:124
bool bool & cur_shift
Definition: types.hh:136
Bitfield< 7 > yOverflow
Definition: types.hh:127
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
static scfx_rep_node * list
Definition: scfx_rep.cc:336
Overload hash function for BasicBlockRange type.
Definition: misc.hh:2826

Generated on Wed Dec 21 2022 10:22:27 for gem5 by doxygen 1.9.1