77-68 was designed to be a low cost system with which the constructor could learn about microcomputing by direct experience. The board can then be expanded, without restriction, to the limit of the 6800 microprocessor s potential. Througnout the following months, additional items will be made available e.g. memory cards, Kansas City interface, RS 232C interface, Monitoring ROM's. The User Group will hold all the latest information and it is expected to play a major role in the development of this system.

If difficulty is experienced in obtaining any parts or in commissioning the microcomputer, do not hesitate to contact the "BEAR" or the User Group.

The instruction set is reproduced by kind permission of Motorola Ltd.

## BEAR MICROCOMPUTER SYSTEMS

2nd. Reprint.

Included in this edition are the details of the two avaiable extentions to 77-68; - the 4Kbytes RAM p.c.b. and the Soft Monitor V24/R232C interface p.c.b. Within the next few weeks a ROM monitor p.c.b. and a V.D.U./Keyboard p.c.b. will become available, plus several more during 1978. You are recommended to the User Group Newsletters No. 1,2 and 3 which have already been publisned.

May 1978.

## LISTOFCONTENTS

Page No.
Cnapter $1 . \quad$ Introduction 1
Chapter 2. 77-68 Characteristics 3
Chapter 3. Hardware Jescription 5
Chapter 4. Construction \& Testing 10
$\begin{array}{ll}\text { Chapter 5. Programming } & 16\end{array}$
Chapter 6. Extending the System 25
Chapter 7 User Group 28
Appendix Binary, Decimal \& Hexadecimal 43

Registration Fomm.
Design Note 15 and 22.
LISTOF FIGURES
Fig. 77-68 Block Diagram 29
Fig. 2 MPU Clock Waveforms 30
Fig. 3 Important Bus Timings 31
Fig. $4 \quad \begin{array}{r}\text { CPU Board - Layout of Major } \\ \text { Components }\end{array} 32$

Fig. 5 Wiring to Board Connector 33
Fig. $6 \quad$ Optional Data Bus Buffers 34
Fig. $7 \quad$ Power Supply 35
Fig. $8 \quad 36$
Fig. $9 \quad$ Circuit Diagram 37
Table $1 \quad 77-68$ Component Distribution 38
Table 2
77-67 Component List 39
Table 3
6800 Instruction Set
40,41
Table 4
Pin assignment Edge connector

## 77-68

Chapter :- Ineroduction
The 77-63 was cesigned as a cheap and simple way to build a working microcomputer which could be expanded at a later date, when the constructor's pocket and time permit.

Although the basic machine described here is limited in terms of memory (256 8 bit words) and input/Output devices (only binary switches anc lamps are provided), it will give the user valuable experience of the hardware and software techniques associated with microprocessors, withour commiteing him to a large initial outlay. Even in its simplest form, the 77-68 can be used to execute real programs. Mathematical routines can be run, simple computer games played, and the machine can be a controller/sequencer for household devices, simple production tools, or even a model train layout.

The basic 77-68 can be built for about $£ 50$, or less if the constructor has a reasonably deep junk box, and the only additional equipment needed is a source of $+5 V$ DC power. By using toggle switches and LED's as iucimentary imput/output devices, the 77-68 user does not need to invest in a teleprinter or VDU before he can get started al though these and other enhancements can be added to the system later.

Care has been taken in the design to ensure that the machine can be expanded easily to have a capability close to that of any 8 bit microprocessor currently avallable. For example, the 6800 MPU chip has been chosen as the heart of the 77-68, rather than one of the simpler, slower and slightly cheaper types which would limit the power of an enhanced machine. Also, provision is made for fully buffered TTL data and address busses for flexibility in adding other units to build up a large system.

Finaliy, a word of warning. Although the $77-68$ is relatively straightforward, it should not be attempted until the would-be constructor is familiar with the construction of TTL based logic circuits, and has some knowledge of microcomputer hardware and software. The following books are highly recommended as suitable

```
background reading;
    'An Introduction To Microcomputers' Vols | & || by Adam Osborne.
Published by Adam Osborne and Associates Inc., 2950 Seventh St.,
Berkekyl, California 94710, and distributed in Europe by SYBEX,
Publications Dept, }313\mathrm{ Rue Lecourbe, }75015\mathrm{ Paris, FRANCE.
or Bear Microcomputer Systems
'M6800 Microcomputer System Designs Data', (or at least the M6800 data
sheets) from Motorola.
or Bear Microcomputer Systems
```


## Chapter 2 77-68 Characteristics

i. CPU

The heart of the 77-68 is the '6800' eight bit microprocessor, readily available from Motorola, AMI, and others. This features;

* 72 instructions.
* 7 Addressing modes (Direct, Relative, Immediate, Indexed, Extended, Implied and Accumulator).
* 6 internal registers (two accumulators, index register, program counter, stack pointer and condition code register).
* 8 bit parallel processing.
* Single (5V) power supply.

2. Memory

The basic $77-68$ card has 255 words of 8 bit static Random Access MOS Memory. However, all 16 of the 6800 address $l i n e s$ are buffered and brought out to the card connector, allowing the constructor to expand to the full 64 K word capability of the 6800 CPU chip.

## 3. CPU Cycle Time

A quartz crystal controlled clock gives a basic CPU cycle time of 1.6uS. This may be extended in increments of 0.2 u to a maximum of 5uS to cater for slow external memory should the need arise.

The time taken to execute an instruction depends upon the particular operation and the addressing mode used e.g.;

| Add Accumulators; | 2 cycles | $3.2 u S$ |
| :--- | ---: | :--- |
| Load Accumulator; | $2-5$ cycles | $3.2-8$ uS |
| Branch; | 4 cycles | $6.4 u S$ |

## 4. Input/Output

Peripheral data and control registers are treated as memory locations, and can therefore be handled using the full 6800 instruction set.

The basic 77-68 uses eight toggle switches as an input register for loading the user's program and for entering data during program execution, and eight LED's as a data display. Although this might be considered a rather primitive approach, it does give the constructor a
minimum 'first cost' system and emphasises the essentially binary nature of microprocessors. More sophisticated peripherals, such as a keyboard, display $\&$ printer, can easily be added to the basic system.

As well as the eight 'data' switches, eight 'address' switches allow the user to examine the contents of any of the 255 memory locations when the processor is halted.

## 5. Construction

The 77-68 is designed around the standard $8.0^{1 i}$ square printed circuit board with a $0.1^{\prime \prime}$ single sided edge connector. Suitable 'prototyping' boards are readily avallable, alternatively the constructor may use a specially designed board supplied by BMS.

The basic machine comprises;

- a single board containing the 6800 microprocessor chip, 255 words of memory, data input and output registers and miscellaneous control circuitry.
- a simple control panel.
- a source of 5VDC at about IA.

6. Expandabillity

Enhancements being designed for the 77-68 include;

- Memory extension
- Tape cassette interface ('Kansas City' standard)
- VDU and keyboard interfaces

These will allow the constructor to build up a system capable of running much of the vast amount of software that is readily avallable to 6800 based system users.

The Basic Machine
Fig 1 shows a block diagram of the basic 77-68. It comprises;

- The 6800 Microprocessor Unit itself. This performs the actual machine language instructions stored in the RAM, using data read from the RAM or the Data Switch Register.
- A 256 word eight bit Random Access Memory used to store data and instructions. The particular word to be read from or written into is selected by the eight address lines AO - A7. The 6800 MPU actually has 16 address lines, providing an addressing range of $2^{16}$, or approximately 65000 words, however the high 8 lines A8 to Al5 are not used by the basic 77-68. Also, the address 255 (Hexadecimal FF) accesses the data switches and data display register as described below, thus the RAM is disabled when this address is selected.
- A 8 line, 2 way, data selector which allows the address bus I ines AO to A7 to be driven either from the 6800 MPU or from the address switches.
- An eight bit data input switch register. When the MPU selects address FF, a read operation will take information from these switches, rather than from the RAM.
- An eight bit output register, driving an eight bit 'data' display. An MPU write operation into location FF will load this register.
- Miscellaneous clock and control logic.

