# **COP401L ROMIess N-Channel Microcontroller** ### **General Description** The COP401L ROMless Microcontroller is a member of the COP5™ family of microcontrollers, fabricated using N-channel, silicon gate MOS technology. The COP401L contains CPU, RAM, I/O and is identical to a COP410L device except the ROM has been removed and pins have been added to output the ROM address and to input the ROM data. In a system the COP401L will perform exactly as the COP410L. This important benefit facilitates development and debug of a COP program prior to masking the final part. The COP401L is intended for emulation only, not intended for volume production. Use COP402 or COP404L for volume production. #### **Features** - Circuit equivalent of COP410L - Low cost - Powerful instruction set - 512 x 8 ROM, 32 x 4 RAM - Separate RAM power supply pin for RAM keep-alive applications - Two-level subroutine stack - 15 µs instruction time - Single supply operation (4.5-5.5V) - Low current drain (8 mA max.) - Internal binary counter register with serial I/O - MICROWIRE™ compatible serial I/O - General purpose outputs - LSTTL/CMOS compatible in and out - Direct drive of LED digit and segment lines - Software/hardware compatible with other members of COP400 family - Pin-for-pin compatible with COP402 and COP404L # **Absolute Maximum Ratings** If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. Voltage at any Pin Relative to GND -0.5V to +10VAmbient Operating Temperature 0°C to +70°C Ambient Storage Temperature -65°C to +150°C Lead Temp. (Soldering, 10 sec.) 300°C Power Dissipation **Total Sink Current** 0.75W at 25°C 0.4W at 70°C **Total Source Current** 120 mA 120 mA Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings. # DC Electrical Characteristics $0^{\circ}C \le T_{A} \le +70^{\circ}C$ , $4.5V \le V_{CC} \le 5.5V$ unless otherwise noted | Parameter | Conditions | Min | Max | Units | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------|----------|----------------| | Operating Voltage (V <sub>CC</sub> ) | | 4.5 | 5.5 | V | | Power Supply Ripple (Notes 2, 3) | Peak to Peak | | 0.5 | v | | Operating Supply Current | All Inputs and Outputs Open | <u> </u> | 8 | mA | | Input Voltage Levels<br>CKI Input Levels<br>Crystal Input | V <sub>CC</sub> = Max | | | | | Logic High (V <sub>IH</sub> )<br>Logic Low (V <sub>II</sub> ) | 100 | 2.0 | | V | | RESET Input Levels | Schmitt Trigger Input | -0.3 | 0.4 | V | | Logic High<br>Logic Low<br>IP0-IP7 Input Levels | | 0.7 V <sub>CC</sub><br>-0.3 | 0.6 | V | | Logic High<br>Logic High<br>Logic Low | V <sub>CC</sub> = 5V ±5% | 2.0<br>-0.3 | 0.8 | V<br>V | | All Other Inputs<br>Logic High<br>Logic High<br>Logic Low<br>Input Capacitance (Note 3) | V <sub>CC</sub> = 5V ±5% | 2.0<br>-0.3 | 0.8<br>7 | V<br>V<br>V | | Output Voltage Levels<br>LSTTL Operation<br>Logic High (V <sub>OH</sub> )<br>Logic Low (V <sub>OL</sub> )<br>IPO-IP7, P8, SKIP<br>Logic Low | $V_{CC} = 5V \pm 10\%$ $I_{OH} = -25 \mu A$ $I_{OL} = 0.36 mA$ (Note 1) $I_{OL} = 1.6 mA$ | 2.7 | 0.4 | ν<br>ν<br>ν | | Output Current Levels Output Sink Current SO and SK Outputs (I <sub>OL</sub> ) L <sub>0</sub> -L <sub>7</sub> and G <sub>0</sub> -G <sub>3</sub> Outputs D <sub>0</sub> -D <sub>3</sub> Outputs | $V_{CC} = 4.5V, V_{OL} = 0.4V$ $V_{CC} = 4.5V, V_{OL} = 0.4V$ $V_{CC} = 4.5V, V_{OL} = 1.0V$ | 0.9<br>0.4<br>15 | | mA<br>mA<br>mA | | CKO<br>RAM Power Supply Input | V <sub>R</sub> = 3.3V | | 1.5 | mA | # **DC Electrical Characteristics** $0^{\circ}C \le T_{A} \le +70^{\circ}C$ , $4.5V \le V_{CC} \le 9.5V$ unless otherwise noted (Continued) | Parameter | Conditions | Min | Max | Units | |--------------------------------------------------------------------------------------------|--------------------------------|------|------|-------| | Output Source Current | | | | | | D <sub>0</sub> -D <sub>3</sub> , G <sub>0</sub> -G <sub>3</sub> Outputs (I <sub>OH</sub> ) | $V_{CC} = 4.5V, V_{OH} = 2.0V$ | -30 | -250 | μΑ | | SO and SK Outputs (I <sub>OH</sub> ) | $V_{CC} = 4.5V, V_{OH} = 1.0V$ | -1.2 | | mA | | L <sub>0</sub> -L <sub>7</sub> Outputs | $V_{CC} = 5.5V, V_{OH} = 2.0V$ | -0.3 | - 25 | mA | | Input Load Source Current (IIL) | $V_{CC} = 5.0V, V_{L} = 0V$ | -10 | -140 | μΑ | | Total Sink Current Allowed | | | | | | All Outputs Combined | | | 120 | mA | | D Port | | | 100 | mA | | L <sub>7</sub> -L <sub>4</sub> , G Port | | ] | 4 | mA | | L3-L0 | | | 4 | mA | | All Other Pins | | | 1.8 | mA | | Total Source Current Allowed | | | | | | All I/O Combined | | | 120 | mA | | L <sub>7</sub> -L <sub>4</sub> | | | 60 | mA | | L <sub>3</sub> -L <sub>0</sub> | | | 60 | mA | | Each L Pin | | , | 25 | mA | | All Other Pins | | } | 1.5 | mA | # AC Electrical Characteristics $0^{\circ}C \le T_{A} \le +70^{\circ}C$ , $4.5V \le V_{CC} \le 5.5V$ unless otherwise specified. | Parameter | Conditions | Min | Max | Units | | |--------------------------------------------------------------------------------------------------|----------------------------|-----|-----|-------|--| | Instruction Cycle Time | | 15 | 40 | μs | | | CKI | | | | | | | Input Frequency f | (÷32 Mode) | 0.8 | 2.1 | MHz | | | Duty Cycle | | 30 | 60 | % | | | Rise Time (Note 3) | f <sub>I</sub> = 2.097 MHz | | 120 | ns | | | Fall Time (Note 3) | II - 2.097 MIH2 | | 80 | ns | | | INPUTS: | | | | | | | SI, IP7-IP0 | | | | | | | t <sub>SETUP</sub> | | 2.0 | | μs | | | thold | | 1.0 | | μs | | | G <sub>3</sub> -G <sub>0</sub> , L <sub>7</sub> -L <sub>0</sub> | | | | | | | tSETUP | | 8.0 | | μs | | | tHOLD | | 1.3 | | μs | | | OUTPUT PROPAGATION DELAY | Test Condition: | | | | | | | $C_L = pF, V_{OUT} = 1.5V$ | | | | | | SO, SK Outputs | $R_L = 20 k\Omega$ | 1 | | | | | t <sub>pd1</sub> , t <sub>pd0</sub> | | | 4.0 | μs | | | D <sub>3</sub> -D <sub>0</sub> , G <sub>3</sub> -G <sub>0</sub> , L <sub>7</sub> -L <sub>0</sub> | $R_L = k\Omega$ | | | | | | t <sub>pd1</sub> , t <sub>pd0</sub> | | | 5.6 | μs | | | IP7-IP0, P8, SKIP | $R_L = 5 k\Omega$ | | | | | | t <sub>pd1</sub> , t <sub>pd0</sub> | | | 7.2 | μs | | Note 1: Pull-up resistors required. Note 2: V<sub>CC</sub> voltage change must be less than 0.5V in a 1 ms period to maintain proper operation. Note 3: This parameter is only sampled and not 100% tested. Variation due to the device included. #### DO CKI 39 IP4 38 RESET 37 IP3 36 P8 IP2 35 NC IP1 34 IPO 33 AD/DATA SKIP 32 10 G3 COP401L 31 11 30 G2 L7 . 12 G1 16 -29 13 28 GO L5 14 15 NC 26 17 SO Vcc 24 L3 18 23 SI - GND 19 22 20 · L0 21 TL/DD/6913-2 Order Number COP401L/N NS Package Number N40A FIGURE 2 # **Pin Descriptions** **Connection Diagram** | Pin | Description | Pin | Description | |-------------|-------------------------------------------|-----------------|--------------------------------------------| | L7-L0 | 8 bidirectional I/O ports with LED | CKI | System oscillator input | | | segment drive | CKO | RAM power supply input | | $G_3-G_0$ | 4 bidirectional I/O ports | RESET | System reset input | | $D_3 - D_0$ | 4 general purpose outputs | V <sub>CC</sub> | Power supply | | SI | Serial input (or counter input) | GND | Ground | | so | Serial output (or general purpose output) | IP7-IP0 | 8 bidirectional ROM address and data ports | | SK | Logic-controlled clock (or general | P8 | Most significant ROM address bit output | | | purpose output) | SKIP | Instruction skip output | | AD/DATA | Address Out/data in flag | | | # **Timing Diagram** 1-199 ### **Functional Description** A block diagram of the COP401L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic "1" greater than 2 volts). When a bit is reset, it is a logic "0" (less than 0.8 volts). #### PROGRAM MEMORY Program Memory consists of a 512-byte external memory. As can be seen by an examination of the COP401L instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words each. ROM addressing is accomplished by a 9-bit PC register. Its binary value selects one of the 512 8-bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transer of control instruction, the PC register is loaded with the next sequential 9-bit binary count value. Two levels of subroutine nesting are implemented by the 9-bit subroutine save registers, SA and SB, providing a last-in, first-out (LIFO) hardware subroutine stack. ROM instruction words are fetched, decoded and executed by the instruction Decode, Control and Skip Logic circuitry. #### **DATA MEMORY** Data memory consists of a 128-bit RAM, organized as 4 data registers of 8 4-bit digits. RAM addressing is implemented by a 6-bit B register whose upper 2 bits (Br) select 1 of 4 data registers and lower 3 bits of the 4-bit Bd select 1 of 8 4-bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into the Q latches or loaded from the L ports. RAM addressing may also be performed directly by the XAD 3, 15 instruction. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs. The most significant bit of Bd is not used to select a RAM digit. Hence each physical digit of RAM may be selected by two different values of Bd as shown in *Figure 4* below. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 and 15, but NOT between 7 and 8 (see Table 3). TL/DD/6913-4 FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping INTERNAL LOGIC The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the B register, to load 4 bits of the 8-bit Q latch data, to input 4 bits of the 8-bit L I/O port data and to perform data exchanges with the SIO register. A 4-bit adder performs the arithmetic and logic functions of the COP401L, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.) The G register contents are outputs to 4 general-purpose bidirectional I/O ports. The Q register is an internal, latched, 8-bit register, used to hold data loaded from M and A, as well as 8-bit data from ROM. Its contents are output to the L I/O ports when the L drivers are enabled under program control. (See LEI instruction.) The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O ports. Also, the contents of L may be read directly into A and M. L I/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with Q data being outputted to the Sa-Sg and decimal point segments of the display. The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A, allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift register. The XAS instruction copies C into the SKL Latch. In the counter mode, SK is the output of SKL in the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock. The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register (EN<sub>3</sub>-EN<sub>0</sub>). - 1. The least significant bit of the enable register, EN<sub>0</sub>, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With EN<sub>0</sub> set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse ("1" to "0") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of EN<sub>3</sub>. With EN<sub>0</sub> reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock. - 2. EN<sub>1</sub> is not used. It has no effect on COP401L operation. | EN <sub>3</sub> | EN <sub>0</sub> | SIO | SI | so | SK | |-----------------|-----------------|----------------|-------------------------|------------|----------------------------------------------------------------| | 0 | 0 | Shift Register | Input to Shift Register | 0 | If SKL = 1, SK = Clock | | 1 | 0 | Shift Register | Input to Shift Register | Serial Out | If SKL = 0, SK = 0 If SKL = 1, SK = Clock | | 0 | 1 | Binary Counter | Input to Binary Counter | О | If $SKL = 0$ , $SK = 0$<br>If $SKL = 1$ , $SK = 1$ | | 1 | 1 | Binary Counter | Input to Binary Counter | 1 | If SKL = 0, SK = 0<br>If SKL = 1, SK = 1<br>If SKL = 0, SK = 0 | - With EN<sub>2</sub> set, the L drivers are enabled to output the data in Q to the L I/O ports. Resetting EN<sub>2</sub> disables the L drivers, placing the L I/O ports in a high-impedance input state - 4. EN<sub>3</sub>, in conjunction with EN<sub>0</sub>, affects the SO output. With EN<sub>0</sub> set (binary counter option selected) SO will output the value loaded into EN<sub>3</sub>. With EN<sub>0</sub> reset (serial shift register option selected), setting EN<sub>3</sub> enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN<sub>3</sub> with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to "O". Table I provides a summary of the modes associated with EN<sub>3</sub> and EN<sub>0</sub>. #### INITIALIZATION The Reset Logic will initialize (clear) the device upon power-up if the power supply rise time is less than 1 ms and greater than 1 µs. If the power supply rise time is greater than 1 ms, the user must provide an external RC network and diode to the RESET pin as shown below (Figure 5). The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to V<sub>CC</sub>. Initialization will occur whenever a logic "0" is applied to the RESET input, provided it stays low for at least three instruction cycle times. TL/DD/6913-5 RC ≥ Power Supply Rise Time FIGURE 5. Power-Up Clear Circuit Upon initialization, the PC register is cleared to 0 (ROM address 0) and the A, B, C, D, EN, and G registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA. #### **EXTERNAL MEMORY INTERFACE** The COP401L is designed for use with an external Program Memory. This memory may be implemented using any devices having the following characteristics: - 1. random addressing - 2. TTL-compatible TRI-STATE® outputs - 3. TTL-compatible inputs - 4. access time = $5 \mu s max$ . Typically these requirements are met using bipolar or MOS PROMs. During operation, the address of the next instruction is sent out on P8 and IP7 through IP0 during the time that AD/DATA is high (logic "1" = address mode). Address data on the IP lines is stored into an external latch on the high-to-low transition of the AD/DATA line; P8 is a dedicated address output, and does not need to be latched. When AD/DATA is low (logic "0" = data mode), the output of the memory is gated onto IP7 through IP0, forming the input bus. Note that the AD/DATA output has a period of one instruction time, a duty cycle of approximately 50%, and specifies whether the IP lines are used for address output or instruction input. #### **OSCILLATOR** CKI is an external clock input signal. The external frequency is divided by 32 to give the instruction cycle time. The divide-by-32 configuration was chosen to make the COP 401L compatible with the COP404L and the COPSTM Development System. However, the $\div32$ configuration is not available on the COP410L/COP411L. It is therefore possible to exactly emulate the system speed (cycle time), but not possible to drive the 401L with the system clock during emulation. #### Functional Description (Continued) #### CKO (RAM POWER) CKO is configured as a RAM power supply pin $(V_R)$ , allowing its connection to a standby/backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. This pin must be connected to $V_{CC}$ if the power backup feature is not used. To insure that RAM integrity is maintained, the following conditions must be met: - RESET must go low before V<sub>CC</sub> goes below spec during power-off; V<sub>CC</sub> must be within spec before RESET goes high on power-up. - 2. During normal operation, V<sub>R</sub> must be within the operating range of the chip with (V<sub>CC</sub>-1) $\leq$ V<sub>R</sub> $\leq$ V<sub>CC</sub>. - 3. $V_R$ must be $\geq$ 3.3V with $V_{CC}$ off. #### INPUT/OUTPUT CONFIGURATIONS COP401L outputs have the following configurations, illustrated in Figure 6: - a. Standard—an enhancement mode device to ground in conjunction with a depletion-mode device to V<sub>CC</sub>, compatible with LSTTL and CMOS input requirements. (Used on D and G outputs.) - b. Open-Drain—an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. (Used on IP, P and SKIP outputs.) - c. Push-Pull—An enhancement-mode device to ground in conjunction with a depletion-mode device paralleled en- hancement-mode device to $V_{CC}$ . This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. (Used on SO and SK outputs.) d. LED Direct Drive—an enhancement-mode device to ground and to V<sub>CC</sub>, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (See Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display. (Used on L outputs.) COP401L inputs have an on-chip depletion load device to $\ensuremath{V_{\text{CC}}}.$ The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of five devices (numbered 1–5, respectively). Minimum and maximum current (I<sub>OUT</sub> and V<sub>OUT</sub>) curves are given in *Figure 7* for each of these devices to allow the designer to effectively use these I/O configurations in designing a system. An important point to remember is that even when the L drivers are disabled, the depletion load device will source a small amount of current (see *Figure 7*, Device 2); however, when the L-lines are used as inputs, the disabled depletion device can *not* be relied on to source sufficient current to pull an input to a logic "1". ### **COP401L Instruction Set** Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table. Table III provides the mnemonic, operand, machine code, data flow, skip conditions, and description associated with each instruction in the COP401L instruction set. TABLE II. COP401L Instruction Set Table Symbols | Symbol | Definition | | | | | | |---------|----------------------------------------------|--|--|--|--|--| | INTERNA | INTERNAL ARCHITECTURE SYMBOLS | | | | | | | Α | 4-bit Accumulator | | | | | | | В | 6-bit RAM Address Register | | | | | | | Br | Upper 2 bits of B (register address) | | | | | | | Bd | Lower 4 bits of B (digit address) | | | | | | | С | 1-bit Carry Register | | | | | | | D | 4-bit Data Output Port | | | | | | | EN | 4-bit Enable Register | | | | | | | G | 4-bit Register to latch data for G I/O Port | | | | | | | L | 8-bit TRI-STATE I/O Port | | | | | | | М | 4-bit contents of RAM Memory pointed to by B | | | | | | | | Register | | | | | | | PC | 9-bit ROM Address Register (program counter) | | | | | | | Q | 8-bit Register to latch data for L I/O Port | | | | | | | SA | 9-bit Subroutine Save Register A | | | | | | | SB | 9-bit Subroutine Save Register B | | | | | | | SIO | 4-bit Shift Register and Counter | | | | | | | SK | Logic-Controlled Clock Output | | | | | | | Symbol | Definition | | | | | | |-----------------------|-------------------------------------------------------|--|--|--|--|--| | INSTRUCT | INSTRUCTION OPERAND SYMBOLS | | | | | | | d | 4-bit Operand Field, 0-15 binary (RAM Digit Select) | | | | | | | r | 2-bit Operand Field, 0-3 binary (RAM Register Select) | | | | | | | а | 9-bit Operand Field, 0-511 binary (ROM Address) | | | | | | | У | 4-bit Operand Field, 0-15 binary (Immediate Data) | | | | | | | RAM(s) | Contents of RAM location addressed by s | | | | | | | ROM(t) | Contents of ROM location addressed by t | | | | | | | OPERATIO | ONAL SYMBOLS | | | | | | | + | Plus | | | | | | | _ | Minus | | | | | | | $\rightarrow$ | Replaces | | | | | | | $\longleftrightarrow$ | Is exchanged with | | | | | | | = | is equal to | | | | | | | Ā | The one's complement of A | | | | | | | ⊕ | Exclusive-OR | | | | | | | : | Range of values | | | | | | #### **TABLE III. COP401L Instruction Set** | Mnemonic | Operand | Hex<br>Code | Machine<br>Language Code<br>(Binary) | Data Flow | Skip Conditions | Description | |-----------|-----------|-------------|--------------------------------------|---------------------------------------------------------|-----------------|-------------------------------------------| | ARITHMETI | C INSTRUC | TIONS | | | | | | ASC | | 30 | [0011 0000 | $A + C + RAM(B) \rightarrow A$<br>Carry $\rightarrow C$ | Carry | Add with Carry, Skip on<br>Carry | | ADD | | 31 | 0011 0001 | A + RAM(B) → A | None | Add RAM to A | | AISC | у | 5- | 0101 y | $A + y \rightarrow A$ | Carry | Add immediate, Skip on Carry (y $\neq$ 0) | | CLRA | | 00 | 0000 0000 | 0 → A | None | Clear A | | COMP | | 40 | 0100 0000 | $\bar{A} \rightarrow A$ | None | One's complement of A to A | | NOP | | 44 | 0100 0100 | None | None | No Operation | | RC | | 32 | 0011 0010 | "o" → C | None | Reset C | | sc | | 22 | 0010 0010 | "1" → C | None | Set C | | XOR | | 02 | 0000 0010 | A ⊕ RAM(B) → A | None | Exclusive-OR RAM with A | # **COP410L Instruction Set** (Continued) | TABLE III. COP401L Instruction Set (Co | ntinued) | |----------------------------------------|----------| |----------------------------------------|----------| | | | | I ABLE III. | COP401L Instruction Set | (Continued) | | |----------|------------------|----------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------------------------------------| | Mnemonic | Operand | Hex<br>Code | Machine<br>Language Code<br>(Binary) | Data Flow | Skip Conditions | Description | | TRANSFER | OF CONTR | OL INST | FRUCTIONS | | - | | | JID | - | FF | 1111 1111 | $PC_{7:0}$ ROM (PC <sub>8</sub> , A,M) $\rightarrow$ | None | Jump Indirect (Note 2) | | JMP | а | 6-<br> | 0110 000 a <sub>8</sub> <br>a <sub>7:0</sub> | a → PC | None | Jump | | JP | а | | [1 a <sub>6:0</sub> (pages 2,3 only) | a → PC <sub>6:0</sub> | None | Jump within Page<br>(Note 3) | | | | | 11 a <sub>5:0</sub> (all other pages) | a → PC <sub>5:0</sub> | | | | JSRP | а | | 10 a <sub>5:0</sub> | $PC + 1 \rightarrow SA \rightarrow SB$ | None | Jump to Subroutine Page<br>(Note 4) | | | | | | $\begin{array}{c} 010 \longrightarrow PC_{8:6} \\ a \longrightarrow PC_{5:0} \end{array}$ | | , | | JSR | а | 6-<br> | 0110 100 a <sub>8</sub> | $PC + 1 \rightarrow SA \rightarrow SB$<br>$a \rightarrow PC$ | None | Jump to Subroutine | | RET | | 48 | 0100 1000 | $SB \rightarrow SA \rightarrow PC$ | None | Return from Subroutine | | RETSK | | 49 | 0100 1001 | $SB \rightarrow SA \rightarrow PC$ | Always Skip on Return | Return from Subroutine then Skip | | MEMORY R | EFERENCE | INSTRU | CTIONS | | | | | CAMQ | | 33<br>3C | 0011 0011 | $A \rightarrow Q_{7:4}$<br>RAM(B) $\rightarrow Q_{3:0}$ | None | Copy A, RAM to Q | | LD | r | -5 | 00 1 0101 | $\begin{array}{c} RAM(B) \longrightarrow A \\ Br \oplus r \longrightarrow Br \end{array}$ | None | Load RAM into A,<br>Exclusive-OR Br with r | | LQID | | BF | 1011 1111 | $ROM(PC_8, A, M) \rightarrow Q$<br>$SA \rightarrow SB$ | None | Load Q Indirect<br>(Note 2) | | RMB | 0<br>1<br>2<br>3 | 4C<br>45<br>42<br>43 | 0100 1100<br>0100 0101<br>0100 0010<br>0100 0011 | $\begin{array}{l} 0 \longrightarrow RAM(B)_0 \\ 0 \longrightarrow RAM(B)_1 \\ 0 \longrightarrow RAM(B)_2 \\ 0 \longrightarrow RAM(B)_3 \end{array}$ | None | Reset RAM Bit | | SMB | 0<br>1<br>2<br>3 | 4D<br>47<br>46<br>4B | 0100 1101 0100 0111 0100 0110 0101 | $ \begin{array}{l} 1 \longrightarrow RAM(B)_0 \\ 1 \longrightarrow RAM(B)_1 \\ 1 \longrightarrow RAM(B)_2 \\ 1 \longrightarrow RAM(B)_3 \end{array} $ | None | Set RAM Bit | | STII | У | 7- | [0111 y ] | $y \rightarrow RAM(B)$<br>Bd + 1 $\rightarrow$ Bd | None | Store Memory Immediate and Increment Bd | | X | r | -6 | 00 r 0110 | $\begin{array}{c} RAM(B) \longleftrightarrow A \\ Br \oplus r \longrightarrow Br \end{array}$ | None | Exchange RAM with A,<br>Exclusive-OR Br with r | | XAD | 3,15 | 23<br>BF | 0010 0011 | RAM(3,15) ←→ A | None | Exchange A with RAM (3,15) | | XDS | r | 7 | 00 r 0111 | $\begin{array}{c} RAM(B) \longleftrightarrow A \\ Bd - 1 \longrightarrow Bd \\ Br \oplus r \longrightarrow Br \end{array}$ | Bd decrements past 0 | Exchange RAM with A and Decrement Bd, Exclusive-OR Br with r | | XIS | r | -4 | 00 r 0100 | $\begin{array}{l} RAM(B) \longleftrightarrow A \\ Bd + 1 \longrightarrow Bd \\ Br \oplus r \longrightarrow Br \end{array}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd, Exclusive-OR Br with r | ### COP410L Instruction Set (Continued) TABLE III. COP401L Instruction Set (Continued) | Mnemonic | Operand | Hex<br>Code | Machine<br>Language Code<br>(Binary) | Data Flow | Skip Conditions | Description | |------------|------------------|----------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------| | REGISTER | REFERENCE | INSTRU | CTIONS | | | | | CAB | | 50 | 0101 0000 | A → Bd | None | Copy A to Bd | | CBA | | 4E | 0100 1110 | Bd → A | None | Copy Bd to A | | LBI | r, d | - | $\frac{ 00 r (d-1)}{(d=0, 9:15)}$ | r, d → B | Skip until not a LBI | Load B Immediate with r, d (Note 5) | | LEI | у | 33<br>6 | 0011 0011<br>0110 y | y → EN | None | Load EN Immediate<br>(Note 6) | | TEST INSTI | RUCTIONS | | | | | | | SKC | | 20 | 0010 0000 | | C = "1" | Skip if C is True | | SKE | | 21 | 0010 0001 | | A = RAM(B) | Skip if A Equals RAM | | SKGZ | | 33<br>21 | 0011 0011 | | $G_{3:0} = 0$ | Skip if G is Zero<br>(all 4 bits) | | SKGBZ | 0<br>1<br>2<br>3 | 33<br>01<br>11<br>03<br>13 | 0011 0011<br>0000 0001<br>0001 0001<br>0000 0011<br>0001 0011 | 1st byte | $G_0 = 0$ $G_1 = 0$ $G_2 = 0$ $G_3 = 0$ | Skip if G Bit is Zero | | SKMBZ | 0<br>1<br>2<br>3 | 01<br>11<br>03<br>13 | 0000 0001 <br>0001 0001 <br>0000 0011 <br>0001 0011 | | $RAM(B)_0 = 0$<br>$RAM(B)_1 = 0$<br>$RAM(B)_2 = 0$<br>$RAM(B)_3 = 0$ | Skip if RAM Bit is Zero | | INPUT/OU | PUT INSTR | UCTIONS | S | | | | | ING | | 33<br>2A | 0011 0011 | $G \rightarrow A$ | None | Input G Ports to A | | INL | | 33<br>2E | 0011 0011 | $\begin{array}{c} L_{7:4} \longrightarrow RAM(B) \\ L_{3:0} \longrightarrow A \end{array}$ | None | Input L Ports to RAM, A | | OBD | | 33<br>3E | 0011 0011 | Bd → D | None | Output Bd to D Outputs | | ОМС | | 33<br>3A | 0011 0011 | RAM(B) → G | None | Output RAM to G Ports | | XAS | | 4F | 0100 1111 | $A \longleftrightarrow SIO, C \to SKL$ | None | Exchange A with SIO (Note 2) | Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, A<sub>3</sub> indicates the most significant (left-most) bit of the 4-bit A register. Note 2: For additional information on the operation of the XAS, JID, and LQID instructions, see below. Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3. The JP instruction, otherwise, permits a jump to a ROM location within the current 64-word page. JP may not jump to the last word of a page. Note 4: A JSRP transfers program control to subroutine page 2 (010 is loaded into the upper 3 bits of P). A JSRP may not be used when in pages 2 or 3. JSRP may not jump to the last word in page 2. Note 5: The machine code for the lower 4 bits of the LBI instruction equals the binary value of the "d" data minus 1, e.g., to load the lower four bits of B (Bd) with the value 9 (1001<sub>2</sub>), the lower 4 bits of the LBI instruction equal 8 (1000<sub>2</sub>). To load 0, the lower 4 bits of the LBI instruction should equal 15 (1111<sub>2</sub>). Note 6: Machine code for operand field y for LEI instruction should equal the binary value to be latched into EN, where a "1" or "0" in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.) # **Description of Selected Instructions** The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP401L programs. #### **XAS INSTRUCTION** XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continous data stream. #### JID INSTRUCTION JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the *contents* of ROM addressed by the 9-bit word, PC<sub>8</sub>, A, M. PC<sub>8</sub> is not affected by this instruction. Note that JID requires 2 instruction cycles to execute. #### LQID INSTRUCTION LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9-bit word PCR, A, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC + 1 $\rightarrow$ SA $\rightarrow$ SB) and replaces the least significant 8 bits of PC as follows: A $\rightarrow$ PC<sub>7:4</sub>, RAM(B) → PC<sub>3:0</sub>, leaving PC<sub>8</sub> unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SA → SB, the previous contents of SB are lost. Also, when LQID pops the stack, the previously pushed contents of SA are left in SB. The net result is that the contents of SA are placed in SB (SA -> SB). Note that LQID takes two instruction cycle times to execute. #### **INSTRUCTION SET NOTES** - a. The first word of a COP401L program (ROM address 0) must be a CLRA (Clear A) instruction. - b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped. - c. The ROM is organized into 8 pages of 64 words each. The Program Counter is a 9-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LOID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LOID or JID located in the last word of page 3 or 7 will access data in the next group of 4 pages. ## Typical Applications #### PROM-BASED SYSTEM The COP401L may be used to emulate the COP410L. Figure 8 shows the interconnect to implement a COP401L hardware emulation. This connection uses one MM5204 EPROM as external memory. Other memory can be used such as bipolar PROM or RAM. Pins $IP_7$ – $IP_0$ are bidirectional inputs and outputs. When the AD/DATA clocking output turns on, the EPROM drivers are disabled and $IP_7$ – $IP_0$ output addresses. The 8-bit latch (MM74C373) latches the address to drive the memory. When AD/ $\overline{DATA}$ turns off, the EPROM is enabled and the IP<sub>7</sub>-IP<sub>0</sub> pins will input the memory data. P8 outputs the most significant address bit to the memory. (SKIP output may be used for program debug if needed.) 24 of the COP401L pins may be configured exactly the same as a COP410L. # **Option Table** ### COP401L MASK OPTIONS The following COP410L options have been implemented in this basic version of the COP401L. | Option Value | Comment | Option Value | Comment | |-----------------|--------------------------------------------|-----------------|----------------------------------| | Option 1 = 0 | Ground—no option | Option $14 = 0$ | SI has load to V <sub>CC</sub> | | Option 2 = 1 | CKO is RAM power supply input | Option 15 = 2 | SO is push-pull output | | Option 3 = N/A | CKI is external clock divide-by- | Option $16 = 2$ | SK is push-pull output | | | 32 (not available on COP410L) | Option $17 = 0$ | | | Option 4 = 0 | Reset has load to V <sub>CC</sub> | Option 18 = 0 | | | Option $5 = 2$ | | Option 19 = 0 | G outputs are standard | | Option 6 = 2 | Lauteute and LED disease daily | Option 20 = 0 | | | Option $7 = 2$ | L outputs are LED direct-drive | Option 21 = 0 | | | Option 8 = 2 | | Option 22 = 0 | D outputs are standard | | Option 9 = 1 | V <sub>CC</sub> pin 4.5V to 9.5V operation | Option 23 = 0 | very high current | | Option $10 = 2$ | | Option $24 = 0$ | , , | | Option 11 = 2 | Lauteute and LED disease 11 a | Option 25 = 0 | L | | Option 12 = 2 | L outputs are LED direct-drive | Option 26 = 0 | G Have standard TTL input levels | | Option 13 = 2 | | Option 27 = 0 | SI | | | | Option 28 = N/A | 40-pin package |