Fail* directories reorganized, Code-cleanup (-> coding-style), Typos+comments fixed.
git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@1321 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
This commit is contained in:
234
simulators/bochs/iodev/keyboard.h
Normal file
234
simulators/bochs/iodev/keyboard.h
Normal file
@ -0,0 +1,234 @@
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
// $Id$
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Copyright (C) 2002-2009 The Bochs Project
|
||||
//
|
||||
// This library is free software; you can redistribute it and/or
|
||||
// modify it under the terms of the GNU Lesser General Public
|
||||
// License as published by the Free Software Foundation; either
|
||||
// version 2 of the License, or (at your option) any later version.
|
||||
//
|
||||
// This library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
// Lesser General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Lesser General Public
|
||||
// License along with this library; if not, write to the Free Software
|
||||
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
|
||||
#ifndef _PCKEY_H
|
||||
#define _PCKEY_H
|
||||
|
||||
#define BX_KBD_ELEMENTS 16
|
||||
|
||||
// these keywords should only be used in keyboard.cc
|
||||
#if BX_USE_KEY_SMF
|
||||
# define BX_KEY_SMF static
|
||||
# define BX_KEY_THIS theKeyboard->
|
||||
#else
|
||||
# define BX_KEY_SMF
|
||||
# define BX_KEY_THIS this->
|
||||
#endif
|
||||
|
||||
#define MOUSE_MODE_RESET 10
|
||||
#define MOUSE_MODE_STREAM 11
|
||||
#define MOUSE_MODE_REMOTE 12
|
||||
#define MOUSE_MODE_WRAP 13
|
||||
|
||||
class bx_keyb_c : public bx_keyb_stub_c {
|
||||
public:
|
||||
bx_keyb_c();
|
||||
virtual ~bx_keyb_c();
|
||||
// implement bx_devmodel_c interface
|
||||
virtual void init(void);
|
||||
virtual void reset(unsigned type);
|
||||
// override stubs from bx_keyb_stub_c
|
||||
virtual void gen_scancode(Bit32u key);
|
||||
virtual void paste_bytes(Bit8u *data, Bit32s length);
|
||||
virtual void register_state(void);
|
||||
virtual void after_restore_state(void);
|
||||
|
||||
// runtime options
|
||||
static Bit64s kbd_param_handler(bx_param_c *param, int set, Bit64s val);
|
||||
BX_KEY_SMF void paste_delay_changed(Bit32u value);
|
||||
|
||||
private:
|
||||
BX_KEY_SMF Bit8u get_kbd_enable(void);
|
||||
BX_KEY_SMF void service_paste_buf ();
|
||||
BX_KEY_SMF void create_mouse_packet(bx_bool force_enq);
|
||||
BX_KEY_SMF unsigned periodic(Bit32u usec_delta);
|
||||
|
||||
|
||||
static Bit32u read_handler(void *this_ptr, Bit32u address, unsigned io_len);
|
||||
static void write_handler(void *this_ptr, Bit32u address, Bit32u value, unsigned io_len);
|
||||
#if !BX_USE_KEY_SMF
|
||||
void write(Bit32u address, Bit32u value, unsigned io_len);
|
||||
Bit32u read(Bit32u address, unsigned io_len);
|
||||
#endif
|
||||
|
||||
struct {
|
||||
struct {
|
||||
/* status bits matching the status port*/
|
||||
bx_bool pare; // Bit7, 1= parity error from keyboard/mouse - ignored.
|
||||
bx_bool tim; // Bit6, 1= timeout from keyboard - ignored.
|
||||
bx_bool auxb; // Bit5, 1= mouse data waiting for CPU to read.
|
||||
bx_bool keyl; // Bit4, 1= keyswitch in lock position - ignored.
|
||||
bx_bool c_d; /* Bit3, 1=command to port 64h, 0=data to port 60h */
|
||||
bx_bool sysf; // Bit2,
|
||||
bx_bool inpb; // Bit1,
|
||||
bx_bool outb; // Bit0, 1= keyboard data or mouse data ready for CPU
|
||||
// check aux to see which. Or just keyboard
|
||||
// data before AT style machines
|
||||
|
||||
/* internal to our version of the keyboard controller */
|
||||
bx_bool kbd_clock_enabled;
|
||||
bx_bool aux_clock_enabled;
|
||||
bx_bool allow_irq1;
|
||||
bx_bool allow_irq12;
|
||||
Bit8u kbd_output_buffer;
|
||||
Bit8u aux_output_buffer;
|
||||
Bit8u last_comm;
|
||||
Bit8u expecting_port60h;
|
||||
Bit8u expecting_mouse_parameter;
|
||||
Bit8u last_mouse_command;
|
||||
Bit32u timer_pending;
|
||||
bx_bool irq1_requested;
|
||||
bx_bool irq12_requested;
|
||||
bx_bool scancodes_translate;
|
||||
bx_bool expecting_scancodes_set;
|
||||
Bit8u current_scancodes_set;
|
||||
bx_bool bat_in_progress;
|
||||
} kbd_controller;
|
||||
|
||||
struct mouseStruct {
|
||||
Bit8u type;
|
||||
Bit8u sample_rate;
|
||||
Bit8u resolution_cpmm; // resolution in counts per mm
|
||||
Bit8u scaling;
|
||||
Bit8u mode;
|
||||
Bit8u saved_mode; // the mode prior to entering wrap mode
|
||||
bx_bool enable;
|
||||
|
||||
Bit8u get_status_byte ()
|
||||
{
|
||||
// top bit is 0 , bit 6 is 1 if remote mode.
|
||||
Bit8u ret = (Bit8u) ((mode == MOUSE_MODE_REMOTE) ? 0x40 : 0);
|
||||
ret |= (enable << 5);
|
||||
ret |= (scaling == 1) ? 0 : (1 << 4);
|
||||
ret |= ((button_status & 0x1) << 2);
|
||||
ret |= ((button_status & 0x2) << 0);
|
||||
return ret;
|
||||
}
|
||||
|
||||
Bit8u get_resolution_byte ()
|
||||
{
|
||||
Bit8u ret = 0;
|
||||
|
||||
switch (resolution_cpmm) {
|
||||
case 1:
|
||||
ret = 0;
|
||||
break;
|
||||
|
||||
case 2:
|
||||
ret = 1;
|
||||
break;
|
||||
|
||||
case 4:
|
||||
ret = 2;
|
||||
break;
|
||||
|
||||
case 8:
|
||||
ret = 3;
|
||||
break;
|
||||
|
||||
default:
|
||||
genlog->panic("mouse: invalid resolution_cpmm");
|
||||
};
|
||||
return ret;
|
||||
}
|
||||
|
||||
Bit8u button_status;
|
||||
Bit16s delayed_dx;
|
||||
Bit16s delayed_dy;
|
||||
Bit16s delayed_dz;
|
||||
Bit8u im_request;
|
||||
bx_bool im_mode;
|
||||
} mouse;
|
||||
|
||||
struct {
|
||||
int num_elements;
|
||||
Bit8u buffer[BX_KBD_ELEMENTS];
|
||||
int head;
|
||||
bx_bool expecting_typematic;
|
||||
bx_bool expecting_led_write;
|
||||
Bit8u delay;
|
||||
Bit8u repeat_rate;
|
||||
Bit8u led_status;
|
||||
bx_bool scanning_enabled;
|
||||
} kbd_internal_buffer;
|
||||
|
||||
struct {
|
||||
int num_elements;
|
||||
Bit8u buffer[BX_MOUSE_BUFF_SIZE];
|
||||
int head;
|
||||
} mouse_internal_buffer;
|
||||
#define BX_KBD_CONTROLLER_QSIZE 5
|
||||
Bit8u controller_Q[BX_KBD_CONTROLLER_QSIZE];
|
||||
unsigned controller_Qsize;
|
||||
unsigned controller_Qsource; // 0=keyboard, 1=mouse
|
||||
} s; // State information for saving/loading
|
||||
|
||||
// The paste buffer does NOT exist in the hardware. It is a bochs
|
||||
// construction that allows the user to "paste" arbitrary length sequences of
|
||||
// keystrokes into the emulated machine. Since the hardware buffer is only
|
||||
// 16 bytes, a very small amount of data can be added to the hardware buffer
|
||||
// at a time. The paste buffer keeps track of the bytes that have not yet
|
||||
// been pasted.
|
||||
//
|
||||
// Lifetime of a paste buffer: The paste data comes from the system
|
||||
// clipboard, which must be accessed using platform independent code in the
|
||||
// gui. Because every gui has its own way of managing the clipboard memory
|
||||
// (in X windows, you're supposed to call Xfree for example), in the platform
|
||||
// specific code we make a copy of the clipboard buffer with
|
||||
// "new Bit8u[length]". Then the pointer is passed into
|
||||
// bx_keyb_c::paste_bytes, along with the length. The gui code never touches
|
||||
// the pastebuf again, and does not free it. The keyboard code is
|
||||
// responsible for deallocating the paste buffer using delete [] buf. The
|
||||
// paste buffer is binary data, and it is probably NOT null terminated.
|
||||
//
|
||||
// Summary: A paste buffer is allocated (new) in the platform-specific gui
|
||||
// code, passed to the keyboard model, and is freed (delete[]) when it is no
|
||||
// longer needed.
|
||||
Bit8u *pastebuf; // ptr to bytes to be pasted, or NULL if none in progress
|
||||
Bit32u pastebuf_len; // length of pastebuf
|
||||
Bit32u pastebuf_ptr; // ptr to next byte to be added to hw buffer
|
||||
Bit32u pastedelay; // count before paste
|
||||
bx_bool paste_service; // set to 1 when gen_scancode() is called from paste service
|
||||
bx_bool stop_paste; // stop the current paste operation on keypress or hardware reset
|
||||
|
||||
BX_KEY_SMF void resetinternals(bx_bool powerup);
|
||||
BX_KEY_SMF void set_kbd_clock_enable(Bit8u value) BX_CPP_AttrRegparmN(1);
|
||||
BX_KEY_SMF void set_aux_clock_enable(Bit8u value);
|
||||
BX_KEY_SMF void kbd_ctrl_to_kbd(Bit8u value);
|
||||
BX_KEY_SMF void kbd_ctrl_to_mouse(Bit8u value);
|
||||
BX_KEY_SMF void kbd_enQ(Bit8u scancode);
|
||||
BX_KEY_SMF void kbd_enQ_imm(Bit8u val);
|
||||
BX_KEY_SMF void activate_timer(void);
|
||||
BX_KEY_SMF void controller_enQ(Bit8u data, unsigned source);
|
||||
BX_KEY_SMF bx_bool mouse_enQ_packet(Bit8u b1, Bit8u b2, Bit8u b3, Bit8u b4);
|
||||
BX_KEY_SMF void mouse_enQ(Bit8u mouse_data);
|
||||
|
||||
static void mouse_enabled_changed_static(void *dev, bx_bool enabled);
|
||||
void mouse_enabled_changed(bx_bool enabled);
|
||||
static void mouse_enq_static(void *dev, int delta_x, int delta_y, int delta_z, unsigned button_state);
|
||||
void mouse_motion(int delta_x, int delta_y, int delta_z, unsigned button_state);
|
||||
|
||||
static void timer_handler(void *);
|
||||
void timer(void);
|
||||
int timer_handle;
|
||||
int statusbar_id[3];
|
||||
};
|
||||
|
||||
#endif // #ifndef _PCKEY_H
|
||||
Reference in New Issue
Block a user