-
Notifications
You must be signed in to change notification settings - Fork 6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
M68k a line trap support for at least Classic Mac, Apple Lisa, and Sharp X68000 #7126
base: master
Are you sure you want to change the base?
M68k a line trap support for at least Classic Mac, Apple Lisa, and Sharp X68000 #7126
Conversation
I have learned that the Atari ST actually did use A-line traps. Specifically for low-level graphics. Unlike Amiga and Classic Mac, it also used the 68000 |
It turns out at least one platform did extensively use F-line traps, the Sharp X68000. So I'll have to make it conditional whether to use FPU opcodes or F-line traps. |
Apparently TI's graphing calculators that ran 68000 CPUs used both A-line and F-line traps in various ways: https://www.omnimaga.org/other-calculator-discussion-and-news/best-ti-89-(titanium)-shell/15/#msg_116730 |
Palm OS also used A-line traps: https://jacobfilipp.com/DrDobbs/articles/DDJ/1999/9911/9911d/9911d.htm In C it used a |
Microware OS-9 for 68K seems to have not used A-line or F-line at all, but did use the |
The Atari ST used: TRAP #1 (GEMDOS), TRAP #13 (BIOS) and TRAP #14 (XBIOS) with a standard 68k C calling convention. TRAP #2 (AES/VDI) is used with a fixed 68k register convention. LINEA #0 … LINEA #15 are used for Line-A draw primitives, also using a 68k registers for I/o parameters. Very old TOS versions used Line-F as well to compress function calls in the ROM from 6 bytes to 2 bytes to make it fit into 192kb ROM. The 12 bit value in the opcode is the function, while parameters follow the standard 68k C calling conversion. |
I was hunting for this Atari Line-F stuff and just found it a couple of hours ago. Not easy to Google. My impression was that it was one part of TOS 1.04 aka "Rainbow TOS", AES I think, and that's where I found it. I didn't check other versions though. |
Yes, the Line-F stuff existed in 192kb ROMs (1.0 till 1.62). When Atari switched to the 256KB ROMs they removed that Line-F code. It exists only in the AES/Desktop code in the ROM. Honestly despite spending a LOT of time reverse engineering on the Atari in the 80s and optimizing the TOS I never touched the Line-F stuff – it was never that important. And today you can look and even compile the leaked source code for the TOS, so the need is simply not there. I can probably provide you with the info, if you really care. |
I was an Amiga guy back in the day so I'm a bit ignorant. Was Desktop part of AES? I only just read a few minutes ago that Desktop used F-line as well as AES.
For me it's just for the fun of retrocomputing + the fun of disassembling + something interesting to program (-:
I just wanted to get a thorough overview of how they were used across systems before hastily jumping in to a too-limited solution. When the Lisa's use was only the second I ever saw I though they might get used a myriad ways, but it's the only real outlier. I'm guessing the specifics, such as what each trap does would belong in a platform-specific script rather than have anything to do with the sleigh, but that's all beyond what I have learned yet in Ghidra. (Also, and off-topic for this thread, but I have some questions about Atari ST object and library file formats if there's an appropriate place to start such a thread. On GitHub or one of the Atari forums?) |
I wouldn't call it "ignorant" at all, it is just not knowing. BIOS/XBIOS/GEMDOS = low level file system, etc. stuff We might want to separate the processor issues (2 byte 68k alignment, function calling conventions) from the file formats and system API integration. I think for the latter some people try to support syscalls for Linux, which is similar – maybe they have some pointers. I think this is the most critical and tricky part to get the 68k CPU adopted to support the different APIs in general, so that the decompiler works as well (the disassembler itself is trivial) Optionally support for system variables, symbol tables, etc. is all part of loaders. These are not hard to write (Classic Mac are tricky because of the resource forks) and are sitting on top of the CPU changes, which are required. I have done some stuff for Ghidra for the Atari ST, C64 and the Atari 400/800/XE series – some with Java code. I am coming from IDA, but as a hobby guy I can no longer afford the license (I spend the money for it, but >$1k for a hobby per year – nope – so I am doing more and more with Ghidra) |
Loaders (and FileSystems) are what I've mostly been working on. Classic Mac was my first one for a 32-bit platform I didn't really know. It's in my project RetroGhidra but I don't think anybody has tried using it yet. I'm sure there are many features of loaders I haven't learned yet.
I have some loaders for those in RetroGhidra too, but other people have made better ones for Ghidra already. I've looked at the free IDA a few times but it's too limited and I don't have spare money. |
Related problem with M68K: I was just told that while OS9 didn't use A-line or F-line traps, it does a similar the to what Apple Lisa does with A-line traps except with the regular It adds an extra word after the instruction which most disassemblers don't know about and hence misinterpret as an instruction, likely a bad instruction. |
You can find the code of LineF handler used in AtariST: https://github.com/th-otto/tos1x/blob/master/aes/linefhdl.S Some explanations are at the top of that file. Unfortunately, the list of functions is also OS version dependent. The list there is for TOS 1.04, but 1.00/1.02 have a different one. In the 256k ROMs (1.06 and later) that ugly hack is not used anymore. The LineA trap however was still used in the latest ROMs, but only to call 16 functions. |
I'm currently struggling trying to implement something similar for the Atari's LineF trap handler. What i did is
to the instr token
But i have two problems with this:
Any hint what i am doing wrong? |
Here's my work so far on #140 and #487 to get so-called "A-line traps" working with the disassembler for Motorola 68000.
This is an early draft for discussion, not intended to be merged yet.
op011
for the opcode is clear but I just pickedopx015
for the second 16-bit word of the Lisa variant because it's the right size. I don't know if it's the best semantically.atrap
andftrap
based on discussion in the feature request. It may be better to mimic what the platforms' native SDKs did? But there may be multiple platforms that did it different ways. Them
andl
suffixes are also just for clarity and need not stay.with : extGUARD=1 {
, both of which might not be best.I noticed that while the Lisa format is very different, using 2 16-bit words instead of one, that the X68000 and Classic Mac also differ to a lesser extent. Mac only needs the high
$f
nybble while the X68000 needs the high$ff
byte. They could be unified or not which would mean part that's semantically part of the platform's instruction would appear in a naïve listing.What Apple Lisa code currently looks like without this support:
The same with this support:
What Classic Mac code looks like with this support:
What X68000 code looks like with this support: