diff options
Diffstat (limited to 'drivers/platform')
| -rw-r--r-- | drivers/platform/mellanox/mlxbf-tmfifo.c | 1 | ||||
| -rw-r--r-- | drivers/platform/mellanox/mlxreg-lc.c | 53 | ||||
| -rw-r--r-- | drivers/platform/surface/surface_aggregator_registry.c | 47 | ||||
| -rw-r--r-- | drivers/platform/x86/acer-wmi.c | 9 | ||||
| -rw-r--r-- | drivers/platform/x86/asus-wmi.c | 11 | ||||
| -rw-r--r-- | drivers/platform/x86/p2sb.c | 18 | ||||
| -rw-r--r-- | drivers/platform/x86/pmc_atom.c | 2 | ||||
| -rw-r--r-- | drivers/platform/x86/serial-multi-instantiate.c | 1 | ||||
| -rw-r--r-- | drivers/platform/x86/thinkpad_acpi.c | 7 | ||||
| -rw-r--r-- | drivers/platform/x86/x86-android-tablets.c | 14 | 
10 files changed, 105 insertions, 58 deletions
| diff --git a/drivers/platform/mellanox/mlxbf-tmfifo.c b/drivers/platform/mellanox/mlxbf-tmfifo.c index 8be13d416f48..1ae3c56b66b0 100644 --- a/drivers/platform/mellanox/mlxbf-tmfifo.c +++ b/drivers/platform/mellanox/mlxbf-tmfifo.c @@ -928,7 +928,6 @@ static int mlxbf_tmfifo_virtio_find_vqs(struct virtio_device *vdev,  					struct virtqueue *vqs[],  					vq_callback_t *callbacks[],  					const char * const names[], -					u32 sizes[],  					const bool *ctx,  					struct irq_affinity *desc)  { diff --git a/drivers/platform/mellanox/mlxreg-lc.c b/drivers/platform/mellanox/mlxreg-lc.c index 55834ccb4ac7..1e071df4c9f5 100644 --- a/drivers/platform/mellanox/mlxreg-lc.c +++ b/drivers/platform/mellanox/mlxreg-lc.c @@ -460,8 +460,6 @@ static int mlxreg_lc_power_on_off(struct mlxreg_lc *mlxreg_lc, u8 action)  	u32 regval;  	int err; -	mutex_lock(&mlxreg_lc->lock); -  	err = regmap_read(mlxreg_lc->par_regmap, mlxreg_lc->data->reg_pwr, ®val);  	if (err)  		goto regmap_read_fail; @@ -474,7 +472,6 @@ static int mlxreg_lc_power_on_off(struct mlxreg_lc *mlxreg_lc, u8 action)  	err = regmap_write(mlxreg_lc->par_regmap, mlxreg_lc->data->reg_pwr, regval);  regmap_read_fail: -	mutex_unlock(&mlxreg_lc->lock);  	return err;  } @@ -491,8 +488,6 @@ static int mlxreg_lc_enable_disable(struct mlxreg_lc *mlxreg_lc, bool action)  	 * line card which is already has been enabled. Disabling does not affect the disabled line  	 * card.  	 */ -	mutex_lock(&mlxreg_lc->lock); -  	err = regmap_read(mlxreg_lc->par_regmap, mlxreg_lc->data->reg_ena, ®val);  	if (err)  		goto regmap_read_fail; @@ -505,7 +500,6 @@ static int mlxreg_lc_enable_disable(struct mlxreg_lc *mlxreg_lc, bool action)  	err = regmap_write(mlxreg_lc->par_regmap, mlxreg_lc->data->reg_ena, regval);  regmap_read_fail: -	mutex_unlock(&mlxreg_lc->lock);  	return err;  } @@ -538,6 +532,15 @@ mlxreg_lc_sn4800_c16_config_init(struct mlxreg_lc *mlxreg_lc, void *regmap,  static void  mlxreg_lc_state_update(struct mlxreg_lc *mlxreg_lc, enum mlxreg_lc_state state, u8 action)  { +	if (action) +		mlxreg_lc->state |= state; +	else +		mlxreg_lc->state &= ~state; +} + +static void +mlxreg_lc_state_update_locked(struct mlxreg_lc *mlxreg_lc, enum mlxreg_lc_state state, u8 action) +{  	mutex_lock(&mlxreg_lc->lock);  	if (action) @@ -560,8 +563,11 @@ static int mlxreg_lc_event_handler(void *handle, enum mlxreg_hotplug_kind kind,  	dev_info(mlxreg_lc->dev, "linecard#%d state %d event kind %d action %d\n",  		 mlxreg_lc->data->slot, mlxreg_lc->state, kind, action); -	if (!(mlxreg_lc->state & MLXREG_LC_INITIALIZED)) +	mutex_lock(&mlxreg_lc->lock); +	if (!(mlxreg_lc->state & MLXREG_LC_INITIALIZED)) { +		mutex_unlock(&mlxreg_lc->lock);  		return 0; +	}  	switch (kind) {  	case MLXREG_HOTPLUG_LC_SYNCED: @@ -574,7 +580,7 @@ static int mlxreg_lc_event_handler(void *handle, enum mlxreg_hotplug_kind kind,  		if (!(mlxreg_lc->state & MLXREG_LC_POWERED) && action) {  			err = mlxreg_lc_power_on_off(mlxreg_lc, 1);  			if (err) -				return err; +				goto mlxreg_lc_power_on_off_fail;  		}  		/* In case line card is configured - enable it. */  		if (mlxreg_lc->state & MLXREG_LC_CONFIGURED && action) @@ -588,12 +594,13 @@ static int mlxreg_lc_event_handler(void *handle, enum mlxreg_hotplug_kind kind,  				/* In case line card is configured - enable it. */  				if (mlxreg_lc->state & MLXREG_LC_CONFIGURED)  					err = mlxreg_lc_enable_disable(mlxreg_lc, 1); +				mutex_unlock(&mlxreg_lc->lock);  				return err;  			}  			err = mlxreg_lc_create_static_devices(mlxreg_lc, mlxreg_lc->main_devs,  							      mlxreg_lc->main_devs_num);  			if (err) -				return err; +				goto mlxreg_lc_create_static_devices_fail;  			/* In case line card is already in ready state - enable it. */  			if (mlxreg_lc->state & MLXREG_LC_CONFIGURED) @@ -620,6 +627,10 @@ static int mlxreg_lc_event_handler(void *handle, enum mlxreg_hotplug_kind kind,  		break;  	} +mlxreg_lc_power_on_off_fail: +mlxreg_lc_create_static_devices_fail: +	mutex_unlock(&mlxreg_lc->lock); +  	return err;  } @@ -665,7 +676,7 @@ static int mlxreg_lc_completion_notify(void *handle, struct i2c_adapter *parent,  		if (err)  			goto mlxreg_lc_create_static_devices_failed; -		mlxreg_lc_state_update(mlxreg_lc, MLXREG_LC_POWERED, 1); +		mlxreg_lc_state_update_locked(mlxreg_lc, MLXREG_LC_POWERED, 1);  	}  	/* Verify if line card is synchronized. */ @@ -676,7 +687,7 @@ static int mlxreg_lc_completion_notify(void *handle, struct i2c_adapter *parent,  	/* Power on line card if necessary. */  	if (regval & mlxreg_lc->data->mask) {  		mlxreg_lc->state |= MLXREG_LC_SYNCED; -		mlxreg_lc_state_update(mlxreg_lc, MLXREG_LC_SYNCED, 1); +		mlxreg_lc_state_update_locked(mlxreg_lc, MLXREG_LC_SYNCED, 1);  		if (mlxreg_lc->state & ~MLXREG_LC_POWERED) {  			err = mlxreg_lc_power_on_off(mlxreg_lc, 1);  			if (err) @@ -684,7 +695,7 @@ static int mlxreg_lc_completion_notify(void *handle, struct i2c_adapter *parent,  		}  	} -	mlxreg_lc_state_update(mlxreg_lc, MLXREG_LC_INITIALIZED, 1); +	mlxreg_lc_state_update_locked(mlxreg_lc, MLXREG_LC_INITIALIZED, 1);  	return 0; @@ -814,10 +825,9 @@ static int mlxreg_lc_probe(struct platform_device *pdev)  	mutex_init(&mlxreg_lc->lock);  	/* Set event notification callback. */ -	if (data->notifier) { -		data->notifier->user_handler = mlxreg_lc_event_handler; -		data->notifier->handle = mlxreg_lc; -	} +	data->notifier->user_handler = mlxreg_lc_event_handler; +	data->notifier->handle = mlxreg_lc; +  	data->hpdev.adapter = i2c_get_adapter(data->hpdev.nr);  	if (!data->hpdev.adapter) {  		dev_err(&pdev->dev, "Failed to get adapter for bus %d\n", @@ -863,7 +873,6 @@ static int mlxreg_lc_probe(struct platform_device *pdev)  	if (err) {  		dev_err(&pdev->dev, "Failed to sync regmap for client %s at bus %d at addr 0x%02x\n",  			data->hpdev.brdinfo->type, data->hpdev.nr, data->hpdev.brdinfo->addr); -		err = PTR_ERR(regmap);  		goto regcache_sync_fail;  	} @@ -878,16 +887,14 @@ static int mlxreg_lc_probe(struct platform_device *pdev)  	if (err)  		goto mlxreg_lc_config_init_fail; -	return err; +	return 0;  mlxreg_lc_config_init_fail:  regcache_sync_fail:  regmap_write_fail:  devm_regmap_init_i2c_fail: -	if (data->hpdev.client) { -		i2c_unregister_device(data->hpdev.client); -		data->hpdev.client = NULL; -	} +	i2c_unregister_device(data->hpdev.client); +	data->hpdev.client = NULL;  i2c_new_device_fail:  	i2c_put_adapter(data->hpdev.adapter);  	data->hpdev.adapter = NULL; @@ -905,6 +912,8 @@ static int mlxreg_lc_remove(struct platform_device *pdev)  	struct mlxreg_core_data *data = dev_get_platdata(&pdev->dev);  	struct mlxreg_lc *mlxreg_lc = platform_get_drvdata(pdev); +	mlxreg_lc_state_update_locked(mlxreg_lc, MLXREG_LC_INITIALIZED, 0); +  	/*  	 * Probing and removing are invoked by hotplug events raised upon line card insertion and  	 * removing. If probing procedure fails all data is cleared. However, hotplug event still diff --git a/drivers/platform/surface/surface_aggregator_registry.c b/drivers/platform/surface/surface_aggregator_registry.c index d5655f6a4a41..585911020cea 100644 --- a/drivers/platform/surface/surface_aggregator_registry.c +++ b/drivers/platform/surface/surface_aggregator_registry.c @@ -86,38 +86,38 @@ static const struct software_node ssam_node_bas_dtx = {  	.parent = &ssam_node_root,  }; -/* HID keyboard (TID1). */ -static const struct software_node ssam_node_hid_tid1_keyboard = { +/* HID keyboard (SAM, TID=1). */ +static const struct software_node ssam_node_hid_sam_keyboard = {  	.name = "ssam:01:15:01:01:00",  	.parent = &ssam_node_root,  }; -/* HID pen stash (TID1; pen taken / stashed away evens). */ -static const struct software_node ssam_node_hid_tid1_penstash = { +/* HID pen stash (SAM, TID=1; pen taken / stashed away evens). */ +static const struct software_node ssam_node_hid_sam_penstash = {  	.name = "ssam:01:15:01:02:00",  	.parent = &ssam_node_root,  }; -/* HID touchpad (TID1). */ -static const struct software_node ssam_node_hid_tid1_touchpad = { +/* HID touchpad (SAM, TID=1). */ +static const struct software_node ssam_node_hid_sam_touchpad = {  	.name = "ssam:01:15:01:03:00",  	.parent = &ssam_node_root,  }; -/* HID device instance 6 (TID1, unknown HID device). */ -static const struct software_node ssam_node_hid_tid1_iid6 = { +/* HID device instance 6 (SAM, TID=1, HID sensor collection). */ +static const struct software_node ssam_node_hid_sam_sensors = {  	.name = "ssam:01:15:01:06:00",  	.parent = &ssam_node_root,  }; -/* HID device instance 7 (TID1, unknown HID device). */ -static const struct software_node ssam_node_hid_tid1_iid7 = { +/* HID device instance 7 (SAM, TID=1, UCM UCSI HID client). */ +static const struct software_node ssam_node_hid_sam_ucm_ucsi = {  	.name = "ssam:01:15:01:07:00",  	.parent = &ssam_node_root,  }; -/* HID system controls (TID1). */ -static const struct software_node ssam_node_hid_tid1_sysctrl = { +/* HID system controls (SAM, TID=1). */ +static const struct software_node ssam_node_hid_sam_sysctrl = {  	.name = "ssam:01:15:01:08:00",  	.parent = &ssam_node_root,  }; @@ -182,8 +182,8 @@ static const struct software_node ssam_node_hid_kip_touchpad = {  	.parent = &ssam_node_hub_kip,  }; -/* HID device instance 5 (KIP hub, unknown HID device). */ -static const struct software_node ssam_node_hid_kip_iid5 = { +/* HID device instance 5 (KIP hub, type-cover firmware update). */ +static const struct software_node ssam_node_hid_kip_fwupd = {  	.name = "ssam:01:15:02:05:00",  	.parent = &ssam_node_hub_kip,  }; @@ -241,12 +241,12 @@ static const struct software_node *ssam_node_group_sls[] = {  	&ssam_node_bat_main,  	&ssam_node_tmp_pprof,  	&ssam_node_pos_tablet_switch, -	&ssam_node_hid_tid1_keyboard, -	&ssam_node_hid_tid1_penstash, -	&ssam_node_hid_tid1_touchpad, -	&ssam_node_hid_tid1_iid6, -	&ssam_node_hid_tid1_iid7, -	&ssam_node_hid_tid1_sysctrl, +	&ssam_node_hid_sam_keyboard, +	&ssam_node_hid_sam_penstash, +	&ssam_node_hid_sam_touchpad, +	&ssam_node_hid_sam_sensors, +	&ssam_node_hid_sam_ucm_ucsi, +	&ssam_node_hid_sam_sysctrl,  	NULL,  }; @@ -278,7 +278,9 @@ static const struct software_node *ssam_node_group_sp8[] = {  	&ssam_node_hid_kip_keyboard,  	&ssam_node_hid_kip_penstash,  	&ssam_node_hid_kip_touchpad, -	&ssam_node_hid_kip_iid5, +	&ssam_node_hid_kip_fwupd, +	&ssam_node_hid_sam_sensors, +	&ssam_node_hid_sam_ucm_ucsi,  	NULL,  }; @@ -325,6 +327,9 @@ static const struct acpi_device_id ssam_platform_hub_match[] = {  	/* Surface Laptop Go 1 */  	{ "MSHW0118", (unsigned long)ssam_node_group_slg1 }, +	/* Surface Laptop Go 2 */ +	{ "MSHW0290", (unsigned long)ssam_node_group_slg1 }, +  	/* Surface Laptop Studio */  	{ "MSHW0123", (unsigned long)ssam_node_group_sls }, diff --git a/drivers/platform/x86/acer-wmi.c b/drivers/platform/x86/acer-wmi.c index e0230ea0cb7e..f1259d81d86d 100644 --- a/drivers/platform/x86/acer-wmi.c +++ b/drivers/platform/x86/acer-wmi.c @@ -99,6 +99,7 @@ static const struct key_entry acer_wmi_keymap[] __initconst = {  	{KE_KEY, 0x22, {KEY_PROG2} },    /* Arcade */  	{KE_KEY, 0x23, {KEY_PROG3} },    /* P_Key */  	{KE_KEY, 0x24, {KEY_PROG4} },    /* Social networking_Key */ +	{KE_KEY, 0x27, {KEY_HELP} },  	{KE_KEY, 0x29, {KEY_PROG3} },    /* P_Key for TM8372 */  	{KE_IGNORE, 0x41, {KEY_MUTE} },  	{KE_IGNORE, 0x42, {KEY_PREVIOUSSONG} }, @@ -112,7 +113,13 @@ static const struct key_entry acer_wmi_keymap[] __initconst = {  	{KE_IGNORE, 0x48, {KEY_VOLUMEUP} },  	{KE_IGNORE, 0x49, {KEY_VOLUMEDOWN} },  	{KE_IGNORE, 0x4a, {KEY_VOLUMEDOWN} }, -	{KE_IGNORE, 0x61, {KEY_SWITCHVIDEOMODE} }, +	/* +	 * 0x61 is KEY_SWITCHVIDEOMODE. Usually this is a duplicate input event +	 * with the "Video Bus" input device events. But sometimes it is not +	 * a dup. Map it to KEY_UNKNOWN instead of using KE_IGNORE so that +	 * udev/hwdb can override it on systems where it is not a dup. +	 */ +	{KE_KEY, 0x61, {KEY_UNKNOWN} },  	{KE_IGNORE, 0x62, {KEY_BRIGHTNESSUP} },  	{KE_IGNORE, 0x63, {KEY_BRIGHTNESSDOWN} },  	{KE_KEY, 0x64, {KEY_SWITCHVIDEOMODE} },	/* Display Switch */ diff --git a/drivers/platform/x86/asus-wmi.c b/drivers/platform/x86/asus-wmi.c index 89b604e04d7f..eec7d0ed7cf2 100644 --- a/drivers/platform/x86/asus-wmi.c +++ b/drivers/platform/x86/asus-wmi.c @@ -107,7 +107,7 @@ module_param(fnlock_default, bool, 0444);  #define WMI_EVENT_MASK			0xFFFF  #define FAN_CURVE_POINTS		8 -#define FAN_CURVE_BUF_LEN		(FAN_CURVE_POINTS * 2) +#define FAN_CURVE_BUF_LEN		32  #define FAN_CURVE_DEV_CPU		0x00  #define FAN_CURVE_DEV_GPU		0x01  /* Mask to determine if setting temperature or percentage */ @@ -1118,7 +1118,7 @@ static int asus_wmi_led_init(struct asus_wmi *asus)  	}  	if (asus_wmi_dev_is_present(asus, ASUS_WMI_DEVID_MICMUTE_LED)) { -		asus->micmute_led.name = "asus::micmute"; +		asus->micmute_led.name = "platform::micmute";  		asus->micmute_led.max_brightness = 1;  		asus->micmute_led.brightness = ledtrig_audio_get(LED_AUDIO_MICMUTE);  		asus->micmute_led.brightness_set_blocking = micmute_led_set; @@ -2233,8 +2233,10 @@ static int fan_curve_get_factory_default(struct asus_wmi *asus, u32 fan_dev)  	curves = &asus->custom_fan_curves[fan_idx];  	err = asus_wmi_evaluate_method_buf(asus->dsts_id, fan_dev, mode, buf,  					   FAN_CURVE_BUF_LEN); -	if (err) +	if (err) { +		pr_warn("%s (0x%08x) failed: %d\n", __func__, fan_dev, err);  		return err; +	}  	fan_curve_copy_from_buf(curves, buf);  	curves->device_id = fan_dev; @@ -2252,9 +2254,6 @@ static int fan_curve_check_present(struct asus_wmi *asus, bool *available,  	err = fan_curve_get_factory_default(asus, fan_dev);  	if (err) { -		pr_debug("fan_curve_get_factory_default(0x%08x) failed: %d\n", -			 fan_dev, err); -		/* Don't cause probe to fail on devices without fan-curves */  		return 0;  	} diff --git a/drivers/platform/x86/p2sb.c b/drivers/platform/x86/p2sb.c index fb2e141f3eb8..384d0962ae93 100644 --- a/drivers/platform/x86/p2sb.c +++ b/drivers/platform/x86/p2sb.c @@ -42,10 +42,24 @@ static int p2sb_get_devfn(unsigned int *devfn)  	return 0;  } +/* Copy resource from the first BAR of the device in question */  static int p2sb_read_bar0(struct pci_dev *pdev, struct resource *mem)  { -	/* Copy resource from the first BAR of the device in question */ -	*mem = pdev->resource[0]; +	struct resource *bar0 = &pdev->resource[0]; + +	/* Make sure we have no dangling pointers in the output */ +	memset(mem, 0, sizeof(*mem)); + +	/* +	 * We copy only selected fields from the original resource. +	 * Because a PCI device will be removed soon, we may not use +	 * any allocated data, hence we may not copy any pointers. +	 */ +	mem->start = bar0->start; +	mem->end = bar0->end; +	mem->flags = bar0->flags; +	mem->desc = bar0->desc; +  	return 0;  } diff --git a/drivers/platform/x86/pmc_atom.c b/drivers/platform/x86/pmc_atom.c index 154317e9910d..5c757c7f64de 100644 --- a/drivers/platform/x86/pmc_atom.c +++ b/drivers/platform/x86/pmc_atom.c @@ -232,7 +232,7 @@ static void pmc_power_off(void)  	pm1_cnt_port = acpi_base_addr + PM1_CNT;  	pm1_cnt_value = inl(pm1_cnt_port); -	pm1_cnt_value &= SLEEP_TYPE_MASK; +	pm1_cnt_value &= ~SLEEP_TYPE_MASK;  	pm1_cnt_value |= SLEEP_TYPE_S5;  	pm1_cnt_value |= SLEEP_ENABLE; diff --git a/drivers/platform/x86/serial-multi-instantiate.c b/drivers/platform/x86/serial-multi-instantiate.c index 67feed25c9db..5362f1a7b77c 100644 --- a/drivers/platform/x86/serial-multi-instantiate.c +++ b/drivers/platform/x86/serial-multi-instantiate.c @@ -328,6 +328,7 @@ static const struct acpi_device_id smi_acpi_ids[] = {  	{ "INT3515", (unsigned long)&int3515_data },  	/* Non-conforming _HID for Cirrus Logic already released */  	{ "CLSA0100", (unsigned long)&cs35l41_hda }, +	{ "CLSA0101", (unsigned long)&cs35l41_hda },  	{ }  };  MODULE_DEVICE_TABLE(acpi, smi_acpi_ids); diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/thinkpad_acpi.c index 22d4e8633e30..2dbb9fc011a7 100644 --- a/drivers/platform/x86/thinkpad_acpi.c +++ b/drivers/platform/x86/thinkpad_acpi.c @@ -10592,10 +10592,9 @@ static int tpacpi_dytc_profile_init(struct ibm_init_struct *iibm)  	/* Ensure initial values are correct */  	dytc_profile_refresh(); -	/* Set AMT correctly now we know current profile */ -	if ((dytc_capabilities & BIT(DYTC_FC_PSC)) && -	    (dytc_capabilities & BIT(DYTC_FC_AMT))) -	    dytc_control_amt(dytc_current_profile == PLATFORM_PROFILE_BALANCED); +	/* Workaround for https://bugzilla.kernel.org/show_bug.cgi?id=216347 */ +	if (dytc_capabilities & BIT(DYTC_FC_PSC)) +		dytc_profile_set(NULL, PLATFORM_PROFILE_BALANCED);  	return 0;  } diff --git a/drivers/platform/x86/x86-android-tablets.c b/drivers/platform/x86/x86-android-tablets.c index 480375977435..4acd6fa8d43b 100644 --- a/drivers/platform/x86/x86-android-tablets.c +++ b/drivers/platform/x86/x86-android-tablets.c @@ -663,9 +663,23 @@ static const struct x86_i2c_client_info chuwi_hi8_i2c_clients[] __initconst = {  	},  }; +static int __init chuwi_hi8_init(void) +{ +	/* +	 * Avoid the acpi_unregister_gsi() call in x86_acpi_irq_helper_get() +	 * breaking the touchscreen + logging various errors when the Windows +	 * BIOS is used. +	 */ +	if (acpi_dev_present("MSSL0001", NULL, 1)) +		return -ENODEV; + +	return 0; +} +  static const struct x86_dev_info chuwi_hi8_info __initconst = {  	.i2c_client_info = chuwi_hi8_i2c_clients,  	.i2c_client_count = ARRAY_SIZE(chuwi_hi8_i2c_clients), +	.init = chuwi_hi8_init,  };  #define CZC_EC_EXTRA_PORT	0x68 | 
