Updated function key mapping because of possible changes to NOTIFY.
The TTY driver now only notifies the IS server about function key event, but does not tell which keys are pressed. The IS servers queries the TTY driver to find out about this.
This commit is contained in:
parent
c0f83b4033
commit
ec24a0798c
13 changed files with 145 additions and 145 deletions
|
@ -16,6 +16,7 @@
|
||||||
#include <minix/devio.h>
|
#include <minix/devio.h>
|
||||||
#include <minix/syslib.h>
|
#include <minix/syslib.h>
|
||||||
#include <minix/utils.h>
|
#include <minix/utils.h>
|
||||||
|
#include <minix/bitmap.h>
|
||||||
|
|
||||||
#include <ibm/interrupt.h> /* IRQ vectors and miscellaneous ports */
|
#include <ibm/interrupt.h> /* IRQ vectors and miscellaneous ports */
|
||||||
#include <ibm/bios.h> /* BIOS index numbers */
|
#include <ibm/bios.h> /* BIOS index numbers */
|
||||||
|
|
|
@ -279,6 +279,7 @@ extern int errno;
|
||||||
*===========================================================================*/
|
*===========================================================================*/
|
||||||
void main(void)
|
void main(void)
|
||||||
{
|
{
|
||||||
|
int fkeys, sfkeys;
|
||||||
int i, r;
|
int i, r;
|
||||||
re_t *rep;
|
re_t *rep;
|
||||||
long v;
|
long v;
|
||||||
|
@ -291,7 +292,8 @@ void main(void)
|
||||||
eth_ign_proto= htons((u16_t) v);
|
eth_ign_proto= htons((u16_t) v);
|
||||||
|
|
||||||
/* Observe some function key for debug dumps. */
|
/* Observe some function key for debug dumps. */
|
||||||
if ((r=fkey_enable(SF9)) != OK)
|
fkeys = sfkeys = 0; bit_set(sfkeys, 9);
|
||||||
|
if ((r=fkey_map(&fkeys, &sfkeys)) != OK)
|
||||||
printf("Warning: RTL8139 couldn't observe Shift+F9 key: %d\n",r);
|
printf("Warning: RTL8139 couldn't observe Shift+F9 key: %d\n",r);
|
||||||
|
|
||||||
/* Claim buffer memory now under Minix, before MM takes it all. */
|
/* Claim buffer memory now under Minix, before MM takes it all. */
|
||||||
|
|
|
@ -76,8 +76,9 @@ PRIVATE char numpad_map[] =
|
||||||
{'H', 'Y', 'A', 'B', 'D', 'C', 'V', 'U', 'G', 'S', 'T', '@'};
|
{'H', 'Y', 'A', 'B', 'D', 'C', 'V', 'U', 'G', 'S', 'T', '@'};
|
||||||
|
|
||||||
/* Variables and definition for observed function keys. */
|
/* Variables and definition for observed function keys. */
|
||||||
PRIVATE int fkey_obs[12]; /* observers for F1-F12 */
|
typedef struct observer { int proc_nr; int events; } obs_t;
|
||||||
PRIVATE int sfkey_obs[12]; /* observers for SHIFT F1-F12 */
|
PRIVATE obs_t fkey_obs[12]; /* observers for F1-F12 */
|
||||||
|
PRIVATE obs_t sfkey_obs[12]; /* observers for SHIFT F1-F12 */
|
||||||
|
|
||||||
FORWARD _PROTOTYPE( int kb_ack, (void) );
|
FORWARD _PROTOTYPE( int kb_ack, (void) );
|
||||||
FORWARD _PROTOTYPE( int kb_wait, (void) );
|
FORWARD _PROTOTYPE( int kb_wait, (void) );
|
||||||
|
@ -393,8 +394,10 @@ tty_t *tp;
|
||||||
|
|
||||||
/* Clear the function key observers array. Also see func_key(). */
|
/* Clear the function key observers array. Also see func_key(). */
|
||||||
for (i=0; i<12; i++) {
|
for (i=0; i<12; i++) {
|
||||||
fkey_obs[i] = NONE; /* F1-F12 observers */
|
fkey_obs[i].proc_nr = NONE; /* F1-F12 observers */
|
||||||
sfkey_obs[i] = NONE; /* Shift F1-F12 observers */
|
fkey_obs[i].events = 0; /* F1-F12 observers */
|
||||||
|
sfkey_obs[i].proc_nr = NONE; /* Shift F1-F12 observers */
|
||||||
|
sfkey_obs[i].events = 0; /* Shift F1-F12 observers */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set interrupt handler and enable keyboard IRQ. */
|
/* Set interrupt handler and enable keyboard IRQ. */
|
||||||
|
@ -430,40 +433,61 @@ message *m_ptr; /* pointer to the request message */
|
||||||
/* This procedure allows processes to register a function key to receive
|
/* This procedure allows processes to register a function key to receive
|
||||||
* notifications if it is pressed. At most one binding per key can exist.
|
* notifications if it is pressed. At most one binding per key can exist.
|
||||||
*/
|
*/
|
||||||
int fkey = m_ptr->FKEY_CODE; /* get function key code */
|
int i;
|
||||||
unsigned code;
|
|
||||||
int *observers = NULL;
|
|
||||||
int index = -1;
|
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
/* See if this key can be observed; get the observers array and index. */
|
switch (m_ptr->FKEY_REQUEST) { /* see what we must do */
|
||||||
if (F1 <= fkey && fkey <= F12) { /* F1-F12 */
|
case FKEY_MAP: /* request for new mapping */
|
||||||
observers = fkey_obs;
|
for (i=0; i < 12; i++) { /* check F1-F12 keys */
|
||||||
index = fkey - F1;
|
if (bit_isset(m_ptr->FKEY_FKEYS, i+1) ) {
|
||||||
} else if (SF1 <= fkey && fkey <= SF12) { /* Shift F1-F12 */
|
if (fkey_obs[i].proc_nr == NONE) {
|
||||||
observers = sfkey_obs;
|
fkey_obs[i].proc_nr = m_ptr->m_source;
|
||||||
index = fkey - SF1;
|
fkey_obs[i].events = 0;
|
||||||
}
|
bit_unset(m_ptr->FKEY_FKEYS, i+1);
|
||||||
|
} else {
|
||||||
/* Handle the request if an observers array was set above. */
|
printf("WARNING, fkey_map failed F%d\n", i);
|
||||||
if (observers) {
|
result = EBUSY;
|
||||||
if (m_ptr->FKEY_ENABLE) { /* try to register an observer */
|
break;
|
||||||
if (observers[index] == NONE) {
|
}
|
||||||
observers[index] = m_ptr->m_source;
|
}
|
||||||
result = OK; /* done, new observer registered */
|
}
|
||||||
} else {
|
for (i=0; i < 12; i++) { /* check Shift+F1-F12 keys */
|
||||||
result = EBUSY; /* function key already bound */
|
if (bit_isset(m_ptr->FKEY_SFKEYS, i+1) ) {
|
||||||
}
|
if (sfkey_obs[i].proc_nr == NONE) {
|
||||||
} else { /* unregister an observer */
|
sfkey_obs[i].proc_nr = m_ptr->m_source;
|
||||||
if (observers[index] == m_ptr->m_source) {
|
sfkey_obs[i].events = 0;
|
||||||
observers[index] = NONE;
|
bit_unset(m_ptr->FKEY_SFKEYS, i+1);
|
||||||
result = OK; /* done, observer unregistered */
|
} else {
|
||||||
} else {
|
printf("WARNING, fkey_map failed Shift F%d\n", i);
|
||||||
result = EPERM; /* can only remove own binding */
|
result = EBUSY;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
result = OK; /* done, new observer registered */
|
||||||
|
break;
|
||||||
|
case FKEY_UNMAP:
|
||||||
|
result = ENOSYS; /* not yet supported (not needed) */
|
||||||
|
break;
|
||||||
|
case FKEY_EVENTS:
|
||||||
|
m_ptr->FKEY_FKEYS = m_ptr->FKEY_SFKEYS = 0;
|
||||||
|
for (i=0; i < 12; i++) { /* check (Shift+) F1-F12 keys */
|
||||||
|
if (fkey_obs[i].proc_nr == m_ptr->m_source) {
|
||||||
|
if (fkey_obs[i].events) {
|
||||||
|
bit_set(m_ptr->FKEY_FKEYS, i+1);
|
||||||
|
fkey_obs[i].events = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sfkey_obs[i].proc_nr == m_ptr->m_source) {
|
||||||
|
if (sfkey_obs[i].events) {
|
||||||
|
bit_set(m_ptr->FKEY_SFKEYS, i+1);
|
||||||
|
sfkey_obs[i].events = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
break;
|
||||||
result = EINVAL; /* key cannot be observed */
|
default:
|
||||||
|
result = EINVAL; /* key cannot be observed */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Almost done, return result to caller. */
|
/* Almost done, return result to caller. */
|
||||||
|
@ -484,14 +508,13 @@ int scode; /* scan code for a function key */
|
||||||
* Returns FALSE on a key release or if the key is not observable.
|
* Returns FALSE on a key release or if the key is not observable.
|
||||||
*/
|
*/
|
||||||
message m;
|
message m;
|
||||||
int *observers = NULL;
|
int key;
|
||||||
unsigned fkey;
|
int proc_nr;
|
||||||
int index = -1;
|
|
||||||
int i,s;
|
int i,s;
|
||||||
|
|
||||||
/* Ignore key releases. If this is a key press, get full key code. */
|
/* Ignore key releases. If this is a key press, get full key code. */
|
||||||
if (scode & KEY_RELEASE) return(FALSE); /* key release */
|
if (scode & KEY_RELEASE) return(FALSE); /* key release */
|
||||||
fkey = map_key(scode); /* include modifiers */
|
key = map_key(scode); /* include modifiers */
|
||||||
|
|
||||||
/* Key pressed, now see if there is an observer for the pressed key.
|
/* Key pressed, now see if there is an observer for the pressed key.
|
||||||
* F1-F12 observers are in fkey_obs array.
|
* F1-F12 observers are in fkey_obs array.
|
||||||
|
@ -499,36 +522,23 @@ int scode; /* scan code for a function key */
|
||||||
* CTRL F1-F12 reserved (see kb_read)
|
* CTRL F1-F12 reserved (see kb_read)
|
||||||
* ALT F1-F12 reserved (see kb_read)
|
* ALT F1-F12 reserved (see kb_read)
|
||||||
* Other combinations are not in use. Note that Alt+Shift+F1-F12 is yet
|
* Other combinations are not in use. Note that Alt+Shift+F1-F12 is yet
|
||||||
* defined in <minix/keymap.h>, but other modifier combinations are not.
|
* defined in <minix/keymap.h>, and thus is easy for future extensions.
|
||||||
*/
|
*/
|
||||||
if (F1 <= fkey && fkey <= F12) { /* F1-F12 */
|
if (F1 <= key && key <= F12) { /* F1-F12 */
|
||||||
observers = &fkey_obs[0];
|
proc_nr = fkey_obs[key - F1].proc_nr;
|
||||||
index = fkey - F1;
|
fkey_obs[key - F1].events ++ ;
|
||||||
} else if (SF1 <= fkey && fkey <= SF12) { /* Shift F2-F12 */
|
} else if (SF1 <= key && key <= SF12) { /* Shift F2-F12 */
|
||||||
observers = &sfkey_obs[0];
|
proc_nr = sfkey_obs[key - SF1].proc_nr;
|
||||||
index = fkey - SF1;
|
sfkey_obs[key - SF1].events ++;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return(FALSE); /* not observable */
|
||||||
}
|
}
|
||||||
if (! observers) return(FALSE); /* not observable */
|
|
||||||
|
|
||||||
/* See if an observer is registered and send it a message. */
|
/* See if an observer is registered and send it a message. */
|
||||||
if (observers[index] != NONE) {
|
if (proc_nr != NONE) {
|
||||||
#if DEAD_CODE
|
|
||||||
m.m_type = FKEY_PRESSED;
|
|
||||||
m.FKEY_NUM = index+1;
|
|
||||||
m.FKEY_CODE = fkey;
|
|
||||||
if (OK != (s=nb_send(observers[index], &m))) {
|
|
||||||
printf("WARNING: F%d key nb_send to process %d failed: %d.\n",
|
|
||||||
index+1, observers[index], s);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
m.NOTIFY_TYPE = FKEY_PRESSED;
|
m.NOTIFY_TYPE = FKEY_PRESSED;
|
||||||
m.NOTIFY_ARG = fkey;
|
notify(proc_nr, &m);
|
||||||
m.NOTIFY_FLAGS = index+1;
|
|
||||||
if (OK != (s=notify(observers[index], &m))) {
|
|
||||||
printf("WARNING: F%d key notify to process %d failed: %d.\n",
|
|
||||||
index+1, observers[index], s);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
return(TRUE);
|
return(TRUE);
|
||||||
}
|
}
|
||||||
|
@ -540,7 +550,7 @@ int scode; /* scan code for a function key */
|
||||||
PRIVATE void show_key_mappings()
|
PRIVATE void show_key_mappings()
|
||||||
{
|
{
|
||||||
int i,s;
|
int i,s;
|
||||||
struct proc proc;
|
struct proc proc;
|
||||||
|
|
||||||
printf("\n");
|
printf("\n");
|
||||||
printf("System information. Known function key mappings to request debug dumps:\n");
|
printf("System information. Known function key mappings to request debug dumps:\n");
|
||||||
|
@ -548,8 +558,8 @@ PRIVATE void show_key_mappings()
|
||||||
for (i=0; i<12; i++) {
|
for (i=0; i<12; i++) {
|
||||||
|
|
||||||
printf(" %sF%d: ", i+1<10? " ":"", i+1);
|
printf(" %sF%d: ", i+1<10? " ":"", i+1);
|
||||||
if (fkey_obs[i] != NONE) {
|
if (fkey_obs[i].proc_nr != NONE) {
|
||||||
if ((s=sys_getproc(&proc, fkey_obs[i]))!=OK)
|
if ((s=sys_getproc(&proc, fkey_obs[i].proc_nr))!=OK)
|
||||||
printf("sys_getproc: %d\n", s);
|
printf("sys_getproc: %d\n", s);
|
||||||
printf("%-14.14s", proc.p_name);
|
printf("%-14.14s", proc.p_name);
|
||||||
} else {
|
} else {
|
||||||
|
@ -557,10 +567,8 @@ PRIVATE void show_key_mappings()
|
||||||
}
|
}
|
||||||
|
|
||||||
printf(" %sShift-F%d: ", i+1<10? " ":"", i+1);
|
printf(" %sShift-F%d: ", i+1<10? " ":"", i+1);
|
||||||
if (i==0) {
|
if (sfkey_obs[i].proc_nr != NONE) {
|
||||||
printf("%-14.14s", "<reserved by TTY>");
|
if ((s=sys_getproc(&proc, sfkey_obs[i].proc_nr))!=OK)
|
||||||
} else if (sfkey_obs[i] != NONE) {
|
|
||||||
if ((s=sys_getproc(&proc, sfkey_obs[i]))!=OK)
|
|
||||||
printf("sys_getproc: %d\n", s);
|
printf("sys_getproc: %d\n", s);
|
||||||
printf("%-14.14s", proc.p_name);
|
printf("%-14.14s", proc.p_name);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -379,7 +379,7 @@
|
||||||
#define PZ_MEM_PTR m1_p1 /* base */
|
#define PZ_MEM_PTR m1_p1 /* base */
|
||||||
#define PZ_COUNT m1_i1 /* count */
|
#define PZ_COUNT m1_i1 /* count */
|
||||||
|
|
||||||
/* Field names for SELECT (FS) */
|
/* Field names for SELECT (FS). */
|
||||||
#define SEL_NFDS m8_i1
|
#define SEL_NFDS m8_i1
|
||||||
#define SEL_READFDS m8_p1
|
#define SEL_READFDS m8_p1
|
||||||
#define SEL_WRITEFDS m8_p2
|
#define SEL_WRITEFDS m8_p2
|
||||||
|
@ -394,9 +394,12 @@
|
||||||
#define PANIC_DUMPS 97 /* debug dumps at the TTY on RBT_PANIC */
|
#define PANIC_DUMPS 97 /* debug dumps at the TTY on RBT_PANIC */
|
||||||
#define FKEY_CONTROL 98 /* control a function key at the TTY */
|
#define FKEY_CONTROL 98 /* control a function key at the TTY */
|
||||||
#define FKEY_PRESSED 99 /* notify process of function key event */
|
#define FKEY_PRESSED 99 /* notify process of function key event */
|
||||||
# define FKEY_NUM m2_l1 /* fkey number excluding modifiers */
|
# define FKEY_REQUEST m2_i1 /* request to perform at TTY */
|
||||||
# define FKEY_CODE m2_l2 /* fkey code including modifiers */
|
# define FKEY_MAP 10 /* observe function key */
|
||||||
# define FKEY_ENABLE m2_i1 /* enable or disable mapping */
|
# define FKEY_UNMAP 11 /* stop observing function key */
|
||||||
|
# define FKEY_EVENTS 12 /* request open key presses */
|
||||||
|
# define FKEY_FKEYS m2_l1 /* F1-F12 keys pressed */
|
||||||
|
# define FKEY_SFKEYS m2_l2 /* Shift-F1-F12 keys pressed */
|
||||||
#define DIAGNOSTICS 100 /* output a string without FS in between */
|
#define DIAGNOSTICS 100 /* output a string without FS in between */
|
||||||
# define DIAG_PRINT_BUF m1_p1
|
# define DIAG_PRINT_BUF m1_p1
|
||||||
# define DIAG_BUF_COUNT m1_i1
|
# define DIAG_BUF_COUNT m1_i1
|
||||||
|
|
|
@ -66,7 +66,6 @@
|
||||||
#define ENABLE_SWAP 1
|
#define ENABLE_SWAP 1
|
||||||
|
|
||||||
/* Enable or disable kernel calls (allows for minimal kernel). */
|
/* Enable or disable kernel calls (allows for minimal kernel). */
|
||||||
#define ENABLE_K_TRACING 1 /* process tracing can be disabled */
|
|
||||||
#define ENABLE_K_DEBUGGING 0 /* kernel debugging calls */
|
#define ENABLE_K_DEBUGGING 0 /* kernel debugging calls */
|
||||||
|
|
||||||
/* Include or exclude an image of /dev/boot in the boot image. */
|
/* Include or exclude an image of /dev/boot in the boot image. */
|
||||||
|
|
|
@ -35,10 +35,10 @@ _PROTOTYPE( void env_panic, (char *key) );
|
||||||
_PROTOTYPE( int env_parse, (char *env, char *fmt, int field, long *param,
|
_PROTOTYPE( int env_parse, (char *env, char *fmt, int field, long *param,
|
||||||
long min, long max) );
|
long min, long max) );
|
||||||
|
|
||||||
#define fkey_enable(fkey) fkey_ctl(fkey, 1)
|
#define fkey_map(fkeys, sfkeys) fkey_ctl(FKEY_MAP, (fkeys), (sfkeys))
|
||||||
#define fkey_disable(fkey) fkey_ctl(fkey, 0)
|
#define fkey_unmap(fkeys, sfkeys) fkey_ctl(FKEY_UNMAP, (fkeys), (sfkeys))
|
||||||
_PROTOTYPE( int fkey_ctl, (int fkey_code, int enable_disable) );
|
#define fkey_events(fkeys, sfkeys) fkey_ctl(FKEY_EVENTS, (fkeys), (sfkeys))
|
||||||
|
_PROTOTYPE( int fkey_ctl, (int req, int *fkeys, int *sfkeys) );
|
||||||
|
|
||||||
_PROTOTYPE( int printf, (const char *fmt, ...));
|
_PROTOTYPE( int printf, (const char *fmt, ...));
|
||||||
_PROTOTYPE( void kputc, (int c));
|
_PROTOTYPE( void kputc, (int c));
|
||||||
|
|
|
@ -12,15 +12,6 @@
|
||||||
#define SENDREC 3 /* function code for SEND + RECEIVE */
|
#define SENDREC 3 /* function code for SEND + RECEIVE */
|
||||||
#define NOTIFY 4 /* function code for notifications */
|
#define NOTIFY 4 /* function code for notifications */
|
||||||
|
|
||||||
#if 0
|
|
||||||
/* Bit map operations to manipulate bits of a simple mask variable. */
|
|
||||||
#define set_bit(mask, n) ((mask) |= (1 << (n)))
|
|
||||||
#define clear_bit(mask, n) ((mask) &= ~(1 << (n)))
|
|
||||||
#define isset_bit(mask, n) ((mask) & (1 << (n)))
|
|
||||||
#define empty_mask (0)
|
|
||||||
#define filled_mask (~0)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Call masks indicating which system calls a process can make. */
|
/* Call masks indicating which system calls a process can make. */
|
||||||
#define EMPTY_CALL_MASK (0)
|
#define EMPTY_CALL_MASK (0)
|
||||||
#define USER_CALL_MASK (1 << SENDREC)
|
#define USER_CALL_MASK (1 << SENDREC)
|
||||||
|
|
|
@ -54,11 +54,7 @@ _PROTOTYPE( int do_setalarm, (message *m_ptr) );
|
||||||
#define do_signalrm do_setalarm
|
#define do_signalrm do_setalarm
|
||||||
#define do_syncalrm do_setalarm
|
#define do_syncalrm do_setalarm
|
||||||
|
|
||||||
#if ENABLE_K_TRACING
|
|
||||||
_PROTOTYPE( int do_trace, (message *m_ptr) ); /* process tracing */
|
_PROTOTYPE( int do_trace, (message *m_ptr) ); /* process tracing */
|
||||||
#else
|
|
||||||
#define do_trace do_unused
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* SYSTEM_H */
|
#endif /* SYSTEM_H */
|
||||||
|
|
|
@ -12,7 +12,6 @@
|
||||||
#include "../system.h"
|
#include "../system.h"
|
||||||
#include <sys/ptrace.h>
|
#include <sys/ptrace.h>
|
||||||
|
|
||||||
#if ENABLE_K_TRACING /* only include code if tracing is enabled */
|
|
||||||
|
|
||||||
/*==========================================================================*
|
/*==========================================================================*
|
||||||
* do_trace *
|
* do_trace *
|
||||||
|
@ -139,4 +138,3 @@ register message *m_ptr;
|
||||||
return(OK);
|
return(OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* ENABLE_K_TRACING */
|
|
||||||
|
|
|
@ -3,9 +3,10 @@
|
||||||
/*===========================================================================*
|
/*===========================================================================*
|
||||||
* fkey_ctl *
|
* fkey_ctl *
|
||||||
*===========================================================================*/
|
*===========================================================================*/
|
||||||
PUBLIC int fkey_ctl(fkey_code, enable_disable)
|
PUBLIC int fkey_ctl(request, fkeys, sfkeys)
|
||||||
int fkey_code; /* function key code it concerns */
|
int request; /* request to perform */
|
||||||
int enable_disable; /* enable or disable notifications */
|
int *fkeys; /* bit masks for F1-F12 keys */
|
||||||
|
int *sfkeys; /* bit masks for Shift F1-F12 keys */
|
||||||
{
|
{
|
||||||
/* Send a message to the TTY server to request notifications for function
|
/* Send a message to the TTY server to request notifications for function
|
||||||
* key presses or to disable notifications. Enabling succeeds unless the key
|
* key presses or to disable notifications. Enabling succeeds unless the key
|
||||||
|
@ -13,9 +14,14 @@ int enable_disable; /* enable or disable notifications */
|
||||||
* bound to the current process.
|
* bound to the current process.
|
||||||
*/
|
*/
|
||||||
message m;
|
message m;
|
||||||
m.FKEY_CODE = fkey_code;
|
int s;
|
||||||
m.FKEY_ENABLE = enable_disable;
|
m.FKEY_REQUEST = request;
|
||||||
return(_taskcall(TTY, FKEY_CONTROL, &m));
|
m.FKEY_FKEYS = (fkeys) ? *fkeys : 0;
|
||||||
|
m.FKEY_SFKEYS = (sfkeys) ? *sfkeys : 0;
|
||||||
|
s = _taskcall(TTY, FKEY_CONTROL, &m);
|
||||||
|
if (fkeys) *fkeys = m.FKEY_FKEYS;
|
||||||
|
if (sfkeys) *sfkeys = m.FKEY_SFKEYS;
|
||||||
|
return(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -13,41 +13,42 @@
|
||||||
/*===========================================================================*
|
/*===========================================================================*
|
||||||
* handle_fkey *
|
* handle_fkey *
|
||||||
*===========================================================================*/
|
*===========================================================================*/
|
||||||
|
#define pressed(k) ((F1<=(k) && (k)<=F12 && bit_isset(m->FKEY_FKEYS, ((k)-F1+1))) \
|
||||||
|
|| (SF1<=(k) && (k)<=SF12 && bit_isset(m->FKEY_SFKEYS, ((k)-SF1+1))))
|
||||||
|
|
||||||
PUBLIC int do_fkey_pressed(message *m)
|
PUBLIC int do_fkey_pressed(message *m)
|
||||||
{
|
{
|
||||||
if (F1 <= m->NOTIFY_ARG && m->NOTIFY_ARG <= F12) {
|
int s;
|
||||||
switch(m->NOTIFY_ARG) {
|
|
||||||
case F1: proctab_dmp(); break;
|
|
||||||
case F2: memmap_dmp(); break;
|
|
||||||
case F3: image_dmp(); break;
|
|
||||||
case F4: sendmask_dmp(); break;
|
|
||||||
case F5: monparams_dmp(); break;
|
|
||||||
case F6: irqtab_dmp(); break;
|
|
||||||
case F7: kmessages_dmp(); break;
|
|
||||||
|
|
||||||
case F10: kenv_dmp(); break;
|
/* The notification message does not convey any information, other
|
||||||
case F11: timing_dmp(); break;
|
* than that some function keys have been pressed. Ask TTY for details.
|
||||||
case F12: sched_dmp(); break;
|
*/
|
||||||
default:
|
m->m_type = FKEY_CONTROL;
|
||||||
printf("IS: unhandled notify for F%d (code %d)\n",
|
m->FKEY_REQUEST = FKEY_EVENTS;
|
||||||
m->NOTIFY_FLAGS, m->NOTIFY_ARG);
|
if (OK != (s=sendrec(TTY, m)))
|
||||||
}
|
report("IS", "warning, sendrec to TTY failed", s);
|
||||||
}
|
|
||||||
|
|
||||||
if (SF1 <= m->NOTIFY_ARG && m->NOTIFY_ARG <= SF12) {
|
/* Now check which keys were pressed: F1-F12. */
|
||||||
switch(m->NOTIFY_ARG) {
|
if (pressed(F1)) proctab_dmp();
|
||||||
|
if (pressed(F2)) memmap_dmp();
|
||||||
|
if (pressed(F3)) image_dmp();
|
||||||
|
if (pressed(F4)) sendmask_dmp();
|
||||||
|
if (pressed(F5)) monparams_dmp();
|
||||||
|
if (pressed(F6)) irqtab_dmp();
|
||||||
|
if (pressed(F7)) kmessages_dmp();
|
||||||
|
|
||||||
case SF1: mproc_dmp(); break;
|
if (pressed(F10)) kenv_dmp();
|
||||||
|
if (pressed(F11)) timing_dmp();
|
||||||
|
if (pressed(F12)) sched_dmp();
|
||||||
|
|
||||||
case SF3: fproc_dmp(); break;
|
/* Also check Shift F1-F6 keys. */
|
||||||
case SF4: dtab_dmp(); break;
|
if (pressed(SF1)) mproc_dmp();
|
||||||
|
|
||||||
case SF6: diagnostics_dmp(); break;
|
if (pressed(SF3)) fproc_dmp();
|
||||||
default:
|
if (pressed(SF4)) dtab_dmp();
|
||||||
printf("IS: unhandled notify for Shift-F%d (code %d)\n",
|
if (pressed(SF6)) diagnostics_dmp();
|
||||||
m->NOTIFY_FLAGS, m->NOTIFY_ARG);
|
|
||||||
}
|
/* Inhibit sending a reply message. */
|
||||||
}
|
return(EDONTREPLY);
|
||||||
return(EDONTREPLY);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include <minix/syslib.h>
|
#include <minix/syslib.h>
|
||||||
#include <minix/utils.h>
|
#include <minix/utils.h>
|
||||||
#include <minix/keymap.h>
|
#include <minix/keymap.h>
|
||||||
|
#include <minix/bitmap.h>
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
|
@ -86,28 +86,22 @@ PRIVATE void init_server()
|
||||||
{
|
{
|
||||||
/* Initialize the information service. */
|
/* Initialize the information service. */
|
||||||
message m;
|
message m;
|
||||||
int r;
|
int i;
|
||||||
long key;
|
|
||||||
|
|
||||||
/* Set own process number. */
|
/* Set own process number. */
|
||||||
is_proc_nr = IS_PROC_NR;
|
is_proc_nr = IS_PROC_NR;
|
||||||
|
|
||||||
/* Set key mappings. IS takes all of F1-F12 and Shift+F1-F6 . */
|
/* Set key mappings. IS takes all of F1-F12 and Shift+F1-F6 . */
|
||||||
for (key=F1; key<=F12; key++) {
|
m.FKEY_FKEYS = m.FKEY_SFKEYS = 0;
|
||||||
if ((r=fkey_enable(key)) != OK) {
|
for (i=1; i<=12; i++) bit_set(m.FKEY_FKEYS, i);
|
||||||
printf("IS: WARNING: couldn't register F%d key: %d\n",
|
for (i=1; i<= 6; i++) bit_set(m.FKEY_SFKEYS, i);
|
||||||
(key-F1+1), r);
|
m.m_type = FKEY_CONTROL;
|
||||||
}
|
m.FKEY_REQUEST = FKEY_MAP;
|
||||||
}
|
if (OK != (i=sendrec(TTY, &m)))
|
||||||
for (key=SF1; key<=SF6; key++) {
|
report("IS", "warning, sendrec failed:", i);
|
||||||
if ((r=fkey_enable(key)) != OK) {
|
|
||||||
printf("IS: WARNING: couldn't register SF%d key: %d\n",
|
|
||||||
(key-SF1+1), r);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Display status message ... */
|
/* Display status message ... */
|
||||||
printf("IS: information service is alive and kicking; press F1-F12 for dumps\n");
|
report("IS", "information service is alive and kicking", NO_NUM);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*===========================================================================*
|
/*===========================================================================*
|
||||||
|
|
Loading…
Reference in a new issue