Annotation of gcc/va-pyr.h, revision 1.1.1.2

1.1       root        1: /**
                      2:  *
                      3:  *     Varargs for PYR/GNU CC
                      4:  *
                      5:  * WARNING -- WARNING -- DANGER
                      6:  *
                      7:  * The code in this file implements varargs for gcc on a pyr in
                      8:  * a way that is compatible with code compiled by the Pyramid Technology
                      9:  * C compiler.
                     10:  * As such, it depends strongly on the Pyramid conventions for
                     11:  * parameter passing.ct and indepenent implementation. 
                     12:  * These (somewhat bizarre) paramter-passing conventions are described
                     13:  * in the ``OSx Operating System Porting Guide''.
                     14:  * 
                     15:  * A quick summary is useful:
                     16:  * 12 of the 48 register-windowed regs available for
                     17:  * parameter passing.  Parameters of a function call that are eligible
                     18:  * to be passed in registers are assigned registers from TR0/PR0 onwards;
                     19:  * all other arguments are passed on the stack.
                     20:  * Structure and union parameters are *never* passed in registers,
                     21:  * even if they are small enough to fit.  They are always passed on
                     22:  * the stack.
                     23:  *
                     24:  * Double-sized parameters cannot be passed in TR11, because
                     25:  * TR12 is not used for passing parameters.  If, in the absence of this
                     26:  * rule, a double-sized param would have been passed in TR11,
                     27:  * that parameter is passed on the stack and no parameters are
                     28:  * passed in TR11.
                     29:  * 
                     30:  * It is only known to work for passing 32-bit integer quantities
                     31:  * (ie chars, shorts, ints/enums, longs), doubles, or pointers. 
                     32:  * Passing structures on a Pyramid via varargs is a loser.
                     33:  * Passing an object larger than 8 bytes on a pyramid via varargs may
                     34:  * also be a loser.
                     35:  * 
                     36:  */
                     37: 
                     38: 
                     39: /*
1.1.1.2 ! root       40:  *  pointer to next stack parameter in __va_buf[0]
        !            41:  *  pointer to next parameter register in __va_buf[1]
        !            42:  *  Count of registers seen at __va_buf[2]
        !            43:  *  saved pr0..pr11 in __va_buf[3..14]
        !            44:  *  # of calls to va_arg (debugging) at __va_buf[15]
1.1       root       45:  */
                     46: 
1.1.1.2 ! root       47: typedef void *__voidptr;
1.1       root       48: #if 1
                     49: 
1.1.1.2 ! root       50: typedef struct __va_regs {
        !            51:       __voidptr __stackp,__regp,__count;
        !            52:       __voidptr __pr0,__pr1,__pr2,__pr3,__pr4,__pr5,__pr6,__pr7,__pr8,__pr9,__pr10,__pr11;
        !            53:   } __va_regs;
1.1       root       54: 
1.1.1.2 ! root       55: typedef __va_regs __va_buf;
1.1       root       56: #else
                     57: 
1.1.1.2 ! root       58: /* __va_buf[0] = address of next arg passed on the stack
        !            59:    __va_buf[1] = address of next arg passed in a register
        !            60:    __va_buf[2] = register-# of next arg passed in a register
        !            61: */
        !            62: typedef __voidptr(*__va_buf);
1.1       root       63: 
                     64: #endif
                     65: 
                     66: #define va_alist \
1.1.1.2 ! root       67:   __va0,__va1,__va2,__va3,__va4,__va5,__va6,__va7,__va8,__va9,__va10,__va11, \
        !            68:   __builtin_va_alist
1.1       root       69: 
1.1.1.2 ! root       70: #define va_dcl __voidptr va_alist;
1.1       root       71: 
1.1.1.2 ! root       72: #define va_list __va_buf
1.1       root       73: 
                     74: 
                     75: /* __asm ("rcsp %0" : "=r" ( _AP [0]));*/
                     76: 
                     77: #define va_start(_AP)  \
1.1.1.2 ! root       78:   _AP =  ((struct __va_regs) {                                         \
        !            79:    &(_AP.__pr0), (void*)&__builtin_va_alist, (void*)0,                 \
        !            80:         __va0,__va1,__va2,__va3,__va4,__va5,                           \
        !            81:        __va6,__va7,__va8,__va9,__va10,__va11})
1.1       root       82:  
                     83:   
                     84:         
                     85: 
                     86: #define va_arg(_AP, _MODE)     \
1.1.1.2 ! root       87: ({__voidptr *__ap = (__voidptr*)&_AP;                                  \
        !            88:   register int __size = sizeof (_MODE);                                        \
        !            89:   register int __onstack =                                             \
        !            90:          (__size > 8 || ( (int)(__ap[2]) > 11) ||                      \
        !            91:            (__size==8 && (int)(__ap[2])==11));                         \
        !            92:   register int* __param_addr =  ((int*)((__ap) [__onstack]));          \
1.1       root       93:                                                                        \
1.1.1.2 ! root       94:   ((void *)__ap[__onstack])+=__size;                                   \
        !            95:     if (__onstack==0 || (int)(__ap[2])==11)                            \
        !            96:       __ap[2]+= (__size >> 2);                                         \
        !            97:   *(( _MODE *)__param_addr);                                           \
1.1       root       98: })
                     99: 
1.1.1.2 ! root      100: #define va_end(_X)

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.