# GGO USER USER NOTES **FEATURES** J. C. WILLIAMS 1 CHEAP RAM (32K) 4 650X REGISTER SAVE & RESTORE J. GREEN TELEPHONE DIALER M. KANTROWITZ 6 LANGUAGE LAB BASIC FORTH FOCAL TINY BASIC ASSEMBLER 18 AIM INFO WARNING ABOUT PRINTER PAPER LEO SCANLON READING KIM CASSETTES D.R. D.R. EPROMS FOR AIM AIM USER I/O LARRY GOGA MEMORY TEST LARRY GOGA KIMSI, S100 20 KIMSI Mod JOHN R. CAMPBELL 65XX CHIP FAMILY STUFF 22 CPU Bug HEINZ SCHILLING 6522 DATA SHEET CORRECTIONS EDITOR EXTENDING TIMER RANGE Cass Lewart SYM & AIM TIMER LOCATIONS MARVIN DEJONG USE OF 6502 RDY LINE CONRAD BOISVERT READERS COMMENTS 25 MUSIC BRUCE NAZARIAN Mods To MTU Music Software 26 CASS LEWART INTERFACE SIMPLE INTERFACE ### EDITORIAL ### BACK ISSUES TO BE AVAILABLE We're now in the process of reprinting issues 1-6 of the 'NOTES' All pertinent information from Volume 1 (including the complimentary issue) will be combined into one giant issue and organized according to subject matter. You'll be able to find information alot faster and It'l be easier to read! Am not sure of the price yet. That info will be available in the next issue. Volume 2 (issues 7-12) will be next. ### 6502 SYSTEM CENTERFOLD? Well, not quite, but I would like to start featuring one 6502 system in each issue. If you'd like to have your system featured in the 'NOTES', send in a black & white glossy photograph of your machine (you can be in the picture also) and a few paragraphs describing what you have, what kind of software you use, and what you do with your machine. The picture should be well focused etc. I always enjoy hearing about your system and I'm sure other readers would also. Let's hear from you!!! ### SUBMITTING ARTICLES Since all articles will be retyped, they need only be readable. Typing it would, of course, guarantee readability. Program listings, on the other hand, may not be repped so, if at all possible, use white paper and a fresh ribbon on your printer. If there's no way you can generate an original source listing, then a handwritten source listing with MOS mnemonics, and labels of up to six characters, (don't forget to use labels when referencing zero page locations) will be satisfactory. Comments should be preceded by a semicolon. This will make it easy for me to assemble your program for publication. Disassembler output is not very satisfactory except when heavily commented labeled and all zero page registers identified by name. Perhaps the best way to submit program source listings would be to send a cassette of the assembler source file and I can then assemble it and run a listing on my Decwriter. I can assemble source files from either the Micro-ade assembler (Peter Jennings) or the MOS/ARESCO/HDE assemblers. If you send a S.A.S.E., I'll return your cassettes. It would be wise to dump two copies of the file to cassette just in case. I can read most of the Hypertape-recorded cassettes I receive once I adjust the azimuth of the cassette head for the higher audio level while reading the program. I think this head adjustment problem has probably accounted for most of the tape interchange problems I've been aware of. The machines I use to make the newsletter cassettes have been adjusted as close as possible and 30 seconds of synch characters precede the program for setting up your equipment. So far, we have not had any cassettes returned, so we must be doing something right. ### BUGS IN ISSUE #14 - INSIDE COVER: The correct price for 1-6 or 7-12 from Mark Kantrowitz is \$7.00 add \$3.00 for airmail overseas. - PAGE 4: (top of the page) the rest of the BANNNER listing should run from \$2500-\$28FF and not \$3400-\$36FF. - PAGE 15 : the short program in the NEW COMMAND FOR BASIC should read: 1000 PRINT: PRINT "Enter space when ready ";: GET A\$: IF A\$<>" " THEN 1000. ### FRCM SYNERTEK Apparently, SYNERTEX has rewritten the SYM monitor to clean up the problems they had reading cassettes and a few other minor glitches. No word yet on the price for retrofit but I should have that info by next issue. The following notice is being reprinted from Vol IV No 5 of the CACHE REGISTER. I don't know how true it is - but it pays to look before you lear. ### WORLD POWER SYSTEMS: FRAUD!!! It appears that World Power Systems is a carefully instigated fraud for ripping off computer hobbyists and small businesses. One Chicago business is out of luck for \$4500. The scenario reads like a TV police show, complete with prison escape, aliases, etc. I guess it's appropriate to repeat the advice that so many have given before: if you don't know the integrety of the company, do all your business in person or via C.O.D. Better yet, deal with local, reputable dealers, like the computer stores; or those who advertise in the CACHE Register, like Lloyd Smith of Smith Computer Systems. (With his good prices, it's a shame he hasn't been getting more business from his ads, and has had to cut them back.) Ward Christensen ### WE'RE GOING TO SUPPORT OSI! From all indications, there are alot of frustrated OSI users out in the field. I've looked over the C-1P and C2-4P and they seem like reasonable machines for the money. The 'USER NOTES' will try to fill in where the documentation leaves off so we really have our work cut Pass the word along to any OSI users you know of We've already got a few goodies to pass along. For the first installment, see the comments section in this issue. KIM, of course, will still get the bulk of our support. ## CHEAP RAM!! Joe was kind enough to lend me one of his dynamic RAM cards for a firsthand opportunity to see how well it worked. I cycled the board for several hours with a couple of the dynamic memory tests contained in the HDE Comprehensive Memory Test [CMT] package. The board performed flawlessly! As for as I can tell, this RAN card should be useable with other 6502 machines uncluding OSI, and PET besides the KIM, SYN and AIM. ### A 32K DYNAMIC RAM BOARD FOR THE KIM-4 BUS by J. C. Williams 55 Holcomb St. Simsbury, Ct 06070 Two years ago, 16K x 1 dynamic memory chips such as Mostek's 4116 sold for about \$40 each; they're now less than \$10 each and available from many semiconductor manufacturers. These prices mean that a 32K board can be built for about \$200. In addition, the board will draw less than 200 mA from the +8 Volt power supply, 200 mA from the +15 supply and 5 mA from the -15 supply. Memories for the APPLE II and TRS-80 microcomputers are based on these devices, as are many mimicomputer memories; in spite of old rumors, dynamic memories work reliably. The circuit of figures 1A and 1B is a 32K byte (16K if only 8 memory chips are installed) memory for the KIM-4 bus which easily fits on a 4½"x6½" circuit board. Figure 2 shows the layout used for one of the prototypes built on a Vector 3662 plugboard. In eight months of constant use with a KIM 1 and KIM-4, no problems of any kind have been encountered with this unit. A second unit, built at the end of 1978, also works well. It would take a long write-up to explain how dynamic memories work and this note is about a specific circuit. Readers who want to learn more details could start with Lane Hauck's article in the July, 1978, issue of BYTE and progress to manufactuerers' data sheets and application notes. Mostek's 1978 Memory Data Book and Designer's Guide is especially useful and has excellent applications information. In the circuit of figure 1, memory refreshes are "hidden" during $\emptyset1$ ( $\emptyset2$ ) of the 65XX processor cycle. This can be done because although the processor puts out address and R/W information during $\emptyset1$ , read or write operations are done during $\emptyset2$ . The circuit described "gives" the memory to the processor during $\emptyset2$ and to the refresh circuit during $\overline{\emptyset2}$ . Memory chips used in this way must be fast enough to function at approximately twice the processor clock frequency. Devices with a 200 ns access time and a 450 ns cycle time are required for this circuit if the processor has a 1 MHz clock. Figure 3 is a timing diagram which shows what must be done to interface the 4116's (or pin-compatable equivilent) to a 1MHz 65XX bus. The bus provides Ø2, R/W, RESET, and address information. During write cycles it provides data and during read cycles it takes data. The specific bus times marked on figure 3 were taken from the MOS Technonology Hardware Manual. The 4116's require a Row Address Strobe (RAS), a Column Address Strobe (CAS), WRITE, and multiplexed address information at specified times. Figure 3 times were selected for the most reliable operation using the full time available during Ø2. Four types of memory cycles can occur: 1) Read 2)Write 3)Refresh and 4)Null. Read or Write cycles occur during Ø2 if the processor has addressed a location on the board. Refresh cycles occur during Ø2 once every 32 clock cycles or during every Ø2 if RESET is low. During Null cycles no 4116 activity occurs. The circuit of figure 1 implements the timing using one CMOS and eleven TTL integrated circuits. The two 16K X 8 banks of 4116's have address lines AO-A6 driven by multiplexers U8-U11. To eliminate undershoot on AO-A6, 1.5 k pull-up resistors are required. Nand gates U6 and U7 drive the 4116 RAS, CAS, and WRITE lines. Nand gate U4 and twelve bit ripple counter U5 produce a REFRESH signal once every 32 clock cycles as well as provide the seven bit refresh address to be used. A REFRESH signal is also produced when RESET is low in order to insure proper start-up of some manufacturer's memory chips. Since Refresh cycles are dependent only on the existence of a lMHz Ø2 signal on the KIM-4 bus, any hardware controlling the bus must provide such a signal. One-shot multivibrators U1 and U2 provide row and column address strobe timing signals when triggered by other signals. U12 generates the BOARD SELECT, UPPER BLOCK SELECT, and ROW ADDRESS 5 and 6 signals by comparing the four most significant bits of the KIM-4 address bus with the settings of the "starting address" switches. Sections of U3 are used as buffers, delay elements and inverters. The circuit of figure 1 implements the timing The construction of this circuit is not difficult, but requires care, planning and some experience. Layout is important to minimize the length of lines carrying high speed signals and undesirable coupling between lines. A low impedance ground and power supply distribution are essential because of the high peak currents drawn by the memory chips during clocking. Don't skimp on bypass capacitors and use \$20 or larger tinned copper buswire for grounding. The grounding and bypass layout of figure 2 works well. Wire-wrapped connections are best made with a Vector Electronics Co. Model 180 "slit and Wrap" tool which enables one to solder to the leads of resistors, capacitors and edge connector pads as well as make "daisy chained" wraps. Once this tool is used, you'll never want to measure, cut and strip regular wire again. The construction of this circuit is not dif- All parts which attach to the board should be on hand before any construction is started. The following sequence may be of help in buidling one of these boards: - Attach wire wrap IC sockets and voltage regulators to board with "five minute" epoxy glue. - lators to board with "five minute" epoxy glue. Heat sinks are not required. Run the ground bus on the bottom of the board using #20 or larger tinned copper bus wire. Start at edge connector pads 1 and A and go around the outside of the board to pads 22 and 2. Stick in and solder bypass capacitors between the bus and the proper IC socket pins as you go to hold the bus wire in place. Complete the ground network with additional lengths of bus wire to the "inner" IC's and install the remaining bypass capacitors. Install the resistors (mounted vertically in - ous wire to the "inner" IC's and install the remaining bypass capacitors. Install the resistors (mounted vertically in some cases) and remaining capacitors by sticking their leads through the board and soldering them to the appropriate pins. Cut any uncommitted leads to \$\frac{1}{2}\$ for later "slit and wrap" connection. --The remaining connections can be made with "slit and wrap" techniques- don't forget to solder after wrapping round leads. Run the \*5, \*12 and -5 Volt power supply lines from the outputs of the respective regulators to the correct IC pins, bypass capacitor leads and pull up resistor (+5 Volt only) leads. Also run the \*8, \*16 and -16 Volt lines from the proper edge connector pads to the correct regulator input pins and bypass capacitors. These lines may be conveniently run on the board top. "Plug in" the board, power it up and check for correct power and ground connections at every location. - IC location. - location. Wire the remainder of the circuit in stages checking between data sheet pinouts, schematics and drawings to eliminate errors. The stages could be a)address lines b)control and timing logic c)data lines and d)row and column address strobes and WRITE lines. It is helpful to use wire with a different color insulation for each Install all IC's except 4116's and test the board on a KIM-4 bus. Set the starting address of the board as desired (for example \$2000) and turn on the power-the system should operate normally. Load test programs in operatonal memory which will "exercise" the board. ### Read Test 0200 AD 00 20 READ LDA \$2000 0203 4C 00 02 JMP READ ### Write Test 2 0200 8D 00 20 WRITE STA \$2000 0203 4C 00 02 JMP WRITE While one of these programs runs, an oscilloscope can be used to check the RAS, CAS and other signals produced at a memory chip socket in the selected block. 02 should be used as the 'scope trigger and displayed on one channel so that the signal being tested can be compared with it. Adjust timing if necessary by changing one-shot timing resistors. Signals to the other memory block can be checked by changing the address used in the test program (for example to \$6000). RAS signals produced during $\frac{\pi}{2}$ 2 by REFRESH may be observed by holding RESET low. Install 4116's and test using the monitor and a program such as Memory Test by Jim Butterfield in the First Book of KIM. If trouble-shooting is needed, the type of problem is an indication of what's wrong. For example, if one bit in one block is always wrong suspect a bad 4116 or data line wiring. If the errors seem to be random, the 4116's may be too slow or there may be excessive noise on the power supply lines. Based on experience with the prototypes, once the clock timing has been adjusted, there will be no problems at all. The author hopes that the availability of large, low-cost memories will stimulate the development of software for 65XX systems. Any correspondence on the memory circuit should be sent to the above address. 03,pi=13 U2,pi=13 1.0k ≷ ₹ 1.5 k V13-U2P1= 13 86 REFRESH ADDRESS A 5 1 \$ 1.5 k 1.5 k 3 pin 1 , ROW AD. 6 U13-028 pin 11 A 4 VI3-V28 pin 12 R3 ₹ 1.5 k 1.5 k 3 V13-V28 pin 6 A2 746315 13.028 pin 7 1.5 k Rd ... Na. va. 8 p.- 5 AO UB U20rU28 pins X+14 U14+U27 pins X+14 U18+U26 ains X+14 U17+U25 pins X+14 U16+U26 pins X+14 U15+U26 pins X+14 BIDIRECTIONAL DATA LINES U14+U22 plas 2+64 U13+U2) plas 2+64 18 ### FIGURE 2-PARTS LAYOUT, GROUND BUS ### FIGURE 3 - TIMING DIAGRAMS - 1 MHz CLOCK ## Some Errors! See #16-1925 ### 650X SAVE AND RESTOR ROUTINES by Jim Green 807 Bridge Street Bethlehem, PA 18018 Copyright, 1979 Commercial Rights Reserved These routines save and recover A, Y and X register values. The ability to protect these values is particularly useful when they might be lost due to modification within, say, a device routine. In the programs below no additional data memory (other than the stack) is required. This makes it possible to save register contents to any level of nesting permitted by the size of the available stack. At the outset one should note that the two subroutines illustrated below, SAVE and RESTOR, can be replaced with just twenty bytes of code (see ASAVE and ARESTR below) which will execute in less than a sixth of the time. Having said that, why would anyone want to know about, much less use, these routines? First, the exercise in writing or understanding the routines is interesting, I think. Second, and more important, a pair of subroutine calls is easier on the overburdened mond of the programmer than remembering the sequence of the ten lines of code. (Did I save the Y before the X or vice versa?!) A third possible reason, that of saved program space, would only exist if in excess of 6 call pairs (ie. a SAVE and a RESTOR) are made to these routines. The alternative code sequences are: | ASAVE: | PHA | | ; push A value to stack | |---------|-------|-----------|--------------------------------| | | TYA | | | | | PHA | | ; push Y value to stack via A | | | TXA | | | | | PHA | | push X value to stack via A | | | TSX | | :use stack pointer | | | LDAX | \$0103 | ; to get A copy | | | PHA | • | ; save it also | | | LDAX | \$0101 | ;retrieve X value | | | TAX | • • • • • | and restore X | | | PLA | | ;now restore A | | | | | | | ARESTR: | PLA | | ; pull X value from stack to A | | | TAX | | ;restore X | | | PLA | | ; pull Y value from stack via | | | TAY | | ;restore Y | | | PLA . | | ;restore A | | | | | | The interesting aspect of the subroutine code presented below is that subroutines are used to perform stack operations. Since the subroutines themselves use the stack as the place where their return addresses are saved, it is necessary to move some stack bytes around and to do this regardless of the current value of the stack pointer. At the beginning of any subroutine, after it has been called, the state of the stack may be represented as shown in Figure 1: Figure 1. Where RAH and RAL are the high and low bytes of the return address, "???" is the next available stack byte, and SP is the address pointed to by the stack pointer. If the operations starting with ASAVE (above) are now invoked, the stack would appear as shown in Figure 2a. Notice that the return address is now hidden and no longer directly available. An attempt to return from the subroutine at this point would get lost by returning to the address equal to Y (as the high byte) and X (as the low). Clearly, some swaps must be made. To accomplish this, the stack pointer is moved "up" two bytes (remember that stacks work upside down). Then RAH and RAL are copied onto the two new locations (Figure 2b.). The entire block of 5 bytes is then shifted "down" (Figure 2c.), and finally the stack pointer is re-established just "above" the return address. The return address is now accessable so that after an RTS (Figure 2d.) only the A, Y and X values remain on the stack. The RESTOR routine does essentually the same thing in reverse. One additional wrinkle occurs at RESTI, in which the current value of A replaces the saved value of A on the stack before program control drops into the RESTOR routine. This feature is useful in single byte input routines where we wish to protect the Y and X values but to replace the old A value with the new input value. SAVE and RESTOR (or RESTI) may be invoked anywhere in a program subject to the restriction that each SAVE call be ultimately followed by a RESTOR (or RESTI) call at the corresponding stack level. The partial code below illustrates the application of the routines. Notice that the pair of calls within SUBROUT are nested within the pair outside SUBROUT: As stated at the outset, these routines will save neither program time nor program space but they may, in the long run, save a programmer from undue wear and tesr. Besides, they were fun to write. Figure 2. Stack values due to SAVE. ``` 650% REGISTER SAVE AND RESTOR ROUTINES VERSION 0.1, 14 FEB 79 COPYRIGHT, 1979 COMMERCIAL RIGHTS RESERVED BY J. S. GREEN, COMPUTER SYSTEMS 807 BRIDGE STREET BETHLEHEM, PA 18018 (215) 867-0924 START OF PAGE ONE .DEF PGONE=$0100 .LOC $0200 SAVE A, Y, & X REGISTER VALUES ON STACK ;SAVE A SAVE: PHA 0200 48 0201 98 0202 48 TYA PHA ; SAVE Y 0202 48 0203 8A 0204 48 0205 48 0206 48 0207 BA 0208 BD 07 01 020B 9D 02 01 0211 9D 01 01 ; SAVE X ; ADD TWO BYTES TO STACK PHA PHA PHA TSX LDAX PGONE+7 ; USE STACK POINTER TO ; MOVE RETURN ADDRESS ; TO TOP OF STACK STAX PGONE+2 PGONE+6 PGONE+1 LDY# ``` | 0216<br>0219<br>021C<br>021D<br>021E<br>0220 | 9D<br>CA<br>88<br>10 | 87 | <b>0</b> 1 | | LDAX<br>STAX<br>DEX<br>DEY<br>BPL<br>PLA | PGONE+7 | ;SHIFT LAST 5 BYTES OF<br>; STACK DOWN TWO CELLS<br>; TO COVER OLD ADDRESS<br>;LOOP TIL 5 DONE<br>;ADJUST POINTER | |----------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------|----------------------------|--------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0221<br>0222<br>0225<br>0226<br>0229<br>022A<br>022D<br>022E<br>022F | BD<br>48<br>BD<br>A8<br>BD<br>AA<br>68 | 0B<br>0A | øı | | PHA<br>LDAX<br>TAY | PGONE+\$0B | ; NOW RESTORE REGISTERS<br>; ACC<br>; Y REGISTER<br>; X REGISTER<br>; ACC | | | | | | • | RESTO | RE X & Y ON | LY | | 0230<br>0231 | | | 01 | RESTI: | | PGONE+5 | ;USE STACK POINTER<br>; TO OVER-RITE OLD A | | 023C<br>023F<br>0240<br>0241 | 48<br>ABABD<br>BBD<br>BBD<br>BBD<br>BBD<br>BBD<br>68<br>88<br>68<br>88<br>88 | 04<br>03<br>01<br>F6<br>02<br>07<br>01 | 01<br>01<br>01<br>01<br>01 | | PHA<br>TSX<br>LDY I<br>LDAX<br>STAX<br>INX<br>DEY<br>BPL<br>TSX<br>LDAX<br>STAX | 4<br>PGONE+3<br>PGONE+1<br>RESTR1<br>PGONE+2<br>PGONE+7<br>PGONE+1<br>PGONE+6 | ; ADD TO STACK ; USE STACK POINTER ; TO SHIFT LAST 5 BYTES ; OF STACK UP 2 CELLS ; TO MAKE ROOM FOR RETURN ; ADDRESS ;BR TIL 5 DONE ;MOVE RETURN ADDRESS ;ADJUST STACK POINTER ;X VALUE ;Y VALUE ;ACCUMULATOR VALUE | | | | | | | · LAD | | ž | ### TELEPHONE DIALER by Mark Kantrowitz 15 Midway Court Rockaway NJ 07866 This telephone dialer program will disl a telephone number (of any length) by pressing a single key on KIM's keypad. The hardware consists of a 7406 inverter, NFN transistor, a couple of resistors and a 12 volt relay (see figure). The switching end of the relay is connected between the green wire and the logic box where the green wire was connected. Up to 16 different telephone numbers can be dialed. You must first store the numbers in memory. Preceeding every telephone number, you must store an I.D. number. The first I.D. number is AO and goes up to AF. Each telephone number consists of one or more bytes. Each byte of the telephone number consists of two digits of the telephone number. Except when there is an odd number of digits, in which case a "F" is placed in the last nybble of the last byte of that particular telephone number. A "FF" in the phone table indicates the end of the table. As an example, a typical phone table would look like this starting in location 0018: AO 20 16 25 17 19 A1 35 91 81 9F A2 80 02 65 48 45 FF This phone table has three numbers in it. Pressing 0 on the keypad will cause, 201-6251719 to be dialed. When you start the program at 0200, the display will flash "PHONE". When you press a key on the keypad, the program changes that key to an I.D. number and searches for it in the phone table. If it is there it dials the number associated with it. If the I.D. number is not in the table, the display will flash "ERROR". As the program dials a number, it displays it in a banner fashion. After dialing, it returns to displaying "PHONE". NOTE: The Telephone Co. takes a dim view of equipment attached to their lines without their approval. D = 1N914 #### HDE ASSEMBLER REV 2.0 ``` LINE# ADDR OBJECT SOURCE PAGE 0001 0010 2000 FTELEPHONE DIALER PROGRAM BY MARK KANTROWITZ 0020 2000 *=$0 0030 0000 MSG *=*+12 0040 000C DISPLY *=*+7 0013 FLASH *=*+5 0060 0018 TABLE #=#+1 START OF NUMBER TABLE 0070 0080 0019 0019 PAD =$1700 0090 0019 PADD =$1701 0100 0019 TIMER =$1707 0110 0019 0120 0019 CHANGE =$1F40 0130 0019 GETKEY =$1F6A 0140 0019 0150 0019 ABLE =$1FE7 0019 0160 =$1742 =$1740 SBD 0170 0180 0019 SAD 0019 SADD =$1741 0190 0200 0019 0019 0210 0019 *=$0200 0220 0230 0200 0202 A2 00 BD 5E 03 INITS LDX #0 INITS1 LDA MESSG.X FINITS MESSG PNTR FGET A MESSAGE BYTE AND 0240 0205 95 00 STA MSG.X FSTORE IN Z-PAGE LOCATIONS E8 INX 0260 0208 EO OC DONE YET? 020A BNE INITS1 DO F6 0280 020C D8 START 020D 020F 0290 A2 00 LBX **0 FINITS INDEX FOR DISPLAYING 0300 86 STX FLASH PHONE MESSAGE. 13 0211 0213 A9 FF BD 07 17 LDA ##FF STA TIMER 0310 SET SET TIMER TO .25 BEC 0320 0330 0216 13 FIVE LDX FLASH 0340 0350 0218 021A STX FLASH+1 LDY #$9 86 AO SELECT FIRST DIGIT 021C 021E 0221 0223 0360 0370 0380 49 LDA #$7F STA SADD STY FLASH+4 7F FOUR SET DIRECTIONAL REGISTER BD 41 17 B4 17 0390 A6 14 LDX FLASH+1 0400 0410 0225 0228 BC 42 17 B5 00 STY SBD LDA MSG,X $LOAD SEGMENT CONTROL BYTE 0420 022A 40 17 STA SAD 8D 0430 0440 022D 022F E6 14 A9 10 INC FLASH+1 LDA #$10 FINCREMENT FOR NEXT DIGIT 0450 0231 85 15 STA FLASH+2 0460 0233 85 16 TWO STA FLASH+3 DEC FLASH+3 DELAY FOR A FEW 0235 # MILLISECONDS BNE ONE DEC FLASH+2 BNE TWO 0480 0237 DO FC 0490 0500 0239 023B 63 DO F6 0510 023D 20 40 1F JSR CHANGE 0520 0530 0240 0243 20 6A C9 10 JSR GETKEY #GET A KEY #VALID KEY? (0-F) 0540 0550 0245 0247 30 26 BMI THREE FIF YES, FIND TELEPHONE NUMBER 0247 0248 0560 CLC E6 17 E6 17 INC FLASH+4 INC FLASH+4 FINCREMENT TO SELECT 0570 0580 0590 024A 024C LDY FLASH+4 CPY #$15 BNE FOUR A4 17 024E 0250 *PAST 6TH DIGIT? *IF NOT, LIGHT NEXT DIGIT *.25 SECONDS UP? 0600 0610 DO CA 0620 0252 2C 07 17 BIT TIMER 0630 0640 0255 0257 10 BF BPL FIVE FIF NOT, LIGHT DISPLAY AGAIN 0650 0660 0257 0259 LDA ##FF SET TIMER FOR ANOTHER .25 SEC BD 07 17 STA TIMER FOR DISPLAY BLANKING 0670 0680 025C 025F 20 40 1F 20 6A 1F SIX JSR CHANGE ;GET A KEY ;VALID KEY? (0-F)? ;IF YES, FIND TELEPHONE NUMBER ;.25 SECONDS PASS? ;IF NOT, GET A KEY ;IF SO, FLASH DISPLAY AGAIN JSR GETKEY 0690 0700 0262 0264 C9 10 30 07 CMP #$10 BMI THREE 0266 0710 2C 07 17 BIT TIMER 0720 0730 0740 10 F1 30 A4 BPL SIX BMI SET 026B 026D 0750 0760 026D 026D FIND TELELPHONE NUMBER CLC ADC #$AO F'A' CONTAINS I.D. 18 THREE 0770 026E 69 AO #MAKE INPUT LOOK LIKE TABLE I.D. 0780 0790 0270 0272 A2 00 D5 18 LDX #$00 CMP TABLE,X TEN FI.D. MATCH? 0800 0810 0274 FOR TABLE RELOCATION NOP BEG EIGHT FO 12 FIF SO, DIAL NUMBER FIF NOT, PASS OVER NUMBER 0820 0830 0277 0278 NINE B4 18 LDY TABLE,X 0840 0850 027A 027B NOP CPY #$AO FOR TABLE RELOCATION CO AO 0860 027D BCC NINE ``` ``` $END OF TABLE? $IF NOT, COMPARE WITH I.D. $IF SO, FLASH "ERROR" MESSAGE CO FF DO EF CPY ##FF BNE TEN 0870 0880 0281 LDA ##6 STA FLASH 0890 0283 A9 06 0900 0910 0285 0287 85 13 DO 88 BNE SET 0289 0920 0930 0940 0289 0289 IDIAL NUMBER LDY ##5 LDA ##0 STA DISPLY,Y AO 05 EIGHT 0950 0960 028B A9 00 99 0C 00 FZERO OUT DISPLAY AREA ELEVEN 0970 0290 0291 88 DEY 0980 10 FA BPL ELEVEN 0990 1000 0293 0294 E8 B5 18 INX LDA TABLE,X NEXT FLOAD TWO NUMBERS NOP CMP ##AO BCS TWELVE LSR A FOR TABLE RELOCATION NUMBER COMPLETED? FIF SO, GO TO START SOLATE LEFT DIGIT 0296 EA C9 1010 AO 1020 0299 029B 1030 BO 26 1040 4A 029C 029D 4A 4A LSR A 1050 BY SHIFTING IT RIGHT 1060 LSR A AND #60F STA DISPLY+6 1070 029E 4A 29 OF 1080 1090 029F 02A1 #MASK LEFT NIBBLE 85 STORE FOR DISPLAY 1100 1110 02A3 02A5 C9 D0 CMP ##0 BNE SKIP FIF ZERO, MAKE IT SOA A9 0A 85 14 20 1B 03 20 D9 02 02A7 02A9 02AB LDA ##0A STA FLASH+1 JSR MOVE 1120 SKIP #STORE FOR DIALING #SHIFT DISPLAY LEFT #LIGHT DISPLAY AND PULSE PHONE 1130 1140 1150 02AE JSR PULSE LAP 1160 1170 02B1 DO FB BNE LAP FINISH PULSING DIGIT? #IF NOT, CONTINUE PULSING..... JSR DELAY #DELAY FOR .5 SEC LDA TABLE,X #LOAD RIGHT DIGHT 1180 02B3 1190 1200 02B3 02B6 20 05 03 B5 18 FLOAD RIGHT DIGIT FFOR TABLE RELOCATION MASK LEFT NIBBLE FSTORE FOR DISPLAY FEND OF NUMBER? FIND OF NUMBER? FIF SO, GO TO BEGINNING 02B8 02B9 1210 AND #$0F STA DISPLY+6 CMP #$0F 29 OF 1220 1230 02BB 02BD 85 12 C9 OF 1240 02BF 02C1 DO 03 4C OC 02 BNE ZERO TWELVE JMP START 1260 1270 02C4 02C4 C9 00 ZERO CMP #60 BNE PASS #NUMBER ZERO? #IF SO, MAKE IT $0A 1280 1290 1300 02C6 02C8 DO 02 A9 0A LDA #$OA #STORE FOR DIALING #SHIFT DISPLAY OVER ONE #LIGHT DISPLAY AND PULSE PHONE #IF NOT DONE PULSING, CONTINUE #DELAY FOR .5 SEC #GET NEXT DIGIT 1310 1320 02CA 02CC 85 14 20 1B 03 STA FLASH+1 MOVE PASS 1330 1340 02CF 02D2 20 D9 02 D0 FB LITE JSR PULSE BNE LITE JSR DELAY 20 05 03 1350 0204 1360 02D7 30 BA BMI NEXT 1370 1380 02D9 02D9 SUBROUTINE TO PULSE PHONE... 1390 1400 1410 02D9 A9 80 8D 01 17 02D9 LDA #$80 STA PADD PULSE SET PA7 TO OUTPUT 02DB LDA #$00 STA PAD 1420 02DE A9 00 TURN DN A7 8D 00 17 A9 31 8D 07 17 1430 1440 1450 02E0 02E3 02E5 LDA ##31 SET TIMER FOR .1 SEC STA TIMER 1460 1470 02E8 02E8 20 30 03 JSR ETIL PLAY FLIGHT DISPLAY 1480 1490 1500 20 07 17 BIT TIMER BPL PLAY LDA #$80 FTIMER UP? FIF NOT, GO LIGHT DISPLAY FTURN PAZ OFF 02EB 02EE 02F0 10 F8 A9 80 02F2 02F5 02F7 02FA 1510 8D 00 17 STA PAD LDA #$31 STA TIMER SET TIMER FOR .1 SEC 1520 A9 31 BD 07 17 1530 1540 20 30 03 UP JSR ETIL BIT TIMER FLIGHT DISPLAY 1550 1560 02FD 0300 2C 07 17 FTIMER UP? 1570 1580 0300 0302 BPL UP DEC FLASH+1 FIF NOT, GO LIGHT DISPLAY DECREMENT DIGIT 10 FB C6 14 1590 0304 1600 SUBROUTINE TO DELAY .5 SECONDS 0305 1610 LDY ##1 STY FLASH LDA ##FF STA TIMER 1620 0305 AO 01 DELAY 0307 0309 030B 1630 1640 84 13 A9 FF TIME 1650 8D 07 17 SET TIMER FOR .25 SEC 20 30 03 2C 07 17 10 F8 JSR ETIL BIT TIMER BPL YALP FLIGHT DISPLAY FTIME UP? FIF NOT, LIGHT DISPLAY 1660 030E YALP 0311 1670 1680 #SET TIMER FOR .25 SEC DELAY 1690 1700 0316 0318 C6 13 10 EF DEC FLASH BPL TIME 1710 1720 031A 60 RTS 031B ``` ``` #SUBROUTINE TO MOVE DISPLAY MOVE LDY **O CONT LDA DISPLY+1,Y #LOAI STA DISPLY+Y #STOR 031B 1740 031B A0 00 1750 1760 031D 0320 B9 OD OO 99 OC OO FLOAD DIGIT FSTORE IN PLACE TO LEFT 1770 0323 CB INY 1780 1790 0324 0326 CO 05 DO F5 CPY ##5 BNE CONT FINISHED? FIF NOT, CONTINUE A4 12 B9 E7 1F 85 11 LDY DISPLY+6 LDA ABLE,Y STA DISPLY+5 FLOAD INCOMING DIGIT FGET BIT REPRESENTATION FSTORE IN 6TH DSPLY POSITION 1800 0328 032A 032D 1810 1820 1830 60 0330 1840 1850 0330 0330 A0 09 1860 0332 0334 0336 0339 0338 SET DIRECTIONAL REGS 1870 1880 84 16 A9 7F 8D 41 17 1890 1900 1910 1920 A0 00 A5 16 BD 42 17 #SELECT DIGIT 033D 0340 0343 0346 0348 034A 1930 1940 LDA DISPLY,Y STA SAD FLOAD CONTROL BYTE LBA #$10 FDELAY FOR .5 MILLISECONDS 1950 A9 10 STA FLASH+2 STA FLASH+4 DEC FLASH+4 1960 1970 85 15 85 17 034E 034E 0350 1980 C6 17 CED BNE CED DEC FLASH+2 1990 DO FC C6 15 BNE ATS INC FLASH+3 INC FLASH+3 0352 0354 0356 2010 DO F6 E6 16 E6 16 FGET NEXT DIGIT SELECT 2020 2030 0358 0359 035B INY CPY #$7 BNE INUE 2040 2050 CO 07 FDONE? FIF NOT, CONTINUE 2060 035D 035E 035E 2070 2080 2090 MESSG .BYTE $F3,$F6,$BF,$D4,$F9,$00 ; "PHONE" MESSAGE F3 2090 035F 0360 0361 2090 D4 2090 0362 0363 2090 F9 2090 .BYTE $79.$50.$50.$50.$50.$00 ; "ERROR" MESSAGE 2100 0364 0365 2100 2100 2100 50 0366 0367 2100 0368 2100 0369 00 2110 .END 036A ``` ERRORS = 0000 # LANGUAGE LAB ## basic SOME IMPORTANT BASIC MODS from Christopher Flynn, 2601 Claxton Dr. Hernggn, VA Enclosed are listings of two machine language programs which should be of interest to users of Johnson Computer's Microsoft BASIC. The first subroutine MLDSPT is a dispatch which BASIC can use to activate user-written machine language subroutines. The second subroutine ARRSAV/ARRLOD provides an easy way to save and load data on cassette tape from BASIC arrays (either floating point or integer). Before describing the subroutines, I would like to mention the features of my eclectic systemperhaps I can share experiences with someone. First of all, I am using a KIMSI motherboard that is populated with 16K of RAM and an Ithaca Audio EPROM board. For a console device, I use an SSM VDB-1B board. My software TTY emulator is homebrew, approximately 500 bytes long, and completely romable and position independent. Hypertape is great, but for tape I/O, a Tarbell board has really proved its worth. Finally, in the hardware area, hard copy is produced by a faithful SWTPC PR-40 printer. So much for my system... ### MLDSPT The USR function in BASIC is used to invoke machine language subroutines. One of the drawbacks of Microsoft's USR is that there is no way to directly specify the address of the user subroutine. Instead, the address of the subroutine must be POKEd into BASIC. Not having access to the source code for BA-SIC, I could not attack the problem head-on. MLDSPT is an alternate way of calling machine language subroutines and works as follows. MLDSPT itself is invoked by the USR function. (This implies that USRLOC must be patched with the address of MLDSPT.) MLDSPT queries locations SFE or 254 into which the programmer has POKEd a subroutine number. MLDSPT then activates the proper subroutine and the subroutine can access the argument of the USR function if desired. Subroutine numbers can be in the range of 0 - 127. MLDSFT multiplies the subroutine number by two and uses the result to index a table of subroutine addresses. The proper address is fetched - \*Program, copy, verify run any of the industry standard EPROM's (2708, 2758, either 2716). Copies to or from any mix of EPROM types! - \*Sockets for 3K of 2114 type RAM with decoding to give KIM 4K continuous RAM. Decoding may also be set to 1K boundries within an 8K block to anywhere in memory. - \*Zero insertion force sockets for both run and program EPROM sockets. - \*No extra power supplies needed--runs from KIM's +5 and +12 supply. Regulated -5V and programming voltages generated on board. - \*Documentation and software listings furnished. - \*Optional 2708 EPROM containing program and verify routines available. Optional KIM format tape available. - \*MORE™ does not monopolize the KIM edge connectors--they pass through so you simply unplug your existing connector, plug on the MORE board, and reconnect your connectors. - \*Special LED lets you see what the KIM audio tape interface is doing. SEE your programs load! ### TENNESSEE TECHNICAL INTRODUCES THE NEW MORE™ BOARD for KIM series Micro-computers LOADED WITH FEATURES More EPROM---up to 2K More RAM---up to 3K More Output---16 latched bits More Use---run, copy, program to or from any eprom type mix. - \*Two 8-bit latchable output ports with 16 LED's in a linear array. Two DIP headers for easy port access. NOTE: the LED's are great for status indicators, educational or game use. Make lights dance! Make a bar graph indicator. Make a disco-KIM! - \*MORE™ includes a prototyping area for your individual projects, i.e. add additional RUN EPROM sockets, etc. - \*All IC's in sockets. No alterations to KIM! - \*G-10 epoxy board with plated through holes. 4" x 103/4". - \*Four sets of programming and/or run personality keys that allow you to change EPROM types in seconds with no board alteration. Keys for 2708, 2716 (3 voltage) 2758, 2716 (5 V only) all included! - \*MORE™ will not become obsolete for many years and is a powerful and useful tool: Ideal for education, development, dedicated applications. And just plain fun! MORE™ board complete with four personality key sets (8 keys), documentation, software listings, assembled and tested. Less EPROM's and RAM's. \$169.95 prepaid in U.S. Check or M.O. to: T.T.I. P.O. Box 2328 Cookeville, TN. 38501 Please allow 4 to 6 weeks for delivery. Software on tape--\$10.00 extra. Software in 2708 EPROM--\$30.00 extra. from the table and pushed on the stack. Next, MLDSPT issues an RTS instruction which pulls the address from the stack into the program counter. Thus, the subroutine is invoked. Please heed the notes on the listings. The addresses in the address bable are the actual machine language subroutine addresses minus one. Examples in the next section will illustrate the use of $\ensuremath{\mathsf{MLDSPT}}$ . ### ARRSAV/ARRLOD One of the curious omissions from Microaoft BASIC is a feature to save and load data using cassette tape. Simple machine language routines have been written to overcome this deficiency. Currently, data stored in either floating point or integer arrays can be stored on or read from tape. To save character string arrays, the information must first be moved to a numeric array. To read character string arrays, the information must be read into a numeric array and then moved to a character string array. One of the curious omissions from Microsoft ### SAVING DATA Perform the following steps to save data on - 1. In my system, using MLDSPT, the save rou-tine is machine language routine number 3 This may vary in other systems. POKE 3 into location 254 (decimal). - Inform ARRSAV of the name of the array to be saved. This is accomplished by POKing the numeric value of the first character of the array name into location 6027 (decimal). Similarly, POKE the numeric value of the second character of the array name into location 6028 (decimal). If the array name is only one character long, set location 6028 to 0. If the array is an integer array, set the high order bits of 6027 and 6028 to 1. Do this even if the integer array name is only one character long. A DIM statement for the array must appear before data can be written form the array. Inform ARRSAV of the name of the array to - Prepare the tape recorder and invoke the USR function. USR will activate MLDSPT which will, in turn, execute ARRSAV. Con-trol will return to BASIC. Reading data back in is very similar, but there are a few cautions to be observed. - POKE the number of ARRLOD into location 254. In my system ARRLOD is routine num-ber 4. - 2. As described above, POKE the array name into decimal locations 6027 and 6028. Data will only load into an array having the same name as the array from which the data was written to tape. Furthermore, the data must be loaded into an array having at least as many bytes as the original array. Finally, a DIM statement must appear for an array before data can be loaded into the array. - 3. Prepare the tape recorder and invoke the USR function. ### EXAMPLES The following BASIC program segments show how MLDSPT and ARRSAV/ARRLOD are used. ### Saving Data - 10 DIM A(100) 20 POKE 254,3: REM SET UP MLDSPT 30 POKE 6027,ASC("A"): REM ARRAY NAME 40 POKE 6028,0 50 Z-USR(0): REM SAVE DATA ### Loading Data 10 DIM A(100): REM DEFINE ARRAY BEFORE LOAD 20 POKE 254,4: REM SET UP MLDSPT 30 POKE 6027,ASC("A"): REM ARRAY NAME 40 POKE 6028,0 50 Z-USR(O): REM LOAD DATA ### HOW IT WORKS The commented listings expalin fairly well the operation of ARRSAV/ARRLOD. The idea is to search BASIC's array symbol table for the desired array name. Once located, data is either written from the proper symbol table entry or loaded into the Each entry in the array symbol table is organized as follows: Rute 0 - first character of array name Byte 1 - second character of array name Byte 2 - low order byte of the length of the entry Byte 3 - high order byte of the length of the Information on the number of dimensions in the array and the actual contents of the array follow the first four bytes. Users should be aware that ARRSAV/ARRLOD represents a minimal approach to tape data handling. Completely absent from these routines is any kind of error-checking facility. For example, no indication is given if the name POKEd into locations 6027 and 6028 cannot be found in the array symbol table. No reporting of read errors is performed. Lastly, no checking is done to prevent the destruction of the array symbol table. Error checking and a file-naming mechanism are areas where an experimenter can customize and improve on the ideas presented here. ### NOTES ON THE LISTINGS The listings for MLDSPT and ARRSAV/ARRLOD were made usng a home-brew editor/text formatter and mnemonic assembler. All addresses are assumed to be in hex in order to save typing of the leading \$. The routines are stored in 2708 EPROMs in my system - hence the awkward addresses. The rou-tines may be relocated as long as the table of addresses in MLDSPT is properly updated. Lastly, note that my tape save and load subroutines are also located in EPROM at \$E800 and \$E886. The JSRs to these routines can be replaced with JMPs to KIM routines at \$1800 and \$1873 in that order. However, the KIM tape routines return to the KIM monitor. BASIC will have to be restarted in the command mode from the terminal or keypad. MICROSOFT BASIC MACHINE LANGUAGE DISPATCHER INVOKED BY Z=USR(0). SUBROUTINE NUMBER IS POKED INTO LOCATION \$FE (254). SUBROUTINE NUMBER MUST BE IN THE RANGE 0-127. FETCH SUBROUTINE NUMBER. MULTIPLY BY 2 TO OBTAIN OFFSET INTO ADDRESS TABLE. INVOKE MACHINE LANGUAGE ROUTINE. E020 ASFE MLDSPT LDA FE E02F 0A E038 AA E031 BD3REB LDA PHR LDA FRZA, X E034 48 E035 BD39E0 E83B, X E038 48 E039 60 PHR RTS ``` ; MOVE SYMBOL TABLE ENTRY LENGTH ; TO KIM CHSSETTE ENDING ADDRESS. ; LENGTH FIELDS ARE OFFSET FROM ; START OF ENTRY BY 243 BYTES. ; $1777 & $1778 RRE KIM CRSSETTE ; ADDRESSES. TABLE OF MACHINE LANGUAGE ROUTINE ADDRESSES. NOTE: ENTRY IN THE ADDRESS TABLE IS THE ACTUAL N. L. ROUTINE ADDRESS MINUS ONE. ADDRESSES ARE STORED HI, LO. ±098 B1FC E080 99F517 E090 88 E0° TOUR SEASON E089 R003 TRP2 E098 88 E091 C001 E093 D0F6 . BYTE $E3 ##01 *-10 FØ3B FF TEST FOR MATCH BETMEEN DESIRED RIRRRY NAME ($1788 & $1788) FIND CURRENT SYMBOL THBLE ENTRY NAME. RIRRRY NAME IS 2 CHARRCTERS LONG FIND IS OFFSET 0 & 1 FROM STATE OF SYMBOL THBLE ENTRY. USE THE X REBISTER TO COUNT THE NUMBER OF MATCHED CHARRCTERS. ; BITON - TURN ON GRAPHICS CELL BITOFF-TURN OFF GRAPHICS CELL. . BYTE $E6 . BYTE $C7 FR3F C7 CARRY SET IF NAMES MATCH. CARRY CLEARED IF MISMATCH. ; arrsav-save array data. . BYTE $E0 E095 R200 TRP3 E097 B1FC . BYTE $67 DR BNE NEW BEECH (FC), Y E097 B1FC E099 D98R17 E099 D007 E09E E8 E09F 88 E0R0 10F5 E0R2 38 E0R3 B001 ; ARRLOD-LOAD ARRRY DATA. . BYTE $E0 E042 É0 E043 6E *-11 . LOCATIONS $E044 through $E067 are reserved for future subroutine calls. *+1 ; MICROSOFT BRSIC ARRAY ALMAYS SET POINTER TO MEXT SYMBOL THBLE ENTRY AND SET UP KIM CASSETTE THPE ADDRESSES. $1775. $1776 IS KIM S. R. $1777. $1778 IS KIM E. R. $FC. $FD IS POINTER. NOTE: LENGTH HAS BEEN LOADED INTO F. R. ROUTINE TO SAVE AND LOAD DATA FROM BASIC ARRAYS. SAVE IS ROUTINE NO. 3. LOAD IS ROUTINE NO. 4. POKE THE NAME OF THE ARRAY INTO LOCATIONS $1788 AND $1788. IF THE ARRAY NAME IS ONE CHARACTER PUT $80 IN $1788. IF THE ARRAY IS AN INTEGER ARRAY, SET THE HIGH ORDER BITS OF $1788 AND $1788 TO 1. INTO E. R. E0A6 ASFC TAPS E0A8 8DF517 E0A8 6DF717 FC 17F5 17F7 17F7 E0HB 60F71/ E0HE 80F717 E0H1 85FC E0H3 A5FD E0H5 80F617 E0H8 60F817 E0H8 80F817 (USES $FC RND $FD RS POINTERS.) FĎ ENTRY POINT FOR ARRAY SAVE. DATA IS SAVED WITH ID = 1. X REGISTER WILL CONTAIN $82 IF PROPER SYMBOL TABLE ENTRY WAS LOCATED. OTHERNISE, GO LOCATE AND TEST NEXT ENTRY IN THE SYMBOL TABLE. E068 8991 E068 80F917 ARRSAY LDA #481 7 STA 17F9 BNE #+5 E060 D005 ; ENTRY POINT FOR ARRAY LOAD. ; LOAD WITH ID = $FF. CPX #$82 BNE *-72 E000 E002 . E002 D0B8 LDA MSFF STA 17F9 EØGF R9FF E071 80F917 EXAMINE KIM TAPE ID ($17F9) TO DETERMINE WHETHER TO SAVE OR LORD. PICK UP START OF SYMBOL TABLE FROM $7C, $7D AND STORE IN POINTER REGISTER $FC, $FD. $E886 IS TAPE INPUT. $E880 IS TAPE OUTPUT. RETURN TO BASIC. E074 A57C TAPO LDA E076 85FC STA TC FC TO FD E076 85FC E078 R57D E078 85FD E0C4 RDF917 17F9 E0C4 NOF517 E0C7 C9FF E0C9 D004 E0C8 2086E8 E0CE 68 E0CF 2000E8 E0D2 60 ### ### E886 CMP TEST IF POINTER HAS REACHED END OF SYMBOL TABLE $7E, $7F. RETURN TO CALLER IF END OF TABLE 15 REACHED. JSR RTS JSR E800 RTS E07C R57E E07E C5FC E080 D007 E082 R57F E084 C5FD E080 D001 LORP CHP BNE CHP BNE SNE EE#F8# ``` ### BASIC SPEED REPORT by Harry D. Bolch Lone Star Elec. PO Box 488 Manchaca Tx 78652 Glad to see the 'Notes become your full-time job. When last we talked you were working at MOS Technology. You may recall that we were discussing the possibility of increasing the clock speed on a KIM. I did replace the 6530's with new ones, the 6502 with a 6502A, and the lMHz Xtal with a 2.01 MHz Xtal. To my knowledge, the only eight-bit system that is faster is the OSI system described by Curt Priest of Cambridge, MASS; the 2.01 MHz KIM with the Microsoft BASIC executes benchmark programs more than 25% faster than the fastest 4MHz Z-80 system. ## forth KIMFORTH is moving right along. The source code has been typed in and it assembles correctly and runs!!! FORTH documentation is fairly complete and is now being typed in to the system. Some cassette support software still needs to be added and verified to operate correctly so KIMFORTH isn't quite ready for distribution yet. Getting a software package of this size to market is no easy thing and usually takes more time than one would like. than one would like. You APPLE owners will be happy to hear that, according to the FORTH INTEREST GROUP, Captain Software of Berkeley California is offering a disc-based APPLE-FORTH system that conforms to the "international FORTH standards." It was further stated in correspondence with the FORTH INTEREST GROUP that the programs being offered by Programma Consultants and Seawell Marketing are not true FORTH implementations because, at least in the Programma software, the "innerinterpreter" concept, essential to FORTH, is not implemented. ## focal FOCAL MODS ....speed it up a little... from Bernhard Mulder Mozart Str 1 6744 Kandel West Germany We change the procedure EATCR (and EATCR1) which is called by the findline, which in turn is called from the GOTO, IF, ON, DO command routines. We assume that the carriage return char is in memory and avoid the call of the routine GETC, where switches are tested which will never be set, when we caome from EATCR (start the following routine at \$26D0 in the Aresco version 3D and \$26DD in the "6502 Program Exchange" FCL-65E (V3D). | C 6 | 2 A | ECR1 | DEC | TXTP | ;EATCP1 | |-----|-----|------|-----|---------|--------------------------------------| | A4 | 2 A | EACR | LDY | TXTP | EATCR | | A9 | OD | | LDA | #OD | ;load CR which we are<br>looking for | | DO | 01 | | BNE | TST1 | rooking for | | C8 | | LABL | INY | | ;next character in line | | Dl | 28 | TST1 | CMP | (TXTA). | Y; C.R. found already? | | DO | F8 | | BNE | LABL | ;branch if noy | | B 1 | 28 | | LDA | | Y; store away for others | | 85 | 2 B | | STA | CHAR | -, | | C8 | | | INY | | | | 98 | | | TYA | | ; calculate address | | | | | | | part CR. | | | | | | | | ``` 18 CLC 65 28 ADC TXTA 85 28 STA TXTA 85 33 STA TXA2 A5 29 LDA TXT1 69 00 ADC $00 85 29 STA TXT1 A9 00 LDA $00 85 24 STA TXP2 60 ENCR RTS ``` Make the following changes to Aresco V3D ``` 208D 20 DO 26 (was 20 D7 26) 21FF 20 DO 26 (was 20 D7 26) 22E1 20 DO 26 (was 20 D7 26) 2752 20 D2 26 (was 20 D0 26) ``` or make the following changes to the Program Exchange FCL-65E $\,$ ``` 208D 20 DD 26 (was 20 E4 26) 21FF 20 DD 26 (was 20 E4 26) 22E3 20 DD 26 (was 20 E4 26) 275F 20 DF 26 (was 20 DD 26) ``` Those of you with ROR instructions in your CPU can eliminate the ROR simulator in FOCAL with the following code. Start at \$3291 for the Aresco version 3D Start at \$3293 for the Program Exchange FCL-65E | 7 E | 89 | 00 | ROR1 | ROR | EP4,X | ;need | not | simulate | ROR | |-----|----|----|------|-----|-------|-------|-----|----------|-----| | E8 | | | | INX | | | | | | | DO | FA | | | BNE | ROR1 | | | | | | 60 | | | | RTS | | | | | | Plenty more mods in store for FOCAL. Until ## tiny basic TINY BASIC CASSETTE SAVE & LOAD by William C. Clements, Jr. Univ. of Alabama Chem & Metal Eng. Box 2662 University, Al 35486 University, Al 35486 I recently bought TINY BASIC and the accompanying experimenter's kit, and have enjoyed finding out how the BASIC statements are broken down and implemented. With a little study one can easily pick up the pseudolanguage used to program the inner interpreter, and then all sorts of possibilities exist for custom modifications to suit one's whim. I noticed the comments about transferring BASIC statements to and from cassette tape in 1ssue 13 (Lew Edwards, p. 14), and thought perhaps your readers might be interested in how I added the SAVE and LOAD commands to my version of TINY Can use the existing KIM monitor routines (or any others if one wishes) to save and load programs, and transfer of starting and ending addresses, etc. is handled by a machine language routine. The cassette file number is specified in the added BASIC commands: SAVE X or LOAD X, where X is any integer 0 X 255 corresponding to KIM file I.D.'s 00 through FF. My version of TINY is the one having the cold start at 2000 hex; corresponding address offsets can be added for other versions. The patch to the Intermediate Interpreter is made at relative location 00B7, as shown on p.38 of the Experimenter's Manual. This is address 2827 absolute. The patch is as follows: ; test for keyword SAVE 00B7 8B534156C5 TAPE BC LOAD "SAVE" push start address of LB 29 00BC 09 29 ; save routine onto stack LB OE 00BE 09 OE LB OE ; do it again Q DS OOCO OB ;error stop if file id not number 00C1 C0 BN ; load routine onto stack LB 28 ; go to load routine at 00CA 09 28 J Q ;2928H via above instructions DFLT BV \* 0000 38 00 OOCE AO ' (continue with ' remaining IL code) The constants after the LB commands specify the hex addresses of the machine language routines which handle the SAVE X and LOAD X functions. The line labeled DFLT is thus moved from relative location 00B7 to 00CE, resulting in an offset of 17m or 23m for remaining lines. This must be accommodated in the jump and jump subroutine commands in the I.L. The changes in destination for those instructions which jump beyond the patch are listed. All error messages originating beyond the patch will also be increased by 23m. My version jumps to a pair of machine language routines which initialize the file i.d., SAL, SAH, and the TINY BASIC registers. BASIC files are saved using a Hypertape routine stored in EPROM at location C400H; if the user wishes to use the KIM tape dump routine, he should change the contents of location 2927H to 18H. Appropriate routines can of course be relocated anywhere the user wishes, so long as the correct entry points are provided for in the I.L. patch. After execution of a SAVE or LOAD, TINY must be manually reentered at the warm start (the limits of memory for the BASIC statements are set for my system when BASIC is first entered). A jump to warm start could of course be placed at the end of the tape dump and load routines if ones stored in RAM instead of ROM were being used. These alterations were worth their trouble in added convenience: SAVE 01 is a lot easier than exiting TINY, storing 01 in 17F9, and looking up the memory bounds for the BASIC statements to set SAL and SAH manually. I hope this modification will be of interest to other users of TINY BASIC. MACHINE LANGUAGE ROUTINES USED BY THE PATCH | 2906 | A9 | F9<br>00<br>F1 | | L.<br>S | DA | \$00 | H STEPS COMMON TO BOTH H ROUTINES | |------|----------------------------------|----------------------------------------|----------------|-----------------------|----------------------------|----------------------|-------------------------------------------| | 290E | A5<br>A5<br>BD<br>A5<br>BD<br>A5 | 20<br>F5<br>21<br>F6<br>24<br>F7<br>25 | 17<br>17<br>17 | L<br>S<br>L<br>S<br>L | DA<br>TA<br>DA<br>TA<br>DA | 0020<br>17F5<br>0021 | H<br>H<br>H INITIALIZATION<br>H<br>H<br>H | | | 4C | 00 | C4 | J: | MP | HYPE | RTAPE | | 2928 | | | 29<br>18 | LOAD | | | QQ set 17F9H, 00F1H<br>TPLOAD read tape | | 292E | | E D<br>24 | 17 | ENTER | | | EAL set address<br>0024H at end | | | | EE | | | | | EAH of BASIC | | | | 25 | | | | | 0075H program file | | | 4 C | 03 | 20 | | | JMP | BASIC go to warm start | Restart BASIC at ENTER (loc. $292E_{\rm H})$ after loading. Restart at warm start (2003 $_{\rm H}$ in my version) after saving. Summary of additional modifications to I.L. Code (new transfer statement destination caused by insertion of patch) | Relative Location<br>(See pp. 36-40 TINY | | |------------------------------------------|-----------------| | BASIC Experimenter's | | | Manual) | New Instruction | | | */ | | 0014 | 30 D3 | | 001F | 30 D3 | | .0029 | 30 D3 | | 004B | 30 D3 | | 0052 | 30 D3 | | 0054 | 31 4B | | 0056 | 30 D3 | | 0073 | 30 D3 | | 009E | 30 D3 | | OOBE | 30 EA | | 0004 | 30 EA | | 00C8 | 30 EA | | OOCE | 30 EA | | 00D3 | 30 F9 | | 00D7 | 30 F9 | | 00F7 | 31 47 | | 0114 | 30 D3 | | 0116 | 31 41 | | 0118 | 31 41 | | 0125 | 30 D3 | | 012C | 38 D3 | ### TINY BASIC STRINGS by Michael E Day 2590 DeBok Rd West Linn, Or 97068 Here is the string mod I've been using which I access thru the USR verb. This requires 512 bytes of memory, and is relocatable and will run out of ROM or protected memory except for the storage area which operates out of RAM, however it can be located in any 256 byte block of free memory. PEEK \$ USR(2816,ADDRESS) PEEK at string at the string relative address ADDRESS. Returns decimal value of addressed byte. POKE \$ USR(2822,ADDRESS,DATA) POKE data byte DATA into the string relative address ADDRESS. Returns string relative address INPUT SPS USR(2832.BEGIN.END) INPUT SP\$ USR(2832,BECIN,END) INPUT a string of characters beginning with string relative address BEGIN, echoing back a space with each input character, until a carriage return is encountered, or the ending address END is reached. Returns the string relative ending address plus one. INPUT \$ USR(2839,BEGIN,END) INPUT a string of characters as in INPUT SP\$, but without the space echo. Returns the string relative ending address plus one. PRINT SP\$ USR(2905, BEGIN, END) PRINT the character string beginning with the string relative address BEGIN, and print a space after each character, until a carriage return is encountered, or the ending address END is reached. Returns the string relative ending address plus PRINT \$ USR(2912,BEGIN,END) PRINT the character string as in PRINT SP\$, but without the space echo. Returns the string relative ending address plus one. SEARCH \$ USR(2946, BEGIN, DATA) SEARCH \$ .USR(2946, BEGIN, DATA) SEARCHes for the BCD equivalent of decimal value DATA, beginning at string relative address BEGIN, until a match is found, or the ending address of variable "L" is reached. Returns the string relative ending address plus one. If a match is not found the return address will be 0 (zero). Variable "L" is decremented once per test until match is found, or it is 0. ``` MOVE $ USR(2966,FROM,TO) (Length in variable "L") ``` MOVEs a group of characters of the length in variable "L" beginning at the relative string address FROM, and moving them to relative string address TO, for the length of variable "L". Returns the FROM ending address plus one. Variable "L" is zeroed. (Lower 8 bits only, see notes on addressing of strings) addressing of strings). ### SET POINTERS These are memory formating routines that are addressed by the other routines, and are listed with USR statements only for reference. They do not need to be accessed by TINY. ### OPERATIONAL NOTES OPERATIONAL NOTES Addressing is limited to 0-256 (8 bit addressing) and the upper bits are ignored (I.E. 512 will appear as a 0, and 513 will appear as a 1). The string array table is perminently fixed to 256 bytes in length, and dedicated for this purpose. This table may be located anyplace in RAM so long as intrusion from other sources is not allowed. Relocation is done by changing the page location address at OBAA (OBAA AO OC LDY #000). The routines that access the table are clean. (They are relocatable, and will operate out of ROM or protected memory.) All data passed through the USR statements both to and from is in decimal. The data inside the routines however, remain in BCD. In the PRINT and INPUT routines, if the BEGIN address is less than the END address, an error exit will occur which causes the exit address to be 0, and the function asked for is not performed. If only one address is given, the second address given (I.E. USR(2912 0) will print out a single character at location 0 and return an address value of 1 to TINY. As with any USR statement in TINY, the adress and data information passed through the USR statement can be calculated from any expression. (Such as USR(2912, B,E-2) can be used to print a string starting at the address in variable "B", and using the E-2 to suppress the ending carriage return, and snother variable can be used to prick-up the returning ending address.) The routines given have been located at the The routines given have been located at the end of TINY, as this allows for easy isolation from TINY by revising the user memory starting address located at 028B. 028B A9 0B LDA #0B Old starting address Discourage of the sister only place that TINY references this, so it is the only place that TINY references this, so it is the only thing that needs to be changed. NOTE: A cold start MUST be done after this change to set the pointers, or else they will have to be set by hand. The entire string mod requires less than 512 bytes of memory (256 bytes for the array, and 187 bytes for the routines.) A possible mod would be to place the array page address in zero page memory, and modify it with TINY before going into the routines. This would allow for greater than 256 bytes, but program management must be closely followed, or strange things might happen!!! The cancel code used in TINY will terminate an INPUT \$\frac{2}{2}\$ without putting the character into the array, therefore this code can not be used directly. All previous characters will have been inserted however. PEEK \$ USR(2816,ADDRESS) 0B00 20 A8 0B JSR 0BA8 Set pointers A 0B03 B1 18 LDA (18),Y Pick up data 0B05 60 RTS Return to TINY POKE \$ USR(2822,ADDRESS,DATA) 0B06 20 A8 0B JSR 0BA8 Set pointers A 0B09 91 18 STA (18),Y Store data 0B0B E6 18 INC 18 Increment pointer Return address to TINY Return to TINY LDA 18 | ORIO | 20 | 9 5 | OB | 100 | , DEGIN, E | Set pointers B<br>Clear 1B<br>Goto Input routine | |--------------|------|------|------|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0813 | 84 | 18 | OB. | STY | 1 R | Clear IR | | OB15 | BO | 0.3 | | BCS | OBIA | Goto Input routine | | | | ••• | | | | | | | | | | | | | | INPUT | \$ | | USR | (2839 | , BEGIN, E | Print a "?" Print a "SP" Get a character Is it "ESC"? If so return to TINY Is it "SS"? If so back up Is it begin of array? If so restart Decrement pointer Input SPS? If not get next character | | OB17 | 20 | В5 | OB | JSR | OBB5 | Set pointers B | | OBlA | A9 | 3F | | LDA | #3F | | | OBIC | 20 | 09 | 02 | JSR | 0209 | Print a "?" | | OBIF | A 9 | 20 | | LDA | #20 | | | OB21 | 20 | 09 | 02 | JSR | 0209 | Print a "SP" | | 0B24 | 20 | 06 | 02 | JSR | 0206 | Get a character | | OB27 | CD | 10 | 02 | CMP | 0210 | Is it "ESC"? | | 0 B 2 A | F0 | 28 | | BEQ | OB54 | If so return to TINY | | OB2C | CD | 0F | 02 | CMP | 020F | Is it "BS"? | | OBZF | D O | 11 | | BNE | OB42 | If so back up | | OB31 | A 5 | 1 A | | LDA | 1 A | | | OB33 | C 5 | 18 | | CMP | 18 | Is it begin of array? | | 0835 | FO | E 8 | | REQ | OBIF | If so restart | | 0837 | C 6 | 18 | | DEC | 18 | Decrement pointer | | 0839 | A D | IB | | LDA | OBOL | Input SPS ! | | 0030 | υυ | E/ | | BNL | 0824 | If not get next | | 0020 | 4.0 | 0.12 | 0.2 | T D 4 | 0000 | character | | 00.00 | AD | OF | 0.2 | LDA | 0201 | Get "BS" Print it Store data | | 0540 | 90 | DF | | BUU | (10) V | Frint it | | 0842 | 91 | 18 | | STA | (18),1 | Store data | | | | | | | | | | INPUT | \$ | 1 | JSR( | 2839. | BEGIN . EN! | D) Con't. Is it end of array? If so return to TINY Increment pointer Is it a "CR" If so return to TINY Print a "SP"? If not get next byte Print a "SP" Increment pointer Return exit address to TINY | | 0B44 | E 4 | 18 | | CPX | 18 | Is it end of array? | | 0846 | FO | 0C | | BEQ | 0B54 | If so return to TINY | | 0B48 | E 6 | 18 | | INC | 18 | Increment pointer | | OB4A | C 9 | OD | | CMP | # O D | Is it a "CR" | | OB4C | F0 | 08 | | BEQ | OB56 | If so return to TINY | | OB4E | A 5 | 1 B | | LDA | 1 B | Print a "SP"? | | 0B50 | DO | D 2 | | BNE | OB24 | If not get next byte | | OB52 | F0 | CB | | BEQ | OB1F | Print a "SP" | | OB54 | E 6 | 18 | | INC | 18 | Increment pointer | | OB 56 | A 5 | 18 | | LDA | 18 | Return exit address | | | | | | | | | | 0858 | 60 | | | RTS | | Return to TINY | | PRINT | SPS | τ | JSR( | 2905, | BEGIN, ENI | ) | | 0B59 | 20 | В5 | OB | JSR | OBB5 | Set pointers B | | OB5C | 84 | 1 B | | STY | 1 B | Clear 1B | | OBSE | BO | 03 | | BCS | OB63 | Set pointers B<br>Clear 1B<br>Goto print routine | | | | | | | | | | | | | | | | | | PRINT | \$ | τ | JSR( | 2912, | BEGIN, ENI | )) | | 0860 | 20 | В5 | OB | JSR | 0B5B | Set pointers B | | 0863 | В1 | 18 | | LDA | (18),Y | Pick up data | | 0865 | 20 | 09 | 02 | JSK | 0209 | Print character | | 0868 | E 4 | 18 | | CPX | 18 | Is it end of array? | | OBGA | F C | 11 | | TNC | 10 | II end return to lini | | 0000 | CO | 10 | | CMD | #OD | Increment pointer | | OPTO | E0 | OD. | | DEO | #UD | If so return to TINY | | OB 77 | Δ5 | 1 R | | LDA | 1 B | Print a "SP"? | | 0874 | D O | FD | | RNF | 0863 | If not get next byte | | OB 7 6 | AG | 20 | | LDA | #20 | II not get next byte | | 0B78 | 20 | 0.9 | 0.2 | ISR | 0209 | Print a "SP" | | 0B7B | DO | E 6 | | BNE | OB 63 | Go get next byte | | OB7D | E6 | 18 | | INC | 18 | Increment pointer | | OB7F | A 5 | 18 | | LDA | 18 | Get exit address | | OB7F<br>OB81 | 60 | | | RTS | | Print a "SP" Go get next byte To get next byte To get next byte To get next byte To get next byte To get next byte To get next byte Increment pointer Get exit address Return to TINY Frint a "SP" To get next byte | | | | | | | | | | SEARC | н \$ | | USR | (2946 | ,BEGIN,D | ATA) (Length in var- | | | | | | | | iable "L") | | 0882 | 02 | A 8 | UB | JSR | UBAB | iable "L") Set pointers A Pick up test byte Increment pointer Found match? If so return to TINY Decrement variable L' | | 0885 | RI | 18 | | LDA | (18),Y | rick up test byte | | OB87 | E 6 | 18 | | INC | 18 | Increment pointer | | 0888 | 60 | 1A | | REA | LA<br>DRO3 | round match? | | OBBD | r 0 | 0.0 | | DEC | 00 | Description to TINY | | OB8F | DO | 30 | | BNE | 98<br>0B85 | If not get next byte | | 0B91 | 20 | 18 | | STY | 18 | Clear 18 (pointer) | | OB 93 | | 18 | | LDA | 18 | Return exit address | | 0273 | , | 10 | | DUA | | to TINY | | 0B95 | 60 | | | RTS | | Return to TINY | | | | | | | | | | | | | | | | | | MOVE | \$ | | USR | (2966 | ,FROM,TO | ) (Length in variable | | _ | | | | | , | "L") | | 0B96 | | A8 | OB | JSR | OBA8 | Set pointers A | | 0B99 | B1 | | | LDA | (18),Y | Pick up byte | | 0B9B | 91 | 1 A | | STA | (1A),Y | Store it | | 0B9D | E 6 | | | INC | 18 | | | OB9F | E 6 | 1 A | | INC | 1 A | Increment pointers | | ODAI | | | | | | | INPUT SP\$ USR(2832, BEGIN, END) | OBA3 DO F4<br>OBA5 A5 18<br>OBA7 60 | BNE 0B99 If end return to TINY LDA 18 Return exit address to TINY RTS Return to TINY | SET POINTERS B USR(2997,Y,A) OBB5 20 A8 OB JSR OBA8 Set pointers A OBB8 AA TAX Save end OBB9 A5 18 LDA 18 Recapture begin OBBB 85 1A STA 1A Save it | | |----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | SET POINTERS A OBA8 84 18 OBAA AO OC OBAC 84 19 OBAE 84 1B OBBO AO OO OBB2 85 1A | USR(2984,Y,A) STY 18 Save begin LDY #OC Set array page STY 19 Store array page STY 1B Store array page LDY #OO Clear Y STA 1A Save A | OBBD E4 18 CPX 18 Bad address? OBBF B0 O3 BCS OBC4 If so go error OBC1 68 PLA Discard string 1 OBC3 98 TYA Clear A OBC4 60 RTS Exit | .ink . | | 0884 60 | RTS Exit | READ KEY USR(3064) OBF8 AD 00 CO LDA OCOO Pick up data OBFB 29 7F AND #7F Clear bit 8 (Str OBFD AO 00 LDY #00 Clear Y | obe) | # assembler HDE ASSEMBLER REV 1.1 | LINE | ADDR | OI | JE | CT | SOURCE | | PAGE | 0001 | | |------|------------------------------|----|-----|-----|----------|--------|----------|--------|--------------------------------------------------| | 0010 | 2000 | | | | ATHTS 1 | 18 A | SYMBOL 1 | TABLE | SORT ROUTINE FOR | | | 2000 | | | | ATHE M | DE /AR | ESCD ASS | SEMB) | ER. IT BETS PATCHED | | | 2000 | | | | | | | | D INSTALLED IMMEDIATELY | | 0030 | 2000 | | | | | | | | AT \$F067. | | 0040 | 2000<br>2000<br>2000 | | | | FULLU | TIME | J. FATO | ING | AI Bruo/. | | 0050 | 2000 | | | | * MKT | EN BI | J. FAIL | JVIC | | | 0060 | 2000 | | | | | | | | | | 0070 | 2000 | | | | | | | | | | 0080 | 2000 | | | | FOR TH | IS R | OUTINE 1 | TO OPI | ERATE, CHANGE<br>\$FO RESPECTIVELY. | | 0090 | 2000 | | | | # \$EB9D | AND | SEB9E TO | \$67 | \$FO RESPECTIVELY. | | 0100 | 2000 | | | | , | | | | | | 0110 | 2000<br>0010 | | | | | ¥=\$1 | 0 | | | | 0120 | 0010 | | | | FLAG | *=*+ | 1 | | | | 0130 | 0011 | | | | CADL | | | | | | 0140 | 0013 | | | | NADL | ***+ | 2 | | | | 0150 | 0013<br>0015 | | | | | | - , | | | | 0140 | 0015 | | | | HON | -410 | 14 | | | | 0170 | 0015 | | | | HON | *=\$D | | | | | 0170 | CODE | | | | STSAVE | | | | | | 0180 | OODF | | | | | | | | | | 0170 | 0015<br>00DF<br>00E1<br>00E1 | | | | NSTAT | | | | | | | | | | | SYMLEN | | | | | | 0210 | 00E1<br>0069 | | | | | *=\$6 | | | | | | | | | | SYMPTR | | | | | | 0230 | 006B | | | | | *=\$4 | | | | | 0240 | 004E<br>0050 | | | | NOSYM | *=*+ | 2 | | | | 0250 | 0050 | | | | | | | | | | 0260 | 0050 | | | | | | | | | | 0270 | 0050 | | | | | *=\$F | 067 | | | | 0280 | F067 | | | | | .OFF | 2000 | | | | 0290 | F067 | | | | | | | | | | 0300 | F067 | A9 | 01 | | SORT1 | LDA | <b>1</b> | | F SET FLAG | | 0310 | F069 | 85 | 10 | | | STA | FLAG | | | | 0320 | F06B | | | | | | | | | | 0330 | FO6B | A5 | DF | | | LDA | STSAVE | | FINIT. CURRENT ADR | | 0340 | FO6D<br>FO6F | 85 | 11 | | | STA | CADL | | · · · · · · · · · · · · · · · · · · · | | 0350 | FOAF | A5 | FO | | | I DA | STSAVE+ | | | | 0360 | F071 | 85 | 12 | | | RTA | CADL+1 | • | | | 0370 | F073 | - | | | | 9,,,, | DRDLIZ | | | | 0370 | F073<br>F073 | Δ0 | 01 | | | LDA | 41 | | ; INITIATE POINTER | | 0300 | F075 | 05 | 44 | | | DIA | CVMDTDI | | , INTITALE POINTER | | 0400 | F073 | 40 | 00 | | | 517 | AA | | | | 0400 | F077<br>F079 | HY | 00 | | | | •• | | | | 0410 | 5077 | 83 | 67 | | | SIA | SYMPTR | | | | | F07B | | | | | | | | | | 0430 | F07B | 20 | DA | F 0 | | JSR | AURNS | | ; INIT. ADR OF NEXT SYMBOL | | | F07E | | | | | | | | | | | F07E | | | | | LDY | •0 | | | | 0460 | F080<br>F082 | B1 | 11 | | SORT2 | LDA | (CADL), | Y | | | 0470 | F0B2 | D1 | 13 | | | CMP | (NADL), | Y | | | | F084 | | | | | | | | | | 0490 | F084 | F0 | 2D | | | BEQ | SRT1 | | F IF EQUAL COMP NEXT CHAR | | 0500 | F086 | | | | | | | | | | 0510 | F086 | BO | 33 | | | BCS | REX | | NEXT SYMBOL PRECEDES - | | | F088 | | | | #80 FX | CHANG | E REGS | | ; NEXT SYMBOL PRECEDES - | | | F088 | | | | | | | | • | | | F088 | 40 | 00 | | SORT3 | ı nv | 40 | | | | 0550 | FOBA | 70 | v | | JUKIS | בעז | •0 | | | | | FOBA | 45 | 17 | | | | | | | | | FOBC | | | | | LDA | NADL | | # MAKE ADR OF NEXT SYMBOL -<br>F-CURRENT ADDRESS | | 05/0 | FOBE | 00 | 11 | | | STA | CADL | | ;-CURRENT ADDRESS | | 0380 | FORC | HO | 14 | | | | NADL+1 | | | | 0400 | F090<br>F092 | 63 | 12 | | | STA | CADL+1 | | | | | F092 | 20 | DC. | EΛ | | | | | | | 0810 | 1072 | 20 | אע | FU | | JSK | ADRNS | | | ``` 0620 F095 0630 F095 0640 F095 0650 F097 INC SYMPTR+1 BNE COMP INC SYMPTR INCREMENT POINTER E6 6A D0 04 E6 69 F0 13 0660 0670 0680 F099 F09B F09D F09D F09E F0A0 F0A2 F0A4 0690 0700 0710 0720 0730 0740 0750 0760 0770 0780 CLV LDA SYMPTR CMP NOSYM BCC SORT2 B8 A5 69 C5 4E 90 DC # FIND IF THIS IS THE #LAST LINE COMP LDA SYMPTR+1 CMP NOSYM+1 BCC SORT2 A5 6A C5 4F 90 D6 FOA4 COMP2 FOAB FOAA FOAA FOAC FOAE FOBO FOB3 FOB3 LDA FLAG AND #1 BEQ SORT1 # CHECK IF FLAG SET, IF SET EXIT 0790 0800 A5 10 29 01 0810 0820 FO B7 JMP NSTAT SORT COMPLETED 0830 0840 0850 0860 4C EE EA FINE INY CPY #SYMLEN+2 BNE SORT2 POINT TO NEXT CHAR SRT1 0870 0880 0890 DO CB # ERROR . RETURN TO MONITOR 4C 14 1C JHP HON 0900 0910 0920 # EXCHANGE REGISTERS A0 00 REX LDY #0 B1 11 48 B1 13 91 11 CB CO 08 DO F4 LDA (CADL),Y RX1 0930 0940 0950 0960 0970 0980 0990 1000 1010 PHA LDA (NADL),Y STA (CADL),Y CPY #SYMLEN+2 BNE RX1 88 DEY PLA STA (NADL),Y DEY 1020 1030 1040 68 91 13 88 RX2 10 FA BPL RX2 1050 1060 LDA ##FE AND FLAG STA FLAG 1070 FODO # REBET FLAG 1080 1090 25 10 85 10 JMP SORT3 1100 1110 4C 88 FO 1120 CLC CLD LDA CADL ADC 05YMLEN+2 STA NADL LDA CADL+1 ADC 00 STA NADL+1 ADRNS 1130 1140 1150 D8 A5 11 1160 1170 1180 1190 1200 1210 69 08 85 13 A5 12 69 00 85 14 60 FINISH .END ``` ERRORS = 0000 ## AIM info ### WARNING WARNING WARNING by Leo Scanlon Documentation Manager Rockwell Microelectronic Devices P.O. Box 3669, RC55 Anaheim, CA 92803 As Documentation Manager at Rockwell, I read with interest the article on AIM 65 Manual corrections published on page 20 of 6502 User Notes, No. 14. In this article, reader Jody Nelis recommends using Texas Instruments #TP-27225 thermal paper with the AIM 65. I urge you to warn all readers NOT to use this particular paper type in their AIM 65's. We have found this particular paper to be so highly abrasive that it can ruin the printer head in a matter of hours! In fact, because of experiences with this paper, we mailed a bright red warning to all AIM 65 owners, giving them a list of "approved" paper types. The approved paper types are: 1. Rockwell #TT270 Source: Rockwell Service Center 6001 Threadgill Avenue El Paso, Texas 79924 El Paso, Texas: 79924 Phone (800) 351-6018 - 2. Sears #3974 or #3986 - 3. Olivetti #74707 or #74708 - 4. NCR #T1102 This paper produces black print, the others produce blue print. All other corrections noted in the article have been picked up in a set of change pages that we mailed to AIM 65 owners that returned the Document Registration Form Incidentally, I always appreciate comments, corrections, gripes, etc. from readers of our manuals, and invite them to write to me directly at the address at the top of this article. #### READING KIM CASSETTES from D.R. Something not mentioned in the AIM65 owners manual makes reading KIM tapes impossible. The ID number is the last two digits of the file name. To read file #2B, enter 'xxx2B' in response to the 'F=' prompt. It took me quite awhile to figure it out, and I thought I'd pass it along. See \$E3A4 in monitor listing for code. ### EPROMS FOR AIM I have a modification for AIM 65 to allow use of on-board ROM sockets with 2758\* EPROMS. Use a low profile 24-pin socket and bend legs 18, 19, 20 away from the body. Solder a bridge across 19,20 and then attach 1" wire wrap wire to junction scrap away soder-mask at botton of chip with an exacto knife and solder loose end of wire to exposed spot. Next attach 2½ - 3" piece os WWW to pin 18 and pin 10 of 227. (For use in address range of DOOO - DFFF.) See page 7-10 of AIM 65 User's Manual for pin \$\pi\$ of different CS llines, insert socket and prom. Until the assembler and basic show up the sockets may be used for user programs with single key entry. Jade Computer Products have 2758 EPROMS (Intel +5V only) in stock, and have good service. \*You can do this with TMS 2516, 2716, 2732 etc. ### NOTES ON AIM USER I/O by Larry Goga 3816 Albright Ave Los Angeles, Ca 90066 According to the AIM-65 User's Guide, there According to the AIM-65 User's Guide, there is only one user character input subroutine which will display a cursor, echo a character, and allow the delete key to function. (see Section 7.7.1 in the User's guide.) This subroutine is identified variously as RUBOUT or RDRUB and resides at address E95F in the AIM Monitor. If you have experienced difficulty in getting this subroutines to support the DELETE function do not be alarmed. After consulting Rockwell about this problem it seems that there is more to using this subroutine than meets the eye. The AIM documentation says that RDRUB uses the accumulator and the Y Index Register. Although this is true, what is not explained is that the Y-Index Register must be incorporated into the user's program. If the Y-Index Register is zero when you call RDRUB then the DELETE function will not work. If the Y-Index Register is negative (MBS set) when you call RDRUB then strange things will happen when the DELETE key is pressed. You may also have found that when the DELETE function is working and you attempt to delete beyond the first character display position the program hangs-up and s question mark is shown in the center of the display. The only way out of this problem is "RESET". The solution to these problems is to use the Y-index Register as an input counter. The Y-Index Register should be cleared to zero before calling RDRUB. Then, call RDRUB, and upon returning increment the Y-index Register. In this manner the Y-Index Register will contain a count of the number of characters which have been inputted from the keyboard to the display. This positive count in the Y-Index Register is the number of times the DRLETE key will work (ie. Y=0, no deletes; Y=5, 5 deletes; etc.). The reason for using the Y-Index Register in this manner is that the RDRUB subroutines automatically decrements the Y-Index Register every in this manner is that the KURUB subroutines automatically decrements the Y-Index Register every time the DELETE key is pressed, but does not return from the subroutine until some other displayable character key is pressed. An example of this use of RDRUB and the Y-Index Register will be found on page 35 of the AIM MONITOR LISTINGS. In a subroutine called ADDIN at address EARE we find the Y-Index Register being cleared to zero in line 1668; and, after checking for a carriage return or space, we find the Y-Index Register being incremented at line 1673. After checking for not more than 10 characters inputted, the program loops back to input the next character. By implementing these steps in your program you should find that the DELETE function will work correctly. (Courtesy of the San Fernando Valley 6502 Users ### MEMORY TEST PROGRAM ADAPTED FROM "MEMORY TEST" BY JIM BUTTERFIELD FROM "THE FIRST BOOK OF KIM" MODIFIED TO RUN ON ROCKWELL AIM-65 BY LARRY GOGA ENTERED: 5 JANUARY 1979 REVISED: 6 Jan. 79 NOTE: FOR "FROM" AND "TO" PROMPTS ENTER ONLY THE LOW AND HIGH PAGE LIMITS (HIGH ORDER ADDRESS BYTE) THEM TYPE <CR>. The ultimate Motherboard for any KIM-1, SYM-1, or AIM-65 system ### Features: - 4K Static RAM on board - +5V, +12V, and –12V regulators on board - 4 + 1 buffered expansion slots - Accepts KIM-4 compatible boards - Full access to application & expansion connector - LED indicators for IRQ, NMI, and power-on Also compatible with SEA-1, SEA-16, the PROMMER, SEA-PROTO, SEA-ISDC, and more - Onboard hardware for optional use of a 17 (128K addressing limit) - · Mounts like KIM-4 or with CPU board standing up - 10 slot Motherboard expansion available -SEAWELL's Maxi Mother Introduction price \$99. Regular price \$119. with 4K Static RAM installed \$169. Assembled - 3 month warranty For further information contact: SEAWELL Marketing Inc. P O. Box 17006 Seattle, WA 98107 SEAWELL Marketing Inc. 315 N.W. 85th Seattle, WA 98117 (206) 782-9480 | 0000 | MTEST ORG | 10000 | FID: MTEST | 0075 4 | | ;FLIP | | | OCATIONS - NOW CHANGE 1 IN 3 | |--------------------------|-------------|-------------------------|----------------------------------------|----------|---------|----------|-------|----------------|------------------------------------------| | | | | | 0035 A6 | | | LDXZ | BEGIN | | | | **** NEM | ORY LOCATIONS | ***** | 0037 M3 | | | | | ACET DOINTED BACK TO CTART | | | | | | 0039 85 | | FILL | LDAZ | | SET POINTER BACK TO START | | 0000 | BEGIN * | \$0085 | | 003D CA | | TOP | DEX | FLMU | ; CHANGE VALUE | | 0000 | END * | \$0086 | | 003E 10 | | TUP | | SKIP | CHID 2 OUT OF T | | 0000 | POINTL * | \$0087 | | 0040 A2 | | | LDXIN | | ;SKIP 2 OUT OF 3 | | 0000 | POINTH * | \$008B | | 0042 PI | | | | | ;RESTORE 3-COUNTER<br>;CHANGE OUT OF 3 | | 0000 | FLAG * | \$0089 | | 0044 C8 | | SKIP | INY | LOTAIL | , CHARGE I GOT OF 3 | | 0000 | * COM | \$008A | | 0045 D0 | | 2411 | | TOP | | | 0000 | FLIP + | \$008B | | 0047 E6 | | | | | :NEW PAGE | | 0000 | ADDRL * | \$A41C | | 0049 A5 | | | LDAZ | | :HAVE WE PASSED END OF | | 0000 | ADDRH * | \$A41D | | 004B C5 | | | | | :TEST AREA? | | | | | | 004B B0 | | | BCS | FILL | :NOPE, KEEP GOING | | | ***** SUB | -ROUTINE EQUATE | S ***** | VV 12 DV | , | - ME HOD | | | TEST IT | | | | | | 004F A5 | 5 85 | MEHOR | | | SET POINTER BACK TO START | | 0000 | FROM * | SE7A3 | | 0051 85 | | | | POINTH | JULY TOTALEN BACK TO STAKE | | 0000 | 10 * | \$E7A7 | | 0053 A6 | | | LDXZ | | ;SET UF 3-COUNTER | | 0000 | BLANKT * | \$E83B | | 6055 A5 | | POP | LDAZ | | TEST FOR FLIP VALUE | | 0000 | CRLOW * | #EA13 | | 0057 CA | | 1 41 | DEX | | 2 OUT OF 3 TIMES | | 0000 | MFAIL + | \$EB39 | | 0058 10 | | | | SLIP | OR | | | | | 101 | 005A A2 | | | LDXIM | | :1 OUT OF 3 | | | ***** BEG | IN PROGRAM **: | *** | 005C A5 | | | LDAZ | | TEST FOR FLAG VALUE | | | | . FDOW -DET | I DU DAGE I THEF | | | | | | | | 0000 20 A3 E7 | | | LOW PAGE LIMIT | 005E D1 | | SLIF | | | HERE'S THE TEST | | 0.003 AD 1C A4 | LDA | | | 0090 DC | | | BNE | OUTPUT | ;BRANCH IF FAILED | | 0006 85 85 | | AZ BEGIN<br>Blankt | | 0062 CE | | | INY | | | | 000B 20 3B EB | <b>∄</b> ₽L | | | 0063 DC | | | BNE | POP | | | 000B 20 A7 E7 | JSR | | HIGH PAGE LINIT | 0065 E | | | | POINTH | | | 000E AD 1C A4 | LDA | | | 0067 AS | | | LDAZ | | | | 0011 85 86 | STA | AZ END | | 0069 C | | | | POINTH | | | | | | | 004B B | 0 E8 | | BCS | POP | | | 0013 A9 00 | START LDA | | O POINTERS FOR | | | ; ABOVE | | | ANGE AND REPEAT | | 0015 AB | TAY | | -ORDER ADDRESSES | 004D C | | | DECZ | | CHANGE 1 OUT OF 3 POSITIONS AND | | 0016 85 87 | | AZ POINTL | | 006F 10 | | | BPL | PASS | ;DO MEXT THIRD | | 0018 85 89 | BIGLP STA | | FIRST PASS, =FF SECOND PASS | 0071 A | | | LDAZ | | - THUSDE SI 40 SOD DAGG THE | | 001A A2 02 | | XIM \$02 | | 0073 49 | | | EDRIM | | ; INVERT FLAG FOR PASS TWO | | 001C 86 8A | | | 3 TEST EACH PASS | 0075 30 | 0 A1 | | BMI | BIGLP | | | 001E A5 B5 | | | POINTER TO START OF | **** | | | | A.D.D.I | -CAUS LOW BERED APPRESS | | 0020 85 88 | | AZ POINTH ;TES | I AKEA | | C 1C A4 | UNIPUL | | ADDRL | SAVE LOW ORDER ADDRESS | | 0022 A6 B6 | | KZ END | | 007A A | | | LDAZ | POINTH | ACANE HACH ODDED ADDRESS | | 0024 A5 89<br>0026 49 FF | | AZ FLAG<br>Rin SFF :rev | EDGE FLAC | | D 10 A4 | | STA | ADDRH<br>Crlow | ;SAVE HIGH ORDER ADDRESS | | | | | ERSE FLAG | | 0 13 EA | | JSR | | ATTERIAN MERCAPE AND ADDRESS | | 0028 85 8B | | MZ FLIF ;=FF | FIRST PASS, =00 SECOND PASS | 0082 40 | C 39 EB | .AND D | JMP | | ;BISPLAY MESSAGE AND ADDRESS | | 002A 91 B7<br>002C CB | LLERK SIA | | TE ABOVE FLIP VALUE<br>O ALL LOCATIONS | | | , HRD K | LIUKN | TO AIN | HOUTION | | 002L LB<br>002D DO FB | BNE | | O MEE ENCHITORS | | | | CUD D | ROGRAN | **** | | 002F E6 88 | | CZ POINTH | | | | | CWD F | NUUKAN | ***** | | 002F E8 88 | | XZ POINTH | | | | | | | | | | | | | | | | | | | | 0033 BO F5 | BCS | S CLEAR | | | | | | | | # **KIMSI, S-100** MODIFICATION TO KIMSI TO ADD 4K OF RAM TO MEMORY SPACE BELOW MONITOR by John R. Campbell 6278 Lake Lucerne Dr. San Diego, Ca. 92119 The KIMSI, as originally designed, allow addition of S-100 type interfaces to the KIM-1, but only in the address space from 2000 Hex and up. By making the following changes, 4K of RAM memory can be added to give a total of 4K from 0000 H to 13FF H, which is desireable to have. - 1. The KIMSI is modified by cutting the trace between IC 8A-12 and IC 9B-3. A 7425 Dual 4 input NOR is added in the expansion area and is wired as shown. - This part of the modification enables the KIMSI and disables the KIM-1 for address space from 0000 H through 0FFF H. - 2. The second part of the modification moves the onboard KIM RAH from 0000 through 03FF to 1000 through 13FF. This is done by cutting the trace between IC U4-1 and IC U16-1. The proper place for cutting this trace is on top of the KIM-1 board near where the trace meets U16-1. On top of the board connect IC U16-1 to IC u4-5 and connect a 560 ohm resistor from IC U16~1 to Vcc (+5V) at the common ends of R36, 37, 38 and 35 (all 560 ohm). Last, insert a 4K RAM board into the KIM-SI with a starting address of 0000 H. Note that all 3 steps must be taken. Incidently, the KIMSI diagram has an error: IC 1B-8 is connected to IC 11C-9 and IC9E-10 does not connect to IC 11C-9. The KIMSI is manufactured by Forthought Products, Box 386, Coburg, OR 97401. ### **HUDSON DIGITAL ELECTRONICS, INC.** BOX 120, ALLAMUCHY, N.J. 07820 • 201-362-6574 ### KIM-1 PRODUCTS FROM HDE, INC. ### DM-816-M8 8K STATIC RAM MEMORY This is the finest memory board available for the KIM-1 at any price. Commercial/Industrial quality. All boards are continuously operated and tested for a minimum of 100 hours prior to release. Full 6 month parts labor warranty. ### **DM-816-DI1 8" FLEXIBLE DISK SYSTEM** Available in single and dual drive versions. Includes interface card, power-supply, Sykes controller and drive, cables and manual. File Oriented Disk System software with HDE text editor. ### DM-816-MD1 5" FLEXIBLE DISK SYSTEM Single and dual drive versions include interface/controller, power supply, Shugart drive, cables and manual. Advanced version of FODS software with HDE text editor. Latest addition to HDE peripheral product line. ### DM-816-CC15 MOTHER BOARD A professional mother board for the KIM-1. All KIM-1 functions remoted, includes power on reset. 15 connectors. Provision for Centronics printer interface. Card cage and cabinet configurations available. ### **DM-816-UB1 PROTOTYPE CARD** Designed for ease of special applications development. Handles up to 40 pin dips. ### HDE ASSEMBLER An advanced, two pass assembler using 6502 cross-assembler mnemonics. Free form, line oriented entry. Directives include: .OPTION, .BYTE, .WORD, .FILE, .OFFSET, .END. Output options include: LIST, NOLIST, SYMBOLS, NOSYMBOLS, GENERATE, NOGENERATE, ERRORS, NOERRORS, TAB, NOTAB. Assemble from single or multiple source files. Place source, object and symbol table anywhere in memory. Automatic paging with header and page number. User's manual. Approximately 4K. Loads at 2000 or E000. Specify on order. ### HDE TEXT OUTPUT PROCESSING SYSTEM (TOPS) A comprehensive output processor, including left, right and full justification, variable page length, page numbering (Arabic or U/C and L/C Roman), page titling, string constants, leading and trailing edge tabbing, field sequence modification, selective repeat, selective page output and much more. Over 30 commands to format and control output of letters, documents, manuscripts. User's manual. Approximately 4K. Loads at 2100 or E100. Specify on order. ### HDE DYNAMIC DEBUGGING TOOL (DDT) Built in assembler/disassembler coupled with program controlled single step and dynamic breakpoint entry/deletion facilitates rapid isolation, identification and correction of programs under development. Keystrokes minimized with single letter, unshifted commands and optional arguments. User's manual. Approximately 2K. Loads at 2000 or E000. Specify on order. ### HDE COMPREHENSIVE MEMORY TEST (CMT) Eight separate diagnostic routines test for a variety of memory problems. Each diagnostic, the sequence of execution, the number of passes and halt/continue on error is selected by the user on call-up. Tests include pattern entry and recall, walking bit, data-address interaction, access time and cross talk, simulated cassette load, slow leaks. Suitable for static and dynamic ram. User's manual. Approximately 3K. Loads at 2000 or E000. Specify on order. ### HDE TEXT EDITOR (TED) Complete, line oriented text editor accepts upper or lower case commands. Functions include line edit, line move, line delete, block delete, resequence, append, list, print, locate, set, scratch, automatic/semi-automatic line numbering, lastcommand recall, job command. This editor is supplied with all HDE Disk Systems. User's Manual. Approximately 4K. Loads at 2000 or E000. Specify on order. ### ALL PROGRAMS ARE AVAILABLE FOR LOCATIONS OTHER THAN THOSE SPECIFIED AT ADDITIONAL CHARGE. | | Disk-Note A | Cassette-Note B | Manual Only | Note C | | |-----------------------------------------------------------------------------|-----------------|-----------------------|-------------|---------|--| | HDE Assembler | \$ 75.00 | \$ 80.00 | \$ 5.00 | \$25.00 | | | HDE Text Output Processing System (TOPS) | 135.00 | 142.50 | 10.00 | 15.00 | | | HDE Dynamic Debugging Tool (DDT) | 65.00 | 68.50 | 5.00 | 5.00 | | | HDE Comprehensive Memory Test (CMT) | 68.50 | 3.00 | 5.00 | | | | HDE Text Editor (TED) N/C 50.00 5.00 1 | | | | | | | Note A. Media charge \$8.00 additional per order. Save by combining orders. | | | | | | | Note B. Cassette versions available 2nd qtr. 1979. | | | | | | | Note C. Additional charge for object assemble | ed to other tha | in specified location | IS. | | | ### ORDER DIRECT OR FROM THESE FINE DEALERS: | | | | | LONG ISLAND | | |---|--------------------|------------------------|--------------------|------------------------|-----------------------| | ı | JOHNSON COMPUTER | PLAINSMAN MICROSYSTEMS | ARESCO | COMPUTER GENERAL STORE | LONE STAR ELECTRONICS | | ı | Box 523 | Box 1712 | P.O. Box 43 | 103 Atlantic Avenue | Box 488 | | i | Medina, Ohio 44256 | Auburn, Ala. 36830 | Audubon, Pa. 19407 | Lynbrook, N.Y. 11563 | Manchaca, Texas 78652 | | | 216-725-4560 | 800-633-8724 | 215-621-0052 | 515-887-1500 | 512-282-3570 | # 65XX chip family stuff CPU BUG by Heinz J. Schilling, DJlXK Im Gruen 15 D-7750 Konstanz 16 This evening I was informed by Dr. Karl Meinzer (see BYTE 1/79: "IPS") that something seems to be wrong with the JMP Indirect instruction. I have made some quick tests, and I must inform you that the JMP Indirect is indeed defective! The MOS Programming Manual says (page 141, 9.8.1.): "In the JMP Indirect instruction, the second "In the JMP Indirect instruction, the secon and third byte of the instruction represent the indirect low and high bytes respectively of the memory location containing ADL. Once ADL is fetched, the program counter is incremented with the next memory location containing ADE." ### But this is only correct al long as the location containing ADL is not the last byte of a page! In this special case the incrementation works like a wrap around in the page as the handling of the carry seems to be processed incorrect. The ADL is fetched from the last byte of the page, but ADH is fetched from the first byte of the same page instead of the first byte of the next page. This error occurs with CPU chips from MoS and from Synertec, it will be the same with Rock- So it is wise not to use the JMP Indirect instruction in the form of 6C FF $\kappa\kappa$ . ### 6522 INFO & DATA SHEET CORRECTIONS THE EDITOR In issue #13 we presented a 6522 I/O board design. If you've looked over the 24 page 6522 spec sheet, you've probably commented on the complexity of the device. While I was at MOS Technology, I had occasion to go through the spec sheet and confirm many of the chips operating modes. A number of typographical & operational errors were found and noted, (thanks to feedback from a number of sharp users). Things may make a little more sense after our discussion of the problem areas with the 6522 VIA chip and documentation. page 3 - the peripheral B port is capable of sourcing 3.0 ma (not 30 ma). page 13 - last sentence should read "Bit 7 will be read as a logic 2. page 16 - section 4 should read+"If ACR5=0. T2 acts..." page 24 - the delay time for $^Tsr1$ , $^Tsr2$ , and $^Tsr3$ should be 300 ns minimum and not 300 ns maxi- page 10 - in mode 010, CB1 generates $\underline{9}$ clock pulses for controlling external devices. This is a serious bug in the chip. page 10 - in mode 011, the shift register DOES stop the shifting operation after 8 bits have been shifted in. Reading or writing the shift register resets the Interrupt Flag and initializes the SR counter as well as re-starting the shifting ac- page 11 - in mode 101, CB2 remains at the state of the last bit shifted until a new bit is figure 11 - data becomes valid approx 1.5 usec following the negative transition of CB1. figure 12 - output data is valid on the ri- page 12 - in mode 111, the SR counter sets the SR Interrupt flag each time it counts 8 pulses and DDES disable the shifting function. Perhaps a little explanation on the 6522 ti-Fernaps a little explanation on the 6522 timers is in order. They're different from the 6530 style in that they are full 16 bit counters as opposed to the 6530 style 8 bit counters with prescaling. This gives the 6522 timer the capability for much better resolution (to lus. with a 1 MHZ clock) over the entire range from 1 us. to 65,536 us. (65.5 milliseconds). There are two timers in the 6522, each slightly different in its abilities. Timer 1 can handle normal 16 bit timer functions as well as operating in the "free running" mode, generating a square wave clock on the output of PB7 independent of any processor intervention. Handy for test signals around the workbench as well as for clocking peripheral devices such as A/D's etc. Timer 2 can operate as a pulse counter where it keeps track of negative going pulses coming in on the PB6 line as well as the normal "one shot" interval timer mode. The shift register is probably the most misunderstood function in the VIA. This 8 bit synchronsus serial port was designed to facilitate inter-system communications, not as a "normal" asynchronsus werial I/O port. The serious bug in the shift-register (mentioned previously) makes this function even less useful. There are, however, other uses for the shift register. How about clock or music generation? I did think about using this shift register as the main element in a mini-floppy interface but gave up the idea after an investigation of the timing requirements of the floppy. ### EXTENDING THE RANGE OF KIM-1 TIMER TO 1:32640 many systems based on the 6502 microprocessor many systems based on the 6502 microprocessor e.g. the popular KIM-1, contain one or more firmware timers. When a value K is stored in a specific location, the timer starts a countdown lasting K time periods P, where P can assume 1, 8, 64, or 1024 usec depending on the time location chosen. A typical program using the firmware timer would look as follows: A2 XX LDX, K 8E 06 17 START STX TIMER start timer 2C 07 17 CHECK BIT TIMOUT check if timer finished BPL CHECK if not, check again With K assuming values between 0 - FFhex, the range of the timer is 1:256 (K=0 results in a countdown of FFhex + 1). This timing range may be inadequate for some applications and can be extended to 1:32 %7% by simply adding two statements at the end of the previous program: BNE START The number of time intervals will be now: $\begin{array}{ccc} (K+1) & \frac{K}{2} & 0 & \langle K \langle FFhex \rangle \\ (FFhex+2) & \frac{\langle FFhex+1 \rangle}{2} & K & = 0 \end{array}$ The following table shows the delay introduced by the timer program for selected values of K. These figures do not include the overhead caused by the testing and looping instructions. | KIM-1 | | | | | |----------------|--------|--------|---------|---------| | TIMER LOCATION | 1704 | 1705 | 1706 | 1707 | | INTERVAL P | lus | 8us | 64us | 1024us | | K (HEX) | | | | | | 01 | lus | 8us | 64us | 1024us | | 10 | 136us | 1.09ms | 8.7ms | 13.9ms | | 20 | 528us | 4.22ms | 33.8ms | 541ms | | 40 | 2.08ms | 16.6ms | 133ms | 2.13sec | | 60 | 4.66ms | 37.2ms | 298ms | 4.77sec | | 80 | 8.26ms | 66ms | 528ms | 8.45sec | | AO | 12.9ms | 103ms | 824ms | 13,2sec | | co | 18.5ms | 148ms | 1.19sec | 19.0sec | | 00 | 32.9ms | 263 ms | 2.01sec | 33.7sec | ### SYM AND AIM TIMER LOCATIONS by Marvin L. De Jong School of the Ozarks Point Lookout, Mo 65726 Enclosed find a short table that may be of some use to SYM-1 and AIM 65 owners. Both the SYM-1 and AIM 65 owners. Both the SYM-1 and AIM 65 have 6532 chips which in turn have interval timers that are almost indentical to the timers on the KIM-1. In fact, in many programs written for the KIM-1, one can merely substitute the address given in the table if he is using an AIM 65 or SYM-1. If the program involving a KIM-1 timer is using the interrupt mode, that is, PB7 is connected to the IRQ line or the NMI line, then SYM-1 users are out of luck as far as using the 6532 is concerned. Perhaps they could jumper a lead from the IRQ pin on the 6502, but I am certainly not recommending that without a SYM-1 with which to experiment. The AIM 65 people are still in luck, for the 6532 interrupt is connected on board to the IRQ pin of the 6502. So AIM 65 users can make use of all the KIM-1 programs that use interval timers by substituting the addresses shown in the table. Of course AIM 65 and SYM-1 users can rewrite any timer routine using the 6522 chips that both these systems include. | TIMER | KIM-1 ADR. | AIM 65 ADR. | SYM-1 ADR. | |-------------|------------|-------------|------------| | T0001 | \$1704* | \$A494* | \$A41C** | | T0008 | \$1705 | \$A495 | \$A41D | | T0064 | \$1706 | \$A496 | SA41E | | T1024 | \$1707 | \$A497 | SA41F | | READ STATUS | \$1707 | \$A497 | \$A407 | | READ TIME | \$1706 | SA486 | SA406 | \*Add eight (in hexadecimal) to the address to enable the interrupt feature on the KIM-1 and AIM 65. \*\*The interrupt line on the SYM-1 is not connected. ### USE OF THE RDY LINE TO HALT THE PROCESSOR by Conrad Boisvert Applications Manager Synertek The RDY line, available on the expansion connector, is used to halt the processor. This line is normally high and is driven to the low state in order to halt, and then driven high again to restart. The timing of the RDY line transition must not be random, relative to the processor clock. If it is, then the processor will occasionally fail to re-start. To solve this problem, it is necessary to time the RDY line transitions so that they occur during 01 timing, only. The following circuit can be used to accomplish this: In this circuit, HALT is the low-going signsl indicating that the processor is to be stopped. SOFTWARE AVAILABLE FOR F-8, 8080, 6800, 8085, Z-80, 6502, KIM-1, 1802, 2650. EPROM type is selected by a personality module which plugs into the front of the programmer. Power requirements are 115 VAC, 50/60 HZ at 15 watts. It is supplied with a 36 inch ribbon cable for connecting to microcomputer. Requires 1 ½ I/O ports. Priced at \$145 with one set of software, personality modules are shown below. | Part No. | Programs | Price | |----------|----------------------|---------| | PM-0 | TMS 2708 | \$15.00 | | PM-1 | 2704, 2708 | 15.00 | | PM-2 | 2732 | 25.00 | | PM-3 | TMS 2716 | 15.00 | | PM-4 | TMS 2532 | 25.00 | | PM-5 | TMS 2516, 2716, 2758 | 15.00 | Optimal Technology, Inc. Blue Wood 127, Earlysville, VA 22936 Phone 804-973-5482 # MVM 1024 MICROPROCESSOR VIDEO MODULE KIM-1 GOES VIOEO \$235.00 The MVM-1024 is a video display that departs from the usual DMA page memory structure. Two on-board bi-directional ports hold the cursor position, eliminating the need to use microprocessor registers to form a memory pointer and external RAM to-save the cursor position. The cursor display is a blinking overand under-line. Reverse video characters can be generated independent of cursor function. The MVM-1024 is ideal as a parallel access display. The upper / lower case capability, together with its unique organization make it a natural for text editing applications. The board uses more expensive low-power Schottky logic and low-power memory. Designed for no specific microprocessor, the interface can be adapted to any available microprocessor. It can support separate IN and OUT data buses, or a single bi-directional data bus. P.O. BOX 523 MEDINA, OHIO 44256 (216) 725-4560 OR 725-4568 ## comments... COMMENTS FROM by Les Jacobson 3841 Fetlock Cir. Colorado Springs Co 80918 I have some information which I would like to have you pass on to the other readers of USER NOTES. It may keep them from repeating some of the mistakes which I have made. First, DESPITE the full page ads in October and November issues of BYTE, Commodore is NOT able to supply the KIM-3B, nor the KIM-4, nor the KIM-5 nor the KIM-6. During telephone conversations with their Marketing dept., in December, I was advised that these items would be available after the first quarter of 1979. This (again) despite their ad's statements that ALL of these were available for immediate shipment. Today (March 13th) I phoned them again. This time I learned that Commodore has decided not to construct and offer EITHER NOW OR IN THE FORSEE-ABLE FUTURE any of the above boards. Further inquiry lead me to locate probably the last remaining KIM-6 in the U.S. Falk-Baker Co. in Nutley, N.J. (201) 661-2430, has a limited supply of the KIM-4 motherboards. So does the NCE/CompuMart in Ann Arbor, Mich. (800) 521-1534. In fact, NCE is discounting their remaining KIM-4s and the very few KIM-3Bs that they still have by almost 30%. My intent is to attempt to locate a manufacmy invent is to attempt to locate a manufacturer who can duplicate the KIM-6 so that I can prototype additional memory. With the recent prices for good 2114s having dropped, I believe that 16K of memory should be buildable for less than \$200. It appears that the KIM is not the only thing which Commodore is not supporting. I'm a Senior Software Systems Engineer with the Aerospace division of Ford. My primary work is for the Dept. of Defense but I interface with other government agencies. The other day I visited the National Bureau of Standards in Boulder. Since my interests are software I was immediately involved with their latest experiments and applications. In support of one of their projects, NBS purchased 29 PET computers. Their problem, I learned, was that NOT ONE of these units functioned as advertised. Commodore had been called to correct the problem and hadn't bothered to extend the courtesy of a response. NBS engineers told me that the problems were shoddy workmanship, poor printed circuit board construction, and the use of many sub-standard chips. I was told that NBS had stopped payment on the purchase and was preparing to return all of the units to Commodore. Interestingly enough, the owner of our local Computerland is returning his entire consignment of PETs to Commodore for the identical reason. I support your search for a RPN calculator chip interface for the KIM. RPN is precisely the concept utilized by the large scale machines because of the inherent efficiency. It may mean dedicating up to 4 memory locations to retain precision, but that appears to be trivial. For anyone still wanting to go "glass" TTY instead of the clanking monster, SWTP makes a very nice unit for almost exactly the same price as a working TTY. And it has many more features than the Teletype does. In addition it displays the more reasonable 24 by 80 format which is far more useable unless you don't care that your computer only plays games. I promise not to write often. But I will attempt to keep you posted on my successes and fail- By the way, Micropolis has impressed me the most of any company with their disk configuration and reliability. Has anyone successfully interfaced their hardware to the KIM bus? If so, how about letting the rest of us in on it. Keep up the good work, and thanks for warning the others of the holes in the KIM path. ### ALTERNATE SOURCE FOR OSI BOARDS by Robert F. Solomon 5868 JoAnne Court North Ridgeville, Ohio 44039 GREAT NEWS FOR OSI OWNERS! As most owners of OSI computers know, delivery on OSI boards range from two weeks to infinity; with emphasis on the latter. While attempting to locate a bare OSI 420 board, I found out that DEN Micro Products, 3932 Oakhust Dr., Fort Wayne, In 46815 made OSI compatible boards. I called them and learned they made an 8K RAM board in kit form at a reasonable price. I promptly sent them a money order and received the kit within 5 days. After assembling it and tracing a shorted foil (my fault, not theirs) it worked beautifully. They also make a Real Time clock and a proto board; with a couple more boards just going into production. I am well pleased with their RAM board and love their delivery. Before I go into my present activities, I would like to explain my system. (Mainly to show that I am not working with a super-sophisticated system, but more on the level of what I consider system, but more on the level of what I consider the system of the average tinkerer. I have an OSI system with 16K, video board and cassette interface. It is based on the 404V board. I have an RO-15 Teletype for hard copy. The entire system has been built from kits. My major accomplishment has been to interface the computer to an electronic organ. This is not synthesized music but a case where the computer actually plays the organ. Most of my programming has been in machine language and Tiny Basic. I am now getting Focal up and running. As of right now, Focal appears to be working, but as yet I have not exercised all of the functions to make sure everything works. I hand loaded the entire program from the KIM based listing of the Aresco version 3D. I have all the patches made to make it operate on the OSI. I am planning to summarize these patches and submit an article to NOTES for publication. At present, I am starting work on a PLL FSK interface to operate with the OSI 430 I/O system to up my cassette records to 1000 baud. I plan on publishing this also. I think that is enough rambling for now, I hope my contributions and thoughts will encourage other OSI users to get on the NOTES bandwagon and share their experiences. ### (EDITORS NOTE Bob has just sent in an article on adapting a KIM 6530-003 to the OSI system for the purpose of reading KIM compatible cassettes. That article will appear in #16. Thanks Bob!) ## music ### ADDITIONS TO THE MTU MUSIC SOFTWARE PACKAGE by Bruce Nazarian WD8DRK As promised, here are a few changes you should try to make to Hal Chamberlain's DAC software. I sent these to him and he told me he liked them and would be using them in the demo ROM for the DAC system. I guess being a musician has its advantages!! So, here they are, and you may wish to put these in the User Notes as well. PROGRAM CHANGES FOR KIM4V (For use with the MTU DAC music system) THESE CHANGES WILL CORRECT AN ERROR IN ASSEMBLY | ADDRESS | SHOULD REA | 1 | |---------|------------|---| | 1788 | 3E, not 2E | | | 178D | 3E, not 2E | | | 1792 | 3E, not 2E | | | 1797 | 3E, not 2E | | | 179C | 3E, not 2E | | | 17A1 | 3E, not 2E | | | 17A6 | 3C, not 2C | | | 17AB | 3C, not 2C | | THESE CHANGES ARE SUBJECTIVE MUSICAL CHANGES IN CONTENT...You may like them, and then again, you may not. Your ears will tell you yes or no. hi. | ADDRESS | SUBSTITUTE | ADDRESS. | SUBSTITUTE | |---------|------------|----------|------------| | 179F | 24 for lE | 8800 | 06 for 14 | | 17A9 | 24 for lE | 0092 | 10 for 1E | | 17B8 | 14 for 22 | 009C | 16 for 24 | | 17BE | 30 for 2C | 0204 | 14 for 22 | | 17C2 | 2C for 22 | 0209 | 1A for 28 | | 17C3 | 32 for 2C | 020E | 1A for 28 | | 17D1 | 10 for 1E | 0234 | 1E for 24 | | 17D6 | 10 for lE | 025C | 1E for 24 | | 17DB | 14 for 22 | 0298 | 1E for 24 | | | | 029D | 22 for 24 | Also the following: | 0209 | 18 | 2 C | 2C | 44 | 44 | |------|----|-----|----|----|----| | 02C3 | 18 | 36 | 36 | 4E | 4E | | 02D3 | 18 | 32 | 36 | 4E | 52 | | 02D8 | 48 | 30 | 3C | 4E | 5C | | 02DD | 18 | 40 | 00 | 00 | 58 | | 02E2 | 24 | 3A | 00 | 00 | 52 | | 02E7 | 0C | 36 | 00 | 00 | 4E | | 02EC | 30 | 2 C | 44 | 4c | 52 | THESE CHANGES ARE FOR THE "EXODUS" SONG TABLE IN THE MTU ADVANCED MUSIC SOFTWARE PACKAGE, AVAILABLE FOR THE MTU DAC MUSIC SYSTEM. (K-1002) ABLE FOR THE MTU DAC MUSIC SYSTEM. (K-1002) I don't know if you have seen the article in MICRO, Ish 2 which attempt to explain how to use the DAC music system. It is a good piece of writing, well aimed at people who do not know that much about the semantics of musical part-writing, but ole Armand (Camus, the author) made a few good old-fashioned boo-boos in there...He states address 001D will change the TEMPO of the tune-well, maybe in his software it is, but in the listing I have, the TEMPO byte is location 0016. Also, he states that the execution point may be changed from the beginning (\$0200) to another point as long as you start out with a correct duration byte. Correct, but the addresses are not 0017 & 0018 in my listing...the starting address should be in locations 0014 (SAL) and 0015 (SAH). The little chart he has made regarding the available memory locations and their use in the song tables is right on the money!! Hope you haven't been confused by this. I really was for a few minutes until I dug back in the lisings I had. Maybe there is a difference in the software that was made available with the DAC that Tripp was selling and the one that MTU is doing on their own? ## interface A SIMPLE MICROPROCESSOR INTERFACE CIRCUIT by Cass R. Lewart The following simple and inexpensive interface circuit will let KIM control LEDs, relays or AC operated appliances. The computer ports are directly connected to inputs of SN75492. This is a popular MOS/LED driver IC, described by me in earlier issues of KUN, which can sink up to 200 mA on each of its six outputs. A typical use for this IC is as digit driver in multiplexed LED calculator displays. It can also be used to drive individual LEDs, relays or optocouplers. To calculate the value of load resistors it should be remembered that the voltage drop between any output and ground of SN75492 is 700 mV. The HEP P5002 or Motorola MOC3010/11 is an optocoupler interfacing an infrared emitting diode to a low power Triac. The low power Triac in the optocoupler in turn controls a larger Triac e.g. HEP R1723 to turn on and off AC appliances, motors, heaters, etc. If more than 6 ports of a computer are being used for control, additional SN75492s can be installed. The same port can also drive more than one output e.g. an AC load via an optocoupler and an LED as activity indicator. ## KIM SOFTWARE ON CASSETTE We know that you have better things to do with your time than punching hex code into your machine. Because of this, we have made some of the longer programs available on KIM cassette. These cassettes are original dumps, not copies, made with top quality 5-screw housing cassettes in the standard KIM tape speed. Thirty seconds of sync characters precede the program to enable you to tune up your recorder or PLL. Are you AIM & SYM owners interested in having some of these programs available for your machines? 6502 USER NOTES, POB 33093, N. Royalton Ohio 44133 ### OUR PRESENT OFFERINGS INCLUDE: | KIMATH (specify \$2000 or \$F800 version)\$12.00 (includes errata sheet for manual) | |-------------------------------------------------------------------------------------| | HEXPAWN (from issue #13)\$5.00 | | DISASSEMBLER (from issue #14)\$5.00 | | BANNER (from issue #14)\$5.00 | | PAYMENT MUST BE IN U.S. FUNDS | OVERSEAS CUSTOMERS PLEASE INCLUDE \$1.00 EXTRA PER CASSETTE FOR EXTRA POSTAGE. #### PET 8K \$ 695 PET 16K NEW Full-size Keyboard \$ 890 PET 32K NEW Full-size Keyboard \$ 1065 PET Dual Disk (343,000 bytes online) \$ 1160 PET Printers (May 1979 availability) 2021 Electrostatic \$ 495 \$ 890 2022 Tractor Feed 2023 Pressure Feed \$ 760 KIM-1 \$ 159 2 SYM-1 \$ 238 6 KL-512 Power Supply for KliM, SYM, and extra RAM 6 Memory Plus \$ 238 6 \$ 95 KIM-4 Motherboard Synertek ROM BASIC \$ 139 Synertek KTM-2 Keyboard Terminal \$ 290 Problem Solver KM8B KIM RAM \$ 149 SEA-16 -- NEW 16K Static RAM \$ 325 Uses new MOS Tech. very low power 2114 (1.35 amp/16K). For SYM, AIM, KIM \$ 99 Seawell Buffered Motherboard Assembled, with space for 4K RAM. For SYM, AIM, KIM Other Seawell products available soon. ### CASSETTE TAPES | Premium quality, low noise, in 5 screw housing.<br>Includes labels All tapes guaranteed | | | | | |-----------------------------------------------------------------------------------------|-----------|--|--|--| | C-10 10/5.95 50/25.00 100/48. | 00 | | | | | C-30 10/7.00 50/30.00 100/57. | 00 | | | | | Norelco-style hard cassette boxes | 10/1.25 | | | | | Soft poly cassette boxes | 10/1.00 | | | | | 2716 (Intel) or 2516 (TI) +5V EPROM | \$ 45 | | | | | 2114 L NEW low power MOS Technolog | y \$ 6.95 | | | | | 6550 RAM (for Commodore PET) | \$ 16.20 | | | | | 5522 VIA or 6520 PIA | \$ 10.50 | | | | | 6500 Programming Manual (MOS) \$ 6.50 | | | | | | 5500 Hardware Manual (MOS) \$ | | | | | | First Book of KIM | \$ 8.95 | | | | | Programming a µComputer: 6502 Foster | \$ 8.95 | | | | | Programming the 6502 R. Zaks | \$ 9.95 | | | | | KIM Microchess (Jennings) | \$ 13.00 | | | | | PET Microchess (Jennings) | \$ 17.95 | | | | | | | | | | Write for: 6502 and S-100 product list PET Software List A B Computers 215-699-8386 115 E. Stump Rd. Montgomeryville, PA 18936 # 6502 CONSULTING SERVICE HAVE COMPUTER/WILL CONSULT CALL ERIC (216) 237-0755 ### REVIEWS ETC. REVIEW: Programming the 6502, by Rodnay Zaks (SYBEX, 305 pp.) review by Jim Butterfield The 650X community is in need of good reference and/or tutorial books on their chip. Unfortunately, this book doesn't make the grade. There are too many mistakes and oversights in the book to make it serve as a useful reference or teaching guide. Some of the problems are relatively minor goofs that may be corrected in a future edition: for example, page 15 notes that binary 10000000 equals a value of minus zero (!), and page 181 says (twice!) that the BIT instruction uses relative addressing. More seriously, themseems to be a lack in the author's depth of understanding. Exercise 3.17 asks the reader, "Why is the return from a subroutine so much faster than the call?" Why indeed? The 6502's JSR (Jump Subroutine) and RTS (return from subroutine) in fact bave identical execution speeds. On the same subject, Zaks suggests that a handy way for a calling program to pass parameters to a subroutine is through the stack. He doesn't mention the formidable coding problems that this creates. Zaks doesn't seem to realize the important difference in indexing behaviour between zero-page and absolute modes, namely that zero-page indexing zan be used to achieve a negative index value. Inyway, he doesn't mention it; indeed, he makes little mention of zero-page indexing except to state that only the X register can be used as an index (which is, once again, wrong). The list of problems goes on. Several examples are incorrect, and on at least one occasion, insult is added to injury by having an explanation of how the incorrect code works. Perhaps the biggest problem is that Zaks doesn't seem to like the 6502. His tutorial style is to outline features he thinks "good" processors should have, and then conclude that the 6502 has a poor capability in that area. The word, "unfortunately", occurs over and over again indescribing the 6502: Unfortunately, it doesn't have both ADD and ADC; unfortunately it can't test bits in sequence (whatever that is); unfortunately, the 6502 has very few internal registers; unfortunately, only the A register can be shifted...the list goes on. on. It reaches a climax on page 182 where Zaks first details indirect addressing on the 6502. He does this with seven sentences criticizing the way it's done. This is followed by, "In fairness, it should be noted that few microprocessors provide any indirect addressing at all." Faint praise indeed for one of industry's biggest-selling microprocessors. A beginner reading this book might wonder whether he's made a mistake in opting for the 6502. Nowhere does the book mention the chip's speed and versatility. Does the book have anything going for it? It covers the instruction set quite well, with addressing modes outline somewhat patchily. Many of the coding examples are well set out and explained. Interrupts are dealt with in a rather rough manner, and support chips are passed over briefly. These are eight pages of good appendices, and a thorough index. It's still hard to find material dealing with the 6502. If you're desperate, this book will be of some help. ### PRODUCT REVIEW THE SEAWELL MARKETING 16K RAM BOARD The SEA-16 is a KIM-4 compatible 16K Static RAM card from SEAWELL MARKETING, 315 N.W. 85th, Seattle, WA 98117 (206) 782-9480. The card has been designed to fit in the standard KIM-4 backplane and cannot be used in the new HDE motherboard. The SEA-16 is a really nicely done board with solder-masking on both sides and labeling of all I.C.'s and DIP switches. All of the 32 RAMs were socketed with lowprofile Augat sockets (the good ones) which seemed indicative of the overall high quality of workmanship involved here. Unfortunately, the documentation that accompanied this otherwise nicely done board consisted of a copy of the schematic and nothing else. I was left to decide for myself which way the write enable and bank select switches should be positioned for proper operation. Also, one of the RAMs failed almost immediately which indicated that this board had not been burned in at all. In a phone conversation with Seawell Marketing shortly thereafter I was assured that this board had somehow "sneaked" past the usual burn-in procedure. It was further stated that the regular documentation package had just been printed up and I would receive it along with a replacement 2114 very shortly. That was over a month ago and I still haven't received anything. Seawell Marketing has done an otherwise first class job on this \$325 RAM board except for the two points that I mentioned. Maybe they'll have gotten their act together by the time you read this. ERIC ### NEW PRODUCT SPEAK & SPELL (TM) INTERFACE KIT If you were wondering whether or not the new Texas Instruments' SPEAK & SPELL learning aid could be hooked up to a computer-wonder no longer! For apparently it already has been done. After following up on an ad that was placed in ON-LINE\*, I found out that Dave Kemp of East Coast Micro Products (1307 Beltram Ct, Odenton, MD 21113) is offering the SP-1, a bidirectional interface to the Speak & Spell for \$49.00. According to the flyer, "It (the SP-1) allows the computer to read speech data as it is being fetched from onboard ROM by the synthesizer, and it allows the computer to transfer data directly to the synthesizer to produce computer generated speech or sound effects." I hope to be reviewing the SP-1 in an upcoming issue. It's really exciting to consider the possibilities of an under \$100 digital speech synthesizer interface. According to the information I received, the SP-1 will interface to a 6522 and includes some 6502 driver software (SYM). \*ON\_LINE is a computer classified ad newsletter. For more info, contact Dave Beetle, publisher, 24695 Santa Cruz Hwy., Los Gatos, CA 95030 ## KIM-1 EXPANSION - KIM-4 Motherboard \$119.00 8K Static RAM \$169.00 8K PROM Board \$165.00 - KIMSI S-100 Motherboard \$165.00 8K Static RAM \$197.00 32K Static RAM \$599.00 64 Character/line Video \$149.00 - KEM S-100 Motherboard \$155.00 includes sockets for 4K 2708 on board 64 Character/line Video Module \$235.00 8K Static RAM \$197.50 - HDE Floppy Disk - PROM Programmers All items are available from stock. P.O. BOX 523 Medina, Ohio 44256 (216) 725-4560 **BOX 120** ALLAMUCHY, N.J. 07820 201-362-6574 ### HUDSON DIGITAL ELECTRONICS INC. ## **JUST THINK OF IT!** **YOUR KIM-1** — No longer limited to those long cassette saves and loads. YOUR KIM-1 — Backed up by 8K static ram so conservatively designed, well manufactured and thoroughly tested, HDE includes a no-nonsense, unconditional, 6 months parts and labor warranty. (Excluding misuse). YOUR KIM-1 — Transformed into one of the most powerful 6502 development systems available today. HDE, INC. supports the KIM-1 with 8" and 5" single and dual drive disk systems, prototyping cards, card racks, desk top cabinets, motherboards, and the finest memory board available, anywhere, at any price. ### AND THIS IS JUST FOR STARTERS . . . Consider: A fast, 2 pass assembler; a complete line oriented editor; a comprehensive text output processing system; an efficient dynamic debugging tool; and, a memory diagnostic package so thorough it's the basis of our memory warranty. Plus, after the sale support that you've known you deserve, but just couldn't seem to get - until now. And, HDE products are KIM-1, KIM-4 compatible. All boards include an oversized 5 volt regulator and address selection switches, in a state-of-the-art 4.5" X 6.5" format, designed, manufactured, and tested for commercial/industrial application. HDE products -- built to be used with confidence. ### **AVAILABLE FROM THESE FINE DEALERS:** JOHNSON COMPUTER PLAINSMAN MICROSYSTEMS Box 523 Box 1712 Medina, Ohio 44256 216-725-4560 Auburn, Ala. 36830 800-633-8724 ARESCO P.O. Box 43 Audubon, Pa. 19407 215-631-9052 LONG ISLAND COMPUTER GENERAL STORE LONE STAR ELECTRONICS 103 Atlantic Avenue Lynbrook, N.Y. 11563 516-887-1500 Box 488 Manchaca, Texas 78652 512-282-3570