]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/ppc/ppc_init.c
xnu-1228.3.13.tar.gz
[apple/xnu.git] / osfmk / ppc / ppc_init.c
index b371e79e1ac7687f4736c0eabad50d2beaace8af..781eb38a19d0ba8b0c8092b8fc5bb733cf54f618 100644 (file)
@@ -1,5 +1,5 @@
 /*
 /*
- * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2007 Apple Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
@@ -54,7 +54,7 @@
 #include <ppc/mem.h>
 #include <ppc/mappings.h>
 #include <ppc/locks.h>
 #include <ppc/mem.h>
 #include <ppc/mappings.h>
 #include <ppc/locks.h>
-#include <ppc/pms.h>
+#include <kern/pms.h>
 #include <ppc/rtclock.h>
 
 #include <pexpert/pexpert.h>
 #include <ppc/rtclock.h>
 
 #include <pexpert/pexpert.h>
@@ -63,9 +63,6 @@ extern unsigned int mckFlags;
 extern vm_offset_t     intstack;
 extern vm_offset_t     debstack;  
 
 extern vm_offset_t     intstack;
 extern vm_offset_t     debstack;  
 
-int pc_trace_buf[1024] = {0};
-int pc_trace_cnt = 1024;
-
 extern unsigned int extPatchMCK;
 extern unsigned int extPatch32;
 extern unsigned int hwulckPatch_isync;
 extern unsigned int extPatchMCK;
 extern unsigned int extPatch32;
 extern unsigned int hwulckPatch_isync;
@@ -82,8 +79,6 @@ extern unsigned int rwlesPatch_isync;
 extern unsigned int rwlesPatch_eieio;
 extern unsigned int rwldPatch_isync;
 extern unsigned int rwldPatch_eieio;
 extern unsigned int rwlesPatch_eieio;
 extern unsigned int rwldPatch_isync;
 extern unsigned int rwldPatch_eieio;
-extern unsigned int retfsectPatch_eieio;
-extern unsigned int retfsectPatch_isync;
 extern unsigned int bcopy_nop_if_32bit;
 extern unsigned int bcopy_nc_nop_if_32bit;
 extern unsigned int memcpy_nop_if_32bit;
 extern unsigned int bcopy_nop_if_32bit;
 extern unsigned int bcopy_nc_nop_if_32bit;
 extern unsigned int memcpy_nop_if_32bit;
@@ -95,6 +90,8 @@ extern unsigned int uft_cuttrace;
 int forcenap = 0;
 int wcte = 0;                          /* Non-cache gather timer disabled */
 
 int forcenap = 0;
 int wcte = 0;                          /* Non-cache gather timer disabled */
 
+int debug_task;
+
 patch_entry_t patch_table[] = {
        {&extPatch32,                   0x60000000, PATCH_FEATURE,              PatchExt32},
        {&extPatchMCK,                  0x60000000, PATCH_PROCESSOR,    CPU_SUBTYPE_POWERPC_970},
 patch_entry_t patch_table[] = {
        {&extPatch32,                   0x60000000, PATCH_FEATURE,              PatchExt32},
        {&extPatchMCK,                  0x60000000, PATCH_PROCESSOR,    CPU_SUBTYPE_POWERPC_970},
@@ -115,10 +112,6 @@ patch_entry_t patch_table[] = {
        {&bcopy_nop_if_32bit,   0x60000000, PATCH_FEATURE,              PatchExt32},
        {&bcopy_nc_nop_if_32bit,0x60000000, PATCH_FEATURE,              PatchExt32},
        {&memcpy_nop_if_32bit,  0x60000000, PATCH_FEATURE,              PatchExt32},
        {&bcopy_nop_if_32bit,   0x60000000, PATCH_FEATURE,              PatchExt32},
        {&bcopy_nc_nop_if_32bit,0x60000000, PATCH_FEATURE,              PatchExt32},
        {&memcpy_nop_if_32bit,  0x60000000, PATCH_FEATURE,              PatchExt32},
-#if    !MACH_LDEBUG
-       {&retfsectPatch_isync,  0x60000000, PATCH_FEATURE,              PatchLwsync},
-       {&retfsectPatch_eieio,  0x7c2004ac, PATCH_FEATURE,              PatchLwsync},
-#endif
        {&xsum_nop_if_32bit,    0x60000000,     PATCH_FEATURE,          PatchExt32},
        {&uft_nop_if_32bit,             0x60000000,     PATCH_FEATURE,          PatchExt32},
        {&uft_uaw_nop_if_32bit, 0x60000000,     PATCH_FEATURE,          PatchExt32},
        {&xsum_nop_if_32bit,    0x60000000,     PATCH_FEATURE,          PatchExt32},
        {&uft_nop_if_32bit,             0x60000000,     PATCH_FEATURE,          PatchExt32},
        {&uft_uaw_nop_if_32bit, 0x60000000,     PATCH_FEATURE,          PatchExt32},
@@ -136,6 +129,7 @@ void        ppc_init(
 void   ppc_init_cpu(
                        struct per_proc_info *proc_info);
 
 void   ppc_init_cpu(
                        struct per_proc_info *proc_info);
 
+       
 /*
  *             Routine:                ppc_init
  *             Function:
 /*
  *             Routine:                ppc_init
  *             Function:
@@ -155,7 +149,6 @@ ppc_init(
        uint64_t                        scdata;
 
 
        uint64_t                        scdata;
 
 
-
        /*
         * Setup per_proc info for first cpu.
         */
        /*
         * Setup per_proc info for first cpu.
         */
@@ -168,8 +161,8 @@ ppc_init(
        BootProcInfo.debstackptr = BootProcInfo.debstack_top_ss;
        BootProcInfo.interrupts_enabled = 0;
        BootProcInfo.pending_ast = AST_NONE;
        BootProcInfo.debstackptr = BootProcInfo.debstack_top_ss;
        BootProcInfo.interrupts_enabled = 0;
        BootProcInfo.pending_ast = AST_NONE;
-       BootProcInfo.FPU_owner = 0;
-       BootProcInfo.VMX_owner = 0;
+       BootProcInfo.FPU_owner = NULL;
+       BootProcInfo.VMX_owner = NULL;
        BootProcInfo.pp_cbfr = console_per_proc_alloc(TRUE);
        BootProcInfo.rtcPop = EndOfAllTime;
        BootProcInfo.pp2ndPage = (addr64_t)&BootProcInfo;       /* Initial physical address of the second page */
        BootProcInfo.pp_cbfr = console_per_proc_alloc(TRUE);
        BootProcInfo.rtcPop = EndOfAllTime;
        BootProcInfo.pp2ndPage = (addr64_t)&BootProcInfo;       /* Initial physical address of the second page */
@@ -200,7 +193,9 @@ ppc_init(
        master_cpu = 0;
        processor_bootstrap();
 
        master_cpu = 0;
        processor_bootstrap();
 
-       timer_switch((uint32_t)mach_absolute_time(), &thread->system_timer);
+       timer_start(&thread->system_timer, mach_absolute_time());
+       PROCESSOR_DATA(master_processor, kernel_timer) =
+                               PROCESSOR_DATA(master_processor, thread_timer) = &thread->system_timer;
 
        static_memory_end = round_page(args->topOfKernelData);;
       
 
        static_memory_end = round_page(args->topOfKernelData);;
       
@@ -278,7 +273,7 @@ ppc_init(
                }
        }
                
                }
        }
                
-       machine_startup(args);
+       machine_startup();
 }
 
 /*
 }
 
 /*