Pull now into release branch

This commit is contained in:
Len Brown 2007-06-02 00:48:48 -04:00
commit fcf75356e9
10 changed files with 126 additions and 113 deletions

View File

@ -138,7 +138,7 @@ Hot keys
-------- --------
procfs: /proc/acpi/ibm/hotkey procfs: /proc/acpi/ibm/hotkey
sysfs device attribute: hotkey/* sysfs device attribute: hotkey_*
Without this driver, only the Fn-F4 key (sleep button) generates an Without this driver, only the Fn-F4 key (sleep button) generates an
ACPI event. With the driver loaded, the hotkey feature enabled and the ACPI event. With the driver loaded, the hotkey feature enabled and the
@ -196,10 +196,7 @@ The following commands can be written to the /proc/acpi/ibm/hotkey file:
sysfs notes: sysfs notes:
The hot keys attributes are in a hotkey/ subdirectory off the hotkey_bios_enabled:
thinkpad device.
bios_enabled:
Returns the status of the hot keys feature when Returns the status of the hot keys feature when
thinkpad-acpi was loaded. Upon module unload, the hot thinkpad-acpi was loaded. Upon module unload, the hot
key feature status will be restored to this value. key feature status will be restored to this value.
@ -207,19 +204,19 @@ sysfs notes:
0: hot keys were disabled 0: hot keys were disabled
1: hot keys were enabled 1: hot keys were enabled
bios_mask: hotkey_bios_mask:
Returns the hot keys mask when thinkpad-acpi was loaded. Returns the hot keys mask when thinkpad-acpi was loaded.
Upon module unload, the hot keys mask will be restored Upon module unload, the hot keys mask will be restored
to this value. to this value.
enable: hotkey_enable:
Enables/disables the hot keys feature, and reports Enables/disables the hot keys feature, and reports
current status of the hot keys feature. current status of the hot keys feature.
0: disables the hot keys feature / feature disabled 0: disables the hot keys feature / feature disabled
1: enables the hot keys feature / feature enabled 1: enables the hot keys feature / feature enabled
mask: hotkey_mask:
bit mask to enable ACPI event generation for each hot bit mask to enable ACPI event generation for each hot
key (see above). Returns the current status of the hot key (see above). Returns the current status of the hot
keys mask, and allows one to modify it. keys mask, and allows one to modify it.
@ -229,7 +226,7 @@ Bluetooth
--------- ---------
procfs: /proc/acpi/ibm/bluetooth procfs: /proc/acpi/ibm/bluetooth
sysfs device attribute: bluetooth/enable sysfs device attribute: bluetooth_enable
This feature shows the presence and current state of a ThinkPad This feature shows the presence and current state of a ThinkPad
Bluetooth device in the internal ThinkPad CDC slot. Bluetooth device in the internal ThinkPad CDC slot.
@ -244,7 +241,7 @@ If Bluetooth is installed, the following commands can be used:
Sysfs notes: Sysfs notes:
If the Bluetooth CDC card is installed, it can be enabled / If the Bluetooth CDC card is installed, it can be enabled /
disabled through the "bluetooth/enable" thinkpad-acpi device disabled through the "bluetooth_enable" thinkpad-acpi device
attribute, and its current status can also be queried. attribute, and its current status can also be queried.
enable: enable:
@ -252,7 +249,7 @@ Sysfs notes:
1: enables Bluetooth / Bluetooth is enabled. 1: enables Bluetooth / Bluetooth is enabled.
Note: this interface will be probably be superseeded by the Note: this interface will be probably be superseeded by the
generic rfkill class. generic rfkill class, so it is NOT to be considered stable yet.
Video output control -- /proc/acpi/ibm/video Video output control -- /proc/acpi/ibm/video
-------------------------------------------- --------------------------------------------
@ -898,7 +895,7 @@ EXPERIMENTAL: WAN
----------------- -----------------
procfs: /proc/acpi/ibm/wan procfs: /proc/acpi/ibm/wan
sysfs device attribute: wwan/enable sysfs device attribute: wwan_enable
This feature is marked EXPERIMENTAL because the implementation This feature is marked EXPERIMENTAL because the implementation
directly accesses hardware registers and may not work as expected. USE directly accesses hardware registers and may not work as expected. USE
@ -921,7 +918,7 @@ If the W-WAN card is installed, the following commands can be used:
Sysfs notes: Sysfs notes:
If the W-WAN card is installed, it can be enabled / If the W-WAN card is installed, it can be enabled /
disabled through the "wwan/enable" thinkpad-acpi device disabled through the "wwan_enable" thinkpad-acpi device
attribute, and its current status can also be queried. attribute, and its current status can also be queried.
enable: enable:
@ -929,7 +926,7 @@ Sysfs notes:
1: enables WWAN card / WWAN card is enabled. 1: enables WWAN card / WWAN card is enabled.
Note: this interface will be probably be superseeded by the Note: this interface will be probably be superseeded by the
generic rfkill class. generic rfkill class, so it is NOT to be considered stable yet.
Multiple Commands, Module Parameters Multiple Commands, Module Parameters
------------------------------------ ------------------------------------

View File

@ -59,7 +59,7 @@ int node_to_pxm(int node)
return node_to_pxm_map[node]; return node_to_pxm_map[node];
} }
int __cpuinit acpi_map_pxm_to_node(int pxm) int acpi_map_pxm_to_node(int pxm)
{ {
int node = pxm_to_node_map[pxm]; int node = pxm_to_node_map[pxm];

View File

@ -123,14 +123,14 @@ acpi_tb_add_table(struct acpi_table_desc *table_desc,
} }
} }
/* The table must be either an SSDT or a PSDT */ /* The table must be either an SSDT or a PSDT or an OEMx */
if ((!ACPI_COMPARE_NAME(table_desc->pointer->signature, ACPI_SIG_PSDT)) if ((!ACPI_COMPARE_NAME(table_desc->pointer->signature, ACPI_SIG_PSDT))
&& &&
(!ACPI_COMPARE_NAME(table_desc->pointer->signature, ACPI_SIG_SSDT))) (!ACPI_COMPARE_NAME(table_desc->pointer->signature, ACPI_SIG_SSDT))
{ && (strncmp(table_desc->pointer->signature, "OEM", 3))) {
ACPI_ERROR((AE_INFO, ACPI_ERROR((AE_INFO,
"Table has invalid signature [%4.4s], must be SSDT or PSDT", "Table has invalid signature [%4.4s], must be SSDT, PSDT or OEMx",
table_desc->pointer->signature)); table_desc->pointer->signature));
return_ACPI_STATUS(AE_BAD_SIGNATURE); return_ACPI_STATUS(AE_BAD_SIGNATURE);
} }

