OSDN Git Service

5767fb271c8c84f8e82f08331e637458296fece8
[csp-qt/common_source_project-fm7.git] / source / src / vm / mz2800 / keyboard.cpp
1 /*
2         SHARP MZ-2800 Emulator 'EmuZ-2800'
3
4         Author : Takeda.Toshiya
5         Date   : 2007.08.13 -
6
7         [ keyboard ]
8 */
9
10 #include "keyboard.h"
11 #include "../i8255.h"
12 #include "../z80pio.h"
13
14 static const int key_map[14][8] = {
15         {0x70, 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77},
16         {0x78, 0x79, 0x68, 0x69, 0x6c, 0x6e, 0x6b, 0x6d},
17         {0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67},
18         {0x09, 0x20, 0x0d, 0x26, 0x28, 0x25, 0x27, 0x13},
19         {0xbf, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47},
20         {0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f},
21         {0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57},
22         {0x58, 0x59, 0x5a, 0xde, 0xdc, 0xe2, 0xbe, 0xbc},
23         {0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37},
24         {0x38, 0x39, 0xba, 0xbb, 0xbd, 0xc0, 0xdb, 0x00},
25         {0xdd, 0x7b, 0x24, 0x2e, 0x08, 0x1b, 0x6a, 0x6f},
26         {0xa4, 0x14, 0x10, 0x15, 0xa2, 0x00, 0x00, 0x00},
27         {0x1d, 0x1c, 0x00, 0xa3, 0xa5, 0x00, 0x00, 0x00},
28         {0x19, 0x7a, 0x00, 0x7c, 0x7d, 0x7e, 0x7d, 0x00}
29 };
30
31 void KEYBOARD::initialize()
32 {
33         key_stat = emu->get_key_buffer();
34         column = 0;
35         register_frame_event(this);
36 }
37
38 void KEYBOARD::write_signal(int id, uint32_t data, uint32_t mask)
39 {
40         if(id == SIG_KEYBOARD_COLUMN) {
41                 column = data & mask;   // from z80pio port a
42                 create_keystat();
43         }
44 }
45
46 void KEYBOARD::event_frame()
47 {
48         // update key status
49         uint8_t buf[256];
50         memcpy(buf, key_stat, sizeof(buf));
51         
52         if(!buf[0x10] && buf[0x21]) {
53                 buf[0x7c] = 0x80;       // PAGE UP -> F13
54         }
55         if(!buf[0x10] && buf[0x22]) {
56                 buf[0x7d] = 0x80;       // PAGE UP -> F14
57         }
58         if(buf[0x10] && buf[0x21]) {
59                 buf[0x7e] = 0x80;       // SHIFT + PAGE UP -> F15
60         }
61         if(buf[0x10] && buf[0x22]) {
62                 buf[0x7f] = 0x80;       // SHIFT + PAGE DOWN -> F16
63         }
64         if(buf[0x2d]) {
65                 buf[0x10] = buf[0x2e] = 0x80;   // INS -> SHIFT + DEL
66         }
67         buf[0] = 0;
68         
69         keys[0xf] = 0xff;
70         for(int i = 0; i <= 0xd; i++) {
71                 uint8_t tmp = 0;
72                 for(int j = 0; j < 8; j++) {
73                         tmp |= (buf[key_map[i][j]]) ? 0 : (1 << j);
74                 }
75                 keys[i] = tmp;
76                 keys[0xf] &= tmp;
77         }
78         create_keystat();
79 }
80
81 void KEYBOARD::create_keystat()
82 {
83         uint8_t val = (!(column & 0x10)) ? keys[0xf] : ((column & 0xf) > 0xd) ? 0xff : keys[column & 0xf];
84         d_pio0->write_signal(SIG_I8255_PORT_B, val, 0x80);      // to i8255 port b
85         d_pio1->write_signal(SIG_Z80PIO_PORT_B, val, 0xff);     // to z80pio port b
86 }
87
88 #define STATE_VERSION   1
89
90 bool KEYBOARD::process_state(FILEIO* state_fio, bool loading)
91 {
92         if(!state_fio->StateCheckUint32(STATE_VERSION)) {
93                 return false;
94         }
95         if(!state_fio->StateCheckInt32(this_device_id)) {
96                 return false;
97         }
98         state_fio->StateUint8(column);
99         return true;
100 }