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