|
|
1.1 root 1: /* Definitions of target machine for GNU compiler.
2: AT&T UNIX PC version (pc7300, 3b1)
3:
4: Written by Alex Crain
5: bug reports to [email protected]
6:
7: Copyright (C) 1987 Free Software Foundation, Inc.
8:
9: This file is part of GNU CC.
10:
11: GNU CC is free software; you can redistribute it and/or modify
12: it under the terms of the GNU General Public License as published by
13: the Free Software Foundation; either version 2, or (at your option)
14: any later version.
15:
16: GNU CC is distributed in the hope that it will be useful,
17: but WITHOUT ANY WARRANTY; without even the implied warranty of
18: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19: GNU General Public License for more details.
20:
21: You should have received a copy of the GNU General Public License
22: along with GNU CC; see the file COPYING. If not, write to
23: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
24:
25: #define SGS_SWITCH_TABLES /* Different switch table handling */
26:
27: #include "m68k/hp320.h"
28:
29: /* See m68k.h. 0 means 680[01]0 with no 68881. */
30:
31: #undef TARGET_DEFAULT
32: #define TARGET_DEFAULT 0
33:
34: /* Don't try using XFmode. */
35: #undef LONG_DOUBLE_TYPE_SIZE
36: #define LONG_DOUBLE_TYPE_SIZE 64
37:
38: /* -m68020 requires special flags to the assembler. */
39:
40: #undef ASM_SPEC
41: #define ASM_SPEC "%{m68020:-68020}%{!m68020:-68010} %{m68881:-68881}"
42:
43: /* we use /lib/libp/lib* when profiling */
44:
45: #undef LIB_SPEC
46: #define LIB_SPEC "%{!shlib:%{p:-L/lib/libp} %{pg:-L/lib/libp} -lc}"
47:
48: /* shared libraries need to use crt0s.o */
49:
50: #undef STARTFILE_SPEC
51: #define STARTFILE_SPEC \
52: "%{!shlib:%{pg:mcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}}\
53: %{shlib:crt0s.o%s shlib.ifile%s} "
54:
55: /* cpp has to support a #sccs directive for the /usr/include files */
56:
57: #define SCCS_DIRECTIVE
58:
59: /* Make output for SDB. */
60:
61: #define SDB_DEBUGGING_INFO
62:
63: /* The .file command should always begin the output. */
64:
65: #undef ASM_FILE_START
66: #define ASM_FILE_START(FILE) \
67: output_file_directive ((FILE), main_input_filename)
68:
69: /* Don't try to define `gcc_compiled.' since the assembler might not
70: accept symbols with periods and GDB doesn't run on this machine anyway. */
71: #define ASM_IDENTIFY_GCC(FILE)
72:
73: /* Define __HAVE_68881__ in preprocessor if -m68881 is specified.
74: This will control the use of inline 68881 insns in certain macros. */
75:
76: #undef CPP_SPEC
77: #define CPP_SPEC "%{m68881:-D__HAVE_68881__}"
78:
79: /* Names to predefine in the preprocessor for this target machine. */
80: /* [email protected] says mc68000 and m68k should not be here. */
81:
82: #undef CPP_PREDEFINES
83: #define CPP_PREDEFINES "-Dmc68k -Dunix -Dunixpc -D__motorola__ -Asystem(unix) -Asystem(svr3) -Acpu(m68k) -Amachine(m68k)"
84:
85: #undef REGISTER_NAMES
86: #define REGISTER_NAMES \
87: {"%d0", "%d1", "%d2", "%d3", "%d4", "%d5", "%d6", "%d7", \
88: "%a0", "%a1", "%a2", "%a3", "%a4", "%a5", "%fp", "%sp", \
89: "%f0", "%f1", "%f2", "%f3", "%f4", "%f5", "%f6", "%f7"}
90:
91: /* Specify how to pad function arguments.
92: Value should be `upward', `downward' or `none'.
93: Same as the default, except no padding for large or variable-size args. */
94:
95: #define FUNCTION_ARG_PADDING(MODE, TYPE) \
96: (((MODE) == BLKmode \
97: ? ((TYPE) && TREE_CODE (TYPE_SIZE (TYPE)) == INTEGER_CST \
98: && int_size_in_bytes (TYPE) < PARM_BOUNDARY / BITS_PER_UNIT) \
99: : GET_MODE_BITSIZE (MODE) < PARM_BOUNDARY) \
100: ? downward : none)
101:
102: /* Override part of the obstack macros. */
103:
104: #define __PTR_TO_INT(P) ((int)(P))
105: #define __INT_TO_PTR(P) ((char *)(P))
106:
107: /* The 3b1 does not have `atexit'. */
108:
109: #undef HAVE_ATEXIT
110:
111: /* Override parts of m68k.h to fit the SGS-3b1 assembler. */
112:
113: #undef TARGET_VERSION
114: #undef ASM_FORMAT_PRIVATE_NAME
115: #undef ASM_OUTPUT_DOUBLE
116: #undef ASM_OUTPUT_FLOAT
117: #undef ASM_OUTPUT_ALIGN
118: #undef ASM_OUTPUT_SOURCE_FILENAME
119: #undef ASM_OUTPUT_SOURCE_LINE
120: #undef PRINT_OPERAND_ADDRESS
121: #undef ASM_GENERATE_INTERNAL_LABEL
122: #undef FUNCTION_PROFILER
123: #undef ASM_OUTPUT_ADDR_VEC_ELT
124: #undef ASM_OUTPUT_ADDR_DIFF_ELT
125: #undef ASM_OUTPUT_INTERNAL_LABEL
126: #undef ASM_OUTPUT_OPCODE
127: #undef ASM_OUTPUT_LOCAL
128: #undef ASM_OUTPUT_LABELREF
129: #undef ASM_OUTPUT_ASCII
130:
131: #define TARGET_VERSION fprintf (stderr, " (68k, SGS/AT&T unixpc syntax)");
132:
133: /* Store in OUTPUT a string (made with alloca) containing
134: an assembler-name for a local static variable named NAME.
135: LABELNO is an integer which is different for each call. */
136:
137: #define ASM_FORMAT_PRIVATE_NAME(OUTPUT, NAME, LABELNO) \
138: ( (OUTPUT) = (char *) alloca (strlen ((NAME)) + 12), \
139: sprintf ((OUTPUT), "%s_%%%d", (NAME), (LABELNO)))
140:
141: /* The unixpc doesn't know about double's and float's */
142:
143: #define ASM_OUTPUT_DOUBLE(FILE,VALUE) \
144: do { long l[2]; \
145: REAL_VALUE_TO_TARGET_DOUBLE (VALUE, l); \
146: fprintf (FILE, "\tlong 0x%x,0x%x\n", l[0], l[1]); \
147: } while (0)
148:
149: #undef ASM_OUTPUT_LONG_DOUBLE
150: #define ASM_OUTPUT_LONG_DOUBLE(FILE,VALUE) \
151: do { long l[3]; \
152: REAL_VALUE_TO_TARGET_LONG_DOUBLE (VALUE, l); \
153: fprintf (FILE, "\tlong 0x%x,0x%x,0x%x\n", l[0], l[1], l[2]); \
154: } while (0)
155:
156: /* This is how to output an assembler line defining a `float' constant. */
157:
158: #define ASM_OUTPUT_FLOAT(FILE,VALUE) \
159: do { long l; \
160: REAL_VALUE_TO_TARGET_SINGLE (VALUE, l); \
161: fprintf ((FILE), "\tlong 0x%x\n", l); \
162: } while (0)
163:
164: #define ASM_OUTPUT_ALIGN(FILE,LOG) \
165: if ((LOG) == 1) \
166: fprintf (FILE, "\teven\n"); \
167: else if ((LOG) != 0) \
168: abort ();
169:
170: /* This is how to output an assembler line
171: that says to advance the location counter by SIZE bytes. */
172:
173: #undef ASM_OUTPUT_SKIP
174: #define ASM_OUTPUT_SKIP(FILE,SIZE) \
175: fprintf (FILE, "\tspace %d\n", (SIZE))
176:
177: /* Can't use ASM_OUTPUT_SKIP in text section; it doesn't leave 0s. */
178:
179: #define ASM_NO_SKIP_IN_TEXT 1
180:
181: /* The beginnings of sdb support... */
182:
183: #define ASM_OUTPUT_SOURCE_FILENAME(FILE, FILENAME) \
184: do { fprintf (FILE, "\tfile\t"); \
185: output_quoted_string (FILE, FILENAME); \
186: fprintf (FILE, "\n"); \
187: } while (0)
188:
189: #define ASM_OUTPUT_SOURCE_LINE(FILE, LINENO) \
190: fprintf (FILE, "\tln\t%d\n", \
191: (sdb_begin_function_line \
192: ? last_linenum - sdb_begin_function_line : 1))
193:
194: /* Yet another null terminated string format. */
195:
196: #define ASM_OUTPUT_ASCII(FILE,PTR,LEN) \
197: { register int sp = 0, lp = 0; \
198: fprintf ((FILE), "\tbyte\t"); \
199: loop: \
200: if ((PTR)[sp] > ' ' && ! ((PTR)[sp] & 0x80) && (PTR)[sp] != '\\') \
201: { lp += 3; \
202: fprintf ((FILE), "'%c", (PTR)[sp]); } \
203: else \
204: { lp += 5; \
205: fprintf ((FILE), "0x%x", (PTR)[sp]); } \
206: if (++sp < (LEN)) \
207: { if (lp > 60) \
208: { lp = 0; \
209: fprintf ((FILE), "\n\t%s ", ASCII_DATA_ASM_OP); } \
210: else \
211: putc (',', (FILE)); \
212: goto loop; } \
213: putc ('\n', (FILE)); }
214:
215: /* Note that in the case of the movhi which fetches an element of
216: an ADDR_DIFF_VEC the offset output is too large by 2.
217: This is because the 3b1 assembler refuses to subtract 2.
218: ASM_OUTPUT_CASE_LABEL, below, compensates for this. */
219:
220: #define PRINT_OPERAND_ADDRESS(FILE, ADDR) \
221: { register rtx reg1, reg2, breg, ireg; \
222: register rtx addr = ADDR; \
223: rtx offset; \
224: switch (GET_CODE (addr)) \
225: { \
226: case REG: \
227: fprintf (FILE, "(%s)", reg_names[REGNO (addr)]); \
228: break; \
229: case PRE_DEC: \
230: fprintf (FILE, "-(%s)", reg_names[REGNO (XEXP (addr, 0))]); \
231: break; \
232: case POST_INC: \
233: fprintf (FILE, "(%s)+", reg_names[REGNO (XEXP (addr, 0))]); \
234: break; \
235: case PLUS: \
236: reg1 = 0; reg2 = 0; \
237: ireg = 0; breg = 0; \
238: offset = 0; \
239: if (CONSTANT_ADDRESS_P (XEXP (addr, 0))) \
240: { \
241: offset = XEXP (addr, 0); \
242: addr = XEXP (addr, 1); \
243: } \
244: else if (CONSTANT_ADDRESS_P (XEXP (addr, 1))) \
245: { \
246: offset = XEXP (addr, 1); \
247: addr = XEXP (addr, 0); \
248: } \
249: if (GET_CODE (addr) != PLUS) ; \
250: else if (GET_CODE (XEXP (addr, 0)) == SIGN_EXTEND) \
251: { \
252: reg1 = XEXP (addr, 0); \
253: addr = XEXP (addr, 1); \
254: } \
255: else if (GET_CODE (XEXP (addr, 1)) == SIGN_EXTEND) \
256: { \
257: reg1 = XEXP (addr, 1); \
258: addr = XEXP (addr, 0); \
259: } \
260: else if (GET_CODE (XEXP (addr, 0)) == MULT) \
261: { \
262: reg1 = XEXP (addr, 0); \
263: addr = XEXP (addr, 1); \
264: } \
265: else if (GET_CODE (XEXP (addr, 1)) == MULT) \
266: { \
267: reg1 = XEXP (addr, 1); \
268: addr = XEXP (addr, 0); \
269: } \
270: else if (GET_CODE (XEXP (addr, 0)) == REG) \
271: { \
272: reg1 = XEXP (addr, 0); \
273: addr = XEXP (addr, 1); \
274: } \
275: else if (GET_CODE (XEXP (addr, 1)) == REG) \
276: { \
277: reg1 = XEXP (addr, 1); \
278: addr = XEXP (addr, 0); \
279: } \
280: if (GET_CODE (addr) == REG || GET_CODE (addr) == MULT \
281: || GET_CODE (addr) == SIGN_EXTEND) \
282: { if (reg1 == 0) reg1 = addr; else reg2 = addr; addr = 0; } \
283: /* for OLD_INDEXING \
284: else if (GET_CODE (addr) == PLUS) \
285: { \
286: if (GET_CODE (XEXP (addr, 0)) == REG) \
287: { \
288: reg2 = XEXP (addr, 0); \
289: addr = XEXP (addr, 1); \
290: } \
291: else if (GET_CODE (XEXP (addr, 1)) == REG) \
292: { \
293: reg2 = XEXP (addr, 1); \
294: addr = XEXP (addr, 0); \
295: } \
296: } \
297: */ \
298: if (offset != 0) { if (addr != 0) abort (); addr = offset; } \
299: if ((reg1 && (GET_CODE (reg1) == SIGN_EXTEND \
300: || GET_CODE (reg1) == MULT)) \
301: || (reg2 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg2)))) \
302: { breg = reg2; ireg = reg1; } \
303: else if (reg1 != 0 && REGNO_OK_FOR_BASE_P (REGNO (reg1))) \
304: { breg = reg1; ireg = reg2; } \
305: if (ireg != 0 && breg == 0 && GET_CODE (addr) == LABEL_REF) \
306: { int scale = 1; \
307: if (GET_CODE (ireg) == MULT) \
308: { scale = INTVAL (XEXP (ireg, 1)); \
309: ireg = XEXP (ireg, 0); } \
310: if (GET_CODE (ireg) == SIGN_EXTEND) \
311: fprintf (FILE, "LD%%%d(%%pc,%s.w", \
312: CODE_LABEL_NUMBER (XEXP (addr, 0)), \
313: reg_names[REGNO (XEXP (ireg, 0))]); \
314: else \
315: fprintf (FILE, "LD%%%d(%%pc,%s.l", \
316: CODE_LABEL_NUMBER (XEXP (addr, 0)), \
317: reg_names[REGNO (ireg)]); \
318: if (scale != 1) fprintf (FILE, "*%d", scale); \
319: fprintf (FILE, ")"); \
320: break; } \
321: if (breg != 0 && ireg == 0 && GET_CODE (addr) == LABEL_REF) \
322: { fprintf (FILE, "LD%%%d(%%pc,%s.l", \
323: CODE_LABEL_NUMBER (XEXP (addr, 0)), \
324: reg_names[REGNO (breg)]); \
325: putc (')', FILE); \
326: break; } \
327: if (ireg != 0 || breg != 0) \
328: { int scale = 1; \
329: if (breg == 0) \
330: abort (); \
331: if (addr != 0) \
332: output_addr_const (FILE, addr); \
333: fprintf (FILE, "(%s", reg_names[REGNO (breg)]); \
334: if (ireg != 0) \
335: putc (',', FILE); \
336: if (ireg != 0 && GET_CODE (ireg) == MULT) \
337: { scale = INTVAL (XEXP (ireg, 1)); \
338: ireg = XEXP (ireg, 0); } \
339: if (ireg != 0 && GET_CODE (ireg) == SIGN_EXTEND) \
340: fprintf (FILE, "%s.w", reg_names[REGNO (XEXP (ireg, 0))]); \
341: else if (ireg != 0) \
342: fprintf (FILE, "%s.l", reg_names[REGNO (ireg)]); \
343: if (scale != 1) fprintf (FILE, "*%d", scale); \
344: putc (')', FILE); \
345: break; \
346: } \
347: else if (reg1 != 0 && GET_CODE (addr) == LABEL_REF) \
348: { fprintf (FILE, "LD%%%d(%%pc,%s.w)", \
349: CODE_LABEL_NUMBER (XEXP (addr, 0)), \
350: reg_names[REGNO (reg1)]); \
351: break; } \
352: default: \
353: if (GET_CODE (addr) == CONST_INT \
354: && INTVAL (addr) < 0x8000 \
355: && INTVAL (addr) >= -0x8000) \
356: fprintf (FILE, "%d", INTVAL (addr)); \
357: else \
358: output_addr_const (FILE, addr); \
359: }}
360:
361: #define ASM_GENERATE_INTERNAL_LABEL(LABEL, PREFIX, NUM) \
362: sprintf ((LABEL), "%s%%%d", (PREFIX), (NUM))
363:
364: #define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM) \
365: fprintf (FILE, "%s%%%d:\n", PREFIX, NUM)
366:
367: /* Must put address in %a0 , not %d0 . -- LGM, 7/15/88 */
368: #define FUNCTION_PROFILER(FILE, LABEL_NO) \
369: fprintf (FILE, "\tmov.l &LP%%%d,%%a0\n\tjsr mcount\n", (LABEL_NO))
370:
371: #define ASM_OUTPUT_ADDR_VEC_ELT(FILE, VALUE) \
372: fprintf (FILE, "\tlong L%%%d\n", (VALUE))
373:
374: #define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \
375: fprintf (FILE, "\tshort L%%%d-L%%%d\n", (VALUE), (REL))
376:
377: /* ihnp4!lmayk!lgm says that `short 0' triggers assembler bug;
378: `short L%nn-L%nn' supposedly works. */
379: #define ASM_OUTPUT_CASE_LABEL(FILE,PREFIX,NUM,TABLE) \
380: if (! RTX_INTEGRATED_P (TABLE)) \
381: fprintf (FILE, "\tswbeg &%d\n%s%%%d:\n", \
382: XVECLEN (PATTERN (TABLE), 1), (PREFIX), (NUM)); \
383: else \
384: fprintf (FILE, "\tswbeg &%d\n%s%%%d:\n\tshort %s%%%d-%s%%%d\n", \
385: XVECLEN (PATTERN (TABLE), 1) + 1, (PREFIX), (NUM), \
386: (PREFIX), (NUM), (PREFIX), (NUM))
387:
388: /* At end of a switch table, define LDnnn iff the symbol LInnn was defined.
389: Some SGS assemblers have a bug such that "Lnnn-LInnn-2.b(pc,d0.l*2)"
390: fails to assemble. Luckily "LDnnn(pc,d0.l*2)" produces the results
391: we want. This difference can be accommodated by making the assembler
392: define such "LDnnn" to be either "Lnnn-LInnn-2.b", "Lnnn", or any other
393: string, as necessary. This is accomplished via the ASM_OUTPUT_CASE_END
394: macro. */
395:
396: #define ASM_OUTPUT_CASE_END(FILE,NUM,TABLE) \
397: { if (switch_table_difference_label_flag) \
398: fprintf (FILE, "\tset LD%%%d,L%%%d-LI%%%d\n", (NUM), (NUM), (NUM)); \
399: switch_table_difference_label_flag = 0; }
400:
401: int switch_table_difference_label_flag;
402:
403: #define ASM_OUTPUT_OPCODE(FILE, PTR) \
404: { if ((PTR)[0] == 'j' && (PTR)[1] == 'b') \
405: { ++(PTR); \
406: while (*(PTR) != ' ') \
407: { putc (*(PTR), (FILE)); ++(PTR); } \
408: fprintf ((FILE), ".w"); } \
409: else if ((PTR)[0] == 's') \
410: { \
411: if (!strncmp ((PTR), "swap", 4)) \
412: { fprintf ((FILE), "swap.w"); (PTR) += 4; } \
413: } \
414: else if ((PTR)[0] == 'f') \
415: { \
416: if (!strncmp ((PTR), "fmove", 5)) \
417: { fprintf ((FILE), "fmov"); (PTR) += 5; } \
418: else if (!strncmp ((PTR), "fbne", 4)) \
419: { fprintf ((FILE), "fbneq"); (PTR) += 4; } \
420: } \
421: /* MOVE, MOVEA, MOVEQ, MOVEC ==> MOV */ \
422: else if ((PTR)[0] == 'm' && (PTR)[1] == 'o' \
423: && (PTR)[2] == 'v' && (PTR)[3] == 'e') \
424: { fprintf ((FILE), "mov"); (PTR) += 4; \
425: if ((PTR)[0] == 'q' || (PTR)[0] == 'a' \
426: || (PTR)[0] == 'c') (PTR)++; } \
427: /* SUB, SUBQ, SUBA, SUBI ==> SUB */ \
428: else if ((PTR)[0] == 's' && (PTR)[1] == 'u' \
429: && (PTR)[2] == 'b') \
430: { fprintf ((FILE), "sub"); (PTR) += 3; \
431: if ((PTR)[0] == 'q' || (PTR)[0] == 'i' \
432: || (PTR)[0] == 'a') (PTR)++; } \
433: /* CMP, CMPA, CMPI, CMPM ==> CMP */ \
434: else if ((PTR)[0] == 'c' && (PTR)[1] == 'm' \
435: && (PTR)[2] == 'p') \
436: { fprintf ((FILE), "cmp"); (PTR) += 3; \
437: if ((PTR)[0] == 'a' || (PTR)[0] == 'i' \
438: || (PTR)[0] == 'm') (PTR)++; } \
439: }
440:
441: #define ASM_OUTPUT_LOCAL(FILE, NAME, SIZE, ROUNDED) \
442: ( fputs ("\tlcomm ", (FILE)), \
443: assemble_name ((FILE), (NAME)), \
444: fprintf ((FILE), ",%u\n", (ROUNDED)))
445:
446: #define ASM_OUTPUT_LABELREF(FILE,NAME) \
447: fprintf (FILE, "%s", NAME)
448:
449: /* Override usual definitions of SDB output macros.
450: These definitions differ only in the absence of the period
451: at the beginning of the name of the directive
452: and in the use of `~' as the symbol for the current location. */
453:
454: #define PUT_SDB_SCL(a) fprintf(asm_out_file, "\tscl\t%d;", (a))
455: #define PUT_SDB_INT_VAL(a) fprintf (asm_out_file, "\tval\t%d;", (a))
456: #define PUT_SDB_VAL(a) \
457: ( fputs ("\tval\t", asm_out_file), \
458: output_addr_const (asm_out_file, (a)), \
459: fputc (';', asm_out_file))
460:
461: #define PUT_SDB_DEF(a) \
462: do { fprintf (asm_out_file, "\tdef\t"); \
463: ASM_OUTPUT_LABELREF (asm_out_file, a); \
464: fprintf (asm_out_file, ";"); } while (0)
465:
466: #define PUT_SDB_PLAIN_DEF(a) fprintf(asm_out_file,"\tdef\t~%s;",a)
467: #define PUT_SDB_ENDEF fputs("\tendef\n", asm_out_file)
468: #define PUT_SDB_TYPE(a) fprintf(asm_out_file, "\ttype\t0%o;", a)
469: #define PUT_SDB_SIZE(a) fprintf(asm_out_file, "\tsize\t%d;", a)
470: #define PUT_SDB_START_DIM fprintf(asm_out_file, "\tdim\t")
471:
472: #define PUT_SDB_TAG(a) \
473: do { fprintf (asm_out_file, "\ttag\t"); \
474: ASM_OUTPUT_LABELREF (asm_out_file, a); \
475: fprintf (asm_out_file, ";"); } while (0)
476:
477: #define PUT_SDB_BLOCK_START(LINE) \
478: fprintf (asm_out_file, \
479: "\tdef\t~bb;\tval\t~;\tscl\t100;\tline\t%d;\tendef\n", \
480: (LINE))
481:
482: #define PUT_SDB_BLOCK_END(LINE) \
483: fprintf (asm_out_file, \
484: "\tdef\t~eb;\tval\t~;\tscl\t100;\tline\t%d;\tendef\n", \
485: (LINE))
486:
487: #define PUT_SDB_FUNCTION_START(LINE) \
488: fprintf (asm_out_file, \
489: "\tdef\t~bf;\tval\t~;\tscl\t101;\tline\t%d;\tendef\n", \
490: (LINE))
491:
492: #define PUT_SDB_FUNCTION_END(LINE) \
493: fprintf (asm_out_file, \
494: "\tdef\t~ef;\tval\t~;\tscl\t101;\tline\t%d;\tendef\n", \
495: (LINE))
496:
497: #define PUT_SDB_EPILOGUE_END(NAME) \
498: fprintf (asm_out_file, \
499: "\tdef\t%s;\tval\t~;\tscl\t-1;\tendef\n", \
500: (NAME))
501:
502: #define SDB_GENERATE_FAKE(BUFFER, NUMBER) \
503: sprintf ((BUFFER), "~%dfake", (NUMBER));
504:
505: /* Define subroutines to call to handle multiply, divide, and remainder.
506: Use the subroutines that the 3b1's library provides.
507: The `*' prevents an underscore from being prepended by the compiler. */
508:
509: #define DIVSI3_LIBCALL "*ldiv"
510: #define UDIVSI3_LIBCALL "*uldiv"
511: #define MODSI3_LIBCALL "*lrem"
512: #define UMODSI3_LIBCALL "*ulrem"
513: #define MULSI3_LIBCALL "*lmul"
514: #define UMULSI3_LIBCALL "*ulmul"
515:
516: /* Definitions for collect2. */
517:
518: #define OBJECT_FORMAT_COFF
519: #define NO_SYS_SIGLIST
520: #define MY_ISCOFF(magic) \
521: ((magic) == MC68KWRMAGIC || (magic) == MC68KROMAGIC || (magic) == MC68KPGMAGIC)
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.