summaryrefslogtreecommitdiffstats
path: root/meta/packages/console-tools/console-tools-0.3.2/kbdrate.patch
blob: 47d7ea54b96d9e9ef8fa0fa403e491522bbb562c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
Patch from Matthias Goebl <oe@m.goebl.net>
Added via OE bugtracker: bug #478

--- console-tools-0.3.2/kbdtools/kbd_mode.c.orig
+++ console-tools-0.3.2/kbdtools/kbd_mode.c
@@ -29,11 +29,16 @@
   OPT("-u --unicode  ", _("UTF-8 mode (UNICODE)"));
   OPT("-s --scancode ", _("scancode mode (RAW)"));
   OPT("   --mode={8bit,keycode,unicode,scancode} ", _("set mode"));
+  OPT("-r --rate=RATE ", _("set repeat rate (default: 33)"));
+  OPT("-d --delay=DELAY ", _("set repeat delay (default: 250)"));
 
   OPT("-h --help     ", HELPDESC);
   OPT("-V --version  ", VERSIONDESC);
 }
 
+int rate=-1;
+int delay=-1;
+
 static int parse_cmdline (int argc, char *argv[])
 {
     int mode = -1;
@@ -46,11 +51,13 @@
       { "mode"     , required_argument, NULL, 'm' },
       { "scancode" , no_argument, NULL, 's' },
       { "unicode"  , no_argument, NULL, 'u' },
+      { "rate"     , required_argument, NULL, 'r' },
+      { "delay"    , required_argument, NULL, 'd' },
       { NULL, 0, NULL, 0 }
     };
     int c;
 
-    while ( (c = getopt_long (argc, argv, "Vhaksu", long_opts, NULL)) != EOF) 
+    while ( (c = getopt_long (argc, argv, "Vhaksur:d:", long_opts, NULL)) != EOF) 
       switch (c) {
       case 'h':
 	usage ();
@@ -58,6 +65,14 @@
       case 'V':
 	version ();
 	exit(0);
+      case 'r':
+	rate = atoi(optarg);
+	mode = -2;
+	break;
+      case 'd':
+	delay = atoi(optarg);
+	mode = -2;
+	break;
       case 'a':
 	mode = K_XLATE;
 	break;
@@ -129,6 +144,20 @@
       exit(0);
     }
   
+  if ( rate != -1 || delay != -1 )
+    {
+    struct kbd_repeat kbd_rep;
+    kbd_rep.delay = delay;
+    kbd_rep.period = rate;
+    if (ioctl(fd, KDKBDREP, &kbd_rep))
+      {
+	fprintf(stderr, progname);
+	perror(_(": error setting keyboard repeat mode\n"));
+	exit(1);
+      }
+    if(mode==-2) exit(0);
+    }
+  
   if (ioctl(fd, KDSKBMODE, mode))
     {
       fprintf(stderr, progname);