]> git.saurik.com Git - apple/xnu.git/blobdiff - libsa/dgraph.c
xnu-1228.tar.gz
[apple/xnu.git] / libsa / dgraph.c
index 50abd38cbf5f790ed3e8a2ebc830f740c8546f8b..03ecb38896444f81b2f246d2cd131ba74e804a8d 100644 (file)
@@ -1,3 +1,31 @@
+/*
+ * Copyright (c) 2004-2007 Apple 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. 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
+ * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
+ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
+ * Please see the License for the specific language governing rights and
+ * limitations under the License.
+ * 
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
+ */
+
 #ifdef KERNEL
 #include <libsa/vers_rsrc.h>
 #else
 #ifdef KERNEL
 #include <libsa/vers_rsrc.h>
 #else
 #include "dgraph.h"
 #include "load.h"
 
 #include "dgraph.h"
 #include "load.h"
 
+#ifdef KERNEL
+#include <sys/malloc.h>
+#endif
 
 static void __dgraph_entry_free(dgraph_entry_t * entry);
 
 #ifdef KERNEL
 
 static void __dgraph_entry_free(dgraph_entry_t * entry);
 
 #ifdef KERNEL
-/*******************************************************************************
-*
-*******************************************************************************/
-char * strdup(const char * string)
-{
-    char * dup = 0;
-    unsigned int length;
-
-    length = strlen(string);
-    dup = (char *)malloc((1+length) * sizeof(char));
-    if (!dup) {
-        return NULL;
-    }
-    strcpy(dup, string);
-    return dup;
-}
-
+#define dgstrdup(string) STRDUP(string, M_TEMP)
+#define dgfree(string) FREE(string, M_TEMP)
+#else
+#define dgstrdup strdup
+#define dgfree(string) free(string)
 #endif /* KERNEL */
 
 /*******************************************************************************
 #endif /* KERNEL */
 
 /*******************************************************************************
@@ -159,15 +178,15 @@ dgraph_error_t dgraph_init_with_arglist(
 static void __dgraph_entry_free(dgraph_entry_t * entry)
 {
     if (entry->name) {
 static void __dgraph_entry_free(dgraph_entry_t * entry)
 {
     if (entry->name) {
-        free(entry->name);
+        dgfree(entry->name);
         entry->name = NULL;
     }
     if (entry->expected_kmod_name) {
         entry->name = NULL;
     }
     if (entry->expected_kmod_name) {
-        free(entry->expected_kmod_name);
+        dgfree(entry->expected_kmod_name);
         entry->expected_kmod_name = NULL;
     }
     if (entry->expected_kmod_vers) {
         entry->expected_kmod_name = NULL;
     }
     if (entry->expected_kmod_vers) {
-        free(entry->expected_kmod_vers);
+        dgfree(entry->expected_kmod_vers);
         entry->expected_kmod_vers = NULL;
     }
     if (entry->dependencies) {
         entry->expected_kmod_vers = NULL;
     }
     if (entry->dependencies) {
@@ -176,7 +195,7 @@ static void __dgraph_entry_free(dgraph_entry_t * entry)
     }
     if (entry->symbols_malloc) {
         free((void *) entry->symbols_malloc);
     }
     if (entry->symbols_malloc) {
         free((void *) entry->symbols_malloc);
-        entry->symbols_malloc = NULL;
+        entry->symbols_malloc = 0;
     }
     free(entry);
     return;
     }
     free(entry);
     return;
@@ -296,7 +315,7 @@ dgraph_entry_t ** fill_backward_load_order(
     dgraph_entry_t * first_entry,
     unsigned int * last_index /* out param */)
 {
     dgraph_entry_t * first_entry,
     unsigned int * last_index /* out param */)
 {
-    int i;
+    unsigned int i;
     unsigned int scan_index = 0;
     unsigned int add_index = 0;
     dgraph_entry_t * scan_entry;
     unsigned int scan_index = 0;
     unsigned int add_index = 0;
     dgraph_entry_t * scan_entry;
@@ -527,6 +546,10 @@ dgraph_entry_t * dgraph_add_dependent(
     void * object,
     size_t object_length,
     bool   object_is_kmem,
     void * object,
     size_t object_length,
     bool   object_is_kmem,
+#if CONFIG_MACF_KEXT
+    kmod_args_t user_data,
+    mach_msg_type_number_t user_data_length,
+#endif
 #endif /* KERNEL */
     const char * expected_kmod_name,
     const char * expected_kmod_vers,
 #endif /* KERNEL */
     const char * expected_kmod_name,
     const char * expected_kmod_vers,
@@ -600,12 +623,12 @@ dgraph_entry_t * dgraph_add_dependent(
         goto finish;
     }
     bzero(new_entry, sizeof(dgraph_entry_t));
         goto finish;
     }
     bzero(new_entry, sizeof(dgraph_entry_t));
-    new_entry->expected_kmod_name = strdup(expected_kmod_name);
+    new_entry->expected_kmod_name = dgstrdup(expected_kmod_name);
     if (!new_entry->expected_kmod_name) {
         error = 1;
         goto finish;
     }
     if (!new_entry->expected_kmod_name) {
         error = 1;
         goto finish;
     }
-    new_entry->expected_kmod_vers = strdup(expected_kmod_vers);
+    new_entry->expected_kmod_vers = dgstrdup(expected_kmod_vers);
     if (!new_entry->expected_kmod_vers) {
         error = 1;
         goto finish;
     if (!new_entry->expected_kmod_vers) {
         error = 1;
         goto finish;
@@ -614,8 +637,14 @@ dgraph_entry_t * dgraph_add_dependent(
 
     // /hacks
     new_entry->is_symbol_set = (2 & is_kernel_component);
 
     // /hacks
     new_entry->is_symbol_set = (2 & is_kernel_component);
-    new_entry->opaques = !strncmp(new_entry->expected_kmod_name, 
-                                   "com.apple.kpi", strlen("com.apple.kpi"));
+
+    new_entry->opaques = 0;
+    if (!strncmp(new_entry->expected_kmod_name, 
+                                   "com.apple.kpi", strlen("com.apple.kpi")))
+        new_entry->opaques |= kOpaqueLink;
+    if (!strcmp(new_entry->expected_kmod_name, 
+                                   "com.apple.kernel"))
+        new_entry->opaques |= kOpaqueLink | kRawKernelLink;
     // hacks/
 
     dgraph->has_symbol_sets |= new_entry->is_symbol_set;
     // hacks/
 
     dgraph->has_symbol_sets |= new_entry->is_symbol_set;
@@ -629,8 +658,12 @@ dgraph_entry_t * dgraph_add_dependent(
     new_entry->object = object;
     new_entry->object_length = object_length;
     new_entry->object_is_kmem = object_is_kmem;
     new_entry->object = object;
     new_entry->object_length = object_length;
     new_entry->object_is_kmem = object_is_kmem;
+#if CONFIG_MACF_KEXT
+    new_entry->user_data = user_data;
+    new_entry->user_data_length = user_data_length;
+#endif
 #endif /* KERNEL */
 #endif /* KERNEL */
-    new_entry->name = strdup(name);
+    new_entry->name = dgstrdup(name);
     if (!new_entry->name) {
         error = 1;
         goto finish;
     if (!new_entry->name) {
         error = 1;
         goto finish;
@@ -677,6 +710,10 @@ dgraph_entry_t * dgraph_add_dependency(
     void * object,
     size_t object_length,
     bool   object_is_kmem,
     void * object,
     size_t object_length,
     bool   object_is_kmem,
+#if CONFIG_MACF_KEXT
+    kmod_args_t user_data,
+    mach_msg_type_number_t user_data_length,
+#endif
 #endif /* KERNEL */
     const char * expected_kmod_name,
     const char * expected_kmod_vers,
 #endif /* KERNEL */
     const char * expected_kmod_name,
     const char * expected_kmod_vers,
@@ -714,6 +751,9 @@ dgraph_entry_t * dgraph_add_dependency(
     dependency = dgraph_add_dependent(dgraph, name,
 #ifdef KERNEL
          object, object_length, object_is_kmem,
     dependency = dgraph_add_dependent(dgraph, name,
 #ifdef KERNEL
          object, object_length, object_is_kmem,
+#if CONFIG_MACF_KEXT
+         user_data, user_data_length,
+#endif
 #endif /* KERNEL */
          expected_kmod_name, expected_kmod_vers, load_address,
          is_kernel_component);
 #endif /* KERNEL */
          expected_kmod_name, expected_kmod_vers, load_address,
          is_kernel_component);