

**Logic gates**

Logic variables and logic gates

- Logic/binary/boolean variables can only take 2 values - TRUE (1) or FALSE (0).
- In electronic circuits, the 2 states of logic variable are represented by 2 voltage levels.
- Electronic circuits that have logic signals in their i/p/s and o/p/s are logical/digital circuitry.
- Basic logic circuits w/ one or more inputs, and one output are known as gates, which can implement an individual logic function.

**NOT gate**

- Graphical symbol



i/p-o/p map

|   |   |   |
|---|---|---|
| A | 0 | 1 |
|   | 1 | 0 |

Boolean representation

$$Y = \bar{A}$$

**AND gate**

- Graphical symbol



i/p-o/p map

|   |   |   |
|---|---|---|
| A | 0 | 1 |
| B | 0 | 0 |
|   | 1 | 0 |

Boolean representation

$$Y = A \cdot B$$

more inputs are possible

**OR gate**

- Graphical symbol



i/p-o/p map

|   |   |   |
|---|---|---|
| A | 0 | 1 |
| B | 0 | 1 |
|   | 1 | 1 |

Boolean representation

$$Y = A + B$$

more inputs are possible

**XOR gate**

- Graphical symbol



i/p-o/p map

|   |   |   |
|---|---|---|
| A | 0 | 1 |
| B | 0 | 1 |
|   | 1 | 0 |

Boolean representation

$$Y = A \oplus B = A \cdot \bar{B} + \bar{A} \cdot B$$

only 2 inputs

# For Personal Use Only -bkwk2

## NAND gate

- Graphical representation



more inputs are possible

i/p-o/p map

|   |   |   |
|---|---|---|
| A | 0 | 1 |
| B | 0 | 1 |
|   | 1 | 0 |

Boolean representation

$$Y = \overline{A \cdot B}$$

## NOR gate

- Graphical representation



more inputs are possible

i/p-o/p map

|   |   |   |
|---|---|---|
| A | 0 | 1 |
| B | 0 | 1 |
|   | 1 | 0 |

Boolean representation

$$Y = \overline{A + B}$$

## Building gates from transistors

### Ideal inverter

- A high voltage represents logic 1, a zero voltage represents logic 0

- The characteristic of an ideal inverter is as follows:



- This characteristic is nonlinear → we can use a graphical technique for analyzing nonlinear circuits.

## Solving non-linear circuits.

- We can use the following graphical method to solve for the operating pt.



- The characteristic of the lower component is plotted normally whereas the characteristic of the upper component is drawn backwards along the V-axis, starting at Vsupply.
- The operating pt. is the intersection of the characteristics.

### NMOS inverter

- An n-type enhancement mode MOSFET conducts when  $V_{GS}$  exceeds a threshold voltage  $V_T$ , typically about 2V.



- The circuit of a simple NMOS inverter is as shown:



- Applying the graphical method to find the operating pt  $\rightarrow$  I/p-O/p characteristic



- The input-output characteristic of the NMOS inverter is far from the ideal inverter

- However, if we say  $V > 9V$  is logic 1 ;  $V < 2V$  is logic 0,  
then the gate will work:  $V_{in} > 9V \rightarrow V_{out} < 2V$  ;  $V_{in} < 2V \rightarrow V_{out} > 9V$

- If we redefine the voltage for logic 1/0, the circuit characteristic does not deviate too much from the ideal

### Speed of NMOS logic

- One of the main speed limitations in real NMOS logic is due to stray capacitance. We can modify the circuit as shown below.



- Assume that initially  $V_{in}$  is HIGH, so  $V_{out} = 1V$ . At time  $t=0$ ,  $V_{in}$  falls to 0V, so  $I_D=0$

$$\text{KCL: } I_R = I_C + I_D^0 \rightarrow \frac{V_{DD} - V_{out}}{R} = C \frac{dV_{out}}{dt}$$

