Index: kbd/arch/mips32/src/kbd.c
===================================================================
--- kbd/arch/mips32/src/kbd.c	(revision f4b961f10016a750e8a60d4e28473058f47a467b)
+++ kbd/arch/mips32/src/kbd.c	(revision d1c4b9ebb506eb6fd936447df810dc5b7282680f)
@@ -30,4 +30,22 @@
 #include <ipc/ipc.h>
 
+
+#define KEY_F1 0x504f1bL
+#define KEY_F2 0x514f1bL
+#define KEY_F3 0x524f1bL
+#define KEY_F4 0x534f1bL
+#define KEY_F5 0x35315b1bL
+#define KEY_F6 0x37315b1bL
+#define KEY_F7 0x38315b1bL
+#define KEY_F8 0x39315b1bL
+#define KEY_F9 0x30325b1bL
+#define KEY_F10 0x31325b1bL
+#define KEY_F11 0x33325b1bL
+#define KEY_F12 0x34325b1bL
+
+
+#define FUNCTION_KEYS 0x100
+
+
 irq_cmd_t msim_cmds[1] = {
 	{ CMD_MEM_READ_1, (void *)0xB0000000, 0 }
@@ -45,7 +63,161 @@
 }
 
+
+/*
+*
+* Please preserve this code (it can be used to determine scancodes)
+*
+int to_hex(int v) 
+{
+        return "0123456789ABCDEF"[v];
+}
+*/
+
 int kbd_arch_process(keybuffer_t *keybuffer, int scan_code)
 {
-	keybuffer_push(keybuffer, scan_code);
-	return 	1;
+
+	static unsigned long buf=0;
+	static int count=0;	
+
+
+	//* Please preserve this code (it can be used to determine scancodes)
+	//*
+	//keybuffer_push(keybuffer, to_hex((scan_code>>4)&0xf));
+	//keybuffer_push(keybuffer, to_hex(scan_code&0xf));
+	//keybuffer_push(keybuffer, ' ');
+	//keybuffer_push(keybuffer, ' ');
+	//*/
+	//return 1;
+	
+	
+	if(scan_code==0x7e)
+	{
+		switch (buf){
+			case KEY_F5:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 5 );
+				buf=count=0;
+				return 1;
+			case KEY_F6:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 6 );
+				buf=count=0;
+				return 1;
+			case KEY_F7:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 7 );
+				buf=count=0;
+				return 1;
+			case KEY_F8:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 8 );
+				buf=count=0;
+				return 1;
+
+			case KEY_F9:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 9 );
+				buf=count=0;
+				return 1;
+			case KEY_F10:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 10 );
+				buf=count=0;
+				return 1;
+
+			case KEY_F11:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 11 );
+				buf=count=0;
+				return 1;
+			case KEY_F12:
+				keybuffer_push(keybuffer,FUNCTION_KEYS | 12 );
+				buf=count=0;
+				return 1;
+			default:
+				keybuffer_push(keybuffer, buf & 0xff );
+				keybuffer_push(keybuffer, (buf >> 8) &0xff );
+				keybuffer_push(keybuffer, (buf >> 16) &0xff );
+				keybuffer_push(keybuffer, (buf >> 24) &0xff );
+				keybuffer_push(keybuffer, scan_code );
+				buf=count=0;
+				return 1;
+	
+		}
+	}
+
+	buf|=((unsigned long) scan_code)<<(8*(count++));
+	
+	
+	if((buf & 0xff)!= (KEY_F1 & 0xff)) {
+
+		keybuffer_push(keybuffer,buf );
+		buf=count=0;
+		return 1;
+	}
+
+	if ( count <= 1 ) 
+		return 1;
+
+	if(    (buf & 0xffff) != (KEY_F1 & 0xffff) 
+	    && (buf & 0xffff) != (KEY_F5 & 0xffff) ) {
+
+		keybuffer_push(keybuffer, buf & 0xff );
+		keybuffer_push(keybuffer, (buf >> 8) &0xff );
+		buf=count=0;
+		return 1;
+	}
+
+	if ( count <= 2) 
+		return 1;
+
+	switch (buf){
+		case KEY_F1:
+			keybuffer_push(keybuffer,FUNCTION_KEYS | 1 );
+			buf=count=0;
+			return 1;
+		case KEY_F2:
+			keybuffer_push(keybuffer,FUNCTION_KEYS | 2 );
+			buf=count=0;
+			return 1;
+		case KEY_F3:
+			keybuffer_push(keybuffer,FUNCTION_KEYS | 3 );
+			buf=count=0;
+			return 1;
+		case KEY_F4:
+			keybuffer_push(keybuffer,FUNCTION_KEYS | 4 );
+			buf=count=0;
+			return 1;
+	}
+
+
+	if(    (buf & 0xffffff) != (KEY_F5 & 0xffffff)
+	    && (buf & 0xffffff) != (KEY_F9 & 0xffffff) ) {
+
+		keybuffer_push(keybuffer, buf & 0xff );
+		keybuffer_push(keybuffer, (buf >> 8) &0xff );
+		keybuffer_push(keybuffer, (buf >> 16) &0xff );
+		buf=count=0;
+		return 1;
+	}
+
+	if ( count <= 3 ) 
+		return 1;
+	
+
+	
+	
+	switch (buf){
+		case KEY_F5:
+		case KEY_F6:
+		case KEY_F7:
+		case KEY_F8:
+		case KEY_F9:
+		case KEY_F10:
+		case KEY_F11:
+		case KEY_F12:
+			return 1;
+		default:
+			keybuffer_push(keybuffer, buf & 0xff );
+			keybuffer_push(keybuffer, (buf >> 8) &0xff );
+			keybuffer_push(keybuffer, (buf >> 16) &0xff );
+			keybuffer_push(keybuffer, (buf >> 24) &0xff );
+			buf=count=0;
+			return 1;
+		
+		}
+	return 1;
 }
