# Interfacing the 68000 to an AIM 65 oday there are several 16-bit CPUs on the market; for a number of reasons the most famous are only three, the 8086, the Z8000 and the Motorola MC68000. We have been hearing a lot about what they can and cannot do; as a matter of fact, boards employing one of such CPUs did not have too much luck. This recalls to memory what happened years ago: everybody realized that the Z80 was more powerful than the 8080, but an upgrading kit for 8080 machines simply did not sell. The reason was not the lack of Z80 software, because the Z80 can run 8080 software. It was that the user was not willing to spend money for something maybe better but not "useful." Nowadays we have to ask ourselves how useful is a 16-bit CPU; we feel it is not for the computer consumer, the one who buys a computer just to play games or little more. There is a range of applications requiring more computational power than what is currently available on 8-bit CPUs. When we say "computational power," we do not only mean an extended instruction set or the capability of running standard programs ten times faster: all those aspects have to be considered as a whole, along with all the hardware facilities. Many concepts developed for the old mainframes are becoming prominent in microsystem design: can you imagine a multi-task, multiprocessor system without the test-and-set instruction and the user-supervisor environment? Even the hobbyist with little background can successfully experiment with concurrent programming on a fairly small system, provided he has the right CPU to start with. We think that a good 16-bit CPU has enough power to handle fairly sophisticated, concurrent programming. Among the available devices, the MC68000 is a good choice. Besides its nice hardware structure, the following points are to be taken into account: - Its instructions are powerful but limited in number. We feel that a large instruction set does not necessarily make a processor more powerful, it may instead confuse the programmer. - 2) The instruction set is microprogrammed; it may be improved without changing the overall structure. - 3) Its pipelined structure is optimized for speed. - 4) It is asynchronous; this feature allows for easy interfacing with all kinds of devices and peripherals. The 68000 has some drawbacks, too: - It does not provide a dynamic memory refresh like the Z8000; this is a really handy feature, even if software refresh is an alternative. - 2) Its most interesting supporting chips are not scheduled to be available in the near future. - 3) Like most of its competitors, there is not too much software available if we exclude that delivered from Motorola for their boards and development systems (which, in any case, are quite expensive). ## **Luca Fusina and Claudio Granuzzo** Luca Fusina, Via Mocenigo 8, Verona 37100, Italy. All the article content may be used for any non-commercial purpose. Nowadays it seems that what really interests the computer consumer is software. He does not care too much about the underlying hardware, he is most concerned about the programs he can run on his machine. At most he considers the interface capabilities of his computer, but usually he even does not know the internal hardware structure. In our opinion there are still some people interested in system design: people who like to experiment with new devices. The tool for this kind of work is called a development system. After the hobbyist eliminates the ones that are too expensive, what is left is an evaluation system which basically is a single board equipped with a CPU and a handful of switches and LEDs. Experimenting with such boards is time consuming and not rewarding at all in any case. There must be a better solution. #### The Idea Almost all of the computer enthusiasts around already own a microcomputer. Why not use our own system to control a 68000? In this article we will describe this hardware and software implementation on a Rockwell AIM 65. For the reader who is unfamiliar with this machine we will summarize its features. It is a single board based on the 6502 with a QWERTY keyboard, a 20-column thermal printer and an alphanumeric display, 4K byte of RAM, an 8K byte ROM monitor, a 4K byte ROM assembler, and 2 Versatile Interface Adapter chips for I/O and expansion. We had to make only a few trivial hardware changes. We have said, indeed, that we are going to control our 68000, but which way? We want to be able to control it during each read or write cycle (from now on simply cycle), in real time, changing the mode of operation according to necessity among all the ones available to our system. Furthermore, we want to be able to manipulate during each cycle all the 68000 control signals; this way we can simulate interrupts, multi-processing and so on. #### The Hardware All we needed to implement our idea was nine eight-bit I/O ports and a couple of decoders. The 68000 became a peripheral connected to the AIM bus at a certain address. On the AIM expansion connector we found all we needed: the 8-bit bi-directional data lines, the 16-bit address lines, and two control signals: R/W and 02 which are used for synchronizing R/W operations. Figure 1 (page 15) shows the block diagram of the interface; Figure 2 (page 16) is the schematic. For all the 6502 timings, the reader can refer to the 6502 hardware manual. From now on we assume the reader understands 68000 hardware and software details; refer to the MC68000 user's manual for a complete description of this processor. As the 68000 is asynchronous, we can control each cycle using the signal $\overline{DTACK}$ , which stands for data transfer acknowledge. When the 68000 wants to perform a read or a write, it asserts the $\overline{AS}$ signal and waits for $\overline{DTACK}$ . At this point our $\overline{AIM}$ program can do all it has to, and when finished it asserts $\overline{DTACK}$ by writing to location \$8XXB, signaling the 68000 to continue. IC 20 (a 74LS74 flip-flop) takes care of negating $\overline{DTACK}$ when 68000 negates $\overline{AS}$ . All 68000 signals are interfaced to the AIM through six DM81LS95 buffers and three 74LS373 latches. The 68000 interface is seen by the AIM as a 1Kbyte memory. The 6502 can address up to sixty-four 1Kbyte pages and the board can be located anywhere inside them, provided there are no conflicts with the AIM 65 requirements. This is accomplished with a DM8131 six-bit comparator (IC 10). To select the right page the user must supply the appropriate logic levels to the comparator inputs. In our implementation the board is located at \$8000. Inside this address space there are sixteen meaningful locations, from address \$8XX0 to address \$8XXF. Only twelve are, however, actually used and only the first nine are used to interface the 68000, by means of selecting one of the I/O ports. Selection 10 (signal $\overline{Y9}$ in Figure 2, address \$8XX9) is used to control the HALT line. Number eleven is not connected. Number twelve asserts DTACK (signal Y11 in Figure 2, address \$8XXB). Refer to Figures number 3, 4, 5 (page 17) for a detailed explanation about how the ports are arranged. Note that with this hardware it is not possible to use the M command of the AIM monitor inside the board space. There are two 68000 signals not connected to any port: VMA (valid memory address) and E (enable). Motorola implemented these signals to maintain compatibility with existing 6800 peripherals. In our opinion it is better to use them as test points. The user can easily add one additional port to the interface to monitor them under program control. The network of open collector inverting gates connected to the 555 timer and the \$8XX9 selection is used to interface correctly the 68000 HALT and RESET signals, which are bidirectional. Two LEDs can be used to monitor their logic levels. The board performs an automatic power-on reset; a manual reset is also provided, as well as software HALT and RESET control. #### The Software Before entering into program details, it may be a good idea to lay down its objectives: Run-time control of the dynamic evolution of each 68000 instruction step using the AIM keyboard. It is possible to execute a program stopping the 68000 every cycle, or to execute any number of instructions consecutively; a dynamic switch between these two modes is possible, too. Run-time control of the 68000 input control signal (IC 19, #74LS374 latch). The AIM 65 keyboard can be used to supply a byte to be stored in that latch. We called this feature "dummy memory." Output on display/printer of each 68000 cycle including addresses, data and control signals coming out from the Dynamic allocation of memory. 68000 memory is segmented and each segment base address can be located anywhere inside the AIM free RAM. If the 68000 is doing a read, it is possible to enter data from keyboard; if it is doing a write, it is possible to do a data display. This way no effective memory operations are done. Use of all AIM 65 peripherals and utilities under 68000 program control. We defined that a 68000 segment cannot be greater than 64Kbytes (in automatic mode). If a write is performed inside the first 256 bytes of the last 1Kbyte page available to a segment (address \$00FCXX) it is assumed that a 6502 subroutine call is made. The 68000 lower data byte is loaded in the 6502 accumulator. The 68000 upper data byte is used to index a table of pointers to 6502 subroutines. On return, the 6502 accumulator is copied into two locations, one # **Bring the flavor of Unix** To your Z80-based CP/M system with Unica Unicum: a thing unique in its kind, especially an example of writing. Unica: the plural of unicum. The Unica: a unique collection of programs supporting many features of the Unix operating system never before available under ${\sf CP/M}$ . The Unica are more than software tools; they are finely crafted instruments of surgical quality. Some of the Unica are: binary file compare catenate files copy one or more files disk map and statistics horizontal file catenation cp dm create file links (aliases) directory lister move (rename) files, even across users mv rm source file compare, with resynchronization sc srt source like content, with Taylor in-memory file sorter search multiple files for a pattern spelling error detector, with 20,000 word dictionary sp Each Unicum understands several flags ("options" or "switches") which control program alternatives. No special shell is needed; Unica commands are typed to the standard CP/M command interpreter. The Unica package supports several Unix-like facilities, like filename user numbers: wename user numbers: sc data.bas;2 data.bas;3 (compares files belonging to user 2 and user 3); Wildcard patterns: rm 'tmp' -v (types each filename containing the letters TMP and asks whether to delete the file); I/O redirection: I/O redirection ls -a ►list (writes a directory listing of all files to file"list"); Pipes: cat chap\*! sp! srt > lst: (concatenates each file whose name starts with "chap", makes a list of mispelled words, sorts the list, and prints it on the listing device). The Unica are written in XM-80, a low level language which combines rigorously checked procedure definition and invocation with the versatility of Z80 assembly language. XM-80 includes a language translator which turns XM-80 programs into source code for MACRO-80, the industry standard assembler from Microsoft. It also includes a MACRO-80 object library with over forty "software components", subroutine packages which are called to perform services such as piping, wildcard matching, output formatting, and deviceindependent I/O with buffers of any size from 1 to 64k bytes. The source code for each Unicum main program (but not for the software component library) is provided. With the Unica and XM-80, you can customize each utility to your installation, and write your own applications quickly and efficiently. Programs which you write using XM-80 components are not subject to any licensing fee. dividual spec sheets for each component, and thorough descriptions of each Unicum. Extensive documentation includes tutorials, reference manuals, in- Update policy: each Unica owner is informed when new Unica or components become available. At any time, and as often as you like, you can return the distribution disk with a \$10 handling fee and get the current versions of the Unica and XM-80, with documentation for all new or changed software. The Unica and XM-80 (which requires MACRO-80) are priced at \$195, or \$25 for the documentation. The Unica alone are supplied as ".COM executable files and are priced at \$95 for the set, or \$15 for the documentation. Software is distributed on 8" floppy disks for Z80 CP/M version 2 systems. # Knowlogy "Shaping Knowledge for Evolving Worlds" P.O. Box 283 Wilsonville, Oregon 97070 Visa/Mastercard customers call (503) 635-5701 after hours for next CP/M is a trademark of Digital Research; Unica is a trademark of Knowlogy; Unix is a trademark of Bell Telephone Labs; XM-80 is a trademark of Scientific Enterprises; Z80 is a trademark of Zilog Inc. **DISK DRIVE WOES?** PRINTER INTERACTION? **MEMORY LOSS? ERRATIC OPERATION?** # Don't **Blame The** Software! Power Line Spikes, Surges & Hash could be the culprit! Floppies, printers, memory & processor often interact! Our unique ISOLATORS eliminate equipment interaction AND curb damaging Power Line Spikes, Surges and Hash. - socket ISOLATOR (ISO-2) 2 fliter Isolated 3-prong socket banks; (6 sockets total); integral Spike/Surge Suppression; 1875 W Max load, 1 KW either bank \$6: - SUPER ISOLATOR (ISO-3), similar to ISO-1 except double - \$106.95 - SUPER ISOLATOR (ISO-3), SIMILAT TO ISO-1 except goudle filtering & Suppression ISOLATOR (ISO-4), Similar to ISO-1 except unit has 6 individually filtered sockets ISOLATOR (ISO-5), Similar to ISO-2 except unit has 3 socket banks, 9 sockets total CIRCUIT BREAKER, any model (add-CB) CKT BRKR/SWITCH/PILOT (CBS) Add \$ \$87.95 Add \$ 8.00 Add \$16.00 Master-Charge, Visa, American Express Order Toll Free 1-800-225-4876 (except AK, HI, MA, PR & Canada) # ESP Electronic Specialists, Inc. 171 South Main Street. Natick, Mass. 01760 Technical 8. Nion-800 1.617 656 1632 ## PROBLEM: How to mate your CP/M<sub>●</sub> or ISIS<sub>●</sub> system to the (without losing all your present capabilities) ### **SOLUTION:** is the software connection which permits Z-8000 applications to run under your current operating system, resulting in portable 16-bit software which runs under CP/M or ISIS! And ZEX is user-configured for any Z-8000 alternate bus master, so that it can support your prototype hardware, as well as commercially available Z-8000 boards. is a complete Z-8000 Development Package, which includes a powerful relocatable cross assembler (ZAS), a flexible object task builder (ZLK), and an absolute object loader (ZLD), as well as the ZEX run time module. The package was developed specifically for the Z-8000, and supports the complete Zilog instruction syntax for both the Z8001 and Z8002, including support for mixed segmented and nonsegmented code. **WARES** **ZAS Package** CP/M® .. \$395 ISIS-II. .. \$495 Manual Only.....\$25 Supplied on Single Density 8" Disk CP/M· Digital Research, Inc. ISIS-II· Intel Corp. Box C Norwood, CO 81423 (303)327-4898 inside the 68000 user data segment and the other inside its supervisor data segment. The 68000 is operated cycle by cycle by the program in Listing 1, p. 36. As the program currently running evolves, whatever happens is shown on the display/printer or whatever is connected to the AIM 65. Various instruction combinations can be tried, and the operation of the 68000 becomes clear. The five objectives that we have so far discussed are implemented in a program 519 bytes long. The user has to select the operating mode by storing an appropriate value in a control byte, CONTRL. Each bit controls a mode as explained below. If bit 0 is set, after printing the 68000 address the AIM 65 program requests a byte from the keyboard. It will be stored in the latch connected to the 68000 input control signals. If bit 1 is set, manual mode is selected, otherwise automatic mode is assumed. Manual mode corresponds to the dummy memory R/W mode previously discussed; in the auto mode, R/W is performed from memory. If bit 2 is set, before issuing the DTACK signal the user is requested to validate all operations performed during the current cycle by entering a carriage return. This is also called step mode. Any other character will repeat the current cycle. No such validation check is made if bit 2 is cleared. If bit 4 is set, fast mode is selected. When this mode is selected 68000 cycle status output is suppressed. This allows for fast 68000 program running, as a great deal of the AIM housekeeping time is spent reporting things on display/printer. The previous modes can be mixed together. Fast mode overrides all the others. When it is set, the other modes are used to select the mode that will be entered upon error. Dynamic mode changing can be accomplished by executing a 68000 instruction that stores a new value in the control variable. Thus, a 68000 program can put itself in Step mode. Memory segmented is implemented using two tables, FCTAB and MAXADD. They specify the AIM 65 base addresses of each 68000 segment and their extension. These latter values must be supplied, and they must be consistent with the former ones. Of course, each 68000 segment starts from location \$0000000. #### **Final Thoughts** We have so far discussed how to build from scratch a small development system for Motorola's 16-bit processor, the MC68000. The underlying concepts are quite general, and it should not be difficult to implement our idea using the reader's own computer instead of our AIM 65. The ones familiar with this machine will have already noted that the accompanying program was not listed with the 20-column thermal printer available on the AIM board, and that the assembler was modi- In fact, besides using the AIM 65 as an experimental computer, we use it as our "big" system. Anyone who is interested and wants more information about how we did it may write to the authors. Let us now report the impressions about the MC68000 that we gained using the board we have here presented. We appreciated most the power and simplicity of its instruction set. Some things shocked us, though. For example, you can try to execute a CLR to memory and see what happens. Before clearing the desired locations, the processor reads them. This, of course, wastes time and has no usefulness. Anyway, summing up all the againsts and fors, it proved to be a superior processor. After executing just a few programs, the user accustomed to 8-bit microprocessors will no longer be satisfied with them. The MC68000 architecture is a bit different from standard 8-bit machines. The reader who will use our board might then have some problems. Let us give some hints that may prove useful. The 68000 has a pipelined structure. This means that it fetches one or more words before actually executing the instruction. These words, which may be subsequent instructions, are printed and displayed. Such a thing may lead one to think that the processor is not executing properly; on the contrary, it is doing its job. Again, during stacking operations, words may not be stacked following the address ordering; the overall stacking procedure is still correct. The MC68000 is a 16-bit machine, therefore it addresses by words. Instructions must start on even boundaries. If the user specifies the initial PC to be at an odd address, the 68000 will enter an address error exception. If the supervisor stack point also starts at an odd address, well, you will be in trouble. There are, of course, many other things that should be said, but it may be more interesting to explore the 68000 world yourself. Concluding, we would like to point out that everything we have said so far is not restricted to a particular machine. Some readers will like to experiment with a different CPU, say the Z8000, and we think they will not have too many problems adapting our ideas to their needs. After a few weeks of experimenting with our board, the need for more sophisticated software may arise. It should not be too difficult to write a cross assembler using AIM BASIC. This would eliminate the need for hand compiling all the 68000 instructions. Again, it is possible to slightly modify the hardware to let the 68000 have an independent life, without passing through the AIM for executing its instructions. Italy is not that far away; anyone who wants to write us to exchange opinions about computers is encouraged to do so. (Figures 2-6 on pages 16 and 17) (Listing begins on page 36) | 68000 On-Board Selections | | | | | | |---------------------------|--------------------------------|--|--|--|--| | Address (Hex) | Selection | | | | | | 8XX0 | 68000 lower 8 data bit (WRITE) | | | | | | 8XX1 | 68000 upper 8 data bit (WRITE) | | | | | | 8XX2 | 68000 output control signals | | | | | | | (refer to Figure 4) | | | | | | 8XX3 | 68000 input control signals | | | | | | | (refer to Figure 5) | | | | | | 8XX4 | 68000 lower 8 address bit | | | | | | 8XX5 | 68000 middle 8 address bit | | | | | | 8XX6 | 68000 upper 7 address bit | | | | | | 8XX7 | 68000 lower 8 data bit (READ) | | | | | | 8XX8 | 68000 upper 8 data bit (READ) | | | | | | 8XX9 | HALT | | | | | | 8XXA | N.C. (not connected) | | | | | | 8XXB | DTACK | | | | | | | Figure 3 | | | | | | 68000 Output Control Signals<br>(IC22) | | | | | | | | |----------------------------------------|--------------------------|-------------------|--|--|--|--|--| | Bit No. on AIM Data Bus | Signal | | | | | | | | AD0 | WRITE | write | | | | | | | AD1 | LDS | lower data strobe | | | | | | | AD2 | <del>UDS</del> | upper data strobe | | | | | | | AD3 | $\overline{AS}$ | address select | | | | | | | AD4 | $\overline{\mathbf{BG}}$ | bus grant | | | | | | | AD5 | FC2 | function code 2 | | | | | | | AD6 | FC1 | function code 1 | | | | | | | AD7 | FC0 | function code 0 | | | | | | | Fig | gure 4 | | | | | | | # Elegance Power Speed BDS © Users' Group Supporting All C Users Box 287 Yates Center, KS 66783 #### **68000 Input Control Signals** (IC19) Signal Bit No. on AIM Data Bus **BGACK** AD0 bus grant ack BERR bus error AD1 N.C. (not connected) AD2 $\overline{VPA}$ valid peripheral AD3 address $\overline{BR}$ bus request AD4 AD5 IPL0 interrupt priority level 0 interrupt priority AD6 IPL1 level 1 AD7 IPL2 interrupt priority level 2 Figure 5 (Listing begins on page 36) #### 0000 0000 0000 0800 0800 0500 JUSER MAY SPECIFY THESE VAR. ADDR.; IF SEGMENT ADDR.; ARE CHANGED, THESE ADDR. MUST BE ACCORDINGLY DEFINED. 68000/AIM 65 0030 0031 0032 0033 0034 REFER TO THE CALSUB ROUTINE SAVEAU (Listing, text begins on page 12) \*=\$500 REFER TO THE CALSUB ROUTINE SAUFAS (See Figure 6, page 17 for meaning of fields in Listing) FPOINTER TO START ADDR. OF 4502 SUBR. ADDR. TABLE 0037 CONTROL MODE TO AUTO AND 0500 0500 ODEA THE FOLLOWINGS ARE USED AS POINTER FOR FINDIRECT 6502 ADDRESSING #+\*++1 ı 00FA 0041 OOFA OOFA OOFB OOFB OOFB 0042 J 0043 0044 0045 0046 0047 FOR 68000 TO MEMORY OPERATIONS - PC FETCH SWITCH TO USER PROGRAM -MOVE.W #0.SR 1 ;LOW BYTE OF POINTER F1 -NOP FETCHED BUT NOT EXECUTED (FBNE) THE FOLL. ARE USED TO SAVE THE 68000 ADDR. -HOVE.W #\$100,\*FCOO.L LINK AIM SUBROUTINE READBYTE 0049 0050 OOFC OOFC SAVEL 0051 OOFD EXEC READBYTE THE BYTE SHOWN IN THE DATA FIELD WAS ENTERED WITH THE AIM KEYBOARD) -MOVE.8 0000.L 0001.L 0053 DOFE $0054 \\ 0055$ SAVEH Pase 02 READ LOC. 0000 WRITE LOC. GOO1 (MODE CONTROL LOC.) NOW THE MODE IS CHANGED: IT IS REQUESTED A BYTE TO BE STORED ON THE 46000 CONTROL IMPUT LINES (LEV. 4 INT.) STACK PC LOW (CNTRL BYTE-SFF, INT. CLEARED) AS FUNCTION CODE 1A, WE ARE STACK STATUS IN MANUAL MODE: VECT. ##-24 STACK STATUS THAN THE PROGRAM TO CHANGE MODE: NOW WITHOUT THE CONTROL BYTE HODE CONTROL VARIABLE. THE ADDR. OF THIS VAR. HUST BE INSIDE USER DATA SEGMENT, SO A 68000 SPROGRAM CAN CHANGE IT OOF F 0058 0059 0060 -THE FOLL. ARE THE BOARD ADDR.; REFER TO THE TEXT THARDWARE DESCRIPTION FOR THE THEIR MEANING 0065 0066 0067 0068 0069 0070 0071 STACK PC HIGH PETCH INT. VECT. (WE ARE IN MAN. MODE AS WE ARE OUT OF SUP. DATA SEGMENT MANUAL MODE AS WE ARE OUT THE SUP. PROG. SEGFINE, MANUAL MODE UNISTACK PARAMETERS \*=BRDADD DII. 800 DIH 8001 8002 8003 8003 8004 8004 8005 CIN 0073 0074 0075 0076 0077 0078 0079 0080 0081 0082 0083 0084 0085 0086 0087 J COUT BACK TO USER PROGRAM ×...×.1 ADDL \*= \*+1 ADDM \*=\*+1 ADDH -CONTROL MODE TO MANUAL AND M)=801 04 00 00 00 (7) 0801 16 (7) 0801 16 M)>200 (6) 7 SP RW 000000 M 0000 SP RW 000000 M 0000 SP RW 000000 M 0000 SP RW 000000 M 0000 SP RW 000000 M 0000 SP RW 000000 M 0000 SP RW 000000 M 1000 SP RW 000000 M 1000 SP RW 000000 M 14000 00000 M 1470 SP RW 00000 M 14000 1473 SP RW 000000 00000 M 1473 SP RW 000000 8006 DOL. 8007 8007 7 8007 8008 8009 8009 800A 800A 800A DOH SSP FETCH HAL.T PC FETCH \*=\*+1 7 RES SWITCH TO USER PROGRAM I \*=\*+1 -NOP FETCHED BUT NOT EXECUTED (FBNE) -CLR.L. \$7000.W CLEAR LOC. \$7000-\$7003 DTACK READS THE LONG WORD (UNUSEFUL) \*=\$200 SEI LDA H\$FF STA COUT JSR CRLOW LDA CIN AND HB BNE WAITAS LDA CONTRL AND HB BEQ OUTFC JMP FAST 0095 78 A9FF 8D0380 2013EA AD0280 2908 D0F9 AD0108 2908 F003 4C2E03 0096 0097 0098 0099 0100 0101 0200 0201 0203 0206 0209 0200 0200 0210 0213 0215 CLEAR LONG WORD CLEAR 68000 INPUT SIGN. -NOP -NOVE.₩ #\$2000,D0 SET DATA REG. 0 J WAITAS 16-BIT MULTIPLICATION -- MIII II . W #4-D0 J ; WAIT FOR ADDR. STROBE SHOW DO CONTENTS 0103 0104 :SPEEDY MODE CONTROL BIT = THE RESULT OF MULU.W 15 \$8000 -NOP -DIVU.W DO∵HO - ZERO DIVIDE: WHAT HAPPENS NOW? FOUTPUT 68000 FUNCTION CODE FUT(UNDEFINED), UZ(UNDEFINED), UZ(UNDEFINED), UZ(UNDEFINED), UZ(UNDEFINED), UZ(UNDEFINED), POSCAMA), FUD(USER DATA), SD(SUPERVISOR DATA), FUZ(UNDEFINED), IA(INTERRUPT ACK.) OUTFC LDA CIN 0109 0110 0111 0112 0113 021A 021A 021A 021A 021A FBNE -STACK PC: ZERO DIVIDE EXCEPTION J ⇒STACK STATUS TREADS ZERO DIVIDE VECTOR AD0280 021A ゴ RETURN FROM EXCEPTION FROM Pase 03 ERNE UNSTACK PARAMETERS AND #X11100000 LSR A LSR A LSR A LSR A TAX LDA TABEC,X 29E0 4A 4A 4A 4A AA BDE803 207AB9 0115 0116 0117 0118 0119 0120 0121 0122 0123 0124 J 021F 0220 0221 0222 0223 0224 0227 BACK TO USER PROGRAM D.L SHOW DO CONTENTS AFTER THE ZERO DIVIDE -MOUL. W DO.\$6000.L JSR OUTPUT LDA TABFC+1,X JSR OUTPUT JSR BLANK BDE 903 PAGE 01 PASS 2 0000 0001 0002 FOUTPUT 4800D R/W CODE :WW(WRITE WORD).RW(READ WORD).WW(WRITE HIGH :BYTE).WL(WRITE LOW BYTE).RL(READ LOW BYTE), :RH(READ HIGH RYTE).UN(UNDEFINED) OUTRWL LOA CIN AND #7 ASI. A TAX LDA TABRWL.X JSR OUTPUT LOA TABRWL-1.X JSR OUTPUT JSR BLANK 0000 0000 0000 0000 0233 0233 0233 0128 0129 0130 0131 0132 0133 0134 0135 0136 0137 0138 0139 0140 0003 \*\* WRITTEN BY LUCA FUSINA AND CLAUDIO GRANUZZO 0233 AD0280 AD0280 2907 0A AA BDD803 207AE9 BD0903 207AE9 203EE8 0236 0236 0239 0239 0230 0240 0243 0246 :IF HORE 4502 USER SUBROUTINES ARE ADDED, THEIR EXACT :NUMBER HUST BE SPECIFIED $\mbox{\sc Maxrou=2}$ $0012 \\ 0013 \\ 0014$ 0000 0000 JOUTPUT 68000 ADDRESSES JME MULTIPLY BY TWO TO CONVERT FROM JOERN TO BYTE ADDR. OUTADD LDA ADDR. ASIA STA SAVEL LDA ADDM ROL A STA SAVEM LDA ADDM ROL A RODA ROL A RODA ROL A RODA ROL A 0143 0144 0145 0249 0249 0249 0249 0240 0246 0252 0253 0253 ;80ARD BASE ADDRESS BRDADD=\$8000 0016 0017 JATM 65 MONITOR SUBROUTINES EQUATES CRION-\$F613 BLANK-\$F693E NUMA-\$F644 OUTPUT A BLANK NUMA-\$F644 TOUTPUT A BYTE AS TWO HEX CHAR. OUTPUT=\$F574 RBYTE=\$F3FD READ=\$F050 JREAD TWO HEX CHAR. FROM KEYBOARD AND PACK THEM IN ONE BYTE FFAD=\$E93C JREAD ONE CHAR. 0000 0000 0000 0000 0000 0000 0146 0147 0148 0149 0150 0151 0152 AD0480 0A 85FD AD0580 2A 85FE AD0680 2A 0019 0020 0021 0022 0023 0024 0025 0026 ``` FISSUE DTACK DTA LDA DTACK JMP LOOP 85FF 2046EA A5FE 2046EA A5FD 2046EA 203EE8 STA SAVEH JSR NUMA LDA SAVEM JSR NUMA 0279 0280 0281 0328 0454 0259 0358 400880 400602 025B 025E 0260 0263 0263 0265 0155 0156 0157 0158 SAVEL FAST AUTO MODE: NO OUTPUT IS PERFORMED 0284 032E FAST LDA ADDL ASL A 0284 0287 0288 AD0480 MULTIPLY BY TWO LDA CONTRL AND #1 0163 0248 AD0108 INCMD WITH THIS BIT SET A BYTE IS ENTERED FROM KEYBOARD TO CONTROL THE 68000 INPUT SGN. 0163 0164 0165 0166 0167 0168 0169 026E 2901 0270 0270 Pase 06 BEG NOCMD JSR RBYTE STA COUT LDA CONTRL AND #2 BEG AUTO F006 20FDE3 8D0380 AD0108 2902 F02D STA FO LDA ADDM ROL A STA SAVEM LDA ADDH ROL A BEQ FAST1 JMP OUTFC 0270 0272 0275 0332 0334 0337 0338 033A 0330 033E 0340 85FB AD0580 2A 85FE AD0680 2A F003 0289 CMD 0290 0291 0292 0170 0171 0172 0278 :MANUAL OR AUTO MODE CNTR. BIT 0293 0294 0295 0296 ;SKIP IF SEG. IS LESS THAN 64K ;ERR.: OUTPUT CYCLE STAT. 401A02 OUTF1 ;MEMORY SEGMENTATION SECTION; ON ERROR ;STANDARD CYCLE HANDLING IS ENTERED. AND ;FAST MODE IS RE-ENTERED NEXT CYCLE FAST1 LDA CIN AND W$ED ;68000 FUNCTION CO LSR A LSR A LSR A LSR A LSR A LSR A TAX 0298 0299 0300 0343 0343 0343 0343 #HANUAL MODE: READ FROM KEYBOARD, #HEMORY WRITE TO DISPLAY/PRINTER ONLY HANUAL LDA 1840 JSR OUTPUT FOUTPUT 'N' JSR BLANK LDA CIN TEST 40000 B4 0175 0176 0177 0178 0179 027F 027F AD0280 0301 027F 0281 0284 0287 A94D 207AE9 203EEB AD0280 ;68000 FUNCTION CODE 29E0 4A 4A 0302 0303 0304 0305 0306 0307 0308 0309 0310 0346 0348 0349 034A 034B 034C 034D 034E 0350 4A 4A 4A AA E007 F0EE A5FE C9FC F04A A5FE DD0004 B0E1 18 7DF803 85FC ;TEST 68000 R/W 0181 0182 2901 000F AND #1 BNE READM LISR A TAX CPX W7 BEQ OUTF1 LDA SAVEH CHP H$FC LDA SAVEH LDA SAVEH LDA SAVEH LDA SAVEH CHP HAXADD,X BCS OUTF1 CLC ADC FCTAB,X STA F1 LDA CIN AND M1 BNE READF FIF WRITE OUTPUT 68000 DATA BUS WRITEN LDA DIH JSR NUMA JDA DIL JSR NUMA JMP TSER 0184 0185 0186 0187 AD0180 2046EA AD0080 2046EA SKIP IF INTA 029E 0291 0294 0297 0352 0354 0356 0311 ;6502 SUBROUTINES CALL 0312 0313 0188 0189 029A 401703 0314 0315 0316 0317 0318 0319 0358 035A 035D 035F 0360 0363 ;IF READ, GET TWO BYTES FROM KEYBOARD AND PUT THEM ;ON THE 68000 INPUT DATA LATCHES READM JSR RBYTE STA DOH JSR RBYTE 0191 0290 FOUT OF SEG. RANGE ERR. 0192 0193 0194 0195 0196 0197 029D 029D 02A0 02A3 02A6 02A6 20FDE3 8D0880 20FDE3 8D0780 4C1703 ;ADD SEG. OFFSET AD0280 2901 D022 0355 0351 0350 ;TEST 68000 R/W 0324 0325 0326 0327 0328 MEMORY WRITE JAUTO MODE: R/W FROM MEMORY AUTO LDA CIN 0200 0201 02AC AD0280 AD0280 036F 0371 0373 AND #2 BNE NOUDSF LDY #0 2902 0007 4000 :68000 UDS #MEMORY SEGMENTATION SECTION; IF OVERFLOW #FROR OR INTA STATE SWITCH TO MANUAL MODE #FCADD AND #X11100000 LSR A LSR A LSR A LSR A LSR A LSR A TAX 0203 0204 0205 0206 0207 WRFUDS LDA DIH STA (FO),Y LDA CIN 0329 AD0180 29E0 0378 037A 037D 037F 0381 0383 0386 0388 91F8 AD0280 NOUDSE 4A 4A 4A 4A AA EDOZ FOC4 ASEF DOCO 0331 AD0280 2904 D007 A001 AD0080 91FB AD0880 0282 AND #4 BNE NOLDSF LDY #1 LDA DIL STA (FO),Y LDA DTACK JMP WAITAS 0332 0333 0334 ;68000 LDS 0208 0209 02B3 02B4 LSR A LSR A TAX CPX #7 BEQ MANUAL LDA SAVEH BNE MANUAL LDA SAVEM CMP #$FC 0219 0210 0211 0212 0213 0214 0215 0216 0217 0284 0285 0284 0287 0289 0288 0280 NOLDSF :48000 HAS ACK. AN INTERRUPT 400902 #FAST MEMORY READ READF LDY #0 SEGMENT GREATER THAN 64K. 0340 0341 0342 0343 0344 0345 0386 A000 B1FB 8D0880 A001 B1FB 8D0780 02BF 02C1 ASFE C9EC LDY #0 LDA (FD),Y STA DOH LDY #1 LDA (FD),Y STA DOL 038E 0390 0392 0395 0397 0399 ;6502 SUBROUTINE CALL IF 68000 ADDR. IS EQUAL TO $00FC00 0218 0219 0203 0203 0205 0208 4CA203 000004 8082 0208 0200 0200 020E 0201 0201 FERR. IF SEGMENT IS OUT OF ITS RANGE 0222 0223 0224 0225 0226 0227 0228 0229 0230 Pase 07 18 7DF803 CLC ADC FCTAB,X FADD SEG. OFFSET 10 EFFECTIVE 68000 ADDR., SO TO SELECT THE RIGHT MEMORY LOCATIONS IN THE AIM MEMORY SPACE 0347 039C 0348 039F AD0880 400902 LDA DTACK 0201 0201 0201 0203 STA F1 LDA SAVEL 03A2 03A2 03A2 03A2 03A2 03A2 03A2 0352 0353 0354 0355 0356 0357 0358 0359 0360 0361 0362 0205 0207 020A 020C STA FO LDA CIN AND #1 BNE READA 0234 85FB 0232 0233 0234 AD0280 2901 D025 ;TEST 68000 R/W AD0280 2901 F003 4C7F02 AD0180 C902 B0F6 OA AA BDD403 03A2 03A2 03A5 03A7 JAUTO WRITE IN MEMORY WRITA LDA CIN AND #2 BNE NOUDS 0236 OSDE AD0280 2902 D00A TEST 68000 UPPER DATA STROBE 0363 0364 0365 0366 0367 0368 0369 0370 03A9 03AC 03AF 03B1 03B3 03B4 03B5 0241 0242 0243 0244 0245 0246 0247 0248 02E5 02E5 02E7 02EA UPPER DATA BYTE WRITE WRIUDS UPPER DATA LDY HOD LDA DIH STA (FO),Y JSR NUMA LDA CIN AND #4 BNE NOLDS A000 AD0180 91FB LDA TABSUB,X STA LOCJMP LDA TABSUB,X STA LOCJMP LDA TABSUB+1,X STA LOCJMP+1 LDA DIL JSR JMPSUB STA SAVEAU STA SAVEAS LDA DTACK 85FA BDD503 TEST 68000 LOWER DATA STROBE 03BA 85FB AD0080 200103 8D0008 8D0005 AD0880 4C0602 02F2 2904 D00A 0371 0372 0373 0374 0375 0376 0377 038A 038F 03C2 03C5 03C8 03CB FWRITE 68000 LOWER DATA BYTE WRILDS LDY #1 0250 0251 0252 02F6 02F6 02F8 02F8 LDY #1 LDA DIL STA (FO),Y JSR NUMA JMP TSER A001 AD0080 91FB 2046EA 401703 0253 JMP LOOP 02FD 0300 0255 NOL.DS JMPSUB JMP (LOCJMP) 0380 0301 60FA00 WORD FROM MEMORY LDY #0 LDA (FO),Y STA DOH JSR NUMA 0303 A000 B1FB B00880 2046EA A001 B1FB B00780 0258 0259 0260 0261 0262 0263 0264 0303 0305 0307 030A 030B 030F 0311 ;4502 SUBR. TABLE TABSUB .WORD NUMA .WORD RBYTE 0304 0304 0306 0384 0385 0386 JSR NUMA LDY #1 LDA (FD),Y STA DOL. JSR NUMA ;68000 R/W CODES TABRWL _BYTE 'WWRWWLRLWHRHUNUN' 5757 2046EA ;68000 FUNCTION CODES TABEC .BYTE 'U1U2UPSPUDSDU3IA' 0391 0392 03E8 0268 0269 0270 0271 0272 0273 5534 0317 0317 0317 0317 0316 0316 0321 0323 0325 ;SEGHENT START ADDR., EXPRESSED IN PAGES OF 256 ;BYTES EACH. USER MAY CHANGE THESE VALUES; IF ;HE DOES SO HE HAS TO CHANGE ALL THE RELATED ;VARTABLE, ADDRESSES (SEE TOP OF PROGRAM). ;HE MAY HAVE TO CHANGE VALUES IN THE MAXADD 0394 0395 0396 0397 0398 03F8 03F8 03F8 03F8 AD0108 2904 F00A 203CE9 C90D F003 400602 0274 0275 0276 0277 (Continued on next page) ``` ## 68000/AIM 65 ### (Listing continued, text begins on page 12) ``` 0200 озна TABLE TOO กก 0400 USEB BYTE O HINDERTNED 0404 0359 nn BYTE O HINDEFTHED 0402 DOEA oc. .BYTE $00 HISER PROGRAM 0403 U.SE.B BYTE 6 SUPERUTSOR PROGRAM 0404 USEC no BYTE B *HEED DATA Page 09 0405 osen os. BYTE 5 SUPERUISOR DATA 0404 DSEE nn BYTE O SUNDERTHED 0407 OBEE nn -BYTE O : (TNTA) 0410 0400 NUMBER OF PAGES AVAILABLE TO EACH SEGMENT 0411 0400 JUSER MAY CHANGE THESE VALUES: HOWEVER THEY 0442 0400 *MUST BE CONSISTENT WITH THE SEGMENTS START 0413 0400 ADDRESSES JUST DEFINED 0400 00 0444 MAXADD BYTE O : HNDEFINED 0415 0401 00 BYTE 0 : HNDEFINED 0416 0402 04 BYTE 4 HISER PROGRAM (1K) 0442 0403 0.5 .BYTE 2 ISUP, PROGRAM (512 BYTES) 0418 0404 Π4 BYTE 4 SUSER DATA (4K) 0449 0405 0.4 .BYTE 1 (SUP. DATA (256 BYTES) 0420 0406 nn .BYTE O HINDEFINED 0421 0407 on -BYTE O : (TNTA) 0424 0408 FEND OF PROGRAM 0424 0408 .END ERRORS = DOOD ``` | MAXROU | A٠ | 0005 | BRDADD | A: | 8000 | CRLOW | A÷ | EA13 | BLANK | Α: | E83E | |--------|-----------|------|---------|----|------|---------------------------------------|----|------|--------|----|------| | NUMA | A: | EA46 | OUTPUT | A۶ | E9ZA | RBYTE | A: | E3F0 | READ | A: | E93C | | SAVEAU | A۱ | 0800 | SAVEAS | A: | 0500 | LOCUMP | Α: | 00FA | F0 | A÷ | OOFB | | F1 | A٠ | OOFC | SAVEL. | A: | OOFD | SAVEM | A: | 00FE | SAVEH | Α: | OOFF | | CONTRL | A۶ | 0801 | DII. | A١ | 8000 | DIH | A٤ | 8001 | CIN | A١ | 8002 | | COUL | A : | 8003 | ADDL. | A: | 8004 | ADDR | Α: | 8005 | ADDH | A: | 8006 | | DGL. | A: | 8007 | DOH | A: | 8008 | HALT | A٠ | 8009 | RES | Α: | 800A | | DTACK | A: | 8008 | 86MMM | A÷ | 0200 | LQ0P | Α: | 0206 | WAITAS | Α: | 0209 | | OUTFC | A: | 021Á | OUTRWL | A: | 0533 | OUTADD | A: | 0249 | INCMD | Α: | 026B | | CMD | A: : | 0272 | NOCMO | A: | 0278 | MANUAL. | Α: | 027F | WRITEM | Α: | 028E | | READM | A: | 029D | AUTO | A: | 02AC | FCADD | A: | 02AF | LABO | A: | 0508 | | WRITA | A: | 02DE | WRITUDS | A: | 02E5 | NOUDS | A: | 02EF | WRILDS | Α: | 02F6 | | NOLDS | A: | 0300 | READA | A٠ | 0303 | TSER | A: | 0317 | DTA | A: | 0328 | | FAST | A: 1 | 032E | OUTF-I | A: | 0340 | FAST1 | A: | 0343 | WRITE | Α: | 0360 | | WREUDS | <b>):</b> | 0323 | NOUDSE | A: | 037A | WRFLDS | A: | 0381 | NOLDSF | A: | 0388 | | READE | 2 | 038E | CALSUB | A٠ | 03A2 | ERR | Α: | 03A9 | CALSU1 | A: | 03AC | | JMP SH | | 03D1 | TABSUB | A: | 0304 | TABRWI | A: | 0308 | TABEC | Α: | 03E8 | | ECTAB | | 03F8 | MAXADD | A: | 0400 | · · · · · · · · · · · · · · · · · · · | | | | | | | | | | | | | | | | | | | #### **End Listing**