]> git.saurik.com Git - apple/xnu.git/blobdiff - libsyscall/xcodescripts/mach_install_mig.sh
xnu-2422.1.72.tar.gz
[apple/xnu.git] / libsyscall / xcodescripts / mach_install_mig.sh
index 068bc30ad15fe8813bda017faa9f3f599a86c91a..ac66a4f2d1c32479c4e93d660a4a7fb33fdc07af 100755 (executable)
@@ -1,4 +1,4 @@
-#!/bin/sh
+#!/bin/sh -x
 #
 # Copyright (c) 2010 Apple Inc. All rights reserved.
 #
 cd $OBJROOT
 
 # check if we're building for the simulator
-[ "$RC_ProjectName" == "Libmach_Sim" ] && DSTROOT="$DSTROOT$SDKROOT"
+if [ "$PLATFORM_NAME" = "iphonesimulator" ] ; then
+       DSTROOT="${DSTROOT}${SDKROOT}"
+fi
 
 MIG=`xcrun -sdk "$SDKROOT" -find mig`
 MIGCC=`xcrun -sdk "$SDKROOT" -find cc`
 export MIGCC
 MIG_DEFINES="-DLIBSYSCALL_INTERFACE"
 MIG_HEADER_DST="$DSTROOT/usr/include/mach"
+MIG_PRIVATE_HEADER_DST="$DSTROOT/usr/local/include/mach"
 SERVER_HEADER_DST="$DSTROOT/usr/include/servers"
+MACH_HEADER_DST="$DSTROOT/usr/include/mach"
+
 # from old Libsystem makefiles
 MACHINE_ARCH=`echo $ARCHS | cut -d' ' -f 1`
+if [[ ( "$MACHINE_ARCH" = "x86_64" ) && `echo $ARCHS | wc -w` -gt 1 ]]
+then
+       # MACHINE_ARCH needs to be a 32-bit arch to generate vm_map_internal.h correctly.
+       MACHINE_ARCH=`echo $ARCHS | cut -d' ' -f 2`
+fi
 SRC="$SRCROOT/mach"
+MIG_INTERNAL_HEADER_DST="$DERIVED_SOURCES_DIR/mach"
+MIG_PRIVATE_DEFS_INCFLAGS="-I${SDKROOT}/System/Library/Frameworks/System.framework/PrivateHeaders"
 
 MIGS="clock.defs
        clock_priv.defs
@@ -49,29 +61,55 @@ MIGS="clock.defs
        exc.defs
        host_priv.defs
        host_security.defs
-       ledger.defs
        lock_set.defs
-       mach_port.defs
        mach_host.defs
-       mach_vm.defs
+       mach_port.defs
        processor.defs
        processor_set.defs
+       task.defs
+       thread_act.defs
        vm_map.defs"
 
-MIGS_ARCH="thread_act.defs
-       task.defs"
+MIGS_PRIVATE=""
+
+MIGS_DUAL_PUBLIC_PRIVATE=""
+
+if [[ "$PLATFORM_NAME" = "iphoneos" || "$PLATFORM_NAME" = "iphonesimulator"  ]]
+then
+       MIGS_PRIVATE="mach_vm.defs"
+else
+       MIGS+=" mach_vm.defs"
+fi
+
+MIGS_INTERNAL="mach_port.defs
+       mach_vm.defs
+       vm_map.defs"
 
 SERVER_HDRS="key_defs.h
        ls_defs.h
        netname_defs.h
        nm_defs.h"
 
+MACH_HDRS="mach.h
+       mach_error.h
+       mach_init.h
+       mach_interface.h
+       port_obj.h
+       sync.h
+       vm_task.h"
+
 # install /usr/include/server headers 
 mkdir -p $SERVER_HEADER_DST
 for hdr in $SERVER_HDRS; do
        install -o 0 -c -m 444 $SRC/servers/$hdr $SERVER_HEADER_DST
 done
 
+# install /usr/include/mach headers
+mkdir -p $MACH_HEADER_DST
+for hdr in $MACH_HDRS; do
+       install -o 0 -c -m 444 $SRC/mach/$hdr $MACH_HEADER_DST
+done
+
 # special case because we only have one to do here
 $MIG -arch $MACHINE_ARCH -header "$SERVER_HEADER_DST/netname.h" $SRC/servers/netname.defs
 
@@ -79,19 +117,30 @@ $MIG -arch $MACHINE_ARCH -header "$SERVER_HEADER_DST/netname.h" $SRC/servers/net
 
 mkdir -p $MIG_HEADER_DST
 
-for mig in $MIGS; do
+for mig in $MIGS $MIGS_DUAL_PUBLIC_PRIVATE; do
        MIG_NAME=`basename $mig .defs`
        $MIG -arch $MACHINE_ARCH -cc $MIGCC -header "$MIG_HEADER_DST/$MIG_NAME.h" $MIG_DEFINES $SRC/$mig
 done
 
-ARCHS=`echo $ARCHS | sed -e 's/armv./arm/g'`
-for arch in $ARCHS; do
-       MIG_ARCH_DST="$MIG_HEADER_DST/$arch"
+mkdir -p $MIG_PRIVATE_HEADER_DST
 
-       mkdir -p $MIG_ARCH_DST
+for mig in $MIGS_PRIVATE $MIGS_DUAL_PUBLIC_PRIVATE; do
+       MIG_NAME=`basename $mig .defs`
+       $MIG -arch $MACHINE_ARCH -cc $MIGCC -header "$MIG_PRIVATE_HEADER_DST/$MIG_NAME.h" $MIG_DEFINES $MIG_PRIVATE_DEFS_INCFLAGS $SRC/$mig
+       if [ ! -e "$MIG_HEADER_DST/$MIG_NAME.h" ]; then
+           echo "#error $MIG_NAME.h unsupported." > "$MIG_HEADER_DST/$MIG_NAME.h"
+       fi
+done
 
-       for mig in $MIGS_ARCH; do
-               MIG_NAME=`basename $mig .defs`
-               $MIG -arch $MACHINE_ARCH -cc $MIGCC -header "$MIG_ARCH_DST/$MIG_NAME.h" $MIG_DEFINES $SRC/$mig
-       done    
+
+# special headers used just for building Libsyscall
+# Note: not including -DLIBSYSCALL_INTERFACE to mig so we'll get the proper
+#  'internal' version of the headers being built
+mkdir -p $MIG_INTERNAL_HEADER_DST
+for mig in $MIGS_INTERNAL; do
+       MIG_NAME=`basename $mig .defs`
+       $MIG -arch $MACHINE_ARCH -cc $MIGCC -header "$MIG_INTERNAL_HEADER_DST/${MIG_NAME}_internal.h" $SRC/$mig
 done