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
fd26d91e
Commit
fd26d91e
authored
Jan 06, 2003
by
Pablo Menichini
Committed by
Greg Kroah-Hartman
Jan 06, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] 2.5.54 dev_*(&<dev>,...): drivers/usb/input/pid.c
parent
25953f41
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
30 deletions
+15
-30
drivers/usb/input/pid.c
drivers/usb/input/pid.c
+15
-30
No files found.
drivers/usb/input/pid.c
View file @
fd26d91e
...
@@ -48,9 +48,7 @@
...
@@ -48,9 +48,7 @@
/* Called when a transfer is completed */
/* Called when a transfer is completed */
static
void
hid_pid_ctrl_out
(
struct
urb
*
u
,
struct
pt_regs
*
regs
)
static
void
hid_pid_ctrl_out
(
struct
urb
*
u
,
struct
pt_regs
*
regs
)
{
{
#ifdef DEBUG
dev_dbg
(
&
u
->
dev
->
dev
,
"hid_pid_ctrl_out - Transfer Completed
\n
"
);
printk
(
"hid_pid_ctrl_out - Transfer Completed
\n
"
);
#endif
}
}
static
void
hid_pid_exit
(
struct
hid_device
*
hid
)
static
void
hid_pid_exit
(
struct
hid_device
*
hid
)
...
@@ -64,32 +62,29 @@ static void hid_pid_exit(struct hid_device* hid)
...
@@ -64,32 +62,29 @@ static void hid_pid_exit(struct hid_device* hid)
}
}
static
int
pid_upload_periodic
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
static
int
pid_upload_periodic
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
dev_info
(
&
pid
->
hid
->
dev
->
dev
,
"requested periodic force upload
\n
"
);
printk
(
"Requested periodic force upload
\n
"
);
return
0
;
return
0
;
}
}
static
int
pid_upload_constant
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
static
int
pid_upload_constant
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
printk
(
"R
equested constant force upload
\n
"
);
dev_info
(
&
pid
->
hid
->
dev
->
dev
,
"r
equested constant force upload
\n
"
);
return
0
;
return
0
;
}
}
static
int
pid_upload_condition
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
static
int
pid_upload_condition
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
printk
(
"R
equested Condition force upload
\n
"
);
dev_info
(
&
pid
->
hid
->
dev
->
dev
,
"r
equested Condition force upload
\n
"
);
return
0
;
return
0
;
}
}
static
int
pid_upload_ramp
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
static
int
pid_upload_ramp
(
struct
hid_ff_pid
*
pid
,
struct
ff_effect
*
effect
,
int
is_update
)
{
printk
(
"R
equest ramp force upload
\n
"
);
dev_info
(
&
pid
->
hid
->
dev
->
dev
,
"r
equest ramp force upload
\n
"
);
return
0
;
return
0
;
}
}
static
int
hid_pid_event
(
struct
hid_device
*
hid
,
struct
input_dev
*
input
,
static
int
hid_pid_event
(
struct
hid_device
*
hid
,
struct
input_dev
*
input
,
unsigned
int
type
,
unsigned
int
code
,
int
value
)
unsigned
int
type
,
unsigned
int
code
,
int
value
)
{
{
#ifdef DEBUG
dev_dbg
(
&
hid
->
dev
->
dev
,
"PID event received: type=%d,code=%d,value=%d.
\n
"
,
type
,
code
,
value
);
printk
(
"PID event received: type=%d,code=%d,value=%d.
\n
"
,
type
,
code
,
value
);
#endif
if
(
type
!=
EV_FF
)
if
(
type
!=
EV_FF
)
return
-
1
;
return
-
1
;
...
@@ -127,20 +122,20 @@ static int hid_pid_erase(struct input_dev *dev, int id)
...
@@ -127,20 +122,20 @@ static int hid_pid_erase(struct input_dev *dev, int id)
/* Find report */
/* Find report */
ret
=
hid_find_report_by_usage
(
hid
,
wanted_report
,
&
report
,
HID_OUTPUT_REPORT
);
ret
=
hid_find_report_by_usage
(
hid
,
wanted_report
,
&
report
,
HID_OUTPUT_REPORT
);
if
(
!
ret
)
{
if
(
!
ret
)
{
printk
(
"C
ouldn't find report
\n
"
);
dev_err
(
&
hid
->
dev
->
dev
,
"c
ouldn't find report
\n
"
);
return
ret
;
return
ret
;
}
}
/* Find field */
/* Find field */
field
=
(
struct
hid_field
*
)
kmalloc
(
sizeof
(
struct
hid_field
),
GFP_KERNEL
);
field
=
(
struct
hid_field
*
)
kmalloc
(
sizeof
(
struct
hid_field
),
GFP_KERNEL
);
if
(
!
field
)
{
if
(
!
field
)
{
printk
(
"C
ouldn't allocate field
\n
"
);
dev_err
(
&
hid
->
dev
->
dev
,
"c
ouldn't allocate field
\n
"
);
return
-
ENOMEM
;
return
-
ENOMEM
;
}
}
ret
=
hid_set_field
(
field
,
ret
,
pid
->
effects
[
id
].
device_id
);
ret
=
hid_set_field
(
field
,
ret
,
pid
->
effects
[
id
].
device_id
);
if
(
!
ret
)
{
if
(
!
ret
)
{
printk
(
"C
ouldn't set field
\n
"
);
dev_err
(
&
hid
->
dev
->
dev
,
"c
ouldn't set field
\n
"
);
return
ret
;
return
ret
;
}
}
...
@@ -169,7 +164,7 @@ static int hid_pid_flush(struct input_dev *dev, struct file *file)
...
@@ -169,7 +164,7 @@ static int hid_pid_flush(struct input_dev *dev, struct file *file)
if
(
current
->
pid
==
pid
->
effects
[
i
].
owner
if
(
current
->
pid
==
pid
->
effects
[
i
].
owner
&&
test_bit
(
FF_PID_FLAGS_USED
,
&
pid
->
effects
[
i
].
flags
))
&&
test_bit
(
FF_PID_FLAGS_USED
,
&
pid
->
effects
[
i
].
flags
))
if
(
hid_pid_erase
(
dev
,
i
))
if
(
hid_pid_erase
(
dev
,
i
))
warn
(
"erase effect %d failed"
,
i
);
dev_warn
(
&
hid
->
dev
->
dev
,
"erase effect %d failed"
,
i
);
return
0
;
return
0
;
}
}
...
@@ -183,14 +178,10 @@ static int hid_pid_upload_effect(struct input_dev *dev,
...
@@ -183,14 +178,10 @@ static int hid_pid_upload_effect(struct input_dev *dev,
int
is_update
;
int
is_update
;
int
flags
=
0
;
int
flags
=
0
;
#ifdef DEBUG
dev_dbg
(
&
pid_private
->
hid
->
dev
->
dev
,
"upload effect called: effect_type=%x
\n
"
,
effect
->
type
);
printk
(
"Upload effect called: effect_type=%x
\n
"
,
effect
->
type
);
#endif
/* Check this effect type is supported by this device */
/* Check this effect type is supported by this device */
if
(
!
test_bit
(
effect
->
type
,
dev
->
ffbit
))
{
if
(
!
test_bit
(
effect
->
type
,
dev
->
ffbit
))
{
#ifdef DEBUG
dev_dbg
(
&
pid_private
->
hid
->
dev
->
dev
,
"invalid kind of effect requested.
\n
"
);
printk
(
"Invalid kind of effect requested.
\n
"
);
#endif
return
-
EINVAL
;
return
-
EINVAL
;
}
}
...
@@ -209,16 +200,12 @@ static int hid_pid_upload_effect(struct input_dev *dev,
...
@@ -209,16 +200,12 @@ static int hid_pid_upload_effect(struct input_dev *dev,
if
(
id
==
FF_EFFECTS_MAX
)
{
if
(
id
==
FF_EFFECTS_MAX
)
{
// TEMP - We need to get ff_effects_max correctly first: || id >= dev->ff_effects_max) {
// TEMP - We need to get ff_effects_max correctly first: || id >= dev->ff_effects_max) {
#ifdef DEBUG
dev_dbg
(
&
pid_private
->
hid
->
dev
->
dev
,
"Not enough device memory
\n
"
);
printk
(
"Not enough device memory
\n
"
);
#endif
return
-
ENOMEM
;
return
-
ENOMEM
;
}
}
effect
->
id
=
id
;
effect
->
id
=
id
;
#ifdef DEBUG
dev_dbg
(
&
pid_private
->
hid
->
dev
->
dev
,
"effect ID is %d
\n
."
,
id
);
printk
(
"Effect ID is %d
\n
."
,
id
);
#endif
pid_private
->
effects
[
id
].
owner
=
current
->
pid
;
pid_private
->
effects
[
id
].
owner
=
current
->
pid
;
pid_private
->
effects
[
id
].
flags
=
(
1
<<
FF_PID_FLAGS_USED
);
pid_private
->
effects
[
id
].
flags
=
(
1
<<
FF_PID_FLAGS_USED
);
spin_unlock_irqrestore
(
&
pid_private
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
pid_private
->
lock
,
flags
);
...
@@ -265,9 +252,7 @@ static int hid_pid_upload_effect(struct input_dev *dev,
...
@@ -265,9 +252,7 @@ static int hid_pid_upload_effect(struct input_dev *dev,
break
;
break
;
default:
default:
#ifdef DEBUG
dev_dbg
(
&
pid_private
->
hid
->
dev
->
dev
,
"invalid type of effect requested - %x.
\n
"
,
effect
->
type
);
printk
(
"Invalid type of effect requested - %x.
\n
"
,
effect
->
type
);
#endif
return
-
EINVAL
;
return
-
EINVAL
;
}
}
/* If a packet was sent, forbid new updates until we are notified
/* If a packet was sent, forbid new updates until we are notified
...
...
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