$$\text{Rearranging: } \frac{dV_{out}}{dt} = -\frac{1}{RC}(V_{out} - V_{DD}) \rightarrow \int_{V_{out}}^{V_{out}'} \frac{1}{V_{out} - V_{DD}} dV_{out} = - \int_0^t \frac{1}{RC} dt$$

$$\therefore V_{out} = V_{DD} + ((V_{DD} - V_{out}') e^{-\frac{t}{RC}})$$

- Typically,  $C \sim 10\text{PF}$  (fixed) and  $R \sim 1\text{k}\Omega$  so  $RC = 10\text{ns}$ .

- To switch (charge), we need to reach 95%  $V_{DD} \rightarrow$  we need  $\sim 3RC = 30\text{ns}$ .

- If discharging of charge through the capacitor takes  $\sim 10\text{ns}$ , then a full cycle (charge+discharge) would take at least  $< 40\text{ns}$  ( $f = 1/40\text{ns} = 25\text{MHz}$ )

# For Personal Use Only -bkwk2

Using a FET to replace the resistor

/ 100 x smaller than resistor

- A big advantage of transistors is that they are small. Implementing a resistor on a chip takes up a lot of space on the silicon, (cost of chip  $\propto$  size of chip)

- We can make a MOSFET behave (almost) like a resistor by connecting the gate to drain.



$$V_{DS} = V_{GS}$$



- The characteristic is not quite a straight line so its behaviour is not exactly the same as a resistor. However, we only deal w/ extremes in digital circuits, so this approximation is good enough (Resistance  $\approx 90\Omega$ ).

- Using a FET to approximate a resistor, we can produce a revised design for an inverter circuit that is easier to miniaturize.



## Power consumption of NMOS inverter

- For simplicity, consider the NMOS inverter w/ a resistor.



- When  $V_{out} = 10V$ , there is no pd across the resistor, so there is no current ( $I_D$ ) and hence no power is dissipated.

- When  $V_{out} \neq 10V$ , the pd across the resistor is no longer zero, so current flows down the resistor and power is dissipated as heat.

- For example, when  $V_{in} = 10V$ ,  $V_{out} = 1V$ ,  $I_D = \frac{10-1}{1000} = 9mA$  so using  $P = I_D^2 R$  and  $P = I_D V$ , we find that 81mW and 9mW will be dissipated in the resistor and the FET respectively.

\* Note that  $P_{FET} < P_R$ .

# For Personal Use Only -bkwk2

NAND gate and NOR gate using NMOS logic

- A NAND gate can be built using NMOS as shown below:



- A NOR gate can be built using NMOS as shown below:



## CMOS inverter

- A complementary MOS (CMOS) uses both n-type MOSFETs and p-type MOSFETs.
- p-type MOSFETs are essentially n-type MOSFETs w/ all the polarities reversed.
- The circuit of a CMOS inverter is as shown:



- The NMOS and PMOS characteristic is as shown



- Applying the graphical method to find the operating pt.  $\rightarrow$  i/p/o/p characteristics.



- The input-output characteristic of the CMOS inverter is much closer to the ideal inverter.

- Qualitatively, a CMOS inverter works as follows:

| $V_{in}$   | $V_{GS}/nMOS$ | $V_{GS}/pMOS$ | $V_{out}$ |
|------------|---------------|---------------|-----------|
| 0V (LOW)   | 0V(OFF)       | -10V(ON)      | HIGH      |
| 10V (HIGH) | 10V(ON)       | 0V(OFF)       | LOW       |

\* THE NMOS AND PMOS ARE NEVER ON SIMULTANEOUSLY

# For Personal Use Only -bkwk2

## Power consumption of CMOS inverter

- For a CMOS inverter, the power dissipated varies w/  $V_{in}$  as follows:



- Neither  $V_{in}=10V$  or  $V_{in}=0V$  dissipates power.
- Current only flows when the gate is changing state  $\rightarrow$  power is only dissipated at the gate switches on or off. (Inverter draws max. power at  $V_{in}=5V$ )
- The power can be calculated using  $P=I_0V$  (both  $I_0$ ,  $V$  from the operating pt.).

## NAND gate and NOR gate using CMOS logic

- A NAND gate can be built using CMOS as shown below:



- A NOR gate can be built using CMOS as shown below:



## Logic families

- NMOS: slow due to stray capacitance

High power consumption

- CMOS: propagation delay  $\sim 8\text{-}50\text{ ns}$ ; max. clock speed  $\sim 12\text{-}40\text{ MHz}$ .

Power consumption  $< 10^6 \text{ W/gate}$  when idle,  $\sim 10^4 \text{ W/gate}$  when changing at 100Hz.

- TTL (transistor-transistor logic): propagation delay  $\sim 15\text{-}40\text{ ns}$ ; max. clock speed  $\sim 35\text{-}200\text{ MHz}$  (fast)

use bipolar transistors  
Power consumption  $\sim 10^2 \text{ W/gate}$  (high power consumption)

- ECL (emitter-coupled logic): high speed

High power consumption as current flows all the time.

# For Personal Use Only -bkwk2

**Boolean algebra for logic design** — *rigorous, easy to adapt for larger problems*

Boolean algebra.

- Commutation (switching order of inputs of gate)

$$\hookrightarrow A+B = B+A$$

$$\hookrightarrow A \cdot B = B \cdot A$$

- Association (adding inputs to the gate)

$$\hookrightarrow (A+B)+C = A+(B+C)$$

$$\hookrightarrow (A \cdot B) \cdot C = A \cdot (B \cdot C)$$

- Distribution

$$\hookrightarrow A \cdot (B+C+...) = A \cdot B + A \cdot C + ...$$

$$\hookrightarrow A + (B \cdot C \cdot ...) = (A+B) \cdot (A+C) \cdot ...$$

- Absorption

$$\hookrightarrow A + (A \cdot C) = A$$

$$\hookrightarrow A \cdot (A+C) = A$$

- ORs

$$\hookrightarrow A + 0 = A$$

$$\hookrightarrow A + A = A$$

$$\hookrightarrow A + 1 = 1$$

$$\hookrightarrow A + \bar{A} = 1$$

- ANDs

$$\hookrightarrow A \cdot 0 = 0$$

$$\hookrightarrow A \cdot A = A$$

$$\hookrightarrow A \cdot 1 = A$$

$$\hookrightarrow A \cdot \bar{A} = 0$$

- AND takes over precedence over OR

- Every boolean law has a dual — any valid statement is also valid w/

↪ . replaced by +

↪ 0 replaced by 1

↪ + replaced by .

↪ 1 replaced by 0.

$$\begin{array}{l} \text{e.g. } A+0=A \\ \downarrow \\ A \cdot 1=A \end{array}$$

De Morgan's theorem.

- In a simple expression ( $A+B+C/A \cdot B \cdot C$ ), we can change all the operators from OR to AND and vice versa, provided we put a bar over each term individually and a further bar over the whole expression.

$$\hookrightarrow A+B+C+\dots = \overline{\overline{A} \cdot \overline{B} \cdot \overline{C} \dots}$$

or

$$A+B+C+\dots = \overline{\overline{A} \cdot \overline{B} \cdot \overline{C} \dots}$$

$$\hookrightarrow A \cdot B \cdot C \cdot \dots = \overline{\overline{A} + \overline{B} + \overline{C} + \dots}$$

or

$$A \cdot B \cdot C \cdot \dots = \overline{\overline{A} + \overline{B} + \overline{C} + \dots}$$

- De Morgan's theorem for 2 variables can be proved by exhaustion. This can be extended to more variables by induction (grouping variables into 1 variable).

# For Personal Use Only -bkwk2

Every variable in every term

- A useful technique is to expand each term until it includes one instance of each variable (on its complement). It may be possible to cancel terms in this expanded form.
- We can expand by multiplying by  $1 = B + \bar{B}$ . (e.g.:  $A = AB + A\bar{B}$ ).

- e.g.: Simplify  $X \cdot Y + \bar{Y} \cdot Z + X \cdot \bar{Z} + X \cdot Y \cdot \bar{Z}$

$$\begin{aligned}
 X \cdot Y + \bar{Y} \cdot Z + X \cdot \bar{Z} + X \cdot Y \cdot \bar{Z} &= \underline{X \cdot Y \cdot \bar{Z}} + \underline{X \cdot Y \cdot \bar{Z}} + \underline{X \cdot \bar{Y} \cdot Z} + \underline{X \cdot \bar{Y} \cdot Z} + \underline{X \cdot Y \cdot Z} \\
 &= X \cdot Y \cdot \bar{Z} + X \cdot Y \cdot \bar{Z} + X \cdot \bar{Y} \cdot Z + \bar{X} \cdot \bar{Y} \cdot Z \\
 &= X \cdot Y \cdot (\bar{Z} + \bar{Z}) + \bar{X} \cdot \bar{Y} \cdot (Z + \bar{Z}) \\
 &= X \cdot Y + \bar{Y} \cdot Z
 \end{aligned}$$

Expanding variables.

- Another useful technique is to expand a variable by multiplying by  $1 = 1 + B$

- e.g.: Simplify  $A \cdot \bar{A} \cdot B$  w/o using commutation over multiplication.

$$\begin{aligned}
 A + \bar{A} \cdot B &= A(1 + B) + \bar{A} \cdot B \\
 &= A + A \cdot B + \bar{A} \cdot B \\
 &= A + B(A + \bar{A}) \\
 &= A + B.
 \end{aligned}$$

Algebraic logic design

- If we design a logic circuit using gates of only certain types, we would only need to stock a limited range of gates  $\rightarrow$  readily available and cheap.
- To design a logic circuit using only NAND/NOT gates, we want a sum of products for the output  $Y$ , then apply De Morgan's theorem.

$$\hookrightarrow \text{e.g.: } Y = (\bar{A}_3 + \bar{A}_1 + \bar{A}_2) \cdot B = \overline{\bar{A}_3 B + \bar{A}_1 \bar{A}_2 B} = \overline{\bar{A}_3 B} \cdot \overline{\bar{A}_1 \bar{A}_2 B}$$

- To design a logic circuit using only NOR/NOT gates, we want a sum of products for the outputs complement  $\bar{Y}$ , then apply De Morgan's theorem and invert.

$$\hookrightarrow \text{e.g.: } \bar{Y} = A_1 A_3 + A_2 A_3 + \bar{B} = \overline{\bar{A}_1 + \bar{A}_3} + \overline{\bar{A}_2 + \bar{A}_3} + \bar{B} \Rightarrow Y = \overline{\overline{\bar{A}_1 + \bar{A}_3} + \overline{\bar{A}_2 + \bar{A}_3} + \bar{B}}$$

\* We could get the NOR expression by applying De Morgan's theorem on the NAND expression, but it is generally not optimised (uses more gates)

$$\hookrightarrow \text{e.g.: } Y = \overline{\overline{\bar{A}_3 B} \cdot \overline{\bar{A}_1 \bar{A}_2 B}} = \overline{(\bar{A}_3 + \bar{B}) \cdot (A_1 + A_2 + \bar{B})} = \overline{\bar{A}_3 + \bar{B}} + \overline{A_1 + A_2 + \bar{B}}$$

\* A NOT gate can be made from a NAND/NOR gate by connecting the inputs.

# For Personal Use Only -bkwk2

Standard boolean forms.

- Sum of products (SOP) : usually best to write down an expression for Y directly.
- Product of sums (POS) : usually best to write down an expression for Y and use De Morgan's theorem (twice — each individual product to sum ; sum of sums to product of sums).
- If it is not easy to convert between SOP and POS by algebraic manipulation  $\rightarrow$  best to consider all the binary permutations to find Y and  $\bar{Y}$  (use Karnaugh maps).

VHDL.

- Very high speed integrated circuits hardware description language (VHDL) describes circuits in terms of design entities.
- Each entity consists of 2 parts — the interface and the architecture.

entity component name is

list of input and output ports

end component name ;

architecture arch\_name of component\_name is

declaration of internal signals ;

begin

description of what the entity does and how it's implemented

end arch\_name ;

entity

architecture

- To use a gate entity in a larger design, we use the following syntax:

unqualified label to refer to this gate : entity name of gate (name of gate architecture)

port map ("port list" of signals connected to gate);

- e.g.: NOT gate (inverter),  $Y = \bar{A}$

entity INV is

port(A: in BIT;

Y: out BIT);

end INV;

architecture IMOD of INV is

begin VHDL operator for "equals"

$Y \leq \text{not } A$ ;

end IMOD;

- e.g.: 2 port NAND gate,  $Y = \overline{A \cdot B}$

entity NAND2 is

port(A,B: in BIT;

Y: out BIT);

end NAND2;

architecture N2M of NAND2 is

begin

$Y \leq \text{not}(A \text{ and } B)$ ;

end N2M;

# For Personal Use Only -bkwk2

- eg. Create an entity "ent1" w/ architecture "arch1" that represents the logic  
 circuit  $Y = (\bar{A} \cdot B) \cdot A$

entity ent1 is

port (A, B : in BIT;

Y : out BIT);

end ent1;

architecture arch1 of ent1 is;

signal AX, R : BIT;

begin

internal signals



I : entity INV(LIMOD) port map (A, AX);

N1 : entity NAND2(NAND2M) port map (AX, B, R);

N2 : entity NAND(NANDM) port map (A, R, Y);

end arch1;

i/p o/p

i/p o/p

## Karnaugh maps for logic design

### Karnaugh maps.

- Karnaugh maps are a powerful visual tool for carrying out simplification and manipulation of logic expressions w/ up to 5 variables.

- The Karnaugh map is a rectangular array of cells. Each possible state of the i/p variables corresponds uniquely to one of the cells, in which we write the corresponding o/p states.

- Karnaugh maps for 3/4/5 variables are shown below:



# For Personal Use Only -bkwk2

## Using Karnaugh maps

- After writing the output states (0 or 1) on the Karnaugh map, we try to group the 1s ( $Y$ ) / 0s ( $\bar{Y}$ ) into rectangles that are as large as possible (so less are needed).
  - ↳ For a 5-variable Karnaugh map, we try to group the 1s ( $Y$ ) / 0s ( $\bar{Y}$ ) into blocks that are as large as possible when 2x4-variable Karnaugh maps are overlapped.
  - Karnaugh maps wrap round flip-bottom and side-to-side
  - Each rectangle/block corresponds to a term in the final simplified Boolean expression.
- e.g. Simplify  $\bar{A} \cdot B \cdot \bar{D} + B \cdot C \cdot D + \bar{A} \cdot B \cdot \bar{C} \cdot D + C \cdot D$  using a Karnaugh map.



∴ The simplified expression is  $\bar{A} \cdot B + C \cdot D$

## Don't care states

- In some applications, the output state for certain combinations of input variables may not matter. Such states are don't care states and are denoted by X.
- The don't care states can be chosen to be 0 or 1, whichever helps to produce the simplest logic (i.e. fewest simplest terms).

## Karnaugh map circuit design.

- To design a logic circuit using only NAND/NOT gates,
  - ↳ Write down simplest sum-of-products for the output Y from the Karnaugh map (1s).
  - ↳ Apply De Morgan's theorem ( $\neg\neg P \rightarrow P$ )
- To design a logic circuit using only NOR/NOT gates,
  - ↳ Write down simplest sum-of-products for the outputs complement  $\bar{Y}$  from the Karnaugh map (0s).
  - ↳ Apply De Morgan's theorem ( $\neg P \rightarrow \neg\neg P$ )
- \* Sometimes a simpler logic circuit can be produced by mapping the opposite way (group 0s for NAND; group 1s for NOR) and use a final inverter gate to change the output back again

# For Personal Use Only -bkwk2

## Hazards

- A static hazard is when a signal undergoes a momentary transition when it is supposed to remain unchanged.
- A dynamic hazard is when a signal changes more than once when it is supposed to change just once.



- Hazards arise due to propagation delay of gates.

- e.g.: Consider the output when  $Z=1$ ,  $X=1$  and  $Y$  changes from 1 to 0.

for the circuit shown. All gates have propagation delay  $\Delta t$



## Removing hazards

- Fix a static-1 hazard by drawing the Karnaugh map of the output  $Y$ . Make sure all the sum-of-product terms overlap.
- Fix a static-0 hazard by drawing the Karnaugh map of the output's complement  $\bar{Y}$ . Make sure all the sum-of-product terms overlap.
- Fix dynamic hazards by redesigning the circuit to simplify the logic beyond the scope of this course.

- e.g.: Remove the static-1 hazard from the circuit above ( $w = \underline{x} \cdot y + \bar{y} \cdot z$ ).



The hazard is removed from the circuit by adding an extra AND gate so now

$$w = x \cdot y + \bar{y} \cdot z + x \cdot z$$

# For Personal Use Only -bkwk2

## Unit distance codes

- Applications exist where a code is req. in which not more than 1 bit changes between consecutive nos. (eg shaft encoder).
- In some designs, there may be unwanted transitory states due to poor positioning, which can be avoided using unit distance codes.
- As we move from a cell to its neighbour in a torough map, only 1 variable changes (since the map wraps round, this is also true moving from top/bottom or left/right).
- This property of torough maps can be used to produce a code in which only 1 bit changes at a time  $\rightarrow$  unit distance code.

- e.g.: Grey code -



A B C D

|         |  |
|---------|--|
| 0 0 0 0 |  |
| 0 0 0 1 |  |
| 0 0 1 1 |  |
| 0 0 1 0 |  |
| 0 1 1 0 |  |
| 0 1 1 1 |  |
| 0 1 0 1 |  |
| 0 1 0 0 |  |

A B C D

|         |  |
|---------|--|
| 1 1 0 0 |  |
| 1 1 0 1 |  |
| 1 1 1 1 |  |
| 1 1 1 0 |  |
| 1 0 1 0 |  |
| 1 0 1 1 |  |
| 1 0 0 1 |  |
| 1 0 0 0 |  |

\* other unit distance codes are possible using a different path around the torough map.

**Binary numbers****Binary numbers**

- Binary is base 2. Each digit is either 0 or 1.

$$\begin{array}{r} 2 \mid 1 \\ 2 \mid 0 \dots 1 \\ 2 \boxed{5} \dots 0 \\ 2 \boxed{2} \dots 1 \\ 1 \dots 0 \end{array} \quad 21_{10} = 10101_2$$

- We can convert decimal into binary using the remainders from successive division.

- A binary digit is called a bit; An 8-bit storage location is a byte.

**Octal numbers**

$$\begin{array}{r} 8 \mid 42 \\ 8 \mid 5 \dots 2 \\ 8 \boxed{5} \dots 1 \\ 8 \boxed{6} \dots 0 \end{array} \quad 42_{10} = 52_8$$

- Octal is base 8. Each digit is either 0, 1, 2, 3, 4, 5, 6, 7 or 8.

- We can convert decimal into octal using the remainders from successive division.

- We can convert between binary and octal by dividing the binary digits into 3-bit groups.

**Hexadecimal numbers**

$$\begin{array}{r} 16 \mid 63 \\ 16 \mid 3 \dots 15 \\ 16 \boxed{3} \dots 15 \end{array} \quad 63_{10} = 3F_{16}$$

- Hexadecimal is base 16. Each digit is either 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E or F.

- We can convert decimal into hexadecimal using the remainders from successive division.

- We can convert between binary and hexadecimal by dividing the binary digits into 4-bit groups.

- Two hexadecimal digits are often used to specify the contents of a byte.

- In assembler programming, hexadecimal nos are indicated using & (e.g. \$57 means 57<sub>16</sub>)

**Negative numbers – sign and magnitude representation**

- For an 8-bit no. using the sign and magnitude representation, the MSB indicates the sign (0:+, 1:-), remaining 7 bits contain the magnitude.



- The sign and magnitude representation is not used because:

↳ We have two zeros: +0(00H) and -0(80H) → we have 1 less no.

↳ We req. separate circuits to add +ve and -ve nos.

# For Personal Use Only -bkwk2

Negative numbers - 2's complement

- To convert between the and the 2's complement no., we invert all the bits and add 1.



- When we do this to an 8-bit binary no.  $-x$ ,

↳ Invert all the bits :

$$x \rightarrow (255-x)$$

↳ Add 1 :

$$(255-x) \rightarrow (256-x)$$

$$+ 256_{10} = 100H$$

Ignore 7th bit.

- Since  $100H$  will not fit into an 8-bit byte, it equals  $00H$  and sets the carry flag.

If we choose to ignore the carry flag, then  $256-x$  will behave just like  $00H$ .

- Therefore, we can use normal binary arithmetic to manipulate the 2's complement and it behaves just like  $-x$ .

- When working w/ unsigned nos., we can detect overflow using the carry flag. As we deliberately ignore the carry flag when working w/ 2's complement nos., we detect overflow by checking if carry into the MSB & carry out of the MSB instead.

e.g.:  $15 + 15$

$$\begin{array}{r} 0\ 0\ 0\ 0\ 1\ 1\ 1\ 1 \quad (+15_{10}) \\ 0\ 0\ 0\ 0\ 1\ 1\ 1\ 1 \quad (+15_{10}) \\ \hline 0\ 0\ 0\ 0\ 1\ 1\ 1\ 0 \end{array}$$

$\times\ \times$   
no carry out of MSB ; no carry into MSB  
 $\rightarrow$  no overflow

e.g.:  $-127 + (-2)$

$$\begin{array}{r} 1\ 0\ 0\ 0\ 0\ 0\ 0\ 1 \quad (-127_{10}) \\ 1\ 1\ 1\ 1\ 1\ 1\ 1\ 0 \quad (-2_{10}) \\ \hline 1\ 1\ 0\ 1\ 1\ 1\ 1\ 1 \end{array}$$

$\times$   
carry out of MSB ; no carry into MSB  
 $\rightarrow$  overflow

Binary coded decimal (BCD)

a group of bits

- For a binary coded decimal no., each decimal digit is coded as a 4-bit word.

↳ e.g.:  $1248_{10} = 0001\ 0010\ 0100\ 1000$  BCD

↳ e.g.:  $1234_{10} = 0001\ 0010\ 0011\ 0100$  BCD

- BCD is not an efficient way of storing the nos., but it is easy to code and decode.

- This is 8421 BCD because the bits have these weightings.

- Other variants of BCD include

↳ 2421 BCD - the top bit only has a weight of 2

↳ Excess-3 code - record each digit value plus 3 using the 8421 weights.

# For Personal Use Only -bkwk2

## Alphanumeric character codes

- In the standard version of ASCII (American Standard Code for Information Interchange), 7 bits are used and the remaining bit is set to zero or used for parity.
- The first 32 numbers are control codes originally used for controlling modems.
- The rest are uppercase letters, lowercase letters, numbers and punctuation.
- An extended version of ASCII uses all 8 bits to provide 128 additional graphic characters which vary from computer to computer.
- Other alphanumeric code systems include EBCDIC (on IBM system) and Unicode (a 16-bit system that inc. Chinese characters etc..)

## Parity.

- Parity is the simplest error detection code used for transferring binary data through an imperfect data channel.
- In the transmission circuitry, it involves setting a particular bit in each binary no. so as to ensure that an even no. of bits are always on.
- In the receiver circuitry, we count the no. of bits are on in each no. and reject any that have an odd no.
- Parity can only detect 1-bit errors — more serious errors may go undetected.

## Bistables.

### Set-Reset bistable (SR bistable)

- The circuit of a SR bistable is as shown:



- S will turn  $Q_1$  ON (set) and  $Q_2$  OFF. They will stay at this state until R turns on.
- R will turn  $Q_1$  OFF (reset) and  $Q_2$  ON. They will stay at this state until S turns on.
- The circuit state depends not only on the current values of S and R, but also on their values in the past — i.e. we have memory.
- If we do not allow  $S=R=1$ , then we can say  $Q_2 = \bar{Q}_1$ , or denote  $Q_1, Q_2$  as  $Q, \bar{Q}$ .
- This state is forbidden as we have a race and therefore we cannot predict what the next state will be.



state diagram of SR bistable.

# For Personal Use Only -bkwk2

contact debouncing.

- An S-R bistable could be used to prevent switches due to contact debouncing.
- Consider moving the switch from position A to position B and back to position A.



Note here  $A = \bar{S}$ ,  $B = \bar{R}$

(Both A and B are active LOW signals)

Gated SR bistable.

- The circuit of a gated SR bistable is as shown:



- To set Q,  $\bar{S}G$  needs to be low, i.e. both S and G are HIGH; To reset Q,  $\bar{R}G$  needs to be low, i.e. both R and G are HIGH.
- This means the bistable can only change states when the gate input G is HIGH.
- The gate G is often connected to a clock signal - a regular signal w/ repetitive timing, which allows for accurate timing and can avoid hazards/races.

Master-Slave Bistable

- The circuit of a master-slave bistable is as shown:



- When CLK is LOW, the master bistable is sensitive to input signals.
- When CLK rises (HIGH), the slave bistable is sensitive to input signals, which are the outputs of the master bistable. (State of master bistable transferred to slave bistable)
- The overall output only changes when the CLK input rises.

# For Personal Use Only -bkwk2

## Master-Slave Bistable with Asynchronous Inputs

- The circuit of a master-slave bistable w/ asynchronous inputs is as shown:



- If PRESET goes to LOW, Q goes to HIGH; If CLEAR goes to LOW, Q goes to LOW.

Both PRESET and CLEAR are active LOW signals.

- S, R are both gated, connected to a CLK signal  $\rightarrow$  synchronous inputs.

- PRESET and CLEAR are not gated, so not connected to a CLK signal  $\rightarrow$  asynchronous inputs.

## D-type latch

- The circuit of a D-type latch is as shown:



- A D-type latch has only 1 input

- The input is clocked through the bistable as CLK goes HIGH.

- The D-type latch is useful for the retrieval of signals - used in shift registers.

## J-K bistable.

- The circuit of a JK bistable is as shown:



- The addition of the AND gates avoids the forbidden state  $S=1, R=1$ .

- The following are the i/p-o/p table and the characteristic table of the JK bistable.

| Inputs when CLK is LOW | Outputs when CLK rises | Output before $\rightarrow$ after | Required inputs. |         |         |
|------------------------|------------------------|-----------------------------------|------------------|---------|---------|
| Input J                | Input K                | Q(n+1)                            | Q(n) Q(n+1)      | Input J | Input K |
| unlocked               | 0 0                    | Q(n)                              | 0 0              | 0       | x       |
| set                    | 0 1                    | 0                                 | 0 1              | 1       | x       |
| reset                  | 1 0                    | 1                                 | 1 0              | x       | 1       |
| toggle                 | 1 1                    | Q(n)                              | 1 1              | x       | 0       |

- When  $J=1, K=1$ , the JK bistable toggles the output

- If at any time when CLK is LOW and a signal exists at the input encouraging the bistable to change state, that change will take place only when CLK rises.

# For Personal Use Only -bkwk2

## Application of bistables

### Divide by 2 counter

- The circuit of a divide by 2 counter is as shown:



- The timing diagram is as follows:



-  $J=1, K=1 \rightarrow$  output toggles at the rising edge of CLK

- Period of Q is doubled / frequency of Q is halved w.r.t. CLK (divide by 2)

\* Propagation delay is not being considered in the timing diagram

## Ripple counter

- The circuit of a ripple counter is as shown:



- The timing diagram is as follows:



- We can use the ripple counter to count up in binary (from 0000 to 1111).

- The propagation delays between CLK signals changing and the J-K output changing results in unwanted transitory states. (glitches)



# For Personal Use Only -bkwk2

## Synchronous counter

- The circuit of a synchronous counter is as shown:



- The timing diagram is as follows:



- By using a common CLK and adding additional circuitry, we can create a synchronous counter that does not have any transitory states.
- Although there is propagation delay between CLK and  $Q_i$ , the delays are not accumulated across  $Q_i$ .

## Divide by 5 counter

- The circuit of a divide by 5 counter is as shown:



- The timing diagram is as follows:



- Asynchronous clear can be used to produce divide by N counters for N not equal to a power of 2.
- However glitches arise because of the use of asynchronous inputs.
- By adding additional circuitry, we can make a synchronous design w/o such glitches.

# For Personal Use Only -bkwk2

## Shift Register

- The circuit of a shift register is as shown:



- The timing diagram is as follows:



- The inputs of each D-type latch are refined and shifted by 1 CLK period rel. to the previous D-type latch
- Therefore the output datastream is the same as the input data but in this case, the output is refined and delayed by roughly 4 CLK periods.

## Parallel loading shift register.

- The circuit of a parallel loading shift register is as shown:



- When the load line is high for a short period,  $I_i$  is loaded to  $Q_i$ .
- This could be then clocked through to  $Q_4$  for a serial output ( $I_1, I_2, I_3, I_4$ ).
- The parallel loading shift register allows us to read a parallel datastream and output a serial datastream at  $Q_4$  (or output data in parallel at  $Q_i$ ).

# For Personal Use Only -bkwk2

## Serial data link

- A serial data link is connected as shown:



- A parallel loading shift register is used to send one data bit at a time across a serial link.

- Doing so would req. less wires than would be req. for a fully parallel link.

## Twisted ring Johnson counter

Johnson counter  
we have  $D_i = \bar{Q}_i$

- The circuit of a twisted ring Johnson counter is as shown:



- A twisted ring Johnson counter uses a shift register of length N to produce a sequence of length of  $2N$ . (Assume initial state of 0000).
- Several other sequences are possible, depending on the initial state.
- For ring counters in general ( $D_i = f_n(Q_1, Q_2, Q_3, Q_4)$ ), the sum of no. of states in each sequence is  $2^N$

## Synchronous logic design

### Synchronous logic design

- By only using synchronous inputs, we can avoid glitches (unwanted transitory states).

- There are 5 stages for synchronous logic design:

↳ 1) State diagram: Define o/p in each state, define transitions for all combination of i/p's.

↳ 2) Bistable allocation: n bistables provided  $2^n$  states. Assign code to each state and note the unused states

↳ 3) State transition table: Work out bistable i/p's req. to perform correct state transitions.

Handle every combination of current state and input variables (inc. unused states)

↳ 4) Karnaugh maps: Work out logic to implement function req. by the state transition table.

↳ 5) Circuit: All the bistables should be clocked synchronously. Transfstate bistable o/p's to the circuit o/p's (if necessary)

\* very important to get the state diagram right → double check.

# For Personal Use Only -bkwk2

-eg : Divide by 3 counter

① state diagram



② Bistable allocation.

- 2 bistables  $\rightarrow 2^2 = 4$  states (3 allocated states + 1 unallocated state)

|         |           | Bistable outputs |    |
|---------|-----------|------------------|----|
|         |           | QA               | QB |
| state 1 | count = 0 | 0                | 0  |
| state 2 | count = 1 | 0                | 1  |
| state 3 | count = 2 | 1                | 0  |
| UNUSED  |           | 1                | 1  |

③ State transition table

|             | CURRENT STATE<br>QA DR | NECESSARY STATE<br>QA QB | REQUIRED INPUTS<br>JA KA JB KB | refer to the J-K characteristic in the databook. |
|-------------|------------------------|--------------------------|--------------------------------|--------------------------------------------------|
| count=0     | 0 0                    | 0 1                      | 0 x 1 x                        |                                                  |
| count=1     | 0 1                    | 1 0                      | 1 x x 1                        |                                                  |
| count=2     | 1 0                    | 0 0                      | x 1 0 x                        |                                                  |
| unallocated | 1 1                    | 0 0                      | x 1 x 1                        |                                                  |