View File

@ -827,6 +827,7 @@ static int acpi_thermal_temp_open_fs(struct inode *inode, struct file *file)
static int acpi_thermal_trip_seq_show(struct seq_file *seq, void *offset) static int acpi_thermal_trip_seq_show(struct seq_file *seq, void *offset)
{ {
struct acpi_thermal *tz = seq->private; struct acpi_thermal *tz = seq->private;
struct acpi_device *device;
int i = 0; int i = 0;
int j = 0; int j = 0;
@ -849,9 +850,8 @@ static int acpi_thermal_trip_seq_show(struct seq_file *seq, void *offset)
tz->trips.passive.tc1, tz->trips.passive.tc2, tz->trips.passive.tc1, tz->trips.passive.tc2,
tz->trips.passive.tsp); tz->trips.passive.tsp);
for (j = 0; j < tz->trips.passive.devices.count; j++) { for (j = 0; j < tz->trips.passive.devices.count; j++) {
acpi_bus_get_device(tz->trips.passive.devices.handles[j], &device);
seq_printf(seq, "0x%p ", seq_printf(seq, "%4.4s ", acpi_device_bid(device));
tz->trips.passive.devices.handles[j]);
} }
seq_puts(seq, "\n"); seq_puts(seq, "\n");
} }
@ -862,9 +862,10 @@ static int acpi_thermal_trip_seq_show(struct seq_file *seq, void *offset)
seq_printf(seq, "active[%d]: %ld C: devices=", seq_printf(seq, "active[%d]: %ld C: devices=",
i, i,
KELVIN_TO_CELSIUS(tz->trips.active[i].temperature)); KELVIN_TO_CELSIUS(tz->trips.active[i].temperature));
for (j = 0; j < tz->trips.active[i].devices.count; j++) for (j = 0; j < tz->trips.active[i].devices.count; j++){
seq_printf(seq, "0x%p ", acpi_bus_get_device(tz->trips.active[i].devices.handles[j], &device);
tz->trips.active[i].devices.handles[j]); seq_printf(seq, "%4.4s ", acpi_device_bid(device));
}
seq_puts(seq, "\n"); seq_puts(seq, "\n");
} }

