]> git.saurik.com Git - apple/xnu.git/blobdiff - pexpert/gen/device_tree.c
xnu-1504.3.12.tar.gz
[apple/xnu.git] / pexpert / gen / device_tree.c
index eb09004c96af903e01e94750a4211dc6f985a2f9..dc3ea9ddc05f7d0a6a3830b13cbc4c1bb7a38143 100644 (file)
@@ -1,16 +1,19 @@
 /*
- * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2004 Apple Computer, Inc. All rights reserved.
  *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Copyright (c) 1999-2003 Apple Computer, Inc.  All Rights Reserved.
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ * 
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
  * 
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
@@ -20,7 +23,7 @@
  * Please see the License for the specific language governing rights and
  * limitations under the License.
  * 
- * @APPLE_LICENSE_HEADER_END@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /*
  * @OSF_FREE_COPYRIGHT@
 #include <pexpert/protos.h>
 #include <pexpert/boot.h>
 #include <pexpert/device_tree.h>
+
+#include <mach/mach_types.h>
 #include <mach/machine/vm_types.h>
+#include <kern/kern_types.h>
+#include <kern/kalloc.h>
+
 #include <sys/types.h>
-#ifdef i386
-#include <i386/fakePPCStructs.h>
-#endif
 
 #ifndef NULL
 #define       NULL    ((void *) 0)
 #endif
 
-#define round_long(x)  (((x) + 3) & -4)
-#define next_prop(x)   ((DeviceTreeNodeProperty *) (((int)x) + sizeof(DeviceTreeNodeProperty) + round_long(x->length)))
+#define round_long(x)  (((x) + 3UL) & ~(3UL))
+#define next_prop(x)   ((DeviceTreeNodeProperty *) (((uintptr_t)x) + sizeof(DeviceTreeNodeProperty) + round_long(x->length)))
 
 /* Entry*/
 typedef DeviceTreeNode *RealDTEntry;
@@ -71,8 +76,6 @@ typedef struct OpaqueDTPropertyIterator {
 static int DTInitialized;
 static RealDTEntry DTRootNode;
 
-void DTInit(void *base);
-
 /*
  * Support Routines
  */
@@ -80,7 +83,7 @@ static RealDTEntry
 skipProperties(RealDTEntry entry)
 {
        DeviceTreeNodeProperty *prop;
-       int k;
+       unsigned int k;
 
        if (entry == NULL || entry->nProperties == 0) {
                return NULL;
@@ -97,7 +100,7 @@ static RealDTEntry
 skipTree(RealDTEntry root)
 {
        RealDTEntry entry;
-       int k;
+       unsigned int k;
 
        entry = skipProperties(root);
        if (entry == NULL) {
@@ -140,8 +143,8 @@ FindChild(RealDTEntry cur, char *buf)
 {
        RealDTEntry     child;
        unsigned long   index;
-       char *          str;
-       int             dummy;
+       char *                  str;
+       unsigned int    dummy;
 
        if (cur->nChildren == 0) {
                return NULL;
@@ -197,20 +200,20 @@ int DTFindEntry(const char *propName, const char *propValue, DTEntry *entryH)
 
 int find_entry(const char *propName, const char *propValue, DTEntry *entryH)
 {
-       DeviceTreeNode *nodeP = (DeviceTreeNode *) startingP;
-       int k;
+       DeviceTreeNode *nodeP = (DeviceTreeNode *) (void *) startingP;
+       unsigned int k;
 
        if (nodeP->nProperties == 0) return(kError);    // End of the list of nodes
        startingP = (char *) (nodeP + 1);
 
        // Search current entry
        for (k = 0; k < nodeP->nProperties; ++k) {
-               DeviceTreeNodeProperty *propP = (DeviceTreeNodeProperty *) startingP;
+               DeviceTreeNodeProperty *propP = (DeviceTreeNodeProperty *) (void *) startingP;
 
                startingP += sizeof (*propP) + ((propP->length + 3) & -4);
 
                if (strcmp (propP->name, propName) == 0) {
-                       if (strcmp( (char *)(propP + 1), propValue) == 0)
+                       if (propValue == NULL || strcmp( (char *)(propP + 1), propValue) == 0)
                        {
                                *entryH = (DTEntry)nodeP;
                                return(kSuccess);
@@ -302,9 +305,9 @@ DTDisposeEntryIterator(DTEntryIterator iterator)
 
        while ((scope = iter->savedScope) != NULL) {
                iter->savedScope = scope->nextScope;
-               kfree((vm_offset_t) scope, sizeof(struct DTSavedScope));
+               kfree(scope, sizeof(struct DTSavedScope));
        }
-       kfree((vm_offset_t) iterator, sizeof(struct OpaqueDTEntryIterator));
+       kfree(iterator, sizeof(struct OpaqueDTEntryIterator));
        return kSuccess;
 }
 
@@ -347,7 +350,7 @@ DTExitEntry(DTEntryIterator iterator, DTEntry *currentPosition)
        iter->currentIndex = newScope->index;
        *currentPosition = iter->currentEntry;
 
-       kfree((vm_offset_t) newScope, sizeof(struct DTSavedScope));
+       kfree(newScope, sizeof(struct DTSavedScope));
 
        return kSuccess;
 }
@@ -396,10 +399,10 @@ DTRestartEntryIteration(DTEntryIterator iterator)
 }
 
 int
-DTGetProperty(const DTEntry entry, const char *propertyName, void **propertyValue, int *propertySize)
+DTGetProperty(const DTEntry entry, const char *propertyName, void **propertyValue, unsigned int *propertySize)
 {
        DeviceTreeNodeProperty *prop;
-       int k;
+       unsigned int k;
 
        if (entry == NULL || entry->nProperties == 0) {
                return kError;
@@ -407,7 +410,7 @@ DTGetProperty(const DTEntry entry, const char *propertyName, void **propertyValu
                prop = (DeviceTreeNodeProperty *) (entry + 1);
                for (k = 0; k < entry->nProperties; k++) {
                        if (strcmp(prop->name, propertyName) == 0) {
-                               *propertyValue = (void *) (((int)prop)
+                               *propertyValue = (void *) (((uintptr_t)prop)
                                                + sizeof(DeviceTreeNodeProperty));
                                *propertySize = prop->length;
                                return kSuccess;
@@ -435,7 +438,7 @@ DTCreatePropertyIterator(const DTEntry entry, DTPropertyIterator *iterator)
 int
 DTDisposePropertyIterator(DTPropertyIterator iterator)
 {
-       kfree((vm_offset_t)iterator, sizeof(struct OpaqueDTPropertyIterator));
+       kfree(iterator, sizeof(struct OpaqueDTPropertyIterator));
        return kSuccess;
 }