④ Karnaugh maps

chosen to go back to 00  
so it won't get stuck.

| JA | QA | KA | QA  | JB  | QA  | KB  | QA  |
|----|----|----|-----|-----|-----|-----|-----|
| 0  | x  |    | x 1 |     | 1 0 |     | x x |
| 1  | x  |    | x 1 | x x | 1 0 | 1 1 | 1 1 |

$$JA = Q_B$$

$$KA = 1$$

$$JB = \bar{QA}$$

$$KB = 1$$

⑤ circuit



\* Output logic step strapped as the bistable outputs are the same as the circuit output

# For Personal Use Only -bkwk2

- e.g. sequence detector

Detect the received sequence 101 on an input I, when the sequence is detected,  $Y=1$ .

only respond to non-overlapping sequences. (10101 should give  $Y=1$  after bit3 but not 5)

① State diagram,



\* 2 possible combination of inputs  $\rightarrow$  2 paths leading every state.

② Bistable allocation

- 2 bits needed  $\rightarrow 2^2 = 4$  states (4 allocated states + 0 unallocated states)

|         |         | Bistable Outputs |
|---------|---------|------------------|
|         |         | QA QB            |
| state 1 | got 0   | 0 0              |
| state 2 | got 1   | 0 1              |
| state 3 | got 10  | 1 0              |
| state 4 | got 101 | 1 1              |