The HALT switch disables the MPU (after allowing it to complete the current instruction) so that its TRI-STATE outputs go to the high impedance state. The address selector is then set so that lines AO - A7 are controlled by the address switches rather than by the MPU. At the same time, the data register input gates are opened so that the data display shows whatever information is on the data bus, and a read condition applied to the RAM. Thus the contents of any of the RAM locations can be examined by setting the appropriate address on the switches.

When the LOAD switch is operated (while the machine is HALTed) the RAM
is set to the write condition, and the contenss of the data switch register gated onto the data bus to be written into menory at the location sefected by the address switches.

Thus, without involving the MPU, we can examine the contents of memory, or load new information into any location.

When the RESET switch is operated, the MPU goes into an imitialisation routine, then it reads the contents of location FF (the data switch register) as the location at which to start program execution when the HALT condition is removed. So, having loaded a program into memory, we can run it by simply setting the data switch register to the program starting address, momentarily operating the RESET switch, then removing the HALT condition. If the HALT condition is removed without the RESET switch having been operated, the MPU will resume operation from the point at which it had been halted.

The RUN lamp is lit whenever the 6800 MPU has control of the busses. Al though the 6800 MPU does not have an explicit HALT instruction, WAI (Wait for interrupt) has roughly the same effect and, when operated, will extinguish the RUN lamp.

## Detailed Circuit Description

In describing the hardware, the following conventions are used;

- '11 is high (any voltage between about +2 and +5 V )
- '0' is low (0 to 0.5V)
- A bar ( $(\square)$ over a signal name means that it is asserted low. For example, the Iine SWSEL goes low to select the switch inputs. Similarly, a circle (o) on a logic element input means that input is asserted low, e.g. X13 pin 40 is pulled low (to 0) to reset the device.
- Gate functions can, in general, be drawn in two ways;

and


The version which best represents the logic function being performed is used in the schematic.

All inputs and outputs of the MOS devices ( $\times 13,17 \varepsilon 18$ ) are protected against static electricity by being connected to some other device; a TTL device input or output will effectively clamp spikes greater than about +8 V , or more negative than about -1 V . Thus, although address lines A8 - Al5 are not used by the basic $77-68$, it is wise to include X11, 12 gates from the beginning to protect the valuable 6800.

X13, the 6800 , is the heart of the machine. Its low order eight address lines AO - A7 are routed to the data selectors X8 \& 9, which take either the 6800 outputs (ADSEL $=0$ ) or the pattern set on the address switches (ADSEL $=1$ ) and apply the result to the RAM and to the connector for system expansion. As well as selecting the appropriate address source, X8 \& 9 also buffer the rather low power outputs of the 6800 to full TTL drive levels. The eight high order address outputs A8 - Al5 of the 6800 are buffered by the OR gates X12 \& X11, which also force A8 - Ai5 at the connector to l's when ADSEL is high.

The data switch information is transferred onto the data bus when required by the Tri-state buffers X22, X23. The inputs of these buffers are high impedance when SWSEL is ' 1 ', otherwise they are at 1 or 0 depending upon the setting of the data switches. (Note; for both the data and address switches, open circuit $=1$, closed $=0$ ). 74125's have been used for $\times 22 \& \times 23$ as these are cheap and readily available. The data register ( $\times 20,21$ ) takes information from the 6800 data bus when RSEL is at i, and latches this information when RSEL falls to 0. The Low Speed Schottky version (74LS75) is used as a normal 7475 would load the 6800 data bus too much, while a 74 L 75 would need additional buffering to drive the LED's. The $\bar{Q}$ outputs of $\mathrm{X} 20,21$ are fully loaded driving the LED's, so the $Q$ outputs are also taken to the card connector to drive any peripheral devices which may be added.

DM81LS97 Octal Tri-State buffers X15, 16 may be added to buffer the data bus to full TTL drive capabillty when it is desired to expand the system, they are not required for the basic 77-68. 74125's cannot be used here as their inputs would load the 6800 data bus outputs too much.

The memory uses two $256 \times 4$ RAM, the widely avallable 2112 devices being chosen. These memories are enabled when MCE is low, the contents of the selected location are read out onto the data bus when MRW is 1, when MRW is 0 the information present on the data bus will be written into the selected location.

The 6800 MPU interrupt inputs $\overline{\mathrm{NMI}}$ and $\overline{\mathrm{TRQ}}$ are not used by the basic 77-68, but are brought to the card connector for future use, and held high by R13, 14 (these are 'active low' inputs).

Timing for the machine is derived from a 5 MHz crystal controlled oscillator. A cheaper RC oscillator using, say, a 7413 could have been used instead, but an accurate timing source is sufficiently valuable in some applications (e.g. a software routine to drive a serial teleprinter input) to make the slight extra expense worthwhile.

The 5 MHz is divided by 8 in X 2 , giving a normal MPU cycle time of 1.6 . This is a bit slower than the maximum operating speed of the $M 6800$, but allows the use of cheap (low speed) memories, and also eases various timing problems that occur if one tries to squeeze the last ounce of performance out of the MPU. The slight reduction in speed does not significantly reduce the system capability.

The MPU clock waveforms $\$ 1$ and $\emptyset 2$ and various other timing signals are derived as shown in Fig 2. Points worthy of note are;

- DBE is high for most of the time. As this line gates the 6800 outputs onto the bus during a Write operation, it allows the use of memories with a relatively long write time, and those which require that the data is present after their $\overline{\mathrm{CE}}$ input goes high at the end of a write cycle.
- The general enable line ( $E$ ) goes to 0 after the end of 02 , ensuring that the 6800 input data hold time requirements are met even when using a fast memory.
- A derived clock is used to synchronise the HALT and LOAD inputs (by $\times 10$ ) to ensure that they only change state at the correct time in the MPU cycle.
- 02 can be extended by holding the HOLD input low by external logic. This allows external slow core (or cheap EPROM) memory
to be added to the system. The external logic must ensure that the 02 ' 1 ' time is not extended beyond the $4.5 u S$ limit given in the M6800 spectification.

The RESET input from the switch is 'de-bounced' by the bistable made from two of $\times 24$ gates.

When the HALT switch is thrown, X 10 pin 5 goes low, applying a HALT signal to the 6800. After completing the current instruction, the 6800 will raise the BA (Bus Available) Iine to 1. Note that the BA line will also go to 1 after execution of the WAl imstruction. BA going to 1 turns off the RUN LED ang, if the HALT switch had been set, puts ADSEL to I which puts AO - A7 under control of the address switches and allows RSEL to go high (when the clock signal on $\times 5$ pin 4 is high) so the data register continually monitors the state of the data bus.

The E line carries a general purpose memory enable signal that goes high when the MPU clock $\phi 1$ is low and a valid address is present on the address bus (X13 VMA output high or the HALT switch thrown).

The '256SEL' card input is not used in the basic 77-68, but if pulled low de-selects the on-card 256 word RAM, allowing the use of an external memory. In the basic 77-68 this card input is left open, pulled high by the 430 ohm resistor.

The MCE line enables the 256 word RAM when low.
X7 detects the 'all ones' condition on the address lines A0 - A7 which is the data switch/register address. It then inhibits the RAM and enables selection of the switch register (MRW high) or data register (MRW low) via $\times 3$, Xig etc.

The MRW line is normally high, and goes low for a write operation (into memory or the data register), including a loAD.

## Chapter 4. Construction \& Testing

The component and connector numbering shown is that for the 77-68 CPU printed circuit board which is avallable as detalled elsewhere. The layout of the major components on this board is shown in Fig. 4. This board is $8.0^{\prime \prime}$ square with a gold plated $0.1^{\prime \prime}$ single sided edge comnector. To cut costs a single sided board has been used thus sone additional wiring is needed to complete the circuit. Nevertheless it forms the basis for a soundly constructed machine. The board has provision for fitting the optional data bus buffers $\times 15, \times 16$.

Compatible 'prototyping' boards and edge connectors are avallable from VERO as;

VB/10725/1 plug-in single sided 0.1" matrix board.


12682 EPOXY ) DIG plug-in boards
$13845 / 1$ single sided piug in DIY board (undrilled, copper clad with edge connector contacts already etched)
10859/4 solder-1ug ) single-sided 0.1' edge comector socket (77 13597/4 mini-wrap ) ways plus polarising key position)

