Annotation of GNUtools/cc/config/m68k/sgs.h, revision 1.1.1.1

1.1       root        1: /* Definitions of target machine for GNU compiler for m68k targets using
                      2:    assemblers derived from AT&T "SGS" releases.
                      3: 
                      4:    Copyright (C) 1991, 1993 Free Software Foundation, Inc.
                      5: 
                      6:    Written by Fred Fish ([email protected])
                      7: 
                      8: This file is part of GNU CC.
                      9: 
                     10: GNU CC is free software; you can redistribute it and/or modify
                     11: it under the terms of the GNU General Public License as published by
                     12: the Free Software Foundation; either version 1, or (at your option)
                     13: any later version.
                     14: 
                     15: GNU CC is distributed in the hope that it will be useful,
                     16: but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: GNU General Public License for more details.
                     19: 
                     20: You should have received a copy of the GNU General Public License
                     21: along with GNU CC; see the file COPYING.  If not, write to
                     22: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
                     23: 
                     24: /* Control assembler-syntax conditionals in m68k.md and conditionals in
                     25:    m68k.h.  Note that some systems may also require SGS_SWAP_W and/or
                     26:    SGS_SWITCH_TABLES to be defined as well.  */
                     27: 
                     28: #define MOTOROLA               /* Use Motorola syntax rather than "MIT" */
                     29: #define SGS                    /* Uses SGS assembler */
                     30: #define SGS_CMP_ORDER          /* Takes cmp operands in reverse order */
                     31: 
                     32: #include "m68k/m68k.h"
                     33: 
                     34: /* SGS specific assembler pseudo ops. */
                     35: 
                     36: #define        BYTE_ASM_OP             ".byte"
                     37: #define WORD_ASM_OP            ".short"
                     38: #define LONG_ASM_OP            ".long"
                     39: #define SPACE_ASM_OP           ".space"
                     40: #define ALIGN_ASM_OP           ".align"
                     41: #undef GLOBAL_ASM_OP
                     42: #define GLOBAL_ASM_OP          ".global"
                     43: #define SWBEG_ASM_OP           ".swbeg"
                     44: #define SET_ASM_OP             ".set"
                     45: 
                     46: #define UNALIGNED_SHORT_ASM_OP ".short"        /* Used in dwarfout.c */
                     47: #define UNALIGNED_INT_ASM_OP   ".long"         /* Used in dwarfout.c */
                     48: 
                     49: #define ASM_PN_FORMAT          "%s_%d"         /* Format for private names */
                     50: 
                     51: /* Here are four prefixes that are used by asm_fprintf to
                     52:    facilitate customization for alternate assembler syntaxes.
                     53:    Machines with no likelihood of an alternate syntax need not
                     54:    define these and need not use asm_fprintf.  */
                     55: 
                     56: /* The prefix for register names.  Note that REGISTER_NAMES
                     57:    is supposed to include this prefix. Also note that this is NOT an
                     58:    fprintf format string, it is a literal string */
                     59: 
                     60: #undef REGISTER_PREFIX
                     61: #define REGISTER_PREFIX "%"
                     62: 
                     63: /* The prefix for local (compiler generated) labels.
                     64:    These labels will not appear in the symbol table. */
                     65: 
                     66: #undef LOCAL_LABEL_PREFIX
                     67: #define LOCAL_LABEL_PREFIX "."
                     68: 
                     69: /* The prefix to add to user-visible assembler symbols. */
                     70: 
                     71: #undef USER_LABEL_PREFIX
                     72: #define USER_LABEL_PREFIX ""
                     73: 
                     74: /* The prefix for immediate operands.  */
                     75: 
                     76: #undef IMMEDIATE_PREFIX
                     77: #define IMMEDIATE_PREFIX "&"
                     78: 
                     79: /* How to refer to registers in assembler output.
                     80:    This sequence is indexed by compiler's hard-register-number.
                     81:    Motorola format uses different register names than defined in m68k.h.
                     82:    We also take this chance to convert 'a6' to 'fp' */
                     83: 
                     84: #undef REGISTER_NAMES
                     85: 
                     86: #ifndef SUPPORT_SUN_FPA
                     87: 
                     88: #define REGISTER_NAMES \
                     89: {"%d0",   "%d1",   "%d2",   "%d3",   "%d4",   "%d5",   "%d6",   "%d7",      \
                     90:  "%a0",   "%a1",   "%a2",   "%a3",   "%a4",   "%a5",   "%fp",   "%sp",      \
                     91:  "%fp0",  "%fp1",  "%fp2",  "%fp3",  "%fp4",  "%fp5",  "%fp6",  "%fp7" }
                     92: 
                     93: #else /* SUPPORTED_SUN_FPA */
                     94: 
                     95: #define REGISTER_NAMES \
                     96: {"%d0",   "%d1",   "%d2",   "%d3",   "%d4",   "%d5",   "%d6",   "%d7",      \
                     97:  "%a0",   "%a1",   "%a2",   "%a3",   "%a4",   "%a5",   "%fp",   "%sp",      \
                     98:  "%fp0",  "%fp1",  "%fp2",  "%fp3",  "%fp4",  "%fp5",  "%fp6",  "%fp7",             \
                     99:  "%fpa0", "%fpa1", "%fpa2", "%fpa3", "%fpa4", "%fpa5", "%fpa6","%fpa7",             \
                    100:  "%fpa8", "%fpa9", "%fpa10","%fpa11","%fpa12","%fpa13","%fpa14","%fpa15",    \
                    101:  "%fpa16","%fpa17","%fpa18","%fpa19","%fpa20","%fpa21","%fpa22","%fpa23",    \
                    102:  "%fpa24","%fpa25","%fpa26","%fpa27","%fpa28","%fpa29","%fpa30","%fpa31" }
                    103: 
                    104: #endif /* defined SUPPORT_SUN_FPA */
                    105: 
                    106: /* When using an SGS assembler, modify the name of the artificial label which
                    107:    identifies this file as having been compiled with gcc, and the macro that
                    108:    emits such a label in the assembly output, to use '%' rather than '.' */
                    109: 
                    110: #define ASM_IDENTIFY_GCC(FILE)                         \
                    111:  { fprintf ((FILE), "%s:\n", "gcc2_compiled%"); }
                    112: 
                    113: /* This is how to output an assembler line defining an `int' constant.  */
                    114: /* The SGS assembler doesn't understand ".word". */
                    115: 
                    116: #undef ASM_OUTPUT_SHORT
                    117: #define ASM_OUTPUT_SHORT(FILE,VALUE)                   \
                    118: ( fprintf ((FILE), "\t%s ", WORD_ASM_OP),              \
                    119:   output_addr_const ((FILE), (VALUE)),                 \
                    120:   fprintf ((FILE), "\n"))
                    121: 
                    122: #undef ASM_OUTPUT_LONG_DOUBLE
                    123: #define ASM_OUTPUT_LONG_DOUBLE(FILE,VALUE)                     \
                    124: do { long l[3];                                                        \
                    125:      REAL_VALUE_TO_TARGET_LONG_DOUBLE (VALUE, l);              \
                    126:      fprintf ((FILE), "\t%s 0x%x,0x%x,0x%x\n", LONG_ASM_OP,    \
                    127:             l[0], l[1], l[2]);                                 \
                    128:    } while (0)
                    129: 
                    130: /* This is how to output an assembler line defining a `double' constant.  */
                    131: 
                    132: #undef ASM_OUTPUT_DOUBLE
                    133: #define ASM_OUTPUT_DOUBLE(FILE,VALUE)                  \
                    134: do { long l[2];                                                \
                    135:      REAL_VALUE_TO_TARGET_DOUBLE (VALUE, l);           \
                    136:      fprintf ((FILE), "\t%s 0x%x,0x%x\n", LONG_ASM_OP, \
                    137:              l[0], l[1]);                              \
                    138:    } while (0)
                    139: 
                    140: /* This is how to output an assembler line defining a `float' constant.  */
                    141: 
                    142: #undef ASM_OUTPUT_FLOAT
                    143: #define ASM_OUTPUT_FLOAT(FILE,VALUE)                   \
                    144: do { long l;                                           \
                    145:      REAL_VALUE_TO_TARGET_SINGLE (VALUE, l);           \
                    146:      fprintf ((FILE), "\t%s 0x%x\n", LONG_ASM_OP, l);  \
                    147:    } while (0)
                    148: 
                    149: /* This is how to output an assembler line that says to advance the
                    150:    location counter to a multiple of 2**LOG bytes.  */
                    151: 
                    152: #undef ASM_OUTPUT_ALIGN
                    153: #define ASM_OUTPUT_ALIGN(FILE,LOG)                             \
                    154:   if ((LOG) > 0)                                               \
                    155:     fprintf ((FILE), "\t%s \t%u\n", ALIGN_ASM_OP, 1 << (LOG)); \
                    156:   else if ((LOG) > 31)                                         \
                    157:     abort ();
                    158: 
                    159: /* The routine used to output null terminated string literals.  We cannot
                    160:    use the ".string" pseudo op, because it silently truncates strings to
                    161:    1023 bytes.  There is no "partial string op" which works like ".string"
                    162:    but doesn't append a null byte, so we can't chop the input string up
                    163:    into small pieces and use that.  Our only remaining alternative is to
                    164:    output the string one byte at a time. */
                    165: 
                    166: #define ASM_OUTPUT_ASCII(FILE,PTR,LEN)                         \
                    167: {                                                              \
                    168:   register int sp = 0, lp = 0, ch;                             \
                    169:   fprintf ((FILE), "\t%s ", BYTE_ASM_OP);                      \
                    170:   do {                                                         \
                    171:     ch = (PTR)[sp];                                            \
                    172:     if (ch > ' ' && ! (ch & 0x80) && ch != '\\')               \
                    173:       {                                                                \
                    174:        fprintf ((FILE), "'%c", ch);                            \
                    175:       }                                                                \
                    176:     else                                                       \
                    177:       {                                                                \
                    178:        fprintf ((FILE), "0x%x", ch);                           \
                    179:       }                                                                \
                    180:     if (++sp < (LEN))                                          \
                    181:       {                                                                \
                    182:        if ((sp % 10) == 0)                                     \
                    183:          {                                                     \
                    184:            fprintf ((FILE), "\n\t%s ", BYTE_ASM_OP);           \
                    185:          }                                                     \
                    186:        else                                                    \
                    187:          {                                                     \
                    188:            putc (',', (FILE));                                 \
                    189:          }                                                     \
                    190:       }                                                                \
                    191:   } while (sp < (LEN));                                                \
                    192:   putc ('\n', (FILE));                                         \
                    193: }
                    194: 
                    195: 
                    196: /* SGS based assemblers don't understand #NO_APP and #APP, so just don't
                    197:    bother emitting them. */
                    198: 
                    199: #undef ASM_APP_ON
                    200: #define ASM_APP_ON ""
                    201: 
                    202: #undef ASM_APP_OFF
                    203: #define ASM_APP_OFF ""
                    204: 
                    205: /* When using SGS derived assemblers, change the "MIT" or "MOTOROLA"
                    206:    to "SGS/AT&T"  */
                    207: 
                    208: #undef TARGET_VERSION
                    209: #define TARGET_VERSION fprintf (stderr, " (68k, SGS/AT&T syntax)");
                    210: 
                    211: /* Use proper assembler syntax for these macros.  */
                    212: #undef ASM_OUTPUT_REG_PUSH
                    213: #define ASM_OUTPUT_REG_PUSH(FILE,REGNO)  \
                    214:   asm_fprintf (FILE, "\t%Omove.l %s,-(%Rsp)\n", reg_names[REGNO])
                    215: 
                    216: #undef ASM_OUTPUT_REG_POP
                    217: #define ASM_OUTPUT_REG_POP(FILE,REGNO)  \
                    218:   asm_fprintf (FILE, "\t%Omove.l (%Rsp)+,%s\n", reg_names[REGNO])
                    219: 
                    220: #undef ASM_OUTPUT_FLOAT_OPERAND
                    221: #define ASM_OUTPUT_FLOAT_OPERAND(CODE,FILE,VALUE)      \
                    222:   do { long l;                                         \
                    223:        REAL_VALUE_TO_TARGET_SINGLE (VALUE, l);         \
                    224:        asm_fprintf ((FILE), "%I0x%x", l);              \
                    225:      } while (0)
                    226:   
                    227: #undef ASM_OUTPUT_DOUBLE_OPERAND
                    228: #define ASM_OUTPUT_DOUBLE_OPERAND(FILE,VALUE)          \
                    229:   do { long l[2];                                      \
                    230:        REAL_VALUE_TO_TARGET_DOUBLE (VALUE, l);         \
                    231:        asm_fprintf ((FILE), "%I0x%x%08x", l[0], l[1]); \
                    232:      } while (0)
                    233: 
                    234: /* How to output a block of SIZE zero bytes.  Note that the `space' pseudo,
                    235:    when used in the text segment, causes SGS assemblers to output nop insns
                    236:    rather than 0s, so we set ASM_NO_SKIP_IN_TEXT to prevent this. */
                    237: 
                    238: #define ASM_NO_SKIP_IN_TEXT 1
                    239: 
                    240: #undef ASM_OUTPUT_SKIP
                    241: #define ASM_OUTPUT_SKIP(FILE,SIZE)  \
                    242:   fprintf (FILE, "\t%s %u\n", SPACE_ASM_OP, (SIZE))
                    243: 
                    244: /* Translate Motorola opcodes such as `jbeq' into SGS opcodes such
                    245:    as `beq.w'.
                    246:    Delete the `e' in `move...' and `fmove'.
                    247:    Change `ftst' to `ftest'.
                    248:    Change `fbne' to `fbneq'
                    249:    Change `fsne' to `fsneq'
                    250:    Change `divsl' to `tdivs' (32/32 -> 32r:32q)
                    251:    Change `divul' to `tdivu' (32/32 -> 32r:32q)
                    252:    Optionally change swap to swap.w.
                    253:    */
                    254: 
                    255: #ifdef SGS_SWAP_W
                    256: #define ASM_OUTPUT_OPCODE(FILE, PTR)                   \
                    257: {                                                      \
                    258:   extern int flag_pic;                                 \
                    259:   if (!strncmp ((PTR), "jbsr", 4))                     \
                    260:     { if (flag_pic)                                    \
                    261:         fprintf ((FILE), "bsr");                       \
                    262:       else                                             \
                    263:         fprintf ((FILE), "jsr");                       \
                    264:     (PTR) += 4; }                                      \
                    265:   else if ((PTR)[0] == 'j' && (PTR)[1] == 'b')         \
                    266:     { ++(PTR);                                         \
                    267:       while (*(PTR) != ' ')                            \
                    268:        { putc (*(PTR), (FILE)); ++(PTR); }             \
                    269:       fprintf ((FILE), ".w"); }                                \
                    270:   else if ((PTR)[0] == 's')                            \
                    271:     {                                                  \
                    272:       if (!strncmp ((PTR), "swap", 4))                 \
                    273:        { fprintf ((FILE), "swap.w"); (PTR) += 4; }     \
                    274:     }                                                  \
                    275: /* FMOVE ==> FMOV, (and F%& F%$ translations) */       \
                    276:   else if ((PTR)[0] == 'f')                            \
                    277:     {                                                  \
                    278:       if (!strncmp ((PTR), "fmove", 5))                        \
                    279:        { fprintf ((FILE), "fmov"); (PTR) += 5; }       \
                    280:       else if (!strncmp ((PTR), "ftst", 4))            \
                    281:        { fprintf ((FILE), "ftest"); (PTR) += 4; }      \
                    282:       else if (!strncmp ((PTR), "fbne", 4))            \
                    283:        { fprintf ((FILE), "fbneq"); (PTR) += 4; }      \
                    284:       else if (!strncmp ((PTR), "fsne", 4))            \
                    285:        { fprintf ((FILE), "fsneq"); (PTR) += 4; }      \
                    286:       else if (!strncmp ((PTR), "f%$move", 7))         \
                    287:        { (PTR) += 7;                                   \
                    288:          if (TARGET_68040_ONLY)                        \
                    289:            fprintf ((FILE), "fsmov");                  \
                    290:          else fprintf ((FILE), "fmov"); }              \
                    291:       else if (!strncmp ((PTR), "f%&move", 7))         \
                    292:        { (PTR) += 7;                                   \
                    293:          if (TARGET_68040_ONLY)                        \
                    294:            fprintf ((FILE), "fdmov");                  \
                    295:          else fprintf ((FILE), "fmov"); }              \
                    296:     }                                                  \
                    297: /* MOVE, MOVEA, MOVEQ, MOVEC ==> MOV   */              \
                    298:   else if ((PTR)[0] == 'm' && (PTR)[1] == 'o'          \
                    299:           && (PTR)[2] == 'v' && (PTR)[3] == 'e')       \
                    300:     { fprintf ((FILE), "mov"); (PTR) += 4;             \
                    301:        if ((PTR)[0] == 'q' || (PTR)[0] == 'a'          \
                    302:           || (PTR)[0] == 'c') (PTR)++; }               \
                    303: /* SUB, SUBQ, SUBA, SUBI ==> SUB */                    \
                    304:   else if ((PTR)[0] == 's' && (PTR)[1] == 'u'          \
                    305:           && (PTR)[2] == 'b')                          \
                    306:     { fprintf ((FILE), "sub"); (PTR) += 3;             \
                    307:        if ((PTR)[0] == 'q' || (PTR)[0] == 'i'          \
                    308:           || (PTR)[0] == 'a') (PTR)++; }               \
                    309: /* CMP, CMPA, CMPI, CMPM ==> CMP       */              \
                    310:   else if ((PTR)[0] == 'c' && (PTR)[1] == 'm'          \
                    311:           && (PTR)[2] == 'p')                          \
                    312:     { fprintf ((FILE), "cmp"); (PTR) += 3;             \
                    313:        if ((PTR)[0] == 'a' || (PTR)[0] == 'i'          \
                    314:           || (PTR)[0] == 'm') (PTR)++; }               \
                    315: /* DIVSL ==> TDIVS */                                  \
                    316:   else if ((PTR)[0] == 'd' && (PTR)[1] == 'i'          \
                    317:           && (PTR)[2] == 'v' && (PTR)[3] == 's'        \
                    318:           && (PTR)[4] == 'l')                          \
                    319:     { fprintf ((FILE), "tdivs"); (PTR) += 5; }         \
                    320: /* DIVUL ==> TDIVU */                                  \
                    321:   else if ((PTR)[0] == 'd' && (PTR)[1] == 'i'          \
                    322:           && (PTR)[2] == 'v' && (PTR)[3] == 'u'        \
                    323:           && (PTR)[4] == 'l')                          \
                    324:     { fprintf ((FILE), "tdivu"); (PTR) += 5; }         \
                    325: }
                    326: 
                    327: #else /* not SGS_SWAP_W */
                    328: 
                    329: #define ASM_OUTPUT_OPCODE(FILE, PTR)                   \
                    330: {                                                      \
                    331:   extern int flag_pic;                                 \
                    332:   if (!strncmp ((PTR), "jbsr", 4))                     \
                    333:     { if (flag_pic)                                    \
                    334:         fprintf ((FILE), "bsr");                       \
                    335:       else                                             \
                    336:         fprintf ((FILE), "jsr");                       \
                    337:     (PTR) += 4; }                                      \
                    338:   else if ((PTR)[0] == 'j' && (PTR)[1] == 'b')         \
                    339:     { ++(PTR);                                         \
                    340:       while (*(PTR) != ' ')                            \
                    341:        { putc (*(PTR), (FILE)); ++(PTR); }             \
                    342:       fprintf ((FILE), ".w"); }                                \
                    343: /* FMOVE ==> FMOV, (and F%& F%$ translations) */       \
                    344:   else if ((PTR)[0] == 'f')                            \
                    345:     {                                                  \
                    346:       if (!strncmp ((PTR), "fmove", 5))                        \
                    347:        { fprintf ((FILE), "fmov"); (PTR) += 5; }       \
                    348:       else if (!strncmp ((PTR), "ftst", 4))            \
                    349:        { fprintf ((FILE), "ftest"); (PTR) += 4; }      \
                    350:       else if (!strncmp ((PTR), "fbne", 4))            \
                    351:        { fprintf ((FILE), "fbneq"); (PTR) += 4; }      \
                    352:       else if (!strncmp ((PTR), "fsne", 4))            \
                    353:        { fprintf ((FILE), "fsneq"); (PTR) += 4; }      \
                    354:       else if (!strncmp ((PTR), "f%$move", 7))         \
                    355:        { (PTR) += 7;                                   \
                    356:          if (TARGET_68040_ONLY)                        \
                    357:            fprintf ((FILE), "fsmov");                  \
                    358:          else fprintf ((FILE), "fmov"); }              \
                    359:       else if (!strncmp ((PTR), "f%&move", 7))         \
                    360:        { (PTR) += 7;                                   \
                    361:          if (TARGET_68040_ONLY)                        \
                    362:            fprintf ((FILE), "fdmov");                  \
                    363:          else fprintf ((FILE), "fmov"); }              \
                    364:     }                                                  \
                    365: /* MOVE, MOVEA, MOVEQ, MOVEC ==> MOV   */              \
                    366:   else if ((PTR)[0] == 'm' && (PTR)[1] == 'o'          \
                    367:           && (PTR)[2] == 'v' && (PTR)[3] == 'e')       \
                    368:     { fprintf ((FILE), "mov"); (PTR) += 4;             \
                    369:        if ((PTR)[0] == 'q' || (PTR)[0] == 'a'          \
                    370:           || (PTR)[0] == 'c') (PTR)++; }               \
                    371: /* SUB, SUBQ, SUBA, SUBI ==> SUB */                    \
                    372:   else if ((PTR)[0] == 's' && (PTR)[1] == 'u'          \
                    373:           && (PTR)[2] == 'b')                          \
                    374:     { fprintf ((FILE), "sub"); (PTR) += 3;             \
                    375:        if ((PTR)[0] == 'q' || (PTR)[0] == 'i'          \
                    376:           || (PTR)[0] == 'a') (PTR)++; }               \
                    377: /* CMP, CMPA, CMPI, CMPM ==> CMP       */              \
                    378:   else if ((PTR)[0] == 'c' && (PTR)[1] == 'm'          \
                    379:           && (PTR)[2] == 'p')                          \
                    380:     { fprintf ((FILE), "cmp"); (PTR) += 3;             \
                    381:        if ((PTR)[0] == 'a' || (PTR)[0] == 'i'          \
                    382:           || (PTR)[0] == 'm') (PTR)++; }               \
                    383: /* DIVSL ==> TDIVS */                                  \
                    384:   else if ((PTR)[0] == 'd' && (PTR)[1] == 'i'          \
                    385:           && (PTR)[2] == 'v' && (PTR)[3] == 's'        \
                    386:           && (PTR)[4] == 'l')                          \
                    387:     { fprintf ((FILE), "tdivs"); (PTR) += 5; }         \
                    388: /* DIVUL ==> TDIVU */                                  \
                    389:   else if ((PTR)[0] == 'd' && (PTR)[1] == 'i'          \
                    390:           && (PTR)[2] == 'v' && (PTR)[3] == 'u'        \
                    391:           && (PTR)[4] == 'l')                          \
                    392:     { fprintf ((FILE), "tdivu"); (PTR) += 5; }         \
                    393: }
                    394: 
                    395: #endif /* not SGS_SWAP_W */
                    396: 
                    397: /* This macro outputs the label at the start of a switch table.  The
                    398:    ".swbeg <N>" is an assembler directive that causes the switch table
                    399:    size to be inserted into the object code so that disassemblers, for
                    400:    example, can identify that it is the start of a switch table. */
                    401: 
                    402: #define ASM_OUTPUT_BEFORE_CASE_LABEL(FILE,PREFIX,NUM,TABLE)            \
                    403:   fprintf ((FILE), "\t%s &%d\n", SWBEG_ASM_OP, XVECLEN (PATTERN (TABLE), 1));
                    404: 
                    405: #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,TABLE)                   \
                    406:   do {                                                                 \
                    407:     ASM_OUTPUT_BEFORE_CASE_LABEL((FILE),(PREFIX),(NUM),(TABLE));       \
                    408:     ASM_OUTPUT_INTERNAL_LABEL((FILE),(PREFIX),(NUM));                  \
                    409:   } while (0)
                    410: 
                    411: /* At end of a switch table, define LDnnn iff the symbol LInnn was defined.
                    412:    Some SGS assemblers have a bug such that "Lnnn-LInnn-2.b(pc,d0.l*2)"
                    413:    fails to assemble.  Luckily "LDnnn(pc,d0.l*2)" produces the results
                    414:    we want.  This difference can be accommodated by making the assembler
                    415:    define such "LDnnn" to be either "Lnnn-LInnn-2.b", "Lnnn", or any other
                    416:    string, as necessary.  This is accomplished via the ASM_OUTPUT_CASE_END
                    417:    macro. */
                    418: 
                    419: #undef ASM_OUTPUT_CASE_END
                    420: #define ASM_OUTPUT_CASE_END(FILE,NUM,TABLE)            \
                    421: { if (switch_table_difference_label_flag)              \
                    422:     asm_fprintf (FILE, "\t%s %LLD%d,%LL%d-%LLI%d-2.b\n",\
                    423:                 SET_ASM_OP, (NUM), (NUM), (NUM))       \
                    424:   switch_table_difference_label_flag = 0; }
                    425: 
                    426: int switch_table_difference_label_flag;
                    427: 
                    428: /* This is how to output an element of a case-vector that is relative.  */
                    429: 
                    430: #undef ASM_OUTPUT_ADDR_DIFF_ELT
                    431: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL)     \
                    432:   asm_fprintf (FILE, "\t%s %LL%d-%LL%d\n", WORD_ASM_OP, VALUE, REL)
                    433: 
                    434: /* Currently, JUMP_TABLES_IN_TEXT_SECTION must be defined in order to
                    435:    keep switch tables in the text section. */
                    436:    
                    437: #define JUMP_TABLES_IN_TEXT_SECTION 1
                    438: 
                    439: /* Store in OUTPUT a string (made with alloca) containing
                    440:    an assembler-name for a local static variable named NAME.
                    441:    LABELNO is an integer which is different for each call.  */
                    442: 
                    443: #undef ASM_FORMAT_PRIVATE_NAME
                    444: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
                    445: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 10),   \
                    446:   sprintf ((OUTPUT), ASM_PN_FORMAT, (NAME), (LABELNO)))
                    447: 

unix.superglobalmegacorp.com

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