③ State transition table

|     | Input<br>I | Current<br>State<br>QA QB | Next<br>State<br>QA QB | determine next state<br>using state diagram |                |                |                |
|-----|------------|---------------------------|------------------------|---------------------------------------------|----------------|----------------|----------------|
|     |            |                           |                        | J <sub>A</sub>                              | K <sub>A</sub> | J <sub>B</sub> | K <sub>B</sub> |
| ST1 | 0          | 0 0                       | 0 0                    | 0 X                                         | 0 X            | X              | X              |
|     | 1          | 0 0                       | 0 1                    | 0 X                                         | 1 X            | X              | X              |
| ST2 | 0          | 0 1                       | 1 0                    | 1 X                                         | X X            | 1              | 1              |
|     | 1          | 0 1                       | 0 1                    | 0 X                                         | X X            | 0              | 0              |
| ST3 | 0          | 1 0                       | 0 0                    | X 1                                         | 0 X            | X              | X              |
|     | 1          | 1 0                       | 1 1                    | X 0                                         | 1 X            | 1              | 1              |
| ST4 | 0          | 1 1                       | 0 0                    | X 1                                         | X 1            | X 1            | X 1            |
|     | 1          | 1 1                       | 0 1                    | X 1                                         | X 0            | 1 X            | 0 X            |

refer to the JK characteristic  
in the textbook.

④ Karnaugh maps

|  |  | QA |   | JA |                | KA |                | QB |   |
|--|--|----|---|----|----------------|----|----------------|----|---|
|  |  |    |   | I  | Q <sub>A</sub> | I  | Q <sub>A</sub> |    |   |
|  |  | 0  | 1 | X  | X              | 1  | X              | X  | X |
|  |  | 0  | 0 | X  | X              | 0  | X              | 1  | 1 |

$$JA = Q_B \cdot \bar{I}$$

$$\bar{KA} = \bar{Q}_B \cdot I \rightarrow KA = \bar{Q}_B \cdot \bar{I}$$

|  |  | QA |   | JB |                | KB |                | QB |   |
|--|--|----|---|----|----------------|----|----------------|----|---|
|  |  |    |   | I  | Q <sub>A</sub> | I  | Q <sub>A</sub> |    |   |
|  |  | 0  | X | X  | 0              | 1  | X              | 1  | X |
|  |  | 1  | X | X  | 1              | 0  | X              | 0  | X |

$$JB = I$$

$$KB = \bar{I}$$

# For Personal Use Only -bkwk2

⑤ circuit.

|         |        | Bistable<br>outputs<br>QA QB | Circuit<br>output<br>Y |
|---------|--------|------------------------------|------------------------|
| State 1 | S0=0   | 0 0                          | 0                      |
| State 2 | S0=1   | 0 1                          | 0                      |
| State 3 | S0=10  | 1 0                          | 0                      |
| State 4 | S0=101 | 1 1                          | 1                      |

$$\text{so } Y = A \cdot B.$$

translate bistable o/p  
to circuit o/p.



Analogue conversion and adder circuits.

Weighted resistor DAC → digital to analogue converter

- The circuit of a weighted resistor DAC is as shown:



- Assume the op-amp is ideal  $\rightarrow$  inverting input is virtual earth and  $V_{out} = -IR'$

Let the latch output voltage be A for each  $Q=1$ , and 0 for each  $Q=0$ .

