X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/b0d623f7f2ae71ed96e60569f61f9a9a27016e80..316670eb35587141e969394ae8537d66b9211e80:/iokit/Kernel/IOKitDebug.cpp diff --git a/iokit/Kernel/IOKitDebug.cpp b/iokit/Kernel/IOKitDebug.cpp index f061b516c..c170d83a6 100644 --- a/iokit/Kernel/IOKitDebug.cpp +++ b/iokit/Kernel/IOKitDebug.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998-2006 Apple Computer, Inc. All rights reserved. + * Copyright (c) 1998-2010 Apple Inc. All rights reserved. * * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ * @@ -25,24 +25,18 @@ * * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ */ -/* - * Copyright (c) 1998 Apple Computer, Inc. All rights reserved. - * - * HISTORY - * - */ #include +#include +#include + #include #include #include #include #include -#include -#include - #ifdef IOKITDEBUG #define DEBUG_INIT_VALUE IOKITDEBUG #else @@ -50,7 +44,10 @@ #endif SInt64 gIOKitDebug = DEBUG_INIT_VALUE; -SYSCTL_QUAD(_debug, OID_AUTO, iokit, CTLFLAG_RW, &gIOKitDebug, "boot_arg io"); +SInt64 gIOKitTrace = 0; + +SYSCTL_QUAD(_debug, OID_AUTO, iokit, CTLFLAG_RW | CTLFLAG_LOCKED, &gIOKitDebug, "boot_arg io"); +SYSCTL_QUAD(_debug, OID_AUTO, iotrace, CTLFLAG_RW | CTLFLAG_LOCKED, &gIOKitTrace, "trace io"); int debug_malloc_size; @@ -101,59 +98,12 @@ void IOPrintPlane( const IORegistryPlane * plane ) iter->release(); } -void dbugprintf(char *fmt, ...); -void db_dumpiojunk( const IORegistryPlane * plane ); - -void db_piokjunk(void) { - - dbugprintf("\nDT plane:\n"); - db_dumpiojunk( gIODTPlane ); - dbugprintf("\n\nService plane:\n"); - db_dumpiojunk( gIOServicePlane ); - dbugprintf("\n\n" - "ivar kalloc() 0x%08x\n" - "malloc() 0x%08x\n" - "containers kalloc() 0x%08x\n" - "IOMalloc() 0x%08x\n" - "----------------------------------------\n", - debug_ivars_size, - debug_malloc_size, - debug_container_malloc_size, - debug_iomalloc_size - ); - +void db_piokjunk(void) +{ } - -void db_dumpiojunk( const IORegistryPlane * plane ) +void db_dumpiojunk( const IORegistryPlane * plane __unused ) { - IORegistryEntry * next; - IORegistryIterator * iter; - OSOrderedSet * all; - char format[] = "%xxxs"; - IOService * service; - - iter = IORegistryIterator::iterateOver( plane ); - - all = iter->iterateAll(); - if( all) { - dbugprintf("Count %d\n", all->getCount() ); - all->release(); - } else dbugprintf("Empty\n"); - - iter->reset(); - while( (next = iter->getNextObjectRecursive())) { - snprintf(format + 1, sizeof(format) - 1, "%ds", 2 * next->getDepth( plane )); - dbugprintf( format, ""); - dbugprintf( "%s", next->getName( plane )); - if( (next->getLocation( plane ))) - dbugprintf("@%s", next->getLocation( plane )); - dbugprintf(" getMetaClass()->getClassName()); - if( (service = OSDynamicCast(IOService, next))) - dbugprintf(", busy %ld", service->getBusyState()); - dbugprintf( ">\n"); - } - iter->release(); } void IOPrintMemory( void )