地

## TSS400 - Family

## User's Guide

Sensor Signal Processors
1992 1992

## TSS400 FAMILY USER'S GUIDE

Part I: TSS400 User's Guide<br>Part II: TSS400/4 User's Guide<br>Part III: TSS400(/4) Software User's Guide<br>Part IV: TSS400 Standard User's Guide

## Part I

## TSS400 USER'S GUIDE October 1991

## Table of Contents

## Purpose and Conventions

Paragraph Title1 TSS400 7
1.1 Functional Specifications ..... 8
1.2 Memory Structure ..... 10
1.3 Subroutine Stack Operation ..... 11
1.4 Digit Latches/R Outputs ..... 12
1.5 DAM Operation ..... 13
1.6 ALU ..... 14
1.7 CKB Memory Map Description ..... 15
1.8 K-line Structure ..... 16
1.9 I/O Structure ..... 17
1.10 Clock ..... 18
2 Operational Description ..... 19
2.1 ROM Decode ..... 19
2.2 Program Counter and Subroutine Register ..... 20
2.3 ROM Page Address Register and Page Buffer ..... 20
2.4 Instruction Decode ..... 21
2.5 Processor Enable and Time Base Multiplexer ..... 22
2.6 Processor Frequency ..... 23
2.7 Timer Oscillator ..... 24
2.8 Time Data Multiplexer ..... 25
2.9 CKB (Constant, K-lines, Bit and Time Multiplexer) ..... 26
2.10 Branch/Call Control ..... 26
2.11 RAM Address/Character Decode Multiplexer ..... 26
2.12 Write Multiplexer ..... 27
2.13 X-Decode ..... 27
2.14 RAM Word Decode ..... 27
2.15 Character Decode ..... 27
2.16 Segment Latches ..... 27
2.17 Segment Drivers ..... 28
2.18 Power Up Clear ..... 28
2.19 Status ..... 28
2.20 P-Multiplexer ..... 29
2.21 N-Multiplexer ..... 29
2.22 Adder-Comparator ..... 29
2.23 Accumulator and Y -Register ..... 29
3 Analog/Digital Converter (ADC) ..... 30
3.1 Description of Conversion ..... 32
3.2 Battery Check ..... 34
3.3 Current Source ..... 35
4 Display ..... 38
4.1 Gate Level PLA ..... 38
4.2 Common Select Lines ..... 39
4.3 Select Lines ..... 40
4.4 Display Drive Waveform ..... 42
5 Instruction Set Description ..... 43
5.1 Functional Description ..... 44
5.2 9-Bit Instruction Map ..... 50
6 Electrical Description ..... 52
6.1 Absolute Maximum Ratings ..... 52
6.2 TSS400 Operating Conditions ..... 53
6.3 TSS400 Operating Characteristics ..... 54
6.4 TSS403 Operating Conditions ..... 76
6.5 TSS403 Operating Characteristics ..... 77
6.6 TSS405 Operating Conditions ..... 95
6.7 TSS405 Operating Characteristics ..... 96
6.8 Typical RC-MOS Oscillator Characteristics ..... 113
6.9 Schematics of Inputs/Outputs ..... 114
APPENDIX A Software Restrictions ..... 116
APPENDIX B Pinning Selection Schematic ..... 119
APPENDIX C User Options ..... 125

## List of Figures

Figure Title Paragraph
1-1 Blockdiagram TSS400 ..... 1.1
1-2 X-REG Values which Address Memory ..... 1.2
1-3 Subroutine Stack Operation ..... 1.3
1-4 Digit Latches/R Outputs ..... 1.4
1-5 Blockdiagram of ALU ..... 1.6
1-6 Instruction Restrictions ..... 1.7
1-7 K-line Structure ..... 1.8
1-8 I/O Structure ..... 1.9
Machine Status 2-1 ..... 2
Table for ext. Wake-up Conditions 2-2 ..... 2.5
2-3 Schematic of Wake-up Path ..... 2.5
2-4 Option TIMOSC ..... 2.7
2-5 TRC Oscillator Frequency ..... 2.7
3-1 Principle of A/D-Converter ..... 3
3-2 Principle of Current Source ..... 3.3
3-3 Current Source with Current Option ..... 3.3
4-1 Decode and OPLA for Segment Output ..... 4.1
4-2 4Mux LCD Application Example ..... 4.2
4-3 2Mux LCD Application Example ..... 4.2
4-4 Display Drive Waveform ..... 4.4
6-1 Typical RC-MOS Oscillator Characteristics ..... 6.8
6-2 Schematic of K-l/O's ..... 6.9
6-3 Schematic of I/O ..... 6.9
6-4 Schematic of XTAL Oscillator ..... 6.9
6-5 Schematic of SVDD ..... 6.9
28pin DIP App. B
40pin DIP
44pin PLCC ..... App. B
App. B

## Purpose and Conventions

The TSS400 User's Guide is intended to aid the development of TSS400 products by collecting and presenting hardware and software information in a manner that will be quickly accessible to engineers and programmers.
The following substitutes have been adopted because typographical limitations do not allow the use of some conventional symbols:

| Symbol | Meaning | Example |
| :---: | :---: | :---: |
| $<>$ | "Not equal" | $\mathrm{Y}<>\mathrm{A}$ |
| [] | Subscript number | $\mathrm{R}[0]$ |
| $\wedge$ | Exponent | $\mathrm{T}^{\wedge} 2$ |
| $\mu \mathrm{sec}$ | Microsecond |  |
| msec | Millisecond |  |
| $>\mathrm{XX}$ | Hex-Value | $>3 \mathrm{~F} 4$ |

## 1 TSS400

This document describes in detail the functional and electrical characteristics of a 4-bit CMOS sensor signal processor with computing capability. Its key applications are A/D conversions, calculating, controlling and displaying information on an LCD display. The part easily interfaces with sensors and actuators.

Typical applications are:

- temperature measurements: calculating, controlling, warning
- pressure and acceleration measurements
- home appliances
- intelligent keyboard and display driver
- timer with control functions
- intelligent subsystem


### 1.1 Functional Specification

- 2048 nine bit words of ROM
- 576 bit static RAM
- Three instruction BCD addition
- 64 character, 7 segment output PLA (DP switchable independently)
- Three levels of subroutine
- Timekeeping capability ( 32768 Hz XTAL)
- Direct drive of LCD: ( 32768 Hz XTAL) Option 2MUX: $1 / 2$ duty cycle containing up to 40 segments Option 4MUX: $1 / 4$ duty cycle containing up to 80 segments
- Low power silicon gate CMOS process:
- Low power consumption at sleep mode (active timer/RAM) - very low power consumption at off mode (active RAM)
- 12 Bit AVD-Converter with 4-MUX-inputs and programmable ranges
- Programmable current source from 0.15 to $2.4 \mathrm{~mA} \times$ VDD/V
- Internal MOS oscillator (see Figure 6-1)
- Instruction execution time: $5.5 \mu \mathrm{~s}$ (@froc $=1.1 \mathrm{MHz}$ )
$15.0 \mu \mathrm{~s}\left(@ f_{\text {proc }}=400 \mathrm{KHz}\right)$
- Processor frequency determined either by the internal RC-MOS oscillator or the external clock input


Figure 1-1: Block diagram TSS400

### 1.2 Memory Structure

The TSS400 has nine (9) registers with sixteen (16) four-bit words per register.
Eight (8) registers are random access memories (RAM) and one (1) register is a direct access memory (DAM).
The 9 registers can be addressed by the X-REG. The content of the XREG (4 bits) is controlled by the software instructions LDX, TDL, COMX8.
The Y-Register ( 4 bits) addresses the word within the selected Register. There are several different software instructions that control the contents of the $Y$-REG.
Since the TSS400 has 9 registers, some values of the X-REG do not address any memory. Figure 1-2 is a list of which values will address memory.

| X-REG | HEX | TYPE |
| :---: | :---: | :---: |
| 0001 | 1 | RAM |
| 0010 | 2 | RAM |
| 0011 | 3 | RAM |
| 0100 | 4 | RAM |
| 1001 | 9 | RAM |
| 1010 | A | RAM |
| 1011 | B | RAM |
| 1100 | C | RAM |
| 0111 | 7 | DAM* |
| 1111 | F | DAM* |

* Both $>7$ and $>F$ address the same register (the DAM).

Figure 1-2: X-REG Values which Address Memory

In addition to the memory controlled by the X-REG and the Y-REG there are sixteen (16) digit latches which can be set and reset by software instructions. These digit latches are reset by hardware during power-up or by INIT. The digit latches are addressed by Y-REG (4 bits) values $>0->F$.

### 1.3 Subroutine Stack Operation

The Subroutine Stack has the following registers:

1) Page ROM Address Stack Register (3)
2) Program Counter Stack Registers (3)

The interaction of Page Register, Page ROM Address and Stack is shown for the execution of subroutines.

| P-Reg | X | X | 2 | 2 | 2 | 3 | 3 | 4 | 4 | 5 | 5 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| ROM <br> Addr. <br> Reg. | 15 | 15 | 15 | 15 | 15 | 15 | 3 | 3 | 4 | 4 | 5 | 5 | 6 |  | 4 | 4 | 4 | 4 | 3 | 3 | 3 |
| Sub- <br> routine <br> Reg. A | X | 15 | 15 | X | X | X | X | X | 3 | 3 | 4 | 4 | 5 | 4 | 3 | 3 | 4 | 3 | 15 | 15 | 15 |
| Sub- <br> routine <br> Reg. B | X | X | X | X | X | X | X | X | X | X | 3 | 3 | 4 | 3 | 15 | 15 | 3 | 15 | 15 | 15 | 15 |
| Sub- <br> routine <br> Reg. C | X | X | X | X | X | X | X | X | X | X | X | X | 3 | 15 | 15 | 15 | 15 | 15 | 15 | 15 | 15 |

* This branch is executed (branch occurs).

Figure 1-3: Subroutine Stack Operation (See Section 2.2 and 2.3 for more details.)

### 1.4 Digit Latches/R Outputs

| Digit Latch | Hardware Function |  |
| :---: | :---: | :---: |
| DLO-DL7 | Stat. outputs R0-R7 $\rightarrow$ max. 8 R outputs available |  |
| DL8 | $\begin{array}{ll} \hline \text { Control of K-Port: } & \text { DL8 }=0-\text { - Input } \\ & \text { DL8 }=1-\text { - Output } \\ \hline \end{array}$ |  |
| DL9-DL11 | Analog Mux for ADC: A1-A2-A3-A4 or Battery check |  |
| DL12 | Selection of $1 \mathrm{~Hz}(\mathrm{DL12}=0)$ or selection of mask programmed frequency for wake-up of the processor. Also selection of time info to CKBBUS. |  |
| DL13 | DL13 | Function |
|  | $\begin{aligned} & \hline 0 \\ & 1 \end{aligned}$ | constant current off constant current on |
| DL14 | MSB of character decode and selection of K8 wake-up edge: leading (DL14 = 0) or trailing (DL14 = 1) |  |
| DL15 | DL15 | Function |
|  | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | wake-up of l/O enabled wake-up of //O disabled |

Figure 1-4: Digit Latches/R Outputs

## PUC-signal will reset all Digit Latches.

The digit latches are set by the SETR instruction and are reset by the RSTR instruction.

The value of the Y-REG determines which digit latch is affected. The data of the Digit Latches will be retained when the product is in Sleep mode or Off mode as long as the power is maintained.

### 1.5 DAM Operation

The DAM outputs are transferred into the ALU input regardless the values of the X-REG. This allows operation on data in DAM and one of the 8 memory banks (RAM) at the same time. The DAM instruction is an example

To write into the DAM, the content of the X-REG has to be 0111 or 1111. This can be accomplished by a LDX 7, LDX 15, or a TDL instruction.

If DAM is addressed by the X-REG, all instructions operating on memory will operate on DAM. An example of this is the execution of a TMA instruction while the X-REG contains a 7. This causes the transfer of the DAM into the ACC.

If X-register is 0111 or 1111 instructions which use RAM and DAM will use DAM only. An example of this is the DMEA instr.:

$$
\mathrm{DAM}+\mathrm{MEM}(=\mathrm{DAM})+\mathrm{SS} \rightarrow \mathrm{ACC} \quad \mathrm{DAM}^{*} 2+\mathrm{SS} \rightarrow \mathrm{ACC}
$$

### 1.6 ALU

The ALU (Arithmetic Logic Unit) can perform addition, subtraction (by two's complement) and comparison of 2 four bit numbers. Data from the Y -register, DAM, CKB multiplexer or RAM is selected by the P-multiplexer and added to or compared with data from CKB, Accumulator or RAM selected by the N -multiplexer. The adder-comparator portion of the ALU adds or compares the data. The status will be set or reset depending on the result. Data from the adder can be transferred to the Accumulator, the Y-register, or can be dumped in case the data is needed for comparison only.


Figure 1-5: Block diagram of ALU

### 1.7 CKB Memory Map Description

The TSS400 has a 4-bit wide bus line (CKB) that may carry constant data, K-line data, timekeeping data or bit data (SBIT, RBIT, TBIT, TBITA, TCTM, TIOM). Any of these instructions determine which data are valid on the bus line at that time. In order to minimize the physical size of the CKB logic, certain portions of the instruction map are reserved by the CKB logic for data from one (1) of the four (4) sources to be on the CKB bus line.

| Instruction Map Locations | Source of Data on CKB Bus |
| :---: | :--- |
| $008 \rightarrow 00 \mathrm{~F}$ | K-lines |
| $018 \rightarrow 01 \mathrm{~F}$ | TKP lines (timekeeping) |
| $020 \rightarrow 02 \mathrm{~F}$ | Bit data for TBIT, TCTM |
| $0 \mathrm{AO} \rightarrow 0 \mathrm{AF}$ | Bit data for |
| $040 \rightarrow 07 \mathrm{~F}$ | SBIT,RBIT,TBITA,TIOM |
| $0 \mathrm{CO} \rightarrow 0 \mathrm{FF}$ | Constant data (I5 $\rightarrow$ I8) |
|  | Constant data ( $15 \rightarrow \mathrm{I8)}$ |

Figure 1-6: Instruction Restrictions

As shown in Figure 1-6, certain areas of the instruction map are decoded by the CKB logic and the CKB bus line will use data from one of its sources. Use micro-instructions CKM, CKP, or CKN to transfer data to another portion of the processor. Please note that the source of data on the CKB bus is solely determined by a location in the instruction map as shown above.

### 1.8 K-Line Structure



Figure 1-7: K-Line Structure

The present state of Digit latch DL8 defines the state of K-Lines to be Input or Output:

Input if DL8 = "0"
Output if DL8 $=$ " 1 ".
PUC signal will reset DL8 to "0" - Input.
The TAK instruction latches the 4 bit ACC into the output data register. If DL8 is " 1 " the data is available at the K-Lines:

K1 --- ACC1
K2 --- ACC2
K4 --- ACC4
K8 --- ACC8

The signals, applied at the K-pins, are read or tested directly or divided:

| Option K8-FF not used | Option K8-FF used |
| :--- | :--- |
| K1 $\rightarrow$ ACC1, MEM0 | K1 $\rightarrow$ ACC1, MEM0 |
| K2 $\rightarrow$ ACC2, MEM1 | K2 $\rightarrow$ ACC2, MEM1 |
| K4 $\rightarrow$ ACC4, MEM2 | K4 $\rightarrow$ ACC4, MEM2 |
| K8 $\rightarrow$ ACC8, MEM3 | K8/2 $\rightarrow$ ACC8, MEM3 |

Three instructions are implemented to read or test the information, applied at the K-Lines:

TKA, TKM and KNEZ.

### 1.9 I/O Structure



Figure 1-8: $/ / O$ Structure

The PUC signal as well as the IOIN instruction will reset the I/O pin to be an input (output buffer is 3-state).
Three instructions define the state of the I/O pin to be an output and will determine the data to be output:

- SETIO : set I/O pin to "1"
- RSTIO : reset I/O pin to "0"
- TSIO : output Status from the previous instruction output.


### 1.10 Clock

The Clock Output has 3 options that can be selected:

$$
\begin{aligned}
& \text { NONE }: \text { not selected } \\
& 256 \mathrm{~Hz}: f_{\text {Clock }}=\frac{f_{\text {TOSCIN }}}{128} \\
& 1024 \mathrm{~Hz}: f_{\text {Clock }}=\frac{f_{\text {TOSCIN }}}{32}
\end{aligned}
$$

When the processor is forced into the OFF mode, the oscillator is stopped and the TOSCIN pin is forced to $\mathrm{V}_{\mathrm{DD}}$ via a p-channel transistor. The signal at the pin 'Clock' remains at the logical level it had during executing the OFF instruction.

When using the Clock Signal together with the OFF mode pay attention to the application S/W and H/W.

If a defined logical level is necessary in the application - e.g. to avoid current consumption - the logical level has to be read e.g. by K-input to check the state of the Clock Signal before executing the OFF instruction.

Note: The signal at the pin 'Clock' is not the same as the signal at the Pin "TOSCIN".

## 2 Operational Description

There are three different machine states: DONE, ACTIVE and OFF. During the DONE state only display and timekeeping circuitry are active. DONE is a low power state.

In the ACTIVE state the chip is executing instructions from its internal ROM and maximum power is dissipated.
In the OFF state only RAM/DAM and the actual level of I/O, R outputs and K-l/O's remain unchanged. This is true in the DONE state as well.

The machine state transitions are illustrated in Figure 1-12.


Figure 2-1: Machine Status

### 2.1 ROM Decode

The ROM on the TSS400 has sixteen (16) pages with 128 words per page and nine bits per word. The ROM page address is contained in the ROM Page Address Register. The ROM word address is derived from the program counter.
The four bits of the page register are decoded in a 1 of 16 decode. A bus runs from the 1 of 16 page decode to the ROM and addresses the proper page.

The seven bits of the program counter are decoded in a 1 of 128 decode. A bus runs from the 1 of 128 word decode to the ROM and addresses one word on each page. Page and word decode select together the particular word.

### 2.2 Program Counter and Subroutine Register

A bus from the program counter (PC) runs to a 1 of 128 decode and to a feedback network, which is used to change the state of the program counter in order to obtain the next ROM word address. When a CALL instruction is executed, the seven PC bits are stored in the first of a three level subroutine stack. Each successful CALL instruction pushes down the stack. As many CALL instructions as necessary may be executed, but only the three most recent return addresses are stored. All previous return addresses are lost. Each RETN instruction, up to a maximum of three consecutive, pops up the stack. Any RETN instructions encountered when the device is not in a subroutine will be treated as no-op instructions.

### 2.3 ROM Page Address Register and Page Buffer

The ROM page address register, like the program counter, is capable of three levels of subroutines.

When a CALL instruction is executed, the four page-address bits are stored in the first of a three level subroutine stack. Each successful CALL instruction pushes down the stack. As many CALL instructions as necessary may be executed, but only the three most recent return addresses are stored. All previous addresses are lost. Each RETN instruction, up to a maximum of three consecutive, pops up the stack. Any RETN instruction encountered when the device is not in a subroutine will be treated as a no-op instruction.
When a LDP instruction is executed, the page address is loaded into the Page Buffer. The Page Address is transferred to the ROM Page Address Register when a CALL or BRANCH instruction is successfully executed. If the CALL or BRANCH instruction is unsuccessful or an RETN instruction is
executed between the LDP and CALL instructions, the Page Buffer and the ROM Page Address Register remain unchanged.

After an LDP-RETN sequence, the ROM page Address Register remains unchained by CALL and BRANCH instructions.

### 2.4 Instruction Decode

First a nine-bit word from the ROM goes to the instruction decode, where three types of instructions are decoded:

- programmable instructions
- fixed instructions
- CKB instructions

If 1 of the 48 programmable instructions is decoded as true, a set of microinstructions will be decoded. These micro-instructions control lines which handle one space too much various logic blocks.

If 1 of the 29 fixed instructions is decoded as true, the output of the respective instruction will set a control line used by a particular logic circuit.
If a CKB instruction is decoded as true, the 4 least significant bits of the ROM word, or the 4 K -lines, or the 4 timekeeping lines are passed into the ALU (depending on which instruction is decoded).

### 2.5 Processor Enable and Time Base Multiplexer

The software determines when the processor is disabled by executing a DONE instruction. The hardware keeps a timer up to 15 seconds; the software must keep time for all times part 15 seconds (minutes, hours, a.m/p.m., day of the week, date, and month). A calculation must not take longer than 15 seconds. In case a calculation does take longer by software an periodical interrupt of the calculation must occur to enable the timekeeping update.
The processor enable logic "wakes-up" the processor from DONE state depending on DL12, to allow the update of the timekeeping.
The processor logic-enable-also senses the K-lines K1, K2, K4, K8 and I/O line.
"Wake-up" from OFF state is only possible via Init, K-lines or I/O line; program execution starts at page $15, \mathrm{PC}=>7 \mathrm{~F}$.

| DL14 DL15 |  | K1 | $K 2$ |  |  | $1 / 1$ | conditions for external wake-up |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | 0 |  |  |  |  |  | before wake-up will be accepted |
|  | 0 |  |  |  |  |  | transition to wake-up processor |
| 1 | 0 |  |  |  |  |  | before wake-up will be accepted |
|  | 0 |  |  |  |  |  | transition to wake-up processor |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 1 |  | 0 | 0 | 0 |  | betore wake-up will be accepted |
|  | 1 |  |  |  |  |  | transition to wake-up processor |
| 1 | 1 | $q^{\wedge} \operatorname{squ}^{\wedge} \tan ^{\frac{1}{2}} \hat{x}$ |  |  |  |  | before wake-up will be accepted |
|  | 1 |  |  |  |  |  | transition to wake-up processor |

Note: ' $v$ ' - logical OR, ' $\wedge$ ' - logical AND, $X$ - don't care

Figure 2-2: Table for ext. Wake-up Conditions


Note: Wake-up occurs when 'wake-up' signal is Low AND processor in DONE/OFF mode
Delay line is active if processor is active ( 5 to 6 instructions) Delay line is inactive if processor is in DONE/OFF mode: No Delay DL14 selects the logical state of K8 for 'wake-up' signal

Figure 2-3: Schematic of Wake-up Path

### 2.6 Processor Frequency

The processor frequency is derived from the internal RC-MOS Oscillator. The typical characteristic of this Oscillator is shown in Figure 6-1.
This internal MOS Oscillator frequency can be overwritten by an external Oscillator connected to Pin PFRQ. The frequency range for the external Oscillator is defined in Chapter 6.2 Operating Conditions.

[^0]
### 2.7 Timer Oscillator

## Crystal Oscillator

A 32.768 Hz signal of the crystal oscillator is fed into the crystal clock generator, which divides the frequency by four and generates four phase clocks. These clocks are divided down through a series of divide-by-two circuits into the frequencies needed for timekeeping functions. A signal KSC is produced by the dividing circuit. This signal is used on the logic of the Common Generator, to generate the signals on the two or four common lines.

## RC Oscillator

Using the RC oscillator (OPTION "TRC") instead of the crystal oscillator, the same applies as described in Section 2.7 (see Figure 2-4).


Figure 2-4: Option TIMOSC


Figure 2-5: TRC Oscillator Frequency

### 2.8 Time Data Multiplexer

The TSS400 processor does not need to be active all the time. The processor is turned on only when needed to perform a software function or to update timekeeping. The processor can "wake-up" to update timekeeping either once per second or $x$-times per second (Option).
This is determined in the Time Data Multiplexer. When DL12 is high, the processor wakes-up $x^{*}$-times per second, and when DL12 is low, the processor wakes-up once per second. This also determines the data used timekeeping.

* Options for x: 128 or 64 or 32 or 16 or 8

Revision 3.2, October 1991

When DL12 is high, the 4-bit timekeeping data represents a time of $0 / 16$ to $15 / 16$ of a second, and when DL12 is Low, the data represent a time of 0 to 15 seconds.

The timekeeping can be accessed via CKB-Bus by software.

### 2.9 CKB (Constant, K-lines, Bit and Time Multiplexer)

All constant data used by the Y-REG, the Accumulator, or memory must pass the CKB. The logic of the CKB determines according to the used instruction whether to select constant, K-lines, bit logic, or timekeeping data to be transferred to various parts of the TSS400.

### 2.10 Branch/Call Control

When a BRANCH is encountered the Branch/Call Control Logic effects the program counter to dump the present ROM word address and accept a new one. When a CALL is encountered the Branch/Call Logic effects the program counter and the ROM page register to move their present contents into the subroutine latches and accept new addresses. A RETN forces the Branch/Call Control Logic to return the program counter to the stored address plus one. The stored address id the address when the call was encountered. The ROM page address register returns to the address it contained before the CALL. If a RETN is encountered while the CPU is not busy in a subroutine, it is regarded as a no-op and ignored. (See Status paragraph).

### 2.11 RAM Address/Character Decode Multiplexer

The RAM Address/Character Decode Multiplexer combines 2 blocks:

1) Multiplexer between the Y-Reg and the Accumulator. The output of the multiplexer is fed into the Decoder.
2) Decoder which decodes either the RAM word address from the $Y$ Register or the LCD character address from the Accumulator.

### 2.12 Write Multiplexer

The Write Multiplexer determines whether data is to be put into the RAM, the DAM, or the P-Multiplexer in the ALU. The data is taken from the CKB logic or from the Accumulator. The Write Multiplexer is controlled by software.

### 2.13 X-Decode

The X-REG is decoded by the X-Decode to select a particular RAM bank. Tthe value of the DAM latch, which enables DAM and disables RAM or vice versa is also decoded by the X-REG.

### 2.14 RAM Word Decode

The RAM Address/Character Decode Multiplexer feeds all 4 bits of the Y REG into a 1 of 16 decode. The state of the sixteen outputs of the RAM word decode which of the sixteen words in each bank of the RAM and DAM or which of the sixteen Digit latches is addressed.

### 2.15 Character Decode

The Character Decode uses DL14, status, and the four Accumulator bits to do a 1 of 64 character decode. The 64 signals are then transferred into the output PLA, where they are converted into a seven-segment output. (The Character Decode is illustrated in the Gate Level PLA paragraph.)

### 2.16 Segment Latches

After decoding and converting the characters into segment outputs, they are latched in Segment latches when the proper Y -pointer is set and a TDO instruction is executed.

### 2.17 Segment Drivers

The segment data is transferred to the Multiplexing Segment Drivers which convert the seven segments and the Segment H information into 2Mux or 4Mux segment information, which is output and used to turn on the LCD segments.

In test mode some of the LCD-Outputs do have other functions.

### 2.18 Power Up Clear

There is an time interval between power is applied to the TSS400 and the starting of the clocks. The Power Up Clear (PUC) signal sets the page and word address and enables the PC after the clocks have started.

When the voltage is applied, PUC starts the program execution on page $15, \mathrm{PC}=>00$. A low signal at INIT pin creates the same function as power being applied.

When the Processor is activated from Done or OFF mode via a K-input-I/O or by a timekeeping update, the program execution begins at Page 15, $P C=>7 \mathrm{~F}$.

### 2.19 Status

Status is held in a single bit latch. When this bit is set, which is its normal state, and a BR or CALL is encountered, the BR or CALL will be executed. When status is reset immediately before a CALL or BR, the instruction will not be executed successfully and the Program Counter will continue incrementing.

Status will remain reset ( 0 ) for only one instruction cycle.
Status can be unconditionally reset by instruction ACACC 0.
Status can be unconditionally set by instruction ACYY 0 .

### 2.20 P-Multiplexer

The P-Multiplexer part of the ALU selects data from the Y-REG, the CKB, the RAM, or the DAM, and feeds this data to the Adder-Comparator part of the ALU. (See Figure 1-5)

### 2.21 N-Multiplexer

The N-Multiplexer part of the ALU selects data from the CKB, the Accumulator, or the RAM, and feeds this data to the Adder-Comparator portion of the ALU. (See Figure 1-5)

### 2.22 Adder-Comparator

The Adder-Comparator portion of the ALU simultaneously adds and compares the data in the N and P Multiplexers. Information from the comparator is used in determining status. Data from the Adder can be sent to the Accumulator or the Y-REG, or can be dumped if the data is needed for comparison only.

### 2.23 Accumulator and $\mathbf{Y}$-Register

The Accumulator is a four-bit register that gets its content from the AdderComparator. The Y-Register (Y-REG) holds the RAM word address and is used to select one of sixteen Digit latches.

## 3 Analog/Digital-Converter (ADC)

The A/D-Converter is specially designed for:

- 1-2 KOhm-temperature Si-sensors
- Pt100/Pt500/Pt1000 Elements in conjunction with internal current source
- Silicon pressure sensors

It is in no way restricted to those applications.
The A/D-Converter compares the external analogue input voltage with an internal voltage.


Figure 3-1: Principle of A/D-Converter

### 3.1 Description of Conversion

The A/D-Conversion is done by executing a software program.
Five instructions are added to the instruction set for controlling the ADC:

- SCSV: switch converter's supply voltage on
- RCSV: reset converter's supply voltage
- RCI: reset converter's comparator inputs to inverted
- TCTM n: transfer comparator (output) to memory - selected by X-REG and Y-REG while $n$ identifies the bit - and set the next lower bit to high (if $n$ is $2,3,4$ ).
- TRTM $n$ : transfer range to memory bit $n(n=1,2,3,4)$.

The A/D-converter consists of:

- a D/A converter (DAC) as voltage reference source
- a Comparator
- an analog switch to interchange input signals at comparator
- an analog multiplexer (4 to 1)
- a constant current source; programmable by one external resistor and enabled or disabled by DL13
- the SV ${ }_{\text {DD }}$ control
- a voltage source (for battery check)

As shown in the Figure 3-1, the instruction SCSV switches the supply voltage to the AID Converter and PIN SV ${ }_{\text {DD }}$ on - instruction RCSV switches it off. The voltage is also switched-off during Power on/INIT and if the processor is in DONE/OFF mode.
The D/A converter is controlled by 12 bits. These 12 bits are memory bits located in the DAM.

| Y-REG | BIT3 | BIT2 | BIT1 | BIT0 |
| :---: | :---: | :---: | :---: | :---: |
| 13 | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ |
| 14 | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ |
| 15 | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

The content of the 12 DAM bits is linearly converted into an analogue voltage by the DAC. This output voltage is fed into the analogue cross bar switch in front of the comparator. The comparator compares this voltage with the analogue input voltage at the selected input A1 ... A4.

A special instruction TCTM is available to do a simple successive approximation by software. This instruction transfers the comparator output to the pre-selected DAM-bit and sets the next lower bit at the same DAM address.

The starting value should be $>800$ (midpoint of range). The time constant of the DAC network requires some wait cycles between the TCTM instructions:

| affected bit | instructions before TCTM |
| :--- | :---: |
| MSB | 5 |
| MSB-1 | 5 |
| MSB-2 | 5 |
| MSB-3 | 5 |
| MSB-4 | 4 |
| MSB-5 | 4 |
| MSB-6 | 4 |
| MSB-7 | 4 |
| MSB-8 | 3 |
| MSB-9 | 3 |
| MSB-10 | 3 |
| LSB | 3 |

Instruction SCSV sets the analog crossbar switch at the comparator input and instruction RCI resets it. Two conversions - one with set and one with reset switch - eliminate the offset of the comparator. The two conversion results are added. The sum is twice the value of the conversion formula.

To ensure that the measurement is within the valid range, a special instruction TRTM is included. This instruction sets the addressed RAM bit to " 0 " if the measured value is greater than $>000$ and less than $>$ FFF. Otherwise the bit is set ("1"): selected analog input voltage out of A/Dconversion range.

Optionally, there are four conversion ranges for the ADC available. One and only one must be selected. This selection is done in connection with the ROM programming.

Conversion formula: (for nominal values)
with: all voltages are referenced to AG

with: $N_{L} \leq N \leq N_{\text {HL }}$

Range large $\quad: a=0.101213203 ; k=0.000096090233{ }^{*} \mathrm{~N}$
Range small : $a=0.231271438 ; k=0.000043048228{ }^{*} \mathrm{~N}$
Range medium-low : $\mathrm{a}=0.1002948411 ; \mathrm{k}=0.000073816955{ }^{*} \mathrm{~N}$
Range medium-high : $\mathrm{a}=0.2326179386 ; \mathrm{k}=0.000065411591{ }^{*} \mathrm{~N}$
Note: $N_{L L}=$ digital value analog input voltage lower limit.
$N_{H L}=$ digital value analog input voltage higher limit.

### 3.2 Battery Check

The stable internal voltage source ( $\mathrm{V}_{\mathrm{REF}}$ ) is applied to the comparator instead of an external voltage signal at the analog inputs. To the other input of the comparator, the DAC output voltage is applied. This DAC output $\left(V_{D A C}\right)$ is a linear function of $S V_{D D}$, that is nearly identical to $V_{D D}$ :

$$
V_{D A C}=(a+K \cdot N) \cdot S V_{D D}
$$

The comparator allows to determine the N value for which $\mathrm{V}_{\mathrm{DAC}}=\mathrm{V}_{\text {REF }}$ and it follows:

$$
S V_{D D}=V_{D D}=\frac{V_{\text {REF }}}{a \cdot K \cdot N}
$$

### 3.3 Current Source

The current source and the A/D converter are ratiometric. Voltage used for A/D conversion and the reference voltage $\left(\mathrm{V}_{\mathrm{V}}\right)$ used to set the current of the current source are proportional to $\mathrm{SV}_{\mathrm{DD}}$ and have a fixed ratio to each other. This ensures optimum tracking. The current source is activated with DL13 set AND with SV $\mathrm{DD}_{\mathrm{D}}$ on; both conditions are necessary to switch on the current source.

The current, passed via an analog input to a sensor, is calculated:

$$
I_{A n}=\frac{V_{\text {Rext }}}{R_{\text {ext }}}
$$

The current, flowing through a sensor (e.g. resistive temperature sensor), generates a voltage drop at the sensor which is available at the analog input for measurement with the A/D converter:

$$
\begin{aligned}
& V_{\text {in }}=I_{\text {An }} \cdot R_{\text {in }} \text { with } R_{\text {in }} \text { is sensor's resistance } \\
& V_{\text {in }}=V_{\text {Rext }} \cdot \frac{R_{\text {in }}}{R_{\text {ext }}}
\end{aligned}
$$



Figure 3-2: Principle of Current Source

| DL13 | DL11 | DL10 | DL9 | analog input selected, <br> Current Source (CS) on/off |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | A1, CS off |
| 0 | 0 | 1 | 0 | A2, CS off |
| 0 | 1 | 0 | 0 | A3, CS off |
| 0 | 1 | 1 | 0 | A4, CS off |
| 1 | 0 | 0 | 0 | A1, CS on |
| 1 | 0 | 1 | 0 | A2, CS on |
| 1 | 1 | 0 | 0 | A3, CS on |
| 1 | 1 | 1 | 0 | A4, CS on |
| X | X | X | 1 | battery check, CS off |

Figure 3-3: Current Source


Figure 3-3: Current Source (continued)

## 4 Display

### 4.1 Gate Level PLA

The TSS400 has a 1 of 64 decode for character output. The decode has six input lines; from the Most Significant Bit (MSB) to the Least Significant Bit (LSB) they are:

- DL14
- Status bit
- The four Accumulator bits from ACC8 to ACC1.

The decoded information is then transferred to a bus to the Segment PLA. The Segment PLA can be gate-level programmed to set the state of each of the seven segment lines, A-G, high or low depending on the decode information.
The Segment H is controlled by SDP/RDP instruction.


Figure 4-1: Decode and OPLA for Segment Output

### 4.2 Common Select Lines

There are four Common Select Lines. Each has a unique output waveform that when used in combination with the twenty (20) Select Lines can control 40/80 different segments on a liquid crystal display (LCD).

The combination of Common Select Lines to Segment Lines is shown in the next paragraph.


Figure 4-2: 4Mux LCD Application Example


Figure 4-3: 2Mux LCD Application Example

### 4.3 Select Lines

Up to twenty Select Lines are available as outputs. Each Select Line defines two/four Segments as shown below. A 64-term gate programmablesegment PLA (decoded by ACC1, ACC2, ACC4, ACC8 Status, DL14) and SGH determines which segments are to be turned on.
These are then loaded into the Segment Latches by Y-Decoder/TDO instruction and time-multiplexed to the Output Select Lines.

## TSS400 Segment Latch Structure

(Standard Common-Segment-Y option) *).

1/2 duty cycle (2 mux)

| Select Line | Segments | Loaded by |
| :---: | :---: | :---: |
|  | $\begin{array}{ll} \hline C & C \\ O & O \\ M & M \\ 3 & 4 \\ \hline \end{array}$ |  |
| S1 | B H | Y0/TDO |
| S2 | A F | Y0/TDO |
| S3 | G E | Y0/TDO |
| S4 | C D | Y0/TDO |
| S5 | B H | Y1/TDO |
| S6 | A F | Y1/TDO |
| S7 | G E | Y1/TDO |
| S8 | C D | Y1/TDO |
| S9 | B H | Y2/TDO |
| S10 | A F | Y2/TDO |
| S11 | G E | Y2/TDO |
| S12 | C D | Y2/TDO |
| S13 | B H | Y3/TDO |
| S14 | A F | Y3/TDO |
| S15 | G E | Y3/TDO |
| S16 | C D | Y3/TDO |
| S17 | B H | Y4/TDO |
| S18 | A F | Y4/TDO |
| S19 | G E | Y4/TDO |
| S20 | C D | Y4/TDO |

1/4 duty cycle (4 mux)

| Select <br> Line | Segments | Loaded <br> by |
| :---: | :---: | :---: |
|  | C C C C |  |
|  | O O O O |  |
| M M M M |  |  |
| 1 |  |  |
| S1 3 4 | A B C D |  |
| S2 | F G E H |  |
| S3 TDO |  |  |
| S4 | A B C D | Y1/TDO |
| S5 G E H | Y1/TDO |  |
| S6 | A B C D | Y2/TDO |
| S7 | A B C D | Y2/TDO |
| S8 | F G E H | Y3/TDO |
| S9 | A B C D | Y4/TDO |
| S10 | F G E H | Y4/TDO |
| S11 | A B C D | Y5/TDO |
| S12 | F G E H | Y5/TDO |
| S13 | A B C D | Y6/TDO |
| S14 | F G E H | Y6/TDO |
| S15 | A B C D | Y7/TDO |
| S16 | F G E H | Y7/TDO |
| S17 | A B C D | Y8/TDO |
| S18 | F G E H | Y8/TDO |
| S19 | A B C D | Y9/TDO |
| S20 | F G E H | Y9/TDO |

*) Note: The Y-Address of each Segment Group is configurable to application needs. The definition is done together with the ROM programming (via mask).

### 4.4 Display Drive Waveforms

Display-Drive waveforms are shown in Figure 4-4 for 1/2 and 1/4 duty cycle LCD. The internal logic signal KSC initiates voltage changes in the display voltages.
KSC has a frequency of 512 Hz and is active for 122 micro-seconds ( TTOSCIN $=32768 \mathrm{~Hz}$ ).


Figure 4-4: Display Drive Waveforms (Standard Gate Placement) e.g. Number 4: Segment 'BCFG' on - 'ADEH' off

## 5 Instruction Set Description

The following abbreviations will be used in describing the Instruction Set:

| ACC | $=$ Accumulator |
| :--- | :--- |
| CONSTANT | $=0-15$ |
| LSB | $=$ Least Significant Bit |
| MEM | $=$ Memory as pointed to by $X$ and $Y$ Registers |
| MSB | $=$ Most Significant Bit |
| REG | $=$ Register |
| SS | $=$ Special Status Latch |
| $\langle>$ | $=$ not equal |
| ACC | $=$ not Accumulator |

5.1 Functional Description (alphabetical listing)

| CODE | MNEMONIC | DESCRIPTION |
| :---: | :---: | :---: |
| 070-07F | ACACC | Add a constant to ACC and store in ACC; if carry status = 1 |
| OFO-0FF | ACYY | Add a constant to Y-REG |
| OEO-EF | ALEC | If ACC less than or equal CONSTANT, status $=1$ |
| 001 | ALEM | If $A C C$ is less than or equal to MEM, status $=1$ |
| 015 | AMAAC | Put MEM + ACC into ACC; if carry, status $=1$ |
| 100-17F | BRANCH | If status $=1$, branch to location $>00$ to >7F as pointed to by label; else increment Program Counter |
| 180-1FF | CALL | If status $=1$, then execute CALL to location $>00->7 \mathrm{~F}$ as defined by label. The 3 -level subroutine stack retains the return address. |
| 012 | CCLA | If $S S=0$, put 0 in $A C C$; if $S S=1$, put 1 in ACC |
| 006 | CLA | Clear ACC |
| OB2 | COMX8 | Complement MSB of X-REG |
| 031 | CPAIZ | Put 2's complement of ACC into ACC; if initial $A C C=0$, status $=1$ |
| 018 | CTMDYN | If both Add Latch and SS are set or both are reset, put ACC into MEM; Decrement $Y$-REG; if initial $Y<>0$, status $=1$ |
| 007 | DMAN | Put MEM-1 into ACC; if MEM $<>0$, status $=1$ |

5.1 Functional Description (alphabetical listing - continued)
CODE MNEMONIC DESCRIPTION

| 010 | DMEA | Put $D A M+M E M+S S$ into $A C C$ |
| :--- | :--- | :--- |
| 011 | DNAA | Add $D A M, \overline{A C C}$ and $S S$ and store it in |
|  |  | ACC |


| OBE | DONE | Turns the processor portion of the chip off <br> 004 |
| :--- | :--- | :--- |
| DYN | Decrement $Y$-REG; if initial $Y<>0$ then <br> status $=1$ |  |


| 032 | IMAC | Store in ACC the result of MEM +1; <br> if MEM $=15$ then status $=1$ |
| :--- | :--- | :--- |
| 01 A | IOIN | I/O Output buffer becomes 3 -state to be <br> Input for ext. signals |
| 005 | IYC | Increment Y-REG; if initial Y $=15$ then <br> status $=1$ |

OOE KNEZ

If K -lines $\langle>0$ then status $=1$. If status is set to 0 then another KNEZ 6 -instruction cycles later must be done; if status $=0$ again you can be certain that K -lines $=0$.

| 080-08F | LDP |
| :--- | :--- |
| 090-09F | LDX |

MNEZ
Load Constant into ROM page buffer Load Constant into X-REG. I(5) = LSB, $\mathrm{I}(8)=$ MSB. RESET DAM-LATCH

| 009 | MNEA |
| :--- | :--- |
| MNEZ | If $M E M<>$ ACC then status $=1$ |
| 033 | If $M E M<>0$ then status $=1$ |

### 5.1 Functional Description (alphabetical listing - continued)

| CODE | MNEMONIC | DESCRIPTION |
| :--- | :--- | :--- |
| 013 | NDMEA | Add MEM, $\overline{\text { DAM }}$ and SS and store it in <br> ACC |
| $0 B 7$ | OFF | Turns the Processor and Timer off <br> 014 |
| ORMA | Logical OR of MEM and $\overline{\text { ACC }}$ stored in <br> ACC <br> Logical OR of MEM and $\overline{\text { ACC }}$ stored in |  |
|  | ORMNAA | ACC |

OA4-0A7 RBIT Reset one of 4 MEM bits as addressed by l(7), l(8)
LSB- Bit $2^{0} \rightarrow$ @I(7), @l(8)
Bit $2^{1} \rightarrow \quad 1(7), \quad @ 1(8)$
Bit $2^{2} \rightarrow$ @ $(7), \quad 1(8)$
MSB- Bit $2^{3} \rightarrow \quad \mathrm{I}(7), \quad \mathrm{l}(8)$

OBD $\quad$ RCI

OBB

0B6
0B4
OBF

RCSV

RDP
REAC
RETN

Reset Comparator offset switch to INVERTED

Reset Converters Supply Voltage and Pin SVDD
Reset Decimal Point (Segment H)
Reset END-Around-Carry (SS)
Reset add latch and branch latch. When in CALL, RETN also transfers subroutine register to Program Counter and transfers ROM page register to Page Buffer + Page Address
5.1 Functional Description (alphabetical listing - continued)

| CODE | MNEMONIC | DESCRIPTION |
| :---: | :---: | :---: |
| 00B | RSTIO | Reset I/O pin - I/O Output buffer is enabled |
| 036 | RSTR | Resets Digit Latch pointed to by Y-REG |
| 0B1 | SAL | Set ADD latch |
| 030 | SAMAN | $\mathrm{MEM}+\overline{\mathrm{ACC}}+1 \rightarrow \mathrm{ACC}$; if MEM $\geq A C C$ then status $=1$ |
| OB3 | SBL | Set Branch Latch |
| OAO-A3 | SBIT | Set 1 of 4 MEM bits as addressed by 17 and 18 |
| OBA | SCSV | Set Converters Supply Voltage and Pin SV ${ }_{\text {DD }}$. The Comparator offset is switched to NONINVERTED |
| OB9 | SDP | Set Decimal Point (Segment H) |
| 0B5 | SEAC | Set End-Around-Carry (SS) |
| 00C | SETIO | Set I/O-I/O Buffer is enabled |
| 00D | SETR | Set Digit Latch pointed to by Y-REG |
| 0B8 | TAK | Transfer ACC to K-latch for Output |
| 03F | TAM | Transfer ACC to MEM |
| ODO-DF | TAMACS | Transfer ACC to MEM; Add a constant to ACC and store in ACC; if Add Latch is set and carry from ALU on previous or present instruction is = 1 , set SS; reset otherwise; if Add Latch is reset and if carry from ALU on only previous instruction $=1$, set SS |
| 03C | TAMDYN | Transfer ACC to MEM; decrement Y-REG; if initial $Y<>0$, status $=1$ |

5.1 Functional Description (alphabetical listing - continued)
CODE MNEMONIC DESCRIPTION

| 03D | TAMIYC | Transfer ACC to MEM; Increment Y-REG, if initial $Y=15$, status $=1$ |
| :---: | :---: | :---: |
| 03E | TAMZA | Transfer ACC to MEM; clear ACC |
| 038 | TAY | Transfer ACC to Y-REG |
| 020-023 | TBIT | Test 1 of 4 MEM bits as addressed by 17 and I8. If MEM bit EQ 1, status $=1$ |
| $0 \mathrm{AB}-0 \mathrm{AB}$ | TBITA | Test 1 of 4 ACC bits as addressed by 17 and I8. If ACC bit EQ 1, status = 1 |
| 0C0-0CF | TCA | Transfer a Constant to ACC |
| 040-04F | TCY | Transfer a Constant to Y-REG |
| 060-06F | TCMIY | Transfer a Constant to MEM; increment $Y$ REG |
| 024-027 | TCTM | Transfer Comparator to 1 of 4 MEM bits as addressed by 17 and 18 , the next lower nibble at the same is set. |
| 016 | TDA | Transfer DAM to ACC independent of X |
| OBC | TDL | Toggle DAM Latch |
| OBO | TDO | Load the Segment Latches with the segment data (A-G) and decimal point into the latches being addressed by $\mathrm{Y}(0-4 / 9)$ |
| OAC-OAF | TIOM | Transfer I/O to 1 of 4 MEM bits as addressed by 17 and 18 (Level sensed during previous instr.) |
| 008 | TKA | Transfer K-lines to ACC |
| 00A | TKM | Transfer K-lines to MEM |
| 039 | TMA | Transfer MEM to ACC |
| 01D | TNEA | If Timer <> ACC, status $=1$ |
| 01C | TNEM | If Timer <> MEM, status $=1$ |

5.1 Functional Description (alphabetical listing - continued)

| CODE | MNEMONIC | DESCRIPTION |
| :---: | :---: | :---: |
| 03A | TMY | Transfer MEM to Y-REG |
| 028-02B | TRTM | Transfer Range (ADC) to 1 of 4 MEM as addressed by 17 and 18 (ADC in Range: 0; out of Range: 1) |
| 00F | TSIO | Transfer Status to I/O-I/O Buffer is enabled |
| 01E | TTA | Transfer seconds to ACC if DL12 $=0$; transfer $1 / 16$ seconds to ACC if DL12 $=1$ |
| 01B | TTM | Transfer seconds to MEM if DL12 $=0$; transfer $1 / 16$ seconds to MEM if DL12 $=1$ |
| 01F | TTY | Transfer seconds to $Y$-REG if DL12 $=0$; transfer $1 / 16$ seconds to $Y$-REG if DL12 = 1 |
| 03B | TYA | Transfer Y-REG to ACC |
| 019 | XDA | Exchange DAM and ACC |
| 003 | XMA | Exchange MEM and ACC |
| 002 | YNEA | If $Y$-REG $<>$ ACC, status $=1$ |
| 050-05F | YNEC | If $\mathrm{Y}-\mathrm{REG}$ <> Constant, status $=1$ |

### 5.2 9-Bit Instruction Map

|  | LSB |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 00 |  | ALEM | YNEA | XMA | DYN | IYC | CLA | DMAN |
| 01 | DMEA | DNAA | CCLA | NDMEA | ORMA | AMAAC | TDA | ORMNAA |
| 02 | TBIT |  |  |  | TCTM |  |  |  |
| 03 | SAMAN | CPAIZ | IMAC | MNEZ |  |  | RSTR |  |
| 04 | TCY |  |  |  |  |  |  |  |
| 05 | YNEC |  |  |  |  |  |  |  |
| 06 | TCMIY |  |  |  |  |  |  |  |
| 07 | ACACC |  |  |  |  |  |  |  |
| 08 | LDP |  |  |  |  |  |  |  |
| 09 | LDX |  |  |  |  |  |  |  |
| OA | SBIT |  |  |  | RBIT |  |  |  |
| OB | TDO | SAL | COMX8 | SBL | REAC | SEAC | RDP | OFF |
| 0 C | TCA |  |  |  |  |  |  |  |
| OD | TAMACS |  |  |  |  |  |  |  |
| OE | ALEC |  |  |  |  |  |  |  |
| OF | ACYY |  |  |  |  |  |  |  |
| $\begin{gathered} 10 \text { to } \\ 17 \\ \hline \end{gathered}$ | BRANCH |  |  |  |  |  |  |  |
| $\begin{gathered} 18 \text { to } \\ 1 \mathrm{~F} \\ \hline \end{gathered}$ | CALL |  |  |  |  |  |  |  |

Note: e.g. SETR : fixed instruction

+ XDA : micro/fixed instruction other : micro instructions


### 5.2 9-Bit Instruction Map (continued)

|  | LSB |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | 8 | 9 | A | B | c | D | E | F |
| 00 | TKA | MNEA | TKM | RSTIO | SETIO | SETR | KNEZ | TSIO |
| 01 | CTMDYN | + XDA | IOIN | TTM | TNEM | TNEA | TTA | TTY |
| 02 | TRM |  |  |  |  |  |  |  |
| 03 | TAY | TMA | TMY | TYA | TAMDYN | TAMIYC | TAMZA | TAM |
| 04 | TCY |  |  |  |  |  |  |  |
| 05 | YNEC |  |  |  |  |  |  |  |
| 06 | TCMIY |  |  |  |  |  |  |  |
| 07 | ACACC |  |  |  |  |  |  |  |
| 08 | LDP |  |  |  |  |  |  |  |
| 09 | LDX |  |  |  |  |  |  |  |
| OA | TBITA |  |  |  | TIOM |  |  |  |
| OB | TAK | SDP | SCSV | RCVS | TDL | RCI | DONE | RETN |
| OC | tCA |  |  |  |  |  |  |  |
| OD | TAMACS |  |  |  |  |  |  |  |
| OE | ALEC |  |  |  |  |  |  |  |
| OF | ACYY |  |  |  |  |  |  |  |
| $\begin{gathered} 10 \text { to } \\ 17 \end{gathered}$ | BRANCH |  |  |  |  |  |  |  |
| $\begin{gathered} 18 \text { to } \\ 1 F \\ \hline \end{gathered}$ | CALL |  |  |  |  |  |  |  |

Note: e.g. SETR : fixed instruction

+ XDA: micro/fixed instruction
other : micro instructions
(48)

Revision 3.2, October 1991

## 6 Electrical Description

### 6.1 Absolute Maximum Ratings

Voltage applied at $\mathrm{V}_{\mathrm{DD}}$ to $\mathrm{V}_{\mathrm{SS}} \quad-0.3 \mathrm{~V}$ to +7.0 V
Voltage applied to any pin (referenced to $\mathrm{V}_{\mathrm{SS}}$ )
$V_{S S}-0.3 V$ to $V_{D D}+0.3 V$
Diode current at any device terminal
$+/-2 \mathrm{~mA}$
Storage Temperature
$-55^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

### 6.2 TSS400-Operating Conditions

## Parameter:

Supply Voltage, $\mathrm{V}_{\mathrm{DD}}$
Supply Voltage, $\mathrm{V}_{\mathrm{SS}}$
Operating Temperature Range I
Range A
Timer Frequency (XTAL)
*)Timer Frequency (ext)
Processor Frequency internal (f $\mathrm{f}_{\text {roc }}$ )
Characteristics: see Figure 6-1
Processor Frequency external, PFRQ Pin ( $\mathrm{f}_{\text {proc }}$ )
**) Instruction execution time
Capacitance of Display:
any Common
any Segment-25

MIN NOM MAX UNITS
2.6
0.0
3.0
5.5
0.0
+85
${ }^{\circ} \mathrm{C}$
${ }^{\circ} \mathrm{C}$
32.768 KHz

20
100
700

400
700
1000
$6 \mu \mathrm{Sec}$
8.5

1000
pF
pF
${ }^{*}$ ) Note: If LCD-display is used be sure that the frequency meets the limits of display frame rate (DFR $\left.=\frac{\text { timer frequency }}{512}\right)$
${ }^{* *}$ ) Note: Each instruction needs 6 cycles of the

$$
\text { processor frequency } f_{\text {proc }}=t_{\text {instruct }}=\frac{6}{f_{\text {proc }}}
$$

### 6.3 TSS400-Operating Characteristics

| Parameter | Conditions | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current (into $\mathrm{V}_{\mathrm{DD}}$ ) | (excluding external current) |  |  |  |  |  |  |
|  | Active Mode with AD " |  | ${ }^{\prime} \mathrm{AD}$ |  |  |  |  |
|  | $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ | 3 V |  |  | 300 | 500 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{A}=-40$ to $125^{\circ} \mathrm{C}$ | 3 V |  |  | 300 | 500 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ | 5 V |  |  | 800 | 1100 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{\mathrm{A}}=-40$ to $125^{\circ} \mathrm{C}$ | 5 V |  |  | 800 | 1400 | $\mu \mathrm{A}$ |
|  | Active Mode |  | 1 act |  |  |  |  |
|  | without AD ${ }^{7}$ $T_{A}=0 \text { to } 80^{\circ} \mathrm{C}$ | 3 V |  |  | 80 | 140 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{A}=-40$ to $125^{\circ} \mathrm{C}$ | 3 V |  |  | 80 | 140 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{A}=0$ to $80^{\circ} \mathrm{C}$ | 5 V |  |  | 400 | 500 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{\mathrm{A}}=-40$ to $125^{\circ} \mathrm{C}$ | 5 V |  |  | 520 | 650 | $\mu \mathrm{A}$ |
|  | DONE Mode |  | ${ }^{\text {Done }}$ |  |  |  |  |
|  | (Standby) ${ }^{\text {\% }}$ |  |  |  |  |  |  |
|  | $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ | 3 V |  |  | 4 | 8 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{A}=-40$ to $125^{\circ} \mathrm{C}$ | 3 V |  |  | 6 | 9 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ | 5 V |  |  | 10 | 18 | $\mu \mathrm{A}$ |
|  | $T_{A}=-40$ to $125^{\circ} \mathrm{C}$ | 5V |  |  | 12 | 20 | $\mu \mathrm{A}$ |
|  | OFF Mode (Halt) ${ }^{7}$ |  | 'OFF |  |  |  |  |
|  | $T_{A}=0 \text { to } 80^{\circ} \mathrm{C}$ | 3 V |  |  | 0.1 | 1 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{\mathrm{A}}=-40$ to $125^{\circ} \mathrm{C}$ | 3 V |  |  | 0.1 | 1 | $\mu \mathrm{A}$ |
|  | $T_{A}=0$ to $80^{\circ} \mathrm{C}$ | 5 V |  |  | 0.1 | 1 | $\mu \mathrm{A}$ |
|  | $\mathrm{T}_{\mathrm{A}}=-40$ to $125^{\circ} \mathrm{C}$ | 5V |  |  | 0.1 | 1 | A |

*) Current values are for input levels in the range of
$0 . .0 .3 \mathrm{~V}$
For $\mathrm{V}_{\mathrm{KL}}$, $\mathrm{V}_{\mathrm{IOL}}$;
$\left(V_{D D}-0.3 V\right) V_{D D}$ For $V_{K H}, V_{I O H}-$ all outputs open

### 6.3 TSS400 - Operating Characteristics (continued):

 $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.
6.3 TSS400-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| K as output |  |  |  |  |  |  |  |
| Option push-pull "1" | $\mathrm{I}_{\text {KHax }}=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{KH}}$ | $\mathrm{V}_{\mathrm{DD}}-0.2$ |  | $V_{\text {D }}$ | v |
| "1" | $1_{K H \text { max }}=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{KH}}$ | $V_{D D}{ }^{-0.6}$ |  | $v_{D D}$ | v |
| "1" | $1_{K H \text { max }}=-0.5 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{\mathrm{KH}}$ | $\mathrm{v}_{\mathrm{DD}}-0.6$ |  | $\mathrm{V}_{\mathrm{DD}}$ | v |
| "0" | ${ }^{\text {KLImax }}=+0.3 \mathrm{~mA}$ | 3 V | $\mathrm{v}_{\mathrm{KL}}$ | $\mathrm{v}_{\text {SS }}$ |  | $\mathrm{V}_{\text {SS }}+0.4$ | v |
| "0" | ${ }^{\text {KLImax }}=+0.4 \mathrm{~mA}$ | 5 V | $\mathrm{v}_{\mathrm{KL}}$ | $v_{\text {SS }}$ |  | $v_{S S}+0.4$ | v |
| Option opensource |  |  |  |  |  |  |  |
| ${ }^{17}$ | ${ }^{\prime} \mathrm{KH}_{\max }=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{KH}}$ | $\mathrm{V}_{\mathrm{DD}}-0.2$ |  | $\mathrm{V}_{\mathrm{DD}}$ | v |
| "1" | $I_{K H \max }=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{KH}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{-0.6}$ |  | $\mathrm{V}_{\mathrm{DD}}$ | v |
| "1" | ${ }^{K} H_{\text {max }}=-0.5 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{\mathrm{KH}}$ | $V_{\text {DD }}{ }^{-0.6}$ |  | $v_{D D}$ | v |
|  | $\mathrm{V}_{\mathrm{K}}=2.3 \mathrm{~V}$ | 3 V | 'KOL | -30 |  | 30 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{K}}=3.8 \mathrm{~V}$ | 5 V | 'KOL | -30 |  | 30 | $\mu \mathrm{A}$ |
| VO as output |  |  |  |  |  |  |  |
| "1" | ${ }^{1} 10 H_{\text {max }}=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{v}_{\mathrm{IOH}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{-0.2}$ |  | $\mathrm{v}_{\mathrm{DD}}$ | v |
| "1" | $\mathrm{I}_{1} \mathrm{OH} \max =-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{OOH}}$ | $\mathrm{V}_{\mathrm{DD}}-0.6$ |  | $v_{D D}$ | v |
| "1" | ${ }^{1} 10 H_{\text {max }}=-0.75 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{\mathrm{IOH}}$ | $V_{\text {DD }}{ }^{-0.6}$ |  | $V_{D D}$ | v |
| "0" | ${ }^{\prime}$ OLImax $=+0.5 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\text {IOL }}$ | $\mathrm{V}_{\text {SS }}$ |  | $\mathrm{V}_{\text {SS }}+0.4$ | v |
| "0" | $\mathrm{I}_{\text {IOLmax }}=+1.0 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{10 \mathrm{~L}}$ | $\mathrm{v}_{\text {SS }}$ |  | $v_{\text {SS }}+0.4$ | v |
| R output |  |  |  |  |  |  |  |
| "1" | $\mathrm{I}_{\text {RHmax }}=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\text {RH }}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{-0.2}$ |  | $v_{\text {D }}$ | v |
| "1" | $I_{\text {RHmax }}=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{RH}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{-0.6}$ |  | $v_{D D}$ | v |
| "1" | ${ }^{\text {RHMmax }}=-0.3 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{\mathrm{RH}}$ | $V_{D D}{ }^{-0.4}$ |  | $\mathrm{v}_{\mathrm{DD}}$ | v |
| -0" | $\mathrm{I}_{\text {RLmax }}=+0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{RL}}$ | $\mathrm{V}_{\text {SS }}$ |  | $\mathrm{v}_{\text {SS }}+0.4$ | v |
| "0" | ${ }^{\text {RLImax }}=+0.3 \mathrm{~mA}$ | 5 V | $\mathrm{v}_{\mathrm{RL}}$ | $\mathrm{v}_{\text {SS }}$ |  | $\mathrm{v}_{\text {SS }}+0.4$ | v |

6.3 TSS400-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{v}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock (Opt.: NONE, $256 \mathrm{~Hz}, 1024 \mathrm{~Hz}$ not active at OFF mode) |  |  |  |  |  |  |  |
| output "1" Output "0" | $\begin{aligned} & { }^{\mathrm{I}} \mathrm{CH}=-0.1 \mathrm{~mA} \\ & { }^{\mathrm{I}} \mathrm{CH}=-0.6 \mathrm{~mA} \\ & { }^{\mathrm{I}} \mathrm{CL}=+0.5 \mathrm{~mA} \\ & { }^{\mathrm{I}} \mathrm{CL}=+0.5 \mathrm{~mA} \end{aligned}$ | 3V <br> 5 V <br> $3 V$ <br> 5 V | $\begin{aligned} & \mathrm{v}_{\mathrm{CH}} \\ & \mathrm{v}_{\mathrm{CH}} \\ & \mathrm{v}_{\mathrm{CL}} \\ & \mathrm{v}_{\mathrm{CL}} \end{aligned}$ | $\begin{gathered} \mathrm{v}_{\mathrm{DD}}-0.2 \\ \mathrm{v}_{\mathrm{DD}}-0.6 \\ \mathrm{v}_{\mathrm{SS}} \\ \mathrm{v}_{\mathrm{ss}} \end{gathered}$ |  | $\begin{gathered} \mathrm{v}_{\mathrm{DD}} \\ \mathrm{v}_{\mathrm{DD}} \\ \mathrm{v}_{\mathrm{SS}^{+}} 0.4 \\ \mathrm{v}_{\mathrm{SS}^{+}}+0.4 \end{gathered}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
| INTTN | $\begin{aligned} & V_{I N}=O V \\ & V_{I N}=O V \\ & V_{I N}=V_{D D} \end{aligned}$ | $3 V$ <br> 5 V <br> $3.8 \mathrm{~V} / 5.5 \mathrm{~V}$ | ${ }^{\text {INIT }}$ <br> ${ }^{\prime}$ INIT <br> ${ }^{\text {INIT }}$ | $\begin{aligned} & -0.2 \\ & -0.5 \\ & -0.1 \end{aligned}$ |  | $\begin{gathered} -1.0 \\ -2.2 \\ 0.1 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| $\mathrm{SV}_{\mathrm{DD}}\left(\right.$ switched $\left.\mathrm{V}_{\mathrm{DD}}\right)$ | $\begin{aligned} & \mathrm{I}_{\mathrm{SVDD}}=2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{SVDD}}=6.5 \mathrm{~mA} \\ & \mathrm{SV}_{\mathrm{DD}} \text { off }(\mathrm{OV}) \end{aligned}$ | $\begin{gathered} 2.6 \mathrm{~V} \\ 2.6 \mathrm{~V} \\ 3.8 \mathrm{~V} / 5.5 \mathrm{~V} \end{gathered}$ | $\mathrm{V}_{\text {SVDD }}$ <br> $\mathrm{V}_{\text {SVDD }}$ <br> 'SVDD | $\begin{gathered} v_{D D}-0.2 \\ v_{D D}-0.3 \\ -0.1 \end{gathered}$ |  | $\begin{aligned} & \mathrm{v}_{\mathrm{DD}} \\ & \mathrm{v}_{\mathrm{DD}} \\ & 0.1 \end{aligned}$ | V <br> v <br> $\mu \mathrm{A}$ |
| KC | $\begin{aligned} & \mathrm{V}_{\mathrm{KC}}=\mathrm{OV} \\ & \mathrm{~V}_{\mathrm{KC}}=\mathrm{V}_{\mathrm{DD}} \end{aligned}$ | $3.8 \mathrm{~V} / 5.5 \mathrm{~V}$ <br> $3.8 \mathrm{~V} / 5.5 \mathrm{~V}$ | ${ }^{\prime} \mathrm{KC}$ <br> ${ }^{\prime} \mathrm{KC}$ | $\begin{aligned} & -0.1 \\ & -0.1 \end{aligned}$ |  | $\begin{aligned} & 0.1 \\ & 0.1 \end{aligned}$ | $\begin{aligned} & \mu A \\ & \mu A \end{aligned}$ |

6.3 TSS400-Operating Characteristics (continued): $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD lines common (1/2 duty cycle) |  |  |  |  |  |  |  |
| output "1" | $\begin{aligned} & { }^{\mathrm{C}} \mathrm{CH}=-50 \mu \mathrm{~A} \\ & { }^{\mathrm{CH}} \mathrm{CH}=-100 \mu \mathrm{~A} \end{aligned}$ | 3 V 5 V | $\begin{aligned} & \mathrm{v}_{\mathrm{CH}} \\ & \mathrm{v}_{\mathrm{CH}} \end{aligned}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{DD}}-0.4 \\ & \mathrm{v}_{\mathrm{DD}}-0.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{v}_{\mathrm{DD}} \\ & \mathrm{v}_{\mathrm{DD}} \end{aligned}$ | v |
| "1/2 Hz" | ${ }^{\prime} \mathrm{CHz}=+/ 10 \mathrm{nA}$ | 3 V | $\mathrm{v}_{\mathrm{Hz}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{12-.06}$ | $\mathrm{V}_{\mathrm{DD}} / 2$ | $\mathrm{V}_{\mathrm{DD}} / 2+.06$ | $v$ |
|  | ${ }^{1} \mathrm{CHz}=+/ 10 \mathrm{nA}$ | 5 V | $\mathrm{v}_{\mathrm{Hz}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\text {/2-.06 }}$ | $\mathrm{v}_{\mathrm{DD}} / 2$ | $\mathrm{V}_{\mathrm{DD}}{ }^{12+.06}$ | v |
| " $1 / 2 \mathrm{~Hz}{ }^{\text {" }}$ | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | -1.5 |  | -4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 3 V | ${ }^{\prime} \mathrm{CHz}$ | 1.5 |  | 4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | -2.5 |  | -6.8 | $\mu \mathrm{A}$ |
|  | $\mathrm{v}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 5 V | ${ }^{\text {I CHz }}$ | 2.5 |  | 6.8 | $\mu \mathrm{A}$ |
| output "0" | ${ }^{\prime} \mathrm{CL}=+50 \mu \mathrm{~A}$ | 3 V | $\mathrm{v}_{\mathrm{CL}}$ | $v_{\text {ss }}$ |  | $\mathrm{v}_{\text {SS }}+0.4$ | v |
|  | ${ }^{\prime} \mathrm{CL}=+100 \mu \mathrm{~A}$ | 5 V | $\mathrm{v}_{\mathrm{CL}}$ | $v_{S S}$ |  | $\mathrm{v}_{\text {SS }}+0.4$ | v |
| LCD lines segment (1/2 duty cycle) |  |  |  |  |  |  |  |
| output "1" | ${ }^{\mathrm{CH}}=5=50 \mu \mathrm{~A}$ | 3 V | $\mathrm{v}_{\text {SH }}$ | $\mathrm{V}_{\mathrm{DD}}-0.4$ |  | $\mathrm{v}_{\mathrm{DD}}$ | v |
| output "1" | ${ }^{1} \mathrm{CH}=-100 \mu \mathrm{~A}$ | 5 V | $\mathrm{v}_{\text {SH }}$ | $v_{\text {DD }}-0.4$ |  | $v_{D D}$ | v |
| output "0" | ${ }^{1} \mathrm{CL}=+50 \mu \mathrm{~A}$ | 3 V | $v_{\text {SL }}$ | $v_{\text {SS }}$ |  | $\mathrm{v}_{\text {SS }}+0.4$ | $v$ |
| output "0" | ${ }^{\prime} \mathrm{CL}=+100 \mu \mathrm{~A}$ | 5 V | $\mathrm{v}_{\mathrm{SL}}$ | $\mathrm{v}_{\mathrm{SS}}$ |  | $\mathrm{V}_{\text {SS }}+0.4$ | v |

### 6.3 TSS400-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD lines common,segment ( $1 / 4$ duty cycle) |  |  |  |  |  |  |  |
| output "1" | $\begin{aligned} & { }^{\mathrm{I}} \mathrm{CH}^{\prime}=-50 \mu \mathrm{~A} \\ & { }^{\mathrm{I}} \mathrm{CH}^{m=}-100 \mu \mathrm{~A} \end{aligned}$ | $3 V$ <br> 5 V | $\begin{aligned} & v_{\mathrm{CH}} \\ & \mathrm{v}_{\mathrm{CH}} \end{aligned}$ | $\begin{aligned} & v_{D D^{-0}}-0.4 \\ & v_{D D^{-0.4}} \end{aligned}$ |  | $\begin{aligned} & \mathrm{v}_{\mathrm{DD}} \\ & \mathrm{v}_{\mathrm{DD}} \end{aligned}$ | V |
| output $\text { " } 2 / 3 \text { Hz" }$ | ${ }^{1} \mathrm{C} \cdot \mathrm{Hz}=+1-10 \mathrm{nA}$ | 3 V | $\mathrm{V}_{\mathrm{Hz}}$ | $2 \cdot \mathrm{~V}_{\mathrm{DD}} / 3-0.04$ | $2 \cdot \mathrm{~V}_{\mathrm{DD}} / 3$ | $2 \cdot \mathrm{~V}_{\mathrm{DD}} / 3+0.04$ | V |
|  | ${ }^{1} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 5V | $\mathrm{V}_{\mathrm{Hz}}$ | $2 \cdot V_{D D} / 3-0.04$ | $2 \cdot \mathrm{VDD}^{\prime 3}$ | $2 \cdot \mathrm{~V}_{\mathrm{DD}} / 3+0.04$ | v |
| "2/3 Hz" | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | -1.5 |  | -4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | 0.75 |  | 2 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | -2.5 |  | -6.8 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | 1.25 |  | 3.4 | $\mu \mathrm{A}$ |
| output $\text { " } 1 / 3 \mathrm{~Hz}{ }^{\prime \prime}$ | ${ }^{1} \mathrm{CHz}=+/-10 \mathrm{nA}$ | 3 V | $\mathrm{V}_{\mathrm{Hz}}$ | $\mathrm{V}_{\mathrm{DD}} / 3-0.04$ | $\mathrm{v}_{\mathrm{DD}}{ }^{\text {/3}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\prime 3+} 0.04$ | V |
|  | ${ }^{1} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 5 V | $\mathrm{V}_{\mathrm{Hz}}$ | $V_{D D}{ }^{\prime 3-0.04}$ | $\mathrm{v}_{\mathrm{DD}}{ }^{\text {/3}}$ | $\mathrm{v}_{\mathrm{DD}} / 3+0.04$ | V |
| " $1 / 3 \mathrm{~Hz}$ " | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | -0.75 |  | -2 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | 1.5 |  | 4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | -1.25 |  | -3.4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | 2.5 |  | 6.8 | $\mu \mathrm{A}$ |
| output "0" | $\begin{aligned} & { }^{\mathrm{I}} \mathrm{CL}=+50 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{CL}}=+100 \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 3 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & v_{C L} \\ & v_{C L} \end{aligned}$ | $\begin{aligned} & v_{S S} \\ & v_{S S} \end{aligned}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.4 \\ & \mathrm{v}_{\mathrm{SS}}+0.4 \end{aligned}$ | V v |

6.3 TSS400-Operating Characteristics (continued): $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline Parameter \& Condition \& \(\mathrm{V}_{\mathrm{DD}}\) \& Symbol \& Min \& Nom \& Max \& Unit \\
\hline AD Converter current source \(V_{\text {Rext }}=\) \(\mathbf{V}_{\text {SVDD }}-\mathbf{V}_{\text {RI }}\) \& \begin{tabular}{l}
operating \\
range of \\
\(V_{D D}\) is \\
limited to \\
\(3.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DD}}\) \\
\(\leq 5.5 \mathrm{~V}\)
\end{tabular} \& \& \& \& \& \& \\
\hline Range large* \& \[
\begin{aligned}
\& \mathrm{I}_{\mathrm{RI}=1.3 \mathrm{~mA} ;}=25^{\circ} \mathrm{C} \\
\& \mathrm{I}_{\mathrm{Al}}=1.3 \mathrm{~mA} ; \\
\& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}
\end{aligned}
\] \& 3.5 V

5 V \& | $V_{\text {Rext }}$ |
| :--- |
| $V_{\text {Rext }}$ | \& \[

$$
\begin{aligned}
& 0.240737 \cdot S V_{D D} \\
& 0.241959 \cdot S V_{D D}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0.244403 \cdot S V_{D D} \\
& 0.244403 \cdot S V_{D D}
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0.248069 \cdot S V_{D D} \\
& 0.246847 \cdot S V_{D D}
\end{aligned}
$$
\] \& V

v <br>

\hline | external |
| :--- |
| Resistor | \& $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ \& 3.5 V \& $\mathrm{R}_{\text {ext }}$ \& 0.10 \& \& 1.6 \& kOhm <br>

\hline $$
\begin{aligned}
& \mathrm{A} 1, \mathrm{~A} 2, \mathrm{~A} 3, \\
& \mathrm{~A} 4
\end{aligned}
$$ \& $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ \& 5 V \& $\mathrm{R}_{\text {ext }}$ \& 0.10 \& \& 1.6 \& kOhm <br>

\hline Temperature stability \& $$
\begin{aligned}
& \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\
& =1.3 \mathrm{~mA}, \\
& \mathrm{AV} \\
& \mathrm{AV}_{\mathrm{HL}}
\end{aligned}
$$ \& \[

$$
\begin{aligned}
& 3.5 \mathrm{~V} \\
& 3.5 \mathrm{~V}
\end{aligned}
$$

\] \& dN/dT dN/dT \& \& \[

$$
\begin{aligned}
& 0.03 \\
& 0.06
\end{aligned}
$$

\] \& \& \[

$$
\begin{aligned}
& \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\
& \mathrm{LSB} /{ }^{\circ} \mathrm{C}
\end{aligned}
$$
\] <br>

\hline Temperature stability \& $$
\begin{aligned}
& \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\
& =1.3 \mathrm{~mA}, \\
& \mathrm{AV} \\
& \mathrm{ALL} \\
& \mathrm{AV}_{\mathrm{HL}}
\end{aligned}
$$ \& \[

$$
\begin{aligned}
& 5 \mathrm{~V} \\
& 5 \mathrm{~V}
\end{aligned}
$$

\] \& $\mathrm{dN} / \mathrm{dT}$ dN/dT \& \& \[

$$
\begin{aligned}
& 0.03 \\
& 0.06
\end{aligned}
$$

\] \& \& \[

$$
\begin{aligned}
& \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\
& \mathrm{LSB} /{ }^{\circ} \mathrm{C}
\end{aligned}
$$
\] <br>

\hline
\end{tabular}

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V
6.3 TSS400-Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline Parameter \& Condition \& \(\mathrm{V}_{\mathrm{DD}}\) \& Symbol \& Min \& Nom \& Max \& Unit \\
\hline \multirow[t]{2}{*}{\begin{tabular}{l}
\(S V_{\text {DD }}\) \\
rejection ratio
\end{tabular}} \& \[
\begin{aligned}
\& T_{A}=25^{\circ} \mathrm{C}, \\
\& A V_{\mathrm{LL}}
\end{aligned}
\] \& 3.5 V \& \[
\begin{aligned}
\& \mathrm{dN} / \\
\& \mathrm{dSV} \\
\& \mathrm{DD}
\end{aligned}
\] \& -3 \& - 1.5 \& 1 \& LSBN \\
\hline \& \(\mathrm{AV}_{\mathrm{HL}}\) \& 3.5 V \& \[
\begin{aligned}
\& \mathrm{dN} / \\
\& \mathrm{dSV} \\
\& \mathrm{DD}
\end{aligned}
\] \& -6 \& -3 \& 2 \& LSBN \\
\hline \multirow[t]{2}{*}{\begin{tabular}{l}
\(S V_{\text {DD }}\) \\
rejection ratio
\end{tabular}} \& \[
\begin{aligned}
\& T_{A}=25^{\circ} \mathrm{C}, \\
\& A V_{L L}
\end{aligned}
\] \& 5 V \& \[
\begin{aligned}
\& \mathrm{dN} \\
\& \mathrm{dSV} \\
\& \mathrm{DD}
\end{aligned}
\] \& -3 \& -1.5 \& 1 \& LSBN \\
\hline \& \& 5 V \& \[
\begin{aligned}
\& \mathrm{dN} \\
\& \mathrm{dSV} \\
\& \mathrm{DD}
\end{aligned}
\] \& -6 \& -3 \& 2 \& LSBN \\
\hline Dritt \& \[
\begin{aligned}
\& V_{\text {Rext }} / R_{\text {ext }} \\
\& =1.3 \mathrm{~mA} \\
\& V_{\text {Rext } / R_{\text {ext }}}=1.3 \mathrm{~mA}
\end{aligned}
\] \& 3.5 V

5 V \& $\mathrm{dV}_{\text {Rext }}$ / month $\mathrm{dV}_{\text {Rext }}{ }^{\prime}$ month \& \& \& \& <br>
\hline
\end{tabular}

### 6.3 TSS400-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{v}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| verter (Range large)* |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{\mathbb{N}}=V_{S S} \\ & \text { to } V_{D D} ; \\ & \text { DL13 }=0 \end{aligned}$ |  | ${ }^{\text {A1/2/3/4 }}$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage | NLL $=046{ }_{16}$ | 3.5 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.106017 \cdot \mathrm{SV}_{\text {DD }}$ | 0.107939 SV $_{\text {DD }}$ | $0.109861 \cdot$ SV ${ }_{\text {DD }}$ | v |
|  | $N L L=02 B_{16}$ | 5V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.103423 \cdot \mathrm{SV}_{\text {DD }}$ | 0.105345.SV ${ }_{\text {DD }}$ | $0.107267 \cdot \mathrm{~V}_{\text {DD }}$ | V |
| Analog input voltage higher limit | $\begin{aligned} & \mathrm{NHL}= \\ & \mathrm{FB9}_{16} \end{aligned}$ | 3.5 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.486055 \cdot \mathrm{SV}_{\text {DD }}$ | $0.487977 \cdot S V_{\text {DD }}$ | 0.489899•SVDD | V |
|  | $\begin{aligned} & \mathrm{NHL}= \\ & \mathrm{FD}_{16} \end{aligned}$ | 5V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.488649 \cdot \mathrm{SV}$ DD | $0.490571 \cdot$ SV ${ }_{\text {DD }}$ | $0.492493 \cdot \mathrm{SV}_{\text {DD }}$ | v |
| Range analog input volt. (see Note) | $\begin{aligned} & \text { digital value } \\ & \left(\text { FB9 }_{16}{ }^{-}\right. \\ & \left.046_{16}\right) \end{aligned}$ | 3.5V | $\begin{aligned} & \mathrm{R}_{\mathrm{AV}} \\ & \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ & \left.\mathrm{AV}_{\mathrm{LL}}\right) \end{aligned}$ | $0.378596 \cdot S V_{\text {DD }}$ | $0.380037 \cdot$ SV ${ }_{\text {DD }}$ | $0.381478 \cdot \mathrm{SV}_{\text {DD }}$ | V |
|  | digital value $\begin{aligned} & \text { (FD4 }_{16} \\ & \left.02 B_{16}\right) \end{aligned}$ | 5V | $\begin{aligned} & \mathrm{R}_{\mathrm{AV}} \\ & \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ & \left.\mathrm{AV}_{\mathrm{LL}^{-}}\right) \end{aligned}$ | $0.383784 \cdot \mathrm{SV}_{\text {DD }}$ | $0.385226 \cdot$ SV ${ }_{\text {DD }}$ | $0.386667 \cdot$ SV ${ }_{\text {DD }}$ | v |

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.
6.3 TSS400-Operating Characteristics (continued): $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 3.5 V |  |  | $96.1 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  | V |
|  |  | 5 V |  |  | $96.1 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  | V |
| Linearity | Delta digital value $\leq 120$ LSB | 3.5 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 3.5 V |  | -11/2 |  | +1 $1 / 2$ | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 3.5 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 3.5 V |  | -41/2 |  | +4 1/2 | LSB |
|  | Delta digital value $\leq 120$ LSB | 5 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 5 V |  | -11/2 |  | +1 $1 / 2$ | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 5 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 5 V |  | -41/2 |  | +4 1/2 | LSB |

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.

### 6.3 TSS400-Operating Characteristics (continued):

 $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source $V_{\text {Rext }}$ $=V_{\text {SVDD }}{ }^{-}$ $V_{\text {RI }}$ |  |  |  |  |  |  |  |
| Range small | $\begin{aligned} \mathrm{I}_{\mathrm{RI}} & =1.3 \mathrm{~mA} \\ T_{A} & =25^{\circ} \mathrm{C} \\ \mathrm{I}_{\mathrm{RI}} & =1.3 \mathrm{~mA} \\ T_{A} & =25^{\circ} \mathrm{C} \end{aligned}$ | 3 V 5 V | $V_{\text {Rext }}$ <br> $V_{\text {Rext }}$ | $\begin{aligned} & 0.236635 \cdot \mathrm{SV}_{\mathrm{DD}} \\ & 0.237836 \cdot \mathrm{SV}_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 0.240238 \cdot \mathrm{SV}_{\mathrm{DD}} \\ & 0.240238 \cdot \mathrm{SV}_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 0.243842 \cdot S V_{D D} \\ & 0.242641 \cdot S V_{D D} \end{aligned}$ | V v |
| external Resistor | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 3 V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| $\begin{aligned} & \mathrm{A} 1, \mathrm{~A} 2, \mathrm{~A} 3, \\ & \mathrm{~A} 4 \end{aligned}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 5 V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & \mathrm{AV} \\ & \mathrm{AL} \\ & \mathrm{AV}_{\mathrm{HL}} \end{aligned}$ | $\begin{aligned} & 3 \mathrm{~V} \\ & 3 \mathrm{~V} \end{aligned}$ | $\mathrm{dN} / \mathrm{dT}$ dN/dT |  | $\begin{aligned} & 0.07 \\ & 0.14 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |
| Temperature stability | $\begin{aligned} & \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & \mathrm{AV} \\ & \mathrm{AL} \\ & \mathrm{AV}_{\mathrm{HL}} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | dN/dT dN/dT |  | $\begin{aligned} & 0.07 \\ & 0.14 \end{aligned}$ |  | $\begin{aligned} & \text { LSB } /{ }^{\circ} \mathrm{C} \\ & \text { LSB } /{ }^{\circ} \mathrm{C} \end{aligned}$ |

6.3 TSS400-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \\ & A V_{\mathrm{LL}} \end{aligned}$ | 3 V | $\begin{aligned} & d N \\ & d S V_{D D} \end{aligned}$ | -7 | -3.5 | 2.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 3 V | $\begin{aligned} & d N \\ & d S V_{D D} \end{aligned}$ | - 14 | -7 | 5 | LSBN |
| $\mathrm{SV}_{\mathrm{DD}}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 5 V | $\begin{aligned} & d N \\ & d S V_{D D} \end{aligned}$ | -7 | -3.5 | 2.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 5 V | $\mathrm{dN} /$ $d S V_{D D}$ | - 14 | -7 | 5 | LSBN |
| Dritt | $\begin{aligned} & V_{\text {Rexi }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \\ & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 3 V 5 V | dVR $_{\text {ext }}{ }^{\prime}$ month $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month |  |  |  |  |

### 6.3 TSS400-Operating Characteristics (continued):

 $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| verter <br> (Range small) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{I N}=V_{S S} \\ & \text { to } V_{D D} ; \\ & D L 13=0 \end{aligned}$ |  | ${ }^{\text {A } 1 / 2 / 3 / 4}$ |  |  | +/-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage lower limit | $N_{L L}=09 C_{16}$ | 3 V | $\mathrm{AV}_{\mathrm{LL}}$ | ${ }^{0.236265 \cdot S V}{ }_{\text {DD }}$ | $0.237986 \cdot \mathrm{SV}_{\text {DD }}$ | $0^{0.239708} \cdot \mathrm{SV}_{\text {DD }}$ | V |
|  | $\mathrm{N}_{\mathrm{LL}}=05 \mathrm{E}_{16}$ | 5V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.233596 \cdot \mathrm{SV}{ }^{\text {DD }}$ | $0^{0.235317} \cdot \mathrm{SV}_{\text {DD }}$ | ${ }^{0.237039} \cdot \mathrm{SV}_{\text {DD }}$ | v |
| Analog input voltage higher limit | $\mathrm{N}_{\mathrm{HL}}=\mathrm{F}^{6} 3_{16}$ | 3 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.399117 \cdot \mathrm{SV}$ DD | $0.400839 \cdot \mathrm{SV} \mathrm{DD}$ | $0^{0.402560 \cdot S V}$ DD | V |
|  | $\mathrm{N}_{\mathrm{HL}}=\mathrm{FA}_{1}{ }_{16}$ | 5V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.401786 \cdot \mathrm{SV}$ DD | $0.403508 \cdot S V_{\text {DD }}$ | $0^{0.405230} \cdot \mathrm{SV} \mathrm{DD}^{\text {d }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \mathrm{FF63}_{16} \\ & \left.\mathrm{ogC}_{16}\right)^{-} \end{aligned}$ | 3 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ (\mathrm{AV} \\ \mathrm{HL}- \\ \left.\mathrm{AV} V_{\mathrm{LL}}\right) \end{gathered}$ | $0.161990 \cdot S V_{\text {DD }}$ | $0.162851 \cdot S V_{\text {DD }}$ | $0.163712 \cdot S V_{\text {DD }}$ | V |
|  | digital value $\begin{aligned} & \left(\mathrm{FA1}_{16}-\right. \\ & \left.05 \mathrm{E}_{16}\right) \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \left.\mathrm{AV}_{\mathrm{LL}^{\prime}}\right) \end{gathered}$ | $0.167328 \cdot \mathrm{SV}_{\text {DD }}$ | $0.168189 \cdot$ SV ${ }_{\text {DD }}$ | $0.169050 \cdot S V_{\text {DD }}$ | v |

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.
6.3 TSS400-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 3 V |  |  | 43.0.10-6.SV SD |  | v |
|  |  | 5 V |  |  | $43.0 \cdot 10-6 \cdot \mathrm{SV}_{\text {DD }}$ |  | V |
| Linearity | Delta digital value $\leq 120$ LSB | 3 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 3 V |  | -11/2 |  | +1 $1 / 2$ | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 3 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 3 V |  | -41/2 |  | +4 1/2 | LSB |
|  | Delta digital value $\leq 120$ LSB | 5 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 5 V |  | -1 1/2 |  | +11/2 | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 5 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV $>2600$ | 5 V |  | -4 1/2 |  | +4 1/2 | LSB |

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.

### 6.3 TSS400-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathbf{V}_{\text {Rext }=} \\ & \mathrm{V}_{\mathrm{SVDD}}-\mathrm{V}_{\mathrm{RI}} \end{aligned}$ | operating range of $\mathrm{V}_{\mathrm{DD}}$ is limited to $\begin{aligned} & 3.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DD}} \\ & \leq 5.5 \mathrm{~V} \end{aligned}$ |  |  |  |  |  |  |
| Range medium-high* | $\begin{aligned} & \mathrm{I}_{\mathrm{RI}}=1.3 \mathrm{~mA} ; \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ | 3.5V | $\mathbf{V}_{\text {Rext }}$ | $0.237979 \cdot S V_{\text {DD }}$ | ${ }^{0.241603} \cdot S^{\text {DD }}$ | $0.245227 \cdot S V_{\text {DD }}$ | v |
|  | $\begin{aligned} & \mathrm{I}_{\mathrm{RI}}=1.3 \mathrm{~mA} ; \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ | 5 V | $V_{\text {Rext }}$ | $0.239187 \cdot \mathrm{SV}$ DD | $0.241603 \cdot \mathrm{SV}_{\text {DD }}$ | 0.244019•SV ${ }_{\text {DD }}$ | V |
| external Resistor | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 3.5 V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| $\begin{aligned} & \mathrm{A} 1, \mathrm{~A} 2, \mathrm{~A} 3, \\ & \mathrm{~A} 4 \end{aligned}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 5 V | $R_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & A V_{\mathrm{LL}} \\ & A V_{\mathrm{HL}} \end{aligned}$ | 3.5 V 3.5 V | $\mathrm{d} N / \mathrm{dT}$ dN/dT |  | $\begin{aligned} & 0.04 \\ & 0.08 \end{aligned}$ |  | $\begin{aligned} & \text { LSB } /{ }^{\circ} \mathrm{C} \\ & \text { LSB } /{ }^{\circ} \mathrm{C} \end{aligned}$ |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \\ & m A, A V_{L L} \\ & \mathrm{AV}_{\mathrm{HL}} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | $\mathrm{dN} / \mathrm{dT}$ dN/dT |  | $\begin{aligned} & 0.04 \\ & 0.08 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V


### 6.3 TSS400 - Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 3.5 V | $\stackrel{\mathrm{dN}}{\mathrm{dSV}}$ | -4.5 | -2 | 1.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 3.5 V | $\begin{gathered} \mathrm{dN} \\ \mathrm{dSV} \\ \mathrm{DD} \end{gathered}$ | -9 | -4.5 | 3 | LSBN |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{dN} \\ \mathrm{dSV}_{\mathrm{DD}} \end{gathered}$ | -4.5 | -2 | 1.5 | LSB/ |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 5 V | $\begin{gathered} \mathrm{dN} \\ \mathrm{dSV} \\ \mathrm{DD} \end{gathered}$ | -9 | -4.5 | 3 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 3.5 V | $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month |  |  |  |  |
|  | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 5V | $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month |  |  |  |  |

6.3 TSS400-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $V_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Con- <br> verter <br> (Range mediumhigh)* |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{I N}=V_{S S} \\ & \text { to } V_{D D} ; \\ & D L 13=0 \end{aligned}$ |  | ${ }^{\text {A } 1 / 2 / 3 / 4}$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage | $N_{L L}=067_{16}$ | 3.5 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.237393 \cdot \mathrm{SV}_{\text {DD }}$ | $0.239355 . S V_{\text {DD }}$ | $0.241317 \cdot$ SV ${ }_{\text {DD }}$ | V |
| lower limit | $N_{L L}=03 E_{16}$ | 5V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.234711 \cdot \mathrm{SV}_{\text {DD }}$ | $0^{0.236673 \cdot S V}$ DD | $0.238635 \cdot \mathrm{SV}$ DD | v |
| Analog input voltage | $\begin{aligned} & \mathrm{N}_{\mathrm{HL}}= \\ & \mathrm{F98}{ }_{16} \end{aligned}$ | 3.5 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.491765 \cdot \mathrm{SV}_{\text {DD }}$ | $0.493731 \cdot \mathrm{SV}_{\text {DD }}$ | $0.495694 \cdot$ SV ${ }_{\text {DD }}$ | V |
| higher limit | $\mathrm{N}_{\mathrm{HL}}=\mathrm{FCl}_{16}$ | 5V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.494451 \cdot \mathrm{SV}_{\text {DD }}$ | $0.496413 \cdot \mathrm{~V}_{\text {DD }}$ | $0.498375 \cdot \mathrm{SV}_{\text {D }}$ | V |
| Range analog input volt. (see note) | digital value $\begin{aligned} & \left(\mathrm{FP8}_{16}-\right. \\ & \left.{ }^{-6}{ }_{16}\right) \end{aligned}$ | 3.5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \left.\mathrm{AV}_{\mathrm{LL}}\right) \end{gathered}$ | $0.253405 \cdot \mathrm{SV}_{\text {DD }}$ | $0.254386 \cdot \mathrm{SV}_{\text {DD }}$ | $0.255367 \cdot S V_{\text {DD }}$ | V |
|  | digital value $\begin{aligned} & \left(\mathrm{FCl}_{16}{ }^{-}\right. \\ & \left.03 \mathrm{E}_{16}\right) \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \left.\mathrm{AV} \mathrm{LL}^{-}\right) \end{gathered}$ | $0.258768 \cdot$ SV ${ }_{\text {DD }}$ | $0.259750 \cdot$ SV ${ }_{\text {DD }}$ | $0.260731 \cdot$ SV ${ }_{\text {DD }}$ | V |

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.
6.3 TSS400 - Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 3.5 V |  |  | $65.4 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  |  |
|  |  | 5 V |  |  | $65.4 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  |  |
| Linearity | Delta digital value $\leq 120$ LSB | 3.5 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 3.5 V |  | -1 1/2 |  | +1 1/2 | LSB |
|  | 240 LSB < DDV 2600 LSB | 3.5 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 3.5 V |  | -41/2 |  | +4 1/2 | LSB |
|  | Delta digital value $\leq 120$ LSB | 5 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 5 V |  | -1 1/2 |  | +1 $1 / 2$ | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 5 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 5 V |  | -41/2 |  | +4 1/2 | LSB |

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.

### 6.3 TSS400 - Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source $V_{\text {Rext }}=$ $\mathrm{V}_{\text {SVDD }}-\mathrm{V}_{\mathrm{RI}}$ |  |  |  |  |  | . |  |
| Range medium-low | $\begin{aligned} \mathrm{I}_{\mathrm{RI}} & =1.3 \mathrm{~mA} \\ \mathrm{~T}_{\mathrm{A}} & =25^{\circ} \mathrm{C} \\ \mathrm{~K}_{\mathrm{RI}} & =1.3 \mathrm{~mA} \\ \mathrm{~T}_{\mathrm{A}} & =25^{\circ} \mathrm{C} \end{aligned}$ | $3 V$ 5 V | $V_{\text {Rext }}$ <br> $V_{\text {Rext }}$ | $\begin{aligned} & 0.238629 \cdot S V_{D D} \\ & 0.239841 \cdot S V_{D D} \end{aligned}$ | $\begin{aligned} & 0.242263 \cdot S V_{D D} \\ & 0.242263 \cdot S V_{D D} \end{aligned}$ | $0.245897 \cdot S V_{\text {DD }}$ $0.244686 \cdot S V_{\text {DD }}$ | V v |
| external Resistor | $\mathrm{T}_{\text {A }}=25^{\circ} \mathrm{C}$ | 3 V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| $\begin{aligned} & \mathrm{A} 1, \mathrm{~A} 2, \mathrm{~A} 3, \\ & \mathrm{~A} 4 \end{aligned}$ | $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ | 5V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & \mathrm{AV}_{\mathrm{LL}} \\ & \mathrm{AV}_{\mathrm{HL}} \end{aligned}$ | $\begin{aligned} & 3 \mathrm{~V} \\ & 3 \mathrm{~V} \end{aligned}$ | dN/dT dN/dT |  | $\begin{aligned} & 0.04 \\ & 0.08 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & A V_{\mathrm{LL}} \\ & A V_{\mathrm{HL}} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | dN/dT <br> dN/dT |  | $\begin{aligned} & 0.04 \\ & 0.08 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |

### 6.3 TSS400-Operating Characteristics (continued): <br> $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 3 V | $\begin{gathered} \mathrm{dN} / \\ \mathrm{dSV}_{\mathrm{DD}} \end{gathered}$ | -4 | -2 | 1.5 | LSB/V |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 3 V | $\begin{gathered} \mathrm{dN} \\ \mathrm{dSV} \\ \mathrm{DD} \end{gathered}$ | -8 | -4 | 2.5 | LSBN |
| $S V_{D D}$ rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{dN} / \\ \mathrm{dSV}_{\mathrm{DD}} \end{gathered}$ | -4 | -2 | 1.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 5 V | $\begin{gathered} \mathrm{dN} / \\ \mathrm{dSV} \\ \mathrm{DD} \end{gathered}$ | -8 | -4 | 2.5 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \\ & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 3 V 5 V | $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month dVR ext $^{\prime}$ month |  |  |  |  |

### 6.3 TSS400-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Con- <br> verter (Range medium-low) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{I N}=V_{S S} \\ & \text { to } V_{D D} ; \\ & D L 13=0 \end{aligned}$ |  | ${ }^{1} \mathbf{A} 1 / 2 / 3 / 4$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage | $N_{L L}=05 B_{16}$ | 3 V | $\mathrm{AV}_{\mathrm{LL}}$ | 0.104798.SV ${ }_{\text {DD }}$ | 0.107013 ${ }^{\text {S }}$ DD | $0.109227 \cdot S V_{\mathrm{DD}}$ | V |
| Lower limit | $N_{\text {LL }}=036_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{LL}}$ | 0.102066•SVDD | $0.104281 \cdot$ SV ${ }_{\text {DD }}$ | $0.106495 \cdot S V_{\text {DD }}$ | V |
| Analog input voltage | $\mathrm{N}_{\mathrm{HL}}=\mathrm{FA4}_{16}$ | 3 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.393642 \cdot \mathrm{SV}$ DD | $0.395857 \cdot \mathrm{SV}$ DD | 0.398072.SV ${ }_{\text {DD }}$ | V |
| Higher limit | $\mathrm{NHL}=\mathrm{FC7}_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.396227 \cdot$ SV ${ }_{\text {DD }}$ | $0.398441 \cdot$ SV ${ }_{\text {DD }}$ | $0.400656 \cdot \mathrm{SV} \mathrm{V}_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \text { FA4 }_{16} \\ & 05 B_{16} \text { ) } \end{aligned}$ | 3V | $\begin{aligned} & \mathrm{R}_{\mathrm{AV}} \\ & \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ & \left.\mathrm{AV}_{\mathrm{LL}}\right) \end{aligned}$ | $0.287739 \cdot S V_{\text {DD }}$ | $0.288846 \cdot \mathrm{SV}$ DD | $0^{0.289953} \cdot \mathrm{SV}_{\text {DD }}$ | V |
|  | digital value $\begin{aligned} & \mathrm{FCC}_{16} \\ & \left.03{ }_{16}\right) \end{aligned}$ | 5 V | $\begin{gathered} \mathbf{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}{ }^{-}\right. \\ \left.\mathrm{AV} \mathrm{LL}^{\prime}\right) \end{gathered}$ | $0.293053 \cdot \mathrm{SV}$ DD | $0.294161 \cdot \mathrm{SV}_{\mathrm{DD}}$ | $0.295268 \cdot S V_{\text {DD }}$ | V |

### 6.3 TSS400 - Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.


### 6.4 TSS403 - Operating Conditions

| Parameter: | MIN | NOM | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage, V $\mathrm{V}_{\text {D }}$ | 2.6 | 3.0 | 3.8 | V |
| Supply Voltage, $\mathrm{V}_{\text {SS }}$ | 0.0 | 0.0 | 0.0 | V |
| Operating Temperature |  |  |  |  |
| Range I | -25 | 27 | +85 | ${ }^{\circ} \mathrm{C}$ |
| Range A | -40 | 27 | +125 | ${ }^{\circ} \mathrm{C}$ |
| Timer Frequency (XTAL) *)Timer Frequency (ext) | 20 | 32.768 | 100 | $\begin{aligned} & \mathrm{KHz} \\ & \mathrm{KHz} \end{aligned}$ |
| Processor Frequency internal ( $\mathrm{f}_{\text {proc }}$ ) Characteristics : see Figure 6-1 |  | 700 |  |  |
| Processor Frequency external, |  |  |  |  |
| PFRQ Pin (f proc) | 400 | 700 | 1000 | KHz |
| ${ }^{* *}$ )Instruction execution time | 15 | 8.5 | 6 | $\mu \mathrm{Sec}$ |
| Capacitance of Display: any Common |  |  | 1000 | pF |
| any Segment |  |  | 200 | pF |

${ }^{*}$ ) Note: If LCD-display is used be sure that the frequency meets

$$
\text { the limits of display frame rate }\left(D F R=\frac{\text { timer frequency }}{512}\right)
$$

$\left.{ }^{* *}\right)$ Note: Each instruction needs 6 cycles of the

$$
\text { processor frequency } f_{\text {proc }}=\text { tinstruct }=\frac{6}{f_{\text {proc }}}
$$

### 6.5 TSS403 - Operating Characteristics

| Parameter | Conditions | $\mathrm{v}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current (into $V_{D D}$ ) | (excluding external current) |  | ${ }^{\prime} /{ }^{\text {d }}$ |  |  |  |  |
|  | Active Mode with AD ${ }^{*}$ ) |  |  |  |  |  |  |
|  | $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ | 3 V |  |  | 300 | 500 | $\mu \mathrm{A}$ |
|  | $T_{A}=-40$ to $125^{\circ} \mathrm{C}$ | 3 V |  |  | 300 | 500 | $\mu \mathrm{A}$ |
|  | Active Mode without AD *) |  | $\mathrm{l}_{\text {act }}$ |  |  |  |  |
|  | $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ | 3 V |  |  | 80 | 140 | $\mu \mathrm{A}$ |
|  | $T_{A}=-40$ to $125^{\circ} \mathrm{C}$ | 3 V |  |  | 80 | 140 | $\mu \mathrm{A}$ |
|  | DONE Mode <br> (Standby) ${ }^{7}$ |  | ${ }^{\text {Done }}$ |  |  |  |  |
|  | $T_{A}=0 \text { to } 80^{\circ} \mathrm{C}$ | 3 V |  |  | 4 | 8 | $\mu \mathrm{A}$ |
|  | $T_{A}=-40 \text { to } 125^{\circ} \mathrm{C}$ | 3 V |  |  | 6 | 9 | $\mu \mathrm{A}$ |
|  | OFF Mode (Halt) \% |  | 'OFF |  |  |  |  |
|  | $T^{\prime}=0$ to $80^{\circ} \mathrm{C}$ | 3 V |  |  | 0.1 | 1 | $\mu \mathrm{A}$ |
|  | $T_{A}=-40 \text { to } 125^{\circ} \mathrm{C}$ | 3 V |  |  | 0.1 | 1 | $\mu \mathrm{A}$ |

*) Current values are for input levels in the range of
0 ... 0.3 V
For $\mathrm{V}_{\mathrm{KL}}$, $\mathrm{V}_{\mathrm{IOL}}$;
( $\mathrm{V}_{\mathrm{DD}}-0.3 \mathrm{~V}$ ) $\mathrm{V}_{\mathrm{DD}}$ For $\mathrm{V}_{\mathrm{KH}}, \mathrm{V}_{I O H}-$ All outputs open

### 6.5 TSS403 - Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| K,VOinputs (Schmitt-Tr) |  |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{T}_{+}}$(positive going threshold voltage) |  | 3 V | $\mathrm{V}_{\mathrm{KH}}$ | 1.5 |  | 2.0 | V |
| $\mathrm{V}_{\mathrm{T} \text { - }}$ (negative going threshold voltage) |  | 3 V | $\mathrm{V}_{\mathrm{KL}}$ | 0.8 |  | 1.5 | v |
| $\mathrm{V}_{\mathrm{T}_{+}}-\mathrm{V}_{\mathrm{T}_{-}}$(Hysteresis) |  | 3 V |  | 0.4 |  | 1.4 | V |
| Option pull-down | $\mathrm{V}_{\text {IN }}=0.6 \mathrm{~V}$ | 3 V | IKR | 5 | 20 | 15 | $\mu \mathrm{A}$ |
|  |  | 3 V | IKR | 30 | 95 | 75 | $\mu \mathrm{A}$ |
| Option no pull-down | $V_{I N}=0 V$ | 3.8 V | ${ }^{\prime}$ KR | -0.1 |  | 0.1 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathbb{I}}=\mathrm{V}_{\text {DD }}$ | 3.8 V | ${ }^{\prime} \mathrm{KR}$ | -0.1 |  | 0.1 | $\mu \mathrm{A}$ |

6.5 TSS403-Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $K$ as output |  |  |  |  |  |  |  |
| Option push-pull |  |  |  |  |  |  |  |
| "1" | $\mathrm{I}_{\text {KHmax }}=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\text {KH }}$ | $\mathrm{V}_{\mathrm{DD}}-0.2$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| "1" | $\mathrm{I}_{\text {KHmax }}=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\text {KH }}$ | $V_{D D}-0.6$ |  | $\mathrm{V}_{\mathrm{DD}}$ | v |
| "0" | ${ }^{\text {KLImax }}=+0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{KL}}$ | $\mathrm{v}_{\text {SS }}$ |  | $V_{S S}+0.4$ | v |
| Option open-source |  |  |  |  |  |  |  |
| "1" | ${ }^{1} \mathrm{KH}_{\max }=-0.1 \mathrm{~mA}$ | 3V | $\mathrm{V}_{\mathrm{KH}}$ | $V_{\text {DD }}-0.2$ |  | $V_{\text {DD }}$ | V |
| "1" | ${ }^{1} \mathrm{KH}$ max $=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{KH}}$ | $V_{\text {DD }}-0.6$ |  | $v_{D D}$ | $v$ |
|  | $\mathrm{V}_{\mathrm{K}}=2.3 \mathrm{~V}$ | 3 V |  |  |  |  | nA |
| VO as output |  |  |  |  |  |  |  |
| "1" | ${ }^{1} \mathrm{IOHmax}=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{1 \mathrm{OH}}$ | $V_{D D}-0.2$ |  | $V_{\text {DD }}$ | V |
| "1" | $\mathrm{I}_{10 H_{\text {max }}}=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{IOH}}$ | $V_{D D}-0.6$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| "0" | $\mathrm{I}^{1 O L \max }=+0.5 \mathrm{~mA}$ | 3 V | VIOL | $V_{S S}$ |  | $\mathrm{V}_{\text {SS }}+0.4$ | V |
| R output |  |  |  |  |  |  |  |
| "1" | ${ }^{\text {RHHax }}=-0.1 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{RH}}$ | $\mathrm{V}_{\mathrm{DD}}-0.2$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| "1" | ${ }^{1} \mathrm{RH}_{\max }=-0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\text {RH }}$ | $\mathrm{V}_{\mathrm{DD}}-0.6$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| "0" | ${ }^{\text {RLImax }}=+0.3 \mathrm{~mA}$ | 3 V | $\mathrm{V}_{\mathrm{RL}}$ |  |  | $\mathrm{V}_{\text {SS }}+0.4$ | V |

### 6.5 TSS403-Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{v}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock <br> (Opt: NONE,256Hz, 1024 Hz ) (not active at OFF mode) |  |  |  |  |  |  |  |
| output "1" <br> output " 0 " | $\begin{aligned} & { }^{\prime} \mathrm{CH}^{\prime}=-0.1 \mathrm{~mA} \\ & { }^{\mathrm{C}} \mathrm{CL}=+0.5 \mathrm{~mA} \end{aligned}$ | $3 V$ <br> $3 V$ | $\begin{aligned} & \mathrm{v}_{\mathrm{CH}} \\ & \mathrm{v}_{\mathrm{CL}} \end{aligned}$ | $\begin{gathered} v_{D D}-0.2 \\ v_{S S} \end{gathered}$ |  | $\begin{gathered} v_{D D} \\ \text { VSS }+0.4 \end{gathered}$ | v |
| INITN | $\begin{aligned} & v_{I N}=0 \mathrm{~V} \\ & v_{I N}=v_{D D} \end{aligned}$ | $\begin{gathered} 3 \mathrm{~V} \\ 3.8 \mathrm{~V} \end{gathered}$ |  | $\begin{aligned} & -0.2 \\ & -0.1 \end{aligned}$ |  | $\begin{gathered} -1.0 \\ 0.1 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| $\mathrm{SV}_{\mathrm{DD}}$ (switched $\mathrm{V}_{\mathrm{DD}}$ ) | $\begin{aligned} & I_{S V D D}=2 \mathrm{~mA} \\ & I_{S V D D}=6.5 \mathrm{~mA} \\ & S V_{D D} \text { off }(\mathrm{OV}) \end{aligned}$ | $\begin{aligned} & 2.6 \mathrm{~V} \\ & 2.6 \mathrm{~V} \\ & 3.8 \mathrm{~V} \end{aligned}$ | $\mathrm{v}_{\text {SVDD }}$ <br> $v_{\text {SVDD }}$ <br> ${ }^{\prime}$ sVDD | $\begin{gathered} v_{D D}-0.2 \\ v_{D D}-0.3 \\ -0.1 \end{gathered}$ |  | $\begin{aligned} & \mathrm{v}_{\mathrm{DD}} \\ & \mathrm{v}_{\mathrm{DD}} \\ & 0.1 \end{aligned}$ | V <br> $\mu \mathrm{A}$ |
| KC | $\begin{aligned} & v_{\mathrm{KC}}=\mathrm{OV} \\ & \mathrm{v}_{\mathrm{KC}}=\mathrm{v}_{\mathrm{DD}} \end{aligned}$ | $\begin{aligned} & 3.8 \mathrm{~V} \\ & 3.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{Kc}} \\ & \mathrm{I} \mathrm{Kc} \end{aligned}$ | $-0.1$ |  | $\begin{aligned} & 0.1 \\ & 0.1 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |

### 6.5 TSS403-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{v}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD lines common (1/2 duty cycle) |  |  |  |  |  |  |  |
| output "1" | ${ }^{\prime} \mathrm{CH}=-50 \mu \mathrm{~A}$ | 3 V | $\mathrm{V}_{\mathrm{CH}}$ | $\mathrm{V}_{\text {DD }}-0.4$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| "1/2 Hz" | ${ }^{\prime} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 3V | $\mathrm{V}_{\mathrm{Hz}}$ | $\mathrm{V}_{\mathrm{DD}} / 2.06$ | $\mathrm{V}_{\mathrm{DD}} / 2$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\text {/2+.06 }}$ | V |
| " $1 / 2 \mathrm{~Hz}{ }^{\text {" }}$ | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | -1.5 |  | -4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | 1.5 |  | 4 | $\mu \mathrm{A}$ |
| output "0" | ${ }^{1} \mathrm{CL}=+50 \mu \mathrm{~A}$ | 3 V | $\mathrm{V}_{\mathrm{CL}}$ | $\mathrm{v}_{\text {SS }}$ |  | $\mathrm{V}_{\text {SS }}+0.4$ | $v$ |
| LCD lines segment (1/2 duty cycle) |  |  |  |  |  |  |  |
| output "1" | ${ }^{1} \mathrm{CH}=-50 \mu \mathrm{~A}$ | 3 V | $\mathrm{V}_{\text {SH }}$ | $V_{D D}-0.4$ |  | $V_{\text {DD }}$ | v |
| output "0" | ${ }^{\prime} \mathrm{CL}^{\prime}=+50 \mu \mathrm{~A}$ | 3 V | $\mathrm{V}_{\mathrm{SL}}$ |  |  |  | V |

### 6.5 TSS403-Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD lines common, segment ( $1 / 4$ duty cycle) |  |  |  |  |  |  |  |
| output "1" | ${ }^{1} \mathrm{CH}=-50 \mu \mathrm{~A}$ | 3 V | $\mathrm{V}_{\mathrm{CH}}$ | $V_{D D}-0.4$ |  | $\mathrm{V}_{\mathrm{DD}}$ | v |
| output " $2 / 3 \mathrm{~Hz}$ " | ${ }^{1} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 3 V | $\mathrm{V}_{\mathrm{Hz}}$ | $2 \cdot \mathrm{~V}_{\mathrm{DD}}{ }^{13-0.04}$ | $2 \cdot \mathrm{~V}_{\mathrm{DD}}{ }^{13}$ | $2 \cdot \mathrm{VDD}^{13+0.04}$ | v |
| "2/3 Hz" | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | -1.5 |  | -4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | 0.75 |  | 2 | $\mu \mathrm{A}$ |
| output "1/3 Hz" | ${ }^{1} \mathrm{CHz}=+/-10 \mathrm{nA}$ | 3V | $\mathrm{V}_{\mathrm{Hz}}$ | $\mathrm{v}_{\mathrm{DD}}{ }^{\text {/3-0.04 }}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\text {3 }}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{13+0.04}$ | V |
| ${ }^{-1 / 3 ~ H z "}$ | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | -0.75 |  | -2 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 3 V | ${ }^{1} \mathrm{CHz}$ | 1.5 |  | 4 | $\mu \mathrm{A}$ |
| output "0" | ${ }^{\prime} \mathrm{CL}^{\prime}=+50 \mu \mathrm{~A}$ | 3 V | $\mathrm{v}_{\mathrm{CL}}$ | $v_{S S}$ |  | $\mathrm{V}_{S S}+0.4$ | $v$ |

### 6.5 TSS403-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source $V_{\text {Rext }}=$ $\mathbf{V}_{\text {SVDD }}-\mathbf{V}_{\text {RI }}$ | operating range of $V_{D D}$ is limited to $\begin{aligned} & 3.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DD}} \\ & \leq 5.5 \mathrm{~V} \end{aligned}$ |  |  |  |  |  |  |
| Range large* | $\begin{aligned} & \mathrm{I}_{\mathrm{RI}}=1.3 \mathrm{~mA} ; \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ | 3.5 V | $V_{\text {Rext }}$ | $0.240737 \cdot S V_{\text {DD }}$ | $0.244403 \cdot S V_{\text {DD }}$ | $0.248069 \cdot S V_{\text {DD }}$ | V |
| external <br> Resistor <br> A1, A2, A3, <br> A4 | $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ | 3.5 V | $R_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & \mathrm{AV} \\ & \mathrm{LL} \\ & \mathrm{AV} \\ & \mathrm{HL} \end{aligned}$ | $\begin{aligned} & 3.5 \mathrm{~V} \\ & 3.5 \mathrm{~V} \end{aligned}$ | dN/dT dN/dT |  | $\begin{aligned} & 0.03 \\ & 0.06 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{SV}_{\mathrm{DD}}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 3.5 V | $\begin{aligned} & \mathrm{dN} / \\ & \mathrm{dSV} \\ & \mathrm{DD} \end{aligned}$ | -3 | - 1.5 | 1 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 3.5 V | dN/ $\mathrm{dSV}_{\mathrm{DD}}$ | -6 | -3 | 2 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext } / R_{\text {ext }}} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 3.5 V | $\mathrm{dV}_{\text {Rext }}$ month |  |  |  |  |

[^1]
### 6.5 TSS405-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range large)* |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{I N}=V_{S S} \\ & \text { to } V_{D D} ; \\ & D L .13=0 \end{aligned}$ |  | ${ }^{1} 1 / 2 / 3 / 4$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage lower limit | $N L L=046{ }_{16}$ | 3.5 V | $\mathrm{AV}_{\mathrm{LL}}$ | 0.106017.SV ${ }_{\text {DD }}$ | 0.107939 ${ }^{\text {SV }}$ DD | $0.109861 \cdot$ SV ${ }_{\text {DD }}$ | V |
| Analog input voltage higher limit | $\begin{aligned} & \mathrm{NHL}= \\ & \mathrm{FB9}_{16} \end{aligned}$ | 3.5 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.486055 \cdot S V_{\text {DD }}$ | $0.487977 \cdot S V_{\text {DD }}$ | 0.489899•SVDD | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \left(\mathrm{FB9}_{16}{ }^{-}\right. \\ & \left.046_{16}\right) \end{aligned}$ | 3.5 V | $\begin{aligned} & \mathrm{R}_{\mathrm{AV}} \\ & \left(\mathrm{AV}_{\mathrm{HL}}{ }^{-}\right. \\ & \left.\mathrm{AV}_{\mathrm{LL}^{\prime}}\right)^{-1} \end{aligned}$ | $0.378596 \cdot \mathrm{SV}_{\text {DD }}$ | $0.380037 \cdot \mathrm{SV}_{\text {DD }}$ | $0.381478 \cdot S V_{\text {DD }}$ | V |

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.
6.5 TSS405-Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 3.5 V |  |  | $96.1 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  | V |
| Linearity | Delta digital value $\leq 120$ LSB | 3.5V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 3.5 V |  | -11/2 |  | +1 $1 / 2$ | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 3.5V |  | -2 1/2 |  | +2 $1 / 2$ | LSB |
|  | DDV >2600 | 3.5V |  | -41/2 |  | +4 1/2 | LSB |

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.
6.5 TSS403-Operating Characteristics (continued): $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.


### 6.5 TSS403 - Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $V_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range small) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{\mathbb{N}}=V_{S S} \\ & \text { to } V_{D D} ; \\ & D L 13=0 \end{aligned}$ |  | ${ }^{\prime}{ }^{1} 1 / 2 / 3 / 4$ |  |  | +/-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage |  |  |  |  |  |  |  |
| lower limit | $\begin{aligned} & N_{L L}= \\ & 09 C_{16} \end{aligned}$ | 3 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.236265 \cdot \mathrm{SV}$ DD | $0.237986 \cdot \mathrm{SV}$ DD | $0.239708 \cdot \mathrm{SV}_{\text {DD }}$ | V |
| Analog input voltage |  |  |  |  |  |  |  |
| higher limit | $\begin{aligned} & \mathrm{N}_{\mathrm{HL}}= \\ & \mathrm{F} 63_{16} \end{aligned}$ | 3 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.399117 \cdot$ SV ${ }_{\text {DD }}$ | $0.400839 \cdot S V_{\text {DD }}$ | $0.402560 \cdot \mathrm{SV}_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \left(\mathrm{F6} 3_{16}\right. \\ & \left.\mathrm{OSC}_{16}\right) \end{aligned}$ | 3 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \left.\mathrm{AV}_{\mathrm{LL}}\right)^{-} \end{gathered}$ | $0.161990 \cdot \mathrm{SV}_{\mathrm{DD}}$ | $0.162851 \cdot S V_{\text {DD }}$ | $0.163712 \cdot \mathrm{SV}_{\mathrm{DD}}$ | v |

Note: AD-range limited due to offset of comparator. Nevertheless, the range can be larger by smaller offset.
6.5 TSS403-Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{v}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 3 V |  |  | $43.0 \cdot 10-6 \cdot \mathrm{SV}_{\text {DD }}$ |  | v |
| Linearity | Delta digital value $\leq 120$ LSB | 3 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 3 V |  | -1 1/2 |  | +11/2 | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 3 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 3 V |  | -41/2 |  | +41/2 | LSB |

Note: AD-range limited due to offset of comparator. Nevertheless, the range can be larger by smaller offset.
6.5 TSS403-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source $V_{\text {Rext }}=$ $\mathbf{V}_{\text {SVDD }}-\mathbf{V}_{\mathbf{R I}}$ | operating range of $V_{D D}$ is limited to $3.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DD}}$ $\leq 5.5 \mathrm{~V}$ |  |  |  |  |  |  |
| Range medium-high* | $\begin{aligned} & \mathrm{I}_{\mathrm{RI}}=1.3 \mathrm{~mA} ; \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ | 3.5 V | $\mathrm{V}_{\text {Rext }}$ | $0.237979 \cdot \mathrm{SV}_{\text {DD }}$ | $0^{0.241603} \cdot \mathrm{SV}_{\text {DD }}$ | $0.245227 \cdot$ SV ${ }_{\text {DD }}$ | V |
| external <br> Resistor <br> A1, A2, A3, <br> A4 | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 3.5 V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & A V_{\mathrm{LL}} \\ & A V_{\mathrm{HL}} \end{aligned}$ | 3.5 V 3.5 V | $\mathrm{dN} / \mathrm{dT}$ dN/dT |  | $\begin{aligned} & 0.04 \\ & 0.08 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |
| $S V_{D D}$ rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & \mathrm{AV}_{\mathrm{LL}} \end{aligned}$ | 3.5 V | $\begin{gathered} \mathrm{dN} / \\ \mathrm{dSV} \\ \mathrm{DD} \end{gathered}$ | -4.5 | -2 | 1.5 | LSBN |
|  |  | 3.5 V | $\begin{gathered} d N / \\ d S V_{D D} \end{gathered}$ | -9 | -4.5 | 3 | LSBN |
| Drift | $\begin{aligned} & V_{R_{\text {ext }}} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 3.5 V | $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month |  |  |  |  |

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V


### 6.5 TSS403-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range mediumhigh)* |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{I N}=V_{S S} \\ & \text { to } V_{D D} ; \\ & D L 13=0 \end{aligned}$ |  | $\mathrm{I}_{\text {A1/2/3/4 }}$ |  |  | +1-30 | $n A$ |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage lower limit | $N_{L L}=067{ }_{16}$ | 3.5 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.237393 \cdot$ SV ${ }_{\text {DD }}$ | $0.239355 \cdot$ SV ${ }_{\text {DD }}$ | $0.241317 \cdot \mathrm{SV}_{\mathrm{DD}}$ | V |
| Analog input voltage higher limit | $\begin{aligned} & \mathrm{N}_{\mathrm{HL}}= \\ & \mathrm{F98} \\ & 16 \end{aligned}$ | 3.5V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.491765 \cdot \mathrm{SV}_{\text {DD }}$ | $0.493731 \cdot \mathrm{SV}$ DD | $0.495694 \cdot \mathrm{SV}$ DD | V |
| Range analog input volt. (see note) | digital value $\begin{aligned} & \left(\mathrm{F98}_{16}{ }^{-}\right. \\ & \left.06{ }_{16}\right) \end{aligned}$ | 3.5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \mathrm{AV} \\ \left.\mathrm{AL}^{-}\right) \end{gathered}$ | $0.253405 \cdot \mathrm{SV}_{\text {DD }}$ | $0.254386 \cdot \mathrm{SV}$ DD | $0.255367 \cdot \mathrm{~V}_{\mathrm{DD}}$ | V |

* This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.
6.5 TSS403 - Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 3.5V |  |  | $65.4 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  |  |
| Linearity | Delta digital value $\leq 120$ LSB | 3.5V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV 5240 LSB | 3.5V |  | -1 1/2 |  | +1 $1 / 2$ | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 3.5V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 3.5 V |  | -4 1/2 |  | +4 1/2 | LSB |

Note: AD-range limited due to offset of comperator. Nevertheless the range can be larger by smaller offset.

### 6.5 TSS403-Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{V}_{\text {Rext }}= \\ & \mathrm{V}_{\text {SVDD }}-\mathrm{V}_{\mathrm{RI}} \end{aligned}$ |  |  |  |  |  |  |  |
| Range medium-low | $\begin{aligned} & \mathrm{I}_{\mathrm{RI}}=1.3 \mathrm{~mA} ; \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ | 3V | $V_{\text {Rext }}$ | $0.238629 \cdot$ SV ${ }_{\text {DD }}$ | 0.242263. SV ${ }_{\text {DD }}$ | $0.245897 \cdot$ SV ${ }_{\text {DD }}$ | v |
| external Re sistor A1, A2, A3, A4 | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 3 V | $\mathrm{R}_{\text {ext }}$ | . 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \end{aligned}$ |  |  |  |  |  |  |
|  | $\mathrm{AV}_{\mathrm{LL}}$ | 3 V | $\mathrm{d} / \mathrm{d} / \mathrm{T}$ |  | 0.04 |  | LSB/ $/{ }^{\circ} \mathrm{C}$ |
|  |  | 3 V | dNdT |  | 0.08 |  | LSB $/{ }^{\circ} \mathrm{C}$ |
| $S V_{\text {DD }}$ | $T_{A}=25^{\circ} \mathrm{C},$ |  |  |  |  |  |  |
| rejection ratio |  | 3 V | $\begin{gathered} \mathrm{dN} / \\ \mathrm{dSV} \\ \mathrm{DD} \end{gathered}$ | -4 | -2 | 1.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 3 V | $\begin{gathered} \mathrm{dN} / \\ \mathrm{dSV}_{\mathrm{DD}} \end{gathered}$ | -8 | -4 | 2.5 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext } / R_{\text {ext }}}=1.3 \mathrm{~mA} \end{aligned}$ | 3 V | $\mathrm{dVR}_{\text {ext }}$ t month |  |  |  |  |

### 6.5 TSS403 - Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range medium-low) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{I N}=V_{S S} \text { to } \\ & V_{D D} \\ & D L 13=0 \end{aligned}$ |  | ${ }^{1} 1 / 23 / 4$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage lower limit | $N_{L L}=05 B_{16}$ | 3 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.104798 \cdot \mathrm{SV}_{\text {DD }}$ | $0.107013 \cdot \mathrm{SV}_{\text {DD }}$ | $0.109227 \cdot S V_{\text {DD }}$ | V |
| Analog input voltage higher limit | $\mathrm{N}_{\mathrm{HL}}=\mathrm{FA} 4_{16}$ | 3 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.393642 \cdot S V_{\text {DD }}$ | $0.395857 \cdot S V_{\text {DD }}$ | ${ }^{0.398072 . S V}{ }_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \text { FA4 }_{16} \\ & 0_{16} \text { ) } \end{aligned}$ | 3 V | $\begin{aligned} & \mathrm{R}_{\mathrm{AV}} \\ & \left(\mathrm{AV}_{\mathrm{HL}}-\right. \\ & \left.\mathrm{AV}_{\mathrm{LL}}\right)^{-} \end{aligned}$ | $0.287739 \cdot \mathrm{~S}_{\mathrm{DD}}$ | $0.288846 \cdot \mathrm{SV}$ DD | $0.289953 \cdot \mathrm{SV}$ DD | V |

### 6.5 TSS403-Operating Characteristics (continued):

 $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $V_{D D}$ | Symbol | Min | Nom | Max | Unit |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  |  |  |  |  |  |  |  |

### 6.6 TSS405-Operating Conditions

Parameter:
Supply Voltage, $\mathrm{V}_{\mathrm{DD}}$
Supply Voltage, $\mathrm{V}_{\mathrm{SS}}$
Operating Temperature
Range I
-25
Range A -40
Timer Frequency (XTAL)
*) Timer Frequency (ext)
Processor Frequency internal (f proc )

| MIN | NOM | MAX | UNITS |
| ---: | ---: | ---: | ---: |
| 4.5 | 5.0 | 5.5 | V |
| 0.0 | 0.0 | 0.0 | V |

Characteristics : see Figure 6-1
Processor Frequency external,
PFRQ Pin (f proc ) 400
**) Instruction execution time
Capacitance of Display:
any Common
any Segment

15 700
8.5

1000 6 1000 200
pF
pF
*) Note: If LCD-display is used be sure that the frequency meets

$$
\text { the limits of display frame rate }\left[\text { DFR }=\frac{\text { timer frequency }}{512}\right)
$$

$\left.{ }^{* *}\right)$ Note: Each instruction needs 6 cycles of the

$$
\text { processor frequency } f_{\text {proc }}=\text { tinstruct }=\frac{6}{f_{\text {proc }}}
$$

### 6.7 TSS405-Operating Characteristics

| Parameter | Conditions | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current (into $V_{D D}$ ) | (excluding external current) |  |  |  |  |  |  |
|  | $\begin{aligned} & \text { Active Mode } \\ & \text { with } A D{ }^{\eta} \\ & T_{A}=0 \text { to } 80^{\circ} \mathrm{C} \\ & T_{A^{*}}=-40 \text { to } 125^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | ${ }^{\text {A }}$ d |  | 800 800 | 1100 1400 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
|  | Active Mode <br> without AD ${ }^{\text {² }}$ ) <br> $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$ <br> $T_{A}=-40$ to $125^{\circ} \mathrm{C}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | ${ }^{\text {act }}$ |  | 400 520 | 500 650 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
|  | DONE Mode <br> (Standby) ") $\begin{aligned} & T_{A}=0 \text { to } 80^{\circ} \mathrm{C} \\ & T_{A}=-40 \text { to } 125^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | 'Done |  | 10 12 | 18 20 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
|  | OFF Mode (Halt) ") $\begin{aligned} & T_{A}=0 \text { to } 80^{\circ} \mathrm{C} \\ & T_{A}=-40 \text { to } 125^{\circ} \mathrm{C} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | 'off |  | $\begin{aligned} & 0.1 \\ & 0.1 \end{aligned}$ | 1 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |

*) Current values are for input levels in the range of
$0 . . .0 .3 \mathrm{~V}$
For $\mathrm{V}_{\mathrm{KL}}$, $\mathrm{V}_{\text {IOL }}$;
$\left(V_{D D}-0.3 \mathrm{~V}\right) \mathrm{V}_{\mathrm{DD}}$ For $\mathrm{V}_{\mathrm{KH}}, \mathrm{V}_{\mathrm{IOH}}-$ All outputs open

### 6.7 TSS405 -Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $V_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| K,VOinputs (Schmitt-Tr) |  |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{T}_{+}}$(positive going threshold voltage) |  | 5V | $\mathrm{V}_{\mathrm{KH}}$ | 2.7 |  | 3.9 | v |
| $\mathrm{V}_{\mathrm{T}}$ (negative going threshold voltage) |  | 5V | $\mathrm{V}_{\mathrm{KL}}$ | 1.0 |  | 1.9 | V |
| $\mathrm{V}_{\mathrm{T}_{+}}-\mathrm{V}_{\mathrm{T}-}$ (Hysteresis) |  | 5 V |  | 0.8 |  | 2.9 | V |
| Option pull-down | $\mathrm{V}_{\text {IN }}=0.6 \mathrm{~V}$ | 5V | ${ }^{\prime} \mathrm{KR}$ | 5 | 20 | 15 | $\mu \mathrm{A}$ |
|  | $V_{1 N}=5 \mathrm{~V}$ | 5 V | ${ }^{\prime} \mathrm{KR}$ | 50 | 160 | 125 | $\mu \mathrm{A}$ |
| Option no pull-down | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ | 5.5 V | ${ }^{\prime} \mathrm{KR}$ | -0.1 |  | 0.1 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{DD}}$ | 5.5 V | ${ }^{\prime} \mathrm{KR}$ | -0.1 |  | 0.1 | $\mu \mathrm{A}$ |
| $K$ as output "1" | $\mathrm{I}_{\mathrm{KH} \max }=-0.5 \mathrm{~mA}$ | 5V | $\mathrm{V}_{\text {KH }}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{-0.6}$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Option push-pull | $\mathrm{I}_{\text {KLmax }}=+0.4 \mathrm{~mA}$ | 5V | $\mathrm{V}_{\mathrm{KL}}$ | $\mathrm{v}_{\mathrm{SS}}$ |  | $\mathrm{V}_{\text {SS }}{ }^{+0.4}$ | V |
| Option open-source | $\begin{aligned} & \mathrm{I}_{\mathrm{KH} \max }=-0.5 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{K}}=3.8 \mathrm{~V} \end{aligned}$ | 5V <br> 5 V | $\begin{aligned} & \mathrm{v}_{\mathrm{KH}} \\ & \mathrm{I}_{\mathrm{KOL}} \end{aligned}$ | $\left\|\begin{array}{c} V_{D D}-0.6 \\ 30 \end{array}\right\|$ |  | $\begin{gathered} \mathrm{v}_{\mathrm{DD}} \\ 30 \end{gathered}$ | V <br> nA |
|  |  |  |  |  |  |  |  |
| "1" | $\mathrm{I}_{10 \mathrm{Hmax}}=-0.75 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{1 \mathrm{OH}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{-0.6}$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| "0" | $\mathrm{I}_{\text {IOLmax }}=+1.0 \mathrm{~mA}$ | 5 V |  |  |  | $\mathrm{V}_{\text {SS }}+0.4$ | V |
| $R$ output |  |  |  |  |  |  |  |
| "1" | $\mathrm{I}_{\text {RHmax }}=-0.3 \mathrm{~mA}$ | 5 V | $\mathrm{V}_{\mathrm{RH}}$ | $V_{D D}-0.4$ |  | $\mathrm{V}_{\mathrm{DD}}$ | V |
| ${ }^{*} 0^{\prime}$ | $\mathrm{I}_{\text {RLmax }}=+0.3 \mathrm{~mA}$ | 5 V |  |  |  | $\mathrm{v}_{\mathrm{SS}}{ }^{+0.4}$ | V |

### 6.7 TSS405-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

6.7 TSS405-Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD lines common (1/2 duty cycle) |  |  |  |  |  |  |  |
| output "1" | ${ }^{1} \mathrm{CH}^{\prime}=-100 \mu \mathrm{~A}$ | 5 V | $\mathrm{v}_{\mathrm{CH}}$ | $\mathrm{V}_{\mathrm{DD}}-0.4$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\text {2 }}$ | $\mathrm{V}_{\text {DD }}$ | v |
| " $1 / 2 \mathrm{~Hz}{ }^{\prime}$ | ${ }^{1} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 5 V | $\mathrm{V}_{\mathrm{Hz}}$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\text {2-.06 }}$ |  | $\mathrm{V}_{\mathrm{DD}}{ }^{2+.06}$ | V |
| "1/2 Hz" | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | -2.5 |  | -6.8 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | 2.5 |  | 6.8 | $\mu \mathrm{A}$ |
| output "0" | ${ }^{\prime} C L=+100 \mu A$ | 5 V | $\mathrm{V}_{\mathrm{CL}}$ | $\mathrm{v}_{\text {SS }}$ |  | $\mathrm{V}_{\text {SS }}+0.4$ | V |
| LCD lines segment (1/2 duty cycle) |  |  |  |  |  |  |  |
| output "1" <br> output "0" | $\begin{aligned} & { }^{{ }^{C} C H}=-100 \mu \mathrm{~A} \\ & { }^{\mathrm{C}} \mathrm{CL}=+100 \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SH}} \\ & \mathrm{v}_{\mathrm{SL}} \end{aligned}$ | $\begin{gathered} \mathrm{v}_{\mathrm{DD}}-0.4 \\ \mathrm{v}_{\mathrm{SS}} \end{gathered}$ |  | $\begin{gathered} \mathrm{v}_{\mathrm{DD}} \\ \mathrm{v}_{\mathrm{SS}}+0.4 \end{gathered}$ | V V |

### 6.7 TSS405-Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LCD lines common, segment ( $1 / 4$ duty cycle) |  |  |  |  |  |  |  |
| output "1" | ${ }^{1} \mathrm{CH}^{\prime}=-100 \mu \mathrm{~A}$ | 5V | $\mathrm{v}_{\mathrm{CH}}$ | $\mathrm{V}_{\mathrm{DD}}-0.4$ |  | $\mathrm{V}_{\mathrm{DD}}$ | $v$ |
| output " $2 / 3 \mathrm{~Hz}$ " | ${ }^{1} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 5 V | $\mathrm{V}_{\mathrm{Hz}}$ | $\begin{gathered} 2 \cdot V_{D D^{\prime 3}} \\ 0.04 \end{gathered}$ | $\begin{aligned} & 2 \cdot V_{D D} \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \cdot \mathrm{v}_{\mathrm{DD}}{ }^{\prime} \\ & 3+0.04 \end{aligned}$ | V |
| "2/3 Hz" | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 5V | ${ }^{1} \mathrm{CHz}$ | -2.5 |  | -6.8 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 5V | ${ }^{1} \mathrm{CHz}$ | 1.25 |  | 3.4 | $\mu \mathrm{A}$ |
| output " $1 / 3 \mathrm{~Hz}$ " | ${ }^{1} \mathrm{CHz}=+1-10 \mathrm{nA}$ | 5V | $\mathrm{V}_{\mathrm{Hz}}$ | $\mathrm{V}_{\mathrm{DD}} / 3-0.04$ | $\mathrm{V}_{\mathrm{DD}}{ }^{\text {/3 }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}^{\prime}} \\ & 3+0.04 \end{aligned}$ | V |
| "1/3 Hz" | $\mathrm{V}_{\mathrm{CHz}}=0 \mathrm{~V}$ | 5V | ${ }^{1} \mathrm{CHz}$ | - 1.25 |  | -3.4 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CHz}}=\mathrm{V}_{\mathrm{DD}}$ | 5 V | ${ }^{1} \mathrm{CHz}$ | 2.5 |  | 6.8 | $\mu \mathrm{A}$ |
| output "0" | ${ }^{\prime} \mathrm{CL}^{\prime}=+100 \mu \mathrm{~A}$ | 5V | $\mathrm{v}_{\mathrm{CL}}$ | $\mathrm{v}_{\text {SS }}$ |  | $\mathrm{v}_{\mathrm{SS}}+0.4$ | v |

### 6.7 TSS405-Operating Characteristics (continued):

 $T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source $\begin{aligned} & V_{\text {Rext }}= \\ & V_{\text {SVDD }}-V_{\text {RI }} \end{aligned}$ |  |  |  |  |  |  |  |
| Range large* | $\begin{aligned} & I_{R I}=1.3 \mathrm{~mA} ; \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ | 5 V | $V_{\text {Rext }}$ | $0.241959 \cdot S V_{\text {DD }}$ | $0.244403 \cdot S V_{\text {DD }}$ | $0.246847 \cdot$ SV ${ }_{\text {DD }}$ | V |
| external Re sistor A1, A2, A3, A4 | $T_{A}=25^{\circ} \mathrm{C}$ | 5V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & A V_{L L} \end{aligned}$ | 5 V | $\mathrm{dN} / \mathrm{dT}$ |  | 0.03 |  | LSB/ $/{ }^{\circ} \mathrm{C}$ |
|  |  | 5 V | dN/dT |  | 0.06 |  | LSB $/{ }^{\circ} \mathrm{C}$ |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C} \\ & A V_{L L} \end{aligned}$ | 5 V | $\begin{aligned} & \mathrm{dN} / \\ & \mathrm{dSV}_{\mathrm{DD}} \end{aligned}$ | -7 | -1.5 | 1 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 5V | dN $\mathrm{dSV}_{\mathrm{DD}}$ | -6 | -3 | 2 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 5 V | $\mathrm{dVR}_{\text {ext }}$ month |  |  |  |  |

### 6.7 TSS405-Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range large) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & V_{\mathbb{N}}=V_{S S} \text { to } \\ & V_{D D} ; \\ & D L 13=0 \end{aligned}$ |  | ${ }^{\text {A } 1 / 2 / 3 / 4}$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  | - |  |
| Analog input voltage lower limit | $N_{L L}=02 B_{16}$ | 5V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.103423 \cdot \mathrm{SV}_{\text {DD }}$ | $0.104345 \cdot S V_{\text {DD }}$ | $0.107267 \cdot S V_{\text {DD }}$ | V |
| Analog input voltage higher limit | $\mathrm{N}_{\mathrm{HL}}=\mathrm{FD}_{1}{ }_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.488649 \cdot$ SV ${ }_{\text {DD }}$ | $\mathrm{0}^{\mathbf{0} 490571 S V_{\text {DD }}}$ | $0.492493 \cdot S V_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \left(\mathrm{FD}_{16}-\right. \\ & \left.\mathrm{OLB}_{16}\right) \end{aligned}$ | 5 V | $\begin{aligned} & \mathrm{R}_{\mathrm{AV}} \\ & \left(\mathrm{AV}_{\mathrm{HL}}{ }^{-}\right. \\ & \mathrm{AV} \mathrm{LLL}) \end{aligned}$ | $0.383784 \cdot \mathrm{SV}$ DD | $0.385226 \cdot S V_{\text {DD }}$ | $0.386667 \cdot S V_{\text {DD }}$ | V |

Note: AD-range limited due to offset of comparator. Nevertheless the range can be larger by smaller offset.
6.7 TSS405-Operating Characteristics (continued):
$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 5 V |  |  | 43.0 $10^{-6} . \mathrm{SV}_{\text {DD }}$ |  | V |
| Linearity | Delta digital value $\leq 120$ LSB <br> 120 LSB < DDV $\leq 240$ LSB <br> 240 LSB < DDV $\leq 2600$ LSB <br> DDV >2600 | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ |  | -1 <br> - 1 1/2 <br> -2 $1 / 2$ <br> $-41 / 2$ |  | $\begin{aligned} & +1 \\ & +1 \\ & +2 \\ & +2 \\ & \hline \end{aligned} 1 / 2$ | LSB <br> LSB <br> LSB <br> LSB |

Note: AD-range limited due to offset of comparator. Nevertheless the range can be larger by smaller offset.

### 6.7 TSS405-Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

6.7 TSS405-Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{v}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range small) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & \mathrm{v}_{\mathrm{IN}}=\mathrm{v}_{\mathrm{SS}} \text { to } \\ & \mathrm{v}_{\mathrm{DD}} ; \\ & \mathrm{DL} 13=0 \end{aligned}$ |  | ${ }^{1} 1 / 2 / 3 / 4$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage lower limit | $N_{L L}=0 E 5_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.233596 \cdot \mathrm{SV}_{\text {DD }}$ | $0.235317 \cdot \mathrm{SV}_{\text {DD }}$ | $0.237039 \cdot S V_{D D}$ | V |
| Analog input voltage higher limit | $N_{H L}=F A 1_{16}$ | 5V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.401786 \cdot \mathrm{SV}$ DD | $0.403508 \cdot$ SV ${ }_{\text {DD }}$ | $0.405230 \cdot S V_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \left(F A 1_{16}\right. \\ & \left.05 E_{16}\right) \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \mathrm{AV}_{\mathrm{LL}} \end{gathered}$ | $0.167328 \cdot \mathrm{SV}_{\text {DD }}$ | $0.168189 \cdot$ SV ${ }_{\text {DD }}$ | $0.169050 \cdot S V_{\text {DD }}$ | V |

Note: AD-range limited due to offset of comparator. Nevertheless the range can be larger by smaller offset.

### 6.7 TSS405-Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 5V |  |  | $43.0 \cdot 10^{-6} \cdot \mathrm{SV}_{\mathrm{DD}}$ |  | V |
| Linearity | $\begin{aligned} & \text { Delta digital value } \leq 120 \text { LSB } \\ & 120 \text { LSB }<\text { DDV } \leq 240 \text { LSB } \\ & 240 \text { LSB }<\text { DDV } \leq 2600 \text { LSB } \\ & \text { DDV }>2600 \end{aligned}$ | 5V <br> 5 V <br> 5V <br> 5V |  | $\begin{aligned} & -1 \\ & -1 \\ & 1 / 2 \\ & -2 \\ & 1 / 2 \\ & -4 \\ & 1 / 2 \end{aligned}$ |  | $+1$ <br> $+11 / 2$ <br> +2 1/2 <br> $+41 / 2$ | $\begin{aligned} & \text { LSB } \\ & \text { LSB } \\ & \text { LSB } \\ & \text { LSB } \end{aligned}$ |

Note: AD-range limited due to offset of comparator. Nevertheless the range can be larger by smaller offset.

### 6.7 TSS405-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathbf{V}_{\text {DD }}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source $\begin{aligned} & V_{\text {Rext }}= \\ & V_{\text {SVDD }}-V_{\text {RI }} \end{aligned}$ |  |  |  |  |  |  |  |
| Range medium-high* | $\begin{aligned} & I_{R I}=1.3 \mathrm{~mA} ; \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ | 5V | $V_{\text {Rext }}$ | $0.239187 \cdot \mathrm{SV}_{\text {DD }}$ | $0.241603 \cdot \mathrm{SV}_{\text {DD }}$ | 0.244019•SV ${ }_{\text {DD }}$ | V |
| external Re sistor A1, A2, A3, A4 | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 5 V | $R_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & \mathrm{V}_{\text {Rext }} / \mathrm{R}_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & \mathrm{AV} \mathrm{LL}_{\mathrm{LL}} \\ & \mathrm{AV} \\ & \mathrm{HL} \end{aligned}$ | 5 V 5 V | dN/dT dN/dT |  | $\begin{aligned} & 0.04 \\ & 0.08 \end{aligned}$ |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 5 V | $\begin{aligned} & \mathrm{dN} / \\ & \mathrm{dSV} \\ & \mathrm{DD} \end{aligned}$ | -4,5 | -2 | 1.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 5 V | $\begin{aligned} & \mathrm{dN} \\ & \mathrm{dSV} \\ & \mathrm{DD} \end{aligned}$ | -9 | -4,5 | 3 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 5 V | $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month |  |  |  |  |

## Revision 3.2, October 1991

### 6.7 TSS405-Operating Characteristics (continued):

$T_{A}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range medium-high) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{SS}} \text { to } \\ & \mathrm{V}_{\mathrm{DD}} ; \mathrm{DL} 13=0 \end{aligned}$ |  | ${ }^{1} 1 / 2 / 3 / 4$ |  |  | +1-30 | nA |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage lower limit | $N_{L L}=03 E_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{LL}}$ | $0.234711 \cdot$ SV ${ }_{\text {DD }}$ | $0.236673 \cdot \mathrm{SV}$ DD | $0^{0.238635} \cdot \mathrm{SV}_{\text {DD }}$ | V |
| Analog input voltage higher limit | $\mathrm{N}_{\mathrm{HL}}=\mathrm{FC1}_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{HL}}$ | $0.494451 \cdot$ SV ${ }_{\text {DD }}$ | $0.496413 \cdot \mathrm{SV}_{\text {DD }}$ | $0.498375 \cdot$ SV ${ }_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \mathrm{FCC}_{16}- \\ & \left.03 \mathrm{E}_{16}\right) \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}{ }^{-}\right. \\ \left.\mathrm{AV}_{\mathrm{LL}}\right) \end{gathered}$ | $0.258768 \cdot \mathrm{SV} \mathrm{V}_{\text {DD }}$ | $0.259750 \cdot \mathrm{SV}_{\text {DD }}$ | $0.260731 \cdot$ SV ${ }_{\text {DD }}$ | V |

Note: AD-range limited due to offset of comparator. Nevertheless the range can be larger by smaller offset.
6.7 TSS405 - Operating Characteristics (continued):
$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  | 5 V |  |  | $65.4 \cdot 10^{-6} . \mathrm{SV}_{\text {DD }}$ |  |  |
| Linearity | Delta digital value $\leq 120$ LSB | 5 V |  | -1 |  | +1 | LSB |
|  | 120 LSB < DDV $\leq 240$ LSB | 5 V |  | -1 1/2 |  | +11/2 | LSB |
|  | 240 LSB < DDV $\leq 2600$ LSB | 5 V |  | -2 1/2 |  | +2 1/2 | LSB |
|  | DDV >2600 | 5 V |  | -41/2 |  | +4 1/2 | LSB |

Note: AD-range limited due to offset of comparator. Nevertheless the range can be larger by smaller offset.

### 6.7 TSS405-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter current source |  |  |  |  |  |  |  |
| $\begin{aligned} & V_{\text {Rext }}= \\ & V_{\text {SVDD }}-V_{\text {RI }} \end{aligned}$ |  |  |  |  |  |  |  |
| Range medium-low | $\begin{aligned} & I_{R I}=1.3 \mathrm{~mA} ; \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ | 5 V | $V_{\text {Rext }}$ | $0.239841 \cdot$ SV ${ }_{\text {DD }}$ | $0.242263 \cdot \mathrm{~V}_{\mathrm{DD}}$ | $0.244686 \cdot S V_{\text {DD }}$ | V |
| external Resistor A1, A2, A3, A4 | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 5 V | $\mathrm{R}_{\text {ext }}$ | 0.10 |  | 1.6 | kOhm |
| Temperature stability | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA}, \\ & \mathrm{AV} \\ & \mathrm{LL} \end{aligned}$ | 5 V | dN/dT |  | 0.04 |  | LSB/ $/{ }^{\circ} \mathrm{C}$ |
|  |  | 5 V | $\mathrm{d} N / \mathrm{dT}$ |  | 0.08 |  | LSB $/{ }^{\circ} \mathrm{C}$ |
| $S V_{D D}$ <br> rejection ratio | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \\ & A V_{L L} \end{aligned}$ | 5 V | $\begin{aligned} & \mathrm{dN} / \\ & \mathrm{dSV} \\ & \mathrm{DD} \end{aligned}$ | -4 | -2 | 1.5 | LSBN |
|  | $\mathrm{AV}_{\mathrm{HL}}$ | 5 V | $\begin{aligned} & \mathrm{dN} / \\ & \mathrm{dSV} \\ & \mathrm{DD} \end{aligned}$ | -8 | -4 | 2.5 | LSBN |
| Drift | $\begin{aligned} & V_{\text {Rext }} / R_{\text {ext }} \\ & =1.3 \mathrm{~mA} \end{aligned}$ | 5 V | $\mathrm{dVR}_{\text {ext }}{ }^{\prime}$ month |  |  |  |  |

### 6.7 TSS405-Operating Characteristics (continued):

 $\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AD Converter (Range medium-low) |  |  |  |  |  |  |  |
| Input current (any inp.) | $\begin{aligned} & \mathrm{v}_{\mathrm{IN}}=\mathrm{v}_{\mathrm{SS}} \text { to } \\ & \mathrm{v}_{\mathrm{DD}} ; \\ & \mathrm{DL} 13=0 \end{aligned}$ |  | ${ }^{1} 11 / 2 / 3 / 4$ |  |  | +1-30 | $n A$ |
| Conversion analog input to digital value |  |  |  |  |  |  |  |
| Analog input voltage bwer limit | $N_{L L}=036{ }_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{LL}}$ | 0.102066.SV ${ }_{\text {DD }}$ | $0.104281 \cdot \mathrm{SV}_{\mathrm{DD}}$ | $0.106495 \cdot \mathrm{SV}$ DD | V |
| Analog input voltage higher limit | $N_{H L}=F C 7_{16}$ | 5 V | $\mathrm{AV}_{\mathrm{HL}}$ | ${ }^{0.396227} \cdot \mathrm{SV}_{\text {DD }}$ | $0.359441 \cdot$ SV ${ }_{\text {DD }}$ | $0.400656 \cdot \mathrm{SV}_{\text {DD }}$ | V |
| Range analog input volt. (see Note) | digital value $\begin{aligned} & \left(\mathrm{FC7}_{16}{ }^{-}\right. \\ & \left.036_{16}\right) \end{aligned}$ | 5 V | $\begin{gathered} \mathrm{R}_{\mathrm{AV}} \\ \left(\mathrm{AV}_{\mathrm{HL}}\right. \\ \left.\mathrm{AV} \mathrm{LL}^{-}\right) \end{gathered}$ | $0.293053 \cdot \mathrm{SV}$ DD | $0.294161 \cdot \mathrm{SV}_{\mathrm{DD}}$ | $0.295268 \cdot$ SV ${ }_{\text {DD }}$ | V |

### 6.7 TSS405-Operating Characteristics (continued):

$\mathrm{T}_{\mathrm{A}}=0$ to $80^{\circ} \mathrm{C}$, unless otherwise noted.

| Parameter | Condition | $\mathrm{V}_{\mathrm{DD}}$ | Symbol | Min | Nom | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB Voltage |  |  |  |  | $73.8 \cdot 10^{-6} . \mathrm{SV}_{\mathrm{DD}}$ |  |  |
| Linearity | Delta digital value $\leq 120$ LSB $\begin{aligned} & 120 \text { LSB }<\text { DDV } \leq 240 \text { LSB } \\ & 240 \text { LSB }<\text { DDV } \leq 2600 \text { LSB } \\ & \text { DDV }>2600 \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \\ & 5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & -1 \\ & -11 / 2 \\ & -21 / 2 \\ & -41 / 2 \end{aligned}$ |  | $+1$ $+11 / 2$ $+21 / 2$ $+41 / 2$ |  |
| Battery check |  |  |  |  |  |  |  |
| Range small, medium-high | $\mathrm{OOO}_{16}$ < conversion result > $\mathrm{FFF}_{16}$ |  | $\mathrm{v}_{\text {DDBC }}$ |  | 2.7 | 3.7 | v |
| Range large, medium-low | $000_{16}$ <conversion result >FFF 16 |  |  |  | 2.7 | 4.8 | V |
| Drift | N of ADC @ $\mathrm{V}_{\mathrm{DD}}=2.7 \mathrm{~V}, 25^{\circ} \mathrm{C}$ |  |  | -0.1 |  | +0.1 | V |

### 6.8 Typical RC-MOS Oscillator Characteristics




Figure 6-1:

### 6.9 Schematics of Inputs/Outputs



Figure 6-2: Schematic of K-I/Os


Figure 6-3: Schematic of I/O

### 6.9 Schematics of Inputs/Outputs (continued)



Figure 6-4: Schematic of XTAL Oscillator


Figure 6-5: Schematic of SVDD

## APPENDIX A - Software Restrictions

1. Carefully examine the states of inputs and outputs when DONE or OFF instruction is used. Prevent additional DC current in low power consumption mode caused by the states of inputs and outputs.
2. Pay attention to the states of $I / O$ pin and the K-lines while being in DONE/OFF. The wake-up can be triggered by K1, K2, K4, K8 and I/O but only if all were Low before one of these Lines goes High.
3. The processor begins execution at page 15; $\mathrm{PC}=00$ the first time power is applied. Each time a "wake-up" signal occurs, the processor begins execution at page 15; $\mathrm{PC}=>7 \mathrm{~F}$.
4. For operations which require more then 15 seconds of processing, the software should periodically update the timekeeping since the chip provides only modulo-16-sec.
5. The SAL instruction may cause the End-Around-Carry (SS) to change state falsely in either direction. Thus; after an SAL, the SS should be set to the desired state with a SEAC or REAC. Also, if both the Add latch and SS must be set to a desired state, the SAL should be done first. For example, in the basic Add loop where both the Add latch must be set and the SS reset, the SAL should be executed prior to the REAC.
6. The TTA and TTM instructions:

It is possible to get a false intermediate reading because of the Timer and Processor operate asynchronous. To prevent this, the time check must be repeated until two successive tests yield the same value.
7. Between a wake-up from the timer and a DONE instruction there must be a minimum number of instructions N :

$$
N>=\frac{4 \times \text { processor frequency }}{6 \times \mathrm{f}_{\mathrm{TOSCIN}}}+1
$$

8. To execute a three instruction BCD addition, the following sequence of instructions may be used:

| LOC |  | INSTRUCTION |  | COMMENT |
| :---: | :---: | :---: | :---: | :---: |
| 001 |  | SBL |  | Before jumping to |
| 002 |  | CALL | START | subroutine, set Branch |
| , |  |  |  | Latch |
| " |  | " |  |  |
| " |  | " |  |  |
| 010 | ADDBCD | TAMACS | 6 |  |
| 011 |  | CTMDYN |  |  |
| 012 | START | BRANCH | ADDBCD | Branch to location 10 |
| 013 |  | CCLA |  | and perform a DMEA |
| 014 |  | RETN |  | instruction (code 10) |
|  |  |  |  | before executing |
|  |  |  |  | TAMACS |

9. SBL instruction:

If Branch Latch is set use only Branches which can operate on an instruction. In other ways it is possible that some of the microinstructions are active and will cause some problems (i.e., transfer CKB-Bus to memory....). Don't forget to reset Branch Latch after using it.
10. Processor enable logic "wake-up"

Between TKA and DONE/OFF instruction not more than three instructions are allowed, if a successful "wake-up" should be performed by external hardware ( $\rightarrow \mathrm{K}$ inputs / I/O).
11. Processor logic "wake-up" enable If the option of "wake-up" the processor by the negative and/or positive edge of K8 is used, pay attention to the effect: inverting K8 by DL14 can produce an edge. If this happens less than 7 instructions before the DONE instruction the processor could "wake up" due to the integrated delay line.

## 12. Table Status after "wake-up"

Register content after entry into active Processor-Mode

| Register |  | Power up | INITN pin | DONE Mode | OFF Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Program Counter | PC | 00 | 00 | 7 F | 7 F |
| Page Address | PA | F | F | F | F |
| Page Buffer | PB | F | F | F | F |
| Status | S | undefined | undefined | undefined | undefined |
| Special Status | SS | undefined | undefined | undefined | undefined |
| Accumulator | A | undefined | undefined | undefined | undefined |
| YRegister | $Y$ | undefined | undefined | undefined | undefined |
| XRegister | X | undefined | undefined | undefined | undefined |
| RAM Content |  | undefined | unchanged | unchanged | unchanged |
| DAM Latch |  | undefined | undefined | undefined | undefined |
| ADD Latch |  | reset | reset | reset | reset |
| BRANCH Latch |  | reset | reset | reset | reset |
| SEG H Decimal point | DP | reset | reset | reset | reset |
| Digit Latches | DLn | reset | reset | unchanged | unchanged |
| K-Port Data Latch |  | undefined | unchanged | unchanged | unchanged |
| VO Port Data Latch |  | undefined | unchanged | unchanged | unchanged |
| VO Port Control Latch |  | reset | reset | unchanged | unchanged |
| Timer0 and Timer 1 |  | undefined | unchanged | actual Time | undefined |
| ADC/Pin Supply SVDD |  | switched off | switched off | switched off | switched off |
| LCD Segment Latches |  | undefined | unchanged | unchanged | unchanged |

## APPENDIX B - Pinning Selection Schematic

28 PIN DUAL-IN-LINE PLASTIC PACKAGE


Note:
mandatory signals are:
VDD,VSS,KC,INITN,SVDD,
TOSCIN,TOSCOUT,S2,S3,S4,S9,S10,S11
GR\#1 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
GR\#2 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
COM2 COM1 S20 S19 S18 S17 S16 S15 S14
GR\#3 = COM2 COM1 S20 S19 S18 S17 S16 S15 S14 R4 R5 R6 R7

Note: NC - No internal connection NC pins may be used for test purposes in agreement with customer.

## APPENDIX B - Pinning Selection Schematic (continued)



All dimensions are in millimeter and parenthetically in inches.
Notes: A: Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.
B: This dimension does not apply for solder-dipped leads.
C: When solder-dipped leads are specified, dipped area of the lead extends from the lead tip to at least $0,51(0.020)$ above seating plane.

## APPENDIX B - Pinning Selection Schematic (continued)



Note:
mandatory signals are:
VDD,VSS,KC,INITN,SVDD,
TOSCIN,TOSCOUT,S2,S3,S4,S9,S10,S11
GR\#1 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
GR\#2 = RO R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
COM2 COM1 S20 S19 S18 S17 S16 S15 S14
GR*3 = COM2 COM1 S20 S19 S18 S17 S16 S15 S14 R4 R5 R6 R7

Note: NC - No internal connection NC pins may be used for test purposes in agreement with customer.

## APPENDIX B - Pinning Selection Schematic (continued)



Note: A: All dimensions are in millimeter and parenthetically in inches.
B: Each pin centerline is located within $0,26(0.010)$ of it's true longitudinal position.

## APPENDIX B - Pinning Selection Schematic (continued)

44 PIN PLASTIC LEADED CHIP CARRIER PLCC


Note:
mandatory signals are:
VDD,VSS,KC,INITN,SVDD, TOSCIN,TOSCOUT,S2,S3,S4,S9,S10,S11

GR*1 = RO R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
GR*2 = RO R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
COM2 COM1 S20 S19 S18 S17 S16 S15 S14
GR*3 $=$ COM2 COM1 S20 S19 S18 S17 S16 S15 S14 R4 R5 R6 R7

Note: NC - No internal connection NC pins may be used for test purposes in agreement with customer.

## APPENDIX B - Pinning Selection Schematic (continued)

## FN Plastic Chip Carrier Package

(28torminal packgge usedror illustistiont


| JEDEC | No. of terminals | A |  | B |  | $c$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Cutline |  | min. | max. | min. | max. | min. | max. |
| MO-047AC | 44 | $\begin{array}{r} 17,40 \\ 90.885 \end{array}$ | $\begin{aligned} & 17.85 \\ & \$ 0.885 \end{aligned}$ | $\begin{gathered} 18.51 \\ 0.850 \end{gathered}$ | $\begin{aligned} & 18,66 \\ & 0.658 \end{aligned}$ | $\begin{aligned} & 15,49 \\ & p .8108 \end{aligned}$ | $\begin{aligned} & 16,00 \\ & 10.830 \end{aligned}$ |



LEADDETAIL

Notes: A: Centerline of center pin each side is within 0,10 (0.004) of package centerline as determine by dimension B .
B: Location of each pin is within $0,127(0.006)$ of true position with respect to center pin on each side.
C: The lead contact points are planar within 0,10 (0.004).
All dimensions and notes for the specified JEDEC outline apply. All linear dimensions are in millimeters and parenthetically in inches.

## APPENDIX C - User Options

## LCD

- Segment PLA with 64 terms:

4bit ACCU + Status + DL14 define on/off of segments A to G. Segment $H$ is defined by instructions SDP and RDP.

- Common lines

2MUX ( $1 / 2$ duty) or 4MUX (1/4 duty). (Some manufacturer use back plane instead of common ).

- Segment lines

1. Attachment segment to common.
2. Attachment segment to $Y$-Register.

Note: All three options must be defined even if no display will be used.

## WAKE-UP FREQUENCY

- DL12 = 0:1 Hz (no option)
- DL12 = 1 : 128 OR 64 OR 32 OR 16 OR 8 Hz only one must be selected.


## PROCESSOR FREQUENCY

- Internal RC-MOS Oscillator (see Figure 6-1).
- External Supply on Pin PFRQ (see 6.3 Operating Conditions)

Note: By using the "EXTERN" Option the internal Osc can be overwritten on Pin "PFRQ".
External Signal strength required $>10 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{DD}^{-0,4}} \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}^{+}}+\mathbf{4} \mathrm{V}$

## ADC RANGE

- SMALL
- MEDIUM LOW
- MEDIUM HIGH
- LARGE

Note: One and only one must be selected.

## TIMOSC

- TRC RC Oscillator
- TXOSC Christal Oscillator

If the RC Oscillator is selected, a resistor needs to be connected from TOSCIN to TOSCOUT and a capacitor from TOSCIN to VSS. Please make sure that the frame frequency is o.k. if an LCD is used.

## PULL-DOWN

Individually selectable for K1, K2, K4, K8 AND I/O.
Kn OPEN-SOURCE ( $\mathrm{n}=1,2,4,8$ )
Individually selectable for K1, K2, K4 and K8 to be open source

## CLOCK

Frequency output divided from the crystal oscillator (XCOSIN).

- NONE : nothing selected - no (bond)pad used
- $256 \mathrm{~Hz}: \mathrm{f}_{\mathrm{CLOCK}}=\mathrm{f}_{\text {TOSCIN }} / 128$
- 1024 Hz : $\mathrm{f}_{\text {CLOCK }}=\mathrm{f}_{\mathrm{TOSCIN}} / 32$


## K8 FLIP-FLOP

Signal on K8 line not immediate available for ACCU/MEMORY; if this option is used, signal at K 8 pin is divided by 2 and then available for further operations (TKA, TKM, KNEZ). The divider by 2 is reset by PUC (power-up clear) or INIT.

## PINNING

Variable pinning helps optimization of system cost including PCB.

## Part II

## TSS400/4 USER'S GUIDE October 1991

## Table of Contents

## Purpose and Conventions

Paragraph Title1 TSS400/4 7
1.1 Functional Specifications ..... 8
1.2 Memory Structure ..... 10
1.3 Subroutine Stack Operation ..... 11
1.4 Digit Latches/R Outputs ..... 12
1.5 DAM Operation ..... 13
1.6 ALU ..... 14
1.7 CKB Memory Map Description ..... 15
1.8 K-line Structure ..... 16
1.9 I/O Structure ..... 17
1.10 Clock ..... 18
2 Operational Description ..... 19
2.1 ROM Decode ..... 19
2.2 Program Counter and Subroutine Register ..... 20
2.3 ROM Page Address Register and Page Buffer ..... 20
2.4 Instruction Decode ..... 21
2.5 Processor Enable and Time Base Multiplexer ..... 22
2.6 Processor Frequency ..... 23
2.7 Timer Oscillator ..... 24
2.8 Time Data Multiplexer ..... 25
2.9 CKB (Constant, K-lines, Bit and Time Multiplexer) ..... 26
2.10 Branch/Call Control ..... 26
2.11 RAM Address/Character Decode Multiplexer 26
2.12 Write Multiplexer ..... 27
2.13 X-Decode ..... 27
2.14 RAM Word Decode ..... 27
2.15 Character Decode ..... 27
2.16 Segment Latches ..... 27
2.17 Segment Drivers ..... 28
2.18 Power Up Clear ..... 28
2.19 Status ..... 28
2.20 P-Multiplexer ..... 29
2.21 N -Multiplexer ..... 29
2.22 Adder-Comparator ..... 29
2.23 Accumulator and Y-Register ..... 29
3 Analog/Digital Converter (ADC) ..... 30
3.1 Description of Conversion ..... 32
3.2 Battery Check ..... 34
3.3 Current Source ..... 35
4 Display ..... 38
4.1 Gate Level PLA ..... 38
4.2 Common Select Lines ..... 39
4.3 Select Lines ..... 40
4.4 Display Drive Waveform ..... 42
5 Instruction Set Description ..... 43
5.1 Functional Description ..... 44
5.2 10-Bit Instruction Map ..... 50
6 Electrical Description ..... 52
6.1 Absolute Maximum Ratings ..... 52
6.2 TSS400/4 Operating Conditions (short form) ..... 53
6.3 Typical RC-MOS Oscillator Characteristics ..... 54
6.4 Schematics of Inputs/Outputs ..... 55
APPENDIX A Software Restrictions ..... 57
APPENDIX B Pinning Selection Schematic ..... 60
APPENDIX C User Options ..... 67

## LIST of FIGURES

Figure Title
1-1 Blockdiagram TSS400/4 1.1
1-2 X-REG Values which Address Memory
1.2

1-3 Subroutine Stack Operation
1.3

1-4 Digit Latches/R Outputs 1.4
1-5
Blockdiagram of ALU 1.6

1-6 Instruction Restrictions 1.7

1-7 K-line Structure 1.8
1-8
I/O Structure 1.9

2-1 Machine Status 2
2-2
2-3
Table for ext. Wake-up Conditions 2.5

Schematic of Wake-up Path 2.5
Option TIMOSC ..... 2.7
2-5 TRC Oscillator Frequency ..... 2.7

3-1
Principle of A/D-Converter ..... 3
3-2 Principle of Current Source ..... 3.3
3-3 Current Source with Current Option ..... 3.3
4-1 Decode and OPLA for Segment Output ..... 4.1
4-2 4Mux LCD Application Example ..... 4.2
4-3 2Mux LCD Application Example ..... 4.2
4-4 Display Drive Waveform ..... 4.4
6-1 Typical RC-MOS Oscillator Characteristics ..... 6.8
6-2 Schematic of K-l/O's ..... 6.9
6-3 Schematic of I/O ..... 6.9
6-4 Schematic of XTAL Oscillator ..... 6.9
6-5 Schematic of SVDD ..... 6.9
28pin DIP ..... App. B
40pin DIP44pin PLCC
App. B

## Purpose and Conventions

The TSS400/4 User's Guide is intended to aid the development of TSS400 products by collecting and presenting hardware and software information in a manner that will be quickly accessible to engineers and programmers.

The following substitutes have been adopted because typographical limitations do not allow the use of some conventional symbols:

| Symbol | Meaning | Example |
| :---: | :---: | :---: |
| $<>$ | "Not equal" | $\mathrm{Y}<>\mathrm{A}$ |
| [] | Subscript number | $\mathrm{R}[0]$ |
| $\wedge$ | Exponent | $\mathrm{T}^{\wedge} 2$ |
| $\mu \mathrm{sec}$ | Microsecond |  |
| msec | Millisecond |  |
| $>\mathrm{XX}$ | Hex-Value | $>3 \mathrm{F4}$ |

## 1 TSS400/4

This document describes in detail the functional and electrical characteristics of a 4-bit CMOS sensor signal processor with computing capability. Its key applications are A/D conversions, calculating, controlling and displaying information on an LCD display. The part easily interfaces with sensors and actuators.

Typical applications are:

- temperature measurements: calculating, controlling, warning
- pressure and acceleration measurements
- home appliances
- intelligent keyboard and display driver
- timer with control functions
- intelligent subsystem

The TSS400/4 is an extension of the TSS400. It holds 4 K instead of 2 K ROM and contains 960 instead of 576 bits of RAM.

### 1.1 Functional Specification

- 4096 ten bit words of ROM
- 960 bit static RAM
- Three instruction BCD addition
- 64 character, 7 segment output PLA (DP switchable independently)
- Three levels of subroutine
- Timekeeping capability ( 32768 Hz XTAL)
- Direct drive of LCD: ( 32768 Hz XTAL)

Option 2MUX: $1 / 2$ duty cycle containing up to 40 segments
Option 4MUX: $1 / 4$ duty cycle containing up to 80 segments

- Low power silicon gate CMOS process:
- Low power consumption at sleep mode (active timer/RAM)
- very low power consumption at off mode (active RAM)
- 12 Bit A/D-Converter with 4-MUX-inputs and programmable ranges
- Programmable current source from 0.15 to $2.4 \mathrm{~mA} \times \mathrm{VDD} / \mathrm{V}$
- Internal MOS oscillator (see Figure 6-1)
- Instruction execution time: $5.5 \mu \mathrm{~s}\left(@ \mathrm{f}_{\mathrm{proc}}=1.1 \mathrm{MHz}\right)$

$$
15.0 \mu \mathrm{~s}\left(@ f_{\text {proc }}=400 \mathrm{KHz}\right)
$$

- Processor frequency determined either by the internal RC-MOS oscillator or the external clock input


Figure 1-1: Block diagram TSS400/4

### 1.2 Memory Structure

The TSS400/4 has fifteen (15) registers with sixteen (16) four-bit words per register.
Fourteen (14) registers are random access memories (RAM) and one (1) register is a direct access memory (DAM).
The 15 registers can be addressed by the X-REG. The content of the XREG (4 bits) is controlled by the software instructions LDX, TDL, COMX8.
The Y-Register ( 4 bits) addresses the word within the selected Register. There are several different software instructions that control the contents of the Y -REG.
Since the TSS400/4 has 15 registers, two values of the X-REG address the same memory. Figure 1-2 is a list of which values will address memory.

| X-REG | HEX | TYPE |
| :---: | :---: | :---: |
| 0000 | 0 | RAM |
| 0001 | 1 | RAM |
| 0010 | 2 | RAM |
| 0011 | 3 | RAM |
| 0100 | 4 | RAM |
| 0101 | 5 | RAM |
| 0110 | 6 | RAM |
| 1000 | 8 | RAM |
| 1001 | 9 | RAM |
| 1010 | A | RAM |
| 1011 | B | RAM |
| 1100 | C | RAM |
| 1101 | D | RAM |
| 1110 | E | RAM |
| 0111 | 7 | DAM* |
| 1111 | F | DAM* |

* Both $>7$ and $>F$ address the same register (the DAM).

Figure 1-2: X-REG Values which Address Memory
In addition to the memory controlled by the X-REG and the Y-REG there are sixteen (16) digit latches which can be set and reset by software instructions. These digit latches are reset by hardware during power-up or by INIT. The digit latches are addressed by Y-REG (4 bits) values $>0->F$.

### 1.3 Subroutine Stack Operation

The Subroutine Stack has the following registers:

1) Page ROM Address Stack Register (3)
2) Program Counter Stack Registers (3)

The interaction of Page Register, Page ROM Address and Stack is shown for the execution of subroutines.

| P-Reg | X | X | 2 | 2 | 2 | 3 | 3 | 4 | 4 | 5 | 5 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROM Addr. Reg. | 15 | 15 | 15 | 15 | 15 | 15 | 3 | 3 | 4 | 4 | 5 | 5 | 6 |  | 4 | 4 | 4 | 4 | 3 | 3 | 3 |
| Subroutine Reg. A | X | 15 | 15 | X | X | X | X | X | 3 | 3 | 4 | 4 | 5 | 4 | 3 | 3 | 4 | 3 | 15 | 15 | 15 |
| Subroutine Reg. B | X | X | X | X | X | X | X | X | X | X | 3 | 3 | 4 | 3 | 15 | 15 | 3 | 15 | 15 | 15 | 15 |
| Subroutine Reg. C | X | X | X | X | X | X | X | X | X | X | X | X | 3 | 15 | 15 | 15 | 15 | 15 | 15 | 15 | 15 |
|  | P | C |  | R | B |  |  |  |  |  |  |  |  |  | R | B | C | R | R | R | R |
|  | U | A | D | E | R | D | R | D | A | D | A | D | A | E | E | R | A | E | E | E | E |
|  | C | L | P | T |  | P | * | P | L | P | L | $P$ | L | T | T |  | L | T | T | T | T |
|  |  | L |  | $N$ |  |  |  |  |  |  | L |  |  | $N$ | $N$ |  | L | $N$ | $N$ | N | $N$ |

* This branch is executed (branch occurs).

Figure 1-3: Subroutine Stack Operation (See Section 2.2 and 2.3 for more details.)

### 1.4 Digit Latches/R Outputs

| Digit Latch | Hardware Function |  |
| :---: | :---: | :---: |
| DL0-DL7 | Stat. outputs RO-R7 $\rightarrow$ max. 8 R outputs available |  |
| DL8 | $\begin{array}{ll} \text { Control of K-Port: } & \text { DL8 }=0-\text { Input } \\ & \text { DL8 }=1-\text { Output } \end{array}$ |  |
| DL9-DL11 | Analog Mux for ADC: A1-A2-A3-A4 or Battery check |  |
| DL12 | Selection of $1 \mathrm{~Hz}($ DL12 $=0$ ) or selection of mask programmed frequency for wake-up of the processor. Also selection of time info to CKBBUS. |  |
| DL13 | DL13 | Function |
|  | $\begin{aligned} & \hline 0 \\ & 1 \\ & \hline \end{aligned}$ | constant current off constant current on |
| DL14 | MSB of character decode and selection of K8 wake-up edge: leading (DL14 = 0 ) or trailing (DL14 = 1) |  |
| DL15 | DL15 | Function |
|  | $\begin{aligned} & \hline 0 \\ & 1 \end{aligned}$ | wake-up of I/O enabled wake-up of I/O disabled |

Figure 1-4: Digit Latches/R Outputs

PUC-signal will reset all Digit Latches.
The digit latches are set by the SETR instruction and are reset by the RSTR instruction.
The value of the Y-REG determines which digit latch is affected. The data of the Digit Latches will be retained when the product is in Sleep mode or Off mode as long as the power is maintained.

### 1.5 DAM Operation

The DAM outputs are transferred into the ALU input regardless the values of the X-REG. This allows operation on data in DAM and one of the 14 memory banks (RAM) at the same time. The DMEA instruction is an example.

To write into the DAM, the content of the X-REG has to be 0111 or 1111. This can be accomplished by a LDX 7, LDX 15, or a TDL instruction.

If DAM is addressed by the X-REG, all instructions operating on memory will operate on DAM. An example of this is the execution of a TMA instruction while the X-REG contains a 7. This causes the transfer of the DAM into the ACC.

If X -register is 0111 or 1111 instructions which use RAM and DAM will use DAM only. An example of this is the DMEA instr.:

$$
\mathrm{DAM}+\mathrm{MEM}(=\mathrm{DAM})+\mathrm{SS} \rightarrow \mathrm{ACC} \quad \mathrm{DAM}^{*} 2+\mathrm{SS} \rightarrow \mathrm{ACC}
$$

### 1.6 ALU

The ALU (Arithmetic Logic Unit) can perform addition, subtraction (by two's complement) and comparison of 2 four bit numbers. Data from the Y -register, DAM, CKB multiplexer or RAM is selected by the P-multiplexer and added to or compared with data from CKB, Accumulator or RAM selected by the N-multiplexer. The adder-comparator portion of the ALU adds or compares the data. The status will be set or reset depending on the result. Data from the adder can be transferred to the Accumulator, the Y -register, or can be dumped in case the data is needed for comparison only.


Figure 1-5: Block diagram of ALU

### 1.7 CKB Memory Map Description

The TSS400/4 has a 4-bit wide bus line (CKB) that may carry constant data, K-line data, timekeeping data or bit data (SBIT, RBIT, TBIT, TBITA, TCTM, TIOM). Any of these instructions determine which data are valid on the bus line at that time. In order to minimize the physical size of the CKB logic, certain portions of the instruction map are reserved by the CKB logic for data from one (1) of the four (4) sources to be on the CKB bus line.

| Instruction Map Locations | Source of Data on CKB Bus |
| :---: | :--- |
| $008 \rightarrow 00 \mathrm{~F}$ | K-lines |
| $018 \rightarrow 01 \mathrm{~F}$ | TKP lines (timekeeping) |
| $020 \rightarrow 02 \mathrm{~F}$ | Bit data for TBIT, TCTM |
| $0 \mathrm{AO} \rightarrow 0 \mathrm{AF}$ | Bit data for |
|  | SBIT,RBIT,TBITA,TIOM |
| $040 \rightarrow 07 \mathrm{~F}$ | Constant data (I5 $\rightarrow$ I8) |
| $0 \mathrm{CO} 0 \rightarrow 0 \mathrm{FF}$ | Constant data (15 $\rightarrow$ I8) |

Figure 1-6: Instruction Restrictions

As shown in Figure 1-6, certain areas of the instruction map are decoded by the CKB logic and the CKB bus line will use data from one of its sources. Use micro-instructions CKM, $\overline{\text { CKP }}$, or $\overline{\text { CKN }}$ to transfer data to another portion of the processor. Please note that the source of data on the CKB bus is solely determined by a location in the instruction map as shown above.

### 1.8 K-Line Structure



Figure 1-7: K-Line Structure

The present state of Digit latch DL8 defines the state of K-Lines to be Input or Output:

Input if DL8 = "0"
Output if DL8 = " 1 ".
PUC signal will reset DL8 to " 0 " - Input.
The TAK instruction latches the 4 bit ACC into the output data register. If DL8 is " 1 " the data is available at the K-Lines:

K1 --- ACC1
K2 --- ACC2
K4 --- ACC4
K8 --- ACC8

The signals, applied at the K-pins, are read or tested directly or divided:

| Option K8-FF not used | Option K8-FF used |
| :--- | :--- |
| K1 $\rightarrow$ ACC1, MEM0 | K1 $\rightarrow$ ACC1, MEM0 |
| K2 $\rightarrow$ ACC2, MEM1 | K2 $\rightarrow$ ACC2, MEM1 |
| K4 $\rightarrow$ ACC4, MEM2 | K4 $\rightarrow$ ACC4, MEM2 |
| K8 $\rightarrow$ ACC8, MEM3 | K8/2 $\rightarrow$ ACC8, MEM3 |

Three instructions are implemented to read or test the information, applied at the K-Lines:

TKA, TKM and KNEZ.

### 1.9 I/O Structure



Figure 1-8: I/O Structure

The PUC signal as well as the IOIN instruction will reset the I/O pin to be an input (output buffer is 3-state).
Three instructions define the state of the I/O pin to be an output and will determine the data to be output:

- SETIO : set I/O pin to "1"
- RSTIO : reset I/O pin to "0"
- TSIO : output Status from the previous instruction output.


### 1.10 Clock

The Clock Output has 3 options that can be selected:

$$
\begin{aligned}
& \text { NONE }: \text { not selected } \\
& 256 \mathrm{~Hz}: f_{\text {Clock }}=\frac{f_{\text {TOSCIN }}}{128} \\
& 1024 \mathrm{~Hz}: f_{\text {Clock }}=\frac{f_{\text {TOSCIN }}}{32}
\end{aligned}
$$

When the processor is forced into the OFF mode, the oscillator is stopped and the TOSCIN pin is forced to $\mathrm{V}_{\mathrm{DD}}$ via a p-channel transistor. The signal at the pin 'Clock' remains at the logical level it had during executing the OFF instruction.

When using the Clock Signal together with the OFF mode pay attention to the application S/W and H/W.

If a defined logical level is necessary in the application-e.g. to avoid current consumption - the logical level has to be read e.g. by K-input to check the state of the Clock Signal before executing the OFF instruction.

Note: The signal at the pin 'Clock' is not the same as the signal at the Pin "TOSCIN".

## 2 Operational Description

There are three different machine states: DONE, ACTIVE and OFF. During the DONE state only display and timekeeping circuitry are active. DONE is a low power state.
In the ACTIVE state the chip is executing instructions from its internal ROM and maximum power is dissipated.
In the OFF state only RAM/DAM and the actual level of I/O, R outputs and K-I/O's remain unchanged. This is true in the DONE state as well.

The machine state transitions are illustrated in Figure 1-12.


Figure 2-1: Machine Status

### 2.1 ROM Decode

The ROM on the TSS400/4 has sixteen (16) pages with 256 words per page and ten bits per word. The ROM page address is contained in the ROM Page Address Register. The ROM word address is derived from the program counter.

The four bits of the page register are decoded in a 1 of 16 decode. A bus runs from the 1 of 16 page decode to the ROM and addresses the proper page.

The eight bits of the program counter are decoded in a 1 of 256 decode. A bus runs from the 1 of 256 word decode to the ROM and addresses one word on each page. Page and word decode select together the particular word.

### 2.2 Program Counter and Subroutine Register

A bus from the program counter (PC) runs to a 1 of 256 decode and to a feedback network, which is used to change the state of the program counter in order to obtain the next ROM word address. When a CALL instruction is executed, the eight PC bits are stored in the first of a three levels of the subroutine stack. Each successful CALL instruction pushes down the stack. As many CALL instructions as necessary may be executed, but only the three most recent return addresses are stored. All previous return addresses are lost. Each RETN instruction, up to a maximum of three consecutive, pops up the stack. Any RETN instructions encountered when the device is not in a subroutine will be treated as no-op instructions.

### 2.3 ROM Page Address Register and Page Buffer

The ROM page address register, like the program counter, is capable of three levels of subroutines.

When a CALL instruction is executed, the four page-address bits are stored in the first of a three level subroutine stack. Each successful CALL instruction pushes down the stack. As many CALL instructions as necessary may be executed, but only the three most recent return addresses are stored. All previous addresses are lost. Each RETN instruction, up to a maximum of three consecutive, pops up the stack. Any RETN instruction encountered when the device is not in a subroutine will be treated as a no-op instruction.

When a LDP instruction is executed, the page address is loaded into the Page Buffer. The Page Address is transferred to the ROM Page Address Register when a CALL or BRANCH instruction is successfully executed. If the CALL or BRANCH instruction is unsuccessful or an RETN instruction is
executed between the LDP and CALL instructions, the Page Buffer and the ROM Page Address Register remain unchanged.
After an LDP-RETN sequence, the ROM page Address Register remains unchained by CALL and BRANCH instructions.

### 2.4 Instruction Decode

First a ten-bit word from the ROM goes to the instruction decode, where three types of instructions are decoded:

- programmable instructions
- fixed instructions
- CKB instructions

If 1 of the 48 programmable instructions is decoded as true, a set of microinstructions will be decoded. These micro-instructions control lines which handle one space too much various logic blocks.

If 1 of the 29 fixed instructions is decoded as true, the output of the respective instruction will set a control line used by a particular logic circuit.

If a CKB instruction is decoded as true, the 4 least significant bits of the ROM word, or the 4 K -lines, or the 4 timekeeping lines are passed into the ALU (depending on which instruction is decoded).

### 2.5 Processor Enable and Time Base Multiplexer

The software determines when the processor is disabled by executing a DONE instruction. The hardware keeps a timer up to 15 seconds; the software must keep time for all times part 15 seconds (minutes, hours, a.m/p.m., day of the week, date, and month). A calculation must not take longer than 15 seconds. In case a calculation does take longer by software an periodical interrupt of the calculation must occure to enable the time keeping update.
The processor enable logic "wakes-up" the processor from DONE state depending on DL12, to allow the update of the timekeeping.

The processor-logic-enable also senses the K-lines K1, K2, K4, K8 and I/O line.
"Wake-up" from OFF state is only possible via Init, K-lines or I/O line; program execution starts at page $15, \mathrm{PC}=>\mathrm{FF}$.


Note: ' $v$ ' - logical OR, '^' - logical AND, $X$ - don't care

Figure 2-2: Table for ext. Wake-up Conditions


Note: Wake-up occurs when 'wake-up' signal is Low AND processor in DONE/OFF mode
Delay line is active if processor is active ( 5 to 6 instructions)
Delay line is inactive if processor is in DONE/OFF mode: No Delay DL14 selects the logical state of K8 for 'wake-up'signal

Figure 2-3: Schematic of Wake-up Path

### 2.6 Processor Frequency

The processor frequency is derived from the internal RC-MOS Oscillator. The typical characteristic of this Oscillator is shown in Figure 6-1.
This internal MOS Oscillator frequency can be overwritten by an external Oscillator connected to Pin PFRQ. The frequency range for the external Oscillator is defined in Chapter 6.2 Operating Conditions.

### 2.7 Timer Oscillator

## Crystal Oscillator

A 32.768 Hz signal of the crystal oscillator is fed into the crystal clock generator, which divides the frequency by four and generates four phase clocks. These clocks are divided down through a series of divide-by-two circuits into the frequencies needed for the timekeeping functions. A signal KSC is produced by the dividing circuit. This signal is used in by logic of the Common Generator, to generate the signals on the two or four common segment lines.

## RC Oscillator

Using the RC oscillator (OPTION "TRC") instead of the crystal oscillator, the same applies as described in Section 2.7 (see Figure 2-4).


Figure 2-4: Option TIMOSC


Figure 2-5: TRC Oscillator Frequency

### 2.8 Time Data Multiplexer

The TSS400/4 processor does not need to be active all the time. The processor is turned on only when needed to perform a software function or to update timekeeping. The processor can "wake-up" to update timekeeping either once per second or $x$-times per second (Option).
This is determined in the Time Data Multiplexer. When DL12 is high, the processor wakes-up $x^{*}$-times per second, and when DL12 is low, the processor wakes-up once per second. This also determines the data used timekeeping.

[^2]Revision 1.1, October 1991

When DL12 is high, the 4-bit timekeeping data represents a time of $0 / 16$ to $15 / 16$ of a second, and when DL12 is Low, the data represent a time of 0 to 15 seconds.

The timekeeping can be accessed via CKB-Bus by software.

### 2.9 CKB (Constant, K-lines, Bit and Time Multiplexer)

All constant data used by the Y-REG, the Accumulator, or memory must pass the CKB. The logic of the CKB determines according to the used instruction whether to select constant, K-lines, bit logic, or timekeeping data to be transferred to various parts of the TSS400/4.

### 2.10 Branch/Call Control

When a BRANCH is encountered the Branch/Call Control Logic effects the program counter to dump the present ROM word address and accept a new one. When a CALL is encountered the Branch/Call Logic effects the program counter and the ROM page register to move their present contents into the subroutine latches and accept new addresses. A RETN forces the Branch/Call Control Logic to return the program counter to the stored address plus one. The stored address is the address when the call was encountered. The ROM page address register returns to the address it contained before the CALL. If a RETN is encountered while the TSS400 is not in a subroutine, it is regarded as a no-op and ignored. (See Status paragraph).

### 2.11 RAM Address/Character Decode Multiplexer

The RAM Address/Character Decode Multiplexer combines 2 blocks:

1) Multiplexer between the Y-Reg and the Accumulator. The output of the multiplexer is fed into the Decoder.
2) Decoder which decodes either the RAM word address from the Y Register or the LCD character address from the Accumulator.

### 2.12 Write Multiplexer

The Write Multiplexer determines whether data is to be put into the RAM, the DAM, or the P-Multiplexer in the ALU. The data is taken from the CKB logic or from the Accumulator. The Write Multiplexer is controlled by software.

### 2.13 X-Decode

The X-REG is decoded by the X-Decode to select a particular RAM bank. The value of the DAM latch, which enables DAM and disables RAM or vice versa is also decoded by the X -REG.

### 2.14 RAM Word Decode

The RAM Address/Character Decode Multiplexer feeds all 4 bits of the Y REG into a 1 of 16 decode. The state of the sixteen outputs of the RAM word decode which of the sixteen words in each bank of the RAM and DAM or which of the sixteen Digit latches is addressed.

### 2.15 Character Decode

The Character Decode uses DL14, status, and the four Accumulator bits to do a 1 of 64 character decode. The 64 signals are then transferred into the output PLA, where they are converted into a seven-segment output. (The Character Decode is illustrated in the Gate Level PLA paragraph.)

### 2.16 Segment Latches

After decoding and converting the characters into segment outputs, they are latched in Segment latches when the proper Y -pointer is set and a TDO instruction is executed.

### 2.17 Segment Drivers

The segment data is transferred to the Multiplexing Segment Drivers which convert the seven segments and the Segment H information into 2 Mux or 4Mux segment information, which is output and used to turn on the LCD segments.
In test mode some of the LCD-Outputs do have other functions.

### 2.18 Power Up Clear

There is an time interval between power is applied to the TSS400/4 and the starting of the clocks. The Power Up Clear (PUC) signal sets the page and word address and enables the PC after the clocks have started.
When the voltage is applied, PUC starts the program execution on page $15, \mathrm{PC}=>00$. A low signal at $\overline{\mathrm{INIT}}$ pin creates the same function as power being applied.
When the Processor is activated from Done or OFF mode via a K-input-I/O or by a timekeeping update, the program execution begins at Page 15, $P C=>F F$.

### 2.19 Status

Status is held in a single bit latch. When this bit is set, which is its normal state, and a BR or CALL is encountered, the BR or CALL will be executed. When status is reset immediately before a CALL or BR, the instruction will not be executed successfully and the Program Counter will continue incrementing.

Status will remain reset (0) for only one instruction cycle.
Status can be unconditionally reset by instruction ACACC 0.
Status can be unconditionally set by instruction ACYY 0.

### 2.20 P-Multiplexer

The P-Multiplexer part of the ALU selects data from the Y-REG, the CKB, the RAM, or the DAM, and feeds this data to the Adder-Comparator part of the ALU. (See Figure 1-5)

### 2.21 N -Multiplexer

The N-Multiplexer part of the ALU selects data from the CKB, the Accumulator, or the RAM, and feeds this data to the Adder-Comparator portion of the ALU. (See Figure 1-5)

### 2.22 Adder-Comparator

The Adder-Comparator portion of the ALU simultaneously adds and compares the data in the $N$ and $P$ Multiplexers. Information from the comparator is used in determining status. Data from the Adder can be sent to the Accumulator or the Y-REG, or can be dumped if the data is needed for comparison only.

### 2.23 Accumulator and Y-Register

The Accumulator is a four-bit register that gets its content from the AdderComparator. The Y-Register (Y-REG) holds the RAM word address and is used to select one of sixteen Digit latches.

## 3 Analog/Digital-Converter (ADC)

The A/D-Converter is specially designed for:

- 1-2 KOhm-temperature Si-sensors
- Pt100/Pt500/Pt1000 Elements in conjunction with internal current source
- Silicon pressure sensors

It is in no way restricted to those applications.
The A/D-Converter compares the external analogue input voltage with an internal voltage.


Figure 3-1: Principle of A/D-Converter

### 3.1 Description of Conversion

The A/D-Conversion is done by executing a software program.
Five instructions are added to the instruction set for controlling the ADC:

- SCSV: switch converter's supply voltage on
- RCSV: reset converter's supply voltage
- RCI: reset converter's comparator inputs to inverted
- TCTM n: transfer comparator (output) to memory - selected by X-REG and Y-REG while $n$ identifies the bit - and set the next lower bit to high (if $n$ is $1,2,3$ ).
- TRTM $n$ : transfer range to memory bit $n(n=0,1,2,3)$.

The A/D-converter consists of:

- a D/A converter (DAC) as voltage reference source
- a Comparator
- an analog switch to interchange input signals at comparator
- an analog multiplexer (4 to 1) to select one input (A1-A4)
- a constant current source; programmable by one external resistor and enabled or disabled by DL13
- the SV ${ }_{\text {DD }}$ control
- a voltage source (for battery check)

As shown in the Figure 3-1, the instruction SCSV switches the supply voltage to the AID Converter and PIN SV ${ }_{\text {DD }}$ on - instruction RCSV switches it off. The voltage is also switched-off during Power on/INIT and if the processor is in DONE/OFF mode.

The D/A converter is controlled by 12 bits. These 12 bits are memory bits located in the DAM.

DAM

| Y-REG | BIT3 | BIT2 | BIT1 | BIT0 |
| :---: | :---: | :---: | :---: | :---: |
| 13 | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ |
| 14 | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ |
| 15 | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

The content of the 12 DAM bits is linearly converted into an analogue voltage by the DAC. This output voltage is fed into the analogue cross bar switch in front of the comparator. The comparator compares this voltage with the analogue input voltage at the selected input A1 ... A4.
A special instruction TCTM is available to do a simple successive approximation by software. This instruction transfers the comparator output to the pre-selected DAM-bit and sets the next lower bit at the same DAM address.

The starting value should be $>800$ (midpoint of range). The time constant of the DAC network requires some wait cycles between the TCTM instructions:

| affected bit | instructions before TCTM |
| :--- | :---: |
| MSB | 5 |
| MSB-1 | 5 |
| MSB-2 | 5 |
| MSB-3 | 5 |
| MSB-4 | 4 |
| MSB-5 | 4 |
| MSB-6 | 4 |
| MSB-7 | 4 |
| MSB-8 | 3 |
| MSB-9 | 3 |
| MSB-10 | 3 |
| LSB | 3 |

Instruction SCSV sets the analog crossbar switch at the comparator input and instruction RCI resets it. Two conversions - one with set and one with reset switch - eliminate the offset of the comparator. The two conversion results are added. The sum is twice the value of the conversion formula.

To ensure that the measurement is within the valid range, a special instruction TRTM is included. This instruction sets the addressed RAM bit to " 0 " if the measured value is greater than $>000$ and less than $>$ FFF. Otherwise the bit is set ("1"): selected analog input voltage is out of A/Dconversion range.

Revision 1.1, October 1991

Optionally, there are four conversion ranges for the ADC available. One and only one must be selected. This selection is done in connection with the ROM programming.

## Conversion formula: (for nominal values)

with: all voltages are referenced to AG


$$
\begin{gathered}
\text { with: } 1_{18} \leq N \leq \mathrm{NFE}_{18} \\
\text { single messuremert }
\end{gathered}
$$

with: $\mathrm{N}_{\mathrm{L}} \leq \mathrm{N} \leq \mathrm{N}_{\mathrm{HL}}$

Range large $\quad: \mathrm{a}=0.101213203 ; \mathrm{k}=0.000096090233{ }^{*} \mathrm{~N}$
Range small $: a=0.231271438 ; k=0.000043048228{ }^{*} \mathrm{~N}$
Range medium-low : $\mathrm{a}=0.1002948411 ; \mathrm{k}=0.000073816955{ }^{*} \mathrm{~N}$
Range medium-high : $\mathrm{a}=0.2326179386 ; \mathrm{k}=0.000065411591$ * N
Note: $N_{L L}=$ digital value analog input voltage lower limit.
$\mathrm{N}_{\mathrm{HL}}=$ digital value analog input voltage higher limit.

### 3.2 Battery Check

The stable internal voltage source ( $\mathrm{V}_{\mathrm{REF}}$ ) is applied to the comparator instead of an external voltage signal at the analog inputs. To the other input of the comparator, the DAC output voltage is applied. This DAC output $\left(V_{D A C}\right)$ is a linear function of $S V_{D D}$, that is nearly identical to $V_{D D}$ :

$$
V_{D A C}=(a+K \cdot N) \cdot S V_{D D}
$$

The comparator allows to determine the $N$ value for which $V_{D A C}=V_{\text {REF }}$ and it follows:

$$
S V_{D D}=V_{D D}=\frac{V_{R E F}}{a \cdot K \cdot N}
$$

### 3.3 Current Source

The current source and the A/D converter are ratiometric. Voltage used for A/D conversion and the reference voltage ( $\mathrm{V}_{\mathrm{I}}$ ) used to set the current of the current source are proportional to $\mathrm{SV}_{\mathrm{DD}}$ and have a fixed ratio to each other. This ensures optimum tracking. The current source is activated with DL13 set AND with SV ${ }_{\text {DD }}$ on; both conditions are necessary to switch on the current source.

The current, passed via an analog input to a sensor, is calculated:

$$
I_{A n}=\frac{V_{\text {Rext }}}{R_{\text {ext }}}
$$

The current, flowing through a sensor (e.g. resistive temperature sensor), generates a voltage drop at the sensor which is available at the analog input for measurement with the A/D converter:

$$
\begin{aligned}
& V_{\text {in }}=I_{A n} \cdot R_{\text {in }} \quad \text { with } R_{\text {in }} \text { is sensor's resistance } \\
& V_{\text {in }}=V_{\text {Rext }} \cdot \frac{R_{\text {in }}}{R_{\text {ext }}}
\end{aligned}
$$



Figure 3-2: Principle of Current Source

| DL13 | DL11 | DL10 | DL9 | analog input selected, <br> Current Source (CS) on/off |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | A1, CS off |
| 0 | 0 | 1 | 0 | A2, CS off |
| 0 | 1 | 0 | 0 | A3, CS off |
| 0 | 1 | 1 | 0 | A4, CS off |
| 1 | 0 | 0 | 0 | A1, CS on |
| 1 | 0 | 1 | 0 | A2, CS on |
| 1 | 1 | 0 | 0 | A3, CS on |
| 1 | 1 | 1 | 0 | A4, CS on |
| X | $X$ | $X$ | 1 | battery check, CS off |

Figure 3-3: Current Source


## 4 Display

### 4.1 Gate Level PLA

The TSS400/4 has a 1 of 64 decode for character output. The decode has six input lines; from the Most Significant Bit (MSB) to the Least Significant Bit (LSB) they are:

- DL14
- Status bit
- The four Accumulator bits from ACC8 to ACC1.

The decoded information is then transferred to a bus to the Segment PLA. The Segment PLA can be gate-level programmed to set the state of each of the seven segment lines, A-G, high or low depending on the decode information.
The Segment H is controlled by SDP/RDP instruction.


Figure 4-1: Decode and OPLA for Segment Output

### 4.2 Common Select Lines

There are four Common Select Lines. Each has a unique output waveform that when used in combination with the twenty (20) Select Lines can control 40/80 different segments on a liquid crystal display (LCD).
The combination of Common Select Lines to Segment Lines is shown in the next paragraph.


Figure 4-2: 4Mux LCD Application Example


Figure 4-3: 2Mux LCD Application Example

### 4.3 Select Lines

Up to twenty Select Lines are available as outputs. Each Select Line defines two/four Segments as shown below. A 64-term gate programmablesegment PLA (decoded by ACC1, ACC2, ACC4, ACC8 Status, DL14) and SGH determines which segments are to be turned on.

These are then loaded into the Segment Latches by Y-Decoder/TDO instruction and time-multiplexed to the Output Select Lines.

## TSS400/4 Segment Latch Structure

(Standard Common-Segment-Y option)*).

## 1/2 duty cycle (2 mux) <br> 1/4 duty cycle (4 mux)

| Select Line | Segments | Loaded by |
| :---: | :---: | :---: |
|  | $\begin{array}{ll} \hline C & C \\ O & O \\ M & M \\ 3 & 4 \\ \hline \end{array}$ |  |
| S1 | B H | Y0/TDO |
| S2 | A F | YO/TDO |
| S3 | G E | YO/TDO |
| S4 | C D | Yo/TDO |
| S5 | B H | Y1/TDO |
| S6 | A F | Y1/TDO |
| S7 | G E | Y1/TDO |
| S8 | C D | Y1/TDO |
| S9 | B H | Y2TDO |
| S10 | A F | Y2TDO |
| S11 | G E | Y2TTDO |
| S12 | C D | Y2TTDO |
| S13 | B H | Y3/TDO |
| S14 | A F | Y3/TDO |
| S15 | G E | Y3/TDO |
| S16 | C D | Y3/TDO |
| S17 | B H | Y4/TDO |
| S18 | A F | Y4/TDO |
| S19 | G E | Y4/TDO |
| S20 | C D | Y4/TDO |

$\left.\begin{array}{|c|c|c|}\hline \begin{array}{c}\text { Select } \\ \text { Line }\end{array} & \text { Segments } & \begin{array}{c}\text { Loaded } \\ \text { by }\end{array} \\ \hline & \text { C C C C } & \\ & \text { O O O O } \\ \text { M M M M } \\ \text { 1 2 3 4 }\end{array}\right)$
*) Note: The Y-Address of each Segment Group is configurable to application needs. The definition is done together with the ROM programming (via mask).

### 4.4 Display Drive Waveforms

Display-Drive waveforms are shown in Figure 4-4 for $1 / 2$ and $1 / 4$ duty cycle LCD. The internal logic signal KSC initiates voltage changes in the display voltages.
KSC has a frequency of 512 Hz and is active for 122 micro-seconds ( t' $_{\text {TOSCIN }}=32768 \mathrm{~Hz}$ ).


Figure 4-4: Display Drive Waveforms (Standard Gate Placement) e.g. Number 4: Segment 'BCFG' on - 'ADEH' off

## 5 Instruction Set Description

The following abbreviations will be used in describing the Instruction Set:

| ACC | $=$ Accumulator |
| :--- | :--- |
| CONSTANT | $=0-15$ |
| LSB | $=$ Least Significant Bit |
| MEM | = Memory as pointed to by $X$ and $Y$ Registers |
| MSB | = Most Significant Bit |
| REG | = Register |
| SS | = Special Status Latch |
| <> | not equal |
| ACC | = not Accumulator |


| CODE | MNEMONIC | DESCRIPTION |
| :---: | :---: | :---: |
| 070-07F | ACACC | Add a constant to ACC and store in ACC; ; carry status = 1 |
| 0F0-0FF | ACYY | Add a constant to Y-REG |
| OEO-EF | ALEC | If ACC less than or equal CONSTANT, status $=1$ |
| 001 | ALEM | If ACC is less than or equal to MEM, status $=1$ |
| 015 | AMAAC | Put MEM + ACC into ACC; if carry, status $=1$ |
| 200-2FF | BRANCH | If status $=1$, branch to location $>00$ to $>$ FF as pointed to by label; else increment Program Counter |
| 300-3FF | CALL | If status $=1$, then execute CALL to location $>00$ to $>$ FF as defined by label. The 3level subroutine stack retains the return address. |
| 012 | CCLA | If $S S=0$, put 0 in $A C C$; if $S S=1$, put 1 in ACC |
| 006 | CLA | Clear ACC |
| 0B2 | COMX8 | Complement MSB of X-REG |
| 031 | CPAIZ | Put 2's complement of ACC into ACC; if initial $A C C=0$, status $=1$ |
| 018 | CTMDYN | If both Add Latch and SS are set or both are reset, put ACC into MEM; Decrement $Y$-REG; if initial $Y<>0$, status $=1$ |
| 007 | DMAN | Put MEM-1 into ACC; if MEM $<>0$, status $=1$ |

5.1 Functional Description (alphabetical listing - continued)

| CODE | MNEMONIC | DESCRIPTION |
| :---: | :---: | :---: |
| 010 | DMEA | Put DAM + MEM + SS into ACC |
| 011 | DNAA | Add DAM, $\overline{A C C}$ and $S S$ and store it in ACC |
| OBE | DONE | Turns the processor portion of the chip off |
| 004 | DYN | Decrement Y -REG; if initial $\mathrm{Y}<>0$ then status $=1$ |
| 032 | IMAC | Store in ACC the result of MEM +1 ; if MEM $=15$ then status = 1 |
| 01A | IOIN | I/O Output buffer becomes 3-state to be Input for ext. signals |
| 005 | IYC | Increment $Y$-REG; if initial $Y=15$ then status $=1$ |
| OOE | KNEZ | If K -lines $<>0$ then status $=1$. If status is set to 0 then another KNEZ 6-instruction cycles later must be done; if status $=0$ again you can be certain that K -lines $=0$. |
| 080-08F | LDP | Load Constant into ROM page buffer |
| 090-09F | LDX | Load Constant into X-REG. I(5) = LSB, $\mathrm{I}(8)=$ MSB. RESET DAM-LATCH |
| 009 | MNEA | If MEM <> ACC then status $=1$ |
| 033 | MNEZ | If MEM <> 0 then status = 1 |

### 5.1 Functional Description (alphabetical listing - continued)

| CODE | MNEMONIC | DESCRIPTION |
| :--- | :--- | :--- |
| 013 | NDMEA | Add MEM, $\overline{\text { DAM }}$ and SS and store it in <br> ACC |
| $0 B 7$ | OFF | Turns the Processor and Timer off <br> Logical OR of MEM and $\overline{\text { ACC }}$ stored in |
| 014 | ORMA | ACC <br> Logical OR of MEM and $\overline{\text { ACC }}$ stored in |
| 017 | ORMNAA | ACC |

0A4-0A7 RBIT Reset one of 4 MEM bits as addressed by l(8), l(9)
LSB- Bit $2^{0} \rightarrow$ @I(7), @I(8) Bit $2^{1} \rightarrow \quad \mathrm{I}(7), \quad @ 1(8)$ Bit $2^{2} \rightarrow$ @ $(7), \quad \mathrm{I}(8)$
MSB- Bit $2^{3} \rightarrow \quad \mathrm{l}(7), \quad \mathrm{l}(8)$

| OBD | RCI | Reset Comparator offset switch to <br> INVERTED |
| :--- | :--- | :--- |
| OBB | RCSV | Reset Converters Supply Voltage and Pin <br> SV |
| OB6 | RDP | Reset Decimal Point (Segment H) <br> 0B4 |
| REAC | Reset END-Around-Carry (SS) |  |
| 0BF | RETN | Reset add latch and branch latch. When in <br> CALL, RETN also transfers subroutine <br> register to Program Counter and transfers <br> ROM page register to Page Buffer + Page <br> Address |

### 5.1 Functional Description (alphabetical listing - continued)

CODE MNEMONIC DESCRIPTION
00B RSTIO Reset I/O pin - I/O Output buffer is enabled

036 RSTR

| 0B1 | SAL |
| :--- | :--- |
| 030 | SAMAN |
|  |  |
| OB3 | SBL |
| OAO-A3 | SBIT |
| OBA | SCSV |


| OB9 | SDP |
| :--- | :--- |
| OB5 | SEAC |
| OOC | SETIO |
| OOD | SETR |


| 0B8 | TAK |
| :--- | :--- |
| 03F | TAM |
| 0D0-DF | TAMACS |

03C
TAMDYN

Set ADD latch
$\mathrm{MEM}+\overline{\mathrm{ACC}}+1 \rightarrow \mathrm{ACC}$; if MEM $\geq A C C$ then status $=1$
Set Branch Latch
Set 1 of 4 MEM bits as addressed by 18 and 19
Set Converters Supply Voltage and Pin SV ${ }_{\text {DD }}$. The Comparator offset is switched to NONINVERTED
0B9 SDP Set Decimal Point (Segment H)
Set End-Around-Carry (SS)
Set I/O - I/O Buffer is enabled
Set Digit Latch pointed to by Y-REG

Transfer ACC to K-latch for Output
Transfer ACC to MEM
Transfer ACC to MEM; Add a constant to ACC and store in ACC; if Add Latch is set and carry from ALU on previous or present instruction is $=1$, set SS; reset otherwise; if Add Latch is reset and if carry from ALU on only previous instruction $=1$, set SS
Transfer ACC to MEM; decrement $Y$-REG; if initial $Y<>0$, status $=1$

| CODE | MNEMONIC | DESCRIPTION |
| :---: | :---: | :---: |
| 03D | TAMIYC | Transfer ACC to MEM; Increment Y-REG, if initial $Y=15$, status $=1$ |
| 03E | TAMZA | Transfer ACC to MEM; clear ACC |
| 038 | TAY | Transfer ACC to Y-REG |
| 020-023 | TBIT | Test 1 of 4 MEM bits as addressed by 18 and I9. If MEM bit EQ 1, status = 1 |
| OA8-0AB | TBITA | Test 1 of 4 ACC bits as addressed by 18 and I9. If ACC bit EQ 1, status $=1$ |
| OCO-0CF | TCA | Transfer a Constant to ACC |
| 040-04F | TCY | Transfer a Constant to Y-REG |
| 060-06F | TCMIY | Transfer a Constant to MEM; increment $Y$ REG |
| 024-027 | TCTM | Transfer Comparator to 1 of 4 MEM bits as addressed by 18 and 19 , the next lower nibble at the same is set. |
| 016 | TDA | Transfer DAM to ACC independent of X |
| OBC | TDL | Toggle DAM Latch |
| OBO | TDO | Load the Segment Latches with the segment data (A-G) and decimal point into the latches being addressed by $Y(0-4 / 9)$ |
| OAC-OAF | TIOM | Transfer I/O to 1 of 4 MEM bits as addressed by 18 and 19 (Level sensed during previous instr.) |
| 008 | TKA | Transfer K-lines to ACC |
| 00A | TKM | Transfer K-lines to MEM |
| 039 | TMA | Transfer MEM to ACC |
| 01D | TNEA | If Timer <> ACC, status $=1$ |
| 01C | TNEM | If Timer $<>$ MEM, status $=1$ |

5.1 Functional Description (alphabetical listing - continued)
CODE MNEMONIC DESCRIPTION

| 03A | TMY | Transfer MEM to Y-REG |
| :---: | :---: | :---: |
| 028-02B | TRTM | Transfer Range (ADC) to 1 of 4 MEM as addressed by 18 and 19 (ADC in Range: 0; out of Range: 1) |
| 00F | TSIO | Transfer Status to I/O - I/O Buffer is enabled |
| 01E | TTA | Transfer seconds to ACC if DL12 $=0$; transfer $1 / 16$ seconds to ACC if DL12 $=1$ |
| 01B | TTM | Transfer seconds to MEM if DL12 $=0$; transfer $1 / 16$ seconds to MEM if DL12 $=1$ |
| 01F | TTY | Transfer seconds to Y-REG if DL12 = 0 ; transfer $1 / 16$ seconds to $Y$-REG if DL12 = 1 |
| 03B | TYA | Transfer Y-REG to ACC |


| 019 | XDA |
| :--- | :--- |
| 003 | XMA |


| 002 | YNEA |
| :--- | :--- |
| $050-05 F$ | YNEC |

If $Y$-REG $<>A C C$, status $=1$
If $Y$-REG $<>$ Constant, status $=1$

### 5.2 10-Bit Instruction Map

|  | LSB |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 00 |  | ALEM | YNEA | XMA | DYN | IYC | CLA | DMAN |
| 01 | DMEA | DNAA | CCLA | NDMEA | ORMA | AMAAC | TDA | ORMNAA |
| 02 | TBIT |  |  |  | TCTM |  |  |  |
| 03 | SAMAN | CPAIZ | IMAC | MNEZ |  |  | RSTR |  |
| 04 | TCY |  |  |  |  |  |  |  |
| 05 | YNEC |  |  |  |  |  |  |  |
| 06 | TCMIY |  |  |  |  |  |  |  |
| 07 | ACACC |  |  |  |  |  |  |  |
| 08 | LDP |  |  |  |  |  |  |  |
| 09 | LDX |  |  |  |  |  |  |  |
| OA | SBIT |  |  |  | RBIT |  |  |  |
| OB | TDO | SAL | COMX8 | SBL | REAC | SEAC | RDP | OFF |
| 0 C | TCA |  |  |  |  |  |  |  |
| OD | TAMACS |  |  |  |  |  |  |  |
| OE | ALEC |  |  |  |  |  |  |  |
| OF | ACYY |  |  |  |  |  |  |  |
| $\begin{gathered} 10 \text { to } \\ 1 \mathrm{~F} \\ \hline \end{gathered}$ | DISABLED |  |  |  |  |  |  |  |
| $\begin{gathered} 20 \text { to } \\ 2 \mathrm{~F} \\ \hline \end{gathered}$ | BRANCH |  |  |  |  |  |  |  |
| $\begin{gathered} 30 \text { to } \\ 3 F \end{gathered}$ | CALL |  |  |  |  |  |  |  |

Note: e.g. SETR : fixed instruction

+ XDA : micro/fixed instruction other : micro instructions


### 5.2 10-Bit Instruction Map (Continued)

|  | LSB |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | 8 | 9 | A | B | C | D | E | F |
| 00 | TKA | MNEA | TKM | RSTIO | SETIO | SETR | KNEZ | TSIO |
| 01 | CTMDYN | + XDA | IOIN | TTM | TNEM | TNEA | TTA | TTY |
| 02 | TRM |  |  |  |  |  |  |  |
| 03 | TAY | TMA | TMY | TYA | TAMDYN | TAMIYC | TAMZA | TAM |
| 04 | TCY |  |  |  |  |  |  |  |
| 05 | YNEC |  |  |  |  |  |  |  |
| 06 | TCMIY |  |  |  |  |  |  |  |
| 07 | ACACC |  |  |  |  |  |  |  |
| 08 | LDP |  |  |  |  |  |  |  |
| 09 | LDX |  |  |  |  |  |  |  |
| OA | TBITA |  |  |  | TIOM |  |  |  |
| OB | TAK | SDP | SCSV | RCVS | TDL | RCl | DONE | RETN |
| 0C | TCA |  |  |  |  |  |  |  |
| OD | TAMACS |  |  |  |  |  |  |  |
| OE | ALEC |  |  |  |  |  |  |  |
| OF | ACYY |  |  |  |  |  |  |  |
| $\begin{gathered} 10 \text { to } \\ 1 \mathrm{~F} \\ \hline \end{gathered}$ | DISABLED |  |  |  |  |  |  |  |
| $\begin{gathered} 20 \text { to } \\ 2 \mathrm{~F} \\ \hline \end{gathered}$ | BRANCH |  |  |  |  |  |  |  |
| $\begin{gathered} 30 \text { to } \\ 3 F \end{gathered}$ | CALL |  |  |  |  |  |  |  |

Note: e.g. SETR : fixed instruction

+ XDA : micro/fixed instruction
other : micro instructions


## 6 Electrical Description

### 6.1 Absolute Maximum Ratings

Voltage applied at $\mathrm{V}_{\mathrm{DD}}$ to $\mathrm{V}_{\mathrm{SS}} \quad-0.3 \mathrm{~V}$ to +7.0 V
Voltage applied to any pin
(referenced to $\mathrm{V}_{\mathrm{SS}}$ )
$\mathrm{V}_{\mathrm{SS}}-0.3 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{DD}}+0.3 \mathrm{~V}$
Diode current at any device terminal $+/-2 \mathrm{~mA}$
Storage Temperature
$-55^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
6.2 TSS400/4-Operating Conditions (short form)

| Parameter: | MIN | NOM | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: |
| Supply Voltage, $\mathrm{V}_{\mathrm{DD}}$ | 2.6 | 3.0 | 5.5 | V |
| Supply Voltage, V ${ }_{\text {SS }}$ | 0.0 | 0.0 | 0.0 | V |
| Operating Temperature |  |  |  |  |
| Range I | -25 | 27 | +85 | ${ }^{\circ} \mathrm{C}$ |
| Range A | -40 | 27 | +125 | ${ }^{\circ} \mathrm{C}$ |
| Timer Frequency (XTAL) ${ }^{*}$ )Timer Frequency (ext) | 2032.768 |  | 100 | $\begin{aligned} & \mathrm{KHz} \\ & \mathrm{KHz} \end{aligned}$ |
| Processor Frequency internal ( $f_{\text {proc }}$ ) Characteristics: see Figure 6-1 | 700 |  |  |  |
| Processor Frequency external, PFRQ Pin (f proc) | 400 | 700 | 1000 | KHz |
| ${ }^{* *}$ ) Instruction execution time | 15 | 8.5 | 6 | $\mu \mathrm{Sec}$ |
| Capacitance of Display: |  |  |  |  |
| any Segment |  |  | 200 | pF |

*) Note: If LCD-display is used be sure that the frequency meets the limits of display frame rate (DFR $\left.=\frac{\text { timer frequency }}{512}\right)$
${ }^{* *}$ ) Note: Each instruction needs 6 cycles of the

$$
\text { processor frequency } f_{\text {proc }}=t_{\text {instruct }}=\frac{6}{f_{\text {proc }}}
$$

The technical parameter are the same as mentioned in the TSS400 User's Guide. Please refere to this. The same derivates as with the TSS400 are available with the TSS400/4.

### 6.3 Typical RC-MOS Oscillator Characteristics

Not available yet.

Figure 6-1:

### 6.4 Schematics of Inputs/Outputs



Figure 6-2: Schematic of K-I/Os


Figure 6-3: Schematic of I/O

## Revision 1.1, October 1991

### 6.4 Schematics of Inputs/Outputs (continued)



Figure 6-4: Schematic of XTAL Oscillator


Figure 6-5: Schematic of SVDD

## APPENDIX A - Software Restrictions

1. Carefully examine the states of inputs and outputs when DONE or OFF instruction is used. Prevent additional DC current in low power consumption mode caused by the states of inputs and outputs.
2. Pay attention to the states of $\mathrm{I} / \mathrm{O}$ pin and the K-lines while being in DONE/OFF. The wake-up can be triggered by K1, K2, K4, K8 and I/O but only if all were Low before one of these Lines goes High.
3. The processor begins execution at page 15; $\mathrm{PC}=00$ the first time power is applied. Each time a "wake-up" signal occurs, the processor begins execution at page 15; $\mathrm{PC}=>\mathrm{FF}$.
4. For operations which require more then 15 seconds of processing, the software should periodically update the timekeeping since the chip provides only modulo-16-sec.
5. The SAL instruction may cause the End-Around-Carry (SS) to change state falsely in either direction. Thus, after an SAL, the SS should be set to the desired state with a SEAC or REAC. Also, if both the Add latch and SS must be set to a desired state, the SAL should be done first. For example, in the basic Add loop where both the Add latch must be set and the SS reset, the SAL should be executed prior to the REAC.
6. The TTA and TTM instructions:

It is possible to get a false intermediate reading because of the Timer and Processor operate asynchronous. To prevent this, the time check must be repeated until two successive tests yield the same value.
7. Between a wake-up from the timer and a DONE instruction there must be a minimum number of instructions N :

$$
N>=\frac{4 \times \text { processor frequency }}{6 \times \mathrm{f}_{\mathrm{TOscIN}}}+1
$$

8. To execute a three instruction BCD addition, the following sequence of instructions may be used:

| LOC | INSTRUCTION |  | COMMENT |
| :--- | :--- | :--- | :--- |
| 001 |  | SBL |  |
| 002 |  | CALL | START | | Before jumping to |
| :--- |
| subroutine, set Branch |
| Latch |

9. SBL instruction:

If Branch Latch is set use only Branches which can operate on an instruction. In other ways it is possible that some of the microinstructions are active and will cause some problems (i.e., transfer CKB-Bus to memory...). Don't forget to reset Branch Latch after using it.
10. Processor enable logic "wake-up"

Between TKA and DONE/OFF instruction not more than three instructions are allowed, if a successful "wake-up" should be performed by external hardware ( $\rightarrow \mathrm{K}$ inputs / I/O).
11. Processor logic "wake-up" enable

If the option of "wake-up" the processor by the negative and/or positive edge of K8 is used, pay attention to the effect: inverting K8 by DL14 can produce an edge. If this happens less than 7 instructions before the DONE instruction the processor could "wake up" due to the integrated delay line.
12. Status after "wake-up"

Register content after entry into active Processor-Mode

| Register |  | Power up | INITN pin | DONE Mode | OFF Mode |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Program Counter | PC | 00 | 00 | FF | FF |
| Page Address | PA | F | F | F | F |
| Page Buffer | PB | F | F | F | F |
| Status | S | undefined | undefined | undefined | undefined |
| Special Status | SS | undefined | undefined | undefined | undefined |
| Accumulator | A | undefined | undefined | undefined | undefined |
| YRegister | Y | undefined | undefined | undefined | undefined |
| XRegister | X | undefined | undefined | undefined | undefined |
| RAM Content |  | undefined | unchanged | unchanged | unchanged |
| DAM Latch |  | undefined | undefined | undefined | undefined |
| ADD Latch | reset | reset | reset | reset |  |
| BRANCH Latch | reset | reset | reset | reset |  |
| SEG-H Decimal point | DP | reset | reset | reset | reset |
| Digit Latches | DLn | reset | reset | unchanged | unchanged |
| K-Port Data Latch |  | undefined | unchanged | unchanged | unchanged |
| VO Port Data Latch |  | undefined | unchanged | unchanged | unchanged |
| VO Port Control Latch |  | reset | reset | unchanged | unchanged |
| Timer0 and Timer1 |  | undefined | unchanged | actual Time | undefined |
| ADC/Pin Supply SVDD |  | switched off | switched off | switched off | switched off |
| LCD Segment Latches |  | undefined | unchanged | unchanged | unchanged |

## APPENDIX B - Pinning Selection Schematic

28 PIN DUAL-IN-LINE PLASTIC PACKAGE


Note:
mandatory signals are:
VDD,VSS,KC,INITN,SVDD, TOSCIN,TOSCOUT,S2,S3,S4,S9,S10,S11

GR\#1 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
GR\#2 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
COM2 COM1 S20 S19 S18 S17 S16 S15 S14
GR\#3 $=$ COM2 COM1 S20 S19 S18 S17 S16 S15 S14 R4 R5 R6 R7

Note: NC - No internal connection NC pins may be used for test purposes in agreement with customer.

## APPENDIX B - Pinning Selection Schematic (continued)

## 28-pin NF package (YS)



All dimensions are in millimeter and parenthetically in inches.
Notes: A: Each pin centerline is located within 0,25 (0.010) of its true longitudinal position.
B: This dimension does not apply for solder-dipped leads.
C: When solder-dipped leads are specified, dipped area of the lead extends from the lead tip to at least $0,51(0.020)$ above seating plane.

## APPENDIX B - Pinning Selection Schematic (continued)

40 PIN DUAL-IN-LINE PLASTIC PACKAGE


Note: NC - No internal connection NC pins may be used for test purposes in agreement with customer.

## APPENDIX B - Pinning Selection Schematic (continued)

40-pin N2 package (YS)


Notes: A: All dimensions are in millimeter and parenthetically in inches.
B: Each pin centerline is located within $0,26(0.010)$ of it's true Iongitudinal position.

## APPENDIX B - Pinning Selection Schematic (continued)

44 PIN PLASTIC LEADED CHIP CARRIER PLCC


Note:
mandatory signals are:
VDD,VSS,KC,INITN,SVDD,
TOSCIN,TOSCOUT,S2,S3,S4,S9,S10,S11
GR\#1 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
GR\#2 = R0 R1 R2 R3 K1 K2 K4 K8 CLOCK PFRQ
COM2 COM1 S20 S19 S18 S17 S16 S15 S14
GR\#3 = COM2 COM1 S20 S19 S18 S17 S16 S15 S14 R4 R5 R6 R7

Note: NC - No internal connection NC pins may be used for test purposes in agreement with customer.

## APPENDIX B - Pinning Selection Schematic (continued)



Notes: A: Centerline of center pin each side is within 0,10 (0.004) of package centerline as determine by dimension $B$.
$B$ : Location of each pin is within $0,127(0.006)$ of true position with respect to center pin on each side.
C: The lead contact points are planar within 0,10 ( 0.004 ). All dimensions and notes for the specified JEDEC outline apply. All linear dimensions are in millimeters and parenthetically in inches.

## APPENDIX C - User Options

## LCD

- Segment PLA with 64 terms:

4bit ACCU + Status + DL14 define on/off of segments A to G. Segment $H$ is defined by instructions SDP and RDP.

- Common lines

2MUX ( $1 / 2$ duty) or 4MUX (1/4 duty). (Some manufacturer use back plane instead of common ).

- Segment lines

1. Attachment segment to common.
2. Attachment segment to $Y$-Register.

Note: All three options must be defined even if no display will be used.

## WAKE-UP FREQUENCY

- DL12 = $0: 1 \mathrm{~Hz}$ (no option)
- LL12 = 1 : 128 OR 64 OR 32 OR 16 OR 8 Hz only one must be selected.


## PROCESSOR FREQUENCY

- Internal RC-MOS Oscillator (see Figure 6-1).
- External Supply on Pin PFRQ (see 6.3 Operating Conditions)

Note: By using the "EXTERN" Option the internal Osc can be overwritten on Pin "PFRQ".
External Signal strength required $>10 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{DD}^{-0}, 4 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}+0,4 \mathrm{~V}}$

## ADC RANGE

- SMALL
- MEDIUM LOW
- MEDIUM HIGH
- LARGE

Note: One and only one must be selected.

## TIMOSC

- TRC RC Oscillator
- TXOSC Christal Oscillator

If the RC Oscillator is selected, a resistor needs to be connected from TOSCIN to TOSCOUT and a capacitor from TOSCIN to VSS. Please make sure that the frame frequency is o.k. if an LCD is used.

## PULL-DOWN

Individually selectable for K1, K2, K4, K8 AND I/O.
Kn OPEN-SOURCE ( $\mathrm{n}=1,2,4,8$ )
Individually selectable for K1, K2, K4 and K8 to be open source

## CLOCK

Frequency output divided from the crystal oscillator (XCOSIN).

- NONE : nothing selected - no (bond)pad used
- $256 \mathrm{~Hz}: \mathrm{f}_{\text {clock }}=\mathrm{f}_{\text {TOSCIN }} / 128$
- 1024 Hz : $\mathrm{f}_{\text {CLOCK }}=\mathrm{f}_{\mathrm{TOSCI}} / 32$


## K8 FLIP-FLOP

Signal on K8 line not immediate available for ACCU/MEMORY; if this option is used, signal at K8 pin is divided by 2 and then available for further operations (TKA, TKM, KNEZ). The divider by 2 is reset by PUC (power-up clear) or INIT.

## PINNING

Variable pinning helps optimization of system cost including PCB.

## Part III

# TSS400(/4) Software User's Guide July 1991 

## Table of Contents

Paragraph Title ..... Page
1 Introduction ..... 10
1.1 General ..... 10
1.2 Design Features ..... 10
1.3 Design Steps ..... 11
1.4 Symbols and Conventions ..... 12
1.4.1 List of Abbreviations ..... 12
1.4.2 Symbols and Logic Notations ..... 13
2 TSS400(/4) Chip Architecture and Operation ..... 16
2.1 General ..... 16
2.2 ROM Addressing ..... 16
2.3 Branching ..... 17
2.4 Subroutines ..... 18
2.5 RAM Addressing ..... 18
2.6 The Y Register ..... 20
2.7 The R Outputs and Digit Latches ..... 21
2.8 The Accumulator Register ..... 23
2.9 Arithmetic Logic Unit ..... 23
2.9.1 The ADD Latch ..... 24
2.9.2 The Branch Latch ..... 25
2.10 Status and Special Status ..... 27
2.10 .1 Status Logic ..... 27
2.10 .2 Special Status ..... 28
2.11 The K-Port ..... 28
2.11 .1 K8 Wakeup Conditions ..... 29
2.11.2 K8 Input Dividing by Flip Flop ..... 31
2.11.3 K-Port Options ..... 31
2.12 The I/O Pin ..... 31
2.13 The Timer ..... 33
2.14 The Current Saving Modes ..... 35
2.14.1 The Done Mode ..... 38
2.14.2 The Off Mode ..... 39
2.15 The Analog Digital Converter ..... 39
2.15.1 Measurement Ranges and Conversion Formulas ..... 41
2.15 .2 Correction of Tolerances by Software ..... 43
2.15 .3 Battery Check ..... 43
2.15 .4 The Current Source ..... 44
2.15 .5 Timing Considerations for the Measurement ..... 45
2.16 The LCD Driver ..... 45
2.16 .1 Multiplexing Scheme ..... 47
2.16 .2 Digit Addressing ..... 47
2.16 .3 Segment Addressing ..... 48
2.16 .4 The Output PLA ..... 48
2.17 Initialization and Power-Up ..... 50
2.18 Hardware Options ..... 52
2.18 .1 The Version Definition ..... 53
2.18.2 The Object Definition .Option ROM ..... 53
2.18 .3 The Pinning Defintion .Option Pinning ..... 53
2.18.4 The K8 Flip Flop Definition .Option K8FF ..... 53
2.18.5 The Pulldown Definition .Option K1K2K4K8IO ..... 54
2.18.6 The ADC Range Definition .Option ADC-Range ..... 54
2.18.7 The Oscilllator Speed Definition .Option Oscillator ..... 55
2.18.8 The Wake-up Frequency Definition. Option Wake-up-Frequency55
2.18.9 The Output Frequency Definition .Option Clock ..... 55
2.18.10 The Timer Oscillator Definition .Option TIMOSC ..... 56
2.18.11 The LCD Multiplex Definition .Option Common ..... 56
2.18.12 The Select Line Definition .Option Select-Lines ..... 56
2.18.13 The Output PLA Definition .Option Segment-PLA ..... 57
2.18.14 The .Option PACKAGE ..... 58
2.18.15 The End of Options Indication .End ..... 59
2.18.16 Example for a complete TSS400(/4) Hardware Definition ..... 59
3 Standard Instruction Set Definitions ..... 64
3.1 Effect on Status ..... 64
3.2 Instruction Formats ..... 64
3.2.1 Instruction Format I ..... 64
3.2.2 Instruction Format II ..... 65
3.2.3 Instruction Format III ..... 65
3.2.4 Instruction Format IV ..... 66
3.2 .5 Coding Format ..... 66
3.2.6 Micro Instructions ..... 67
3.3 Register to Register Transfer Instructions ..... 68
3.3.1 Transfer Accumulator to Y Register ..... 68
3.3.2 Transfer Y Register to Accumulator ..... 69
3.3.3 Clear Accumulator ..... 69
3.4 Register to Memory, Memory to Register Transfer Instructions ..... 69
3.4.1 Transfer DAM to Accumulator ..... 69
3.4.2 Exchange DAM and Accumulator ..... 70
3.4.3 Transfer Accumulator to Memory ..... 71
3.4.4 $\quad$ Transfer Accumulator to Memory and Increment $Y$ Register ..... 71
3.4.5 Transfer Accumulator to Memory and Decrement Y-Register ..... 72
3.4.6 $\quad$ Transfer Accumulator to Memory and Zero Accumulator ..... 72
3.4.7 Transfer Memory to Y-Register ..... 73
3.4.8 Transfer Memory to Accumulator ..... 73
3.4.9 Exchange Memory and Accumulator ..... 73
3.5 Arithmetic Instructions ..... 74
3.5.1 Add Constant to Accumulator, Result to Accumulator ..... 74
3.5.2 Add Memory to Accumulator, Result to Accumulator ..... 74
3.5.3 Subtract Accumulator from Memory, Result to Accumulator ..... 75
3.5.4 Increment Memory and load into Accumulator ..... 76
3.5.5 Decrement Memory and load into Accumulator ..... 76
3.5.6 Increment Y Register ..... 77
3.5.7 Decrement $Y$ Register ..... 77
3.5.8 Add Constant to Y Register ..... 78
3.5.9 Complement Accumulator and Increment ..... 78
3.6 Special Arithmetic Instructions ..... 79
3.6.1 Add DAM and Memory and Special Status, Result to Accumulator ..... 79
3.6.2 Add inverted DAM and Memory and Special Status, Result to Accumulator ..... 80
3.6.3 Add DAM and inverted Accumulator and Special Status, Result to Accumulator ..... 81
3.6.4 Reset End-Around-Carry [Special Status] ..... 81
3.6.5 Set End-Around-Carry [Special Status] ..... 82
3.6.6 Set ADD Latch ..... 82
3.6.7 $\quad$ Transfer Accumulator to Memory, add Constant to Accumulator ..... 83
3.6.8 Conditionally Transfer Accumulator to Memory, Decrement Y Register ..... 83
3.6.9 Transfer Special Status to Accumulator ..... 84
3.6.10 Set Branch Latch ..... 85
3.7 Arithmetic Compare Instructions ..... 85
3.7.1 If Accumulator is less than or equal to Memory, One to Status ..... 85
3.7.2 If Accumulator is less than or equal to Constant, One to Status ..... 86
3.8 Logical Compare Instructions ..... 86
3.8.1 If Memory is not equal to Accumulator, One to Status ..... 86
3.8.2 If Memory is not equal to Zero, One to Status ..... 87
3.8.3 If Y-Register is not equal to Accumulator, One to Status ..... 87
3.8.4 If $Y$-Register is not equal to a Constant, One to Status ..... 87
3.9 Bit Manipulation Instructions ..... 88
3.9.1 Set Memory Bit ..... 88
3.9.2 Reset Memory Bit ..... 89
3.9.3 Test Memory Bit ..... 89
3.9.4 Test Accumulator Bit for One ..... 893.9.6 $\quad$ Or Memory with Inverted Accumulator, Result toAccumulator91
3.10 Constant Transfer Instructions ..... 91
3.10.1 Transfer Constant to Accumulator ..... 91
3.10.2 Transfer Constant to Y-Register ..... 92
3.10.3 Transfer Constant to Memory and Increment $Y$ Register ..... 92
3.11 Input/Output Instructions ..... 92
3.11.1 Reset I/O Pin ..... 92
3.11.2 Set I/O Pin ..... 93
3.11.3 Switch I/O Pin to Input ..... 93
3.11.4 Transfer Status to I/O Pin ..... 94
3.11.5 Transfer I/O Pin to Memory ..... 94
3.11 .6 Transfer Accumulator to K Latch ..... 95
3.11.7 Transfer K Lines to Memory ..... 95
3.11.8 Transfer Data from Accumulator, Status and DL14 to Segment Latches ..... 96
3.11.9 Set Decimal Point [Segment H] ..... 96
3.11 .10 Reset Decimal Point [Segment H] ..... 97
3.11.11 If K Inputs are not equal to Zero, set Status ..... 97
3.11.12 Transfer K Inputs to Accumulator ..... 98
3.11.13 Set R Output ..... 98
3.11.14 Reset R Output ..... 99
3.12 RAM Addressing Instructions ..... 99
3.12.1 Load X Register with a Constant ..... 99
3.12.2 Complement the MSB of the X Register ..... 100
3.12.3 Toggle DAM Latch ..... 100
3.13 ROM Addressing Instructions ..... 100
3.13.1 Branch, Conditional on Status ..... 101
3.13.2 Call Subroutine, Conditional on Status ..... 102
3.13.3 Branch Long ..... 103
3.13.4 Call Long Subroutine ..... 104
3.13.5 Load Page Buffer with a Constant ..... 104
3.13.6 Return from Subroutine ..... 104
$3.14 \quad$ Analog-Digital-Converter Instructions ..... 105
3.14.1 Set Converter Supply Voltage ..... 105
3.14.2 Reset Converter Supply Voltage ..... 106
3.14.3 Reset Comparator Offset switch to Inverted ..... 106
3.14.4 Transfer Comparator Output to Memory Bit ..... 106
3.14.5 Transfer Range to Memory Bit ..... 107
3.15 Miscellaneous Instructions ..... 108
3.15.1 Enter Done Mode ..... 108
3.15.2 Enter Off Mode ..... 108
3.16 Timer Instructions ..... 109
3.16.1 Transfer Timer to Accumulator ..... 109
3.16.2 Transfer Timer to Y Register ..... 109
3.16.3 Transfer Timer to Memory ..... 110
3.16.4 If Timer not equal to Memory, One to Status ..... 111
3.16.5 If Timer not equal to Accumulator, One to Status ..... 111
4 Subroutine Software ..... 112
4.1 General ..... 112
4.2 Nesting Subroutines ..... 112
4.3 Example Calling Sequence ..... 113
4.3.1 Calling a Subroutine on the same page ..... 113
4.3.2 Calling a Subroutine from a different page ..... 115
4.4 Multiple Entry Points ..... 116
5 Organizing the RAM ..... 118
5.1 General ..... 118
5.2 Data Register Organization ..... 118
5.2.1 Register left Shift Example ..... 119
5.2.2 Transfer from Register 9 to 1 [Example] ..... 120
5.2.3 Register Transfer Example using COMX8 ..... 120
5.3 Placing FLAG Bits ..... 121
5.4 Temporary Working Areas ..... 122
5.5 DAM Addressing ..... 123
6 General Purpose Subroutines ..... 126
6.1 Register Shift Right [Rounding Routine] ..... 126
6.2 Register Clear Routine ..... 127
6.3 Display Driver Routine ..... 128
6.4 Leading Zero Suppression ..... 129
6.5 Integer Math Package ..... 129
6.6 Square Root Routine ..... 140
6.7 ADC Measurement Routines ..... 141
6.7.1 ADC Measurement Routine with two Measurements ..... 142
6.7.2 ADC Measurement Routine with "EQU" defined Number of Conversion ..... 144
6.7.3 ADC Measurement Routine with Number of Conversions in Accumulator ..... 146
6.8 Binary to BCD Conversion ..... 147
6.9 Keyboard Scan Routines ..... 148
6.9.1 Keyboard Routine with fast Wakeup [8 to 128 Hz ] ..... 149
6.9.2 Keyboard Routine with 1 Hz Wakeup ..... 151
6.10 Clock Routine ..... 153
6.11 Temperature Computation for Sensors ..... 154
6.11.1 Temperature Computation for PT500 Sensors ..... 154
6.11 .2 Temperature Computation for TSP202 Sensors ..... 156
6.12 Battery Check Routines ..... 157
6.12 .1 Battery Check Routine I ..... 157
6.12 .2 Battery Check Routine II ..... 158
6.13 Initialization Routine ..... 159
6.14 Waiting Routines ..... 161
Appendix A: Differences of the TSS400/4 compared to the TSS400
A. 1 ROM Addressing ..... 163
A. 2 Program Counter Stepping Order ..... 163
A. 3 RAM Addressing ..... 164
A. 4 Opcodes ..... 164
A. 5 MOS Oscillator Frequency ..... 164

## List of Figures

| Figure | Title | Paragraph |
| :--- | :--- | ---: |
|  |  |  |
| 1 | Blockdiagram TSS400(/4) | 1.4 .2 |
| 2 | PC Stepping Order | 2.2 |
| 3 | RAM Map | 2.5 |
| 4 | Analog-Digital-Converter Addressing | 2.7 |
| 5 | Wakeup Conditions for external Events | 2.14 |
| 6 | Wakeup Contents of internal Registers | 2.14 |
| 7 | Analog-Digital-Converter Addressing | 2.15 |
| 8 | Analog-Digital-Converter Ranges | 2.15 .1 |
| 9 | Number of Instructions before ADC-Comparisons | 2.15 .5 |
| 10 | Character Representation in OUTPUT OPLA | 2.16 .4 |
| 11 | Initialization Contents of internal Registers | 2.17 |
| 12 | Standard Segment Notation Scheme | 2.18 .13 |
| 13 | Instruction Format I | 3.2 .1 |
| 14 | Instruction Format II | 3.2 .2 |
| 15 | Instruction Format III | 3.2 .3 |
| 16 | Instruction Format IV | 3.2 .4 |
| 17 | CKB Memory Map Description | 3.2 .6 |
| 18 | Register Example | 5.2 .1 |
| 19 | Register Example for the Integer Math Package | 6.5 |
| 20 | Information in Keyboard Status Bits | 6.9 .1 |
| 21 | RAM Organization Keyboard Routines | 6.9 .1 |

[^3]
## 1 Introduction

### 1.1 General

This section introduces the TSS400(/4) one-chip sensor signal processor and outlines how an algorithm is developed and implemented to achieve cost effective designs. This introduction includes a definition of terms and conventions. This manual treats the TSS400(/4) as a system of logic and analog blocks controlled by the programmer.
After introduction of the hardware a detailed presentation of the standard instructions will follow. Hints for efficient algorithms and a number of example programs are presented last, in the sections 4 to 6 , since they require a thorough understanding of the standard instruction set.

### 1.2 Design Features

The TSS400(/4) series architecture is constructed to suit a wide variety of applications. The design is both cost effective and flexible because data input, processing and output are performed in one self-contained unit. An internal ROM, RAM A/D converter, ALU and LCD driver comprise a single chip sensor signal processor which functions according to the ROM program and the system inputs.

## Features

- minimal system: one device containing ROM, RAM, inputs, outputs, A/D converter, LCD driver, timer and more
- 12 bit A/D converter with 4 selectable inputs and 1 out of 4 ranges.
- programmable current source from 0.15 to $2.4 \mathrm{~mA} \cdot \mathrm{~V}_{\mathrm{DD}} / \mathrm{V}$ for all $\mathrm{A} / \mathrm{D}$ converter inputs
- mask programmable 2 or 4 common multiplex LCD driver 2 common driver controls up to 5 digits 4 common driver controls up to 10 digits
- 64 character, 7 segment output PLA, decimal point segment is switched independently
- 2048 nine bit words of ROM / 4096 nine bit words of ROM
- 576 bits of static RAM / 960 bits of static RAM
- three levels of subroutine
- timekeeping from an on chip quartz oscillator ( 32768 Hz ) or an RC oscillator
- low power silicon gate CMOS process
- DONE mode for reduction of power consumption with active timer and RAM; the CPU is woken up regularly by 2 selectable frequencies or by input changes
- OFF mode for very low power consumption with active RAM; wakeup by input changes
- internal MOS oscillator or external frequency input selectable
- three instruction BCD addition possible
- easy tailoring to actual needs by several hardware options
- one bit I/O port for fast data exchange
- 3 different packages available


### 1.3 Design Steps

Several steps are necessary to complete a system consisting of the TSS400(/4) and its periphery with the necessary performance. A typical and recommended development cycle is shown below:

1. Definition of tasks to be performed by TSS400(/4) and periphery.
2. Definition of the needed hardware options (ADC range, LCD hardware, wakeup frequency etc.).
3. Decision if 2 common or 4 common LCD display.
4. Input and output definition (K-Port, R outputs, ADC inputs, segment outputs, I/O pin etc.)
5. Drawing a complete hardware schematic.
6. Worst case design for all external components.
7. RAM organization.
8. Flowcharting the complete program for determining the instruction coding necessary to fulfil specification requirements.
9. Coding of the program with an editor.
10. Assembling the program with TSS400 assembler.
11. Testing the program with the ADT400(/4) emulator after removing of all assembly errors.
12. After approval of the program, preparation of the production definition file with the ADT system (hardware options, ROM code).
13. Sending the specification file to TI for manufacturing prototype circuits.
14. After checking and approving the prototype circuits, TI starts volume production.

### 1.4 Symbols and Conventions

### 1.4.1 List of Abbreviations

A Accumulator Register
ADC Analog Digital Converter
ALU Arithmetic and Logic Unit
B $\quad$ Bit Field of Instruction Word (2 bits)
C
CKB
CPU
DAM
DP
DLn
Kn
LCD
LSB
Constant Field of Instruction Word (4 bits)
Constant and K-Lines Bus
Central Processing Unit
Direct Access Memory
$M(15,0-15)$ or $M(7,0-15)$
Decimal Point Latch
Digit Latch $n$
( $\mathrm{n}=0-15$ )
K-Port $n$
( $n=1,2,4,8$ )
Liquid Crystal Display
LSD
MSB
MSD
$M(X, Y)$
Least Significant Bit
Least Significant Digit
Most Significant Bit
Most Significant Digit
$M(X, Y, B) \quad$ RAM Memory Bit Location $\quad(B=0-3)$

| OPLA | Output Programmable Logic Array |
| :---: | :---: |
| PA | Page Address Register |
| PB | Page Buffer Register |
| PC | Program Counter |
| RAM | Random Access Memory (Read/Write) |
| ROM | Read Only Memory |
| Rn | R Output $\mathrm{n} \quad(\mathrm{n}=0-7)$ |
| S | Status Bit |
| SS | Special Status Bit (End-Around-Carry) |
| Timer0 | Timer Nibble fed from $1 \mathrm{~Hz}(\mathrm{DL} 12=0)$ |
| Timer1 | Timer Nibble fed from 16 Hz (DL12 = 1) |
| W | Branch Address of Instruction Field (7 bits) |
| $X$ | RAM X Address Register |
| Y | RAM Y Address Register |
| SRn | Subroutine PC Register Level $\mathrm{n} \quad(\mathrm{n}=1-3)$ |
| PSRn | Subroutine Page Register Level n ( $\mathrm{n}=1-3$ ) |
| 10En | 10 raised to n-th power |
| EMI | Electro Magnetic Interference |

Note: $M(X, Y), M(X, Y, B)$, "Addressed Memory" and "Memory addressed by $X$ and $Y$ register" are used for indicating the currently addressed memory location or memory bit.
This means:
If DAM Latch $=0: \quad X=$ contents of $X$ register
If DAM Latch $=1$ :
$X=15$

### 1.4.2 Symbols and Logic Notations

$\mathrm{a} \rightarrow \mathrm{b} \quad$ Transfer value a to b
$a \leftrightarrow b \quad$ Exchange contents of $a$ and $b$
$>$ NNN $\quad$ NNN in hexadecimal number format
NNN NNN in decimal number format
$=\quad$ Equal
<> Not equal
$>\quad$ Greater than
$\geq$
Greater than or equal to

| < | Less than |
| :---: | :---: |
| $\leq$ | Less than or equal to |
| + | Addition |
| - | Subtraction |
| . OR. | Boolean OR function |
| .AND. | Boolean AND function |
| $P C+1 \rightarrow P C$ | PC value goes to next word address in the pseudo random sequence ( $00,01,03,07,0 \mathrm{Fetc}$.). |
|  | The complete sequence is given in Figure 2. |
| $\overline{\mathrm{X}}$ | One's complement of $X$ |
| XXX.YY | Number with 2 digits after the decimal point |



Figure 1: Blockdiagram TSS400(/4)

## 2 TSS400(/4) Chip Architecture and Operation

### 2.1 General

The instruction timing is fixed and each instruction requires six oscillator cycles to execute. By initalization, the Program Counter PC is reset to location 00 and the Page Address register PA and the Page Buffer PB are set to 15. Then the Program Counter counts to the next ROM address in a pseudo random sequence. If the PB is not changed, execution continues on the same page. In other words, when the PC reaches the 128th word on a page, execution begins again at PC location 00 on that page (wrap around).
The actual available signals (Kn, Rn, Select Lines etc.) depend on the ADT configuration program. All signals are described wether existent or not in a given configuration.

### 2.2 ROM Addressing

The ROM has 2048 words or 4096 words in the 4 k version of 9 bits each. NMOS transistors are placed to define bit patterns of machine language. The ROM is organized into 16 pages of 128 words or 256 words in the 4 k versiojn each ( $16 \cdot 128=2048$ words total).
Registers used to address the ROM include the following:
a) Page Address register PA: Contains the page number within the ROM being addressed. The contents of the PA (four bits) are decoded into one of sixteen address lines by the page decoder.
b) Page Buffer register PB: The PB is loaded with a new page address by the LDP instruction. This page address is transferred to the PA when a successful CALL or BRANCH instruction is executed.
c) Program Counter PC: Contains the current location of the word (within the current page) being addressed. The contents of the PC (seven bits length) are decoded by the PC decoder into one of 128/256 address lines selecting one instruction on a page.

The PC steps forward in a pseudo random sequence. This sequence is shown below: (00, 01, 03 ... 40)

| $\overrightarrow{\omega 0}$ | 01 | 03 | 07 | $0 F$ | $1 F$ | 3 F | 7 F |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 7 E | 7 D | 7 B | 77 | 6 F | 5 F | 3 E | 7 C |
| 79 | 73 | 67 | 4 F | 1 E | 3 D | 7 A | 75 |
| 6 B | 57 | 2 E | 5 C | 38 | 70 | 61 | 43 |
| 06 | 0 D | 1 B | 37 | 6 E | 5 D | 3 A | 74 |
| 69 | 53 | 26 | 4 C | 18 | 31 | 62 | 45 |
| 0 A | 15 | 2 B | 56 | 2 C | 58 | 30 | 60 |
| 41 | 02 | 05 | 0 B | 17 | 2 F | 5 E | 3 C |
| 78 | 71 | 63 | 47 | 0 E | 1 D | 3 B | 76 |
| 6 D | 5 B | 36 | 6 C | 59 | 32 | 64 | 49 |
| 12 | 25 | 4 A | 14 | 29 | 52 | 24 | 48 |
| 10 | 21 | 42 | 04 | 09 | 13 | 27 | 4 E |
| 1 C | 39 | 72 | 65 | 4 B | 16 | 2 D | 5 A |
| 34 | 68 | 51 | 22 | 44 | 08 | 11 | 23 |
| 46 | 0 C | 19 | 33 | 66 | 4 D | 1 A | 35 |
| 6 A | 55 | 2 A | 54 | 28 | 50 | 20 | 40 |

Figure 2: PC Stepping Order

### 2.3 Branching

All branches are conditional; a status logic path comes from the ALU to designate if a branch instruction should be successfully executed. A successfully executed branch or call is defined to be the case when the branch or call transfers control to an instruction address out of the normal sequence. An unsuccessful branch or call does not affect the normal sequence of the Program Counter. The execution of a branch or call depends on the status:

- If the status equals one, then the branch will be successfully executed. That is, seven bits are transferred from the instruction bus from ROM into the Program Counter. These seven bits are the branch address W which locates the next word on the page to be executed.
- If the status logic is equal to zero, then the branch instruction is unsuccessful. The Program Counter sequences to the next instruction, and then status reverts to a one.

If the contents of the Page Buffer register had been modified previous to the branch instruction, then this instruction is called a long branch instruction, since it may branch anywhere in the ROM (a long branch, the BL directive in the source program, generates two instructions: LDP load Page Buffer and BR branch).

Note: The normal state of the status logic is one. Several instructions can alter this state to a zero; however, the zero state lasts for only one subsequent instruction cycle (which could be during a branch or call), then the status logic will normally revert back to its one state (unless the following instruction resets it to zero again).

### 2.4 Subroutines

Similar to the BRANCH instruction, the CALL instruction is conditional, too. Three levels of subroutine nesting are allowed and a 4th level CALL does not work properly. In the case of a successful CALL when status logic equals 1:

- the contents of the Page Buffer PB are written to the Page Address PA
- the return address is pushed onto the stack (PSR1 and SR1) (the return address is the address after the call instruction and is called normally PC + 1)
- the address field W of the CALL instruction is written into the Program Counter PC
When a return instruction RETN occurs in a subroutine:
- the Subroutine PC Register SR1 (which holds the address after the last CALL instruction) is written to the PC
- the Subroutine Page Register PSR1 is written to the PA
- the stack is raised one level up


### 2.5 RAM Addressing

There are 9 RAM banks each containing 16 four-bit words (nibbles) in the RAM's 576 bit matrix of the TSS400. There are 15 RAM banks each containing 16 four-bit words (nibbles) in the RAM's 960 bit matrix of the TSS400(/4). Eight of these registers are normal RAM registers, one of them is a special Direct Access Memory (DAM) register. Special instruc-
tions address this DAM without changing the $X$ register. When addressed implicitely ( $\mathrm{X}=7$ or 15 ) all instructions operate in the same manner on the DAM as when used for the normal RAM banks.


Figure 3: RAM Map TSS400

Usage of a RAM map like shown above is strongly recommended. It makes the RAM usage very clear and eases coding and test.

Three registers are important in RAM adressing:

- the X register addresses each bank with a four-bit address only (1, 2, 3, $4,7,9,10,11,12,15$ in the TSS400), the address being decoded by the $X$ decoder
- the Y register identifies the particular nibble in the bank with a four-bit address ( 0 to 15). The Y register is decoded by the Y decoder
- the DAM Latch decides if the X register is used for the addressing of a register bank (DAM Latch $=0$ ) or if the DAM is addressed independently from the $X$ register contents (DAM Latch $=1$ )

The DAM Latch will reset upon a LDX instruction and will set and reset on subsequent TDL instructions. When the DAM Latch is reset, the RAM bank addressed by the X register is in use again.

### 2.6 The Y Register

The Y register has four purposes.

- the Y register addresses the RAM in conjunction with the X register for RAM I/O
- the Y register addresses the Digit Latches for setting and resetting individual latches. Whenever a particular Digit Latch needs to be set or reset, a TCY instruction with the appropriate $Y$ and then a SETR or RSTR instruction is to be executed
- the Y register is used as a working register; for example, a long delay time is desired, the Y register is used as a counter (see subroutine WAIT2MS in example 6.14)
- the Y register addresses the display digit which is to be loaded with the TDO instruction

Example: For setting the R0 output the following program can be used.
TCY $\quad 0 \quad 0 \rightarrow Y$ (ADDRESS R 0 )
SETR SETRO

The following instructions affect the Y register:
CTMDYN Conditional transfer to memory + DYN
DYN Decrement Y register, if no borrow one to status
IYC Increment $Y$ register, if carry one to status
TAMDYN Transfer accumulator to memory + DYN
TAMIYC Transfer accumulator to memory + IYC
TAY Transfer accumulator to Y register
TYA Transfer $Y$ register to accumulator
TCY Transfer constant to Y register
TCMIY Transfer constant to memory. Increment Y register
TMY $\quad$ Transfer memory to Y register
TTY Transfer timer to Y register
YNEA If $Y$ register not equal to accumulator, set status
YNEC If $Y$ register not equal to constant, set status
ACYY Add constant to $Y$ register
The ACYY instruction allows any constant $(0-15)$ to be added to the $Y$ register. This is helpful for addressing transfer loops.

### 2.7 The R Outputs and Digit Latches

The Y register addresses 16 Digit Latches which can be set and reset by the instructions SETR and RSTR. Initialization will reset all Digit Latches to zero. The data of the Digit Latches is retained during Done Mode and Off Mode as long as the supply voltage is maintained.

Two groups of Digit Latches can be distinguished:

- R outputs: The latches which are addressed by $Y$ values zero to seven are connected to these outputs named R0 to R7. All of them are equal in function. They can be used for several purposes:
- scanning of a keyboard, or switches or programming diodes
- controlling of relays, lamps, LEDs etc. via buffers
- switching of gates, multiplexers etc.
- Digit Latches: These latches are addressed by Y values eight to fifteen. Each Digit Latch DLn has a unique function as described below:
- DL8: Controls the direction of the K-Port:

DL8 $=0$ : K-Port is input
DL8 $=1$ : K -Port is output

- DL9 - DL11: Control of the analog multiplexer of the ADC:

| DL11 | DL10 | DL9 | Function |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | A1 to comparator |
| 0 | 1 | 0 | A2 to comparator |
| 1 | 0 | 0 | A3 to comparator |
| 1 | 1 | 0 | A4 to comparator |
| x | x | 1 | Battery check |

Figure 4: Analog-Digital-Converter Addressing

- DL12: Controls which timer register is connected to the ALU or memory for the timer instructions and functions:
DL12 $=0$ : Timer0 ( $0-15 \mathrm{~s}$ ) is addressed
DL12 $=1$ : Timer1 ( $0-15 / 16 \mathrm{~s}$ ) is addressed
- DL13: Controls the constant current source of the ADC:

DL13 $=0$ : Constant current source is off
DL13 = 1: Constant current source is on if $S_{D D}$ is on

- DL14: Is MSB for the OPLA character decoding and selects wake up direction of the K8 input.
DL14 = 0 :
Leading edge at K 8 generates wakeup (LO-HI change)
Characters 0 to 31 are addressed in the OPLA
DL14 = 1:
Trailing edge at K 8 generates wakeup (HI-LO change)
Characters 32 to 63 are addressed in the OPLA
- DL15: Controls wakeup of the I/O Pin:

DL15 $=0$ : Wakeup is enabled for I/O Pin
DL15 = 1: Wakeup is disabled for I/O Pin

### 2.8 The Accumulator Register

The accumulator is a four-bit register that interacts with the adder, the RAM, the DAM, the Y register, the LCD driver and the K-Ports. The accumulator is the main working register for addition and subtraction. Subtraction is accomplished by complement of two arithmetic. The functions are as follows:

- main register for computations
- selection of OPLA term for display together with status and DL14
- storage register for K-Port (input and output)


### 2.9 Arithmetic Logic Unit

Arithmetic and logic operations are performed by the Arithmetic Logic Unit (ALU) which is a four-bit adder/comparator and associated logic. The Arithmetic Logic Unit performs logical comparison, addition, subtraction and arithmetic comparison functions on its inputs.
Two input groups are available: P input and N input. These two four-bit parallel inputs ( P and N ) may be added together or compared logically.
The inputs of the P group are:

- Y register
- constant from instruction
- addressed DAM nibble
- addressed DAM nibble inverted
- addressed RAM nibble

The inputs of the N group are:

- addressed RAM nibble
- constant from instruction
- accumulator
- accumulator inverted

The adder has additional inputs for:

- $15(-1)$ for decrementing purposes
- special Status SS
- 1 for incrementing purposes

Addition and subtraction results are stored in either the Y register or the accumulator. Either an arithmetic function or a logical comparison may generate an output to the status logic. If either logical or arithmetic comparison functions are used only the status bit affects the program control, and neither the Y register's nor the accumulator's contents are affected. If a branch or call is attempted when the status is a logic 1 (which is the normal state), the conditional branch or call is executed.

If an instruction calls for a carry output to status and the carry does not occur, then the status will go to a zero level for one instruction cycle. Likewise, if an instruction calls for the logical comparison function and the bits compared are all equal, then the status will go to a zero level for one instruction cycle. If status is a logical zero, then branches and calls are not performed.

For the ORMA and ORMNAA instruction, which allow the logical OR function for the accumulator and the addressed memory, both data sources are connected to the N group inputs.

The ALU has a carry-in feature in which a one is added to the sum of the $P$ and N adder inputs.

### 2.9.1 The ADD Latch

The ADD Latch, together with the Special Status SS and the BRANCH Latch logic, facilitates the execution of arithmetic with other bases than 16. Normally the used base is 10 (BCD arithmetic). The ADD Latch connects the adder logic optimally for addition if set and for subtraction if reset.

The ADD Latch is affected by the following instructions:
$\begin{array}{ll}\text { SAL } & \text { Set ADD Latch } \\ \text { RETN } & \text { Reset ADD Latch }\end{array}$
The ADD Latch is reset by the RETN instruction, after initialization and after wakeup from Done Mode and Off Mode.

When the SAL instruction is used and a defined status of the Special Status SS is necessary, the SAL instruction should be used before the REAC
or SEAC instruction. This is because the SAL instruction causes an undefined status of the SS.

Example: The subroutine following will add the numbers in $\mathrm{M}(15,0-5)$ to the numbers in $M(3,0-5)$ in octal format.

| OCTALADD | LDX | 3 | Address LSD of registers |
| :--- | :--- | :---: | :--- |
|  | TCY | 5 | M(3,5) |
|  | SAL |  | Set ADD Latch for addition |
|  | REAC |  | Reset Special Status |
| ADDLOP | DMEA |  | Add DAM and RAM $\rightarrow A$ |
|  | TAMACS | 8 | $A \rightarrow M(3, Y), A+8 \rightarrow A$ |
|  | CTMDYN |  | Correction if necessary |
|  | BRANCH | ADDLOP | to octal range $0-7$ |
|  | RETN |  | Result in $M(3,0-5)$ |

Note: Only the constant of the TAMACS instructiondecides which numbering base NB is used:
Addition: $\quad \mathrm{NB}=16-$ TAMACS constant
Subtraction: NB = TAMACS constant

### 2.9.2 The Branch Latch

The BRANCH Latch is set when it is desired to have the BRANCH instruction decoded not only as a BRANCH, but also as an instruction. The instruction decoded will execute irregardless of status. When the BRANCH Latch is set it will allow the Microinstruction Decode to interprete the BRANCH instruction with the MSB set to zero. This means, that the destination address of the BRANCH must have a ROM address equal to the instruction opcode to be performed together with the BRANCH.
The reason for the BRANCH Latch is the fact that when using arithmetic functions, the program is nearly $100 \%$ inside the add loop of a multiplication or the subtract loop of a division. The Special Arithmetic Instructions of the TSS400(/4) reduce these loops to 4 instructions compared to 11-13 instructions for TMS1000 family members. The usage of the BRANCH Latch gives an additional $25 \%$ speed improvement.

[^4]Instructions which cannot be executed in this way are: TKA, TKM, KNEZ, XDA, TBIT, TTM, TTA

The following instructions affect the BRANCH Latch:
SBL Set BRANCH Latch
RETN Reset BRANCH Latch
The BRANCH Latch is reset by the RETN instruction, after initialization and after wakeup from Done Mode and Off Mode.

When the BRANCH Latch is set, every BRANCH works as a branch and as an instruction. Use only branches which are defined as instructions when the MSB is zero. If not it is possible that some microinstructions which are activated will cause problems (e.g. transferring adder output to memory). Don't forget to reset the BRANCH Latch by a RETN instruction when finished.

Caution: Be very cautious using this feature. Any shift inside the ROM page will change the instruction which is performed by the BRANCH additional to the branching. Document the used instruction in the comment field and use the ORG Directive for placing the BRANCH instruction. Then a warning will occur if modifications before the ORG directive overflow into the critical loop.
Example: Three instruction BCD Addition and Subtraction.
The ORG operands are computed as follows:
ORG operand $=($ PAGE $\cdot 128)+$ CNT
PAGE Page number ( $0-15$ ) where instruction is located
CNT Count from PC $=0$ to $\mathrm{PC}=$ Opcode

```
PC INSTR. LINE
```

| 00 | 095 | 2 | ADDITION | LDX | 10 | Add M(15,0-8) to M(10, 0-8) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 01 | 041 | 3 |  | TCY | 8 |  |
| 03 | $0 B 1$ | 4 |  | SAL |  | Set ADD Latch for Addition |
| 07 | $0 B 3$ | 5 |  | SBL |  | Set BRANCH Latch for speed |
| 0 F | 0 B 4 | 6 |  | REAC |  | SS $=0$ |
| 1 F | 110 | 7 |  | BR | ADDLOP | Includes DMEA (010) instr. |


| 3 F | 095 | 9 | SUBTRACT | LDX | 10 | Subtract M(15, 0-8) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 F | 041 | 10 |  | TCY | 8 | from M(10,0-8) |
| 7 E | 0B3 | 11 |  | SBL |  | Set BRANCH Latch for speed |
| 7D | 0B5 | 12 |  | SEAC |  | $\mathrm{SS}=1 \mathrm{ADD}$ Latch not set |
| 7B | 113 | 13 |  | BR | SUBLOP | Includes NDMEA (013) instr. |
|  |  | 14 | * |  |  |  |
|  |  | 15 |  | ORG | 88 | Place ADDLOP to $\mathrm{PC}=10$ |
| 10 | 0D6 | 16 | ADDLOP | TAMACS | 6 | A $\rightarrow$ M (X, Y) |
| 21 | 018 | 17 |  | CTMDYN |  | Correction if necessary |
| 42 | 110 | 18 |  | BRANCH | ADDLOP | Includes DMEA (010) instr. |
| 04 | 012 | 19 |  | CCLA |  | Carry from MSD -> A |
| 09 | 0BF | 20 |  | RETN |  | Reset BRANCH + ADD Latch |
|  |  | 21 | * |  |  |  |
|  |  | 22 |  | ORG | 93 | Place SUBLOP to $\mathrm{PC}=13$ |
| 13 | 0D5 | 23 | SUBLOP | TAMACS | 10 | A $\rightarrow$ M (X, Y) |
| 27 | 018 | 24 |  | CTMDYN |  | Correction if necessary |
| 4 E | 113 | 25 |  | BRANCH | SUBLOP | Includes NDMEA (013) instr. |
| 1 C | 012 | 26 |  | CCLA |  | Carry from MSD -> A |
| 39 | 0BF | 27 |  | RETN |  | Reset BRANCH + ADD Latch |

### 2.10 Status and Special Status

### 2.10.1 Status Logic

There are several instructions that affect status logic, either setting it to one or resetting it to zero. In turn the status logic will permit the successful execution of a BRANCH or CALL instruction if status is a one, or prevent sucessful execution of these instructions if status is zero. Status logic will remain at a zero level only for the following instruction cycle and then automatically be set to the normal one status by begin of the next instruction.

There are two microinstructions (NE and C 8 ) that are used to affect status. If the C8 microinstruction is used and a carry occurs in the addition of two four-bit nibbles, the carry goes from the MSB of the sum to status, setting the status logic to a one. If no carry occurs, status logic is reset to a zero for one instruction cycle. In a logic compare instruction using the microinstruction NE, status is set to one if the four-bit nibbles at the $N$ and $P$ adder/comparator inputs are not equal, conversely, status logic is reset to zero if the inputs are equal.

Revision 1, July 1991

The status can be set or reset without any other side effects by the following instructions:

$$
\begin{array}{lll}
\text { ACACC } & 0 & \text { Reset status unconditionally } \\
\text { ACYY } & 0 & \text { Set status unconditionally }
\end{array}
$$

### 2.10.2 Special Status

The Special Status SS or End-Around-Carry is used by the Special Arithmetic Instructions only. The BRANCH and CALL instructions do not depend on the special status; it is an arithmetic status only. All of the instructions mentioned below (except CTMDYN) unconditionally set the status.

The following instructions depend on or modify the Special Status:
SEAC sets the SS
REAC resets the SS
DMEA adds the SS to the result
NDMEA adds the SS to the result
DNAA adds the SS to the result
TAMACS sets or resets the SS conditionally
CTMDYN transfers accumulator to memory depending on SS
CCLA transfers the SS to the accumulator
SAL switches ALU to addition (to subtraction if not set)
The TAMACS instruction which sets or resets the SS conditionally uses the carry out of each instruction which affluences the carry, not only out of the instructions named above. This means that all arithmetic instructions (including the instruction ACYY which always sets the status) can be used together with the TAMACS instruction. See example 6.10 where the AMAAC instruction is used together with the Special Arithmetic Instructions. The ALU always stores the carry of the previous instruction, too.

### 2.11 The K-Port

The K-Port is a four-bit I/O port. Its direction is controlled by DL8 while the output data is stored in the four-bit K-Port Latch.

> DL8 $=0:$ K-Port is switched to input direction
> DL8 $=1:$ K-Port is switched to output direction. The K-Port Latch information appears at the K-Pins.

Because initialization resets DL8, the K-Port is switched to input direction when initialization occurs.

The following instructions affect the K-Port:
TKA Transfer K-Port to accumulator
TKM Transfer K-Port to addressed memory
KNEZ If K-Port input not equal to zero, set status
Reset status if K-Port input is zero
TAK Transfer accumulator to K-Port Latch
The TAK instruction latches the four-bit accumulator into the K-Port Latch. If DL8 is set, the K-Port Latch is output to the K-Pins. K8 is MSB, K1 is LSB. The contents of the K-Port Latch are not affected if DL8 is switched to input direction.

Example: The example outputs a memory value to the K-Port

| TMA |  |
| :--- | :--- |
| TM $(X, Y) \rightarrow A$ |  |
| TAK |  |
| TCY | ALB PORT LATCH |
| SETR | SWITCH K PORT TO OUTPUT |
| SORT LATCH $\rightarrow$ K PORT |  |

The K-Port input instructions TKM, TKA, KNEZ read the K-Port information via SCHMITT-triggers into the ALU or memory. This means that depending on the state of DL8 the input is read in or the information coming from the K-Port Latch.

The K-Port will wakeup the TSS400(/4) from Done Mode and Off Mode under certain circumstances. See Figure 5 for the conditions of wakeup at the K-Port.

### 2.11.1 K8 Wakeup Conditions

K8 differs from the other K-Pins in that the wakeup conditions depend on DL14 (See also Figure 5):

DL14 $=0$ : K8 transition from 0 to 1 will wake up the CPU DL14 $=1$ : K8 transition from 1 to 0 will wake up the CPU

This feature is for applications with relatively high input frequencies which have to be handled. Before entering the Done Mode or Off Mode, the software checks the state of the K8 input and sets DL14 accordingly for a safe wakeup.

|  | TCY | DL8 | SWITCH K PORT TO INPUT |
| :--- | :--- | :--- | :--- |
|  | RSTR |  |  |
|  | TCY | DL14 | ADDRESS DL14 |
|  | TKA |  | READ IN K PORT |
|  | TBITA | 3 | IS K8 HI ? |
|  | BRANCH | L\$080 |  |
|  | RSTR |  | K8 IS LO, RESET DL14 FOR WAKEUP |
|  | DONE |  | BY LO-HI CHANGE |
| L\$080 |  |  | K8 IS HI, SET DL14 FOR WAKEUP |
|  | SETR |  | BY HI-LO CHANGE |

Changes of K8 occuring between the TKA instruction and the DONE instruction will also wake up the ALU, because these changes are stored in a 5 instruction shiftregister. It wakes up if the current wakeup direction is addressed. Due to this shiftregister, no unnecessary DL14 changes should be made within 6 instructions before the DONE instruction. The following example would wakeup erroneously the ALU each time after the DONE instruction in an endless loop: Dependent on the state of K8, the conditions for wakeup inside the stored 5 instructions can be met.

> If K8 is 0 : The SETR instruction simulates a HI-LO change If K8 is 1 : Correct function

|  | TCY | DL8 | SWITCH K PORT TO INPUT |
| :--- | :--- | :--- | :--- |
| RSTR |  |  |  |
|  |  |  |  |
| TCY | DL14 | ADDRESS DL14. PRESET IT FOR |  |
| SETR |  | HI-LO CHANGE (WRONG !!) |  |
| TKA |  | READ IN K PORT |  |
|  | TBITA | 3 | IS K8 HI ? |
|  | BRANCH | L\$080 | YES, DL14 YET RIGHT |
| LSTR |  | K8 IS LO, RESET DL14 FOR WAKEUP |  |

### 2.11.2 K8 Input Dividing by Flip-Flop

Fast input transitions are very hard to count, especially if the pulses are of short duration. To compete with this situation a hardware option can be selected which divides the K8 input with a flip flop. Each input pulse at K8 changes the output of the flip flop and stores this information until the next K8 input pulse occurs. This flip flop is reset by initialization or powerup. The first LO-HI change at the K8 input delivers a logical 1 to the ALU. The current state of the K8 pin is not available to the ALU. The wake up information, which depends on DL14, is triggered by the K8 pin directly and is not affected by this option.

The K8 flip flop is controlled by the .OPTION K8FF. See 2.18.4.

### 2.11.3 K-Port Options

Each K-Pin can have a pull-down resistor individually by defining it with the hardware option .OPTION K1K2K4K8IO. See 2.18.5 for examples. It is strongly recommended for all K-Pins which are not connected to external resistors or gate outputs to have internal pulldown resistors. This avoids floating input levels and EMI influences.

The output configuration of each K-Pin is selectable by the .OPTION K1K2K4K81O, too. Two possibilities exist:

- K-Pin is configured with push pull output
- K-Pin is configured with open source output

Pulldown resistor and output configuration can be chosen independently for each K-Pin. See 2.18.5 for examples.

### 2.12 The I/O Pin

The I/O Pin is a one-bit bidirectional port which is controlled by its own instructions. The l/O Pin can be used for a two line bus or other purposes:

- additional input or output to K-Port and R outputs
- connection to a host computer
- connection to a calibration unit
- read in and read out of measurement results

The I/O Pin is controlled by two one-bit registers:

- The I/O Data Latch which holds the output information. If set to one, the output info is nearly $\mathrm{V}_{\mathrm{DD}}$, if reset to zero the output info is nearly $\mathrm{V}_{\mathrm{SS}}$.
- The I/O Control Latch which controls the direction of the I/O Pin. This latch is reset to input direction by initialization.
Both I/O latches hold their information during Done Mode and Off Mode. The I/O Pin output information settles in the middle of an instruction.
The instructions which affect the I/O Pin are:
SETIO set I/O Data Latch to 1 and set I/O Control Latch to output direction
RSTIO reset I/O Data Latch to 0 and set I/O Control Latch to output direction
TSIO transfer status to I/O Data Latch and set I/O Control Latch to output direction
IOIN reset I/O Control Latch to input direction
TIOM transfer I/O pin information to addressed memory (I/O Pin is not switched to input direction !)
The I/O Pin can have an internal pulldown resistor if defined by the hardware option .OPTION K1K2K4K8IO. See 2.18.5.
Example: The following code output a HI signal at the I/O Pin, three instructions in length which is a trigger signal for the host and input then one bit of information.

| READ | SETIO |  | SET I/O PIN HI |
| :--- | :--- | :--- | :--- |
|  | LDX | 4 | FOR 3 INSTRUCTIONS |
|  | TCY | 0 | TO TRIGGER HOST |
|  | RSTIO |  |  |
|  | IOIN |  | SWITCH TO INPUT DIR. |
|  | TIOM | 3 | READ INFO TO M $(4,0,3)$ |

### 2.13 The Timer

The TSS400(/4) has an eight bit timer register which is fed by a frequency derived from the oscillator after dividing by $2048(16 \mathrm{~Hz}$ for 32768 Hz ).
The oscillator circuitry is selectable (see hardware option .OPTION TIMOSC). Two posibilities exist:

- Quartz oscillator 10 to 100 kHz (nominal 32768 Hz )
- RC oscillator

The quartz oscillator circuitry is intended for applications which need an accurate time base. The RC oscillator circuitry can be used when no time base is necessary and very fast startup after powerup or release from Off Mode is essential (the internal powerup logic delays the program start until 6 to 8 clock cycles came from the oscillator. This can last up to $0.5 \mathrm{sec}-$ onds with a quartz oscillator. The RC oscillator starts immediately).
The timer is divided into two nibbles Timer0 and Timer1, which can be read into the accumulator, the addressed memory or the Y register. The frequency information in the remaining timer description is always related to an input frequency of 32768 Hz .
Timer0: Fed by 1 Hz coming out of the MSB of Timer1.
Addressed if DL12 is reset. Counts from 0 to 15 seconds.
Timer1: Fed by 16 Hz coming out of the divider chain of the timer oscillator.
Addressed if DL12 is set. Counts from 0 to $15 / 16$ seconds.
For intervals greater than 15 seconds the timing information has to be enlarged by software using the RAM. See example below. The timer can be used for several purposes:

- time base for software timers
- measurement of time intervals
- keyboard debounce
- wait routines
- wakeup from Done Mode: If DL12 is reset, wakeup will occur each second. If DL12 is set, wakeup will occur with the frequency defined by hardware option .OPTION WAKEUP (see 2.18.8) Possible frequencies are 8, 16, 32, 64 and 128 Hz .

The following instructions handle the timer information:
TTA transfer addressed timer nibble to accumulator
TTM transfer addressed timer nibble to $M(X, Y)$
TTY transfer addressed timer nibble to $Y$ register
TNEA if addressed timer nibble is not equal to accumulator set status to one; reset status if both are equal;
TNEM if addressed timer nibble is not equal to $M(X, Y)$ set status to one; reset status if both are equal;

The MOS oscillator and the timer oscillator are completely independent from each other. This means that the timer information can be in an intermediate state when read out by the instructions TTY, TTA or TTM. This would lead to false readings. The TNEA and TNEM instructions are used to ensure that the read timer information is stable. If the read timer values differs, another double read is made until both are equal. See example below.

When DL12 is reset the value of Timer1 is 0 after wakeup is caused by the timer. This can be used for assuring that the timer woke up the CPU. If Timer1 doesn't contain 0 , the wakeup was caused by the K-Port, the I/O Pin or noise.

When DL12 is set and the used wakeup frequency is 32 Hz and higher it is not as easy as above to decide where the wakeup came from. The K-Port and the I/O pin have to be checked if they woke up the CPU before the time counter is incremented. If high time accuracy is needed, it is advised to synchronize the time with the readable 16 Hz Timer1.

Example: The following program reads the Timer0 and builds the difference to the last read value. This difference is used for incrementing the clock routine which is shown in 6.10. Using the difference of readings assures that neither noise nor long computations (up to 15 seconds) can influence timing accuracy. It can not be recommended to increment a timer simply after wakeup!

|  | TCY | DL12 | ADDRESS TIMER0 |
| :--- | :--- | :--- | :--- |
|  | RSTR |  |  |
|  | TCY | Y | M(X,Y) OLD VALUE |
|  | TTA |  | TIMER0 -> A |
|  | TNEA |  | TIMER0 $=$ A ? |
|  | BRANCH | L\$100 | READ ONCE MORE IF NOT |
|  | XMA |  | OLD <-> NEW |
|  | SAMAN |  | NEW - OLD -> A |
|  | CALLL | CLOCK | ADD DIFF. TO CLOCK |

By using the hardware option .OPTION CLOCK and a 32768 Hz quartz it is possible to have either 256 Hz or 1024 Hz at a pin named CLOCK. This frequency is output in the Done Mode, too. If quartzes with other frequencies or an RC oscillator are used, the output frequency is $1 / 128$ resp. $1 / 32$ of the used frequency. After execution of the OFF instruction the state of the CLOCK output is not defined, it can be HI or LO. If a certain state is necessary, the CLOCK output has to be supervised via a K-input and the OFF instruction executed when the wished state is reached.

This CLOCK output can be used for the timing of external devices or for the improvement of the time measurement accuracy of the TSS400(/4). For this purpose, the CLOCK output is connected to a K-input via a gate controlled by an R output to allow the Done Mode without continuous wake up by the CLOCK frequency. During the critical time measurement the R output is switched on and the software can count the CLOCK pulses for better resolution.

### 2.14 The Current Saving Modes

It is not necessary for the TSS400(/4) to stay on at all times. The processor can be programmed to come on only if it is needed. This can be for updating the timekeeping or for performing a software function. The advantage is the vast amount of current saving by using these features of the TSS400(/4). Two different modes of current saving are possible: The Done Mode and the Off Mode. The following chapter will describe the common elements of both modes:

Wakeup from initialization: see Figure 11 for conditions.

Wakeup from K-Port or I/O Pin: See Figure 5. Depending on the Digit Latches DL14 and DL15 certain conditions must be met that wakeup can occur. Only if the conditions described under "before wakeup" are met, the conditions described under "wakeup condition" will wakeup the CPU from Done Mode or Off Mode.

For example if DL14 = DL15 = 0: Only if all K-Ports and the I/O Pin are low, then the LO-HI change of anyone of the inputs will wakeup the TSS400(/4).

| DL15 | DL14 | I/O Pin | K8 | K4 | K2 | K1 | Comment |
| :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | before wakeup |
| 0 | 1 | 1 or | 1 or | 1 or | 1 or | 1 | wakeup condition |
|  |  | 0 | 1 | 0 | 0 | 0 | before wakeup |
| 1 | 0 | X or | 0 or | 1 or | 1 or | 1 | wakeup condition |
|  |  | X | 0 | 0 | 0 | 0 | before wakeup |
| 1 | 1 | X | 1 | 1 or | 1 or | 1 | wakeup condition |
|  |  | X | 0 or | 1 or | 1 or | 1 | 1 |
| before wakeup |  |  |  |  |  |  |  |
|  |  |  | wakeup condition |  |  |  |  |

Figure 5: Wakeup Conditions for external Events

The processor registers wake up with the following contents:

| Register |  | Done Mode | Off Mode |
| :--- | :--- | :--- | :--- |
| Program Counter PC | $>7 F$ | $>7 F$ |  |
| Page Address | PA | 15 | 15 |
| Page Buffer | PB | 15 | 15 |
| Status | S | undefined | undefined |
| Special Status | SS | undefined | undefined |
| Accumulator | A | undefined | undefined |
| Y register | Y | undefined | undefined |
| X register | X | undefined | undefined |
| RAM Contents |  | unchanged | unchanged |
| DAM Latch |  | undefined | undefined |
| ADD Latch |  | reset to 0 | reset to 0 |
| BRANCH Latch |  | reset to 0 | reset to 0 |
| Decimal Point | DP | reset to 0 | reset to 0 |
| Digit Latches | DLn | unchanged | unchanged |
| K-Port Latch | unchanged | unchanged |  |
| l/O Port Data Latch | unchanged | unchanged |  |
| I/O Port Control Latch | unchanged | unchanged |  |
| Timer0 and Timer1 | actual time | undefined |  |
| ADC voltage SV DD | switched off | switched off |  |
| LCD segment latches | unchanged | unchanged |  |
| Subroutine Stack | level 0 | level 0 |  |

Figure 6: Wakeup Contents of internal Registers
Note: Due to the undefined state of the status a BRANCH or CALL instruction located at page 15 PC 7 F (wakeup address) will not be executed safely. It is strongly recommended to use an instruction which is executed independently from the status at the wakeup address (LDX e.g.)

When in Active Mode, a delay line is active which stores all events that could wake up the CPU in Off Mode or Done Mode up to 5 instruction cycles. This ensures that no event is missed if the DONE instruction fol-

Revision 1, July 1991
lows within 5 instructions after the last software check. This delay is not active when in Done Mode or Off Mode. The CPU wakes up immediately in these cases.

Example: To ensure safe wake up in situations described as above the sequence before the DONE instruction should look like:

| TKA | LAST CHECK FOR CHANGES |
| :--- | :--- |
| $\ldots$ |  |
| $\ldots$ | 3 INSTRUCTIONS MAX. |
| $\ldots$ |  |
| DONE | OR OFF INSTRUCTION |

### 2.14.1 The Done Mode

During the Done Mode the CPU is switched off completely. Only the timer, the RAM banks, the LCD driver, the Digit Latches and certain other registers are active. See Figure 6 for more information concerning data retention during the Done Mode. The other registers do not maintain information. Wakeup from this mode can come from the timer, the K-Port, the I/O Pin or initialization.

Wakeup from timer: Dependent on DL12 the TSS400(/4) will be woken up with $1 \mathrm{~Hz}(\mathrm{DL} 12=0)$ or with a frequency ranging from 8 Hz to 128 Hz selectable by the hardware option .OPTION WAKEUP-FREQUENCY (DL12 = 1). The wakeup from the timer occurs always, independent of the state of the K-Port or I/O pin. When woken up by the timer, there must be a minimum number of instructions $N$ until the DONE instruction can be used.

$$
N \geq \frac{4 \cdot \text { Max. processor frequency }}{6 \cdot \text { Min. timer frequency }}
$$

The Done Mode is entered by execution of the DONE instruction. The ADC voltage $\mathrm{SV}_{\mathrm{DD}}$ is switched off by entering the Done Mode. The frequency output at the CLOCK pin continues during the Done Mode.

### 2.14.2 The Off Mode

During the Off Mode the CPU is switched off completely. Only the RAM banks and Digit Latches and certain other registers are active. See Figure 6 for more information concerning data retention during the Off Mode. Wakeup from the Off Mode can come only from initialization, the K-Port or the I/O Pin. See Figure 5 for wakeup conditions. The current consumption is further reduced compared to the Done Mode.
The Off Mode is entered by execution of the instruction OFF. The ADC voltage SV $_{\text {DD }}$ is switched off by entering the OFF Mode. The CLOCK output remains the current state ( HI or LO) after execution of the OFF instruction.

### 2.15 The Analog Digital Converter

The TSS400(/4) contains an Analog Digital Converter with a resolution of 12 bits. Up to 4 analog inputs are possible which are named A1 to A4. The input selection is made by DL9, DL10 and DL11:

| DL11 | DL10 | DL9 | Function |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | A1 to comparator |
| 0 | 1 | 0 | A2 to comparator |
| 1 | 0 | 0 | A3 to comparator |
| 1 | 1 | 0 | A4 to comparator |
| x | x | 1 | Battery check |

Figure 7: Analog-Digital-Converter Addressing

The ADC does not measure absolute voltages but the ratio of the input voltage to the supply voltage. So the measurement of sensors is independent of the supply voltage. Absolute measurements are possible if $\mathrm{SV}_{D D}$ is held constant, which means stable $\mathrm{V}_{\mathrm{DD}}$ and very small loading at $\mathrm{SV}_{\mathrm{DD}}$.

The following instructions control the AVD converter:
SCSV Switches on the SV ${ }_{\text {DD }}$ of the ADC. Switches comparator inputs to noninverted.
RCSV Switches off the SV ${ }_{D D}$ of the ADCT.
CTM Transfers output of comparator to addressed memory bit and sets next lower bit to 1.
TRTM Sets addressed memory bit to 1 if input voltage is out of ADC range (result 000 or >FFF). Resets bit otherwise.
$\mathrm{RCI} \quad$ Switches comparator inputs to inverted.
The Analog Digital Conversion can be done by a simple software program using successive approximation. The memory nibbles $M(15,13-15)$ are connected to a Digital Analog Converter (DAC) where $M(15,13,3)$ is the MSB and $M(15,15,0)$ is the LSB. Starting with the midpoint of the range ( $>800$ ) the input voltage is compared to the output voltage of the DAC and the comparator output written to the addressed memory bit. Additional the next lower memory bit is set for the next comparison (no bit is set if $M(X, Y, 0)$ is addressed). With 12 comparisons a 12 bit result is built.

The basic principle of the successive approximaton routine is shown in the next example:

|  | LDX | 15 | LOAD >800 INTO |
| :---: | :---: | :---: | :---: |
|  | TCY | 13 | M (15, 13-15) |
|  | TCMIY | 8 | TO HAVE MIDPOINT OF RANGE |
|  | TCMIY | 0 |  |
|  | TCMIY | 0 |  |
|  | TCY | 13 | START WITH MSD M $(15,13)$ |
| ADCLOOP | SBIT | 3 | SET MSB OF NIBBLE (WHICH IS NOT |
|  | TCTM | 3 | SET BY TCTM 0 BEFORE) |
|  | TСTM | 2 | MAKE 4 COMPARES PER NIBBLE |
|  | TCTM | 1 |  |
|  | TСTM | 0 |  |
|  | IYC |  | NEXT LOWER NIBBLE |
|  | YNEC | 0 | LSD BUILT YET ? |
|  | BRANCH | ADCLOOP | IF NOT, PROCEED |
|  | -•• |  | 12 BIT RESULT IN M (15,13-15) |

To get the full accuracy of the ADC, slight modifications of the above idealistic example are recommended:

- A delay should be inserted between the modification of a DAC bit and the comparison with the input voltage. This delay should depend on the bit in use: When building the MSB of the ADC value a larger voltage swing occurs when the DAC bit is changed as compared with the change of the LSB. See 2.15.5 for details.
- For compensation of the offset error of the comparator, one more A/D conversion should be made with inverted comparator inputs. When added together with the result of the noninverted A/D conversion result, the offset error is eliminated.
- After each A/D conversion (inverted and noninverted) a test should be made if the input voltage was inside the range of the ADC. This is simply done by using the TRTM instruction which sets the addressed memory bit if the input voltage was outside of the range (result is 000 for underflow or >FFF for overflow) and resets the addressed memory bit if the input voltage was inside the range.
The above mentioned three improvements are included in the examples shown in 6.7. See there for explanations.


### 2.15.1 Measurement Ranges and Conversion Formulas

Four different measurement ranges are selectable by the hardware option .OPTION ADC-RANGE. The chosen range is the same for all inputs A1 to A4. The nominal properties of the 4 ranges are listed below:
$\mathrm{N} \quad \mathrm{A} / \mathrm{D}$ conversion result for single measurement
$V \min \quad \mathrm{Vin} / \mathrm{SV}_{\text {DD }}$ for $\mathrm{N}=1$
Vmax $\quad V i n / V_{\text {DD }}$ for $N=4094$ ( $>F F F$-1)
Resolution Delta in $\mu \mathrm{V} / \mathrm{SV}_{\text {DD }}$ for 1 bit result difference

| ADC RANGE | Vmin | $V \max$ | Resolution |
| :--- | :---: | :---: | :---: |
| LARGE | 0.101309 | 0.494607 | 96.1 |
| SMALL | 0.231314 | 0.407511 | 43.0 |
| MEDIUM-LOW | 0.100369 | 0.402501 | 73.8 |
| MEDIUM-HIGH | 0.232683 | 0.500413 | 65.4 |

Figure 8: Analog-Digital-Converter Ranges

The nominal conversion equations for single measurements are:
LARGE

$$
\begin{aligned}
\mathrm{Vin} / \mathrm{SV}_{D D} & =0.101213203+0.000096090233 \cdot \mathrm{~N} \\
\mathrm{~N} & =10406.88496 \cdot \mathrm{Vin} / \mathrm{SV}_{D D}-1053.314159
\end{aligned}
$$

SMALL $\quad V i n / S V_{D D}=0.231271438+0.000043048228 \cdot N$ $N=23229.76 \cdot V i n / S V_{D D}-5372.38$
MEDIUM-LOW Vin/SV $V_{D D}=0.100294841+0.000073816955 \cdot \mathrm{~N}$ $N=13547.02312 \cdot \operatorname{Vin} / S V_{D D}-1358.696532$
MEDIUM-HIGH $\quad \mathrm{Vin} / \mathrm{SV}_{D D}=0.232617939+0.000065411591 \cdot \mathrm{~N}$ $N=15287.81046 \cdot \operatorname{Vin} / S V_{D D}-3556.218954$

If, as recommended, even numbered measurement counts $M$ are used and the results are added together, the above mentioned conversion equations have to be modified as follows:
$\mathrm{Vin} / \mathrm{SV}_{\mathrm{DD}}=\mathrm{A}+\mathrm{B} \cdot \mathrm{N} \quad$ equation for single measurement
$\mathrm{Vin} / \mathrm{SV}_{D D}=\mathrm{A}+(\mathrm{B} \cdot \mathrm{N}) / \mathrm{M}$ equation for M measurements added
$N=E \cdot \operatorname{Vin} / S V_{D D}-F \quad$ equation for single measurement
$N=\left(E \cdot V i n / S V_{D D}-F\right) \cdot M$ equation for $M$ measurements added
Note: The useable range of the Analog Digital Converter starts at values greater than 1 and ends at values less than >FFE due to the offset of the comparator. The useable range depends on the $V_{D D}$ and the chosen hardware ADC range. See the specification for actual values.

### 2.15.2 Correction of Tolerances by Software

The conversion equations mentioned in 2.15 .1 show nominal values which in reality differ due to tolerances of Vmin and Vmax. The sensors connected to the ADC have tolerances too, so calibration of the complete system is necessary by hardware (potentiometer, resistors) or by software. The later one is possible if the TSS400(/4) is connected always to a battery. Correction variables once written into the RAM via the I/O Pin are used after the A/D conversion and nominal value computation for correcting the result.

Example: The subroutine TEMPCOMP (see 6.11.2) computes the nominal temperature $\mathrm{T}_{\text {nom }}$ out of the ADC value. RAM locations contain correction values C and D for adjusting the temperature value to the corrected temperature Treal:

$$
\begin{array}{ll}
T_{\text {nom }}=N \cdot 0.1363-6.696 & \text { TEMPCOMP constants } \\
T_{\text {real }}=T n o m \cdot C+D & \text { Correction formula } \\
C=\text { Slope correction } & \\
D=\text { Offset correction } &
\end{array}
$$

CALLL
CALLL
CALLL
CALLL
CALLL
CALLL
CALLL

TEMPCOMP HEX ADC $\rightarrow$ FLAC BCD
CLRREGB $+0->$ REGB
C $->$ RB
MULTIPL
DIV10E4
D->RB
ADPITION

Two possibilities are shown for the battery test:

- A complete measurement is made and the result compared to the stored value measured with $V_{D D}=V_{D D \min }$. If the measured value exceeds the stored one, then $V_{D D}<V_{D D m i n}$ and a "Battery low" indication can be given by software. See example 6.12.1
- The stored RAM value for $\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{DD} \text { min }}$ (measured only with inverted comparator inputs) is transferred to the ADC hardware buffer and compared with one instruction against the reference voltage. If the comparator output is 1 , the warning level is reached and a "Battery low" indication can be given by software. See example 6.12.2


### 2.15.4 The Current Source

A switchable current source is available for supplying special sensors. DL13 switches the current source which is simply programmable by an external resistor:

- DL13 $=0$ : current source is off
- DL13 = 1: current source is on if SV $_{\text {DD }}$ is on

When switched on, the current source feeds the constant current out of the addressed analog input An. The voltage generated at the external sensor is measured with the same input.
The current I programmed by the external resistor Rext is given by the following equation:

$$
I=V_{\text {rext }} / R_{\text {ext }}
$$

$\mathrm{V}_{\text {rext }}$ depends sligthly on the chosen ADC range and is approximatively $0.24 \cdot \mathrm{SV}_{\mathrm{DD}}$.

The current range for each ADC input is as follows:
0.15 to $2.4 \mathrm{~mA} \cdot \mathrm{SV}_{\mathrm{DD}} / \mathrm{V}$

This current range is sufficient to drive PT100 sensors, too. (Platinum temperature sensors with a nominal resistance of 100 Ohm )

### 2.15.5 Timing Considerations for the Measurement

As mentioned earlier, a delay should be inserted between the modification of a DAC bit and the comparison with the input voltage. This delay depends on the bit position of the DAC.

Figure 9 shows the number of delay instructions for each ADC-Bit. The TCTM instruction itself counts too.

| ADC-Bit | delay instr. |
| :--- | :---: |
| MSB | 5 |
| MSB-1 | 5 |
| MSB-2 | 5 |
| MSB-3 | 5 |
| MSB-4 | 4 |
| MSB-5 | 4 |
| MSB-6 | 4 |
| MSB-7 | 4 |
| MSB-8 | 3 |
| MSB-9 | 3 |
| MSB-10 | 3 |
| LSB | 3 |

Figure 9: Number of Instructions before ADC-Comparisons

### 2.16 The LCD Driver

The TSS400(/4) contains a complex LCD driver circuitry which can be modified widely for adapting the TSS400(/4) to the external hardware. The hardware steps the display information has to go through from the software instruction to the common/select line drivers are as follows:

- The software addresses the digit with the Y register and sets DL14, status and accumulator according to the character to be output. Then the TDO instruction is executed which starts the output of the display information.
- The OPLA address defined by DL14, status and accumulator is passed to a decoder, which activates 1 out of 64 output lines.
- The activated output line addresses the segment PLA which outputs the according 7 segments $A$ to $G$ and, dependent on the DP Latch, segment H .
- The segment information out of the segment PLA is transferred via 8 segment lines to the common/select programming area. (This programming area defines which common/select pair activates which segment). The output of the programming area is the segment information adapted to the used LCD display. (See .OPTION SELECT-LINES)
- The decoded ten Y register lines ( 0 to 9 ) are transferred to the Y programming area. (This programming area defines which $Y$ register contents activate which digit). The output of the $Y$ programming area addresses the segment latches. (See .OPTION SELECT-LINES)
- The adapted segment information is stored in the 8 segment latches of the addressed digit. Each of these segment latches controls a fixed common/select pair.
- The information of the segment latches is output automatically by the common and select drivers.

From a software point of view the LCD driver looks very simple:

- No timing problems exist with multiplexing for getting a quiet, stable display. The LCD driver hardware outputs the loaded display information automatically, without any software burden, during Active Mode and Done Mode.
- The software only has to decide which segment information (selected by DL14, status and accumulator) has to be displayed at which digit (addressed by Y register).

Steps for defining the display:

- decision if 2 common or 4 common is needed
- definition of $Y$ address for each digit
- definition of select line and common line for each segment
- definition of displayed segments for each DL14, status and accumulator combination
These 4 definition steps are discussed in detail in the following paragraphs.


### 2.16.1 Multiplexing Scheme

Two multiplexing schemes can be defined for the TSS400(/4) hardware:

- 2 common multiplexing
- 4 common multiplexing

2 common offers better readability, 4 common offers more digits (10 instead of 5 for 2 common). No difference exists for the software between the two multiplexing schemes, the addressing of the (possible) digits is exactly the same for both of them.
The definition is made with the hardware option .OPTION COMMON. See hardware options 2.18.11 for more information.

### 2.16.2 Digit Addressing

The TSS400(/4) hardware contains a programmable decoder for the addressing of the digits from the Y register. For each digit one (and only one) Y register value can be defined which addresses it. Normally a standard definition is used (see .OPTION SELECT-LINES), but if necessary, this definition is changeable to existing needs. The following example shows the inverse accordance between Y register and select lines than the standard definition defines. If RAM nibble and related digit share the same $Y$ address, additional TCY instructions can be ommitted during output of the display information.

| . OPTION SELECT-LINES |  |  |  | ; 2 common |
| :---: | :---: | :---: | :---: | :---: |
| LOAD | S1+S2 | BY | Y4 | ; Load digit by $Y=4$ |
| LOAD | S3+S4 | BY | Y4 |  |
| LOAD | S5+S6 | BY | Y3 |  |
| LOAD | S7+S8 | BY | Y3 |  |
| LOAD | S9+S10 | BY | Y2 |  |
| LOAD | S11+S12 | BY | Y2 |  |
| LOAD | S13+S14 | BY | Y1 |  |
| LOAD | S15+S16 | BY | Y1 |  |
| LOAD | S17+S18 | BY | Y0 |  |
| LOAD | S19+S20 | BY | Y0 |  |

### 2.16.3 Segment Addressing

For each segment the common line and select line can be defined which activate it. This omits the tedious segment transformation task which is necessary if the used display differs from the standard definition. The common and select line for each segment can be defined with the second part of the hardware option .OPTION SELECT-LINES. The following example shows the inverse select line definition than the standard definition has:

```
!
COMMON 34
FOR MUX2 AND S4N-3 LOAD C D ; S1, S5, S9, S13, S17
FOR MUX2 AND S4N-2 LOAD G E ; S2, S6, S10, S14, S18
FOR MUX2 AND S4N-1 LOAD A F ; S3, S7, S11, S15, S19
FOR MUX2 AND S4N LOAD B H ; S4, S8, S12, S16, S20
```


### 2.16.4 The Output PLA

The TSS400(/4) LCD driver contains a gate level PLA with $64 \times 7$ bits. The 7 bits represent the segment information $A$ to $G$ for 64 definable combinations (the segment H info is independent from this OPLA and depends only on the SDP and RDP instructions). This OUTPUT PLA is used to simplify the output of the displayed characters e.g. if a "4" is to be output, the accumulator contains 4 and is written to the segment latches via the OPLA which outputs B,C,F,G for this input code. (Without the OPLA feature the segment representation of $4(B, C, F, G)$ has to be built and output.
The addressing of this 64 segment combinations is made by DL14 (MSB), status, and accumulator (4 LSBs).

The definition of this OPLA is made by .OPTION SEGMENT-PLA. See 2.18.13 for this option.

Characters 00 to 15 are addressed by DL14 $=0$, status $=0$ Characters 16 to 31 are addressed by DL14 $=0$, status $=1$ Characters 32 to 47 are addressed by DL14 $=1$, status $=0$ Characters 48 to 63 are addressed by DL14 $=1$, status $=1$

## Some hints:

- If 32 OPLA characters are sufficient, the definitions of the characters 32 to 63 should be made equal to the ones for the characters 00 to 31 . This gives independency from DL14.
- Note that DL14 is used with the K8 edge detection too. This can lead to conflicts if display information is output while DL14 has to be stable.
- When defining the OPLA the most used characters (normally the numbers 0-9) should be placed from character 16 to 31 . (defined for status $=1$, the normal state of the status). Binary output for flags can be placed into characters 00 to 15.

Examples: For each character block a control sequence is given.

```
* SEQUENCE OUTPUTS DEFINED CHARACTEERS 00 TO 15
```

* 

| TMA |  | $M(X, Y) \rightarrow A$ |
| :--- | :--- | :--- |
| TCY | DL14 | RESET DL14 |
| RSTR |  |  |
| ACACC | 0 | STATUS $=0$ |
| TDO |  | OUTPUT CHARACTER 00 TO 15 |

* SEQUENCE OUTPUTS DEFINED CHARACTERS 16 TO 31
* 

```
TMA M(X,Y) >> A
TCY DL14 RESET DL14
RSTR STATUS = 1
TDO OUTPUT CHARACTER 16 TO 31
```

* SEQUENCE OUTPUTS DEFINED CHARACTERS 32 TO 47
* 

| TMA |  | $\mathrm{M}(\mathrm{X}, \mathrm{Y}) \rightarrow$ A |
| :---: | :---: | :---: |
| TCY | DL14 | SET DL14 |
| SETR |  |  |
| ACACC | 0 | STATUS $=0$ |
| TDO |  | OUTPUT CHARACTER 32 TO 47 |

* SEQUENCE OUTPUTS DEFINED CHARACTERS 48 TO 63
* 

Revision 1, July 1991

| TMA |  | $M(X, Y)->~ A$ |
| :--- | :--- | :--- | :--- |
| TCY | DL14 | SET DL14 |
| SETR |  | STATUS $=1$ |
| TDO |  | OUTPUT CHARACTER 48 TO 63 |

The character number in the OPLA definition is the decimal representation of DL14, status and accumulator:


Figure 10: Character Representation in OUTPUT OPLA

Due to the free choice of a segments common/select accordance by the .OPTION SELECT-LINES (See 2.18.12) the OPLA can be defined using the standard segment notation. See Figure 12 for this standard notation.

### 2.17 Initialization and Power-Up

Initialization can have two hardware reasons:

- Power-Up: The voltage $\mathrm{V}_{\mathrm{DD}}$ is switched on (Cold start). The CPU starts operation at page $15, \mathrm{PC}=00$ when the internal timer oscillator started operation and has output 6 to 8 cycles.
- INITN Pin: Is held low for more than $10 \mu \mathrm{~s}$ (if this occurs during program execution it is named Warm start). The CPU starts operation at Page 15, PC = 00 when the INITN Pin is released to $\mathrm{V}_{\mathrm{DD}}$ potential.
The TSS400(/4) internal registers have the following contents after the occurence of power up or the activation of the INIT Pin.

| Register |  | Power up | INITN Pin |
| :--- | :--- | :--- | :--- |
| Program Counter | PC | 00 | 00 |
| Page Address | PA | 15 | 15 |
| Page Buffer | PB | 15 | 15 |
| Status | S | undefined | undefined |
| Special Status | SS | undefined | undefined |
| Accumulator | A | undefined | undefined |
| Y register | Y | undefined | undefined |
| X register | X | undefined | undefined |
| RAM Contents | (see Note) | undefined | unchanged |
| DAM Latch |  | undefined | undefined |
| ADD Latch |  | reset to 0 | reset to 0 |
| BRANCH Latch |  | reset to 0 | reset to 0 |
| Decimal Point | DP | reset to 0 | reset to 0 |
| Digit Latches | DLn | reset to 0 | reset to 0 |
| K-Port Latch | undefined | unchanged |  |
| I/O Port Data Latch | undefined | unchanged |  |
| I/O Port Control Latch | reset to 0 | reset to 0 |  |
| Timer0 and Timer1 | undefined | unchanged |  |
| ADC Voltage SV | sw | switched off | switched off |
| LCD Segment Latches | undefined | unchanged |  |
| Subroutine Stack | level 0 | level 0 |  |

Figure 11: Initialization Contents of internal Registers

[^5]Note: Despite the RAM remains unchanged if Warm start (see below) occurs, the memory addressed when the INITN Pin was activated may be destroyed by a write cycle.
Due to the undefined state of the status a BRANCH or CALL instruction located at page 15
$\mathrm{PC}=00$ (power up address) will not be executed surely. It is strongly recommended to use an instruction which is executed independently of the status at the initialization address (LDX, TCY e.g.).
The instruction located at page $15, \mathrm{PC}=00$ maybe executed repeatedly. Thus toggle instructions (TDL, COMX8 e.g.) at this address should be ommitted.

If the TSS400(/4) system is battery powered and contains calibration factors or other important data in its RAM it is advised to distinguish between Cold start and Warm start. The reason is the possibility of initializations caused by EMI. If such an erroneous initialization is not tested for legality, EMI influence could destroy the RAM contents by clearing the RAM with the initialization software routine. Testing can be made by comparing RAM nibbles with known contents to their nominal value. These RAM nibbles could be identification codes or extra written test patterns (e.g. A5). If the tested RAM contains the right pattern, a spurious signal caused the initialization and normal program can continue. If the tested RAM nibbles differ from the nominal value, the RAM contents have been destroyed (e.g. by loss of power) and the initialization routine is invoked (clearing RAM, initializing computing constants). See 6.13 for software realization.

### 2.18 Hardware Options

The high grade of flexibility the TSS400(/4) offers makes it necessary to define which of the available options are used for a given application. With the hardware options it is possible to define completely the hardware for a TSS400(/4). A complete hardware definition is given in 2.18.15. See also "ADT User's Guide Compile Specification" for further details on putting together an actual specification list.

### 2.18.1 The Version Definition .OPTION VERSION

This option defines the product code for the TSS400(/4) mask. The code "yyy" is replaced by a 3 digit decimal number.

```
.OPTION VERSION
VERSION SYYY ON TSS40X
```

TSS40X describes which version of the TSS400 is used. The options are:
TSS400 TSS400/4
TSS402 TSS402/4
TSS403 TSS403/4
TSS404 TSS404/4
TSS405 TSS405/4

### 2.18.2 The Object Definition .OPTION ROM

This option precedes the object which is to be placed into the ROM of the TSS400(/4).

```
.OPTION ROM
TSS0400 OBJECT: EXAMPL CREATED 22 JUN 1987 10:29:21 VERS J.3 LB
0046000D002100400126014700E2000D0000008C008D0083000001270036019A
```

00BF005A006B009C01BC000600560080014C01FA004F01150094002301E800BF

### 2.18.3 The Pinning Definition .OPTION PINNING

This option precedes the definitions of the connections between the TSS400(/4) chip and the actual package pins. See 2.18.15 for an example of this option.

### 2.18.4 The K8 Flip Flop Definition .OPTION K8FF

This option defines if the K8 input goes to the ALU directly (FLIP-FLOP DISABLED) or if it is divided by a flip flop (FLIP-FLOP ACTIVE).
. OPTION K8FF
FLIP-FLOP DISABLED
FLIP-FLOP ACTIVE

```
FLIP-FLOP IN K8-INPUT
NORMAL K8 INPUT
K8 INPUT DIVIDED BY }
```


### 2.18.5 The Pulldown Definition .OPTION K1K2K4K8IO

This option has two parts which are completely independent. The 1st part defines if a pulldown resistor is required for any input of the K-Port and the I/O pin. Allowed responses are YES and NONE. The 2nd part defines if the K-port, used as an output, has push-pull characteristics (NO) or open source characteristics (YES). Open source is recommended for keyboard scanning or other applications where a serial diode is needed normally. Push pull is recommended for driving of gates or switching of lines.

```
.OPTION K1K2K4K8IO
INPUT K1 PULL-DOWN YES ; K1 has pulldown resistance
INPUT K2 PULL-DOWN NONE ; K2 not
INPUT K4 PULL-DOWN YES
INPUT K8 PULL-DOWN YES
INPUT I/O PULL-DOWN NONE
OUPUT K1 OPEN-SOURCE NO ; K1 has push-pull output stage
OUPUT K2 OPEN-SOURCE YES ; K2 has open source output stage
OUPUT K4 OPEN-SOURCE NO
OUPUT K8 OPEN-SOURCE NO
```


### 2.18.6 The ADC Range Definition .OPTION ADC-Range

This option defines which range is to be used for the Analog Digital Converter. 4 different ranges are available, each with 4094 steps. Only one range is possible for all ADC inputs.

```
.OPTION ADC-RANGE
RANGE-IS LARGE ; 0.1013 x SVDD - 0.4946 x SVDD
```

The other possible ADC ranges are:

```
RANGE-IS SMALL ; 0.2313 x SVDD - 0.4075 x SVDD
RANGE-IS MEDIUM-LOW ; 0.1003 x SVDD - 0.4025 x SVDD
RANGE-IS MEDIUM-HIGH ; 0.2327 x SVDD - 0.5004 x SVDD
```


### 2.18.7 The Oscillator Speed Definition .OPTION OSCILLATOR

This option defines the source of the frequency for the MOS oscillator which is used for CPU timing. The item EXTERN means oscillator input via pin PFRQ which overwrites the internal oscillator.

```
.OPTION OSCILLATOR
FREQUENCY HIGH ; 500 - 950 kHz INTERNAL
```

The other possible frequency ranges are:

```
FREQUENCY EXTERN ; EXTERNALLY FED FREQUENCY
```


### 2.18.8 The Wake-up Frequency Definition .OPTION WAKE-UPFREQUENCY.

This option defines the wakeup frequency which is active when DL12 is set (1). A timer oscillator frequenzy of 32768 Hz is assumed for the named wakeup frequencies.

```
.OPTION WAKE-UP-FREQUENCY
FREQUENCY 32HZ ; Wakeup with 32 Hz
```

The other possible wakeup frequencies are:

| FREQUENCY | 8 HZ |
| :--- | :--- |
| FREQUENCY | 16 HZ |
| FREQUENCY | 64 HZ |
| FREQUENCY | 128 |
| FZ | $; 16 \mathrm{~Hz}$ |
|  | $; 64 \mathrm{~Hz}$ |
| 128 Hz |  |

### 2.18.9 The Output Frequency Definition .OPTION CLOCK

This option defines if a frequency which is derived from the timer oscillator is connected to pin CLOCK or if the pin is ommitted. Two frequencies are possible (a timer oscillator frequency of 32768 Hz is assumed):

```
.OPTION CLOCK
FREQUENCY 256HZ ; 256 Hz connected to pin CLOCK
```

The other possible options are:

```
FREQUENCY 1024HZ ; 1024 Hz connected to pin CLOCK
FREQUENCY NONE ; Pin CLOCK is ommitted
```

Revision 1, July 1991

### 2.18.10 The Timer Oscillator Definition .OPTION TIMOSC

This option defines the timer oscillator circuitry which is the time base for the display driver too. If no timer accuracy is needed the TRC option can be used which is cheap (only a resistor and a capacitor are needed) and has very fast start up features. If a display is used with this option, be sure that the worst case timer frequencies meet the limits of the display frame rate DFR:

$$
\mathrm{DFR}=\frac{\text { timer frequency }}{512}
$$

If an accurate time base is necessary the option TXOSC and a quartz (10 to 100 kHz ) are needed.

```
.OPTION TIMOSC
USE TRC ; RC DRIVEN TIMER OSCILLATOR
USE TXOSC ; QUARTZ DRIVEN OSCILLATOR
```


### 2.18.11 The LCD Multiplex Definition .OPTION COMMON

This option defines if 2 common multiplex or 4 common multiplex is used for the LCD display driver.

```
.OPTION COMMON
USE MUX4 ; }4\mathrm{ common multiplex
```

The other possible option is:
USE MUX2 ; 2 common multiplex

### 2.18.12 The Select Line Definition .OPTION SELECT-LINES

This option defines the controlling Y contents for each LCD digit and the common/select definition for each segment.

The 1st example shows the default definition for 4 common multiplex:

```
.OPTION SELECT-LINES ; 4 common multiplex
LOAD S1+S2 BY Y0 ; Load digit by Y = 0
LOAD S3+S4 BY Y1
LOAD S5+S6 BY Y2
LOAD S7+S8 BY Y3
```



The 2nd example shows the default definition for 2 common multiplex:

| . OPTION SELECT-LINES |  |  |  |  |  | ; 2 common multiplex <br> ; Load digit by $Y=0$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOAD | S1+S2 | BY Y0 |  |  |  |  |  |
| LOAD | S3+S4 | BY Y0 |  |  |  |  |  |
| LOAD | S5+S6 | BY Y1 |  |  |  |  |  |
| LOAD | S7+S8 | BY Y1 |  |  |  |  |  |
| LOAD | S9+S10 | BY Y2 |  |  |  |  |  |
| LOAD | S11+S12 | BY Y2 |  |  |  |  |  |
| LOAD | S13+S14 | BY Y3 |  |  |  |  |  |
| LOAD | S15+S16 | BY Y3 |  |  |  |  |  |
| LOAD | S17+S18 | BY Y4 |  |  |  |  |  |
| LOAD | S19+S20 | BY Y4 |  |  |  |  |  |
| $!$ |  |  | COMMON | 3 | 4 |  |  |
| FOR | MUX2 AND | S4N-3 | LOAD | B | H |  | S1, S5, S9, S13, S17 |
| FOR | MUX2 AND | S4N-2 | LOAD | A | F |  | S2, S6, S10, S14, S18 |
| FOR | MUX2 AND | S4N-1 | LOAD | G | E |  | S3, S7, S11, S15, S19 |
| FOR | MUX2 AND | S4N | LOAD | C | D |  | S4, S8, S12, S16, S20 |

### 2.18.13 The Output PLA Definition .OPTION SEGMENT-PLA

This option defines the output pattern for the LCD display. Which pattern is to be output depends on DL14, status and accumulator.

All 64 possibilities have to be defined. Only the segment H is controlled outside this option by the DP Latch. The segments are named as usual:

[^6]

H (Decimal Point)

Figure 12: Standard Segment Notation Scheme

This is possible by defining the segments with the hardware option .OPTION SELECT LINES at the appropriate common/select combinations. See 2.18.12 for this definitions.
Example: A part of the 64 definitions is shown below.

```
CHARACTER 00 HAS-SEGMENTS NONE ; DL14 = 0, ST = 0
CHARACTER 01 HAS-SEGMENTS B C ; 1
CHARACTER 08 HAS-SEGMENTS A B C D E F G ; 8
CHARACTER 15 HAS-SEGMENTS NONE ; BLANK
CHARACTER 63 HAS-SEGMENTS G
```


### 2.18.14 The .OPTION PACKAGE

The option PACKAGE defines which package is used. there are 3 packages available: 44PLCC, 40DIP, 28DIP
. OPTION PACKAGE
44 PLCC

### 2.18.15 The End of Options Indication .END

This statement terminates the definition of the hardware options:
. END

### 2.18.16 Example for a complete TSS400(/4) Hardware Definition

!

| . OPTİON VERSION |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VERSION S211 ON TSS400 |  |  |  |  |  |  |  |
| ! |  |  |  |  |  |  |  |
| . OPTION | PINNING |  |  |  |  |  |  |
| ! |  |  | NO TEST | TEST | K | R | S/C |
| $!$ |  |  | $\mathrm{KC}=0$ |  | RMIN | RMOUT | HVT |
| PAD 1 | IS-PIN | 1 | APPL VSS | TEST | vss | VSS | VSS |
| PAD | IS-PIN | 2 | APPL KC | TEST | KC | KC | KC |
| PAD 3 | IS-PIN | 3 | APPL INITN | TEST | INITN | INITN | INITN |
| PAD | IS-PIN | 4 | APPL VDD | TEST | VDD | VDD | VDD |
| PAD | IS-PIN | NONE | APPL NONE | TEST | NONE | R1 | NONE PULLDO |
| PAD | IS-PIN | 5 | APPL SVDD | TEST | SVDD | SVDD | SVDD |
| PAD | IS-PIN | 6 | APPL RI | TEST | RI | RI | RI PULLDO |
| PAD | IS-PIN | 7 | APPL A4 | TEST | A4 | A4 | A4 PULLD |
| PAD | IS-PIN | NONE | APPL NONE | TEST | NONE | R2 | NONE PULLDO |
| PAD 10 | IS-PIN | 8 | APPL A3 | TEST | A3 | A3 | A3 PULLDO |
| PAD 11 | IS-PIN | NONE | APPL NONE | TEST | NONE | R3 | NONE PULLDO |
| PAD 12 | IS-PIN | 9 | APPL A2 | TEST | A2 | A2 | A2 PULLD |
| PAD 13 | IS-PIN | NONE | APPL NONE | TEST | CLOCK | CLOCK | CLOCK PULLD |
| PAD 14 | IS-PIN | 10 | APPL A1 | TEST | A1 | A1 | A1 PULLDO |
| PAD 15 | IS-PIN | 11 | APPL K8 | TEST | K8 | NONE | NONE PULLDO |
| PAD 16 | IS-PIN | 12 | APPL AGND | TEST | AGND | AGND | AGND PULLDO |
| PAD 17 | IS-PIN | 13 | APPL XOSCOUT | TEST | xoscout | Xoscou | jt XoSCOUT ; |
| PAD 18 | IS-PIN | 14 | APPL XOSCIN | TEST | XOSCIN | XoSCIN | J XOSCIN |
| PAD 19 | IS-PIN | 15 | APPL K4 | TEST | K4 | NONE | NONE PULLDO |
| PAD 20 | IS-PIN | 16 | APPL K1 | TEST | K1 | NONE | NONE PULLDO |
| PAD 21 | IS-PIN | 17 | APPL I/O | TEST | I/O | I/O | I/O PULLDO |
| PAD 22. | IS-PIN | 18 | APPL R0 | TEST | NONE | R0 | S20 |
| PAD 23 | IS-PIN | 19 | APPL K2 | TEST | K2 | NONE | S19 |
| PAD 24 | IS-PIN | 20 | APPL R4 | TEST | NONE | R4 | NONE |
| PAD 25 | IS-PIN | NONE | APPL R5 | TEST | NONE | R5 | NONE |
| PAD 26 | IS-PIN | 21 | APPL S18 | TEST | NONE | R6 | S18 |
| PAD 27 | IS-PIN | 22 | APPL S17 | TEST | NONE | R7 | S17 |
| PAD 28 | IS-PIN | 23 | APPL S16 | TEST | NONE | NONE | S16 |
| PAD 29 | IS-PIN | 24 | APPL S15 | TEST | NONE | NONE | S15 |
| PAD 30 | IS-PIN | 25 | APPL S14 | TEST | NONE | NONE | S14 |


| PAD 31 | IS-PIN 26 | APPL S13 | TEST | S13 | S13 | S13 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PAD 32 | IS-PIN 27 | APPL S12 | TEST | S12 | S12 | S12 | ; |
| PAD 33 | IS-PIN 28 | APPL S11 | TEST | S11 | S11 | S11 | ; |
| PAD 34 | IS-PIN 29 | APPL S10 | TEST | COA4A1 | MOSOSC | S10 | ; |
| PAD 35 | IS-PIN 30 | APPL S9 | TEST | STA8A2 | PC6 | S9 | ; |
| PAD 36 | IS-PIN 31 | APPL S8 | TEST | S8 | S8 | S8 |  |
| PAD 37 | IS-PIN 32 | APPL S7 | TEST | S7 | S7 | S7 |  |
| PAD 38 | IS-PIN 33 | APPL S6 | TEST | S6 | S6 | S6 |  |
| PAD 39 | IS-PIN 34 | APPL S5 | TEST | S5 | S5 | S5 |  |
| PAD 40 | IS-PIN 35 | APPL S4 | TEST | R036 | R036 | S4 |  |
| PAD 41 | IS-PIN 36 | APPL S3 | TEST | R147 | R147 | S3 |  |
| PAD 42 | IS-PIN 37 | APPL S2 | TEST | R258 | R258 | S2 |  |
| PAD 43 | IS-PIN 38 | APPL S1 | TEST | S1 | S1 | S1 |  |
| PAD 44 | IS-PIN 39 | APPL COM3 | TEST | COM3 | COM3 | COM 3 |  |
| PAD 45 | IS-PIN 40 | APPL COM4 | TEST | COM4 | COM4 | COM4 |  |
| $!$ |  |  |  |  |  |  |  |
| . OPTION | PACKAGE |  |  |  |  |  |  |
| 40DIP |  |  |  |  |  |  |  |
| ! |  |  |  |  |  |  |  |
| . OPTION | ROM |  |  |  |  |  |  |
| TSS0400 | OBJECT: EXAMPL CREATED 16 JUN 1987 10:29:21 VERS J. 3 LB | CREATED 16 JUN 1987 10:29:21 VERS J. 3 LB |  |  |  |  |  |
| 0046000 D | 0021004001 | 6014700E200 | 00000 | C008D0 | 33000001 | 7003 |  |
| 00980000 | 0100011 E 0 | 0180000001 | 19 C 00 | 000000 | 500980 | 8008 |  |

Note: Only four lines out of the 128 object lines are shown.

```
01E3009D008D017601150067000001FA001A0084000000360189014900480100
00BF005A006B009C01BC000600560080014C01FA004F01150094002301E800BF
!
.OPTION K1K2K4K8IO
INPUT K1 PULL-DOWN YES
INPUT K2 PULL-DOWN NO
INPUT K4 PULL-DOWN YES
INPUT K8 PULL-DOWN YES
INPUT I/O PULL-DOWN YES
OUTPUT K1 OPEN-SOURCE NO ; PUSH-PULL
OUTPUT K2 OPEN-SOURCE NO ; PUSH-PULL
OUTPUT K4 OPEN-SOURCE NO ; PUSH-PULL
OUTPUT K8 OPEN-SOURCE NO ; PUSH-PULL
!
.OPTION K8FF
FLIP-FLOP ACTIVE ; FLIP FLOP IN K8-INPUT
!
.OPTION ADC-RANGE
RANGE-IS LARGE ; 0.101 x SVDD - 0.49 x SVDD
!
```

```
.OPTION OSCILLATOR
FREQUENCY HIGH ; INTERNAL OSCILATOR
!
.OPTION WAKE-UP-FREQUENCY
FREQUENCY 8HZ ; 8 Hz wakeup for DL12 = 1
!
    .OPTION CLOCK
FREQUENCY NONE
!
    .OPTION TIMOSC
USE TXOSC ; QUARTZ IS USED
!
    .OPTION COMMON
USE MUX2
    .OPTION DELINIT IS ACTIVE
!
    .OPTION SELECT-LINES ; 2 COMMON STANDARD
LOAD S1+S2 BY Y0
LOAD S3+S4 BY Y0
LOAD S5+S6 BY Y1
LOAD S7+S8 BY Y1
LOAD S9+S10 BY Y2
LOAD S11+S12 BY Y2
LOAD S13+S14 BY Y3
LOAD S15+S16 BY Y3
LOAD S17+S18 BY Y4
LOAD S19+S20 BY Y4
! COMMON 1 2
FOR MUX2 AND S4N-3 LOAD D H ; Special select/common
FOR MUX2 AND S4N-2 LOAD E C ; combination
FOR MUX2 AND S4N-1 LOAD G B
FOR MUX2 AND S4N LOAD F A
!
.OPTION SEGMENT-PLA
! DL14 = 0 , ST = 0
CHARACTER 00 HAS-SEGMENTS NONE ;
CHARACTER 01 HAS-SEGMENTS A ;
CHARACTER 02 HAS-SEGMENTS A B ;
CHARACTER 03 HAS-SEGMENTS A B C ;
CHARACTIER 04 HAS-SEGMENTS A B C D ;
CHARACTER 05 HAS-SEGMENTS A B C D E ;
CHARACTER 06 HAS-SEGMENTS A B C D E F ;
CHARACTER 07 HAS-SEGMENTS A B C D E F G ;
CHARACTER 08 HAS-SEGMENTS B C D E F G ;
CHARACTER 09 HAS-SEGMENTS C D E F G ;
CHARACTER 10 HAS-SEGMENTS D E F G ;
CHARACTER }11\mathrm{ HAS-SEGMENTS E F G ;
```

```
CHARACTER 12 HAS-SEGMENTS F G ;
CHARACTER 13 HAS-SEGMENTS G ;
CHARACTER 14 HAS-SEGMENTS NONE
CHARACTER 15 HAS-SEGMENTS NONE
\(!\)
! \(\quad\) DL14 \(=0, S T=1\)
CHARACTER 16 HAS-SEGMENTS A B C D E F ; 0
CHARACTER 17 HAS-SEGMENTS B C ; 1
CHARACTER 18 HAS-SEGMENTS A B D E G ; 2
CHARACTER 19 HAS-SEGMENTS A B C D G ; 3
CHARACTER 20 HAS-SEGMENTS B C F G ; 4
CHARACTER 21 HAS-SEGMENTS A C D F G ; 5
CHARACTER 22 HAS-SEGMENTS A C D E F G ; 6
CHARACTER 23 HAS-SEGMENTS A B C ; 7
CHARACTER 24 HAS-SEGMENTS A B C D E F G ; 8
CHARACTER 25 HAS-SEGMENTS A B C D F G ; 9
CHARACTER 26 HAS-SEGMENTS A B C E F G ; A
CHARACTER 27 HAS-SEGMENTS C D E F G ; b
CHARACTER 28 HAS-SEGMENTS A D E F ; C
CHARACTER 29 HAS-SEGMENTS B C D E G ; d
CHARACTER 30 HAS-SEGMENTS A D E F G ; E
CHARACTER 31 HAS-SEGMENTS A E F G ; F
!
! \(\quad\) DL14 \(=1\), \(\mathrm{ST}=0\)
CHARACTER 32 HAS-SEGMENTS B C E F G ; H
CHARACTER 33 HAS-SEGMENTS B C D E ; J
CHARACTER 34 HAS-SEGMENTS D E F ; L
CHARACTER 35 HAS-SEGMENTS C E G ; n
CHARACTER 36 HAS-SEGMENTS C D E G ; O
CHARACTER 37 HAS-SEGMENTS A B E F G ; P
CHARACTER 38 HAS-SEGMENTS E G ; r
CHARACTER 39 HAS-SEGMENTS D E F G ; t
CHARACTER 40 HAS-SEGMENTS B C D E F ; U
CHARACTER 41 HAS-SEGMENTS C D E ; V
CHARACTER 42 HAS-SEGMENTS G ; -
CHARACTER 43 HAS-SEGMENTS D ;
CHARACTER 44 HAS-SEGMENTS A B C D ; - ]
CHARACTER 45 HAS-SEGMENTS NONE
CHARACTER 46 HAS-SEGMENTS NONE
CHARACTER 47 HAS-SEGMENTS NONE
!
! \(\quad\) DL14 \(=1, S T=1\)
CHARACTER 48 HAS-SEGMENTS A ; SINGLE SEGMENTS
CHARACTER 49 HAS-SEGMENTS B
CHARACTER 50 HAS-SEGMENTS C
CHARACTER 51 HAS-SEGMENTS D
CHARACTER 52 HAS-SEGMENTS E
```

```
CHARACTER 53 HAS-SEGMENTS F
CHARACTER 54 HAS-SEGMENTS G
CHARACTER 55 HAS-SEGMENTS B C G ; -1
CHARACTER 56 HAS-SEGMENTS B C D E F G ; INVERSE SINGLE SEGMENTS
CHARACTER 57 HAS-SEGMENTS A C D E F G
CHARACTER 58 HAS-SEGMENTS A B D E F G
CHARACTER 59 HAS-SEGMENTS A B C E F G
CHARACTER 60 HAS-SEGMENTS A B C D F G
CHARACTER 61 HAS-SEGMENTS A B C D E G
CHARACTER 62 HAS-SEGMENTS A B C D E F
CHARACTER 63 HAS-SEGMENTS NONE
. END
```


## 3 Standard Instruction Set Definitions

### 3.1 Effect on Status

Each instruction description in this section contains a status description. The way in which the instruction depends upon status or sets status is deined as follows:

- Set: The instruction is not conditional upon status and forces the status to one.
- Carry into status: The value of the carry from the adder is transferred to status. For the subtraction instructions,
Carry = Borrow.
- Comparison result: The logical comparison result from the ALU is transferred to status (equal: status is reset, unequal: status is set).
- Conditional on status: The instruction's execution results are conditional upon the state of the status. After executing the instruction, status is unconditionally set to one.
- Not applicable: Status not available due to nonoperating CPU.


### 3.2 Instruction Formats

### 3.2.1 Instruction Format I

This format has a two-bit opcode field, and the operand W is a seven bit ROM word address field. This format is used for program control by BRANCH and CALL instructions. The operand W, the branch address, has a value from 0 to $>3 F$ (127)


Figure 13: Instruction Format I

### 3.2.2 Instruction Format II

This format has a five-bit opcode field, and the operand $C$ is a four-bit constant field. This format is used for instructions that contain an immediate value. The operand C has a value from 0 to 15 .


Figure 14: Instruction Format II

Note: The constant value $C$ (from 0 to 15) is reversed in the C-field. The assembler properly converts any decimal value into this machine format. For example 3 (0011) is converted to 12 (1100).

### 3.2.3 Instruction Format III

This format has a seven-bit opcode field, and the operand B is a two-bit constant field. This format is used for instructions that address bits in a nibble. The operand $B$ has a value from 0 to 3 .


Figure 15: Instruction Format III

Note: The constant value B (from 0 to 3 ) is reversed in the B-field. The assembler properly converts any decimal value into this machine format. For example $2(10)$ is converted to 1 (01).

### 3.2.4 Instruction Format IV

This format defines a nine-bit operation code field only. Instructions of this format have no constant operands. The instruction always performs the same action, for example transferring the accumulator to the Y register.


Figure 16: Instruction Format IV

### 3.2.5 Coding Format

The following rules should be followed in writing a program:

- Label fields are a maximum of eight alphanumeric characters starting with an alphabetic character. The label field begins in column one.
- The operation code is to the right of a label, the two separated by at least one blank space. If no label is used, the operation code begins after the first column (second column or further over).
- The operand is to the right of the operation code, the two separated by at least one blank space.
- A comment is to the right of the operand, the two separated by at least one blank space. If a comment occupies a separate line, it must begin with an asterisk (*) in column one.
For legibility, it is recommended that the fields begin in the following columns:
- label fields begin in column 1
- operation codes should begin in columnn 11
- operands should begin in column 21
- comments to an instruction should begin in column 31
- comment lines begin in column one with an asterisk

Example: The following lines show source lines conforming to the above rules:

* THIS IS A PURE COMMENT LINE



### 3.2.6 Micro Instructions

The TSS400(/4) uses microcoded instructions and fixed instructions. If microinstructions are used, they are listed after the description of the instruction. This can be helpful in understanding the effects of an instruction.
The used microinstructions are:
STO Accumulator moved to addressed memory
CKM CKB logic output to addressed memory
@CKP CKB logic connected to $P$ adder input
@YTP $\quad$ Y register connected to $P$ adder input
@MTP Addressed memory connected to $P$ adder input
@ATN Accumulator connected to N adder input
@NATN Inverted accumulator connected to N adder input
@MTN Addressed memory connected to N adder input
@15TN Constant 15 (-1) connected to $N$ adder input
@CKN CKB logic connected to $N$ adder input
NE Comparator output written to status
C8 Carry out of MSB written to status
@CIN Constant 1 added
AUTA ALU output written to accumulator
AUTY ALU output written to Y register
@NDMTP Inverted DAM connected to $P$ adder input
@DMTP DAM connected to $P$ adder input
SSE Special Status set or reset according to result
$\begin{array}{ll}\text { SSS } & \text { Special Status added to adder inputs } \\ \text { CME } & \text { Accumulator moved to memory conditionally }\end{array}$
The CKM, @CKP and @CKN microinstructions depend on the opcode. The actual opcode determines which data the CKB bus will have on it when these microinstructions are called. See Figure 17 for more information.

| Opcode | Source Data on CKB bus |
| :--- | :--- |
| $008-00 \mathrm{~F}$ | K-lines |
| $018-01 \mathrm{~F}$ | Timer |
| $020-02 \mathrm{~F}$ | Bit data TBIT, TCTM, TRTM |
| $0 A 0-0 A F$ | Bit data SBIT, RBIT, TBITA, TIOM |
| $040-07 \mathrm{~F}$ | Constant data from instruction |
| $0 \mathrm{C} 0-0 \mathrm{FF}$ | Constant data from instruction |

Figure 17: CKB Memory Map Description

### 3.3 Register to Register Transfer Instructions

### 3.3.1 Transfer Accumulator to Y Register

MNEMONIC: TAY
STATUS: set
ACTION: $\quad A \rightarrow Y$
PURPOSE: Copying or saving the accumulator.
DESCRIPTION: The accumulator contents are unconditionally transferred to the Y register. The accumulator contents are unaltered.

MICROINSTRUCTIONS: @ATN, AUTY
3.3.2 Transfer Y Register to Accumulator
MNEMONIC: TYA OPCODE: 03B
STATUS: set FORMAT: IV
ACTION: $\quad Y \rightarrow A$
PURPOSE: Copying or saving the $Y$ register.
DESCRIPTION: The four-bit contents of the Y register are unconditionally transferred to the accumulator. The contents of the Y register are unaltered.
MICROINSTRUCTIONS: @YTP, AUTA
3.3.3 Clear Accumulator
MNEMONIC: CLA ..... OPCODE: 006
STATUS: set ..... FORMAT: IV
ACTION: ..... $0 \rightarrow A$
DESCRIPTION: The contents of the accumulator are unconditionally cleared to zero.
MICROINSTRUCTIONS: AUTA
3.4 Register to Memory, Memory to Register Transfer Instructions
3.4.1 Transfer DAM to Accumulator
MNEMONIC: TDA ..... OPCODE: 016
STATUS: ..... set
FORMAT: IV
ACTION: $\quad \mathrm{M}(15, \mathrm{Y}) \rightarrow \mathrm{A}$PURPOSE: To transfer the DAM value to accumulator withoutchanging the X register.

DESCRIPTION: The contents of the DAM location addressed by the Y register are loaded into the accumulator. The $X$ register and the memory contents are not altered.

MICROINSTRUCTIONS: @DMTP, AUTA
EXAMPLE: Comparison of DAM to memory

| LDX | 1 |  |
| :--- | :--- | :--- |
| TCY | 3 | ADDRESS $M(1,3)$ |
| TDA |  | $M(15,3)->A$ |
| MNEA |  | $M(15,3)=M(1,3) ?$ |
| BRANCH | NOTEQU | NO, NOT EQUAL <br> $\ldots$ |
|  |  | EQUAL |

### 3.4.2 Exchange DAM and Accumulator

MNEMONIC: XDA
OPCODE: 019
STATUS: set
FORMAT: IV
ACTION: $\quad M(15, Y) \leftrightarrow A$
PURPOSE: To exchange DAM value and accumulator without changing the X register.

DESCRIPTION: The contents of the DAM location addressed by the $Y$ register and the contents of the accumulator are exchanged. The X register is not altered.

MICROINSTRUCTIONS: @DMTP, STO, AUTA
EXAMPLE: $\quad$ Exchange $M(1,0-5)$ and $M(15,0-5)$

|  | LDX |
| :--- | :--- |
| L\$300 | TCY |
|  | TMA |
|  | XDA |
|  | TAMDYN |

1 ADDRESS M(1,5)
5
$\mathrm{M}(1, Y) \rightarrow A$
A $<->M(15, Y)$
A $\rightarrow M(1, Y)$
LOOP UNTIL Y $=15$

### 3.4.3 Transfer Accumulator to Memory

MNEMONIC: TAM
STATUS: set

OPCODE: 03F
FORMAT: IV

ACTION: $\quad A \rightarrow M(X, Y)$
PURPOSE: Storing the accumulator in the RAM.
DESCRIPTION: The four-bit contents of the accumulator are stored in the memory location addressed by the X and Y registers. The accumulator contents are unaltered.

MICROINSTRUCTIONS: STO

### 3.4.4 Transfer Accumulator to Memory and Increment Y Register

MNEMONIC: TAMIYC OPCODE: 03D
STATUS: carry into status FORMAT: IV
ACTION: $\quad A \rightarrow M(X, Y)$
$Y+1 \rightarrow Y$
$1 \rightarrow S$ if $Y=0$
$0 \rightarrow S$ if $Y$ \# 0
PURPOSE: The Y register sequentially addresses a bank of 16 RAM words, and the addressed words are set to the accumulator value(s), during initialization for example.
DESCRIPTION: The contents of the accumulator are stored in the memory location addressed by the X and Y registers. The contents of the accumulator are unaltered. Then the contents of the Y register are incremented by one. Carry information is transferred into status. If the result is zero, status is set.
MICROINSTRUCTIONS: STO, @YTP, @CIN, C8, AUTY

Revision 1, July 1991

| 3.4.5 | Transfer Accumulator to Memory and Decrement $Y$ Register |  |
| :--- | :--- | :--- |
| MNEMONIC: | TAMDYN | OPCODE: 03C |
| STATUS: | carry into status | FORMAT: IV |
| ACTION: | $A \rightarrow M(X, Y)$ |  |
|  | $Y-1 \rightarrow Y$ |  |
|  | $1 \rightarrow S$ if $Y \# 15$ |  |
|  | $0 \rightarrow S$ if $Y=15$ |  |

PURPOSE: The Y register sequentially addresses a bank of 16 RAM words, and the addressed words are set to the accumulator value(s), during initialization for example.
DESCRIPTION: The contents of the accumulator are stored in the memory location addressed by the X and Y registers. The contents of the accumulator are unaltered. Then the contents of the Y register are decremented by one. Carry information is transferred to status. If the result is not equal to 15 , status will be set.
MICROINSTRUCTIONS: STO, @YTP, @15TN, C8, AUTY
3.4.6 Tranfer Accumulator to Memory and Zero Accumulator MNEMONIC: TAMZA OPCODE: 03E

STATUS: set FORMAT: IV
ACTION: $\quad A \rightarrow M(X, Y)$ $0 \rightarrow A$

PURPOSE: Storing and clearing of accumulator in one instruction.
DESCRIPTION: The contents of the accumulator are stored in the RAM location addressed by the $X$ and $Y$ registers. The contents of the accumulator are then cleared to zero.

MICROINSTRUCTIONS: STO, AUTA

| 3.4.7 | Transfer Memory to $Y$ Register |  |
| :--- | :--- | :--- |
| MNEMONIC: | TMY | OPCODE: 03A |
| STATUS: | set | FORMAT: IV |
| ACTION: | $M(X, Y) \rightarrow Y$ |  |

PURPOSE: Loading of $Y$ register from memory. This is useful if the $Y$ register is used as a pointer.

DESCRIPTION: The contents of the RAM location addressed by the X and Y registers are loaded into the Y register. Memory contents are unaltered.

MICROINSTRUCTIONS: @MTP, AUTY

### 3.4.8 Transfer Memory to Accumulator

MNEMONIC: TMA OPCODE: 039
STATUS: set FORMAT: IV
ACTION: $\quad M(X, Y) \rightarrow A$
PURPOSE: Loading accumulator from memory.
DESCRIPTION: The contents of the RAM location addressed by $X$ and $Y$ registers are loaded into the accumulator. Memory contents are unaltered.

MICROINSTRUCTIONS: @MTP, AUTA

### 3.4.9 Exchange Memory and Accumulator

MNEMONIC: XMA OPCODE: 003
STATUS: set FORMAT:IV

ACTION: $\quad M(X, Y) \leftrightarrow A$

Revision 1, July 1991

PURPOSE: Exchange of accumulator and memory without intermediate storage.
DESCRIPTION: The memory contents (addressed by the X and Y registers) are exchanged with the accumulator contents. For example, this instruction is useful to retrieve a memory word into the accumulator for an arithmetic operation and save the current accumulator in this RAM location temporarily. The accumulator can be restored by a second XMA instruction.

MICROINSTRUCTIONS: @MTP, STO, AUTA

### 3.5 Arithmetic Instructions

### 3.5.1 Add Constant to Accumulator, Result to Accumulator

MNEMONIC: ACACC C OPCODE: 070-07F
STATUS: carry into status FORMAT: II
ACTION: $\quad A+C \rightarrow A$
$1 \rightarrow S$ if sum $>15$
$0 \rightarrow S$ if sum $<16$
PURPOSE: To add a constant to the accumulator.
DESCRIPTION: The constant from the four lower bits of the instruction, is added to the accumulator contents. Carry information is transferred into status. A sum greater than 15 will generate a carry and will set status.

MICROINSTRUCTIONS: @CKP, @ATN, C8, AUTA

### 3.5.2 Add Memory to Accumulator, Result to Accumulator

MNEMONIC: AMAAC
STATUS: carry into status

OPCODE: 015
FORMAT: IV

ACTION: $\quad M(X, Y)+A \rightarrow A$
$1 \rightarrow S$ if sum $>15$
$0 \rightarrow S$ if sum < 16
PURPOSE: Addition of memory contents to accumulator.
DESCRIPTION: The contents of the memory location addressed by the $X$ and $Y$ registers are added to the contents of the accumulator. The result is stored in the accumulator. The resulting carry information is transferred to status. A sum that is greater than 15 results in a carry and a one to status. Memory contents are unaltered.
MICROINSTRUCTIONS: @MTP, @ATN, C8, AUTA

### 3.5.3 Substract Accumulator from Memory, Result to Accumulator

MNEMONIC: SAMAN
OPCODE: 030
STATUS: carry into status
ACTION: $\quad M(X, Y)-A \rightarrow A$
$1 \rightarrow S$ if $A \leq M(X, Y) \quad$ Initial conditions $0 \rightarrow S$ if $A>M(X, Y)$
PURPOSE: Subtracting accumulator from memory.
DESCRIPTION: The contents of the accumulator are subtracted from the memory word addressed by the X and Y registers via two's complement addition. The result is stored into the accumulator. Status is set if the accumulator is less than or equal to the memory word, indicating that no-borrow occurred. A borrow occurs when the accumulator is greater than the memory word and status is reset to zero.
MICROINSTRUCTIONS: @MTP, @NATN, @CIN, C8, AUTA

Revision 1, July 1991
3.5.4 Increment Memory and load into Accumulator

MNEMONIC: IMAC OPCODE: 032
STATUS: carry into status FORMAT: IV
ACTION: $\quad M(X, Y)+1 \rightarrow A$
$1 \rightarrow S$ if $M(X, Y)=15$
$0 \rightarrow S$ if $M(X, Y)<15$
PURPOSE: Loading and incrementing accumulator in one instruction. Useful for incrementing counters.

DESCRIPTION: The contents of memory addressed by the $X$ and $Y$ registers are fetched. One is added to this word and the result is stored in the accumulator. The resulting carry information is transferred to status. Status is set if the sum is greater than 15 . Memory is left unaltered.

MICROINSTRUCTIONS: @MTP, @CIN, C8, AUTA
Example: The subroutine below increments a counter $M(X, 0-3)$ in hexadecimal format.


$$
\begin{array}{ll}
\text { PURPOSE: } & \begin{array}{l}
\text { Loading and decrementing accumulator in one instruc- } \\
\text { tion. Useful for decrementing counters. }
\end{array} \\
\text { DESCRIPTION: } \begin{array}{l}
\text { The contents of memory addressed by the } X \text { and } Y \text { regis- } \\
\text { ters are fetched. One is subtracted from this word (add } \\
\text { 15), and the result is placed in the accumulator. The re- } \\
\text { sulting carry information is transferred to status. If mem- } \\
\text { ory is greater than or equal to one, status is set. Memory } \\
\text { contents are unaltered. }
\end{array}
\end{array}
$$

MICROINSTRUCTIONS: @MTP, @15TN, C8, AUTA

### 3.5.6 Increment Y Register

MNEMONIC: IYC
STATUS: carry into status FORMAT: IV
ACTION: $\quad Y+1 \rightarrow Y$
$1 \rightarrow S$ if $Y=0$
$0 \rightarrow S$ if $Y$ \# 0
PURPOSE: Incrementing Y register e.g. for loop control.
DESCRIPTION: The contents of the Y register are incremented by one. The result is placed back into the Y register. Resulting carry information is transferred to status. A sum greater than 15 results in status being set.

MICROINSTRUCTIONS: @YTP, @CIN, C8, AUTY

### 3.5.7 Decrement Y Register

MNEMONIC: DYN
STATUS: carry into status
ACTION: $\quad Y-1 \rightarrow Y$
$1 \rightarrow S$ if $Y$ \# 15
$0 \rightarrow S$ if $Y=15$

PURPOSE: To decrement the contents of the Y register by one.
DESCRIPTION: The contents of the Y register are decremented by one. This is performed by adding a minus one (15). Resulting carry information is transferred into status. If the result is not equal to 15 , status will be set.
MICROINSTRUCTIONS: @YTP, @15TN, C8, AUTY

### 3.5.8 Add Constant to $Y$ Register

MNEMONIC: ACYY C
STATUS: set

OPCODE: OFO - OFF
FORMAT: II

ACTION: $\quad Y+C \rightarrow Y$
PURPOSE: Adding a constant to $Y$ register. Useful in transfer loops with different $Y$ addresses for digits.

DESCRIPTION: The four-bit constant of the C field is added to the contents of the Y register. Status is always set.
MICROINSTRUCTIONS: @YTP, @CKN, AUTY
Example: The subroutine transfers 4 nibbles from $M(1,0-3)$ to $M(2,4-7)$.

| RAMXFER | TCY | 0 | ADDRESS SOURCE MSD |
| :--- | :--- | :--- | :--- |
| L\$104 | LDX | 1 |  |
|  | TMA |  | SOURCE DIGIT $\rightarrow$ A |
|  | LDX | 2 |  |
|  | ACYY | 4 | ADD Y DIFFERENCE TO Y |
|  | TAM |  | DIGIT $\rightarrow$ DESTINATION |
|  | ACYY | 13 | ADDRESS NEXT SOURCE DIGIT |
|  | YNEC | 4 | SOURCE TRANSFERRED ? |
|  | BRANCH | L\$104 | NO, PROCEED |
|  | RETN |  |  |

### 3.5.9 Complement Accumulator and Increment

MNEMONIC: CPAIZ
STATUS: carry into status FORMAT: IV

ACTION: $\quad \bar{A}+1 \rightarrow A$

$$
1 \rightarrow S \text { if } A=0
$$

$0 \rightarrow S$ if $A$ \# 0
PURPOSE: To obtain the two's complement of the accumulator.
DESCRIPTION: The two's complement of the accumulator is computed by adding one to the one's complement of the accumulator and storing the result in the accumulator. Carry information is transferred into status. If the accumulator contents are zero, carry occurs, and status is set.

MICROINSTRUCTIONS: @NATN, @CIN, C8, AUTA

### 3.6 Special Arithmetic Instructions

The Special Arithmetic Instructions result from the need for faster computing, especially multiplying. The instructions are tailored to fast addition and subtraction and are not easy to understand. The purpose is minimizing the instruction count inside the add or subtract loops of multiplication and division.

### 3.6.1 Add DAM and Memory and Special Status, Result to Accumulator

MNEMONIC: DMEA OPCODE: 010
STATUS: set FORMAT: IV
ACTION: $\quad M(15, Y)+M(X, Y)+S S \rightarrow A C$
PURPOSE: Fast addition without X register changes.
DESCRIPTION: The contents of the DAM and of the addressed memory are added together with the Special Status generated before. The result is stored in the accumulator. The carry is stored in the ALU.

Note: If DAM is addressed, the doubled contents of $M(15, Y)$ are added to the special status.
MICROINSTRUCTIONS: @MTN, @DMTP, SSS, AUTA
Example: Addition of $\mathrm{M}(15,0-8)$ to $\mathrm{M}(3,0-8)$

| ADDITION | SAL |  | PREPARE ADD LATCH FOR ADDITION |
| :---: | :---: | :---: | :---: |
|  | REAC |  | RESET SS |
|  | LDX | 3 | $\mathrm{M}(3,8-0)+\mathrm{M}(15,8-0)$ |
|  | TCY | 8 | LSD M (X, 8) |
| ADDLOOP | DMEA |  | $\mathrm{M}(3, Y)+\mathrm{M}(15, Y)+S S$ |
|  | TAMACS | 6 | TEST IF CORRECTION NECESSARY |
|  | CTMDYN |  | CORRECT RESULT. $\mathrm{Y}=\mathrm{Y}-1$ |
|  | BRANCH | ADDLOOP | LOOP UNTIL MSD IS HANDLED TOO |
|  | RETN |  | RESULT IN M ( $3,8-0$ ) |

### 3.6.2 Add inverted DAM and Memory and Special Status, Result to Accumulator

MNEMONIC: NDMEA
OPCODE: 013
STATUS: set FORMAT:IV
ACTION: $\quad \overline{M(15, Y)}+M(X, Y)+S S \rightarrow A C$
PURPOSE: Fast subtraction without changes of the $X$ register.
DESCRIPTION: The contents of the inverted DAM and of the addressed memory are added together with the Special Status generated before. The result is stored in the accumulator. The carry is stored in the ALU.
MICROINSTRUCTIONS: @MTN, @NDMTP, SSS, AUTA
Example: Subtract $M(15,0-8)$ from $M(3,0-8)$

| SUBTRACT | SEAC |  | SET SS. ADD LATCH IS RESET |
| :---: | :---: | :---: | :---: |
|  | LDX | 3 | $\mathrm{m}(3,8-0)-\mathrm{m}(15,8-0)$ |
|  | TCY | 8 |  |
| SUBLOOP | NDMEA |  | $\mathrm{M}(3, Y)+\mathrm{M}(15, Y)+\mathrm{SS}$ |
|  | TAMACS | 10 | TEST IF CORRECTION NECESSARY |
|  | CTMDYN |  | CORRECT RESULT. $\mathrm{Y}=\mathrm{Y}-1$ |
|  | BRANCH | SUBLOOP | LOOP UNTIL MSD IS DONE |
|  | RETN |  | RESULT IN M ( $3,8-0$ ) |

### 3.6.3 Add DAM and inverted Accumulator and Special Status, Result to Accumulator

MNEMONIC: DNAA
STATUS: set

OPCODE: 011
FORMAT: IV

ACTION: $\quad \mathrm{M}(15, \mathrm{Y})+\overline{\mathrm{A}}+\mathrm{SS} \rightarrow \mathrm{A}$
PURPOSE: To subtract the accumulator from a DAM nibble.
DESCRIPTION: The addressed DAM and the inverted accumulator are added together with the Special Status. The result is stored in the accumulator. The carry is stored in the ALU.

MICROINSTRUCTIONS: @DMTP, @NATN, SSS, AUTA
Example: The routine subtracts the accumulator from $\mathrm{M}(15,0-8)$ in BCD format.

| SUBACC | SEAC |  | SET SS FOR SUBTRACTION |
| :--- | :--- | :--- | :--- |
|  | TCY | 8 | ADDRESS LSD, X CAN BE RANDOM |
| L 360 | DNAA |  | SUBTRAHEND IN A: DAM - A |
|  | TAMACS | 10 | RESULT $->$ M (15, Y) |
|  | CTMDYN |  | CORRECT IF NECESSARY |
|  | CCLA |  | SS $->$ A |
|  | YNEC | 15 | ALL THROUGH ? |
|  | BRANCH | L\$360 | LOOP UNTIL MSD IS HANDLED TOO |
|  | RETN |  |  |

### 3.6.4 Reset End-Around-Carry [Special Status]

MNEMONIC: REAC OPCODE: 0B4
STATUS: set FORMAT: IV
ACTION: $\quad 0 \rightarrow$ SS
PURPOSE: To reset the Special Status before entering and add loop. DESCRIPTION: The Special Status is reset.

Note: The setting of the ADD Latch by the instruction "SAL" can cause ambiguous change of the Special Status. So it is advised to set or reset the Special Status after the SAL instruction. See example at 3.6.1

MICROINSTRUCTIONS: none

### 3.6.5 Set End-Around-Carry [Special Status]

MNEMONIC: SEAC
STATUS: set FORMAT:IV

OPCODE: 0B5

ACTION: $\quad 1 \rightarrow$ SS
PURPOSE: To set the Special Status before entering a subtract loop.
DESCRIPTION: The Special Status is set.
Note: The setting of the ADD Latch by the instruction "SAL" can cause ambiguous change of the Special Status. So it is advised to set or reset the Special Status after the SAL instruction. See example at 3.6.1

MICROINSTRUCTIONS: none

### 3.6.6 Set ADD Latch

MNEMONIC: SAL OPCODE: OB1
STATUS: set
FORMAT: IV
ACTION: $\quad 1 \rightarrow$ ADD Latch
PURPOSE: Preparing of the Special Status logic for addition. (If not set, the adder logic is prepared for subtraction). See examples of Special Arithmetic Instructions.
DESCRIPTION: The "ADD Latch" is set (until a RETN instruction is performed).
MICROINSTRUCTIONS: none

### 3.6.7 Transfer Accumulator to Memory, add Constant to Accumulator

MNEMONIC: TAMACS C OPCODE: ODO-0DF
STATUS: set FORMAT: II

ACTION: $\quad A \rightarrow M(X, Y)$
$A+C \rightarrow A$
If Add Latch = 1 :
If Prev. Carry .OR. Carry $=1: 1 \rightarrow$ SS
Otherwise $\quad 0 \rightarrow$ SS
If Add Latch $=0$ :
Prev. Carry $\rightarrow$ SS
PURPOSE: Transfer of result and correction test for addition and subtraction in one instruction. See examples of Special Arithmetic Instructions.

DESCRIPTION: The four-bit contents of the accumulator are stored in the memory location adressed by the X and Y registers. Then the four bit constant from the four lower bits of the instruction is added to the accumulator. If the ADD Latch is set and the carry from the previous or the TAMACS instruction is 1 , then the Special Status is set. If the ADD Latch is reset and the carry from the previous instruction is 1 , then the Special Status is set. If the conditions above are not satisfied, the Special Status is reset.

MICROINSTRUCTIONS: STO, @ATN, @CKP, AUTA, SSE

### 3.6.8 Conditionally Transfer Accumulator to Memory, Decrement Y Register

MNEMONIC: CTMDYN OPCODE: 018
STATUS: carry into status FORMAT:IV

ACTION: If ADD Latch $=1 . A N D . S S=1: A \rightarrow M(X, Y)$
If $A D D$ Latch $=0 . A N D . S S=0: A \rightarrow M(X, Y)$
Y-1 $\rightarrow$ Y
If $Y$ \# 15: $1 \rightarrow S$
If $Y=15: 0 \rightarrow S$
PURPOSE: Transfer of corrected result when correction (e.g. for decimal) was necessary. Decrement of $Y$ register for looping until MSD M(X,0) is handled too. See examples for Special Arithmetic Instructions.

DESCRIPTION: If both ADD Latch and Special Status are set or both are reset then the four-bit contents of the accumulator are stored in the memory location adressed by the X and Y registers. Then the contents of the Y register are decremented by one. This is performed by adding a minus one (15). Resulting carry information is transferred into status. If the result is not equal to 15 , status will be set.
MICROINSTRUCTIONS: @YTP, @15TN, C8, AUTY, CME

### 3.6.9 Transfer Special Status to Accumulator

MNEMONIC: CCLA OPCODE: 012
STATUS: set FORMAT: IV

ACTION: $\quad S S \rightarrow A$
PURPOSE: Makes the Special Status visible e.g. for overflow tests out of the MSD.

DESCRIPTION: The Special Status is transferred into the least significant bit (LSB) of the accumulator. The other accumulator bits are reset.

MICROINSTRUCTIONS: AUTA, SSS

### 3.6.10 Set Branch Latch

MNEMONIC: SBL OPCODE: 0B3
STATUS: set FORMAT:IV
ACTION: $\quad 1 \rightarrow$ BRANCH Latch
PURPOSE: For very fast additions or subtractions by decoding of branches as instructions and branches.

DESCRIPTION: The BRANCH Latch is set (until a RETN instruction is performed).

MICROINSTRUCTIONS: none

### 3.7 Arithmetic Compare Instructions

### 3.7.1 If Accumulator is less than or equal to Memory, One to Status

MNEMONIC: ALEM
STATUS: carry into status
ACTION: $\quad 1 \rightarrow S$ if $A \leq M(X, Y)$
$0 \rightarrow S$ if $A>M(X, Y)$
PURPOSE: Comparing accumulator and addressed memory.
DESCRIPTION: The value from the accumulator is subtracted from the contents of the memory location, addressed by the $X$ and Y registers, using two's complement addition. Resulting carry information is transferred into status. Status equal to one indicates that the accumulator is less than or equal to the memory word. Memory and accumulator contents are unaltered.

MICROINSTRUCTIONS: @MTP, @NATN, @CIN, C8

### 3.7.2 If Accumulator is less than or equal to Constant, One to Status

MNEMONIC: ALEC C
STATUS: carry into status
ACTION: $\quad 1 \rightarrow S$ if $A \leq C$
$0 \rightarrow S$ if $A>C$
PURPOSE: To arithmetically compare accumulator contents to a constant value.

DESCRIPTION: The accumulator value is subtracted from the constant (in C field of the instruction) using two's complement addition. Resulting carry information is transferred into status. Status is set if the accumulator is less than or equal to the constant. The accumulator data is unaltered.

MICROINSTRUCTIONS: @CKP, @NATN, @CIN, C8

### 3.8 Logical Compare Instructions

### 3.8.1 If Memory is not equal to Accumulator, One to Status

MNEMONIC: MNEA
STATUS: comparison result
ACTION: $\quad 1 \rightarrow S$ if $M(X, Y)$ \# A
$0 \rightarrow S$ if $M(X, Y)=A$
PURPOSE: To compare the addressed memory with the accumulator contents.

DESCRIPTION: The contents of the memory addressed by the $X$ and $Y$ registers are logically compared to the accumulator contents. The comparison information is transferred to status. Inequality will set status.

MICROINSTRUCTIONS: @MTP, @ATN, NE

### 3.8.2 If Memory is not equal to Zero, One to Status

MNEMONIC: MNEZ OPCODE: 033
STATUS: comparison result FORMAT:IV
ACTION: $\quad 1 \rightarrow S$ if $M(X, Y) \# 0$
$0 \rightarrow S$ if $M(X, Y)=0$
PURPOSE: To compare a memory word to zero.
DESCRIPTION: The memory contents addressed by the X and Y register are logically compared to zero. Comparison information is transferred into status. Inequality between memory value and zero will set status.

MICROINSTRUCTIONS: @MTP, NE

### 3.8.3 If $\mathbf{Y}$ Register is not equal to Accumulator, One to Status

MNEMONIC: YNEA
STATUS: comparison result
ACTION: $\quad 1 \rightarrow S$ if $Y$ \# A
$0 \rightarrow S$ if $Y=A$
PURPOSE: To compare the contents of the Y register and the accumulator for inequality.

DESCRIPTION: The contents of the Y register are logically compared to the contents of the accumulator. Comparison information is transferred into status. Inequality will set status.

MICROINSTRUCTIONS: @YTP, @ATN, NE
3.8.4 If Y Register is not equal to a Constant, One to Status

MNEMONIC: YNEC C OPCODE: 050-05F
STATUS: comparison result FORMAT: II

Revision 1, July 1991

ACTION: $\quad \begin{array}{ll}1 & \rightarrow S \text { if } Y \# C \\ & 0 \rightarrow S \text { if } Y=C\end{array}$
$0 \rightarrow S$ if $Y=C$
PURPOSE: Comparing Y register to a constant value. Useful for loop control.

DESCRIPTION: The contents of the Y register are logically compared to the four-bit value from the C field of the instruction. Compare result is transferred into status. Inequality between the operands causes status to be set.

## MICROINSTRUCTIONS: @YTP, @CKN, NE

Example: The subroutine clears the memory $M(X, 0-4)$ in a loop.

| CLEAR | TCY | 0 | START WITH M (X, 0) |
| :--- | :--- | :--- | :--- |
| L\$103 | TCMIY | 0 | CLEAR NIBBLE AND INCR. Y |
|  | YNEC | 5 | Y > YMAX ? |
|  | BRANCH | L\$103 | IF NOT CLEAR NEXT NIBBLE |
|  | RETN |  | $Y=5:$ RETURN TO CALLER |

### 3.9 Bit Manipulation Instructions

### 3.9.1 Set Memory Bit

MNEMONIC: SBIT B
OPCODE: OAO-0A3
STATUS: set FORMAT: III
ACTION: $\quad 1 \rightarrow M(X, Y, B)$
PURPOSE: Setting a single bit without affecting the other bits in the addressed nibble. Useful for flags.
DESCRIPTION: One of the four bits, as selected by the B-field of the operand, is set to one in the memory word addresssed by the contents of the X and Y registers.
MICROINSTRUCTIONS: none

### 3.9.2 Reset Memory Bit

MNEMONIC: RBIT B
STATUS: set

OPCODE: OA4-0A7
FORMAT: III

ACTION: $\quad 0 \rightarrow M(X, Y, B)$
PURPOSE: Resetting a single bit without affecting the other bits in the addressed nibble. Useful for flags.
DESCRIPTION: One of the four bits, as selected by the B field of the instruction, is reset to zero in the memory word addressed by the contents of the X and Y registers.
MICROINSTRUCTIONS: none

### 3.9.3 Test Memory Bit

MNEMONIC: TBIT B
STATUS: comparison result
OPCODE: 020-023
FORMAT: III
ACTION: $\quad M(X, Y, B) \rightarrow S$
PURPOSE: To test a selected memory bit for a logic one and set status accordingly e.g. testing of flags.
DESCRIPTION: The addressed memory bit is transferred to the status. This means, if the memory bit is set, the status is set to one, if the memory bit is not set, the status is reset to zero.
MICROINSTRUCTIONS: @CKP, @CKN, @MTP, NE

### 3.9.4 Test Accumulator Bit for One

MNEMONIC: TBITA B OPCODE: 0A8-0AB
STATUS: comparison result FORMAT: III
ACTION: If accumulator bit $=1: 1 \rightarrow S$
If accumulator bit $=0: 0 \rightarrow S$

PURPOSE: To test a selected accumulator bit for a logic one.
DESCRIPTION: The value of the accumulator bit defined by the operand is transferred to status.

MICROINSTRUCTIONS: @ATN, @CKN, @CKP, NE

### 3.9.5 Or Memory with Accumulator, Result to Accumulator

MNEMONIC: ORMA OPCODE: 014
STATUS: set FORMAT: IV
ACTION: $\quad M(X, Y) . O R . A \rightarrow A$
PURPOSE: Logical OR function
DESCRIPTION: The addressed memory is ORed bitwise with the accumulator. The result is stored in the accumulator.

MICROINSTRUCTIONS: @ATN, @MTN, AUTA
Example: The logical OR of $M(4,2)$ and the accumulator is built and tested if bit 2 is set in one of them.

| LDX | 4 |  |
| :--- | :--- | :--- |
| TCY | 2 |  |
| ORMA |  | A .OR. M(X,Y) |
| TBITA | 2 | IS BIT 2 SET IN One OF THEM ? |
| BRANCH | L\$222 | YES, BIT 2 OF A IS 1 |
| .. |  |  |

Example: Test if bit 1 and bit 2 of $M(X, Y)$ are set together. A mask is used with set bits at the positions which are not interesting. When all four accumulator bits are set after the ORMA instruction both bits were set in $M(X, Y)$.

| TCA | 9 | BUILD MASK |
| :--- | :--- | :--- |
| ORMA |  | A.OR. M $(X, Y)$ |
| ACACC | 1 | $M(X, Y, 1) . A N D . M(X, Y, 2)=1 ?$ |
| BRANCH | $L \$ 223$ | YES, A $=15$ |
| $\ldots$ |  | NO |

### 3.9.6 Or Memory with Inverted Accumulator, Result to Accumulator

MNEMONIC: ORMNAA
STATUS: set

OPCODE:6017
FORMAT: IV

ACTION: $\quad M(X, Y) . O R . \bar{A} \rightarrow A$
PURPOSE: Logical NOR function (masks e.g.).
DESCRIPTION: The addressed memory is ORed bitwise with the inverted accumulator. The result is stored in the accumulator.

MICROINSTRUCTIONS: @NATN, @MTN, AUTA
Example: Test if bit 1 and bit 2 of $M(X, Y)$ are set together. A mask is used in the accumulator which defines the interesting bits.

```
TCA 6 BUILD MASK BIT 1 .OR. BIT 2
ORMNAA M(X,Y) .OR. A
ACACC 1
BRANCH L$224
```

```
M(X,Y,1) .AND. M(X,Y,2) = 1 ?
```

M(X,Y,1) .AND. M(X,Y,2) = 1 ?
YES, IF A = 15
YES, IF A = 15
NO

```
NO
```


### 3.10 Constant Transfer Instructions

### 3.10.1 Transfer Constant to Accumulator

MNEMONIC: TCA C OPCODE: OCO-OCF

STATUS: set FORMAT: II
ACTION: $\quad C \rightarrow A$
PURPOSE: Loading accumulator with a constant in one instruction.
DESCRIPTION: The four-bit constant from the C-field of the instruction is loaded into the accumulator.

MICROINSTRUCTIONS: @CKP, AUTA

[^7]3.10.2 Transfer Constant to Y Register

MNEMONIC: TCY C OPCODE: 040-04F
STATUS: set FORMAT: II

ACTION: $\quad C \rightarrow Y$
PURPOSE: To load the $Y$ register with a constant. Common uses are to set Y to a particular RAM word address, address a selected Digit Latch or to initialize Y for loop control.
DESCRIPTION: The four-bit value from the C-field of the instruction is transferred into the Y register.

MICROINSTRUCTIONS: @CKP, AUTY

### 3.10.3 Transfer Constant to Memory and Increment Y Register

MNEMONIC: TCMIY C OPCODE: 060-06F
STATUS: set • FORMAT: II
ACTION: $\quad C \rightarrow M(X, Y)$ $Y+1 \rightarrow Y$

PURPOSE: Loading the RAM with constants.
DESCRIPTION: The four-bit value from the C-field of the instruction is stored in the memory location addressed by the X and Y registers. The Y register contents are then incremented by one.

MICROINSTRUCTIONS: CKM, @YTP, @CIN, AUTY

### 3.11 Input/Output Instructions

### 3.11.1 Reset I/O Pin

MNEMONIC: RSTIO
OPCODE: 00B
STATUS: set
FORMAT: IV

ACTION: $\quad 0 \rightarrow I / O$ Data Latch I/O Control Latch is set to output direction.

PURPOSE: Output of an active LO at the I/O Pin.
DESCRIPTION: The I/O Data Latch is reset (LO) and the I/O Control Latch is set to output direction. The I/O Pin goes LO in the middle of the instruction.

MICROINSTRUCTIONS: none

### 3.11.2 Set I/O Pin

MNEMONIC: SETIO OPCODE: OOC
STATUS: set FORMAT:IV
ACTION: $\quad 1 \rightarrow I / O$ Data Latch
I/O Control Latch is set to output direction.
PURPOSE: Output of an active HI at the I/O Pin.
DESCRIPTION: The I/O Data Latch is set (HI) and the I/O Control Latch is set to output direction. The I/O Pin goes HI in the middle of the instruction.

MICROINSTRUCTIONS: none

### 3.11.3 Switch I/O Pin to Input

MNEMONIC: IOIN OPCODE: 01A
STATUS: set FORMAT: IV
ACTION: $\quad$ /O Control Latch is set to input direction.
PURPOSE: Preparation for reads from the I/O Pin.
DESCRIPTION: The I/O Control Latch is set to input direction.
The I/O Data Latch is not affected.
MICROINSTRUCTIONS: none

Revision 1, July 1991

### 3.11.4 Transfer Status to I/O Pin

MNEMONIC: TSIO
STATUS: set

OPCODE: 00F
FORMAT: IV

ACTION: $\quad S \rightarrow I / O$ Data Latch I/O Control Latch is set to output direction.
PURPOSE: Conditional output at the I/O Pin.
DESCRIPTION: The I/O Data Latch is loaded with the status. The I/O Control Latch is set to output direction. The I/O Pin settles in the middle of the instruction.
MICROINSTRUCTIONS: none
Example: The memory bit masked by the accumulator is output to the I/O Pin.

```
TCA 8 MASK M(X,Y,3)
ORMNAA IF M(X,Y,3) = 1: A = 15
ACACC 1 TEST IF A = 15
TSIO S -> I/O PIN
```


### 3.11.5 Transfer I/O Pin to Memory

MNEMONIC: TIOM B
STATUS: set

OPCODE: OAC - OAF
FORMAT: III

ACTION: $\quad$ I/O Pin $\rightarrow M(X, Y, B)$
PURPOSE: Input instruction for the I/O Pin.
DESCRIPTION: The level at the I/O Pin which was sensed during the previous instruction is transferred to the addressed memory bit.
Note: The l/O Pin is not switched to input direction by this instruction. For I/O input functions the IOIN instruction has to be performed before the TIOM instruction. Otherwise the information of the I/O Data Latch, output by the I/O Pin, is read in.

MICROINSTRUCTIONS: none
Example: Transfer I/O Pin info to $M(X, Y, 2)$

| IOIN |  |
| :--- | :--- |
| TIOM | 2 |

### 3.11.6 Transfer Accumulator to K Latch

MNEMONIC: TAK OPCODE: 0B8
STATUS: set FORMAT:IV
ACTION: $\quad$ A $\rightarrow$ K-Port Latch
PURPOSE: Preparation of output data for the K-Port.
DESCRIPTION: The contents of the accumulator are written into the KPort Latch. The data appears at the K-Pins if DL8 is set. If DL8 is reset the data is stored only in the K-Port Latch.
MICROINSTRUCTIONS: none
Example: Set K8 and K2 to one, reset K1 and K4 to zero.

TCA
10
TAK
TCY
SETR

INFO $8+2->A$
MOVE A $->$ K PORT LATCH
SWITCH K PORT TO OUTPUT DIRECTION

### 3.11.7 Transfer K Lines to Memory

MNEMONIC: TKM
STATUS: set FORMAT:IV

ACTION: $\quad$ K-Port $\rightarrow M(X, Y)$
PURPOSE: Input instruction for the K-Port.
DESCRIPTION: The data at the K-Port is transferred to $M(X, Y)$.

Revision 1, July 1991

Note: If DL8 is set (K-Port is output) the data from the KPort Latch is seen at the K-Port lines. Reset DL8 if external data is to be read.

## MICROINSTRUCTIONS: CKM

### 3.11.8 Transfer Data from Accumulator, Status and DL14 to Segment Latches

MNEMONIC: TDO OPCODE: 0B0

STATUS: set FORMAT:IV
ACTION: DL14, S and A decode segment info $A$ to $G$. DP Latch defines segment info H Segment info A to H is transferred into segment latches decoded by Y register.
PURPOSE: Loading of the display segment buffers.
DESCRIPTION: The actual DL14, status and accumulator contents decode a term out of the 64 term OPLA. The segment $A$ to G info out of this term and the segment H info out of the Decimal Point Latch DP are stored into the segment latches decoded by the Y register.
Note: Which segment info is decoded by DL14, status and accumulator is defined by hardware option .OPTION SEGMENT-PLA (see 2.18.13) Which digit is addressed by the Y register is defined by hardware option .OPTION SELECT-LINES (see 2.18.12)
MICROINSTRUCTIONS: none

| 3.11.9 Set Decimal Point [Segment H] |  |  |
| :--- | :--- | :--- |
| MNEMONIC: $\quad$ SDP | OPCODE: 0B9 |  |
| STATUS: | set | FORMAT: IV |

$$
\begin{array}{ll}
\text { ACTION: } & 1 \rightarrow \text { DP } \\
\text { PURPOSE: } & \text { Activate segment } H . \\
\text { DESCRIPTION: } & \begin{array}{l}
\text { The Decimal Point Latch DP is set. Segment } H \text { appears } \\
\text { in digits which are loaded by the TDO instruction until DP } \\
\text { is reset again. }
\end{array}
\end{array}
$$

MICROINSTRUCTIONS: none

### 3.11.10 Reset Decimal Point [Segment H]

MNEMONIC: RDP
OPCODE: 0B6
STATUS: set
FORMAT: IV
ACTION: $\quad 0 \rightarrow$ DP
PURPOSE: Deactivate segment $H$.
DESCRIPTION: The Decimal Point Latch DP is reset. Segment H disappears in digits which are loaded by the TDO instruction until DP is set again.
MICROINSTRUCTIONS: none

### 3.11.11 If K Inputs are not equal to Zero, set Status

MNEMONIC: KNEZ
STATUS: comparison result FORMAT:IV
ACTION: $\quad 1 \rightarrow S$ if $K 1+K 2+K 4+K 8 \# 0$
$0 \rightarrow \mathrm{~S}$ if $\mathrm{K} 1+\mathrm{K} 2+\mathrm{K} 4+\mathrm{K} 8=0$
PURPOSE: To test the four K-Port lines for a non-zero state. This instruction is useful for monitoring a keyboard for a "key down" condition.

DESCRIPTION: Data on the four external K-Port lines are compared to zero. Comparison information is transferred into status. Non-zero data inputs cause status to be set.

Revision 1, July 1991


#### Abstract

Note: If DL8 is set (K-Port is output) the data from the KPort Latch is seen at the K-Port lines. Reset DL8 if external data is to be read.


MICROINSTRUCTIONS: @CKP, NE

### 3.11.12 Transfer K Inputs to Accumulator

MNEMONIC: TKA
STATUS: set
ACTION: $\quad$ K-Port $\rightarrow A$
PURPOSE: To transfer the K-Port input data into the accumulator for processing.
DESCRIPTION: Data present at the four external K-Port lines is transferred into the accumulator.
Note: If DL8 is set (K-Port is output) the data from the KPort Latch is seen at the K-Port lines. Reset DL8 if external data is to be read.

MICROINSTRUCTIONS: @CKP, AUTA

### 3.11.13 Set R Output

MNEMONIC: SETR
STATUS: set
ACTION: $\quad 1 \rightarrow$ DLn
PURPOSE: To set a Digit Latch to a logic one.
DESCRIPTION: The contents of the Y register select the proper Digit Latch. If the contents of the Y register are from 0 to 7 inclusive, outputs R0 to R7 are set. For values greater than 7 the Digit Latches DL8 to DL15 are set.
MICROINSTRUCTION: none

### 3.11.14 Reset R Output

MNEMONIC: RSTR OPCODE: 036

STATUS: set FORMAT: IV

$$
\text { ACTION: } \quad 0 \rightarrow \text { DLn }
$$

PURPOSE: To reset a Digit Latch to a logic zero.
DESCRIPTION: The contents of the Y register select the proper Digit Latch. If the contents of the Y register are from 0 to 7 inclusive, outputs R0 to R7 are reset. For values greater than 7 the Digit Latches DL8 to DL15 are reset.

MICROINSTRUCTION: NONE

### 3.12 RAM Addressing Instructions

### 3.12.1 Load X Register with a Constant

MNEMONIC: LDX C OPCODE: 090-09F
STATUS: set
ACTION: $\quad C \rightarrow X$
$0 \rightarrow$ DAM Latch
PURPOSE: Changing the addressed X bank. Resetting the DAM Latch.
DESCRIPTION: The constant from the C field of the instruction is loaded into the X register. The DAM Latch is reset.
Note: The constant $C$ is restricted to the values of the existing RAM banks: $1,2,3,4,7,9,10,11,12,15$

MICROINSTRUCTIONS: none

### 3.12.2 Complement the MSB of the X Register

MNEMONIC: COMX8 OPCODE: 0B2
STATUS: set FORMAT:IV

ACTION: $\quad X+8 \rightarrow X$
PURPOSE: Fast switching from one $X$ bank to another one.
DESCRIPTION: The MSB of the X register is complemented.
MICROINSTRUCTIONS: none

### 3.12.3 Toggle DAM Latch

MNEMONIC: TDL OPCODE: OBC
STATUS: set FORMAT:IV
ACTION: If DAM Latch $=0: 1 \rightarrow$ DAM Latch
If DAM Latch $=1: 0 \rightarrow$ DAM Latch
PURPOSE: Fast switching from addressed $X$ bank to DAM or reverse. Allows subroutine usage with different $X$ values.

DESCRIPTION: The one bit DAM Latch is toggled. The DAM is addressed if the DAM Latch is set. The $X$ register address is used if the DAM Latch is reset. The contents of the X register are not affected.
Note: The DAM Latch is reset by an LDX instruction.
MICROINSTRUCTIONS: none

### 3.13 ROM Addressing Instructions

See also chapter 4 SUBROUTINE SOFTWARE

### 3.13.1 Branch, Conditional on Status

MNEMONIC: BRANCH W

STATUS: conditional on Status FORMAT: I
ACTION: If $S=0: P C+1 \rightarrow P C$
$1 \rightarrow$ S
If $S=1: W \rightarrow P C$
$\mathrm{PB} \rightarrow \mathrm{PA}$
Note: The PC actually uses a pseudo random count. See Figure 2 for stepping order.
PURPOSE: To allow the program to alter the normal sequential program execution. The BRANCH instruction is conditional on the status results of the previously executed instruction.

DESCRIPTION: The BRANCH instruction is always conditional upon the state of status. If status is reset, then the branch is unsuccessfully executed and the next sequential instruction will be performed. If the status is set, then the branch will occur by the following actions: The W-field of the instruction (7 bits) is transferred to the Program Counter PC. The contents of the Page Buffer PB are transferred to the Page Address PA. After these actions the program continues at the newly loaded page and PC.
Branches may be of 2 types, short or long.
Short branches address within the current page while long branches address into another ROM page. The type of branch performed is determined by the contents of the PB register, which is loaded by the LDP instruction. See 3.13.3 for description of the compound instruction BL (Branch Long).

Note: To allow for conditional branching, the BRANCH instruction must immediately follow the instruction that affected the status. Only that instruction immediately preceding the BRANCH instruction determines if status is zero, causing the branch to be unsuccessfull. If unconditional branching is desired, the preceding instruction must always set status to one.

MICROINSTRUCTIONS: none

### 3.13.2 Call Subroutine, Conditional on Status

MNEMONIC: CALL W
STATUS: conditional on Status
ACTION:

$$
\begin{aligned}
& \text { If } S=0: P C+1 \rightarrow P C \\
& 1 \rightarrow \text { S } \\
& \text { If } S=1: \text { SR3 } \rightarrow \text { lost PSR3 } \rightarrow \text { lost } \\
& \text { SR2 } \rightarrow \text { SR3 PSR2 } \rightarrow \text { PSR3 } \\
& \text { SR1 } \rightarrow \text { SR2 PSR1 } \rightarrow \text { PSR2 } \\
& \mathrm{PC}+1 \rightarrow \mathrm{SR} 1 \mathrm{PA} \rightarrow \mathrm{PSR} 1 \\
& W \rightarrow P C \\
& P B \rightarrow P A
\end{aligned}
$$

PURPOSE: To allow the program to transfer control to a common subroutine. Because the CALL instruction saves the return address, subroutines may be called from various locations in a program, and the subroutine will return control back to the proper, saved address after the call using the call-return instruction RETN.

DESCRIPTION: The CALL instruction is always conditional upon the state of status. If status is reset, then the call is executed unsuccessfully and the next sequential instruction will be performed. If the status is set, then the call will occur by the following actions. The address of the next instruction (PC +1) is pushed onto the Subroutine Return stack. The

Page Address PA is pushed onto the Page Address Return stack. This defines the point where the program will continue after returning from the subroutine.
The stack depth is 3 . This allows 3 levels of subroutine nesting. If a 4th level of subroutine nesting is entered, the values stored in SR3 and PSR3 are lost. The W-field of the instruction ( 7 bits) is transferred to the Program Counter PC. The contents of the Page Buffer PB are transferred to the Page Address PA. After these actions the program continues at the newly loaded page and PC.
Calls may be of 2 types, short or long. Short calls address within the current page while long calls (CALLL) address into another ROM page. The type of call performed is determined by the contents of the PB register, which is loaded by the LDP instruction. See 3.13.4 for description of the compound instruction CALLL.

MICROINSTRUCTIONS: none

### 3.13.3 Branch Long

MNEMONIC: BL
STATUS: set

OPCODE: LDP + BRANCH FORMAT: COMPOUND

ACTION: LDP instruction followed by BRANCH instruction. See description of these instructions for details.
PURPOSE: Branching to a destination outside the current page.
DESCRIPTION: The assembler generates two instructions out of this compound instruction. The correct page is inserted into the LDP instruction and the correct new PC inserted into the BRANCH instruction.

MICROINSTRUCTIONS: none

Revision 1, July 1991

### 3.13.4 Call Long Subroutine

MNEMONIC: CALLL
STATUS: set

OPCODE: LDP + CALL
FORMAT: COMPOUND

ACTION: LDP instruction followed by CALL instruction. See description of these instructions for details.

PURPOSE: Calling a subroutine outside the current page.
DESCRIPTION: The assembler generates two instructions out of this compound instruction. The correct page is inserted into the LDP instruction and the correct new PC inserted into the CALL instruction.

MICROINSTRUCTIONS: none

### 3.13.5 Load Page Buffer with a Constant

MNEMONIC: LDP C OPCODE: 080-08F
STATUS: set FORMAT: II
ACTION: $\quad C \rightarrow P B$
PURPOSE: Preparing of destination page for BRANCH or CALL.
DESCRIPTION: The Page Buffer PB is loaded with the four-bit value from the C -field of the instruction. (The ROM page is not changed until the next BRANCH or CALL occurs).

MICROINSTRUCTIONS: none

### 3.13.6 Return from Subroutine

MNEMONIC: RETN OPCODE: OBF
STATUS: set FORMAT: IV
ACTION: $\quad 0 \rightarrow$ ADD Latch
$0 \rightarrow$ BRANCH Latch

$$
\begin{aligned}
& \text { If inside Subroutine: SR1 } \rightarrow \text { PC PSR1 } \rightarrow \text { PA } \\
& \text { PSR1 } \rightarrow \text { PB } \\
& \text { SR2 } \rightarrow \text { SR1 PSR2 } \rightarrow \text { PSR1 } \\
& \text { SR3 } \rightarrow \text { SR2 PSR3 } \rightarrow \text { PSR2 }
\end{aligned}
$$

MICROINSTRUCTIONS: none

### 3.14 Analog-Digital-Converter Instructions

### 3.14.1 Set Converter Supply

MNEMONIC: SCSV OPCODE: OBA
STATUS: set FORMAT:IV

ACTION: $\quad$ Pin SV $_{\text {DD }}$ is switched on. Comparator offset switch $\rightarrow$ NONINVERTED
PURPOSE: Supplying the ADC part and sensors with voltage.
DESCRIPTION: The supply converter voltage is switched to the external sensors and the resistor network of the comparator. The comparator offset switch is switched to "NONINVERTED".

MICROINSTRUCTIONS: none

### 3.14.2 Reset Converter Supply Voltage

MNEMONIC: RCSV OPCODE: 0BB
STATUS: set FORMAT: IV

ACTION: $\quad$ Pin $S V_{D D}$ is switched off.
PURPOSE: Switching off the ADC part.
DESCRIPTION: The supply converter voltage $S V_{D D}$ is switched off.
Note: The supply converter voltage SV $_{\text {DD }}$ is switched off too by initialization and the instructions DONE and OFF.

MICROINSTRUCTIONS: none

### 3.14.3 Reset Comparator Offset switch to Inverted

MNEMONIC: RCI OPCODE: OBD
STATUS: set . FORMAT:IV
ACTION: Comparator offset switch $\rightarrow$ INVERTED.
PURPOSE: To initialize measurement with inverted comparator inputs. The addition of a measurement result with inverted comparator and one with noninverted comparator compensates the offset error of the comparator.
Note: The comparator offset switch can be reset to the NONINVERTED state by the instruction SCSV.
DESCRIPTION: The comparator offset switch is set to INVERTED.
MICROINSTRUCTIONS: none
3.14.4 Transfer Comparator Output to Memory Bit

MNEMONIC: TCTM B OPCODE: 024-027
STATUS: set FORMAT: III

ACTION: $\quad$ Comparator output $\rightarrow M(X, Y, B)$
$1 \rightarrow M(X, Y, B-1)$
PURPOSE: Building the ADC value by successive approximation.
DESCRIPTION: The comparator output is written to the addressed memory bit $M(X, Y, B)$. Then the next lower bit of the addressed nibble is set to one to prepare for the next comparison. If the LSB of the nibble is addressed, no additional bit is set.
Note: For A/D conversions the addressed memory has to be $M(15,13-15)$. Only these RAM nibbles are connected to the A/D converter for comparison.

MICROINSTRUCTIONS: none

### 3.14.5 Transfer Range to Memory Bit

MNEMONIC: TRTM B OPCODE: 028-02B
STATUS: set
FORMAT: III
ACTION: If $M(15,13-15)=>000: 1 \rightarrow M(X, Y, B)$
If $M(15,13-15)=>F F F: 1 \rightarrow M(X, Y, B)$
Otherwise $\quad: 0 \rightarrow M(X, Y, B)$
PURPOSE: Fast validity checking of the measured ADC value.
DESCRIPTION: The range output is written to the memory bit addressed by the operand field. If the measured value is inside the voltage range of the ADC the bit is set to zero. If the measured voltage is below the voltage range of the ADC (ADC value is 000 ) or above the voltage range of the ADC (ADC value is >FFF) the addressed bit is set to one.
Note: The TRTM instruction checks only the contents of the RAM nibbles $M(15,13-15)$ independent if the stored values came from an ADC conversion or not.

MICROINSTRUCTIONS: none

### 3.15 Miscellaneous Instructions

### 3.15.1 Enter Done Mode

MNEMONIC: DONE
STATUS: not applicable FORMAT: IV
ACTION: CPU part is switched off. SV $_{\text {DD }}$ is switched off.
PURPOSE: Current saving by deactivation of unnecessary parts.
DESCRIPTION: The CPU part is switched off, only the RAM, the LCD drive, the timer and other parts stay active. See Figure 6 for more information. A delay line is read out which wakes up the CPU if during the last 5 instructions before the DONE instructing an external event occured which would wake up the processor during the Done Mode. This ensures that every event can be recognized. See Figure 5 for the conditions. The ADC supply voltage $\mathrm{SV}_{\mathrm{DD}}$ is switched off too.

MICROINSTRUCTIONS: none

### 3.15.2 Enter Off Mode

MNEMONIC: OFF
OPCODE: 0B7
STATUS: not applicable FORMAT: IV
ACTION: $\quad$ CPU, SV ${ }_{D D}$ and timer are switched off.
PURPOSE: Current saving by deactivation of not necessary parts.
DESCRIPTION: The CPU and the timer are switched off, only the RAM stays active. Events at the inputs which would wake up the CPU from Done Mode, will wake up the CPU from this mode too. See Figure 5 for the conditions. The ADC supply voltage $\mathrm{SV}_{\mathrm{DD}}$ is switched off too.

MICROINSTRUCTIONS: none

### 3.16 Timer Instructions

### 3.16.1 Transfer Timer to Accumulator

MNEMONIC: TTA
STATUS: set

OPCODE: 01E
FORMAT: IV

ACTION: $\quad$ If DL12 $=0:$ Timer0 $\rightarrow \mathrm{A}$ If DL12 $=1:$ Timer $1 \rightarrow A$

PURPOSE: Reading of the timer.
DESCRIPTION: The timer nibble which is addressed by DL12 is transferred to the accumulator.
Note: A check is necessary to assure a stable value. This avoids reading temporary timer values.
MICROINSTRUCTIONS: @CKP, AUTA
Example: The timer is read into the accumulator. To be shure that a stable value was read in, the timer is read in once more if the value in the accumulator differs from the timer value.

```
                TTA
                TNEA
                BRANCH L$1
```

```
TIMER -> A
YET SAME VALUE ?
IF NOT READ ONCE MORE
STABLE VALUE IN A
```


### 3.16.2 Transfer Timer to Y Register

MNEMONIC: TTY OPCODE: 01F
STATUS: set FORMAT: IV

ACTION: If DL12 $=0:$ Timer0 $\rightarrow Y$ If DL12 $=1:$ Timer1 $\rightarrow Y$

PURPOSE: Reading of the timer.
DESCRIPTION: The timer nibble which is addressed by DL12 is transferred to the Y register.

Note: A check is necessary to assure a stable value. This avoids reading temporary timer values.

## MICROINSTRUCTIONS: @CKP, AUTY

Example: The timer info read into the Y register is compared with a second read into the accumulator. If the info differs, the operation is repeated once more.

| L\$500 | TTY |  | TIMER $\rightarrow$ Y |
| :--- | :--- | :--- | :--- |
|  | TTA |  | TIMER $->$ A |
|  | YNEA |  | SAME INFO ? |
|  | BRANCH | L\$500 | NO, READ ONCE MORE |
|  | $\cdots$ |  | YES, PROCEED |

### 3.16.3 Transfer Timer to Memory

MNEMONIC: TTM
STATUS: set

OPCODE: 01B
FORMAT: IV

ACTION: If DL12 $=0:$ Timer0 $\rightarrow M(X, Y)$ If DL12 $=1:$ Timer1 $\rightarrow M(X, Y)$

PURPOSE: Reading of the timer.
DESCRIPTION: The timer nibble which is addressed by DL12 is transferred to the addressed memory.
Note: A check is necessary to assure a stable timer value. This avoids reading temporary values.

## MICROINSTRUCTIONS: CKM

Example: The timer is read into the addressed memory. To be shure that a stable value was read in the timer is read in once more if the value in $M(X, Y)$ differs from the timer value.

| L\$100 | TTM |  | TIMER $\rightarrow$ M $(\mathrm{X}, \mathrm{Y})$ |
| :--- | :--- | :--- | :--- |
|  | TNEM |  | YET SAME VALUE ? |
|  | BRANCH | L\$100 | IF NOT READ ONCE MORE |
|  | $\ldots$ |  | STABLE VALUE IN M $(X, Y)$ |

3.16.4 If Timer not equal to Memory, One to Status
MNEMONIC: TNEM OPCODE: 01C

STATUS: comparison result FORMAT:IV
ACTION: If DL12 = 0:
If Timer0 \# M(X,Y): $1 \rightarrow$ S
If Timer0 $=M(X, Y): 0 \rightarrow S$
If $\mathrm{DL} 12=1$ :
If Timer1 \# M(X,Y): $1 \rightarrow S$
If Timer1 $=M(X, Y): 0 \rightarrow S$
PURPOSE: Assuring a stable timer readout.
DESCRIPTION: The timer nibble which is addressed by DL12 is compared against the addressed memory $M(X, Y)$. If the contents are equal, status is reset. If they are not equal, status is set. See example at 3.16.3.
MICROINSTRUCTIONS: @CKN, @MTP, NE

### 3.16.5 If Timer not equal to Accumulator, One to Status

MNEMONIC: TNEA OPCODE:01D
STATUS: comparison result FORMAT: IV
ACTION: If DL12 $=0$ :
If Timer0 \# A: $1 \rightarrow$ S
If Timer0 $=\mathrm{A}: 0 \rightarrow \mathrm{~S}$
If DL12 $=1$ :
If Timer1 \# A: $1 \rightarrow$ S
If Timer1 $=A: 0 \rightarrow S$
PURPOSE: Assuring a stable timer readout.
DESCRIPTION: The timer nibble which is addressed by DL12 is compared against the accumulator. If the contents are equal, status is reset. If they are not equal, status is set. See example at 3.16.1.
MICROINSTRUCTIONS: @ATN, @CKP, NE

## 4 Subroutine Software

### 4.1 General

By using the subroutine capability of the TSS400(/4) series, programs are substantially compacted, enabling the user to write very powerful algorithms within the 2048 word limit. Normally "straight line" programming is used only for high speed applications.

A subroutine is used to avoid duplication of ROM code when a particular section of code is used several times within a program. A subroutine is a section of code terminated with a RETN instruction. A CALL instruction transfers program execution to the first instruction in the subroutine. At the completion of the subroutine, program control is transferred to the instruction address immediately following the CALL instruction. Examples of a subroutine and different calling techniques follow.

### 4.2 Nesting Subroutines

The TSS400(/4) has a subroutine stack with a depth of 3 . This means that 3 levels of subroutines are possible (a subroutine can call a subroutine and this one can call a subroutine too). This procedure is called nesting subroutines. If a 4th level of subroutines is used, the return information of the 1st level is lost and the software will not work properly. So the programmer is advised always to be informed which subroutine level he is using when coding programs.

Example: The following program shows subroutine nesting 3 levels deep.

| MAINLOOP | CALLL | TEST | INVOKE TEST SUBROUTINE |
| :--- | :--- | :--- | :--- |
|  | $\cdots$ |  | FROM MAINLOOP: 1st LEVEL |

## TSS400(/4) Software User's Guide



### 4.3 Example Calling Sequence

The following subroutine CREG will clear digits 0 to 6 on a given RAM bank. The X register value is set prior to the CALL.

|  | ORG | 896 | PLACE CREG ON PAGE 7 PC 00 <br> $(7 \times 128=896)$ |
| :--- | :--- | :--- | :--- |
| * CREG | TCY | 0 | INITIALIZE Y TO 0 |
| C1 | TCMIY | 0 | CLEAR NIBBLE |

Recall that both CALL and BRANCH instructions are conditional on status. To successfully execute a call, the CALL instruction must either follow a non-status affecting instruction, such as TCY or LDX, or follow a status affecting instruction that will leave status set at one. Care must be taken to ensure that the Page Buffer contents point to the subroutine page before attempting a call. This is always sure if the CALLL directive is used which inserts the proper LDP instruction automatically. The subroutine labeled CREG is arbitrarily placed on ROM page 7 PC 00 . To demonstrate calling sequences, examples of calling from page 7 and calling from other pages are given.

### 4.3.1 Calling a Subroutine on the same page

Remember that a successful branch to a page transfers the Page Buffer contents to the Page Address register, leaving them identical. The first example assumes that both registers are identical. By preceding the call with a non-status affecting instruction, the call will be unconditional.

[^8]| LDX | 3 | STATUS $=1$ AFTER LDX |
| :--- | :--- | :--- |
| CALL | CREG | SO CREG IS ALWAYS CALLED |
| BR | XYZ | $M(3,0-6)$ IS CLEARED |

When a subroutine is used initially, it is embedded directly in a straight line sequence rather than called, to save a CALL instruction. This holds only if the Page Buffer and Page Address register contents are identical.

|  | LDX | 3 | PB $=$ PA $=7$ |
| :--- | :--- | :--- | :--- |
| CREG | TCY | 0 | PASS THROUGH CREG |
| C1 | TCMIY | 0 |  |
|  | YNEC | 7 |  |
|  | BRANCH | $C 1$ |  |
|  | RETN |  | NOP WHEN NOT "CALLED" |

The following example shows how to correctly call a subroutine when the Page Buffer has been modified. If accumulator is less or equal to 6 a branch to label ABC located on page 4 should be made. If this condition is not met the subroutine CREG located on the current page 7 is to be called.

| LDP | 4 | PREPARE PB FOR BRANCHING TO PAGE 4 |
| :--- | :--- | :--- |
| ALEC | 6 | IF A IS LESS THAN 7, BRANCH TO ABC |
| BRANCH | ABC |  |
| LDP | 7 | CHANGE PAGE BUFFER BACK TO 7 |
| CALL | CREG | CALL CREG CORRECT ON CURRENT PAGE |

The above mentioned example is for demonstration purposes only. The LDP instruction should never be used explicitly but only implicitly with the directives BL and CALLL. These directives insert the right page into the LDP instruction automatically. This avoids branches to wrong pages if the addressed labels are shifted to other pages and the LDP constant wasn't corrected. The better sequence for the above example would be:

|  | ALEC | 6 | IF A IS LESS THAN 7, BRANCH TO ABC |
| :--- | :--- | :--- | :--- |
|  | BRANCH | PABC |  |
|  | CALL | CREG | CALL CREG CORRECT ON CURRENT PAGE |
|  | BR | LABEL | AND GO ON |
| PABC | BL | ABC | ASSEMBLER INSERTS LDP 4 AND BR ABC |

The LDP instruction should only be used explicitly if clarity is better than compared with BL. An example is a branch table with all destinations located on the same page 8 . Branching depends on accumulator contents:

```
LDP 8 PREPARE PAGE BUFFER
ALEC 0 LABELS CODE0 TO CODE15 IN PAGE 8
BRANCH CODEO
ALEC 1
BRANCH CODE1
. . .
...
ALEC 14
BRANCH CODE14
BR CODE15 AC = 15
```


### 4.3.2 Calling a Subroutine from a different page

If the calling sequence is not on the same page as the subroutine, a LDP precedes the CALL so that the Page Buffer contents are equal to the subroutine's page address. This is accomplished normally by using the CALLL directive:

| LDX | 2 | CLEAR M $(2,0-6)$ |
| :--- | :--- | :--- |
| CALLL | CREG |  |
| LDX | 3 | CLEAR M $(3,0-6)$ |
| CALLL | CREG |  |

The following example demonstrates a CALL from one page to another with a conditional CALL. Current page is 4.

| LDP | 7 | SET PAGE BUFFER TO 7 |
| :--- | :--- | :--- |
| ALEC | 0 | IF A $=0$, THEN CREG WILL BE |
| CALL | CREG | SUCCESSFULLY CALLED. |
| LDP | 4 | SET PAGE BUFFER BACK TO 4 |
| BR | XYZ | PROCEED AT PAGE 4 |

Notice that the test instruction, ALEC 0 , must immediately precede the CALL since status is affected for one instruction cycle only. If label XYZ is located on page 7 too, the LDP 4 instruction is to be ommitted.

Note: As mentioned at 4.3.1 the last example is only for demonstration purposes. The correct way for coding would be as follows:

Revision 1, July 1991

|  | ALEC | 0 | IF A = 0, THEN CREG WILL BE |
| :--- | :--- | :--- | :--- |
|  | BRANCH | PCREG | CALLED BY CALLL |
|  | BR | XYZ | A \# 0 PROCEED |
| PCREG | CALLL | CREG | POINTER TO CREG |
|  | BR | XYZ |  |

### 4.4 Multiple Entry Points

Often it is desired to use a subroutine several times, specifying different conditions each time for entering that subroutine. A call to the multiple entry points presets different conditions, and then a branch into the base subroutine is executed. Thus, rewriting the subroutine for each entry condition is avoided.

The following examples use the CREG routine as the basic subroutine. The CREG routine clears words 0 to 6 on a RAM bank where the $X$ address is set before CREG is called (as in example, paragraph 4.3.1). If clearing words 0 to 6 is required more than once in a program, then it is advantageous to create a new subroutine (e.g., CREG3 which sets X to 3 before entering CREG).


Now the calling sequence for clearing $M(15,0-6), M(3,0-6)$ and $M(2,0-6)$ becomes:

| CALL | CREG15 | CLEAR M $(15,0-6)$ |
| :--- | :--- | :--- |
| CALL | CREG3 | CLEAR $M(3,0-6)$ |
| LDX | 2 |  |
| CALL | CREG | CLEAR $M(2,0-6)$ |

Note: that the CREG subroutine is not modified and can be called again (like explained above for $\mathrm{X}=2$ )

Another example, again using CREG as the base subroutine, is the subroutine CLALL. CLALL sets $Y$ to 7 before entering the clearing routine, so every word on the RAM bank is cleared, including words 7 to 15.

| CLALL | TCY | 7 | SET Y $=7$. CLEAR $M(X, 0-15)$ <br> BRANCH INTO THE CLEARING LOOP |
| :--- | :--- | :--- | :--- |
| $*$ |  | C1 |  |
| CREG | TCY | 0 |  |
| C1 | TCMIY | 0 | ENTRY POINT FOR CLALL |
|  | YNEC | 7 | BASIC SUBROUTINE |
|  | BRANCH | C1 |  |
|  | RETN |  |  |

Generally, less LDP instructions are needed when a subroutine resides on the same ROM page that the subroutine calls most frequently.

## 5 Organizing the RAM

### 5.1 General

To use the TSS400(/4) data storage efficiently, the locations of storage areas in the RAM must be assigned carefully. The RAM is normally subdivided into data "registers", flag bits, and temporary working areas. If the location assignments are chosen logically, unnecessary use of RAM addressing instructions, such as LDX and TCY, can be minimized.
The following paragraphs give general guidelines for RAM organization which are useful in most programs.

Organization of the RAM should start with organizing the DAM.
This results from the special assignment of the DAM for A/D conversion and computing with Special Arithmetic Instructions:

- DAM locations M(15,13-15) are hardwired to the Digital Analog Converter which controls the A/D conversion. This dictates usage for the ADC if it is used in the application.
- The Special Arithmetic Instructions work only together with the DAM, so if fast arithmetic is needed (e.g. the Integer Math. Package shown under 6.5 ) one computation register (REGB) is to be located in the DAM.

Example: The ADC is used and a 9 digit Integer Math. Package is necessary. The resulting DAM would look like as follows:

| $\leftarrow$ |  | Data Register REGB |  |  |  |  |  |  | $\rightarrow$ |  |  |  |  | ADC | $\rightarrow$ |  | $X=15$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 |  |  | $Y$ |
| MSD |  |  |  |  |  |  |  | LSD |  |  |  |  | MSD |  | LS |  |  |

### 5.2 Data Register Organization

To minimize X and Y addressing, data "registers" should be located on sequential locations on the same RAM bank. For example, the following is a seven word "register" organization that defines a subset of any 16 word bank:


If organized in this manner, a register left-shift subroutine requires only three Y addressing instructions.

Note: Assume in this example and in all succeeding examples, that register location $Y=0$ is the most significant digit (MSD) and location $\mathrm{Y}=6$ is the least significant digit (LSD).

### 5.2.1 Register left Shift Example

The subroutine LSHIFT multplies the register $M(X, 0-6)$ by ten if decimal numbers are used. If another numbering base is used the register is multiplied by this base. For example: $0123456 \rightarrow 1234560$

| LSHIFT | CLA | ENTER WITH SET X |  |
| :--- | :--- | :---: | :---: |
| LDATA | TCY | 6 | THE LOCATION Y $=6$ IS THE LSD. |
| L1 | XMA |  | EXCHANGE MEMORY AND ACCUMULATOR. |
|  | DYN |  | TO NEXT HIGHER DIGIT |
|  | BRANCH | L1 |  |

Note that this subroutine could also be a data entry subroutine by setting the accumulator equal to the new LSD data and calling DATA.

| TCA | 5 | XXXXX $\rightarrow>$ XXXXX5 |
| :--- | :--- | :--- |
| CALL | LDATA | USE 2nd ENTRY POINT |

For most programs, several data registers are required. Whenever possible, these registers are placed on different RAM banks, and their Y locations on these banks would be equal. Thus, $X$ and $Y$ addressing can be minimized on register-to- register operations such as transfers, addition and subtraction. If organized as in the figure below, a transfer from DR9 to register DR1 requires only three addressing instructions.


Figure 18: Register Example

### 5.2.2 Transfer from Register 9 to 1 [Example]

| TR91 | TCY | 6 | INITIALIZE $Y=6$ (LSD) |
| :--- | :--- | :--- | :--- |
| T1 | LDX | 9 | SET $X=9$ |
|  | TMA |  | TRANSFER M $9, Y)$ TO ACCUMULATOR |
|  | LDX | 1 | SET $X=1$ |
|  | TAMDYN |  | TRANSFER ACCUMULATOR TO M(1,Y) AND |
|  | BRANCH | $T 1$ | DECREMENT Y UNTIL $Y=15$ |

### 5.2.3 Register Transfer Example using COMX8

Notice in paragraph 5.2.2 that DR9 contents can be transferred to DR1, but DR1 cannot be transferred to DR9. Also, this subroutine cannot be used for transfers between any other register pairs.
This limitation can be overcome by using the COMX8 instruction in the following subroutine and by defining paired registers (two registers that transfer to and from each other) to be on X banks with complementary MSBs.

| TRB3 <br> $*$ | LDX | 3 | $M(11,0-6) \rightarrow M(3,0-6)$ |
| :--- | :--- | :--- | :--- |
| TR0 |  |  | BASE SUBROUTINE FOR ALL OTHERS: |

```
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{6}{*}{T2} & \multicolumn{2}{|l|}{COMX8} & COMPLEMENT MSB OF X \\
\hline & TMA & & TRANSFER M M (X,Y) TO ACCUMULATOR \\
\hline & COMX8 & & COMPLEMENT MSB OF X \\
\hline & TAMDYN & & \multirow[t]{3}{*}{TRANSFER ACCUMULATOR TO M ( \(\mathrm{X}, \mathrm{Y}\) ) ,} \\
\hline & BRANCH & T2 & \\
\hline & RETN & & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multicolumn{4}{|l|}{\multirow[t]{2}{*}{* OTHER ENTRY POINTS FOR THE ABOVE SUBROUTINE:}} \\
\hline & & & \\
\hline \multirow[t]{2}{*}{TR3B} & LDX & 11 & \multirow[t]{2}{*}{\(M(3,0-6) \rightarrow M(11,0-6)\)} \\
\hline & BR & TR0 & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline TR19 & LDX & 9 & \multirow[t]{2}{*}{\(M(1,0-6) \rightarrow M(9,0-6)\)} \\
\hline & BR & TR0 & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline TR91 & LDX & 1 & \multirow[t]{2}{*}{\(M(9,0-6) \rightarrow M(1,0-6)\)} \\
\hline & BR & TR0 & \\
\hline
\end{tabular}
```

By using multiple entry points, four register transfers are accomplished with one base subroutine.

### 5.3 Placing FLAG Bits

One should carefully choose the location of flag bits. As usual, the objective is to minimize addressing instructions. The following are general suggestions on bit placement.

Registers and the registers' sign bits should be located in the same RAM bank and located in adjacent Y addresses. This permits the transfer of sign bits by the same subroutine which transfers the register contents. For instance, in examples in paragraphs 5.2.2 and 5.2.3, sign bits located in $\mathrm{Y}=7$ could be transferred, along with the data in the register, simply by changing the initializing TCY 6 to a TCY 7 command.

Different flags which are tested sequentially in a program should be placed in the same RAM word to eliminate both $X$ and $Y$ changes between tests.

For flags which are used with several $X$ banks the placement in the DAM should be considered. See 5.5 for examples.

### 5.4 Temporary Working Areas

Temporary working areas are either full register length, which is required in a three register calculation (i.e., divide, when one register holds the intermediate results), or shorter length areas which are used for counters and pointers.

Pointers and counters should be placed on the same RAM bank as the registers that they interact with. The following example monitors an external event (detected at EXIT label), counts to 16 (e.g., 16 items loaded into a container), and then adds one to a BCD register in the same bank for each count of 16.

Binary Event Counter


| COUNT | TCY | 7 | ADDRESS EVENT COUNTER |
| :---: | :---: | :---: | :---: |
|  | IMAC |  | COUNTER + 1 |
|  | BRANCH | ADD1 | IF CARRY, ADD 1 TO REGISTER |
|  | TAM |  | IF NO CARRY A $\rightarrow$ M ( $\mathrm{X}, 7)$ |
|  | BR | EXIT | WAIT FOR NEXT EVENT |
| * ${ }^{\text {a }}$ |  |  |  |
| ADD1 | TAMDYN |  | 16'TH PULSE: 0 -> M (X,7) |
| INCM | IMAC |  | $\mathrm{M}(\mathrm{X}, \mathrm{Y})+1$-> A |
|  | TAM |  | A $\rightarrow$ M $(X, Y)$ |
|  | ALEC 9 |  | BCD Correction NECCESSARY ? |
|  | BRANCH | EXIT | NO, WAIT FOR NEXT EVENT |
|  | TCMIY | 0 | YES, $0 \rightarrow \mathrm{M}(\mathrm{X}, \mathrm{Y})$ |
|  | ACYY | 14 | ADDRESS NEXT HIGHER DIGIT |
|  | BR | INCM | AND INCREMENT IT |
| * |  |  |  |
| EXIT | - |  | EXTERNAL ROUTINE WAITS FOR THE |
|  | . |  | COMPLETION OF A NEW EVENT THAT IS |
|  | $\cdot$ |  | TO BE COUNTED. |
|  | BR | COUNT | EVENT OCCURED, INCR. EVENT CTR. |

Notice that by placing the BCD counter and event counter in the same bank, no X addressing was required. The LSD of the BCD register was addressed with TAMDYN, saving both ROM code and execution time.

### 5.5 DAM Addressing

Three RAM addressing instructions allow to address the DAM immediately without changing the contents of the X register.

The above mentioned instructions are:
TDL Toggle DAM Latch
TDA Transfer addressed DAM nibble to accumulator
XDA Exchange addressed DAM nibble and accumulator
This saves ROM code due to 2 reasons:

- The $X$ register can stay unchanged despite referencing of another $X$ register (the DAM)
- One properly written subroutine can be used with every $X$ bank despite referencing the DAM
Example: The checksum for an X bank is to be computed and stored in $M(15,0)$ and accumulator. The $X$ register is loaded before the call.

|  | LDX CALL | $3$ <br> CHKSUM | ADDRESS X-BANK <br> CALL CHECKSUM SUBROUTINE <br> M $(3,0)$ IS ADDRESSED |
| :---: | :---: | :---: | :---: |
| CHKSUM | CLA |  | CLEAR SUMMING REGISTER |
|  | TCY | 15 | START WITH M ( $\mathrm{X}, 15$ ) |
| L\$105 | AMAAC |  | ADD M(X,Y) TO A |
|  | DYN |  |  |
|  | BRANCH | L\$105 | $\mathrm{M}(\mathrm{X}, 15-0)$ ADDED UP ? |
| * | TCY | 0 | YES, CHECKSUM IN A |
|  | XDA |  | CHECKSUM -> M $(15,0)$ |
|  | TDA |  | $\mathrm{M}(15,0) \rightarrow \mathrm{A}$ |
|  | RETN |  | $\mathrm{M}(\mathrm{X}, 0)$ IS ADDRESSED |

Often referenced flags may be placed in the DAM where they can be tested without changing the X register. They are located best between the Integer Math Register REGB and the locations used by the ADC M(15,1315).

Example: Dependent on FLAG1 located in M(15, FLAGS, FLAG1) the program should take different pathes.

| LDX | 3 |  |
| :--- | :--- | :--- |
| TCY | 7 |  |
| TCMIY | 15 | $15 \rightarrow \mathrm{M}(3,7)$ |
| TCY | FLAGS | FETCH FLAGS FOR TEST |
| TDA |  | M(15, FLAGS) $\rightarrow$ A |
| TBITA | FLAG1 | FLAG1 SET ? |
| BRANCH | FLAG1SET | YES, M(3, FLAGS) ADDRESSED |
| BR | FLAG1CLR | NO, M(3, FLAGS) ADDRESSED |

If neither the contents of the X register nor the contents of the Y register may be lost, despite information has to be fetched from the DAM, the following example may be of help.

Example: The Information of $M(15, F L A G S)$ is needed with several $X$ and Y register contents which may not be lost. If FLAG2 located in $M(15$, FLAGS $)$ is set, a subroutine SUBR is to be called which processes data in the previous addressed RAM nibble. A temporary storage nibble $M(15, T E M P)$ is needed for the $Y$ register.

|  | LDX | 4 |  |
| :---: | :---: | :---: | :---: |
|  | TCY | 8 | M (15, FLAGS) INFO NEEDED IN A |
|  | CALL | CHKFLAGS | M 115, FLAGS $) ~->~ A ~$ |
|  | TBITA | FLAG2 | $\mathrm{M}(4,8)$ IS STILL ADDRESSED |
|  | CALL | SUBR | CALL SUBR IF FLAG2 IS SET |
|  | -•• |  | SUBR WORKS ON M $(4,8)$ |
| CHKFLAGS | TYA |  | STORE Y IN A |
|  | TDL |  | ADDRESS DAM |
|  | TCY | TEMP | ADDRESS M (15, TEMP) |
|  | TAM |  | STORE Y |
|  | TCY | FLAGS |  |
|  | TMA |  | FLAGS M(15, FLAGS) $->\mathrm{A}$ |
|  | TCY | TEMP |  |

```
TMY
TDL
RETN
```

RESTORE Y
ADDRESS M(X,Y) AGAIN
$M(X, Y)$, FLAGS IN A

General the usage of the 3 direct DAM instructions can be described as follows:

TDL Change of the addressed RAM to the DAM if more complex modifications than transfers are necessary. A second TDL instruction addresses the previous X register again.
TDA Transfers to the DAM
XDA Transfers from the DAM. Note that the accumulator is replaced by the contents of $M(15, Y)$. If the transferred information is still needed in the accumulator, a TDA instruction after the XDA instruction may be used. See first example above.

## 6 General Purpose Subroutines

This chapter shows and comments some useful subroutines which have been tested thouroughly in several applications. Some subroutines call other subroutines: if this happens, the called subroutine is shown also.

The TSS400(/4) assembler knows both mnemonics of the BRANCH instruction (BR, BRANCH). It is good practice to use the two mnemonics in different ways despite the fact that they share the same opcode.

$$
\begin{array}{ll}
\text { BR } & \text { Status is always } 1 \text { due to the previous instruction } \\
\text { BRANCH } & \text { Branch depends on status of previous instruction }
\end{array}
$$

Another good programming practice is the use of "Local Assembly Labels". This means that labels, which are referenced only inside the subroutine where they are defined, have names in the form $L \$ x x x$, where $x x x$ is a unique decimal number. Otherwise labels which are entry points should get labels which give a certain description e.g. DIVISION. This simplifies the distinction between outside referenced labels and local labels.

The software examples all use the above mentioned nomenclature whenever possible.

### 6.1 Register Shift Right [Rounding Routine]

This routine is used for dividing a BCD register like the FLAC by 10. If the LSD is less than four, only shifting right takes place, if it is five or greater, the LSD+1 is incremented (rounded up) and the result of the complete register corrected if necessary. Any register arranged like the FLAC can be shifted and rounded if the second entry "ROUND" is used and the $X$ register is loaded appropriate prior to the CALL.

Example: If the Help Register M(RRXHR,0-RRVZ) is to be rounded the following call sequence can be used:

| LDX | RRXHR | LOAD APPROPRIATE X. SHIFT |
| :--- | :--- | :--- |
| CALL | ROUND | HELP REGISTER M(RRXHR,0-RRVZ) |

If frequently more than one shift is necessary, which means divisions by 100,1000 or 10000 , a subroutine can save ROM by calling the shift routine
more than once. Three entries are shown, note that 2 levels of subroutine nesting are used. The subroutine "falls through" to the "ROUNDFL" subroutine which saves 2 instructions.

| DIV10E4 | CALL | ROUNDFL | DIVIDE FLAC BY 10000 |
| :---: | :---: | :---: | :---: |
| DIV10E3 | CALL | ROUNDFL | DIVIDE FLAC BY 1000 |
| DIV10E2 | CALL | ROUNDFL | DIVIDE FLAC BY 100 |
| * |  |  |  |
| * ROUTINE DIVIDES FLAC M(RRXFL, 0-RRLSD) BY 10 AND* ROUNDS UP IF LSD $>4$. |  |  |  |
|  |  |  |  |
| ROUNDFL | LDX | RRXFL | ADDRESS LSD M (RRXFL, RRLSD) |
| ROUND | TCY | RRLSD | ENTRY FOR SHIFTING OTHER REG. |
|  | SAL |  | SET ADD LATCH |
|  | REAC |  | $S S=0$ |
|  | IMA |  |  |
|  | ALEC | 4 | IS LSD < 5 ? |
|  | BRANCH | L\$000 | YES, DO NOT ROUND UP |
|  | SEAC |  | NO, SET SS FOR ROUNDING UP |
| L\$000 | DYN |  | ADDRESS NEXT HIGHER DIGIT |
|  | CCLA |  | SS -> AC |
|  | AMAAC |  | ADD DIGIT TO AC (0 OR 1) |
|  | IYC |  |  |
|  | TAMACS | 6 | TRANSFER TO NEXT LOWER DIGIT |
|  | CTMDYN |  | AND CORRECT IF NECESSARY |
|  | YNEC | RRMSD | MSD M (RRXFL, 0) REACHED ? |
|  | BRANCH | L\$000 |  |
|  | CCLA |  | YES, STORE OVERFLOW OUT OF |
|  | TAM |  | MSD-1 INTO MSD |
|  | RETN |  |  |

### 6.2 Register Clear Routine

Before registers are loaded with new constants, they should be cleared (set to +0 ). The X register is loaded with the right value before branching to the main part label CLR.

| CLRZWSP | LDX | XZWSP | CLEAR INTERMEDIATE BUFFER |
| :--- | :--- | :--- | :--- |
|  | BR | CLR | USE 2nd ENTRY POINT |
| CLRREGB | LDX | RRXRB | CLEAR REGB M (RRXRB, 0-RRVZ) |
|  | BR | CLR | USE 2nd ENTRY POINT |
| * CLRFLAC | LDX | RRXFL | CLEAR FLAC M(RRXFL,0-RRVZ) |


| CLR | TCY | RRMSD | 2nd ENTRY POINT |
| :--- | :--- | :--- | :--- |
| L\$001 | TCMIY | 0 |  |
|  | YNEC | RRVZ+1 | SIGN CLEARED TOO ? |
|  | BRANCH | L\$001 | NO, ONCE MORE |

### 6.3 Display Driver Routine

The display driver routine below outputs a display buffer located in $M$ (XDISPL, $0-4$ ). Digits in $Y=0$ to 3 contain numbers or blanks while $M(X D I S P L, 4)$ contains flags which are output binary. The same $Y$ register contents address the RAM and the Select Lines. If this is not true, an additional TCY $n$ instruction is necessary after the TMA instruction for selecting the correct Select Lines.

The subroutine assumes the following conditions:
OPLA definition for numbers: DL14 $=0$, status $=1$
OPLA definition for flags: $\quad$ DL14 $=0$, status $=0$

| DISPLAY | CALL | ZEROSUPP | SUPPRESS LEADING ZEROES |
| :---: | :---: | :---: | :---: |
|  | TCY | DL14 | $\mathrm{X}=\mathrm{XDISPL}$ |
|  | RSTR |  | SWITCH TO OPLA PART DL14 $=0$ |
|  | RDP |  | OUTPUT WITHOUT SEGMENT H |
|  | TCY | 0 | START WITH MSD |
|  | TMA |  |  |
|  | TDO |  | OUTPUT TO DIGIT 0 |
| * |  |  |  |
|  | TCY | 1 | MSD-1 |
|  | TMA |  |  |
|  | TDO |  | DIGIT 1 |
| * |  |  |  |
|  | TCY | 2 | LSD+1 |
|  | TMA |  |  |
|  | SDP |  | SET DEC. POINT |
|  | TDO |  |  |
| * |  |  |  |
|  | TCY | 3 | LSD |
|  | TMA |  |  |
|  | RDP |  |  |
|  | TDO |  | S11+S12 |
| * |  |  |  |
|  | TCY | 4 | FLAGS IN DISPLAY |

```
TMA
ACACC 0 RESET STATUS FOR BINARY OUTPUT
TDO
RETN
```


### 6.4 Leading Zero Suppression

For good readability of a display it is normally necessary to suppress leading zeroes. The following subroutine suppresses all leading zeroes with exception of the least significant digit. The leading zeroes are replaced by the code which is defined as blank character in the OPLA.

| ZEROSUPP | LDX | XDISPL | START WITH THE MSD OF THE |
| :--- | :--- | :--- | :--- |
|  | TCY | YMSD | DISPLAY BUFFER M(XDISPL, YMSD-YLSD) |
| L\$002 | MNEZ |  | IS CURRENT DIGIT 0 ? |
|  | BRANCH | L\$003 | NO, RETURN TO MAIN PROGRAM |
|  | TCMIY | BLANK | YES, REPLACE IT WITH BLANK |
|  | YNEC | YLSD | LSD REACHED ? |
|  | BRANCH | L\$002 | NO, TEST NEXT LOWER DIGIT |
| L\$0.03 | RETN |  | YES, DON'T MODIFY IT |

### 6.5 Integer Math Package

This package consists of four subroutines for signed addition, subtraction, multiplication and division. The sign is located in M(X, RRVZ, 3).

Three RAM registers are used by the package:
FLAC: holds 1st operand and result after operation
REGB: holds 2nd operand (not modified by operation) exception: subtraction changes the sign of REGB).
HELP: Used as a help register for multiplication and division (not necessary if neither multiplication nor division is used)
The following register example shows the RAM like defined in the shown Integer Math Package:

FLAC


REGB


MSD $\leftarrow \quad$ PREx $\quad \rightarrow$ LSD


Figure 19: Register Example for the Integer Math Package

| Name | Subroutine Call | Operation | Used ROM |
| :--- | :--- | :--- | :---: |
| Addition | CALL ADDITION | FLAC = FLAC + REGB | 48 |
| Subtraction | CALL SUBTRACT | FLAC = FLAC - REGB | 4 |
| Multiplication | CALL MULTIPLY | FLAC = FLAC $\cdot$ REGB | 40 |
| Division | CALL DIVISION | FLAC = FLAC $:$ REGB | 64 |

The formulas for the execution times of the four routines can be found at the beginning of the software package. Before calling one of the four subroutines, the registers FLAC and REGB have to be loaded with the numbers to be processed. The result of the operation is transferred to the FLAC register.
The ADDITION subroutine can be used for all $X$ banks if the second entry ADDREGX is used:

```
\begin{tabular}{lll} 
LDX & \(X\) & \(M(X, 0-\) RRLSD \()\) \\
CALL & ADDREGX & \(M(X, 0-R R L S D)\)
\end{tabular}
```

The register length can be tailored to the needed accuracy. The length can range from 2 to 15 digits. One nibble is used for the sign resp. the pointer of the register. The routines are designed for a maximum of speed and a
minimum of ROM space. This is accomplished by use of the Special Arithmetic Instructions explained in 3.6.

The definitions for the package can be modified as follows:

| RRXFL | $1,2,3,4,9,10,11,12$ | X FLAC |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| RRLSD | $1,-14$ |  | Y LSD |  |
| RRVZ | $2-15$ |  | Y SIGN (RRLSD+1 !) |  |
| RRXHR | $1,2,3,4,9,10,11,12$ | X HELP | (RRXFL \# RRXHR) |  |
|  |  |  |  |  |

All other definitions of the package are fixed and may not be modified!
The package is an Integer Package which means that the position of the decimal point has to be controlled by the programmer. To show where the decimal point is assumed, one should note the format of the number at the right margin of the source as it is done in the following examples:
XXX.YY two digits right of the thought decimal point XXXXXX integer number without fraction

The digit count of "X" can be used to show the largest possible number of digits left of the decimal point.

The rules for the position of the decimal point are:

- Addition: Positions after the decimal point have to be equal. Position is the same for the result.
- Subtraction: Same as addition.
- Multiplication: Positions after the decimal point may be different. Add positions for the result position.
- Division: Positions after the decimal point may be different. Subtract REGB position from the FLAC position to get the result position.


## Examples:

| FLAC |  | REGB | RESULT IN FLAC |
| :---: | :---: | :---: | :---: |
| XXX.YYY | + | X.YYY | XXX.YYY |
| XXX.Y | - | XX.Y | $X X X . Y$ |
| XXX.YYY | x | XX.Y | XXXXX.YYYY |
| XX | x | XX | XXXX |
| XXX.YYYY | : | XX.YYY | X.Y |
| XX.YY | : | XX | X.YY |

Revision 1, July 1991

If two numbers have to be divided and the result should have n digits after the decimal point, the FLAC has to be loaded with the number shifted to the left appropriately and zeroes filled into the lower digits. The same procedure can be used if a smaller number is to be divided by a larger one.

## Examples:

| FLAC |  | REGB | RESULT IN FLAC |
| :--- | ---: | ---: | ---: |
|  |  |  |  |
| XXXX.000 | $:$ | $X X$ | XX.YYY |
| XXXX.000 | $:$ | $X X . Y$ | XX.YY |
| XXXX.000 | $:$ | $X . Y Y$ | XXX.Y |
| $0 . X X X 000$ | $:$ | $X X . Y$ | $0 . X X X X X$ |

It is the programmer's task to assure that no overflow conditions can occur. Before defining register length a "worst case design" has to be made concerning the greatest numbers which have to be handled. If numbers grow too large the previously described rounding routine should be used (See 6.1). If overflow occurs, no errors are reported! If division is used it must be shure, that the divisor can't be zero: The software would stay endlessly in the division loop.


## Revision 1, July 1991



```
TAMACS 6 AC -> FLAC, IF CARRY NOW OR
CTMDYN OF "DMEA" : AC + 6 -> FLAC
BRANCH ADLOP ALL THROUGH?
CCLA
                                LAST CARRY IN AC: SS -> AC
*
* ADDITION IS COMPLETE. CONTROL IF CORRECTION NECESSARY.
*
\begin{tabular}{lll} 
TCY & RRVZ & X = RRXFL \\
TBIT & PASSFLG & PASSFLAG=1? \\
BRANCH & REKOMPL & YES \\
BR & RETUR & FINISHED, ADD WITH SAME SIGN
\end{tabular}
* WHEN SIGNS ARE DIFFERENT, EVTL., FLAC MUST BE COMPLEMENTED
* ONCE MORE (NULFLG=0, NO CARRY IN AC)
*
REKOMPL RBIT PASSFLG DELETE PASSFLAG
    TBIT NULFLG NULFLG=1?
    BRANCH VZW
    CPAIZ
    BRANCH NOCAR NO CARRY FROM ADD
*
* PASSFLAG IS 1, CARRY IS 1, SIGN OF FLAG HAS TO
* BE CHANGED.
*
VZW XMA Y = RRVZ
    ACACC 8
    XMA
    BR RETUR FINISHED
* SIGN OF REGB AND FLAC ARE DIFFERENT
*
KOMPL SBIT PASSFLG SET PASSFLAG, Y = RRVZ
*
* COMPLEMENT OF FLAC (10ES + 1 - FLAC) => FLAC
*
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{NOCAR} & TCY & RRLSD & LSD OF FLAC \\
\hline & TCA & 1 & 10E0 DIGIT: 10- COMPLEMENT \\
\hline NILOP & ACACC & 9 & OTHERWISE: 9- COMPLEMENT \\
\hline XMA & & \multicolumn{2}{|l|}{FLAC DIGIT IN AC, \(9(10) \Rightarrow M\)} \\
\hline SAMAN & & \multicolumn{2}{|l|}{\(9(10)\) - FLAC DIGIT -> AC} \\
\hline \multicolumn{4}{|l|}{TAM} \\
\hline ACACC & 6 & \multicolumn{2}{|l|}{AC > 9 ?} \\
\hline BRANCH & AC10 & \multicolumn{2}{|l|}{YES, CORRECTIION} \\
\hline & CLA & \multicolumn{2}{|r|}{NO} \\
\hline & BR & ETE & \\
\hline \multirow[t]{2}{*}{AC10} & TAMZA & & \(A C+6\) IN FLAC DIGIT \\
\hline & ACACC & 1 & CARRY FOR NEXT DIGIT \\
\hline
\end{tabular}
```



```
*
* THE PRESENT HR-DIGIT IS 0. MULTIPLICATION IS
* FINISHED IF POINTER POINTS TO 10E0 HR, OTHERWISE FLAC
* IS MULTIPLIED BY 10 (SHIFT LEFT, 1 POSITION).
*
YNEC RRLSD 10E0 DIGIT HR ?
BRANCH FLSH NO: FLAC x 10
*
* 10E0 IS PROCESSED. RESULT WITHIN FLAC, FINISHED.
*
    RETN
*
* REGB IS ADDED TO THE FLAC.
*
\begin{tabular}{llll} 
FADD & TAMZA & & HR-DIGIT \(-1 \rightarrow\) HR \\
& TCY & RRLSD & ADDITION \\
& LDX & RRXFL & \\
& REAC & & SS \(=0\) (SAL SETS SS !) \\
ADLOPM & DMEA & & FLAC + REGB \(+\mathrm{SS}->\) AC \\
& TAMACS & 6 & /FLAC/ \(=/\) FLAC \(+/\) REGB/ \\
& CTMDYN & & \\
& BRANCH & ADLOPM & \\
& BR & MULLOP & ADDITION FINISHED
\end{tabular}
*_--------
* SHIFT FLAC 1 DIGIT TO THE LEFT (X 10)
*
\begin{tabular}{llll} 
FLSH & TCY & RRPFL & \(X=\) RRXHR \\
& IMAC & & POINTER FOR HR \\
& TAMZA & & TO NEXT LOWER DIGIT
\end{tabular}
```



```
\begin{tabular}{llll} 
& TAMDYN & & \(Y=\) RRLSD \\
* HRRLOP & LDX & RRXFL & FLAC \(->\) HR \\
& CLA & & FLAC <-- 0000 \\
& XMA & & \\
& LDX & RRXHR & \\
& TAMDYN & & \\
& BRANCH & HRRLOP & \\
& & & \\
& TCY & RRPFL & X \(=\) RRXHR \\
& TCMIY & RRLSD & SET POTCTR TO LSD
\end{tabular}
```

```
* (a)
```

* (a)
* SHIFT CONTENT OF REGB TO THE LEFT, UNTIL MSD IS UNLIKE 0.
* 

INLOP LDX RRXRB
TCY RRMSD
MNEZ
BRANCH PDIVLOP UNLIKE 0: FINISHED
*

* MSD IS STILL 0. REGB IS SHIFTED 1 DIGIT TO THE LEFT.

```

```

* 
* CHECK IF HR > REGB
* 

DIVLOP TCY RRMSD
COMLOP TDA

```


\subsection*{6.6 Square Root Routine}

The square root is often needed in computations. The following subroutine uses the NEWTONIAN approximation for this problem. 10 iterations are used.
```

* SQUARE ROOT OF VALUE A IN FLAC: X = SQROOT(A)
* Xn+1 = 1/2(Xn + A/Xn) NEWTONIAN APPROXIMATION
* BEFORE CALL: A IN FLAC XXXXX OR XXXX.XX OR XXX.XXXX
* AFTER RETURN: X IN FLAC XXX.Y OR XXX.YY XX.YYY
* 

| SQROOT | CALLL | FLACZWSP | A $\quad->$ ZWSP | XXXX |
| :---: | :---: | :---: | :---: | :---: |
|  | CALL | FLTORB | A/10 -> REGB | XXX. X |
|  | TCY | LOOPCNT | $\mathrm{X}=\mathrm{RRXFL}$ |  |
|  | TCA | 10 | SET LOOP COUNT $=10$ |  |
| L\$004 | TAM |  |  |  |
|  | CALLL | CLRFLAC | +0 -> FLAC |  |
|  | CALLL | ZWFL100 | A $\times 100 \rightarrow$ FLAC | XXXX. 00 |
|  | CALLL | DIVISION | A/Xn $\quad->$ FLAC | XXX.Y |
|  | CALLL | ADDITION | $\mathrm{A} / \mathrm{Xn}+\mathrm{Xn} \rightarrow \mathrm{FLAC}$ | XXX.Y |
|  | CALLL | CLRREGB |  |  |
|  | TCY | RRLSD |  |  |
|  | TCMIY | 2 | $2 \rightarrow$ REGB | X |
|  | CALLL | DIVISION | $\mathrm{Xn}+1=1 / 2(\mathrm{~A} / \mathrm{Xn}+\mathrm{Xn})$ | XXX.Y |
|  | CALL | FLTORB | $\mathrm{Xn}+1 \rightarrow$ REGB | XXX.Y |
|  | TCY | LOOPCNT | $\mathrm{X}=\mathrm{RRXFL}$ |  |
|  | DMAN |  | LOOP COUNT - 1 |  |
|  | BRANCH | L\$004 |  |  |
|  | RETN |  |  |  |


| ZWFL100 | TCY | RRLSD | ZWSP x $100 \rightarrow$ FLAC |
| :---: | :---: | :---: | :---: |
| L\$005 | LDX | XZWSP | M (XZWSP, 0-RRVZ) -> M (RRXFL, 0-RRVZ) |
|  | TMA |  |  |
|  | ACYY | 14 |  |
|  | LDX | RRXFL |  |
|  | TAMIYC |  |  |
|  | YNEC | 1 | Y MSD-1 |
|  | BRANCH | L\$005 | XXXX. 00 |
|  | RETN |  |  |
| * |  |  |  |
| FLTORB | LDX | RRXFL | COPY FLAC TO REGB |
|  | TCY | RRVZ |  |
| L\$006 | TMA |  |  |
|  | XDA |  | M (RRXFL, 0-RRVZ) $\rightarrow$ M (15, 0-RRVZ) |

            DYN
            BRANCH L$006
    ```
\begin{tabular}{llll} 
& RETN & & \\
* & & & \\
FLACZWSP & TCY & RRVZ & COPY FLAC TO INTERM. BUFFER \\
L\$009 & LDX & RRXFL & \\
& TMA & & \\
& LDX & XZWSP & M(RRXFL, 0-RRVZ) \(\rightarrow\) M(15, 0-RRVZ) \\
& TAMDYN & & \\
& BRANCH & L\$009 & \\
& RETN & &
\end{tabular}

\subsection*{6.7 ADC Measurement Routines}

To achieve a reliable result A/D conversions should add at least two measurements: one with noninverted and one with inverted comparator inputs. This compensates the offset error of the comparator. Adding more than two measurements increases the accuracy of the measurements. After each conversion the range bit should be controlled.

Three measurement routines are shown:
- Two measurements
- More than two measurements with fixed count
- More than two measurements with count in accumulator

The routines use all the same subroutines and are optimized concerning ROM space. Implemented delays are for the highest MOS oscillator frequency ( 950 kHz ). The SV DDD is switched on as soon as possible to allow the resistor network to settle.

If the highest possible speed is necessary, the measurement loop is to be coded straight forward. This means, the successive approximation part of the following examples would look like:
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[t]{10}{*}{MEASLOOP} & LDX & 15 & & \\
\hline & TCY & 13 & ADC HW-BUFFER M (15,13-15) & \\
\hline & TCMIY & 8 & LOADED WITH MIDTH OF RANGE & - \\
\hline & TCMIY & 0 & (800) & 1 \\
\hline & TCMIY & 0 & & 1 \\
\hline & TCY & 13 & START WITH MSB OF MSD & 7 INSTR. \\
\hline & CALL & DELAY3 & & V \\
\hline & TCTM & 3 & & - \\
\hline & CALL & DELAY4 & & 5 INSTR. \\
\hline & TCTM & 2 & & - \\
\hline
\end{tabular}

Revision 1, July 1991
\begin{tabular}{lllll} 
CALL & DELAY3 & & 4 & INSTR. \\
TCTM & 1 & & - \\
CALL & DELAY2 & & 3 & INSTR. \\
TCTM & 0 & & - \\
IYC & & & \\
SBIT & 3 & & - \\
MNEA & & DELAY & 2 & INSTR. \\
TCTM & 3 & & - \\
TCTM & 2 & 1 INSTRUCTION DELAY & \\
TCTM & 1 & UNTIL LSB & \\
TCTM & 0 & & \\
IYC & & & \\
SBIT & 3 & & \\
TCTM & 3 & & \\
TCTM & 2 & & \\
TCTM & 1 & & \\
TCTM & 0 & LSB: CONVERSION COMPLETE &
\end{tabular}

\subsection*{6.7.1 ADC Measurement Routines with two Measurements}
* MEASUREMENT ROUTINE: 2 MEASUREMENTS ARE ADDED, ONE WITH
* INVERTED AND ONE WITH NONINVERTED COMPARATOR INPUTS.
* M(15,12) IS USED FOR COUNTING
* RETURN: AC = 0: MEASUREMENT OK, RESULT M(XA/D,12-15)
* AC \# 0: MEASUREMENT NOT OK, RESULT UNDEFINED
*
* CALL: CALLL MEASINIT 1. MEASUREMENT
* CALLL MEASURE FOR ADDITIONAL MEASUREMENTS
*
MEASINIT SCSV SWITCH SVDD ON, COMP. NONINV.
LDX XA/D \(0->A / D\) BUFFER M(XA/D,12-15)
TCY 12 (BUFFER FOR ADDING)
TCMIY 0
TCMIY 0
TCMIY 0
TCMIY 0
*
\begin{tabular}{llll} 
MEASURE & TCY & DL13 & \begin{tabular}{l} 
CURRENT SOURCE ON (DELETE LINES
\end{tabular} \\
* & SETR & & IF VOLTAGE SOURCE NEEDED)
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[t]{5}{*}{} & TCY & 13 & \multicolumn{3}{|l|}{ADC HW-BUFFER M (15,13-15)} \\
\hline & TCMIY & 8 & LOADED WITH MIDTH OF RANGE & & - \\
\hline & TCMIY & 0 & (800) & & 1 \\
\hline & TCMIY & 0 & & & I \\
\hline & TCY & 13 & START WITH MSB OF MSD & \multirow[t]{4}{*}{7} & \multirow[t]{2}{*}{INSTR. I} \\
\hline \multirow[t]{12}{*}{SUKZLP} & SBIT & 3 & \multirow[t]{12}{*}{SUCCESSIVE LOOP M (15,13-15)} & & \\
\hline & CALL & DELAY2 & & & V \\
\hline & TCTM & 3 & & & - \\
\hline & CALL & DELAY4 & & 5 & INSTR. \\
\hline & TCTM & 2 & & & - \\
\hline & CALL & DELAY3 & & 4 & INSTR. \\
\hline & TCTM & 1 & & & - \\
\hline & CALL & DELAY2 & & 3 & INSTR. \\
\hline & TCTM & 0 & & & - \\
\hline & IYC & & & & \\
\hline & YNEC & 0 & & & \\
\hline & BRANCH & SUKZLP & & & \\
\hline \multicolumn{6}{|l|}{*} \\
\hline & TCY & 12 & \multicolumn{3}{|l|}{RANGE CONTROL:} \\
\hline & TRTM & 3 & \multicolumn{3}{|l|}{RESULT >FFF ODER >000 ?} \\
\hline & TBIT & 3 & \multicolumn{3}{|l|}{\(\mathrm{M}(15,12,3): 0=O \mathrm{~K}\)} \\
\hline & BRANCH & MESERROR & 1 = FEHLMESSUNG & & \\
\hline & DMAN & & \multicolumn{3}{|l|}{COUNT -1} \\
\hline & BRANCH & M2 & & & \\
\hline
\end{tabular}
*
* BOTH MEASUREMENTS ARE OK: ADD RESULT WITH INVERTED
* COMPARATOR INPUTS TO PREVIOUS RESULT.
\begin{tabular}{|c|c|c|c|}
\hline & RCSV & & SWITCH SVDD OFF \\
\hline \multirow[t]{4}{*}{ADDA/D} & TCY & 15 & ADD A/D VALUE M(15, 13-15) \\
\hline & LDX & XA/D & TO A/D BUFFER M (XA/D, 12-15) \\
\hline & SAL & & \\
\hline & REAC & & \\
\hline \multirow[t]{9}{*}{ADL} & DMEA & & \\
\hline & TAMACS & 0 & \\
\hline & CTMDYN & & \\
\hline & YNEC & 12 & \\
\hline & BRANCH & ADL & \\
\hline & CCLA & & SPECIAL STATUS -> A \\
\hline & AMAAC & & ADD MSD \\
\hline & TAMZA & & MSD -> M \((12,12)\) \\
\hline & RETN & & AC \(=0:\) ALL OK \\
\hline
\end{tabular}
* MEASUREMENT WITH NONINVERTING COMPARATOR INPUTS IS OK:
* STORE A/D VALUE.
* START MEASUREMENT WITH INVERTED COMPARATOR INPUTS NOW
*

Revision 1, July 1991


\subsection*{6.7.2 ADC Measurement Routine with "EQU" defined Number of Conversions}

The next A/D conversion uses a fixed number of measurements defined by an "EQU" directive. The maximum number of added conversions is \(4 \cdot 2\). If more added conversions are needed, the entry "MEASURE" can be used once more for additional 4 - 2 measurements (then the four-digit A/D buffer is full).
```

* ANALOG DIGITAL CONVERSION ROUTINE
* NUMBER OF CONVERSIONS IS DEFINED BY "EQU" DIRECTIVE
* M(15,12) IS USED FOR COUNTING
* RETURN: AC = 0: MEASUREMENT OK, RESULT IN M(XA/D,12-15)
* AC \# 0: MEASUREMENT NOT OK, RESULT UNDEFINED
* 
* CALL: CALLL MEASINIT 1st N MEASUREMENTS
* CALLL MEASURE ADDITIONAL N MEASUREMENTS
* 
* ENTRY FOR 1st N MEASUREMENTS
* 

| N-1  <br> $\star$ EQU | 7 | EXAMPLE: ADD UP 8 MEASUREMENTS |  |
| :--- | :--- | :--- | :--- |
| MEASINIT | SCSV |  |  |
|  | LDX | XA/D | $0 \rightarrow$ A/D SVDD ON, COMP, NONINV. |
|  | TCY | 12 | (BUFFER FOR ADDING UP) |

```
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{3}{*}{} & TCMIY & 0 & \\
\hline & TCMIY & 0 & \\
\hline & TCMIY & 0 & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multicolumn{4}{|l|}{* ENTRY FOR ADDITIONAL N MEASUREMENTS} \\
\hline \multirow[t]{2}{*}{MEASURE} & TCY & DL13 & CURRENT SOURCE ON \\
\hline & SETR & & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline & LDX & 15 & 1st MEASUREMENT: COMP. NONINV. \\
\hline & TCY & 12 & COUNTER FOR N MEASUREMENTS \\
\hline & TCMIY & N-1 & LOAD COUNTER WITH N-1 ( \(\mathrm{Nmax}=8\) ) \\
\hline \multicolumn{4}{|l|}{* \({ }^{\text {a }}\)} \\
\hline \multirow[t]{6}{*}{MEASLOOP} & LDX & 15 & \\
\hline & TCY & 13 & LOAD ADC HW-BUFFER M (15,13-15) \\
\hline & TCMIY & 8 & WITH MIDTH OF ADC RANGE \\
\hline & TCMIY & 0 & \\
\hline & TCMIY & 0 & \\
\hline & TCY & 13 & START WITH MSB OF MSD \\
\hline \multirow[t]{12}{*}{SUKZLP} & SBIT & 3 & SUCCESSIVE LOOP M (15,13-15) \\
\hline & CALL & DELAY2 & \\
\hline & TCTM & 3 & \\
\hline & CALL & DELAY4 & \\
\hline & TCTM & 2 & \\
\hline & CALL & DELAY3 & \\
\hline & TCTM & 1 & \\
\hline & CALL & DELAY2 & \\
\hline & TCTM & 0 & \\
\hline & IYC & & \\
\hline & YNEC & 0 & \\
\hline & BRANCH & SUKZLP & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline & TCY & 12 & RANGE CONTROL: \\
\hline & TRTM & 3 & RESULT >FFF ODER >000 ? \\
\hline & TBIT & 3 & \(\mathrm{M}(15,12,3): 0=\mathrm{OK}\) \\
\hline & BRANCH & MESERROR & \(1=\) ERROR \\
\hline & DMAN & & DECREMENT COUNT \\
\hline & BRANCH & M2 & \\
\hline * & & . & \\
\hline \multicolumn{4}{|l|}{* ALL MEASUREMENTS OK: ADD RESULT TO A/D BUFFER} \\
\hline & RCSV & & SWITCH SVDD OFF \\
\hline \multirow[t]{4}{*}{ADDA/D} & TCY & 15 & ADD A/D VALUE M (15, 13-15) \\
\hline & LDX & XA/D & TO A/D BUFFER M (XA/D, 12-15) \\
\hline & SAL & & \\
\hline & REAC & & \\
\hline ADL & DMEA & & \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{8}{*}{} & TAMACS & 0 & \\
\hline & CTMDYN & & \\
\hline & YNEC & 12 & \\
\hline & BRANCH & ADL & \\
\hline & CCLA & & SPECIAL STATUS -> AC \\
\hline & AMAAC & & ADD MSD \\
\hline & TAMZA & & MSD \(\rightarrow\) M \((12,12)\) \\
\hline & RETN & & \(A C=0: ~ A L L O K\) \\
\hline \multicolumn{4}{|l|}{\multirow[t]{3}{*}{\begin{tabular}{l}
* MEASUREMENT OK. SWITCH COMPARATOR INPUT: \\
* EVEN MEASUREMENTS WITH INVERTED COMPARATOR INPUTS, \\
* ODD MEASUREMENTS WITH NONINVERTED COMPARATOR INPUTS. *
\end{tabular}}} \\
\hline & & & \\
\hline & & & \\
\hline \multirow[t]{5}{*}{M2} & TAM & & WRITE BACK DECREMENTED COUNT \\
\hline & SCSV & & NON INVERTED COMP. INPUTS \\
\hline & TBIT & 0 & BIT 20 CONTAINS COMP. INFO \\
\hline & BRANCH & L\$810 & ODD MEASUREMENT: NONINV. \\
\hline & RCI & & EVEN MEASUREMENT: INV. \\
\hline \multirow[t]{2}{*}{L\$810} & CALL & ADDA/D & A/D VALUE \(\rightarrow\) A/D BUFFER \\
\hline & BR & MEASLOOP & NEXT MEASUREMENT \\
\hline \multicolumn{4}{|l|}{* ERRONEOUS MEASUREMENT: AC <-- 15 *} \\
\hline \multirow[t]{3}{*}{MESERROR} & RCSV & & SWITCH OFF SVDD \\
\hline & TCA & 15 & ERROR INDICATION \(->\) A \\
\hline & RETN & & \\
\hline
\end{tabular}

\subsection*{6.7.3 ADC Measurement Routine with Number of Conversions in Accumulator}

The next A/D conversion uses a number of measurements which is contained in the accumulator. The maximum number of added conversions is 8. If more added conversions are needed, the entry "MEASURE" can be used once more for additional 8 measurements (then the four-digit A/D buffer is full). Starting at the label MEASLOOP the same software is used as with the last example.
* ANALOG DIGITAL CONVERSION ROUTINE
* NUMBER OF CONVERSIONS \(N\) IS CONTAINED IN ACCUMULATOR AS N-1
* \(\mathrm{M}(15,12)\) IS USED FOR COUNTING
* RETURN: \(\quad \mathrm{AC}=0\) : MEASUREMENT OK, RESULT IN M(XA/D,12-15)
* AC \# 0: MEASUREMENT NOT OK, RESULT UNDEFINED
```

| CALL: | TCA | N-1 | CALL FOR N MEASUREMENTS 1st N MEASUREMENTS |
| :---: | :---: | :---: | :---: |
|  | CALLL | MEASINIT |  |
|  | TCA | $\mathrm{N}-1$ |  |
|  | CALLL | MEASURE | ADDITIONAL N MEASUREMENTS |
| * |  |  |  |
| * ENTRY FOR 1st N MEASUREMENTS |  |  |  |
| MEASINIT | SCSV |  | SWITCH SVDD ON, COMP. NONINV. 0 -> A/D BUFFER M(XA/D, 12-15) (BUFFER FOR ADDING UP) |
|  | LDX | XA/D |  |
|  | TCY | 12 |  |
|  | TCMIY | 0 |  |
|  | TCMIY | 0 |  |
|  | TCMIY | 0 |  |
|  | TCMIY | 0 |  |
| * |  |  |  |
| * ENTRY FOR ADDITIONAL N MEASUREMENTS * |  |  |  |
|  |  |  |  |  |
| MEASURE | TCY | DL13 | CURRENT SOURCE ON |
|  | SETR |  |  |
| * |  |  |  |
|  | LDX | 15 | 1st MEASUREMENT: COMP. NONINV. COUNTER FOR N MEASUREMENTS |
|  | TCY | 12 |  |
|  | TAM |  | LOAD COUNTER WITH N-1 FROM ACCU |
| * |  |  |  |
| MEASLOOP | LDX | 15 |  |
|  | TCY | 13 | LOAD ADC HW-BUFFER M(15,13-15) PROGRAM EXACTLY LIKE SHOWN ABOVE SEE EXAMPLE 6.7.2 |
|  | . . |  |  |
|  | -• |  |  |

```

\subsection*{6.8 Binary to BCD Conversion}

The hexadecimal value in \(M(X A / D, 12-15)\), normally the output value of an A/D conversion, is converted to BCD format by this subroutine. The result is stored in the FLAC. The memory nibble M(XA/D,YPOI) is used as a pointer to the hexadecimal number. The subroutines of the Integer Math. Package are used for the conversion. If hex numbers are greater than \(>\) FFFF, the pointer M(XA/D, YPOI) must be loaded initially with the Y address of the MSD.
```

* CONVERSION OF A HEXADECIMAL VALUE INTO DECIMAL FORMAT
* 
* INPUT: HEX VALUE (0 - >FFFF) IN M(XA/D,12-15)
* AFTER RETURN: BCD VALUE (0 - 65535) IN FLAC

```
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{4}{*}{HEXDEC} & CALL & CLRFLAC & +0 \(->\) FLAC \\
\hline & LDX & XA/D & \\
\hline & TCY & YPOI & SET POINTER FOR ACTUAL HEX DIGIT \\
\hline & TCMIY & 12 & TO MSD OF THE HEX NUMBER \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multirow[t]{12}{*}{L\$045} & LDX & XA/D & POINTER -> Y \\
\hline & TCY & YPOI & \\
\hline & TMY & & \\
\hline & TMA & & ACTUAL HEX DIGIT -> AC \\
\hline & CALL & CLRREGB & +0 -> REGB \\
\hline & TCY & RRLSD & ADD ACTUAL HEX DIGIT TO FLAC \\
\hline & TAM & & \\
\hline & ALEC & 9 & CORRECT IT IF GREATER THAN 9 \\
\hline & BRANCH & L\$046 & \\
\hline & ACACC & 6 & \(>\mathrm{A}\) TO >F \(->10\) TO 15 \\
\hline & TAMDYN & & \\
\hline & TCMIY & 1 & \\
\hline \multirow[t]{12}{*}{L\$046} & CALLL & ADDITION & FLAC + REGB \(\rightarrow\) FLAC \\
\hline & LDX & XA/D & TO NEXT LOWER HEX DIGIT \\
\hline & TCY & YPOI & \\
\hline & IMAC & & POINTER : = POINTER + 1 \\
\hline & BRANCH & L\$047 & IF RESULT IS 0: CONV. DONE \\
\hline & TAM & & \[
\mathrm{POI}+1->\mathrm{POI}
\] \\
\hline & CALL & CLRREGB & \\
\hline & TCY & RRE1 & \(16 \rightarrow\) REGB \\
\hline & TCMIY & 1 & \\
\hline & TCMIY & 6 & \\
\hline & CALLL & MULTIPL & FLAC x \(16 \rightarrow\) FLAC \\
\hline & BR & L\$045 & \\
\hline L\$047 & RETN & & RESULT IN FLAC \\
\hline
\end{tabular}

\subsection*{6.9 Keyboard Scan Routines}

If more than 2 keys are used in an application, the keys are normally arranged in a matrix to save outputs and inputs. With \(n\) outputs and \(m\) inputs, \(m \cdot n\) keys, programming diodes and switches can be scanned.

Three different hardware configurations are possible:
- If only one key can be activated at any time, no diodes are necessary for decoupling.
- If multiple key functions are not allowed (but cannot be excluded) diodes are necessary only at each output.
- If multiple key functions are used, each key needs a decoupling diode in series with the contact.
Two software solutions for keyboard scanning are possible:
- If the wakeup frequency is 8 Hz or higher, polling is possible after wakeup. Debouncing can be done by multiple wakeups, which results in current saving compared to delay routines.
- If the wakeup frequency is 1 Hz , the R-outputs which control keys, have to be set during Done Mode to allow wakeup by key activation.

\subsection*{6.9.1 Keyboard Routine with fast Wakeup [8 to 128 Hz ]}

The example uses one RAM nibble for each R-output and a common status nibble for all keys. The status nibble is shift left one position by each wakeup and the LSB is set if a keyboard change occured, compared to the last wakeup. If no change occured the LSB is reset.
The debouncing time is one wakeup period.
The following information can be extracted out of the status nibble:
\begin{tabular}{|c|c|l|}
\hline Bit 1 & Bit 0 & Function \\
\hline 0 & 0 & no change compared with last wakeup \\
0 & 1 & change occured, but not yet debounced \\
1 & 0 & change occured, debounced \\
1 & 1 & change ongoing \\
\hline
\end{tabular}

Figure 20: Information in Keyboard Status Bits

For wakeup frequencies higher than 8 Hz , Bit 2 and Bit 3 of the status nibble can also be used:

Debouncing is reached if several LSBs are all 0 and the next bit is 1 .
The \(K\) and \(R\) lines of the RAM nibbles \(0-2\) show the current state of the keyboard. Each activated key, switch or programming diode is represented by a set bit. All other bits are reset:

\footnotetext{
Revision 1, July 1991
}


Figure 21: RAM Organization Keyboard Routines
The routine is designed for applications where DL12 is always set.This means wakeup frequencies from 8 Hz to 128 Hz . The switches, diodes and keys are placed in a 3 - 4 matrix: (R0, R1, R2) and (K1, K2, K4, K8). The high wakeup frequency allows normal scanning of the keyboard without using the wakeup feature of the K-Port.

\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{3}{|c|}{DONE} & \multirow[t]{2}{*}{AND SLEEP AGAIN} \\
\hline * KEYBOARD & ROUTIN & & \\
\hline \multirow[t]{2}{*}{KEYBOARD} & LDX & XORG & M (XORG, 0-3) USED FOR KEYBOARD \\
\hline & TCY & R0 & START WITH RO KEYS \\
\hline \multirow[t]{11}{*}{L\$500} & SETR & & SET R OUTPUT \\
\hline & TMA & & INFO OF LAST WAKEUP \(->\) A \\
\hline & TKM & & NEW INFO -> MEMORY \\
\hline & RSTR & & RESET R OUTPUT \\
\hline & MNEA & & CHANGE COMPARED TO LAST WAKEUP ? \\
\hline & BRANCH & L\$501 & \\
\hline & IYC & & NO, PREPARE FOR NEXT R OUTPUT \\
\hline & YNEC & KEYSTAT & ALL R OUTPUTS THROUGH ? \\
\hline & BRANCH & L\$500 & \\
\hline & TCA & 0 & YES, NO CHANGE IN KEYBOARD \\
\hline & BRANCH & L\$502 & RESET BIT 0 OF STATUS \\
\hline L\$501 & TCA & 1 & CHANGE IN KEYBOARD, SET BIT 0 \\
\hline \multirow[t]{5}{*}{L\$502} & TCY & KEYSTAT & \\
\hline & AMAAC & & SHIFT LEFT PREVIOUS INFO \\
\hline & AMAAC & & NEW STATUS TO BIT 0 \\
\hline & TAM & & RETURN WITH ADDRESSED STATUS \\
\hline & RETN & & NIBBLE M (XORG, KEYSTAT) \\
\hline
\end{tabular}

\subsection*{6.9.2 Keyboard Routine with 1 Hz Wakeup}

The example uses the same RAM locations and status information as the "fast version" described before. The R-outputs are set to allow fast response to a key activation. After recognition of a LO-HI transition at any Kinput, the Digit Latch DL12 is set to operate at a higher wakeup frequency for debouncing. The keyboard scanning is made as described in the "fast version" before. When all keys are released as debounced, DL12 is reset to 1 Hz wakeup frequency and the R-outputs are set again to allow wakeup by LO-HI transitions.
Note: R-outputs which control switches and diodes must not be set during Done Mode: wakeup initiated by LO-HI transitions is only possible, if all other K-inputs are low.

```

RSTR WAKEUP BACK TO 1 HZ
CALL SETR012 SET R-OUTPUTS
BR
MAINLOOP

| CHANGE | - . | PROCESS KEYBOARD CHANGE |
| :--- | :--- | :--- |
|  | DONE | AND SLEEP AGAIN |

*---------

* SUBROUTINE SETS R0, R1 AND R2 TO ALLOW WAKEUP
* 

SETR012 TCY R2
L\$506 SETR
DYN
BRANCH L\$506
RETN

```

\subsection*{6.10 Clock Routine}

The subroutine maintains the time in the european format:
\[
00.00 .00 \text { to } 23.59 .59
\]

The subroutine is entered with the difference in seconds to the last call in the accumulator. This ensures that no second is lost up to 15 seconds difference.
\begin{tabular}{|c|c|c|c|}
\hline XCLK & EQU & 3 & X BANK OF CLOCK \\
\hline YSEC0 & EQU & 5 & Y SECONDS 10E0 \\
\hline YHRS0 & EQU & 1 & Y Hours 10E0 \\
\hline YHRS1 & EQU & 0 & Y Hours 10E1 \\
\hline YHRS1-1 & EQU & 15 & Y OUTSIDE CLOCK BUFFER \\
\hline \multirow[t]{3}{*}{CLOCK} & LDX & XCLK & DIFFERENCE IN ACCUMULATOR \\
\hline & TCY & YSEC0 & SEC 10E0 \\
\hline & SAL & & SET ADD LATCH FOR ADDITION \\
\hline \multirow[t]{10}{*}{CLKLP} & AMAAC & & \\
\hline & TAMACS & 6 & SECONDS, MINUTES, HOURS 10E0 \\
\hline & CTMDYN & & CORRECT FOR \(0-9\) \\
\hline & CCLA & & SS (CARRY) -> A \\
\hline & AMAAC & & \\
\hline & TAMACS & 10 & SECONDS, MINUTES, HOURS 10E1 \\
\hline & CTMDYN & & CORRECT FOR 0-6 \\
\hline & CCLA & & \\
\hline & YNEC & YHRS1-1 & Hours 10E1 YET DONE ? \\
\hline & BRANCH & CLKLP & NO \\
\hline
\end{tabular}

\footnotetext{
Revision 1, July 1991
}
\begin{tabular}{|c|c|c|c|}
\hline & TCY & YHRS 0 & TIME \(=24 . \mathrm{XX}\) ? \\
\hline & TMA & & \\
\hline & ALEC & 3 & \\
\hline & BRANCH & CLKRET & \\
\hline & TCY & YHRS1 & \\
\hline & TMA & & \\
\hline & ALEC & 1 & \\
\hline & BRANCH & CLKRET & \\
\hline & TCMIY & 0 & YES, CORRECT TO 00.XX \\
\hline & TCMIY & 0 & \\
\hline CLKRET & RETN & & \\
\hline
\end{tabular}

\subsection*{6.11 Temperature Computation for Sensors}

\subsection*{6.11.1 Temperature Computation for PT500 Sensors}
* SUBROUTINE: COMPUTATION OF SENSOR TEMPERATURE FROM A/DC VALUE
*
* INPUT: ADC VALUE ( \(>\mathrm{A}->9 \mathrm{FEC}\) ) IN M(XA/D,12-15)
* AFTER RETURN: TEMPERATURE T (+-XXX. YYYY C) IN FLAC
*
* VALUES FOR COMPUTATION:
*
* RV \(=487\) OHM Rext CURRENT SOURCE RESISTOR
* R25 = 500 OHM SENSOR RESISTANCE @ 0 C
* ADC VALUE 0002 EQUALS \(0.231314 \times\) SVDD LOWEST A/D VALUE
* ADC VALUE 1FFC EQUALS 0.407511 x SVDD HIGHEST A/D VALUE
* FROM THE ABOVE:
* ADC VALUE \(\mathrm{N}=\) Vin/SVDD x 46459.36-10744.7 ADC EQUATION
* USED VALUES FOR COMPUTATION:
*
* TEMP [C] RF ADC VALUE
*
\begin{tabular}{cccc}
-1 & 500 & 3572.718 \\
0 & \((568.05)\) & \((11370.73) \quad\) CONTROL ONLY \\
70 & 635.35 & 19082.81 \\
140 & 767.9 & 34272.03 \\
200 & 879.2 & 47026.17 \\
\(T=((A \times M+B) \times M+C) \times M)+D\)
\end{tabular}

\begin{tabular}{|c|c|c|c|}
\hline CALLL & LOADM & & MMMMM \\
\hline CALLL & MULTIPL & \(\mathrm{Mx}(\mathrm{Mx}(\mathrm{AxM}+\mathrm{B})+\mathrm{C})\) & XX. YYYYYYYYYYY \\
\hline CALLL & CLRREGB & CONST. D TO REGB & -1.593 E +1 \\
\hline TCY & RRE12 & & \\
\hline TCMIY & 1 & E +1 & X.YYY00000000 \\
\hline TCMIY & 5 & & \\
\hline TCMIY & 9 & & \\
\hline TCMIY & 3 & & \\
\hline TCY & 15 & & \\
\hline TCMIY & 8 & INSERT - SIGN & \\
\hline CALLL & ADDITION & \(\operatorname{Mx}(\mathrm{Mx}(\mathrm{MXA})+\mathrm{B})+\mathrm{C})\) & \\
\hline CALLL & DIV10E3 & & \\
\hline CALLL & DIV10E4 & SHIFT 7 RIGHT & \\
\hline RETN & & & XXX.YYYY \\
\hline
\end{tabular}

\subsection*{6.11.2 Temperature Computation for TSP202 Sensors}
* SUBROUTINE COMPUTES TEMPERATURE FROM A/DC VALUE
*
* INPUT: ADC VALUE ( \(>2->1 \mathrm{FFC}\) ) IN M(XA/D,12-15)
* AFTER RETURN: TEMPERATURE T (+-XXX.YY C) IN FLAC
*
* BASE OF COMPUTATIONS:
*
* RV = 5.11 KOHM SERIES RESISTOR
* R25 \(=2.00 \mathrm{KOHM}\) SENSOR RESISTOR @25C
* R85/R25 = 1.54 SENSOR INCLINATION
* ADC VALUE 0002 EQUALS 0.231271 x SVDD LOWER A/D VALUE
* ADC VALUE 1FFC EQUALS 0.407511 x SVDD UPPER A/D VALUE
* FROM THE ABOVE:
* ADC VALUE \(=\) Vin/SVDD x 46448.18355-10740.13644 A/DC EQUATION
* \(T=A D C\) VALUE \(x 0.013629859-6.695646691 \quad\) EXACTLY
* \(T=A D C\) VALUE \(x 0.01363\) USED
*
* CALL: ADC VALUE ( 0 - >FFFF) IN M (XA/D, 12-15)
* RESULT: TEMPERATURE (XXX.YY) IN FLAC
*
\begin{tabular}{llll} 
TEMPCOMP & CALLL & HEXBCD & COMPUTE BCD VALUE OF (XA/D, 12-15) \\
CALLL & CLRREGB & BCD VALUE IN FLAC & XXXXX \\
TCY & RRE3 & & \\
TCMIY & 1 & \(0.01363->\) REGB & \(0.0 Y Y Y Y ~\) \\
TCMIY & 3 & & \\
TCMIY & 6 & & \\
TCMIY & 3 & & XXX.YYYYY
\end{tabular}
\begin{tabular}{llll} 
CALLL & ROUNDFL & ROUND FLAC & XXX.YYYY \\
CALLL & ROUNDFL & & XXX.YYY \\
CALLL & CLRREGB & & \\
TCY & RRE3 & & \\
TCMIY & 6 & \(6.696->\) REGB & \\
TCMIY & 6 & & \\
TCMIY & 9 & & \\
TCMIY & 6 & & \\
CALLL & SUBTRAKT & ADC VALUE X & \(0.01363-6.696\) X.YYY \\
CALLL & ROUNDFL & & \\
RETN & & &
\end{tabular}

\subsection*{6.12 Battery Check Routines}

\subsection*{6.12.1 Battery Check Routine I}

The 1st subroutine is used during system calibration with \(V_{D D}=V_{D D \min }\). The output of the measurement routine is stored in \(M(10,12-15)\) for later references by the 2nd subroutine.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{6}{*}{SETLOVDD} & TCY & DL9 & PREPARE FOR BATTERY CHECK \\
\hline & \multicolumn{3}{|l|}{SETR} \\
\hline & CALLL & MEASURE & ADC RESULT -> M (XA/D, 12-15) \\
\hline & ACACC & 15 & AC \# 0 IF ERROR \\
\hline & CALL & WARNING & USER DEFINED ERROR ROUTINE \\
\hline & TCY & 12 & STORE RESULT TO M (10,12-15) \\
\hline \multirow[t]{8}{*}{L\$010} & LDX & XA/D & \\
\hline & TMA & & \(M(X A / D, 12-15) \rightarrow M(10,12-15)\) \\
\hline & \multicolumn{3}{|l|}{TAMIYC} \\
\hline & YNEC & 0 & \\
\hline & BRANCH & L\$010 & \\
\hline & TCY & DL9 & ALLOW A1 TO A4 USAGE AGAIN \\
\hline & \multicolumn{3}{|l|}{RSTR} \\
\hline & \multicolumn{3}{|l|}{RETN} \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multicolumn{4}{|l|}{\multirow[t]{2}{*}{\begin{tabular}{l}
* SUBROUTINE TESTS IF VDDMIN IS REACHED. \\
* THIS ROUTINE SHOULD BE CALLED REGULARELY (EG. ONCE PER DAY)
\end{tabular}}} \\
\hline & & & \\
\hline \multirow[t]{2}{*}{* CALL:} & CALLL & TSTVDD & \\
\hline & ACACC & 15 & TEST RESULT IN A \\
\hline \multirow[t]{2}{*}{*} & BRANCH & VDDLO & A \# 0: VDD \(=<\) VDDMIN \\
\hline & & & \(\mathrm{A}=0: \quad \mathrm{VDD}>\mathrm{VDDMIN}\) \\
\hline \multicolumn{4}{|l|}{*} \\
\hline TSTVDD & TCY & DL9 & PREPARE FOR BATTERY CHECK \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{3}{*}{} & SETR & & \\
\hline & CALLL & MEASURE & ADC RESULT -> M (XA/D, 12-15) \\
\hline & TCY & 12 & COMPARISON WITH M (10,12-15) \\
\hline \multirow[t]{7}{*}{L\$601} & LDX & 10 & NREF: M (10,12-15) \\
\hline & TMA & & \\
\hline & LDX & XA/D & NMEAS: M (XA/D, 12-15) \\
\hline & ALEM & & \\
\hline & BRANCH & L\$600 & NREFn \(=<\) NMEASn \\
\hline & TCA & 0 & NREF > NMEAS: \\
\hline & BR & L\$603 & VDD > VDDMIN \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multirow[t]{5}{*}{L\$600} & MNEA & & NREFn \(=<\) NMEASn \\
\hline & BRANCH & L\$602 & NREF < NMEAS: VDD < VDDMIN \\
\hline & IYC & & NREFn \(=\) NMEASn \\
\hline & YNEC & 0 & NEXT LOWER PART \\
\hline & BRANCH & L\$601 & LSD YET HANDLED ? \\
\hline L\$602 & TCA & 15 & NREF \(=<\) NMEAS: VDD < VDDMIN \\
\hline \multirow[t]{3}{*}{L\$603} & TCY & 9 & ALLOW A1 TO A4 AGAIN \\
\hline & RSTR & & RESULT IN A \\
\hline & RETN & & \\
\hline
\end{tabular}

\subsection*{6.12.2 Battery Check Routine II}

The 1st subroutine is used during system calibration with \(V_{D D}=V_{D D m i n}\). The output of the measurement routine (only the value measured with noninverted inputs is used) is stored in \(M(10,13-15)\) for later references by the 2nd subroutine.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{7}{*}{SETLOVDD} & TCY & DL9 & PREPARE FOR BATTERY CHECK \\
\hline & SETR & & \\
\hline & CALLL & MEASURE & \\
\hline & ACACC & 15 & AC \# 0 IF ERROR \\
\hline & CALL & WARNING & USER DEFINED ERROR ROUTINE \\
\hline & LDX & 10 & STORE RESULT TO M (10,13-15) \\
\hline & TCY & 13 & \\
\hline \multirow[t]{7}{*}{L\$010} & TDA & & \(M(15,13-15) \rightarrow M(10,13-15)\) \\
\hline & TAMIYC & & \\
\hline & YNEC & 0 & \\
\hline & BRANCH & L\$010 & \\
\hline & TCY & DL9 & ALLOW A1 TO A4 USAGE AGAIN \\
\hline & RSTR & & \\
\hline & RETN & & \\
\hline
\end{tabular}
* RESULT. THIS ROUTINE SHOULD BE CALLED REGULARELY (EG. ONCE
* PER DAY).
*
* CALL: CALLL TSTVDD 
* BRANCH VDDLO IF SET: VDD < VDDMIN
* NOT SET: VDD > VDDMIN
*
\begin{tabular}{llll} 
TSTVDD & LDX & 10 & COPY M(10, 13-15) \\
& TCY & 13 & \\
L\$011 & TMA & & \\
& XDA & & \\
& IYC & & \\
& YNEC & 0 & \\
& BRANCH & L\$011 &
\end{tabular}
TCY DL9 PREPARE FOR BATTERY CHECK
        SETR
        SCSV SWITCH SVDD ON
        RCI SWITCH TO INVERTED COMP. INPUTS
        LDX 15 USE M(15,15,0) FOR COMPARISON
        TCY 15 RESULT:
        TCTM 0 M(15,15,0) = 0: VDD > VDDMIN
        TCY 9 M(15,15,0) = 1: VDD < VDDMIN
        RSTR
        RCSV
        TCY 15 PREPARE Y FOR MAINLOOP TEST
        RETN
```


### 6.13 Initialization Routine

The first program part checks if Warm start conditions are met: $\mathrm{M}(\mathrm{XORG}, 0-3)$ contains check code $>A 50 \mathrm{~F}$. If this code is there, no actions are started. If this condition is not met, the normal initialization routine starts.

## See 2.17 for description of Warm start and Cold start.

|  | ORG | 1920 | POWER UP POINT: PAGE 15 PC 00 |
| :--- | :--- | :--- | :--- |
| INIT? | LDX | XORG | TEST CHECK CODE M(XORG, 0-3) |
|  | TCY | CHCKCOD |  |
|  | TCA | 10 |  |
|  | MNEA |  |  |
|  | BRANCH | INIT |  |

Revision 1, July 1991

```
ACYY 1
BR INIT2 SKIP WAKEUP POINT
ORG 1927 WAKEUP POINT: PAGE 15 PC >7F
....
*
INIT2 TCA 5
MNEA 5
BRANCH INIT
ACYY 1
MNEZ 0
BRANCH INIT
ACYY 1
TCA 15
MNEA >F
BRANCH INIT
DONE RAM IS OK: SPURIOUS INIT-SIGNAL
* RAM CONTENTS ARE DESTROYED: INITIALIZE TSS400
*
\begin{tabular}{lllll} 
INIT & LDX & 1 & CLEAR M(1,0-15) & AND M(9,0-15) \\
& CALL & CLRRAM & & \\
& LDX & 2 & \(\mathrm{X}: 2\) UND A & \\
& CALL & CLRRAM & & \\
& LDX & 3 & \(\mathrm{X}: 3\) UND B \\
& CALL & CLRRAM & & \\
& LDX & 4 & \(\mathrm{X}: 4\) UND C \\
& CALL & CLRRAM & & \\
& LDX & 7 & CLEAR DAM \\
& CALL & CLRRAM & &
\end{tabular}
* NOW INITIALIZE THE NOMINAL CONSTANTS FOR COMPUTING
\begin{tabular}{llll} 
LDX & XCONST & \\
TCY & YB1 & B1: 1.000
\end{tabular}
TCMIY 1
\begin{tabular}{lll} 
LDX & XORG & SET CHECK CODE NIBBLES TO \\
TCY & CHCKCOD & >A50F \\
TCMIY & 10 & \\
TCMIY & 5 & \\
TCMIY & 0 & \\
TCMIY & 15 & \\
BL & MAINLOOP & START PROGRAM
\end{tabular}
```

```
* SUBROUTINE CLEARS ADDRESSED RAM BANK UND RAM BANK+8
*
\begin{tabular}{llll} 
CLRRAM & CLA & & \\
& TCY & 15 & \\
CLRLP & TAMZA & & \(0 \rightarrow M(X, Y)\) \\
& COMX8 & & \\
& TAMDYN & & \(0 \rightarrow M(X+8, Y)\) \\
& BRANCH & CLRLP &
\end{tabular}
```


### 6.14 Waiting Routines

It is often necessary to wait a certain or minimum time before the processing may continue. 3 subroutines for different delay time magnitudes are shown. The delay time of each subroutine can be computed by the formula:

$$
T_{\text {delay }}=\frac{6}{F_{\text {osc }} \cdot \text { instruction count }}
$$

If the delay time is only few microseconds, the following subroutine with several entry points may be used:

| DELAY7 | MNEA | 7 | INSTRUCTIONS DELAY INCL. CALL |
| :--- | :--- | :--- | :--- |
| DELAY6 | MNEA | 6 | INSTRUCTIONS DELAY |
| DELAY5 | MNEA | 5 | INSTRUCTIONS DELAY |
| DELAY4 | MNEA | 4 | INSTRUCTIONS DELAY |
| DELAY3 | MNEA | 3 | INSTRUCTIONS DELAY |
|  | RETN | 2 INSTRUCTIONS DELAY |  |

If the delay time is in the range of milliseconds the above mentioned subroutine would waste to much ROM space. The following subroutine uses two nested loops. The delay time can be computed by the formula:

$$
T_{\text {delay }}=\frac{6}{\mathrm{~F}_{\text {osc }} \cdot(3+((\mathrm{A}+1) \cdot 2+2) *(Y+1))}
$$

* SUBROUTINE FOR WAITING 2 MS (FOSC $=500 \mathrm{KHZ}$ )
* 

| WAIT2MS | TCY | 6 |  |  |
| :--- | :--- | :--- | :--- | :--- |
| WAITXMS | TCA | 10 | ENTRY POINT FOR SET Y REGISTER |  |
| L\$804 | ACACC | 15 |  |  |

Revision 1, July 1991

```
DYN
BRANCH WAITXMS
RETN
```

To achieve other delays than 2 milliseconds, the $Y$ register can be loaded with other values and the entry point WAITXMS can be used. Note the offset +1 which is added to the accumulator and the Y register in the formula.

```
* SUBROUTINE FOR WAITING 4 MS (FOSC = 500 KHZ)
*
WAIT4MS \begin{tabular}{lll} 
TCY & 13 & \((13+1)=2 \times(6+1)\)
\end{tabular}
```

The maximum delay which is possible with the above subroutine is 547 instructions ( 6.56 ms at $\mathrm{F}_{\mathrm{osc}}=500 \mathrm{kHz}$ ). It is achieved if accumulator and Y register are loaded with 15. If the needed delays exceed this magnitude, the timer of the TSS400(/4) can be used: The timer is read and a number added to the read value. When the timer reaches this computed value, the delay time elapsed. The uncertainity is 1 timer step ( $1 / 16 \mathrm{~s}$ ). If Timer0 is used, the delay steps are seconds instead of $1 / 16$ seconds.

| WAIT | TCY | DL12 | ADDRESS TIMER1 (OR TIMER0) |
| :---: | :---: | :---: | :---: |
|  | SETR |  |  |
| L\$200 | TTA |  | READ STABLE TIMER |
|  | TNEA |  |  |
|  | BRANCH | L $\$ 200$ |  |
|  | ACACC | N | ADD N x $1 / 16$ SECOND |
|  | TAY |  | AND STORE TO Y FOR COMPARISON |
| L\$201 | TTA |  | READ STABLE TIMER AGAIN |
|  | TNEA |  |  |
|  | BRANCH | L\$201 |  |
|  | YNEA |  | COMPARE TIMER WITH |
|  | BRANCH | L\$201 | COMPUTED VALUE |
|  | RETN |  | DELAY TIME ELAPSED |

## APPENDIX A

## Differences of the TSS400/4 compared to the TSS400

The TSS400/4 is the 4 K -version of the TSS400. The architecture of both is nearly the same, only few differences exist due to the ROM and RAMenlargement. These differences are listed below.

## A. 1 ROM Addressing

The ROM of the TSS400/4 has 4096 words of 10 bits each. The ROM is organized into 16 pages of 256 words each ( $16 \cdot 256=4096$ words total).

## A. 2 Program Counter Stepping Order

The 256 words of a page make a different stepping order necessary. The actual stepping order is shown below. The first half of it is identical to the TSS400 stepping order, the second half contains the same order with the MSB set to one.

```
-->
00 01 03 07 0F 1F 3F 7F 7E 7D 7B 77 6F 5F 3E 7C
79 73 67 4F 1E 3D 7A 75 6B 57 2E 5C 38 70 61 43
06 0D 1B 37 6E 5D 3A 74 69 53 26 4C 18 31 62 45
0A 15 2B 56 2C 58 30 60 41 02 05 OB 17 2F 5E 3C
78 71 63 47 0E 1D 3B 76 6D 5B 36 6C 59 32 64 49
12
```



```
46 0C 19 33 66 4D 1A 35 6A 55 2A 54 28 50 20 40
80 81 83 87 8F 9F BF FF FE FD FB F7 EF DF BE FC
F9 F3 E7 CF 9E BD FA F5 EB D7 AE DC B8 F0 E1 C3
86 8D 9B B7 EE DD BA F4 E9 D3 A6 CC 98 B1 E2 C5
8A 95 AB D6 AC D8 B0 E0 C1 82 85 8B 97 AF DE BC
F8 F1 E3 C7 8E 9D BB F6 ED DB B6 EC D9 B2 E4 C9
92 A5 CA 94 A9 D2 A4 C8 90 A1 C2 84 89 93 A7 CE
9C B9 F2 E5 CB 96 AD DA B4 E8 D1 A2 C4 88 91 A3
C6 8C 99 B3 E6 CD 9A B5 EA D5 AA D4 A8 D0 A0 C0
```


## Figure A-1: TSS400/4 PC Stepping Order

## A. 3 RAM Addressing

The RAM of the TSS400/4 consists of 15 banks each containing 16 four-bit words. The legal operands of the LDX instruction are 0 to 15 , where 7 and 15 address the same RAM bank: The DAM.

## A. 4 Opcodes

The BRANCH and CALL instructions have new opcodes due to the larger pages. All other instructions have unchanged opcodes.

| Mnemonic | TSS400 Opcodes | TSS400/4 Opcodes |
| :--- | :---: | :---: |
|  |  |  |
| BRANCH | $>100->17 \mathrm{~F}$ | $>200->2 \mathrm{FF}$ |
| CALL | $>180->1 \mathrm{FF}$ | $>300->3 \mathrm{FF}$ |
| All other Opcodes $>000->0 \mathrm{FF}$ | $>000->0 \mathrm{FF}$ |  |
| Disabled | $\ldots-$ | $>100->1 \mathrm{FF}$ |

## A. 5 MOS Oscillator Frequency

The MOS-oscillator frequency is $1 \mathrm{MHz} \pm 20 \%$. This tighter tolerance eases the "worst case design" of time critical software parts and reduces the current consumption of the measurement part.

## Part IV

## TSS400 STANDARD USER'S GUIDE

## November 1990

## Important Notice

Texas Instruments (TI) reserves the right to make changes in the devices or the device specifications identified in this publication without notice. TI advises its customers to obtain the latest version of device specifications to verify, before placing orders, that the information being relied upon by the customer is current.

In the absence of written agreement to the contrary, TI assumes no liability for TI applications assistance, customer's product design, or infringement of patents or copyrights of third parties by or arising from use of semiconductor devices described herein. Nor does TI warrant or represent that any license, either expressed or implied, is granted under any patent right, copyright, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor devices might be or are used.


#### Abstract

The TSS400 Standard User's Guide describes the application of a preprogrammed TSS400. The user's program is written in an interpreter language which is read and executed by an interpreter contained in the TSS400 ROM. This interpreter language allows nearly the direct conversion of a flowchart to written code. The user's program is contained in an EEPROM connected to the TSS400. The software routines included in the ROM are explained in detail. Examples are used wherever appropriate. The instruction set of the interpreter language is described in depth.


## Table of Contents

Paragraph Title Page
1 Introduction ..... 14
1.1 General ..... 14
1.2 Design Features ..... 14
1.3 Design Steps ..... 15
1.4 Symbols and Conventions ..... 16
1.4.1 List of Abbreviations ..... 16
1.4.2 Symbols and Logic Notations ..... 17
2 Hardware and Operation ..... 19
2.1 General ..... 19
2.2 EEPROM Addressing ..... 20
2.3 Jumps ..... 20
2.4 Subroutines ..... 21
2.5 RAM Usage ..... 21
2.5.1 The FLAC Register ..... 22
2.5.2 The REGB Register ..... 23
2.5.3 The STORAGE Registers ..... 24
2.5.4 The FLAG Registers ..... 25
2.5.5 The Counters ..... 26
2.6 The R Outputs and Digit Latches ..... 27
2.7 Status Logic ..... 29
2.7.1 Zero Bit ..... 29
2.7.2 Positive Bit ..... 29
2.7.3 Negative Bit ..... 30
2.8 The K-Port ..... 30
2.8.1 K8 Wake-up Conditions ..... 31
2.9 The Timers ..... 31
2.10 The Current Saving Modes ..... 33
2.10.1 The Done Mode ..... 34
2.10.2 The Off Mode ..... 35
2.11 The Analog Digital Converter ..... 35
2.11.1 Single and Compensated Measurements ..... 37
2.11.2 Measurement Range and Conversion Formulas ..... 37
2.11.3 Battery Check ..... 38
2.11.4 The Current Source ..... 39
2.12 The LCD Driver ..... 39
2.12.1 Digit Addressing ..... 40
2.12.2 Segment Addressing ..... 41
2.12.3 The Output PLA ..... 42
2.12.4 Special Display Considerations ..... 44
2.13 Initialization and Powerup ..... 48
2.14 Hardware Options ..... 49
2.14.1 Pinning ..... 50
2.14.2 Input Options ..... 50
2.14.3 Timer Options ..... 51
2.14.4 Display Options ..... 51
2.15 Instruction Execution Times ..... 51
2.16 Usage of RAMS ..... 52
3 Interpreter Instruction Set Definitions ..... 53
$3.1 \quad$ Interpreter Language Instruction Map ..... 53
3.2 Effect on Status Bits ..... 56
3.3 Interpreter Instruction Formats ..... 56
3.3.1 Constant Operand ..... 56
3.3.2 EEPROM Address Operand ..... 56
3.3.3 Implicit Operand ..... 57
3.3.4 Hexadecimal Operand ..... 57
3.3.5 Decimal Operand ..... 57
3.3.6 Attached, Floating Number of Operands ..... 57
3.3.7 Attached, Fixed Number of Operands ..... 58
3.3.8 Coding Format ..... 58
3.4 Register to Register Transfer Instructions ..... 60
3.4.1 Move FLAC to Storage Register ..... 60
3.4.2 Move Storage Register to FLAC ..... 60
3.4.3 Move REGB to Storage Register ..... 61
3.4.4 Move Storage Register to REGB ..... 61
3.4.5 Move FLAC to REGB ..... 62
3.4.6 Move REGB to FLAC ..... 62
3.4.7 Exchange REGB and FLAC Registers ..... 63
3.4.8 Move FLAC to EEPROM ..... 63
3.4.9 Move EEPROM to REGB ..... 65
3.5 Arithmetic Instructions ..... 66
3.5 .1 Add REGB to FLAC Decimally, Result to FLAC ..... 66
3.5.2 Subtract REGB from FLAC Decimally, Result to FLAC ..... 66
3.5.3 Multiply FLAC and REGB Decimally, Result to FLAC ..... 67
3.5.4 Divide FLAC by REGB Decimally, Result to FLAC ..... 67
3.5.5 Add REGB to FLAC Hexadecimally, Result to FLAC ..... 68
3.5.6 Subtract REGB from FLAC Hexadecimally, Result to FLAC ..... 69
3.5.7 Hexadecimal to Decimal Conversion ..... 69
3.5.8 Round FLAC N Times ..... 70
3.5.9 $\quad$ Shift Right FLAC N Times ..... 71
3.5.10 Shift Left FLAC N Times ..... 72
3.6 Arithmetic Compare Instructions ..... 72
3.6.1 Compare FLAC and REGB ..... 72
3.6.2 Test Contents of REGB ..... 73
3.7 Bit Manipulation Instructions ..... 74
3.7.1 Set FLAG Bit ..... 74
3.7.2 Reset FLAG Bit ..... 74
3.7.3 Test FLAG Bit ..... 75
3.7.4 Select FLAG Bits Group N ..... 75
3.7.5 Or FLAC and REGB ..... 76
3.7.6 And FALAC and REGB ..... 76
3.8 Constant Transfer Instructions ..... 77
3.8.1 Load FLAC with a Positive Constant ..... 77
3.8.2 Load FLAC with a Negative Constant ..... 78
3.8.3 Load REGB with a Positive Constant ..... 78
3.8.4 Load REGB with a Negative Constant ..... 79
3.8.5 Clear FLAC Register ..... 80
3.8.6 Clear REGB ..... 80
3.9 Input/Output Instructions ..... 81
3.9.1 Set R Output ..... 81
3.9.2 Reset R Output ..... 81
3.9.3 Test Keyboard ..... 82
3.9.4 Actualize K-Input and Timers ..... 84
3.9.5 Read K-Input ..... 85
3.9.6 Output LSD of FLAC to K-Port ..... 85
3.9.7 Output Constant to K-Port ..... 86
$3.10 \quad$ Program Flow Control Instructions ..... 87
3.10.1 Jump Unconditional ..... 87
3.10.2 Jump if Zero, Jump if Equal ..... 87
3.10.3 Jump if not Zero, Jump if not Equal ..... 87
3.10.4 Jump if Positive ..... 88
3.10.5 Jump if Negative ..... 89
3.10.6 Call Subroutine ..... 89
3.10.7 Return from Subroutine ..... 90
3.11 Analog-Digital-Converter Instructions ..... 90
3.11.1 Set Converter Supply Voltage ..... 90
3.11.2 Reset Converter Supply Voltage ..... 91
3.11.3 Measure Addressed A/D Input ..... 91
3.11.4 Adjust Battery Voltage ..... 93
3.11.5 Check Battery Voltage ..... 94
3.11.6 Adjust Comparator Voltage ..... 94
3.11.7 Check Comparator Voltage ..... 95
3.12 Display Instructions ..... 96
3.12.1 Display Digit ..... 96
3.12.2 Clear Display ..... 99
3.12.3 Display FLAC ..... 99
3.13 Miscellaneous Instructions ..... 104
3.13.1 Enter Done Mode ..... 104
3.13.2 Enter Off Mode ..... 104
3.13.3 No Operation ..... 105
$3.14 \quad$ Counter Instructions ..... 105
3.14.1 Decrement Counter N ..... 105
3.14.2 Increment Counter N ..... 106
3.14.3 Decrement Double Counter ..... 107
3.14.4 Increment Double Counter ..... 107
3.14.5 Load Counter N Decimal ..... 108
3.14.6 Move Counter $N$ to REGB ..... 108
3.14.7 Move Combined Counters to REGB ..... 109
3.15 Timer Instructions ..... 109
3.15.1 Load Timer Long ..... 109
3.15.2 Load Timer Short ..... 110
3.15.3 Actualize Timers ..... 112
3.15.4 Stop Long Timer ..... 113
3.15.5 Stop Short Timer ..... 113
3.16 Host Control Instructions ..... 114
4 Subroutine Software ..... 117
4.1 General ..... 117
4.2 Nesting Subroutines ..... 117
4.3 Multiple Entry Points ..... 118
5 Correction of Tolerances by Software ..... 120
5.1 Calibration Variables Stored in RAM ..... 120
5.1.1 Computation with Nominal Values and Correction ..... 120
5.1.2 Computation with Corrected Values only ..... 121
5.2 Calibration Variables Stored in EEPROM ..... 122
6 System Calibration ..... 123
7 Hints, Recommendations and Examples ..... 126
7.1 Local Assembly Labels ..... 126
7.2 Integer Math Package ..... 126
7.3 Keyboard Scan ..... 128
7.4 Clock Routine ..... 130
7.5 Temperature Computation for Sensors ..... 131
7.6 Battery Check ..... 132
7.7 Cold Start, Warm Start ..... 133
7.8 Waiting Routines ..... 134
7.9 Address Modification ..... 135
7.10 Square Root Routine ..... 137
8 Development Tools ..... 139
8.1 The Development Board ..... 139
8.2 Development with the ADT400 ..... 141
8.2.1 Assembling the User's Software ..... 141
8.2.2 Loading the User's Software into the EEPROMS ..... 143
8.2.3 Debugging the User's Software with the ADT400 ..... 144
8.2.4 RAM Map of the TSS400 Standard ..... 146
8.3 Development with the Software Simulator ..... 149
8.3.1 Restrictions of the Software Simulator ..... 149
8.3.2 Assembling the User's Software ..... 150
8.3.3 Debugging the User's Software with the Software Simulator ..... 150
8.3.4 Realtime Debugging of the User's Software ..... 150
8.3.5 Most often Occuring Difficulties ..... 155
9 Controlling of the TSS400 Standard in Slave Mode ..... 157
9.1 Handshaking and Program Control ..... 158
9.2 Starting of the Slave Mode ..... 158
9.3 Data Transfer ..... 160
9.3.1 Data Transfer to the TSS400 Standard ..... 160
9.3.2 Data Transfer to the Host ..... 161
9.4 IDLE Modes for the Slave ..... 162
9.5 Not Executable Instructions ..... 163
APPENDIX A Actual Hardware Definition ..... 164
APPENDIX B Applicable Documents ..... 167
APPENDIX C TSS400 Standard Instructions ..... 167

## List of Figures

| Figure | Title | Paragraph |
| :--- | :--- | ---: |
|  |  |  |
| 1 | Blockdiagram of the TSS400 Standard | 1.4 .2 |
| 2 | Addressing of the EEPROMs | 2.2 |
| 3 | FLAC Register | 2.5 .1 |
| 4 | Storage Registers STOO to STO5 | 2.5 .3 |
| 5 | Flag Register Groups | 2.5 .4 |
| 6 | Analog-Digital-Converter Addressing | 2.6 |
| 7 | Status Logic Bits | 2.7 |
| 8 | Wake-up conditions for external events | 2.10 |
| 9 | Wake-up contents of the internal registers | 2.10 |
| 10 | Operand of the MEASR instruction | 2.11 |
| 11 | Parameter byte of the MEASR instruction | 2.11 .1 |
| 12 | Connection of display and FLAC | 2.12 |
| 13 | Select/Common/Segment Definition | 2.12 .2 |
| 14 | Standard Segment Notation | 2.12 .2 |
| 15 | Characters contained in the OPLA | 2.12 .3 |
| 16 | Character numbers for single segments | 2.12 .4 |
| 17 | Character numbers for a Bar graph display | 2.12 .4 |
| 18 | Digit contents of segment combinations | 2.12 .4 |
| 19 | Character numbers for segment combinations | 2.12 .4 |
| 20 | Initialization contents of the internal registers | 2.13 |
| 21 | Pinning of the TSS400 Standard | 2.14 .1 |
| 22 | Standard Segment Notation Scheme | 2.14 .4 |
| 23 | Instruction map lower part | 3.3 |
| 24 | Instruction map upper part | 3.3 |
| 25 | EEPROM map of the MOVFLPRM values | 3.4 .8 |
| 26 | Flag Bit setting by the CMPFLRB instruction | 3.6 .1 |
| 27 | Status Bit setting by the TSTKEY instruction | 3.9 .3 |
| 28 | Operand byte of the TSTKEY instruction | 3.9 .3 |
| 29 | Parameter byte of the MEASR instruction | 3.11 .3 |
| 30 | Display configuration | 3.12 |
| 31 | Operand byte of the DISPLDGn instruction | 3.12 .1 |

TSS400 Standard User's Guide ..... 11
32 Parameter byte of the DISPLFL instruction ..... 3.12.3
33 Display depending on the DISPLFL parameter ..... 3.12.3
34 Operand byte of the SLV instruction ..... 3.16
35 Register configuration of the Integer Math Package ..... 7.2
36 Schematic of the Development Board ..... 8.1
37 RAM Map of the TSS400 Standard ..... 8.2.4
38 Mode check after initialization ..... 9.1
39 Data transfer to the TSS400 Standard ..... 9.3.1
40 ..... 41
I/O timing of a data transfer to the TSS400 Standard ..... 9.3.1
I/O timing of a data transfer to the Host ..... 9.3.2

## List of Examples

| Example | Title | Paragraph |
| :--- | :--- | ---: |
|  |  |  |
| 1 | Multiplication by Three | 3.4 .5 |
| 2 | Storage of a computed value in the EEPROM | 3.4 .8 |
| 3 | Storing and retrieving of an EEPROM value | 3.4 .9 |
| 4 | FLAC before and after rounding | 3.5 .8 |
| 5 | Adjusting of the FLAC by shifting | 3.5 .9 |
| 6 | Inserting to the FLAC by shifting left | 3.5 .10 |
| 7 | Zero test before division | 3.6 .2 |
| 8 | Loading the FLAC with a positive constant | 3.8 .1 |
| 9 | Loading of REGB with a negative constant | 3.8 .4 |
| 10 | Keyboard test example | 3.9 .3 |
| 11 | Outputting of the FLAC with clocks | 3.9 .6 |
| 12 | Outputting of a constant to the K-Port | 3.9 .7 |
| 13 | Measurement with error checking | 3.11 .3 |
| 14 | Comparing of two analog voltages | 3.11 .7 |
| 15 | Display of the FLAC with additional terms | 3.12 .1 |
| 16 | Display of one term | 3.12 .2 |
| 17 | Display with variables Z, M and H | 3.12 .3 |
| 18 | Display of segment combinations | 3.12 .3 |
| 19 | Usage of a counter for repetitions | 3.14 .1 |
| 20 | Loading of the counters | 3.14 .5 |
| 21 | Loading of the long timer | 3.15 .1 |
| 22 | Loading of both timers | 3.15 .2 |
| 23 | Updating of the timers during active mode | 3.15 .3 |
| 24 | Loading and Stopping of a Timer | 3.15 .5 |
| 25 | Subroutine Nesting Levels | 4.2 |
| 26 | Multiple subroutine entry points | 4.3 |
| 27 | Subroutine calls | 4.3 |
| 28 | Computation with nominal values and correction | 5.1 .1 |
| 29 | Computation with corrected values only | 5.1 .2 |
| 30 | Calibration variables stored in the EEPROM | 5.2 |
| 31 | System calibration routine | 6 |
| 32 | Computation using system calibration variables | 6 |
|  |  |  |

33 Decimal point location after computations ..... 7.2
34 Decimal point location for the division ..... 7.2
35 Keyboard with 4 keys and 4 diodes ..... 7.3
36 24 Hour clock routine ..... 7.4
37 Temperature computation routine ..... 7.5
38 Vddmin setting and Battery Check ..... 7.6
39 Cold Start/Warm Start distinction ..... 7.7
40 Timer usage for waiting purposes ..... 7.8
41 Value storage in EEPROM ..... 7.9
42 Square Root routine ..... 7.10
43 Software breakpoint 1 ..... 8.3.3
44 Software breakpoint 2 ..... 8.3.3
45 Software breakpoint with display ..... 8.3.3
46Software breakpoint with multiple display8.3.3
47
Software breakpoint with wait cycles ..... 8.3.3
48 Deactivation of the Slave by the Done Mode ..... 9.4

## 1 Introduction

### 1.1 General

This section introduces the TSS400 Standard and outlines how an algorithm is developed and implemented to achieve cost effective designs. This introduction includes a definition of terms and conventions. This manual treats the TSS400 Standard as a system of logic and analog blocks controlled by the user.

After the introduction of the hardware a detailed presentation of the interpreter's instruction set will follow. Hints for efficient algorithms and a number of example programs are presented in the last sections, since they require a thorough understanding of the interpreter's instruction set.

The development tools are described in the last chapters.

### 1.2 Design Features

The TSS400 Standard is developed to suit a wide variety of applications where the costs of a ROM mask are not appropriate. Instead proven software routines are stored in the TSS 400 ROM which can be called according to the user's need with an interpreter contained in the ROM, too. The user's program is stored in external EEPROMs which are loaded with interpreter opcodes by the development tool.

## Features

- Minimum component count: System consists of 2 devices only, in a minimum configuration:
- TSS400 with preprogrammed interpreter software
- EEPROM with user's program
- 512 instructions (8 bits wide) in each EEPROM. Up to four EEPROMs are possible (2048 byte maximum). There is also an EEPROM available holding 2048 byte in one package.
- 12 bit A/D converter with 4 selectable inputs (A1 to A4)
- A/D converter range 0.1013 to $0.4946 \cdot \mathrm{SV}_{\mathrm{DD}}$
- Programmable current source from 0.15 to $2.4 \mathrm{~mA} \cdot \mathrm{~V}_{\mathrm{DD}} / \mathrm{V}$ for all $\mathrm{A} / \mathrm{D}$ converter inputs.
- LCD driver with 7 digits using 4 common multiplex.
- 64 preprogrammed characters, contained in a 7 segment output PLA. The decimal point, segment H , is switched independently.
- 576 bits of static RAM
- Three levels of subroutine
- Timekeeping from an on-chip cristal oscillator ( 32768 Hz )
- Done Mode for reduction of power consumption with active timers and RAM. Wake-up is possible by 2 timers (input frequencies 1 Hz and 16 Hz ) or by input changes.
- Off Mode for very low power consumption with active RAM. Wake-up by input changes only.
- Internal MOS oscillator: 500 kHz to 1 MHz
- 6 freely usable push-pull outputs (R1 to R6)
- 4 bit I/O port (K-Port)
- Program control by EEPROM or host computer (Slave Mode)


### 1.3 Design Steps

Several steps are necessary to complete a system consisting of the TSS400 Standard and its peripheral with the necessary performance. A typical and recommended development cycle is shown below:

1. Definition of the tasks to be performed by the TSS400 and its peripheral.
2. Worst case timing consideration for the tasks.
3. Drawing of a complete hardware schematic.
4. Worst case design for all external components.
5. Organization of variables: Storage is possible in six Storage Registers and in EEPROM bytes.
6. Flowcharting of the complete program for determining the instruction coding necessary to fulfil the specification requirements.
7. Coding of the program with an editor.
8. Assembling of the program with the ASM400 assembler.
9. Removing of errors found by the ASM400 assembler.
10. Testing of the program with the ADT400 emulator or the Software Simulator.

### 1.4 Symbols and Conventions

### 1.4.1 List of Abbreviations

ADC Analog Digital Converter
ALU Arithmetic and Logic Unit
CPU Centrai Processing Únit
DLn $\quad$ Digit Latch $n(n=0-15)$
EEPROM Electrically Eraseable Programmable Memory
FLAC Register used for Arithmetic and Results
Kn K-Port $n$ Pin ( $n=1,2,4,8$ )
LCD Liquid Crystal Display
LSB Least Significant Bit
LSD Least Significant Digit
MSB Most Significant Bit
MSD Most Significant Digit
OPLA Output Programmable Logic Array
PC Program Counter (Interpreter)
RAM Random Access Memory (Read/Write)
ROM Read Only Memory
REGB Register for arithmetic Operands
Rn R Output n ( $\mathrm{n}=0-7$ )
W Branch Address of Instruction Field (11 bits)
SRn Subroutine PC Register Level $\mathrm{n}(\mathrm{n}=1-3)$
STOn Storage Register $\mathrm{n}(\mathrm{n}=0-5)$
POS Positive Flag in Status Bits
NEG Negative Flag in Status Bits
ZERO Zero Flag in Status Bits
10En $\quad 10$ raised to $n$-th Power
EMI Electro Magnetic Interference



## 2 Hardware and Operation

### 2.1 General

As shown in Figure 1 up to four EEPROMs maybe connected to the TSS400 Standard. The TSS400 contains an interpreter in its ROM which uses the data storen in the EEPROM(s).
The interpreter reads the next instruction from the EEPROM, interprets the read opcode and executes the function defined by the opcode. If the read opcode needs much time for execution (e.g. multiplication) the supply voltage of the EEPROM is switched off for power saving. The instruction timing consists of the instruction fetch time and the execution time. During initalization, the interpreter's Program Counter PC is reset to location >000. Afterwards the Program Counter counts to the next address in a binary sequence.

The user's program is stored in one or more EEPROMs. It is written in a language ranging between assembler and compiler: The TSS400 Standard interpreter language. The interpreter language is assembled with the ASM400 assembler (see chapter 8 for details). The object created by the ASM400 assembler is transferred by the host computer via utility programs to the EEPROMs.

The EEPROMs are connected to the TSS400 via 4 lines:

1. RO clocks the EEPROM during data transfers
2. R7 controls a PNP transistor which switches the EEPROM supply voltage
3. The I/O Pin transfers the data to and from the EEPROM
4. Common ground line

The 3 first mentioned lines cannot be used by the user's program due to by the interpreter usage.

### 2.2 EEPROM Addressing

The used EEPROM X24C04 handles 512 words each 8 bit which contain the user's program. If more than 512 bytes of program are necessary, the address space can be enlarged up to 2048 bytes by paralleling of EEPROMs. If more than two EEPROMs are necessary, the use of an X24C16 is considerable. It replaces four X24C04 with one package. The hardware address of the 4 EEPROMs is defined by the logic levels of their pins A1 and A2 as follows:

| E[EPROM Pins | A2 | A1 | Address Space |  |  |
| :--- | :---: | :---: | ---: | :--- | :--- |
|  | 0 | 0 | 0 | -511 | $(>0 \rightarrow>1 F F)$ |
|  | 0 | 1 | 512 | -1023 | $(>200 \rightarrow>3 F F)$ |
|  | 1 | 0 | 1024 | -1535 | $(>400 \rightarrow>5 F F)$ |
|  | 1 | 1 | 1536 | -2047 | $(>600 \rightarrow>7 F F)$ |

Figure 2: Adressing of the EEPROMs
The register used to address the EEPROM is the Program Counter PC which is 11 bits wide. This allows the addressing of 2048 bytes without paging.

### 2.3 Jumps

Jumps are unconditional or conditional. An unconditional jump (JMP) is always executed successfully. A conditional jump (Jcond) depends on certain Status Bits. A successfully executed jump is defined to be the case when the jump transfers control to an instruction address out of the normal sequence. This is done by transferring the 11 bit address W contained in the opcode of the jump command into the Program Counter PC. An unsuccessful jump does not affect the normal sequence of the Program Counter.

## Jump commands:

JMP Jump unconditionally
JZ/JEQ Jump if the ZERO Bit is set

JNZ/JNE Jump if the ZERO Bit is reset
JP Jump if the POS Bit is set
JN Jump if the NEG Bit is set

### 2.4 Subroutines

Three levels of subroutine nesting are allowed. A 4th level CALL does not work properly. A subroutine call initiates the following activities:

- The subroutine stack is lowered one level and the return address is pushed onto the stack (SR1). (The return address is the address after the CALL instruction and is called normally PC + 2).
- The address field W of the CALL instruction is written into the Program Counter PC.

When a return instruction RETN occurs in a subroutine:

- The Subroutine PC Register SR1 (which holds the address after the last CALL instruction) is written to the PC.
- The stack is raised one level.

Warning: If the RETN instruction is used outside of a subroutine the last Subroutine Stack item is transferred to the PC. The program will not work properly.

Note: When considering subroutine stack levels it should be remembered that the instructions MOVPRMRB and MOVFLPRM also use one subroutine stack level (see later).

### 2.5 RAM Usage

There are 9 RAM banks, each containing 16 four-bit words (nibbles) in the RAM's 576 bit matrix. Eight of these RAM banks are normal RAM banks, one of them is a special Direct Access Memory (DAM). A complete RAM map is shown in chapter 8.

The TSS400 Standard RAM is organized in several registers, which are described in the following if they are visible to the user. Two RAM banks are used for supervising purposes, subroutine stack, PC and so on.

### 2.5.1 The FLAC Register

The FLAC register (the name is taken from the used Integer Math Package) is the main working register. It consists of eight nibbles containing the number itself and a ninth nibble which holds the sign and 2 flags used by the arithmetic routines. For positive numbers the sign bit is zero, for negative numbers the sign bit is one.

| 10E7 10E6 10E5 10E4 10E3 10E2 10E1 10EO  <br> LSD       SIGN  |
| :--- |

Figure 3: FLAC Register
The FLAC is used for several purposes:

- stores the result of all arithmetic and logic operations
- holds the 1st operand for arithmetic and logic operations
- contains the result of a hexadecimal to decimal conversion
- holds the information for transfers to the EEPROM
- holds the information to be displayed in the LCD


## Instructions which affect or use the FLAC are:

LDFLPOS load FLAC with a positive number
LDFLNEG load FLAC with a negative number
MOVFLSTO move FLAC to Storage Register
MOVSTOFL move Storage Register to FLAC
MOVFLPR move FLAC to EEPROM
MOVFLRB move FLAC to REGB
MOVRBFL move REGB to FLAC
CLRFL clear FLAC

EXCHRBFL exchange FLAC and REGB

HEXDEC
ADD
SUB
MPY
DIV
ADDH
SUBH
AND
OR
CMPFLRB
ROUNDn
SHIFTRn
SHIFTLn
CHKBATT
CHKCOMP
ADJBATT
ADJCOMP DISPLFL KIN
convert hexadecimal number to decimal add REGB to FLAC
subtract REGB from FLAC multiply REGB and FLAC divide REGB into FLAC add REGB to FLAC hexadecimally subtract REGB from FLAC hexadecimally logically AND FLAC and REGB
logically OR FLAC and REGB
compare FLAC and REGB
round FLAC $n$ times
shift FLAC right $n$ times
shift FLAC left $n$ times
battery check with ADC value in FLAC analog input compared with ADC value in FLAC battery measurement with the internal reference voltage ADC value of a single measurement to FLAC display the FLAC as defined in the following bytes K-Port to FLAC's LSD and to Group 1 Flags

Note: The FLAC will never contain -0 after an arithmetic operation. The status setting routine will always place +0 into the FLAC if all digits are equal to zero.

### 2.5.2 The REGB Register

The REGB register (the name is taken from the used Integer Math Package) is the second working register. It consists of eight nibbles containing the number itself and a ninth nibble which holds the sign. The sign bit is zero for positive numbers and one for negative numbers. See Figure 3 for the structure of the REGB, which is the same one as for the FLAC.

The REGB is used for:

- holding the 2nd operand for arithmetic and logic operations
- holding the constants read from the EEPROM
- holding the contents after transfers of the counters

Instructions which affect or use the REGB are:
LDRBPOS load REGB with a positive number
LDRBNEG load REGB with a negative number
MOVRBSTO MOVSTORB
MOVFLRB MOVRBFL
MOVCNTn MOVPRMRB
SLRPB
EXCHRBFL HEXDEC CMPFLRB TSTRB
move REGB to Storage Register
move Storage Register to REGB
move FLAC to REGB
move REGB to FLAC
move Counter $n$ to REGB
move EEPROM to REGB clear REGB
exchange FLAC and REGB
REGB is destroyed by the conversion
compare FLAC with REGB
test REGB
all arithmetic and logic instructions

### 2.5.3 The Storage Registers

For storing information 6 Storage Registers may beused. They are configured exactly like the FLAC with 8 digits and a sign nibble. See Figure 4 for details. Storage Registers 1 to 5 hold their information until they overwritten by the MOVFLSTO or MOVRBSTO instructions.

The Storage registers are organized as follows


Figure 4: Storage Registers STO0 to STO5

Storage Register 0 (STO0) is restricted in its use because it is used by the multiplication and division, too. This means it can hold information only until
the next MPY, DIV or HEXDEC instruction occurs. After a multiplication it is set to 0 , after a division it contains the remainder of the operation. This remainder may be used in conversions e.g. minutes to hours. See the Clock Routine example in chapter 7.

## Instructions which use the Storage Registers:

MOVFLSTO move FLAC to Storage Register
MOVSTOFL move Storage Register to FLAC
MOVSTORB move Storage Register to REGB
MOVRBSTO move REGB to Storage Register

### 2.5.4 The Flag Registers

For common purposes two flag registers exist which contain 16 flags each. They are named Group 1 and Group 2. The selection is made by the instructions SELGRP1 and SELGRP2. The group in use is addressed until the other group is selected. These flags may be set, reset or tested. The usage of the 32 flags is shown below:

| Group 1 | Flag | 0 | Arbitrary use |
| :--- | :--- | :--- | :--- |
|  | Flags | 1 to 7 | Segment H info for digits 1 to 7 |
|  | Flags | 8 to 9 | Arbitrary use |
|  | Flag | 10 | LT: Long Timer reached zero if set |
|  | Flag | 11 | ST: Short Timer reached zero if set |
|  | Flags | 12 to 15 | K1 to K8 buffer |
| Group 2 | Flags | 0 to 15 | Arbitrary use |

Group 1

| H3 | H7 | ST | K8 |
| :---: | :---: | :---: | :---: |
| H2 | H6 | LT | K4 |
| H1 | H5 | 9 | K2 |
| 0 | H 4 | 8 | K1 |

Figure 5: Flag Register Groups

[^9]Instructions which affect or use the flags are:

| SBIT | set the addressed flag to one <br> RBIT |
| :--- | :--- |
| reset the addressed flag to zero |  |
| TBIT | test the addressed flag |
| KIN | read information from K-Port to Group 1 Flags 12-15 <br> KINTIM |
| ead information from K-Port to Group 1 Flags 12-15 |  |

The Flags 1 to 7 in Group 1 control the H -segments of the display. If a $\mathrm{H}-$ flag is set, the according H -segment (decimal point) will be active. If H -flag is reset, the according H -segment will be off, except a display instruction switched it on by setting the H -bit contained in the according operand byte.
The Flags 10 and 11 in Group 1 are set by the timers when they reached zero. Resetting is to be done by the user's software.

The Flags 12 to 15 in Group 1 contain the K-Port information read in by the instructions KIN and KINTIM.

### 2.5.5 The Counters

Two decimal counters, Counter 1 and Counter 2, which can be loaded with constants ranging from 0 to 99 are included. They may be connected together forming a counter ranging up to 9999. Counter 1 is the least significant part of this combined counter. After the incrementing or decrementing of the counters the ZERO Bit is set or reset according to the result.

For computing or comparing purposes the counters may be transferred to the LSDs of the REGB. This may be done for the single or the combined counters. Decimal counting is used to ease computations with the counter contents after such transfers.

## Instructions which affect or use the counters:

LDCNT1 load Counter 1 with the constant in the byte following
LDCNT2 load Counter 2 with the constant in the byte following
INCCNT1 increment Counter 1
INCCNT2 increment Counter 2
DECCNT1 decrement Counter 1
DECCNT2 decrement Counter 2
INCLBL increment the combined counters
DECDBL decrement the combined counters
MOVCNT1 move Counter 1 to REGB
MOVCNT2 move Counter 2 to REGB
MOVDBL move the combined counters to REGB

### 2.6 The R Outputs and Digit Latches

The TSS400 contains of one-bit latches which can be set and reset independently: The Digit Latches DLn.

Two groups of Digit Latches can be distinguished:

- R outputs: The latches addressed from one to six are connected to external outputs named R1 to R6. All of them are equal in function. They can be used for several purposes:
- Scanning of a keyboard, switches or programming diodes. The TSTKEY instruction uses R1 to R4 for this purpose.
- Controlling of relays, lamps, LEDs etc. via buffers.
- Switching of gates, multiplexers etc. directly.

Note: The R-outputs R0 and R7 cannot be addressed due to their usage by the control software. R0 steers the clock and R7 switches the supply voltage of the EEPROM. The assembler indicates an error message if one of these outputs is addressed.

- Digit Latches without external outputs: These latches are addressed by the operands eight to thirteen. Each Digit Latch DLn has a unique function as described below:
- DL8: Controls the direction of the K-Port:

DL8 $=0$ : $\quad$ The K-Port is an input port.
DL8 $=1$ : $\quad$ The K-Port is an output port.

- DL9 - DL11: Control of the analog multiplexer of the ADC:

| DL11 | DL10 | DL9 | Function |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | A1 to comparator |
| 0 | 1 | 0 | A2 to comparator |
| 1 | 0 | 0 | A3 to comparator |
| 1 | 1 | 0 | A4 to comparator |
| x | x | 1 | Battery check |

Figure 6: Analog-Digital-Converter Addressing
Note: The Digit Latches DL9, DL10 and DL11 are controlled by the ADC instructions too. It is normally not necessary to change them by the user's software.

- DL12: Controls which timer register is connected to the ALU for the timer instructions and functions:
DL12 $=0: 1 \mathrm{~Hz}$ input
DL12 = 1: 16 Hz input
- DL13: Controls the constant current source of the ADC:

DL13 = 0 : Constant current source is off.
$\mathrm{DL13}=1$ : Constant current source is on if $\mathrm{SV}_{\mathrm{DD}}$ is on.

## Instructions which affect the Digit Latches:

SETR set the addressed Digit Latch to one
RSTR reset the addressed Digit Latch to zero
TSTKEY the addressed R output is used for keyboard scanning
MEASR the ADC input addressing affects DL9, DL10, DL11

Initialization resets all Digit Latches to zero. The contents of the Digit Latches are retained during the Done Mode and the Off Mode as long as the supply voltage is maintained.

### 2.7 Status Logic

The status logic consists of 3 bits which are modified after the execution of several instructions. Within each instruction description the way the Status Bits are affected is explained. The Status Bits are checked by conditional jumps which are executed or not depending on the state of the tested Status Bit.

Note: Not every instruction influences the Status Bits. If an instruction does not affect the Status Bits, the status of the last instruction influencing the Status Bits is stored.

| POS | NEG | ZERO |
| :--- | :--- | :--- |

Figure 7: Status Logic Bits

### 2.7.1 Zero Bit

The bit ZERO is set to one if the result of the last instruction is zero. If the result is not zero the bit is cleared. The ZERO bit also indicates equality after comparisons in case it is set.

### 2.7.2 Positive Bit

The positive bit POS is set after arithmetic instructions if the result of an operation has a positive sign. If the result is negative the POS bit is reset. Other instructions will set the positive bit POS if no error occured. The cleared POS bit can be used as an error indication.

### 2.7.3 Negative Bit

The negative bit NEG is set after arithmetic instructions if the result of an operation has a negative sign. If the result is positive the NEG bit is reset. Other instructions will set the negative bit NEG if an error occured. The cleared NEG bit can be used as a "No Error" indication.

### 2.8 The K-Port

The K-Port is a four-bit I/O port. It's direction is controlled by DL8. The data to be output is stored in the four-bit K-Port Latch.
DL8 $=0$ : K-Port is switched to input direction
DL8 = 1: K-Port is switched to output direction. The contents of the K-Port Latch appears on the K-Port.

Because initialization resets DL8 the K-Port is switched to the input direction when initialization occurs.

## The following instructions affect or use the K-Port:

| TSTKEY | read the key connected to the addressed R-output |
| :--- | :--- |
| FLKOUT | output the LSD of the FLAC to the K-Port |
| KOUT | output a constant to the K-Port |
| KIN | read information from the K-Port |
| KINTIM | read information from the K-Port and update the timers |

If DL8 is set the K-Port Latch is output to the K-Port. K8 is the MSB, K1 is the LSB. The contents of the K-Port Latch is not affected if DL8 is switched to input direction.
The K-Port is read via Schmitt-triggers into the ALU. Depending on the state of DL8, the input pins or the contents of the K-Port Latch is read in. The K-Port has no pull-down resistors.
The K-Port will wake-up the TSS400 from Done Mode and Off Mode under certain circumstances. See Figure 8 for the conditions for wake-up at the K-Port.

### 2.8.1 K8 wake-up Conditions

K1, K2 and K4 wake up the CPU only when changing from LO to HI. K8 differs from the other K-pins in its wake-up conditions. The CPU is woken up on every change of the K8-input if all other K-inputs are held LO. The interpreter checks the state of the K8 input each time Done Mode or the Off Mode is entered. It also prepares the wake-up logic to wake up in case the K8 input changes.

This feature is for applications which handle relatively high input frequencies. See Figure 8 for details.

### 2.9 The Timers

The TSS400 has an eight bit hardware timer register which is fed by a frequency derived from the cristal oscillator after dividing by 2048 ( 16 Hz from 32768 Hz ). The timer register is used for updating the interpreter's two software timers: the Long Timer and the Short Timer.

## Instruction which affect the Digit Latches:

SETR set the addressed Digit Latch to one
The cristal oscillator circuitry is intended for applications which need an accurate time base. The timer description is always related to an input frequency of 32768 Hz .

Two timers can be used:

- the Long Timer which counts up to 256 seconds
- the Short Timer which counts up to $16(256 / 16)$ seconds

Note: It is the user's responsibility to set the Digit Latch DL12 to one if the Short Timer is used. If the Long Timer is used, only the state of DL12 is not of concern. The current consumption of the system is higher if DL12 is set.

The timers may be loaded with values up to 255 and are counted down with 1 Hz (Long Timer) resp. 16 Hz (Short Timer). When zero is reached or an underflow occurrs, the according flag in the Flag Group 1 is set to one and a wake-up occurs if Done Mode is active:

- Flag 10 (LT) is set when the Long Timer reaches zero
- Flag 11 (ST) is set when the Short Timer reaches zero

The two flags LT and ST are only set by the interpreter, never reset. Resetting of the flags must be done by the user's program with the instructions: LDTIML, LDTIMS, STPTIML, STPTIMS or RBIT. As long as one of the two flags is set, the program will leave the Done Mode immediately.

A timer which reached zero or run under zero is updated automatically by adding the last loaded value, which is stored in the Timer Buffer, to the actual contents of the timer. This assures stable timing as long as a underflow of the timer does not occur twice in a sequence. Two Timer Buffers exist:

- The Long Timer Buffer which stores the timer values loaded by the LDTIML instruction.
- The Short Timer Buffer which stores the values loaded by the LDTIMS instruction.

The Timer Buffers hold the loaded values until they overwritten by a new LDTIMx instruction. The loading of a Timer Buffer starts the according timer, which operates until a STPTIMx instruction is executed.

During Active Mode the timers have to be updated periodically with the instructions ACTTIM or KINTIM. This is done in time intervals ti. The conditions for ti are:
ti < loaded time by LDTIMS or LDTIML
and $\quad \mathrm{ti}=<15 / 16 \mathrm{~s}$ for the Short Timer
$\mathrm{ti}=<15 \mathrm{~s}$ for the Long Timer
If a timer is stopped by a STPTIMx instruction the ACTTIM and KINTIM instructions do not affect it.

The timers may be used for several purposes:

- time base for software timers
- time base for software clocks
- measurement of time intervals
- keyboard debounce
- wait routines


## The following instructions handle timer information:

LDTIML load the Long Timer
LDTIMS load the Short Timer
KINTIM actualize the timers and the K-Port during Active Mode ACTTIM actualize the timers during the Active Mode
STPTIML stop the Long Timer
STPTIMS stop the Short Timer

### 2.10 The Current Saving Modes

It is not necessary for the TSS400 to stay on at all the time. The processor can be programmed to be active only if needed. This happens for updating the timekeeping or for performing software functions. The big advantage is the vast amount of current saved by using this feature. Two different modes of current saving are possible: the Done Mode and the Off Mode. The following part will describe the common elements of both modes:
Wake-up from initialization: see Figure 20 for conditions
Wake-up from K-Port: see Figure 8. Only if the conditions described under "before wake-up" are met, the conditions described under "wake-up condition" will wakeup the CPU from Done Mode or Off Mode.
For example if $\mathrm{K} 8=0$ : Only if $\mathrm{K} 1, \mathrm{~K} 2$ and K 4 are also low, then the LO-HI change of any inputs will wake-up the TSS400.

| K8 |  | K4 |  | K2 |  | K1 | Comment |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 |  | 0 |  | 0 |  | 0 | before wake-up |
| 1 | .OR. | 1 | .OR. | 1 | .OR. | 1 | wake-up condition |
| 1 |  | 0 |  | 0 |  | 0 | before wake-up |
| 0 | .OR. | 1 | .OR. | 1 | .OR. | 1 | wake-up condition |

Figure 8: Wake-up Conditions for external Events

## The TSS400 Standard Registers wake up with the following contents:

| Register | Done Mode | Off Mode |
| :--- | :--- | :--- |
| Program Counter PC | last PC +1 | last PC +1 |
| Status Bits POS NEG | unchanged | unchanged |
| ZERO |  |  |
| RAM Contents | unchanged | unchanged |
| Digit Latches DLn | unchanged | unchanged |
| K-Port Latch Contents | unchanged | unchanged |
| Timers | actualized | undefined |
| ADC voltage SV | sD | switched off |
| switched off |  |  |
| LCD segment latches | unchanged | unchanged |
| Subroutine Stack | unchanged | unchanged |

Figure 9: Wake-up Contents of the internal Registers
The wake-up address is always the next instruction following the DONE or OFF instruction (DONE or OFF work similar to an "IDLE" instruction). The unchanged Subroutine Stack allows a DONE or OFF instructions inside subroutines.

### 2.10.1 The Done Mode

DuringDone Mode the CPU is switched off completely. Only the timers, the RAM, the LCD driver, the Digit Latches and certain other registers are
active. See Figure 9 for more information concerning the data retention during Done Mode. Other registers do not maintain information. Wake-up from this mode the timer, the K-Port or by linitiated by initialization.

Wake-up from timers: if the Long Timer or the Short Timer reaches zero the TSS400 is woken up. The wake-up from the timers occurs always, independent of the state of the K-Ports. The updating of the 2 timers is made without EEPROM activation. Only in the case zero is reached the EEPROM is switched on.

The Done Mode is entered by executing the DONE instruction. The ADC voltage $S V_{D D}$ and the EEPROM supply voltage are switched when Done Mode is entered.

### 2.10.2 The Off Mode

During Off Mode the CPU is switched off completely. Only the RAM, the Digit Latches and certain other registers are active. See Figure 9 for more information concerning the data retention during Off Mode. Wake-up from Off Mode can be done by initialization or the K-Port only. See Figure 8 for wake-up conditions.

The current consumption is further reduced compared to the Done Mode.
The Off Mode is entered by executiing the instruction OFF. The ADC voltage SV $_{\text {DD }}$ and the EEPROM supply voltage are switched off before OFF Mode is entered.

### 2.11 The Analog Digital Converter

The TSS400 contains an Analog Digital Converter (ADC) with a resolution of 12 bits. Four analog inputs are useable which are named A1 to A4. The input selection is made by the operand of the instruction MEASR:

| MEASR | 0 | CONNECT A1 TO THE ADC |
| :--- | :--- | :--- |
| MEASR | 1 | CONNECT A2 TO THE ADC |
| MEASR | 2 | CONNECT A3 TO THE ADC |
| MEASR | 3 | CONNECT A4 TO THE ADC |

Figure 10: Operand of the MEASR Instruction
The interpreter switches the internalDigit Latches DL9, DL10 and DL11 according to the operand of the NEASR insiruction (see Figure 6).
The ADC does not measure absolute voltages but the ratio of the input voltage to the supply voltage. Hereby the measurement of resistive sensors is independent of the supply voltage. Absolute measurements are possible if $\mathrm{SV}_{\mathrm{DD}}$ is held constant, which means a stable $\mathrm{V}_{\mathrm{DD}}$ during a conversion and very small loading of $S V_{D D}$.

The following instructions control the $A / D$ converter:

| SVDDON | Switches $S_{\text {DD }}$ of the ADC on |
| :--- | :--- |
| SVDDOFF | Switches $S V_{D D}$ of the ADC off |
| MEASR | Measures the addressed analog input |

The instructions SVDDON and SVDDOFF are included only for special cases. Instructions using the ADC switch the SV DD $^{\text {on }}$ and off automatically.

## The following instructions use the A/D converter:

CHKBATT battery check with the control value in the FLAC
CHKCOMP
ADJBATT
ADJCOMP analog input value compared with the value in the FLAC battery measurement with the internal reference voltage transfers ADC value of a single measurement to the FLAC

### 2.11.1 Single and Compensated Measurements

Two different ADC measurements are possible:

- Single measurementsmade with the noninverted comparator inputs only. The offset error of the comparator is not compensated.
- Compensated measurements made by adding up the results of two measurements. One with noninverted comparator inputs and one with inverted inputs. The comparator's offset error is fully compensated this way.

Which kind of measurement is to be used, is defined in the byte following the MEASR instruction. This byte also defines how many single or compensated measurements have to be made:


S: 0: Compensated measurements
1: Single measurements
$\mathrm{N}: \quad \mathrm{N}+1$ single or compensated measurements

Figure 11: Parameter Byte of the MEASR Instruction

### 2.11.2 Measurement Range and Conversion Formulas

The chosen range is the same for all inputs A1 to A4. The nominal properties of the ADC range are listed below (TSS400 User's Guide Revision 3.1):
N . A/D conversion result for a single measurement
$V \min \quad V i n / S V_{D D}$ for $N=1$
Vmax $\quad V i n / S V_{\text {DD }}$ for $\mathrm{N}=4094$ ( $>$ FFF - 1)
Resolution delta in $\mu \mathrm{V} / \mathrm{SV}_{\mathrm{DD}}$ for 1 bit difference of result

| ADC RANGE | $\mathrm{V}_{\min }$ | $\mathrm{V}_{\max }$ | Resolution |
| :--- | :--- | :--- | :--- |
| LARGE | 0.101309 | 0.494607 | 96.1 |

The nominal conversion equations for single measurements are:
$\begin{array}{ll}\mathrm{Vin} / \mathrm{SV}_{\text {DD }} & =0.101213203+0.000096090233 \cdot \mathrm{~N} \\ \mathrm{~N} & =10406.88496 \cdot \mathrm{Vin} / \mathrm{SV}_{\mathrm{DD}}-1053.314159\end{array}$
If more than one measurement result is added up, the above mentioned conversion equations have to be modified as follows:
$\mathrm{Vin} / \mathrm{SV}_{\mathrm{DD}}=\mathrm{A}+\mathrm{B} \cdot \mathrm{N} \quad$ equation for a single measurement
$\mathrm{Vin} / S V_{D D}=A+(B \cdot N) / M$ equation for $M$ measurements added $N=E \cdot \operatorname{Vin} / S V_{D D}-F \quad$ equation for a single measurement $N=\left(E \cdot V i n / S V_{D D}-F\right) \cdot M$ equation for $M$ measurements added

If the input voltage is below the lower limit Vmin of the ADC the value $>000$ is returned. If the input voltage is above the upper limit Vmax of the ADC the value $>$ FFF is returned from the ADC. The NEG bit is set in both cases.

Note: The useable range of the Analog Digital Converter starts at values greater than 1 and ends at values less than >FFE due to the offset of the comparator. The useable range depends on the supply voltage. See the TSS400 User's Guide for actual values.

### 2.11.3 Battery Check

When DL9 is set, the analog inputs A1 to A4 are switched off from the ADC and the battery check connection is made: An internal reference voltage is connected to the ADC input and can be measured. Due to the ratiometric measurement principle of the ADC, the measured digital value is an indication of the supply voltage of the TSS400. The measured value is inversely proportional to the supply voltage $\mathrm{V}_{\mathrm{DD}}$. To get the reference for later battery tests a measurement is made with $\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{DD}} \mathrm{min}$. The result is stored in the FLAC and can be transferred to a Storage Register or to the EEPROM. For later checks this value is transferred to the FLAC and compared to the internal reference voltage. The Status Bits POS or NEG are set according to the result.

The battery check feature is made by the following instructions:
ADJBATT measure the internal reference voltage, result to FLAC CHKBATT compare the internal reference voltage to the FLAC.

### 2.11.4 The Current Source

A switchable current source is available for supplying special sensors.
DL13 switches the current source which is simply programmable by an external resistor:

- DL13 = 0 : current source is off
- DL13 = 1 : current source is on if $S V_{D D}$ is on

When switched on, the current source feeds the constant current out of the addressed (DL10, DL11) analog input An. The voltage generated at the external sensor is measured with the same analog input An.

The current I programmed by the external resistor Rext, which is connected between $\mathrm{SV}_{\mathrm{DD}}$ and the input Ri , is given by the following equation:

$$
I=V_{\text {rext }} / R e x t
$$

$\mathrm{V}_{\text {rext }}$ is approximatively $0.24 \cdot \mathrm{SV}_{\mathrm{DD}}$.
The current range for each ADC input is as follows:

$$
0.15 \text { to } 2.4 \mathrm{~mA} \cdot \mathrm{SV}_{\mathrm{DD}} / \mathrm{V}
$$

This current range is sufficient to drive PT100 sensors too (Platinum temperature sensors with a nominal resistance of 100 Ohms).

### 2.12 The LCD Driver

The TSS400 contains complex LCD driver circuitry which is defined for the TSS400 Standard in a way to get best results for a wide range of applications. From a software point of view the LCD driver looks very simple:

[^10]- No timing problems exist with multiplexing for getting a quiet, stable display. The LCD driver hardware outputs the loaded display information automatically, without any software burden, during Active Mode and Done Mode.
- The software has to decide which segment information has to be displayed at which digit only.


## Instructions controlling the display:

DISPLCLR clear the whole display (blanks into all digits)
DISPI DGn load digit $n$ with the following byte's info DISPLFL load the display with the following info
The display used by the TSS400 Standard is configured like shown below. The according FLAC nibbles are shown too:


Figure 12: Connection of Display and FLAC

### 2.12.1 Digit Addressing

Normaly the contents of the FLAC is output to the display. The relations are as follows:

FLAC 10E0 $\rightarrow$ S13 + S14 Digit 7 LSD
FLAC 10E1 $\rightarrow$ S11 + S12 Digit 6
FLAC 10E2 $\rightarrow$ S9 + S10 Digit 5
FLAC 10E3 $\rightarrow$ S7 + S8 Digit 4

```
FLAC 10E4 }->\mathrm{ S5 + S6 Digit 3
FLAC 10E5 }->\mathrm{ S3 + S4 Digit 2
FLAC 10E6 }->\mathrm{ S1 + S2 Digit 1 MSD
```

The FLAC's MSD (10E7) cannot be displayed normally due to the 7 digit configuration of the display driver. If it is necessary to display the MSD too, a right shift with decimal point correction needs to be done.

### 2.12.2 Segement Addressing

The OPLA terms definition is based on the following hardware configuration:

| SELECT LINES |  |  |  |  |  |  |  | COMMON |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| S1 | S3 | S5 | S7 | S9 | S11 | S13 | C | F | H |  |  |
| S2 | S4 | S6 | S8 | S10 | S12 | S14 | A | B | D |  |  |
| S | G |  |  |  |  |  |  |  |  |  |  |

Caution: The shown Common/Select definition cannot be modified. The used display must confirm to it.

Figure 13: Common/Segment Definition

This means for instance odd Select Lines and Common 4 address the segment $E$. The assumed segment notation follows:


Figure 14: Standard Segment Notation

The chosen Common/Select configuration is fail safe. This means no valid numbers or characters are displayed in case of a segment or common failure. Instead senseless segment combinations are displayed.

### 2.12.3 The Output PLA

The TSS400 LCD driver contains a gate level Output PLA (OPLA) with $64 \cdot 7$ bits. The 7 bits represent the segment information A to G for 64 predefined combinations (the segment H info is independent from this OPLA and is given with the dispiay instructions).
The addressing of these 64 segment combinations is made by the display instructions. See there for details. The character number in the following OPLA list is the number to be used with the instructions DISPLFL and DISPLDGn.

The OPLA block number is used if combinations of single segments are to be output by FLAC digits. The OPLA block number consists of two MSBs of the character number.

| OPLA Block | Character Number | Segments | Character |
| :---: | :---: | :---: | :---: |
| 0 | 0 | ABCDEF | 0 |
| 0 | 1 | B C | 1 |
| 0 | 2 | ABDEG | 2 |
| 0 | 3 | ABCDG | 3 |
| 0 | 4 | BCFG | 4 |
| 0 | 5 | ACDFG | 5 |
| 0 | 6 | ACDEFG | 6 |
| 0 | 7 | ABC | 7 |
| 0 | 8 | ABCDEFG | 8 |
| 0 | 9 | ABCDFG | 9 |
| 0 | 10 | ABCEFG | A |
| 0 | 11 | CDEFG | b |
| 0 | 12 | ADEF | C or [ |
| 0 | 13 | BCDEG | d |
| 0 | 14 | ADEFG | E |


| OPLA Block | Character Number | Segments | Character |
| :---: | :---: | :---: | :---: |
| 0 | 15 | AEFG | F |
| 1 | 16 | None | Blank |
| 1 | 17 | BCD | $J$ |
| 1 | 18 | DEF | L |
| 1 | 19 | ABEFG | P |
| 1 | 20 | BCDEF | U |
| 1 | 21 | DEG | c |
| 1 | 22 | CEFG | h |
| 1 | 23 | DE | 1 |
| 1 | 24 | CEG | n |
| 1 | 25 | CDEG | - |
| 1 | 26 | E G | r |
| 1 | 27 | DEFG | t |
| 1 | 28 | CDE | $v$ |
| 1 | 29 | BCDFG | Y |
| 1 | 30 | BCEFG | H |
| 1 | 31 | BCG | -1 |
| 2 | 32 | None | Blank |
| 2 | 33 | A |  |
| 2 | 34 | F |  |
| 2 | 35 | AF |  |
| 2 | 36 | B |  |
| 2 | 37 | A B |  |
| 2 | 38 | B F |  |
| 2 | 39 | A B F |  |
| 2 | 40 | G | Minus Sign |
| 2 | 41 | A G |  |
| 2 | 42 | F G |  |
| 2 | 43 | AFG |  |
| 2 | 44 | B G |  |
| 2 | 45 | ABG |  |
| 2 | 46 | B F G |  |


| OPLA Block | Character Number | Segments | Character |
| :---: | :---: | :---: | :---: |
| 2 | 47 | ABFG | Degree |
| 3 | 48 | E |  |
| 3 | 49 | AE |  |
| 3 | 50 | EF |  |
| 3 | 51 | AEF |  |
| 3 | 52 | BE |  |
| 3 | 53 | ABE |  |
| 3 | 54 | BEF |  |
| 3 | 55 | ABEF |  |
| 3 | 56 | E G |  |
| 3 | 57 | A EG |  |
| 3 | 58 | EFG |  |
| 3 | 59 | AEFG |  |
| 3 | 60 | C |  |
| 3 | 61 | D |  |
| 3 | 62 | ABCD | ] |
| 3 | 63 | ABCDE | J |

Figure 15: Characters contained in the OPLA

### 2.12.4 Special Display Considerations

If a display is needed which differs from the normal scheme (seven segments + one independent segment $H$ ) the characters contained in the OPLA have to be considered. Three additional possibilities exist beside the display of numbers with or without decimal point:

- single segment display
- bar graph display
- combinations of up to six segments


## Single Segment Display:

For each single segment A to H a character number exists:

| Character Number | Segments |
| :---: | :---: |
| 33 | A |
| 36 | B |
| 60 | C |
| 61 | D |
| 48 | E |
| 34 | F |
| 40 | G |
| $16+\mathrm{H}$ | H |

Figure 16: Character Numbers for single Segments

## Bar Graph Display:

A bar graph may be built with the complete segments $A$ to $H$. The character numbers for each graph are shown below:

| Character Number | Segments |
| :---: | :--- |
| 33 | $A$ |
| 37 | $A B$ |
| 7 | $A B C$ |
| 62 | $A B C D$ |
| 63 | $A B C D E$ |
| 0 | ABCDEF |
| 8 | ABCDEFG |
| $8+\mathrm{H}$ | ABCDEFGH |

Figure 17: Character Numbers for a Bar Graph Display

## Combination of up to six Segments:

If a digit is used for the display of independent segments (signs, modes e.g.) the segments A F B G E and H may be used. The segments C and D may not be connected to this digit if all possible 64 terms are used. The combinations are structured starting at character number 32 up to 59 . This means, the combinations may be output with a number in a FLAC digit with the correct OPLA block defined in the instructions parameter. The last 4 combinations have randomly defined character numbers and have to be output explicitly.

The six segments correspond to the following digit bits and OPLA blocks:

| OPLA Block | Bit | Segments | Valence |
| :---: | :---: | :---: | :--- |
| 2 | 0 | A | LSB |
| 2 | 1 | F | LSB +1 |
| 2 | 2 | B | LSB +2 |
| 2 | 3 | G | MSB -1 |
| 3 | - | E | MSB |
| - | - | H | MSB +1 |

Figure 18: Digit Contents of Segment Combinations

If a combination of segments AFB and G is needed, the appropriate bits have to be set in the addressed FLAC digit. The used OPLA block is 2 in this case. If segment $E$ is needed too with segments AFB and $G$, the same bits in the addressed FLAC digit are set, but the OPLA block 3 is used. The segment H is possible for each combination by setting the H bit in the instruction's parameter. See the description of the instructions DISPLDGn and DISPLFL for details.


Figure 19: Character Numbers for Segment Combinations

If for example the combination F G (character number 42) is to be output, the addressed FLAC digit has to contain 10 (bit 3 and bit 1) and the OPLA block 2 has to be selected.

If additional the segment $E$ is to be output with segments $F$ and $G$, (character number 58), the addressed FLAC digit has to contain 10 again and the OPLA block 3 needs to be used. See also an example where of the display instructions are described.

### 2.13 Initialization and Powerup

Initialization is initiated by two hardware reasons:

- Power up: The voltage $V_{D D}$ is switched on (Cold start). The CPU starts to work at PC 000 after the internal cristal oscillator started operation. This may last 1 to 6 seconds.
- INITN pin: If the INITN pin is held low for more than $10 \mu \mathrm{~s}$ (in case this occurs during program execution it is named Warm Start). The CPU starts operation at PC 000 when the INITN pin is released to $V_{D D}$ potential.

The TSS400 Standard registers show the following contents after a power up or a INITN pin.

| Register | Power up <br> (Cold Start) | INITN pin <br> (Warm Start) |
| :--- | :--- | :--- |
| Program Counter PC | 000 | 000 |
| Status Bits POS NEG ZERO | undefined | unchanged |
| RAM Contents (see Note) | reset to 0 | unchanged |
| reset to 0 | reset to 0 |  |
| Digit Latches DLn | undefined | unchanged |
| K-Port Latch Contents | 0 | unchanged |
| Timers | switched off | switched off |
| ADC Voltage SV | DD | undefined | | unchanged |
| :--- |
| LCD Segment Latches |
| Subroutine Stack |

Figure 20: Initialization contents of the internal registers

Note: Despite the RAM remains unchanged if Warm Start (see below) occurs. The memory addressed when the INITN pin was activated may be destroyed by a write cycle.

If the TSS400 system is battery powered and contains calibration factors or other important data in RAM it is advisable to distinguish between Cold Start and Warm Start. The reason is the possibility of initializations caused by EMI. If such an erroneous initialization is not tested for egality, EMI influence could destroy the RAM contents by clearing the RAM by the initialization software routine. The TSS400 Standard compares two reserved RAM nibbles if they contain >A5 after each initialization:

- If the RAM nibbles contain expected right information $>A 5$, continues at PC 000. The RAM contents is not influenced. This means a spurious signal caused the initialization (Warm Start).
- If the RAM nibbles differ from >A5, the RAM is cleared and the program continues at PC 000. This means the TSS400's supply voltage was switched on (Cold Start).

Note: The Short Timer and the Long Timer are not stopped by a Warm Start. This means, they stay active and have to be stopped by a STPTIMx instruction if necessary.

See Chapter 7 for an example how to distinguish the two start-ups by the user's software.

### 2.14 Hardware Options

The used hardware options are a compromise for getting best result for several applications. See the "TSS400 Software User's Guide" for a detailed description of the options.

### 2.14.1 Pinning

| Pin | Connection | Pin | Connection |
| :---: | :---: | :---: | :---: |
| 1 | $\mathrm{V}_{\text {SS }}$ | 23 | R4 |
| 2 | KC | 24 | R5 |
| 3 | INITN | 25 | R6 |
| 4 | $V_{D D}$ | 26 | R7 |
| 5 | K1 | 27 | COM2 |
| 6 | SV ${ }_{\text {DD }}$ | 28 | COM1 |
| 7 | Ri | 29 | S14 |
| 8 | A4 | 30 | S13 |
| 9 | K2 | 31 | S12 |
| 10 | A3 | 32 | S11 |
| 11 | A2 | 33 | S10 |
| 12 | K4 | 34 | S9 |
| 13 | A1 | 35 | S8 |
| 14 | K8 | 36 | S7 |
| 15 | AGND | 37 | S6 |
| 16 | TOSCOUT | 38 | S5 |
| 17 | TOSCIN | 39 | S4 |
| 18 | R0 | 40 | S3 |
| 19 | R1 | 41 | S2 |
| 20 | 1/O | 42 | S1 |
| 21 | R2 | 43 | COM3 |
| 22 | R3 | 44 | COM4 |

Figure 21: Pinning of the TSS400 Standard

### 2.14.2 Input Options

- K8 is connected directly to the ALU, the flip flop in the K8 logic is not active
- the K-Port has push pull outputs and no pulldown resistors
- the used ADC range is $0.1013 \cdot \mathrm{SV}_{\mathrm{DD}}$ to $0.4946 \cdot \mathrm{SV}_{\mathrm{DD}}$
- the MOS oscillator speed is 500 kHz to 1 MHz


### 2.14.3 Timer Options

- 6 Hz are used for the wake-up frequency with set DL12
- no clock frequency is output to a pin
- the oscillator hardware is chosen for a 32768 Hz cristal


### 2.14.4 Display Options

- 4 common multiplex is used
- The following Common/Select configuration is used:
- The 64 possible characters are shown in Figure 15.


Figure 22: Standard segment notation scheme
The complete hardware definition file of the TSS400 Standard is shown in Appendix A.

### 2.15 Instruction Execution Times

The complete instruction execution time consists of:

- Instruction fetch time from the EEPROM
- Instruction decoding time
- Instruction execution time by the TSS400

The exact timing of each instruction is very difficult to compute, caused by its dependance on circumstances. Measurements showed, that a good estimation value is 150 TSS400 instructions for each byte (not instruction!) read from the EEPROM. This means, if the oscillator frequency is 500 kHz , each byte of the user's code needs approximatively 1.8 ms for execution. ( $150 \cdot 6 / 500000 \mathrm{~Hz}=1.8 \mathrm{~ms}$ ).

This estimation bases on normal instruction sequences. If computation intensive instructions occur very often, the mean time of an instruction increases. The instruction times for these time consuming instructions are:

- Multiplication MPY: average register contents 15 ms
- Division DIV: average register contents 18 ms
- Conversion HEXDEC: average register contents 46 ms
- Measurement MEASR: Four compensated measurements 13 ms

With the above given average execution times, the time estimations should be corrected.
The program flow control instructions have the following execution times:

- CALL including RETN:
9.5 ms
- unconditional Jump:
4.5 ms
- conditional Jump executed:
4.5 ms
- conditional Jump not executed:
2.2 ms

The EEPROM instructions have the following execution times:

- EEPROM Write instruction: MOVFLPRM 40 ms
- EEPROM Read instruction: MOVPRMRB 15 ms


### 2.16 Usage of RAMS

The PHILIPS PCF8570, a $256 \cdot 8$ bit RAM can be used for TSS400 Standard applications due to the identical bus protocol. Often modified pointers for EEPROM addressing may be allocated inside of the RAM, which is not degraded by often occuring write operations. See also 7.9 ADDRESS MODIFICATION for more information.

The interpreter assumes blocks of 512 bytes as used with the X24C04 EEPROMs and issues therefore no addressing information if the 256 byte boundary of a RAM is exceeded. This means, the user has to include a jump instruction to get into the 2nd RAM in case it is used. Instructions with more than one byte may not be placed on the boundary due to that reason.

## 3 Interpreter Instruction Set Definitions

### 3.1 Interpreter Language Instruction Map

The instruction map is shown for convenience purposes. The numbers on the left margin show the MSD part of the opcode, the numbers above the map show the LSD part. The opcode for ROUND2 is E1 for example.

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| F | FLKOUT | KOUT | KIN | $\begin{gathered} \text { SEL } \\ \text { GRP1 } \end{gathered}$ | $\begin{gathered} \text { SEL } \\ \text { GRP2 } \end{gathered}$ | MOV CNT1 | MOV CNT2 | $\begin{aligned} & \text { MOV } \\ & \text { DBL } \end{aligned}$ |
| E | ROUND $\qquad$ 1 | ROUND $2$ | $\begin{gathered} \text { ROUND } \\ 3 \\ \hline \end{gathered}$ | $\begin{gathered} \text { ROUND } \\ 4 \\ \hline \end{gathered}$ | $\begin{gathered} \text { SHIFT } \\ \text { R1 } \\ \hline \end{gathered}$ | $\begin{gathered} \text { SHIFT } \\ \text { R" } \\ \hline \end{gathered}$ | SHIFT L1 | $\begin{gathered} \text { SHIFT } \\ \text { L" } \end{gathered}$ |
| D | LDTIML | LDTIMS | DONE | OFF | RETN | CLRFL | CLRRB | $\begin{aligned} & \mathrm{EXCH} \\ & \mathrm{RBFL} \end{aligned}$ |
| C | MOVFLPRM |  |  |  |  |  |  |  |
| B | $\begin{gathered} \text { DISPL } \\ \text { FL } \end{gathered}$ | $\begin{gathered} \text { DISPL } \\ \text { DG1 } \\ \hline \end{gathered}$ | $\begin{gathered} \text { DISPL } \\ \text { DG2 } \end{gathered}$ | $\begin{aligned} & \text { DISPL } \\ & \text { DG3 } \\ & \hline \end{aligned}$ | $\begin{gathered} \text { DISPL } \\ \text { DG4 } \end{gathered}$ | $\begin{gathered} \text { DISPL } \\ \text { DG5 } \end{gathered}$ | $\begin{gathered} \text { DISPL } \\ \text { DG6 } \\ \hline \end{gathered}$ | $\begin{gathered} \text { DISPL } \\ \text { DG7 } \\ \hline \end{gathered}$ |
| A | MOVFLSTO |  |  |  |  |  | MOVSTOFL |  |
| 9 | MOVRBSTO |  |  |  |  |  | MOVSTORB |  |
| 8 | JP |  |  |  |  |  |  |  |
| 7 | JZ/JEQ |  |  |  |  |  |  |  |
| 6 | JMP |  |  |  |  |  |  |  |
| 5 | LDFLPOS |  |  |  | LDFLNEG |  |  |  |
| 4 | TBIT |  |  |  |  |  |  |  |
| 3 | RBIT |  |  |  |  |  |  |  |
| 2 | SBIT |  |  |  |  |  |  |  |
| 1 | ACTTIM | RSTR |  |  |  |  |  | SVDD OFF |
| 0 | NOP | SETR |  |  |  |  |  | SVDD ON |

Figure 23: Instruction Map lower Part

|  | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| F | STP <br> TIML | STP <br> TIMS | SLV |  |  |  |  | (NOP) |
| E | $\begin{aligned} & \text { ADJ } \\ & \text { BATT } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ADJ } \\ & \text { COMP } \end{aligned}$ | $\begin{aligned} & \text { CHK } \\ & \text { BATT } \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{CHK} \\ \mathrm{COMP} \\ \hline \end{gathered}$ | $\begin{aligned} & \text { CMP } \\ & \text { FLRB } \end{aligned}$ | $\begin{gathered} \text { TSTKE } \\ Y \\ \hline \end{gathered}$ | TSTRB | KINTIM |
| D | $\begin{aligned} & \text { DEC } \\ & \text { CNT2 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { CNT1 } \end{aligned}$ | DECDBL | $\begin{aligned} & \text { INC } \\ & \text { CNT2 } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { CNT1 } \end{aligned}$ | INCDBL | $\begin{gathered} \text { LDCNT } \\ 2 \\ \hline \end{gathered}$ | $\begin{gathered} \text { LDCNT } \\ 1 \\ \hline \end{gathered}$ |
| C | MOVPRMRB |  |  |  |  |  |  |  |
| B | $\begin{gathered} \text { DISPL } \\ \text { CLR } \end{gathered}$ | $\begin{aligned} & \text { MOV } \\ & \text { FLRB } \end{aligned}$ | MOV RBFL | ADD | SUB | MPY | DIV | $\begin{aligned} & \text { HEX } \\ & \text { DEC } \\ & \hline \end{aligned}$ |
| A | MOVSTOFL |  |  |  | MEASR |  |  |  |
| 9 | MOVSTORB |  |  |  |  |  |  |  |
| 8 | JN |  |  |  |  |  |  |  |
| 7 | JNE/JNZ |  |  |  |  |  |  |  |
| 6 | CALL |  |  |  |  |  |  |  |
| 5 | LDRBPOS |  |  |  | LDRBNEG |  |  |  |
| 4 | TBIT |  |  |  |  |  |  |  |
| 3 | RBIT |  |  |  |  |  |  |  |
| 2 | SBIT |  |  |  |  |  |  |  |
| 1 | RSTR |  |  |  |  |  | SUBH | AND |
| 0 | SETR |  |  |  |  |  | ADDH | OR |

Figure 24: Instruction Map upper Part

### 3.2 Effect on Status Bits

Each instruction description in this section contains a status description. The way in which an instruction depends on, or modifies the Status Bits is defined as follows:

Not affected: the Status Bits remain unchanged
POS $=1$ the Status Bit (here POS) is set
NEG $=0 \quad$ the Status Bit (here NEG) is reset
ZERO = $X \quad$ the Status Bit (here ZERO) remains unchanged
The information shown after STATUS is given for the completed instruction.

### 3.3 Interpreter Instruction Formats

The interpreter uses different instruction formats. Each instruction description shows the correct source format after the label MNEMONIC. The different source formats are explained in the following:

### 3.3.1 Constant Operand

## INSTR n

The operand n , whose range is defined in the description of the instruction, is placed into the opcode's operand field or into the following byte by the assembler.

### 3.3.2 EEPROM Address Operand

## INSTR LABEL

The operand, which is an EEPROM address, is placed into the opcode's LSBs and into a byte following the instruction by the assembler.

### 3.3.3 Implicit Operand

INSTR
The instruction does not have an operand.
INSTRn
The instruction contains the operand in the mnemonic. The range of $n$ is defined in the instruction's description.

### 3.3.4 Hexadecimal Operand

INSTR >NN

The instruction uses hexadecimal or BCD numbers for operands. The assembler locates the operand in the next byte.

### 3.3.5 Decimal Operand

INSTR NNN
The instruction uses decimal numbers for operands. The assembler locates the operand in the next byte.

Note: Numbers maybe formatted $>$ NN or NNN normally. Only if BCD numbers are used, the $>$ NN format is necessary for separating the two digits.

### 3.3.6 Attached, Floating Number of Operands

$$
\begin{aligned}
& \text { INSTR n } \\
& \text { BYTE }>\text { NN } \\
& \ldots \\
& \text { BYTE }>N N
\end{aligned}
$$

The instruction uses $n$ bytes following the instruction for additional information. The n bytes needs to be included into the source program by the user.

INSTR >NN
BYTE >NN
BYTE >NN
The number of additional bytes is defined by:

$$
\text { Operand LSD - MSD + } 1 .
$$

### 3.3.7 Attached, Fixed Number of Operands

INSTR n
BYTE >NN
The instruction uses one byte following the instruction. The byte is to be included by the user. An operand n is used, too.

### 3.3.8 Coding Format

The following rules should be followed in writing a program:

- Label fields are a maximum of eight alphanumeric characters starting with an alphabetic character. The label field begins in column one.
- The operation code (opcode) is to the right of a label, the two separated by at least one blank space. If no label is used, the operation code begins after the first column (second column or further right).
- The operand is to the right of the operation code, they are separated by at least one blank.
- A comment is to the right of the operand, they are separated by at least one blank. If a comment occupies a separate line, it must begin with an asterisk ( ${ }^{*}$ ) in column one.

For legibility, it is recommended that fields begin in the following columns:

- label fields must begin in column 1
- operation codes should begin in columnn 11
- operands should begin in column 21
- comments to an instruction should begin in column 31
- comment lines must begin in column one with an asterisk

Example: The following lines show source lines conforming to the above rules.

* THIS IS A PURE COMMENT LINE

column 1


### 3.4 Register to Register Transfer Instructions

### 3.4.1 Move FLAC to Storage Register

MNEMONIC: MOVFLSTOn
OPCODE: A0 - A5
STATUS: If FLAC $=0$ :
POS = 1 NEG = 0 ZERO = 1
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC $<0$
$\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC $\rightarrow$ STOn $\quad(0 \leq n<6)$
PARAMETER: none
PURPOSE: Copying or saving the FLAC into a Storage Register.
DESCRIPTION: The FLAC content is unconditionally transferred to the Storage Register n . The FLAC contents is unaltered.

### 3.4.2 Move Storage Register to FLAC

MNEMONIC: MOVSTOFLn OPCODE: A6-AB
STATUS: If FLAC $=0$ :
$P O S=1$ NEG = 0 ZERO = 1
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $\mathrm{FLAC}<0$
$\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ STOn $\rightarrow$ FLAC $\quad(0 \leq n<6)$
PARAMETER: none
PURPOSE: Reading a Storage Register.
DESCRIPTION: The content of the Storage Register n is unconditionally transferred to the FLAC. The content of the Storage Register n is unaltered.

### 3.4.3 Move REGB to Storage Register

MNEMONIC: MOVRBSTOn
OPCODE: 90-95
STATUS: If REGB $=0$ :
$P O S=1$ NEG $=0$ ZERO $=1$
If REGB > 0
POS $=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If REGB < 0
POS $=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ REGB $\rightarrow$ STOn $\quad(0 \leq n<6)$
PARAMETER: none
PURPOSE: Copying or saving the REGB into a Storage Register.
DESCRIPTION: The REGB content is unconditionally transferred to the Storage Register n . The REGB contents is unaltered.

### 3.4.4 Move Storage Register to REGB.

MNEMONIC: MOVSTORBn
OPCODE: 96-9B
STATUS: If REGB $=0$ :
POS $=1$ NEG $=0$ ZERO $=1$
If REGB > 0
POS $=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If REGB < 0
$\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ STOn $\rightarrow$ REGB $\quad(0 \leq n<6)$
PARAMETER: none
PURPOSE: Reading a Storage Register.
DESCRIPTION: The content of the Storage Register n is unconditionally transferred to the REGB. The content of the Storage Register n is unaltered.

[^11]
### 3.4.5 Move FLAC to REGB

MNEMONIC: MOVFLRB
OPCODE: B9
STATUS: If $\operatorname{FLAC}=0$ :
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=1$
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC < 0
$\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: FLAC $\rightarrow$ REGB
PURPOSE: Copying of the FLAC to REGB
DESCRIPTION: The content of the FLAC is transferred to the REGB. The Status Bits are set according to the FLAC content.
PARAMETER: none
EXAMPLE: The FLAC is to be multiplied by three:

| MOVFLRB | MULTIPLY FLAC BY 3 |
| :--- | :--- |
| ADD | $\times 2$ |
| ADD | $\times 3$ |

Example 1: Multiplication by Three

### 3.4.6 Move REGB to FLAC

MNEMONIC: MOVRBFL
OPCODE: BA
STATUS: If FLAC $=0$ :
POS = 1 NEG = 0 ZERO = 1
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC $<0$
$P O S=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ REGB $\rightarrow$ FLAC

PURPOSE: Copying of the REGB to the FLAC
DESCRIPTION: The content of the REGB is transferred to the FLAC. The Status Bits are set according to the FLAC contents.

PARAMETER: none

### 3.4.7 Exchange REGB and FLAC Registers

MNEMONIC: EXCHRBFL
OPCODE: D7
$\begin{array}{ll}\text { STATUS: } & \text { After execution: } \\ & \text { If } F L A C=0: \\ & P O S=1 \text { NEG }=0 \text { ZERO }=1 \\ & \text { If } F L A C>0 \\ & P O S=1 \text { NEG }=0 \text { ZERO }=0 \\ & \text { If } F L A C<0 \\ & P O S=0 \text { NEG }=1 \text { ZERO }=0\end{array}$
ACTION: REGB $\leftrightarrow$ FLAC
PURPOSE: Exchanging REGB and FLAC.
DESCRIPTION: The contents of REGB and FLAC are exchanged. The
Status Bits are set according to the FLAC contents after execution of the instruction.

PARAMETER: none

### 3.4.8 Move FLAC to EEPROM

MNEMONIC: MOVFLPRM LABEL OPCODE: C0-C7
STATUS: not affected
ACTION: PC+2 $\rightarrow$ Stack
FLAC $\rightarrow$ EEPROM
Stack $\rightarrow$ PC
PARAMETER: None. Two byte instruction.

Revision 1, November 1990

PURPOSE: Storing of constants in the EEPROM.
DESCRIPTION: The content of the FLAC is written to four EEPROM bytes starting at the address defined by the label. This allows the storage of computed constants in the EEPROM which for example gives the possibility of selfcalibration of the system. The sign of the FLAC is stored in the MSB of the number; this reduces the number's range to $+/-79999999$. The MSD is stored at the first byte (High nibble of address LABEL). The inverse operation MOUVPRMRB restores the sign correctiy.

Note: One level of the stack is used for the storage of the PC. This means that this instruction cannot be used in the 3rd subroutine level.

EXAMPLE: The result of a computation need to be stored in the EEPROM address CONST2 for later use.

|  | ADD |  | CONST2 COMPUTED IN FLAC |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  | MOVFLPRM | CONST2 | WRITE CONST2 TO EEPROM |  |  |
|  | OMG |  |  |  |  |
| CONST2 | ORG | 500 | CONSTANTS IN EEPROM ADDRESS 500 |  |  |
|  | BYTE | 0 | $10 E 7 / 10 \mathrm{E} 6$ SIGN IN MSB |  |  |
|  | BYTE | 0 | $10 E 5 / 10 \mathrm{E} 4$ |  |  |
|  | BYTE | 0 | $10 E 3 / 10 \mathrm{E} 2$ |  |  |
|  | BYTE | 0 | $10 E 1 / 10 \mathrm{E} 0$ | LSD |  |

Example 2: Storage of a computed value in the EEPROM

The allocation inside the EEPROM is shown in Figure 25:
MSB

| S | 10 E 7 | 10E6 | 5 |
| :---: | :---: | :---: | :---: |
| 500 | 500 ADDRESS |  |  |
|  | 10 E 5 | 10 E 4 | 501 |
| 5 | 10 E 3 | 10 E 2 | 502 |
|  | 10E1 | 10 E 0 | 503 |

Figure 25: EEPROM map of the MOVFLPRM values

### 3.4.9 Move EEPROM to REGB

MNEMONIC: MOVPRMRB LABEL
STATUS: not affected
ACTION: PC+2 $\rightarrow$ Stack
EEPROM $\rightarrow$ REGB
Stack $\rightarrow \mathrm{PC}$
PARAMETER: None. Two byte instruction.
PURPOSE: Loading of constants stored in the EEPROM.
DESCRIPTION: The contents of the EEPROM address defined by the label and the contents of the following 3 bytes are written to REGB. The sign is restored out of the MSB of the number into the sign nibble of REGB. The MSD is stored in the 1st byte (high nibble of address LABEL).

Note: One level of the stack is used for the storage of the PC. This means that this instruction may not be used in the 3rd subroutine level.

EXAMPLE: The computed constant of a multiplication need to be stored in the EEPROM at the label CONST1. For later computations the constant is read back from the EEPROM:

| A2 | EQU | 1 |  |
| :--- | :--- | :--- | :--- |
|  | MPY |  |  |
|  | MOVFLPRM | CONST1 | CONSTANT IN FLAC |
|  | $\cdots$ |  |  |
|  | $\cdots$ |  | MEASURE A2 INPUT |
|  | MEASR | A2 | WITH 2 COMPENSATED MEASUREMENTS |
|  | BYTE | 1 | CONVERT ADC RESULT TO DECIMAL |
|  | HEXDEC |  | CONST1 -> REGB |
|  | MOVPRMRB | CONST1 |  |
|  | ADD |  | ADD CONST1 TO ADC-VALUE |
|  | $\cdots$ |  |  |
|  | ORG | 504 | CONSTANTS AREA IN EEPROM |
|  | BYTE | 0 | MSDS AND SIGN |

Example 3: Storing and retrieving of an EEPROM value

### 3.5 Arithmetic Instructions

See Chapter 7 for useful hints and applications of these Instructions.

### 3.5.1 Add REGB to FLAC Decimally, Result to FLAC

MNEMONIC: ADD
OPCODE: BB
STATUS: If $\operatorname{FLAC}=0$ :
POS = 1 NEG = 0 ZERO = 1
If FLAC > 0
POS $=1$ NEG $=0$ ZERO $=0$
If $\mathrm{FLAC}<0$
$\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC + REGB $\rightarrow$ FLAC
PARAMETER: none
PURPOSE: Adding of two signed, decimal values.
DESCRIPTION: The content of REGB is added decimally to the content of the FLAC, the result is stored in the FLAC. REGB and STOO are not altered.

### 3.5.2 Subtract REGB From FLAC Decimally, Result to FLAC

MNEMONIC: SUB
OPCODE: BC
STATUS: If FLAC $=0$ :
POS = $1 \mathrm{NEG}=0 \mathrm{ZERO}=1$
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC < 0
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC - REGB $\rightarrow$ FLAC
PARAMETER: none
PURPOSE: Subtracting of two signed, decimal values.

DESCRIPTION: The content of REGB is subtracted decimally from the content of the FLAC, leaving the result in the FLAC. REGB and STOO are not altered.

### 3.5.3 Multiply FLAC and REGB Decimally, Result to FLAC

MNEMONIC: MPY
OPCODE: BD
STATUS:

> If $\mathrm{FLAC}=0$ :
> $\mathrm{POS}=1 \mathrm{NEG}=0$ ZERO $=1$
> If $\mathrm{FLAC}>0$
> $\mathrm{POS}=1 \mathrm{NEG}=0$ ZERO $=0$
> If $\mathrm{FLAC}<0$
> $\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=0$

ACTION: $\quad$ FLAC $\times$ REGB $\rightarrow$ FLAC
$0 \rightarrow$ STOO
PARAMETER: none
PURPOSE: Multiplying of two signed, decimal values.
DESCRIPTION: The content of the REGB is multiplied with the content of the FLAC, leaving the result in the FLAC. Storage Register STOO is cleared. REGB is not altered. The numbers are treated as decimal ones.

### 3.5.4 Divide FLAC by REGB Decimally, Result to FLAC

MNEMONIC:
DIV
OPCODE: BE
STATUS: If FLAC $=0$ :
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=1$
If FLAC > 0
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC $<0$
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: FLAC : REGB $\rightarrow$ FLAC

[^12]
## Remainder $\rightarrow$ STO0

PARAMETER: none
PURPOSE: Dividing of two signed, decimal values.
DESCRIPTION: The content of the FLAC is divided by the content of REGB. The result is left in the FLAC, the remainder in the Storage Register STOO. The numbers are treated as decimal ones. REGB is not altered.

Note: The division routine will hang endlessly if REGB contain zero. Before each division the content of REGB have to be tested with the instruction TSTRB to assure that it is not zero.

### 3.5.5 Add REGB to FLAC Hexadecimally, Result to FLAC

MNEMONIC: ADDH
OPCODE: OE
STATUS: If FLAC $=0$ :
POS = 1 NEG = 0 ZERO = 1
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $\mathrm{FLAC}<0$
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC + REGB $\rightarrow$ FLAC
PARAMETER: none
PURPOSE: Adding of two hexadecimal values.
DESCRIPTION: The content of REGB is added to the content of the FLAC, the result is stored in the FLAC. The contents of both registers are treated as hexadecimal numbers in two's complement format. REGB and STOO are not altered.

### 3.5.6 Substract REGB from FLAC Hexadecimally, Result to FLAC

MNEMONIC: SUBH
OPCODE: 1E
STATUS: If FLAC $=0$ :
POS = 1 NEG = 0 ZERO = 1
If $\mathrm{FLAC}>0$
POS = $1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $\operatorname{FLAC}<0$
$P O S=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC - REGB $\rightarrow$ FLAC
PARAMETER: none
PURPOSE: Subtracting of two hexadecimal values.
DESCRIPTION: The content of REGB is subtracted from the content of the FLAC, leaving the result in the FLAC. The contents of both registers are treated as hexadecimal numbers in two's complement format. REGB and STOO are not altered.

### 3.5.7 Hexadecimal to Decimal Conversion

MNEMONIC: HEXDEC
STATUS: If FLAC >0
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $\mathrm{FLAC}=0$
POS = 1 NEG = 0 ZERO = 1
ACTION: $\quad$ FLAC hexadecimally $\rightarrow$ FLAC decimally
NNN $\rightarrow$ REGB
$0 \rightarrow$ STOO
PARAMETER: none
PURPOSE: Converting of the hexadecimal FLAC value to decimal format for computations.

Revision 1, November 1990

DESCRIPTION: The hexadecimal value, stored in digits 10E4 to 10 E 0 of the FLAC, is converted to decimal format. The decimal result is stored in the FLAC. REGB is destroyed by the conversion. Storage Register STOO is cleared.

### 3.5.8 Round FLAC n Times

MNEMONIC: ROUNDn OPCODE: E0 - E3

STATUS: $\quad$ If $F L A C=0$ : POS = 1 NEG = 0 ZERO = 1
If FLAC > 0
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC < 0 $P O S=0$ NEG $=1 \mathrm{ZERO}=0$

ACTION: $\quad$ FLAC : 10E(n-1) $\rightarrow$ FLAC FLAC: $10 \rightarrow$ FLAC with rounding

PARAMETER: None. The implicit operand n ranges from 1 to 4 .
PURPOSE: Adjusting the FLAC when too large e.g. after a multiplication.

DESCRIPTION: The FLAC is shifted right n times. During the last shift the FLAC is rounded up or down depending on the value of the out shifted digit:
Digit < 5: no change of the new LSD
Digit > 4: the new FLAC is rounded up by 1
EXAMPLES: The FLAC is shown before and after rounding. Different contents and roundings are used:

| FLAC before | FLAC after | Instruction |
| ---: | :---: | :--- |
| 12345 |  |  |
| 12345 | 1235 | ROUND1 |
| 98765432 | 123 | ROUND2 |
| 98765432 | 98765 | ROUND3 |
| 0 | 9877 | ROUND 4 |
| -15 | 0 | ROUNDn |
|  | -2 | ROUND1 |

Example 4: FLAC before and after Rounding

### 3.5.9 Shift Right FLAC $n$ Times

MNEMONIC: SHIFTRn
STATUS: If FLAC $=0$ :
POS = 1 NEG = 0 ZERO $=1$
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC $<0$
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC : 10En $\rightarrow$ FLAC $\quad(0<n<3)$
PARAMETER: None. The implicit operand n ranges from 1 to 2 .
PURPOSE: Adjusting of the FLAC.
DESCRIPTION: The FLAC is shiftet right $n$ times. No rounding is made.
EXAMPLE: The FLAC's two LSDs are to be cleared.

| -. | FLAC: | XXXX.YYYY |
| :--- | :--- | ---: |
| SHIFTR2 | TRUNCATE LSDs | XXXX.YY |
| SHIFTL2 | LSDS <- OO | XXXX.YYOO |
| . . | NEXT INSTRUCTION | HERE |

Example 5: Adjusting of the FLAC by shifting

### 3.5.10 Shift Left FLAC n Times

MNEMONIC: SHIFTLn
OPCODE: E6-E7
STATUS: If $\operatorname{FLAC}=0$ :
POS = $1 \mathrm{NEG}=0 \mathrm{ZERO}=1$
If $\mathrm{FLAC}>0$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $F L A C<0$
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: $\quad$ FLAC $\cdot 10 E n \rightarrow$ FLAC $\quad(0<n<3)$
PARAMETER: none
PURPOSE: Shifting left the FLAC n-times.
DESCRIPTION: The FLAC is shifted left one or two times. Zeroes are filled into the vacated nibbles of the FLAC.

EXAMPLE: The FLAC is to be shifted left twice freeing the 2 LSDs. These 2 digits are to be replaced by the value in REGB.

```
SHIFTL2
```

FLAC x 100 REGB: YY

XXXXX00 XXXXXYY

Example 6: Inserting to the FLAC by shifting left

### 3.6 Arithmetic Compare Instructions

### 3.6.1 Compare FLAC and REGB

MNEMONIC: CMPFLRB
STATUS: If FLAC = REGB
POS = 0 NEG $=0$ ZERO $=1$
If FLAC $>$ REGB
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If FLAC < REGB
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$

ACTION: $\quad$ FLAC - REGB $\rightarrow$ computed but not stored
PARAMETER: none
PURPOSE: Comparing the two signed values of FLAC and REGB.
DESCRIPTION: The contents of REGB are compared to the contents of the FLAC. This is done similiarly to a subtraction FLAC REGB with the result stored nowhere. The Status Bits are set according to the following table:

| SIGN | FLAC | + | + | - | - |
| :--- | :--- | :---: | :---: | :---: | :---: |
| SIGN | REGB | + | - | + | - |
| $\mid$ FLAC $\mid$ | $>\mid$ REGB $\mid$ | POS | POS | NEG | NEG |
| $\mid$ FLAAC | $=\|R E G B\|$ | ZERO | POS | NEG | ZERO |
| $\mid$ FLAC $\mid$ | $<\|R E G B\|$ | NEG | POS | NEG | POS |

Figure 26: Flag Bit setting by the CMPFLRB instruction

### 3.6.2 Test Contents of REGB

MNEMONIC: TSTRB
STATUS: If REGB $=0$

$$
\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=1
$$

If REGB >0
POS $=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If REGB < 0
$P O S=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: REGB compared to 0
PARAMETER: none
PURPOSE: Getting information concerning REGB.
DESCRIPTION: The content of REGB is compared to 0 . The result is written to the Status Bits.

# EXAMPLE: The content of REGB is tested before a division. If it contains 0 . The division is not made due to the hangup caused by this REGB value. 

```
MOVSTORB 2
TSTRB
JZ DIVERR
DIV
```

```
MOVE STO2 -> REGB
```

MOVE STO2 -> REGB
IF REGB = 0: ERROR OCCURED
IF REGB = 0: ERROR OCCURED
JUMP TO ERROR HANDLING
JUMP TO ERROR HANDLING
REGB \# 0: FLAC : REGB -> FLAC

```
REGB # 0: FLAC : REGB -> FLAC
```

Example 7: Zero test before division

### 3.7 Bit Manipulation Instructions

### 3.7.1 Set Flag Bit

MNEMONIC: SBIT n
OPCODE: 20-2F
STATUS: not affected
ACTION: $\quad 1 \rightarrow$ addressed Flag Bit $(0 \leq n<16)$
PURPOSE: Setting a Flag Bit without affecting the other bits in the flag area.
DESCRIPTION: One of the 32 Flag Bits, selected by the operand $n$ and the used Flag Group, is set to one in the flag area. The last SELGRPn instruction selects the used group.
PARAMETER: none

### 3.7.2 Reset Flag Bit

MNEMONIC: RBIT $\mathbf{n}$ OPCODE: 30-3F
STATUS: not affected
ACTION: $\quad 0 \rightarrow$ addressed Flag Bit $(0 \leq n<16)$
PURPOSE: Resetting a Flag Bit without affecting the other bits in the flag area.

DESCRIPTION: One of the 32 Flag Bits, selected by the operand n of the instruction and the used Flag Group, is reset to zero in the flag area. The last SELGRPn instruction selects the used group.

PARAMETER: none

### 3.7.3 Test Flag Bit

MNEMONIC: TBIT n OPCODE: 40-4F
STATUS: $\quad$ If $\mathrm{Bit}=0$
$Z E R O=1 \mathrm{NEG}=1 \mathrm{POS}=0$
If Bit $=1$
$Z E R O=0$ NEG $=0$ POS $=1$

ACTION: $\quad \overline{\text { Addressed bit }} \rightarrow$ ZERO and NEG $(0 \leq n<16)$
Addressed bit $\rightarrow$ POS
PURPOSE: To test a selected Flag Bit if set or not.
DESCRIPTION: The addressed Flag Bit (by Group and bit number n) is transferred to the POS Bit. The inverted bit is transferred to the ZERO and NEG Bits. The last SELGRPn instruction selects the used group.
PARAMETER: none

### 3.7.4 Select Flag Bits Group $\mathbf{n}$

MNEMONIC: SELGRPn OPCODE: F3-F4
STATUS: not affected
ACTION: if $\mathrm{n}=1$ : Select Group 1 flags
if $\mathrm{n}=2$ : Select Group 2 flags
PURPOSE: Select the flags to be used.

DESCRIPTION: The selected group of flags is addressed for all bit modifying and testing instructions until an other SELGRPn instruction is encountered.

PARAMETER: none

### 3.7.5 OR FLAC and REGB

MNEMONIC: OR
STATUS: If FLAC $=0$
ZERO = $1 \quad \mathrm{NEG}=0 \quad \mathrm{POS}=1$
If FLAC > 0
ZERO $=0 \quad \mathrm{NEG}=0 \quad \mathrm{POS}=1$
ACTION: $\quad$ FLAC .OR. REGB $\rightarrow$ FLAC
PURPOSE: Oring the two register values.
DESCRIPTION: The logical OR function is applied to FLAC and REGB. Bits set in one or both registers are set in the FLAC. Bits not set in both registers are cleared in the FLAC.
PARAMETER: none

### 3.7.6 And FLAC and REGB

MNEMONIC: AND
STATUS: $\quad$ If $F L A C=0$
ZERO = 1 NEG = 0 POS = 1
If $\mathrm{FLAC}>0$
ZERO $=0$ NEG $=0$ POS $=1$
ACTION: $\quad$ FLAC .AND. REGB $\rightarrow$ FLAC
PURPOSE: Anding the two register values.

DESCRIPTION: The logical AND function is applied to FLAC and REGB. Bits set in both registers are set in the FLAC, all others are cleared to zeroes in the FLAC.

PARAMETER: none

### 3.8 Constant Transfer Instructions

3.8.1 Load FLAC with a Positive Constant

MNEMONIC: LDFLPOS n
OPCODE: 50-53
BYTE $>N N$
BYTE $>N N$
STATUS: not affected
ACTION: $\quad+$ CONSTANT $\rightarrow$ FLAC $(0 \leq n<4)$
PURPOSE: Loading the FLAC with a positive constant.
DESCRIPTION: The constant, which length is defined by the operand $n$, is loaded into the cleared FLAC with a positive sign. The constant follows the instruction in subsequent bytes. To assure the BCD format, the hex sign ">" has to be used for the constants.

PARAMETER: Defined by the operand $n ; n$ bytes follow. If $n=0 ; 4$ bytes follow. Each byte contains two BCD numbers. The MSD of the operand is contained in the 1st byte after the instruction.

Note: It is the user's responsibility to append the correct number of bytes after the instruction. The assembler doesn't give a warning if the operand n and the number of appended bytes do not match. This is true for all four load instructions.

EXAMPLE: $\quad$ The FLAC is to be loaded with the constant +123456

```
LDFLPOS 3 3 BYTES WITH PARAMETERS FOLLOW
BYTE >12 +123456 -> FLAC
BYTE >34
BYTE >56
ADD 123456 + REGB -> FLAC
    NEXT INSTRUCTION HERE
```

Example 8: Loading the FLAC with a positive constant

### 3.8.2 Load FLAC with a Negative Constant <br> MNEMONIC: LDFLNEG n <br> OPCODE: 54-57 <br> BYTE $\quad$ NN <br> BYTE $\quad$ NN <br> STATUS: not affected <br> ACTION: $\quad$ - CONSTANT $\rightarrow$ FLAC <br> PURPOSE: Loading the FLAC with a negative constant. <br> DESCRIPTION: The constant, which length is defined by the operand $n$, is loaded into the cleared FLAC with a negative sign. The constant follows the instruction in subsequent bytes. To assure the BCD format, the hex sign ">" has to be used for the constants. <br> PARAMETER: Defined by the operand $n ; n$ bytes follow. If $n=0 ; 4$ bytes follow. Each byte contains two BCD numbers. The MSD of the operand is contained in the 1st byte after the instruction.

### 3.8.3 Load REGB with a Positive Constant

MNEMONIC: LDRBPOS n
OPCODE: 58-5B
BYTE $>N N$
BYTE $>N N$

STATUS: not affected
ACTION: $\quad+$ CONSTANT $\rightarrow$ REGB
PURPOSE: Loading REGB with a positive constant.
DESCRIPTION: The constant, which length is defined by the operand $n$, is loaded into the cleared REGB with a positive sign. The constant follows the instruction in subsequent bytes. To assure the BCD format, the hex sign ">" has to be used for the constants.

PARAMETER: Defined by the operand $n ; n$ bytes follow. If $n=0 ; 4$ bytes follow. Each byte contains two BCD numbers. The MSD of the operand is contained in the 1st byte after the instruction.

### 3.8.4 Load REGB with a Negative Constant

MNEMONIC: LDRBNEG n OPCODE: 5C-5F
BYTE $\quad$ NN

BYTE $\quad$ NN
STATUS: not affected
ACTION: $\quad$ - CONSTANT $\rightarrow$ REGB
PURPOSE: Loading REGB with a negative constant.
DESCRIPTION: The constant, which length is defined by the operand $n$, is loaded into the cleared REGB with a negative sign. The constant follows the instruction in subsequent bytes. To assure the BCD format, the hex sign ">" has to be used for the constants.

PARAMETER: Defined by the operand $n ; n$ bytes follow. If $n=0 ; 4$ bytes follow. Each byte contains two BCD numbers. The MSD of the operand is contained in the 1st byte after the instruction.

[^13]EXAMPLE: REGB is to be loaded with the constant $\mathbf{- 7 6 5 4 3 2 1 0 .}$

| LDRBNEG | 0 | 4 BYTES WITH PARAMETERS FOLLOW |
| :--- | :--- | :--- |
| BYTE | $>76$ |  |
| BYTE | $>54$ | $-76543210->$ REGB |
| BYTE | $>32$ |  |
| BYTE | $>10$ | FLAC $+(-76543210)->$ FLAC |
| ADD |  | NEXT INSTRUCTION HERE |

Example 9: Loading of REGB with a negative constant
3.8.5 Clear FLAC Register
MNEMONIC: CLRFL ..... OPCODE: D5
STATUS: not affected
ACTION: $\quad+0 \rightarrow$ FLAC
PURPOSE: Clearing of the FLAC.
DESCRIPTION: The constant +0 is loaded into the FLAC.
PARAMETER: ..... none
3.8.6 Clear REGB
MNEMONIC: CLRRB ..... OPCODE: D6
STATUS: not affected
ACTION: $\quad+0 \rightarrow$ REGB
PURPOSE: Clearing of REGB.
DESCRIPTION: The constant +0 is loaded into the REGB.
PARAMETER: none

### 3.9 Input/Output Instructions

### 3.9.1 Set R Output

MNEMONIC: SETR $n$ OPCODE: 01-06
08-0D
STATUS: not affected
ACTION: $\quad 1 \rightarrow$ DLn $\quad(0<n<14, n \# 7)$
PURPOSE: To set a Digit Latch to a logical one.
DESCRIPTION: The operand $n$ selects the proper Digit Latch. If the operand n is from 1 to 6 inclusive, outputs R1 to R6 are set. For values greater than 7 the Digit Latches DL8 to DL13 are set.

PARAMETER: none
Note: R0 and R7 cannot be addressed due to their usage by the control software.

### 3.9.2 Reset R Output

MNEMONIC: RSTR n
OPCODE: 11-16
18-1D
STATUS: not affected
ACTION: $\quad 0 \rightarrow$ DLn $\quad(0<n<14, \mathrm{n} \# 7)$
PURPOSE: To reset a Digit Latch to a logical zero.

DESCRIPTION: The operand $n$ selects the proper Digit Latch. If the operand n is from 1 to 6 inclusive, outputs R1 to R6 are reset. For values greater than 7 the Digit Latches DL8 to DL13 are reset.

PARAMETER: none

Revision 1, November 1990

Note: R0 and R7 cannot be addressed due to their usage by the control software.

### 3.9.3 Test Keyboard

MNEMONIC: TSTKEY >NN
STATUS: See Figure 27.
ACTION: Key status to Status Bits.
DL8 = 0
PURPOSE: Testing of a key connected to the K-Port or testing of a KPort level.

DESCRIPTION: The addressed K-Port Kn is read in. This can be done with a set, reset or unchanged R-output. The input is compared with the information read in the last time and the Status Bits set according to the following list:

| Transition | ZERO | POS | NEG |
| :--- | :---: | :---: | :---: |
| LO-LO | 1 | 0 | 0 |
| LO-HI | 0 | 1 | 0 |
| HI-LO | 1 | 0 | 1 |
| HI-HI | 0 | 0 | 0 |

Figure 27: Status Bit setting by the TSTKEY instruction The ZERO Bit shows the actual state of the key, the POS and NEG Bits show if transitions occured. The operand format is shown below:

| 0 | R | STR | Kn |
| :--- | :--- | :--- | :--- |

Figure 28: Operand byte of the TSTKEY instruction

| R: Strobing R-output | 00 | R1 |
| :--- | :--- | :--- |
|  | 01 | R2 |
|  | 10 | R3 |
|  | 11 | R4 |
|  | STR: Strobe used | $x 0$ | R-output not changed

The read information without affecting the other K-inputs is stored and the addressed R-output set after the instruction according to the used strobe STR:
STR = x0: the R-output is not changed at all
STR = 01: the R-output is set to 1
STR = 11: the R-output is reset to 0
PARAMETER: 1 byte containing the operand. Appended by the assembler. See Figure 28 for details.
EXAMPLE: If the key, connected to R3 and K2 is pressed (LO-HI) the program has to continue at label PRESSK2. If the same key is released, the program has to continue at label RELEASK2

```
* TEST IF KEY R3/K2 CHANGED SINCE THE LAST READIN
    TSTKEY
    JP
JN
                                >20+>0C+1 R3, POS. STROBE, K2
                                PRESSK2 KEY WAS PRESSED
                                RELEASK2 KEY WAS RELEASED
                                NO CHANGE AT THE KEY
```

Example 10: Keyboard test example
3.9.4 Actualize K-Input and Timers
MNEMONIC: KINTIM
STATUS: $\quad$ If $\mathrm{K} 8=\mathrm{K} 4=\mathrm{K} 2=\mathrm{K} 1=0$
$Z E R O=1 P O S=X N E G=X$
Otherwise
ZERO = 0 POS $=X$ NEG $=X$
ACTION: $\quad$ K8 $\rightarrow$ Group $1 \quad$ Flag 15
$\mathrm{K} 4 \rightarrow \quad$ Flag 14
$\mathrm{K} 2 \rightarrow \quad$ Flag 13
$\mathrm{K} 1 \rightarrow \quad$ Flag 12
Short Timer - Time difference $\rightarrow$ Short Timer
Long Timer - Time difference $\rightarrow$ Long Timer
If Short Timer $\leq 0$
Short Timer + Short Timer Buffer $\rightarrow$ Short Timer
ST = 1 (Group 1 Flag 11)
If Long Timer $\leq 0$
Long Timer + Long Timer Buffer $\rightarrow$ Long Timer
LT = 1 (Group 1 Flag 10)
PURPOSE: Updating timers and K-inputs during Active Mode.
DESCRIPTION: The Short Timer and Long Timer are actualized and the K -Port is read in. The actualization is only made for an activated timer, a stopped timer is not affected. The time difference since the last update is subtracted from the timers. If a timer reaches 0 or is counted below 0 , the last loaded value, which is stored in the Timer Buffer, is added to the timer. This ensures stable timing as long as underflow doesn't occure twice in sequence. The appropriate flag is set, too. (The two flags ST and LT are reset only by the user's program, never by the interpreter). DL8 is not changed, if it is set, the contents of the K-Port Latch are read into the Group 1 flags 12 to 15.

PARAMETER: none

### 3.9.5 Read K-Input

MNEMONIC: KIN
STATUS: $\quad$ If $\mathrm{K} 8=\mathrm{K} 4=\mathrm{K} 2=\mathrm{K} 1=0$
$Z E R O=1 \quad P O S=X \quad N E G=X$
Otherwise
$Z E R O=0 \quad P O S=X \quad N E G=X$
ACTION: $0 \rightarrow$ DL8
K8 $\rightarrow$ Group 1 Flag 15
K4 $\rightarrow \quad$ Flag 14
K2 $\rightarrow \quad$ Flag 13
K1 $\rightarrow \quad$ Flag 12
K-Port $\rightarrow \quad$ FLAC LSD
PURPOSE: Reading K-Port to flags and FLAC for testing.
DESCRIPTION: DL8 is switched to Oto set the K-Port to input direction. The K-Port is read into the Group 1 flags 12 to 15 and the FLAC's LSD without disturbing the other digits.
PARAMETER: none

### 3.9.6 Output LSD of FLAC to K-Port

MNEMONIC: FLKOUT
OPCODE: F0
STATUS: not affected
ACTION: $\quad 1 \rightarrow$ DL8
FLAC LSD $\rightarrow$ K-Port
PURPOSE: Outputting FLAC's LSD to the K-Port.
DESCRIPTION: The LSD of the FLAC is transferred to the K-Port Latch. DL8 is set, switching the K-Port to the output direction.

PARAMETER: none

[^14]EXAMPLE: The FLAC is to be output at the K-Port starting with the LSD. After each nibble R5 is to be set and reset for clocking.

| R5 | EQU | 5 |  |
| :--- | :--- | :--- | :--- |
|  | LOCNT1 | 8 | USE COUNTER 1 FOR COUNTING |
| LOOP | FDCNTUT |  | LSD OF FLAC -> K-PORT |
|  | FLKOR | R5 | OUTPUT CLOCK AT R5 |
|  | RSTR | R5 |  |
|  | SHIFTR1 |  | SHIFT NEXT NIBBLE TO LSD |
|  | DECCNT1 |  | DECREMENT COUNTER 1 |
|  | JNZ | LOOP | IF COUNTER 1 \# 0: NEXT NIBBLE |
|  | $\cdots$ |  | IS 0: 8 NIBBLES ARE OUTPUT |

Example 11: Outputting of the FLAC with clocks

### 3.9.7 Output Constant to K-Port

MNEMONIC: KOUT n

## OPCODE: F1

STATUS: not affected
ACTION: $\quad 1 \rightarrow$ DL8
$n \rightarrow$ K-Port ( $0 \leq n<16$ )
PURPOSE: Outputting of constants to the K-Port.
DESCRIPTION: The operand n is transferred to the K-Port Latch. DL8 is set, switching the K-Port to the output direction.
PARAMETER: 1 byte containing the operand n . Two byte instruction.
EXAMPLE: $\quad \mathrm{K} 1$ and K 4 are to be set
OUT $5 \quad$ SET K1 AND K4
Example 12: Outputting of a constant to the K-Port

### 3.10 Rrogram Flow Control Instructions

See also chapter Subroutine Software.

### 3.10.1 Jump Unconditional

MNEMONIC: JMP LABEL OPCODE: 60-67
STATUS: not affected
ACTION: $\quad W \rightarrow P C$
PURPOSE: Allows the program to alter the normal sequential program execution.
DESCRIPTION: The JMP instruction jumps unconditionally to the address W specified by the label. The three MSBs are defined with 3 bits in the 1st byte of the instruction, the eight LSBs are defined by the 2nd byte of the instruction. The assembler generates both bytes of this 2 byte instruction automatically.

PARAMETER: None. Two byte instruction.

### 3.10.2 Jump if Zero, Jump if Equal

MNEMONICS: JZ LABEL OPCODE: 70-77

STATUS: not affected
ACTION: If ZERO $=0 \quad \mathrm{PC}+2 \rightarrow \mathrm{PC}$
If $\mathrm{ZERO}=1 \mathrm{~W} \rightarrow \mathrm{PC}$
PURPOSE: Allows the program to alter the normal sequential program execution if the ZERO Bit is set.

DESCRIPTION: The JZ or JEQ instruction jumps to the address W specified by the label if the ZERO Bit is set. If the ZERO Bit is reset, the instruction following will be executed.

PARAMETER: None. Two byte instruction.
3.10.3 Jump if not Zero, Jump if not Equal

MNEMONIC: JNZ LABEL OPCODE: 78-7F JNE LABEL

STATUS: not affected
ACTION: If ZERO $=0 \quad \mathrm{~W} \rightarrow \mathrm{PC}$
If $Z E R O=1 \quad P C+2 \rightarrow P C$
PURPOSE: Allows the program to alter the normal sequential program execution if the ZERO Bit is reset.
DESCRIPTION: The JNZ or JNE instruction jumps to the address W specified by the label if the ZERO Bit is 0 . If the ZERO Bit is set, the instruction following will be executed.
PARAMETER: None. Two byte instruction.

### 3.10.4 Jump if Positive

MNEMONIC: JP LABEL
STATUS: not affected
ACTION: If $\mathrm{POS}=0 \mathrm{PC}+2 \rightarrow \mathrm{PC}$
If $\mathrm{POS}=1 \mathrm{~W} \rightarrow P C$
PURPOSE: Allows the program to alter the normal sequential program execution if the POS Bit is set.
DESCRIPTION: The JP instruction jumps to the address $W$ specified by the label if the POS Bit is 1 . If the POS Bit is 0 the instruction following will be executed.
PARAMETER: None. Two byte instruction.

### 3.10.5 Jump if Negative

MNEMONIC: JN LABEL OPCODE: 88-8F
STATUS: not affected
ACTION: If NEG $=0 \mathrm{PC}+2 \rightarrow \mathrm{PC}$
If $N E G=1 \mathrm{~W} \rightarrow P C$
PURPOSE: Allows the program to alter the normal sequential program execution if the NEG Bit is set.
DESCRIPTION: The JN instruction jumps to the address W specified by the label if the NEG Bit is 1 . If the NEG Bit is 0 , the instruction following will be executed.

PARAMETER: None. Two byte instruction.

### 3.10.6 Call Subroutine

MNEMONIC: CALL LABEL
OPCODE: 68-6F
STATUS: not affected
ACTION: $\quad$ SR2 $\rightarrow$ SR3
SR1 $\rightarrow$ SR2
PC $+2 \rightarrow$ SR1
$\mathrm{W} \rightarrow \mathrm{PC}$
PURPOSE: Allows the program the control transfer to a subroutine. Because the CALL instruction saves the return address, subroutines may be called from various locations in a program. The subroutine will return control back to the proper, saved address after the return instruction RETN.

DESCRIPTION: The CALL instruction invokes a subroutine starting at the label's address W and pushes the return address onto the subroutine stack.
The stack's depth is 3 . This allows 3 levels of subroutine nesting. If a 4 th level of subroutine nesting is entered, the return address stored in SR3 is lost.

[^15]PARAMETER: None. Two byte instruction.
3.10.7 Return from Subroutine

MNEMONIC: RETN
OPCODE: D4
STATUS: not affected
ACTION: SR1 $\rightarrow$ PC
SR2 $\rightarrow$ SR1
SR3 $\rightarrow$ SR2
PURPOSE: Returning from a subroutine to the address following the CALL of the subroutine.

DESCRIPTION: The Program Counter is loaded from the top of the subroutine stack. Then the stack is raised one level up, leaving the next return address on top of the subroutine stack. If the instruction RETN is used outside of a subroutine non predictable results will occur.

PARAMETER: none.

### 3.11 Analog-Digital-Converter Instructions

### 3.11.1 Set Converter Supply Voltage

MNEMONIC: SVDDON
OPCODE: 07
STATUS: not affected
ACTION: $\quad S V_{D D}$ is switched on.
PURPOSE: Supplying the ADC part and sensors with voltage.
DESCRIPTION: The supply converter voltage is switched to the SV $_{\text {DD }}$ pin and the internal resistor network of the ADC comparator.

PARAMETER: none
3.11.2 Reset Converter Supply Voltage
MNEMONIC: SVDDOFF
OPCODE: 17
STATUS: not affected
ACTION: $\quad S V_{D D}$ is switched off.
PURPOSE: Switching off the ADC part.
DESCRIPTION: The supply converter voltage $S V_{D D}$ is switched off.
PARAMETER: none

Note: The supply converter voltage $\mathrm{SV}_{\mathrm{DD}}$ is also switched off too by initialization and the instructions DONE and OFF. Also the instruction MEASR switches the SV $_{\text {DD }}$ off after the completed measurement.
3.11.3 Measure Addressed A/D Input

MNEMONIC: MEASR a OPCODE: AC - AF BYTE NNN

STATUS: If $0<A D C<>F F F$ $\mathrm{POS}=1 \mathrm{ZERO}=0 \quad \mathrm{NEG}=0$

If ADC Value $=000$
$\mathrm{POS}=0 \mathrm{ZERO}=1 \quad \mathrm{NEG}=1$
If ADC Value $\rightarrow$ FFF
$\mathrm{POS}=0 \mathrm{ZERO}=0 \quad \mathrm{NEG}=1$
ACTION: $\quad$ DL9 $\leftarrow 0$
$S V_{D D}$ on
Adding up ADC results of analog input $A(a+1)$ in the ADC buffer. Final result $\rightarrow$ FLAC.
SV ${ }_{D D}$ off
PURPOSE: $\quad$ Single or double (compensated) measurements may be defined for the addressed analog input $A(a+1)$.

Revision 1, November 1990

DESCRIPTION: The analog input addressed by the operand a is switched to the ADC and measured CNT+1 times. CNT, which ranges from 0 to 127 , is defined in the byte following the instruction. See Figure 29.
Compensated measurements: If the MSB M of the parameter byte is zero, CNT +1 measurements with noninverted comparator inputs and CNT +1 measurements with inverted comparator inputs are accumulated. This compensates the offset error of the internal comparator.
Single measurements: If the MSB M of the parameter byte is $1, C N T+1$ measurements with noninverted comparator inputs are accumulated.
The ADC value is tested after each measurement: If an error occured, the NEG Bit is set to one and the measurements are terminated. The ZERO Bit shows if overflow or underflow occured. $\mathrm{SV}_{\mathrm{DD}}$ is switched on before the measurements and is switched off after completion.

The result of the measurements is placed into the FLAC.
PARAMETER: The byte following the opcode contains the number of measurements CNT and the single/compensated information $M$ in the MSB.


0 : Compensated Measurements (CNT+1) • 2
1: Single Measurements (CNT+1)
Figure 29: Parameter byte of the MEASR instruction

EXAMPLE: Analog input A3 is to be measured 50 times in compensated mode. The result in BCD is to be loaded into the FLAC. If an error occurs program has to continue at labels OVFL resp. UNFL depending on the reason for the error.

| A3 | EQU | 2 |  |
| :--- | :--- | :--- | :--- |
|  | MEASR | A3 |  |
|  | BYTE | 49 | MEASURE A3 |
|  | JN | ERROR | ADD 49+1 COMPENSATED RESULTS |
|  | HEXDEC |  | NO, CONVERT RESULT TO BCD |
|  | $\cdots$ |  | RESULT IN FLAC |
|  |  |  | UNDERFLOW OCCURED |
| ERROR | JZ |  |  |
| OVFL | $\cdots$ |  |  |

Example 13: Measurement with error checking

### 3.11.4 Adjust Battery Voltage

MNEMONIC: ADJBATT OPCODE: E8
STATUS: If $0<A D C<>$ FFF
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $\mathrm{ADC}=000$
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=1$
If $\mathrm{ADC} \geq \mathrm{FFF}$
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: $1 \rightarrow$ DL9
ADC $\rightarrow$ FLAC
PURPOSE: Battery measurement under Vddmin conditions for later battery checks.

DESCRIPTION: The value of the internal reference voltage is measured with a single measurement and the ADC hex value is stored in the 3 LSDs of the cleared FLAC. See examples in chapter 7.
PARAMETER: none

### 3.11.5 Check Battery Voltage

MNEMONIC: CHKBATT OPCODE: EA

STATUS: If Vdd > Vddmin:
POS = 1 NEG = 0 ZERO $=0$
If Vdd < Vddmin
$P O S=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad 1 \rightarrow$ DL9
Comparison of the FLAC with the internal reference voitage.
PURPOSE: Battery voltage measurement for Vddmin check.
DESCRIPTION: The ADC measurement value of the internal reference voltage is compared against the hex value contained in the FLAC. Only a single measurement is made. See examples in chapter 7.
PARAMETER: none

### 3.11.6 Adjust Comparator Voltage

MNEMONIC: ADJCOMP
OPCODE: E9
STATUS: If $0<A D C$ < $\operatorname{FFF}$
$\mathrm{POS}=1 \mathrm{NEG}=0 \mathrm{ZERO}=0$
If $A D C=000$
$\mathrm{POS}=0$ NEG $=1 \mathrm{ZERO}=1$
If $A D C \geq$ FFF
$\mathrm{POS}=0 \mathrm{NEG}=1 \mathrm{ZERO}=0$
ACTION: $0 \rightarrow$ DL9
ADC $\rightarrow$ FLAC
PURPOSE: ADC measurement for later comparisons.
DESCRIPTION: The ADC measurement value of the addressed analog input is measured with a single measurement. The ADC hex value is stored in the cleared FLAC's LSDs.

PARAMETER: none
Note: The analog input to be measured has to be addressed explicitly by DL10 and DL11. See Figure 6 for addressing.

### 3.11.7 Check Comparator Voltage

MNEMONIC: CHKCOMP OPCODE: EB
STATUS: If Vadc $>$ Vin:
POS = 1 NEG = 0 ZERO $=0$
If Vadc < Vin:
$P O S=0$ NEG $=1 \mathrm{ZERO}=0$
ACTION: $\quad 0 \rightarrow$ DL9
Comparison of the FLAC with the addressed analog input.
PURPOSE: Comparison of input voltages with stored ADC values.
DESCRIPTION: The addressed analog input is compared against the hex value contained in the FLAC. Only a single measurement is made.

PARAMETER: none
Note: The analog input to be measured has to be addressed explicitly by DL10 and DL11. See Figure 6 for addressing.

EXAMPLE: The analog input A4 is to be measured for later comparisons. The ADC value is to be stored in STO4. The stored value is to be compared later against the analog input A3. If the voltage at A3 is higher than the stored value, then a subroutine LEVEL is to be invoked.

| SETR | DL10 | ADDRESS A4: DL10 = DL11 = 1 |
| :--- | :--- | :--- |
| SETR | DL11 |  |
| ADJCOMP |  | MEASURE A4 AND STORE RESULT IN FLAC |
| MOVFLSTO | 4 |  |
| $\cdots$ |  |  |
| STORE RESULT IN STO4 |  |  |

Example 14: Comparing of two analog voltages

### 3.12 Display Instructions

The display used by the TSS400 Standard is configured like shown below:

|  | MSD |  |  |  |  |  | LSD |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Digit n | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| Select | S1/2 | S3/4 | S5/6 | S7/8 | S9/10 | S11/12 | S13/14 |
| Magnitude | 10E6 | 10E5 | 10E4 | 10E3 | 10E2 | 10E1 | 10E0 |

Figure 30: Display configuration

### 3.12.1 Display Digit

MNEMONIC: DISPLDGn > NN OPCODE: B1-B7
STATUS: not affected
ACTION: $\quad$ Byte info $>\mathrm{NN} \rightarrow$ Digit $\mathrm{n}(0<\mathrm{n}<8)$
PURPOSE: Change of a single display digit e.g. after displaying the FLAC.

DESCRIPTION: The operand is interpreted in two ways as shown below. The resulting character is displayed in the addressed digit n .


Figure 31: Operand byte of the DISPLDGn instruction

Two different formats exist for the operand. They differ in the MSB of the operand:

MSB $=0$ : The six least significant bits define the character number which is output to the addressed display digit. The character numbers are defined in Figure 15.
$M S B=1$ : The contents of the according FLAC digit (0-15) are output, depending on the bits $\mathrm{H}, \mathrm{M}, \mathrm{Z}$ and Block to the addressed display digit.

## The bits H , Block, M and Z have the following meaning:

$\mathrm{H}: \quad$ If set, the segment H of the digit is displayed independently of the according H -segment bit in Flag Group 1. If reset, the according H -segment bit in Flag Group 1 decides if the segment H is switched on or off.
Block: These two bits define the block of the character numbers to be used. If the contents of the current digit are to be output, the block 0 (numbers 0-9 and characters A-F) is to be used. Block 1 is to be used, if characters outside A $F$ are to be output. If combinations of the segments AFB

G E and H are to be output dependent on the contents of the current digit, the blocks 2 and 3 are to be used.

M: If set, a minus sign (segment $G$ ) is output at the addressed digit if the FLAC's sign is negative. If the FLAC's sign is positive or if $M$ is reset, the addressed digit is handled normally.

Z: If set, leading zero suppression is made for the addressed digit. This means, the digit is blanked if it contains zero. If reset, a zero is treated like other numbers.

Note: The bits $M$ and $Z$ are normally senseless if not used with OPLA block 0 . They should be zero if blocks 1 to 3 are used.

PARAMETER: 1 byte added by the asssembler containing the display information. Two byte instruction.

EXAMPLE: The FLAC is to be displayed with leading zeroes suppressed and no segment H. If Flag Bit 4 of Flag Group 2 is set, the 20th character of the OPLA is to be displayed at digit 1 with the segment H set. If the bit is reset, the 21st character without segment $H$ is to be displayed.

| H | EQU | $>40$ |  |
| :---: | :---: | :---: | :---: |
| Z | EQU | $>04$ |  |
|  | DİSPLFL | >17 | DISPLAY FLAC DIGIT 1 - 7 |
|  | BYTE | $20+\mathrm{H}$ | DIGIT 1 ASSUME BIT $4=1$ |
|  | BYTE | $>80+\mathrm{Z}$ | DIGIT 2 ZERO SUPPRESSED |
|  | BYTE | $>80+\mathrm{Z}$ |  |
|  | BYTE | $>80+2$ |  |
|  | BYTE | $>80+Z$ |  |
|  | BYTE | $>80+\mathrm{Z}$ |  |
|  | BYTE | $>80$ | DIGIT 7 NO ZERO SUPPRESSION |
|  | SELGRP2 |  | TEST FLAG BIT 4 GROUP 2 |
|  | TBIT | 4 |  |
|  | JNZ | BIT4SET | BIT $4=1:$ DISPLAY IS YET CORRECT |
|  | DISPLDG1 | 21 | BIT 4 = 0: DISPLAY TERM 21 (c) |
| BIT4SET | ... |  | U. 123 IF FLAC $=123$ OR |
|  | . . |  | c IF FLAC $=123$ |

Example 15: Display of the FLAC with additional terms

### 3.12.2 Clear Display

MNEMONIC: DISPLCLR
OPCODE: B8
STATUS: not affected
ACTION: Blanks $\rightarrow$ Display
PURPOSE: Clearing of the whole display.
DESCRIPTION: The display is filled with blank characters.
PARAMETER: none
EXAMPLE: The 22nd term of the OPLA is to be displayed at digit 2 with all other digits blanked:

```
DISPLCLR
DISPLDG2
```

BLANK THE WHOLE DISPLAY
DISPLAY TERM 22 AT DIGIT 2
h_ -> DISPLAY

```

Example 16: Display of one term
\begin{tabular}{ll} 
3.12.3 Display FLAC \\
MNEMONIC: & \begin{tabular}{l} 
DISPLFL \(>\) NN \\
BYTE \(>M M\)
\end{tabular} \\
& \(\ldots\) \\
BYTE \(>\) MM
\end{tabular}\(\quad\) OPCODE: BO

DESCRIPTION: The operand \(>\) NN defines the digits of the FLAC which are to be output to the display. The MSD defines the start digit, the LSD defines the end digit. E.g. >25 means, digit 2 to 5 ( 4 digits) are to be output. The display digits not involved in the operand stay unchanged. For each digit to be output, a parameter byte is needed. The number of parameter bytes is:
Operand's LSD - Operand's MSD + 1
The first parameter byte contains the information of the start digit, the last parameter byte contains the information of the end digit.

Note: It is the user's responsibilty to add the correct number of parameter bytes to the DISPLFL instruction. No errors or warnings are given by the assembler if the number mismatches with the instruction's operand.

The parameter bytes following the instruction are interpreted in two ways as shown below. The resulting character is displayed at the addressed digit:


Figure 32: Parameter byte of the DISPLFL instruction

Two different formats exist for the parameters. They differ in the MSB of the parameters:
\(M S B=0\) : The six least significant bits define the character number which is output to the according display digit. The character numbers are defined in Figure 15.
\(M S B=1:\) The contents of the according FLAC digit (0-15) are output to the according display digit, depending on the bits \(\mathrm{H}, \mathrm{M}, \mathrm{Z}\) and Block.

\section*{The bits \(H\), Block, \(M\) and \(Z\) have the following meaning:}
\(\mathrm{H}: \quad\) If set, the segment H of the digit is displayed independently of the according H -segment bit in Flag Group 1. If reset, the according H-segment bit in Flag Group 1 decides if the segment H is switched on or off.
Block: These two bits define the block of the character numbers to be used. If the contents of the current digit are to be output, block 0 (numbers 0-9 and characters A-F) has to be used. If characters outside A - F are to be output, Block 1 has to be used. If combinations of the segments AFB G E and H are to be output dependent on the contents of the current digit, block 2 and 3 have to be used.

M:
If set, a minus sign (segment G) is output at the according digit if the FLAC's sign is negative. If the FLAC's sign is positive, a blank character is output. If reset, the according digit is handled normally.
Z: If set, leading zero suppression is made for the according digit. This means, the digit is blanked if it contains zero and all digits left to it, beginning at the first displayed digit in the FLAC, are zero, too. If reset, a zero is treated like other numbers.

Note: The bits \(M\) and \(Z\) are normally senseless if used with OPLA block 1 to 3. They should be zero if these blocks are used.

Figure 33 shows the displayed information depending on the variables \(\mathrm{H}, \mathrm{M}\) and Z (block 0 ). Display 1 shows a FLAC containing - 00001234, Display 2 shows it containing +00000000 . The instruction used for the figure follows. The term INFO contains the \(\mathrm{H}, \mathrm{M}\) and Z bit.
\begin{tabular}{lllllll} 
DISPLFL & \(>17\) & DISPLAY FLAC DIGIT 1 TO 7 \\
BYTE & 14 & DIGIT 1 MSD: E & & \\
BYTE & \(>80+Z\) & & & & \\
BYTE & \(>80+\) INFO & DIGIT 3 CONTAINS THE VARIABLE \\
BYTE & \(>80\) & & & & \\
BYTE & \(>80\) & & & \\
BYTE & \(>80\) & & & \\
BYTE & \(>80\) & DIGIT 7 LSD
\end{tabular}

INFO:
\begin{tabular}{lllll}
H & M & Z & Display 1 & Display 2 \\
\hline 0 & 0 & 0 & \(\mathrm{E}_{-} 01234\) & \(\mathrm{E}-00000\) \\
0 & 0 & 1 & \(\mathrm{E}-1234\) & \(\mathrm{E}-0000\) \\
0 & 1 & 0 & \(\mathrm{E}_{-}-1234\) & \(\mathrm{E}-0000\) \\
0 & 1 & 1 & \(\mathrm{E}_{-}-1234\) & \(\mathrm{E}-0000\) \\
1 & 0 & 0 & \(\mathrm{E}_{-} 0.1234\) & \(\mathrm{E}-0.0000\) \\
1 & 0 & 1 & \(\mathrm{E}_{-} .1234\) & \(\mathrm{E}-.0000\) \\
1 & 1 & 0 & \(\mathrm{E}_{-} .1234\) & \(\mathrm{E}-.0000\) \\
1 & 1 & 1 & \(\mathrm{E}_{-}-.1234\) & \(\mathrm{E}-.0000\)
\end{tabular}

Figure 33: Display depending on the DISPLFL Para meter

PARAMETER: 1 byte added by the assembler containing the operand information >NN which digits are to be displayed. For each digit involved by the operand an additional parameter byte is to be added by the user.

EXAMPLE: The Storage Register 5 is to be displayed with the decimal point (segment H ) on at digit 5 . Leading zero suppression is needed. The sign is to be located at digit 1.
\begin{tabular}{|c|c|c|c|}
\hline H & EQU & \(>40\) & H SEGMENT ON \\
\hline M & EQU & \(>08\) & SIGN (-) ON IF NEGATIVE \\
\hline Z & EQU & \(>04\) & LEAD. ZERO SUPPRESSION ON \\
\hline & MOVSTOFL & 5 & STO5 -> FLAC \\
\hline & DISPLFL & \(>17\) & DISPLAY FLAC: - X.XX \\
\hline & BYTE & \(>80+\mathrm{Z}+\mathrm{M}\) & DIGIT 1 CONTAINS SIGN \\
\hline
\end{tabular}
\begin{tabular}{lllll} 
BYTE & \(>80+Z\) & DIGIT 2 & & \\
BYTE & \(>80+Z\) & DIGIT 3 & & \\
BYTE & \(>80+Z\) & DIGIT 4 & & \\
BYTE & \(>80+H\) & LIGIT 5 & WITH & DEC. POINT \\
BYTE & \(>80\) & DIGIT 6 & & \\
BYTE & \(>80\) & DIGIT 7
\end{tabular}

\section*{Example 17: Display with variables \(\mathrm{Z}, \mathrm{M}\) and H}

EXAMPLE: The FLAC is to be output to the display digits 1 to 6 . The digit 7 contains mode information in the especially designed segments A F B G and E. The mode information A F B G is stored in the FLAC's LSD. The segment \(E\) information is contained in bit 0 of Flag Group 1. The nonstructured combinations cannot occur.
\begin{tabular}{|c|c|c|c|}
\hline BL2 & EQU & \(>20\) & OPLA BLOCK 2 (A F B G) \\
\hline \multirow[t]{12}{*}{BL3} & EQU & \(>30\) & OPLA BLOCK 3 (A F B G E) \\
\hline & DISPLFL & >16 & DISPLAY FLAC DIGIT 1 TO 6 \\
\hline & BYTE & \(>80\) & DIGIT 1 \\
\hline & BYTE & \(>80\) & DIGIT 2 \\
\hline & BYTE & >80 & DIGIT 3 \\
\hline & BYTE & \(>80\) & DIGIT 4 \\
\hline & BYTE & \(>80\) & DIGIT 5 \\
\hline & BYTE & \(>80\) & DIGIT 6 \\
\hline & SELGRP1 & & SEGMENT E ON ? \\
\hline & TBIT & 0 & \\
\hline & JNZ & SEGEON & YES \\
\hline & DISPLDG7 & \(>80+\) BL 2 & NO, ONLY A F B G \\
\hline SEGEON & DISPLDG7 & \(>80+\mathrm{BL} 3\) & YES, DISPLAY WITH E \\
\hline
\end{tabular}

Example 18: Display of segment combinations

\subsection*{3.13 Miscellaneous Instructions}

\subsection*{3.13.1 Enter Done Mode}

MNEMONIC: DONE
OPCODE: D2
STATUS: not affected
ACTION: CPU part is switched off. SV \(_{\text {DD }}\) is switched off. EEPROM is switched off.

PURPOSE: Current saving by deactivation of unnecessary parts.
DESCRIPTION: The CPU part is switched off, mainly only RAM, the LCD driver and the timers stay active. The ADC supply voltage \(\mathrm{SV}_{\mathrm{DD}}\) and the EEPROM voltage are switched off, too. Wake-up occurs at the instruction following the DONE instruction. See Figure 8 and 9 for wake-up conditions.
PARAMETER: none

\subsection*{3.13.2 Enter Off Mode}

MNEMONIC: OFF
OPCODE: D3
STATUS: not affected
ACTION: CPU, SV \(\quad\), EEPROM, LCD and timers are switched off.
PURPOSE: Current saving by deactivation of not necessary parts.
DESCRIPTION: The CPU and the timers are switched off, only the RAM stays active. Events at the inputs which would wake up the CPU from Done Mode, will wake up the CPU from Off Mode, too. See Figure 8 and 9 for the wake-up conditions. The ADC supply voltage \(\mathrm{SV}_{\mathrm{DD}}\) and the EEPROM voltage are switched off, too. Wake-up will occur at the address following the OFF instruction.
PARAMETER: none

\subsection*{3.13.3 No Operation}

MNEMONIC: NOP OPCODE: 00 or FF
STATUS: not affected
ACTION: \(\quad P C+1 \rightarrow P C\)
PURPOSE: Code for doing nothing definitively: Deleting of opcodes during debugging. Insertion of delays.
DESCRIPTION: The next instruction is read.
PARAMETER: none

\subsection*{3.14 Counter Instructions}

Two decimal counters exist (Counter 1 and Counter 2) which are identical in its single use. The descriptions use n for 1 or 2 respectively.

\subsection*{3.14.1 Decrement Counter n}

MNEMONIC: DECCNTn
OPCODE: D8-D9
\begin{tabular}{ll} 
STATUS: & If Result \(=0\) \\
& ZERO \(=1\) POS \(=X\) NEG \(=X\) \\
& If Result \# 0 \\
& ZERO \(=0\) POS \(=X\) NEG \(=X\)
\end{tabular}

ACTION: \(\quad\) Counter \(\mathrm{n}-1 \rightarrow\) Counter \(\mathrm{n} \quad(0<\mathrm{n}<3)\)
PURPOSE: Counting down of Counter \(n\) decimally until zero is reached.
DESCRIPTION: The Counter n is decremented and the ZERO Bit set or reset according to the result.
PARAMETER: none

Revision 1, November 1990

EXAMPLE: \(\quad 50\) compensated measurements are to be added for the ADC input A3. If an error occurs during these measurements, this is to be tried 5 times. After 5 effortless trials an error message is to be output.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{A3} & EQU & 2 & \\
\hline & LDCNT1 & 5 & LOAD COUNTER 1 WITH 5 TRIALS \\
\hline \multirow[t]{4}{*}{LOOP} & MEASR & A3 & ADD UP 50 COMP. MEASUREMENTS \\
\hline & BYTE & 49 & \\
\hline & JN & CNTDWN & ERROR ? \\
\hline & & & NO, MEASUREMENTS OK, PROCEED \\
\hline \multirow[t]{3}{*}{CNTDWN} & \multicolumn{2}{|c|}{DECCNT1} & YES, DECR. TRIAL COUNT \\
\hline & JNZ & LOOP & AND TRY ONCE MORE \\
\hline & CALL & ERRMSG & 5 EFFORTLESS TRIALS: ERROR \\
\hline
\end{tabular}

\section*{Example 19: Usage of a counter for repetitions}

\subsection*{3.14.2 Increment Counter n}

MNEMONIC: INCCNTn
STATUS: If Result \(=0\) ( 99 before)
ZERO \(=1\) POS \(=X\) NEG \(=X\)
If Result \# 0
\(Z E R O=0\) POS \(=X\) NEG \(=X\)
ACTION: \(\quad\) Counter \(\mathrm{n}+1 \rightarrow\) Counter \(\mathrm{n} \quad(0<\mathrm{n}<3)\)
PURPOSE: Counting up of Counter \(n\) decimally until zero (100) is reached.

DESCRIPTION: The Counter n is incremented and the ZERO Bit set if the counter overflows to 100 . The ZERO Bit is reset otherwise.

PARAMETER: none

\subsection*{3.14.3 Decrement Double Counter}

MNEMONIC: DECDBL OPCODE: DA
STATUS: If Result \(=0000\)
ZERO = 1 POS \(=X\) NEG \(=X\) If Result \# 0000 ZERO \(=0\) POS \(=X\) NEG \(=X\)

ACTION: A decimal counter consisting of Counter 2 (MSD) and Counter 1 (LSD) is decremented by 1.

PURPOSE: Counting down a decimal counter of doubled length.
DESCRIPTION: The counter consisting of the connected Counters 1 and 2 is decremented and the ZERO Bit set if the result is 0000. The ZERO Bit is reset otherwise.

PARAMETER: none

\subsection*{3.14.4 Increment Double Counter}

MNEMONIC: INCDBL
OPCODE: DD
STATUS: If Result \(=0000\) ( 9999 before) ZERO = 1 POS \(=X\) NEG \(=X\) If Result \# 0000 ZERO \(=0\) POS \(=X\) NEG \(=X\)

ACTION: A decimal counter consisting of Counter 2 (MSD) and Counter 1 (LSD) is incremented by 1.
PURPOSE: Counting up a decimal counter of doubled length.
DESCRIPTION: The counter consisting of the connected Counters 1 and 2 is incremented and the ZERO Bit set if the counter overflows to 10000 . The ZERO Bit is reset otherwise.

PARAMETER: none

\subsection*{3.14.5 Load Counter n Decimal}

MNEMONIC: LDCNTn >NN OPCODE: DE - DF
STATUS: not affected
ACTION: \(\quad>\mathrm{NN} \rightarrow\) Counter \(\mathrm{n} \quad(0<\mathrm{n}<3)\)
\(\mathrm{PC}+2 \rightarrow \mathrm{PC}\)
PURPOSE: Loading Counter \(n\) with a decimal value.
DESCRIPTION: The value of the operand is loaded into Counter n.The PC is adjusted to point to the next following instruction.

PARAMETER: 1 byte added by the assembler containing the decimal value in BCD format. ">" is used to assure BCD format. Two byte instruction.
EXAMPLES: The Counter 2 is to be loaded with the value 89:
```

LDCNT2 >89 LOAD COUNTER 2 WITH 89

```

The counters are to be loaded with the decimal value 1234 for combined counting.
\begin{tabular}{lll} 
LDCNT2 & \(>12\) & LOAD COUNTER 2 WITH MSDs \\
LDCNT1 & \(>34\) & LOAD COUNTER 1 WITH LSDS \\
\(\ldots\). & READY FOR DOUBLE INCR/DECR
\end{tabular}

Example 20: Loading of the counters

\subsection*{3.14.6 Move Counter \(\boldsymbol{n}\) to REGB}

MNEMONIC: MOVCNTn
STATUS: If Counter \(\mathrm{n}=00\)
\[
\begin{aligned}
& Z E R O=1 \quad \mathrm{POS}=1 \quad \mathrm{NEG}=0 \\
& \text { If Counter } n \# 00 \\
& Z E R O=0 \text { POS }=1 \quad \text { NEG }=0
\end{aligned}
\]

ACTION: \(0 \rightarrow\) REGB
Counter \(\mathrm{n} \rightarrow\) REGB \(\quad(0<\mathrm{n}<3)\)

PURPOSE: Loading Counter \(n\) to the REGB for comparing or computing.
DESCRIPTION: Counter n is transferred into the LSDs of the cleared REGB.

PARAMETER: none
3.14.7 Move Combined Counters to REGB

MNEMONIC: MOVDBL OPCODE: F7
STATUS: If Counters \(=0000\)
ZERO = 1 POS = 1 NEG = 0
If Counters \# 0000
\(Z E R O=0\) POS \(=1\) NEG \(=0\)
ACTION: \(0 \rightarrow\) REGB
Counter \(1 \rightarrow\) REGB 10E1-10E0
Counter \(2 \rightarrow\) REGB 10E3-10E2
PURPOSE: Loading of the combined counters to the REGB for comparing or computing.
DESCRIPTION: The combined counters are transferred into the LSDs of the cleared REGB. Counter 2 contains the MSDs.

PARAMETER: none

\subsection*{3.15 Timer Instructions}

\subsection*{3.15.1 Load Timer Long}

MNEMONIC: LDTIML NNN
OPCODE: D0
STATUS: not affected
\begin{tabular}{ll} 
ACTION: & NNN \(\rightarrow\) Long Timer \(\quad(0 \leq\) NNN < 256) \\
& NNN \(\rightarrow\) Long Timer Buffer \\
& \(0 \quad \rightarrow\) LT Group 1 Flag 10 \\
& start of Long Timer;
\end{tabular}

PURPOSE: Loading and starting of the Long Timer.
DESCRIPTION: The operand NNN is loaded into the timer counting seconds. A zero operand means 256 seconds. The value NNN is stored in the Long Timer Buffer too for restoring of the Long Timer when its contents reach or pass zero. The Group 1 Flag 10 (LT) is reset.

Note: The first timer interval after starting has an uncertain duration due to the asynchronous start inside the hardware timer's sequence. The first time interval has an uncertainity of up to 1 second. The Long Timer remains active until the instruction STPTIML occurs.

PARAMETER: One byte added by the assembler containing the timer value. Two byte instruction.

EXAMPLE: The timer is to be loaded with 2 seconds.
```

LDTIML 2 LOAD SECONDS COUNTER
WITH 2 SECONDS

```

Example 21: Loading of the long timer

\subsection*{3.15.2 Load Timer Short}

MNEMONIC: LDTIMS NNN
STATUS: not affected

ACTION: \(\quad\) NNN \(\rightarrow\) Short Timer \(\quad(0 \leq\) NNN \(<256)\)
NNN \(\rightarrow\) Short Timer Buffer
\(0 \quad \rightarrow\) ST Group 1 Flag 11
start of Short Timer;
PURPOSE: Loading and starting of the Short Timer.
DESCRIPTION: The operand NNN is loaded into the timer counting \(1 / 16\) s. A zero operand means 256/16 seconds. The value NNN is stored in the Short Timer Buffer too for restoring of the Short Timer when its contents reach or pass zero. The Group 1 Flag 11 (ST) is reset.

Note: The first timer interval has an uncertain duration due to the asynchronous start inside the hardware timer's sequence. The first time interval has an uncertainity of up to \(1 / 16\) second.
The Short Timer remains active until the STPTIMS instruction occurs.
It is the user's responsibility to set the Digit Latch DL12 to one, if the Short Timer is to be used. The Short Timer will not operate with a reset DL12.

PARAMETER: One byte added by the assembler containing the timer value. Two byte instruction.
EXAMPLE: The Short Timer is to be loaded with 0.5 seconds. The Long Timer is to be loaded with 256 seconds.
```

SETR DL12
LDTIMS 8
LDTIML 0
SET DL12 FOR THE SHORT TIMER
LOAD 1/16 S COUNTER: 0.5 S (8/16)
LOAD TIMER FOR SECONDS
WITH 256 SECONDS (0)

```

Example 22: Loading of both timers

\subsection*{3.15.3 Actualize Timers}

MNEMONIC: ACTTIM
OPCODE: 10
STATUS: not affected
ACTION: \(\quad\) Short Timer - Time difference \(\rightarrow\) Short Timer Long Timer - Time difference \(\rightarrow\) Long Timer
If Short Timer \(\leq 0\)
Short Timer + Short Timer Buffer \(\rightarrow\) Short Timer
ST = 1 (Group 1 Flag 11)
If Long Timer \(\leq 0\)
Long Timer + Long Timer Buffer \(\rightarrow\) Long Timer
LT = 1 (Group 1 Flag 10)
PURPOSE: Updating Long and Short Timer during Active Mode.
DESCRIPTION: The Short Timer and Long Timer are actualized, if activated. A stopped timer is not affected by this instruction.
The time difference since the last update is subtracted from the timers. If a timer reaches 0 or is counted below 0 , the last loaded value, which is stored in the according Timer Buffer, is added to the timer. This ensures stable timing as long as an underflow doesn't occure twice in sequence. The appropriate flag is set, too. (The two flags ST and LT are reset only by the user's program, never by the interpreter). To ensure stable timing without loosing of information the updating has to be done in time intervals ti. The conditions for ti are:
ti < loaded time by LDTIMS or LDTIML
and \(\quad t i \leq 15 / 16 s\) for the Short Timer
\(\mathrm{ti} \leq 15 \mathrm{~s}\) for the Long Timer
PARAMETER: none
EXAMPLE: The timers are to be updated during a period of computation intensive tasks. The flag checking part is shown, too.
\begin{tabular}{|c|c|c|c|}
\hline LT & EQU & 10 & LONG TIMER FLAG \\
\hline \multirow[t]{11}{*}{ST} & EQU & 11 & SHORT TIMER FLAG \\
\hline & MOVSTORB & 2 & STO2 -> REGB \\
\hline & MPY & & STO2 x FLAC \\
\hline & ACTTIM & & UPDATE TIMERS AFTER MULTIPLY \\
\hline & SHIFTL2 & & FLAC x 100 \\
\hline & MOVPRMRB & CONSTANT & CONSTANT \(->\) REGB \\
\hline & DIV & & FLAC x 100 : CONSTANT \\
\hline & ACTTIM & & UPDATE TIMERS AFTER DIVISION \\
\hline & SELGRP1 & & ADDRESS TIMER FLAGS \\
\hline & TBIT & LT & LONG TIMER COUNTED DOWN ? \\
\hline & JNZ & LTOV & YES \\
\hline \multirow[t]{3}{*}{L\$400} & TBIT & ST & SHORT TIMER COUNTED DOWN ? \\
\hline & JNZ & STOV & \\
\hline & & & CONTINUE PROGRAM \\
\hline \multirow[t]{3}{*}{LTOV} & RBIT & LT & RESET LT FLAG \\
\hline & & & DO THINGS NECESSARY \\
\hline & JMP & L\$400 & CHECK THE ST FLAG \\
\hline STOV & RBIT & ST & RESET ST FLAG \\
\hline
\end{tabular}

Example 23: Updating of the timers during active mode

\subsection*{3.15.4 Stop Long Timer}

MNEMONIC: STPTIML
STATUS: not affected
ACTION: The Long Timer is stopped. \(0 \rightarrow\) LT (Group 1 Flag 10)

PURPOSE: Deactivation of Long Timer.
DESCRIPTION: The Long Timer is stopped and the LT flag is reset. The LT flag stays reset until a LDTIML instruction restarts the Long Timer and underflow occurs afterwards.

PARAMETER: none

\subsection*{3.15.5 Stop Short Timer}

MNEMONIC: STPTIMS
STATUS: not affected

Revision 1, November 1990


Example 24: Loading and Stopping of a Timer

\subsection*{3.16 Host Control Instructions}

These instructions are implemented mainly for the connection of the TSS400 Standard to a host (Slave Mode). They may be used in normal environments too, if this is valuable.
MNEMONIC: SLV \(\quad\) NNN OPCODE: FA
STATUS: not affected
PURPOSE: I/O instructions when controlled by a host computer in the Slave Mode.
DESCRIPTION: The operand byte defines the function to be executed in the Slave Mode:


Figure 34: Operand Byte of the SLV Instruction
\begin{tabular}{|c|c|}
\hline Code 0 & \begin{tabular}{l}
Ouput Status Bits during Rx is \(\mathbf{H I}\) \\
The Sign nibble of the FLAC and the Status Bits are output to the l/O Pin in the following order: Sign, 3 dummy bits, POS, ZERO, NEG, 1 dummy bit. Rx is HI during the 8 bit transfer.
\end{tabular} \\
\hline Code 1 & \begin{tabular}{l}
Output FLAC during Rx is HI \\
The FLAC content is output to the I/O Pin starting with the MSB of the MSD and ending with the LSB of the Sign nibble. Then the Status Bits are output in the following order: POS, ZERO, NEG, 1 dummy bit. Rx is HI during the transfer of these \(10 \times 4\) bits.
\end{tabular} \\
\hline Code 2 & \begin{tabular}{l}
Read RAM in during Rx is HI \\
The complete RAM is read in. The transfer starts with the MSB of the nibble \(\mathrm{Y}=0\) located in X-bank 1 and ends with the LSB of the nibble \(Y=15\) in X -bank 15. See figure 37 for the sequence. Rx is HI during the transfer of these \(9 \times 16 \times 4\) bits.
\end{tabular} \\
\hline Code 3 & \begin{tabular}{l}
Output RAM during Rx is \(\mathbf{H I}\) \\
The complete RAM is written out. The transfer starts with the MSB of the nibble \(\mathrm{Y}=0\) located in X-bank 1 and ends with the LSB of the nibble \(\mathrm{Y}=15\) in X -bank 15. See figure 37 for the sequence. Rx is HI during the transfer of these \(9 \times 16 \times 4\) bits.
\end{tabular} \\
\hline Code 4 & \begin{tabular}{l}
Wait \(x\) seconds \\
The program waits 0 to 15 seconds in Active Mode before the next instruction is read. The timing ambiguity is 1 second due to the random start.
\end{tabular} \\
\hline
\end{tabular}

\section*{Code 5 Soft start}

The program starts at PC 000, the normal start point after initialization.
\(\mathbf{x} \quad \quad \quad\) Codes 0-3: R-output Rx used for transfer indication The chosen R-output is set to HI during the transfer of the information. This allows distinction of the transferred information from the EEPROM control signals which use the I/O-Pin normally.
Code 4: waiting time in seconds
Code 5: not used
Note: The R-output used for transfer indication can range from R1 to R6. If no such signal is wished, DL10 or DL11 may be used. No checks are made to avoid the usage of R0, R7 or other digit latches.

More information concerning the above instructions is contained in chapter 9 . See there for a description of the signals used for the transfers.
PARAMETER: 1 byte containing the actual I/O function and the R-Output for the clock resp. the waiting time.

\section*{4 Subroutine Software}

\subsection*{4.1 General}

By using the subroutine capability of the TSS400 Standard, programs are substantially compacted, enabling the user to write very powerful algorithms within the 512 (2048) word limit.

A subroutine is used to avoid duplication of EEPROM code when a particular section of code is used several times within a program. A subroutine is a section of code terminated with a RETN instruction. A CALL instruction transfers program execution to the first instruction in the subroutine. At the completion of the subroutine, program control is transferred to the instruction address immediately following the CALL instruction. Examples of a subroutine and different calling techniques will follow.

\subsection*{4.2 Nesting Subroutines}

The TSS400 Standard has a subroutine stack with a depth of 3 . This means that 3 levels of subroutines are possible (a subroutine can call a subroutine and this one can call a subroutine, too). This procedure is called nesting subroutines. If a 4th subroutine level is used, the return information of the 1 st level is lost and the software will not work properly. So the user is advised always to be informed which subroutine level he is using when coding programs.

The same is true for the return instruction RETN. If this instruction is used when not inside a subroutine the Program Counter PC is filled with irrelevant data from the stack. Non predictable results will occur.
Example: The following program shows subroutine nesting 3 levels deep.
\begin{tabular}{llll} 
R5 & EQU & 5 & \\
MAINLOOP & CALL & TEST & INVOKE TEST SUBROUTINE \\
\(\star\) & \(\cdots\) & & FROM MAINLOOP: 1st LEVEL \\
TEST & & & \\
& CALL & PREPARE & CALL 2nd LEVEL \\
& CALL & DISPLAY & CALL 2nd LEVEL AGAIN
\end{tabular}

\footnotetext{
Revision 1, November 1990
}
\begin{tabular}{llll} 
PREPARE & CALL & CLRDISPL & CALL 3rd LEVEL \\
& SETR & R5 & OUTPUT PULSE AT R5 \\
& RSTR & R5 & \\
& RETN & & RETURN TO 1st LEVEL \\
* & & & \\
CLRDISPL & DISPLCLR & & ROUTINE CLEARS DISPLAY BUFFER \\
& \(\ldots\) & & \\
\multirow{3}{*}{} & RETN & & \\
& &
\end{tabular}

Example 25: Subroutine nesting levels

\subsection*{4.3 Multiple Entry Points}

Often it is desired to use a subroutine several times, specifying different conditions each time for entering that subroutine. A call to the multiple entry points presets different conditions, and then a branch into the base subroutine is executed. Thus, rewriting the subroutine for each entry condition is avoided.

The following examples use the CREG routine as the basic subroutine.
\begin{tabular}{llll} 
CREG1 & MOVSTORB & 1 & STO1 \(\rightarrow\) REGB \\
\(\star\) & JMP & CREG & USE CREG SUBROUTINE \\
CREG3 & MOVSTORB & 3 & STO3 \(\rightarrow\) REGB. FALL INTO CREG \\
\(\star\) & & & \\
CREG & ADD & & FLAC + STOX \(->\) FLAC \\
C1 & MOVSTORB & 2 & STO2 \(->\) REGB \\
& MPY & & RESULT x STO2 \(->\) FLAC \\
& ROUND3 & &
\end{tabular}

Example 26: Multiple Subroutine entry points

Now calling sequences for computations can become:
\begin{tabular}{lll} 
CALL & CREG1 & COMPUTATION WITH STO1 \\
CALL & CREG3 & COMPUTATION WITH STO3 \\
MOVSTORB & 4 & COMPUTATION WITH STO4 \\
MALL & CREG & USE BASIC ROUTINE \\
C. & \\
\begin{tabular}{l} 
MOVSTORB \\
SUB \\
CALL
\end{tabular} & 5 & COMPUTATION WITH SUBTRACTED STO5 \\
C. & C1 & \\
\begin{tabular}{l} 
CALL
\end{tabular} & CREG &
\end{tabular}

\section*{Example 27: Subroutine calls}

Note that the CREG subroutine is not modified and can be called again (like explained above with computation of STO4).

\section*{5 Correction of Tolerances by Software}

The ADC conversion equations mentioned in 2.11 show nominal values which in reality differ due to tolerances of Vmin and Vmax. The sensors connected to the ADC have tolerances too, so calibration of the complete system is necessary by hardware (potentiometer, resistors) or by software.

Two possibilities exist for software calibration:
- Storage of the calibration factors in the TSS400 RAM
- Storage of the calibration factors in the EEPROM

The following chapters explain the two possibilities with examples.

\subsection*{5.1 Calibration Variables Stored in RAM}

This kind of calibration variables storing is only possible if the TSS400 is connected always to a battery.

\subsection*{5.1.1 Computation with Nominal Values and Correction}

Correction variables once written into the RAM via the I/O Pin are used after the A/D conversion and nominal value computation for correcting the result. This allows measurements with the noncalibrated device.

Example: RAM locations contain correction values \(C\) and \(D\) for adjusting of the temperature value to the corrected temperature \(T_{\text {real }}\) :
```

* Tnom = N x 0.1363-6.696
nominal constants
* Treal = Tnom x C + D
* C = Slope correction in STO2
* D = Offset correction in STO3
* 

A1 EQU 0
MEASR A1 MEASURE A1
BYTE 1 ERROR 2 COMPENSATED MEASUREMENTS XXXX
JN ERROR
HEXDEC
BYTE >13
BYTE >63

```
\begin{tabular}{|c|c|c|c|c|}
\hline & MPY & & & XXX. YYYY \\
\hline & ROUND1 & & & XXX. YYY \\
\hline & LDRBPOS & 2 & \(6.696->\) REGB & \\
\hline & BYTE & \(>66\) & & \\
\hline & BYTE & >96 & & \\
\hline & SUB & & & \\
\hline & ROUND 1 & & TNOM -> FLAC & XXX.YY \\
\hline & MOVSTORB & 2 & C -> REGB & X.YYY \\
\hline & MPY & & TNOM x C \(\rightarrow\) F FLAC & XX.YYYYY \\
\hline & ROUND2 & & ROUND 2 DIGITS & XX.YYY \\
\hline & MOVSTORB & 3 & D \(\rightarrow\) REGB & -X. YYY \\
\hline & ADD & & TNOM \(\times \mathrm{C}+\mathrm{D}->\) FLAC & XX.YYY \\
\hline & MOVFLSTO & 1 & CORRECTED RESULT TO STO1 & \\
\hline
\end{tabular}

Example 28: Computation with nominal values and correction

\subsection*{5.1.2 Computation with Corrected Values only}

Corrected variables once written into the RAM via the I/O Pin are used after the A/D conversion. The nominal constants have to be loaded for the 1st calibration measurements via the I/O or during the initialization by the user's program.

Example: RAM locations contain the corrected values C and D (slope and offset) for adjusting of the temperature value to the corrected temperature \(\mathrm{T}_{\text {real }}\) :
```

* Treal = N x C + D
* C = Slope in STO2
* D = Offset in STO3
A1

| EQU | 0 |  |  |
| :--- | :--- | :--- | :--- |
| MEASR | A1 | MEASURE A1 |  |
| MEATE | 1 | 2 COMPENSATED MEASUREMENTS | XXXX |
| BY | ERROR |  |  |
| JN |  |  |  |
| HEXDEC |  | CONVERT RESULT N TO BCD | XXXX |
| MOVSTORB | 2 | N X C $->$ FLAC |  |
| MPY |  | ROUND 1 DIGIT | XX.YYYY |
| ROUND1 |  | D -> REGB | XX.YYY |
| MOVSTORB | 3 | N X C + D -> FLAC | -X.YYY |
| ADD |  | CORRECTED RESULT TO STO1 |  |
| MOVFLSTO | 1 |  |  |

```

Example 29: Computation with corrected values only

\footnotetext{
Revision 1, November 1990
}

\subsection*{5.2 Calibration Variables stored in EEPROM}

If the correction variables are stored in the EEPROM the correction routine may look like the following example. This way is recommended if no battery is used. These EEPROM variables can be computed by a host computer or by the TSS400 Standard itself if a calibration software part is used. The nominal slope and offset values are part of the user's program. These values are overwritten with the corrected values after calibration. The example is the same as described before.

Example: EEPROM locations contain the corrected values C and D (slope and offset) for adjusting of the temperature value to the corrected temperature \(\mathrm{T}_{\text {real }}\) :
```

* Tnom = N x 0.1363-6.696
nominal constants
* Treal = N x C + D Corrected formula
* C = Slope in SLOPE
* D = Offset in OFFSET
* 

A1 EQU O

```


Example 30: Calibration variables stored in the EEPROM

\section*{6 System Calibration}

With a few simple instructions it is possible for the system to compute the calibration constants by itself.

Example: A thermometer at A 1 is to be calibrated. Key 1 (R1/K1) is activated when the sensor is dived into a bath with 0 C . Key 2 (R1/K2) is activated when the sensor is dived into a bath with +80 C . When both measurements are made, the slope and offset are to be computed and stored in STO2 and STO1 respectively. The routine which computes the temperature T with these computed values is to be shown, too.
```

l T1 = ADC1 x SLOPE + OFFSET
A1 EQU 0 DEFINE AI INPUT
CALIBRAT TSTKEY >0+>30+0 R1, POS. STROBE, K1
JZ CALIBRAT KEY1 ACTIVE ?
MEASR A1 YES, MEASURE AT O C XXXX
BYTE 3 4 COMPENSATED MEAS. ADDED
JN ERROR OUTSIDE RANGE
HEXDEC HEX }->\mathrm{ BCD FLAC
MOVFLSTO 1 SAVE ADC1 IN STO1
TSTKEY >0+>30+1 R1, POS. STROBE, K2
JZ L\$401 KEY2 ACTIVE ?
MEASR A1 YES, MEASURE AT 80 C XXXX
BYTE 3
JN ERROR OUTSIDE RANGE
HEXDEC ADC2 -> FLAC XXXXX
MOVSTORB 1 ADC1 -> REGB XXXXX
SUB
MOVFLRB
LDFLPOS 0
BYTE >80

```
\begin{tabular}{|c|c|c|c|c|}
\hline & BYTE & \(>00\) & & \\
\hline & BYTE & \(>00\) & & \\
\hline & BYTE & \(>00\) & & \\
\hline & DIV & & +80: : (ADC2 - ADC1) = SLOPE & \(0.00 Y Y Y Y\) \\
\hline & ROUND1 & & ROUND LAST DIGIT & \(0.00 Y Y Y\) \\
\hline & MOVFLSTO & 2 & SLOPE -> STO2 & 0.00YYY \\
\hline & MOVSTORB & 1 & ADC1 \(\rightarrow\) REGB & XXXX \\
\hline & MPY & & ADC1 x SLOPE = -OFFSET & \(0 . Y Y Y Y Y\) \\
\hline & MOVFLSTO RETN & 1 & -OFFSET -> STO1 & \(0 . Y Y Y Y Y\) \\
\hline * & & & & \\
\hline ERROR & & & ERROR HANDLING & \\
\hline RETN & & & & \\
\hline
\end{tabular}

\section*{Example 31: System calibration routine}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|l|}{\begin{tabular}{l}
* THE SUBROUTINE COMPUTES THE TEMPERATURE T OUT OF THE ADC VALUE \\
* AND THE STORED SLOPE (STO2) AND OFFSET (STO1). THE COMPUTED \\
* TEMPERATURE IS DISPLAYED
\end{tabular}} \\
\hline H & EQU & \(>40\) & H SEGMENT ON \\
\hline Z & EQU & \(>04\) & LEAD. ZERO SUPPRESSION ON \\
\hline M
* & EQU & \(>08\) & SIGN (-) ON IF NEGATIVE \\
\hline \multirow[t]{9}{*}{COMPUTE} & MEASR & A1 & MEASURE A1 \\
\hline & BYTE & 3 & \multirow[t]{2}{*}{4 COMPENSATED MEAS. ADDED XXXX} \\
\hline & JN & ERROR1 & \\
\hline & HEXDEC & & ADC VALUE -> FLAC IN BCD \\
\hline & MOVSTORB & 2 & SLOPE \(\rightarrow\) REGB 0.YYYYY \\
\hline & MPY & & ADC X SLOPE \(\rightarrow\) F FLAC X.YYYYY \\
\hline & MOVSTORB & 1 & -OFFSET \(\rightarrow\) REGB 0.YYYYY \\
\hline & SUB & & ADC \(x\) SLOPE - (-OFFSET) XX.YYYYY \\
\hline & ROUND 3 & & ADJÚST TO XX.YY XX.YY \\
\hline * & & & DISPLAY FLAC: LEAD. 0 SUPPR. \\
\hline & DISPLFL & \(>17\) & DISPLAY FLAC: _-XX.YY \\
\hline & BYTE & 16 & DIGIT 1 ALWAYS BĒANK \\
\hline & BYTE & \(>80+\mathrm{Z}+\mathrm{M}\) & DIGIT 2 CONTAINS SIGN \\
\hline & BYTE & \(>80+\mathrm{Z}\) & DIGIT 3 \\
\hline & BYTE & \(>80+\mathrm{z}\) & DIGIT 4 \\
\hline & BYTE & \(>80+\mathrm{H}\) & DIGIT 5 WITH DEC. POINT \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & \(>80\) & \[
\begin{aligned}
& \text { DIGIT } 6 \\
& \text { DIGIT } 7
\end{aligned}
\] \\
\hline & \multicolumn{3}{|l|}{RETN} \\
\hline \multicolumn{4}{|l|}{* .} \\
\hline ERROR1 & . . & & ERROR HANDLING \\
\hline
\end{tabular}

Example 32: Computation using system calibration variables

If the computed values for slope and offset are to be stored in the EEPROM, then the following exchanges have to be made:
\[
\begin{aligned}
& \text { MOVFLSTO } 1 \rightarrow \text { MOVFLPRM } \\
& \text { MOVFLSTO } 2 \rightarrow \text { OFFSET } \\
& \text { MOVSTORB } 1 \rightarrow \text { MOVFLPRM } \\
& \text { MOLOPE } \\
& \text { MOVSTORB } 2 \rightarrow
\end{aligned} \text { MOVPRMRB } \text { OFFSET }
\]

\section*{7 Hints, Recommendations and Examples}

\subsection*{7.1 Local Assembly Labels}

A good programming practice is the use of "Local Assembly Labels". This means that labels, which are referenced only inside the subroutine where they are defined, have names in the form \(L \$ x x x\), where \(x x x\) is a unique, decimal number. Otherwise labels which are entry points should get labels which give a certain description e.g. DIV, ADD. This simplifies the distinction between outside referenced labels and local labels.

The software examples use the above mentioned nomenclature whenever possible.

\subsection*{7.2 Integer Math Package}

The package consists of four subroutines for signed addition, subtraction, multiplication and division. The sign is located in the MSB of the sign nibble.

The Integer Math Package consists of the following subroutines:
- ADD: adds REGB to the FLAC
- SUB: subtracts REGB from the FLAC
- MPY: multiplies REGB and FLAC
- DIV: divides REGB into the FLAC

The result always appears in the FLAC register.
Three RAM registers are used by the package:
FLAC: holds 1st operand and result after operation
REGB: holds 2nd operand (not modified by operation)
STOO: Used as a help register for multiplication and division. It can be used for intermediate storage as long as no division or multiplication is performed.

The following figure shows the registers like defined in the used Integer Math Package:
\begin{tabular}{l} 
FLAC \\
REGB \\
STO0
\end{tabular}
\begin{tabular}{l} 
10E7
\end{tabular} 10E6
MSD

Figure 35: Register configuration of the ilnteger Math Package
Before calling one of the four subroutines, the registers FLAC and REGB have to be loaded with the numbers to be processed. The result of the operation is always left in the FLAC register.

The package is an Integer Package which means that the position of the decimal point has to be controlled by the user. To show where the decimal point is assumed, one should note the format of the number at the right margin of the source as it is done in the following examples:
XXX.YY two digits right of the thought decimal point

XXXXXX integer number without fraction

The digit count of " X " can be used to show the largest possible number of digits left to the decimal point.

The rules for the position of the decimal point are:
- Addition: Positions after the decimal point have to be equal. The position is the same for the result.
- Subtraction: Same as addition.
- Multiplication: Positions after the decimal point may be different. Add the positions for the result position.
- Division: Positions after the decimal point may be different. Subtract the REGB position from the FLAC position to get the result position.
\begin{tabular}{rrr} 
FLAC & REGB & RESULT IN FLAC \\
XXX.YYY + & X.YYY & XXX.YYY \\
XXX.Y - & XX.Y & XXX.Y \\
XXX.YYY - & XX.Y & XXXXX.YYYY \\
XXX.YYYY : & XX.YYY & XXXX \\
XX.YY : & \(X X\) & \(X . Y\) \\
& & \(X . Y Y\)
\end{tabular}

\section*{Example 33: Decimal point location after computations}

If two numbers have to be divided and the result should have n digits after the decimal point, the FLAC has to be loaded with the number shifted to the left appropriately and zeroes filled into the lower digits. The same procedure can be used if a smaller number is to be divided by a larger one.
\begin{tabular}{lccc} 
FLAC & & REGB & RESULT IN FLAC \\
XXXX.000 & \(:\) & \(X X\) & \\
XXXX.000 & \(:\) & \(X X . Y\) & XX.YYY \\
XXXX.000 & \(:\) & \(X . Y Y\) & \(X X . Y Y\) \\
\(0 . Y Y Y 000\) & \(:\) & \(X X . Y\) & \(X X X . Y\) \\
& & & \(0 . Y Y Y Y Y\)
\end{tabular}

Example 34: Decimal point location for the division

It is the user's task to assure that no overflow conditions can occur. Before defining computations, a "worst case design" has to be made concerning the greatest numbers which have to be handled. If numbers grow too large, the previously described rounding routines (ROUNDn) may be used. If overflow occurs, no errors are reported! If the division is used it must be assured, that the divisor can't be zero: The software would stay endlessly in the division loop. This can be avoided by using the instruction TSTRB before any division.

\subsection*{7.3 Keyboard Scan}

Up to 16 keys are possible with the four R-outputs and the four K-Ports. Static and dynamic states may be observed with the TSTKEY instruction. The following example shows an application with four keys and up to four
diodes giving static information. The keys and diodes are connected to the TSS400 as follows (the pull-down resistors are shown too):


Key3: during activation no other key is to be recognized. Key2: when activated (LO-HI) Counter 1 is to be incremented Key1: when released (HI-LO) Counter 2 is to be displayed Key0: when not activated Counter 1 is to be displayed Diodes: are to be stored in Group 1 Flags 12 to 15
```

* KEYBOARD ROUTINE: 4 KEYS AND 4 DIODES ARE HANDLED
KEYBOARD TSTKEY >20+>C+3 R3, POS. STROBE, K8
JNZ
TSTKEY
JP
L\$444 TSTKEY
JN
L\$445 TSTKEY
MOVCNT1
EXCHRBFL
DISPLCLR
DISPLFL
>67 DISPLAY FLAC WITHOUT SEGMENT H
BYTE >80 DIGIT 6: 10E1
BYTE >80 DIGIT 7: 10E0
` CHKDIODE SETR R4
KIN

```

Revision 1, November 1990
\begin{tabular}{|c|c|c|c|}
\hline & RSTR & \multicolumn{2}{|l|}{\multirow[t]{2}{*}{R4}} \\
\hline & RETN & & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multirow[t]{2}{*}{KEY2LOHI} & INCCNT1 & & K2 LO-HI CHANGE: INCR. COUNTER 1 \\
\hline & JMP & L\$444 & \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multirow[t]{7}{*}{KEY1HILO} & MOVCNT2 & & K1 HI-LO CHANGE: DISPLAY COUNTER 2 \\
\hline & EXCHRBFL & & COUNTER \(2->\) REGB \(\rightarrow>\) FLAC \\
\hline & DISPLCLR & & CLEAR DISPLAY \\
\hline & DISPLFL & \(>67\) & DISPLAY FLAC, NO SEGMENT H \\
\hline & BYTE & \(>80\) & DIGIT 6: 10E1 \\
\hline & BYTE & >80 & DIGIT 7: 10E2 \\
\hline & JMP & L\$445 & \\
\hline
\end{tabular}

Example 35: Keyboard with 4 keys and 4 diodes

If more than 16 keys have to be handled, R5 and R6 can be used, too. They have to be set and reset by additional instructions placed before and after the TSTKEY-instruction. Additional the STR-bits of the TSTKEYinstruction should be set to 00 to ensure, that no other R-output is modified.

\subsection*{7.4 Clock Routine}

The actual time is stored in Storage Register 1 in minutes. If the time is to be displayed, the time is computed into the format XX.YY (00.00 to 23.59) by a subroutine called CLOCK24. The same procedure may be used for inclusion of the day of the week.
\begin{tabular}{|c|c|c|c|}
\hline LT & EQU & 10 & DEFINE LONG TIMER FLAG \\
\hline H & EQU & >40 & DECIMAL POINT SEGMENT H \\
\hline \multirow{5}{*}{IDLE} & LDTIML & 60 & \multirow[t]{2}{*}{LOAD LONG TIMER WITH 60 SECONDS SLEEP UNTIL NEXT MINUTE IS OVER} \\
\hline & DONE & & \\
\hline & CALL & CLOCK2 4 & CLOCK ROUTINE OUTPUTS TIME TO LCD \\
\hline & & & OTHER ACTIVITIES, AFTER COMPLETION \\
\hline & JMP & IDLE & JUMP BACK TO 1 MINUTE LOOP \\
\hline \multicolumn{4}{|l|}{*} \\
\hline \multicolumn{4}{|l|}{* THE CLOCK ROUTINE COMPUTES HOUR AND MINUTES OUT OF THE} \\
\hline \multicolumn{4}{|l|}{\begin{tabular}{l}
* ACCUMULATED MINUTES IN STO1. \\
*
\end{tabular}} \\
\hline \multirow[t]{3}{*}{CLOCK24} & SELGRP1 & & SELECT GROUP 1 FLAGS \\
\hline & TBIT & LT & LONG TIMER COUNT DOWN TO 0 ? \\
\hline & JZ & NOACT & NO, WAKEUP NOT CAUSED BY TIMER \\
\hline
\end{tabular}
* THE LONG TIMER REACHED ZERO: INCREMENT MINUTES
\begin{tabular}{|c|c|c|c|c|}
\hline & RBIT & LT & RESET UNDERFLOW FLAG LT & \\
\hline & MOVSTOFL & 1 & COUNTED MINUTES TO FLAC & XXXX \\
\hline & LDRBPOS & 1 & ADD 1 MINUTE & \\
\hline & BYTE & >01 & & \\
\hline & ADD & & & \\
\hline * CHECK & IF 24.00 IS & REACHED : & COUNTER CONTAINS 1440 OR MORE & \\
\hline & LDRBPOS & 2 & 24.00 REACHED ? & \\
\hline & BYTE & \(>14\) & \(24 \times 60=1440\) MINUTES & \\
\hline & BYTE & \(>40\) & & \\
\hline & CMPFLRB & & FLAC - REGB: StAtus BItS SET & \\
\hline & JN & GOON & TIME < 24.00 ( 1440 MINUTES) & \\
\hline & SUB & & TIME > \(=24.00\) : SUBTRACT 1440 & MINUTES \\
\hline GOON & MOVFLSTO & 1 & CORRECTED TIME BACK TO STO1 & \\
\hline
\end{tabular}
* THE MINUTES ARE DIVIDED BY 60. THE FLAC CONTAINS THE HOURS * AFTERWARDS, STOO THE MINUTES AS REMAINDER.
    LDRBPOS 1 60 -> REGB
    LDRBPOS 1 60 -> REGB
    LDRBPOS 1 60 -> REGB
    BYTE \(\quad>60\)
    BYTE \(\quad>60\)
    DIV MINUTES : 60 -> FLAC (HOURS)
    DIV MINUTES : 60 -> FLAC (HOURS)
    SHIFTL2 HOURS \(x 100\) XX00
    SHIFTL2 HOURS \(x 100\) XX00
    MOVSTORB 0
    MOVSTORB 0
    ADD
    ADD
    MINUTES (REMAINDER STOO) YY
    MINUTES (REMAINDER STOO) YY
    ADD HOURS AND MINUTES XXYY
    ADD HOURS AND MINUTES XXYY
* DISPLAY TIME: ZERO SUPPRESSED, DECIMAL POINT AT DIGIT 5
* DISPLAY TIME: ZERO SUPPRESSED, DECIMAL POINT AT DIGIT 5
* DISPLCLR
* DISPLCLR
CLEAR DISPLAY
CLEAR DISPLAY
    DISPLFL \(>47\) OUTPUT FLAC
    DISPLFL \(>47\) OUTPUT FLAC
    BYTE \(\quad>80 \quad\) DIGIT 4: HOURS 10E1
    BYTE \(\quad>80 \quad\) DIGIT 4: HOURS 10E1
    BYTE \(>80+\mathrm{H}\) DIGIT 5: HOURS 10E0 + DEC. POINT
    BYTE \(>80+\mathrm{H}\) DIGIT 5: HOURS 10E0 + DEC. POINT
    BYTE \(>80\) DIGIT 6: MINUTES 10E1
    BYTE \(>80\) DIGIT 6: MINUTES 10E1
    BYTE \(>80\) DIGIT 7: MINUTES 10E0
    BYTE \(>80\) DIGIT 7: MINUTES 10E0

Example 36: 24 Hour clock routine

\subsection*{7.5 Temperature Computation for Sensors}

Shown is a subroutine which computes the nominal temperature out of the ADC value in the FLAC. The used TSS400 values are corresponding to Spec. Rev. 1.0. One compensated measurement is made.
```

* SUBROUTINE COMPUTES TEMPERATURE FROM A/DC VALUE OF ONE
* COMPENSATED MEASUREMENT.
* INPUT: ADC VALUE (>2 - >1FFC) IN A/D BUFFER
* AFTER RETURN: TEMPERATURE T (+-XXX.YY C) IN FLAC
* BASE OF COMPUTATIONS:
* RV = 5.11 KOHM SERIES RESISTOR
* R25 = 2.00 KOHM SENSOR RESISTOR @25C
* R85/R25 = 1.54 SENSOR INCLINATION
* ADC VALUE 0002 EQUALS 0.101309 x SVDD LOWER SPEC A/D VALUE
* ADC VALUE 1FFC EQUALS 0.494607 x SVDD UPPER SPEC A/D VALUE
* FROM THE ABOVE:
* ADC VALUE = Vin/SVDD x 20813.7699 - 2106.6282 A/DC EQUATTON
* T = ADC VALUE x 0.030416508 - 89.005919 EXACTLY
* T = ADC VALUE x 0.03042 - 89.01 USED
* CALL: ADC VALUE (0 - >1FFC) IN FLAC
* RESULT: TEMPERATURE (XXX.YY) IN FLAC
* 

TEMPCOMP HEXDEC BCD VALUE OF ADC VALUE XXXX
LDRBPOS 2 0.03042 -> REGB
BYTE >30 0.OYYYY
BYTE >42
MPY ADC-VALUE X 0.01363 XXX.YYYYY
ROUND3
MYRB }
BYTE >01
ADD ADC-VALUE x 0.03042 - 89.01
RETN TEMPERATURE IN FLAC X.YY

```

\section*{Example 37: Temperature computation routine}

\subsection*{7.6 Battery Check}

If regular battery checks are necessary, the ADC value of the internal reference voltage is to be measured with the critical low Vdd value. This ADC value is stored in the EEPROM and transferred to the FLAC when a battery check is necessary. The measured ADC value is compared to this stored value and the Status Bits set according to the result:
```

If Vdd $>$ Vddmin: POS $=1$ ZERO $=0 \quad$ NEG $=0$
If Vdd < Vddmin: POS $=0$ ZERO $=0$ NEG $=1$

```
```

TSS400 Standard User's Guide

* Vddmin IS APPLIED TO Vdd AND A MEASUREMENT MADE TO GET
* THE WARNING VALUE FOR LATER BATTERY CHECKS
* 

| MEASVDDM | ADJBATT |  | MEASURE REFERENCE VOLTAGE |
| :--- | :--- | :--- | :--- |
|  | MOVFLPRM | BATTMIN | WITH VDDMIN APPLIED |
|  | $\ldots$. |  | RESULT IN FLAC TO EEPROM (HEX) |

```


\section*{Example 38: Vddmin setting and Battery Check}

\subsection*{7.7 Cold Start, Warm Start}

The TSS400 Standard checks after each initializaton if Cold Start or Warm Start occured. If the RAM locations "identity", loaded by the interpreter, contain >A5, the interpreter assumes Warm Start occured. If these locations contain other numbers, Cold Start is assumed and the RAM is cleared.

See 2.13 for description of Warm Start and Cold Start.
If it is necessary to continue at a certain program part after a Warm Start condition and not at the Cold Start address, one of the flags in the Flag Registers may be used for this purpose. This flag is set by the user's program to one after the Cold Start and may be tested when the program starts at PC 000:

If the flag is 0 : Cold Start occured (RAM reset by interpreter) If the flag is 1 :Warm Start occured (RAM not modified)

The following example shows this approach to distinguish between Cold Start and Warm Start when the program has to continue at different program parts:
```

ORG 000 START AFTER HARDWARE INIT
SELGRP1
TBIT
JNZ

| 000 | START AFTER HARDWARE INIT |
| :--- | :--- |
|  | USE GROUP1 FLAG 9 |
| WARMSTRTT | IF SET. WARMSTART OCCURED |

                            IF SET: WARMSTART OCCURED
    * 
* COLDSTART: BIT RESET BY INTERPRETER'S RAM CLEAR ROUTINE
* SBIT 9 WARM START BIT <- 1
CALL INIT INITIALIZE SYSTEM
* 
* WARMSTART: CONTINUATION AFTER EMI INDUCED INITS
* 

WARMSTRT ... RECOVER PART

```

\section*{Example 39: Cold Start/Warm Start distinction}

\subsection*{7.8 Waiting Routines}

It is often necessary to wait a certain or minimum time before the processing may continue. For this purpose the two timers may be used:
- The timer is loaded with the appropriate value.
- The Done Mode is activated with the instruction DONE.
- When the chosen time has elapsed the program will continue at the address following the DONE instruction. If changes at the K inputs can occur, a test has to be made if this was the reason for a wake-up.

Example: The FLAC is to be displayed for 2 seconds. Then the display is to be cleared. Changes at the K-Port may not shorten the waiting time. The Short Timer is to be deactivated after the elapsed delay.
\begin{tabular}{|c|c|c|c|}
\hline & DISPLFL & \(>17\) & DISPLAY FLAC \(1-7\) \\
\hline & BYTE & \(>80\) & DIGIT 1 \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & >80 & \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & \(>80\) & DIGIT 7 \\
\hline & LDTIMS & 32 & LOAD 1/16 S TIMER WITH \(32 \mathrm{x} 1 / 16 \mathrm{~S}\) \\
\hline WAIT2S & DONE & & DONE MODE FOR 2 SECONDS \\
\hline & SELGRP1 & & SELECT GROUP 1 FLAGS \\
\hline & TBIT & ST & WAKEUP CAUSED BY SHORT TIMER ? \\
\hline
\end{tabular}
```

JZ KEY NO, IF ST = 0
STPTIMS
DISPLCLR
*
KEY
JMP

```

KEY
STPTIMS
DISPLCLR
...

WAIT2S

NO, \(I F S T=0\)
YES, CAUSED BY THE SHORT TIMER
CLEAR THE DISPLAY, 2 S ELAPSED CONTINUE WITH PROGRAM

CAUSED KEYBOARD THE WAKEUP ?
WAIT UNTIL 2 S ELAPSED

Example 40: Timer usage for waiting purposes

\subsection*{7.9 Address Modification}

The EEPROM store and retrieve instructions MOVFLPRM and MOVPRMRB use fixed addresses inside the EEPROM. If tables are used, each item to be stored or retrieved needs an instruction which addresses it explicitly.

A way to circumvent this EEPROM consuming approach is to modify the address part of the MOVFLPRM or MOVPRMRB instructions:


The steps needed are:
- initializing of the instruction with the address of the 1st address (highest address in our example)
- storage or retrieving of an item
- transfer of the complete instruction to the FLAC
- subtraction of the item length from the instruction
- transfer of the modified instruction back to the original place
- check if the lowest address is reached and terminating resp. Looping back dependend on the result

Note: Starting with the lowest address and incrementing is possible too, but left shifts are needed if the EEPROM space is to be used efficiently. Backward stepping allows the adaptation to the actual length of information by overwriting of the leading zeroes of the item before. Two NOPs are necessary before the MOVFLPRM or MOVPRMRB instructions due to the length of the FLAC, which is 4 bytes.

Example: Data with four digits (XX.YY) is to be stored downwards from EEPROM address \(>6 \mathrm{FF}\) to \(>600\) :
```

* INITIALIZATION OF THE DATA POINTER
* 

LENGTH EQU ITEM LENGTH IN BYTES (4 DIGITS)
LDFLPOS 2 2 BYTES
BYTE >CO+>6 OPCODE MOVFLPRM: >C0
BYTE }\quad>\textrm{FF}-3 1. BYTE OF 4 TO >6FC
MOVFLPRM POINTER 0000C6FC -> POINTER
*

* THE LOOP FOLLOWS:
* THE CONTENTS OF THE FLAC ARE STORED DOWNWARDS
* 

POINTER NOP THE FOLLOWING 4 BYTES ARE
NOP MODIFIED AFTER EACH TRANSFER.
MOVFLPRM POINTER THE MODIFIED INSTRUCTION

* DECREMENTING BY 2 FOR THE NEXT ITEM. THE LEADING NOPs
* ARE OVERWRITTEN.
* MOVPRMRB POINTER CURRENT POINTER -> FLAC
MOVRBFL
LDRBPOS 1 ITEM LENGTH IN BYTES
BYTE LENGTH TO REGB
SUBH POINTER - LENGTH -> POINTER
MOVFLPRM POINTER NEW POINTER BACK
* 
* CHECK IF THE LOWEST ADDRESS IS REACHED
* LDRBPOS 2 LAST USEABLE ADDRESS
BYT̈E >CO+>6 >600 + OPCODE -> REGB
BYTE >00 >600 AND >601 ALWAYS 00
CMPFLRB
JP
...
ORG >600 START OF TABLES
BYTE 0 ALWAYS 0
BYTE 0 ALWAYS 0

```
\begin{tabular}{lllll} 
BYTE & 0 & XX. & ITEM 127 & \(>602\) \\
BYTE & 0 & YY & ITEM 127 & \(>603\) \\
BYTE & 0 & XX. & ITEM 126 & \(>604\) \\
BYTE & 0 & \(Y Y\). & ITEM 126 & \(>605\) \\
BYTE & 0 & & & \\
BYTE & 0 & XX. & ITEM 2 & \(>6\) FC \\
BYTE & 0 & YY & ITEM 2 & \(>6 F D\) \\
BYTE & 0 & YY. & ITEM 1 & \(>6 F E\) \\
& & & ITEM 1 & \(>6 F F\)
\end{tabular}

\section*{Example 41: Value storage in EEPROM}

If data is to be retrieved from the EEPROM, the same way may be used as shown in the example above. The only difference is the opcode of the instruction:
\begin{tabular}{ll} 
MOVFLPRM & Opcode \(>\) C0 \\
MOVPRMRB & Opcode \(>\) C8
\end{tabular}

Note: If more tables are used, it is adviseable to use more than one pointer. This reduces the necessary write cycles to the EEPROM bytes used as pointers. Another way would be the usage of PCF8570 RAMs for the pointer locations. See 2.16 for more information.

\subsection*{7.10 Square Root Routine}

The routine shown computes the square root of the FLAC. The FLAC must contain a value A with an even number of digits after the imaginal decimal point. The result has the half number count of digits after the imaginal decimal point. The used approximation is:
\[
X n+1=(A / X n+X n) / 2
\]

The first part of the subroutine looks for a good starting value X 1 (eg. 10 for \(A=1\) to 99,100 for \(A=100\) to 9999 ) the second part starts with this value 10 approximations, leaving the result in the FLAC.
```

* SQUARE ROOT ROUTINE: THE SQUARE ROOT OF THE FLAC IS
* COMPUTED WITH THE NEWTONIAN PROCEDURE
* FLAC BEFORE: XXXXXX XXXX.YY XX.YYYY NUMBER
* FLAC AFTER: XXX XX.Y X.YY ROOT
* MOROOT MOVFLSTO 2 STORE VALUE A IN FLAC
SQROOT MOVFLSTO 2 STORE VALUE A IN FLAC
BYTE 1
PLOOP EXCHRBFL
SHIFTLI
EXCHRBFL
SHIFTR2
JNZ PLOOP
MOVRBSTO 1 STORE X1
LDCNT1 10 10 TRIALS ARE MADE
MOVSTOFL 2 A -> FLAC
MOVSTORB 1 Xn m REGB
DIV
ADD
LDRBPOS 1
BYTE 2
DIV
MOVFLSTO 1
DECCNT1
JNZ LOOP
RETN YES, SQUARE ROOT IN FLAC

```

Example 42: Square Root routine

\section*{8 Development Tools}

The keys to be pressed at the host computer are shown in brackets. The meaning is as follows:
\(<\) RETN \(>\) The key, here the return key, is to be pressed
<SHIFT/F3> The keys, here the shift and the F3 key, are to be pressed simultaneously

The cursor may be moved with the arrow keys, the acknowledge is made with the return key.

\subsection*{8.1 The Development Board}

For the development of the users software including the debugging phase, a special hardware, the Development Board is necessary. This Development Board contains all necessary hardware needed for debugging and the final application:
- sockets for the TSS400 and the EEPROMs
- connectors to the users hardware (I/O and display)
- connector to the host computer
- interface to the host computer

If the ADT400 is used for development, the connector of the ADT400 is inserted into the microcomputer socket.
If no ADT400 is used, the TSS400 Standard is inserted into the microcomputer socket.
The schematic of the Development Board is shown in the following figure. If an X 24 C 16 is used, it must be placed in socket 0 .


Figure 36: Schematic of the Development Board

\subsection*{8.2 Development with the ADT400}

Necessary components for the software development are:
- IBM compatible Personal Computer
- ADT400 hardware connected to the Personal Computer
- ADT400 development software installed on the Personal Computer
- Development Board with EEPROM(s)

For details concerning the connection of the ADT400 to the host computer see the "TSS400 ADT USER'S GUIDE".
The TSS400 Standard software running on the ADT400 is delivered in a version which allows "worst case" real time tests. All necessary runtime definitions of the ADT400 are chosen to allow this. The used main oscillator frequency is 500 kHz . This is the minimum frequency of the TSS400.
When using the ADT400 the TSS400 Standard software is loaded into the ADT400. Then the ADT400 is used like the TSS400 Standard. The interpreter code is developed with the host computer's editor and assembled with the ASM400 assembler. The assembler outputs on request up to four TSS400 objects which contain the user's object together with an EEPROM burning software for transferring the object to the EEPROMs. After burning of the EEPROMs the TSS400 Standard software is loaded into the ADT400 system and the user's software may be debugged or run under control of the ADT400 emulator.

\subsection*{8.2.1 Assembling the User's Software}

The ASM400 assembler for the TSS400 family includes the instruction set of the TSS400 Standard interpreter. To load the right instruction set, the 1st line of the user's code must look like the 1st line of the following example where xxxxxx is the title of the program. TSS444 or TSS0444 is the code which invokes the interpreter's instruction set. The 2nd line of code is necessary to have the arithmetic functions of the assembler available (+ - * \(\gg\) ).
```

TITLE
XXXXXX
OPTION ARITHM
END

```

Revision 1, November 1990

The users code must end with the "END" directive as shown above. Additional information concerning the ASM400 assembler may be found in the "4-Bit Microcomputer Cross Assembler User's Guide".

The ASM400 is called by the following sequence:
C:/ASM400
<RETN>

INSTRUCTION SET FILE [INSTRUCT.400]: INSTRUCT. 400 <RETN> SOURCE FILE: \(x x x x x x . S R C \quad<R E T N>\) OBJECT FILE: \(x x x x x x\).OBJ <RETN>

OPLA FILE: \(x x x x x x\).OPL <RETN> LISTING FILE: \(x x x x x x\).LST <RETN>

After the input of all filenames the assembler starts and will output the following status messages:

\section*{READ INSTRUCTION SET CONTINUE WITH PASS1 CONTINUE WITH PASS2}

0 ERROR(S) 0 WARNING(S) IN MODULE xxxxxx
After completion of the assembly run, the ASM400 asks if the EEPROM burning files are wished. If they are wished they are created and written to the disk:

Transferroutine: \(\rightarrow\) BURN.BR\#
Note: If a Burn-File is necessary and not created by the delivered ASM400 version, please contact your sales chanel.
Start this routine? \(\quad[\mathrm{Y} / \mathrm{N}]<\mathrm{Y}>\)
The ASM400 indicates the creation of the burning files and gives a completion message. Only the necessary files are created:
xxxxxx.BR1
xxxxxx.BR2
xxxxxx.BR3
xxxxxx.BR4
Burnfile(s) created !

\subsection*{8.2.2 Loading the User's Software into the EEPROMs}

The ASM400 creates up to four burning files which are necessary for the burning of the EEPROM(s). Each of these files contains the 512 bytes of object code for one of the EEPROMs and the burning software in TSS400 object code. Before debugging can start, the EEPROMs have to be loaded with the users software.

The ADT400 emulator software is started by: C:/TSS400 <RETN>
The ADT400 asks if the last work is to be reloaded:
Do you wish to reload the last work ? NO <RETN>
Select "Load Version from File" out of the displayed menue. The ADT400 shows the existing versions, select "SSW.STA" which is the TSS400 Standard software version containing all necessary informations.

The ADT400 now asks for the wished task, select:
Emulation / Debugging <RETN> <ESC>
After this a selection of objects is shown, the "Wildcard" option is needed to get the "xxxxxx.BR1" object loaded: <F1> *.BR1 <RETN> All objects with the extension."BR1" are shown now. The cursor movement keys may be used to select the "xxxxxx.BR1" object. After pressing of the return key, the "xxxxxx.BR1" object is loaded and reassembled. When this is finished the ADT400 aks:
Do you want to load Emulator processor data? \([\mathrm{Y} / \mathrm{N}]<\mathrm{N}>\)
Pressing <SHIFT/F4> and then <SHIFT/F3> initializes the emulator. Pressing <F5> afterwards runs the burning program for the 1st EEPROM which lasts 2 seconds approximatively.
Pressing the <SPACE> bar halts the emulator and the display shows an endless BRANCH if the burning routine completed successfully.

If another EEPROM is to be burned, pressing of <ALT/L> shows the object selection seen before again. The "Wildcard" option is now to be used to get the "xxxxxx.BR2" files displayed: <F1> *.BR2 <RETN>

Proceeding is the same like shown for the burning of "xxxxxx.BR1" before. The same is to be done for the burning of "xxxxxx.BR3" and "xxxxxx.BR4" if existing.

\subsection*{8.2.3 Debugging the User's Software with the ADT400}

\section*{Loading of the TSS400 Standard Software}

After burning of the EEPROMs with the users software, the interpreter is to be loaded:
Pressing <ALT/L> shows an object selection. The file "SSW.OBJ" contains the interpreter. Pressing the <RETN> key after selecting this file with the cursor loads and reassembles the interpreter.

Pressing <SHIFT/F4> and then <SHIFT/F3> initializes the emulator.

\section*{Setting and Resetting Breakpoints}

Pressing <F9> shows the table for selecting of the breakpoint data. At first all existing breakpoints have to be deleted:
```

TYPE: Reset ALL <RETN>
PAGE: xxx
PC: xxx
LABEL: xxxxx
CMD: xxxxx

```

The ADT400 asks: Clear all Breakpoints? Y/N Y <RETN>
The same procedure may be used for removing of one breakpoint.
For setting a breakpoint <F9> is to be pressed again. The breakpoint data appear on the screen, and the following inputs (here for the label DECODE) are made:

TYPE: Label
PAGE: xxx
PC: \(\quad x x x\)
LABEL: DECODE <RETN>
CMD: xxxxx

\section*{Breakpoint Set}

Pressing of <F5> starts the execution of the users software for one instruction byte or one instruction depending on the used breakpoint label. These two labels are explained with the debugging modes.

Debugging with the ADT400 allows the following modes:
- Single Byte Execution
- Single Step Execution
- Free Run
- Free Run with Software Breakpoints

The above mentioned debugging modes are described in the following:

\section*{Single Byte Execution}

By setting an ADT400 breakpoint to the label BREAK inside the TSS400 Standard software, the Single Byte Execution is possible. This means, each time the breakpoint is reached, one single byte of the user's program was read and executed. Setting a breakpoint to the label BREAK and pressing <F5> will read and execute one instruction byte.

\section*{Single Step Execution}

By setting an ADT400 breakpoint to the label MASTER inside the TSS400 Standard software, the Single Step Execution is possible. This means, each time the breakpoint is reached, one complete instruction with all parameter bytes was read and executed. Setting a breakpoint to DECODE and pressing <F5> will execute one instruction. The RAM shows the next instruction and address which is not yet executed.

\section*{Free Run}

The user's program may be checked during Free Run by watching the display and the outputs. This mode is only possible after removing of all software and ADT400 breakpoints. Press <F5> after the initialization of the ADT400 to get Free Run.

\section*{Free Run with Software Breakpoints}

The software breakpoints described later on are possible with the ADT400 too. See at "DEVELOPMENT WITH THE SOFTWARE SIMULATOR" how to use these software breakpoints. After resetting of all ADT400 breakpoints, press <F5> to get this run mode.

\subsection*{8.2.4 RAM Map of the TSS400 Standard}

When a breakpoint is reached, the ADT400 shows the state of all registers of the TSS400. The RAM of the TSS400 is arrranged as follows.

Note: The shown RAM is configured like the RAM shown on the ADT400 screen. The numbers above the RAM are the \(Y\)-Register values, the numbers to the left of the RAM are the X-Register values shown by the ADT400.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Y & \(=0\) & 7 & 8 & 9 & 10 & 11 & 12 & 13 & 14 & 15 \\
\hline \multirow[t]{5}{*}{X9} & \multicolumn{3}{|r|}{\multirow[t]{4}{*}{\begin{tabular}{l}
\(\square\) \\
Storage Register 2
\end{tabular}}} & & \multicolumn{2}{|l|}{\multirow[t]{4}{*}{Counter 2}} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{Short
Timer
Buffer
MSD}} & & - \\
\hline & & & & & & & & & & Long \\
\hline & & & & & & & & & & Timer \\
\hline & & & & & & & & & & Buffer \\
\hline & 10E7 & 10E0 & & & 10E1 & 10EO & & & MSD & \\
\hline
\end{tabular}


\subsection*{8.3 Development with the Software Simulator}

The Software Simulator, which runs on all IBM-AT compatible Personal Computers (PC), allows fast development of the software for the TSS400 Standard. All functions, with the exception of the hardware communication with the inputs and outputs, are possible. For the development of the program's algorithms, no hardware at all is necessary.

All internal registers, inputs, outputs, flags, are shown simultaneously on one screen and may be modified whenever wished, also during the run mode.

The following part does not describe the handling of the Software simulator but gives some hints how to test the user's program with the Development Board. For a detailed description of the Software Simulator see "TSS400 Standard Simulator User's Guide".

Necessary components for the software development with the Software Simulator are:
- IBM-AT compatible Personal Computer
- ASM400 software installed on the Personal Computer
- software Simulator installed on the Personal Computer
- interface hardware for the connection of the Development Board
- development Board with EEPROM(s) and TSS400 inserted

The last two items are only needed if tests within the target hardware are necessary. For the test of the user's software, it is only necessary to assemble it with the ASM400 crossassembler. The produced object is loaded and executed bv the Software Simulator.

\subsection*{8.3.1 Restrictions of the Software Simulator}

The Software Simulator is a software tool written in PASCAL, which simulates only the TSS400 Standard. This prohibits some functions of the TSS400 Standard. The following list gives a short overview concerning the differences:
- The R-Outputs, the I/O Pin and the K-Port are not available as outputs.
- The K-Port used as an input may be modified by Simulator commands only.
- The instructions do not work in exact realtime, only the timers do this.
- The instruction SLV is interpreted as a NOP.
- If overflow occurs during a multiplication, the FLAC is loaded with 99999999 due to the used PASCAL software. The TSS400 Standard looses the MSDs instead and holds only the 8 LSDs of the result.

\subsection*{8.3.2 Assembling the User's Software}

The assembly of the users program is made exactly like described at "Development with the ADT400". See there how to proceed.
After completion of the assembly run, the ASM400 asks if the EEPROM burning files are wished. They are not needed, so the answer is NO.
Transferroutine: \(\rightarrow\) BURN.BR\#
Start this routine? \([\mathrm{Y} / \mathrm{N}]<N>\)
The assembler ceases after the NO input.

\subsection*{8.3.3 Debugging the User's Software with the Software Simulator}

The object file generated by the ASM400 crossassembler can be loaded into the Software Simulator's object buffer and tested until the complete algorithms are checked. See "TSS400 Standard Simulator User's Guide" for a description of the possibilities the Software Simulator gives for software testing.

\subsection*{8.3.4 Realtime Debugging of the User's Software}

After verification of all software parts which do not need connection to the target hardware, the realtime tests with the Development Board connected to the target hardware may be started.

The Development Board is connected to the CENTRONICS interface connector with the delivered cable. The tested user's program is burned into the EEPROMs with the appropriate Simulator instruction and reread for verification. The user's program, stored in the EEPROMs now, may be started and stopped by instructions of the Software Simulator.

Realtime debugging with the Development Board is made by inserting software breakpoints into the user's program at locations where program parts are completed. These may be computations, measurement parts, keyboard tests and so on. The software breakpoints are inserted by the editor and are deleted after use or replaced by NOP instructions.

Several possibilities exist for halting and checking at those locations:
- jumps to the same location
- waiting for a definitive key to be pressed
- displaying of the register which contains important information
- displaying of the interesting registers with wait cycles

The possibilities mentoned above are described in the following:

\section*{Jumps to the same location:}

At the locations where the program should cease, a jump to the same location is inserted:
```

L\$555
JMP
L\$555
END OF PART TO BE CHECKED
ENDLESS LOOP

```

Example 43: Software breakpoint 1
The endless loop stops the program at location \(L \$ 555\). The outputs may be observed for correctness, the displayed information, too.

To proceed from this breakpoint, a change of the program with the editor, an assembly run and an EEPROM burning is necessary.

\section*{Waiting for a definitive key tc be pressed:}

At the locations where the program should cease, a call to a subroutine is inserted. This subroutine waits until a certain (normally unused) key is pressed. After this activation, the program continues until the subroutine is invoked the next time.
After completion of the debugging, the subroutine and all calls to it are removed from the user's program.
Example: It shows the use and the code of the subroutine:


Example 44: Software breakpoint 2
The used R-output/K-input combination may be defined with the operand of the TSTKEY instruction. The same is true for the strobe used with the Routput.

\section*{Displaying the Register which contains important information:}

This kind of information getting may be used with the above mentioned software breakpoints. Any register with important information may be displayed before the software breakpoint occurs.

Example: The contents of the FLAC are important at the software breakpoint. Its contents (10E3-10E0) should be displayed then:
\begin{tabular}{llll} 
& & & PROGRAM PART TO BE CHECKED \\
& MISPLFL & \(>47\) & DISPLAY RESULT IN FLAC \\
& BYTE & \(>80\) & DIGIT 4 10E3 \\
& \\
& BYTE & \(>80\) & \\
BYTE & \(>80\) & & \\
L\$556 & BYTE & \(>80\) & DIGIT 7 10E0
\end{tabular}

Example 45: Software breakpoint with display
With multiple key activations, the contents of some registers may be displayed in sequence after a software breakpoint. After each key activation the displaying of a Storage Register follows.
Example: The FLAC is to be displayed when the software breakpoint is reached. The activation of the key, connected to R3/K4 has to display the contents of STO1, STO4 and STO3 in sequence.
\begin{tabular}{|c|c|c|c|}
\hline & & & PROGRAM PART TO BE CHECKED \\
\hline & CALL & DISFLAC & DISPLAY FLAC \\
\hline & CALL & SWBKPT & WAIT HERE UNTIL KEY IS PUSHED \\
\hline & MOVSTOFL & 1 & \\
\hline & CALL & DISFLAC & DISPLAY STORAGE REGISTER 1 \\
\hline & CALL & SWBKPT & WAIT HERE UNTIL KEY IS PUSHED \\
\hline & MOVSTOFL & 4 & \\
\hline & CALL & DISFLAC & DISPLAY STORAGE REGISTER 4 \\
\hline & CALL & SWBKPT & WAIT HERE UNTIL KEY IS PUSHED \\
\hline & MOVSTOFL & 3 & \\
\hline & CALL & DISFLAC & DISPLAY STORAGE REGISTER 3 \\
\hline & & & PROCEED TO NEXT BREAKPOINT \\
\hline \({ }_{\star}^{*}\) THE US & KEY IS C & NNECTED & R3 AND K4 \\
\hline SWBKPT & TSTKEY & \(>20+>C+2\) & R3, POS. STROBE, K4 \\
\hline & JP & SWRET & LO-HI TRANSITION ? \\
\hline & JMP & SWBKPT & NO, WAIT \\
\hline \[
\begin{aligned}
& \text { SWRET } \\
& \star
\end{aligned}
\] & RETN & & YES, PROCEED \\
\hline * SUBROU & NE DISPLA & S FLAC A & IT IS \\
\hline DISFLAC & DISPLFL & >17 & DISPLAY DIGIT \(1-7\) \\
\hline & BYTE & \(>80\) & DIGIT 1 \\
\hline & BYTE & >80 & \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & >80 & \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & \(>80\) & \\
\hline & BYTE & >80 & DIGIT 7 \\
\hline & ETN & & \\
\hline
\end{tabular}

Example 46: Software breakpoint with multiple display

\section*{Displaying the interesting registers with wait cycles:}

Using one of the timers with the Done Mode gives the possibility to display one or more registers for a given time and to proceed then without any activity. If the wait time is long enough, the results may be written down conveniently for later checks.
Example: The FLAC is to be displayed first when the software breakpoint is reached. Then the contents of STO1, STO4 and STO3 have to be displayed in sequence. Each register display should last for six seconds.
\begin{tabular}{lllll} 
CALL & & PROGRAM PART TO BE CHECKED \\
CALLL & WISFLAC & DISPLAY FLAC FOR 6 SECONDS \\
MOVSTOFL & 1 & & \\
CALL & DISFLAC & DISPLAY STORAGE REGISTER 1 \\
CALL & WAIT6S & WAIT FOR 6 SECONDS \\
MOVSTOFL & 4 & & \\
CALL & DISFLAC & DISPLAY STORAGE REGISTER 4 \\
CALL & WAIT6S & WAIT FOR 6 SECONDS \\
MOVSTOFL & 3 & & \\
CALL & DISFLAC & DISPLAY STORAGF REGISTER 3 \\
CALL & WAIT6S & & \\
-. & & PROCEED TO NEXT BREAKPOINT
\end{tabular}
```

* WAITING ROUTINE 6 SECONDS
* 

WAIT6S LDTIML LOAD LONG TIMER WITH 6 SECONDS
DONE SLEEP FOR THIS TIME
RETN RETURN TO CALLER
*
DISFLAC ... SUBROUTINE: SEE EXAMPLE ABOVE

```

Example 47: Software breakpoint with wait cycles

\subsection*{8.3.5 Most often occuring difficulties}

User programs running errorfree with the Software Simulator sometimes show unexpected behaviour when running on the Development Board. This is due to the differences of the Software Simulator and the Development Board. A list with often occuring errors is given together with explanations and hints.
- no wake-up occurs
- wake-up occurs with wrong timing
- DONE mode is not executed
- ADC result is always \(>000\)
- ADC result is always >FFF
- wrong results of computations
- counters count wrong
- no wake-up from Off or Done mode
- wrong decimal points appear in LCD
see chapter 1, 4
see chapter 1, 3
see chapter 4, 3
see chapter 2, 5, 8
see chapter 5,8
see chapter 6, 7, 8
see chapter 6
see chapter 9
see chapter 10

\section*{Reasons for the malfunctions:}
1. DL12 not set: DL12 must be set, if the Short Timer is used. The timer handling of the interpreter bases on time differences, if DL12 is reset, the wake-up occurs every second with avalue of 0 contained in the 16 Hz hardware timer. The interpreter doesn't see a difference to the last value read and doesn't execute the instruction after the DONE instruction therefore. Setting of DL12 avoids this malfunction.
2. DL13 not set: DL13 must be set, if the current source of the ADC is used. If all measured values are \(>000\), the not set DL13 may be the cause. Only if DL13 is set, a current is output to the addressed analog input An.
3. Unused timers not stopped: If the former executed program used one of the timers, wrong timing will occur with the currently running program. The reason is, neither the INIT nor the LOAD command do stop the timers (see INIT conditions). Inclusion of STPTIMS or STPTIML into the initialization part will cease this behaviour.
4. Timer flags not reset: The DONE cannot be entered as long as one of the timer flags (Group 1 Flags 10, 11) are set. The user's program must reset these flags after the verification that one of the timers wokeup the TSS400 Standard.
5. No sensors or sensors at wrong analog input: If an anolog input is measured which doesn't have a sensor connected, the result is as follows:
\(>000\) : if DL13 is reset
\(>F F F\) : if DL13 is set
The wrong addressing may be caused by the operand of the MEASR instruction: The operand \(n\) addresses the analog input \(A n+1\).
6. Erroneous use of the " \(>\) " sign: The ASM400 assembler converts all operands into the hexadecimal format This means where hexadecimal numbers are used (timers, display instructions) the operands may be defined in decimal or hexadecimal format. If BCD format is necessary (counters, loading of registers) a " \(>\) " sign must precede the number which instructs the assembler to take the number as it is. A missing ">" sign would yield the hexadecimal number for the operand (e.g. 2 C for 44).
7. Overflow occured: No indication is given, if the result of an instruction overflows the FLAC. A worst case computation concerning the largest possible results must be made preceding the software development to avoid this error. SHIFTRn or ROUNDn may be used.
8. Erroneous hardware design: The values of the external hardware (Rext, Rsensor aso.) are not correct. Checking of the values with worst case design methods will avoid this error.
9. DL8 set: DL8 must be reset, if a wake-up is needed from the K-Port.
10. Group 1 Flag bits set: If the H -segment flag bits in Group 1 are set from a previous program, the according H -segments will be on in the LCD. Clearing of the flags will solve the problem.

\section*{9 Controlling of the TSS400 Standard in Slave Mode}

It is possible to use the TSS400 Standard as a pure slave processor. The complete control is made by a host processor which sends instructions to the TSS400 Standard via the I/O Pin. The TSS400 executes these instructions and sends the results, if wished by the host, back also via the I/O Pin. The line between the TSS400's I/O Pin and the host is referred to as data line.

The host is connected to the TSS400 Standard with 3 lines:
- Data line: From an I/O Port to the TSS400's I/O Pin.
- Init line: From an output to the TSS400's INITN Pin.
- Common ground line.

If the TSS400 Standard is used in Slave Mode, it is not possible to use a program EEPROM. If an EEPROM is necessary, it must be connected to the host directly. R0 and R7 cannot be used in the Slave Mode.

The Slave mode can be used for:
- transferring of ADC values to the host for computations
- writing of computed variables to the RAM
- transferring of internal flags to the host and back
- initiation of measurements with defined parameters
- reading and writing of counters and timers

The reading and writing of the RAM enables the user to have complete informations concerning the state of the TSS400 system.

Due to the relative low speed of the TSS400 the transfers via the data line are determined as follows:
- controlling is always made by the host computer
- clocking is always made by the TSS400
- the TSS400 is always slave, the host is always master

All inputs or outputs start with the MSB of the MSD, followed by the MSB-1 of the MSD and end with the LSB of the LSD.

Note: All signals in the following parts are described as they appear at the TSS400 pins. The Development Board and possibly the users final hardware have inverting stages in between the TSS400 and the host's interface. So the signals may be inverted in reality.

\subsection*{9.1 Handshaking and Program Control}

The I/O Pin is not only used for the transfer of instructions and data, but for the necessary handshaking, too. The principle is simple: Host and TSS400 Siandard hoid iow the data iine as iong as they are busy. Onily if both of them are ready for a transfer, the line is pulled up by the pullup resistor. When this occurs, the TSS400 Standard asks for the next instruction or sends data if this was wished by the host instruction received before (SLV eg.).

This allows:
- the host to evaluate the last received results and to prepare the next instruction for the TSS400 Standard.
- the TSS400 Standard to execute the received instruction.

For program control, the opcodes of the instructions shown in Figure 23 and 24 are transferred to the TSS400 Standard, with the MSB of the eight bit opcode first. If an instruction consists of more than one byte, the additional bytes have to be transferred when demanded by the TSS400 Standard.

\subsection*{9.2 Starting of the Slave Mode}

The I/O Pin is used normally for the data transfers from and to the EEPROM. This makes a special interfacing necessary to start the Slave Mode.
- The host pulls down the INITN Pin to \(\mathrm{V}_{\text {Ss }}\).
- The host releases the INITN Pin to VDD, the TSS400 starts execution.
- The TSS400 resets the I/O Pin to LO for at least 75 us.
- The TSS400 switches the I/O Pin to input direction and waits until the host releases the line, too.
- When the host releases the I/O Pin to HI, the TSS400 Standard outputs \(4 \times 4\) pulses, MSB first, which have to be prolonged (1s) or not (0s) by the host for the codes >FF and >A5 in sequence to initiate the Slave Mode. All other received codes initiate the normal EEPROM Mode.

Note: The first two nibbles, containing >FF should be used by the host for the measurement of the oscillator frequency of the TSS400. One bit is 24 internal instructions in length. The knowledge of the oscillator frequency is necessary for a good synchronization.


Figure 38: Mode check after initialization

The signals described before are shown below. The signals output by the host and the TSS400 are shown on separated lines although they appear both on the same line. The following figure shows the start of the TSS400 Standard software after an initialization:

\subsection*{9.3 Data Transfer}

Data means instructions, operands, parameters, results and status information transferred between the host and the TSS400 Standard.

\subsection*{9.3.1 Data Transfer to the TSS400 Standard}

The TSS400 Standard switches the data line to the input direction and waits until the host releases the line too, which leads to a high level. Then the TSS400 Standard reads in the next instruction or data to be processed. The host extends the pulses coming from the TSS400 if ones are to be transferred and doesn't extend the pulses if zeroes are to be transferred to the TSS400 Standard.


Figure 39: Data transfer to the TSS400 Standard
Figure 39 shows the first 3 bits of a data transfer after a busy host released the data line. The shown, transferred info is \(010 x\).
Figure 40 shows the timing of a nibble transferred to the TSS400 Standard. The numbers show the length of the signals measured in TSS400 instructions. A TSS400 instruction needs \(6 / \mathrm{fosc}\) seconds for the execution. The TSS400 scans the data line 12 instructions after the positive edge of the pulse.


Figure 40: I/O Timing of a data transfer to the TSS400 Standard

\section*{Writing of the complete RAM}

The instruction SLV allows the writing of the complete RAM. The transfer starts with the MSB of the nibble \(\mathrm{Y}=0\) located in the X1-bank and ends with the LSB of the nibble \(Y=15\) located in the XF-bank. See the RAM map shown in Figure 37 for the meaning of the bits. The RAM map also shows the sequence, the X -Banks are read in.
576 bits are read by the TSS400 Standard ( \(9 \cdot 16 \cdot 4=576\) )
Warning: It is strongly advisable to read out and store the RAM before any RAM writing is made. Non predictable results will occur, if RAM parts are not restored exactly like they were read out. Only the nibbles to be changed should be modified.

\subsection*{9.3.2 Data Transfer to the Host}

If an instruction assumes results from the TSS400 Standard, the TSS400 sends the data after the host released the data line.

The timing for one nibble (which contains 5) is shown in Figure 41. The numbers below the figure show the length measured in TSS400 instructions. A TSS400 instruction needs \(6 / \mathrm{fosc}\) seconds.


Figure 41: //O Timing of a data transfer to the Host

\section*{Reading of the complete RAM}

The instruction SLV allows the reading of the complete RAM. The transfer starts with the MSB of the nibble \(Y=0\) located in the X1-bank and ends with the LSB of the nibble \(Y=15\) located in the \(X F\)-bank. See the RAM map shown in Figure 37 for the meaning of the bits. The RAM map shows also the sequence, the X-Banks are read out.
576 bits are written by the TSS400 Standard \((9 \cdot 16 \cdot 4=576)\)

\subsection*{9.4 Idle Modes for the Slave}

The host can deactivate the TSS400 Standard if activity is not needed. Two possibilities exist:
- Holding low the I/O Pin line after the last instruction.
- Loading of one of the timers with a constant and usage of the Done Mode afterwards.

The first method uses the handshake feature of the TSS400 Standard. Normal operating current is drawn from the power supply.

The second method has the advantage of the very low supply current drawn during the Done Mode.

Example: The TSS400 is not needed for 6 seconds. The host sends the two instructions shown below to the TSS400 Standard which sleeps for 6 seconds. When this time elapsed, the TSS400 Standard will call for the next instruction.
```

LDTIML 6 6 SECONDS DEACTIVATION
DONE DONE MODE
CALL FOR NEXT INSTRUCTION

```

\section*{Example 48: Deactivation of the Slave by the Done Mode}

\subsection*{9.5 Not Executable Instructions}

The following instructions cannot be executed in the Slave Mode:
MOVFLPRM no EEPROM connected to the TSS400 in Slave Mode MOVPRMRB same as above

The program flow instructions like CALL, JMP and so on are senseless in the Slave Mode.

\section*{APPENDIX A}

\section*{Hardware Definition}

For references the actual hardware definition of the TSS400 Standard, used for production purposes, is listed below:
```

!
.OPTION VERSION
VERSION S220
!
.OPTION PINNING

| $!$ |  |  |  | NO TEST | TEST | K | R | S/C |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $!$ |  |  | KC $=0$ |  | RMIN | RMOUT | HVT |  |
| PAD | 1 | IS-PIN | 1 | APPL VSS | TEST | VSS | VSS | VSS |

!
.OPTION ROM
TSS0400 OBJECT:STDSW CREATED 11 NOV 1988 11:11:11 VERS J.8 LB
0046000D002100400126014700E2000D0000008C008D0083000001270036019C
009800000100011E00450180000001E2019C0000000000450098009800880044

```

Note: Only four lines out of the 128 object lines are shown.
```

01E3009D008D017601150067000001FA001A0084000000360189014900480100
00BF005A006B009C01BC000600560080014C01FA004F01150094002301E800BF
!
.OPTION K1K2K4K8IO
INPUT K1 PULL-DOWN NONE ; NO PULL-DOWN ANYWHERE
INPUT K2 PULL-DOWN NONE
INPUT K4 PULL-DOWN NONE
INPUT K8 PULL-DOWN NONE
INPUT I/O PULL-DOWN NONE
OUTPUT K1 OPEN-SOURCE NO ; PUSH-PULL OUTPUTS
OUTPUT K2 OPEN-SOURCE NO ; PUSH-PULL OUTPUTS
OUTPUT K4 OPEN-SOURCE NO ; PUSH-PULL OUTPUTS
OUTPUT K8 OPEN-SOURCE NO ; PUSH-PULL OUTPUTS
!
.OPTION K8FF.
FLIP-FLOP DISABLED ; NO FLIP FLOP IN K8-INPUT
.OPTION ADC-RANGE
RANGE-IS LARGE ; 0.1013 x SVDD - 0.4946 x SVDD
!
.OPTION WAKE-UP-FREQUENCY
FREQUENCY 16HZ ; 16 Hz WAKEUP FREQUENCY FOR DL12 = 1
!
.OPTION CLOCK

```


Revision 1, November 1990
```

CHARACTER 31 HAS-SEGMENTS B C G ; -1
!
! DL14 = 1 , ST = 0 COMBINATIONS
CHARACTER 32 HAS-SEGMENTS NONE ; BLANK
CHARACTER 33 HAS-SEGMENTS A
CHARACTER 34 HAS-SEGMENTS F
CHARACTER 35 HAS-SEGMENTS A F
CHARACTER 36 HAS-SEGMENTS B
CHARACTER 37 HAS-SEGMENTS A B
CHARACTER 38 HAS-SEGMENTS B F
CHARACTER 39 HAS-SEGMENTS A B F
CHARACTER 40 HAS-SEGMENTS G ; MINUS SIGN
CHARACTER 41 HAS-SEGMENTS A G
CHARACTER 42 HAS-SEGMENTS F G
CHARACTER 43 HAS-SEGMENTS A F G
CHARACTER 44 HAS-SEGMENTS B G
CHARACTER 45 HAS-SEGMENTS A B G
CHARACTER 46 HAS-SEGMENTS B F G
CHARACTER 47 HAS-SEGMENTS A B F G ; DEGREE
!
! DL14 = 1., ST = 1
CHARACTER 48 HAS-SEGMENTS E
CHARACTER 49 HAS-SEGMENTS A E
CHARACTER 50 HAS-SEGMENTS E F
CHARACTER 51 HAS-SEGMENTS A E F
CHARACTER 52 HAS-SEGMENTS B E
CHARACTER 53 HAS-SEGMENTS A B E
CHARACTER 54 HAS-SEGMENTS B E F
CHARACTER 55 HAS-SEGMENTS A B E F
CHARACTER 56 HAS-SEGMFNTS E G
CHARACTER 57 HAS-SEGMENTS A E G
CHARACTER 58 HAS-SEGMENTS E F G
CHARACTER 59 HAS-SEGMENTS A E F G
CHARACTER 60 HAS-SEGMENTS C ; SEGMENT C
CHARACTER 61 HAS-SEGMENTS D ; SEGMENT D
CHARACTER 62 HAS-SEGMENTS A B C D ; ]
CHARACTER 63 HAS-SEGMENTS A B C D E ; J
.END ; END OF HARDWARE OPTIONS

```

\section*{APPENDIX B}

\section*{Applicable Documents}
- TSS400 Application Report EB175 E
- TSS400 User's Guide
- TSS400 Software User's Guide
- TSS400 ADT User's Guide
- TSS400 Standard Simulator User's Guide
- 4-Bit Microcomputer Cross Assembler User's Guide

\section*{APPENDIX C}

\section*{TSS400 Standard Instructions}

Register to Register Transfer Instructions
\begin{tabular}{lll} 
MOVFLSTO & \(n\) & Move FLAC to Storage Register n \\
MOVSTOFL & \(n\) & Move Storage Register n to FLAC \\
MOVRBSTO & \(n\) & Move REGB to Storage Register n \\
MOVSTORB & \(n\) & \begin{tabular}{l} 
Move Storage Register n to REGB \\
Exchange REGB and FLAC Registers
\end{tabular} \\
EXCHRBFL & & \begin{tabular}{l} 
Move FLAC to REGB
\end{tabular} \\
MOVFLRB & & \begin{tabular}{l} 
Move REGB to FLAC
\end{tabular} \\
MOVRBFL & Label & \begin{tabular}{l} 
Move FLAC to EEPROM starting at Address \\
MOVFLPRM
\end{tabular} \\
MOVPRMRB & Label & \begin{tabular}{l} 
Move EEPROM Contents starting at Address \\
Label to REGB
\end{tabular}
\end{tabular}

Arithmetic Instructions (Results always to FLAC)
\begin{tabular}{ll} 
ADD & Add REGB to FLAC decimally \\
SUB & Subtract REGB from FLAC decimally \\
MPY & Multiply FLAC and REGB decimally
\end{tabular}

\footnotetext{
Revision 1, November 1990
}
\begin{tabular}{ll} 
DIV & Divide FLAC by REGB decimally \\
ADDH & Add REGB to FLAC hexadecimally \\
SUBH & Subtract REGB from FLAC hexadecimally \\
HEXDEC & Hexadecimal to decimal Conversion \\
ROUNDn & Round FLAC \(n\) times \\
SHIFTRn & Shift right FLAC \(n\) times \\
SHIFTLn & Shift left FLAC \(n\) times \\
S & \((0<n<3)\) \\
& \((0<n<3)\)
\end{tabular}

\section*{Arithmetics Compare Instructions}

CMPFLRB TSTRB

Compare FLAC and REGB. Set Status Fiags.
Test Contents of REGB. Set Status Flags.

Bit Manipulation Instructions
\begin{tabular}{llll} 
SBIT & n & Set Flag Bit n & \((0 \leq n<16)\) \\
RBIT & n & Reset Flag Bit n & \((0 \leq n<16)\) \\
TBIT & n & Test Flag Bit n & \((0 \leq n<16)\) \\
SELGRPn & & Select Flag Bits Group n & \((0<n<3)\) \\
OR & & \begin{tabular}{l} 
Or FLAC and REGB, Result to FLAC
\end{tabular} \\
AND & & And FLAC and REGB, Result to FLAC
\end{tabular}

\section*{Constant Transfer Instructions}
\begin{tabular}{lll} 
LDFLPOS & \(n\) & \begin{tabular}{l} 
Load FLAC with a positive Constant contained \\
in the \(n\) following Bytes in BCD Format \\
\((n=0.4\) Bytes).
\end{tabular} \\
LDFLNEG & \(n\) & \begin{tabular}{l} 
Load FLAC with a negative Constant (Same as \\
above).
\end{tabular} \\
LDRBPOS & \(n\) & \begin{tabular}{l} 
Load REGB with a positive Constant.(Same as \\
above).
\end{tabular} \\
LDRBNEG & \(n\) & \begin{tabular}{l} 
Load REGB with a negative Constant.(Same as \\
above).
\end{tabular} \\
CLRFL & & \begin{tabular}{l} 
Clear FLAC Register \\
Clear REGB
\end{tabular}
\end{tabular}

\section*{Input/Output Instructions}
\begin{tabular}{llll} 
SETR & \(n\) & Set Output Rn (DLn) & \((\mathrm{n} \# 0,7,14,15)\) \\
RSTR & n & Reset Output Rn (DLn) \(\quad(\mathrm{n} \# 0,7,14,15)\) \\
TSTKEY & \(>\) NN & Test Keyboard like described by operand \\
KINTIM & & \begin{tabular}{l} 
Actualize K-Input and Timers
\end{tabular} \\
KIN & & Read K-Input to FLAC (LSD) and FLAGS 12-15 \\
FLKOUT & & Output LSD of FLAC to K-Port \\
KOUT & n & Output Constant n to K-PORT
\end{tabular}

\section*{Program Flow Control Instructions}
\begin{tabular}{llll} 
JMP & Label & Jump unconditional & \\
JZ & Label & Jump if zero & \((\) ZERO \(=1)\) \\
JEQ & Label & Jump if equal & \((\) ZERO \(=1)\) \\
JNZ & Label & Jump if not zero & (ZERO \(=0)\) \\
JNE & Label & Jump if not equal & (ZERO \(=0)\) \\
JP & Label & Jump if positive & (POS \(=1)\) \\
JN & Label & Jump if negative & (NEG \(=1)\) \\
CALL & Label Call Subroutine & \\
RETN & Return from Subroutine &
\end{tabular}

\section*{Analog-Digital-Converter Instructions}
\begin{tabular}{ll} 
SVDDON & \multicolumn{1}{l}{ Set Converter Supply Voltage } \\
SVDDOFF & Reset Converter Supply Voltage \\
MEASR & a \(\quad\)\begin{tabular}{l} 
Measure addressed A/D Input a+1. Following Byte \\
contains number of conversions and Mode.
\end{tabular} \\
ADJBATT & \\
CHKBATT & Measure Battery Voltage, Result to FLAC \\
Check Battery Voltage \\
ADJCOMP & Measure A/D Input, Result to FLAC \\
CHKCOMP & Compare A/D Input with Value in FLAC
\end{tabular}

\section*{Display Instructions}
\begin{tabular}{lll} 
DISPLDGn & NN & \begin{tabular}{l} 
Display Info of Operand \(>N N\) in Digit \(n\). \\
DISPLCLR
\end{tabular} \\
DISPLFL & \(>M N\) & \begin{tabular}{l} 
Clear Display \\
Display FLAC from Digit \(M\) to \(N\). Appended \\
\((M-N+1)\) Bytes contain Info for each Digit.
\end{tabular}
\end{tabular}

\section*{Miscellaneous Instructions}
\begin{tabular}{lll} 
DONE & Enter Done Mode \\
OFF & & Enter Off Mode \\
NOP & & No Operation \\
SLV & \(>\) NN & Host Control Instruction
\end{tabular}

\section*{Counter Instructions}
\(\left.\begin{array}{ll}\text { DECCNTn } & \begin{array}{l}\text { Decrement Counter } n \text { decimally } \\
\text { Increment Counter } n \text { decimally }\end{array} \\
\text { INCCNTn } & \begin{array}{l}\text { Decrement Double Counter decimally } \\
\text { DECDBL }\end{array} \\
\text { Increment Double Counter decimally }\end{array}\right]\)\begin{tabular}{ll} 
INCDBL & Load Counter \(n\) decimally with Constant \(>\) NN \\
LDCNTn & Move Counter \(n\) to REGB \\
MOVCNTn & Move Combined Counters to REGB
\end{tabular}

\section*{Timer Instructions}
\begin{tabular}{lll} 
LDTIML & NNN & Load Long Timer with Constant NNN \\
LDTIMS & NNN & Load Short Timer with Constant NNN \\
ACTTIM & & Actualize Timers \\
STPTIML & & Stop Long Timer \\
STPTIMS & & Stop Short Timer
\end{tabular}

\section*{TI Worldwide Sales Offices}

ALABAMA: Huntsville: 4960 Corporate Drive Suite N-150, Huntsville, AL 35805-6202, (205) 837-7530.
ARIZONA: Phoenix: 8825 N. 23rd Avenue, Suite 100, Phoenix, AZ 85021, (602) 995-1007; Tucson: 818 W. Miracle Mile, Suite 43, Tucson, AZ 85705, (602) 292-2640.
CALIFORNIA: Irvine: 17891 Cartwright Drive, vine, CA 92714, (714) 660-1200; Roseville: Sierra Gate Plaza, Suite 255B, Roseville, CA 95678, (916) 786-9208; San Diego: 5625 Ruffin Road, Suite 100, San Diego, CA 92123, (619) 278-9601; Santa Clara: 5353 Betsy Ross Drive, Santa Clara, CA 95054, (408) 980-9000;
Woodland Hiis: 21550 Oxnard Street, Suite
COLORADO: Aurora: 1400 S. Potomac Street,
Suite 101, Aurora, CO 80012, (303) 368-8000
CONNECTICUT: Wallingford: 9 Barnes Industrial Park Road, Wallingford, CT 06492, (203) 269-0074.

FLORIUA: Aitamonte Springs: उ̄Ũ S. ivorin Lake Boulevard, Suite 1008, Altamonte Springs, L 32701, (407) 260-2116; Fort Lauderdale 2950 N.W. 62nd Street, Suite 100, Fort Lauderdale, FL 33309, (305) 973-8502; Tampa: 4803 George Road, Suite 390, Tampa, FL 33634, (813) 885-7411.
GEORGIA: Norcross: 5515 Spalding Drive, Norcross, GA 30092, (404) 662-7900
ILLINOIS: Arlington Heights: 515 W Algonquin, Arlington Heights, IL 60005, (708) 640-3000.
NDIANA: Carmel: 550 Congressional Drive, Suite 100, Carmel, IN 46032, (317) 573-6400, Fort Wayne: 118 E. Ludwig Road, Suite 102,
Fort Wayne, IN 46825, (219) 482-3311.
IOWA: Cedar Rapids: 373 Collins Road N.E., Suite 201, Cedar Rapids, IA 52402, (319) 395-9550.
KANSAS: Overiand Park: 7300 College Boulevard, Lighton Plaza, Suite 150, Overland Park, KS 66210, (913) 451-4511.
MARYLAND: Columbia: 8815 Centre Park Drive, Suite 100, Columbia, MD 21045, (301) 964-2003.
MASSACHUSETTS: Waltham: 950 Winter Street, Suite 2800, Waltham, MA 02154, (617) 895-9100.
MICHIGAN: Farmington Hilis: 33737 W. 12 Mile Road, Farmington Hills, Ml 48018, (313) 553-1500; Grand Rapids: 3075 Orchard Vista Drive S.E., Grand Rapids, MI 49506, (616) 957-4202.
MINNESOTA: Eden Prairie: 11000 W. 78th Street, Suite 100, Eden Prairie, MN 55344, (612) 828-9300.
MISSOURI: St. Louis: 11816 Borman Drive St. Louis, MO 63146, (314) 994-2100
NEW JERSEY: Iselin: Parkway Towers, 485 E. Route 1 South, Iselin, NJ 08830, (201) 750-1050 NEW MEXICO: Albuquerque: 1224 Parsons Court, N.E., Albuquerque, NM 87112, (505) 291-0495.
NEW YORK: East Syracuse: 6365 Collamer Drive, East Syracuse, NY 13057, (315) 463-9291; Fishkill: 300 Westage Business enter, Suite 140, Fishkin, Walt Whitman 897-2900; Melville: 1895 Wait Whitman Road P54-6600 Pittsford: 2851 Clover Street Pittsford, NY 14534, (716) 385-6770.
NORTH CAROLINA: Charlotte: 8 Woodlawn Green, Suite 100, Charlotte, NC 28217, (704) 527-0930; Raleigh: 2809 Highwoods Boulevard Suite 100, Raleigh, NC 27625, (919) 876-2725 OHIO: Beachwood: 23775 Commerce Park Road, Beachwood, OH 44122, (216) 464-6100 Beavercreek: 4200 Colonel Glenn Highway, Suite 600, Beavercreek, OH 45431, (513) 427-6200.

OREGON: Beaverton: 6700 S.W. 105th Street Suite 110, Beaverton, OR 97005, (503) 643-6758. PENNSYLVANIA: Blue Bell: 670 Sentry Parkway, Blue Bell, PA 19422; (215) 825-9500 PUERTO RICO: Hato Rey: 615 Merchantile Plaza Building, Suite 505, Hato Rey, PR 00918 , (809) 753-8700

TENNESSEE: Johnson City: P.O. Drawer 1255, Erwin Hwy., Johnson City, TN 37605 , (615) 461-2192.

TEXAS: Austin: 12501 Research Boulevard Austin, TX 78759, (512) 250-7655; Dallas: 7839 Churchill Way, Dallas, TX 75251, (214 917-1264; Houston: 9301 Southwest Freeway, Commerce Park, Suite 360, Houston, TX 77074 (713) 778-6592

UTAH: Salt Lake City: 1800 S. West Temple Street, Suite 201, Salt Lake City, UT 84115 , (801) 466-8973.

WASHINGTON: Redmond: 5010 148th Avenue N.E., Building B, Suite 107, Redmond, WA 98052, (206) 881-3080
WISCONSIN: Waukesha: 20825 Swenson Drive, Suite 900, Waukesha WI 53186, (414) 798-1001.
CANADA: Nepean: 301 Moodie Drive, Mallorn Center, Suite 102, Nepean, Ontario, Canada ќ2'1 ЗС4, (013) 720-1370, nichimutu thit: 200 Centre Street East, Richmond Hill, Ontario, Canada L4C 1B1, (416) 884-9181; St. Laurent: 9460 Trans Canada Highway, St. Laurent, Quebec, Canada H4S 1R7, (514) 335-8392

ARGENTINA: Texas Instruments Argentina Viamonte 1119, 1053 Capital Federal, Buenos Aires, Argentina, 1/748-3699.
AUSTRALIA (\& NEW ZEALAND): Texas Instruments Australia Ltd., 6-10 Talavera Road, North Ryde (Sydney), New South Wales, Australia 2113, 2 887-1122; 5th Floor, 418 Street Kilda Road, Melbourne, Victoria, Australia 3004 3 267-4677; 171 Philip Highway, Elizabeth, South Australia 5112, 8 255-2066.
AUSTRIA: Texas instruments GmbH., Hietzinger Kai 101-105, A-1130 Wien, (0222) 9100-0. BELGIUM: S.A. Texas Instruments Belgium N.V., 11, Avenue Jules Bordetlaan 11, 1140 Brussels, Belgium, (02) 2423080
BRAZIL: Texas Instruments Electronicos do Brasil Ltda., Rua Paes Leme, 524-7 Andar Pinheiros, 05424 Sao Paulo, Brazil, 0815-6166. DENMARK: Texas instruments A/S, Marielundvej 46E, 2730 Herlev, Denmark, (42) 917400.

FINLAND: Texas Instruments OY, Ahertajantie 3 P.O. Box 81, 02101 Espoo, Finland, (90) 461-422
FRANCE: Texas Instruments France, 8-10 Avenue Morane Saulnier-B.P. 67, 78141 Velizy Villacoublay Cedex. France, (1) 30701003. GERMANY: Texas Instruments Deutschland GmbH., Haggertystrasse 1, 8050 Freising-RFA, (08161) 80-0 od. Nbst; Kurfurstendamm 195-196, 1000 Berlin 15, (030) 8827365 ; Dusseldorfer Strasse 40, 6236 Eschborn 1, (06196) 8070 ; III Hagen 43/Kibbelstrasse 19, 4300 Essen 1, (0201) 24 25-0; Kirchhorster Strasse 2, 3000 Hannover 51, (0511) 64 68-0; Maybachstrasse II 7302 Ostfildern 2 (Nellingen), (0711) 34 03-0. HOLLAND: Texas instruments Holland B Hogehilweg 19, Postbus 12995, 1100 AZ Amsterdam-Zuidoost, Holland, (020) 5602911


Texas
INSTRUMENTS

HONG KONG: Texas Instruments Hong Kong Ltd., 8th Floor, World Shipping Center, 7 Canton Road, Kowloon, Hong Kong, 7351223
IRELAND: Texas Instruments Ireland Ltd., 7/8 Harcourt Street, Dublin 2, Ireland, (01) 755233 ITALY: Texas Instruments Italia S.p.A., Centro Direzionale Colleoni, Palazzo Perseo-Via Paracelso 12, 20041, Agrate Brianza (Mi), (039) 63221; Via Castello della Magliana, 38, 00148 Rome, (06) 5222651; Via Amendola, 17, 40100 Bologna, (051) 554004
JAPAN: Texas Instruments Japan Ltd., Aoyama Fuji Building 3-6-12 Kita-aoyama Minato-ku,
Tokyo, Japan 107, 03-498-2111; MS Shibaura Building 9F, 4-13-23 Shibaura, Minato-ku, Tokyo, Japan 108, 03-769-8700; Nissho-iwai Building 5F, 2-5-8 Imabashi, Chuou-ku, Osaka, Japan 541, 06-204-1881; Dai-ni Toyota Building
Nishi-kan 7F, 4-10-27 Meieki, Nakamura-ku,
Nagoya, Japan 450, 052-583-8691; Kanazawa Oyama-cho Daiichi Seimei Building 6F, 3-10 Oyama-cho, Kanazawa, Ishikawa, Japan 920 0762-23-5471; Matsumoto Showa Building 6F 1-2-11 Fukashi, Matsumoto, Nagano, Japan 390 0263-33-1060; Daiichi Olympic Tachikawa Building 6F, 1-25-12. Akebono-cho, Tachikawa Tokyo, Japan 190, 0425-27-6760; Yokohama Nishiguchi KN Building 6F, 2-8-4 Kita-Saiwa Nishi Ku, Yokchama, Kanagawa, Japan 220 045-322-6741; Nihon Seimei Kyoto Yasaka Building 5F, 843-2, Higashi Shiokohijcho Higashi-iru, Nishinotoh-in, Shiokohii-dor Shimogyo-ku, Kyoto, Japan 600, 075-341-7713 Sumitomo Seimei Kumagaya Building 8F, 2-44 Yayoi, Kumagaya, Saitama, Japan 360 , 0485-22-2440; 2597-1. Aza Harudai, Oaz Yasaka, Kitsuki, Oita, Japan 873, 09786-3-3211 KOREA: Texas Instruments Korea Ltd., 28th Floor, Trade Tower, 159, Samsung-Dong Kangnam-ku Seoul, Korea, 25512800.
MEXICO: Texas Instruments de Mexico S.A. MEXICO: Texas Instruments de Mexico S.A.,
Alfonso Reyes 115, Col. Hipodromo Condesa Alfonso Reyes 115, Col. Hipodromo Conde
Mexico, D.F., Mexico 06120, 5/525-3860. Mexico, D.F., Mexico 06120, 5/525-3860. MIDDLE EAST: Texas Instruments, No. 13, 1 st Floor Mannai Building, Diplomatic Area, P.O. Box 26335, Manama Bahrain, Arabian Gulf, 973 274681
NORWAY: Texas Instruments Norge A/S, PB 106, Refstad (Sinsenveien 53), 0513 Oslo 5 Norway, (02) 155090
PEOPLE'S REPUBLIC OF CHINA: Texas Instruments China Inc., Beijing Representative Office, 7-05 CITIC Building, 19 Jianguomenwai Dajie, Beijing, China, 500-2255, Ext. 3750
PHILIPPINES: Texas Instruments Asia Ltd.,
Philippines Branch, 14th Floor, Ba-Lepanto Building, Paseo de Roxas, Makati, Metro Manila, Philippines, 28176031
PORTUGAL: Texas instruments Equipamento Electronico (Portugal) LDA., 2650 Moreira Da Maia, 4470 Maia, Portugal (2) 9481003
SINGAPORE (\& INDIA, INDONESIA,
MALAYSIA, THAILAND): Texas Instruments Singapore (PTE) Ltd., Asia Pacific Division, 101 Thomson Road, \#23-01, United Square Singapore 1130, 3508100
SPAIN: Texas Instruments Espana S.A., c/Gobelas 43, Ctra de la Coruna km 14, La Florida, 28023, Madrid, Spain, (1) 372 8051: c/Diputacion, 279-3-5, 08007 Barcelona, Spain, (3) 3179180

SWEDEN: Texas Instruments International Trade Corporation (Sverigefilialen). (visit address: Isafjords gatan 7, Kista), Box 30, S-164 93 Kista Sweden, (08) 7525800.
SWITZERLAND: Texas Instruments Switzerland AG, Riedstrasse 6, CH-8953 Dietikon,
Switzerland, (01) 7402220.
TAIWAN: Texas Instruments Supply Company, Taiwan Branch, Room 903, 9th Floor, Bank Tower, 205 Tun Hwa N. Road, Taipei, Taiwan Republic of China, 27139311
UNITED KINGDOM: Texas instruments Ltd. Manton Lane, Bedford, England, MK41 7PA (0234) 270111```


[^0]:    Revision 3.2, October 1991

[^1]:    * This range is fully available only for $\mathrm{V}_{\mathrm{DD}}$ at or above 3.5 V

[^2]:    * Options for x: 128 or 64 or 32 or 16 or 8

[^3]:    Revision 1, July 1991

[^4]:    Revision 1, July 1991

[^5]:    Revision 1, July 1991

[^6]:    Revision 1, July 1991

[^7]:    Revision 1, July 1991

[^8]:    Revision 1, July 1991

[^9]:    Revision 1, November 1990

[^10]:    Revision 1, November 1990

[^11]:    Revision 1, November 1990

[^12]:    Revision 1, November 1990

[^13]:    Revision 1, November 1990

[^14]:    Revision 1, November 1990

[^15]:    Revision 1, November 1990

