]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/i386/postcode.h
xnu-3789.70.16.tar.gz
[apple/xnu.git] / osfmk / i386 / postcode.h
index 42a4627b0c84e77d41333b1f0c998032b6dc4542..d2a8593547e946f7d293b05f7a5f55ef9aba8fe6 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2003 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2008 Apple Computer, Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
 #ifndef        _I386_POSTCODE_H_
 #define        _I386_POSTCODE_H_
 
-#ifndef DEBUG
-#include <debug.h>
-#endif
+/*
+ * Postcodes are no longer enabled by default in the DEBUG kernel
+ * because platforms may not have builtin port 0x80 support.
+ * To re-enable postcode outpout, uncomment the following define:
+ */
+//#define DEBUG_POSTCODE 1
 
 /* Define this to delay about 1 sec after posting each code */
 //#define POSTCODE_DELAY 1
@@ -42,7 +45,7 @@
 #define        SPINCOUNT       300000000
 #define CPU_PAUSE()    rep; nop
 
-#if DEBUG
+#if DEBUG_POSTCODE
 /*
  * Macro to output byte value to postcode, destoying register al.
  * Additionally, if POSTCODE_DELAY, spin for about a second.
        CPU_PAUSE();                    \
        decl    %eax;                   \
        jne     1b
+#define POSTCODE_AX                    \
+        outw    %ax,$(POSTPORT);       \
+       movl    $(SPINCOUNT), %eax;     \
+1:                                     \
+       CPU_PAUSE();                    \
+       decl    %eax;                   \
+       jne     1b
 #else
 #define POSTCODE_AL                    \
         outb    %al,$(POSTPORT)
+#define POSTCODE_AX                    \
+        outw    %ax,$(POSTPORT)
 #endif /* POSTCODE_DELAY */
 
 #define POSTCODE(XX)                   \
        mov     $(XX), %al;             \
        POSTCODE_AL
 
+#define POSTCODE2(XXXX)                        \
+       mov     $(XXXX), %ax;           \
+       POSTCODE_AX
+
 /* Output byte value to postcode, without destoying register eax */ 
 #define        POSTCODE_SAVE_EAX(XX)           \
        push    %eax;                   \
        movl    %ebx, %eax;             \
        POSTCODE_AL
 
-#else  /* DEBUG */
+#else  /* DEBUG_POSTCODE */
 #define POSTCODE_AL
+#define POSTCODE_AX
 #define POSTCODE(X)
+#define POSTCODE2(X)
+#define POSTCODE_SAVE_EAX(X)
 #define POSTCODE32_EBX
-#endif /* DEBUG */
+#endif /* DEBUG_POSTCODE */
 
 /*
  * The following postcodes are defined for stages of early startup:
  */
 
-#define        _PSTART_ENTRY                   0xFF
-#define        _PSTART_RELOC                   0xFE
-#define        PSTART_ENTRY                    0xFD
-#define PSTART_PAGE_TABLES             0xFC
-#define PSTART_BEFORE_PAGING           0xFB
-#define VSTART_ENTRY                   0xFA
-#define VSTART_STACK_SWITCH            0xF9
-#define VSTART_EXIT                    0xF8
-#define        I386_INIT_ENTRY                 0xF7
-#define        CPU_INIT_D                      0xF6
-#define        PE_INIT_PLATFORM_D              0xF5
-
-#define        SLAVE_RSTART_ENTRY              0xEF
-#define        SLAVE_REAL_TO_PROT_ENTRY        0xEE
-#define        SLAVE_REAL_TO_PROT_EXIT         0xED
-#define        SLAVE_STARTPROG_ENTRY           0xEC
-#define        SLAVE_STARTPROG_EXIT            0xEB
-#define        SLAVE_PSTART_ENTRY              0xEA
-#define        SLAVE_PSTART_EXIT               0xE9
-#define        SLAVE_VSTART_ENTRY              0xE8
-#define        SLAVE_VSTART_DESC_INIT          0xE7
-#define        SLAVE_VSTART_STACK_SWITCH       0xE6
-#define        SLAVE_VSTART_EXIT               0xE5
-#define        I386_INIT_SLAVE                 0xE4
+#define        PSTART_ENTRY                    0xFF
+#define PSTART_REBASE                  0xFE
+#define PSTART_BEFORE_PAGING           0xFE
+#define        PSTART_VSTART                   0xFD
+#define VSTART_ENTRY                   0xFC
+#define VSTART_IDLE_PTS_INIT           0xFB
+#define VSTART_PHYSMAP_INIT            0xFA
+#define VSTART_DESC_ALIAS_INIT         0xF9
+#define VSTART_SET_CR3                 0xF8
+#define VSTART_CPU_DESC_INIT           0xF7
+#define VSTART_CPU_MODE_INIT           0xF6
+#define VSTART_EXIT                    0xF5
+#define        I386_INIT_ENTRY                 0xF4
+#define        CPU_INIT_D                      0xF3
+#define        PE_INIT_PLATFORM_D              0xF2
+
+#define        SLAVE_STARTPROG_ENTRY           0xEF
+#define        SLAVE_PSTART                    0xEE
+#define        I386_INIT_SLAVE                 0xED
 
 #define        PANIC_DOUBLE_FAULT              0xDF    /* Double Fault exception */
 #define        PANIC_MACHINE_CHECK             0xDE    /* Machine-Check */
@@ -162,7 +176,12 @@ _postcode(uint8_t  xx)
 {
        asm volatile("outb %0, %1" : : "a" (xx), "N" (POSTPORT));
 }
-#if    DEBUG
+inline static void
+_postcode2(uint16_t    xxxx)
+{
+       asm volatile("outw %0, %1" : : "a" (xxxx), "N" (POSTPORT));
+}
+#if    DEBUG_POSTCODE
 inline static void
 postcode(uint8_t       xx)
 {
@@ -171,8 +190,17 @@ postcode(uint8_t   xx)
        _postcode_delay(SPINCOUNT);
 #endif
 }
+inline static void
+postcode2(uint8_t      xxxx)
+{
+       _postcode2(xxxx);
+#if    POSTCODE_DELAY
+       _postcode_delay(SPINCOUNT);
+#endif
+}
 #else
 #define postcode(xx) do {} while(0)
+#define postcode2(xxxx) do {} while(0)
 #endif
 #endif