Annotation of researchv10dc/cmd/gcc/tm-hp9k320.h, revision 1.1.1.1

1.1       root        1: /* Definitions of target machine for GNU compiler.  HP-UX 68000/68020 version.
                      2:    Copyright (C) 1987, 1988 Free Software Foundation, Inc.
                      3: 
                      4: This file is part of GNU CC.
                      5: 
                      6: GNU CC is distributed in the hope that it will be useful,
                      7: but WITHOUT ANY WARRANTY.  No author or distributor
                      8: accepts responsibility to anyone for the consequences of using it
                      9: or for whether it serves any particular purpose or works at all,
                     10: unless he says so in writing.  Refer to the GNU CC General Public
                     11: License for full details.
                     12: 
                     13: Everyone is granted permission to copy, modify and redistribute
                     14: GNU CC, but only under the conditions described in the
                     15: GNU CC General Public License.   A copy of this license is
                     16: supposed to have been given to you along with GNU CC so you
                     17: can know your rights and responsibilities.  It should be in a
                     18: file named COPYING.  Among other things, the copyright notice
                     19: and this notice must be preserved on all copies.  */
                     20: 
                     21: /* Define USE_GAS if GCC is supposed to work with the GNU assembler,
                     22:    GNU linker and GNU debugger using DBX debugging information.
                     23:    (In other words, much of HPUX has been cast aside.)
                     24:    Undefine USE_GAS if you want GCC to feed the HP assembler.  */
                     25: 
                     26: /* #define USE_GAS */  /* Use tm-hp9k320g.h if you want this.  */
                     27: 
                     28: /* Control assembler-syntax conditionals in m68k.md.  */
                     29: 
                     30: #ifndef USE_GAS
                     31: #define MOTOROLA
                     32: #define SGS
                     33: #define HPUX_ASM
                     34: #endif
                     35: 
                     36: #include "tm-m68k.h"
                     37: 
                     38: /* See tm-m68k.h.  7 means 68020 with 68881.  */
                     39: 
                     40: #define        TARGET_DEFAULT 7
                     41: 
                     42: /* Names to predefine in the preprocessor for this target machine.  */
                     43: 
                     44: #ifdef HPUX_ASM
                     45: /* This is needed because some programs, particularly GDB, need to
                     46:    know which assembler is being used so that the correct `asm'
                     47:    instructions can be used. */
                     48: #define CPP_PREDEFINES "-Dhp9000s200 -Dhp9000s300 -DPWB -Dmc68k -Dmc68000 -Dhpux -Dunix -D__HPUX_ASM__"
                     49: #else
                     50: #define CPP_PREDEFINES "-Dhp9000s200 -Dhp9000s300 -DPWB -Dmc68k -Dmc68000 -Dhpux -Dunix"
                     51: #endif
                     52: 
                     53: /* Every structure or union's size must be a multiple of 2 bytes.  */
                     54: 
                     55: #define STRUCTURE_SIZE_BOUNDARY 16
                     56: 
                     57: /* Generate calls to memcpy, memcmp and memset.  */
                     58: #define TARGET_MEM_FUNCTIONS
                     59: 
                     60: /* Function calls don't save any fp registers on hpux.  */
                     61: 
                     62: #undef CALL_USED_REGISTERS
                     63: #define CALL_USED_REGISTERS                                            \
                     64:  {1, 1, 0, 0, 0, 0, 0, 0,                                              \
                     65:   1, 1, 0, 0, 0, 0, 0, 1,                                              \
                     66:   1, 1, 1, 1, 1, 1, 1, 1}
                     67: 
                     68: #ifdef HPUX_ASM
                     69: 
                     70: /* Override parts of tm-m68k.h to fit the HPUX assembler.  */
                     71: 
                     72: #undef TARGET_VERSION
                     73: #undef REGISTER_NAMES
                     74: #undef FUNCTION_PROLOGUE
                     75: #undef FUNCTION_EPILOGUE
                     76: #undef ASM_FILE_START
                     77: #undef ASM_APP_ON
                     78: #undef ASM_APP_OFF
                     79: #undef TEXT_SECTION_ASM_OP
                     80: #undef DATA_SECTION_ASM_OP
                     81: #undef ASM_OUTPUT_DOUBLE
                     82: #undef ASM_OUTPUT_FLOAT
                     83: #undef ASM_OUTPUT_INT
                     84: #undef ASM_OUTPUT_SHORT
                     85: #undef ASM_OUTPUT_CHAR
                     86: #undef ASM_OUTPUT_BYTE
                     87: #undef ASM_OUTPUT_ADDR_VEC_ELT
                     88: #undef ASM_OUTPUT_ADDR_DIFF_ELT
                     89: #undef ASM_OUTPUT_ALIGN
                     90: #undef ASM_OUTPUT_SKIP
                     91: #undef ASM_OUTPUT_COMMON
                     92: #undef ASM_OUTPUT_LOCAL
                     93: #undef ASM_FORMAT_PRIVATE_NAME
                     94: #undef PRINT_OPERAND
                     95: #undef PRINT_OPERAND_ADDRESS
                     96: #undef FUNCTION_PROFILER
                     97: #undef ASM_GLOBALIZE_LABEL
                     98: #undef ASM_OUTPUT_INTERNAL_LABEL
                     99: 
                    100: #define TARGET_VERSION printf (" (68k, SGS/hpux syntax)");
                    101: 
                    102: #define NO_DBX_FORMAT
                    103: 
                    104: #define ASM_SPEC "%{m68000:+X}"
                    105: 
                    106: #define REGISTER_NAMES \
                    107: {"%d0", "%d1", "%d2", "%d3", "%d4", "%d5", "%d6", "%d7",       \
                    108:  "%a0", "%a1", "%a2", "%a3", "%a4", "%a5", "%fp", "%sp",       \
                    109:  "%fp0", "%fp1", "%fp2", "%fp3", "%fp4", "%fp5", "%fp6", "%fp7"}
                    110: 
                    111: #define FUNCTION_PROLOGUE(FILE, SIZE)     \
                    112: { register int regno;                                          \
                    113:   register int mask = 0;                                       \
                    114:   static char *reg_names[] = REGISTER_NAMES;                   \
                    115:   extern char call_used_regs[];                                        \
                    116:   int fsize = (SIZE);                                          \
                    117:   if (frame_pointer_needed)                                    \
                    118:     { if (TARGET_68020 || fsize < 0x8000)                      \
                    119:         fprintf (FILE, "\tlink.w %%a6,&%d\n", -fsize);         \
                    120:       else                                                     \
                    121:        fprintf (FILE, "\tlink.w %%a6,&0\n\tsub.l &%d,%%sp\n", fsize); }  \
                    122:   for (regno = 16; regno < FIRST_PSEUDO_REGISTER; regno++)     \
                    123:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
                    124:        mask |= 1 << (regno - 16);                              \
                    125:   if (mask != 0)                                               \
                    126:     fprintf (FILE, "\tfmovem &0x%x,-(%%sp)\n", mask & 0xff);       \
                    127:   mask = 0;                                                    \
                    128:   for (regno = 0; regno < 16; regno++)                         \
                    129:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
                    130:        mask |= 1 << (15 - regno);                              \
                    131:   if (frame_pointer_needed)                                    \
                    132:     mask &= ~ (1 << (15-FRAME_POINTER_REGNUM));                        \
                    133:   if (exact_log2 (mask) >= 0)                                  \
                    134:     fprintf (FILE, "\tmov.l %s,-(%%sp)\n", reg_names[15 - exact_log2 (mask)]);  \
                    135:   else if (mask) fprintf (FILE, "\tmovm.l &0x%x,-(%%sp)\n", mask); }
                    136: 
                    137: #define FUNCTION_PROFILER(FILE, LABEL_NO) \
                    138:    fprintf (FILE, "\tmov.l &LP%d,%%d0\n\tjsr mcount\n", (LABEL_NO));
                    139: 
                    140: #define FUNCTION_EPILOGUE(FILE, SIZE) \
                    141: { register int regno;                                          \
                    142:   register int mask, fmask;                                    \
                    143:   register int nregs;                                          \
                    144:   int offset, foffset;                                         \
                    145:   extern char call_used_regs[];                                        \
                    146:   static char *reg_names[] = REGISTER_NAMES;                   \
                    147:   extern int current_function_pops_args;                       \
                    148:   extern int current_function_args_size;                       \
                    149:   int fsize = (SIZE);                                          \
                    150:   int big = 0;                                                 \
                    151:   nregs = 0;  fmask = 0;                                       \
                    152:   for (regno = 16; regno < FIRST_PSEUDO_REGISTER; regno++)     \
                    153:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
                    154:       { nregs++; fmask |= 1 << (23 - regno); }                 \
                    155:   foffset = nregs * 12;                                                \
                    156:   nregs = 0;  mask = 0;                                                \
                    157:   if (frame_pointer_needed) regs_ever_live[FRAME_POINTER_REGNUM] = 0; \
                    158:   for (regno = 0; regno < 16; regno++)                         \
                    159:     if (regs_ever_live[regno] && ! call_used_regs[regno])      \
                    160:       { nregs++; mask |= 1 << regno; }                         \
                    161:   offset = foffset + nregs * 4;                                        \
                    162:   if (offset + fsize >= 0x8000 && frame_pointer_needed)                \
                    163:     { fprintf (FILE, "\tmov.l &%d,%%a0\n", -fsize);            \
                    164:       fsize = 0, big = 1; }                                    \
                    165:   if (exact_log2 (mask) >= 0) {                                        \
                    166:     if (big)                                                   \
                    167:       fprintf (FILE, "\tmov.l -%d(%%a6,%%a0.l),%s\n",          \
                    168:               offset + fsize, reg_names[exact_log2 (mask)]);   \
                    169:     else if (! frame_pointer_needed)                           \
                    170:       fprintf (FILE, "\tmov.l (%%sp)+,%s\n",                   \
                    171:               reg_names[exact_log2 (mask)]);                   \
                    172:     else                                                       \
                    173:       fprintf (FILE, "\tmov.l -%d(%%a6),%s\n",                 \
                    174:               offset + fsize, reg_names[exact_log2 (mask)]); } \
                    175:   else if (mask) {                                             \
                    176:     if (big)                                                   \
                    177:       fprintf (FILE, "\tmovm.l -%d(%%a6,%%a0.l),&0x%x\n",      \
                    178:               offset + fsize, mask);                           \
                    179:     else if (! frame_pointer_needed)                           \
                    180:       fprintf (FILE, "\tmovm.l (%%sp)+,&0x%x\n", mask);                \
                    181:     else                                                       \
                    182:       fprintf (FILE, "\tmovm.l -%d(%%a6),&0x%x\n",             \
                    183:               offset + fsize, mask); }                         \
                    184:   if (fmask) {                                                 \
                    185:     if (big)                                                   \
                    186:       fprintf (FILE, "\tfmovem -%d(%%a6,%%a0.l),&0x%x\n",      \
                    187:               foffset + fsize, fmask);                         \
                    188:     else if (! frame_pointer_needed)                           \
                    189:       fprintf (FILE, "\tfmovem (%%sp)+,&0x%x\n", fmask);       \
                    190:     else                                                       \
                    191:       fprintf (FILE, "\tfmovem -%d(%%a6),&0x%x\n",             \
                    192:               foffset + fsize, fmask); }                       \
                    193:   if (frame_pointer_needed)                                    \
                    194:     fprintf (FILE, "\tunlk %%a6\n");                           \
                    195:   if (current_function_pops_args && current_function_args_size)        \
                    196:     fprintf (FILE, "\trtd &%d\n", current_function_args_size); \
                    197:   else fprintf (FILE, "\trts\n"); }
                    198: 
                    199: #define ASM_FILE_START ""
                    200: 
                    201: #define ASM_APP_ON ""
                    202: 
                    203: #define ASM_APP_OFF ""
                    204: 
                    205: #define TEXT_SECTION_ASM_OP "\ttext"
                    206: 
                    207: #define DATA_SECTION_ASM_OP "\tdata"
                    208: 
                    209: #define        ASCII_DATA_ASM_OP "\tbyte"
                    210: 
                    211: /* This says how to output an assembler line
                    212:    to define a global common symbol.  */
                    213: 
                    214: #define ASM_OUTPUT_COMMON(FILE, NAME, SIZE)  \
                    215: ( fputs ("\tcomm ", (FILE)),                   \
                    216:   assemble_name ((FILE), (NAME)),              \
                    217:   fprintf ((FILE), ",%d\n", (SIZE)))
                    218: 
                    219: /* This says how to output an assembler line
                    220:    to define a local common symbol.  */
                    221: 
                    222: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE)  \
                    223: ( fputs ("\tlcomm ", (FILE)),                  \
                    224:   assemble_name ((FILE), (NAME)),              \
                    225:   fprintf ((FILE), ",%d,2\n", (SIZE)))
                    226: 
                    227: /* Store in OUTPUT a string (made with alloca) containing
                    228:    an assembler-name for a local static variable named NAME.
                    229:    LABELNO is an integer which is different for each call.  */
                    230: 
                    231: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
                    232: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 12),   \
                    233:   sprintf ((OUTPUT), "%s___%d", (NAME), (LABELNO)))
                    234: 
                    235: /* This is how to output a command to make the user-level label named NAME
                    236:    defined for reference from other files.  */
                    237: 
                    238: #define ASM_GLOBALIZE_LABEL(FILE,NAME) \
                    239:   do { fputs ("\tglobal ", FILE); assemble_name (FILE, NAME); fputs ("\n", FILE);} while (0)
                    240: 
                    241: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM)     \
                    242: do{  if (PREFIX[0] == 'L' && PREFIX[1] == 'I')         \
                    243:     fprintf(FILE, "\tset %s%d,.+2\n", PREFIX, NUM);    \
                    244:   else                                                 \
                    245:     fprintf (FILE, "%s%d:\n", PREFIX, NUM);            \
                    246: } while(0)
                    247: 
                    248: #if 0
                    249: /* Are these definitions necessary? */
                    250: 
                    251: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)  \
                    252: do { union { double d; long l[2]; } tem;               \
                    253:      tem.d = (VALUE);                                  \
                    254:      fprintf(FILE, "\tlong 0x%x,0x%x\n", tem.l[0], tem.l[1]); \
                    255:    } while (0)
                    256: 
                    257: #define ASM_OUTPUT_FLOAT(FILE,VALUE)  \
                    258: do { union { float f; long l;} tem;                    \
                    259:      tem.f = (VALUE);                                  \
                    260:      fprintf (FILE, "\tlong 0x%x\n", tem.l);   \
                    261:    } while (0)
                    262: #endif
                    263: 
                    264: #define ASM_OUTPUT_DOUBLE(FILE, VALUE)                                 \
                    265:   fprintf (FILE, "\tdouble 0f%.20g\n", (VALUE))
                    266: 
                    267: #define ASM_OUTPUT_FLOAT(FILE, VALUE)                                  \
                    268:   fprintf (FILE, "\tfloat 0f%.9g\n", (VALUE))
                    269: 
                    270: /* This is how to output an assembler line defining an `int' constant.  */
                    271: 
                    272: #define ASM_OUTPUT_INT(FILE,VALUE)  \
                    273: ( fprintf (FILE, "\tlong "),                   \
                    274:   output_addr_const (FILE, (VALUE)),           \
                    275:   fprintf (FILE, "\n"))
                    276: 
                    277: /* Likewise for `char' and `short' constants.  */
                    278: 
                    279: #define ASM_OUTPUT_SHORT(FILE,VALUE)  \
                    280: ( fprintf (FILE, "\tshort "),                  \
                    281:   output_addr_const (FILE, (VALUE)),           \
                    282:   fprintf (FILE, "\n"))
                    283: 
                    284: #define ASM_OUTPUT_CHAR(FILE,VALUE)  \
                    285: ( fprintf (FILE, "\tbyte "),                   \
                    286:   output_addr_const (FILE, (VALUE)),           \
                    287:   fprintf (FILE, "\n"))
                    288: 
                    289: /* This is how to output an assembler line for a numeric constant byte.  */
                    290: 
                    291: #define ASM_OUTPUT_BYTE(FILE,VALUE)  \
                    292:   fprintf (FILE, "\tbyte 0x%x\n", (VALUE))
                    293: 
                    294: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE)  \
                    295:   fprintf (FILE, "\tlong L%d\n", VALUE)
                    296: 
                    297: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)  \
                    298:   fprintf (FILE, "\tshort L%d-L%d\n", VALUE, REL)
                    299: 
                    300: #define ASM_OUTPUT_ALIGN(FILE,LOG)     \
                    301:   if ((LOG) == 1)                      \
                    302:     fprintf (FILE, "\tlalign 2\n");    \
                    303:   else if ((LOG) != 0)                 \
                    304:     abort ();
                    305: 
                    306: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
                    307:   fprintf (FILE, "\tspace %d\n", (SIZE))
                    308: 
                    309: #define ASM_OUTPUT_SOURCE_FILENAME(FILE, FILENAME)
                    310: #define ASM_OUTPUT_SOURCE_LINE(FILE, LINENO)
                    311: 
                    312: #define PRINT_OPERAND(FILE, X, CODE)  \
                    313: { if (CODE == '.') fprintf (FILE, ".");                                        \
                    314:   else if (CODE == '#') fprintf (FILE, "&");                           \
                    315:   else if (CODE == '-') fprintf (FILE, "-(%%sp)");                     \
                    316:   else if (CODE == '+') fprintf (FILE, "(%%sp)+");                     \
                    317:   else if (CODE == 's') fprintf (FILE, "(%%sp)");                      \
                    318:   else if (CODE == '!') fprintf (FILE, "%%cc");                                \
                    319:   else if (GET_CODE (X) == REG)                                                \
                    320:     fprintf (FILE, "%s", reg_name [REGNO (X)]);                                \
                    321:   else if (GET_CODE (X) == MEM)                                                \
                    322:     output_address (XEXP (X, 0));                                      \
                    323:   else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == SFmode)     \
                    324:     { union { double d; int i[2]; } u;                                 \
                    325:       union { float f; int i; } u1;                                    \
                    326:       u.i[0] = XINT (X, 0); u.i[1] = XINT (X, 1);                      \
                    327:       u1.f = u.d;                                                      \
                    328:       if (CODE == 'f')                                                 \
                    329:         fprintf (FILE, "&0f%.9g", u1.f);                               \
                    330:       else                                                             \
                    331:         fprintf (FILE, "&0x%x", u1.i); }                               \
                    332:   else if (GET_CODE (X) == CONST_DOUBLE)                               \
                    333:     { union { double d; int i[2]; } u;                                 \
                    334:       u.i[0] = XINT (X, 0); u.i[1] = XINT (X, 1);                      \
                    335:       fprintf (FILE, "&0f%.20g", u.d); }                               \
                    336:   else { putc ('&', FILE); output_addr_const (FILE, X); }}
                    337: 
                    338: #define PRINT_OPERAND_ADDRESS(FILE, ADDR)  \
                    339: { register rtx reg1, reg2, breg, ireg;                                 \
                    340:   register rtx addr = ADDR;                                            \
                    341:   rtx offset;                                                          \
                    342:   switch (GET_CODE (addr))                                             \
                    343:     {                                                                  \
                    344:     case REG:                                                          \
                    345:       fprintf (FILE, "(%s)", reg_name [REGNO (addr)]);                 \
                    346:       break;                                                           \
                    347:     case PRE_DEC:                                                      \
                    348:       fprintf (FILE, "-(%s)", reg_name [REGNO (XEXP (addr, 0))]);      \
                    349:       break;                                                           \
                    350:     case POST_INC:                                                     \
                    351:       fprintf (FILE, "(%s)+", reg_name [REGNO (XEXP (addr, 0))]);      \
                    352:       break;                                                           \
                    353:     case PLUS:                                                         \
                    354:       reg1 = 0;        reg2 = 0;                                               \
                    355:       ireg = 0;        breg = 0;                                               \
                    356:       offset = 0;                                                      \
                    357:       if (CONSTANT_ADDRESS_P (XEXP (addr, 0)))                         \
                    358:        {                                                               \
                    359:          offset = XEXP (addr, 0);                                      \
                    360:          addr = XEXP (addr, 1);                                        \
                    361:        }                                                               \
                    362:       else if (CONSTANT_ADDRESS_P (XEXP (addr, 1)))                    \
                    363:        {                                                               \
                    364:          offset = XEXP (addr, 1);                                      \
                    365:          addr = XEXP (addr, 0);                                        \
                    366:        }                                                               \
                    367:       if (GET_CODE (addr) != PLUS) ;                                   \
                    368:       else if (GET_CODE (XEXP (addr, 0)) == SIGN_EXTEND)               \
                    369:        {                                                               \
                    370:          reg1 = XEXP (addr, 0);                                        \
                    371:          addr = XEXP (addr, 1);                                        \
                    372:        }                                                               \
                    373:       else if (GET_CODE (XEXP (addr, 1)) == SIGN_EXTEND)               \
                    374:        {                                                               \
                    375:          reg1 = XEXP (addr, 1);                                        \
                    376:          addr = XEXP (addr, 0);                                        \
                    377:        }                                                               \
                    378:       else if (GET_CODE (XEXP (addr, 0)) == MULT)                      \
                    379:        {                                                               \
                    380:          reg1 = XEXP (addr, 0);                                        \
                    381:          addr = XEXP (addr, 1);                                        \
                    382:        }                                                               \
                    383:       else if (GET_CODE (XEXP (addr, 1)) == MULT)                      \
                    384:        {                                                               \
                    385:          reg1 = XEXP (addr, 1);                                        \
                    386:          addr = XEXP (addr, 0);                                        \
                    387:        }                                                               \
                    388:       else if (GET_CODE (XEXP (addr, 0)) == REG)                       \
                    389:        {                                                               \
                    390:          reg1 = XEXP (addr, 0);                                        \
                    391:          addr = XEXP (addr, 1);                                        \
                    392:        }                                                               \
                    393:       else if (GET_CODE (XEXP (addr, 1)) == REG)                       \
                    394:        {                                                               \
                    395:          reg1 = XEXP (addr, 1);                                        \
                    396:          addr = XEXP (addr, 0);                                        \
                    397:        }                                                               \
                    398:       if (GET_CODE (addr) == REG || GET_CODE (addr) == MULT            \
                    399:          || GET_CODE (addr) == SIGN_EXTEND)                            \
                    400:        { if (reg1 == 0) reg1 = addr; else reg2 = addr; addr = 0; }     \
                    401: /*  for OLD_INDEXING                                                   \
                    402:       else if (GET_CODE (addr) == PLUS)                                        \
                    403:        {                                                               \
                    404:          if (GET_CODE (XEXP (addr, 0)) == REG)                         \
                    405:            {                                                           \
                    406:              reg2 = XEXP (addr, 0);                                    \
                    407:              addr = XEXP (addr, 1);                                    \
                    408:            }                                                           \
                    409:          else if (GET_CODE (XEXP (addr, 1)) == REG)                    \
                    410:            {                                                           \
                    411:              reg2 = XEXP (addr, 1);                                    \
                    412:              addr = XEXP (addr, 0);                                    \
                    413:            }                                                           \
                    414:        }                                                               \
                    415:   */                                                                   \
                    416:       if (offset != 0) { if (addr != 0) abort (); addr = offset; }     \
                    417:       if ((reg1 && (GET_CODE (reg1) == SIGN_EXTEND                     \
                    418:                    || GET_CODE (reg1) == MULT))                        \
                    419:          || (reg2 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg2))))         \
                    420:        { breg = reg2; ireg = reg1; }                                   \
                    421:       else if (reg1 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg1)))                \
                    422:        { breg = reg1; ireg = reg2; }                                   \
                    423:       if (ireg != 0 && breg == 0 && GET_CODE (addr) == LABEL_REF)      \
                    424:         { int scale = 1;                                               \
                    425:          if (GET_CODE (ireg) == MULT)                                  \
                    426:            { scale = INTVAL (XEXP (ireg, 1));                          \
                    427:              ireg = XEXP (ireg, 0); }                                  \
                    428:          if (GET_CODE (ireg) == SIGN_EXTEND)                           \
                    429:            fprintf (FILE, "L%d-LI%d(%%pc,%s.w",                        \
                    430:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
                    431:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
                    432:                     reg_name[REGNO (XEXP (ireg, 0))]);                 \
                    433:          else                                                          \
                    434:            fprintf (FILE, "L%d-LI%d(%%pc,%s.l",                        \
                    435:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
                    436:                     CODE_LABEL_NUMBER (XEXP (addr, 0)),                \
                    437:                     reg_name[REGNO (ireg)]);                           \
                    438:          if (scale != 1) fprintf (FILE, "*%d", scale);                 \
                    439:          putc (')', FILE);                                             \
                    440:          break; }                                                      \
                    441:       if (ireg != 0 || breg != 0)                                      \
                    442:        { int scale = 1;                                                \
                    443:          if (breg == 0)                                                \
                    444:            abort ();                                                   \
                    445:          if (addr != 0)                                                \
                    446:            output_addr_const (FILE, addr);                             \
                    447:          fprintf (FILE, "(%s", reg_name[REGNO (breg)]);                \
                    448:          if (ireg != 0)                                                \
                    449:            putc (',', FILE);                                           \
                    450:          if (ireg != 0 && GET_CODE (ireg) == MULT)                     \
                    451:            { scale = INTVAL (XEXP (ireg, 1));                          \
                    452:              ireg = XEXP (ireg, 0); }                                  \
                    453:          if (ireg != 0 && GET_CODE (ireg) == SIGN_EXTEND)              \
                    454:            fprintf (FILE, "%s.w", reg_name[REGNO (XEXP (ireg, 0))]);   \
                    455:          else if (ireg != 0)                                           \
                    456:            fprintf (FILE, "%s.l", reg_name[REGNO (ireg)]);             \
                    457:          if (scale != 1) fprintf (FILE, "*%d", scale);                 \
                    458:          putc (')', FILE);                                             \
                    459:          break;                                                        \
                    460:        }                                                               \
                    461:       else if (reg1 != 0 && GET_CODE (addr) == LABEL_REF)              \
                    462:        { fprintf (FILE, "L%d-LI%d(%%pc,%s.w)",                         \
                    463:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
                    464:                   CODE_LABEL_NUMBER (XEXP (addr, 0)),                  \
                    465:                   reg_name[REGNO (reg1)]);                             \
                    466:          break; }                                                      \
                    467:     default:                                                           \
                    468:       if (GET_CODE (addr) == CONST_INT                                 \
                    469:          && INTVAL (addr) < 0x8000                                     \
                    470:          && INTVAL (addr) >= -0x8000)                                  \
                    471:        fprintf (FILE, "%d.w", INTVAL (addr));                          \
                    472:       else                                                             \
                    473:         output_addr_const (FILE, addr);                                        \
                    474:     }}
                    475: 
                    476: #define        ASM_OUTPUT_ASCII(f, p, size)    \
                    477: { register int i;                      \
                    478:   int inside;                          \
                    479:   inside = FALSE;                      \
                    480:   for (i = 0; i < size; i++) {         \
                    481:     if (i % 8 == 0) {                  \
                    482:       if (i != 0) {                    \
                    483:        if (inside)                     \
                    484:          putc('"', f);                 \
                    485:        putc('\n', f);                  \
                    486:        inside = FALSE;                 \
                    487:       }                                        \
                    488:       fprintf(f, "%s ", ASCII_DATA_ASM_OP);    \
                    489:     }                                  \
                    490:     if (p[i] < 32 || p[i] == '\\' || p[i] == '"' || p[i] == 127) {     \
                    491:       if (inside) {                    \
                    492:        putc('"', f);                   \
                    493:        inside = FALSE;                 \
                    494:       }                                        \
                    495:       if (i % 8 != 0)                  \
                    496:        putc(',', f);                   \
                    497:       fprintf(f, "%d", p[i]);          \
                    498:     } else {                           \
                    499:       if (!inside) {                   \
                    500:        if (i % 8 != 0)                 \
                    501:          putc(',', f);                 \
                    502:        putc('"', f);                   \
                    503:        inside = TRUE;                  \
                    504:       }                                        \
                    505:       putc(p[i], f);                   \
                    506:     }                                  \
                    507:   }                                    \
                    508:   if (inside)                          \
                    509:     putc('"', f);                      \
                    510:   putc('\n', f);                       \
                    511: }
                    512: 
                    513: /* Translate Motorola opcodes such as `jbeq'
                    514:    into SGS opcodes such as `beq.w'.
                    515:    Delete the `e' in `move...' and `fmove'.
                    516:    Change `ftst' to `ftest'.  */
                    517: 
                    518: #define ASM_OUTPUT_OPCODE(FILE, PTR)                   \
                    519: { if ((PTR)[0] == 'j' && (PTR)[1] == 'b')              \
                    520:     { ++(PTR);                                         \
                    521:       while (*(PTR) != ' ')                            \
                    522:        { putc (*(PTR), (FILE)); ++(PTR); }             \
                    523:       fprintf ((FILE), ".w"); }                                \
                    524:   else if ((PTR)[0] == 'f')                            \
                    525:     {                                                  \
                    526:       if (!strncmp ((PTR), "fmove", 5))                        \
                    527:        { fprintf ((FILE), "fmov"); (PTR) += 5; }       \
                    528:       else if (!strncmp ((PTR), "ftst", 4))            \
                    529:        { fprintf ((FILE), "ftest"); (PTR) += 4; }      \
                    530:     }                                                  \
                    531:   else if ((PTR)[0] == 'm' && (PTR)[1] == 'o'          \
                    532:           && (PTR)[2] == 'v' && (PTR)[3] == 'e')       \
                    533:     { fprintf ((FILE), "mov"); (PTR) += 4; }           \
                    534: }
                    535: 
                    536: #else /* not HPUX_ASM */
                    537: 
                    538: #undef FUNCTION_PROFILER
                    539: #define FUNCTION_PROFILER(FILE, LABELNO)  \
                    540:    fprintf (FILE, "\tmovl #LP%d,d0\n\tjsr mcount\n", (LABELNO));
                    541: 
                    542: #endif /* not HPUX_ASM */

unix.superglobalmegacorp.com

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