Skip to content

Commit

Permalink
HID: roccat: cleaned up code for Kone and fixed wrong initialization …
Browse files Browse the repository at this point in the history
…value

Introduced function kone_profile_activated() to reduce code duplication.
This by the way fixes a wrong initialization value.
Also fixes early mutex unlocks.

Signed-off-by: Stefan Achatz <erazor_de@users.sourceforge.net>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
  • Loading branch information
Stefan Achatz authored and Jiri Kosina committed Sep 7, 2011
1 parent 6b9a57b commit bd9c35d
Showing 1 changed file with 22 additions and 21 deletions.
43 changes: 22 additions & 21 deletions drivers/hid/hid-roccat-kone.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,12 @@

static uint profile_numbers[5] = {0, 1, 2, 3, 4};

static void kone_profile_activated(struct kone_device *kone, uint new_profile)
{
kone->actual_profile = new_profile;
kone->actual_dpi = kone->profiles[new_profile - 1].startup_dpi;
}

static int kone_receive(struct usb_device *usb_dev, uint usb_command,
void *data, uint size)
{
Expand Down Expand Up @@ -294,21 +300,16 @@ static ssize_t kone_sysfs_write_settings(struct file *fp, struct kobject *kobj,
if (difference) {
retval = kone_set_settings(usb_dev,
(struct kone_settings const *)buf);
if (!retval)
memcpy(&kone->settings, buf,
sizeof(struct kone_settings));
}
mutex_unlock(&kone->kone_lock);
if (retval) {
mutex_unlock(&kone->kone_lock);
return retval;
}

if (retval)
return retval;
memcpy(&kone->settings, buf, sizeof(struct kone_settings));

/*
* If we get here, treat settings as okay and update actual values
* according to startup_profile
*/
kone->actual_profile = kone->settings.startup_profile;
kone->actual_dpi = kone->profiles[kone->actual_profile - 1].startup_dpi;
kone_profile_activated(kone, kone->settings.startup_profile);
}
mutex_unlock(&kone->kone_lock);

return sizeof(struct kone_settings);
}
Expand Down Expand Up @@ -501,6 +502,8 @@ static ssize_t kone_sysfs_set_tcu(struct device *dev,
goto exit_no_settings;
goto exit_unlock;
}
/* calibration resets profile */
kone_profile_activated(kone, kone->settings.startup_profile);
}

retval = size;
Expand Down Expand Up @@ -544,16 +547,15 @@ static ssize_t kone_sysfs_set_startup_profile(struct device *dev,
kone_set_settings_checksum(&kone->settings);

retval = kone_set_settings(usb_dev, &kone->settings);

mutex_unlock(&kone->kone_lock);

if (retval)
if (retval) {
mutex_unlock(&kone->kone_lock);
return retval;
}

/* changing the startup profile immediately activates this profile */
kone->actual_profile = new_startup_profile;
kone->actual_dpi = kone->profiles[kone->actual_profile - 1].startup_dpi;
kone_profile_activated(kone, new_startup_profile);

mutex_unlock(&kone->kone_lock);
return size;
}

Expand Down Expand Up @@ -665,8 +667,7 @@ static int kone_init_kone_device_struct(struct usb_device *usb_dev,
if (retval)
return retval;

kone->actual_profile = kone->settings.startup_profile;
kone->actual_dpi = kone->profiles[kone->actual_profile].startup_dpi;
kone_profile_activated(kone, kone->settings.startup_profile);

return 0;
}
Expand Down

0 comments on commit bd9c35d

Please sign in to comment.