mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-15 01:44:52 +00:00
Merge branch 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6
* 'release' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6: ACPI: fix "acpi=ht" boot option ACPI, i915: blacklist Clevo M5x0N bad_lid state ACPI: fix High cpu temperature with 2.6.32 ACPI: dock: properly initialize local struct dock_station in dock_add() ACPI: remove Asus P2B-DS from acpi=ht blacklist thinkpad-acpi: wrong thermal attribute_group removed in thermal_exit() ACPI: acpi_bus_{scan,bus,add}: return -ENODEV if no device was found ACPI: Add NULL pointer check in acpi_bus_start ACPI: processor: only evaluate _PDC once per processor ACPI: processor: add kernel command line support for early _PDC eval
This commit is contained in:
commit
2fa298cf6d
@ -199,6 +199,10 @@ and is between 256 and 4096 characters. It is defined in the file
|
|||||||
acpi_display_output=video
|
acpi_display_output=video
|
||||||
See above.
|
See above.
|
||||||
|
|
||||||
|
acpi_early_pdc_eval [HW,ACPI] Evaluate processor _PDC methods
|
||||||
|
early. Needed on some platforms to properly
|
||||||
|
initialize the EC.
|
||||||
|
|
||||||
acpi_irq_balance [HW,ACPI]
|
acpi_irq_balance [HW,ACPI]
|
||||||
ACPI will balance active IRQs
|
ACPI will balance active IRQs
|
||||||
default in APIC mode
|
default in APIC mode
|
||||||
|
@ -94,6 +94,7 @@ ia64_acpi_release_global_lock (unsigned int *lock)
|
|||||||
#define acpi_noirq 0 /* ACPI always enabled on IA64 */
|
#define acpi_noirq 0 /* ACPI always enabled on IA64 */
|
||||||
#define acpi_pci_disabled 0 /* ACPI PCI always enabled on IA64 */
|
#define acpi_pci_disabled 0 /* ACPI PCI always enabled on IA64 */
|
||||||
#define acpi_strict 1 /* no ACPI spec workarounds on IA64 */
|
#define acpi_strict 1 /* no ACPI spec workarounds on IA64 */
|
||||||
|
#define acpi_ht 0 /* no HT-only mode on IA64 */
|
||||||
#endif
|
#endif
|
||||||
#define acpi_processor_cstate_check(x) (x) /* no idle limits on IA64 :) */
|
#define acpi_processor_cstate_check(x) (x) /* no idle limits on IA64 :) */
|
||||||
static inline void disable_acpi(void) { }
|
static inline void disable_acpi(void) { }
|
||||||
|
@ -1342,14 +1342,6 @@ static struct dmi_system_id __initdata acpi_dmi_table[] = {
|
|||||||
DMI_MATCH(DMI_PRODUCT_NAME, "Workstation W8000"),
|
DMI_MATCH(DMI_PRODUCT_NAME, "Workstation W8000"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
|
||||||
.callback = force_acpi_ht,
|
|
||||||
.ident = "ASUS P2B-DS",
|
|
||||||
.matches = {
|
|
||||||
DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK Computer INC."),
|
|
||||||
DMI_MATCH(DMI_BOARD_NAME, "P2B-DS"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
.callback = force_acpi_ht,
|
.callback = force_acpi_ht,
|
||||||
.ident = "ASUS CUR-DLS",
|
.ident = "ASUS CUR-DLS",
|
||||||
|
@ -935,6 +935,7 @@ static int dock_add(acpi_handle handle)
|
|||||||
struct platform_device *dd;
|
struct platform_device *dd;
|
||||||
|
|
||||||
id = dock_station_count;
|
id = dock_station_count;
|
||||||
|
memset(&ds, 0, sizeof(ds));
|
||||||
dd = platform_device_register_data(NULL, "dock", id, &ds, sizeof(ds));
|
dd = platform_device_register_data(NULL, "dock", id, &ds, sizeof(ds));
|
||||||
if (IS_ERR(dd))
|
if (IS_ERR(dd))
|
||||||
return PTR_ERR(dd);
|
return PTR_ERR(dd);
|
||||||
|
@ -110,6 +110,14 @@ static struct dmi_system_id __cpuinitdata processor_power_dmi_table[] = {
|
|||||||
DMI_MATCH(DMI_BIOS_VENDOR,"Phoenix Technologies LTD"),
|
DMI_MATCH(DMI_BIOS_VENDOR,"Phoenix Technologies LTD"),
|
||||||
DMI_MATCH(DMI_BIOS_VERSION,"SHE845M0.86C.0013.D.0302131307")},
|
DMI_MATCH(DMI_BIOS_VERSION,"SHE845M0.86C.0013.D.0302131307")},
|
||||||
(void *)2},
|
(void *)2},
|
||||||
|
{ set_max_cstate, "Pavilion zv5000", {
|
||||||
|
DMI_MATCH(DMI_SYS_VENDOR, "Hewlett-Packard"),
|
||||||
|
DMI_MATCH(DMI_PRODUCT_NAME,"Pavilion zv5000 (DS502A#ABA)")},
|
||||||
|
(void *)1},
|
||||||
|
{ set_max_cstate, "Asus L8400B", {
|
||||||
|
DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK Computer Inc."),
|
||||||
|
DMI_MATCH(DMI_PRODUCT_NAME,"L8400B series Notebook PC")},
|
||||||
|
(void *)1},
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -125,6 +125,8 @@ acpi_processor_eval_pdc(acpi_handle handle, struct acpi_object_list *pdc_in)
|
|||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int early_pdc_done;
|
||||||
|
|
||||||
void acpi_processor_set_pdc(acpi_handle handle)
|
void acpi_processor_set_pdc(acpi_handle handle)
|
||||||
{
|
{
|
||||||
struct acpi_object_list *obj_list;
|
struct acpi_object_list *obj_list;
|
||||||
@ -132,6 +134,9 @@ void acpi_processor_set_pdc(acpi_handle handle)
|
|||||||
if (arch_has_acpi_pdc() == false)
|
if (arch_has_acpi_pdc() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (early_pdc_done)
|
||||||
|
return;
|
||||||
|
|
||||||
obj_list = acpi_processor_alloc_pdc();
|
obj_list = acpi_processor_alloc_pdc();
|
||||||
if (!obj_list)
|
if (!obj_list)
|
||||||
return;
|
return;
|
||||||
@ -151,6 +156,13 @@ static int set_early_pdc_optin(const struct dmi_system_id *id)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int param_early_pdc_optin(char *s)
|
||||||
|
{
|
||||||
|
early_pdc_optin = 1;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
__setup("acpi_early_pdc_eval", param_early_pdc_optin);
|
||||||
|
|
||||||
static struct dmi_system_id __cpuinitdata early_pdc_optin_table[] = {
|
static struct dmi_system_id __cpuinitdata early_pdc_optin_table[] = {
|
||||||
{
|
{
|
||||||
set_early_pdc_optin, "HP Envy", {
|
set_early_pdc_optin, "HP Envy", {
|
||||||
@ -192,4 +204,6 @@ void __init acpi_early_processor_set_pdc(void)
|
|||||||
acpi_walk_namespace(ACPI_TYPE_PROCESSOR, ACPI_ROOT_OBJECT,
|
acpi_walk_namespace(ACPI_TYPE_PROCESSOR, ACPI_ROOT_OBJECT,
|
||||||
ACPI_UINT32_MAX,
|
ACPI_UINT32_MAX,
|
||||||
early_init_pdc, NULL, NULL, NULL);
|
early_init_pdc, NULL, NULL, NULL);
|
||||||
|
|
||||||
|
early_pdc_done = 1;
|
||||||
}
|
}
|
||||||
|
@ -1336,9 +1336,25 @@ static int acpi_bus_scan(acpi_handle handle, struct acpi_bus_ops *ops,
|
|||||||
|
|
||||||
if (child)
|
if (child)
|
||||||
*child = device;
|
*child = device;
|
||||||
return 0;
|
|
||||||
|
if (device)
|
||||||
|
return 0;
|
||||||
|
else
|
||||||
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* acpi_bus_add and acpi_bus_start
|
||||||
|
*
|
||||||
|
* scan a given ACPI tree and (probably recently hot-plugged)
|
||||||
|
* create and add or starts found devices.
|
||||||
|
*
|
||||||
|
* If no devices were found -ENODEV is returned which does not
|
||||||
|
* mean that this is a real error, there just have been no suitable
|
||||||
|
* ACPI objects in the table trunk from which the kernel could create
|
||||||
|
* a device and add/start an appropriate driver.
|
||||||
|
*/
|
||||||
|
|
||||||
int
|
int
|
||||||
acpi_bus_add(struct acpi_device **child,
|
acpi_bus_add(struct acpi_device **child,
|
||||||
struct acpi_device *parent, acpi_handle handle, int type)
|
struct acpi_device *parent, acpi_handle handle, int type)
|
||||||
@ -1348,8 +1364,7 @@ acpi_bus_add(struct acpi_device **child,
|
|||||||
memset(&ops, 0, sizeof(ops));
|
memset(&ops, 0, sizeof(ops));
|
||||||
ops.acpi_op_add = 1;
|
ops.acpi_op_add = 1;
|
||||||
|
|
||||||
acpi_bus_scan(handle, &ops, child);
|
return acpi_bus_scan(handle, &ops, child);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(acpi_bus_add);
|
EXPORT_SYMBOL(acpi_bus_add);
|
||||||
|
|
||||||
@ -1357,11 +1372,13 @@ int acpi_bus_start(struct acpi_device *device)
|
|||||||
{
|
{
|
||||||
struct acpi_bus_ops ops;
|
struct acpi_bus_ops ops;
|
||||||
|
|
||||||
|
if (!device)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
memset(&ops, 0, sizeof(ops));
|
memset(&ops, 0, sizeof(ops));
|
||||||
ops.acpi_op_start = 1;
|
ops.acpi_op_start = 1;
|
||||||
|
|
||||||
acpi_bus_scan(device->handle, &ops, NULL);
|
return acpi_bus_scan(device->handle, &ops, NULL);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(acpi_bus_start);
|
EXPORT_SYMBOL(acpi_bus_start);
|
||||||
|
|
||||||
|
@ -213,7 +213,7 @@ acpi_table_parse_entries(char *id,
|
|||||||
unsigned long table_end;
|
unsigned long table_end;
|
||||||
acpi_size tbl_size;
|
acpi_size tbl_size;
|
||||||
|
|
||||||
if (acpi_disabled)
|
if (acpi_disabled && !acpi_ht)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if (!handler)
|
if (!handler)
|
||||||
@ -280,7 +280,7 @@ int __init acpi_table_parse(char *id, acpi_table_handler handler)
|
|||||||
struct acpi_table_header *table = NULL;
|
struct acpi_table_header *table = NULL;
|
||||||
acpi_size tbl_size;
|
acpi_size tbl_size;
|
||||||
|
|
||||||
if (acpi_disabled)
|
if (acpi_disabled && !acpi_ht)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
if (!handler)
|
if (!handler)
|
||||||
|
@ -636,6 +636,13 @@ static const struct dmi_system_id bad_lid_status[] = {
|
|||||||
DMI_MATCH(DMI_PRODUCT_NAME, "PC-81005"),
|
DMI_MATCH(DMI_PRODUCT_NAME, "PC-81005"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.ident = "Clevo M5x0N",
|
||||||
|
.matches = {
|
||||||
|
DMI_MATCH(DMI_SYS_VENDOR, "CLEVO Co."),
|
||||||
|
DMI_MATCH(DMI_BOARD_NAME, "M5x0N"),
|
||||||
|
},
|
||||||
|
},
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -720,12 +720,6 @@ static int acpiphp_bus_add(struct acpiphp_func *func)
|
|||||||
-ret_val);
|
-ret_val);
|
||||||
goto acpiphp_bus_add_out;
|
goto acpiphp_bus_add_out;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
* try to start anyway. We could have failed to add
|
|
||||||
* simply because this bus had previously been added
|
|
||||||
* on another add. Don't bother with the return value
|
|
||||||
* we just keep going.
|
|
||||||
*/
|
|
||||||
ret_val = acpi_bus_start(device);
|
ret_val = acpi_bus_start(device);
|
||||||
|
|
||||||
acpiphp_bus_add_out:
|
acpiphp_bus_add_out:
|
||||||
|
@ -5771,7 +5771,7 @@ static void thermal_exit(void)
|
|||||||
case TPACPI_THERMAL_ACPI_TMP07:
|
case TPACPI_THERMAL_ACPI_TMP07:
|
||||||
case TPACPI_THERMAL_ACPI_UPDT:
|
case TPACPI_THERMAL_ACPI_UPDT:
|
||||||
sysfs_remove_group(&tpacpi_sensors_pdev->dev.kobj,
|
sysfs_remove_group(&tpacpi_sensors_pdev->dev.kobj,
|
||||||
&thermal_temp_input16_group);
|
&thermal_temp_input8_group);
|
||||||
break;
|
break;
|
||||||
case TPACPI_THERMAL_NONE:
|
case TPACPI_THERMAL_NONE:
|
||||||
default:
|
default:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user