]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/ppc/mcount.s
xnu-1228.12.14.tar.gz
[apple/xnu.git] / osfmk / ppc / mcount.s
index 8c91e175f507db25072c649c61b1a33f85e18ee1..fd25185674109f8b41b1158783fd9447977b8e4d 100644 (file)
@@ -1,16 +1,19 @@
 /*
  * Copyright (c) 2000 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
  * Please see the License for the specific language governing rights and
  * limitations under the License.
  * 
- * @APPLE_LICENSE_HEADER_END@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 #include <ppc/asm.h>
 #include <ppc/proc_reg.h>
-#include <cpus.h>
 #include <assym.s>
 #include <debug.h>
 #include <mach/ppc/vm_param.h>
@@ -53,7 +55,8 @@ mcount:
                rlwinm  r8,r9,0,MSR_EE_BIT+1,MSR_EE_BIT-1       ; Turn off interruptions
                mtmsr   r8                                                                      ; Update msr    
                isync           
-               mfsprg  r7,0                                                            ; Get per_proc
+               mfsprg  r7,1                                                            ; Get the current activation
+               lwz             r7,ACT_PER_PROC(r7)                                     ; Get the per_proc block
                lhz             r6,PP_CPU_FLAGS(r7)                                     ; Get  cpu flags 
                ori             r5,r6,mcountOff                                         ; 
                cmplw   r5,r6                                                           ; is mount off
@@ -63,7 +66,8 @@ mcount:
                mr r4, r0
                bl      _mcount                                                                 ; Call the C routine
                lwz     r9,FM_ARG0(r1)
-               mfsprg  r7,0                                                            ; Get per-proc block
+               mfsprg  r7,1                                                            ; Get the current activation
+               lwz             r7,ACT_PER_PROC(r7)                                     ; Get the per_proc block
                lhz             r6,PP_CPU_FLAGS(r7)                                     ; Get CPU number 
                li              r5,mcountOff                                            ; 
                andc            r6,r6,r5                                                ; Clear mcount_off