View File

@ -67,6 +67,10 @@ static acpi_status
acpi_ut_copy_esimple_to_isimple(union acpi_object *user_obj, acpi_ut_copy_esimple_to_isimple(union acpi_object *user_obj,
union acpi_operand_object **return_obj); union acpi_operand_object **return_obj);
static acpi_status
acpi_ut_copy_epackage_to_ipackage(union acpi_object *external_object,
union acpi_operand_object **internal_object);
static acpi_status static acpi_status
acpi_ut_copy_simple_object(union acpi_operand_object *source_desc, acpi_ut_copy_simple_object(union acpi_operand_object *source_desc,
union acpi_operand_object *dest_desc); union acpi_operand_object *dest_desc);
@ -518,77 +522,73 @@ acpi_ut_copy_esimple_to_isimple(union acpi_object *external_object,
return_ACPI_STATUS(AE_NO_MEMORY); return_ACPI_STATUS(AE_NO_MEMORY);
} }
#ifdef ACPI_FUTURE_IMPLEMENTATION
/* Code to convert packages that are parameters to control methods */
/******************************************************************************* /*******************************************************************************
* *
* FUNCTION: acpi_ut_copy_epackage_to_ipackage * FUNCTION: acpi_ut_copy_epackage_to_ipackage
* *
* PARAMETERS: *internal_object - Pointer to the object we are returning * PARAMETERS: external_object - The external object to be converted
* *Buffer - Where the object is returned * internal_object - Where the internal object is returned
* *space_used - Where the length of the object is returned
* *
* RETURN: Status * RETURN: Status
* *
* DESCRIPTION: This function is called to place a package object in a user * DESCRIPTION: Copy an external package object to an internal package.
* buffer. A package object by definition contains other objects. * Handles nested packages.
*
* The buffer is assumed to have sufficient space for the object.
* The caller must have verified the buffer length needed using the
* acpi_ut_get_object_size function before calling this function.
* *
******************************************************************************/ ******************************************************************************/
static acpi_status static acpi_status
acpi_ut_copy_epackage_to_ipackage(union acpi_operand_object *internal_object, acpi_ut_copy_epackage_to_ipackage(union acpi_object *external_object,
u8 * buffer, u32 * space_used) union acpi_operand_object **internal_object)
{ {
u8 *free_space; acpi_status status = AE_OK;
union acpi_object *external_object; union acpi_operand_object *package_object;
u32 length = 0; union acpi_operand_object **package_elements;
u32 this_index; acpi_native_uint i;
u32 object_space = 0;
union acpi_operand_object *this_internal_obj;
union acpi_object *this_external_obj;
ACPI_FUNCTION_TRACE(ut_copy_epackage_to_ipackage); ACPI_FUNCTION_TRACE(ut_copy_epackage_to_ipackage);
/* /* Create the package object */
* First package at head of the buffer
*/ package_object =
external_object = (union acpi_object *)buffer; acpi_ut_create_package_object(external_object->package.count);
if (!package_object) {
return_ACPI_STATUS(AE_NO_MEMORY);
}
package_elements = package_object->package.elements;
/* /*
* Free space begins right after the first package * Recursive implementation. Probably ok, since nested external packages
* as parameters should be very rare.
*/ */
free_space = buffer + sizeof(union acpi_object); for (i = 0; i < external_object->package.count; i++) {
status =
acpi_ut_copy_eobject_to_iobject(&external_object->package.
elements[i],
&package_elements[i]);
if (ACPI_FAILURE(status)) {
external_object->type = ACPI_GET_OBJECT_TYPE(internal_object); /* Truncate package and delete it */
external_object->package.count = internal_object->package.count;
external_object->package.elements = (union acpi_object *)free_space;
/* package_object->package.count = i;
* Build an array of ACPI_OBJECTS in the buffer package_elements[i] = NULL;
* and move the free space past it acpi_ut_remove_reference(package_object);
*/ return_ACPI_STATUS(status);
free_space += }
external_object->package.count * sizeof(union acpi_object); }
/* Call walk_package */
*internal_object = package_object;
return_ACPI_STATUS(status);
} }
#endif /* Future implementation */
/******************************************************************************* /*******************************************************************************
* *
* FUNCTION: acpi_ut_copy_eobject_to_iobject * FUNCTION: acpi_ut_copy_eobject_to_iobject
* *
* PARAMETERS: *internal_object - The external object to be converted * PARAMETERS: external_object - The external object to be converted
* *buffer_ptr - Where the internal object is returned * internal_object - Where the internal object is returned
* *
* RETURN: Status - the status of the call * RETURN: Status - the status of the call
* *
* DESCRIPTION: Converts an external object to an internal object. * DESCRIPTION: Converts an external object to an internal object.
* *
@ -603,16 +603,10 @@ acpi_ut_copy_eobject_to_iobject(union acpi_object *external_object,
ACPI_FUNCTION_TRACE(ut_copy_eobject_to_iobject); ACPI_FUNCTION_TRACE(ut_copy_eobject_to_iobject);
if (external_object->type == ACPI_TYPE_PACKAGE) { if (external_object->type == ACPI_TYPE_PACKAGE) {
/* status =
* Packages as external input to control methods are not supported, acpi_ut_copy_epackage_to_ipackage(external_object,
*/ internal_object);
ACPI_ERROR((AE_INFO, } else {
"Packages as parameters not implemented!"));
return_ACPI_STATUS(AE_NOT_IMPLEMENTED);
}
else {
/* /*
* Build a simple object (no nested objects) * Build a simple object (no nested objects)
*/ */
@ -803,33 +797,19 @@ acpi_ut_copy_ielement_to_ielement(u8 object_type,
* Create and build the package object * Create and build the package object
*/ */
target_object = target_object =
acpi_ut_create_internal_object(ACPI_TYPE_PACKAGE); acpi_ut_create_package_object(source_object->package.count);
if (!target_object) { if (!target_object) {
return (AE_NO_MEMORY); return (AE_NO_MEMORY);
} }
target_object->package.count = source_object->package.count;
target_object->common.flags = source_object->common.flags; target_object->common.flags = source_object->common.flags;
/* /* Pass the new package object back to the package walk routine */
* Create the object array
*/
target_object->package.elements =
ACPI_ALLOCATE_ZEROED(((acpi_size) source_object->package.
count + 1) * sizeof(void *));
if (!target_object->package.elements) {
status = AE_NO_MEMORY;
goto error_exit;
}
/*
* Pass the new package object back to the package walk routine
*/
state->pkg.this_target_obj = target_object; state->pkg.this_target_obj = target_object;
/* /* Store the object pointer in the parent package object */
* Store the object pointer in the parent package object
*/
*this_target_ptr = target_object; *this_target_ptr = target_object;
break; break;

View File

@ -144,6 +144,48 @@ union acpi_operand_object *acpi_ut_create_internal_object_dbg(char *module_name,
return_PTR(object); return_PTR(object);
} }
/*******************************************************************************
*
* FUNCTION: acpi_ut_create_package_object
*
* PARAMETERS: Count - Number of package elements
*
* RETURN: Pointer to a new Package object, null on failure
*
* DESCRIPTION: Create a fully initialized package object
*
******************************************************************************/
union acpi_operand_object *acpi_ut_create_package_object(u32 count)
{
union acpi_operand_object *package_desc;
union acpi_operand_object **package_elements;
ACPI_FUNCTION_TRACE_U32(ut_create_package_object, count);
/* Create a new Package object */
package_desc = acpi_ut_create_internal_object(ACPI_TYPE_PACKAGE);
if (!package_desc) {
return_PTR(NULL);
}
/*
* Create the element array. Count+1 allows the array to be null
* terminated.
*/
package_elements = ACPI_ALLOCATE_ZEROED((acpi_size)
(count + 1) * sizeof(void *));
if (!package_elements) {
ACPI_FREE(package_desc);
return_PTR(NULL);
}
package_desc->package.count = count;
package_desc->package.elements = package_elements;
return_PTR(package_desc);
}
/******************************************************************************* /*******************************************************************************
* *
* FUNCTION: acpi_ut_create_buffer_object * FUNCTION: acpi_ut_create_buffer_object

View File

@ -740,7 +740,7 @@ static ssize_t hotkey_enable_store(struct device *dev,
} }
static struct device_attribute dev_attr_hotkey_enable = static struct device_attribute dev_attr_hotkey_enable =
__ATTR(enable, S_IWUSR | S_IRUGO, __ATTR(hotkey_enable, S_IWUSR | S_IRUGO,
hotkey_enable_show, hotkey_enable_store); hotkey_enable_show, hotkey_enable_store);
/* sysfs hotkey mask --------------------------------------------------- */ /* sysfs hotkey mask --------------------------------------------------- */
@ -775,7 +775,7 @@ static ssize_t hotkey_mask_store(struct device *dev,
} }
static struct device_attribute dev_attr_hotkey_mask = static struct device_attribute dev_attr_hotkey_mask =
__ATTR(mask, S_IWUSR | S_IRUGO, __ATTR(hotkey_mask, S_IWUSR | S_IRUGO,
hotkey_mask_show, hotkey_mask_store); hotkey_mask_show, hotkey_mask_store);
/* sysfs hotkey bios_enabled ------------------------------------------- */ /* sysfs hotkey bios_enabled ------------------------------------------- */
@ -787,7 +787,7 @@ static ssize_t hotkey_bios_enabled_show(struct device *dev,
} }
static struct device_attribute dev_attr_hotkey_bios_enabled = static struct device_attribute dev_attr_hotkey_bios_enabled =
__ATTR(bios_enabled, S_IRUGO, hotkey_bios_enabled_show, NULL); __ATTR(hotkey_bios_enabled, S_IRUGO, hotkey_bios_enabled_show, NULL);
/* sysfs hotkey bios_mask ---------------------------------------------- */ /* sysfs hotkey bios_mask ---------------------------------------------- */
static ssize_t hotkey_bios_mask_show(struct device *dev, static ssize_t hotkey_bios_mask_show(struct device *dev,
@ -798,7 +798,7 @@ static ssize_t hotkey_bios_mask_show(struct device *dev,
} }
static struct device_attribute dev_attr_hotkey_bios_mask = static struct device_attribute dev_attr_hotkey_bios_mask =
__ATTR(bios_mask, S_IRUGO, hotkey_bios_mask_show, NULL); __ATTR(hotkey_bios_mask, S_IRUGO, hotkey_bios_mask_show, NULL);
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
@ -824,8 +824,7 @@ static int __init hotkey_init(struct ibm_init_struct *iibm)
str_supported(tp_features.hotkey)); str_supported(tp_features.hotkey));
if (tp_features.hotkey) { if (tp_features.hotkey) {
hotkey_dev_attributes = create_attr_set(4, hotkey_dev_attributes = create_attr_set(4, NULL);
TPACPI_HOTKEY_SYSFS_GROUP);
if (!hotkey_dev_attributes) if (!hotkey_dev_attributes)
return -ENOMEM; return -ENOMEM;
res = add_to_attr_set(hotkey_dev_attributes, res = add_to_attr_set(hotkey_dev_attributes,
@ -1050,7 +1049,7 @@ static ssize_t bluetooth_enable_store(struct device *dev,
} }
static struct device_attribute dev_attr_bluetooth_enable = static struct device_attribute dev_attr_bluetooth_enable =
__ATTR(enable, S_IWUSR | S_IRUGO, __ATTR(bluetooth_enable, S_IWUSR | S_IRUGO,
bluetooth_enable_show, bluetooth_enable_store); bluetooth_enable_show, bluetooth_enable_store);
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
@ -1061,7 +1060,6 @@ static struct attribute *bluetooth_attributes[] = {
}; };
static const struct attribute_group bluetooth_attr_group = { static const struct attribute_group bluetooth_attr_group = {
.name = TPACPI_BLUETH_SYSFS_GROUP,
.attrs = bluetooth_attributes, .attrs = bluetooth_attributes,
}; };
@ -1215,7 +1213,7 @@ static ssize_t wan_enable_store(struct device *dev,
} }
static struct device_attribute dev_attr_wan_enable = static struct device_attribute dev_attr_wan_enable =
__ATTR(enable, S_IWUSR | S_IRUGO, __ATTR(wwan_enable, S_IWUSR | S_IRUGO,
wan_enable_show, wan_enable_store); wan_enable_show, wan_enable_store);
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
@ -1226,7 +1224,6 @@ static struct attribute *wan_attributes[] = {
}; };
static const struct attribute_group wan_attr_group = { static const struct attribute_group wan_attr_group = {
.name = TPACPI_WAN_SYSFS_GROUP,
.attrs = wan_attributes, .attrs = wan_attributes,
}; };

View File

@ -278,8 +278,6 @@ static int beep_write(char *buf);
* Bluetooth subdriver * Bluetooth subdriver
*/ */
#define TPACPI_BLUETH_SYSFS_GROUP "bluetooth"
enum { enum {
/* ACPI GBDC/SBDC bits */ /* ACPI GBDC/SBDC bits */
TP_ACPI_BLUETOOTH_HWPRESENT = 0x01, /* Bluetooth hw available */ TP_ACPI_BLUETOOTH_HWPRESENT = 0x01, /* Bluetooth hw available */
@ -416,8 +414,6 @@ static int fan_write_cmd_watchdog(const char *cmd, int *rc);
* Hotkey subdriver * Hotkey subdriver
*/ */
#define TPACPI_HOTKEY_SYSFS_GROUP "hotkey"
static int hotkey_orig_status; static int hotkey_orig_status;
static int hotkey_orig_mask; static int hotkey_orig_mask;
@ -553,8 +549,6 @@ static int volume_write(char *buf);
* Wan subdriver * Wan subdriver
*/ */
#define TPACPI_WAN_SYSFS_GROUP "wwan"
enum { enum {
/* ACPI GWAN/SWAN bits */ /* ACPI GWAN/SWAN bits */
TP_ACPI_WANCARD_HWPRESENT = 0x01, /* Wan hw available */ TP_ACPI_WANCARD_HWPRESENT = 0x01, /* Wan hw available */

View File

@ -13,7 +13,7 @@
extern int pxm_to_node(int); extern int pxm_to_node(int);
extern int node_to_pxm(int); extern int node_to_pxm(int);
extern int __cpuinit acpi_map_pxm_to_node(int); extern int acpi_map_pxm_to_node(int);
extern void __cpuinit acpi_unmap_pxm_to_node(int); extern void __cpuinit acpi_unmap_pxm_to_node(int);
#endif /* CONFIG_ACPI_NUMA */ #endif /* CONFIG_ACPI_NUMA */

View File

@ -390,6 +390,8 @@ void acpi_ut_delete_object_desc(union acpi_operand_object *object);
u8 acpi_ut_valid_internal_object(void *object); u8 acpi_ut_valid_internal_object(void *object);
union acpi_operand_object *acpi_ut_create_package_object(u32 count);
union acpi_operand_object *acpi_ut_create_buffer_object(acpi_size buffer_size); union acpi_operand_object *acpi_ut_create_buffer_object(acpi_size buffer_size);
union acpi_operand_object *acpi_ut_create_string_object(acpi_size string_size); union acpi_operand_object *acpi_ut_create_string_object(acpi_size string_size);