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
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