#### PERIPHERAL EXPANSION SYSTEM Theory Of Operation And Technical Training Manual TEXAS INSTRUMENTS MAKES NO WARRANTY, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR PARTICULAR PURPOSE, REGARDING THIS LITERATURE OR ANY INFORMATION DERIVED THEREFROM AND MAKES SUCH MATERIALS AVAILABLE ON AN "AS-IS" BASIS. IN NO EVENT SHALL TEXAS INSTRUMENTS BE LIABLE TO ANYONE FOR SPECIAL, COLLATERAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES IN CONNECTION WITH OR ARISING OUT OF THE PURCHASE OR USE OF THIS LITERATURE AND SOLE AND EXCLUSIVE LIABILITY TO TEXAS INSTRUMENTS, REGARDLESS OF THE FORM OR ACTION, SHALL NOT EXCEED THE PURCHASE PRICE OF THIS BOOK. MOREOVER, TEXAS INSTRUMENTS SHALL NOT BE LIABLE FOR ANY CLAIM OF ANY KIND WHATSOEVER AGAINST THE USER OF THIS MATERIAL BY ANY OTHER PARTY. #### UPDATE TRACKS 07/13/82 \* Corrected VDP and GROM addresses. Ø9/Ø3/82 \* Updated pinouts to include Second Generation CPU bits. # TI 99/4 PERIPHERAL EXPANSION TECHNICAL TRAINING COURSE OUTLINE This outline will serve the repair technician both as a guide to the portions of the Peripheral System Theory of Operation which are applicable as service information, and as a syllabus for a series of peripheral repair training sessions. The apparent breaks in consecutive numbering are due to planned omission of subjects not related to repair. The Theory of operation, however, will be provided unedited since some individuals may be interested in system design considerations as an extra curricular activity. It is recommended that review of this theory of operation be accomplished along with a detailed study of the applicable system schematics. | SECTION | DESCRIPTION / CONTENT | PAGE | |----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 1.Ø<br>1.1<br>1.2<br>1.2.1<br>1.2.2<br>1.3<br>1.3.1<br>1.3.2<br>1.3.3<br>1.3.4<br>1.4<br>1.5 | CPU REQUIREMENTS GENERAL COMMENTS 99/4A MEMORY SPACE ORGANIZATION READ BEFORE WRITE CONSIDERATIONS COMMAND MODULE MEMORY SPACE 99/4A CRU SPACE DEFINITION DISALLOWED INSTRUCTIONS CRU OUTPUT DEFINITION CRU INPUT DEFINITION SPARE CRU BIT USE PERIPHERAL POLLING INDICATOR LED DEVICE SERVICE ROUTINE ROMS EXPANSION BOX REQUIREMENTS (BOX/CABLE SCHEMATICS) | 1-1<br>1-1<br>1-2<br>1-3<br>1-4<br>1-4<br>1-4<br>1-7 | | 2.1<br>2.1.1<br>2.1.2<br>2.2 | EXPANSION BOX REQUIREMENTS (BOX/CABLE SCHEMATICS) SYSTEM BUS REQUIREMENTS REMOTE DATA BUS DRIVER BURN IN CONSIDERATION POWER ALLOCATION SYSTEM BUS PIN DEFINITION | 2-1 | | 3.1<br>3.2 | GENERAL HARDWARE REQUIREMENTS PURPOSE TESTING DESIGN RULES | 3-1<br>3-1<br>3-2 | | 4.Ø | RS232 PCB, 99/4B AND JOHNNY BOX (UPDATE TRACKS) | | | SECTION | DESCRIPTION / CONTENT | PAGE | |------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------| | 5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.10.1<br>5.10.3<br>5.10.4<br>5.11<br>5.12<br>5.13 | RS232 ELECTICAL DEFINITION ORGANIZATION GENERAL KNOWN 99/4A TO 99/4B SOFTWARE INCOMPATIBILITIES 99/4A - 99/4B DETERMINATION DESIGN VERIFICATION TEST CONSIDERATIONS LED INDICATOR PARALLEL PORT DSR ROM CRU DEFINITION FIRST RS-232 PCB SECOND RS-232 PCB LED INDICATOR BIT CRU BIT DEFINITIONS INTERRUPTS | | | 6.1<br>6.2<br>6.3<br>6.4<br>6.5<br>6.6<br>6.7<br>6.8<br>6.9<br>6.10 | P-CODE ELECTRICAL DEFINITION ORGANIZATION GENERAL KNOWN 99/4B AND 99/4X SOFTWARE INCOMPATIBILITIES SOFTWARE REQUIREMENTS DESIGN VERIFICATION TEST CONSIDERATIONS DSR ROMS REMOTE DATA BUS DRIVER CONTROL GROMS CRU DEFINITION CRU BIT DEFINITION SYSTEM BUS I/O CONNECTOR PIN DEFINITION | 6-2<br>6-2<br>6-2<br>6-2<br>6-3<br>6-3<br>6-3<br>6-4<br>6-4<br>6-5 | | 7.0<br>7.1<br>7.2<br>7.3<br>7.4<br>7.4.1<br>7.5<br>7.6<br>7.7<br>7.8<br>7.9<br>7.10<br>7.11 | P-CODE THEORY OF OPERATION GENERAL DESCRIPTION DSR ROMS GROM ARRAY PROGRAMMABLE LOGIC ARRAY MMI PAL12L6 DEFINITION SYSTEM READY CONTROL CRU OUTPUT REGISTER ADDRESS AND DATA BUS BUFFERS SPECIAL CONSIDERATION POWER ANALYSIS MNEMONIC DEFINITIONS P-CODE PAL12L6 | 7-1<br>7-1<br>7-1<br>7-2<br>7-4<br>7-5<br>7-5<br>7-5<br>7-5<br>7-6<br>7-11 | | SECTION | DESCRIPTION / CONTENT | PAGE | |--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | 8.1<br>8.2<br>8.3<br>8.4<br>8.5<br>8.6<br>8.7 | EXPANSION BOX MEMORY MEU INTENT GENERAL ADDRESS ORGANIZATION MEMORY SPACE DECODE REFRESH DRAM ARRAY DEVICES REMOTE DATA BUS DRIVER CONTROL | 8-3<br>8-3<br>8-3<br>8-4<br>8-4<br>8-4<br>8-4 | | 9.1<br>9.2<br>9.3<br>9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4<br>9.5<br>9.5.1.1<br>9.5.1.2<br>9.5.1.3<br>9.5.1.4<br>9.5.2 | MEU TEST REQUIREMENTS GENERAL TEST PHILOSOPHY GENERAL COMMENTS BARE ETCH TESTING ASSEMBLED PCB TESTING MARCHING PATTERNS CHECKBOARD PATTERN VOLTAGE PARAMETRICS POWER SUPPLY LEVELS BURN IN TEST PATTERNS GALPAT ADDRESS COMPLEMENTATION SLIDING DIAGONAL RANDOM ADDRESS/DATA CHECK POWER CYCLING ERROR DATA LOGGING | 9-1<br>9-1<br>9-1<br>9-1<br>9-2<br>9-2<br>9-2<br>9-3<br>9-3<br>9-3<br>9-4<br>9-5<br>9-5 | | 10.1<br>10.2<br>10.3<br>10.4 | MEMORY EXPANSION UNIT THEORY OF OPERATION PURPOSE APPROACH MEU SCHEMATIC SEGMENTATION TERMS USED TMS 4116 DRAM FUNDAMENTALS GENERAL REMARKS RAS* CAS* W* SUPPLY CURRENT REQUIREMENTS OUTPUT DATA INPUT DATA INPUT DATA REFRESH CLOCKING SCHEME ADDRESS SPACE SYSTEM BUS BUFFERS ADDRESS BUS DATA BUS CONTROL LINES DRAM SEGMENTATION ADDRESS MULTIPLEXER | 10-1<br>10-1<br>10-1<br>10-2<br>10-2<br>10-2<br>10-2<br>10-3<br>10-3<br>10-3<br>10-3<br>10-4<br>10-4<br>10-4<br>10-4 | | SECTION | DESCRIPTION / CONTENT | PAGE | |---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | 10.12<br>10.13<br>10.13.1<br>10.13.2<br>10.14<br>10.15 | REFRESH LOGIC RASØ/RAS1 SELECTION DATA CONNECTIONS DATA TO DRAM DATA FROM MEU TEST CONSIDERATIONS EARLY WRITE MEU OPERATION, GENERAL COMMENTS MEU IDLE STATE FIRST CYCLE CALCULATED POWER REQUIREMENTS TTL POWER REQUIREMENTS MOS POWER REQUIREMENTS | 10-6<br>10-6<br>10-7<br>10-7<br>10-7<br>10-7<br>10-8<br>10-8<br>10-8<br>10-9<br>10-10<br>10-10<br>10-11 | | 11.2<br>11.3<br>11.4<br>11.5<br>11.6<br>11.7<br>11.7.1<br>11.7.2<br>11.8<br>11.9<br>11.10<br>11.10 | SD DISK CONTROLLER ELECTRICAL SPECIFICATIONS DISK CONTROLLER PCB GENERAL KNOWN 99/4A AND 99/4B SOFTWARE INCOMPATIBILITIES TESTABILITY DESIGN VERIFICATION DSR ROM DISK CONTROLLER CRU DEFINITION CRU OUTPUT BIT DEFINITIONS CRU INPUT BIT DEFINITION SYSTEM INTERFACE FOR WD 1771 DATA/CLOCK SEPERATOR MOTOR DRIVE KEEP ALIVE WD 1771 CRYSTAL OSCILLATOR INTERRUPTS CONNECTORS I/O CONNECTOR GROUND RETURNS RECEIVER PULL-UP RESISTORS I/O DRIVERS I/O RFI CONSIDERATIONS DISK DRIVE I/O PORT DEFINITION SYSTEM BUS PIN DEFINITION | 11-3<br>11-4<br>11-4<br>11-4<br>11-5<br>11-5<br>11-5<br>11-6<br>11-6<br>11-6<br>11-6<br>11-7<br>11-7<br>11-7 | | 12.Ø<br>12.1<br>12.2<br>12.2.1<br>12.2.2<br>12.2.3<br>12.2.4<br>12.2.5<br>12.2.6<br>12.2.7<br>12.2.8<br>12.2.9<br>12.2.1Ø | DISK CONTROLLER THEORY OF OPERATION PURPOSE AREAS OF INTEREST PLA AND SUPPORT LOGIC WESTERN DIGITAL 1771 DISK CONTROLLER CHIP READY CONTROL DSR ROMS / 1771 TRAP DRIVE SIDE SELECT CRU OUTPUT CRU INPUT BUS DRIVERS INTERRUPTS MASTER OSCILLATOR | 12-1<br>12-1<br>12-1<br>12-2<br>12-2<br>12-2<br>12-2<br>12-2 | | SECTION | DESCRIPTION / CONTENT | PAGE | |-----------|----------------------------------------|------| | 12.2.11 | DATA/CLOCK SEPARATOR | 12-3 | | 12.2.11.1 | STEERING LOGIC | 12-3 | | 12.2.11.2 | SWITCHING LOGIC | 12-4 | | 12.2.11.3 | MISSING CLOCK COMPENSATION | 12-4 | | 12.2.11.4 | MISSING CLOCK COUNTER | 12-4 | | 12.3 | PAL LOGIC DEFINITION | 12-4 | | 12.4 | MNEMONIC DEFINITIONS | 12-6 | | 13.Ø | SPEECH SYNTHESIZER THEORY OF OPERATION | 13-1 | | 13.1 | PRINCIPLE OF OPERATION | 13-1 | | 13.2 | TMC Ø285 SPEECH SYNTHESIS IC | 13-1 | | 13.3 | TMC Ø35Ø PHRASE ROMS | 13-1 | | 13.4 | OPERATIONAL DESCRIPTION | 13-2 | #### SECTION 1 ## CPU REQUIREMENTS #### 1.1 GENERAL COMMENTS The purpose of these notes is to outline considerations necessary or advisable for Hardware interfacing peripherals to the 99/4. If this interface is to be through the Peripheral Expansion unit, the rules become more complex due to the fact that two different processors may be used to drive the PEU. It will obviously be to TI's advantage if the involved peripheral will function correctly with both processors. To make matters worse, the timing of the second generation processor has not been published. I think I can safely say that ROM and SRAM based designs will work with either case, but designers of DRAM based logic beware! Required 99/4 timing is shown in the TI 99/4 TECHNICAL DATA manual, and another separate document is available to detail the Software requirements for peripheral interfacing. #### 1.2 99/4 MEMORY SPACE ORGANIZATION The memory map of the TI 99/4 is as follows. The allocated spaces are shown in parentheses, and the actual memory space used is shown where applicable. This is notable of the Memory Mapped Devices (MMD) in the >8000 to >9FFF space. All of these devices live in 1K blocks, and block decoding is used to select them. Even though they are shown to respond at the base address, they will respond ANYWHERE in the 1K block assigned to them. This is certainly true of the 128 BYTE SRAM which is decoded to respond at a base of >8000, but it is noted in the literature to respond at a base of >8300. Software is written to conform to the latter base. The point I am trying to make is that there is a given amount of wasted space, BUT YOU CANNOT TAKE ADVANTAGE OF IT BECAUSE OF THE BASIC SPACE DEFINITION AND THE DECODING USED ON EXISTING PRODUCTS. 1.2.1 READ Before WRITE Considerations. Note also that there are different READ and WRITE addresses for most of the MMDs. This is because the TMS9900 does a READ operation at the destination address prior to writing to it. Many of the MMDs have internal address registers that auto-increment after either a READ or WRITE operation, and this 9900 characteristic, if unchecked, rarely produces the desired results. The READ before WRITE exists because the 9900 is a word oriented machine from a memory access standpoint. The several BYTE oriented instructions are carried out by the machine in a WORD world, and the other BYTE in the WORD must not be altered. The machine itself must save the unaltered BYTE, concatenate the new BYTE with it, and then return the WORD to memory. The internal logic of the TMS9900 is such that it was to the designer's distinct advantage to do this same READ before WRITE on both BYTE and WORD moves. While this is an easy design fix, it certainly is nice to know the problem exists prior to any design effort. 1.2.2 Command Module Memory Space. The Command Module Memory Space must be treated as logically connected to the Command module port only. The GROM chips are rather poor line drivers at best, and their life on the I/O Data Bus is limited. Even though the GROM Data Bus is connected directly to the I/O Data Bus currently, there is no guarantee that updated versions of the 99/4 will have the same connection. I think one can safely say that new generation products will isolate the GROM Data Bus from the I/O Data Bus. DON'T TRY TO ACCESS THE COMMAND MODULE MEMORY SPACE FROM THE I/O PORT! | 99/4 Memory Map | |-------------------------------------| | >0000 | | Console ROM (8K BY) >1FFF | | | | >2000 | | Used by 32K Mem Exp (8K BY) >3FFF | | | | >4000 | | DSR ROM Space | | (8K BY) >5FFF | | | | >6000 | | Command Module Memory <br> Space | | (8K BY) >7FFF | | 99/4 Memory Map, Cont | |--------------------------------------------------------------| | >8000<br> Console 128 Byte RAM<br> (1K BY) >83FF | | >8400<br> Sound Chip, 1 BY req'd<br> (1K BY) >87FF | | >88ØØ<br> VDP READ, 2 BY req'd<br> (1K BY) >8BFF | | >8CØØ<br> VDP WRITE, 2 BY req'd<br> (1K BY) >8FFF | | >9000<br> Speech Module READ<br> Space<br> (1K BY) >93FF | | >94ØØ<br> Speech Module WRITE<br> Space<br> (1K BY) >97FF | | <br> >9800<br> GROM READ, 2 BY req'd<br> (1K BY) >9BFF | | >9CØØ<br> GROM WRITE, 2 BY req'd<br> (1K BY) >9FFF | | >AØØØ<br> Used by 32K Mem Exp<br> (24K BY) >FFFF<br>+ | ## 1.3 CRU SPACE DEFINITION As is with the Memory Space decoding, the CRU Space devices are not fully decoded. Thus, most devices will respond just as well to other addresses in their block as they will to the block base address. By and large, the CRU space is allocated to peripherals with only a very small amount devoted to internal machine control (Keyboard Scan, Cassette control, etc.). - 1.3.1 Disallowed Instructions. The CRU control signal "CRUCLK" is also not fully decoded, and as the result of not including the most significant three Address Bus bits in the decode, certain instructions of the TMS9900 must be disallowed. These are: LREX, CKOF, CKON, RSET and IDLE. ONE MUST NOT USE THESE INSTRUCTIONS, AS THE LOGIC BLOCKS FED BY CRUCLK WILL THINK THAT STROBE IS FOR A CRU OPERATION. - 1.3.2 CRU OUTPUT Definition. There is only one restriction on the definition of CRU OUTPUT bits for Peripheral use, and that is the base address bit. It must be used to page in DSR ROMs when SET, and should, where possible, be RESET by the Power Up RESET line in the I/O Port. Thus, the DSR ROM will be paged out by a RESET operation. For more information, see the Paragraph on DSR ROM Considerations. - 1.3.3 CRU INPUT Definition. There is no definition for CRU Input lines, and one is free to define them within that Peripheral Space as desired. - 1.3.4 Spare CRU Bit Use. Spare CRU bits may be put to good use as test bits. If spare INPUT and OUTPUT bits are available, the ones used should be chosen such that spare INPUTs may be connected to spare OUTPUTs (each pair displaced by the same amount from the base) to form software FLAG bits. Otherwise, spare inputs should be tied to VCC and GROUND in some manner that will be verified during the power up routine execution for that peripheral. Spare outputs may be left unconnected or terminated on an etch pad to be connected to Automatic Test Equipment. ## CRU MAP | >ØØØØ<br> CPU TMS99Ø1 Space <br> >Ø3FE | |-------------------------------------------| | <br> | | ממאטל<br> Not Assigned | | Not Assigned | | /WIIL | | <br> >1ØØØ | | For Test Equip use | | on Production Line | | (128 Lines) | | (128 E11188) | | | | <br> >1100 | | Disk Controller | | (128 Lines) | | >11FE | | | | >1200 | | For future use | | ;<br> >12FE | | jj | | >13ØØ | | Primary RS232 | | >13FE | | Íi | | j>14ØØ | | For future use | | >14FE | | + | # CRU MAP (Continued) |>15ØØ Secondary RS232 >15FE| I>16ØØ | Not Assigned >16FE| l>17ØØ Not Assigned l>18ØØ | Thermal Printer >18FE| |>19ØØ | Not Assigned >19FE| |>1AØØ | Not Assigned 99/4 Debugger For future use >1CFE| I>1DØØ For future use >1DFE| |>1EØØ Not Assigned |>1FØØ | P-CODE | |>1EFE| #### 1.4 99/4 PERIPHERAL POLLING The 99/4 polls the I/O Port for the presence of peripherals on either a Software Restart or a Hardware RESET. This polling starts in the CRU Space at >1000 and continues in >100 increments until >1F00 has been polled. Power up routines will be executed for each peripheral as its DSR ROM is polled (if the DSR header indicates that a power up sequence is required). #### 1.5 INDICATOR LED An Indicator LED shall be provided and shall be driven by a unique CRU OUTPUT bit. If all CRU OUTPUT bits have been defined, it shall be acceptable to connect the LED drive to the DSR ROM Page Bit. #### 1.6 DSR ROM CONSIDERATIONS The DSR ROMs for all peripherals must be based at >4000 and may be contiguous through >5FFF. These ROMs must not respond unless the respective CRU DSR ROM Page Bit is set ON (SET to a HIGH level with either a SBO instruction or "1" data in a LDCR instruction). It is the responsibility of the CPU to insure the proper control of all of the DSR ROM Page Bits. 1.6.1 Extended DSR ROM Techniques. ROM Space in excess of 8K BYTES may be obtained by paging the paged DSR ROM. This secondary paging may be used anywhere in the 99/4 Memory Space and has been used both in the Command Module Space and in the DSR ROM Space. The Secondary Page Bit may be obtained easily from the assigned CRU space to that peripheral (as was done on the P-CODE PCB) or by WRITING to a ROM Address and then decoding that condition to strobe a Flip-Flop. The latter Method was used on the Extended BASIC Command Module to page the upper 4K half of that space. Either a Data Bus or an Address Bus bit may be used for data to the FF. Both schemes provided a non-paged 4K base ROM, and paged the upper 4K half of the space. #### SECTION 2 #### EXPANSION BOX REQUIREMENTS ## 2.1 System Bus Requirements There are only two design considerations to be comprehended in interfacing to the system bus. One controls a Data Bus driver on the 99/4 end of the connecting cable and the other is used during PCB Burn In. - 2.1.1 Remote Data Bus Driver. As has been previously noted, there are additional requirements for interfacing through the Peripheral Expansion Unit. Regardless of the processor driving the PEU, a signal must be provided to indicate to the interface that a memory cycle is being requested for a PCB in the PEU. This signal is termed "RDBENA\*" and is used to enable Data Bus drivers on the 99/4 end of the cable. It must function as an open-collector signal and be LOW True for the full memory cycle on that PCB. I have used the same signal that drives my bidirectional Data Bus driver chip for the enable on a tri-state gate (with its input connected LOW) in the past for this function. - 2.1.2 Burn In Consideration. A single HIGH True line shall be provided to enable the PCB to respond to both Memory and CRU accesses. This line is held at a HIGH level in the PEU but is driven to allow a parallel connection of 8 PCBs during Burn In. When LOW, this signal shall disable the PCB from driving any of the System Memory and CRU Bus lines. I have excepted the interrupt sensing from this in the past. #### 2.2 POWER ALLOCATION ASSUMPTIONS The following is a guide for maximum load current a PCBs should present to the PEU. - \* 250 ma on the +15V unregulated bus - \* 500 ma on the +8V unregulated bus - \* 30 ma on the -15V unregulated bus ## 2.3 SYSTEM BUS PIN DEFINITION .100" PIN TO PIN SPACING, ATTLEBORO CONNECTOR | PIN # | MNEMONIC | FUNCTION | |----------|---------------------|----------------------------------------------------------------------| | 1 2 | 0115 | +5V 3-T Regulator supply voltage<br>+5V 3-T Regulator supply voltage | | 3<br>4 | GND<br>BEADY A | Logic Ground | | 4<br>5 | READY.A<br>GND | System READY<br>Logic GROUND | | 6 | RESET* | Active LOW System driven RESET | | 7 | GND | Logic GROUND | | 8 | SCLK | System clock | | 9 | LCP | Second generation CPU indicator | | _ | | Ø=Second Gen CPU 1=99/4 | | 1Ø | AUDIO | Input Audio | | 11 | RBDENA* | Active Low Remote Data Bus Driver | | | | Enable control line | | 12 | PCBEN | Active HIGH PCB enable for Burn In | | 13 | HOLD* | Active LOW CPU HOLD request | | | | Second generation CPU only | | 14 | IAQHDA | IAQ HOLDA Logical OR | | 4 = | OFNELA | Second generation CPU only | | 15 | SENILA* | Interrupt Level A Sense Enable | | 16 | SENILB* | Interrupt Level B Sense Enable | | 17 | INTA* | Second generation CPU only<br>Active LOW Interrupt Level A | | 18 | LINSP | LOW for 99/4 Memory Expansion | | 10 | LINOI | HI for linear memory space | | | | Second generation CPU only | | 19 | D7 | System DATA Bus, LSB | | 20 | GND | Logic Ground | | 21 | D5 | System DATA Bus | | 22 | D6 | System DATA Bus | | 23 | D3 | System DATA Bus | | 24 | D4 | System DATA Bus | | 25 | D1 | System DATA Bus | | 26 | D2 | System DATA Bus | | 27 | GND | Logic Ground | | 28 | DØ | System DATA Bus, MSB | | 29 | A14.A | Address Bit | | 3Ø<br>31 | A15/COUT.A<br>A12.A | · | | 31 | A12.A<br>A13.A | Address Bit<br>Address Bit | | 33 | A1Ø.A | Address Bit | | 33 | 710.A | Audi 633 Dit | | PIN # | MNEMONIC | FUNCTION | |----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 34<br>35<br>36<br>37<br>38<br>39<br>40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53 | A11.A AØ8.A AØ9.A AØ6.A AØ7.A AØ4.A AØ5.A AØ2.A AØ3.A AØ8.A AØ8.A AØ8.A AMB.A AMB.A GND AMC.A GND CLKOUT* CRUCLK.A* DBIN.A GND WE.A* | Address Bit normally HIGH Address Bit normally HIGH Logic Ground Address Bit, MSB normally HIGH Logic Ground Active LOW CPU Clock Active LOW CPU Output Clock Data Bus Direction, HIGH is CPU READ Logic Ground LOW true CPU Write Enable | | 53 | GND | Logic Ground | | 54<br>55<br>56<br>57<br>58<br>59<br>6Ø | WE.A*<br>CRUIN<br>MEMEN.A* | LOW true CPU Write Enable HIGH true CRU Input data Active LOW memory request -12V 3-T Regulator supply voltage -12V 3-T Regulator supply voltage +12V 3-T Regulator supply voltage +12V 3-T Regulator supply voltage | | | | | #### SECTION 3 ## GENERAL HARDWARE REQUIREMENTS #### 3.1 PURPOSE The purpose of this Section is to provide some insight on the hardware interface to the 99/4A via the Expansion box, and how to bring a design into production. The actual product hardware design time represents between $1/2\emptyset$ and 1/5 the time necessary to bring a product into production. The vast majority of the time involved will be in doing in essence "dog work". A detailed test specification must be written, a detailed Trouble Shoot and Repair manual must be written, the product must be Qualified by CGA, QA, Assembly Tooling must be defined, etc. Thus, there are many more tasks to be handled past the design. If these details are not handled (as they have not been on several notable products), great time demands, misunderstandings and other bad things will be rained all over the designer. The end result is many more man hours spent than necessary. As a design aid, the Personal Computer Group has two prototyping PCB's; one to drive the System Bus and one to receive that Bus. These PCB's will accomodate about 36 16-pin DIP sockets and have the necessary System Bus buffers in place with etch connections to the System I/O pins. The PCB designers need only to hook the buffered world into theirs. Other design rules are included elsewhere in this section. Schematics of these PCBs are available and standard 99/4A timing diagrams should be used for the PEU PCB Design. Timing Diagrams for the next generation HC products will also be included as they are published. #### 3.2 TESTING Signature Analysis has been selected as the primary method for TS&R of the PCBs. Hewlett Packard reps will be happy tp present a short seminar on this if an individual has no prior knowledge of SA. Pattern generators will be designed for known 99/4 products and details of these will be made available when they have been completed. We will try to design these test systems in the general sense to provide some coverage of currently undefined products. We observe the design rules of double spacing non +5V power (+12V, -5V and -12V) to minimize a TTL to power line short or a power etch to power etch short. This should be a requirement for your PCB design team also. #### 3.3 DESIGN RULES This paragraph covers both Hardware and PCB design rules. - \* Each PCB must be completely disabled by an Active LOW disable (Active HIGH enable). The disable must disable both Memory and CRU functions on the PCB and is used for Burn In purposes. - \* The +12V, -5V and -12V power etches shall be double spaced from other etches where possible; thus TTL damaging shorts are minimized. - \* Signals such as CRUIN that are taken very far from the System I/O connector shall be guarded with GROUND etch. Where practical, these signals should be buffered with tri-state buffers. - \* Buffers to drive the bus must be physically close to the I/O Bus. The prototyping PCB's have most of this already in place, but signals such as READY and CRUIN do not have them as they are not always used. A connection to the System Bus constitutes a stub connection and generally obeys transmission line theory. These stubs should be kept as short as is practical. - \* All 19 System Address bits shall be included in the Memory Space decode for that peripheral. Assume AMC, AMB and AMA to be in the HIGH state. - \* Address lines A00 to A07 shall be included in the CRU Space decode even though the 99/4 assumes A00 through A02 to be zero. - \* There are two levels on which to interrupt but the 99/4 supports only one (INTA\*). THIS IS THE ONE YOU MUST USE. Interrupt level status bits are defined by the Personal Computer PCC at TI and for the moment not sensed by the 99/4. If they were to be sensed, the 99/4 would cause a line to go low (SENILA\*) which tells the PCB logic to gate its status bit to the System Data Bus. # SECTION 4 RS232 PCB, 99/4B AND JOHNNY BOX SPEC DWG. #ØØØØØØ5 Ø2/Ø5/82 #### UPDATE TRACKS #### 7/21/81 - \* Changed Parallel I/O Port pin definition in hopes of using a commercially available cable. - \* Added user jumper to +5V on Parallel Port. - \* Added CRU bit definitions. #### 7/22/81 - st Added new System I/O Pin definitions to reflect new address bit and the new .1" pin to pin spacing. - st Redefined Parallel I/O Pinouts because of lack of space on I/O tab for the 26-pin connector. #### 7/28/81 \* Found and corrected references to "two MSB Address Lines" to "three MSB Address Lines". #### 8/17/81 - \* Added Mnemonic definition list. - st Reworded Parallel I/O Port definition to state an address bias for the CRU handshake lines. ## 8/18/81 \* Added paragraph on 99/4A to 99/4B Software incompatibility. #### 8/19/81 - \* Changed PIO Port configuration bit to be "1" for the INPUT mode. - \* Changed PIO Port handshake address bias to 4 and the configuration address bias to 2. ## 8/20/81 - \* Added paragraph on 99/4A/B sense bits. - \* Added paragraph on the Indicator LED. MLB 7/13/82 4-2 PRELIMINARY #### 10/01/81 \* Tried once again to define 4A/4B DSR ROM compatibility. There is none. #### 11/13/81 - \* Started update from 11/11/81 review. - \* Added Clear-to-Send output. #### Ø1/Ø7/82 \* Revised I/O connector pin definition to reflect Attleboro plug definition. #### Ø1/28/82 - \* Revised PIO Connector to reflect newly desired pin requirements. - \* Revised signal definitions to include RBGEN\* and W5, W6, W7 and W8. - \* Added PAL definition. ## Ø2/Ø5/82 \* Added pictures for pin definitions on 25-pin D connector and 16-pin, pin header connector. MLB 7/13/82 4-3 PRELIMINARY #### SECTION 5 #### RS-232 ELECTRICAL DEFINITION #### 5.1 ORGANIZATION The RS-232 PCB shall furnish two EIA RS-232 like ports and a single 8-bit Bidirectional Port with one CRU IN and one CRU OUT bit for simple parallel operating devices. Deviations from the EIA RS-232C Specification lie mostly in the switching time area due to RFI considerations now imposed by the Federal Communications Commission. #### 5.2 GENERAL - \* There shall be no more than one input connected to the System driven Bus. No more than three open collector or tri-state outputs may be connected to drive the System Bus. Both bus drivers and receivers shall be physically located close to the System I/O connector. - \* Memory/CRU space decodes shall comphrehend PLA decoding as a cost reduction path. - \* RS-232 level translators for line drivers shall conform to DWG $WA\emptyset\emptyset\emptyset\emptysetMBJT$ . - \* Adequate decoupling shall be provided on the logic and the RS-232 ports. ## 5.3 KNOWN 99/4A TO 99/4B SOFTWARE INCOMPATIBILITIES - \* The baud rate generator in the TMS9902 UART is a divide by counter and will require a different count for the 99/4A 3Mhz clock than for the 2.66Mhz 99/4B clock. - \* Data from/to the 9902 UARTs is in the very slow access VDP RAM for the 99/4A. It will be in primary RAM for the 99/4B. MLB 7/13/82 5-1 PRELIMINARY #### 5.4 99/4A-99/4B DETERMINATION Separate DSR ROMs shall be used for each system and this device shall be socketed. #### 5.5 DESIGN VERIFICATION Characterization with respect to System level propogation delays shall be performed on all of the QUAL units and others as is required. If any negative deviations from design values are found, they shall drive any design changes required. ## 5.6 TEST CONSIDERATIONS Signature Analysis shall be designed in, as the primary fault isolation tool and test specifications for this PCB shall be written after both design and prototype debug have been completed. #### 5.7 LED INDICATOR A single LED shall be provided that is under Software Control. The LED shall be turned on every time the RS-232 port is utilized in order to blink the LED during normal operation. If self testing determines the PCB to be defective, the LED shall be left ON. It shall be turned ON during the self test operation and then turned OFF if the PCB tests good. #### 5.8 PARALLEL PORT The parallel port shall be configured as an 8-bit bidirectional data port with four CRU based handshake lines. The data port shall respond to any address in the upper 4K half of the DSR ROM space and data OUT shall be latched. Data IN shall be gated directly to the System Data Bus. See the sections on the CRU defintion and the Parallel I/O Port pin definition for additional information. MLB 7/13/82 5-2 PRELIMINARY A single CRU OUT bit with an address bias of >4 shall be the handshake OUT bit and a single CRU bit with an address bias of >4 shall be the handshake IN bit. Input/Output configuration shall be accomplished at an address bias >2. A SBZ at that location shall configure the PIO Port as an OUTPUT Port and a SBO shall cause it to function as an INPUT Port. ## 5.9 DSR ROM The DSR ROM space decode shall be a function of the 19 System Address lines, MEMIN\*, DBIN and the signal PCBEN. PCBEN is a HIGH true signal that will be used in the Burn In Racks. The DSR ROM shall be considered to be a 4K $\times$ 8 ROM and shall be decoded to respond to the lower half of the DSR ROM space only. It shall also be connected such that an EPROM can be substituted with no wiring changes. For the "first" RS-232 PCB, the DSR ROM base address shall be at >74000 (>4000 for Johnny Box) and the DSR ROM Page enable shall respond to a CRU base of >01300 (>1300 for the Expansion Box). For the "second" RS-232 PCB, the DSR ROM base address shall again be at >74000 (>4000 for Expansion Box), but the DSR ROM Page enable shall respond to a CRU base of >01500 (>1500 for the Expansion Box). ## 5.10 CRU DEFINITION The CRU space shall comprehend 15 System Address lines (the most significant three of the 99/4B shall be assumed to be zeros), MEMEM\* and the HIGH true signal PCBEN which will be used in the Burn In Racks. CRU addresses for the Johnny Box are derived from 99/4B addresses by dropping the most significant character (3 bits). - 5.10.1 First RS-232 PCB. The CRU base address for the "first" RS-232 PCB shall be at >01300, the DSR ROM Page enable shall respond to a CRU address of >01300, UART0 shall respond to a CRU base of >01340 and UART1 shall respond to a base of >01380. A System RESET shall set the DSR ROM page bit to a state that disables the DSR ROM. - 5.10.2 Second RS-232 PCB. The CRU base address for the "second RS-232 PCB shall be at >01500, the DSR ROM Page enable shall respond to a CRU address of >01500, UARTO shall respond to a CRU base of >01540 and UART1 shall respond to a base of >01580. A System RESET shall set the DSR ROM page bit to a state that disables the DSR ROM. MLB 7/13/82 5-3 PRELIMINARY 5.10.3 LED Indicator Bit. A single bit shall be used to drive the Indicator LED. The power up sequence in the DSR ROM shall cause the LED to be set ON for the duration of the self test. If the PCB passes the self test operation, the LED shall be turned OFF. If a failure occurs, the LED shall be left ON. In addition, the LED shall be blinked with about a 200ms ON time to indicate RS232 PCB activity. #### 5.10.4 CRU Bit Definitions | Output Bit<br>Displacement | Definition | |--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Ø<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | DSR ROM Page Enable, 1 = enabled Parallel Port mode set, 1 = INPUT mode Parallel Port Strobe bit Spare Parallel Port bit Flag Ø Clear to Send, RS232 Port Ø, Ø = Active Clear to Send, RS232 Port 1, 1 = Active Indicator LED control, 1 = LED ON | | Input Bit Displacement | Definition | ## 5.11 INTERRUPTS The interrupts from both UARTs shall be "OR" connected and drive Interrupt Level A (ILA). Interrupt Level Status Bits (ILSB) Ø and 1 shall be driven for UARTs Ø and 1 respectively for the "first" RS-232 and be used on the 99/4B, but the Johnny Box shall not use interrupts. The ISLBs shall be gated to the Data Bus with the LOW true signal "SENILA\*". RS-232 #2 shall drive ILSBs 4 and 5 with UARTs Ø and 1 respectively; thus, ILSW bits shall be auto insert jumper options for both PCBs. MLB 7/13/82 5-4 **PRELIMINARY** ## 5.12 FLAGS CRU bit 4 IN and OUT shall be connected to provide a Flag for $\ensuremath{\mathsf{S}}/\ensuremath{\mathsf{W}}$ use. #### 5.13 I/O VOLTAGE LEVELS All System Bus signals shall comply with standard TTL voltage levels and all RS-232 I/O shall function with voltages bigger than 5V but less than 25V in absolute magnitude for the required RS-232 logic levels. ## 5.14 CONNECTORS Both UARTs shall be connected to a single 25-pin D female connector and shall conform to the definitions that are listed under RS-232 I/O PORT DEFINITION. UART outputs shall drive translator output buffers and UART inputs shall be driven by receiver translators. MLB 7/13/82 5-5 PRELIMINARY RS-232 I/O PORT DEFINITION DATA SET PIN DEFINITIONS, FEMALE CONNECTOR | PIN # | TYPE | FUNCTION | |-------|----------|---------------------------| | 1 | driven | Protective Ground | | 2 | received | Data to UARTØ | | 3 | driven | Data from UARTØ | | 5 | driven | Clear to Send CRU Out, UØ | | 6 | driven | 1.8K Pull-up res to +12V | | 7 | driven | Logic Ground | | 8 | driven | Data Carrier Detect UARTØ | | 12 | driven | Data Carrier Detect UART1 | | 13 | driven | Clear to Send CRU Out, U1 | | 14 | received | Data to UART1 | | 16 | driven | Data from UART1 | | 19 | received | Data Terminal Ready UART1 | | 2Ø | received | Data Terminal Ready UARTØ | ## PIN VIEW OF 25-PIN PORT DEFINITION 13 12 11 10 9 8 7 6 5 4 3 2 1 25 24 23 22 21 20 19 18 17 16 15 14 ## PARALLEL I/O PORT DEFINITION | PIN # | FUNCTION | |-------|----------------------| | | | | 1 | Handshake OUT | | 2 | Data, LSB | | 3 | Data | | 4 | Data | | 5 | Data | | 6 | Data | | 7 | Data | | 8 | Data | | 9 | Data, MSB | | 1Ø | Handshake IN | | 11 | Spare Input bit | | 12 | 1K Ohm Pull-up to +5 | | 13 | 10 Ohm Pull-up to +5 | | 14 | Logic Ground | | 15 | Spare Output bit | | 16 | Logic Ground | 5-6 MLB 7/13/82 PRELIMINARY ## PIN VIEW OF 16-PIN HEADER CONNECTOR +----+ |15 13 11 9 7 5 3 1 | |16 14 12 10 8 6 4 2 | +----+ ## 5.15 Y CABLE A Y cable shall be available for users that wish to use both RS-232 ports. This cable shall be defined as follows. | PCB | | P2 | Р3 | |-----|-------------------|-----|-----| | PIN | FUNCTION | PIN | PIN | | | | | | | 1 | Protective Ground | 1 | 1 | | 2 | DATA to UARTØ | 2 | | | 3 | DATA from UARTØ | 3 | | | 5 | CTS CRU Out, UØ | 5 | | | 6 | 1.8K P/U to +12V | 6 | 6 | | 7 | Logic Ground | 7 | 7 | | 8 | DCD UARTØ | 8 | | | 12 | DCD UART1 | | 8 | | 13 | CTS CRU Out, U1 | | 5 | | 14 | DATA to UART1 | | 2 | | 16 | DATA from UART1 | | 3 | | 19 | DTR UART1 | | 2Ø | | 2Ø | DTR UARTØ | 2Ø | | MLB 7/13/82 5-7 PRELIMINARY ## PRODUCTION PCB PIN OUTS System Bus I/O Connector Pin Definition .100" PIN TO PIN SPACING, ATTLEBORO CONNECTOR | PIN # | MNEMONIC | FUNCTION | |----------|---------------------|-------------------------------------------------------------------| | 1<br>2 | | +5V 3-T Regulator supply voltage +5V 3-T Regulator supply voltage | | 3 | GND | Logic Ground | | 4 | | not used, READY.A | | 5 | GND | Logic Ground | | 6 | RESET* | Active LOW System driven RESET | | 7 | GND | Logic Ground | | 8<br>9 | | not used, SCLK<br>not used, B00TPG* | | 1Ø | | not used, AUDIO | | 11 | RBDEN* | Active Low Remote Data Bus Driver | | • • | NBB 211 | enable control line | | 12 | PCBEN | Active HIGH PCB enable for Burn In | | 13 | | not used, HOLD* | | 14 | | not used, IAQHDA | | 15 | SENILA* | Interrupt Level A Sense Enable | | 16 | T.N.T.A. | not used, SENILB* | | 17 | INTA* | Active LOW Interrupt Level A | | 18<br>19 | D7 | not used, INTB*<br>System DATA Bus, LSB | | 2Ø | GND | Logic Ground | | 21 | D5 | System DATA Bus | | 22 | D6 | System DATA Bus | | 23 | D3 | System DATA Bus | | 24 | D4 | System DATA Bus | | 25 | D1 | System DATA Bus | | 26 | D2 | System DATA Bus | | 27 | GND | Logic Ground | | 28 | DØ | System DATA Bus, MSB | | 29<br>3Ø | A14.A<br>A15/CONT.A | Address Bit, LSB | | 31 | A12.A | Address Bit | | 32 | A13.A | Address Bit | | 33 | A1Ø.A | Address Bit | | 34 | A11.A | Address Bit | | 35 | AØ8.A | Address Bit | | 36 | AØ9.A | Address Bit | | 37 | AØ6.A | Address Bit | | 38 | AØ7.A | Address Bit | | 39 | AØ4.A | Address Bit | | 4Ø<br>41 | AØ5.A | Address Bit | | 41<br>42 | AØ2.A<br>AØ3.A | Address Bit<br>Address Bit | | 74 | 1100.A | Addi 633 Dit | 5-8 MLB 7/13/82 PRELIMINARY # PRODUCTION PCB PIN OUTS, CONTINUED | PIN # | MNEMONIC | FUNCTION | |----------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------| | 43<br>44 | AØØ.A<br>AØ1.A<br>AMB.A | Address Bit Address Bit Address Bit Address Bit Address Bit Logic Ground Address Bit, MSB Logic Ground Active LOW CPU Clock | | 6Ø | | +12V 3-T Regulator supply voltage | # 5.16 MNEMONIC DEFINTIONS | MNEMONIC | | DEFIN | ITION<br> | | | |----------|--------|--------|-----------|-----|-----| | AMC.A | System | 19-bit | Address | Bus | MSB | | AMB.A | System | 19-bit | Address | Bus | | | AMA.A | System | 19-bit | Address | Bus | | | AØØ.A | System | 19-bit | Address | Bus | | | AØ1.A | System | 19-bit | Address | Bus | | | AØ2.A | System | 19-bit | Address | Bus | | | AØ3.A | System | 19-bit | Address | Bus | | | AØ4.A | System | 19-bit | Address | Bus | | 5-9 MLB 7/13/82 PRELIMINARY | MNEMONIC | DEFINITION | |------------|---------------------------------------------------------| | AØ5.A | System 19-bit Address Bus MSB | | AØ6.A | System 19-bit Address Bus | | AØ7.A | System 19-bit Address Bus | | AØ8.A | System 19-bit Address Bus | | AØ9.A | System 19-bit Address Bus | | A1Ø.A | System 19-bit Address Bus | | A11.A | System 19-bit Address Bus | | A12.A | System 19-bit Address Bus | | A13.A | System 19-bit Address Bus MSB | | A14.A | System 19-bit Address Bus | | A15/COUT.A | System Combination Address Bus LSB and CRU Output Data. | | AMC.A | Buffered 19-bit Address Bus, MSB | | AMB.A | Buffered 19-bit Address Bus | | AMA.A | Buffered 19-bit Address Bus | | AØØ.A | Buffered 19-bit Address Bus | | AØ1.A | Buffered 19-bit Address Bus | | AØ2.A | Buffered 19-bit Address Bus | | AØ3.A | Buffered 19-bit Address Bus | | AØ4.A | Buffered 19-bit Address Bus | | AØ5.A | Buffered 19-bit Address Bus | | AØ6.A | Buffered 19-bit Address Bus | | AØ7.A | Buffered 19-bit Address Bus | | AØ8.A | System 19-bit Address Bus MSB | 5-1Ø PRELIMINARY MLB 7/13/82 | DEFINITION | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | System 19-bit Address Bus | | System 19-bit Address Bus | | System 19-bit Address Bus | | System 19-bit Address Bus | | System 19-bit Address Bus | | System 19-bit Address Bus | | Buffered combination 19-bit Address Bus<br>LSB and CRU Output Data. | | Active Low enable for the Data Bus<br>Bidirectional Bus driver chip (SN74LS245). | | Bus level System Clock. For 99/4A based systems it is the 3 MHz Phase 3 clock. For 99/4B based systems it is a 2.68 MHz clock similiar to a 99/4A, but more than twice as wide and a different frequency. | | Buffered System Clock. For 99/4A based systems it is the 3 MHz Phase 3 clock. For 99/4B based systems it is a 2.68 MHz clock similiar to a 99/4A, but more than twice as wide and a different frequency. | | UARTØ Carrier Detect output. | | UART1 Carrier Detect output. | | RS-232 level Carrier Detect to 25-pin<br>D Conn, pin 8 | | RS-232 level Carrier Detect to 25-pin<br>D Conn, pin 12 | | System level, Active LOW CRU Clock from the CPU | | Buffered, Active HIGH CRU Clock from the CPU | | Buffered, Active LOW CRU Clock from the CPU | | HIGH true CRU data to the CPU (CPU READ Data) | | | MLB 7/13/82 5-11 PRELIMINARY | MNEMONIC | DEFINITION | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------| | CRU0* | Active LOW enable for a bit CRU operation.<br>It is the CRU base of either >1300 or >1500<br>for either module type ("First" or "Second"<br>RS-232). | | DATAINØ | RS-232 level received data from 25-pin d Conn, pin 2. | | DATAIN1 | RS-232 level received data from 25-pin d Conn, pin 14. | | DATAOUTØ | RS-232 level data to 25-pin D Connector, pin 3. | | DATAOUT1 | RS-232 level data to 25-pin D Connector, pin 16. | | DBIN.B | Buffered Active LOW Data Bus Input control line. The data direction is from the PCB to the CPU when this line is HIGH. | | DBIN.B* | Buffered Active LOW Data Bus Input control line. The data direction is from the PCB to the CPU when this line is LOW. | | DIØ.A | Received Data for UARTØ. | | DI1.A | Received Data for UART1. | | DOUTØ | UARTØ data output. | | DOUT1 | UART1 data output. | | DSRROM* | Active LOW DSR ROM enable to be ANDed with DBIN.B to drive the DSR ROM Chip Enable pin. | | DTRØ | RS-232 level Data Terminal Ready from 26-pin D Connector pin 20. | | DTR1 | RS-232 level Data Terminal Ready from 26-pin<br>D Connector pin 19. | | DTRØ.A | Received Data Terminal Ready to UARTØ Input. | | DTR1.A | Received Data Terminal Ready to UART1 Input. | | DØ | System Side Data Bus MSB | | D1 | System Side Data Bus | MLB 7/13/82 5-12 PRELIMINARY | MNEMONIC | DEFINITION | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D2 | System Side Data Bus | | D3 | System Side Data Bus MSB | | D4 | System Side Data Bus | | D5 | System Side Data Bus | | D6 | System Side Data Bus | | D7 | System Side Data Bus, LSB | | FLAGØ | Software Flag #Ø. Connects from a 259 output to a 251 input. | | FLAG1 | Software Flag #1. Connects from a 259 output to a 251 input. | | FLAG2 | Software Flag #2. Connects from a 259 output to a 251 input. | | FLAG3 | Software Flag #3. Connects from a 259 output to a 251 input, and also drives an indicator LCD. | | ILA* | Tristate, Active LOW driver for Interrupt level A. | | MEMEN.A* | System Memory Enable control signal from the CPU. When LOW it indicates that a memory access IS required by the CPU. When HIGH it indicates that a CRU MIGHT be taking place. | | MEMEN.B* | Buffered Memory Enable control signal from the CPU. When LOW it indicates that a memory access IS required by the CPU. When HIGH it indicates that a CRU MIGHT be taking place. | | PCBEN | Active HIGH enable signal. It is used on the Burn In Rack to allow the controlling CPU to talk to only one PCB at a time. When LOW the PCB is disabled for both CRU and Memory operations. | | PIO* | Active LOW enable for a parallel I/O operation. | PRELIMINARY MLB 7/13/82 5-13 | MNEMONIC | DEFINITION | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PIOOC | Direction Control bit for the Parallel I/O Port. If LOW, the PIO port shall function as an OUTPUT Port, and it will be LOW for either a Master Reset or a SBZ operation. | | PIOR | Received handshake bit from Parallel I/O Port. | | PIOS | Handshake bit for the Parallel I/O Port that is driven by the PCB. It will be LOW with either a SBZ or a Master Reset operation. | | PIOØ | Parallel I/O Data Port MSB | | PI01 | Parallel I/O Data Port | | PI02 | Parallel I/O Data Port | | PI03 | Parallel I/O Data Port | | PI04 | Parallel I/O Data Port | | PI05 | Parallel I/O Data Port | | PI06 | Parallel I/O Data Port | | PI07 | Parallel I/O Data Port | | RDØ | PCB Side Data Bus MSB | | RD1 | PCB Side Data Bus | | RD2 | PCB Side Data Bus | | RD3 | PCB Side Data Bus | | RD4 | PCB Side Data Bus | | RD5 | PCB Side Data Bus | | RD6 | PCB Side Data Bus | | RD7 | PCB Side Data Bus LSB | | RDBEN* | Active LOW Control line to enable remote Data Bus drivers at the 99/4 end of the connecting cable. | | RESET.A* | System Active LOW Master Reset line. | | RESET.B* | Buffered Active LOW Master Reset line. | MLB 7/13/82 5-14 PRELIMINARY | MNEMONIC | DEFINITION | |----------|-----------------------------------------------------------------------------------------------------------------------------| | RPGEN | Active HIGH RS-232 DSR ROM Page Bit. It must be HIGH before the RS-232 DSR ROM may be accessed. | | SENILA* | CPU driven line to allow the PCB to gate interrupt data to the system side of the Data Bus. | | SI | Spare received handshake bit from Parallel I/O Port. | | S0 | Spare CRU handshake bit for the Parallel $\rm I/O$ Port that is similiar to the signal PIOS. | | UARTØ* | Active LOW chip select for the 9902 UART biased >40 from the CRU base. | | UART1* | Active LOW chip select for the 9902 UART biased >80 from the CRU base. | | UØINT* | UARTØ interrupt drive. | | U1INT* | UART1 interrupt drive. | | WE.A* | System Write Enable from the CPU, and is used to write data to the Parallel I/O Port. | | WE.B* | Buffered Write Enable from the CPU, and is used to write data to the Parallel I/O Port. | | W5 | Jumper wire to connect DTRØ to pin 20 on the 25-pin D Connector. W7 must not be connected if W5 is. W5 IS FACTORY INSERTED. | | W7 | Jumper wire to connect DTRØ to pin 11 on the 25-pin D Connector. W5 must not be connected if W7 is. W7 IS FACTORY INSERTED. | | W6 | Jumper wire to connect DTR1 to pin 19 on the 25-pin D Connector. W8 must not be connected if W6 is. W6 IS FACTORY INSERTED | | W8 | Jumper wire to connect DTR1 to pin 18 on the 25-pin D Connector. W6 must not be connected if W8 is. | MLB 7/13/82 5-15 PRELIMINARY ### 5.17 RS232 PAL12L6 DSRROM = V1\*V2\*AØ1\*/AØ3\*MEMEN\*PCBEN BDRVR = V1\*V2\*AØ1\*MEMEN\*PCBEN PIO = V1\*V2\*AØ1\*AØ3\*MEMEN\*PCBEN CRUO = V2\*/AØ1\*AØ3\*V3\*/AØ5\*AØ6\*/AØ8\*/AØ9\*/MEMEN\*PCBEN\*/CSSEL + V2\*/AØ1\*AØ3\*V3\*VØ5\*/AØ6\*/AØ8\*/AØ9\*/MEMEN\*PCBEN\*CSSEL UARTØ = V2\*/AØ1\*AØ3\*V3\*/AØ5\*AØ6\*/AØ8\*AØ9\*/MEMEN\*PCBEN\*/CSSEL + V2\*/AØ1\*AØ3\*V3\*AØ5\*/AØ6\*/AØ8\*AØ9\*/MEMEN\*PCBEN\*CSSEL UART1 = V2\*/AØ1\*AØ3\*V3\*/AØ5\*AØ6\*/AØ8\*AØ9\*/MEMEN\*PCBEN\*/CSSEL + V2\*/AØ1\*AØ3\*V3\*AØ5\*/AØ6\*AØ8\*/AØ9\*/MEMEN\*PCBEN\*CSSEL | 1 | V1 | 11 | /MEMEN | |----|----------------|----|-------------| | 2 | /V2 | 12 | PCBEN | | 3 | AØ1 | 13 | /DSRROM | | 4 | AØ3 | 14 | /BDRVR | | 5 | /V3 | 15 | /PIO | | 6 | AØ5 | 16 | /CRUO | | 7 | AØ6 | 17 | /UARTØ | | 8 | AØ8 | 18 | /UART1 | | 9 | AØ9 | 19 | CSSEL | | 1Ø | GROUND (POWER) | 2Ø | VCC (POWER) | MLB 7/13/82 5-16 PRELIMINARY # P-CODE PCB, 99/4X AND JOHNNY BOX SPEC DWG. #ØØØØØØ9 Ø1/29/82 ### **UPDATE TRACKS** ### First version written 7/28/81 ### 8/17/81 \* Added Mnemonic definitions ### 8/18/81 \* Added paragraph on software incompatibilties between 99/4A and 99/4X. There were none. #### 10/8/81 - $\ast$ Added DBIN and AØ5.b to the PLA equations for the GROM chip select. - \* Added AØ5.B to the source PLA input. ### Ø1/29/82 - Defined System I/O for Attlboro connector. - \* Added RDBIN\* signal definition. - \* Added PAL definition. - \* Deleted reference to the 75366 and used a 7417 instead. - \* Added the LED with W1 and W2 wire jumpers. MLB 7/13/82 6-1 PRELIMINARY ### SECTION 6 ### P-CODE ELECTRICAL DEFINITION #### 6.1 ORGANIZATION The P-CODE PCB shall be comprised of one (1) $4K \times 8$ , one (1) $8K \times 8$ Primary ROM and eight (8) GROM chips with the required decode logic to support them. #### 6.2 GENERAL - \* There shall be no more than one input connected to the System driven Bus. No more than three open collector or tri-state outputs may be connected to drive the System Bus. Both Bus drivers and receivers shall be physically located to the System I/O connector. - \* Memory/CRU space decodes shall comprehend PLA decoding as a cost reduction path. - \* Required GROM voltage levels shall be designed in. - \* Adequate decoupling shall be provided on the logic, ROM and the GROM chips. # 6.3 KNOWN 99/4B AND 99/4X SOFTWARE INCOMPATIBILITIES There are no known software incompatibilities between the $\,$ 4A $\,$ and the $\,$ 4X. ### 6.4 SOFTWARE REQUIREMENTS It will be necessary to perform a "DUMMY" DATA READ from the GROM Library to initialize the GROM chips. This initialization insures the correct Address Counter byte is loaded on the first WRITE to the Address Register. # 6.5 DESIGN VERIFICATION Characterization with respect to System level propogation delays shall be performed on all of the QUAL units and others as is required. If any negative deviations from design values are found, they shall drive any design changes required. MLB 7/13/82 6-2 PRELIMINARY ### 6.6 TEST CONSIDERATIONS Signature Analysis shall be designed in as the primary fault isolation tool and test specifications for this PCB shall be written after both design and prototype debug have been completed. All ROMs and GROMs shall have CRC words in the last TWO byte locations. Six spare CRU Output bits are available and may be used in the testing process if practical. ### 6.7 DSR ROMs The 8K DSR ROM space decode shall be a function of the 19 System Address lines, MEMEN\*, DBIN and the signal PCBEN. PCBEN is a HIGH true signal that will be used in the Burn In Racks. The 4K x 8 DSR ROM shall be organized at >74000 and the 8K x 8 ROM shall be based at >75000. The proper half of the 8K x 8 ROM shall be selectable with a CRU bit. ### 6.8 REMOTE DATA BUS DRIVER CONTROL Provisions shall be made to drive the System bus line needed to control remote Data Bus drivers. This signal shall be driven active LOW any time the CPU is requesting a memory cycle from the P-Code PCB and shall be open collector or equivalent. ### 6.9 GROMs Eight GROM chips shall be parallel connected and addressed for chip select at >75BFC for a DATA READ, >75BFE for a ADDRESS READ, >75FFC for a DATA WRITE (not normally used) and >75FFE for an ADDRESS WRITE. DBIN shall be used to inhibit a READ at a WRITE address and vice versa. #### 6.1Ø CRU DEFINITION The CRU space shall comprehend 15 System Address lines (the most significant three of the 99/4X shall be assumed to be zeros), MEMEN\* and the HIGH true signal PCBEN which will be used in the Burn In Racks. CRU addresses for the Johnny Box are derived from 99/4X addresses by dropping the most significant character (3 bits). MLB 7/13/82 6-3 PRELIMINARY The CRU base address for the P-CODE PCB shall be >1F00 and a SBZ at >1F80 shall select the lower half of the 8K x 8 ROM to be based at >75000. A SBO at >1F80 shall select the upper half of the 8K x 8 ROM to be based at >75000. CRU displaced from both >1F00 and >1F80 by 1, 2 and 3 shall be connected to auto inserted wires and used as test bits if practical. An Indicator LED shall be jumper selectable between the DSR Page enable CRU bit (>1FØØ) and the CRU Output bit at >1F83. If W1 is inserted, a connection to >1F83 is made and W2 makes connection to the DSR Page bit. A SBO instruction turns the LED ON and a SBZ instruction turns it OFF. W2 is factory inserted. There shall be no CRU Input required. ### 6.10.1 CRU Bit Definitions. | Output Bit<br>Displacement<br>From >1FØØ | Definition | |------------------------------------------|----------------------------------------------------| | ~ | | | Ø<br>1<br>2<br>3 | DSR ROM Page Enable, 1=enabled Spare Spare Spare | | Output Bit<br>Displacement<br>From >1FØØ | Definition | | Ø | 8Kx8 DSR ROM Half Select, 1=Upper, Ø=Lower 1 Spare | | 1 | Spare | | 2 | Spare | | 3 | LED, 1=ON, Ø=OFF | MLB 7/13/82 6-4 PRELIMINARY # 6.11 System Bus I/O Connector Pin Definition .100" PIN TO PIN SPACING, ATTLEBORO CONNECTOR | PIN # | MNEMONIC | FUNCTION | |----------------------|----------------|------------------------------------------------------------------------------------------------------| | 1<br>2<br>3<br>4 | GND<br>READY.A | +5V 3-T Regulator supply voltage<br>+5V 3-T Regulator supply voltage<br>Logic Ground<br>System READY | | 5 | GND | Logic Ground | | 6 | RESET* | Active LOW System driven RESET | | 7 | GND | Logic Ground | | 8 | | not used, SCLK | | 9 | | not used, BOOTPG* | | 1Ø | | not used, AUDIO | | 11 | RBDEN* | Active Low Remote Data Bus Driver Enable control line | | 12 | PCBEN | active HIGH PCB enable for Burn In | | 13 | | not used, HOLD* | | 14 | | not used, IAQHDA | | 15 | SENILA* | Interrupt Level A Sense Enable | | 16 | | not used, SENILB* | | 17 | INTA* | active LOW Interrupt Level A | | 18 | | not used, INTB* | | 19 | D7 | System DATA Bus, LSB | | 2Ø | GND | Logic Ground | | 21 | D5 | System DATA Bus | | 22 | D6 | System DATA Bus | | 23 | D3 | System DATA Bus | | 24 | D4 | System DATA Bus | | 25 | D1 | System DATA Bus | | 26 | D2 | System DATA Bus | | 27 | GND | Logic Ground | | 28 | DØ | System DATA Bus, MSB | | 29 | A14.A | Address Bit | | 3Ø | A15/CONT.A | · · · · · · · · · · · · · · · · · · · | | 31 | A12.A | Address Bit | | 32<br>33 | A13.A | Address Bit | | 33<br>34 | A1Ø.A<br>A11.A | Address Bit<br>Address Bit | | 3 <del>4</del><br>35 | AUI.A<br>AØ8.A | Address Bit | | 36 | AØ9.A<br>AØ9.A | Address Bit | | 37 | AØ6.A | Address Bit | | 51 | ABO.A | Addi Coo Dit | 6-5 MLB 7/13/82 PRELIMINARY # SYSTEM BUS I/O CONNECTOR PINS CONTINUED | PIN # | MNEMONIC | FUNCTION | |----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 38<br>39<br>40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50<br>51<br>52<br>53 | AØ7.A<br>AØ4.A<br>AØ5.A<br>AØ2.A<br>AØ3.A<br>AØ0.A<br>AØ1.A<br>AMB.A<br>AMA.A<br>GND<br>AMC.A | Address Bit Logic Ground Address Bit, MSB Logic Ground Active LOW CPU Clock Active LOW CRU Output Clock Data Bus Dir'tn HIGH is CPU READ Logic Ground LOW true CPU Write Enable HIGH true CRU Input data | | 59<br>6Ø | | +12V 3-T Regulator supply voltage<br>+12V 3-T Regulator supply voltage | MLB 7/13/82 6-6 PRELIMINARY #### SECTION 7 # P-CODE THEORY OF OPERATION #### 7.1 GENERAL DESCRIPTION The P-CODE PCB is a ROM/GROM based PCB to support the programming language PASCAL. It must be used on the system level in conjuction with a 32K or larger Memory Expansion. #### 7.2 DSR ROMs The 8K DSR ROM address space is comprised of a 4K ROM based at >74000, and an 8K ROM paged into two equal parts and based at >75000. A CRU bit located at >1F80 is used to select between the two halves and a SBZ instruction at that address will select the lower half of the 8K ROM. Conversely, a SBO instruction at that same address will select the upper half. The DSR ROMs are shown on Page 5 of the P-CODE Schematics. # 7.3 GROM ARRAY An array of eight GROM chips gives a 48K Byte Graphics Read Only Memory and the chips are all connected in parallel. Open collector drivers (SN7417N) and 47Ø Ohm pull-up resistors to +5V are used to interface the four PMOS GROM chip control lines to the system. A CMOS Bidirectional Data Bus Driver provides the proper HIGH logic level (+4.3V or higher) to the GROM data inputs. Grom Ground is connected to System Ground to prevent the internal P-CODE data bus from being driven below the System Ground level. The GROM clock is derived from the System CPU clock and has a frequency of 375 Khz that is derived from the System 3.0 Mhz clock. This lower frequency was selected to provide higher GROM functional reliability. MLB 7/13/82 7-1 PRELIMINARY The GROMs are accessed in the upper half of the DSR ROM space as follows. - \* >75BFC for DATA READs. - \* >75BFE for ADDRESS READs - \* >75FFC for DATA WRITEs (not a normal operation). - \* >75FFE for ADDRESS WRITEs. This breaks down into: AMC=AMB=AMA=1 AØØ=1 AØ1=1 AØ2=Ø AØ3=AØ4=1 AØ5=X AØ6=AØ7=AØ8=AØ9=A1Ø=A11=A12=A13=1 A14=Data/Address select A15/CRUOUT=X The System Level signal DBIN is used to determine a READ or a WRITE signal to the GROM chips as well as to inhibit a READ at one of the two WRITE addresses. The GROM Array is shown on Page 4 of the P-CODE Schematics along with the divide by 8 counter (a SN74LS161A) that is used to derive the GROM clock from the CPU clock. The TTL to MOS converters are also shown on that page. ### 7.4 PROGRAMMABLE LOGIC ARRAY A PLA is used to generate all chip selects and it is supported by some combinational logic to generate terms that reduce the number of PLA inputs to an acceptable level (12 inputs or less). It has been previously noted that the GROMs responded to four addresses in the upper DSR ROM space and an 8 Input NAND gate is used to help trap those addresses. AØ9 is handled in the PLA in conjuction with this to provide the proper address trapping to disable the 8K DSR ROM and enable the GROMs. A pair of 4 Input AND gates and a single 2 Input OR gate is used to reduce the number of inputs required on the PLA. All of this logic is located on Page 1 of the P-CODE Schematics. MLB 7/13/82 7-2 PRELIMINARY The following table is included to detail the operation of the PLA. | INPUT | 8K | ROM | 4K ROM | BDBD | GRO | DM | CRU OUT | SPARE | |---------|----|-----|--------|------|-----|----------|---------|-------| | | | | | | | | | | | | - | + | | | - | <b>-</b> | | | | V1 | Н | Н | Н | Н | Н | Н | Χ | X | | V2 | Н | Н | Н | Н | Н | Н | Н | Н | | AØ1 | Н | Н | Н | Н | Н | Н | L | L | | AØ3 | Н | Н | L | X | Н | Н | Н | Н | | V3 | Χ | Χ | Χ | X | Χ | Χ | Н | Н | | AØ9 | Χ | L | Χ | Χ | Н | Н | Н | Н | | V4* | Н | Χ | Χ | X | L | L | Χ | X | | CRUCLK* | Χ | Χ | Χ | X | Χ | Χ | L | X | | DBIN | Н | Н | Н | X | Н | L | Χ | X | | MEMEN* | L | L | L | L | L | L | Н | Н | | PCBEN | Н | Н | Н | Н | Н | Н | Н | Н | | AØ5 | Χ | Χ | X | Χ | L | Н | Χ | X | "H" denotes a HIGH level, "L" a LOW level and "X" a Not Included value. V1=AMCxAMBxAMAxPCPAGE, V2=AØØ\*x/AØ2\*, V3=AØ4xAØ5xAØ6xAØ7 V4\*=AØ4xAØ6xAØ7xAØ8xA1ØxA11xA12xA13 MLB 7/13/82 7-3 PRELIMINARY #### 7.4.1 MMI PAL12L6 Definition EKDSRCS = V1\*V2\*AØ1\*AØ3\*/V4\*DBIN\*MEMEN\*PCBEN ; 8K DSR ROM + V1\*V2\*AØ1\*AØ3\*/AØ9\*DBIN\*MEMEN\*PCBEN FKDSRCS = V1\*V2\*AØ1\*/AØ3\*DBIN\*MEMEN\*PCBEN : 4K DSR ROM BDRVR = V1\*V2\*AØ1\*MEMEN\*PCBEN ; BIDIRECTIONAL BUS DRIVER GCS = V1\*V2\*AØ1\*AØ3\*AØ9\*V4\*DBIN\*MEMEN\*PCBEN\*/AØ5 ; GROM CS + V1\*V2\*AØ1\*AØ3\*AØ9\*V4\*/DBIN\*MEMEN\*PCBEN\*AØ5 ; GROM CS CRUWT = V2\*/AØ1\*AØ3\*V3\*/AØ9\*CRUCLK\*/MEMEN\*PCBEN ; CRU REG LD SPAREO = Spare output | 1 | V1 | 11 | /MEMEN | |----|----------------|----|-------------| | 2 | /V2 | 12 | PCBEN | | 3 | AØ1 | 13 | /EKDSRCS | | 4 | AØ3 | 14 | /FKDSRCS | | 5 | V3 | 15 | /BDRVR | | 6 | AØ9 | 16 | /GCS | | 7 | /V4 | 17 | /CRUWT | | 8 | /CRUCLK | 18 | SPARE0 | | 9 | DBIN | 19 | AØ5 | | 1Ø | GROUND (POWER) | 2Ø | VCC (POWER) | ### 7.5 SYSTEM READY CONTROL The "READY" output of the GROM chips is connected to the input of a SN74LS15AN bus driver and the primary chip select (from the PLA) for the GROMs enables that particular driver (along with the GROMs). The output of the 125 is connected to the Tri-state driven System READY Status line to control the CPU; thus, when the GROM Array is enabled, the normally low GROM READY line causes the System to go "NOT READY". When the last GROM chip goes "READY", the System also goes READY. A fault (a screw up) in this area can hold the System "NOT READY" (lock the thing up, Tim). This logic is shown on Page 4 of the P-CODE Schematics. MLB 7/13/82 7-4 PRELIMINARY A 5.6K pull-up on GROM READY was used to lighten the load on the READY output driver in the GROM chips. ### 7.6 CRU OUTPUT REGISTER The CRU Output Register is shown on Page 1 of the P-CODE Schematics and is connected such that 4-bit LDCR instructions can be utilized when operating at either >1F00 or >1F80. ### 7.7 ADDRESS AND DATA BUS BUFFERS All System level signals are buffered prior to being used and this logic is shown on Pages 2, 3 and 4 of the P-CODE Schematics. ### 7.8 SPECIAL CONSIDERATIONS Spare 2 Input OR gates are used for buffers to drive the SN7417 open collector drivers for the TTL/MOS interface and the extra input to these gates is connected to the primary GROM chip select. In this manner transitions on the control lines in the GROM array is limited to only those needed by the array; thus, system level noise is reduced. ### 7.9 POWER ANALYSIS | | | +5 | MA | | -5 | MA | |-------|-------------|-------|-------|-------|------|------| | QUAN | DEVICE | MIN | MAX | | MIN | MAX | | | | | | | | | | 1 | SN7417N | 29.Ø | 41.Ø | | - | - | | 1 | SN74LS21N | 1.7 | 3.4 | | - | - | | 1 | SN74LS3ØN | . 5 | .8 | | - | - | | 1 | SN74LS32N | 4.9 | 9.8 | | - | - | | 1 | SN74LS125AN | 11.Ø | 2Ø.Ø | | - | - | | 1 | SN74LS161AN | 19.Ø | 32.Ø | | - | - | | 3 | SN74LS244N | 81.Ø | 138.Ø | | - | - | | 1 | SN74LS259N | 22.Ø | 36.Ø | | - | _ | | 1 | PAL12L6 | 55.Ø | 9Ø.Ø | | - | - | | 1 | SN74SC245N | 1Ø.Ø | 2Ø.Ø | (est) | - | - | | 1 | TMS4732N | 65.Ø | 95.Ø | | - | _ | | 1 | TMS4764N | 89.Ø | 13Ø.Ø | | - | - | | 8 | TMCØ43ØN | 64.Ø | 8Ø.Ø | | 64.Ø | 8Ø.Ø | | | | | | | | | | Total | Currents | 452.1 | 696.Ø | | 64.Ø | 8Ø.Ø | MLB 7/13/82 7-5 PRELIMINARY # 7.1Ø MNEMONIC DEFINITIONS | MNEMONIC | DEFINITION | |------------|--------------------------------------------------------------| | AMC.A | System Address Bus, MSB | | AMB.A | System Address Bus | | AMA.A | System Address Bus | | AØØ.A | System Address Bus | | AØ1.A | System Address Bus | | AØ3.A | System Address Bus | | AØ4.A | System Address Bus | | AØ5.A | System Address Bus | | AØ6.A | System Address Bus | | AØ7.A | System Address Bus | | AØ8.A | System Address Bus | | AØ9.A | System Address Bus | | A1Ø.A | System Address Bus | | A11.A | System Address Bus | | A12.A | System Address Bus | | A13.A | System Address Bus | | A14.A | System Address Bus | | A15/COUT.A | System side combination Address Bus LSB and CRU Output Data. | | AMC.B | Buffered Address Bus, MSB | | AMB.B | Buffered Address Bus | MLB 7/13/82 7-6 PRELIMINARY MNEMONIC DEFINITION | AMA.B | Buffered Address Bus | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AØØ.B | Buffered Address Bus | | AØ1.B | Buffered Address Bus | | AØ2.B | Buffered Address Bus | | AØ3.B | Buffered Address Bus | | AØ4.B | Buffered Address Bus | | AØ5.B | Buffered Address Bus | | AØ6.B | Buffered Address Bus | | AØ7.B | Buffered Address Bus | | AØ8.B | Buffered Address Bus | | AØ9.B | Buffered Address Bus | | A1Ø.B | Buffered Address Bus | | A11.B | Buffered Address Bus | | A12.B | Buffered Address Bus | | A13.B | Buffered Address Bus | | A14.B | Buffered Address Bus | | A15/COUT.B | Buffered combination Address Bus LSB and CRU Output Data. | | A14.C | Buffered Address bit for higher logic "1" voltage for GROM array. | | BDRVR* | Tristate enable for the Bidirectional Data Bus driver chip (SN74LS245). | | CLKOUT.A* | System side of the System Clock. In 99/4A systems, it is the 3Mhz Phase 3 clock and in 99/4X systems, it is a 2.68 Mhz clock (slightly more than twice the pulse width of the 99/4A clock). | MLB 7/13/82 7-7 PRELIMINARY | MNEMONIC | DEFINITION | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CLKOUT.B* | Buffered side of the System Clock. In 99/4A systems it is the 3 Mhz Phase 3 clock and in 99/4X systems it is a 2.68 Mhz clock, slightly more than twice the pulse width of the 99/4A clock. | | CRUCLK.A* | Active Low System side CRU Clock. | | CRUCLK.B* | Buffered Active Low CRU Clock. | | CRULD* | Strobe for loading the CRU Out register. | | DBIN.A | System side Data Bus direction indicator. A "Ø" indicates a WRITE to the PCB and a "1" indicates a READ from the PCB to the CPU. | | DBIN.B | Buffered Data Bus direction indicator. A "Ø" indicates a WRITE to the PCB and a "1" indicates a READ from the PCB to the CPU. | | DBIN.C | Buffered Data Bus direction indicator to gain the required higher logic "1" voltage for the GROM array. | | DØ | System side of the Data Bus, MSB | | D1 | System side of the Data Bus | | D2 | System side of the Data Bus | | D3 | System side of the Data Bus | | D4 | System side of the Data Bus | | D5 | System side of the Data Bus | | D6 | System side of the Data Bus | | D7 | System side of the Data Bus | | EKDSRCS* | Chip select signal for the 8K DSR ROM. | | EKRPG | Half select for the 8K DSR ROM. A "Ø" on this line selects the lower half and a "1" selects the upper half. | | FKDSRCS* | Chip Select signal for the 4K DSR ROM. | MLB 7/13/82 7-8 PRELIMINARY | MNEMONIC | DEFINITION | |----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GCS* | Primary GROM chip select signal from the PLA. It must be buffered for more voltage drive before going to the GROM Array. | | GCS.A* | Buffered GROM Chip Select to gain the higher logic "1" voltage required for the GROM Array. | | GRDY | "READY" output from the GROM array. | | MEMEN.A* | System side Memory Enable control signal. A "Ø" indicates that the CPU IS requesting a memory cycle and a "1" indicates that the CPU MIGHT be requesting a CRU cycle. | | MEMEN.B* | Buffered Memory Enable control signal. A "Ø" indicates that the CPU IS requesting a memory cycle and a "1" indicates that the CPU MIGHT be requesting a CRU cycle. | | PCBEN | Active High control signal used in Burn<br>In to enable the PCB to respond to either<br>Memory or CRU accesses. | | PCPAGE | P-CODE DSR ROM Page Bit. A "1" on this line enables the P-CODE DSR ROM and a "0" disables it. | | PDØ | PCB side of the Data Bus, MSB | | PD1 | PCB side of the Data Bus | | PD2 | PCB side of the Data Bus | | PD3 | PCB side of the Data Bus | | PD4 | PCB side of the Data Bus | | PD5 | PCB side of the Data Bus | | PD6 | PCB side of the Data Bus | | PD7 | PCB side of the Data Bus | | RDBEN* | Remote Data Bus Driver enable control line for use in 99/4-Exp Box Cable interface. | MLB 7/13/82 7-9 PRELIMINARY | MNEMONIC | DEFINITION<br> | |----------|-----------------------------------------------------------------------------------------------------------| | READY.A | System READY input to CRU. | | RESET.A* | System side of the Master Reset. | | RESET.B* | Buffered Master Reset. | | SPARE0* | Spare PLA output. | | W1 | Jumper wire used to connect >1F83 to<br>the LED. If W1 is inserted, W2 shall<br>not be. | | W2 | Jumper wire used to connect >1FØØ to the LED. If W2 is inserted, W1 shall not be. W2 is Factory inserted. | MLB 7/13/82 7-1Ø PRELIMINARY ### 7.11 P-CODE PAL12L6 EKDSRCS = V1\*V2\*AØ1\*AØ3\*/V4\*DBIN\*MEMEN\*PCBEN ; 8K DSR ROM + V1\*V2\*AØ1\*AØ3\*/AØ9\*DBIN\*MEMEN\*PCBEN FKDSRCS = V1\*V2\*AØ1\*/AØ3\*DBIN\*MEMEN\*PCBEN ; 4K DSR ROM BDRVR = V1\*V2\*AØ1\*MEMEN\*PCBEN ; BIDIRECTIONAL BUS DRIVE GCS = V1\*V2\*AØ1\*AØ3\*AØ9\*V4\*DBIN\*MEMEN\*PCBEN\*/AØ5 ; GROM CS + V1\*V2\*AØ1\*AØ3\*AØ9\*V4\*/DBIN\*MEMEN\*PCBEN\*AØ5 ; GROM CS CRUWT = V2\*/AØ1\*AØ3\*V3\*/AØ9\*CRUCLK\*/MEMEN\*PCBEN ; CRU REG LD SPAREO = Spare output | 1 | V1 | 11 | /MEMEN | | | |----|----------------|----|-------------|--|--| | 2 | /V2 | 12 | PCBEN | | | | 3 | AØ1 | 13 | / EKDSRCS | | | | 4 | AØ3 | 14 | / FKDSRCS | | | | 5 | V3 | 15 | / BDRVR | | | | 6 | AØ9 | 16 | /GCS | | | | 7 | /V4 | 17 | / CRUWT | | | | 8 | /CRUCLK | 18 | SPARE0 | | | | 9 | DBIN | 19 | AØ5 | | | | 1Ø | GROUND (POWER) | 2Ø | VCC (POWER) | | | | | | | | | | MLB 7/13/82 7-11 PRELIMINARY # SECTION 8 EXPANSION BOX MEMORY EXPANSION EXPANSION BOX 32K MEMORY EXPANSION Ø2/Ø1/8Ø 8-1 MLB 7/13/82 **PRELIMINARY** ### **UPDATE TRACKS** ### 8/24/81 \* Added section on testing. ### 8/25/81 \* Added to section on testing. ### 11/11/81 - \* Added paragraph on LED. - \* Updated paragraphs on testing. #### 11/12/81 - \* Continued with general update from 11/11/81 review. - \* Changed System I/O connector pinouts to comprehend 19 address lines. #### 1/28/82 - \* Added PAL to documentation. - \* Changed System I/O pin definition to Attleboro plug connector. - \* Added paragraph on Remote Data Bus Driver control. ### 1/29/82 \* Revised device notation from alpha to Ui type. # 2/Ø1/82 \* Added the 50 ma LED load to the +5V current requirement. MLB 7/13/82 8-2 PRELIMINARY #### 8.1 MEU INTENT The intent of this PCB is to provide functional equivalency to the existing 99/4 Memory Expansion Unit while functioning in the Expansion Box. The existing MEU will not function with a TMS9995 microprocessor and this unit shall not be so constrained also. ### 8.2 GENERAL There shall be no more than one input connected to any System driven bus line and bus buffers shall be located in close proximity of the $\rm I/O$ connector. If 4116 DRAMs are to be used, one coupling capacitor shall be provided for each DRAM on both the +12V and -5V buses in close proximity to the DRAM supply pins, and one 22 uF or bigger capacitor shall be provided on both the +12V and the -5V buses for each of the four DRAM chips. If 32K, +5V only parts are to be used, each DRAM shall be bypassed and two 22 uF or larger capacitors shall be provided for the array. For either device type, .1 uF @50V Z5U axial load devices shall be used. Gridded GROUND lines shall be used throughout the DRAM array where practical. System RESET shall not be used on the Memory Expansion, but all sequential logic shall be either pulled up or down to allow initialization for testing on ATE. The DRAMs shall function in the EARLY WRITE mode and shall be timed by the Phase 3 System level clock. Where practical, Signature Analysis hooks shall be included. ### 8.3 ADDRESS ORGANIZATION The Memory Expansion PCB for the Expansion Box shall be $\$ organized as a 32K x 8 DRAM, located in the memory space in four equal segments. These are: - 1) from >2000 thru >3FFF - 2) from >AØØØ thru >BFFF - 3) from >CØØØ thru >DFFF - 4) from >EØØØ thru >FFFF MLB 7/13/82 8-3 PRELIMINARY ### 8.4 MEMORY SPACE DECODE The decode for the memory space shall be a function of the 19 System Address lines, MEMEN\* and PCBEN. The last signal is an active HIGH disable control signal that shall disable the ME PCB and is for PCB Burn In use. ### 8.5 REFRESH A fresh READ shall be performed after every MEMEN\* cycle regardless of what that particular memory was for. If for some reason READY is held FALSE, a REFRESH operation shall occur every 5 1/3 us. The Refresh Address Counter shall be configured such that one full 16K $\times$ 8 bank (i.e. 8 DRAM chips) is Refreshed before starting on the other bank. This address ordering is primarily for ease of Troubleshooting and Repair. ### 8.6 DRAM ARRAY DEVICES Where practical, the buffers for the DRAM array shall be standard TTL rather than LS TTL. Series matching resistors shall be included to ease the capacitive loading effects of under and overshoot if a long physical etch from the driver to the array is required. # 8.7 REMOTE DATA BUS DRIVER CONTROL Provisions shall be made to drive the System Bus line required to enable the remote Data Bus drivers. This shall be a LOW true signal that is open-collector or equivalent. #### 8.8 LED A LED shall be provided that is driven by a one-shot triggered by a CPU requested RAS. The period of the one-shot shall be 200ms + 1/2. Error conditions on this card must be detected in software and a software routine must keep accessing the MEU to keep the LED ON in case of a fail. MLB 7/13/82 8-4 PRELIMINARY # 8.9 SYSTEM BUS PIN DEFINITION | PIN# | MNEMONIC | FUNCTION | |------|------------|------------------------------------| | 1 | | +5V 3-T Regulator supply voltage | | 2 | | +5V 3-T Regulator supply voltage | | 3 | GND | Logic Ground | | 4 | READY.A | System READY | | 5 | GND | Logic Ground | | 6 | | Not used, System RESET | | 7 | GND | Logic Ground | | 8 | | Not used, SCLK | | 9 | | Not used, BOOTPG* | | 1Ø | | Not used, AUDIO | | 11 | RDBENA* | Active Low Remote Data Bus Driver | | | | Enable Control line | | 12 | PCBEN | Active HIGH PCB enable for Burn In | | 13 | | Not used, HOLD* | | 14 | | Not used, IAQHDA | | 15 | | Not used, SENILA* | | 16 | | Not used, SENILB* | | 17 | | Not used, INTA* | | 18 | | Not used, INTB* | | 19 | D7 | System DATA Bus, LSB | | 2Ø | GND | Logic Ground | | 21 | D5 | System DATA Bus | | 22 | D6 | System DATA Bus | | 23 | D3 | System DATA Bus | | 24 | D4 | System DATA Bus | | 25 | D1 | System DATA Bus | | 26 | D2 | System DATA Bus | | 27 | GND | Logic Ground | | 28 | DØ | System DATA Bus, MSB | | 29 | A14.A | Address Bit | | ЗØ | A15/COUT.A | Address Bit, LSB | | 31 | A12.A | Address Bit | | 32 | A13.A | Address Bit | | 33 | A1Ø.A | Address Bit | | 34 | A11.A | Address Bit | | 35 | AØ8.A | Address Bit | | 36 | AØ9.A | Address Bit | | 37 | AØ6.A | Address Bit | 8-5 MLB 7/13/82 PRELIMINARY # SYSTEM BUS PIN DEFINITION, CONTINUED | PIN # | MNEMONIC | FUNCTION | |-------|-----------|--------------------------------------| | | | | | 38 | AØ7.A | Address Bit | | 39 | AØ4.A | Address Bit | | 4Ø | AØ5.A | Address Bit | | 41 | AØ2.A | Address Bit | | 42 | AØ3.A | Address Bit | | 43 | AØØ.A | Address Bit | | 44 | AØ1.A | Address Bit | | 45 | AMB.A | Address Bit | | 46 | AMA.A | Address Bit | | 47 | GND | Logic Ground | | 48 | AMC.A | Address Bit, MSB | | 49 | GND | Logic Ground | | 5Ø | CLKOUT.A* | Active LOW CPU Clock | | 51 | CRUCLK.A* | Active LOW CRU Output Clock | | 52 | DBIN.A | Data Bus Direction, HIGH is CPU READ | | 53 | GND | Logic Ground | | 54 | WE.A* | LOW true CPU Write Enable | | 55 | | Not used, CRUIN | | 56 | MEMEN.A* | Active LOW memory request | | 57 | | -12V 3-T Regulator supply voltage | | 58 | | -12V 3-T Regulator supply voltage | | 59 | | +12V 3-T Regulator supply voltage | | 6Ø | | +12V 3-T Regulator supply voltage | 8-6 MLB 7/13/82 PRELIMINARY ### SECTION 9 # MEU TEST REQUIREMENTS #### 9.1 GENERAL TEST PHILOSOPHY The intent of this section is to detail the test plan for all stages of manufacture starting with Bare Etch Testing and ending with Burn In. The intent of testing is to ensure a top quality finished product; thus, test programs and test times shall be adjusted to compliment the time available for testing during vital steps of the manufacturing process. All active components on the Memory Expansion PCB shall be PEP III parts or eqivalent. ### 9.2 GENERAL COMMENTS Each of the test systems described here shall have a RS-232 port implemented for Host to Satellite communications. This port is in addition to that for debug purposes. #### 9.3 BARE ETCH TESTING The PCB shall be 100% Bare Etch Tested at incoming Quality Control. The results of this test shall be used to modify Production Line testing if desirable (for under etching it may be desirable to run more extensive tests at the first assembled PCB test station, etc.). ### 9.4 ASSEMBLED PCB TESTING This test is intended for ATE testing (possible on the HP3060A) and this is at a point in the line balance where a minimal test shall be run. PCB testing could possibly be done at this point on a functional test system that has the capability of testing other PCBs in the 99/4 family since the load on the 3060A is an unknown at this time. The test patterns are defined in the next paragraph. MLB 7/13/82 9-1 PRELIMINARY - 9.4.1 Marching Patterns. This test shall not be included on the 3060A if it is used for pattern testing. - \* Set the background (BKGND) to "Ø"s. - \* Delay 400 ms. - \* Starting with location $\emptyset$ and advancing to the end of RAM sequentially, read, verify and replace the BKGND byte with all "1"s at each address location. - \* Starting with the top end of memory and advancing sequentially to the lowest address, read, verify and replace the BKGND byte with all $"\emptyset"s$ . - 9.4.2 Checkerboard Pattern. The intent at this point is to verify that all cells respond to 1's and Ø's; therefore, the checkboard pattern is adequate. - \* Starting with address = $\emptyset$ , sequentially load bytes with >55, >AA, >55, ... to the end of the MEU address space. Delay 400 ms and then verify that memory has not changed. Next, load >AA, >55, >AA, ... into the MEU, delay 400 ms and then verify that memory did not change. - 9.4.3 Voltage Parametrics. The test interface shall provide LOW level voltages of .7V +15% -0% and HIGH level voltages of 2.0 +5% -0%. Voltages from the MEU PCB shall be sensed to be less than .4V +/-5% for a LOW and larger than 2.4V +/- 5% for a HIGH level. All voltages are referenced from the ME PCB Logic Ground at the System I/O connector. Worst case parametric voltages shall not be run on the 3060A. 9.4.4 Power Supply Levels. Power supplied to the PCB shall be set at +7.0% for the +5% regulator, +14.5% for the +12% regulator, and -14.5% for the -5% regulator all referenced from the ME PCB Logic Ground at the System I/O connector. Voltage check points shall be selected on the PCB at a point found by trail measuring on prototype PCBs to have the most voltage drop for each level. Fail levels shall be 4.8% for the 5% supplies and 11.5% for the +12%. Pass levels shall be more than or equal to 4.8% or less than or equal to 5.25% in magnitude for the 5% supplies and more than or equal to 11.5% or less than or equal to 12.6% in magnitude for the +12% supplies. These trip levels shall be set with a DVM to +/- .05% of the magnitudes listed. The supply voltage set accuracies shall be +.1% - 0%. MLB 7/13/82 9-2 PRELIMINARY ### 9.5 BURN IN The Burn In tests shall be the most comprehensive as an initial 96 hour Burn In time shall be used. There shall be a CPU PCB and a Controller PCB that drive 16 MEU PCBs per shelf in the Burn In Rack. Each CPU PCB shall be linked via a party line bus to a host machine for both the downloading of test programs and for data logging. - 9.5.1 Test Patterns. A series of test patterns shall be used to adequately test address decoders and data paths and are defined in the following paragraphs. At such time as is shown necessary, the patterns may be adjusted by adding new ones or by deleting existing ones. Note also that the TMS99ØØ moves WORDs rather than bytes and the stored bit patterns will be word even with a MOVB instruction. An alternate pattern generator shall be provided. - 9.5.1.1 GALPAT. A Galloping Pattern shall be used for sense amplifier and data path testing and shall be as is described in this paragraph to test all manufacture devices. The procedure is as follows for an 8-bit wide memory chip array and is to be run one time in each test sequence. - \* Set a background (BKGND) of all Ø's. - \* Write a Test Byte of 1's in the first memory location. - \* Delay 400 ms. - \* Check that the Test Byte is still valid. - \* Check that the first BKGND Byte is still valid. - \* Check that the Test Byte is still valid. - \* Check that the second BKGND Byte is still valid. - Continue this alternating test of the Test Byte and the BKGND Byte until all BKGND bytes have been tested. - \* Restore the Test Byte to the value of the BKGND Byte and put the Test Byte value in the next memory location past that previously tested. - Perform the previously described procedure until ALL BKGND Bytes have been tested, not just those above the address of the Test Byte. Testing is continued until all address locations have contained the Test Byte. - \* Set a BKGND of all 1's, use a Test Byte of all Ø's and run the complete test again. MLB 7/13/82 9-3 PRELIMINARY - 9.5.1.2 Address Complementation. The following pattern shall be used to adequately test the address drivers and shall be run as follows. Note that the concept must be translated to correspond to MEU PCB addressing of its disjoint space as this description pertains to the memory chip addressing. This test is to be run one time in each test sequence. - \* Set a Background (BKGND) of >FF, >ØØ, >FF, >ØØ, etc. - \* Delay 400 ms. - \* Verify address location $\emptyset$ (the Base Address and >FF should be found). - \* Complement the address and check that location (> $\emptyset\emptyset$ should be found). - \* Increment the Test Address and check that location (> $\emptyset\emptyset$ should be found). - \* Complement that address and check that location (>FF should be found). - Continue until the incremented Test Address is 1 larger than the MEU byte address range. - \* Reset the BKGND to $>\emptyset\emptyset$ , >FF, $>\emptyset\emptyset$ , >FF, etc. - Rerun the tests as previously described but with complemented data checks. - 9.5.1.3 Sliding Diagonal. The Sliding Diagonal test writes test data into identical row and column numbers and is as follows. Note that the RAM chip addresses must be translated into 99/4A addresses. Isn't it nice that so much thought was put into the 99/4A memory map? It has certainly made life miserable here! This test is to be run one time in each test sequence and is to verify the memory for sensitivity to diagonal addressing. - \* Set the background (BKGND) to "Ø"s. - \* Delay 400 ms. - \* Write a byte of >FF into ROW=COL=Ø. - Check all other diagonal bytes and finally the Test Byte. MLB 7/13/82 9-4 PRELIMINARY - st Set the Test Byte to $\emptyset$ , increment the ROW-COL number, store the Test Byte there and continue as in the previous step until all diagonals have been checked. - \* Set the BKGND to "1"s and run the test again with the Test Byte = $>\emptyset\emptyset$ . - 9.5.1.4 Random Address/Data Checks. This test sequence is to be run repetitively after the other test have been run until the Host machine commands it to be halted. - \* Set the background (BKGND) in location $\emptyset$ of >5A. - \* Generate address locations from a LSRG counter with feedback bits of Qn and Qp. The seed word shall be >ØØØ1 and that shall be translated to the corresponding MEU PCB addresses. A seperate LSRG counter shall be used to generate data to be stored. - \* Fill the MEU PCB with these bit patterns in that manner and save the last LSRG address as a new address seed word and the last data byte for that new seed byte. - \* Delay 400 ms. - \* Regenerate the random address/data information and verify it for each memory location. - \* Using the last LSRG counter address as new seed word, rerun the tests as outlined for that, with a seed of >0001. - \* Continue this self feeding test until told to stop by the host machine. - 9.5.2 Power Cycling. It shall be the duty of the Host machine to Power Cycle each shelf of the Burn In Rack on a cycle of 30 minutes ON and 15 minutes OFF. This cycle shall be modified as additional information is obtained and AC Line control shall be utilized rather than DC Power Control. - 9.5.3 Error Data Logging. An eight position stack shall be assigned to each Burn In Rack PCB position for error data logging. Each position shall contain the type of test failed, the address of the failure, the test data, the faulty data and the time into the test in hours and minutes. The latter information shall be used to adjust the Burn In time period. MLB 7/13/82 9-5 PRELIMINARY #### SECTION 10 ### EXPANSION BOX MEU THEORY OF OPERATION ### 1Ø.1 PURPOSE The purpose of this document is to detail the electrical operation of the 99/4 Expansion Box Memory Expansion PCB. ### 10.2 APPROACH The presentation of material will be to first cover 4116 DRAM fundamentals as they are used in the Memory Expansion PCB and then to discuss the Memory Expansion PCB functional blocks. ### 10.3 MEU SCHEMATIC SEGMENTATION The schematics for the Memory Expansion PCB are drawn on several B size sheets and schematic page numbers are noted on figure 1 for each functional block. The functional description of each schematic page is found at the bottom of that page. #### 10.4 TERMS USED - BANK 8 DRAM chips to give 16K bytes and all connected to the same RAS\* and CAS\* drivers. - SEGMENT an 8K contiguious DRAM space. - PHASE 2 CLOCK Mainframe Phase 2 clock. It does not come outside of the Mainframe, but most memory related control signals (WE\* excepted) are timed with respect to this clock phase by the TMS $\,$ 99ØØ. - PHASE 3 CLOCK Mainframe Phase 3 clock that is used in the Mainframe and is available from the I/O Port for Peripheral The Memory Expansion PCB and other peripherals use this clock. MLB 7/13/82 1Ø-1 **PRELIMINARY** ### 10.5 TMS 4116 DRAM FUNDAMENTALS - 10.5.1 GENERAL REMARKS. The fundamentals of DRAM operation revolve around eight main points: - 1) RAS\* - CAS\* 2) - 3) the address bus - 4) - 5) Supply current requirements - DATA OUT latched vs. unlatched - DATA IN 7) - 8) REFRESH requirements All will be discussed later in these notes. A RANDOM ACCESS MEMORY has been corrupted to now mean a memory that can be either WRITTEN to or READ from AND any memory location may be directly selected with equal ease by the ADDRESS lines to this The latter part of this definition includes either a READ/WRITE or READ ONLY MEMORY, but the first part includes only a READ/WRITE memory. The first part is the corruption of the term RAM. Note also that ROM normally means Random Access Read Only Memory...so much for words, though. The TMS 4116 DRAM is of the address MUXed variety that has two chip select signals required to get the full address into the memory chip. The user of the chip must provide the external multiplexer to MUX the address bus and the SN74LS257N guad 2/1 MUX is frequently used for this. - 10.5.2 RAS\*. Most memories have an input that is used to tell the memory that an access request is required, or in other words, to turn the memory ON. RAS\* is a LOW true signal that is used to load (strobe) the address on the DRAM Address Bus into the internal Row Address Register. RAS stands for Row Address Strobe. RAS\* normally goes LOW before CAS\* does. - 10.5.3 CAS\*. CAS\* is the Column Address Strobe and is used to load the internal DRAM Column Address Register when CAS\* goes LOW. It also enables the output buffer if a READ operation is indicated on the W\* (READ/WRITE) control input (W\*=1). CAS\* will go LOW after RAS\* does and there is a minimum time period when both are active. Most designs (ME PCB included) require that they both go inactive at the same time when they are both active concurrently. MLB 7/13/82 1Ø-2 PRELIMINARY - 10.5.4 W\*. The W\* input indicates a READ operation if W\* is HIGH and a WRITE oeration if W\* is LOW. It must be stable very shortly after CAS\* occurs, but is not used on the falling edge of RAS\*. If neither RAS\* or CAS\* is true, W\* wil not affect the DRAM if it changes state and thus is quite often connected directly to the CPU signal DBIN. - 10.5.5 SUPPLY CURRENT REQUIREMENTS. Current spikes, typically 80 ma per chip on both the +12V and -5V supply lines, occur when either RAS\* or CAS\* go LOW; that is, one 80 ma spike when RAS\* goes LOW and then another one when CAS\* goes LOW. Bypass capacitors on each chip must furnish this abrupt but short term current requirement. - 10.5.6 OUTPUT DATA. The TMS 4116 has unlatched data outputs that will release drive to the DATA BUS when CAS\* returns to a high level. Many 4K DRAMS of the Address MUXed variety have latched outputs which do not behave in the previously described manner. - 1Ø.5.7 INPUT DATA. Input Data must be stable at the time that CAS\* occurs. If HIGH Data is stored, HIGH Data will be read and vice versa. - 10.5.8 REFRESH. REFRESH is a term used to describe an operation required to re-establish data in each memory cell because they will otherwise be lost by capacitor discharge action. Either a READ or WRITE to each of the 128 Row Addresses will accomplish this task, but since a WRITE operation would require one to know what should be in memory to begin with, a READ operation is normally used. All 128 combinations of the DRAM 7 bit Address Bus must be READ (refreshed) within a 2 ms time period. At room temperature this may be a much longer time period, but it goes down as temperature increases. There is no need to activate CAS\* for this operation; thus, system level noise may be reduced by not driving CAS\* for a REFRESH operation. The ME PCB design does not drive CAS\* for a REFRESH operation. ### 10.6 CLOCKING SCHEME The Phase 3 clock supplied from the CPU is the clock used in the ME PCB and all clocking is done with either the TRUE Phase 3 or the FALSE Phase 3 clock to provide both Leading Edge (LE) and Trailing Edge (TE) clocking action. The period of the clock is 333 ns and the active pulse width is about 63 ns. From the TE of one clock pulse to the LE of the next is about 270 ns (333 - 63). MLB 7/13/82 1Ø-3 PRELIMINARY #### 10.7 ADDRESS SPACE The ME PCB responds to two disjoint and unequal sized memory spaces in the 64K byte CPU memory space. The first is an 8K byte block starting at >2000 and ending with memory location >3FFF and the second is a 24K byte block starting at >AØØØ and ending with >FFFF. ### 10.8 SYSTEM BUS BUFFERS All output lines from the CPU are buffered before they are used on the ME PCB. The DATA Bus is also buffered prior to being used. Input lines are unbuffered since a number of modules may drive them. Either open-collector or tri-state gates must be used to drive these lines. READY is an example of a line that may be either driven or sensed. The ME PCB senses this line for REFRESH purposes, but does not drive it. - 10.8.1 Address Bus. All Address bits are buffered. - 10.8.2 Data Bus. The Data Bus is buffered and is only enabled for the Memory Expansion PCB memory space. - 10.8.3 Control Lines. Five CONTROL lines are buffered for use on the ME PCB and they are: - 1) MEMEN\* - 2) DBIN - **PCBEN** 3) - 4) READY - 5) PH3\* #### 10.9 DRAM SEGMENTATION There are two banks of 8 each 4116 DRAMs to obtain the 32K byte capacity. Devices U2Ø, U21, U22, U23, U24, U25, U26 and U28 respond to both the >2000 and the >A000 bases, and the devices U28, U29, U30, U32, U33, U34 and U35 respond to the >CØØØ and >EØØØ bases. Note that the address space between >AØØØ through >FFFF is contiguous. MLB 7/13/82 1Ø-4 **PRELIMINARY** The Address Bit A1 functions as a bank select bit and a pseudo address bit is formed by the ANDing of AØ and A2. This choice gives the proper four different combinations of the bank select and the pseudo address bits, and may be seen in the following table. | | ΑØ | A1 | A2 | А3 | A4-A7 | A8-A11 | A12-A15 | |-------|----|----|----|----|-------|--------|---------| | | | | | | | | | | >2ØØØ | Ø | Ø | 1 | Ø | Ø | Ø | Ø | | >AØØØ | 1 | Ø | 1 | Ø | Ø | Ø | Ø | | >CØØØ | 1 | 1 | Ø | Ø | Ø | Ø | Ø | | >EØØØ | 1 | 1 | 1 | Ø | Ø | Ø | Ø | The previous listing of AØ, A1, A2 and A3 show that A2 is a "1" in 3 out of 4 cases. It needed to be a "1" half of the time in one bank and a "1" half of the time in the other bank for proper Memory This condition is met by ANDing AØ and A2 to Expansion operation. provide the modified address bit "APO". | | AP0 | A1 | А3 | A4-A7 | A8-A11 | A12-A15 | |-------|-----|----|----|-------|--------|---------| | | | | | | | | | >2ØØØ | 1 | Ø | Ø | Ø | Ø | Ø | | >AØØØ | Ø | Ø | Ø | Ø | Ø | Ø | | >CØØØ | 1 | 1 | Ø | Ø | Ø | Ø | | >EØØØ | Ø | 1 | Ø | Ø | Ø | Ø | Notice here, that A1 is a "1" half of the time and a " $\emptyset$ " the other half. This is the address bit used for 4116 bank selection with the pair of AND OR INVERT gates in A6. ### 10.10 ADDRESS MULTIPLEXER A 7 bit DRAM address is derived from either the 16 bit CPU Address Bus or the 8 bit Refresh counter buffers. A 2/1 MUX is used to obtain a 7 bit address from the CPU Address (3 CPU Address Bits are used to determine which of the four 8K segments will be selected and note that this choice includes none of the four, MUX B2 does this). Devices U15 and U16 are 74LS257 MUXes with 3 state outputs and are used for CPU address MUXing to the DRAM address bus. Seven 3 state drivers in U19 are used to MUX the Refresh Address onto the 7 bit DRAM Address Bus when the CPU Address Bus is not needed. Notice from Sheet 3 of the Memory Expansion PCB Schematics that if the CPU is not requesting a MEU cycle, the DRAM Address Bus is connected to the Refresh Counter. concept lowers the random system level noise generated by drivers unnecessarily driving large loads. This concept has also been applied to both the W\* input of the 16 DRAM chip array and the DATA inputs as well. 1Ø-5 MLB 7/13/82 PRELIMINARY #### 10.11 REFRESH LOGIC Refresh logic is found in devices U10, U18, U19, U7A U12B and U1. A Refresh Cycle will be initiated: - 1) after every MEMEN\* cycle of the CPU - 2) on 5 1/3 us intervals if the CPU MEMEN\* is inactive (HIGH) - 3) if CPU MEMEN\* is active (LOW) and READY to the CPU is FALSE (LOW) The latter case will occur when the CPU requests cycles from the Speech Module or possibly when the CPU accesses either GROMs or the VDP. This give more than adequate margin on the required 2 ms Refresh time period. Each bank of 8 4116 DRAM chips is Refreshed individually (first one, and then the other). U1Ø on Sheet 1 of the Schematics is a counter that is used to request Refresh cycles. It is put in the LOAD state to load >E (14) into the counter when MEMEN\* goes active LOW and READY stays HIGH. MEMEN\* goes HIGH shortly after the Leading Edge (LE) of the Phase 2 clock in the 99/4 M/F and A1 will be incremented to >F (15) on the TE of the very next Phase 3 clock. Now, the Ripple Carry output (pin 15) will go HIGH. U7A is connected to the Ripple Carry output of U1Ø, will be clocked SET on the Leading Edge (LE) of the next Phase 3 clock pulse after U1Ø was incremented from >E to >F. U7A generates what is called REFRAS, and it will be SET for 333 ns (one Phase 3 clock period). MEMEN\* will be HIGH for at least 666 ns and the Refresh operation will complete MEMEN\* can go LOW again. If MEMEN\*, for some reason, stays HIGH (CPU is executing a LDCR, MPY or perhaps a DIV instruction) or if the CPU is accessing the Speech Module and READY is LOW, U10 will count normally to >F and a Refresh cycle will be initiated in the same manner just described. The Refresh Address Counter (A1) will be incremented on the TE of REFRAS. ### 10.12 RAS0/RAS1 SELECTION Address bit A1 is synchronized to provide stability from one access into the next and then used to select which of the two DRAM banks is to receive RAS\*. The Refresh Address Counter MSB is select between the two banks for the Refresh. There is was done in order to completely REFRESH one bank before starting the other. CAS\* does not occur for Refresh cycles. 1Ø-6 MLB 7/13/82 PRELIMINARY ### 10.13 DATA CONNECTIONS Both the data IN (D) and data OUT (Q) pins on the 4116 DRAMs are connected together for EARLY WRITE operation. WRITE data are gated to the DRAM banks through 1Ø.13.1 Data TO DRAM. U3 (74LS245) which is enabled any time the ME PCB is selected. 10.13.2 Data FROM MEU. READ data are gated to the System Data Bus U3 (74LS245) with RAS\* and CAS\* both active (RAS\*=CAS\*=LOW); thus, data is stable for the 9900 CPU. See the attached timing diagrams in FIGURES 2 and 3 for this and note that the 9900 takes READ data in during the Phase 1 clock time period. The proper Phase 1 is marked on the Timing Diagram. ### 10.14 TEST CONSIDERATIONS A pull-down resistor is used to connect the HIGH true CLEAR inputs of the Refresh Address Counter (U18) to Ground. This allows one to momentarily short this to +5V to reset the Refresh Address or to disable the full Refresh Address space range. It is currently used to facilitate using Signature Analysis on the Refresh logic. pull-up resistor is used on direct inputs to U7A, U9, U11 and U18 to allow Automatic Test Equipment (ATE) use on the ME PCB. primary consideration is to allow the ATE to initialize the MEU logic to a known condition and the signal is named INIT\*. ### 10.15 EARLY WRITE The Early Write technique is used to Write to the DRAMs. simply means that W\* is stable just before and stays so all during the time when CAS\* is active (LOW). The System DBIN.A is clocked by Q2 into FF U8B in order to guarantee its stability for the entire duration of the 4116 cycle. The FF is jammed to the RESET state when the 9900 is not requesting cycles from the ME PCB. MLB 7/13/82 1Ø-7 PRELIMINARY # 10.16 MEU OPERATION, GENERAL COMMENTS This section is included to walk one memory cycle through. FIGURES 2 and 3 are timing diagrams of the system and note that the CPU requires two bytes for its operation. If the CPU locates its Work Space in the MEU, quite often four bytes will be required, and six bytes will be required for a RTWP instruction. These multiple byte accesses will be "back to back" accesses running the MEU as fast as it will go (1 us byte cycle times). #### 10.17 MEU IDLE STATE A state counter made up of two SN74LS1Ø9A FFs (U11) is used to control the 4116 DRAMs. FF U9A is used to detect when the CPU is requesting ME PCB cycles and is the control input to the state counter. CAS is derived asynchronously after the address MUX has changed and is the only case where asynchronous timing is used. There is no possible conflict, as it is timed directly off of an event that must occur before CAS\* itself may occur. # 10.18 FIRST CYCLE The CPU will activate MEMEN\* shortly after the LE of the Phase 2 clock in the Mainframe and the Address Bus (and Data Bus too, if a WRITE operation is to occur) will be stablized at that time also. is a PAL12L6 that is used to decode the CPU ddress Bus and generate a cycle request if the MEU space is selected (it is also a function of the Burn In signal PCBEN). FF U9A is clocked OFF on the TE of PH3.B (with PH3.B\*) and the state counter will count from the ØØ state (A2A=Ø and $A2B=\emptyset$ ) to the state $\emptyset1$ ( $A2A=\emptyset$ , A2B=1) on the LE of the next PH3 clock (with PH3.B). U11B forms the signal Q2 that is the root signal of RAS\* and this signal is applied to the PAL12L6 to generate either RASØ\* or RAS1\* (the synchronized Address bit A1 selects which one). With the exception of the PAL which is found on Sheet 2 of the schematics, the prementioned logic is found on Sheet 1. When Q2 goes HIGH, the MUX control FF (U8A) is released from the jammed RESET condition and will be clocked SET with the TE of the same clock pulse that caused the state counter to be clocked to the Ø1 state. This delay provides more than adequate margin for RAS data hold time. Also, the cycle request sense FF U9A is jammed SET by Q2\* for the duration of the DRAM cycle. 1Ø-8 MLB 7/13/82 PRELIMINARY When the MUXing action is completed, a "Ø" will be gated to the Inverter C3E, which in turn clocks on FF U7B to generate CAS. This signal then drives the DRAM array through a 27 ohm resistor. The MUX control FF is also on Sheet 1 and the Address MUX with CAS FF is on Sheet 3. At this stage the DRAMs are turned on and the cycle is initiated. The next PH3 LE will advance the state counter to the 11 state since RAS is a function of Q2, it is still LOW (as is CAS\*). The 9900 will take data if a READ operation is to occur on the very next CPU PH1 clock, MEMEN\* will return to a HIGH condition if the cycle is complete on the following CPU PH2 clock and in any case the state counter will count back to the ØØ state on the LE of the next PH3 clock pulse. Once back in the ØØ state both the MUX and CAS FFs are jammed RESET, RAS is turned OFF and the cycle request sense FF U9A is once again able to detect if the CPU is asking (and it may still be) for a memory cycle. #### 10.19 CALCULATED POWER REQUIREMENTS The total power requirements ignore 3-Terminal requirements and the totals are based on a 1/3 duty cycle allocated to Operating, Refresh and Idle modes of operation. | +12 Load | | +5 | Load | -5 | Load | | |----------|-----|-----|------|-----|------|--| | ma | | ma | | | ua | | | TYP | MAX | TYP | MAX | TYP | MAX | | | | | | | | | | | 1Ø3 | 175 | 319 | 515 | 373 | 2133 | | 10.19.1 TTL Power Requirements. TTL currents were based on largest values taken with devices in their "normal" states; ie. SN74LS245 and Refresh SN74LS241 in the tristate condition, etc. | +12 Load | | +5 | Load | -5 I | ∟oad | |----------|-----|-----|------|------|------| | ma | | ma | | ua | | | TYP | MAX | TYP | MAX | TYP | MAX | | | | | | | | | Ø | Ø | 368 | 564 | Ø | Ø | MLB 7/13/82 1Ø-9 PRELIMINARY 10.19.2 MOS Power Requirements. MOS requirements are based on a 16 chip array and single chip requirements are listed in the following table. | | +12 Load | | +5 | +5 Load | | -5 Load | | |-----------|----------|-----|-----|---------|-----|---------|--| | | m | а | | ma | | ua | | | | TYP | MAX | TYP | MAX | TYP | MAX | | | | | | | | | | | | Operating | 27 | 35 | - | Ø.1 | 5Ø | 200 | | | Refresh | 20 | 27 | - | - | 5Ø | 200 | | | Stand By | Ø.5 | 1.5 | - | - | 1Ø | 1ØØ | | Further, assuming that the duty cycle will be 1/3 of each column but for only eight chips (the other eight will be in the Stand By mode), the following array currents are obtained. | +12 Load<br>ma | | +5 | Load | -5 | Load | |----------------|-----|-----|------|-----|------| | | | ma | | ua | | | TYP | MAX | TYP | MAX | TYP | MAX | | | | | | | | | 1Ø3 | 175 | - | 1 | 373 | 2133 | # 10.20 MEASURED POWER REQUIREMENTS TO BE ADDED WHEN AVAILABLE MLB 7/13/82 1Ø-1Ø **PRELIMINARY** # 10.21 EXP BOX MEU PAL12L6 DEFINITION RASØ = MQ2\*/AØ1S + REFRAS\*/REFADR7 MESEL = PCBEN\*MEMEN\*AMC\*AMB\*AMA\*/AØ1\*AØ2 + PCBEN\*MEMEN\*AMC\*AMB\*AMA\*AØØ\*AØ1 RAS1\* = MQ2\*AØ1S + REFRAS\*REFADR7 APØ2 = AØØ\*AØ2 Spare Output MEMENB = /MEMEN | 1 | PCBEN | 11 | REFRAS | |----|----------------|----|--------------| | 2 | AMC | 12 | REFADR7 | | 3 | AMB | 13 | /RASØ | | 4 | AMA | 14 | /MESEL | | 5 | AØØ | 15 | /RAS1 | | 6 | AØ1 | 16 | /APØ2 | | 7 | AØ2 | 17 | Spare Output | | 8 | /MEMEN | 18 | /MEMENB | | 9 | MQ2 | 19 | AØ1S | | 1Ø | GROUND (POWER) | 2Ø | VCC (POWER) | MLB 7/13/82 1Ø-11 **PRELIMINARY** # DOUBLE SIDED, SINGLE DENSITY DISK CONTROLLER PCB SPEC DWG #ØØØØØØ8 Ø5/Ø5/82 MLB 7/13/82 11-1 **PRELIMINARY** # **UPDATE TRACKS** ## 8/18/81 \* Added paragraph on 99/4A and 99/4B Software incompatibilities. ## 9/22/81 - \* Added CRU sense of Motor ON condition. - \* Started Theory of Operation # 10/07/81 Continued Theory Of Operation # Ø1/29/82 - Changed System I/O definition to Attleboro plug. - Added PAL definition. #### Ø2/Ø2/82 Continued general revision started 1/29/82. # Ø5/Ø5/82 Fixed System Bus Pin screw up for interrupts and added LCP and LINSP definitions. MLB 7/13/82 11-2 **PRELIMINARY** #### SECTION 11 # DS/SD DISK CONTROLLER ELECTRICAL SPECIFICATIONS # 11.1 DISK CONTROLLER PCB (DOUBLE SIDED/SINGLE DENSITY) The Disk Controller shall control up to three Double Sided, Single Density, 5 1/4" Mini Floppy disk drives through a Western Digital 1771 chip. Memory addresses for the Johnny Box are derived by dropping the most significant character. 11.1.1 Intent. The intent of this PCB is to provide equivalency to the existing 99/4 Disk Controller Module while functioning in either the Johnny Box or the 99/4B. Two additional features shall be added in the form of a side select and a "drive connected" sense for each of the three possible drives. # 11.2 GENERAL - \* There shall be no more than one input connected to the System driven Bus. No more than three open collector or tri-state outputs may be connected to drive the System Bus. - \* Memory/CRU space decodes shall comphrehend PLA decoding as a cost reduction path. - \* Timing considerations for the WD 1771 shall be made such that none are either violated or marginal. - An adequate number of decoupling capacitors shall be provided for the logic chips. Particular attention shall be paid to MSI and LSI chips. - \* RFI consideration shall be applied to the Drive I/O Port. - \* All System Bus signals driven by the Disk Controller shall comply with standard TTL voltage levels. MLB 7/13/82 11-3 PRELIMINARY ## 11.3 KNOWN 99/4A AND 99/4B SOFTWARE INCOMPATIBILITIES As of 8/18/81 there are no known incompatibilities. #### 11.4 TESTABILITY Signature Analysis shall be designed in as the desired method of test. Test specification shall be written for this PCB after both the design and debug efforts have been completed. #### 11.5 DESIGN VERIFICATION System level propogation delays shall be carefully measured on each of the QUAL units and compared against design values. Any negative deviations shall be fully understood and these shall drive redesign where required. ## 11.6 DSR ROM The DSR ROM space decode shall be a function of the 18 System Address lines MEMEN\*, DBIN, the DSR ROM Page enable and the signal PCBEN. PCBEN is a HIGH true signal that will be used in the Burn In Racks. The DSR ROM shall be considered to be an 8K x 8 ROM (or a pair of $4K \times 8 \text{ ROMs}$ ) and shall be connected such that an EPROM(s) can be substituted with no wiring changes. The 1771 shall occupy a trapped area in the top of the DSR ROM space. This area shall be defined by the AND combination of the following Address bits HIGH: AMC, AMB, AMA, AØ\*, A1, A2\*, A3, A4, A5, A7, A8, A9, A10 and A11. The DSR ROM base address shall be at >34000 (>4000 for Johnny Box) and the DSR ROM Page enable shall respond to a CRU base of >Ø11ØØ (>1100 for the Johnny Box). MLB 7/13/82 11-4 PRELIMINARY # 11.7 CRU DEFINITION The CRU space comphrehend 15 System Address lines (the most significant two Address lines being ignored) and the HIGH true signal PCBEN which will be used in the Burn In Racks. The CRU base address for the Disk Controller PCB shall be at >Ø11ØØ and the System RESET shall reset all the output bits to a LOW value (same as a SBZ at >Ø11ØØ instruction). # 11.7.1 CRU Output Bit Definitions. | DISPLACEMENT | FUNCTION | |--------------|---------------------------------------------------------------------------| | | | | Ø | Disk DSR ROM Page Enable, 1=enabled Also used for LED, Ø=0FF 1=0N | | 1 | Motor keep alive strobe (pulse formed by a SBO 1 - SBZ 1 inst combination | | 2 | Wait enable for 1771 chip communication 1=enabled | | 3 | Head Load timing to 1771 chip, 1=load head | | 4 | Drive #1 select, 1=selected | | 5 | Drive #2 select, 1=selected | | 6 | Drive #3 select, 1=selected | | 7 | Side select, Ø=Normal 1=Opposite | 11.7.2 CRU Input Bit Definition. The functions to be sensed through the CRU are the "HEAD LOAD" output of the WD 1771 chip, the three "drive connected" sense lines and the Head Select line. These are detailed in the following table. CRU IN Definition | DISPLACEMENT | FUNCTION | |--------------|---------------------------------------| | | | | Ø | HEAD LOAD Output of WD 1771 chip | | 1 | Drive #1 Connected sense, Ø=connected | | 2 | Drive #2 Connected sense, Ø=connected | | 3 | Drive #3 Connected sense, Ø=connected | | 4 | Motor ON sense, Ø=ON 1=OFF | | 5 | VCC | | 6 | VCC | | 7 | Ground | MLB 7/13/82 11-5 PRELIMINARY ## 11.8 SYSTEM INTERFACE FOR WD 1771 the 1771 was designed to interface to an 8080 uP (microprocessor), special care shall be exercised in the timing area so as not to violate the required 1771 timing. ## 11.9 DATA/CLOCK SEPARATOR An external Data/Clock separator shall be used instead of the 1771 internal separator. One shots shall be avoided if practical as a design goal. ## 11.10 MOTOR DRIVE KEEP ALIVE A five second keep alive circuit shall control the disk drive motor line. The "keep alive" function shall be realized by pulsing the circuit (SBO/SBZ) from the CRU output. # 11.11 WD 1771 CRYSTAL OSCILLATOR A one Mhz crystal controlled clock shall be provided for the 1771 chip. #### 11.12 INTERRUPTS The Disk Controller PCB shall be connected to interrupt on ILB with an ILSB of bit Ø. #### 11.13 CONNECTORS There shall be a single 34 pin male PCB connector for external disk drive I/O and a single 34 pin header type connector for the internal drive. If used, the internal drive should be the first possible drive. MLB 7/13/82 11-6 PRELIMINARY ## 11.14 I/O CONNECTOR GROUND RETURNS The odd pin numbers of the 34 pin I/O connectors are all Ground pins. They shall be bussed together into a bus of Ø.125" width or larger, and run as short as is practical to the Ground pins of the driver chips and then to the receiver chips. This shall be done in order to provide a good Ground return for RFI and other TTL considerations. ## 11.15 RECEIVER PULL-UP RESISTORS All pull-ups on received I/O lines shall be 1K Ohms with the exception of the DATA line. It shall be pulled up with a 470 Ohm resistor. ## 11.16 I/O DRIVERS Driven I/O to the disk drives shall be open collector devices capable of sinking 16 ma minimum. ## 11.17 I/O RFI CONSIDERATIONS A LC pi filter network shall be used on I/O lines as necessary to provide acceptable RFI levels. MLB 7/13/82 11-7 PRELIMINARY # 11.18 DISK DRIVE I/O PORT DEFINITION, BOTH PORTS | PIN | TYPE | FUNCTION | |----------|-------------|----------------------------------------------| | 1 | | Logic GROUND | | 2 | | Not Used | | 3 | | Logic GROUND | | 4 | | Not Used | | 5 | | Logic GROUND | | 6 | | Not Used | | 7 | | Logic GROUND | | 8 | receive | Index Pulse from Drive, LOW TRUE PULSE | | 9 | | Logic GROUND | | 1Ø | drive | Drive Select #1, LOW=SELECTED | | 11 | | Logic GROUND | | 12 | drive | Drive Select #2, LOW=SELECTED | | 13 | | Logic GROUND | | 14 | drive | Drive Select #3, LOW=SELECTED | | 15 | | Logic GROUND | | 16 | drive | Motor control, LOW=ON | | 17 | | Logic GROUND | | 18 | drive | Head Step Direction, LOW=STEP OUT | | 19 | | Logic GROUND | | 2Ø | drive | Head Step pulse, LOW TRUE PULSE | | 21 | al .a. al a | Logic GROUND | | 22 | drive | Write Data, LOW=TRUE | | 23 | doduc | Logic GROUND | | 24<br>25 | drive | Write Gate, LOW=WRITE ENABLE<br>Logic GROUND | | 26<br>26 | receive | Track ØØ, LOW=TRACK ØØ | | 20<br>27 | receive | Logic GROUND | | 28 | receive | Write Protect, LOW=PROTECTED | | 29 | 1000170 | Logic GROUND | | 3Ø | receive | Read Data, LOW=TRUE | | 31 | 1000110 | Logic GROUND | | 32 | drive | Side Select, Ø=Opposite 1=Normal | | 33 | <u> </u> | Logic GROUND | | 34 | | Not Used | | | | | MLB 7/13/82 11-8 PRELIMINARY # 11.19 SYSTEM BUS PIN DEFINITION .100" PIN TO PIN SPACING, ATTLEBORO CONNECTOR | PIN # | MNEMONIC | FUNCTION | |-------|------------|-------------------------------------------------------| | 1 | | +5V 3-T Regulator supply voltage | | 2 | | +5V 3-T Regulator supply voltage | | 3 | GND | Logic Ground | | 4 | READY.A | System READY | | 5 | GND | Logic GROUND | | 6 | RESET* | Active LOW System driven RESET | | 7 | GND | Logic GROUND | | 8 | | Not Used, SCLK | | 9 | | Not Used, LCP | | 1Ø | | Not Used, AUDIO | | 11 | RBDEN* | Active Low Remote Data Bus Driver Enable control line | | 12 | PCBEN | Active HIGH PCB enable for Burn In | | 13 | | Not Used, HOLD* | | 14 | | Not Used, IAQHDA | | 15 | | Not Used, SENILA* | | 16 | SENILB* | Active LOW sense Interrupt Level B | | 17 | | Not Used, INTA* | | 18 | INTB* | Active LOW Interrupt Level B | | 19 | D7 | System DATA Bus, LSB | | 2Ø | GND | Logic Ground | | 21 | D5 | System DATA Bus | | 22 | D6 | System DATA Bus | | 23 | D3 | System DATA Bus | | 24 | D4 | System DATA Bus | | 25 | D1 | System DATA Bus | | 26 | D2 | System DATA Bus | | 27 | GND | Logic Ground | | 28 | DØ | System DATA Bus, MSB | | 29 | A14.A | Address Bit | | ЗØ | A15/COUT.A | • | | 31 | A12.A | Address Bit | | 32 | A13.A | Address Bit | | 33 | A1Ø.A | Address Bit | MLB 7/13/82 11-9 PRELIMINARY # SYSTEM BUS PIN DEFINITION, CONTINUED | PIN # | MNEMONIC | FUNCTION | |-------|-----------|--------------------------------------| | | | | | 34 | A11.A | Address Bit | | 35 | AØ8.A | Address Bit | | 36 | AØ9.A | Address Bit | | 37 | AØ6.A | Address Bit | | 38 | AØ7.A | Address Bit | | 39 | AØ4.A | Address Bit | | 4Ø | AØ5.A | Address Bit | | 41 | AØ2.A | Address Bit | | 42 | AØ3.A | Address Bit | | 43 | AØØ.A | Address Bit | | 44 | AØ1.A | Address Bit | | 45 | AMB.A | Address Bit | | 46 | AMA.A | Address Bit | | 47 | GND | Logic Ground | | 48 | AMC.A | Address Bit, MSB | | 49 | GND | Logic Ground | | 5Ø | CLK0UT* | Active LOW CPU Clock | | 51 | CRUCLK.A* | Active LOW CPU Output Clock | | 52 | DBIN.A | Data Bus Direction, HIGH is CPU READ | | 53 | GND | Logic Ground | | 54 | WE.A* | LOW true CPU Write Enable | | 55 | CRUIN | HIGH true CRU Input data | | 56 | MEMEN.A* | Active LOW memory request | | 57 | | -12V 3-T Regulator supply voltage | | 58 | | -12V 3-T Regulator supply voltage | | 59 | | +12V 3-T Regulator supply voltage | | 6Ø | | +12V 3-T Regulator supply voltage | MLB 7/13/82 11-1Ø PRELIMINARY #### SECTION 12 #### DISK CONTROLLER THEORY OF OPERATION # 12.1 PURPOSE The purpose of these notes are to provide a detailed Theory of Operation to aid in Trouble Shoot and Repair (TS&R). The intent of the Disk Controller PCB is to provide a unit very similiar to the existing Disk Controller Module but with minor enhancements. The date for the January CES (Consumer Electronics Show) dictated that we do very little developement effort. We did add an 8 bit CRU Input port to replace the bit one on the existing DCM and designed the timing one-shots out of the Data/Clock Separator. We also added simple sense circuits to determine if a drive was connected to the desired drive number (a total of 3 sense circuits) and used the spare CRU Output bit to be a "Side Select" to allow double sided disks. # 12.2 AREAS OF INTEREST There are about 11 major areas of interest on this PCB and they will be covered in detail in the following paragraphs. 12.2.1 PLA and Support Logic. All major System Bus decoding is done in a Programmable Logic Array and there are five out of the six available outputs used. Additional logic in the form of a 3-AND, an 8-NAND and a 3-NOR is used to reduce the number of inputs required on the PLA. Additionally, the 8-NAND is used to determine when the upper DSR ROM (it responds starting at >75000) should be disabled and the WD 1771 chip enabled in its place. This occurs at the top end of the upper DSR ROM space (starts with >75FFØ). The 3-AND gate ANDs the three most significant bits of the System Address Bus together in order to obtain a 3 to 1 PLA input reduction and is used only for memory address decodes and not for CRU operations. The 3-NOR gate is used only for CRU decodes and also gives a 3 to 1 PLA input pin reduction. 12-1 MLB 7/13/82 PRELIMINARY - 12.2.2 WD 1771 Disk Controller Chip. The Chip select to the WD 1771 chip is driven LOW when the WORD address space is satisfied. One us (microsecond) later, the Read Enable input will be driven if DBIN is If DBIN is LOW, the Write Enable input is driven with WE\* a little longer than 1 us later than the WD 1771 Select. A15/COUT is the gating element in the first case and both A15/COUT and WE\* are getting elements in the second. - 12.2.3 READY Control. The System READY line is manipulated only when data is being Written To or Read From the Disk Drive. This is enabled by a SBO 2 operation and once done, any access of the WD 1771 chip (if the Keep Alive One-shot has not timed out) will cause the System READY line to go LOW until either a Data Request (DRQ) or an Interrupt Request (IRQ) from the WD 1771 occurs. - 12.2.4 DSR ROMs. Two 4K x \* DSR ROMs are required for normal operation but could just as easily have been a single 8K x 8 ROM. Neither of these ROMs can be accessed until the DSR page bit (at >1100) has been turned ON. - 12.2.4.1 Low ROM. The Low DSR ROM is based at >4000 and is fully accessable between >4000 and >4FFF. - 12.2.4.2 High ROM. The High DSR ROM is based at >5000 and has the upper 16 Bytes trapped out (only 4 were needed) for the WD 1771 chip. - 12.2.4.3 WD 1771 Trap. The WD 1771 chip was not decoded all the way down to the last four upper bytes because of the unavailability of two more NAND inputs. - 12.2.5 Disk Drive Side Interface. The lines to the Drive are all driven with open collector power drivers and the lines received from the drive are pulled up and then buffered with Schmidt trigger non-inverting gates. The Pull-up values are 1K Ohms except for the received data which is a 470 Ohm value. - 12.2.6 CRU Output. An 8 bit 74LS259 Octal Latch is used for a CRU Output Register and responds linearily to a CRU Address of >1100. There are no spare output lines. - 12.2.7 CRU In. A 74LS251 is used to provide an eight line CRU input interface. Two inputs are spares. MLB 7/13/82 12-2 **PRELIMINARY** - 12.2.8 Bus Buffers. Bus Buffers are used for all lines received except for RESET.A\* which drives only one unit load. With the exception of CRUIN, all lines to the System Bus are driven with line drivers. CRUIN is LS TTL driven and the driver was located as close to the I/O pin as was practical. - 12.2.9 Interrupts. The Disk Controller PCB interrupts on Level B and is sensed on Data Bit $\emptyset$ . - 12.2.10 Master Oscillator. An eight Mhz Crystal controlled oscillator is used as a master oscillator and then divided by 8 to feed the WD 1771 chip. The fundamental frequency was chosen to obtain a smaller crystal can size. ATE provisions have been included to isolate the oscillator from the WD 1771 and drive the WD 1771 from a remote oscillator. 12.2.11 Data/Clock Separator. The fundamental purpose Data/Clock Separator is to separate the raw data stream from the Disk Drive into CLOCK pulses and DATA pulses. In accomplishing this function it must shape the raw data pulse width for the WD 1771 chip, compensate for missing clock pulses and resync to look for CLOCK pulses if too many DATA pulses occur (4) with no CLOCK pulses in between. Up to 3 missing CLOCK pulses can normally occur, thus some compensation for raw data stream switching is required. The data rate for the Mini-Floppy Drive is 125 Khz with FM DATA/CLOCK encoding and this yields a CLOCK period of 8 us. A 4 us time displacement occurs between the leading edge (LE) of the CLOCK and the LE of the DATA pulse if one occurs. 12.2.11.1 Steering Logic. The steering logic consists of a SN74LSØØ 2-NAND gate that is connected to steer the Disk Data either to the WD 1771 Clock or Data input. Gating is done such that the full pulse width must occur before it is possible to change from the clock output to the data output or vice versa. The logic is enabled by a One-shot that shapes the raw data from the drive to an approximate 500 ns pulse width for the WD 1771 chip. Steering is accomplished with the control signal "STEER". The control signal "STEER" is a "Ø" for the DATA path and a "1" for the CLOCK path. MLB 7/13/82 12-3 **PRELIMINARY** 12.2.11.2 Switching Logic. The purpose of the Switching Logic is to provide the control signal "STEER" to the ØØ NAND gates in the Steering Logic. Raw disk data is steering to the data output if a clock output has occured within the last 6 us, or if less than four data outputs have occured with no clock in between. This logic is built around several 2-NAND gates and a One-shot that is timed for a 6 us clock. $12.2.11.3\,$ Missing Clock Compensation. Up to 3 missing CLOCK pulses will occur normally in the generation of the address mark, et cetera in the header area preceding the actual data. Steering must be generated to switch over to the DATA path even though no CLOCK occured to cause the switching to begin with. There will always be a DATA pulse (by definition) just prior to (4 us) the missing clock. That DATA pulse is detected, and a psuedo CLOCK is later generated and fed to the switching logic (only) just as a separated CLOCK pulse normally is. This pseudo clock is inhibited if a normal CLOCK occurs but would cause no ill effects if it were permitted. The pseudo CLOCK is not fed to the CLOCK pulse path to the WD 1771 chip. If a 4 CLOCK pulses are missing, the Missing Clock Compensation is inhibited and the Switching Logic is set up to steer the very next raw data pulse to the CLOCK pulse line. A second One-shot timed for 5.4 us and a DFF comprise this logic. 12.2.11.4 Missing Clock Counter. Still another missing clock function is required in the form of a Missing Clock Counter. This is for resynchronizing purposes if the separator accidently syncs to DATA rather than CLOCK pulses in the raw data stream. This incorrect sync can be caused by the "write splice" area between the header information and the data information, or in the area between sectors. The Missing Clock Counter is INCREMENTED by separated DATA pulses and RESET by separated CLOCK pulses. If no separated CLOCK pulses occur between four separated DATA pulses, the counter "C" output is used to inhibit the Missing Clock Compensator from providing the pseudo CLOCK pulse to the Switching Logic. Three DFFs are used to count the steered raw data pulses to the DATA output. MLB 7/13/82 12-4 **PRELIMINARY** # 12.3 DSSD DISK PAL12L6 LOROM = V1\*/AØØ\*AØ1\*/AØ2\*/AØ3\*DSKPG\*MEMEN\*PCBEN HIROM = V1\*/AØØ\*AØ1\*/AØ2\*AØ3\*V3\*DSKPG\*MEMEN\*PCBEN BDRVR = V1\*/AØØ\*AØ1\*/AØ2\*DSKPG\*MEMEN\*PCBEN WDEN = V1\*/AØØ\*AØ1\*/AØ2\*AØ3\*/V3\*DSKPG\*MEMEN\*PCBEN CRU = /AØØ\*/AØ1\*/AØ2\*AØ3\*AØ7\*V2\*/MEMEN\*PCBEN # Spare Output | 1 | V1 | 11 | VCC (LOGIC) | |----|----------------|----|--------------| | 2 | AØØ | 12 | V2 | | 3 | AØ1 | 13 | /LOROM | | 4 | AØ2 | 14 | /HIROM | | 5 | AØ3 | 15 | /BDRVR | | 6 | DSKPG | 16 | /WDEN | | 7 | AØ7 | 17 | / CRU | | 8 | /MEMEN | 18 | Spare Output | | 9 | PCBEN | 19 | V3 | | 1Ø | GROUND (POWER) | 2Ø | VCC (POWER) | | | | | | MLB 7/13/82 12-5 **PRELIMINARY** # 12.4 MNEMONIC DEFINITIONS | MNEMONIC | DEFINITION<br> | |------------|---------------------------------------------------------| | AMC.A | System 19-bit Address Bus, MSB | | AMB.A | System 19-bit Address Bus | | AMA.A | System 19-bit Address Bus | | AØØ.A | System 19-bit Address Bus | | AØ1.A | System 19-bit Address Bus | | AØ3.A | System 19-bit Address Bus | | AØ4.A | System 19-bit Address Bus | | AØ5.A | System 19-bit Address Bus | | AØ6.A | System 19-bit Address Bus | | AØ7.A | System 19-bit Address Bus | | AØ8.A | System 19-bit Address Bus | | AØ9.A | System 19-bit Address Bus | | A1Ø.A | System 19-bit Address Bus | | A11.A | System 19-bit Address Bus | | A12.A | System 19-bit Address Bus | | A13.A | System 19-bit Address Bus | | A14.A | System 19-bit Address Bus | | A15/COUT.A | System combination Address Bus LSB and CRU Output Data. | 12-6 MLB 7/13/82 PRELIMINARY | MNEMONIC | DEFINITION | |------------|-------------------------------------------------------------------------------| | AMC.B | Buffered 19-bit Address Bus MSB | | AMB.B | Buffered 19-bit Address Bus | | AMA.B | Buffered 19-bit Address Bus | | AØØ.B | Buffered 19-bit Address Bus | | AØ1.B | Buffered 19-bit Address Bus | | AØ2.B | Buffered 19-bit Address Bus | | AØ3.B | Buffered 19-bit Address Bus | | AØ4.B | Buffered 19-bit Address Bus | | AØ5.B | Buffered 19-bit Address Bus | | AØ6.B | Buffered 19-bit Address Bus | | AØ7.B | Buffered 19-bit Address Bus | | AØ8.B | Buffered 19-bit Address Bus | | AØ9.B | Buffered 19-bit Address Bus | | A1Ø.B | Buffered 19-bit Address Bus | | A11.B | Buffered 19-bit Address Bus | | A12.B | Buffered 19-bit Address Bus | | A13.B | Buffered 19-bit Address Bus | | A14.B | Buffered 19-bit Address Bus | | A15/COUT.B | Buffered combination 19-bit Address Bus LSB and CRU Output Data. | | BDRVR* | Active Low enable for the Data Bus Bidirectional Bus driver chip (SN74LS245). | | CLK | Separated clock to WD 1771 chip. | 12-7 PRELIMINARY MLB 7/13/82 | MNEMONIC | DEFINITION | |-----------|-------------------------------------------------------------------------------------------------------------------------| | CLKOUT.A* | Bus level System Clock. For 99/4A based systems, it is the 3 Mhz Phase 3 clock. | | CLKOUT.B* | Buffered System Clock. For 99/4A based systems, it is the 3 Mhz Phase 3 clock. | | CRUCLK.A* | System level, Active LOW CRU Clock from the CPU. | | CRUCLK.B* | Buffered Active LOW CRU Clock from the CPU. | | CRUEN* | Active LOW Disk SCR space enable. | | CRUIN | High True CRU data to the CPU (CPU READ data). | | DBIN.A | Buffered Active High Data Bus Input control line. The data direction is from the PCB to the CPU when this line is HIGH. | | DBIN.B | Buffered Active High Data Bus Input control line. The data direction is from the PCB to the CPU when this line is HIGH. | | DDBØ | PCB Side Data Bus, MSB | | DDB1 | PCB Side Data Bus | | DDB2 | PCB Side Data Bus | | DDB3 | PCB Side Data Bus | | DDB4 | PCB Side Data Bus | | DDB5 | PCB Side Data Bus | | DDB6 | PCB Side Data Bus | | DDB7 | PCB Side Data Bus, LSB | | DIR | Head step direction from WD 1771 chip. | | DIR* | Buffered Head step direction to drive. | | DRESET* | Reset line for the Disk Drive PCB. It is the OR of the System level Reset and the PCB Power-up Resistor. | 12-8 PRELIMINARY MLB 7/13/82 | MNEMONIC | DEFINITION | |----------|-------------------------------------------------------------------------------------------| | DRQ | Active HIGH Data Request from the WD 1771 chip. | | DSEL1 | Drive #1 select from the CRU Output register. | | DSEL2 | Drive #2 select from the CRU Output register. | | DSEL3 | Drive #3 select from the CRU Output register. | | DSKPGENA | Active HIGH page enable for the DSR ROMs. | | DS1* | Buffered Drive Select to Disk Drive #1. | | DS2* | Buffered Drive Select to Disk Drive #2. | | DS3* | Buffered Drive Select to Disk Drive #3. | | DØ | System Side Data Bus, MSB | | D1 | System Side Data Bus | | D2 | System Side Data Bus | | D3 | System Side Data Bus | | D4 | System Side Data Bus | | D5 | System Side Data Bus | | D6 | System Side Data Bus | | D7 | System Side Data Bus, LSB | | D1C* | Active LOW sense for Drive #1 connected. It does not indicate that the drive motor is ON. | | D2C* | Active LOW sense for Drive #2 connected. It does not indicate that the drive motor is ON. | | D3C* | Active LOW sense for Drive #3 connected. It does not indicate that the drive motor is ON. | 12-9 MLB 7/13/82 PRELIMINARY | MNEMONIC | DEFINITION | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HIROMEN* | Enable for the DSR ROM that starts at >5000. The Chip Enables for the WD 1771 are trapped out of the top end of this space; thus the CRCs cannot be read after the ROMs have been installed on the PCB. | | HLT | Head Load Timing from the CRU Output register to the WD 1771. | | HLD | Head Load output of the WD 1771. | | INTB* | Active LOW Interrupt Level B request. | | INTRQ | Active HIGH Interrupt Request output of the WD 1771. | | IXP* | Active LOW Index Pulse from the Drive. | | IXP.A* | Buffered Active LOW Index Pulse from the Drive. | | KACLK | Keep Alive One-shot Clock from the CRU Output Register. | | LOROMEN* | Active LOW chip enable for the DSR ROM based $>4000$ . | | MEMEN.A* | System Memory Enable control signal from the CPU. When LOW it indicates that a memory access IS required by the CPU. When HIGH it indicates that a CRU MIGHT be taking place. | | MTRON* | Active LOW Motor ON to Disk Drive. | | ОМНСК | Crystal controlled one Mhz clock to WD 1771 chip. | 12-1Ø MLB 7/13/82 PRELIMINARY | MNEMONIC | DEFINITION | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PCBEN | Active High PCB enable signal. It is used on the Burn In Rack to allow the controlling CPU to talk to only one PCB at a time. When LOW the PCB is disabled for both CRU and Memory operations. | | RDBENA* | Active LOW enable for the System Data Bus drivers on the 99/4 end of the interface cable. | | RDDTA* | Complement Received Data from Disk Drive. | | READY.A | Active HIGH System Ready. | | RESET.A* | System Active Low Master Reset line from the CPU. | | SENILB* | CPU driven line to allow the PCB to gate interrupt data to the system side of the Data Bus. | | SIDSEL | Active HIGH Side select from the CRU Output Register. A "Ø" selects the first (same as Single Side) side and a "1" selects the second side. Either a RESET or a SBZ 7 operation is required to select the second side. | | SIDSEL* | Active LOW side select to the Drive. A "Ø" selects the second side and a "1" selects the first side. Either a RESET or a SBZ 7 selects the first side and a SBO 7 will select the second. | | SRDTA | This is the Q output of a One-shot used to provide the correct Read Data pulse width for the WD 1771 once the Data and Clock are separated. | | STEP | Active HIGH output from the WD 1771 chip to tell the Drive to step to another track. "DIR" tells which direction to step. | | STEP* | Buffered "step" control line to Disk Drive. | | | | 12-11 PRELIMINARY MLB 7/13/82 | MNEMONIC | DEFINITION<br> | |-----------|---------------------------------------------------------------------------------------------------------------------| | ALB TKØØ | Track ØØ status signal from the Disk Drive. | | ALB TKØØ* | Buffered Track ØØ status signal from the Disk Drive. | | WAITEN | CRU Output to enable Wait Reads and Wait Writes. Both are used to get data from and to the Disk Drive respectively. | | WDRE* | Active LOW Read Enable to the WD 1771 chip. | | WDSEL* | Active LOW WD 1771 memory space decode. | | WDWE* | Active LOW Write Enable to the WD 1771. | | WE.A* | System Write Enable from the CPU and is used to write data to the Parallel ${\rm I/O}$ Port. | | WE.B* | Buffered Write Enable from the CPU and is used to write data to the Parallel I/O Port. | | WRTGT* | Active LOW Write Gate to the Drive. | | WTDATA | WD 1771 HIGH True data output to the Disk Drive. | | WTDATA* | Buffered LOW True data to the Disk Drive. | | WTG | Write Gate output of the WD 1771. | | WTPT* | Active LOW Write Protect status from the Drive. A LOW level is Write Protected. | | WTPT.A* | Buffered Active LOW Write Protect status from the Disk Drive. | 12-12 MLB 7/13/82 PRELIMINARY #### SECTION 13 ## SPEECH SYNTHESIZER THEORY OF OPERATION ## 13.1 PRINCIPLE OF OPERATION The Speech Synthesizer generates synthetic speech within the synthesizer Integrated Circuit (TMC $\emptyset 285$ ) from coded data stored in Phrase ROMs (PHROMS). The $\emptyset 285$ interfaces to the home computer through the data bus. I/O to the speech peripheral is enabled when the SPEECH BLOCK ENABLE signal from the console is a logic HIGH. The $\emptyset 285$ in turn controls the PHROMS to fetch data when required. Data brought to the $\emptyset 285$ is fed to the speech synthesis network, there assembled into digital code, then fed to a Digital to Analog Converter to generate the analog speech waveforms. The analog output is coupled back to the console sound chip and amplified to drive a speaker. # 13.2 TMC Ø285 The TMC $\emptyset 285$ (U1) is a MOS LSI circuit that contains not only the data and control interface, but also complex circuitry that uses coded data strings obtained from the PHROMS to control a digital filter network. This filter network may be thought of as an electronic model of the human larnynx. Output from the $\emptyset 285$ is an analog speech signal which requires no further processing other than amplification to drive a speaker. For a detailed explanation of the $\emptyset 285$ , refer to TI Drawing #15 $\emptyset 164\emptyset$ and ELECTRONICS (August 31, 1978 - page 1 $\emptyset 9$ ), "Three Chip System Synthesizes Human Speech". ## 13.3 TMC Ø35Ø PHROMS The PHROMS are TMC $\emptyset 35\emptyset$ 16K x 8 ROMS. The PHROMS use an 18 bit address, of which the 4 MSBs select 1-of-16 PHROMS, although only two are installed in the speech synthesizer peripheral. It will be noted that since only four address lines are available on the $\emptyset 35\emptyset$ ROM, several address cycles are required to fully address the ROM. MLB 7/13/82 13-1 PRELIMINARY #### 13.4 OPERATION Activity in the speech peripheral is initiated by the Home Computer CPU through a speech select (SBE). The speech select signal decoded in the console at address 9000 (read) and 9400 (write) and presented to the Speech Synthesizer as a single control line (SBE) on pin 2 of the I/O port. It is then necessary to redivide the SBE signal into a read and write select. The read select (RS) to the Ø285 is decoded through U3 (LS138) from SBE, \*A5 and \*A15 (9000). A write select (WS) is derived from SBE, A5 and A15 (9400). These control signals determine whether the Ø285 will put information on the data bus or receive information from the data bus. Immediately after a \*RS or \*WS the Ø285 will take the system not ready by making READY at the I/O port a logic LOW. The Speech Synthesizer will hold the system not ready until the data being received has been latched in (write) or the data being sent is stable on the bus (read). The not ready time is around 20 microseconds but is variable and depends on which mode has been selected and the command. Timing can be obtained from the Speech Module Spec. 1034759. After receiving a command, the $\emptyset 285$ begins processing and if required, sends control and address to the PHROM. The control signals I $\emptyset$ and I1, pins 15 and 16 respectively, operate as follows: | I1 | ΙØ | FUNCTION | |----|----|-----------------------------------------| | | | | | Ø | 1 | data read | | 1 | Ø | address load | | 1 | 1 | read and branch | | | | <pre>(not used in present system)</pre> | Address information is passed to the PHROMS on the ADD 1, 2, 4 and 8 lines (pins 2, 25, 23, 21 respectively). The ADD1 is the LSB and ADD8 the MSB of the address nibble from the data bus D7 through D4. Data from the PHROMS is transfered to the $\emptyset 285$ serially over the ADD8 line following a Read function. Transfers are synchronized by the 160 Khz ROM Clock (U1-3). The ROM Clock is a divide-by-four of the internal oscillator (U1-6). The oscillator is adjusted to 160 Khz by clipping R5, R6 or both out of the circuit. The speech output is open drain and requires a DC path to ground (R3) to operate. R3 sets an operating point at about one-third supply to prevent clipping the peaks of the audio output. Capacitor C2 provides DC isolation and C6 along with R3 forms a low pass filter to trap noise from the 8 Khz sampling rate. A sample sequence to speak a word assuming its address in PHROM has previously been obtained would be as follows: MLB 7/13/82 13-2 PRELIMINARY The address is set to 9000 (speech write) by the console, SBE goes HIGH, \*WS at U1 goes LOW and READY (I/O pin 12) goes LOW taking the console not ready. Along with the address, the data bus information will contain a command code on D1-D3 to load address. The format is as follows: The nibble of address and an I1 pulse would in turn be sent to the PHROMS. Upon completion of latching in the data, U1 releases the ready line and allows the console to continue. Since the PHROM takes 18 bits to fully address, four more load address commands are needed. This causes I1 pulses to be sent in sets of five. With the address written, the next command is a speak. This follows a write-to-speech sequence as previously described. The command code for speak is D1=1, D2= $\emptyset$ , D3=1 and all other data lines are don't care states. The ready release is again completed when the data has been latched. The TMC $\emptyset$ 285 will then issue a read pulse (I $\emptyset$ ) to the PHROM and a byte of data will be read in serially through U1-21 (ADD8). The TMC $\emptyset$ 285 will continue to send I $\emptyset$ pulses as required to supply the data necessary to speak the word until a stop code is encountered. Speech activity will then stop until the next command is written to the speech module. During speech, the audio waveform may be observed by looking at U1-8 (note that I/O pin 44 is a low impedance across which little AC voltage will be observed). If it is unknown to the CPU what the speech module is doing, its status can be read. This is accomplished by issuing a speech read (address 9400). The TMC 0285 will take the ready line LOW and set up the status on the data bus. When the data is stable, ready will be released and the status can be read. Status bits are interpreted as follows: DØ=Talk Status (TS) D1=Buffer Low (BL) D2=Buffer Empty (BE) All active high signals. (the BL and BE signals are used when inputting data on the data bus) Other commands include READ BYTE, used to bring data from the PHROMS to the data bus, SPEAK EXTERNAL, used to put speech data into the TMC Ø285 via the data bus, NOP, RESET and READ AND BRANCH. For further information, refer to previously cited documents. MLB 7/13/82 13-3 PRELIMINARY