Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
44b2d32a
Commit
44b2d32a
authored
Sep 12, 2002
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://linux-input.bkbits.net/linux-input
into home.transmeta.com:/home/torvalds/v2.5/linux
parents
9d8fc1ab
09261189
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
58 additions
and
76 deletions
+58
-76
Documentation/input/ff.txt
Documentation/input/ff.txt
+5
-3
drivers/char/Makefile
drivers/char/Makefile
+1
-1
drivers/char/keyboard.c
drivers/char/keyboard.c
+1
-0
drivers/char/tty_io.c
drivers/char/tty_io.c
+2
-0
drivers/input/input.c
drivers/input/input.c
+1
-1
drivers/input/misc/pcspkr.c
drivers/input/misc/pcspkr.c
+2
-2
drivers/input/serio/i8042-io.h
drivers/input/serio/i8042-io.h
+2
-2
drivers/input/serio/q40kbd.c
drivers/input/serio/q40kbd.c
+21
-10
drivers/input/serio/serport.c
drivers/input/serio/serport.c
+23
-54
drivers/usb/input/hid-lgff.c
drivers/usb/input/hid-lgff.c
+0
-3
No files found.
Documentation/input/ff.txt
View file @
44b2d32a
Force feedback for Linux.
Force feedback for Linux.
By Johann Deneux <deneux@ifrance.com> on 2001/04/22.
By Johann Deneux <deneux@ifrance.com> on 2001/04/22.
You
can redistribute this file, provided you
include shape.fig and
You
may redistribute this file. Please remember to
include shape.fig and
interactive.fig.
interactive.fig
as well
.
----------------------------------------------------------------------------
----------------------------------------------------------------------------
0. Introduction
0. Introduction
...
@@ -90,12 +90,14 @@ following bits:
...
@@ -90,12 +90,14 @@ following bits:
- FF_Y has an Y axis (usually joysticks)
- FF_Y has an Y axis (usually joysticks)
- FF_WHEEL has a wheel (usually sterring wheels)
- FF_WHEEL has a wheel (usually sterring wheels)
- FF_CONSTANT can render constant force effects
- FF_CONSTANT can render constant force effects
- FF_PERIODIC can render periodic effects (sine, ramp, square...)
- FF_PERIODIC can render periodic effects (sine, triangle, square...)
- FF_RAMP can render ramp effects
- FF_SPRING can simulate the presence of a spring
- FF_SPRING can simulate the presence of a spring
- FF_FRICTION can simulate friction
- FF_FRICTION can simulate friction
- FF_DAMPER can simulate damper effects
- FF_DAMPER can simulate damper effects
- FF_RUMBLE rumble effects (normally the only effect supported by rumble
- FF_RUMBLE rumble effects (normally the only effect supported by rumble
pads)
pads)
- FF_INERTIA can simulate inertia
int ioctl(int fd, EVIOCGEFFECTS, int *n);
int ioctl(int fd, EVIOCGEFFECTS, int *n);
...
...
drivers/char/Makefile
View file @
44b2d32a
...
@@ -13,7 +13,7 @@ obj-y += mem.o tty_io.o n_tty.o tty_ioctl.o pty.o misc.o random.o
...
@@ -13,7 +13,7 @@ obj-y += mem.o tty_io.o n_tty.o tty_ioctl.o pty.o misc.o random.o
# This list comes from 'grep -l EXPORT_SYMBOL *.[hc]'.
# This list comes from 'grep -l EXPORT_SYMBOL *.[hc]'.
export-objs
:=
busmouse.o console.o generic_serial.o ip2main.o
\
export-objs
:=
busmouse.o console.o generic_serial.o ip2main.o
\
ite_gpio.o misc.o nvram.o random.o rtc.o
\
ite_gpio.o
keyboard.o
misc.o nvram.o random.o rtc.o
\
selection.o sonypi.o sysrq.o tty_io.o tty_ioctl.o
selection.o sonypi.o sysrq.o tty_io.o tty_ioctl.o
obj-$(CONFIG_VT)
+=
vt.o vc_screen.o consolemap.o consolemap_deftbl.o selection.o keyboard.o
obj-$(CONFIG_VT)
+=
vt.o vc_screen.o consolemap.o consolemap_deftbl.o selection.o keyboard.o
...
...
drivers/char/keyboard.c
View file @
44b2d32a
...
@@ -66,6 +66,7 @@ extern void ctrl_alt_del(void);
...
@@ -66,6 +66,7 @@ extern void ctrl_alt_del(void);
#endif
#endif
struct
pt_regs
*
kbd_pt_regs
;
struct
pt_regs
*
kbd_pt_regs
;
EXPORT_SYMBOL
(
kbd_pt_regs
);
void
compute_shiftstate
(
void
);
void
compute_shiftstate
(
void
);
/*
/*
...
...
drivers/char/tty_io.c
View file @
44b2d32a
...
@@ -204,6 +204,8 @@ char *tty_name(struct tty_struct *tty, char *buf)
...
@@ -204,6 +204,8 @@ char *tty_name(struct tty_struct *tty, char *buf)
return
_tty_make_name
(
tty
,
(
tty
)
?
tty
->
driver
.
name
:
NULL
,
buf
);
return
_tty_make_name
(
tty
,
(
tty
)
?
tty
->
driver
.
name
:
NULL
,
buf
);
}
}
EXPORT_SYMBOL
(
tty_name
);
inline
int
tty_paranoia_check
(
struct
tty_struct
*
tty
,
kdev_t
device
,
inline
int
tty_paranoia_check
(
struct
tty_struct
*
tty
,
kdev_t
device
,
const
char
*
routine
)
const
char
*
routine
)
{
{
...
...
drivers/input/input.c
View file @
44b2d32a
...
@@ -605,7 +605,7 @@ static int input_devices_read(char *buf, char **start, off_t pos, int count, int
...
@@ -605,7 +605,7 @@ static int input_devices_read(char *buf, char **start, off_t pos, int count, int
len
+=
sprintf
(
buf
+
len
,
"N: Name=
\"
%s
\"\n
"
,
dev
->
name
?
dev
->
name
:
""
);
len
+=
sprintf
(
buf
+
len
,
"N: Name=
\"
%s
\"\n
"
,
dev
->
name
?
dev
->
name
:
""
);
len
+=
sprintf
(
buf
+
len
,
"P: Phys=%s
\n
"
,
dev
->
phys
?
dev
->
phys
:
""
);
len
+=
sprintf
(
buf
+
len
,
"P: Phys=%s
\n
"
,
dev
->
phys
?
dev
->
phys
:
""
);
len
+=
sprintf
(
buf
+
len
,
"
D: Driv
ers="
);
len
+=
sprintf
(
buf
+
len
,
"
H: Handl
ers="
);
list_for_each
(
hnode
,
&
dev
->
h_list
)
{
list_for_each
(
hnode
,
&
dev
->
h_list
)
{
struct
input_handle
*
handle
=
to_handle
(
hnode
);
struct
input_handle
*
handle
=
to_handle
(
hnode
);
...
...
drivers/input/misc/pcspkr.c
View file @
44b2d32a
...
@@ -22,8 +22,8 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
...
@@ -22,8 +22,8 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
MODULE_DESCRIPTION
(
"PC Speaker beeper driver"
);
MODULE_DESCRIPTION
(
"PC Speaker beeper driver"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
static
char
*
pcspkr_name
=
"PC Speaker"
;
static
char
pcspkr_name
[]
=
"PC Speaker"
;
static
char
*
pcspkr_phys
=
"isa0061/input0"
;
static
char
pcspkr_phys
[]
=
"isa0061/input0"
;
static
struct
input_dev
pcspkr_dev
;
static
struct
input_dev
pcspkr_dev
;
spinlock_t
i8253_beep_lock
=
SPIN_LOCK_UNLOCKED
;
spinlock_t
i8253_beep_lock
=
SPIN_LOCK_UNLOCKED
;
...
...
drivers/input/serio/i8042-io.h
View file @
44b2d32a
...
@@ -62,7 +62,7 @@ static inline int i8042_platform_init(void)
...
@@ -62,7 +62,7 @@ static inline int i8042_platform_init(void)
* On ix86 platforms touching the i8042 data register region can do really
* On ix86 platforms touching the i8042 data register region can do really
* bad things. Because of this the region is always reserved on ix86 boxes.
* bad things. Because of this the region is always reserved on ix86 boxes.
*/
*/
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
&& !defined(__x86_64__)
if
(
!
request_region
(
I8042_DATA_REG
,
16
,
"i8042"
))
if
(
!
request_region
(
I8042_DATA_REG
,
16
,
"i8042"
))
return
0
;
return
0
;
#endif
#endif
...
@@ -71,7 +71,7 @@ static inline int i8042_platform_init(void)
...
@@ -71,7 +71,7 @@ static inline int i8042_platform_init(void)
static
inline
void
i8042_platform_exit
(
void
)
static
inline
void
i8042_platform_exit
(
void
)
{
{
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
&& !defined(__x86_64__)
release_region
(
I8042_DATA_REG
,
16
);
release_region
(
I8042_DATA_REG
,
16
);
#endif
#endif
}
}
...
...
drivers/input/serio/q40kbd.c
View file @
44b2d32a
...
@@ -47,12 +47,24 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
...
@@ -47,12 +47,24 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
MODULE_DESCRIPTION
(
"Q40 PS/2 keyboard controller driver"
);
MODULE_DESCRIPTION
(
"Q40 PS/2 keyboard controller driver"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
static
int
q40kbd_open
(
struct
serio
*
port
)
{
return
0
;
}
static
void
q40kbd_close
(
struct
serio
*
port
)
{
return
0
;
}
static
struct
serio
q40kbd_port
=
static
struct
serio
q40kbd_port
=
{
{
.
type
=
SERIO_8042
,
.
type
=
SERIO_8042
,
.
name
=
"Q40 kbd port"
,
.
phys
=
"Q40"
,
.
write
=
NULL
,
.
write
=
NULL
,
.
name
=
"Q40 PS/2 kbd port"
,
.
open
=
q40kbd_open
,
.
phys
=
"isa0060/serio0"
,
.
close
=
q40kbd_close
,
};
};
static
void
q40kbd_interrupt
(
int
irq
,
void
*
dev_id
,
struct
pt_regs
*
regs
)
static
void
q40kbd_interrupt
(
int
irq
,
void
*
dev_id
,
struct
pt_regs
*
regs
)
...
@@ -70,13 +82,10 @@ void __init q40kbd_init(void)
...
@@ -70,13 +82,10 @@ void __init q40kbd_init(void)
{
{
int
maxread
=
100
;
int
maxread
=
100
;
/* Get the keyboard controller registers (incomplete decode) */
request_region
(
0x60
,
16
,
"q40kbd"
);
/* allocate the IRQ */
/* allocate the IRQ */
request_irq
(
Q40_IRQ_KEYBOARD
,
q40kbd_interrupt
,
0
,
"q40kbd"
,
NULL
);
request_irq
(
Q40_IRQ_KEYBOARD
,
q40kbd_interrupt
,
0
,
"q40kbd"
,
NULL
);
/* flush any pending input
.
*/
/* flush any pending input */
while
(
maxread
--
&&
(
IRQ_KEYB_MASK
&
master_inb
(
INTERRUPT_REG
)))
while
(
maxread
--
&&
(
IRQ_KEYB_MASK
&
master_inb
(
INTERRUPT_REG
)))
master_inb
(
KEYCODE_REG
);
master_inb
(
KEYCODE_REG
);
...
@@ -84,15 +93,17 @@ void __init q40kbd_init(void)
...
@@ -84,15 +93,17 @@ void __init q40kbd_init(void)
master_outb
(
-
1
,
KEYBOARD_UNLOCK_REG
);
master_outb
(
-
1
,
KEYBOARD_UNLOCK_REG
);
master_outb
(
1
,
KEY_IRQ_ENABLE_REG
);
master_outb
(
1
,
KEY_IRQ_ENABLE_REG
);
register_serio
_port
(
&
q40kbd_port
);
serio_register
_port
(
&
q40kbd_port
);
printk
(
KERN_INFO
"serio: Q40
PS/2 kbd port irq %d
\n
"
,
Q40_IRQ_KEYBOARD
);
printk
(
KERN_INFO
"serio: Q40
kbd registered
\n
"
);
}
}
void
__exit
q40kbd_exit
(
void
)
void
__exit
q40kbd_exit
(
void
)
{
{
unregister_serio_port
(
&
q40kbd_port
);
master_outb
(
0
,
KEY_IRQ_ENABLE_REG
);
master_outb
(
-
1
,
KEYBOARD_UNLOCK_REG
);
serio_unregister_port
(
&
q40kbd_port
);
free_irq
(
Q40_IRQ_KEYBOARD
,
NULL
);
free_irq
(
Q40_IRQ_KEYBOARD
,
NULL
);
release_region
(
0x60
,
16
);
}
}
module_init
(
q40kbd_init
);
module_init
(
q40kbd_init
);
...
...
drivers/input/serio/serport.c
View file @
44b2d32a
/*
/*
* $Id: serport_old.c,v 1.10 2002/01/24 19:52:57 vojtech Exp $
* Input device TTY line discipline
*
* Copyright (c) 1999-2002 Vojtech Pavlik
*
*
* Copyright (c) 1999-2001 Vojtech Pavlik
*/
/*
* This is a module that converts a tty line into a much simpler
* This is a module that converts a tty line into a much simpler
* 'serial io port' abstraction that the input device drivers use.
* 'serial io port' abstraction that the input device drivers use.
*/
*/
/*
/*
* This program is free software; you can redistribute it and/or modify
* This program is free software; you can redistribute it and/or modify it
* it under the terms of the GNU General Public License as published by
* under the terms of the GNU General Public License version 2 as published by
* the Free Software Foundation; either version 2 of the License, or
* the Free Software Foundation.
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Should you need to contact me, the author, you can do so either by
* e-mail - mail your message to <vojtech@ucw.cz>, or by paper mail:
* Vojtech Pavlik, Simunkova 1594, Prague 8, 182 00 Czech Republic
*/
*/
#include <asm/uaccess.h>
#include <asm/uaccess.h>
...
@@ -41,10 +25,13 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
...
@@ -41,10 +25,13 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
MODULE_DESCRIPTION
(
"Input device TTY line discipline"
);
MODULE_DESCRIPTION
(
"Input device TTY line discipline"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
#define SERPORT_BUSY 1
struct
serport
{
struct
serport
{
struct
tty_struct
*
tty
;
struct
tty_struct
*
tty
;
wait_queue_head_t
wait
;
wait_queue_head_t
wait
;
struct
serio
serio
;
struct
serio
serio
;
unsigned
long
flags
;
char
phys
[
32
];
char
phys
[
32
];
};
};
...
@@ -68,20 +55,20 @@ static int serport_serio_open(struct serio *serio)
...
@@ -68,20 +55,20 @@ static int serport_serio_open(struct serio *serio)
static
void
serport_serio_close
(
struct
serio
*
serio
)
static
void
serport_serio_close
(
struct
serio
*
serio
)
{
{
struct
serport
*
serport
=
serio
->
driver
;
struct
serport
*
serport
=
serio
->
driver
;
serport
->
serio
.
type
=
0
;
wake_up_interruptible
(
&
serport
->
wait
);
wake_up_interruptible
(
&
serport
->
wait
);
}
}
/*
/*
* serport_ldisc_open() is the routine that is called upon setting our line
* serport_ldisc_open() is the routine that is called upon setting our line
* discipline on a tty. It looks for the Mag, and if found, registers
* discipline on a tty. It prepares the serio struct.
* it as a joystick device.
*/
*/
static
int
serport_ldisc_open
(
struct
tty_struct
*
tty
)
static
int
serport_ldisc_open
(
struct
tty_struct
*
tty
)
{
{
struct
serport
*
serport
;
struct
serport
*
serport
;
char
ttyname
[
64
];
char
name
[
64
];
int
i
;
MOD_INC_USE_COUNT
;
MOD_INC_USE_COUNT
;
...
@@ -96,11 +83,7 @@ static int serport_ldisc_open(struct tty_struct *tty)
...
@@ -96,11 +83,7 @@ static int serport_ldisc_open(struct tty_struct *tty)
serport
->
tty
=
tty
;
serport
->
tty
=
tty
;
tty
->
disc_data
=
serport
;
tty
->
disc_data
=
serport
;
strcpy
(
ttyname
,
tty
->
driver
.
name
);
snprintf
(
serport
->
phys
,
sizeof
(
serport
->
phys
),
"%s/serio0"
,
tty_name
(
tty
,
name
));
for
(
i
=
0
;
ttyname
[
i
]
!=
0
&&
ttyname
[
i
]
!=
'/'
;
i
++
);
ttyname
[
i
]
=
0
;
sprintf
(
serport
->
phys
,
"%s%d/serio0"
,
ttyname
,
minor
(
tty
->
device
)
-
tty
->
driver
.
minor_start
);
serport
->
serio
.
name
=
serport_name
;
serport
->
serio
.
name
=
serport_name
;
serport
->
serio
.
phys
=
serport
->
phys
;
serport
->
serio
.
phys
=
serport
->
phys
;
...
@@ -161,29 +144,18 @@ static int serport_ldisc_room(struct tty_struct *tty)
...
@@ -161,29 +144,18 @@ static int serport_ldisc_room(struct tty_struct *tty)
static
ssize_t
serport_ldisc_read
(
struct
tty_struct
*
tty
,
struct
file
*
file
,
unsigned
char
*
buf
,
size_t
nr
)
static
ssize_t
serport_ldisc_read
(
struct
tty_struct
*
tty
,
struct
file
*
file
,
unsigned
char
*
buf
,
size_t
nr
)
{
{
struct
serport
*
serport
=
(
struct
serport
*
)
tty
->
disc_data
;
struct
serport
*
serport
=
(
struct
serport
*
)
tty
->
disc_data
;
DECLARE_WAITQUEUE
(
wait
,
current
);
char
name
[
64
];
char
name
[
32
];
#ifdef CONFIG_DEVFS_FS
if
(
test_and_set_bit
(
SERPORT_BUSY
,
&
serport
->
flags
))
sprintf
(
name
,
tty
->
driver
.
name
,
minor
(
tty
->
device
)
-
tty
->
driver
.
minor_start
);
return
-
EBUSY
;
#else
sprintf
(
name
,
"%s%d"
,
tty
->
driver
.
name
,
minor
(
tty
->
device
)
-
tty
->
driver
.
minor_start
);
#endif
serio_register_port
(
&
serport
->
serio
);
serio_register_port
(
&
serport
->
serio
);
printk
(
KERN_INFO
"serio: Serial port %s
\n
"
,
tty_name
(
tty
,
name
));
printk
(
KERN_INFO
"serio: Serial port %s
\n
"
,
name
);
wait_event_interruptible
(
serport
->
wait
,
!
serport
->
serio
.
type
);
add_wait_queue
(
&
serport
->
wait
,
&
wait
);
set_current_state
(
TASK_INTERRUPTIBLE
);
while
(
serport
->
serio
.
type
&&
!
signal_pending
(
current
))
schedule
();
set_current_state
(
TASK_RUNNING
);
remove_wait_queue
(
&
serport
->
wait
,
&
wait
);
serio_unregister_port
(
&
serport
->
serio
);
serio_unregister_port
(
&
serport
->
serio
);
clear_bit
(
SERPORT_BUSY
,
&
serport
->
flags
);
return
0
;
return
0
;
}
}
...
@@ -195,10 +167,8 @@ static int serport_ldisc_ioctl(struct tty_struct * tty, struct file * file, unsi
...
@@ -195,10 +167,8 @@ static int serport_ldisc_ioctl(struct tty_struct * tty, struct file * file, unsi
{
{
struct
serport
*
serport
=
(
struct
serport
*
)
tty
->
disc_data
;
struct
serport
*
serport
=
(
struct
serport
*
)
tty
->
disc_data
;
switch
(
cmd
)
{
if
(
cmd
==
SPIOCSTYPE
)
case
SPIOCSTYPE
:
return
get_user
(
serport
->
serio
.
type
,
(
unsigned
long
*
)
arg
);
return
get_user
(
serport
->
serio
.
type
,
(
unsigned
long
*
)
arg
);
}
return
-
EINVAL
;
return
-
EINVAL
;
}
}
...
@@ -208,7 +178,6 @@ static void serport_ldisc_write_wakeup(struct tty_struct * tty)
...
@@ -208,7 +178,6 @@ static void serport_ldisc_write_wakeup(struct tty_struct * tty)
struct
serport
*
sp
=
(
struct
serport
*
)
tty
->
disc_data
;
struct
serport
*
sp
=
(
struct
serport
*
)
tty
->
disc_data
;
serio_dev_write_wakeup
(
&
sp
->
serio
);
serio_dev_write_wakeup
(
&
sp
->
serio
);
}
}
/*
/*
...
...
drivers/usb/input/hid-lgff.c
View file @
44b2d32a
...
@@ -45,9 +45,6 @@
...
@@ -45,9 +45,6 @@
#define RUN_AT(t) (jiffies + (t))
#define RUN_AT(t) (jiffies + (t))
/* Transmition state */
#define XMIT_RUNNING 0
/* Effect status */
/* Effect status */
#define EFFECT_STARTED 0
/* Effect is going to play after some time
#define EFFECT_STARTED 0
/* Effect is going to play after some time
(ff_replay.delay) */
(ff_replay.delay) */
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment