cvs commit: src/sys/boot/pc32/libi386 biosacpi.c src/sys/conf acpi.mk files src/sys/dev/acpica5 Makefile Makefile.inc acdragonfly.h acpi.c acpi_acad.c acpi_button.c acpi_cmbat.c acpi_cpu.c acpi_ec.c acpi_lid.c acpi_resource.c acpi_thermal.c ...
Johannes Hofmann
Johannes.Hofmann at gmx.de
Fri Jan 19 13:53:05 PST 2007
YONETANI Tomokazu <qhwt+dfly at les.ath.cx> wrote:
> On Fri, Jan 19, 2007 at 01:45:26PM +0100, Simon 'corecode' Schubert wrote:
>> YONETANI Tomokazu wrote:
>> >>Uff, now I've got it.
>> >>It hangs in OsdCache.c:AcpiOsAcquireObject
>> >>
>> >>Object = objcache_get(Cache->cache, M_WAITOK);
>>
>> Heh. The ACPI docs are simply not nice enough:
>>
>> /*******************************************************************************
>> *
>> * FUNCTION: AcpiOsCreateCache
>> *
>> * PARAMETERS: CacheName - Ascii name for the cache
>> * ObjectSize - Size of each cached object
>> * MaxDepth - Maximum depth of the cache (in objects)
>> * ReturnCache - Where the new cache object is returned
>>
>> we interpret MaxDepth as "object limit".
>>
>> but look what utcache.c/AcpiOsReleaseObject does:
>>
>> /* If cache is full, just free this object */
>>
>> if (Cache->CurrentDepth >= Cache->MaxDepth)
>> {
>> ACPI_FREE (Object);
>> ACPI_MEM_TRACKING (Cache->TotalFreed++);
>> }
>>
>> /* Otherwise put this object back into the cache */
>>
>> Quite differently. Basically MaxDepth is "maximum number of unallocated
>> objects", not "maximum number of allocated objects". bummer :)
>
> A-ha, good catch. So what can we do to this problem? Since
> ACPI-CA original version doesn't have an upper limit to
> the number of allocated objects anyway, do we just ignore
> the MaxDepth parameter and trust our objcache's effectiveness?
>
> Index: Osd/OsdCache.c
> ===================================================================
> RCS file: /home/source/dragonfly/cvs/src/sys/dev/acpica5/Osd/OsdCache.c,v
> retrieving revision 1.1
> diff -u -p -r1.1 OsdCache.c
> --- Osd/OsdCache.c 17 Jan 2007 17:31:19 -0000 1.1
> +++ Osd/OsdCache.c 19 Jan 2007 17:22:47 -0000
> @@ -52,8 +52,8 @@ AcpiOsCreateCache(char *CacheName, UINT1
> cache = kmalloc(sizeof(*cache), M_TEMP, M_WAITOK);
> cache->args.objsize = ObjectSize;
> cache->args.mtype = M_CACHE;
> - cache->cache = objcache_create(CacheName, MaxDepth, 0, NULL, NULL, NULL,
> - objcache_malloc_alloc, objcache_malloc_free, &cache->args);
> + cache->cache = objcache_create(CacheName, 0, 0, NULL, NULL,
> + NULL, objcache_malloc_alloc, objcache_malloc_free, &cache->args);
> *ReturnCache = cache;
> return AE_OK;
> }
This fixes the hang for me!
Thanks, Johannes
More information about the Commits
mailing list