$$\begin{aligned} \text{KCL: } I &= \frac{a_0 A}{R} + \frac{2a_1 A}{R} + \dots + \frac{2^{n-1} a_{n-1} A}{R} \\ \therefore V_{out} &= -\frac{A R'}{R} \sum_{m=0}^{n-1} a_m 2^m \end{aligned}$$

- Plotting  $-V_{out}$  against the digital count,



- The staircase approximation becomes closer to the target analogue value as we increase n / size of the data word (latch o/p voltage divided into smaller units).

- The weighted resistor DAC has a large range of resistance values  $\rightarrow$  hard to implement, made from different materials so the output may drift as it warms up.

- If the tolerance of the 1LSB resistor is  $\alpha\%$ , then the tolerance of the MSB resistor must be  $\frac{\alpha}{2^{n-1}}\%$ .  $\rightarrow$  time consuming and expensive to achieve.

# For Personal Use Only -bkwk2

## R-2R ladder DAC

- The circuit of a R-2R ladder DAC is as shown:



- Assume the opamp is ideal  $\rightarrow$  inverting input is virtual earth and  $V_{\text{out}} = -IR'$

In this configuration, we find that  $i_{\text{in}1} = i_m$  so  $i_m = 2^m i_0$

Consider the left-most  $2R$  resistor, w/ current  $i_{n-1}$ ,

$$A = i_{n-1} \cdot 2R = 2^{n-1} i_0 \cdot 2R \rightarrow i_0 = \frac{A}{2^n R}.$$

$$\begin{aligned} \text{KCL: } I &= \sum_{m=1}^{n-1} a_m i_m \\ &= \sum_{m=1}^{n-1} a_m 2^m \left( \frac{A}{2^n R} \right) \\ &= \frac{A}{2^n R} \sum_{m=1}^{n-1} a_m 2^m \\ \therefore V_{\text{out}} &= -\frac{A R}{2^n R} \sum_{m=1}^{n-1} a_m 2^m \end{aligned}$$

- This circuit provides similar functionality to the weighted resistor DAC but only has 2 resistor values ( $R$  and  $2R$ ).
- Therefore it is more accurate, scalable and potentially cheaper.

## Analogue-to-digital converter 1 bit ADC without hysteresis

- The circuit of a 1 bit ADC (comparator) w/o hysteresis is as shown:



- In general,  $V_{\text{out}} = \text{Gain} \times (V_{\text{ref}} - V_{\text{in}})$ . However, since gain is large,

$$V_{\text{in}} > V_{\text{ref}} \rightarrow V_{\text{out}} = V_- ; \quad V_{\text{in}} < V_{\text{ref}} \rightarrow V_{\text{out}} = V_+$$



# For Personal Use Only -bkwk2

I bit ADC w/ hysteresis (Schmidt trigger)

- The circuit of a 1 bit ADC (comparator w/ hysteresis) is as shown:



$$- \text{ In general, } V_{\text{ref}} - V' = IR \Rightarrow V' - V_{\text{out}} = NIR \Rightarrow V' = \frac{N V_{\text{ref}} + V_{\text{out}}}{N+1}$$

However, since gain is large, when,

$$V_{\text{in}} > V' \rightarrow V_{\text{out}} = V_- \rightarrow V' = \frac{N V_{\text{ref}} + V_-}{N+1} \text{ which gives } V_{\text{lower}}$$

$$V_{\text{in}} < V' \rightarrow V_{\text{out}} = V_+ \rightarrow V' = \frac{N V_{\text{ref}} + V_+}{N+1} \text{ which gives } V_{\text{upper}}.$$

- If  $V_{\text{in}}$  is initially LOW,  $V_{\text{in}}$  must rise above  $V_{\text{lower}}$  for  $V_{\text{out}}$  to be LOW.

If  $V_{\text{in}}$  is initially HIGH,  $V_{\text{in}}$  must drop below  $V_{\text{lower}}$  for  $V_{\text{out}}$  to be HIGH



- The transfer characteristics of the comparator w/ hysteresis is as follows:



## Flash ADC

- The circuit of a flash ADC is as shown (2 bit)



- The flash ADC is very fast - the binary word is updated at each CLK pulse.

- For a large no. of bits (higher resolution), we will need a large no. of comparators.

A n bit flash ADC req.  $2^n - 1$  comparators.

# For Personal Use Only -bkwk2

## Digital ramp ADC

- The circuit of a digital ramp ADC is as shown:



- The digital ramp ADC uses a counter + DAC to create a gradually increasing reference voltage  $V_{ref}$ , which is used to compare w/ the analogue input  $V_{in}$  using a comparator.
- This is much slower than the flash ADC

## Full adder

- For a full adder, the input-output table is as follows:

| $A_i$ | $B_i$ | $C_i$ | $C_{i+1}$ | $S_i$ |
|-------|-------|-------|-----------|-------|
| 0     | 0     | 0     | 0         | 0     |
| 0     | 0     | 1     | 0         | 1     |
| 0     | 1     | 0     | 0         | 1     |
| 0     | 1     | 1     | 1         | 0     |
| 1     | 0     | 0     | 0         | 1     |
| 1     | 0     | 1     | 1         | 0     |
| 1     | 1     | 0     | 1         | 0     |
| 1     | 1     | 1     | 1         | 1     |

- Carry ( $C_{i+1}$ ): 2 or more inputs need to be 1 if we want  $C_{i+1} = 1$

$$\hookrightarrow C_{i+1} = A_i \cdot B_i + A_i \cdot C_i + B_i \cdot C_i$$

- Sum ( $S_i$ ): Needs an odd no. of inputs to be 1 if we want  $S_i = 1$

$$\hookrightarrow S_i = A_i \oplus B_i \oplus C_i$$

- The circuit of a full adder is as follows:



- The full adder circuit is used in the arithmetic logic units (ALU) of microprocessors.

↳ There are no 3 i/p XOR gates → we use 2x 2 i/p XOR gates.

# For Personal Use Only -bkwk2

## Ripple carry adder circuit

- The circuit of a ripple carry adder (4 bits) is as shown:



- We can cascade  $n$  full adder circuits to make an adder of  $n$  bit words

- If we input  $\bar{A}_0, \bar{A}_1, \bar{A}_2$  and  $\bar{A}_3$  instead, and set  $C_0$  to 1, we would effectively add the 2's complement of  $A$ , i.e. subtract  $A$ .

## Microprocessors

For Personal Use Only -bkwk2

### MICROPROCESSOR ARCHITECTURES

#### MICROPROCESSOR ARCHITECTURE

- The basic Von Neumann architecture is as follows



- The design was the first ever stored program machine.

- The architecture of a (simple) modern computer is as follows



- The central processing unit (CPU) / microprocessor consists of

- ↳ An Arithmetic Logic Unit (ALU) which performs mathematical and logic operations.

- ↳ A control unit that manages the execution of instructions

- ↳ Multiple registers that are used for temporary storage for instructions and data.

- The memory stores instructions and data

- Input and output ports act as an interface w/ the outside world (keyboard, mouse..)

- Buses connect everything together.

### BASIC BUS STRUCTURE.

- The data bus is bidirectional ; The address and control buses are unidirectional.

- The 6800 microprocessor has an 8 bit data bus and a 16 bit address bus. More advanced processors have more data and address lines (usually 16, 32, 64)

- \* The PIC does not have this architecture - memory and I/O are via registers.



# For Personal Use Only -bkwk2

## Arithmetic logic unit (ALU)

- A N-bit ALU is connected as follows:



$\overbrace{N}$  denotes a  $N$ -bit bus.

- The ALU inputs from a register/memory location and outputs to a register/memory location.
- The ALU can perform simple 2 operand functions (e.g.  $a+b$ ,  $a-b$ ,  $a \text{ AND } b$ ,  $a \text{ OR } b$  etc) where  $a, b$  could be single bits or words.
- The ALU can perform simple comparison operations (test for zero, ve etc.)
- The function to be carried out is set by the function code.

## 1-bit ALU implementation

- A 1-bit ALU is implemented as follows:



- This 1-bit ALU can perform 8 possible functions -  $a \text{ AND } b$ ,  $a \text{ AND } \bar{b}$ ,  $a \text{ OR } b$ ,  $a \text{ OR } \bar{b}$ ,  $a+b$ ,  $a+b$  w/ carry,  $a-b$ ,  $a-b$  w/ borrow.
- The function is selected by multiplexers.
- To make a  $N$ -bit ALU, we connect  $N \times 1$ -bit ALUs together, using  $Cin$ ,  $Cout$ .

## Registers

- Registers are used for temporary storage for instructions and data within the microprocessor.
- In the PIC12F675, there are 2 main types of registers.

### ① Special purpose registers.

- ↳ usually 8 bits (the PC is 13 bits, made up of RCL and POLATH registers)
- ↳ PC holds the address of the next instruction to be executed.
- ↳ W holds the data the PIC is working on at the current time (accumulator)
- ↳ STATUS register stores the results of the previous calculation (carry, digit carry, zero flag), as well as power down, time out and register bank information
- ↳ GPIO register holds data either input (output to pins on the chip. [bidirectional])
- ↳ TRISIO register holds the information which bits in the GPIO register are i/p's or o/p's

### ② General purpose registers

- ↳ 64 x 8 bit data registers, accessed via File select register (FSR)

Memory in the von Neumann architecture.

# For Personal Use Only -bkwk2

## Program counter (PC)

- Program counter (PC) is a (13 bit for PIC) register inside the microprocessor that stores the program memory address of the next instruction to be executed.
- The PC is key to the fundamental fetch-decode-execute cycle:
  - ↳ The processor first fetches the instruction from the address stored in the PC.
  - ↳ The fetched instruction is then decoded so that it can be interpreted by the microprocessor.
  - ↳ Once decoded, the instruction is executed and the PC is incremented so that it contains the address of the next instruction.



## Working register, W

- W holds the data the processor is currently working on.
- The data stored can only be an 8-bit word.
- Many PIC instructions take a memory location F and a destination d or argument. The destination can be the location specified by F (d=1) or the working register W (d=0).

## Timing diagram (Read)

### Memory and memory chip addressing

#### Memory read and write operations

- To read (write) data from (to) memory, we
  - Set address of the memory location on the address bus.
  - Set the read/write, R/W of the control bus HIGH (LOW).
  - Set the address valid control wire HIGH.
  - The above together activate the memory chip select CS by setting it LOW.
  - If R/W is HIGH (read operation), the memory chip drives the data bus w/ the data from the location indicated by the address bus.
  - Once the data is read (usually into a register on the microprocessor) the control wires are "reset".
  - If R/W is LOW (write operation), the memory chip writes the data from the data bus into the location indicated by the address bus.
  - Once the data is written to the memory, the control wires are "reset".

# For Personal Use Only -bkwk2

## Memory address capacity

- Let  $a$  be the no. of address wires (width of address bus) and  $d$  be the no. of data wires (width of data bus).

- The total addressed capacity is given by

$$d \times 2^a$$

- 1 kilobyte (kilobyte) is  $2^{10} = 1024$  bytes ; 1 megabyte (megabyte) is  $2^{20} = 1024$  kilobytes = 1048576 bytes.

- For the 6800 microprocessor,  $a=16$ ,  $d=8$  so the total addressed capacity is  $8 \times 2^{16}$ , or  $8 \times 2^{10} \times 2^6 = 64$  kilobytes.

## RAM chip architecture.

- Each DRAM inside the RAM chip has its own memory element, which can be set LOW(0) or HIGH(1)

↳ These memory elements are arranged as a matrix of rows and columns.

↳ There is one row of memory elements for each address and one column for each data wire.

- Address bus signals are passed to a decoder

↳ The decoder determines which row of memory elements corresponds to the address on the bus.

↳ The decoder selects one row out of the  $2^a$  possibilities.



## Address decoder (single memory chip)

- The word select lines are driven from the one out of  $2^a$  decoder. → only 1 word select line is driven HIGH at any time.

- The one out of  $2^a$  address decoder selects 1 address line for each combination of address bits.

- A one out of  $2^3$  decoder is as shown:



# For Personal Use Only -bkwk2

Individual memory element.

- Each individual memory element is as follows :



- A particular memory element is selected when the word select line is HIGH.
- When write enable is HIGH, data is written onto the SR bistable; when write enable is LOW, data is read out from the SR bistable.

Data interface at the edge of the chip.

- The interface logic inside a memory chip works as follows :



- We need to select either input or output as the data bus is bidirectional
- For the output, we need to drive the wire + strengthen the signal  $\rightarrow$  tri-state buffer;  
For the input, we just req. a simple buffer to strengthen the signal.

- Tri-state buffers are connected as follows.



- When the enable is LOW, neither transistor is on and the output is not connected to any voltage by this part of this circuit (high impedance - i/p and o/p disconnected).
- Tri-state buffers are useful in avoiding the lost in data when several logic outputs are connected together (If we use AND/OR gates, the o/p's can affect the i/p's).

Multiple memory chips

- If a single memory chip has  $a_i$  address wires and the microprocessor has  $a_i$ -tag address wires, we could connect  $2^{a_j}$  memory chips to the microprocessor.
- The  $a_i$  LSB address wires ( $a_0, a_1, \dots, a_{i-1}$ ) of the microprocessor are used to address the location within the memory chip.
- The  $a_j$  MSB address wires ( $a_i, a_{i+1}, \dots, a_{j-1}$ ) of the microprocessor are used to address the memory chip we are selecting.
- e.g.: 1st chip has addresses :  $000\ 0000H$  to  $000\ FFFFH$  ] Here,  $a_i = 4 \times 4 = 16$   
2nd chip has addresses :  $001\ 0000H$  to  $001\ FFFFH$  ]  $a_j = 4 \times 3 = 12$

