summarylogtreecommitdiffstats
diff options
context:
space:
mode:
authorNadia Holmquist Pedersen2021-02-08 17:33:43 +0100
committerNadia Holmquist Pedersen2021-02-08 17:33:43 +0100
commitafac0ba15393af6db9572e329127ce73eb143888 (patch)
tree0ad80d5d88bdc5ce390e65d04c75a7da160910d4
parentfc46b71ab47f9d1d113e441ab374d6a9b1f3a4a4 (diff)
downloadaur-afac0ba15393af6db9572e329127ce73eb143888.tar.gz
Update to v6 patches
-rw-r--r--.SRCINFO6
-rw-r--r--PKGBUILD6
-rw-r--r--hid-playstation.c42
3 files changed, 33 insertions, 21 deletions
diff --git a/.SRCINFO b/.SRCINFO
index 238b865e53f7..aa1eb0931b01 100644
--- a/.SRCINFO
+++ b/.SRCINFO
@@ -1,8 +1,8 @@
pkgbase = hid-playstation-dkms
pkgdesc = Sony's official HID driver for the PS5 DualSense controller.
- pkgver = 20210128
+ pkgver = 20210207
pkgrel = 1
- url = https://patchwork.kernel.org/project/linux-input/list/?series=423945
+ url = https://patchwork.kernel.org/project/linux-input/list/?series=429573
arch = any
license = GPL2
depends = dkms
@@ -11,7 +11,7 @@ pkgbase = hid-playstation-dkms
source = hid-ids.h
source = Makefile
source = disable-ff-enabled-check.patch
- md5sums = 079f73703bb601f79f8377d3da18231b
+ md5sums = 6e4906b4d3d92a20e3db2a4165622aaf
md5sums = 6d97239c33773b3f2fc5d497e98a1017
md5sums = c9585c976df5c262127bfe8b595824b3
md5sums = b5424fcb24f12a53b4ff18f1b85bcb23
diff --git a/PKGBUILD b/PKGBUILD
index 6fc79069de0d..10ff5936a72c 100644
--- a/PKGBUILD
+++ b/PKGBUILD
@@ -2,11 +2,11 @@
_pkgbase=hid-playstation
pkgname=${_pkgbase}-dkms
-pkgver=20210128
+pkgver=20210207
pkgrel=1
pkgdesc="Sony's official HID driver for the PS5 DualSense controller."
arch=(any)
-url="https://patchwork.kernel.org/project/linux-input/list/?series=423945"
+url="https://patchwork.kernel.org/project/linux-input/list/?series=429573"
license=("GPL2")
depends=('dkms')
source=(
@@ -14,7 +14,7 @@ source=(
disable-ff-enabled-check.patch
)
-md5sums=('079f73703bb601f79f8377d3da18231b'
+md5sums=('6e4906b4d3d92a20e3db2a4165622aaf'
'6d97239c33773b3f2fc5d497e98a1017'
'c9585c976df5c262127bfe8b595824b3'
'b5424fcb24f12a53b4ff18f1b85bcb23'
diff --git a/hid-playstation.c b/hid-playstation.c
index 354c81f83d10..cc93c16cc822 100644
--- a/hid-playstation.c
+++ b/hid-playstation.c
@@ -423,6 +423,7 @@ static int ps_device_register_battery(struct ps_device *dev)
{
struct power_supply *battery;
struct power_supply_config battery_cfg = { .drv_data = dev };
+ int ret;
dev->battery_desc.type = POWER_SUPPLY_TYPE_BATTERY;
dev->battery_desc.properties = ps_power_supply_props;
@@ -430,16 +431,23 @@ static int ps_device_register_battery(struct ps_device *dev)
dev->battery_desc.get_property = ps_battery_get_property;
dev->battery_desc.name = devm_kasprintf(&dev->hdev->dev, GFP_KERNEL,
"ps-controller-battery-%pMR", dev->mac_address);
+ if (!dev->battery_desc.name)
+ return -ENOMEM;
battery = devm_power_supply_register(&dev->hdev->dev, &dev->battery_desc, &battery_cfg);
if (IS_ERR(battery)) {
- int ret = PTR_ERR(battery);
+ ret = PTR_ERR(battery);
hid_err(dev->hdev, "Unable to register battery device: %d\n", ret);
return ret;
}
dev->battery = battery;
- power_supply_powers(dev->battery, &dev->hdev->dev);
+ ret = power_supply_powers(dev->battery, &dev->hdev->dev);
+ if (ret) {
+ hid_err(dev->hdev, "Unable to activate battery device: %d\n", ret);
+ return ret;
+ }
+
return 0;
}
@@ -496,7 +504,8 @@ static int ps_get_report(struct hid_device *hdev, uint8_t report_id, uint8_t *bu
{
int ret;
- ret = hid_hw_raw_request(hdev, report_id, buf, size, HID_FEATURE_REPORT, HID_REQ_GET_REPORT);
+ ret = hid_hw_raw_request(hdev, report_id, buf, size, HID_FEATURE_REPORT,
+ HID_REQ_GET_REPORT);
if (ret < 0) {
hid_err(hdev, "Failed to retrieve feature with reportID %d: %d\n", report_id, ret);
return ret;
@@ -508,7 +517,7 @@ static int ps_get_report(struct hid_device *hdev, uint8_t report_id, uint8_t *bu
}
if (buf[0] != report_id) {
- hid_err(hdev, "Incorrect reportID received, expected %d got %d\n", report_id, buf[0]);
+ hid_err(hdev, "Invalid reportID received, expected %d got %d\n", report_id, buf[0]);
return -EINVAL;
}
@@ -561,7 +570,8 @@ static int ps_lightbar_register(struct ps_device *ps_dev, struct led_classdev_mc
struct led_classdev *led_cdev;
int ret;
- mc_led_info = devm_kmalloc_array(&hdev->dev, 3, sizeof(*mc_led_info), GFP_KERNEL | __GFP_ZERO);
+ mc_led_info = devm_kmalloc_array(&hdev->dev, 3, sizeof(*mc_led_info),
+ GFP_KERNEL | __GFP_ZERO);
if (!mc_led_info)
return -ENOMEM;
@@ -575,6 +585,8 @@ static int ps_lightbar_register(struct ps_device *ps_dev, struct led_classdev_mc
led_cdev = &lightbar_mc_dev->led_cdev;
led_cdev->name = devm_kasprintf(&hdev->dev, GFP_KERNEL, "playstation::%pMR::rgb",
ps_dev->mac_address);
+ if (!led_cdev->name)
+ return -ENOMEM;
led_cdev->brightness = 255;
led_cdev->max_brightness = 255;
led_cdev->brightness_set_blocking = brightness_set;
@@ -653,7 +665,7 @@ static struct input_dev *ps_touchpad_create(struct hid_device *hdev, int width,
return touchpad;
}
-static ssize_t ps_show_firmware_version(struct device *dev,
+static ssize_t firmware_version_show(struct device *dev,
struct device_attribute
*attr, char *buf)
{
@@ -663,9 +675,9 @@ static ssize_t ps_show_firmware_version(struct device *dev,
return sysfs_emit(buf, "0x%08x\n", ps_dev->fw_version);
}
-static DEVICE_ATTR(firmware_version, 0444, ps_show_firmware_version, NULL);
+static DEVICE_ATTR_RO(firmware_version);
-static ssize_t ps_show_hardware_version(struct device *dev,
+static ssize_t hardware_version_show(struct device *dev,
struct device_attribute
*attr, char *buf)
{
@@ -675,7 +687,7 @@ static ssize_t ps_show_hardware_version(struct device *dev,
return sysfs_emit(buf, "0x%08x\n", ps_dev->hw_version);
}
-static DEVICE_ATTR(hardware_version, 0444, ps_show_hardware_version, NULL);
+static DEVICE_ATTR_RO(hardware_version);
static struct attribute *ps_device_attributes[] = {
&dev_attr_firmware_version.attr,
@@ -1237,7 +1249,7 @@ static void dualsense_set_player_leds(struct dualsense *ds)
* across the LEDs, so e.g. player 1 would be "--x--" with x being 'on'.
* Follow a similar mapping here.
*/
- int player_ids[5] = {
+ static const int player_ids[5] = {
BIT(2),
BIT(3) | BIT(1),
BIT(4) | BIT(2) | BIT(0),
@@ -1466,11 +1478,11 @@ static const struct hid_device_id ps_devices[] = {
MODULE_DEVICE_TABLE(hid, ps_devices);
static struct hid_driver ps_driver = {
- .name = "playstation",
- .id_table = ps_devices,
- .probe = ps_probe,
- .remove = ps_remove,
- .raw_event = ps_raw_event,
+ .name = "playstation",
+ .id_table = ps_devices,
+ .probe = ps_probe,
+ .remove = ps_remove,
+ .raw_event = ps_raw_event,
};
static int __init ps_init(void)