ack/mach/i80/ncg/mach.c
George Koehler 1faff418ec Teach some ncg machines to use .data8
This turns EM `con 5000000000I8` into assembly `.data8 5000000000` for
machines i386, i80, i86, m68020, powerpc, vc4.  These are the only ncg
machines in our build.

i80 and i86 get con_mult(sz) for sz == 4 and sz == 8.  The other
machines only get sz == 8, because they have 4-byte words, and ncg
only calls con_mult(sz) when sz is greater than the word size.  The
tab "\t" after .data4 or .data8 is like the tabs in the con_*() macros
of mach/*/ncg/mach.h.

i86 now uses .data4, like i80.  Also, i86 and i386 now use the numeric
string without converting it to an integer and back to a string.
2019-08-13 15:37:05 -04:00

92 lines
1.7 KiB
C

/*
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
* See the copyright notice in the ACK home directory, in the file "Copyright".
*
*/
/*
* machine dependent back end routines for the Intel 8080.
*/
#include <stdlib.h> /* atol */
void con_part(int sz, word w)
{
while (part_size % sz)
part_size++;
if (part_size == 2)
part_flush();
if (sz == 1)
{
w &= 0xFF;
if (part_size)
w <<= 8;
part_word |= w;
}
else
{
assert(sz == 2);
part_word = w;
}
part_size += sz;
}
void
con_mult(word sz) {
if (sz != 4 && sz != 8)
fatal("bad icon/ucon size");
fprintf(codefile,".data%d\t%s\n", (int)sz, str);
}
#define CODE_GENERATOR
#define IEEEFLOAT
#define FL_MSL_AT_LOW_ADDRESS 0
#define FL_MSW_AT_LOW_ADDRESS 0
#define FL_MSB_AT_LOW_ADDRESS 0
#include <con_float>
void prolog(full nlocals)
{
int16_t adjustment = -nlocals;
if (adjustment == 0)
fprintf(codefile, "\tcall .pro0\n");
else if (adjustment == -2)
fprintf(codefile, "\tcall .pro2\n");
else if (adjustment == -4)
fprintf(codefile, "\tcall .pro4\n");
else if ((adjustment >= -128) && (adjustment <= 127))
fprintf(codefile, "\tcall .probyte\n\t.data1 %d\n", adjustment);
else
fprintf(codefile, "\tcall .proword\n\t.data2 %d\n", adjustment);
}
void mes(type) word type;
{
int argt;
switch ((int)type)
{
case ms_ext:
for (;;)
{
switch (argt = getarg(ptyp(sp_cend) | ptyp(sp_pnam) | sym_ptyp))
{
case sp_cend:
return;
default:
strarg(argt);
fprintf(codefile, ".define %s\n", argstr);
break;
}
}
default:
while (getarg(any_ptyp) != sp_cend)
;
break;
}
}
char* segname[] = { ".sect .text", ".sect .data", ".sect .rom", ".sect .bss" };