Add test for EM _rck_. Fix traps in PowerPC ncg.
authorGeorge Koehler <xkernigh@netscape.net>
Mon, 25 Dec 2017 03:37:52 +0000 (22:37 -0500)
committerGeorge Koehler <xkernigh@netscape.net>
Mon, 25 Dec 2017 03:37:52 +0000 (22:37 -0500)
commit26de4c1ab18df825607d7882924f57c673af46cf
treea05ddda3132eb5693d376230327d578397e4590b
parent5f2a7b260fd8af26294062f69599db4d0d698293
Add test for EM _rck_.  Fix traps in PowerPC ncg.

The new test rck_e.e segfaults on PowerPC unless I make some changes.
The inline code for _rck_ was wrong because it didn't allow the trap
handler to return.  _sig_ forgot to push the old trap handler.

Move plat/linuxppc/libsys/trap.s to mach/powerpc/libem/trp.s and
rewrite it with simplified/extended mnemonics.  Remove .trap alias for
.trp procedure.  Add a missing `mtspr lr, r0` so we can return from
the trap handler.  Call write() and _exit() so trp.s works with both
linuxppc and osxppc.  Before, Mac OS X was wrongly using the trap.s
for Linux.

In powerpc/libem, simplify .aar4; teach .csa and .csb to raise the
trap if the default target is zero.

C programs don't need these changes.  You may relink your C programs
with the changed .csa and .csb, but C code doesn't raise the trap.
Modula-2 code can raise traps, so you may want to relink your Modula-2
programs with the changed libem, but you might keep your old .o files
from Modula-2.  You may need to recompile your Pascal programs (delete
old .o files from Pascal) because the Pascal compiler might use _rck_.
12 files changed:
mach/powerpc/libem/aar4.s
mach/powerpc/libem/build.lua
mach/powerpc/libem/csa.s
mach/powerpc/libem/csb.s
mach/powerpc/libem/rck.s
mach/powerpc/libem/trp.s [new file with mode: 0644]
mach/powerpc/ncg/table
plat/linuxppc/libsys/build.lua
plat/linuxppc/libsys/trap.s [deleted file]
plat/osxppc/libsys/build.lua
tests/plat/build.lua
tests/plat/rck_e.e [new file with mode: 0644]