diff options
author | Lv Zheng <lv.zheng@intel.com> | 2013-10-28 21:29:27 -0400 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2013-10-30 07:24:21 -0400 |
commit | b3c86c30efd83ebfa7010c5890e2ebf2678e49f8 (patch) | |
tree | f354d1d0a7a01d40345b155e3d271ca9275adb09 /drivers/acpi/acpica | |
parent | 73424473d0801f7079258897901ba1edc660dbd3 (diff) |
ACPICA: Cleanup memory allocation macros and configurability.
In the common case, the ACPI_ALLOCATE and related macros now resolve
directly to their respective acpi_os* OSL interfaces. Two options:
1) The ACPI_ALLOCATE_ZEROED macro defaults to a simple local implementation
by default, unless overridden by the USE_NATIVE_ALLOCATE_ZEROED define.
2) For ACPI execution simulation environment (AcpiExec) which is not
shipped with the Linux kernel, the macros can optionally be resolved to
the local interfaces that track each allocation (used to immediately
detect memory leaks).
Signed-off-by: Lv Zheng <lv.zheng@intel.com>
Signed-off-by: Bob Moore <robert.moore@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'drivers/acpi/acpica')
-rw-r--r-- | drivers/acpi/acpica/acmacros.h | 31 | ||||
-rw-r--r-- | drivers/acpi/acpica/acutils.h | 6 | ||||
-rw-r--r-- | drivers/acpi/acpica/utalloc.c | 113 | ||||
-rw-r--r-- | drivers/acpi/acpica/uttrack.c | 29 |
4 files changed, 59 insertions, 120 deletions
diff --git a/drivers/acpi/acpica/acmacros.h b/drivers/acpi/acpica/acmacros.h index 530a2f8c1252..2a86c65d873b 100644 --- a/drivers/acpi/acpica/acmacros.h +++ b/drivers/acpi/acpica/acmacros.h | |||
@@ -410,37 +410,6 @@ | |||
410 | #endif | 410 | #endif |
411 | 411 | ||
412 | /* | 412 | /* |
413 | * Memory allocation tracking (DEBUG ONLY) | ||
414 | */ | ||
415 | #define ACPI_MEM_PARAMETERS _COMPONENT, _acpi_module_name, __LINE__ | ||
416 | |||
417 | #ifndef ACPI_DBG_TRACK_ALLOCATIONS | ||
418 | |||
419 | /* Memory allocation */ | ||
420 | |||
421 | #ifndef ACPI_ALLOCATE | ||
422 | #define ACPI_ALLOCATE(a) acpi_ut_allocate((acpi_size) (a), ACPI_MEM_PARAMETERS) | ||
423 | #endif | ||
424 | #ifndef ACPI_ALLOCATE_ZEROED | ||
425 | #define ACPI_ALLOCATE_ZEROED(a) acpi_ut_allocate_zeroed((acpi_size) (a), ACPI_MEM_PARAMETERS) | ||
426 | #endif | ||
427 | #ifndef ACPI_FREE | ||
428 | #define ACPI_FREE(a) acpi_os_free(a) | ||
429 | #endif | ||
430 | #define ACPI_MEM_TRACKING(a) | ||
431 | |||
432 | #else | ||
433 | |||
434 | /* Memory allocation */ | ||
435 | |||
436 | #define ACPI_ALLOCATE(a) acpi_ut_allocate_and_track((acpi_size) (a), ACPI_MEM_PARAMETERS) | ||
437 | #define ACPI_ALLOCATE_ZEROED(a) acpi_ut_allocate_zeroed_and_track((acpi_size) (a), ACPI_MEM_PARAMETERS) | ||
438 | #define ACPI_FREE(a) acpi_ut_free_and_track(a, ACPI_MEM_PARAMETERS) | ||
439 | #define ACPI_MEM_TRACKING(a) a | ||
440 | |||
441 | #endif /* ACPI_DBG_TRACK_ALLOCATIONS */ | ||
442 | |||
443 | /* | ||
444 | * Macros used for ACPICA utilities only | 413 | * Macros used for ACPICA utilities only |
445 | */ | 414 | */ |
446 | 415 | ||
diff --git a/drivers/acpi/acpica/acutils.h b/drivers/acpi/acpica/acutils.h index 4f25e8f0cd5f..be8180c17d7e 100644 --- a/drivers/acpi/acpica/acutils.h +++ b/drivers/acpi/acpica/acutils.h | |||
@@ -663,12 +663,6 @@ acpi_status | |||
663 | acpi_ut_initialize_buffer(struct acpi_buffer *buffer, | 663 | acpi_ut_initialize_buffer(struct acpi_buffer *buffer, |
664 | acpi_size required_length); | 664 | acpi_size required_length); |
665 | 665 | ||
666 | void *acpi_ut_allocate(acpi_size size, | ||
667 | u32 component, const char *module, u32 line); | ||
668 | |||
669 | void *acpi_ut_allocate_zeroed(acpi_size size, | ||
670 | u32 component, const char *module, u32 line); | ||
671 | |||
672 | #ifdef ACPI_DBG_TRACK_ALLOCATIONS | 666 | #ifdef ACPI_DBG_TRACK_ALLOCATIONS |
673 | void *acpi_ut_allocate_and_track(acpi_size size, | 667 | void *acpi_ut_allocate_and_track(acpi_size size, |
674 | u32 component, const char *module, u32 line); | 668 | u32 component, const char *module, u32 line); |
diff --git a/drivers/acpi/acpica/utalloc.c b/drivers/acpi/acpica/utalloc.c index e0ffb580f4b0..d84479610971 100644 --- a/drivers/acpi/acpica/utalloc.c +++ b/drivers/acpi/acpica/utalloc.c | |||
@@ -48,6 +48,39 @@ | |||
48 | #define _COMPONENT ACPI_UTILITIES | 48 | #define _COMPONENT ACPI_UTILITIES |
49 | ACPI_MODULE_NAME("utalloc") | 49 | ACPI_MODULE_NAME("utalloc") |
50 | 50 | ||
51 | #if !defined (USE_NATIVE_ALLOCATE_ZEROED) | ||
52 | /******************************************************************************* | ||
53 | * | ||
54 | * FUNCTION: acpi_os_allocate_zeroed | ||
55 | * | ||
56 | * PARAMETERS: size - Size of the allocation | ||
57 | * | ||
58 | * RETURN: Address of the allocated memory on success, NULL on failure. | ||
59 | * | ||
60 | * DESCRIPTION: Subsystem equivalent of calloc. Allocate and zero memory. | ||
61 | * This is the default implementation. Can be overridden via the | ||
62 | * USE_NATIVE_ALLOCATE_ZEROED flag. | ||
63 | * | ||
64 | ******************************************************************************/ | ||
65 | void *acpi_os_allocate_zeroed(acpi_size size) | ||
66 | { | ||
67 | void *allocation; | ||
68 | |||
69 | ACPI_FUNCTION_ENTRY(); | ||
70 | |||
71 | allocation = acpi_os_allocate(size); | ||
72 | if (allocation) { | ||
73 | |||
74 | /* Clear the memory block */ | ||
75 | |||
76 | ACPI_MEMSET(allocation, 0, size); | ||
77 | } | ||
78 | |||
79 | return (allocation); | ||
80 | } | ||
81 | |||
82 | #endif /* !USE_NATIVE_ALLOCATE_ZEROED */ | ||
83 | |||
51 | /******************************************************************************* | 84 | /******************************************************************************* |
52 | * | 85 | * |
53 | * FUNCTION: acpi_ut_create_caches | 86 | * FUNCTION: acpi_ut_create_caches |
@@ -59,6 +92,7 @@ ACPI_MODULE_NAME("utalloc") | |||
59 | * DESCRIPTION: Create all local caches | 92 | * DESCRIPTION: Create all local caches |
60 | * | 93 | * |
61 | ******************************************************************************/ | 94 | ******************************************************************************/ |
95 | |||
62 | acpi_status acpi_ut_create_caches(void) | 96 | acpi_status acpi_ut_create_caches(void) |
63 | { | 97 | { |
64 | acpi_status status; | 98 | acpi_status status; |
@@ -302,82 +336,3 @@ acpi_ut_initialize_buffer(struct acpi_buffer * buffer, | |||
302 | ACPI_MEMSET(buffer->pointer, 0, required_length); | 336 | ACPI_MEMSET(buffer->pointer, 0, required_length); |
303 | return (AE_OK); | 337 | return (AE_OK); |
304 | } | 338 | } |
305 | |||
306 | #ifdef NOT_USED_BY_LINUX | ||
307 | /******************************************************************************* | ||
308 | * | ||
309 | * FUNCTION: acpi_ut_allocate | ||
310 | * | ||
311 | * PARAMETERS: size - Size of the allocation | ||
312 | * component - Component type of caller | ||
313 | * module - Source file name of caller | ||
314 | * line - Line number of caller | ||
315 | * | ||
316 | * RETURN: Address of the allocated memory on success, NULL on failure. | ||
317 | * | ||
318 | * DESCRIPTION: Subsystem equivalent of malloc. | ||
319 | * | ||
320 | ******************************************************************************/ | ||
321 | |||
322 | void *acpi_ut_allocate(acpi_size size, | ||
323 | u32 component, const char *module, u32 line) | ||
324 | { | ||
325 | void *allocation; | ||
326 | |||
327 | ACPI_FUNCTION_TRACE_U32(ut_allocate, size); | ||
328 | |||
329 | /* Check for an inadvertent size of zero bytes */ | ||
330 | |||
331 | if (!size) { | ||
332 | ACPI_WARNING((module, line, | ||
333 | "Attempt to allocate zero bytes, allocating 1 byte")); | ||
334 | size = 1; | ||
335 | } | ||
336 | |||
337 | allocation = acpi_os_allocate(size); | ||
338 | if (!allocation) { | ||
339 | |||
340 | /* Report allocation error */ | ||
341 | |||
342 | ACPI_WARNING((module, line, | ||
343 | "Could not allocate size %u", (u32) size)); | ||
344 | |||
345 | return_PTR(NULL); | ||
346 | } | ||
347 | |||
348 | return_PTR(allocation); | ||
349 | } | ||
350 | |||
351 | /******************************************************************************* | ||
352 | * | ||
353 | * FUNCTION: acpi_ut_allocate_zeroed | ||
354 | * | ||
355 | * PARAMETERS: size - Size of the allocation | ||
356 | * component - Component type of caller | ||
357 | * module - Source file name of caller | ||
358 | * line - Line number of caller | ||
359 | * | ||
360 | * RETURN: Address of the allocated memory on success, NULL on failure. | ||
361 | * | ||
362 | * DESCRIPTION: Subsystem equivalent of calloc. Allocate and zero memory. | ||
363 | * | ||
364 | ******************************************************************************/ | ||
365 | |||
366 | void *acpi_ut_allocate_zeroed(acpi_size size, | ||
367 | u32 component, const char *module, u32 line) | ||
368 | { | ||
369 | void *allocation; | ||
370 | |||
371 | ACPI_FUNCTION_ENTRY(); | ||
372 | |||
373 | allocation = acpi_ut_allocate(size, component, module, line); | ||
374 | if (allocation) { | ||
375 | |||
376 | /* Clear the memory block */ | ||
377 | |||
378 | ACPI_MEMSET(allocation, 0, size); | ||
379 | } | ||
380 | |||
381 | return (allocation); | ||
382 | } | ||
383 | #endif | ||
diff --git a/drivers/acpi/acpica/uttrack.c b/drivers/acpi/acpica/uttrack.c index 160f13f4aab5..77e3eb7d7c04 100644 --- a/drivers/acpi/acpica/uttrack.c +++ b/drivers/acpi/acpica/uttrack.c | |||
@@ -130,10 +130,23 @@ void *acpi_ut_allocate_and_track(acpi_size size, | |||
130 | struct acpi_debug_mem_block *allocation; | 130 | struct acpi_debug_mem_block *allocation; |
131 | acpi_status status; | 131 | acpi_status status; |
132 | 132 | ||
133 | /* Check for an inadvertent size of zero bytes */ | ||
134 | |||
135 | if (!size) { | ||
136 | ACPI_WARNING((module, line, | ||
137 | "Attempt to allocate zero bytes, allocating 1 byte")); | ||
138 | size = 1; | ||
139 | } | ||
140 | |||
133 | allocation = | 141 | allocation = |
134 | acpi_ut_allocate(size + sizeof(struct acpi_debug_mem_header), | 142 | acpi_os_allocate(size + sizeof(struct acpi_debug_mem_header)); |
135 | component, module, line); | ||
136 | if (!allocation) { | 143 | if (!allocation) { |
144 | |||
145 | /* Report allocation error */ | ||
146 | |||
147 | ACPI_WARNING((module, line, | ||
148 | "Could not allocate size %u", (u32)size)); | ||
149 | |||
137 | return (NULL); | 150 | return (NULL); |
138 | } | 151 | } |
139 | 152 | ||
@@ -179,9 +192,17 @@ void *acpi_ut_allocate_zeroed_and_track(acpi_size size, | |||
179 | struct acpi_debug_mem_block *allocation; | 192 | struct acpi_debug_mem_block *allocation; |
180 | acpi_status status; | 193 | acpi_status status; |
181 | 194 | ||
195 | /* Check for an inadvertent size of zero bytes */ | ||
196 | |||
197 | if (!size) { | ||
198 | ACPI_WARNING((module, line, | ||
199 | "Attempt to allocate zero bytes, allocating 1 byte")); | ||
200 | size = 1; | ||
201 | } | ||
202 | |||
182 | allocation = | 203 | allocation = |
183 | acpi_ut_allocate_zeroed(size + sizeof(struct acpi_debug_mem_header), | 204 | acpi_os_allocate_zeroed(size + |
184 | component, module, line); | 205 | sizeof(struct acpi_debug_mem_header)); |
185 | if (!allocation) { | 206 | if (!allocation) { |
186 | 207 | ||
187 | /* Report allocation error */ | 208 | /* Report allocation error */ |