2013-05-08 23:56:10 +00:00
|
|
|
# $Source: /cvsroot/tack/Ack/plat/linux386/descr,v $
|
|
|
|
# $State: Exp $
|
|
|
|
# $Revision: 1.1 $
|
|
|
|
|
|
|
|
var w=4
|
2013-05-21 18:18:11 +00:00
|
|
|
var wa=4
|
|
|
|
var p={w}
|
|
|
|
var pa={w}
|
2013-05-08 23:56:10 +00:00
|
|
|
var s=2
|
2013-05-21 18:18:11 +00:00
|
|
|
var sa={s}
|
|
|
|
var l={w}
|
|
|
|
var la={w}
|
Add 8-byte long long for linux68k.
Add rules for 8-byte integers to m68020 ncg. Add 8-byte long long to
ACK C on linux68k. Enable long-long tests for linux68k. The tests
pass in our emulator using musahi; I don't have a real 68k processor
and haven't tried other emulators.
Still missing are conversions between 8-byte integers and any size of
floats. The long-long tests don't cover these conversions, and our
emulator can't do floating-point.
Our build always enables TBL68020 and uses word size 4. Without
TBL68020, 8-byte multiply and divide are missing. With word size 2,
some conversions between 2-byte and 8-byte integers are missing.
Fix .cii in libem, which didn't work when converting from 1-byte or
2-byte integers. Now .cii and .cuu work, but also add some rules to
skip .cii and .cuu when converting 8-byte integers. The new rule for
loc 4 loc 8 cii `with test_set4` exposes a bug: the table may believe
that the condition codes test a 4-byte register when they only test a
word or byte, and this incorrect test may describe an unsigned word or
byte as negative. Another rule `with exact test_set1+test_set2` works
around the bug by ignoring the negative flag, because a zero-extended
word or byte is never negative.
The old rules for comparison and logic do work with 8-byte integers
and bitsets, but add some specific 8-byte rules to skip libem calls or
loops. There were no rules for 8-byte arithmetic, shift, or rotate;
so add some. There is a register shortage, because the table requires
preserving d3 to d7, leaving only 3 data registers (d0, d1, d2) for
8-byte operations. Because of the shortage, the code may move data to
an address register, or read a memory location more than once.
The multiplication and division code are translations of the i386
code. They pass the tests, but might not give the best performance on
a real 68k processor.
2019-09-24 17:32:17 +00:00
|
|
|
var q=8
|
|
|
|
var qa=4
|
2013-05-21 18:18:11 +00:00
|
|
|
var f={w}
|
|
|
|
var fa={w}
|
2013-05-08 23:56:10 +00:00
|
|
|
var d=8
|
2013-05-21 18:18:11 +00:00
|
|
|
var da={d}
|
|
|
|
var x=8
|
|
|
|
var xa={x}
|
2013-05-08 23:56:10 +00:00
|
|
|
var ARCH=m68020
|
|
|
|
var PLATFORM=linux68k
|
2013-05-12 22:51:55 +00:00
|
|
|
var PLATFORMDIR={EM}/share/ack/{PLATFORM}
|
Add 8-byte long long for linux68k.
Add rules for 8-byte integers to m68020 ncg. Add 8-byte long long to
ACK C on linux68k. Enable long-long tests for linux68k. The tests
pass in our emulator using musahi; I don't have a real 68k processor
and haven't tried other emulators.
Still missing are conversions between 8-byte integers and any size of
floats. The long-long tests don't cover these conversions, and our
emulator can't do floating-point.
Our build always enables TBL68020 and uses word size 4. Without
TBL68020, 8-byte multiply and divide are missing. With word size 2,
some conversions between 2-byte and 8-byte integers are missing.
Fix .cii in libem, which didn't work when converting from 1-byte or
2-byte integers. Now .cii and .cuu work, but also add some rules to
skip .cii and .cuu when converting 8-byte integers. The new rule for
loc 4 loc 8 cii `with test_set4` exposes a bug: the table may believe
that the condition codes test a 4-byte register when they only test a
word or byte, and this incorrect test may describe an unsigned word or
byte as negative. Another rule `with exact test_set1+test_set2` works
around the bug by ignoring the negative flag, because a zero-extended
word or byte is never negative.
The old rules for comparison and logic do work with 8-byte integers
and bitsets, but add some specific 8-byte rules to skip libem calls or
loops. There were no rules for 8-byte arithmetic, shift, or rotate;
so add some. There is a register shortage, because the table requires
preserving d3 to d7, leaving only 3 data registers (d0, d1, d2) for
8-byte operations. Because of the shortage, the code may move data to
an address register, or read a memory location more than once.
The multiplication and division code are translations of the i386
code. They pass the tests, but might not give the best performance on
a real 68k processor.
2019-09-24 17:32:17 +00:00
|
|
|
var CPP_F=-D__unix -D__mc68020 -D__m68k -D__mc68000 -D__M68020 -D_EM_LLSIZE={q}
|
2013-05-08 23:56:10 +00:00
|
|
|
var ALIGN=-a0:4 -a1:4 -a2:4 -a3:4 -b0:0x08000054
|
|
|
|
var C_LIB={PLATFORMDIR}/libc-ansi.a
|
|
|
|
# bitfields reversed for compatibility with (g)cc.
|
Add 8-byte long long for linux68k.
Add rules for 8-byte integers to m68020 ncg. Add 8-byte long long to
ACK C on linux68k. Enable long-long tests for linux68k. The tests
pass in our emulator using musahi; I don't have a real 68k processor
and haven't tried other emulators.
Still missing are conversions between 8-byte integers and any size of
floats. The long-long tests don't cover these conversions, and our
emulator can't do floating-point.
Our build always enables TBL68020 and uses word size 4. Without
TBL68020, 8-byte multiply and divide are missing. With word size 2,
some conversions between 2-byte and 8-byte integers are missing.
Fix .cii in libem, which didn't work when converting from 1-byte or
2-byte integers. Now .cii and .cuu work, but also add some rules to
skip .cii and .cuu when converting 8-byte integers. The new rule for
loc 4 loc 8 cii `with test_set4` exposes a bug: the table may believe
that the condition codes test a 4-byte register when they only test a
word or byte, and this incorrect test may describe an unsigned word or
byte as negative. Another rule `with exact test_set1+test_set2` works
around the bug by ignoring the negative flag, because a zero-extended
word or byte is never negative.
The old rules for comparison and logic do work with 8-byte integers
and bitsets, but add some specific 8-byte rules to skip libem calls or
loops. There were no rules for 8-byte arithmetic, shift, or rotate;
so add some. There is a register shortage, because the table requires
preserving d3 to d7, leaving only 3 data registers (d0, d1, d2) for
8-byte operations. Because of the shortage, the code may move data to
an address register, or read a memory location more than once.
The multiplication and division code are translations of the i386
code. They pass the tests, but might not give the best performance on
a real 68k processor.
2019-09-24 17:32:17 +00:00
|
|
|
# long long enabled.
|
|
|
|
var CC_ALIGN=-Vrq{q}.{qa}
|
2013-05-08 23:56:10 +00:00
|
|
|
var OLD_C_LIB={C_LIB}
|
|
|
|
var MACHOPT_F=-ml10
|
2016-08-21 20:01:19 +00:00
|
|
|
var EGO_PLAT_FLAGS=-M{EM}/share/ack/ego/{ARCH}.descr
|
2013-05-08 23:56:10 +00:00
|
|
|
|
|
|
|
# Override the setting in fe so that files compiled for linux68k can see
|
|
|
|
# the platform-specific headers.
|
|
|
|
|
2018-06-24 17:57:43 +00:00
|
|
|
var C_INCLUDES=-I{EM}/share/ack/linux/include -I{EM}/share/ack/include/ansi
|
2013-05-08 23:56:10 +00:00
|
|
|
|
|
|
|
name be
|
|
|
|
from .m.g
|
|
|
|
to .s
|
2013-05-13 22:26:15 +00:00
|
|
|
program {EM}/lib/ack/{PLATFORM}/ncg
|
2013-05-08 23:56:10 +00:00
|
|
|
mapflag -gdb GF=-gdb
|
|
|
|
args {GF?} <
|
|
|
|
stdout
|
|
|
|
need .e
|
|
|
|
end
|
|
|
|
name as
|
|
|
|
from .s.so
|
|
|
|
to .o
|
2013-05-13 22:26:15 +00:00
|
|
|
program {EM}/lib/ack/{PLATFORM}/as
|
2013-05-08 23:56:10 +00:00
|
|
|
args - -o > <
|
|
|
|
prep cond
|
|
|
|
end
|
|
|
|
name led
|
|
|
|
from .o.a
|
|
|
|
to .out
|
2013-05-12 22:51:55 +00:00
|
|
|
program {EM}/lib/ack/em_led
|
2013-05-08 23:56:10 +00:00
|
|
|
mapflag -l* LNAME={PLATFORMDIR}/lib*
|
|
|
|
mapflag -fp FLOATS={EM}/{LIB}fp
|
|
|
|
args {ALIGN} {SEPID?} \
|
2016-12-29 17:11:53 +00:00
|
|
|
({RTS}:.b=-u _i_main) \
|
2013-05-08 23:56:10 +00:00
|
|
|
(.e:{HEAD}={PLATFORMDIR}/boot.o) \
|
2016-11-27 19:48:07 +00:00
|
|
|
({RTS}:.ocm.bas.b={PLATFORMDIR}/c-ansi.o) \
|
2013-05-08 23:56:10 +00:00
|
|
|
({RTS}:.c={PLATFORMDIR}/c-ansi.o) \
|
|
|
|
({RTS}:.mod={PLATFORMDIR}/modula2.o) \
|
|
|
|
({RTS}:.p={PLATFORMDIR}/pascal.o) \
|
|
|
|
-o > < \
|
|
|
|
(.p:{TAIL}={PLATFORMDIR}/libpascal.a) \
|
2016-11-27 19:48:07 +00:00
|
|
|
(.b:{TAIL}={PLATFORMDIR}/libb.a) \
|
2016-11-27 19:38:33 +00:00
|
|
|
(.bas:{TAIL}={PLATFORMDIR}/libbasic.a) \
|
2013-05-08 23:56:10 +00:00
|
|
|
(.mod:{TAIL}={PLATFORMDIR}/libmodula2.a) \
|
|
|
|
(.ocm:{TAIL}={PLATFORMDIR}/liboccam.a) \
|
2016-11-27 19:48:07 +00:00
|
|
|
(.ocm.bas.mod.b.c.p:{TAIL}={PLATFORMDIR}/libc.a) \
|
2013-05-08 23:56:10 +00:00
|
|
|
{FLOATS?} \
|
|
|
|
(.e:{TAIL}={PLATFORMDIR}/libem.a \
|
|
|
|
{PLATFORMDIR}/libsys.a \
|
|
|
|
{PLATFORMDIR}/libend.a)
|
|
|
|
linker
|
|
|
|
end
|
|
|
|
name cv
|
|
|
|
from .out
|
|
|
|
to .exe
|
|
|
|
program {EM}/bin/aelflod
|
2013-05-09 14:54:23 +00:00
|
|
|
args -m4 -b < >
|
2013-05-08 23:56:10 +00:00
|
|
|
outfile linux68k.exe
|
|
|
|
end
|