11da177e4SLinus Torvalds 21da177e4SLinus Torvalds /* 31da177e4SLinus Torvalds * IBM ASM Service Processor Device Driver 41da177e4SLinus Torvalds * 51da177e4SLinus Torvalds * This program is free software; you can redistribute it and/or modify 61da177e4SLinus Torvalds * it under the terms of the GNU General Public License as published by 71da177e4SLinus Torvalds * the Free Software Foundation; either version 2 of the License, or 81da177e4SLinus Torvalds * (at your option) any later version. 91da177e4SLinus Torvalds * 101da177e4SLinus Torvalds * This program is distributed in the hope that it will be useful, 111da177e4SLinus Torvalds * but WITHOUT ANY WARRANTY; without even the implied warranty of 121da177e4SLinus Torvalds * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 131da177e4SLinus Torvalds * GNU General Public License for more details. 141da177e4SLinus Torvalds * 151da177e4SLinus Torvalds * You should have received a copy of the GNU General Public License 161da177e4SLinus Torvalds * along with this program; if not, write to the Free Software 171da177e4SLinus Torvalds * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 181da177e4SLinus Torvalds * 191da177e4SLinus Torvalds * Copyright (C) IBM Corporation, 2004 201da177e4SLinus Torvalds * 211da177e4SLinus Torvalds * Author: Max Asb�ck <amax@us.ibm.com> 221da177e4SLinus Torvalds * 23*25985edcSLucas De Marchi * Originally written by Pete Reynolds 241da177e4SLinus Torvalds */ 251da177e4SLinus Torvalds 261da177e4SLinus Torvalds #ifndef _IBMASM_REMOTE_H_ 271da177e4SLinus Torvalds #define _IBMASM_REMOTE_H_ 281da177e4SLinus Torvalds 291da177e4SLinus Torvalds #include <asm/io.h> 301da177e4SLinus Torvalds 311da177e4SLinus Torvalds /* pci offsets */ 321da177e4SLinus Torvalds #define CONDOR_MOUSE_DATA 0x000AC000 331da177e4SLinus Torvalds #define CONDOR_MOUSE_ISR_CONTROL 0x00 341da177e4SLinus Torvalds #define CONDOR_MOUSE_ISR_STATUS 0x04 351da177e4SLinus Torvalds #define CONDOR_MOUSE_Q_READER 0x08 361da177e4SLinus Torvalds #define CONDOR_MOUSE_Q_WRITER 0x0C 371da177e4SLinus Torvalds #define CONDOR_MOUSE_Q_BEGIN 0x10 381da177e4SLinus Torvalds #define CONDOR_MOUSE_MAX_X 0x14 391da177e4SLinus Torvalds #define CONDOR_MOUSE_MAX_Y 0x18 401da177e4SLinus Torvalds 411da177e4SLinus Torvalds #define CONDOR_INPUT_DESKTOP_INFO 0x1F0 421da177e4SLinus Torvalds #define CONDOR_INPUT_DISPLAY_RESX 0x1F4 431da177e4SLinus Torvalds #define CONDOR_INPUT_DISPLAY_RESY 0x1F8 441da177e4SLinus Torvalds #define CONDOR_INPUT_DISPLAY_BITS 0x1FC 451da177e4SLinus Torvalds #define CONDOR_OUTPUT_VNC_STATUS 0x200 461da177e4SLinus Torvalds 471da177e4SLinus Torvalds #define CONDOR_MOUSE_INTR_STATUS_MASK 0x00000001 481da177e4SLinus Torvalds 491da177e4SLinus Torvalds #define INPUT_TYPE_MOUSE 0x1 501da177e4SLinus Torvalds #define INPUT_TYPE_KEYBOARD 0x2 511da177e4SLinus Torvalds 521da177e4SLinus Torvalds 531da177e4SLinus Torvalds /* mouse button states received from SP */ 54278d72aeSMax Asbock #define REMOTE_DOUBLE_CLICK 0xF0 55278d72aeSMax Asbock #define REMOTE_BUTTON_LEFT 0x01 56278d72aeSMax Asbock #define REMOTE_BUTTON_MIDDLE 0x02 57278d72aeSMax Asbock #define REMOTE_BUTTON_RIGHT 0x04 581da177e4SLinus Torvalds 59278d72aeSMax Asbock /* size of keysym/keycode translation matricies */ 60278d72aeSMax Asbock #define XLATE_SIZE 256 611da177e4SLinus Torvalds 621da177e4SLinus Torvalds struct mouse_input { 631da177e4SLinus Torvalds unsigned short y; 641da177e4SLinus Torvalds unsigned short x; 651da177e4SLinus Torvalds }; 661da177e4SLinus Torvalds 671da177e4SLinus Torvalds 681da177e4SLinus Torvalds struct keyboard_input { 691da177e4SLinus Torvalds unsigned short key_code; 701da177e4SLinus Torvalds unsigned char key_flag; 711da177e4SLinus Torvalds unsigned char key_down; 721da177e4SLinus Torvalds }; 731da177e4SLinus Torvalds 741da177e4SLinus Torvalds 751da177e4SLinus Torvalds 761da177e4SLinus Torvalds struct remote_input { 771da177e4SLinus Torvalds union { 781da177e4SLinus Torvalds struct mouse_input mouse; 791da177e4SLinus Torvalds struct keyboard_input keyboard; 801da177e4SLinus Torvalds } data; 811da177e4SLinus Torvalds 821da177e4SLinus Torvalds unsigned char type; 831da177e4SLinus Torvalds unsigned char pad1; 841da177e4SLinus Torvalds unsigned char mouse_buttons; 851da177e4SLinus Torvalds unsigned char pad3; 861da177e4SLinus Torvalds }; 871da177e4SLinus Torvalds 88278d72aeSMax Asbock #define mouse_addr(sp) (sp->base_address + CONDOR_MOUSE_DATA) 89278d72aeSMax Asbock #define display_width(sp) (mouse_addr(sp) + CONDOR_INPUT_DISPLAY_RESX) 90278d72aeSMax Asbock #define display_height(sp) (mouse_addr(sp) + CONDOR_INPUT_DISPLAY_RESY) 91278d72aeSMax Asbock #define display_depth(sp) (mouse_addr(sp) + CONDOR_INPUT_DISPLAY_BITS) 92278d72aeSMax Asbock #define desktop_info(sp) (mouse_addr(sp) + CONDOR_INPUT_DESKTOP_INFO) 93278d72aeSMax Asbock #define vnc_status(sp) (mouse_addr(sp) + CONDOR_OUTPUT_VNC_STATUS) 94278d72aeSMax Asbock #define isr_control(sp) (mouse_addr(sp) + CONDOR_MOUSE_ISR_CONTROL) 951da177e4SLinus Torvalds 961da177e4SLinus Torvalds #define mouse_interrupt_pending(sp) readl(mouse_addr(sp) + CONDOR_MOUSE_ISR_STATUS) 971da177e4SLinus Torvalds #define clear_mouse_interrupt(sp) writel(0, mouse_addr(sp) + CONDOR_MOUSE_ISR_STATUS) 981da177e4SLinus Torvalds #define enable_mouse_interrupts(sp) writel(1, mouse_addr(sp) + CONDOR_MOUSE_ISR_CONTROL) 991da177e4SLinus Torvalds #define disable_mouse_interrupts(sp) writel(0, mouse_addr(sp) + CONDOR_MOUSE_ISR_CONTROL) 1001da177e4SLinus Torvalds 1011da177e4SLinus Torvalds /* remote input queue operations */ 1021da177e4SLinus Torvalds #define REMOTE_QUEUE_SIZE 60 1031da177e4SLinus Torvalds 1041da177e4SLinus Torvalds #define get_queue_writer(sp) readl(mouse_addr(sp) + CONDOR_MOUSE_Q_WRITER) 1051da177e4SLinus Torvalds #define get_queue_reader(sp) readl(mouse_addr(sp) + CONDOR_MOUSE_Q_READER) 1061da177e4SLinus Torvalds #define set_queue_reader(sp, reader) writel(reader, mouse_addr(sp) + CONDOR_MOUSE_Q_READER) 1071da177e4SLinus Torvalds 108278d72aeSMax Asbock #define queue_begin (mouse_addr(sp) + CONDOR_MOUSE_Q_BEGIN) 1091da177e4SLinus Torvalds 1101da177e4SLinus Torvalds #define get_queue_entry(sp, read_index) \ 111278d72aeSMax Asbock ((void*)(queue_begin + read_index * sizeof(struct remote_input))) 1121da177e4SLinus Torvalds 1131da177e4SLinus Torvalds static inline int advance_queue_reader(struct service_processor *sp, unsigned long reader) 1141da177e4SLinus Torvalds { 1151da177e4SLinus Torvalds reader++; 1161da177e4SLinus Torvalds if (reader == REMOTE_QUEUE_SIZE) 1171da177e4SLinus Torvalds reader = 0; 1181da177e4SLinus Torvalds 1191da177e4SLinus Torvalds set_queue_reader(sp, reader); 1201da177e4SLinus Torvalds return reader; 1211da177e4SLinus Torvalds } 1221da177e4SLinus Torvalds 123278d72aeSMax Asbock #define NO_KEYCODE 0 124278d72aeSMax Asbock #define KEY_SYM_BK_SPC 0xFF08 125278d72aeSMax Asbock #define KEY_SYM_TAB 0xFF09 126278d72aeSMax Asbock #define KEY_SYM_ENTER 0xFF0D 127278d72aeSMax Asbock #define KEY_SYM_SCR_LOCK 0xFF14 128278d72aeSMax Asbock #define KEY_SYM_ESCAPE 0xFF1B 129278d72aeSMax Asbock #define KEY_SYM_HOME 0xFF50 130278d72aeSMax Asbock #define KEY_SYM_LARROW 0xFF51 131278d72aeSMax Asbock #define KEY_SYM_UARROW 0xFF52 132278d72aeSMax Asbock #define KEY_SYM_RARROW 0xFF53 133278d72aeSMax Asbock #define KEY_SYM_DARROW 0xFF54 134278d72aeSMax Asbock #define KEY_SYM_PAGEUP 0xFF55 135278d72aeSMax Asbock #define KEY_SYM_PAGEDOWN 0xFF56 136278d72aeSMax Asbock #define KEY_SYM_END 0xFF57 137278d72aeSMax Asbock #define KEY_SYM_INSERT 0xFF63 138278d72aeSMax Asbock #define KEY_SYM_NUM_LOCK 0xFF7F 139278d72aeSMax Asbock #define KEY_SYM_KPSTAR 0xFFAA 140278d72aeSMax Asbock #define KEY_SYM_KPPLUS 0xFFAB 141278d72aeSMax Asbock #define KEY_SYM_KPMINUS 0xFFAD 142278d72aeSMax Asbock #define KEY_SYM_KPDOT 0xFFAE 143278d72aeSMax Asbock #define KEY_SYM_KPSLASH 0xFFAF 144278d72aeSMax Asbock #define KEY_SYM_KPRIGHT 0xFF96 145278d72aeSMax Asbock #define KEY_SYM_KPUP 0xFF97 146278d72aeSMax Asbock #define KEY_SYM_KPLEFT 0xFF98 147278d72aeSMax Asbock #define KEY_SYM_KPDOWN 0xFF99 148278d72aeSMax Asbock #define KEY_SYM_KP0 0xFFB0 149278d72aeSMax Asbock #define KEY_SYM_KP1 0xFFB1 150278d72aeSMax Asbock #define KEY_SYM_KP2 0xFFB2 151278d72aeSMax Asbock #define KEY_SYM_KP3 0xFFB3 152278d72aeSMax Asbock #define KEY_SYM_KP4 0xFFB4 153278d72aeSMax Asbock #define KEY_SYM_KP5 0xFFB5 154278d72aeSMax Asbock #define KEY_SYM_KP6 0xFFB6 155278d72aeSMax Asbock #define KEY_SYM_KP7 0xFFB7 156278d72aeSMax Asbock #define KEY_SYM_KP8 0xFFB8 157278d72aeSMax Asbock #define KEY_SYM_KP9 0xFFB9 158278d72aeSMax Asbock #define KEY_SYM_F1 0xFFBE // 1B 5B 5B 41 159278d72aeSMax Asbock #define KEY_SYM_F2 0xFFBF // 1B 5B 5B 42 160278d72aeSMax Asbock #define KEY_SYM_F3 0xFFC0 // 1B 5B 5B 43 161278d72aeSMax Asbock #define KEY_SYM_F4 0xFFC1 // 1B 5B 5B 44 162278d72aeSMax Asbock #define KEY_SYM_F5 0xFFC2 // 1B 5B 5B 45 163278d72aeSMax Asbock #define KEY_SYM_F6 0xFFC3 // 1B 5B 31 37 7E 164278d72aeSMax Asbock #define KEY_SYM_F7 0xFFC4 // 1B 5B 31 38 7E 165278d72aeSMax Asbock #define KEY_SYM_F8 0xFFC5 // 1B 5B 31 39 7E 166278d72aeSMax Asbock #define KEY_SYM_F9 0xFFC6 // 1B 5B 32 30 7E 167278d72aeSMax Asbock #define KEY_SYM_F10 0xFFC7 // 1B 5B 32 31 7E 168278d72aeSMax Asbock #define KEY_SYM_F11 0xFFC8 // 1B 5B 32 33 7E 169278d72aeSMax Asbock #define KEY_SYM_F12 0xFFC9 // 1B 5B 32 34 7E 170278d72aeSMax Asbock #define KEY_SYM_SHIFT 0xFFE1 171278d72aeSMax Asbock #define KEY_SYM_CTRL 0xFFE3 172278d72aeSMax Asbock #define KEY_SYM_ALT 0xFFE9 173278d72aeSMax Asbock #define KEY_SYM_CAP_LOCK 0xFFE5 174278d72aeSMax Asbock #define KEY_SYM_DELETE 0xFFFF 175278d72aeSMax Asbock #define KEY_SYM_TILDE 0x60 176278d72aeSMax Asbock #define KEY_SYM_BKTIC 0x7E 177278d72aeSMax Asbock #define KEY_SYM_ONE 0x31 178278d72aeSMax Asbock #define KEY_SYM_BANG 0x21 179278d72aeSMax Asbock #define KEY_SYM_TWO 0x32 180278d72aeSMax Asbock #define KEY_SYM_AT 0x40 181278d72aeSMax Asbock #define KEY_SYM_THREE 0x33 182278d72aeSMax Asbock #define KEY_SYM_POUND 0x23 183278d72aeSMax Asbock #define KEY_SYM_FOUR 0x34 184278d72aeSMax Asbock #define KEY_SYM_DOLLAR 0x24 185278d72aeSMax Asbock #define KEY_SYM_FIVE 0x35 186278d72aeSMax Asbock #define KEY_SYM_PERCENT 0x25 187278d72aeSMax Asbock #define KEY_SYM_SIX 0x36 188278d72aeSMax Asbock #define KEY_SYM_CARAT 0x5E 189278d72aeSMax Asbock #define KEY_SYM_SEVEN 0x37 190278d72aeSMax Asbock #define KEY_SYM_AMPER 0x26 191278d72aeSMax Asbock #define KEY_SYM_EIGHT 0x38 192278d72aeSMax Asbock #define KEY_SYM_STAR 0x2A 193278d72aeSMax Asbock #define KEY_SYM_NINE 0x39 194278d72aeSMax Asbock #define KEY_SYM_LPAREN 0x28 195278d72aeSMax Asbock #define KEY_SYM_ZERO 0x30 196278d72aeSMax Asbock #define KEY_SYM_RPAREN 0x29 197278d72aeSMax Asbock #define KEY_SYM_MINUS 0x2D 198278d72aeSMax Asbock #define KEY_SYM_USCORE 0x5F 199278d72aeSMax Asbock #define KEY_SYM_EQUAL 0x2B 200278d72aeSMax Asbock #define KEY_SYM_PLUS 0x3D 201278d72aeSMax Asbock #define KEY_SYM_LBRKT 0x5B 202278d72aeSMax Asbock #define KEY_SYM_LCURLY 0x7B 203278d72aeSMax Asbock #define KEY_SYM_RBRKT 0x5D 204278d72aeSMax Asbock #define KEY_SYM_RCURLY 0x7D 205278d72aeSMax Asbock #define KEY_SYM_SLASH 0x5C 206278d72aeSMax Asbock #define KEY_SYM_PIPE 0x7C 207278d72aeSMax Asbock #define KEY_SYM_TIC 0x27 208278d72aeSMax Asbock #define KEY_SYM_QUOTE 0x22 209278d72aeSMax Asbock #define KEY_SYM_SEMIC 0x3B 210278d72aeSMax Asbock #define KEY_SYM_COLON 0x3A 211278d72aeSMax Asbock #define KEY_SYM_COMMA 0x2C 212278d72aeSMax Asbock #define KEY_SYM_LT 0x3C 213278d72aeSMax Asbock #define KEY_SYM_PERIOD 0x2E 214278d72aeSMax Asbock #define KEY_SYM_GT 0x3E 215278d72aeSMax Asbock #define KEY_SYM_BSLASH 0x2F 216278d72aeSMax Asbock #define KEY_SYM_QMARK 0x3F 217278d72aeSMax Asbock #define KEY_SYM_A 0x41 218278d72aeSMax Asbock #define KEY_SYM_B 0x42 219278d72aeSMax Asbock #define KEY_SYM_C 0x43 220278d72aeSMax Asbock #define KEY_SYM_D 0x44 221278d72aeSMax Asbock #define KEY_SYM_E 0x45 222278d72aeSMax Asbock #define KEY_SYM_F 0x46 223278d72aeSMax Asbock #define KEY_SYM_G 0x47 224278d72aeSMax Asbock #define KEY_SYM_H 0x48 225278d72aeSMax Asbock #define KEY_SYM_I 0x49 226278d72aeSMax Asbock #define KEY_SYM_J 0x4A 227278d72aeSMax Asbock #define KEY_SYM_K 0x4B 228278d72aeSMax Asbock #define KEY_SYM_L 0x4C 229278d72aeSMax Asbock #define KEY_SYM_M 0x4D 230278d72aeSMax Asbock #define KEY_SYM_N 0x4E 231278d72aeSMax Asbock #define KEY_SYM_O 0x4F 232278d72aeSMax Asbock #define KEY_SYM_P 0x50 233278d72aeSMax Asbock #define KEY_SYM_Q 0x51 234278d72aeSMax Asbock #define KEY_SYM_R 0x52 235278d72aeSMax Asbock #define KEY_SYM_S 0x53 236278d72aeSMax Asbock #define KEY_SYM_T 0x54 237278d72aeSMax Asbock #define KEY_SYM_U 0x55 238278d72aeSMax Asbock #define KEY_SYM_V 0x56 239278d72aeSMax Asbock #define KEY_SYM_W 0x57 240278d72aeSMax Asbock #define KEY_SYM_X 0x58 241278d72aeSMax Asbock #define KEY_SYM_Y 0x59 242278d72aeSMax Asbock #define KEY_SYM_Z 0x5A 243278d72aeSMax Asbock #define KEY_SYM_a 0x61 244278d72aeSMax Asbock #define KEY_SYM_b 0x62 245278d72aeSMax Asbock #define KEY_SYM_c 0x63 246278d72aeSMax Asbock #define KEY_SYM_d 0x64 247278d72aeSMax Asbock #define KEY_SYM_e 0x65 248278d72aeSMax Asbock #define KEY_SYM_f 0x66 249278d72aeSMax Asbock #define KEY_SYM_g 0x67 250278d72aeSMax Asbock #define KEY_SYM_h 0x68 251278d72aeSMax Asbock #define KEY_SYM_i 0x69 252278d72aeSMax Asbock #define KEY_SYM_j 0x6A 253278d72aeSMax Asbock #define KEY_SYM_k 0x6B 254278d72aeSMax Asbock #define KEY_SYM_l 0x6C 255278d72aeSMax Asbock #define KEY_SYM_m 0x6D 256278d72aeSMax Asbock #define KEY_SYM_n 0x6E 257278d72aeSMax Asbock #define KEY_SYM_o 0x6F 258278d72aeSMax Asbock #define KEY_SYM_p 0x70 259278d72aeSMax Asbock #define KEY_SYM_q 0x71 260278d72aeSMax Asbock #define KEY_SYM_r 0x72 261278d72aeSMax Asbock #define KEY_SYM_s 0x73 262278d72aeSMax Asbock #define KEY_SYM_t 0x74 263278d72aeSMax Asbock #define KEY_SYM_u 0x75 264278d72aeSMax Asbock #define KEY_SYM_v 0x76 265278d72aeSMax Asbock #define KEY_SYM_w 0x77 266278d72aeSMax Asbock #define KEY_SYM_x 0x78 267278d72aeSMax Asbock #define KEY_SYM_y 0x79 268278d72aeSMax Asbock #define KEY_SYM_z 0x7A 269278d72aeSMax Asbock #define KEY_SYM_SPACE 0x20 2701da177e4SLinus Torvalds #endif /* _IBMASM_REMOTE_H_ */ 271