1 // license:BSD-3-Clause
2 // copyright-holders:Patrick Mackinlay
3
4 /*
5 * Sony NEWS keyboard and mouse (high-level emulation).
6 *
7 * Sources:
8 *
9 * - https://github.com/tmk/tmk_keyboard/tree/master/converter/news_usb
10 * - https://github.com/NetBSD/src/blob/trunk/sys/dev/news/newskeymap.c
11 * - https://github.com/NetBSD/src/blob/trunk/sys/arch/newsmips/dev/ms_hb.c
12 *
13 * TODO:
14 * - other languages (esp. Japanese)
15 * - other variations
16 * - dip switches
17 */
18
19 #include "emu.h"
20 #include "news_hid.h"
21
22 #include "machine/keyboard.ipp"
23
24 #define VERBOSE 0
25 #include "logmacro.h"
26
27 DEFINE_DEVICE_TYPE(NEWS_HID_HLE, news_hid_hle_device, "news_hid_hle", "Sony NEWS Keyboard and Mouse (HLE)")
28
news_hid_hle_device(machine_config const & mconfig,char const * tag,device_t * owner,u32 clock)29 news_hid_hle_device::news_hid_hle_device(machine_config const &mconfig, char const *tag, device_t *owner, u32 clock)
30 : device_t(mconfig, NEWS_HID_HLE, tag, owner, clock)
31 , device_matrix_keyboard_interface(mconfig, *this, "ROW0", "ROW1", "ROW2", "ROW3", "ROW4", "ROW5", "ROW6", "ROW7")
32 , m_mouse_x_axis(*this, "mouse_x_axis")
33 , m_mouse_y_axis(*this, "mouse_y_axis")
34 , m_mouse_buttons(*this, "mouse_buttons")
35 , m_irq_out_cb(*this)
36 {
37 }
38
map(address_map & map)39 void news_hid_hle_device::map(address_map &map)
40 {
41 map(0x0, 0x0).r(FUNC(news_hid_hle_device::data_r<KEYBOARD>));
42 map(0x1, 0x1).r(FUNC(news_hid_hle_device::status_r<KEYBOARD>));
43 map(0x2, 0x2).w(FUNC(news_hid_hle_device::reset_w<KEYBOARD>));
44 map(0x3, 0x3).w(FUNC(news_hid_hle_device::init_w<KEYBOARD>));
45 map(0x4, 0x4).r(FUNC(news_hid_hle_device::data_r<MOUSE>));
46 map(0x5, 0x5).r(FUNC(news_hid_hle_device::status_r<MOUSE>));
47 map(0x6, 0x6).w(FUNC(news_hid_hle_device::reset_w<MOUSE>));
48 map(0x7, 0x7).w(FUNC(news_hid_hle_device::init_w<MOUSE>));
49 }
50
map_68k(address_map & map)51 void news_hid_hle_device::map_68k(address_map &map)
52 {
53 map(0x0, 0x0).r(FUNC(news_hid_hle_device::data_r<KEYBOARD>));
54 map(0x1, 0x1).r(FUNC(news_hid_hle_device::status_68k_r));
55 map(0x2, 0x2).w(FUNC(news_hid_hle_device::ien_w<KEYBOARD>));
56 map(0x3, 0x3).w(FUNC(news_hid_hle_device::reset_w<KEYBOARD>));
57 // TODO: keyboard buzzer
58 map(0x5, 0x5).r(FUNC(news_hid_hle_device::data_r<MOUSE>));
59 map(0x6, 0x6).w(FUNC(news_hid_hle_device::ien_w<MOUSE>));
60 map(0x7, 0x7).w(FUNC(news_hid_hle_device::reset_w<MOUSE>));
61 }
62
device_start()63 void news_hid_hle_device::device_start()
64 {
65 m_irq_out_cb.resolve_all_safe();
66
67 //save_item(NAME(m_fifo));
68 save_item(NAME(m_irq_enabled));
69 save_item(NAME(m_irq_out_state));
70
71 save_item(NAME(m_mouse_x));
72 save_item(NAME(m_mouse_y));
73 save_item(NAME(m_mouse_b));
74 }
75
device_reset()76 void news_hid_hle_device::device_reset()
77 {
78 m_fifo[KEYBOARD].clear();
79 m_fifo[MOUSE].clear();
80
81 m_irq_enabled[KEYBOARD] = false;
82 m_irq_enabled[MOUSE] = false;
83 out_irq<KEYBOARD>(false);
84 out_irq<MOUSE>(false);
85
86 reset_key_state();
87 start_processing(attotime::from_hz(1'200));
88 }
89
key_make(u8 row,u8 column)90 void news_hid_hle_device::key_make(u8 row, u8 column)
91 {
92 LOG("key_make row %d col %d\n", row, column);
93
94 push_key((row << 4) | column);
95 }
96
key_break(u8 row,u8 column)97 void news_hid_hle_device::key_break(u8 row, u8 column)
98 {
99 LOG("key_break row %d col %d\n", row, column);
100
101 push_key(0x80 | (row << 4) | column);
102 }
103
push_key(u8 code)104 void news_hid_hle_device::push_key(u8 code)
105 {
106 m_fifo[KEYBOARD].enqueue(code);
107
108 out_irq<KEYBOARD>(true);
109 }
110
111 // HACK: abuse the keyboard row scanner to sample the mouse too
scan_complete()112 void news_hid_hle_device::scan_complete()
113 {
114 // read mouse state
115 s16 const x = m_mouse_x_axis->read();
116 s16 const y = m_mouse_y_axis->read();
117 u8 const b = m_mouse_buttons->read();
118
119 // compute delta
120 s8 const dx = x - m_mouse_x;
121 s8 const dy = y - m_mouse_y;
122 u8 const db = b ^ m_mouse_b;
123
124 // report if fifo has room and position or buttons changed
125 if ((m_fifo[MOUSE].queue_length() < 6) && (dx || dy || db))
126 {
127 LOG("mouse dx %d dy %d db %d\n", dx, dy, db);
128
129 // compute sign
130 u8 const sx = (dx < 0) ? 0x08 : 0x00;
131 u8 const sy = (dy < 0) ? 0x10 : 0x00;
132
133 // transmit data
134 m_fifo[MOUSE].enqueue(0x80 | sy | sx | b);
135 m_fifo[MOUSE].enqueue(dx & 0x7f);
136 m_fifo[MOUSE].enqueue(dy & 0x7f);
137
138 // update mouse state
139 m_mouse_x = x;
140 m_mouse_y = y;
141 m_mouse_b = b;
142
143 out_irq<MOUSE>(true);
144 }
145 }
146
out_irq(bool state)147 template <news_hid_hle_device::news_hid_device Device> void news_hid_hle_device::out_irq(bool state)
148 {
149 if (m_irq_out_state[Device] != state)
150 {
151 m_irq_out_state[Device] = state;
152 m_irq_out_cb[Device](state && m_irq_enabled[Device]);
153 }
154 }
155
data_r()156 template <news_hid_hle_device::news_hid_device Device> u8 news_hid_hle_device::data_r()
157 {
158 if (m_fifo[Device].empty())
159 return 0;
160
161 if (!machine().side_effects_disabled())
162 {
163 u8 const data = m_fifo[Device].dequeue();
164
165 if (m_fifo[Device].empty())
166 out_irq<Device>(false);
167
168 return data;
169 }
170 else
171 return m_fifo[Device].peek();
172 }
173
reset_w(u8 data)174 template <news_hid_hle_device::news_hid_device Device> void news_hid_hle_device::reset_w(u8 data)
175 {
176 LOG("reset_w<%d> 0x%02x\n", Device, data);
177 m_fifo[Device].clear();
178
179 out_irq<Device>(false);
180 }
181
init_w(u8 data)182 template <news_hid_hle_device::news_hid_device Device> void news_hid_hle_device::init_w(u8 data)
183 {
184 LOG("init_w<%d> 0x%02x\n", Device, data);
185
186 ien_w<Device>(data);
187 }
188
ien_w(u8 data)189 template <news_hid_hle_device::news_hid_device Device> void news_hid_hle_device::ien_w(u8 data)
190 {
191 LOG("ien_w<%d> 0x%02x\n", Device, data);
192
193 m_irq_enabled[Device] = bool(data);
194 }
195
status_68k_r()196 u8 news_hid_hle_device::status_68k_r()
197 {
198 u8 const data =
199 (!m_fifo[KEYBOARD].empty() ? 0x80 : 0) |
200 (!m_fifo[MOUSE].empty() ? 0x40 : 0) |
201 (m_fifo[KEYBOARD].full() ? 0x20 : 0) |
202 (m_fifo[MOUSE].full() ? 0x10 : 0) |
203 (m_irq_out_state[KEYBOARD] ? 0 : 0x08) |
204 (m_irq_out_state[MOUSE] ? 0 : 0x04) |
205 (m_irq_enabled[KEYBOARD] ? 0x02 : 0) |
206 (m_irq_enabled[MOUSE] ? 0x01 : 0);
207
208 LOG("status_r 0x%02x\n", data);
209
210 return data;
211 }
212
213 INPUT_PORTS_START(news_hid_hle_device)
214 PORT_START("ROW0")
215 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_UNUSED)
PORT_CODE(KEYCODE_F1)216 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F1") PORT_CODE(KEYCODE_F1) PORT_CHAR(UCHAR_MAMEKEY(F1))
217 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F2") PORT_CODE(KEYCODE_F2) PORT_CHAR(UCHAR_MAMEKEY(F2))
218 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F3") PORT_CODE(KEYCODE_F3) PORT_CHAR(UCHAR_MAMEKEY(F3))
219 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F4") PORT_CODE(KEYCODE_F4) PORT_CHAR(UCHAR_MAMEKEY(F4))
220 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F5") PORT_CODE(KEYCODE_F5) PORT_CHAR(UCHAR_MAMEKEY(F5))
221 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F6") PORT_CODE(KEYCODE_F6) PORT_CHAR(UCHAR_MAMEKEY(F6))
222 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F7") PORT_CODE(KEYCODE_F7) PORT_CHAR(UCHAR_MAMEKEY(F7))
223 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F8") PORT_CODE(KEYCODE_F8) PORT_CHAR(UCHAR_MAMEKEY(F8))
224 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F9") PORT_CODE(KEYCODE_F9) PORT_CHAR(UCHAR_MAMEKEY(F9))
225 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F10") PORT_CODE(KEYCODE_F10) PORT_CHAR(UCHAR_MAMEKEY(F10))
226 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Esc") PORT_CODE(KEYCODE_ESC) PORT_CHAR(UCHAR_MAMEKEY(ESC))
227 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHAR('!')
228 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHAR('@')
229 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CHAR('#')
230 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CHAR('$')
231
232 PORT_START("ROW1")
233 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CHAR('%')
234 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CHAR('^')
235 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CHAR('&')
236 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CHAR('*')
237 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CHAR('(')
238 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CHAR(')')
239 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CHAR('_')
240 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_EQUALS) PORT_CHAR('=') PORT_CHAR('+')
241 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_BACKSLASH) PORT_CHAR('\\') PORT_CHAR('|')
242 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Backspace") PORT_CODE(KEYCODE_BACKSPACE) PORT_CHAR(8)
243 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Tab") PORT_CODE(KEYCODE_TAB) PORT_CHAR(9)
244 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Q) PORT_CHAR('q') PORT_CHAR('Q')
245 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_W) PORT_CHAR('w') PORT_CHAR('W')
246 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_E) PORT_CHAR('e') PORT_CHAR('E')
247 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_R) PORT_CHAR('r') PORT_CHAR('R')
248 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_T) PORT_CHAR('t') PORT_CHAR('T')
249
250 PORT_START("ROW2")
251 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y) PORT_CHAR('y') PORT_CHAR('Y')
252 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_U) PORT_CHAR('u') PORT_CHAR('U')
253 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_I) PORT_CHAR('i') PORT_CHAR('I')
254 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_O) PORT_CHAR('o') PORT_CHAR('O')
255 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_P) PORT_CHAR('p') PORT_CHAR('P')
256 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_OPENBRACE) PORT_CHAR('[') PORT_CHAR('{')
257 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_CLOSEBRACE) PORT_CHAR(']') PORT_CHAR('}')
258 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Delete") PORT_CODE(KEYCODE_DEL) PORT_CHAR(UCHAR_MAMEKEY(DEL))
259 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Control") PORT_CODE(KEYCODE_LCONTROL) PORT_CHAR(UCHAR_MAMEKEY(LCONTROL))
260 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_A) PORT_CHAR('a') PORT_CHAR('A')
261 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_S) PORT_CHAR('s') PORT_CHAR('S')
262 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_D) PORT_CHAR('d') PORT_CHAR('D')
263 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F) PORT_CHAR('f') PORT_CHAR('F')
264 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_G) PORT_CHAR('g') PORT_CHAR('G')
265 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_H) PORT_CHAR('h') PORT_CHAR('H')
266 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_J) PORT_CHAR('j') PORT_CHAR('J')
267
268 PORT_START("ROW3")
269 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_K) PORT_CHAR('k') PORT_CHAR('K')
270 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_L) PORT_CHAR('l') PORT_CHAR('L')
271 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_COLON) PORT_CHAR(';') PORT_CHAR(':')
272 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_QUOTE) PORT_CHAR('\'') PORT_CHAR('"')
273 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_TILDE) PORT_CHAR('`') PORT_CHAR('~')
274 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Return") PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13)
275 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("L Shift") PORT_CODE(KEYCODE_LSHIFT) PORT_CHAR(UCHAR_SHIFT_1)
276 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z')
277 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X')
278 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_C) PORT_CHAR('c') PORT_CHAR('C')
279 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_V) PORT_CHAR('v') PORT_CHAR('V')
280 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_B) PORT_CHAR('b') PORT_CHAR('B')
281 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N')
282 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_M) PORT_CHAR('m') PORT_CHAR('M')
283 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_COMMA) PORT_CHAR(',') PORT_CHAR('<')
284 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_CHAR('>')
285
286 PORT_START("ROW4")
287 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') PORT_CHAR('?')
288 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_UNUSED)
289 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("R Shift") PORT_CODE(KEYCODE_RSHIFT) PORT_CHAR(UCHAR_MAMEKEY(RSHIFT))
290 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Alternate") PORT_CODE(KEYCODE_LALT)
291 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Caps Lock") PORT_CODE(KEYCODE_CAPSLOCK) PORT_CHAR(UCHAR_MAMEKEY(CAPSLOCK))
292 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Nfer") // muhenkan?
293 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Space") PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ')
294 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Xfer") // henkan?
295 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) // eisu?
296 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) // kana?
297 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) // Execute?
298 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 7") PORT_CODE(KEYCODE_7_PAD) PORT_CHAR(UCHAR_MAMEKEY(7_PAD))
299 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 8") PORT_CODE(KEYCODE_8_PAD) PORT_CHAR(UCHAR_MAMEKEY(8_PAD))
300 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 9") PORT_CODE(KEYCODE_9_PAD) PORT_CHAR(UCHAR_MAMEKEY(9_PAD))
301 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP -") PORT_CODE(KEYCODE_MINUS_PAD) PORT_CHAR(UCHAR_MAMEKEY(MINUS_PAD))
302 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 4") PORT_CODE(KEYCODE_4_PAD) PORT_CHAR(UCHAR_MAMEKEY(4_PAD))
303
304 PORT_START("ROW5")
305 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 5") PORT_CODE(KEYCODE_5_PAD) PORT_CHAR(UCHAR_MAMEKEY(5_PAD))
306 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 6") PORT_CODE(KEYCODE_6_PAD) PORT_CHAR(UCHAR_MAMEKEY(6_PAD))
307 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP +") PORT_CODE(KEYCODE_PLUS_PAD) PORT_CHAR(UCHAR_MAMEKEY(PLUS_PAD))
308 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 1") PORT_CODE(KEYCODE_1_PAD) PORT_CHAR(UCHAR_MAMEKEY(1_PAD))
309 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 2") PORT_CODE(KEYCODE_2_PAD) PORT_CHAR(UCHAR_MAMEKEY(2_PAD))
310 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 3") PORT_CODE(KEYCODE_3_PAD) PORT_CHAR(UCHAR_MAMEKEY(3_PAD))
311 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) // Separator?
312 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP 0") PORT_CODE(KEYCODE_0_PAD) PORT_CHAR(UCHAR_MAMEKEY(0_PAD))
313 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Up") PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP))
314 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP .") PORT_CODE(KEYCODE_DEL_PAD) PORT_CHAR(UCHAR_MAMEKEY(DEL_PAD))
315 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Enter") PORT_CODE(KEYCODE_ENTER_PAD)
316 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Left") PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT))
317 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Down") PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN))
318 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Right") PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT))
319 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP *") PORT_CODE(KEYCODE_ASTERISK) PORT_CHAR(UCHAR_MAMEKEY(ASTERISK))
320 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP /") PORT_CODE(KEYCODE_SLASH_PAD)
321
322 PORT_START("ROW6")
323 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("KP Tab")
324 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F11") PORT_CODE(KEYCODE_F11) PORT_CHAR(UCHAR_MAMEKEY(F11))
325 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F12") PORT_CODE(KEYCODE_F12) PORT_CHAR(UCHAR_MAMEKEY(F12))
326 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Help")
327 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Insert") PORT_CODE(KEYCODE_INSERT) PORT_CHAR(UCHAR_MAMEKEY(INSERT))
328 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Clear")
329 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Prior") PORT_CODE(KEYCODE_PGUP) PORT_CHAR(UCHAR_MAMEKEY(PGUP))
330 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Next") PORT_CODE(KEYCODE_PGDN) PORT_CHAR(UCHAR_MAMEKEY(PGDN))
331 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_UNUSED)
332 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_UNUSED)
333 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_UNUSED)
334 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_UNUSED)
335 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_UNUSED)
336 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_UNUSED)
337 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_UNUSED)
338 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_UNUSED)
339
340 PORT_START("ROW7")
341 PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_UNUSED)
342 PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_UNUSED)
343 PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_UNUSED)
344 PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_UNUSED)
345 PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_UNUSED)
346 PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_UNUSED)
347 PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_UNUSED)
348 PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_UNUSED)
349 PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_UNUSED)
350 PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_UNUSED)
351 PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_UNUSED)
352 PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_UNUSED)
353 PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_UNUSED)
354 PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_UNUSED)
355 PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_UNUSED)
356 PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_UNUSED)
357
358 PORT_START("mouse_x_axis")
359 PORT_BIT(0xffff, 0, IPT_MOUSE_X) PORT_SENSITIVITY(100)
360
361 PORT_START("mouse_y_axis")
362 PORT_BIT(0xffff, 0, IPT_MOUSE_Y) PORT_SENSITIVITY(100)
363
364 PORT_START("mouse_buttons")
365 PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_BUTTON1) PORT_CODE(MOUSECODE_BUTTON1) PORT_NAME("Left Button")
366 PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_BUTTON2) PORT_CODE(MOUSECODE_BUTTON2) PORT_NAME("Right Button")
367 PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_BUTTON3) PORT_CODE(MOUSECODE_BUTTON3) PORT_NAME("Middle Button")
368 PORT_BIT(0xf8, IP_ACTIVE_HIGH, IPT_UNUSED)
369 INPUT_PORTS_END
370
371 ioport_constructor news_hid_hle_device::device_input_ports() const
372 {
373 return INPUT_PORTS_NAME(news_hid_hle_device);
374 }
375