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
nexedi
linux
Commits
56d2d368
Commit
56d2d368
authored
Jul 10, 2002
by
James Simmons
Browse files
Options
Browse Files
Download
Plain Diff
Merge
http://linux-input.bkbits.net/linux-input
into heisenberg.transvirtual.com:/tmp/linux-input
parents
4379c670
5d6fcf67
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
94 additions
and
41 deletions
+94
-41
drivers/input/joystick/iforce/Config.in
drivers/input/joystick/iforce/Config.in
+4
-4
drivers/input/serio/i8042.c
drivers/input/serio/i8042.c
+72
-25
drivers/input/serio/i8042.h
drivers/input/serio/i8042.h
+9
-6
drivers/input/serio/serio.c
drivers/input/serio/serio.c
+8
-0
include/linux/serio.h
include/linux/serio.h
+1
-6
No files found.
drivers/input/joystick/iforce/Config.in
View file @
56d2d368
...
@@ -5,10 +5,10 @@
...
@@ -5,10 +5,10 @@
dep_tristate ' I-Force devices' CONFIG_JOYSTICK_IFORCE $CONFIG_INPUT $CONFIG_INPUT_JOYSTICK
dep_tristate ' I-Force devices' CONFIG_JOYSTICK_IFORCE $CONFIG_INPUT $CONFIG_INPUT_JOYSTICK
if [ "$CONFIG_JOYSTICK_IFORCE" = "m" -o "$CONFIG_JOYSTICK_IFORCE" = "y" ]; then
if [ "$CONFIG_JOYSTICK_IFORCE" = "m" -o "$CONFIG_JOYSTICK_IFORCE" = "y" ]; then
if [ "$CONFIG_
USB" != "n
" ]; then
if [ "$CONFIG_
JOYSTICK_IFORCE" = "m" -o "$CONFIG_USB" = "y
" ]; then
bool ' I-Force USB joysticks and wheels' CONFIG_JOYSTICK_IFORCE
_USB
dep_mbool ' I-Force USB joysticks and wheels' CONFIG_JOYSTICK_IFORCE_USB $CONFIG
_USB
fi
fi
if [ "$CONFIG_
SERIO" != "n
" ]; then
if [ "$CONFIG_
JOYSTICK_IFORCE" = "m" -o "$CONFIG_SERIO" = "y
" ]; then
bool ' I-Force Serial joysticks and wheels' CONFIG_JOYSTICK_IFORCE_232
dep_mbool ' I-Force Serial joysticks and wheels' CONFIG_JOYSTICK_IFORCE_232 $CONFIG_SERIO
fi
fi
fi
fi
drivers/input/serio/i8042.c
View file @
56d2d368
...
@@ -70,6 +70,7 @@ static struct serio i8042_kbd_port;
...
@@ -70,6 +70,7 @@ static struct serio i8042_kbd_port;
static
struct
serio
i8042_aux_port
;
static
struct
serio
i8042_aux_port
;
static
unsigned
char
i8042_initial_ctr
;
static
unsigned
char
i8042_initial_ctr
;
static
unsigned
char
i8042_ctr
;
static
unsigned
char
i8042_ctr
;
struct
timer_list
i8042_timer
;
#ifdef I8042_DEBUG_IO
#ifdef I8042_DEBUG_IO
static
unsigned
long
i8042_start
;
static
unsigned
long
i8042_start
;
...
@@ -243,7 +244,7 @@ static int i8042_aux_write(struct serio *port, unsigned char c)
...
@@ -243,7 +244,7 @@ static int i8042_aux_write(struct serio *port, unsigned char c)
* mode tend to trash their CTR when doing the AUX_SEND command.
* mode tend to trash their CTR when doing the AUX_SEND command.
*/
*/
retval
+
=
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
);
retval
|
=
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
);
/*
/*
* Make sure the interrupt happens and the character is received even
* Make sure the interrupt happens and the character is received even
...
@@ -251,7 +252,7 @@ static int i8042_aux_write(struct serio *port, unsigned char c)
...
@@ -251,7 +252,7 @@ static int i8042_aux_write(struct serio *port, unsigned char c)
* characters later.
* characters later.
*/
*/
i8042_interrupt
(
0
,
port
,
NULL
);
i8042_interrupt
(
0
,
NULL
,
NULL
);
return
retval
;
return
retval
;
}
}
...
@@ -269,28 +270,23 @@ static int i8042_open(struct serio *port)
...
@@ -269,28 +270,23 @@ static int i8042_open(struct serio *port)
*/
*/
if
(
request_irq
(
values
->
irq
,
i8042_interrupt
,
0
,
"i8042"
,
NULL
))
{
if
(
request_irq
(
values
->
irq
,
i8042_interrupt
,
0
,
"i8042"
,
NULL
))
{
printk
(
KERN_ERR
"i8042.c: Can't get irq %d for %s
\n
"
,
values
->
irq
,
values
->
name
);
printk
(
KERN_ERR
"i8042.c: Can't get irq %d for %s, unregistering the port.
\n
"
,
values
->
irq
,
values
->
name
);
values
->
exists
=
0
;
serio_unregister_port
(
port
);
return
-
1
;
return
-
1
;
}
}
/*
/*
* Enable the
device and its
interrupt.
* Enable the interrupt.
*/
*/
i8042_ctr
|=
values
->
irqen
;
i8042_ctr
|=
values
->
irqen
;
i8042_ctr
&=
~
values
->
disable
;
if
(
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
))
{
if
(
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
))
{
printk
(
KERN_ERR
"i8042.c: Can't write CTR while opening %s.
\n
"
,
values
->
name
);
printk
(
KERN_ERR
"i8042.c: Can't write CTR while opening %s.
\n
"
,
values
->
name
);
return
-
1
;
return
-
1
;
}
}
/*
* Flush buffers
*/
i8042_flush
();
return
0
;
return
0
;
}
}
...
@@ -304,11 +300,10 @@ static void i8042_close(struct serio *port)
...
@@ -304,11 +300,10 @@ static void i8042_close(struct serio *port)
struct
i8042_values
*
values
=
port
->
driver
;
struct
i8042_values
*
values
=
port
->
driver
;
/*
/*
* Disable the
device and its
interrupt.
* Disable the interrupt.
*/
*/
i8042_ctr
&=
~
values
->
irqen
;
i8042_ctr
&=
~
values
->
irqen
;
i8042_ctr
|=
values
->
disable
;
if
(
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
))
{
if
(
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
))
{
printk
(
KERN_ERR
"i8042.c: Can't write CTR while closing %s.
\n
"
,
values
->
name
);
printk
(
KERN_ERR
"i8042.c: Can't write CTR while closing %s.
\n
"
,
values
->
name
);
...
@@ -374,26 +369,29 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
...
@@ -374,26 +369,29 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{
{
unsigned
long
flags
;
unsigned
long
flags
;
unsigned
char
str
,
data
;
unsigned
char
str
,
data
;
unsigned
int
dfl
;
spin_lock_irqsave
(
&
i8042_lock
,
flags
);
spin_lock_irqsave
(
&
i8042_lock
,
flags
);
while
((
str
=
inb
(
I8042_STATUS_REG
))
&
I8042_STR_OBF
)
{
while
((
str
=
inb
(
I8042_STATUS_REG
))
&
I8042_STR_OBF
)
{
data
=
inb
(
I8042_DATA_REG
);
data
=
inb
(
I8042_DATA_REG
);
dfl
=
((
str
&
I8042_STR_PARITY
)
?
SERIO_PARITY
:
0
)
|
((
str
&
I8042_STR_TIMEOUT
)
?
SERIO_TIMEOUT
:
0
);
#ifdef I8042_DEBUG_IO
#ifdef I8042_DEBUG_IO
printk
(
KERN_DEBUG
"i8042.c: %02x <- i8042 (interrupt-%s) [%d]
\n
"
,
printk
(
KERN_DEBUG
"i8042.c: %02x <- i8042 (interrupt-%s
, %d
) [%d]
\n
"
,
data
,
(
str
&
I8042_STR_AUXDATA
)
?
"aux"
:
"kbd"
,
(
int
)
(
jiffies
-
i8042_start
));
data
,
(
str
&
I8042_STR_AUXDATA
)
?
"aux"
:
"kbd"
,
irq
,
(
int
)
(
jiffies
-
i8042_start
));
#endif
#endif
if
(
i8042_aux_values
.
exists
&&
(
str
&
I8042_STR_AUXDATA
))
{
if
(
i8042_aux_values
.
exists
&&
(
str
&
I8042_STR_AUXDATA
))
{
serio_interrupt
(
&
i8042_aux_port
,
data
,
0
);
serio_interrupt
(
&
i8042_aux_port
,
data
,
dfl
);
}
else
{
}
else
{
if
(
i8042_kbd_values
.
exists
)
{
if
(
i8042_kbd_values
.
exists
)
{
if
(
!
i8042_direct
)
{
if
(
!
i8042_direct
)
{
if
(
data
>
0x7f
)
{
if
(
data
>
0x7f
)
{
if
(
test_and_clear_bit
(
data
&
0x7f
,
i8042_unxlate_seen
))
{
if
(
test_and_clear_bit
(
data
&
0x7f
,
i8042_unxlate_seen
))
{
serio_interrupt
(
&
i8042_kbd_port
,
0xf0
,
0
);
serio_interrupt
(
&
i8042_kbd_port
,
0xf0
,
dfl
);
data
=
i8042_unxlate_table
[
data
&
0x7f
];
data
=
i8042_unxlate_table
[
data
&
0x7f
];
}
}
}
else
{
}
else
{
...
@@ -401,7 +399,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
...
@@ -401,7 +399,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
data
=
i8042_unxlate_table
[
data
];
data
=
i8042_unxlate_table
[
data
];
}
}
}
}
serio_interrupt
(
&
i8042_kbd_port
,
data
,
0
);
serio_interrupt
(
&
i8042_kbd_port
,
data
,
dfl
);
}
}
}
}
}
}
...
@@ -524,6 +522,8 @@ static int __init i8042_controller_init(void)
...
@@ -524,6 +522,8 @@ static int __init i8042_controller_init(void)
void
i8042_controller_cleanup
(
void
)
void
i8042_controller_cleanup
(
void
)
{
{
i8042_flush
();
/*
/*
* Reset the controller.
* Reset the controller.
*/
*/
...
@@ -565,6 +565,19 @@ static int __init i8042_check_aux(struct i8042_values *values, struct serio *por
...
@@ -565,6 +565,19 @@ static int __init i8042_check_aux(struct i8042_values *values, struct serio *por
{
{
unsigned
char
param
;
unsigned
char
param
;
/*
* Check if AUX irq is available. If it isn't, then there is no point
* in trying to detect AUX presence.
*/
if
(
request_irq
(
values
->
irq
,
i8042_interrupt
,
0
,
"i8042"
,
NULL
))
return
-
1
;
free_irq
(
values
->
irq
,
NULL
);
/*
* Get rid of bytes in the queue.
*/
i8042_flush
();
i8042_flush
();
/*
/*
...
@@ -637,6 +650,32 @@ static int __init i8042_port_register(struct i8042_values *values, struct serio
...
@@ -637,6 +650,32 @@ static int __init i8042_port_register(struct i8042_values *values, struct serio
return
0
;
return
0
;
}
}
static
void
i8042_timer_func
(
unsigned
long
data
)
{
i8042_interrupt
(
0
,
NULL
,
NULL
);
mod_timer
(
&
i8042_timer
,
jiffies
+
I8042_POLL_PERIOD
);
}
static
void
__init
i8042_start_polling
(
void
)
{
i8042_ctr
&=
~
I8042_CTR_KBDDIS
;
if
(
i8042_aux_values
.
exists
)
i8042_ctr
&=
~
I8042_CTR_AUXDIS
;
if
(
i8042_command
(
&
i8042_ctr
,
I8042_CMD_CTL_WCTR
))
{
printk
(
KERN_WARNING
"i8042.c: Can't write CTR while starting polling.
\n
"
);
return
;
}
i8042_timer
.
function
=
i8042_timer_func
;
mod_timer
(
&
i8042_timer
,
jiffies
+
I8042_POLL_PERIOD
);
}
static
void
__exit
i8042_stop_polling
(
void
)
{
del_timer
(
&
i8042_timer
);
}
/*
/*
* Module init and cleanup functions.
* Module init and cleanup functions.
*/
*/
...
@@ -677,6 +716,15 @@ int __init i8042_init(void)
...
@@ -677,6 +716,15 @@ int __init i8042_init(void)
i8042_start
=
jiffies
;
i8042_start
=
jiffies
;
#endif
#endif
/*
* 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.
*/
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
if
(
!
request_region
(
I8042_DATA_REG
,
16
,
"i8042"
))
return
-
EBUSY
;
#endif
if
(
i8042_controller_init
())
if
(
i8042_controller_init
())
return
-
ENODEV
;
return
-
ENODEV
;
...
@@ -685,20 +733,18 @@ int __init i8042_init(void)
...
@@ -685,20 +733,18 @@ int __init i8042_init(void)
if
(
!
i8042_noaux
&&
!
i8042_check_aux
(
&
i8042_aux_values
,
&
i8042_aux_port
))
if
(
!
i8042_noaux
&&
!
i8042_check_aux
(
&
i8042_aux_values
,
&
i8042_aux_port
))
i8042_port_register
(
&
i8042_aux_values
,
&
i8042_aux_port
);
i8042_port_register
(
&
i8042_aux_values
,
&
i8042_aux_port
);
/*
i8042_start_polling
();
* 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.
*/
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
request_region
(
I8042_DATA_REG
,
16
,
"i8042"
);
#endif
register_reboot_notifier
(
&
i8042_notifier
);
register_reboot_notifier
(
&
i8042_notifier
);
return
0
;
return
0
;
}
}
void
__exit
i8042_exit
(
void
)
void
__exit
i8042_exit
(
void
)
{
{
unregister_reboot_notifier
(
&
i8042_notifier
);
unregister_reboot_notifier
(
&
i8042_notifier
);
i8042_stop_polling
();
if
(
i8042_kbd_values
.
exists
)
if
(
i8042_kbd_values
.
exists
)
serio_unregister_port
(
&
i8042_kbd_port
);
serio_unregister_port
(
&
i8042_kbd_port
);
...
@@ -707,6 +753,7 @@ void __exit i8042_exit(void)
...
@@ -707,6 +753,7 @@ void __exit i8042_exit(void)
serio_unregister_port
(
&
i8042_aux_port
);
serio_unregister_port
(
&
i8042_aux_port
);
i8042_controller_cleanup
();
i8042_controller_cleanup
();
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
#if !defined(__i386__) && !defined(__sh__) && !defined(__alpha__)
release_region
(
I8042_DATA_REG
,
16
);
release_region
(
I8042_DATA_REG
,
16
);
#endif
#endif
...
...
drivers/input/serio/i8042.h
View file @
56d2d368
...
@@ -27,12 +27,6 @@
...
@@ -27,12 +27,6 @@
* Vojtech Pavlik, Simunkova 1594, Prague 8, 182 00 Czech Republic
* Vojtech Pavlik, Simunkova 1594, Prague 8, 182 00 Czech Republic
*/
*/
/*
* If you want to reset your i8042 upon boot, define this.
*/
#undef I8042_RESET
/*
/*
* If you want to trace all the i/o the i8042 module does for
* If you want to trace all the i/o the i8042 module does for
* debugging purposes, define this.
* debugging purposes, define this.
...
@@ -62,6 +56,15 @@
...
@@ -62,6 +56,15 @@
#define I8042_CTL_TIMEOUT 10000
#define I8042_CTL_TIMEOUT 10000
/*
* When the device isn't opened and it's interrupts aren't used, we poll it at
* regular intervals to see if any characters arrived. If yes, we can start
* probing for any mouse / keyboard connected. This is the period of the
* polling.
*/
#define I8042_POLL_PERIOD HZ/20
/*
/*
* Register numbers.
* Register numbers.
*/
*/
...
...
drivers/input/serio/serio.c
View file @
56d2d368
...
@@ -111,6 +111,14 @@ void serio_rescan(struct serio *serio)
...
@@ -111,6 +111,14 @@ void serio_rescan(struct serio *serio)
wake_up
(
&
serio_wait
);
wake_up
(
&
serio_wait
);
}
}
void
serio_interrupt
(
struct
serio
*
serio
,
unsigned
char
data
,
unsigned
int
flags
)
{
if
(
serio
->
dev
&&
serio
->
dev
->
interrupt
)
serio
->
dev
->
interrupt
(
serio
,
data
,
flags
);
else
serio_rescan
(
serio
);
}
void
serio_register_port
(
struct
serio
*
serio
)
void
serio_register_port
(
struct
serio
*
serio
)
{
{
serio
->
next
=
serio_list
;
serio
->
next
=
serio_list
;
...
...
include/linux/serio.h
View file @
56d2d368
...
@@ -76,6 +76,7 @@ struct serio_dev {
...
@@ -76,6 +76,7 @@ struct serio_dev {
int
serio_open
(
struct
serio
*
serio
,
struct
serio_dev
*
dev
);
int
serio_open
(
struct
serio
*
serio
,
struct
serio_dev
*
dev
);
void
serio_close
(
struct
serio
*
serio
);
void
serio_close
(
struct
serio
*
serio
);
void
serio_rescan
(
struct
serio
*
serio
);
void
serio_rescan
(
struct
serio
*
serio
);
void
serio_interrupt
(
struct
serio
*
serio
,
unsigned
char
data
,
unsigned
int
flags
);
void
serio_register_port
(
struct
serio
*
serio
);
void
serio_register_port
(
struct
serio
*
serio
);
void
serio_unregister_port
(
struct
serio
*
serio
);
void
serio_unregister_port
(
struct
serio
*
serio
);
...
@@ -93,12 +94,6 @@ static __inline__ void serio_dev_write_wakeup(struct serio *serio)
...
@@ -93,12 +94,6 @@ static __inline__ void serio_dev_write_wakeup(struct serio *serio)
serio
->
dev
->
write_wakeup
(
serio
);
serio
->
dev
->
write_wakeup
(
serio
);
}
}
static
__inline__
void
serio_interrupt
(
struct
serio
*
serio
,
unsigned
char
data
,
unsigned
int
flags
)
{
if
(
serio
->
dev
&&
serio
->
dev
->
interrupt
)
serio
->
dev
->
interrupt
(
serio
,
data
,
flags
);
}
#define SERIO_TIMEOUT 1
#define SERIO_TIMEOUT 1
#define SERIO_PARITY 2
#define SERIO_PARITY 2
...
...
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