| 
									
										
										
										
											2010-05-23 03:07:47 -04:00
										 |  |  | USING: alien.syntax alien.c-types alien.data core-foundation | 
					
						
							| 
									
										
										
										
											2009-01-16 19:45:39 -05:00
										 |  |  | core-foundation.bundles core-foundation.dictionaries system | 
					
						
							| 
									
										
										
										
											2009-11-15 01:47:52 -05:00
										 |  |  | combinators kernel sequences io accessors unix.types ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | IN: iokit | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-16 09:37:36 -04:00
										 |  |  | << | 
					
						
							|  |  |  |     os macosx? | 
					
						
							|  |  |  |     [ "/System/Library/Frameworks/IOKit.framework" load-framework ] | 
					
						
							|  |  |  |     when
 | 
					
						
							|  |  |  | >> | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOKitBuildVersionKey   "IOKitBuildVersion" | 
					
						
							|  |  |  | CONSTANT: kIOKitDiagnosticsKey   "IOKitDiagnostics" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  |   | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIORegistryPlanesKey   "IORegistryPlanes" | 
					
						
							|  |  |  | CONSTANT: kIOCatalogueKey    "IOCatalogue" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOServicePlane    "IOService" | 
					
						
							|  |  |  | CONSTANT: kIOPowerPlane    "IOPower" | 
					
						
							|  |  |  | CONSTANT: kIODeviceTreePlane   "IODeviceTree" | 
					
						
							|  |  |  | CONSTANT: kIOAudioPlane    "IOAudio" | 
					
						
							|  |  |  | CONSTANT: kIOFireWirePlane   "IOFireWire" | 
					
						
							|  |  |  | CONSTANT: kIOUSBPlane    "IOUSB" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOServiceClass    "IOService" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOResourcesClass   "IOResources" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOClassKey    "IOClass" | 
					
						
							|  |  |  | CONSTANT: kIOProbeScoreKey   "IOProbeScore" | 
					
						
							|  |  |  | CONSTANT: kIOKitDebugKey    "IOKitDebug" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOProviderClassKey   "IOProviderClass" | 
					
						
							|  |  |  | CONSTANT: kIONameMatchKey    "IONameMatch" | 
					
						
							|  |  |  | CONSTANT: kIOPropertyMatchKey   "IOPropertyMatch" | 
					
						
							|  |  |  | CONSTANT: kIOPathMatchKey    "IOPathMatch" | 
					
						
							|  |  |  | CONSTANT: kIOLocationMatchKey   "IOLocationMatch" | 
					
						
							|  |  |  | CONSTANT: kIOParentMatchKey   "IOParentMatch" | 
					
						
							|  |  |  | CONSTANT: kIOResourceMatchKey   "IOResourceMatch" | 
					
						
							|  |  |  | CONSTANT: kIOMatchedServiceCountKey  "IOMatchedServiceCountMatch" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIONameMatchedKey   "IONameMatched" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOMatchCategoryKey   "IOMatchCategory" | 
					
						
							|  |  |  | CONSTANT: kIODefaultMatchCategoryKey  "IODefaultMatchCategory" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOUserClientClassKey   "IOUserClientClass" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOUserClientCrossEndianKey   "IOUserClientCrossEndian" | 
					
						
							|  |  |  | CONSTANT: kIOUserClientCrossEndianCompatibleKey  "IOUserClientCrossEndianCompatible" | 
					
						
							|  |  |  | CONSTANT: kIOUserClientSharedInstanceKey   "IOUserClientSharedInstance" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOPublishNotification   "IOServicePublish" | 
					
						
							|  |  |  | CONSTANT: kIOFirstPublishNotification  "IOServiceFirstPublish" | 
					
						
							|  |  |  | CONSTANT: kIOMatchedNotification   "IOServiceMatched" | 
					
						
							|  |  |  | CONSTANT: kIOFirstMatchNotification  "IOServiceFirstMatch" | 
					
						
							|  |  |  | CONSTANT: kIOTerminatedNotification  "IOServiceTerminate" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOGeneralInterest   "IOGeneralInterest" | 
					
						
							|  |  |  | CONSTANT: kIOBusyInterest    "IOBusyInterest" | 
					
						
							|  |  |  | CONSTANT: kIOAppPowerStateInterest  "IOAppPowerStateInterest" | 
					
						
							|  |  |  | CONSTANT: kIOPriorityPowerStateInterest  "IOPriorityPowerStateInterest" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOPlatformDeviceMessageKey "IOPlatformDeviceMessage" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOCFPlugInTypesKey   "IOCFPlugInTypes" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOCommandPoolSizeKey         "IOCommandPoolSize" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOMaximumBlockCountReadKey "IOMaximumBlockCountRead" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumBlockCountWriteKey "IOMaximumBlockCountWrite" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumByteCountReadKey "IOMaximumByteCountRead" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumByteCountWriteKey "IOMaximumByteCountWrite" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumSegmentCountReadKey "IOMaximumSegmentCountRead" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumSegmentCountWriteKey "IOMaximumSegmentCountWrite" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumSegmentByteCountReadKey "IOMaximumSegmentByteCountRead" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumSegmentByteCountWriteKey "IOMaximumSegmentByteCountWrite" | 
					
						
							|  |  |  | CONSTANT: kIOMinimumSegmentAlignmentByteCountKey "IOMinimumSegmentAlignmentByteCount" | 
					
						
							|  |  |  | CONSTANT: kIOMaximumSegmentAddressableBitCountKey "IOMaximumSegmentAddressableBitCount" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOIconKey "IOIcon" | 
					
						
							|  |  |  | CONSTANT: kIOBundleResourceFileKey "IOBundleResourceFile" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOBusBadgeKey "IOBusBadge" | 
					
						
							|  |  |  | CONSTANT: kIODeviceIconKey "IODeviceIcon" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOPlatformSerialNumberKey  "IOPlatformSerialNumber"  | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOPlatformUUIDKey  "IOPlatformUUID"  | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIONVRAMDeletePropertyKey  "IONVRAM-DELETE-PROPERTY" | 
					
						
							|  |  |  | CONSTANT: kIODTNVRAMPanicInfoKey   "aapl,panic-info" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kIOBootDeviceKey "IOBootDevice"   | 
					
						
							|  |  |  | CONSTANT: kIOBootDevicePathKey "IOBootDevicePath"  | 
					
						
							|  |  |  | CONSTANT: kIOBootDeviceSizeKey "IOBootDeviceSize"  | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kOSBuildVersionKey   "OS Build Version" | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: kNilOptions 0
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-22 18:56:12 -05:00
										 |  |  | CONSTANT: MACH_PORT_NULL 0
 | 
					
						
							|  |  |  | CONSTANT: KERN_SUCCESS 0
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-14 22:43:39 -04:00
										 |  |  | FUNCTION: IOReturn IOMasterPort ( mach_port_t bootstrap, mach_port_t* master ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: CFDictionaryRef IOServiceMatching ( c-string name ) ;
 | 
					
						
							|  |  |  | FUNCTION: CFDictionaryRef IOServiceNameMatching ( c-string name ) ;
 | 
					
						
							|  |  |  | FUNCTION: CFDictionaryRef IOBSDNameMatching ( c-string name ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-14 22:43:39 -04:00
										 |  |  | FUNCTION: IOReturn IOObjectRetain ( io_object_t o ) ;
 | 
					
						
							|  |  |  | FUNCTION: IOReturn IOObjectRelease ( io_object_t o ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-14 22:43:39 -04:00
										 |  |  | FUNCTION: IOReturn IOServiceGetMatchingServices ( mach_port_t master, CFDictionaryRef matchingDict, io_iterator_t* iterator ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | FUNCTION: io_object_t IOIteratorNext ( io_iterator_t i ) ;
 | 
					
						
							|  |  |  | FUNCTION: void IOIteratorReset ( io_iterator_t i ) ;
 | 
					
						
							|  |  |  | FUNCTION: boolean_t IOIteratorIsValid ( io_iterator_t i ) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-14 22:43:39 -04:00
										 |  |  | FUNCTION: IOReturn IORegistryEntryGetPath ( io_registry_entry_t entry, io_name_t plane, io_string_t path ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-14 22:43:39 -04:00
										 |  |  | FUNCTION: IOReturn IORegistryEntryCreateCFProperties ( io_registry_entry_t entry, CFMutableDictionaryRef properties, CFAllocatorRef allocator, IOOptionBits options ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-23 14:42:02 -05:00
										 |  |  | FUNCTION: c-string mach_error_string ( IOReturn error ) ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 20:02:40 -04:00
										 |  |  | TUPLE: mach-error error-code error-string ;
 | 
					
						
							|  |  |  | : <mach-error> ( code -- error )
 | 
					
						
							|  |  |  |     dup mach_error_string \ mach-error boa ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : mach-error ( return -- )
 | 
					
						
							|  |  |  |     dup KERN_SUCCESS = [ drop ] [ <mach-error> throw ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : master-port ( -- port )
 | 
					
						
							| 
									
										
										
										
											2010-07-16 17:32:05 -04:00
										 |  |  |     MACH_PORT_NULL { uint } [ IOMasterPort mach-error ] with-out-parameters ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : io-services-matching-dictionary ( nsdictionary -- iterator )
 | 
					
						
							| 
									
										
										
										
											2010-05-23 03:07:47 -04:00
										 |  |  |     master-port swap
 | 
					
						
							| 
									
										
										
										
											2010-07-16 17:32:05 -04:00
										 |  |  |     { uint } [ IOServiceGetMatchingServices mach-error ] with-out-parameters ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : io-services-matching-service ( service -- iterator )
 | 
					
						
							|  |  |  |     IOServiceMatching io-services-matching-dictionary ;
 | 
					
						
							|  |  |  | : io-services-matching-service-name ( service-name -- iterator )
 | 
					
						
							|  |  |  |     IOServiceNameMatching io-services-matching-dictionary ;
 | 
					
						
							|  |  |  | : io-services-matching-bsd-name ( bsd-name -- iterator )
 | 
					
						
							|  |  |  |     IOBSDNameMatching io-services-matching-dictionary ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : retain-io-object ( o -- o )
 | 
					
						
							|  |  |  |     [ IOObjectRetain mach-error ] keep ;
 | 
					
						
							|  |  |  | : release-io-object ( o -- )
 | 
					
						
							|  |  |  |     IOObjectRelease mach-error ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : io-objects-from-iterator* ( i -- i array )
 | 
					
						
							| 
									
										
										
										
											2009-02-28 16:31:34 -05:00
										 |  |  |     [ dup IOIteratorNext dup MACH_PORT_NULL = not ] [ ] produce nip ;
 | 
					
						
							| 
									
										
										
										
											2008-07-13 13:42:35 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : io-objects-from-iterator ( i -- array )
 | 
					
						
							|  |  |  |     io-objects-from-iterator* [ release-io-object ] dip ;
 | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | : properties-from-io-object ( o -- o nsdictionary )
 | 
					
						
							|  |  |  |     dup f <void*> [ | 
					
						
							|  |  |  |         kCFAllocatorDefault kNilOptions | 
					
						
							|  |  |  |         IORegistryEntryCreateCFProperties mach-error | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     keep *void* ;
 | 
					
						
							|  |  |  | 
 |