Also, the IMHOF-BEDCO MCV/5CX/100 'MCARD' may be used, although this card is slightly smaller ( $7.9^{\prime \prime}$ wide $\times 7.5^{\prime \prime}$ long) and has only 75 edge contacts (plus polarising slot) corresponding to posttions $2-77$ on the VERO boards.

Should the constructor decide to 'wire his own', layout is not critical, except that the $01 \& 2$ drive lines from $\times 5$ to $\times 13$ (via R17, 18) should be kept short, and power lines, espectally of (Ground) should be thick and laid out in the form of amesh to minimise the impedance (and hence noise) between any two points in the circuit. Decoupling capacitors $\mathrm{Cl}-\mathrm{cll}$ should be distributed evenly across the board, with one of the electrolytics being positioned close to X13, another near X20, 21 .

Whichever method is chosen, it is recommended that sockets be used for the MOS devices ( $\mathrm{Ki} 3,17$ \& 18). The 40 way socket used by $\mathrm{X13}$ should be of reasonable quallity, not requiring excessive insertion force.

The wiring between the edge connctor and the power supply and control panel are shown in Fig. 5. This flgure also shows the basic 'Bus' connections from the CPU board to other boards (such as Memory, Cassette Interface, VDU control) which may be added later.

## Testing

Most of the circuitry can be checked without the expensive X13, 17 or 18.

When the unit is fully assembled, but before plugging in $\mathrm{X13}, 17 \mathrm{E} 18$, check for any possible short-circuits between 0 and +5 V inputs, and then apply power. None of the 1 C (except for $\mathrm{X13}, 17 \& 18$ ) consume much power, so any which feel more than slightly warm to the touch after a few minutes should be suspect.

Testing the oscillator and $\varnothing 1, \varnothing 2$ generator is easy with a 'scope of suitable bandwidth, but for those without, a moving coil voltmeter (greater than lok / Volt resistance) should show;


Edge connector pins $9(5 \mathrm{MHz})$ and 10 (CLK) should be about 1.5 V , as should $\times 10$ pins $3 \varepsilon 11$ and $X 4$ pins $4 \varepsilon 5$. These points should go to either ' ${ }^{\prime}$ ' (about 3 V ) or '0' (about 0.IV) if the oscillator is stopped.

Check the $\overline{H O L D}$ input (pin 8) by earthing it and noting that $\times 13$ pin 37 ( 22 ) goes to +5 V .

X13 pin 40 (RESET) should be at '1', falling to ' 0 ' when the RESET switch is thrown.

The RUN LED should be out, but should light when pin 7 (BA) of X13 is temporarily connected to OV.

X13 pin 2 (HALT) should be 'l', falling to ' 0 ' when the HALT switch is set.

With X13, $17 \varepsilon 18$ still missing, set all address and data switches to ' 0 ' and switch to HALT. All data LED's should be on. Turn the address switches in turn to '/'. Only when they are all at 'l' should the data LED go out (because the address FF of the switch register has
been selected). Leaving the address set to FF check that each data LED can be turned on and off by the corresponding data switch.

With the HALT switch in the RUN position, check that, regardless of the address switch settings, operation of the LOAD switch transfers the setting of the data switches to the LED's. With the LOAD switch unoperated the display should remain unaffected by any alteration of the data switch settings.

Now, plug in one of the 2112 memories ( $\times 17$ ) (the right way round!), turn the power back on and switch to HALT.

You should now be able to store any pattern of bits 4-7 in any address (00 - FE) by;

- setting the data pattern and address on the switches and then operating the LOAD switch.

The stored pattern is read by setting the appropriate address on the switches (with the switch set to HALT).

For example;
set data 00, address 00 , press LOAD

| $"$ | $"$ | 10 | $"$ | 01 | $"$ | $"$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $"$ | 1 | 20 | $"$ | 02 | $"$ | $"$ |
| $"$ | $"$ | 30 | 11 | 03 | $"$ | $"$ |

Then check that;
setting address to 00 displays 00
$\begin{array}{llllll}11 & 11 & 1 & 02 & \end{array}$
etc.
If this seems to be working, plug in the other memory (X18) and check that you can write into and read out of the low four bits as well.

Before proceeding, it is worthwhile spending half an hour or so practicing writing into and reading different memory locations and converting between hexadecimal notation and the switch settings. (Note that address FF is the switch/register, and the memory is inhibited at this address).

Next, carefully test the voltages on X13 socket pins (don't accidentally

```
short two pins together when doing this!);
    pins 1, 21 & 39 are at OV
    pins 4,6 & 8 are at }45\textrm{V
    other pins will be at various voltages but none should be higher
    than +4V.
```

REMOVE ALL POWER FROM THE BOARD.

PLUG IN X13 VERY CAREFULLY - exerting an even pressure on all 40 pins, making sure that it goes into the socket straight, watching for signs of any leads bending under the 10 body. The ceramic package version in particular is rather prone to cracking if an uneven stress is applied.

CHECK THAT IT IS THE RIGHT WAY ROUND.
If the machine has been hand wired, rather than built on a PC board, check that plugging in $X 13$ has not disturbed any wires causing possible short circuits.

Make sure the supply is the correct voltage and polarity, then reconnect it.

With the switch in the HALT position, check that you can still load and read inemory as tested previously.

Then check that pressing the RESET button lights the RUN LED.
Now for the first program. Load the following;


This program reads the contents of location FFFF (the switch register), adds one, then stores the result in location FFFF (the data display register). It then branches back to the beginning and repeats for ever.

Having loaded and checked the program, set the data switches to the start address (00), momentarily depress the RESET button, then switch to RUN. The RUN LED should light and the data display show OL (switch register +1 . Check that whatever the setting of the switch register the display is always one greater. Also check that operation of the HALT switch turns off the RUN LED, and that the machine starts again when the HALT condition is removed.

By changing the instruction stored at location 00 , the program can perform other functions;

| 10c 00 | instr | display |
| :---: | :---: | :---: |
| 7 F | CLR | 00 |
| 73 | COM | One's complement (inverse) of sw reg |
| 70 | NEG | Two's complement (negative) of sw reg |
| 7 A | DEC | Sw reg minus one |
| 79 | ROL | Sw reg rotated left one position (BO will be set according to what was in the $C$ bit) |
| 76 | ROR | Sw reg rotated right one position (B7 will be set according to what was in the $C$ bit) |
| 78 | ASL. | Sw reg shifted left one position (BO set to 'O') |
| 77 | ASR | Sw reg shifted right one position, except for B7 which remains the same |
| 74 | LSR | Sw reg shifted right one position, B7 set to : $0^{\prime}$ |
| 70 | TST | Sw reg unchanged |

Notes;
Each time the ROL instruction is performed during the program, the $C$ bit will be set according to 87 of the switch reg, and in the next operation this will be set into $B 0$ of the display. Bo of the display will therefore equal $B 7$ of the Switch reg.

Similarly, when using tis progran with the ROR instruction, the $C$ bit, ard nence 87 of the display, will equal 80 of the $S w$ reg.

The TST instruction as mplemented on the 6800 actually reads from the addressed location, then stores the data, unaltered, back in the same
location. Thus in this program it transfers the contents of the switch reg into the display reg.

Further test programs are given in the following section, but take heart, having got this far the machine is now basically working.

## Chapter 5. Programming

For a detailed knowledge of the 77-68 instruction set, the constructor should refer to a publication such as the Motorola M6800 Microprocessor Programming Manual or Desig Note 4, however this chapter gives a summary of the more important features, illustrated by programs which will run on the 77-68.

## Programming Model

From the programmer's point of view, the 77-68 consists of;

- Two eight bit accumulators; $A \& B$
- An eight bit 'Condition Code' register
- A 16 bit Program Counter
- A 16 bit Index Register
- 255 (decimal) 8 bit words of random access memory (addresses 00 to FE)
- An 8 bit write-only display register at address FF
- An 8 bit read-only input switch register at address FF


## Notation

The programs in this book are written in Motorola 6800 Assembly Language. Mnemonic codes are used to represent the instructions, and the actual machine code is also given, in hexadecimal format (see Appendix 1).

To save space, each line contains a complete instruction, whether it consists of one, two or three bytes. Thus in the 177-68 FLASHER Version $1^{\prime}$ example, address 06 contains machine code 20 , and machine code F8 is stored in address 07.

## Addressing Modes

The 6800 (and hence the $77-68$ ) has seven addressing modes;
Accumulator Addressing;
One byte, single operand instructions which operate on either of the accumulators e.g. INC A DEC B

Inherent Addressing;
One byte instructions which imply the use of one or more of the 6800 registers e.g. INX ABA

Two or three byte instructions in which the second (and third) byte of the instruction is data. In writing Assembly Language, a \# sign is written before the data to distinguish it from an address e.g.

ADD A \#02 adds the value 2 to accumulator $A$
LDX \# ABCD loads the (hex) value $A B C D$ into the index reg.

## Direct Addressing;

These are two byte instructions in which the second byte contains the address of the operand (which must lie in the range $0-255$ (decimal) 00 - FF hex), and are written in the form;

$$
\text { OP } \quad N \quad \text { where } N \text { is a number or symbol }
$$

e.g. ADD A 27 adds the contents of location 27 to acc. A ADD A ITEM adds the contents of location ITEM to acc. A

## Extended Addressing;

These are three byte instructions which contain full 16 bit address (in the range 0 to FFFF hex) in the second and third bytes. The second byte of the instruction contains the most significant 8 bits of the address and is ignored by the basic 77-68 (which only examines the eight least significant address bits)

## Relative Addressing;

Branch instructions are all two bytes long, where the second byte contains an offset value which specifies the branch destination address according to the formula

$$
D=P C+2+R
$$

where $D=$ address of destination
$P C=$ address of first byte of branch instruction
$R=8$ bit, two's complement, binary number stored in the second byte of the instruction.

When writing branch instructions in assembly code, the address is given as a label which points to the required destination. Thus, in the 'Flasher, Version 1 ' program;

| Address | Machine Code | Assembly Language Mnemonics |
| :---: | :---: | :---: |
| 00 |  | START - - |
| - | ---- | - - |
| - | - - - | - - |
| 06 | 20 F8 | BRA START |

Indexed Addressing;
These are two byte instructions in which the address of the operand is obtained by adding the ( 8 bit ) value in the second byte of the instruction to the ( 16 bit) contents of the index register. Note that, unlike the branch instructions, the second byte of the instruction is treated as a positive unsigned integer in the range 0 to 255 (decimal). This addressing mode is identified in assembly language by the addition of ', $X^{\prime}$ at the end of the instruction, e.g. ADD A ITEM, X

77-68 Flashers
These three programs generate a changing pattern on the display, useful to amuse the children, impress the neighbours, or as a quick check that the system is working.

The main problem is to slow things down so that the pattern changes are visible. Versions 1 \& 2 use the index register as a 16 bit counter; the program only gets beyond the 'BNE START' instruction when the index register steps to zero - every 65000 loops. Version 3 uses three nested loops; the inner loop increments accumulator $A$ until it overflows and passes through zero, the second (middle) loop increments accumulator $B$ once every 2.4 mS until $B$ equals the setting on the switch register. (Don't forget that when starting this program the switch register should be set to zero while the RESET switch is operated). The third, outermost, loop increments the index register every so often and displays the least significant 8 bits.

## Tone Generator

This program generates an audio tone at a frequency determined by the setting of the switch register. To use it, connect bit 7 output of the
display register (connector pin 61) to an audio amplifier via a volume control;


The basic frequency is determined by the first three instructions, and the (square) waveform generated by incrementing the contents of accumulator $B$ (hence changing the state of bit 7) after each timing period.

Taking the audio signal from other outputs of the display register will give a tone one or more octaves lower - for a given setting of the display register.

Tuner
Having made 77-68 generate tones, the next step must be to get it to play a tune!. To do this we need to be able to store in memory details of the notes, the order and durations for which they are played (and the durations of the spaces between the notes).

In the progran Tuner, the tune to be played is stored as a string of pairs of ( 8 bit) bytes in sequential locations, starting at location 'TUNE' (store address 40 hex). Each data byte is interpreted as an unsigned binary integer in the range 0 to 255 (decimal).

The first byte of the string, and subsequent bytes stored in even numbered locations, defines the length of the note or silence. A zero value indicates the end of the tune.

The second byte, and all those stored at odd numbered addresses, define the frequency according to the following table;

| $\begin{gathered} \text { Value of byte } \\ \quad(\text { Hex) } \end{gathered}$ | Note | Value of byte $\qquad$ | Note |
| :---: | :---: | :---: | :---: |
| $\varphi 0$ | Silence | 64 | c |
| 27 | E | 6 A | B |
| 2 C | D | 77 | A |
| 31 | C | 86 | G |
| 34 | B | 97 | F |
| 38 | A | A 0 | E |
| 42 | G | B4 | D |
| 4 B | F | CA | c |
| 51 | E | D6 | B |
| 59 | D | Fø | A |

The first instruction of the program loads the index register with the address of the store location two bytes before the beginning of the 'tune' string, the two subsequent INX instructions increment the index register so that at instruction ' $L D A A \varnothing, X$ ', the index register is pointing at location 'TUNE'. (This may seem a roundabout way to do things, but it simplifies later parts of the program).

LDA A $\emptyset, X$ loads the $A$ accumulator with the value stored at the address 'Index Reg Contents $+\emptyset$ ' i.e. the location TUNE. This is the duration of the first note (or silence), and if it has zero value, the program branches back to START to begin the tune again. The duration value is then stored in the temporary storage location TIME, and accumulator $A$ cleared.

LDA B I,X loads the B accumulator with the value stored at the address 'Index Reg Contents + l' i.e. the location TUNE + 1 . This is the frequency of the note (branch to routine QUIET if the value is zero). The sequence INS, STS FE changes the state of bit 7 of the display register (beginning of one half-cycle of output).

The routine CYCLE is then entered. This decrements two counters;

- a 16 bit counter using accumulator $A$ as the least significant eight bits and temporary location TIME as the eight most significant. When this counter reaches zero the program branches to NUNOTE where the index register is incremented by two to point to the next pair of bytes in the 'tune' list, and the next note (or period of silence) started.
- an eight bit counter using accumulator B which defines the length of one half-cycle of output: When accumulator $B$ reaches zero the program branches to NUCYCL to reload accumulator $B$ and change the state of bit 7 of the display register, thus stariing the next half-cycle of output.

Routine QUIET merely decrements the 16 bit counter (accumulator $A$ and location TIME) until the end of the period, without changing the state of bit 7 of the display register. The NOP instructions are fillers to make the routine cycle time similar to that of the routine CYCLE.

Constructors who have got this far might like to try the tune listed below;

| Location | Values |  | Location | Values |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MSB | LSB |  | MSB | LSB |
| 40 | 20 | 42 | 70 | 20 | 4 B |
| 42 | 20 | 51 | 72 | 20 | 59 |
| 44 | 60 | 00 | 74 | 60 | 00 |
| 46 | 20 | 51 | 76 | 20 | 3 B |
| 48 | 20 | 4 B | 78 | 20 | 34 |
| 4 A | 20 | 42 | 7 A | 20 | 3 B |
| 4 C | 20 | 27 | 76 | 20 | 31 |
| 4 E | 20 | 00 | 75 | 20 | 42 |
| 50 | 20 | 27 | 80 | 60 | 00 |
| 52 | 20 | 00 | 82 | 20 | 42 |
| 54 | 58 | 31 | 84 | 20 | 4 B |
| 56 | 08 | 00 | 86 | 20 | 51 |
| 58 | 20 | 42 | 88 | 20 | 59 |
| 5A | 20 | 51 | 8 A | 20 | 3B |
| $5 c^{\circ}$ | 60 | 00 | 8 C | 20 | 00 |
| 5 E | 20 | 51 | 8 E | 20 | 64 |
| 60 | 20 | 48 | 90 | 20 | 6 A |
| 62 | 20 | 51 | 92 | 20 | 42 |
| 64 | 20 | 42 | 94 | 20 | 00 |
| 66 | 20 | 00 | 96 | 20 | 42 |
| 68 | 20 | 42 | 98 | FF | 64 |
| 6 A | 20 | 00 | 9 A | FF | 00 |
| 60 | 58 | 48 | 9 C | 00 | 00 |
| 6 E | 08 | 00 |  |  |  |

Notes; data \& addresses given in hexadecimal.
MSB = data stored at even numbered location e.g. 40
$L S B=$ data stored at odd numbered location e.g. 41
(SEAR MICROCOMPUTER SYSTEMS


| program | TONE GENERATOR |  | version | 1 author |  | DATE 22－5－n | Page 10 OF 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADDRESS | machine code | label |  | OPERATOR \＆PPERAND |  | comments |  |
| 1中 | 4，$C_{1}$ | StART |  | INC A | 7 | For PERIOD PE | TERMINEP |
| ¢， 1 | Q，1，F，F |  |  | CMP A FF | \＆By | W REG SETTIN | NG（fF） |
| 1.3 | 2，6，F，$B_{1}$ |  |  | BNE START |  |  |  |
| 1.5 | 5，C ，， 1 |  |  | INC ${ }^{\text {S }}$ | cha | state of | data reg |
| 1.6 | D．アFF」 |  |  | STA FF | Bit |  |  |
| ¢ 7 | 4．F1， |  |  | CLR | An | ROUND AGAIN |  |
| 1.9 | 2，¢F， 51 |  |  | BRA START |  |  |  |
| 1 | －1．1． |  |  |  |  |  |  |
| 1. | －1．1． |  |  |  |  |  |  |
| 1. | －1，1， |  |  |  |  |  |  |
| 1. | 1．1． |  |  |  |  |  |  |
| 1, | －1，1， |  |  |  |  |  |  |
| 1． | 1．1．1． |  |  |  |  |  |  |
| 1 | 1.1 |  |  |  |  |  |  |
| －1， | ，1，1， |  |  |  |  |  |  |
| ， 1. | －1，1， |  |  |  |  |  |  |
|  | －1，1， |  |  |  |  |  |  |
| －1， | 1 1 1 1 |  |  |  |  |  |  |
| －1， | ，1．1． |  |  |  |  |  |  |
| 1 | ，1，1， |  |  |  |  |  |  |
| $1$ | 1－1． |  |  |  |  |  |  |
| －1． | －1，1．1． |  |  |  |  |  |  |
| －1， | －1，1， |  |  |  |  |  |  |
| ， | ，1， 1 |  |  |  |  |  |  |
| 1. | －1．1． |  |  |  |  |  |  |
| －1， | －1．1． |  |  |  |  |  |  |
| ＋1． | ＋．．．1． |  |  |  |  |  |  |
| －1． | 1．1．1． |  |  |  |  |  |  |
| －1， | ，1．1．1． |  |  |  |  |  |  |
| －1， | ．1．1． |  |  |  |  |  |  |
| －1． | 1．1．1． |  |  |  |  |  |  |
| －1， | ＋1．．．． |  |  |  |  |  |  |
|  | 1 |  |  |  |  |  |  |
| $\underline{1}$ | ＋1．1． |  |  |  |  |  |  |
| $\square$ | －1． |  |  |  |  |  |  |



BEAR MICROCOMPUTER SYSTEMS
24 College Road, Maidenhead, Berks, SL6 GBN

HEXADECIMAL CODING FORM


## Chapter 6 Extending the system

Enhancenents planned by BMS for the basic 77-68 system include;

- additional memory.
- tape cassette interface.
- VDU and keyboard interface.

However, the following notes are offered as guidance to the experimenter who wishes to design his own circultry, or interface the $77-68 \mathrm{CPU}$ board to other computer parss.

77-68 Bus
This is in three main parts;

1. A bidirectional data bus (pins 38-45) which carries data and instructions between the CPU board and memory or perfpheral devices. The optional buffers $\times 15$ and $\times 16$ convert the low power outputs of the 6800 to normal three-state TTL levels.

A maximum of 10 standard TTL inputs can be driven by the bus, or 44 low power Schottky TTL inputs. Data from external menory or peripherals should be put on to the bus via a threemstate buffer (DM81Ls97 or similar), suitably controlled so that no more than one buffer is trying to drive the bus at any time:

2. A unidirectional 16 line address bus (pins 21-26) with a maximum drive capability of 9 standard TTL gate inputs (or 40 low power schottky).
3. Miscellaneous timing and bus control signals (pins 4-12);

- R/W is a signal from the CPU card which controls the direction of transmission on the data bus. When it is at logicall (read) information should flow to the 6800 from memory or peripherals. When at logical 0 (write), data is being sent from the CPU and therefore no other part of the system should be trying to put information onto the bus.
- When extra memory (or peripherals) are added to the basic system, suitable address decoding circuitry should be included to discriminate between those addresses which refer to the external memory (or peripheral) and those which refer to the memory and data register/display on the CPU board. This external address decoding circuitry should pull the '256sEL' line to 0 (low) with a three-state or open collector gate output whenever external memory is selected by the address bus.
- The 'E' output from the CPU board goes to logical 1 when there is a valid address on the address bus lines.
- The $\overline{H O L D}$ input to the CPU card should normally be high as when pulled low (by the output of a three-state or open collector gate) it will hold the 6800 clock driver in the 'g2 high' state. This allows the use of slow external memory, however care should be taken to ensure that the ' $\emptyset 2$ high' state is not extended beyond the 4.5 uS specification limit for the 6800 .
- '5MHz' and 'CLK' outputs are provided to drive external circuitry (for example that which may be incorporated to extend the $\varnothing 2$ time). Note that 'CLK' is equivalent to 02 and thus goes to 'l' about 200 n later than $E$. It also changes from ' 1 ' to ' 0 ' slightly earlier than $E$ and is therefore useful for gating information from the data bus into external memory or peripheral control registers.

- 'TRQ' and 'NM' are the 6800 interrupt inputs and are normally at +5 V . For detalls of thelr use, the constructor should refer to the 6800 data sheets.

Critical bus timing which should be examined when designing external memory or peripheral circuits are given in Fig. 3. The times shown are the worst case values, thus for a normal (i.e. not extended) cycle;

- data read from menory should be valid not later than 800 n after the 0 to 1 transition of $E$, and not later than $1100 n s$ after the $R / W$ line has settled into the 'l' (read) state.
- during a write cycle, the address lines are stable for at least $1300 n$ S before the '1' to 'O' transition of $E$, and the data from the CPU board is valid for at least $1000 n 5$ before the ' 1 ' to ' 0 ' transition of $E$, and for at least 150 ns afterwards.


## Spare Data Register Outputs R0 - R7

These are brought out to the board edge connector for use as the constructor sees fit. For example, a two digit hexadecimal display using 7 segment LED displays may be added as shown below;


Alternatively, these outputs could be used to drive relays (model train control), a louspeaker ('music' generation), a digital to analogue converter (waveform synthesis) or in whatever way the user wishes.

## Chapter 7. User Group

77-68 is a "live" project. It is a small start to a large system (by microcomputer standards). Designs for other boards will be made. Some by the "Bear" and some no doubt by users. News of all the latest developments and available software will be held by the User group and circulated by the quarterly newsletter. Contained in the newsletter will be a register of all the names and addresses of users, this is to enable a free discussion between constructors as to the merits and deficiences of the system.

The purchase of this book plus registration gives the individual a year's free subscription to the user group.

It is hoped that this "back-up" support will encourage those
individuals with a non-technical background to take the plunge .........


FIG.I 7768 BLOCK DIAGRAM


FIG. 2 MPU CLOCK WAVEFORMS


FIG. 3 IMPORTANT BUS TIMINGS FOR EXTERNAL MEMORY


78
77-68 CPU BOARD - VIEWED FROM COMPONENT SIDE
Showing positions of components and straps.
Join $A 0$ - - A7 to $A 0$ - - A7, and $a, b, c$ etc. to $a, b, c$ ( 8 way ribbon cable makes a neat job; use solid cored type such as Doram 10 way miniature cable No 357-491)
Note: all $1 C^{\prime}$ s are the same way round, all straps are parallel to board edges.

FIG. 4 CPU BOARD - LAYOUT OF MAJOR COMPONENTS


FIG.5 77-68 CPU BOARD CONNECTOR WIRING


FIG. 6 OPTIONAL BUFFERS DM8ILS97


OR


FIG. 7 POWER SUPPLY


FITTING WIRE LINKS
The easiest way is to measure sleeving to length, slide on to length of 22 S.W.G. wire leaving $1 / 2^{\prime \prime}$ bare wire either end, bend and insert.

FIG. 8 NOTES ON THE PC.B. WIRING 8 WAY RIBBON CABLE


Table 1
77-68 Component Distribution
Logic

| X1 | 7404 | X13 | 6800 |  |
| :--- | :--- | :--- | :--- | :--- |
| X2 | 7495 | X14 | 7400 |  |
| X3 | 7410 | X15 | 81 LS97 |  |
| X4 | 7400 | X16 | 81 LS97 |  |
| X5 | 7428 or $7402 *$ | X17 | 2112, | any type |
| X6 | 7428 or $7402 *$ | X18 | 2112, | \& speed |
| X7 | 7430 | X19 | 7402 |  |
| X8 | 74157 | X20 | $74 L S 75$ |  |
| X9 | 74357 | X21 | $74 L S 75$ |  |
| X10 | 7474 | X22 | 74125 |  |
| X11 | 7432 | X23 | 74125 |  |
| X12 | 7432 | X24 | 7400 |  |

Resistors (all $\frac{1}{2}$ Watt)

| R1 | 430 | R20 | 4.7K |  |
| :---: | :---: | :---: | :---: | :---: |
| R2 | 430 | R21 | 4.7 K |  |
| R3 | 430 | R22 | 4.7 K |  |
| R4 | 430 | R23 | 4.7 K |  |
| R5 | 4.7 K | R24 | 4.7K |  |
| R6 | 4.7 K | R25 | 4.7 K |  |
| $R 7$ | 4.7 K | R26 | 4.7K |  |
| R8 | 4.7 K | R27 | 4.7 K |  |
| R9 | 4.7 K | R28 | 4.7 K |  |
| R10 | 4.7 K | R29 | 4.7K |  |
| R11 | 4.7 K | R30 | 4.7K |  |
| R12 | 4.7 K | R31 | 270 |  |
| R13 | 430 | R32 | 430 |  |
| R14 | 430 | R33 | 430 |  |
| R15 | 220 or 1 $\mathrm{K} *$ | R34 | 430 |  |
| R16 | 220 or $1 \mathrm{~K} *$ | R35 | 430 | not mounted on |
| R17 | 22 | R36 | 430 | p.c.b. |
| R18 | 22 | R37 | 430 |  |
| R19 | 4.7 K | R38 | 430 |  |
|  |  | R39 | 430 |  |

Capacitors

| Cl | $0.14 F$ | C8 | 0.1 uF |
| :---: | :---: | :---: | :---: |
| C2 | 33 FF | C9 | 0.1 uF |
| C3 | $33 \mathrm{LF}{ }^{+}$ | C10 | $33 \mathrm{UF}{ }^{+}$ |
| C4 | 0.14 F | Cl 1 | 0.1 uF |
| C5 | 0.14 F | C12 | 33 pF |
| C6 | 0.14 F | + or similar small electrolytics |  |
| C7 | $0.14 F$ |  |  |
| 9 off |  | Crystal | 5 MHz |

Switches
S1 Single pole n.o. push S2,S4-S1l single pole on/off
S3 Single pole c.o. push
toggle
Power Supply
+5 V at ? Amp. See separate diagram.

* opticn

Table 2
77-68 Components List
Logic

| 3 off | 7400 | $\times 4, \times 14,24$ | 1 off | 7495 | $\times 2$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 off | 7402 | $\times 19$ | 2 off | 74125 | $\times 22, \times 23$ |
| 1 off | 7404 | $\times 1$ | 2 off | 74157 | $\times 8, \times 9$ |
| 1 off | 7410 | $\times 3$ | $\times 2$ off | $81 L 597$ | $\times 15, \times 16$ |
| 2 off | 7428 | $\times 5, \times 6$ | 2 off | 2112 | $\times 17, \times 18$ |
| 1 off | 7430 | $\times 7$ | 1 off | 6800 | $\times 13$ |
| 2 off | 7432 | $\times 11, \times 12$ |  |  |  |
| 1 off | 7474 | $\times 10$ |  |  |  |
| 2 off | $74 L 575$ | $\times 20, \times 21$ |  |  |  |
|  |  |  |  |  |  |
| Coptional buffers |  |  |  |  |  |


| 20 off | $4.7 k$ | $\frac{1}{2} w$ | 3 off | $33 u F$ | $6.3 V$ tant |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $* 2$ off | $1 k$ | $\frac{1}{2} w$ | 8 off | 0.1 luF | ceramic |
| 14 off | 430 | $\frac{1}{2} w$ | 1 off | $33 p F$ |  |
| 1 off | 270 | $\frac{1}{2} w$ |  |  |  |
| 2 off | 220 | $\frac{1}{2} w$ |  |  |  |
| 2 off | 22 | $\frac{1}{2} w$ |  |  |  |

L.E.D.'s

9 off

5 MHz

Switches
17 subminiature toggle switches single pole 2 way $\$ 3-19$
1 push single pole n.o. Sl
1 push single pole c.o. $\$ 2$

* option
Low profile sockets

2. off 16 pin
1 off 40 pin

3 feet 22 s.w.g. wire and sleeving
1 foot 8 way ribbon cable
Printed Circuit Board
Edge Connector, 77 way + polarising key $0.1^{\prime \prime}$ single sided.


(i)

```
LRGEND:
```



```
Number of NPU Cyifm:
Number of NPU Cyctro,
Ac:hluarne Plus:
Arthmrtu Maws.
    Bowican ANO.
```



```
Note
```




```
```

+ Boalogn Inclusve OR:

```
```

+ Boalogn Inclusve OR:
(-) Booleon Exclusive OR:
(-) Booleon Exclusive OR:
M Complerient of M:
M Complerient of M:
Transter into.
Transter into.
O Bu:ZENO:

```
O Bu:ZENO:
```

```
    *
```

    *
    00 Byte Zaro

```
```

00 Byte Zaro

```
```




Table 36800 Instruction Set

## cendition code symbols:

[^0]| POINTER OPERATIONS | MNEMONIC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | BOOLEAN/ARITHMETIC OPERATION |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIRECT |  |  | INDEX |  |  | EXTND |  |  | IMPLIED |  |  | BOOLEAN/ARITHMETIC OPERATION |  | 4 | 3 | 2 | 1 |  |
|  |  | OP | $\checkmark$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | 0P | $\sim$ | \# |  | H | 1 | N | 2 | $V$ | C |
| Compare Index Reg | $C P X$ | 8C | 3 | 3 | 9C | 4 | 2 | AC | 6 | 2 | BC | 5 | 3 |  |  |  | $X_{H}-M, X_{L}-(M+1)$ |  |  | (7) |  | (7) | - |
| Decrement Index Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 09 | 4 | 1 | $x-1 \rightarrow x$ | - |  | - | 1 | - | - |
| Decrement Stack Pntr | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 4 | 1 | SP-1 $\rightarrow$ SP | - | - | - | - | - | - |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 4 | 1 | $X+1 \rightarrow X$ | - | - | - | i | - | - |
| Increment Stack Pntr | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 4 | 1 | SP $+1 \rightarrow \mathbf{S P}$ |  | - | - | - | - | - |
| Load Index Reg | LOX | CE | 3 | 3 | DE | 4 | 2 | EE | 6 | 2 | FE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{XH}_{\mathrm{H}^{\prime}}(\mathrm{M}+1) \cdot \mathrm{X}_{\text {L }}$ | - | - | (9) | $t$ | R | - |
| Load Stack Pntr | LDS | 8 E | 3 | 3 | 9E | 4 | 2 | AE | 6 | 2 | BE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{SP}_{\mathrm{H}}(\mathrm{M}+1) \rightarrow$ SP ${ }_{\text {L }}$ | - |  | (9) | 1 | R | - |
| Store Index Reg | STX |  |  |  | DF | 5 | 2 | EF | 7 | 2 | FF | 6 | 3 |  |  |  | $X_{H} \rightarrow M, X_{L} \rightarrow(M+1)$ | - | - | (9) | $t$ | R | - |
| Store Stack Pitr | STS |  |  |  | 9 F | 5 | 2 | AF | 7 | 2 | BF | 6 | 3 |  |  |  | $S P_{H} \rightarrow$ M, SP $_{\text {L }} \rightarrow(M+1)$ | - | - | (9) | 1 | $R$ | - |
| Indx Reg $\rightarrow$ Stack Potr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 4 | 1 | $X-1 \rightarrow$ SP | - | - | - | - | - | - |
| Stack Pntt $\rightarrow$ Indx Reg | ISX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 4 | 1 | $S P+1 \rightarrow X$ | - | - | - | - | - | - |

JUMP AND BRANCH INSTRUCTIONS

| OPERATIONS | MNEMONIC |  |  |  |  |  |  |  |  |  |  |  |  | BRANCH TEST | COND. CODE REG. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | RELATIVE |  |  | INDEX |  |  | EXTNO |  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# | OP | $\sim$ | \# |  | H | 1 | N | 2 | $v$ | C |
| Branch Always | BRA | 20 | 4 | 2 |  |  |  |  |  |  |  |  |  | None | $\bullet$ | - | $\bullet$ | - | - | $\bullet$ |
| Branch It Carry Clear | BCC | 24 | 4 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{C}=0$ | - | - | - | - | - | - |
| Branch If Carry Set | BCS | 25 | 4 | 2 |  |  |  |  |  |  |  |  |  | $C=1$ | - | - | - | $\bullet$ | - | - |
| Branch If = Zero | BEO | 27 | 4 | 2 |  |  |  |  |  |  |  |  |  | $Z=1$ | - | - | - | $\bullet$ | - | * |
| Branch if $\geqslant$ Zero | BGE | 2 C | 4 | 2 |  |  |  |  |  |  |  |  |  | $N \oplus V=0$ | - | - | - | $\bullet$ | $\bullet$ | * |
| Branch if $>$ Zero | BGT | 2 E | 4 | 2 |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | - | - | - | $\bullet$ | $\bullet$ | - |
| Branch If Higher | 8 HI | 22 | 4 | 2 |  |  |  |  |  |  |  |  |  | $C+Z=0$ | - | - | - | $\bullet$ | $\bullet$ | - |
| Branch if $\leqslant$ Zero | BLE | 2 F | 4 | 2 |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=1$ | - | - | - | $\bullet$ | $\bullet$ | - |
| Branch il Lower Or Same | BLS | 23 | 4 | 2 |  |  |  |  |  |  |  |  |  | $C+Z=1$ | - | - | - | $\bullet$ | $\bullet$ | - |
| Branch If < Zero | BLT | 20 | 4 | 2 |  |  |  |  |  |  |  |  |  | $N \oplus \sim=1$ | - | - | - | - | - | $\omega$ |
| Branch If Minus | BMI | $2 B$ | 4 | 2 |  |  |  |  |  |  |  |  |  | $N=1$ | $\bullet$ | $\bullet$ | - | - | - | - |
| Branch if Not Equal Zero | BNE | 26 | 4 | 2 |  |  |  |  |  |  |  |  |  | Z $=0$ | - | - | - | - | - | $\pm$ |
| Branch if Overflow Clear | BVC | 28 | 4 | 2 |  |  |  |  |  |  |  |  |  | $V=0$ | - | - | - | - | - | - |
| Branch If Overflow Set | BVS | 29 | 4 | 2 |  |  |  |  |  |  |  |  |  | $V=1$ | - | - | - | - | - | $\bullet$ |
| Branch if Plus | BPL | 2 A | 4 | 2 |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | - | - | - | - | - | - |
| Branch To Subroutine | BSR | 80 | 8 | 2 |  |  |  |  |  |  |  |  |  |  | $\bullet$ | - | - | - | - | - |
| Jump | JMP |  |  |  | 6E | 4 | 2 | $7 E$ | 3 | 3 |  |  |  | See Special Operations | $\bullet$ | - | - | - | - | - |
| Jump To Subroutine | JSR |  |  |  | AD | 8 | 2 | BD | 9 | 3 |  |  |  |  | - | - | - | - | - | - |
| No Operation | NOP |  |  |  |  |  |  |  |  |  | 02 | 2 | 1 | Advances Prog. Cntr. Only | - | - | - | - | - | $*$ |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  | 3B | 10 | 1 |  |  |  |  |  |  |  |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  |  |  |  |  |  | - |
| Software Interrupt | SWI |  |  |  |  |  |  |  |  |  | 3 F | 12 | 1 | See Special Operations | $\bullet$ | $\bullet$ | - | - | - | - |
| Wait for Interrupt | WAI |  |  |  |  |  |  |  |  |  | 3 E | 9 | 1 |  | - | (11) | - | - | - | - |

CONDITION CODE REGISTER MANIPULATION INSTRUCTIONS

| OPERATIONS | MNEMONIC |  |  |  | BOOLEAN OPERATION | COND. CODE REG. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | \# |  | H | 1 | N | Z | V | C |
| Clear Carry | CLC | OC | 2 | 1 | $0 \sim \mathrm{C}$ | - | - | - | - | - | R |
| Clear interrupt Mask | CLI | OE | 2 | 1 | $0 \rightarrow 1$ | - | R | - | - | - | - |
| Cleat Overflow | CLV | DA | 2 | 1 | $0 \rightarrow V$ | - | - | - | - | R | - |
| Set Carry | SEC | 00 | 2 | 1 | $1 \rightarrow$ C | - | - | - | - | - | S |
| Set Interrupt Mask | SEI | DF | 2 | 1 | $1 \rightarrow 1$ | - | S | - | - | - | - |
| Set Overtlow | SEV | 0B | 2 | 1. | $1 \rightarrow \mathrm{~V}$ | - | - | - | - | S | - |
| Acmitr $A \rightarrow$ CCR | TAP | 06 | 2 | 1 | $A \rightarrow \mathrm{CCH}$ |  |  |  |  |  |  |
| CCR $\rightarrow$ Acmlt $A$ | TPA | 07 | 2 | 1 | CCR $\rightarrow$ A | - | - | - | - | - | $\bullet$ |

CONDITION CODE REGISTER NOTES:
(Bit set if test is true and cleared otherwise)
Bit V) Bit seat iest is rue and
(Bit C) Test Result 00000000 ?
(Bit C.) Test. Decmai value of most significant BCD Character greater than nine? (Not cleared if previously set.)
(BIt V) Fest Operand : 10000000 prior to execution?
(Bit V) Test: Operand $=01111111$ prior to execution?
(E. V ) Test Set equal to resilt of $\mathrm{N} \oplus \mathrm{C}$ after shift has occurred.
(Bis N) Test: Sign bit of most significan: MS) byte $=1$ ?
(Sit V) Test Tiscomplement overflow from subtraction of MS bytes?
(But N) Test Resuth less thanzero? (Bit $15=1$ )
A. Load Conotic. Code Register from Stack. (See Special Operations)
(Bit 1) Set when isterrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state.
(Ail) Set according to ine contents of Accumulator $A$.

Table 36800 Instruction Set

| 1 | O.V |
| :---: | :---: |
| 2 | O.V |
| 3 | $+5 \mathrm{~V}$ |
| 4 | R/W |
| 5 | SEL |
| 6 | E |
| 7 | blank |
| 8 | HOLD |
| 9 | 5 MHZ |
| 10 | CLK |
| 11 | IRQ |
| 12 | NMI |
| 13 | $A \varnothing>$ |
| 14 | Al |
| 15 | A2 |
| 16 | A3 |
| 17 | A4 Address switches |
| 18 | A5 |
| 19 | A6 |
| 20 | A7 |
| 21 | $A \square^{-}$ |
| 22 | A1 |
| 23 | A2 |
| 24 | A3 |
| 25 | A4 |
| 26 | A5 |
| 27 | A6 |
| 28 | A7 Address Bus |
| 29 | A8 |
| 30 | A9 |
| 31 | A10 |
| 32 | A11 |
| 33 | A12 |
| 34 | A13 |
| 35 | A14 |
| 36 | A15 |
| 37 | $0 . \mathrm{V}$ |
| 38 | D7 |
| 39 | D6 |


| 40 | D5 |
| :---: | :---: |
| 41 | D4 |
| 42 | D3 |
| 43 | D2 Data Bus |
| 44 | D1 |
| 45 | $D \emptyset$ |
| 46 | D7 |
| 47 | D7 |
| 48 | D6 |
| 49 | D6 |
| 50 | $\overline{\mathrm{DS}}$ D5 Data LED's |
| 51 | D5 Data Led's |
| 52 | $\overline{\text { D4 }}$ ( ${ }^{\text {E }}$ ( |
| 53 | - D4 $\begin{aligned} & \text { Spare Data } \\ & \text { Reg Outputs }\end{aligned}$ |
| 54 | D3 Reg Outputs |
| 55 | D3 |
| 56 | $\overline{\mathrm{D} 2}$ |
| 57 | D2 |
| 58 | $\overline{\text { D1 }}$ |
| 59 | $\overline{\text { Da }}$ D1 |
| 60 | $\overline{D \emptyset}$ |
| 61 | DD |
| 62 | D7 |
| 63 | D6 |
| 64 | D5 |
| 65 | D4 ${ }^{\text {d }}$ ( Data Switches |
| 66 | D3 |
| 67 | D2 |
| 68 | Blank |
| 69 | D1 |
| 70 | $D \emptyset \quad$ |
| 71 | 'RUN' LED |
| 72 | \}RESET |
| 73 | \} RESET $\{$ To Control |
| 74 | LOAD $\quad$ Switches |
| 75 | HALT |
| 76 | +5V |
| 77 | 0 V |
| 78 | OV |

Table 4 77-68 pin assignment - edge connector

## Appendix 1

## Binary, Decimal and Hexadecimal Notations

Although the 77-68, like most other computers, actually handles information in binary form, humans have great difficulty in remembering long strings of 'I's and '0's. However, by taking groups of 4 binary bits and expressing each group in 'hexadecimal' (base 16) format, we can write binary patterns in a more readable form.

| Binary |  |  |
| :---: | :---: | :---: |
| MSB | LSB | Hexadecimal <br> representation |
| 0 | 0 | 0 |
| 0 | 0 | 0 | 1

Notes; $M S B=$ most significant of 4 binary bits LSB = least significant

Thus each 8 bit word can be expressed as two hexadecimal characters;
Binary (e.g. inf as stored in computer or set on data: 10100011 switch reg or displayed)

Hexadecimal (as written for human use) : $\quad \mathrm{A}$ 3 And a 16 bit address as four hex characters;


Generally the information contained in an eight bit word is considered to be a positive (unsigned) integer in the range 0 to 255 (decimal). (In practice the information may instead be an ASCII coded character, or two BCD digits, or whatever else the user decides - but ignore these possibilities for the moment). Then each binary bit in the word has a particular value; $B 0$ (least significant) $=1$, $B 1=2, B 2=4--B 7$ (most significant) $=128$. Thus for example;
$10000011=128+2+1=131$ (decimal)
However, this binary word would be written in hexadecimal as '83'.
Conversion between hexadecimal representations and their decimal equivalents may be done by reference to the following table;

Hex Character
Equivalent decimal
(Hex char on left) (Hex char on right)

| 0 | 0 | 0 |
| :--- | ---: | ---: |
| 1 | 16 | 1 |
| 2 | 32 | 2 |
| 3 | 48 | 3 |
| 4 | 64 | 4 |
| 5 | 80 | 5 |
| 6 | 96 | 6 |
| 7 | 112 | 7 |
| 8 | 128 | 8 |
| 9 | 144 | 9 |
| A | 160 | 10 |
| B | 176 | 11 |
| C | 192 | 12 |
| D | 208 | 13 |
| E | 224 | 14 |
| F | 240 | 15 |

Thus Hex ' $83^{\prime}=$ decimal $128+3=131$
Note again that this conversion table applies only to unsigned positive integers stored in natural binary form.


[^0]:    ```
    H Helf carry hrombit 3.
    I Intestemt mask
    Neguive (syy but)
    Zern (oybo)
    Overllow, Z's compiement
    Carry fromit+1?
    Reset Alvars
    Sit Alvays
    Not Atreceg true.deard utherw,
    H. Refl carty mombit 3.
    \(z\) Zen (oybo)
    8 Resel Ahways
    : Tertand set at true. cleard utherwis
    - NotAltected
    ```

