]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/chud/chud_cpu.c
xnu-2050.7.9.tar.gz
[apple/xnu.git] / osfmk / chud / chud_cpu.c
index 4b7f8bdb7093423f4958151d8df04db20988619b..c21a40eb2af5075a7e897cd53f8b4d420ac8d7e4 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2003-2004 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2003-2007 Apple Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
  * 
  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
+
+
 #include <mach/mach_types.h>
 #include <mach/mach_host.h>
 
 #include <kern/host.h>
 #include <kern/processor.h>
 #include <kern/cpu_data.h>
-
+#include <kern/machine.h>
 #include <machine/machine_routines.h>
 
 #include <chud/chud_xnu.h>
 
+#if 0
 #pragma mark **** cpu count ****
+#endif
 
-__private_extern__ int
-chudxnu_avail_cpu_count(void)
+__private_extern__ int 
+chudxnu_logical_cpu_count(void)
 {
-    host_basic_info_data_t hinfo;
-    kern_return_t kr;
-    mach_msg_type_number_t count = HOST_BASIC_INFO_COUNT;
-
-    kr = host_info(host_self(), HOST_BASIC_INFO, (integer_t *)&hinfo, &count);
-    if(kr == KERN_SUCCESS) {
-        return hinfo.avail_cpus;
-    } else {
-        return 0;
-    }
+       return machine_info.logical_cpu_max;
 }
 
 __private_extern__ int
@@ -64,36 +59,19 @@ chudxnu_phys_cpu_count(void)
     if(kr == KERN_SUCCESS) {
         return hinfo.max_cpus;
     } else {
-        return 0;
+        return 1;  // fall back to 1, 0 doesn't make sense at all
     }
 }
 
-__private_extern__
-int chudxnu_cpu_number(void)
+__private_extern__ int
+chudxnu_cpu_number(void)
 {
     return cpu_number();
 }
 
-#pragma mark **** branch trace buffer ****
-
-extern int pc_trace_buf[1024];
-
-__private_extern__ uint32_t *
-chudxnu_get_branch_trace_buffer(uint32_t *entries)
-{
-    if(entries) {
-        *entries = sizeof(pc_trace_buf)/sizeof(int);
-    }
-    return pc_trace_buf;
-}
-
+#if 0
 #pragma mark **** interrupts enable/disable ****
-
-__private_extern__ boolean_t
-chudxnu_get_interrupts_enabled(void)
-{
-    return ml_get_interrupts_enabled();
-}
+#endif
 
 __private_extern__ boolean_t
 chudxnu_set_interrupts_enabled(boolean_t enable)
@@ -101,19 +79,15 @@ chudxnu_set_interrupts_enabled(boolean_t enable)
     return ml_set_interrupts_enabled(enable);
 }
 
-__private_extern__ boolean_t
-chudxnu_at_interrupt_context(void)
-{
-    return ml_at_interrupt_context();
-}
-
 __private_extern__ void
 chudxnu_cause_interrupt(void)
 {
     ml_cause_interrupt();
 }
 
+#if 0
 #pragma mark **** preemption enable/disable ****
+#endif
 
 __private_extern__ void
 chudxnu_enable_preemption(void)
@@ -132,3 +106,4 @@ chudxnu_get_preemption_level(void)
 {
        return get_preemption_level();
 }
+