Commit 5e3d5283 authored by Sean Young's avatar Sean Young Committed by Greg Kroah-Hartman

[PATCH] USB: USB PhidgetServo driver update

Once again a (small) patch for the phidgetservo driver.

Some servos have a very high maximum angle, set upper limit to the
maximum allowed by the hardware. Reported by Mario Scholz
<mario@expires-0409.mail.trial-n-error.net>
Signed-off-by: default avatarSean Young <sean@mess.org>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent 5a528e75
...@@ -12,8 +12,6 @@ ...@@ -12,8 +12,6 @@
* controllers available at: http://www.phidgets.com/ * controllers available at: http://www.phidgets.com/
* *
* Note that the driver takes input as: degrees.minutes * Note that the driver takes input as: degrees.minutes
* -23 < degrees < 203
* 0 < minutes < 59
* *
* CAUTION: Generally you should use 0 < degrees < 180 as anything else * CAUTION: Generally you should use 0 < degrees < 180 as anything else
* is probably beyond the range of your servo and may damage it. * is probably beyond the range of your servo and may damage it.
...@@ -21,6 +19,10 @@ ...@@ -21,6 +19,10 @@
* Jun 16, 2004: Sean Young <sean@mess.org> * Jun 16, 2004: Sean Young <sean@mess.org>
* - cleanups * - cleanups
* - was using memory after kfree() * - was using memory after kfree()
* Aug 8, 2004: Sean Young <sean@mess.org>
* - set the highest angle as high as the hardware allows, there are
* some odd servos out there
*
*/ */
#include <linux/config.h> #include <linux/config.h>
...@@ -87,6 +89,9 @@ change_position_v30(struct phidget_servo *servo, int servo_no, int degrees, ...@@ -87,6 +89,9 @@ change_position_v30(struct phidget_servo *servo, int servo_no, int degrees,
int retval; int retval;
unsigned char *buffer; unsigned char *buffer;
if (degrees < -23 || degrees > 362)
return -EINVAL;
buffer = kmalloc(6, GFP_KERNEL); buffer = kmalloc(6, GFP_KERNEL);
if (!buffer) { if (!buffer) {
dev_err(&servo->udev->dev, "%s - out of memory\n", dev_err(&servo->udev->dev, "%s - out of memory\n",
...@@ -157,6 +162,9 @@ change_position_v20(struct phidget_servo *servo, int servo_no, int degrees, ...@@ -157,6 +162,9 @@ change_position_v20(struct phidget_servo *servo, int servo_no, int degrees,
int retval; int retval;
unsigned char *buffer; unsigned char *buffer;
if (degrees < -23 || degrees > 278)
return -EINVAL;
buffer = kmalloc(2, GFP_KERNEL); buffer = kmalloc(2, GFP_KERNEL);
if (!buffer) { if (!buffer) {
dev_err(&servo->udev->dev, "%s - out of memory\n", dev_err(&servo->udev->dev, "%s - out of memory\n",
...@@ -212,10 +220,8 @@ static ssize_t set_servo##value (struct device *dev, \ ...@@ -212,10 +220,8 @@ static ssize_t set_servo##value (struct device *dev, \
return -EINVAL; \ return -EINVAL; \
} \ } \
\ \
if (degrees < -23 || degrees > (180 + 23) || \ if (minutes < 0 || minutes > 59) \
minutes < 0 || minutes > 59) { \
return -EINVAL; \ return -EINVAL; \
} \
\ \
if (servo->type & SERVO_VERSION_30) \ if (servo->type & SERVO_VERSION_30) \
retval = change_position_v30 (servo, value, degrees, \ retval = change_position_v30 (servo, value, degrees, \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment