ACPI updates for 5.4-rc1

- Update the ACPICA code in the kernel to upstream revision 20190816
    including:
    * Internal limits change to support larger systems (Bob Moore).
    * Macros clean up (Bob Moore).
    * printf format string fixes (Bob Moore).
    * Full deployment of the ACPI_PRINTF_LIKE macro (Bob Moore).
    * Tools improvements (Bob Moore, Colin Ian King).
    * Windows _OSI support fixes (Jung-uk Kim).
 
  - Improve memory hot-add support in the ACPI HMAT handling code (Dan
    Williams, Keith Busch).
 
  - Fix the ACPI LPSS (Low-Power Subsystem) driver for Intel SoCs to
    save and restore private registers during system-wide suspend and
    resume on systems with the Lynxpoint PCH (Jarkko Nikula).
 
  - Convert the ACPI documentation related to LEDs to ReST (Sakari
    Ailus).
 
  - Fix assorted issues and make assorted minor improvements in the
    ACPI-related code (Al Stone, Andy Shevchenko, Jiri Slaby, Kelsey
    Skunberg, Krzysztof Wilczynski, Liguang Zhang, Wenwen Wang,
    YueHaibing).
 -----BEGIN PGP SIGNATURE-----
 
 iQJGBAABCAAwFiEE4fcc61cGeeHD/fCwgsRv/nhiVHEFAl2ArjwSHHJqd0Byand5
 c29ja2kubmV0AAoJEILEb/54YlRxTwIP/1z6g8tO8B8pFSjp1C7+Mw6hxfVIONtp
 gzO0FRwopeUI0pD6frdfDAXLATFk/qEOWVEA+iGHm79BhuVIl6EbEnPbDaMeHE2L
 27OhUw+0URukFbWdHvw5pykgs5EYJPXPYewTYyOVGR7v+7EZLMw7dHqs9yJgGCpN
 nTr1eE6zAstujEwLKed0zqs2g7nIariTCxxwvY85lEpnn8aFSqrMA6f9Xg539YUs
 O1jevdpFAJFreRaXfq2ip1sOJq1uGGzieG1wHM1g7UR9g2lHdPioAz0jDb5Bvuxo
 VF+Hu5V6S7VtCrYFZVsVNVbVfoGynasP4T/Cz0ERzeaGYqP7nVkpaegd/19P9nyZ
 ySQUyObL248ZJVHvIrgrBNVwXj0b4ukLhvu+X/Yymlt+TGgokswQSOiwYqu41jIQ
 ieCVCnIju62IsrhTKxEl8xFA4UfhNylOYGK1fPKYqHz7cstuoiU5n+SBiMJW2T0y
 DKbuQ5mSZ167vGjbCw1XrkZlL5eW2BYBg53SE4ol+YESFLkACxN8z7THQsQe+wdr
 AiUw3aNnawRZG5z+qhsHJEEC+5XRSn1OnHG5TKyPZnmpYvwc8gv/DEss3PDWuSjA
 ychgJvfFVgvkNXjDPgNlyau9WYAeITJO+Hoe+D+nhj/klefU9AcJSbDrvK1rORmk
 Tm9yuxh9PiJW
 =2Tf0
 -----END PGP SIGNATURE-----

Merge tag 'acpi-5.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm

Pull ACPI updates from Rafael Wysocki:
 "These include an ACPICA update (to upstream revision 20190816),
  improvements of support for memory hot-add in the HMAT handling code
  and some assorted fixes and cleanups.

  Specifics:

   - Update the ACPICA code in the kernel to upstream revision 20190816
     including:
      * Internal limits change to support larger systems (Bob Moore).
      * Macros clean up (Bob Moore).
      * printf format string fixes (Bob Moore).
      * Full deployment of the ACPI_PRINTF_LIKE macro (Bob Moore).
      * Tools improvements (Bob Moore, Colin Ian King).
      * Windows _OSI support fixes (Jung-uk Kim).

   - Improve memory hot-add support in the ACPI HMAT handling code (Dan
     Williams, Keith Busch).

   - Fix the ACPI LPSS (Low-Power Subsystem) driver for Intel SoCs to
     save and restore private registers during system-wide suspend and
     resume on systems with the Lynxpoint PCH (Jarkko Nikula).

   - Convert the ACPI documentation related to LEDs to ReST (Sakari
     Ailus).

   - Fix assorted issues and make assorted minor improvements in the
     ACPI-related code (Al Stone, Andy Shevchenko, Jiri Slaby, Kelsey
     Skunberg, Krzysztof Wilczynski, Liguang Zhang, Wenwen Wang,
     YueHaibing)"

* tag 'acpi-5.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (23 commits)
  ACPI / PCI: fix acpi_pci_irq_enable() memory leak
  ACPI: custom_method: fix memory leaks
  ACPI: thermal: Remove redundant acpi_has_method() calls
  ACPI / CPPC: do not require the _PSD method
  ACPI: SBS: remove unused const variable 'SMBUS_PEC'
  ACPI / LPSS: Save/restore LPSS private registers also on Lynxpoint
  ACPI/PCI: Remove surplus parentheses from a return statement
  ACPICA: Update version to 20190816.
  ACPICA: Add "Windows 2019" string to _OSI support.
  ACPICA: Differentiate Windows 8.1 from Windows 8.
  ACPICA: Fully deploy ACPI_PRINTF_LIKE macro
  ACPICA: iASL,acpi_dump: Improve y/n query
  ACPICA: Fix issues with arg types within printf format strings
  ACPICA: Macros: remove pointer math on a null pointer
  ACPICA: Increase total number of possible Owner IDs
  ACPICA: Debugger: remove redundant assignment on obj_desc
  Documentation: ACPI: DSD: Convert LED documentation to ReST
  ACPI / APEI: Release resources if gen_pool_add() fails
  HMAT: Skip publishing target info for nodes with no online memory
  HMAT: Register attributes for memory hot add
  ...
This commit is contained in:
Linus Torvalds 2019-09-17 19:31:36 -07:00
commit d2aaa49e28
36 changed files with 287 additions and 154 deletions

View File

@ -1,4 +1,9 @@
.. SPDX-License-Identifier: GPL-2.0
.. include:: <isonum.txt>
========================================
Describing and referring to LEDs in ACPI Describing and referring to LEDs in ACPI
========================================
Individual LEDs are described by hierarchical data extension [6] nodes under the Individual LEDs are described by hierarchical data extension [6] nodes under the
device node, the LED driver chip. The "reg" property in the LED specific nodes device node, the LED driver chip. The "reg" property in the LED specific nodes
@ -25,8 +30,12 @@ entry shall contain the string "led@" followed by the number of the LED,
followed by the referred object name. That object shall be named "LED" followed followed by the referred object name. That object shall be named "LED" followed
by the number of the LED. by the number of the LED.
An ASL example of a camera sensor device and a LED driver device for two LEDs. Example
Objects not relevant for LEDs or the references to them have been omitted. =======
An ASL example of a camera sensor device and a LED driver device for two LEDs is
show below. Objects not relevant for LEDs or the references to them have been
omitted. ::
Device (LED) Device (LED)
{ {
@ -71,12 +80,15 @@ Objects not relevant for LEDs or the references to them have been omitted.
} }
where where
::
LED LED driver device LED LED driver device
LED0 First LED LED0 First LED
LED1 Second LED LED1 Second LED
SEN Camera sensor device (or another device the LED is SEN Camera sensor device (or another device the LED is related to)
related to)
References
==========
[1] Device tree. <URL:http://www.devicetree.org>, referenced 2019-02-21. [1] Device tree. <URL:http://www.devicetree.org>, referenced 2019-02-21.

View File

@ -10,6 +10,7 @@ ACPI Support
namespace namespace
dsd/graph dsd/graph
dsd/data-node-references dsd/data-node-references
dsd/leds
enumeration enumeration
osi osi
method-customizing method-customizing

View File

@ -219,12 +219,13 @@ static void bsw_pwm_setup(struct lpss_private_data *pdata)
} }
static const struct lpss_device_desc lpt_dev_desc = { static const struct lpss_device_desc lpt_dev_desc = {
.flags = LPSS_CLK | LPSS_CLK_GATE | LPSS_CLK_DIVIDER | LPSS_LTR, .flags = LPSS_CLK | LPSS_CLK_GATE | LPSS_CLK_DIVIDER | LPSS_LTR
| LPSS_SAVE_CTX,
.prv_offset = 0x800, .prv_offset = 0x800,
}; };
static const struct lpss_device_desc lpt_i2c_dev_desc = { static const struct lpss_device_desc lpt_i2c_dev_desc = {
.flags = LPSS_CLK | LPSS_CLK_GATE | LPSS_LTR, .flags = LPSS_CLK | LPSS_CLK_GATE | LPSS_LTR | LPSS_SAVE_CTX,
.prv_offset = 0x800, .prv_offset = 0x800,
}; };
@ -236,7 +237,8 @@ static struct property_entry uart_properties[] = {
}; };
static const struct lpss_device_desc lpt_uart_dev_desc = { static const struct lpss_device_desc lpt_uart_dev_desc = {
.flags = LPSS_CLK | LPSS_CLK_GATE | LPSS_CLK_DIVIDER | LPSS_LTR, .flags = LPSS_CLK | LPSS_CLK_GATE | LPSS_CLK_DIVIDER | LPSS_LTR
| LPSS_SAVE_CTX,
.clk_con_id = "baudclk", .clk_con_id = "baudclk",
.prv_offset = 0x800, .prv_offset = 0x800,
.setup = lpss_uart_setup, .setup = lpss_uart_setup,

View File

@ -279,6 +279,10 @@ static int acpi_processor_get_info(struct acpi_device *device)
} }
if (acpi_duplicate_processor_id(pr->acpi_id)) { if (acpi_duplicate_processor_id(pr->acpi_id)) {
if (pr->acpi_id == 0xff)
dev_info_once(&device->dev,
"Entry not well-defined, consider updating BIOS\n");
else
dev_err(&device->dev, dev_err(&device->dev,
"Failed to get unique processor _UID (0x%x)\n", "Failed to get unique processor _UID (0x%x)\n",
pr->acpi_id); pr->acpi_id);

View File

@ -134,12 +134,12 @@ struct acpi_namespace_node {
union acpi_operand_object *object; /* Interpreter object */ union acpi_operand_object *object; /* Interpreter object */
u8 descriptor_type; /* Differentiate object descriptor types */ u8 descriptor_type; /* Differentiate object descriptor types */
u8 type; /* ACPI Type associated with this name */ u8 type; /* ACPI Type associated with this name */
u8 flags; /* Miscellaneous flags */ u16 flags; /* Miscellaneous flags */
acpi_owner_id owner_id; /* Node creator */
union acpi_name_union name; /* ACPI Name, always 4 chars per ACPI spec */ union acpi_name_union name; /* ACPI Name, always 4 chars per ACPI spec */
struct acpi_namespace_node *parent; /* Parent node */ struct acpi_namespace_node *parent; /* Parent node */
struct acpi_namespace_node *child; /* First child */ struct acpi_namespace_node *child; /* First child */
struct acpi_namespace_node *peer; /* First peer */ struct acpi_namespace_node *peer; /* First peer */
acpi_owner_id owner_id; /* Node creator */
/* /*
* The following fields are used by the ASL compiler and disassembler only * The following fields are used by the ASL compiler and disassembler only

View File

@ -153,8 +153,8 @@ struct acpi_object_method {
} dispatch; } dispatch;
u32 aml_length; u32 aml_length;
u8 thread_count;
acpi_owner_id owner_id; acpi_owner_id owner_id;
u8 thread_count;
}; };
/* Flags for info_flags field above */ /* Flags for info_flags field above */

View File

@ -167,9 +167,9 @@ struct acpi_evaluate_info {
u32 return_flags; /* Used for return value analysis */ u32 return_flags; /* Used for return value analysis */
u32 return_btype; /* Bitmapped type of the returned object */ u32 return_btype; /* Bitmapped type of the returned object */
u16 param_count; /* Count of the input argument list */ u16 param_count; /* Count of the input argument list */
u16 node_flags; /* Same as Node->Flags */
u8 pass_number; /* Parser pass number */ u8 pass_number; /* Parser pass number */
u8 return_object_type; /* Object type of the returned object */ u8 return_object_type; /* Object type of the returned object */
u8 node_flags; /* Same as Node->Flags */
u8 flags; /* General flags */ u8 flags; /* General flags */
}; };

View File

@ -686,22 +686,26 @@ void acpi_ut_delete_address_lists(void);
/* /*
* utxferror - various error/warning output functions * utxferror - various error/warning output functions
*/ */
ACPI_PRINTF_LIKE(5)
void ACPI_INTERNAL_VAR_XFACE void ACPI_INTERNAL_VAR_XFACE
acpi_ut_predefined_warning(const char *module_name, acpi_ut_predefined_warning(const char *module_name,
u32 line_number, u32 line_number,
char *pathname, char *pathname,
u8 node_flags, const char *format, ...); u16 node_flags, const char *format, ...);
ACPI_PRINTF_LIKE(5)
void ACPI_INTERNAL_VAR_XFACE void ACPI_INTERNAL_VAR_XFACE
acpi_ut_predefined_info(const char *module_name, acpi_ut_predefined_info(const char *module_name,
u32 line_number, u32 line_number,
char *pathname, u8 node_flags, const char *format, ...); char *pathname,
u16 node_flags, const char *format, ...);
ACPI_PRINTF_LIKE(5)
void ACPI_INTERNAL_VAR_XFACE void ACPI_INTERNAL_VAR_XFACE
acpi_ut_predefined_bios_error(const char *module_name, acpi_ut_predefined_bios_error(const char *module_name,
u32 line_number, u32 line_number,
char *pathname, char *pathname,
u8 node_flags, const char *format, ...); u16 node_flags, const char *format, ...);
void void
acpi_ut_prefixed_namespace_error(const char *module_name, acpi_ut_prefixed_namespace_error(const char *module_name,

View File

@ -121,7 +121,7 @@ void acpi_db_display_history(void)
for (i = 0; i < acpi_gbl_num_history; i++) { for (i = 0; i < acpi_gbl_num_history; i++) {
if (acpi_gbl_history_buffer[history_index].command) { if (acpi_gbl_history_buffer[history_index].command) {
acpi_os_printf("%3ld %s\n", acpi_os_printf("%3u %s\n",
acpi_gbl_history_buffer[history_index]. acpi_gbl_history_buffer[history_index].
cmd_num, cmd_num,
acpi_gbl_history_buffer[history_index]. acpi_gbl_history_buffer[history_index].

View File

@ -593,7 +593,7 @@ static u32 acpi_db_get_line(char *input_buffer)
input_buffer)) { input_buffer)) {
acpi_os_printf acpi_os_printf
("Buffer overflow while parsing input line (max %u characters)\n", ("Buffer overflow while parsing input line (max %u characters)\n",
sizeof(acpi_gbl_db_parsed_buf)); (u32)sizeof(acpi_gbl_db_parsed_buf));
return (0); return (0);
} }
@ -853,24 +853,24 @@ acpi_db_command_dispatch(char *input_buffer,
if (param_count == 0) { if (param_count == 0) {
acpi_os_printf acpi_os_printf
("Current debug level for file output is: %8.8lX\n", ("Current debug level for file output is: %8.8X\n",
acpi_gbl_db_debug_level); acpi_gbl_db_debug_level);
acpi_os_printf acpi_os_printf
("Current debug level for console output is: %8.8lX\n", ("Current debug level for console output is: %8.8X\n",
acpi_gbl_db_console_debug_level); acpi_gbl_db_console_debug_level);
} else if (param_count == 2) { } else if (param_count == 2) {
temp = acpi_gbl_db_console_debug_level; temp = acpi_gbl_db_console_debug_level;
acpi_gbl_db_console_debug_level = acpi_gbl_db_console_debug_level =
strtoul(acpi_gbl_db_args[1], NULL, 16); strtoul(acpi_gbl_db_args[1], NULL, 16);
acpi_os_printf acpi_os_printf
("Debug Level for console output was %8.8lX, now %8.8lX\n", ("Debug Level for console output was %8.8X, now %8.8X\n",
temp, acpi_gbl_db_console_debug_level); temp, acpi_gbl_db_console_debug_level);
} else { } else {
temp = acpi_gbl_db_debug_level; temp = acpi_gbl_db_debug_level;
acpi_gbl_db_debug_level = acpi_gbl_db_debug_level =
strtoul(acpi_gbl_db_args[1], NULL, 16); strtoul(acpi_gbl_db_args[1], NULL, 16);
acpi_os_printf acpi_os_printf
("Debug Level for file output was %8.8lX, now %8.8lX\n", ("Debug Level for file output was %8.8X, now %8.8X\n",
temp, acpi_gbl_db_debug_level); temp, acpi_gbl_db_debug_level);
} }
break; break;

View File

@ -302,6 +302,10 @@ acpi_status acpi_db_disassemble_method(char *name)
} }
status = acpi_ut_allocate_owner_id(&obj_desc->method.owner_id); status = acpi_ut_allocate_owner_id(&obj_desc->method.owner_id);
if (ACPI_FAILURE(status)) {
return (status);
}
walk_state->owner_id = obj_desc->method.owner_id; walk_state->owner_id = obj_desc->method.owner_id;
/* Push start scope on scope stack and make it current */ /* Push start scope on scope stack and make it current */

View File

@ -394,7 +394,6 @@ void acpi_db_decode_locals(struct acpi_walk_state *walk_state)
u8 display_locals = FALSE; u8 display_locals = FALSE;
node = walk_state->method_node; node = walk_state->method_node;
obj_desc = walk_state->method_desc;
/* There are no locals for the module-level code case */ /* There are no locals for the module-level code case */

View File

@ -341,17 +341,17 @@ acpi_status acpi_db_display_statistics(char *type_arg)
"ACPI_TYPE", "NODES", "OBJECTS"); "ACPI_TYPE", "NODES", "OBJECTS");
for (i = 0; i < ACPI_TYPE_NS_NODE_MAX; i++) { for (i = 0; i < ACPI_TYPE_NS_NODE_MAX; i++) {
acpi_os_printf("%16.16s % 10ld% 10ld\n", acpi_os_printf("%16.16s %10u %10u\n",
acpi_ut_get_type_name(i), acpi_ut_get_type_name(i),
acpi_gbl_node_type_count[i], acpi_gbl_node_type_count[i],
acpi_gbl_obj_type_count[i]); acpi_gbl_obj_type_count[i]);
} }
acpi_os_printf("%16.16s % 10ld% 10ld\n", "Misc/Unknown", acpi_os_printf("%16.16s %10u %10u\n", "Misc/Unknown",
acpi_gbl_node_type_count_misc, acpi_gbl_node_type_count_misc,
acpi_gbl_obj_type_count_misc); acpi_gbl_obj_type_count_misc);
acpi_os_printf("%16.16s % 10ld% 10ld\n", "TOTALS:", acpi_os_printf("%16.16s %10u %10u\n", "TOTALS:",
acpi_gbl_num_nodes, acpi_gbl_num_objects); acpi_gbl_num_nodes, acpi_gbl_num_objects);
break; break;
@ -379,16 +379,14 @@ acpi_status acpi_db_display_statistics(char *type_arg)
case CMD_STAT_MISC: case CMD_STAT_MISC:
acpi_os_printf("\nMiscellaneous Statistics:\n\n"); acpi_os_printf("\nMiscellaneous Statistics:\n\n");
acpi_os_printf("Calls to AcpiPsFind:.. ........% 7ld\n", acpi_os_printf("%-28s: %7u\n", "Calls to AcpiPsFind",
acpi_gbl_ps_find_count); acpi_gbl_ps_find_count);
acpi_os_printf("Calls to AcpiNsLookup:..........% 7ld\n", acpi_os_printf("%-28s: %7u\n", "Calls to AcpiNsLookup",
acpi_gbl_ns_lookup_count); acpi_gbl_ns_lookup_count);
acpi_os_printf("\n"); acpi_os_printf("\nMutex usage:\n\n");
acpi_os_printf("Mutex usage:\n\n");
for (i = 0; i < ACPI_NUM_MUTEX; i++) { for (i = 0; i < ACPI_NUM_MUTEX; i++) {
acpi_os_printf("%-28s: % 7ld\n", acpi_os_printf("%-28s: %7u\n",
acpi_ut_get_mutex_name(i), acpi_ut_get_mutex_name(i),
acpi_gbl_mutex_info[i].use_count); acpi_gbl_mutex_info[i].use_count);
} }
@ -399,87 +397,87 @@ acpi_status acpi_db_display_statistics(char *type_arg)
acpi_os_printf("\nInternal object sizes:\n\n"); acpi_os_printf("\nInternal object sizes:\n\n");
acpi_os_printf("Common %3d\n", acpi_os_printf("Common %3d\n",
sizeof(struct acpi_object_common)); (u32)sizeof(struct acpi_object_common));
acpi_os_printf("Number %3d\n", acpi_os_printf("Number %3d\n",
sizeof(struct acpi_object_integer)); (u32)sizeof(struct acpi_object_integer));
acpi_os_printf("String %3d\n", acpi_os_printf("String %3d\n",
sizeof(struct acpi_object_string)); (u32)sizeof(struct acpi_object_string));
acpi_os_printf("Buffer %3d\n", acpi_os_printf("Buffer %3d\n",
sizeof(struct acpi_object_buffer)); (u32)sizeof(struct acpi_object_buffer));
acpi_os_printf("Package %3d\n", acpi_os_printf("Package %3d\n",
sizeof(struct acpi_object_package)); (u32)sizeof(struct acpi_object_package));
acpi_os_printf("BufferField %3d\n", acpi_os_printf("BufferField %3d\n",
sizeof(struct acpi_object_buffer_field)); (u32)sizeof(struct acpi_object_buffer_field));
acpi_os_printf("Device %3d\n", acpi_os_printf("Device %3d\n",
sizeof(struct acpi_object_device)); (u32)sizeof(struct acpi_object_device));
acpi_os_printf("Event %3d\n", acpi_os_printf("Event %3d\n",
sizeof(struct acpi_object_event)); (u32)sizeof(struct acpi_object_event));
acpi_os_printf("Method %3d\n", acpi_os_printf("Method %3d\n",
sizeof(struct acpi_object_method)); (u32)sizeof(struct acpi_object_method));
acpi_os_printf("Mutex %3d\n", acpi_os_printf("Mutex %3d\n",
sizeof(struct acpi_object_mutex)); (u32)sizeof(struct acpi_object_mutex));
acpi_os_printf("Region %3d\n", acpi_os_printf("Region %3d\n",
sizeof(struct acpi_object_region)); (u32)sizeof(struct acpi_object_region));
acpi_os_printf("PowerResource %3d\n", acpi_os_printf("PowerResource %3d\n",
sizeof(struct acpi_object_power_resource)); (u32)sizeof(struct acpi_object_power_resource));
acpi_os_printf("Processor %3d\n", acpi_os_printf("Processor %3d\n",
sizeof(struct acpi_object_processor)); (u32)sizeof(struct acpi_object_processor));
acpi_os_printf("ThermalZone %3d\n", acpi_os_printf("ThermalZone %3d\n",
sizeof(struct acpi_object_thermal_zone)); (u32)sizeof(struct acpi_object_thermal_zone));
acpi_os_printf("RegionField %3d\n", acpi_os_printf("RegionField %3d\n",
sizeof(struct acpi_object_region_field)); (u32)sizeof(struct acpi_object_region_field));
acpi_os_printf("BankField %3d\n", acpi_os_printf("BankField %3d\n",
sizeof(struct acpi_object_bank_field)); (u32)sizeof(struct acpi_object_bank_field));
acpi_os_printf("IndexField %3d\n", acpi_os_printf("IndexField %3d\n",
sizeof(struct acpi_object_index_field)); (u32)sizeof(struct acpi_object_index_field));
acpi_os_printf("Reference %3d\n", acpi_os_printf("Reference %3d\n",
sizeof(struct acpi_object_reference)); (u32)sizeof(struct acpi_object_reference));
acpi_os_printf("Notify %3d\n", acpi_os_printf("Notify %3d\n",
sizeof(struct acpi_object_notify_handler)); (u32)sizeof(struct acpi_object_notify_handler));
acpi_os_printf("AddressSpace %3d\n", acpi_os_printf("AddressSpace %3d\n",
sizeof(struct acpi_object_addr_handler)); (u32)sizeof(struct acpi_object_addr_handler));
acpi_os_printf("Extra %3d\n", acpi_os_printf("Extra %3d\n",
sizeof(struct acpi_object_extra)); (u32)sizeof(struct acpi_object_extra));
acpi_os_printf("Data %3d\n", acpi_os_printf("Data %3d\n",
sizeof(struct acpi_object_data)); (u32)sizeof(struct acpi_object_data));
acpi_os_printf("\n"); acpi_os_printf("\n");
acpi_os_printf("ParseObject %3d\n", acpi_os_printf("ParseObject %3d\n",
sizeof(struct acpi_parse_obj_common)); (u32)sizeof(struct acpi_parse_obj_common));
acpi_os_printf("ParseObjectNamed %3d\n", acpi_os_printf("ParseObjectNamed %3d\n",
sizeof(struct acpi_parse_obj_named)); (u32)sizeof(struct acpi_parse_obj_named));
acpi_os_printf("ParseObjectAsl %3d\n", acpi_os_printf("ParseObjectAsl %3d\n",
sizeof(struct acpi_parse_obj_asl)); (u32)sizeof(struct acpi_parse_obj_asl));
acpi_os_printf("OperandObject %3d\n", acpi_os_printf("OperandObject %3d\n",
sizeof(union acpi_operand_object)); (u32)sizeof(union acpi_operand_object));
acpi_os_printf("NamespaceNode %3d\n", acpi_os_printf("NamespaceNode %3d\n",
sizeof(struct acpi_namespace_node)); (u32)sizeof(struct acpi_namespace_node));
acpi_os_printf("AcpiObject %3d\n", acpi_os_printf("AcpiObject %3d\n",
sizeof(union acpi_object)); (u32)sizeof(union acpi_object));
acpi_os_printf("\n"); acpi_os_printf("\n");
acpi_os_printf("Generic State %3d\n", acpi_os_printf("Generic State %3d\n",
sizeof(union acpi_generic_state)); (u32)sizeof(union acpi_generic_state));
acpi_os_printf("Common State %3d\n", acpi_os_printf("Common State %3d\n",
sizeof(struct acpi_common_state)); (u32)sizeof(struct acpi_common_state));
acpi_os_printf("Control State %3d\n", acpi_os_printf("Control State %3d\n",
sizeof(struct acpi_control_state)); (u32)sizeof(struct acpi_control_state));
acpi_os_printf("Update State %3d\n", acpi_os_printf("Update State %3d\n",
sizeof(struct acpi_update_state)); (u32)sizeof(struct acpi_update_state));
acpi_os_printf("Scope State %3d\n", acpi_os_printf("Scope State %3d\n",
sizeof(struct acpi_scope_state)); (u32)sizeof(struct acpi_scope_state));
acpi_os_printf("Parse Scope %3d\n", acpi_os_printf("Parse Scope %3d\n",
sizeof(struct acpi_pscope_state)); (u32)sizeof(struct acpi_pscope_state));
acpi_os_printf("Package State %3d\n", acpi_os_printf("Package State %3d\n",
sizeof(struct acpi_pkg_state)); (u32)sizeof(struct acpi_pkg_state));
acpi_os_printf("Thread State %3d\n", acpi_os_printf("Thread State %3d\n",
sizeof(struct acpi_thread_state)); (u32)sizeof(struct acpi_thread_state));
acpi_os_printf("Result Values %3d\n", acpi_os_printf("Result Values %3d\n",
sizeof(struct acpi_result_values)); (u32)sizeof(struct acpi_result_values));
acpi_os_printf("Notify Info %3d\n", acpi_os_printf("Notify Info %3d\n",
sizeof(struct acpi_notify_info)); (u32)sizeof(struct acpi_notify_info));
break; break;
case CMD_STAT_STACK: case CMD_STAT_STACK:

View File

@ -94,7 +94,7 @@ static struct acpi_exdump_info acpi_ex_dump_method[9] = {
"Parameter Count"}, "Parameter Count"},
{ACPI_EXD_UINT8, ACPI_EXD_OFFSET(method.sync_level), "Sync Level"}, {ACPI_EXD_UINT8, ACPI_EXD_OFFSET(method.sync_level), "Sync Level"},
{ACPI_EXD_POINTER, ACPI_EXD_OFFSET(method.mutex), "Mutex"}, {ACPI_EXD_POINTER, ACPI_EXD_OFFSET(method.mutex), "Mutex"},
{ACPI_EXD_UINT8, ACPI_EXD_OFFSET(method.owner_id), "Owner Id"}, {ACPI_EXD_UINT16, ACPI_EXD_OFFSET(method.owner_id), "Owner Id"},
{ACPI_EXD_UINT8, ACPI_EXD_OFFSET(method.thread_count), "Thread Count"}, {ACPI_EXD_UINT8, ACPI_EXD_OFFSET(method.thread_count), "Thread Count"},
{ACPI_EXD_UINT32, ACPI_EXD_OFFSET(method.aml_length), "Aml Length"}, {ACPI_EXD_UINT32, ACPI_EXD_OFFSET(method.aml_length), "Aml Length"},
{ACPI_EXD_POINTER, ACPI_EXD_OFFSET(method.aml_start), "Aml Start"} {ACPI_EXD_POINTER, ACPI_EXD_OFFSET(method.aml_start), "Aml Start"}
@ -269,8 +269,8 @@ static struct acpi_exdump_info acpi_ex_dump_field_common[7] = {
static struct acpi_exdump_info acpi_ex_dump_node[7] = { static struct acpi_exdump_info acpi_ex_dump_node[7] = {
{ACPI_EXD_INIT, ACPI_EXD_TABLE_SIZE(acpi_ex_dump_node), NULL}, {ACPI_EXD_INIT, ACPI_EXD_TABLE_SIZE(acpi_ex_dump_node), NULL},
{ACPI_EXD_UINT8, ACPI_EXD_NSOFFSET(flags), "Flags"}, {ACPI_EXD_UINT16, ACPI_EXD_NSOFFSET(flags), "Flags"},
{ACPI_EXD_UINT8, ACPI_EXD_NSOFFSET(owner_id), "Owner Id"}, {ACPI_EXD_UINT16, ACPI_EXD_NSOFFSET(owner_id), "Owner Id"},
{ACPI_EXD_LIST, ACPI_EXD_NSOFFSET(object), "Object List"}, {ACPI_EXD_LIST, ACPI_EXD_NSOFFSET(object), "Object List"},
{ACPI_EXD_NODE, ACPI_EXD_NSOFFSET(parent), "Parent"}, {ACPI_EXD_NODE, ACPI_EXD_NSOFFSET(parent), "Parent"},
{ACPI_EXD_NODE, ACPI_EXD_NSOFFSET(child), "Child"}, {ACPI_EXD_NODE, ACPI_EXD_NSOFFSET(child), "Child"},

View File

@ -598,7 +598,7 @@ acpi_ns_lookup(union acpi_generic_state *scope_info,
if (flags & ACPI_NS_PREFIX_MUST_EXIST) { if (flags & ACPI_NS_PREFIX_MUST_EXIST) {
acpi_os_printf(ACPI_MSG_BIOS_ERROR acpi_os_printf(ACPI_MSG_BIOS_ERROR
"Object does not exist: %4.4s\n", "Object does not exist: %4.4s\n",
&simple_name); (char *)&simple_name);
} }
#endif #endif
/* Name not found in ACPI namespace */ /* Name not found in ACPI namespace */

View File

@ -241,7 +241,7 @@ void acpi_ns_install_node(struct acpi_walk_state *walk_state, struct acpi_namesp
node->type = (u8) type; node->type = (u8) type;
ACPI_DEBUG_PRINT((ACPI_DB_NAMES, ACPI_DEBUG_PRINT((ACPI_DB_NAMES,
"%4.4s (%s) [Node %p Owner %X] added to %4.4s (%s) [Node %p]\n", "%4.4s (%s) [Node %p Owner %3.3X] added to %4.4s (%s) [Node %p]\n",
acpi_ut_get_node_name(node), acpi_ut_get_node_name(node),
acpi_ut_get_type_name(node->type), node, owner_id, acpi_ut_get_type_name(node->type), node, owner_id,
acpi_ut_get_node_name(parent_node), acpi_ut_get_node_name(parent_node),

View File

@ -197,7 +197,7 @@ acpi_ns_dump_one_object(acpi_handle obj_handle,
/* Now we can print out the pertinent information */ /* Now we can print out the pertinent information */
acpi_os_printf(" %-12s %p %2.2X ", acpi_os_printf(" %-12s %p %3.3X ",
acpi_ut_get_type_name(type), this_node, acpi_ut_get_type_name(type), this_node,
this_node->owner_id); this_node->owner_id);

View File

@ -126,7 +126,7 @@ static const struct acpi_repair_info acpi_ns_repairable_names[] = {
#define ACPI_FDE_FIELD_COUNT 5 #define ACPI_FDE_FIELD_COUNT 5
#define ACPI_FDE_BYTE_BUFFER_SIZE 5 #define ACPI_FDE_BYTE_BUFFER_SIZE 5
#define ACPI_FDE_DWORD_BUFFER_SIZE (ACPI_FDE_FIELD_COUNT * sizeof (u32)) #define ACPI_FDE_DWORD_BUFFER_SIZE (ACPI_FDE_FIELD_COUNT * (u32) sizeof (u32))
/****************************************************************************** /******************************************************************************
* *

View File

@ -750,6 +750,7 @@ acpi_status acpi_tb_delete_namespace_by_owner(u32 table_index)
if (ACPI_FAILURE(status)) { if (ACPI_FAILURE(status)) {
return_ACPI_STATUS(status); return_ACPI_STATUS(status);
} }
acpi_ns_delete_namespace_by_owner(owner_id); acpi_ns_delete_namespace_by_owner(owner_id);
acpi_ut_release_write_lock(&acpi_gbl_namespace_rw_lock); acpi_ut_release_write_lock(&acpi_gbl_namespace_rw_lock);
return_ACPI_STATUS(status); return_ACPI_STATUS(status);

View File

@ -158,7 +158,7 @@ acpi_debug_print(u32 requested_debug_level,
* Display the module name, current line number, thread ID (if requested), * Display the module name, current line number, thread ID (if requested),
* current procedure nesting level, and the current procedure name * current procedure nesting level, and the current procedure name
*/ */
acpi_os_printf("%9s-%04ld ", module_name, line_number); acpi_os_printf("%9s-%04d ", module_name, line_number);
#ifdef ACPI_APPLICATION #ifdef ACPI_APPLICATION
/* /*
@ -177,7 +177,7 @@ acpi_debug_print(u32 requested_debug_level,
fill_count = 0; fill_count = 0;
} }
acpi_os_printf("[%02ld] %*s", acpi_os_printf("[%02d] %*s",
acpi_gbl_nesting_level, acpi_gbl_nesting_level + 1, " "); acpi_gbl_nesting_level, acpi_gbl_nesting_level + 1, " ");
acpi_os_printf("%s%*s: ", acpi_os_printf("%s%*s: ",
acpi_ut_trim_function_name(function_name), fill_count, acpi_ut_trim_function_name(function_name), fill_count,

View File

@ -39,7 +39,7 @@ void ACPI_INTERNAL_VAR_XFACE
acpi_ut_predefined_warning(const char *module_name, acpi_ut_predefined_warning(const char *module_name,
u32 line_number, u32 line_number,
char *pathname, char *pathname,
u8 node_flags, const char *format, ...) u16 node_flags, const char *format, ...)
{ {
va_list arg_list; va_list arg_list;
@ -81,7 +81,7 @@ acpi_ut_predefined_warning(const char *module_name,
void ACPI_INTERNAL_VAR_XFACE void ACPI_INTERNAL_VAR_XFACE
acpi_ut_predefined_info(const char *module_name, acpi_ut_predefined_info(const char *module_name,
u32 line_number, u32 line_number,
char *pathname, u8 node_flags, const char *format, ...) char *pathname, u16 node_flags, const char *format, ...)
{ {
va_list arg_list; va_list arg_list;
@ -124,7 +124,7 @@ void ACPI_INTERNAL_VAR_XFACE
acpi_ut_predefined_bios_error(const char *module_name, acpi_ut_predefined_bios_error(const char *module_name,
u32 line_number, u32 line_number,
char *pathname, char *pathname,
u8 node_flags, const char *format, ...) u16 node_flags, const char *format, ...)
{ {
va_list arg_list; va_list arg_list;

View File

@ -65,13 +65,14 @@ static struct acpi_interface_info acpi_default_supported_interfaces[] = {
{"Windows 2006 SP2", NULL, 0, ACPI_OSI_WIN_VISTA_SP2}, /* Windows Vista SP2 - Added 09/2010 */ {"Windows 2006 SP2", NULL, 0, ACPI_OSI_WIN_VISTA_SP2}, /* Windows Vista SP2 - Added 09/2010 */
{"Windows 2009", NULL, 0, ACPI_OSI_WIN_7}, /* Windows 7 and Server 2008 R2 - Added 09/2009 */ {"Windows 2009", NULL, 0, ACPI_OSI_WIN_7}, /* Windows 7 and Server 2008 R2 - Added 09/2009 */
{"Windows 2012", NULL, 0, ACPI_OSI_WIN_8}, /* Windows 8 and Server 2012 - Added 08/2012 */ {"Windows 2012", NULL, 0, ACPI_OSI_WIN_8}, /* Windows 8 and Server 2012 - Added 08/2012 */
{"Windows 2013", NULL, 0, ACPI_OSI_WIN_8}, /* Windows 8.1 and Server 2012 R2 - Added 01/2014 */ {"Windows 2013", NULL, 0, ACPI_OSI_WIN_8_1}, /* Windows 8.1 and Server 2012 R2 - Added 01/2014 */
{"Windows 2015", NULL, 0, ACPI_OSI_WIN_10}, /* Windows 10 - Added 03/2015 */ {"Windows 2015", NULL, 0, ACPI_OSI_WIN_10}, /* Windows 10 - Added 03/2015 */
{"Windows 2016", NULL, 0, ACPI_OSI_WIN_10_RS1}, /* Windows 10 version 1607 - Added 12/2017 */ {"Windows 2016", NULL, 0, ACPI_OSI_WIN_10_RS1}, /* Windows 10 version 1607 - Added 12/2017 */
{"Windows 2017", NULL, 0, ACPI_OSI_WIN_10_RS2}, /* Windows 10 version 1703 - Added 12/2017 */ {"Windows 2017", NULL, 0, ACPI_OSI_WIN_10_RS2}, /* Windows 10 version 1703 - Added 12/2017 */
{"Windows 2017.2", NULL, 0, ACPI_OSI_WIN_10_RS3}, /* Windows 10 version 1709 - Added 02/2018 */ {"Windows 2017.2", NULL, 0, ACPI_OSI_WIN_10_RS3}, /* Windows 10 version 1709 - Added 02/2018 */
{"Windows 2018", NULL, 0, ACPI_OSI_WIN_10_RS4}, /* Windows 10 version 1803 - Added 11/2018 */ {"Windows 2018", NULL, 0, ACPI_OSI_WIN_10_RS4}, /* Windows 10 version 1803 - Added 11/2018 */
{"Windows 2018.2", NULL, 0, ACPI_OSI_WIN_10_RS5}, /* Windows 10 version 1809 - Added 11/2018 */ {"Windows 2018.2", NULL, 0, ACPI_OSI_WIN_10_RS5}, /* Windows 10 version 1809 - Added 11/2018 */
{"Windows 2019", NULL, 0, ACPI_OSI_WIN_10_19H1}, /* Windows 10 version 1903 - Added 08/2019 */
/* Feature Group Strings */ /* Feature Group Strings */

View File

@ -38,7 +38,7 @@ acpi_status acpi_ut_allocate_owner_id(acpi_owner_id *owner_id)
if (*owner_id) { if (*owner_id) {
ACPI_ERROR((AE_INFO, ACPI_ERROR((AE_INFO,
"Owner ID [0x%2.2X] already exists", *owner_id)); "Owner ID [0x%3.3X] already exists", *owner_id));
return_ACPI_STATUS(AE_ALREADY_EXISTS); return_ACPI_STATUS(AE_ALREADY_EXISTS);
} }
@ -88,14 +88,14 @@ acpi_status acpi_ut_allocate_owner_id(acpi_owner_id *owner_id)
/* /*
* Construct encoded ID from the index and bit position * Construct encoded ID from the index and bit position
* *
* Note: Last [j].k (bit 255) is never used and is marked * Note: Last [j].k (bit 4095) is never used and is marked
* permanently allocated (prevents +1 overflow) * permanently allocated (prevents +1 overflow)
*/ */
*owner_id = *owner_id =
(acpi_owner_id)((k + 1) + ACPI_MUL_32(j)); (acpi_owner_id)((k + 1) + ACPI_MUL_32(j));
ACPI_DEBUG_PRINT((ACPI_DB_VALUES, ACPI_DEBUG_PRINT((ACPI_DB_VALUES,
"Allocated OwnerId: %2.2X\n", "Allocated OwnerId: 0x%3.3X\n",
(unsigned int)*owner_id)); (unsigned int)*owner_id));
goto exit; goto exit;
} }
@ -116,7 +116,7 @@ acpi_status acpi_ut_allocate_owner_id(acpi_owner_id *owner_id)
*/ */
status = AE_OWNER_ID_LIMIT; status = AE_OWNER_ID_LIMIT;
ACPI_ERROR((AE_INFO, ACPI_ERROR((AE_INFO,
"Could not allocate new OwnerId (255 max), AE_OWNER_ID_LIMIT")); "Could not allocate new OwnerId (4095 max), AE_OWNER_ID_LIMIT"));
exit: exit:
(void)acpi_ut_release_mutex(ACPI_MTX_CACHES); (void)acpi_ut_release_mutex(ACPI_MTX_CACHES);
@ -153,7 +153,7 @@ void acpi_ut_release_owner_id(acpi_owner_id *owner_id_ptr)
/* Zero is not a valid owner_ID */ /* Zero is not a valid owner_ID */
if (owner_id == 0) { if (owner_id == 0) {
ACPI_ERROR((AE_INFO, "Invalid OwnerId: 0x%2.2X", owner_id)); ACPI_ERROR((AE_INFO, "Invalid OwnerId: 0x%3.3X", owner_id));
return_VOID; return_VOID;
} }
@ -179,7 +179,7 @@ void acpi_ut_release_owner_id(acpi_owner_id *owner_id_ptr)
acpi_gbl_owner_id_mask[index] ^= bit; acpi_gbl_owner_id_mask[index] ^= bit;
} else { } else {
ACPI_ERROR((AE_INFO, ACPI_ERROR((AE_INFO,
"Release of non-allocated OwnerId: 0x%2.2X", "Attempted release of non-allocated OwnerId: 0x%3.3X",
owner_id + 1)); owner_id + 1));
} }

View File

@ -153,6 +153,7 @@ static void ghes_unmap(void __iomem *vaddr, enum fixed_addresses fixmap_idx)
int ghes_estatus_pool_init(int num_ghes) int ghes_estatus_pool_init(int num_ghes)
{ {
unsigned long addr, len; unsigned long addr, len;
int rc;
ghes_estatus_pool = gen_pool_create(GHES_ESTATUS_POOL_MIN_ALLOC_ORDER, -1); ghes_estatus_pool = gen_pool_create(GHES_ESTATUS_POOL_MIN_ALLOC_ORDER, -1);
if (!ghes_estatus_pool) if (!ghes_estatus_pool)
@ -164,7 +165,7 @@ int ghes_estatus_pool_init(int num_ghes)
ghes_estatus_pool_size_request = PAGE_ALIGN(len); ghes_estatus_pool_size_request = PAGE_ALIGN(len);
addr = (unsigned long)vmalloc(PAGE_ALIGN(len)); addr = (unsigned long)vmalloc(PAGE_ALIGN(len));
if (!addr) if (!addr)
return -ENOMEM; goto err_pool_alloc;
/* /*
* New allocation must be visible in all pgd before it can be found by * New allocation must be visible in all pgd before it can be found by
@ -172,7 +173,19 @@ int ghes_estatus_pool_init(int num_ghes)
*/ */
vmalloc_sync_all(); vmalloc_sync_all();
return gen_pool_add(ghes_estatus_pool, addr, PAGE_ALIGN(len), -1); rc = gen_pool_add(ghes_estatus_pool, addr, PAGE_ALIGN(len), -1);
if (rc)
goto err_pool_add;
return 0;
err_pool_add:
vfree((void *)addr);
err_pool_alloc:
gen_pool_destroy(ghes_estatus_pool);
return -ENOMEM;
} }
static int map_gen_v2(struct ghes *ghes) static int map_gen_v2(struct ghes *ghes)
@ -483,7 +496,7 @@ static void ghes_do_proc(struct ghes *ghes,
int sev, sec_sev; int sev, sec_sev;
struct acpi_hest_generic_data *gdata; struct acpi_hest_generic_data *gdata;
guid_t *sec_type; guid_t *sec_type;
guid_t *fru_id = &NULL_UUID_LE; const guid_t *fru_id = &guid_null;
char *fru_text = ""; char *fru_text = "";
sev = ghes_severity(estatus->error_severity); sev = ghes_severity(estatus->error_severity);

View File

@ -365,8 +365,10 @@ static int acpi_get_psd(struct cpc_desc *cpc_ptr, acpi_handle handle)
union acpi_object *psd = NULL; union acpi_object *psd = NULL;
struct acpi_psd_package *pdomain; struct acpi_psd_package *pdomain;
status = acpi_evaluate_object_typed(handle, "_PSD", NULL, &buffer, status = acpi_evaluate_object_typed(handle, "_PSD", NULL,
ACPI_TYPE_PACKAGE); &buffer, ACPI_TYPE_PACKAGE);
if (status == AE_NOT_FOUND) /* _PSD is optional */
return 0;
if (ACPI_FAILURE(status)) if (ACPI_FAILURE(status))
return -ENODEV; return -ENODEV;

View File

@ -49,8 +49,10 @@ static ssize_t cm_write(struct file *file, const char __user * user_buf,
if ((*ppos > max_size) || if ((*ppos > max_size) ||
(*ppos + count > max_size) || (*ppos + count > max_size) ||
(*ppos + count < count) || (*ppos + count < count) ||
(count > uncopied_bytes)) (count > uncopied_bytes)) {
kfree(buf);
return -EINVAL; return -EINVAL;
}
if (copy_from_user(buf + (*ppos), user_buf, count)) { if (copy_from_user(buf + (*ppos), user_buf, count)) {
kfree(buf); kfree(buf);
@ -70,6 +72,7 @@ static ssize_t cm_write(struct file *file, const char __user * user_buf,
add_taint(TAINT_OVERRIDDEN_ACPI_TABLE, LOCKDEP_NOW_UNRELIABLE); add_taint(TAINT_OVERRIDDEN_ACPI_TABLE, LOCKDEP_NOW_UNRELIABLE);
} }
kfree(buf);
return count; return count;
} }

View File

@ -14,14 +14,18 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/list_sort.h> #include <linux/list_sort.h>
#include <linux/memory.h>
#include <linux/mutex.h>
#include <linux/node.h> #include <linux/node.h>
#include <linux/sysfs.h> #include <linux/sysfs.h>
static __initdata u8 hmat_revision; static u8 hmat_revision;
static __initdata LIST_HEAD(targets); static LIST_HEAD(targets);
static __initdata LIST_HEAD(initiators); static LIST_HEAD(initiators);
static __initdata LIST_HEAD(localities); static LIST_HEAD(localities);
static DEFINE_MUTEX(target_lock);
/* /*
* The defined enum order is used to prioritize attributes to break ties when * The defined enum order is used to prioritize attributes to break ties when
@ -36,11 +40,19 @@ enum locality_types {
static struct memory_locality *localities_types[4]; static struct memory_locality *localities_types[4];
struct target_cache {
struct list_head node;
struct node_cache_attrs cache_attrs;
};
struct memory_target { struct memory_target {
struct list_head node; struct list_head node;
unsigned int memory_pxm; unsigned int memory_pxm;
unsigned int processor_pxm; unsigned int processor_pxm;
struct node_hmem_attrs hmem_attrs; struct node_hmem_attrs hmem_attrs;
struct list_head caches;
struct node_cache_attrs cache_attrs;
bool registered;
}; };
struct memory_initiator { struct memory_initiator {
@ -53,7 +65,7 @@ struct memory_locality {
struct acpi_hmat_locality *hmat_loc; struct acpi_hmat_locality *hmat_loc;
}; };
static __init struct memory_initiator *find_mem_initiator(unsigned int cpu_pxm) static struct memory_initiator *find_mem_initiator(unsigned int cpu_pxm)
{ {
struct memory_initiator *initiator; struct memory_initiator *initiator;
@ -63,7 +75,7 @@ static __init struct memory_initiator *find_mem_initiator(unsigned int cpu_pxm)
return NULL; return NULL;
} }
static __init struct memory_target *find_mem_target(unsigned int mem_pxm) static struct memory_target *find_mem_target(unsigned int mem_pxm)
{ {
struct memory_target *target; struct memory_target *target;
@ -96,9 +108,6 @@ static __init void alloc_memory_target(unsigned int mem_pxm)
{ {
struct memory_target *target; struct memory_target *target;
if (pxm_to_node(mem_pxm) == NUMA_NO_NODE)
return;
target = find_mem_target(mem_pxm); target = find_mem_target(mem_pxm);
if (target) if (target)
return; return;
@ -110,6 +119,7 @@ static __init void alloc_memory_target(unsigned int mem_pxm)
target->memory_pxm = mem_pxm; target->memory_pxm = mem_pxm;
target->processor_pxm = PXM_INVAL; target->processor_pxm = PXM_INVAL;
list_add_tail(&target->node, &targets); list_add_tail(&target->node, &targets);
INIT_LIST_HEAD(&target->caches);
} }
static __init const char *hmat_data_type(u8 type) static __init const char *hmat_data_type(u8 type)
@ -148,7 +158,7 @@ static __init const char *hmat_data_type_suffix(u8 type)
} }
} }
static __init u32 hmat_normalize(u16 entry, u64 base, u8 type) static u32 hmat_normalize(u16 entry, u64 base, u8 type)
{ {
u32 value; u32 value;
@ -183,7 +193,7 @@ static __init u32 hmat_normalize(u16 entry, u64 base, u8 type)
return value; return value;
} }
static __init void hmat_update_target_access(struct memory_target *target, static void hmat_update_target_access(struct memory_target *target,
u8 type, u32 value) u8 type, u32 value)
{ {
switch (type) { switch (type) {
@ -314,7 +324,8 @@ static __init int hmat_parse_cache(union acpi_subtable_headers *header,
const unsigned long end) const unsigned long end)
{ {
struct acpi_hmat_cache *cache = (void *)header; struct acpi_hmat_cache *cache = (void *)header;
struct node_cache_attrs cache_attrs; struct memory_target *target;
struct target_cache *tcache;
u32 attrs; u32 attrs;
if (cache->header.length < sizeof(*cache)) { if (cache->header.length < sizeof(*cache)) {
@ -328,37 +339,47 @@ static __init int hmat_parse_cache(union acpi_subtable_headers *header,
cache->memory_PD, cache->cache_size, attrs, cache->memory_PD, cache->cache_size, attrs,
cache->number_of_SMBIOShandles); cache->number_of_SMBIOShandles);
cache_attrs.size = cache->cache_size; target = find_mem_target(cache->memory_PD);
cache_attrs.level = (attrs & ACPI_HMAT_CACHE_LEVEL) >> 4; if (!target)
cache_attrs.line_size = (attrs & ACPI_HMAT_CACHE_LINE_SIZE) >> 16; return 0;
tcache = kzalloc(sizeof(*tcache), GFP_KERNEL);
if (!tcache) {
pr_notice_once("Failed to allocate HMAT cache info\n");
return 0;
}
tcache->cache_attrs.size = cache->cache_size;
tcache->cache_attrs.level = (attrs & ACPI_HMAT_CACHE_LEVEL) >> 4;
tcache->cache_attrs.line_size = (attrs & ACPI_HMAT_CACHE_LINE_SIZE) >> 16;
switch ((attrs & ACPI_HMAT_CACHE_ASSOCIATIVITY) >> 8) { switch ((attrs & ACPI_HMAT_CACHE_ASSOCIATIVITY) >> 8) {
case ACPI_HMAT_CA_DIRECT_MAPPED: case ACPI_HMAT_CA_DIRECT_MAPPED:
cache_attrs.indexing = NODE_CACHE_DIRECT_MAP; tcache->cache_attrs.indexing = NODE_CACHE_DIRECT_MAP;
break; break;
case ACPI_HMAT_CA_COMPLEX_CACHE_INDEXING: case ACPI_HMAT_CA_COMPLEX_CACHE_INDEXING:
cache_attrs.indexing = NODE_CACHE_INDEXED; tcache->cache_attrs.indexing = NODE_CACHE_INDEXED;
break; break;
case ACPI_HMAT_CA_NONE: case ACPI_HMAT_CA_NONE:
default: default:
cache_attrs.indexing = NODE_CACHE_OTHER; tcache->cache_attrs.indexing = NODE_CACHE_OTHER;
break; break;
} }
switch ((attrs & ACPI_HMAT_WRITE_POLICY) >> 12) { switch ((attrs & ACPI_HMAT_WRITE_POLICY) >> 12) {
case ACPI_HMAT_CP_WB: case ACPI_HMAT_CP_WB:
cache_attrs.write_policy = NODE_CACHE_WRITE_BACK; tcache->cache_attrs.write_policy = NODE_CACHE_WRITE_BACK;
break; break;
case ACPI_HMAT_CP_WT: case ACPI_HMAT_CP_WT:
cache_attrs.write_policy = NODE_CACHE_WRITE_THROUGH; tcache->cache_attrs.write_policy = NODE_CACHE_WRITE_THROUGH;
break; break;
case ACPI_HMAT_CP_NONE: case ACPI_HMAT_CP_NONE:
default: default:
cache_attrs.write_policy = NODE_CACHE_WRITE_OTHER; tcache->cache_attrs.write_policy = NODE_CACHE_WRITE_OTHER;
break; break;
} }
list_add_tail(&tcache->node, &target->caches);
node_add_cache(pxm_to_node(cache->memory_PD), &cache_attrs);
return 0; return 0;
} }
@ -435,7 +456,7 @@ static __init int srat_parse_mem_affinity(union acpi_subtable_headers *header,
return 0; return 0;
} }
static __init u32 hmat_initiator_perf(struct memory_target *target, static u32 hmat_initiator_perf(struct memory_target *target,
struct memory_initiator *initiator, struct memory_initiator *initiator,
struct acpi_hmat_locality *hmat_loc) struct acpi_hmat_locality *hmat_loc)
{ {
@ -473,7 +494,7 @@ static __init u32 hmat_initiator_perf(struct memory_target *target,
hmat_loc->data_type); hmat_loc->data_type);
} }
static __init bool hmat_update_best(u8 type, u32 value, u32 *best) static bool hmat_update_best(u8 type, u32 value, u32 *best)
{ {
bool updated = false; bool updated = false;
@ -517,7 +538,7 @@ static int initiator_cmp(void *priv, struct list_head *a, struct list_head *b)
return ia->processor_pxm - ib->processor_pxm; return ia->processor_pxm - ib->processor_pxm;
} }
static __init void hmat_register_target_initiators(struct memory_target *target) static void hmat_register_target_initiators(struct memory_target *target)
{ {
static DECLARE_BITMAP(p_nodes, MAX_NUMNODES); static DECLARE_BITMAP(p_nodes, MAX_NUMNODES);
struct memory_initiator *initiator; struct memory_initiator *initiator;
@ -577,29 +598,89 @@ static __init void hmat_register_target_initiators(struct memory_target *target)
} }
} }
static __init void hmat_register_target_perf(struct memory_target *target) static void hmat_register_target_cache(struct memory_target *target)
{
unsigned mem_nid = pxm_to_node(target->memory_pxm);
struct target_cache *tcache;
list_for_each_entry(tcache, &target->caches, node)
node_add_cache(mem_nid, &tcache->cache_attrs);
}
static void hmat_register_target_perf(struct memory_target *target)
{ {
unsigned mem_nid = pxm_to_node(target->memory_pxm); unsigned mem_nid = pxm_to_node(target->memory_pxm);
node_set_perf_attrs(mem_nid, &target->hmem_attrs, 0); node_set_perf_attrs(mem_nid, &target->hmem_attrs, 0);
} }
static __init void hmat_register_targets(void) static void hmat_register_target(struct memory_target *target)
{
int nid = pxm_to_node(target->memory_pxm);
/*
* Skip offline nodes. This can happen when memory
* marked EFI_MEMORY_SP, "specific purpose", is applied
* to all the memory in a promixity domain leading to
* the node being marked offline / unplugged, or if
* memory-only "hotplug" node is offline.
*/
if (nid == NUMA_NO_NODE || !node_online(nid))
return;
mutex_lock(&target_lock);
if (!target->registered) {
hmat_register_target_initiators(target);
hmat_register_target_cache(target);
hmat_register_target_perf(target);
target->registered = true;
}
mutex_unlock(&target_lock);
}
static void hmat_register_targets(void)
{ {
struct memory_target *target; struct memory_target *target;
list_for_each_entry(target, &targets, node) { list_for_each_entry(target, &targets, node)
hmat_register_target_initiators(target); hmat_register_target(target);
hmat_register_target_perf(target);
} }
static int hmat_callback(struct notifier_block *self,
unsigned long action, void *arg)
{
struct memory_target *target;
struct memory_notify *mnb = arg;
int pxm, nid = mnb->status_change_nid;
if (nid == NUMA_NO_NODE || action != MEM_ONLINE)
return NOTIFY_OK;
pxm = node_to_pxm(nid);
target = find_mem_target(pxm);
if (!target)
return NOTIFY_OK;
hmat_register_target(target);
return NOTIFY_OK;
} }
static struct notifier_block hmat_callback_nb = {
.notifier_call = hmat_callback,
.priority = 2,
};
static __init void hmat_free_structures(void) static __init void hmat_free_structures(void)
{ {
struct memory_target *target, *tnext; struct memory_target *target, *tnext;
struct memory_locality *loc, *lnext; struct memory_locality *loc, *lnext;
struct memory_initiator *initiator, *inext; struct memory_initiator *initiator, *inext;
struct target_cache *tcache, *cnext;
list_for_each_entry_safe(target, tnext, &targets, node) { list_for_each_entry_safe(target, tnext, &targets, node) {
list_for_each_entry_safe(tcache, cnext, &target->caches, node) {
list_del(&tcache->node);
kfree(tcache);
}
list_del(&target->node); list_del(&target->node);
kfree(target); kfree(target);
} }
@ -658,6 +739,10 @@ static __init int hmat_init(void)
} }
} }
hmat_register_targets(); hmat_register_targets();
/* Keep the table and structures if the notifier may use them */
if (!register_hotmemory_notifier(&hmat_callback_nb))
return 0;
out_put: out_put:
hmat_free_structures(); hmat_free_structures();
acpi_put_table(tbl); acpi_put_table(tbl);

View File

@ -449,8 +449,10 @@ int acpi_pci_irq_enable(struct pci_dev *dev)
* No IRQ known to the ACPI subsystem - maybe the BIOS / * No IRQ known to the ACPI subsystem - maybe the BIOS /
* driver reported one, then use it. Exit in any case. * driver reported one, then use it. Exit in any case.
*/ */
if (!acpi_pci_irq_valid(dev, pin)) if (!acpi_pci_irq_valid(dev, pin)) {
kfree(entry);
return 0; return 0;
}
if (acpi_isa_register_gsi(dev)) if (acpi_isa_register_gsi(dev))
dev_warn(&dev->dev, "PCI INT %c: no GSI\n", dev_warn(&dev->dev, "PCI INT %c: no GSI\n",

View File

@ -661,7 +661,7 @@ int acpi_pci_link_allocate_irq(acpi_handle handle, int index, int *triggering,
ACPI_DEBUG_PRINT((ACPI_DB_INFO, ACPI_DEBUG_PRINT((ACPI_DB_INFO,
"Link %s is referenced\n", "Link %s is referenced\n",
acpi_device_bid(link->device))); acpi_device_bid(link->device)));
return (link->irq.active); return link->irq.active;
} }
/* /*
@ -712,7 +712,7 @@ int acpi_pci_link_free_irq(acpi_handle handle)
acpi_evaluate_object(link->device->handle, "_DIS", NULL, NULL); acpi_evaluate_object(link->device->handle, "_DIS", NULL, NULL);
mutex_unlock(&acpi_link_lock); mutex_unlock(&acpi_link_lock);
return (link->irq.active); return link->irq.active;
} }
/* -------------------------------------------------------------------------- /* --------------------------------------------------------------------------

View File

@ -15,8 +15,6 @@ enum acpi_smb_protocol {
SMBUS_BLOCK_PROCESS_CALL = 0xd, SMBUS_BLOCK_PROCESS_CALL = 0xd,
}; };
static const u8 SMBUS_PEC = 0x80;
enum acpi_sbs_device_addr { enum acpi_sbs_device_addr {
ACPI_SBS_CHARGER = 0x9, ACPI_SBS_CHARGER = 0x9,
ACPI_SBS_MANAGER = 0xa, ACPI_SBS_MANAGER = 0xa,

View File

@ -225,13 +225,9 @@ static int acpi_thermal_set_cooling_mode(struct acpi_thermal *tz, int mode)
if (!tz) if (!tz)
return -EINVAL; return -EINVAL;
if (!acpi_has_method(tz->device->handle, "_SCP")) { if (ACPI_FAILURE(acpi_execute_simple_method(tz->device->handle,
ACPI_DEBUG_PRINT((ACPI_DB_INFO, "_SCP not present\n")); "_SCP", mode)))
return -ENODEV; return -ENODEV;
} else if (ACPI_FAILURE(acpi_execute_simple_method(tz->device->handle,
"_SCP", mode))) {
return -ENODEV;
}
return 0; return 0;
} }
@ -463,8 +459,7 @@ static int acpi_thermal_trips_update(struct acpi_thermal *tz, int flag)
break; break;
} }
if ((flag & ACPI_TRIPS_DEVICES) if (flag & ACPI_TRIPS_DEVICES) {
&& acpi_has_method(tz->device->handle, "_TZD")) {
memset(&devices, 0, sizeof(devices)); memset(&devices, 0, sizeof(devices));
status = acpi_evaluate_reference(tz->device->handle, "_TZD", status = acpi_evaluate_reference(tz->device->handle, "_TZD",
NULL, &devices); NULL, &devices);

View File

@ -95,9 +95,9 @@
#define ACPI_DEFAULT_PAGE_SIZE 4096 /* Must be power of 2 */ #define ACPI_DEFAULT_PAGE_SIZE 4096 /* Must be power of 2 */
/* owner_id tracking. 8 entries allows for 255 owner_ids */ /* owner_id tracking. 128 entries allows for 4095 owner_ids */
#define ACPI_NUM_OWNERID_MASKS 8 #define ACPI_NUM_OWNERID_MASKS 128
/* Size of the root table array is increased by this increment */ /* Size of the root table array is increased by this increment */

View File

@ -330,6 +330,7 @@ acpi_status acpi_os_enter_sleep(u8 sleep_state, u32 rega_value, u32 regb_value);
* Debug print routines * Debug print routines
*/ */
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_printf #ifndef ACPI_USE_ALTERNATE_PROTOTYPE_acpi_os_printf
ACPI_PRINTF_LIKE(1)
void ACPI_INTERNAL_VAR_XFACE acpi_os_printf(const char *format, ...); void ACPI_INTERNAL_VAR_XFACE acpi_os_printf(const char *format, ...);
#endif #endif

View File

@ -12,7 +12,7 @@
/* Current ACPICA subsystem version in YYYYMMDD format */ /* Current ACPICA subsystem version in YYYYMMDD format */
#define ACPI_CA_VERSION 0x20190703 #define ACPI_CA_VERSION 0x20190816
#include <acpi/acconfig.h> #include <acpi/acconfig.h>
#include <acpi/actypes.h> #include <acpi/actypes.h>

View File

@ -442,8 +442,8 @@ typedef void *acpi_handle; /* Actually a ptr to a NS Node */
/* Owner IDs are used to track namespace nodes for selective deletion */ /* Owner IDs are used to track namespace nodes for selective deletion */
typedef u8 acpi_owner_id; typedef u16 acpi_owner_id;
#define ACPI_OWNER_ID_MAX 0xFF #define ACPI_OWNER_ID_MAX 0xFFF /* 4095 possible owner IDs */
#define ACPI_INTEGER_BIT_SIZE 64 #define ACPI_INTEGER_BIT_SIZE 64
#define ACPI_MAX_DECIMAL_DIGITS 20 /* 2^64 = 18,446,744,073,709,551,616 */ #define ACPI_MAX_DECIMAL_DIGITS 20 /* 2^64 = 18,446,744,073,709,551,616 */
@ -506,7 +506,7 @@ typedef u64 acpi_integer;
/* Pointer/Integer type conversions */ /* Pointer/Integer type conversions */
#define ACPI_TO_POINTER(i) ACPI_ADD_PTR (void, (void *) 0, (acpi_size) (i)) #define ACPI_TO_POINTER(i) ACPI_CAST_PTR (void, (acpi_size) (i))
#define ACPI_TO_INTEGER(p) ACPI_PTR_DIFF (p, (void *) 0) #define ACPI_TO_INTEGER(p) ACPI_PTR_DIFF (p, (void *) 0)
#define ACPI_OFFSET(d, f) ACPI_PTR_DIFF (&(((d *) 0)->f), (void *) 0) #define ACPI_OFFSET(d, f) ACPI_PTR_DIFF (&(((d *) 0)->f), (void *) 0)
#define ACPI_PHYSADDR_TO_PTR(i) ACPI_TO_POINTER(i) #define ACPI_PHYSADDR_TO_PTR(i) ACPI_TO_POINTER(i)
@ -1265,12 +1265,14 @@ typedef enum {
#define ACPI_OSI_WIN_VISTA_SP2 0x0A #define ACPI_OSI_WIN_VISTA_SP2 0x0A
#define ACPI_OSI_WIN_7 0x0B #define ACPI_OSI_WIN_7 0x0B
#define ACPI_OSI_WIN_8 0x0C #define ACPI_OSI_WIN_8 0x0C
#define ACPI_OSI_WIN_10 0x0D #define ACPI_OSI_WIN_8_1 0x0D
#define ACPI_OSI_WIN_10_RS1 0x0E #define ACPI_OSI_WIN_10 0x0E
#define ACPI_OSI_WIN_10_RS2 0x0F #define ACPI_OSI_WIN_10_RS1 0x0F
#define ACPI_OSI_WIN_10_RS3 0x10 #define ACPI_OSI_WIN_10_RS2 0x10
#define ACPI_OSI_WIN_10_RS4 0x11 #define ACPI_OSI_WIN_10_RS3 0x11
#define ACPI_OSI_WIN_10_RS5 0x12 #define ACPI_OSI_WIN_10_RS4 0x12
#define ACPI_OSI_WIN_10_RS5 0x13
#define ACPI_OSI_WIN_10_19H1 0x14
/* Definitions of getopt */ /* Definitions of getopt */

View File

@ -29,18 +29,24 @@ static int ap_is_existing_file(char *pathname)
{ {
#if !defined(_GNU_EFI) && !defined(_EDK2_EFI) #if !defined(_GNU_EFI) && !defined(_EDK2_EFI)
struct stat stat_info; struct stat stat_info;
int in_char;
if (!stat(pathname, &stat_info)) { if (!stat(pathname, &stat_info)) {
fprintf(stderr, fprintf(stderr,
"Target path already exists, overwrite? [y|n] "); "Target path already exists, overwrite? [y|n] ");
if (getchar() != 'y') { in_char = fgetc(stdin);
if (in_char == '\n') {
in_char = fgetc(stdin);
}
if (in_char != 'y' && in_char != 'Y') {
return (-1); return (-1);
} }
} }
#endif #endif
return 0; return (0);
} }
/****************************************************************************** /******************************************************************************