# For Personal Use Only -bkwk2

## Address decoder (Multiple memory chips)

- Other than one out of  $2^9$  decoder in each memory chip, we need another one out of  $2^3$  decoder to activate a particular memory chip.
- e.g.: If  $a_1 = 13$ ,  $a_2 = 3$ , design the address decoding logic for the 3rd chip (i.e. memory addresses  $4000H - 5FFFH$ ).
  - $\overline{CS}$  should be set to low when the MSBs are 010, i.e.  $A_{15} = 0$ ,  $A_{14} = 1$ ,  $A_{13} = 0$
  - so the req. logic is  $\overline{A_{15}} \cdot A_{14} \cdot \overline{A_{13}}$
  - $\overline{CS}$  is an active LOW signal.
- this is usually AND-ed w/ the address valid wire, i.e.  $\overline{A_{15}} \cdot A_{14} \cdot \overline{A_{13}} \cdot \overline{AV}$

## Memory mapped input/output

- For memory mapped input/output, the input/output ports are treated as memory locations → the microprocessor does not know the difference between a memory chip and an input/output port
- consider mapping both the input/output ports to  $00000000H$ .



Reading from  $0000\ 0000H$  reads from the input port; writing to  $0000\ 0000H$  writes to the output port.

If we read a no. at location  $0000\ 0000H$ , then write at the same location, we get the same no. However, the reverse is not necessarily true.

## Other types of memory.

- Random access memory (RAM)
  - ↳ It is readable and writable, but "forgets" when the power is off (volatile memory).
  - ↳ Static RAM (SRAM) has a simple interface, good storage density, speedy access and low power consumption (when not in active use) → used for fast cache memories on laptops/phones.
  - ↳ Dynamic RAM (DRAM) has a complex interface (content refreshed continuously), consumes power even when not in use, slower than SRAM but has high storage density → used as PC main memory.
- Read only memory (ROM)
  - ↳ ROM contents are set at manufacturing time → can never be changed by the microprocessor.
  - ↳ It is non-volatile and is used to store the necessary instructions for communication between various hardware components.

# For Personal Use Only -bkwk2

- Erasable programmable read only memory (EPROM)
  - ↳ Cannot be changed by the microprocessor but can be programmed using a device that uses higher voltages than in a normal microprocessor circuit.
  - ↳ Can be erased either using UV light or a higher voltage.  
↳ **EEPROM**
- Flash memory
  - ↳ Non-volatile storage that can be electrically erased and reprogrammed.
  - ↳ Developed from EEPROM - but can be written to and read in blocks (bytes) rather than the entire device.
- More long term storage is achieved through the use of magnetic disks (hard drive) or solid state hard drives.

## Microprocessor programming.

### Programming languages.

- High level languages (C++, Python) are great for application programming but must be translated for the microprocessor to act on the programs.
- Low level languages (machine code) can be hexadecimal opcode sequences or a long sequence of binary 0s and 1s, which can be directly understood by the appropriate microprocessors, but is difficult to write even short programs.
- To make programming easier, an assembler translates an assembly language program into opcodes that are understood by the microprocessor.



### Assembly language.

- Assembly language programs are more efficient and req. less memory than programs in high level languages
- There is one assembly language instruction for each opcode in the machine code, giving programmers direct control of the microprocessor.
- It is not complicated for the assembler to translate assembly language into opcodes  
→ this process is quick on computers.
- The PIC only has 35 commands, but it is still possible to build up complex programs from these.

# For Personal Use Only -bkwk2

Representing numbers.

