# 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: every-body 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, multi-processor 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. - The instruction set is microprogrammed; it may be improved without changing the overall structure. - 3) Its pipelined structure is optimized for speed. - 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. - Its most interesting supporting chips are not scheduled to be available in the near future. - 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 AlM 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 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 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 \$8XXY selection is used to interface correctly the 68000 HALT and RESET signals, which are bi-directional. 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 processor. 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 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 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 automode, 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 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 50000000. ### **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 modified. 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. Any- way, 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 prob-lems 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. $DD_J$ (Figures 2-6 on pages 16 and 17) (Listing begins on page 36) 15 | 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 Outpu<br>(I | t Control<br>C22) | Signals | |-------------------------|-------------------|-------------------| | Bit No. on AIM Data Bus | Signal | | | AD0 | WRITE | write | | AD1 | LDS | lower data strobe | | AD2 | <b>UDS</b> | upper data strob | | AD3 | AS | address select | | AD4 | $\overline{BG}$ | bus grant | | AD5 | FC2 | function code 2 | | AD6 | FC1 | function code 1 | | AD7 | FC0 | function code 0 | | 68000 Input Control Signals<br>(IC19) | | | | | | | |---------------------------------------|--------------|-------------------------------|--|--|--|--| | Bit No. on AIM Data Bus | Signal | | | | | | | AD0 | <b>BGACK</b> | bus grant ack | | | | | | AD1 | BERR | bus error | | | | | | AD2 | N.C. (not | I.C. (not connected) | | | | | | AD3 | VPA | valid peripheral address | | | | | | AD4 | BR | bus request | | | | | | AD5 | IPL0 | interrupt priority<br>level 0 | | | | | | AD6 | IPL1 | interrupt priority<br>level 1 | | | | | | AD7 | IPL2 | interrupt priority<br>level 2 | | | | | | 1 | Figure 5 | | | | | | (Listing begins on page 36) | 68000/AIM 65 | 0029<br>0030<br>0031 | 0000<br>0000<br>0000 | | JUSER MAY SPECIFY THESE VAR. ADDR. J IF SEGMENT ADDR. SARE CHANGED. THESE ADDR. MUST BE ACCORDINGLY DEFINED \$1800 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (Listing, text begins on page 12) | 0032<br>0033<br>0034 | 0800<br>0800<br>0500 | | SAVEAU ***\$500 SAVEAS REFER TO THE CALSUB ROUTINE | | (See Figure 6, page 17 for meaning of fields in Listing) | | | | | | CONTROL MODE TO AUTO AND STEP | 0037<br>0038<br>0039 | 0500<br>0500<br>00FA | | POINTER TO START ADDR. OF 6502 SUBR. ADDR. TABLE *- \$FA LOCUMP | | *>-200<br>(6)2/<br>SP RW 000000 0000 | 0041 | nns a | | THE LOUI ONINGS ARE HEED AS BOTHTER FOR | | SP RW 100000 0000 SSP FETCH SP RW 100000 0000 PC FETCH PC FETCH | 0042<br>0043<br>0044 | OOF A<br>OOF A<br>OOF 8 | | SINDIRECT 65D2 ADDRESSING *- **1 SHIGH BYTE OF A POINTER USED | | SP RW 000008 46FC THOUSE, W NO.SR SWITCH TO USER PROGRAM | 0045 | OUFR | | FOR 68000 TO MEMORY OPERATION | | W BW DODCOC 39FC W RW DODCOC 39FC W RW DODCOC 0100 W RW DOCCOC 0100 W RW DOCCOC 0100 W RW DOCCOC 0100 W RW DOCCOC 0100 | 0047 | DOFC | | F1 JLOW BYTE OF POINTER | | P NU 000015 0000 P NU 000015 179 P NU 000011 179 P NU 000011 179 P NU 000011 179 P NU 000011 179 P NU 000011 0000 P NU 000010 00000 P NU 000010 0000 P NU 000010 0000 P NU 000010 0000 P NU 000010 0000 P NU 000010 0000 P NU 000010 0000 P NU 000010 00000 00000000000000000000000000000 | 0050 | OOF D<br>OOF D | | STHE FOLL. ARE USED TO SAVE THE 68000 ADDR. | | P NU 00011 0000 F NU 00011 107 F NU 00011 107 F NU 00011 107 F NU 00011 0000 00000 000000 F NU 00011 000000 F NU 00011 000000000000000000000000000000 | 0051<br>0052<br>0053<br>0054 | DOFE | | SAVEH | | | 0055<br>Page 02 | DOFF | | SAVEH | | 00 MH 000000 0504 READ LOC. 0000 PR MU 000010 0001 MRITE LOC. 0001 (MODE CONTROL LOC.) | | | | | | P RW 000076 754671 NOP NOW THE MODE IS CHANGED! IT IS REQUESTED A BYTE TO BE HOP STORED ON THE 68000 CONTROL INPUT LINES (LEV. 4 INI.) BU W 0000FC FF001E STACK PC LOW (CNTRL BYTE-8FF, INT. CLEARED) | 0058<br>0059<br>0060 | OOF F<br>OOF F | | MODE CONTROL VARIABLE. THE ADDR. OF THIS VAR. MUST BE INSIDE USER DATA SEGMENT, SO A 69000 PROGRAM CAN CHANGE IT | | AR W FBFFFC FFH 0064 IA AS FUNCTION CODE=IA, WE ARE 10 WH 0000F8 FF0000 STACK STATUS IN MANUAL MODE; VECT, W=64 TO WH 0000F8 FF0000 FF0000 TO STACK STATUS | 0060 | OOFF<br>OBO1 | | IPROGRAM CAN CHANGE IT \$801 CONTRI | | P BU GODDLE CR01 - MAIL TO F.C. FOOT (MODE CORTEO). LOC.) P BU GODDLE 774571 - MOP NOW THE RODE IS CAMPAGED IT IS REQUESTED AS BYET TO BE P BU GODDLE 774571 - MOP STORED ON THE ABOUT CONTROL JUPUT LINES (LEV. 4 THI.) BU BUTTER FIFT GODGLE - MORE FIRST G | | | | | | 3 - 200<br>5 W 0000FA 0000 STACK PC HIGH | 0065<br>0066<br>0067 | 0801<br>0801<br>0801 | | THE FOLL. ARE THE BOARD ADDR.; REFER TO THE TEXT HARDWARE DESCRIPTION FOR THE THEIR MEANING | | O W 000004 0000 | 8800 | 8000<br>8000<br>8001 | | DII1 | | P KN 004002 H 4E71 — NOP FEME, MANUAL HODE NS WE | 0070<br>0071<br>0072 | 8002 | | 4-#+1<br>CIN | | D RM 0000FA 0000 | 0073 | 8002<br>8003<br>8003 | | COUT | | D NN CORDOR CSCA | 0074<br>0075<br>0076<br>0077 | 8003<br>8004<br>8004 | | ADDL1 | | P RM 000026 4E71 ——NOP | 0079 | 8005<br>8005<br>8006 | | ADDH *=*+1 | | 2-801 04 00 00 00 CONTROL HODE TO MANUAL AND SIEP | 0079<br>0080<br>0081<br>0082 | 8006<br>8007 | | ADDH *-*+1 | | )>>200 RUN<br>6)7 SSP FETCH | 0003 | 9007 | | ****1<br>DOH | | # \$4 000000 H 0000 | 0085<br>0085<br>0086<br>0087 | 8008<br>8008<br>8009 | | HALT | | #P RM 004000 M 4000 → MOVE.N NO.SR SWITCH TO USER PROGRAM #P RM 004002 M 0000 → | 0089 | 800A<br>800A<br>800B | | RES *-**1 | | IF NE 000006 N 4000 FETCHED BUT NOT EXCEPT (FINE) FETCHED BUT NOT EXCEPT (FINE) FETCHED BUT NOT EXCEUTED | 0090 | 8008 | | DTACK | | NO-NO-NO-NO-NO-NO-NO-NO-NO-NO-NO-NO-NO-N | | | | | | 10 RM 00/2002 M FFFF NOF N | 0095 | 0500<br>8008 | 78 | *=\$200<br>HNM68 SFI<br>LDA ##FF | | 10 MM 007002 N 0000 | 0097<br>0098<br>0099<br>0100 | 0201<br>0203<br>0206 | A9FF<br>8D0380<br>2013EA | STA COULT CLEAR 68000 INPUT SIGN. | | IP RU DOCADO H 3000 | 0100<br>0101<br>0102 | 050C<br>050C | AD0280<br>2908<br>D0F9 | LOOP JSK (RIOW HALTAS JWAIT FOR ADDR. STROBE | | IP RM 004014 M 0004 HOVE.W DO: \$8000.I SHOW DO CONTENTS IP RM 004018 M 0000 | 0102<br>0103<br>0104<br>0105 | 0210<br>0213<br>0215 | AD0108<br>2908 | INE MATTAS TWAIT FOR ADDR. STROBE LDA CONTRL AND MR JSPEEDY MODE CONTROL BIT REG OUTFC | | F ML 004014 M 53CD MOVE N BO. \$8000.1 SHOW DO CONTENTS F ML 004014 M 70001 F ML 004016 M 4571 NOP D ML 004016 M 9000 THE RESULT OF MULLI.W IS \$8000 | 0105 | 0215 | F003<br>4C2E03 | REQ OUTFO | | P RN 00401E H 4671 — NOP<br>P RN 004020 H 80FC — DIVILW DO. NO 75RO DIVIDES WHAT HAPPENS NOW? | 0409 | 0244 | | TOUTPUT AROOD FUNCTION CODE | | P RN 004022 H 0000 | 0109<br>0110<br>0111 | 021A<br>021A<br>021A | | SOUTHIT ARROD FUNCTION CODE JUSTIANNE PROBLEM JUSTIANNE PRODUCT PROGRAM), SP (SUPERVISOR PROGRAM), JUSTIANNE PROBLEM JUSTIAN), JUSTIANNE PROBLEM JUSTIANNE JUSTIAN, JUSTIANNE PROBLEM JUSTIANNE JUSTIAN, JUSTIANNE JA CIM | | D WW 000FFE H 4024 STACK PC: 7EKO DIVIDE EXCEPTION D WW 000FFE H 0000 STACK STATUS D WW 000FFE H 0000 STACK STATUS D WW 0000FF H 0000 READS ZEKO DIVIDE VECTOR | 0112<br>0113<br>0114 | 021A<br>021A<br>021A | AD0280 | JUD(USER DATA), SD(SUPERVISOR DATA), JUB(UNDEFINED), JACINTERRUPT ACK.) | | P NO 004072 H CORE P NO 004012 H 0060 P NO 004014 00402 00604 00404 0040 | Page 03 | | | | | P RW 009002 H 4871 — ROP FRHE D RW 000FFG H 0000 T | 0115 | 0210 | 298.0 | AND #X11100000 | | D NU DOBFFC N DOBO D NU DOBFF N 4024 NOF P NU DO4024 N 520 NOF NU DO4024 N 530 NOF NU DO4024 N 5300 NOF NU DO4024 N 5300 | 0116 | 021F<br>0220 | 4A<br>4A<br>4A | LSR A | | NO GAODE A SOCIO | 0118<br>0119<br>0120 | 0223 | 46 | LSR A<br>LSR A<br>LSR A<br>LSR A<br>LSR A<br>LAX TABEC.X | | P NO 004024 N 33C0 1000 N 100 | 0121<br>0122<br>0123 | 0224 | AA<br>BDE 803<br>207AF 9 | IDA TABEC,X<br>ISR OUIFUT | | AGE 01 | 0124 | 022A<br>022D<br>0230 | 207AF9<br>BDE 903<br>207AE9<br>203EFB | ISR OUTPUT<br>LDA TABFC+1, X<br>ISR OUTPUT<br>JSR RLANK | | ASS 2 | | | | | | 0002 0000 ;* | 0128<br>0129<br>0130 | 0233<br>0233 | | COLIPUT ABOOD R/W CODE SWU(WRITH MODD).RW(READ WORD).WH(WRITE HIGH SBYTE).WL(URRITE LOW BYTE).RL(READ LOW BYTE), SRH(READ HIGH RYTE).UN(UNDEFINED) | | 0004 0000 3* WRITTEN BY LUCA FUSINA AND CLAUDIO GRANUZZO = 0005 0000 3**************************** | | 0233<br>0233 | A00280 | IRH(READ HIGH RYTE), UN(UNDEFINED)<br>OUTRWL LDA CIN<br>AND #7 | | | 0132<br>0133<br>0134<br>0135 | 0238 | 2907<br>0A<br>AA | ASI. A<br>TAX | | | 0136<br>0137<br>0138 | 023A<br>023D<br>0240 | 800903<br>800903 | I DA TARRUI V | | 0012 0000 :IF HORE 6502 USER SUBROUTINES ARE ADDED. THEIR EXACT 0013 0000 FAXROUSE ODD 10000 MAXROUSE 0000 MAXROUSE 0000 MAXROUSE 00000 000000 0000 | 0138<br>0139<br>0140 | 0240<br>0243<br>0246 | 207AF9<br>203EE8 | JSR OUTPUT<br>LDA TABRML+1,X<br>JSR OUTPUT<br>JSR BLAMK | | | | | 2 transfer | | | 0016 0000 #80ARD BASE ADDRESS<br>0017 0000 BRDADD-48000 | 0143<br>0144<br>0145 | 0249<br>0249<br>0249 | | TOUTPUT 68000 ADDRESSES WE HULLTPLY BY TWO TO CONVERT FROM | | 0019 U000 FAIH 65 HONITOR SUBROUTINES EQUATES 0020 0000 CRLOW-\$EA13 TOUTPUT CR.LF | 0146 | 0249<br>0240<br>0240<br>024F | AD0480<br>0A | SOUTHUL ARDON ADDRESSES HIS HILLY BY THAN TO COMMERT FROM IARDON MORE ADDR. TO BYTE ADDR. OUTAGD LOA ADDR. ASIA STR SAME | | 0021 0000 BLANK-\$E83E ;OUTPUT A BLANK<br>0029 0000 MHMA-\$EA46 10UTPUT A BYTE AS TWO HEX CHAR.<br>0023 0000 0UTPUT=\$E97A ;OUTPUT A CHAR. | 0146<br>0147<br>0148<br>0149<br>0150 | 024D<br>024F | 0A<br>85FD<br>AD0580<br>2A | | | 0024 0000 RBYTE=6E3FD READ TWO HEX CHAR. FROM KEYBOARD 0025 0000 : AND PACK THEM IN ONE BYTE | 0151<br>0152<br>0153 | 0252<br>0253<br>0255<br>0258 | 85FE<br>AD0680<br>2A | ROL A<br>STA SAVEH<br>I.DA ADDH<br>ROI A | | U026 0000 READ-\$E93C IREAD ONE CHAR. | 0153 | 0258 | PA | ROI A | ``` 85FF 2046EA A5FE 2046EA A5FD 2046EA 203EER STA SAVEH JSR NUMA LDA SAVEM JSR NUMA LDA SAVEL JSR NUMA JSR BLANK FISSHE DTACK DTA LDA DTACK JMP LOOP 0259 0258 0256 0260 0263 0265 0268 0279 0328 0280 0328 AD0880 0281 0328 400602 0284 032E FAST AUTO HODE: NO OUTPUT IS PERFORMED 032E 032F AD0480 0331 0A FAST LDA ADDL ASL A HULTIPLY BY THO 0163 0164 0165 0166 0167 0168 0169 0170 0171 0172 0268 0266 0270 0270 0270 0272 0275 0278 0278 LDA CONTRL MITH THIS BIT SET A BYTE IS ENTERED FROM KEYBOARD TO CONTROL THE 68000 INPUT SGN. ; REG NOCHD JSR RBYTE STA COUT LDA CONTRL AND N2 BEG AUTO Pane D6 F006 20F0E3 8D0380 AD0108 2902 F020 0289 0332 0290 0334 0291 0337 0292 0338 0293 0334 0294 0330 0295 033E 0296 0340 CMD NOCMD 85FB AD0580 2A 85FE AD0680 2A F003 4C1A02 STA FO ILDA ADDM ROL A STA SAVEM LDA ADDM ROL A BEG FAST1 JMP OUTFC MANUAL OR AUTO HODE CHTR. BIT Pase 04 SKIP IF SEG. IS LESS THAN 64K 0995 0344 041602 0996 0344 041602 0996 0344 0399 0344 0399 0344 0399 0344 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0348 0390 0390 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 0391 0398 OUTF1 JMP OUTFC INHOUSY SEGMENTATION PLANDARD CYCLE MANDL PAST AND TENTANDARD CYCLE MANDL PAST AND TENTANDARD CYCLE MANDL ISR A OUTF1 IMANUAL HODE: READ FROM KEYROARD, JHEMORY WRITE TO DISPLAY/PRINTER ONLY HANDAL LIA BASO JISE BLANK LOA (IN AND M1 BMC READH 027F 027F 027F 0281 0284 0287 028A 028C 0175 0176 0177 0178 0179 0180 0181 0182 A940 207AE9 203EE8 A00280 2901 DOOF :68000 FUNCTION CODE 0184 0185 0186 0187 0188 0189 028E 028E 0291 0294 0297 029A IIF WRITE OUTPUT 68000 DATA BUS WRITEN I.DA DIH I.DA DII I.DA DII JSR NUMA JMP TSER 16502 SUBROUTINES CALL IIF READ, GET TWO BYTES FROM KEYBOARD AND PUT THEM JON THE ABOOD INPUT DATA LATCHES FRAND JSR RRYTE STA DOH JSR RRYTE STA DOL JHP TSER 0290 0290 0290 0240 0243 0246 0249 TOUT OF SEG. RANGE ERR. 20FDF3 8D0880 20FDE3 8D0780 4C1703 034A D022 034C D022 034C A002H0 034F 2902 034F 2902 0375 A00180 0375 A00180 0376 9184 0376 A00280 0376 A00280 0376 9184 0376 A00280 0386 A0080 0386 A0080 0386 A0080 0386 A0080 0386 A0080 0387 G076 0387 G076 0388 A0080 A00 FAST HENDRY WRITE WRITT DA CIN WREDS 107 HOUSE LOA DIN LOA DIN LOA DIN HOUSE HO 0200 02AC AD0280 0324 0325 0326 0327 0328 0329 0330 0331 0332 0333 0335 0336 0337 AUTO HODE: R/W FROM MEMORY HITO LDA CIN FERSON OR INTA STATE SWITCH TO MANHAL MODE FEADO AND MAY 11100001 LSR A 0203 0204 0205 0206 0207 0208 0210 0211 0212 0213 0214 0215 0217 0218 0219 0220 0223 0223 0223 0225 0225 0226 0227 0228 0229 0229 29E0 4A 4A 4A 4A 4A E007 F0C4 A5FF 00C0 A0FE C9FC :68000 LDS 168000 HAS ACK. AN INTERRUPT ISEGHENT GREATER THAN 64K. 0340 0341 0342 0343 0344 0345 HAST HEHORY READ READE LDY MO LDA (FO),Y STA DOH LDY M1 LDA (FO),Y STA DOL #6502 SUBROUTINE CALL IF 68000 ADDR. IS EQUAL TO $00FC00 D003 40A203 D00004 B082 BNE LABO JMP CALSUB CMP MAXADD,X BCS MANUAL LABO IERR. IF SEGMENT IS OUT OF ITS RANGE 18 7DF 803 CLC ADC FCTAR,X JADD SEG. OFFSET 10 FFFECTIVE 68000 ADDR., SO TO SELECT THE RIGHT MEMORY LOCATIONS IN THE AIM MEMORY SPACE. Pase 07 0347 039C ADOBBII 0348 039F 400902 JAP WAITAS JAP WALTAS WA STA F1 0351 0352 0353 0354 0355 0356 0357 0359 0363 0362 0363 0364 0365 0367 0371 0372 0373 0374 0375 0376 0377 Pase 05 0231 0232 0233 0234 0205 85FB 0207 A00280 020A 2901 020C 0025 STA FO LDA CIN AND #1 BNE READA TEST 68000 R/W SAUTO WRITE IN HEHORY WRITA LDA CIN AND M2 BNE NOUDS 02DE 02DE AD0280 02E1 2902 02E3 000A AD0280 2901 F003 4C2F02 AD0180 C5902 80F6 0A 8DD403 85F8 AD0803 80F8 AD0808 8D0008 8D0008 8D0008 8D0008 FTEST 68000 R/W BECAUSE FONLY WRITE IS ALLOWED UPPER DATA BYTE LDY MOD LDA DIH STA (FO),Y JER NUMA LDA CIN AND M4 BNE NOLDS 02E5 02E5 02E7 02EA 02EC 02EF 02F2 ISUBR. ADDR. TABLE OVERFLOW 0241 0242 0243 0244 0245 0246 0247 0248 A000 AD0180 91F8 2046EA AD0280 2904 D00A TEST 68000 LOWER DATA STROBE :WRITE 68000 LOWER DATA BYTE WRILDS I.DY M1 LDA DIL STA (FD), JSR NUMA NOLDS JMP TSER 0250 0251 0252 0253 0254 0255 02F6 02F6 02F8 02F8 02F0 0300 A001 AD0080 91FB 2046EA 4C1/03 0380 0301 6CF ADD 0257 0258 0259 0260 0261 0262 0263 0264 0265 0303 0303 0305 0307 030A 030D 030F 0311 READ A WORD FROM MEHORY READA LDY NO LDA (FO), Y STA DOH JSR NUMA LDY W1 LDA (FO), Y STA DOL JSR NUMA JMP (LOCJMP A000 B1FB BD0880 2046FA A001 B1FB BD0780 2046EA #4502 SUBR. TABLE TARSUB .WORD NUMA .WORD RBYTE 0384 0304 0385 0304 46EA 0386 0306 FDE3 0388 0308 0389 0308 5757 168000 R/W CODES TABRUL .BYTE 'WWRWWLRLWHRHUNUN TABLE .BYTE 'U1U2UPSPUDSDU3IA' 0391 03E8 0392 03E8 5531 JIF SIEP HODE IS SELECTED, WAIT FOR A CHAR, FROM THEYBOARD IF JT IS NOT A CR DO NOT JSSU: JDTACK, AND REPEAT THE CITA. SEE LDA CONTRL AND 4. JSSE READ CHP *800 BEG DTA JHP LOOP 0268 0269 0270 0271 0272 0273 0274 0275 0276 0317 0317 0317 0317 0318 0310 031E 0321 ISEGMENT START ADDR., EXPRESSED IN PAGES OF 256 FRYTES EACH. USER MAY CHANGE THESE VALUES; TE HE DOES SO NE MAS TO CHANGE ALL THE RELATED JUARTABLE ADDRESSES (SEE TOP OF PROGRAM). HE HAY HADE TO CHANGE VALUES IN THE MAXADD 0394 03F8 0395 03F9 0396 03F8 0397 03F8 0398 03F8 AD010R 2904 F00A 203CE9 C90D F003 4C0602 (Continued on next page) ``` **68000/AIM 65** (Listing continued, text begins on page 12) ``` FCTAB .BYTE 0 .BYTE 0 .BYTE 40C .BYTE 6 0399 03F8 00 0400 03F8 00 0401 03F9 00 0402 03FA 00 0403 03FB 04 0404 03FC 08 Pase 08 0405 03FD 05 0406 03FE 00 0407 03FF 00 SUPERVISOR DATA SUNDEFINED S(INTA) JNUMBER OF PAGES AVAILABLE TO EACH SEGMENT. IUSER MAY CHAMME THISSE VALUES HOMEVER THRY JNUST BE CORDISTENT WITH THE SEGMENTS START JADORESSES JUST DEFINED MAKADO BYTE 0 JUSTE PROGRAM (15) BYTE 4 JUSTE PAGEMAN (15) BYTE 4 JUSTE PAGEMAN (15) BYTE 4 JUSTE DATA (1K) BYTE 1 JUSTE DATA (1K) BYTE 0 0410 0400 0411 0400 0412 0400 0412 0400 0413 0400 0414 0400 0415 0401 00 0416 0402 04 0417 0403 02 0418 0404 04 0419 0405 01 0420 0406 00 0421 0407 00 0424 0408 0426 0408 END OF PROGRAM .END ERRORS - 0000 BLANK A: E67E READ A: E78C A: E78C CIN A: 00F8 SAVEH A: 00F6 CIN A: 0002 'ADDM A: 0004 BES A: 0004 WAITAS A: 0268 WRITEH A: 028C WRITE A: 0346C TABFC A: 0346C A: EA13 A: E3FD A: 00FA A: 00FE A: 8007 A: 8007 A: 8009 A: 020A A: 0249 A: 0249 A: 024F A: 024F A: 0347 A: 0343 A: 0384 A: 0384 A: 0384 A1 0002 A1 EA44 A1 0800 A1 000C A1 000C A1 000C A1 8003 A1 8007 A1 0274 A1 0290 A1 0290 A1 0300 030 A: 8000 A: E97A A: 0500 A: 00F0 A: 8000 A: 8000 A: 8000 A: 8008 A: 0200 A: 0230 A: 0256 A: 0256 A: 0303 A: 0340 A: 0340 A: 0304 A: 0304 A: 0304 A: 0400 CRLOW RBYTE I OC.JMP SAVEH DIH ADDH HALT LOOP OUTADD HANUAL FCADD NOUDS TSER FAST1 WRFLDSERR TABRWL ``` **End Listing**