- 0x before a no. indicates hexadecimal. (e.g. 0x32)
- 0 with x indicates octal from the leading zero. (e.g. 024)
- b before the no. indicates binary (e.g. b(01010)
- otherwise the no. is in decimal (e.g. 63).

Types of operations

- Assembly language instructions are written using mnemonic code words.
- All PIC instructions are 14 bit words consisting of an opcode and data source information.
- There are 2 main types of instructions
  - ↳ Data processing operations — move, register, arithmetic, logic
  - ↳ Program sequence control operations — unconditional/conditional jump, call, control.
- The operations can be on one of three types of data.
  - ↳ Byte oriented : operation is on a byte (8 bits)
  - ↳ Bit oriented : operation is on a single bit of the byte
  - ↳ Literal : operation is on a literal value.



PIC12F675 memory bank

- The PIC12F675 has a memory map organised into 2 banks (Bank 0 and Bank 1) of registers.
- We can select which bank we want to use by clearing (Bank 0) or setting (Bank 1) bit 5 in the STATUS register.
- The lower set of address locations in each bank is reserved for special registers.
- The general purpose registers between memory locations 0x20 and 0x5F are used as on-chip data memory.

| Bank 0                               |     | Bank 1 |     |
|--------------------------------------|-----|--------|-----|
| IODF                                 | 00H | IODE   | 80H |
| TMR0                                 | 01H |        | 81H |
| PCL                                  | 02H | PCL    | 82H |
| STATUS                               | 03H | STATUS | 83H |
| FSR                                  | 04H | FSR    | 84H |
| GPIO                                 | 05H | TRISD  | 85H |
|                                      |     |        |     |
| PCIAFH                               | 0AH | PCIAFH | 8AH |
| INTCON                               | 0BH | INTCON | 8BH |
|                                      |     |        |     |
| General Purpose Registers (64 bytes) | 20H |        | 8CH |
| f                                    | 5FH | f      | FFH |
|                                      | 60H |        |     |
|                                      | 7FH |        |     |

# For Personal Use Only -bkwk2

## Input/Output for PIC12F675

- For the PIC12F675, the GPIO register acts as a 6-bit wide bidirectional port (at memory location 0x05, Bank 0)
- Bit 3 can only be an input; all other pins can either act as an input or an output.
- The corresponding data direction is managed by the TRISIO register (at memory location 0x85, Bank 1)
  - ✓ TRISIO bit 3 is always set
- Setting a bit in the TRISIO register makes the corresponding bit in GPIO an input; clearing a bit in the TRISIO register makes the corresponding bit in GPIO an output.
- We can set some bits to 1 and some to 0 to have both input and output ports.
  - ↳ Before inputting data into W from GPIO, we should clear the 2 MSB in W as we only have 6 inputs. (at most).

## Special uses of commands:

- **andwf** can be used to round numbers
  - ↳ Round to the nearest even no. by ANDing w/ b1111110
  - ↳ Round to the nearest odd no. by ANDing w/ b1111110 then increment by 1.
- **rf** can be used to determine whether the original no. was true or false in 2's complement or multiply by 2 (sometimes)
  - ↳ check C flag : 0 → true ; 1 → false.
  - ↳ No. is multiplied by 2 (sometimes — check C and MSB)
- **rnf** can be used to determine whether the original no. was odd or even or divide by 2 (sometimes)
  - ↳ check C flag. 0 → even ; 1 → odd
  - ↳ No. is divided by 2 (sometimes — check C and LSB)



# For Personal Use Only -bkwk2

## STATUS register, flags, tests and flowcharts

### STATUS register

- several bits in the STATUS register hold information about the result of the last arithmetic or logic operation → can be used in a conditional instruction.
- other bits contain powerdown, timer out and register bank information.
- the STATUS register is at memory location 0x03, bank 0 and 0x83 bank 2.

| SELECT BANK 0 OR 2 |   |   |   |   |   |   |    |
|--------------------|---|---|---|---|---|---|----|
| I                  | E | R | P | T | D | Z | DC |
| 7                  | 6 | 5 | 4 | 3 | 2 | 1 | 0  |

clear when watchdog timer times out      clear if in sleep mode

### Tests and conditional instructions.

- several instructions can test a bit in a register or data word.

- |                      |                                                                    |
|----------------------|--------------------------------------------------------------------|
| ↳ <b>btfsc F, b</b>  | often used to test the C, DC<br>and Z flags in the STATUS register |
| ↳ <b>btfss F, b</b>  |                                                                    |
| ↳ <b>decfsz F, d</b> | often used to generate                                             |
| ↳ <b>incfsz F, d</b> | a delay or in timers                                               |

### carry flag, C

- the C flag is set when there is a carry from the MSB (bit 7) during a calculation.
- If we have an addition

$$F \text{ plus } W \rightarrow W_{\text{after}}$$

then the carry flag will be determined by the Boolean expression

$$C = F_7 \cdot W_7 + (F_7 + W_7) \cdot \overline{W_7}_{\text{after}}$$

both MSB are 1      either MSB is 1      MSB of the result is 0

### Digit carry flag, DC

- A byte is made up of 2 nibbles (4 bits) - there is a lower nibble (bits 0-3) and an upper nibble (bits 4-7)
- The DC flag is set when there is carry from the lower to the higher nibble during a calculation.
- If we have an addition

$$F \text{ plus } W \rightarrow W_{\text{after}}$$

then the digit carry flag will be determined by the Boolean expression

$$DC = F_3 \cdot W_3 + (F_3 + W_3) \cdot \overline{W_3}_{\text{after}}$$

both bit 3 are 1      either bit 3 is 1      bit 3 of the result is 0

# For Personal Use Only -bkwk2

zero flag, z

- The z flag is set when the result of an instruction is zero

- If we have an addition:

$$F \text{ plus } W \rightarrow W_{\text{after}}$$

then the zero flag will be set if

$$W_{\text{after}} = 0$$

Flowcharts for assembly programs

- Flowcharts are a graphical technique for designing short programs

↳ ✓ : encourage design of the overall algorithm

↳ ✓ : independent of microprocessor architecture / instruction set

↳ ✓ : easier to read than machine code / assembly language.

↳ ✗ : modern programming techniques in high level languages are quicker to use

↳ ✗ : the precise way the processor instructions are used are important for machine code programming → flowcharts not useful.

- The conventions for flow charts are as follows:



goto, loops and the use of labels

- In conditional branches, we can use **goto** to jump to a label.

- The **goto** instruction is quite useful for making loops.

e.g.: **movf GPIO, 0x30;**

label **movf GPIO, W;** ←

**subwf 0x30, W;**

**btfss STATUS, Z;**

**goto label;**

**goto end;**

**end sleep;**



\* Here, we assume TRISIO is set so all GPIO pins are inputs.

# For Personal Use Only -bkwk2

## Program run time

- For most PIC processors, each instruction takes 1 internal clock cycle to execute.
- There are 2 main exceptions that take 2 internal clock cycles to execute
  - ↳ Instructions which need to replace PC contents (goto, call, return etc.)
  - ↳ TEST/conditional branch instructions - if the conditional branch does skip, it discards the next instruction and executes a **nop** (0/W only 1~)

## Generating a delay

- It is often useful to be able to generate a delay whilst waiting for an event to happen.  
(e.g. turn on LED ON for a fixed time)
- Consider the delay program that uses the **decfsz** instruction.

```
    movlw 0xFF;    1~  
    movwf 0x30;    1~  
loop decfsz 0x30;    1~ for first 254, 2~ for final  
    goto loop;    2~  
sleep.        1~
```

$$\text{Total runtime} = 1 + 1 + 1 \times 254 + 2 + 2 \times 254 + 1 = 767 \text{ clock cycles.}$$

If the microprocessor has a 4MHz clock, total execution time  $\frac{767}{4 \times 10^6} = 19.15 \mu\text{s}$ .

## File register indirect addressing

- The File Select Register (FSR) is used for indirect addressing (at memory location 0x04, Bank 0 and 0x84, Bank 1)
- If a file register address is loaded into FSR, the contents of that register can be read through the Indirect File Register (INDF), (at memory location 0x01, Bank 0 and 0x80, Bank 1).
- This method can be used to access a set of data in memory locations by reading/writing the data via INDF and selecting the next location by incrementing FSR.
- This is particularly useful for storing a sequence of data that has been read in through a port.

# For Personal Use Only -bkwk2

-e.g. Load a set of file registers 0x20-0x2F w/ dummy data 0xAA

```
    movlw 0x20;  
    movwf FSR;  
    movlw 0xAA;  
    / we start at 0010 0000  
loop: movwf INDF;  
      and end at 0010 1111  
      incf FSR;  
      btfss FSR, 4;  
      / → look for 0011bte4 0000 → bit FSR bit 4.  
      goto loop;  
    sleep;
```

## Assembling into machine code

- The data block has a list of commands and its machine code equivalent.

↳ e.g.: `movwf F` is 00 0000 1fff ffff so `movwf 0x30` is 00 0000 1011 0000

- For a program, each 14-bit instruction is stored in a program memory location

↳ Program memory location has a 13-bit address and 1-bit content ;

File register memory location has a 8-bit address and 8-bit content

## Stack, subroutines, interrupts and the RESET pin

### The stack - basics

- The stack is a data structure that allows data to be stored and retrieved in an organised way.

↳ as opposed to queue, which is "first in, first out"

- It is "last in, first out" - last item placed on a stack is the first item to be removed

- When data is added to the stack, it is PUSHed onto the stack ; when data is removed from the stack, it is POPped off the stack.

- In many microprocessors, we can use assembly instructions to PUSH and POP items to/from the stack.

SP is another register.

- In a PUSH operation, the contents of one or more registers will be placed on the stack.)

    The memory address location where the 1st item is stored is held in the stack pointer (SP)

- In a POP operation, we load content into one or more registers and adjust the SP to reflect the freeing up of memory.

# For Personal Use Only -bkwk2

## The PIC12F675 Stack.

- The PIC12F675 has an 8-level deep, 13 bit wide stack.
- The stack space is not part of either program or data (file) space and the SP is not readable or writable (i.e. no PUSH or POP commands).
- Instead, the stack is automatically used for subroutines ↴  
↳ The PC is PUSHed onto the stack when a **call** instruction is executed  
↳ The stack is POPped in the event of a **return**, **retlw** or a **retfie** instruction execution.  
*so no need to worry for day-to-day programming*

## Sub-routines (functions)

- Subroutines are used to carry out discrete program functions → allow programs to be written in manageable self-contained blocks which can be executed or re-used.
- **call** is used to jump to a subroutine and **return** to terminate it and return to the main program.
- **retlw** is the same as **return** but also stores return value in W.
- + The **call** command has the address of the subroutine as an argument (The main program PC contents are pushed onto the stack and replaced w/ the subroutine address).

## Interrupts

- Interrupts are generated by an asynchronous event (i.e. not linked to program timing)
- When an interrupt is called, the Interrupt Service Routine (ISR) is run, PC is pushed onto the stack and is set to 0x0004 (Interrupt vector)
- When the ISR finishes w/ the **retfie** instruction, the PC is reloaded from the stack and the original program must resume as if nothing had happened.

## The RESET pin.

- Microprocessors have a RESET input that when activated initialises the processor and starts it running in a predetermined and safe fashion, (PC is reinitialised to 0x0000)
- A reset button can be connected that brings the RESET pin voltage to LOW and hence restart the microprocessor → emergency reboot
- When the power is switched on, suitable circuitry can ensure that the RESET pin voltage is held at LOW for a short period → start up in a predefined state.

The off-time depends on how long it takes the processor to initiate the reset sequence.

