

per

## Memory and Programmable logic

Syllabus: RAM - Memory Decoding - Error Detection and Correction - ROM - Programmable Logic Array - Programmable Array Logic - Sequential Programmable Devices

### Definitions:

#### ① Memory Unit:

- a collection of cells capable of storing a large quantity of binary information.
- Information is transferred to the memory unit for storage and retrieved for processing.
- There are 2 types of memories used in digital systems - random access memory (RAM) and read only memory (ROM)

#### ② Memory Write: The process of storing new information into the memory is referred to as a memory-write operation.

#### ③ Memory Read : The process of reading the stored information out of the memory is termed as a memory-read operation.

### \* Types of memories: RAM vs. ROM

#### (a) Random-Access Memory (RAM)

- used in operating systems, application programs
- Data which is in current use resides in the RAM for quick reach by the processor.

## (b) Read-Only Memory (ROM)

- content cannot be changed
- contents retained even when shut off
- used to start up computer and load the operating system into the RAM
- can be used as a Programmable logic Device (PLD).
- different types of ROM include Mask Programming, PROM, EEPROM, EEPROM, Flash Memory

## \* Random Access Memory

- The architecture of RAM is such that data can be selectively retrieved from any of its internal locations.
- The time taken to transfer information to or from any desired location is always the same - which is why the device is termed as Random Access Memory. This is in contrast to the fact that the time taken to retrieve information on a magnetic tape depends on the location of the data.

## Information Storage in RAM

- The memory unit of a RAM stores information in groups of bits called words
- **Word** → a set of bits that moves in and out of storage as a unit.

→ The group of 0's and 1's in a word may represent a number, an instruction, one or more alphanumeric characters, or any other binary-coded information.

→ 8 bits = 1 byte

→ Computer memories use words that are multiples of 8 bits in length.

Capacity of a memory unit : The total number of bytes that the unit can store.

### Communication in RAM :

→ Communication between the memory and the environment happens through

- \* data input and output lines

- \* address selection lines

- \* control lines specifying the direction of transfer

### Block Diagram

→ n data i/p and o/p lines



→ k address lines specifies

the particular word

→ 2 control inputs specify the direction of transfer

write op → binary data transferred into memory  
read op → binary data transferred out of memory

## Working

- Each word has an address (like an id no)
- Each address line selects a particular word to R/W operations
- Selection of a word is done by applying the  $k$ -bit address to the address lines.
- An internal decoder accepts this address and opens the paths needed to select the word specified.
- Addresses go from  $0 - (2^k - 1)$ , where  $k$  is the number of address lines.
- The number of words in the memory is referred to by
  - K → kilo  $\rightarrow 2^{10}$
  - M → mega  $\rightarrow 2^{20}$
  - G → giga  $\rightarrow 2^{30}$

Example: If a memory unit has a capacity of 1K words of 16 bits each, then

$$1K = 2^{10} = 1024$$

$$16 \text{ bits} = 2 \text{ bytes}$$

$$\begin{aligned}\therefore \text{the memory can accommodate } & 1024 \times 2 \\ & = 2048 = 2K \text{ bytes}\end{aligned}$$

(5)

Diagram

| Memory Address | Memory content |
|----------------|----------------|
| Binary         | Decimal        |
| 0000 000000    | 0              |
|                | 1              |
|                | 2              |
|                | :              |
|                |                |
| 1111 111101    | 1021           |
| waddr          |                |
| 1111 111110    | 1022           |
| 1111 111111    | 1023           |

write some  
decin binary nos  
in boxes to rep  
words


Write and Read Operations on Ram

(i) To transfer a new word into the memory (WRITE)

1. Place address in address line
2. Place input data in data line
3. Activate the write control signal

(ii) To transfer a stored word out of the memory (READ)

1. Place address in address line
2. Activate the read control signal
3. Output will be in the data line

Control Inputs to Memory Chip

| Memory Enable | Read / Write | Memory Operation |
|---------------|--------------|------------------|
| 0             | X            | None             |
| 1             | 0            | Write            |
| 1             | 1            | Read             |

## \* Timing Waveforms

- The operation of the memory unit is controlled by the central processing unit (CPU).
- The CPU is synchronized by its own clock.
- The memory does not use an internal clock.
- Its read and write operations are specified by control inputs.
- The CPU provides memory control signals in such a way so as to synchronize its internal clock with the read and write operations of the memory.

Consider the following example:

Let the CPU clock frequency be 50MHz

Let the memory cycle time be 50 ns.

$$f_{CPU} = 50 \text{ MHz} \quad T_{CPU} = \frac{1}{50 \times 10^6} = 20 \text{ ns}$$

→ A 50 ns memory cycle time means that

(i) the write cycle terminates the storage of given word within a 50ns interval

(ii) the read cycle always provides an o/p of the selected word in < 50ns.

→ The time period of the CPU is 20ns  $\Rightarrow$  25/3 clock cycles are needed for each memory request.

### Case 1: Write Operations



→ There are 3 20ns cycles T<sub>1</sub>, T<sub>2</sub>, T<sub>3</sub>

→ To write, the address & input data is supplied. The crossed lines that cross in the address & data waveforms indicate a possible change in value.

→ The memory enable signal switches to high

→ The read/write signal switches to low (0) to indicate a write operation

→ The address and data signals must remain valid for a short time after the control signals are deactivated.

→ After the third clock cycle is completed, the memory write operation is completed and the CPU can access the memory again from the next T<sub>1</sub> cycle.

## Case 2: Read Operations



- To perform read operations, the memory enable is set to high.
- The read / write signal is also set to high
- The memory places the data of the word selected by the address into the output data line within a 50 ns interval or less from the time that the memory enable is activated.
- The CPU transfers the data into one of its internal registers during the negative transition of T<sub>3</sub>
- The next cycle T<sub>1</sub> is available for another memory request.

### \* Definitions

Access time → Time required by the memory to select a word & read it

Cycle Time → Time required to complete a write operation.

## Types of Memories

### (i) Sequential vs. Random Access memory

Sequential access memory → information stored is not immediately accessible, but is available only at certain intervals of time.

- A magnetic disk or tape unit is of this type.
- Each memory location passes the read and write heads in turn, but ~~info.~~ info. is only read out when the requested memory is reached.
- i.e. Time taken to access a word depends on the position of the word

Random Access memory → access time is always the same

- word locations may be thought of as being separated by a space, each word occupying one particular location

### (ii) Static and Dynamic Ram

Static RAM → has internal latches to store binary information

- stored info retained as long as there is power supply

- easier to use, has shorter read and write cycles.

Dynamic RAM → stores binary info in the form of electric charges on capacitors

- the stored charges tend to discharge with time

- periodic charging is done by refreshing
  - Refreshing is done by cycling through the words every few milliseconds
  - offers reduced power consumption and larger storage capacity in a single memory chip.
- (iii) Volatile and Non Volatile RAM
- Volatile → lose stored information when power is turned off
- binary cells need external power to maintain the stored information.
- Non-Volatile → retains stored information even after removing power
- includes magnetic disks, ROM, hard disks, CDs.
- \* Memory Decoding
- There is a need for decoding circuits to select the memory word specified by the input address.
  - The internal construction of RAM with m words and n bits per word consists of  $m \times n$  binary storage cells
- <sup>The storage</sup>  
→ ~~Each~~ part of the binary cell is modeled using an SR latch with the associated gates to form a D latch.
- The internal latch stores 1 bit of information
  - The select input enables the cell for reading & writing.
  - The read/write input determines the operation of the cell.



Consider the following example:

there are 4 words ( $m = 4$ )

each word is four bit ( $n = 4$ )

$\therefore$  Total no. of binary cells  $= m \times n = 16$

No. of outputs = 4

No. of address lines = 2

→ Each binary cell has 3 inputs and 1 output

→ When the memory is 0, all outputs of the decoder are 0.

→ When the memory select is 1, one of the words chosen, depending on the address line values.

→ Once a word is chosen, the read / write input determines the operation.

Read Operations: 4 bits of the selected word go through the OR gates to the o/p terminal

Write Operations: data available in the input is transferred to the 4 binary cells of the selected word.



### \* Coincident Decoding

→ A decoder with  $k$  inputs would ~~require~~ have  $2^k$  outputs, and thereby require  $2^k$  AND gates in all.

- The total no. of gates and the no. of inputs per gate can be reduced by employing 2 decoders in a 2 dimensional selection scheme.
  - $k/2$  input decoders are used instead of one  $R$ -input decoder.
  - One decoder performs row selection, the other column selection.
- For example, for a 1K word memory:
- rather than using a  $10 \times 1024$  decoder, 2  $5 \times 32$  decoders be used
  - This means that only 64 AND gates with 5 inputs each would be needed over 1024 AND gates with 10 inputs each.
  - The 5 most significant bits go to input  $X$ , and the 5 least significant go to  $Y$ .
  - Each word within the memory is selected by the coincidence of 1  $X$  line and 1  $Y$  line, i.e. each intersection represents a word



for ex. if a word has the address 404, the 10 bit binary equivalent is 01100 10100

$$\begin{aligned} \Rightarrow X &= 01100 = 12 \\ Y &= 10100 = 20 \end{aligned}$$

binary address 404

## \* Address Multiplexing

- SRAM memory cells have 6 transistors.
- To build memories with a higher density, it is necessary to reduce the no. of transistors in a cell.
- The DRAM cell has a single mos transistor and a capacitor.
- The charge stored on the capacitor discharges with time, so the memory cells are periodically recharged by refreshing the memory.
- The density of DRAMs =  $4 \times$  SRAMs
- DRAMs also cost 4 times less, and have a lower power requirement.
- Because of the large capacity, the address decoding of DRAMs is arranged into a 2 dimensional array, and larger memories often have multiple arrays.
- To minimize the no. of pins, designers use address multiplexing whereby one set of address input pins accommodates the address components.
- In a 2 dimensional array, the address is applied in 2 parts at 2 different parts, first the row address and then the column address.
- The no. of pins used for both parts of the address are the same.  $\Rightarrow$  the size of the package decreases significantly.



Consider a 64K memory.

- The memory has a 2D array of cells arranged into 256 rows<sup>2</sup> columns
- There are 2 8x256 decoders.
- There is a single data input line , and a single output line
- There is also a read/write control.
- There is an 8 bit address input, and two address ~~strobes~~ stobes to enable the rows and columns addresses into their respective registers.
- The RAS = Row Access Strobe enables the 8 bit row register
- The CAS = Column Address Strobe enables the 8 bit column register.
- The bar above the RAS & CAS indicates that the registers are enabled on the zero level of the signal.

Working : → Initially, both probes are in 1-state

- The 8 bit row address is applied to the ~~row~~ register address input , RAS is turned to 0.
- The corresponding decoder is also enabled, and one row is selected

- After the settling time of the row selection, it goes back to 0.
- The 8 bit column address is then applied to the address inputs, and CAS goes to the 0 state.
- The column address is transferred to the column register & the column decoder is enable.
- Now that the 2 parts of the address are in their respective registers, the decoders have decoded them to select one cell corresponding to the row and column address.
- A read or write operation can be performed on that cell.
- CAS must go back to 1, before initiating another memory operation.

### Error Detection and Correction - Hamming Code

- The dynamic physical interaction of the electrical signals affecting the data path may cause occasional errors in storing and retrieving binary information.

### Error Detecting & Correcting Schemes

Error Detecting Scheme: parity bit

- A parity bit is generated and stored along with the data word in the memory.
- After reading the word, the parity is checked.
- If the parity bits are correct, then the word is accepted.
- This technique can only detect errors, not correct them.

Error Correcting Code → Multiple parity check bits

are stored with the data word in the memory.

→ Each check bit is a parity over a group of bits in the data word.

→ When the word is read back from the memory, the parity bits are checked with a set of check bits generated from the data.

→ If the check bits are correct, then there is no error. If they do not match, they generate a unique pattern called a syndrome, that can be used to identify the bit that is in error.

### \* Hamming Code

→ Devised by R.W. Hamming

→ If there is an  $n$  bit word,  $k$  parity bits are added

→ A new word of  $n+k$  bits is formed.

→ The relation between  $n$  and  $k$  is:

$$2^k - 1 \geq n+k$$

→ The positions numbered as powers of 2 are reserved for the parity bits.

→ The remaining bits are data bits.

For example, consider an 8 bit word: 11000100.

$$n=8$$

$$2^k - 1 \geq n+k$$

$$2^k - 1 \geq 8+k$$

$$\Rightarrow k = 4$$

4 parity bits are required.

Total no. of bits = 12

| Decimal | P <sub>8</sub> C <sub>8</sub> | P <sub>4</sub> C <sub>4</sub> | P <sub>2</sub> C <sub>2</sub> | P <sub>1</sub> C <sub>1</sub> |
|---------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|
| 0       | 0                             | 0                             | 0                             | 0                             |
| 1       | 0                             | 0                             | 0                             | 1                             |
| 2       | 0                             | 0                             | 1                             | 0                             |
| 3       | 0                             | 0                             | 1                             | 1                             |
| 4       | 0                             | 1                             | 0                             | 0                             |
| 5       | 0                             | 1                             | 0                             | 1                             |
| 6       | 0                             | 1                             | 1                             | 0                             |
| 7       | 0                             | 1                             | 1                             | 1                             |
| 8       | 1                             | 0                             | 0                             | 0                             |
| 9       | 1                             | 0                             | 0                             | 1                             |
| 10      | 1                             | 0                             | 1                             | 0                             |
| 11      | 1                             | 0                             | 1                             | 1                             |
| 12      | 1                             | 1                             | 0                             | 0                             |
| 13      | 1                             | 1                             | 0                             | 1                             |
| 14      | 1                             | 1                             | 1                             | 0                             |
| 15      | 1                             | 1                             | 1                             | 1                             |

$$P_1 = \text{XOR } (3, 5, 7, 9, 11)$$

$$P_2 = \text{XOR } (2, 3, 6, 7, 10, 11)$$

$$P_4 = \text{XOR } (4, 5, 6, 7, 12)$$

$$P_8 = \text{XOR } (8, 9, 10, 11, 12)$$

$$C_1 = \text{XOR } (1, 3, 5, 7, 9, 11)$$

$$C_2 = \text{XOR } (2, 3, 6, 7, 10, 11)$$

$$C_4 = \text{XOR } (4, 5, 6, 7, 12)$$

$$C_8 = \text{XOR } (8, 9, 10, 11, 12)$$

The value of each parity bit is calculated as follows (Refer table below)

$$P_1 = \text{XOR} (3, 5, 7, 9, 11) \Rightarrow 0$$

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

$$P_2 = \text{XOR} (2, 3, 6, 7, 10, 11) \Rightarrow 0$$

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

$$P_4 = \text{XOR} (4, 5, 6, 7, 12) \Rightarrow 1$$

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

$$P_8 = \text{XOR} (8, 9, 10, 11, 12) \Rightarrow 1$$

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

Bit position

| 1              | 2              | 3 | 4              | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 |   |
|----------------|----------------|---|----------------|---|---|---|----------------|---|----|----|----|---|
| P <sub>1</sub> | P <sub>2</sub> | 1 | P <sub>3</sub> | 1 | 0 | 0 | P <sub>4</sub> | 0 | 1  | 1  | 0  | 0 |
| 0              | 0              |   | 1              |   |   |   | 1              |   |    |    |    |   |

The corresponding Hamming code is

001110010100

### Hamming Code Check

$$c_1 = \text{XOR} (1, 3, 5, 7, 9, 11) \Rightarrow 0$$

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

$$c_2 = \text{XOR} (2, 3, 6, 7, 10, 11) \Rightarrow 0$$

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

$$c_4 = \text{XOR} (4, 5, 6, 7, 12) \Rightarrow 0$$

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

$$c_8 = \text{XOR} (8, 9, 10, 11, 12) \Rightarrow 0$$

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

$$C = c_8 c_4 c_2 c_1 \Rightarrow 0000 \Rightarrow \text{No error}$$

### Example:

Find the error, if any, and the bit at which the error is present in the following Hamming code

### Ex1 Bit position

| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
|---|---|---|---|---|---|---|---|---|----|----|----|
| 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1  | 0  | 0  |

$$C_1 = \text{XOR } (1, 3, 5, 7, 9, 11) \Rightarrow 1$$

$$C_2 = \text{XOR } (2, 3, 6, 7, 10, 11) \Rightarrow 0$$

$$C_4 = \text{XOR } (4, 5, 6, 7, 12) \Rightarrow 0$$

$$C_8 = \text{XOR } (8, 9, 10, 11, 12) \Rightarrow 0$$

$$C = C_8 C_4 C_2 C_1 = 0001 \Rightarrow \text{Error in bit 1}$$

### Ex2 Bit Position

| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
|---|---|---|---|---|---|---|---|---|----|----|----|
| 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1  | 0  | 0  |

$$C_1 = \text{XOR } (1, 3, 5, 7, 9, 11) \Rightarrow 1$$

$$C_2 = \text{XOR } (2, 3, 6, 7, 10, 11) \Rightarrow 0$$

$$C_4 = \text{XOR } (4, 5, 6, 7, 12) \Rightarrow 1$$

$$C_8 = \text{XOR } (8, 9, 10, 11, 12) \Rightarrow 0$$

$$C = C_8 C_4 C_2 C_1 = 0101 \Rightarrow \text{Error in bit 5}$$

## \* Single Error Correction, Double Error Detection

→ By adding another parity bit to the coded word, the Hamming code can be used to correct a single error and detect multiple errors.

→ The additional parity bit is evaluated as the X-OR of all the other bits.

e.g.

If the Hamming code is:

0 0 1 1 1 0 0 1 0 1 0 0

then  $P_{13} = 1$

This becomes a check for even parity

During checking

If  $P=0 \Rightarrow$  correct

$P=1 \Rightarrow$  incorrect

The following 4 cases arise:

| C | $P_{13}$ |                     |
|---|----------|---------------------|
| 0 | 0        | → no error          |
| 0 | 1        | → error in $P_{13}$ |
| 1 | 0        | → double error      |
| 1 | 1        | → single error      |

## Example Questions

- ① Given the 8 bit word 01011011, generate the 13 bit composite word for the Hamming code that corrects single errors and detects double errors.

$$\begin{aligned}
 P_1 &= \text{XOR } (3, 5, 7, 9, 11) & \Rightarrow 0 \\
 P_2 &= \text{XOR } (3, 6, 7, 10, 11) & \Rightarrow 0 \\
 P_4 &= \text{XOR } (5, 6, 7, 12) & \Rightarrow 1 \\
 P_8 &= \text{XOR } (9, 10, 11, 12) & \Rightarrow 1
 \end{aligned}$$

| Bit position | 1              | 2 | 3              | 4 | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 | 13              |
|--------------|----------------|---|----------------|---|---|---|---|----------------|---|----|----|----|-----------------|
| R            | P <sub>2</sub> | D | P <sub>4</sub> | D | D | D | D | P <sub>8</sub> | D | D  | D  | D  | P <sub>13</sub> |
| Data         |                | 0 |                | 1 | 0 | 1 |   | 1              | 0 | 1  | 1  |    |                 |
| Parity       | 0              | 0 | 1              |   |   | 1 |   |                |   |    |    |    |                 |
| HammingCode  | 0              | 0 | 0              | 1 | 1 | 0 | 1 | 1              | 1 | 0  | 1  | 1  | 1               |

∴ The 13 bit composite word is 0001 1011 1011 1

- ② Obtain the 15 bit Hamming code word for the 11 bit data word 11001001010

Ans: n = 11

$$2^k - 1 \geq n+k$$

$$2^k - 1 \geq 11 + k$$

$$k=4$$

∴ Total no. of bits required = n+k = 11+4=15

| Decimal | P <sub>8C8</sub> | P <sub>4C4</sub> | P <sub>2C2</sub> | P <sub>1C1</sub> |
|---------|------------------|------------------|------------------|------------------|
| 0       | 0                | 0                | 0                | 0                |
| 1       | 0                | 0                | 0                | 1                |
| 2       | 0                | 0                | 1                | 0                |
| 3       | 0                | 0                | 1                | 1                |
| 4       | 0                | 1                | 0                | 0                |
| 5       | 0                | 1                | 0                | 1                |
| 6       | 0                | 1                | 1                | 0                |
| 7       | 0                | 1                | 1                | 1                |
| 8       | 1                | 0                | 0                | 0                |
| 9       | 1                | 0                | 0                | 1                |
| 10      | 1                | 0                | 1                | 0                |
| 11      | 1                | 0                | 1                | 1                |
| 12      | 1                | 1                | 0                | 0                |
| 13      | 1                | 1                | 0                | 1                |
| 14      | 1                | 1                | 1                | 0                |
| 15      | 1                | 1                | 1                | 1                |

$$C_1 = \text{XOR } (1, 3, 5, 7, 9, 11, 13, 15)$$

$$C_2 = \text{XOR } (2, 3, 6, 7, 10, 11, 14, 15)$$

$$C_4 = \text{XOR } (4, 5, 6, 7, 12, 13, 14, 15)$$

$$C_8 = \text{XOR } (8, 9, 10, 11, 12, 13, 14, 15)$$

$$P_1 = \text{XOR } (3, 5, 7, 9, 11, 13, 15)$$

$$P_2 = \text{XOR } (3, 6, 7, 10, 11, 14, 15)$$

$$P_4 = \text{XOR } (5, 6, 7, 12, 13, 14, 15)$$

$$P_8 = \text{XOR } (9, 10, 11, 12, 13, 14, 15)$$

| Bit Position | 1              | 2              | 3 | 4              | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|--------------|----------------|----------------|---|----------------|---|---|---|----------------|---|----|----|----|----|----|----|
|              | P <sub>1</sub> | P <sub>2</sub> | 0 | P <sub>4</sub> | 0 | 0 | 0 | P <sub>8</sub> | 0 | 0  | 0  | 0  | 0  | 0  | 0  |
| Data         | .              | .              | 1 | 1              | 0 | 0 | . | 1              | 0 | 0  | 1  | 0  | 1  | 0  | .  |
| Parity       | 1              | 0              | . | 1              | . | . | 1 | .              | . | .  | .  | .  | .  | .  | .  |
| Hamming code | 1              | 0              | 1 | 1              | 1 | 0 | 0 | 1              | 1 | 0  | 0  | 1  | 0  | 1  | 0  |

$$P_1 = \text{XOR } (3, 5, 7, 9, 11, 13, 15) \Rightarrow 1$$

$$P_2 = \text{XOR } (3, 6, 7, 10, 11, 14, 15) \Rightarrow 0$$

$$P_4 = \text{XOR } (5, 6, 7, 12, 13, 14, 15) \Rightarrow 1$$

$$P_8 = \text{XOR } (9, 10, 11, 12, 13, 14, 15) \Rightarrow 1$$

∴ The 15 bit Hamming Code word is : 101 110 011 001 010

Ques 3 A 12-bit Hamming code word containing 8 bits of data & 4 parity bits is read from memory. What was the original 8 bit data word?

(a) 000010101010

| Bit Position | 1              | 2              | 3 | 4              | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12              |
|--------------|----------------|----------------|---|----------------|---|---|---|----------------|---|----|----|-----------------|
|              | P <sub>1</sub> | P <sub>2</sub> | 0 | P <sub>4</sub> | 0 | 0 | 0 | P <sub>8</sub> | 0 | 0  | 0  | P <sub>12</sub> |
|              | 0              | 0              | 0 | 0              | 1 | 0 | 1 | 0              | 1 | 0  | 1  | 0               |

Original word = ~~01010101010~~ 0101 1010

(b) 011101101111

| Bit position | 1              | 2              | 3 | 4              | 5 | 6 | 7 | 8              | 9 | 10 | 11 | 12              |
|--------------|----------------|----------------|---|----------------|---|---|---|----------------|---|----|----|-----------------|
|              | P <sub>1</sub> | P <sub>2</sub> | 0 | P <sub>4</sub> | 0 | 0 | 0 | P <sub>8</sub> | 0 | 0  | 0  | P <sub>12</sub> |
|              | 0              | 1              | 1 | 1              | 0 | 1 | 1 | 0              | 1 | 1  | 1  | 1               |

Original word: 1011 1111

E24: How many parity check bits must be included with the data word to achieve single error correction and double error detection, when the data word contains

(a) 24 bits

$$n = 24$$

$$2^k - 1 \geq n + k$$

$$2^k - 1 \geq 24 + k$$

$$\boxed{1 \leq k \leq 5}$$

$\therefore$  5 check bits + 1 = 6 parity bits

(b) 32 bits

$$n = 32$$

$$2^k - 1 \geq n + k$$

$$2^k - 1 \geq 32 + k$$

$$2^6 - 1 \geq 32 + 6$$

$$\boxed{1 \leq k \leq 6}$$

$\Rightarrow$  7 parity bits

(c) 64 bits

$$2^7 - 1 \geq 64 + 7$$

= 7 check bits + 1 parity bit

$$= \boxed{8 \text{ parity bit.}}$$

## \* Read-Only Memory (ROM)

- A memory device in which permanent binary information is stored.
- The binary information is specified by the designer and is then embedded in the unit to form the required interconnection pattern.
- Once the pattern is established, it stays within the unit even when the power is turned off and on again.
- If there are  $2^k$  words, then  $k$  address lines are needed.
- Each word has  $n$  bits.



Example: Consider a  $32 \times 8$  ROM

$$n = 8 \quad = \text{no. of bits per word}$$

$$\text{no. of words} = 32$$

$$\text{no. of address lines} = k = 5 \quad (2^5 = 32)$$

→ The 5 inputs are decoded into a ~~5x32 decoder~~ using outputs using a  $5 \times 32$  decoder.

→ Each of the 32 outputs are connected to 8 OR Gates.

In general

$$\left. \begin{array}{l} k = \text{no. of inputs} \\ 2^k = \text{no. of words} \\ k \times 2^k = \text{decoder} \\ n = \text{no. of outputs} = \text{no. of OR Gates} \end{array} \right\}$$



### \* Types of ROMs

#### ① Mask Programming

- programming done by the semiconductor company
- customer fills out truth table he wishes the ROM to satisfy
- the manufacturer makes the corresponding mask for the paths to produce 0s and 1s according to the truth table
- Expensive, since the ROM is custom made
- Economical only if a large no. of the same configuration are ordered.

#### ② PROM - Programmable Read Only Memory

- Programming done with fuses at the intersections
- Initially, all the fuses are intact, all are 1.
- The fuses are blown by the application of a high-voltage pulse through a pin.

→ blown fuse  $\Rightarrow$  binary state 0

intact fuse  $\Rightarrow$  binary state 1

→ This procedure allows users to program, using special instruments.

→ Once programmed, it is reversible.

### ③ EPROM - Erasable PROM

→ Can be restructured to the initial state even though it has been programmed previously.

→ When placed under a special UV light, the shortwave radiation discharges the internal floating gates, that serve as programmed connection

→ A new set of values can be then programmed.

### ④ EEPROM or E<sup>2</sup>ROM - Electrically Erasable PROM

→ Similar to an ROM

→ Previously programmed connections can be erased with an electrical signal instead of UV light.

→ The advantage is that the device can be erased without removing it from its socket.

### ⑤ Flash Memory Devices

→ Similar to EEPROMs, but have additional built-in circuitry to selectively program and erase the circuit, without the need of a special programmer.

→ Have widespread application in modern technology

like cell phones, digital cameras, microcontrollers.

- Attractive storage for laptops, due to their low power consumption.
- like EEPROMs, can be subject to fatigue.

### \* Programmable Logic Devices (PLD)

- Electronic component used to build digital circuits
- It must be programmed before being used in a circuit.

Types of PLDs

- PROM
- Programmable Logic Array (PLA)
- Programmable Array Logic (PAL)
- Field programmable gate array (FPGA)

### Configuration of PLDs



## ① Programming PROMs

- The intersections of the output of the decoder, and the inputs to the OR gates are programmable.
- They are equivalent to switches and are called crosspoints.
- Various physical devices are used to implement crosspoint switches, out of which the simplest is using fuses.
- Fuses are blown by the application of a high-voltage pulse.

Example : Design a combinational circuit using a ROM. The circuit accepts a 3-bit number and outputs a binary number equal to the square of the input number.

Ans: no. of input lines: 3  $k=3$

no. of output lines: 6 ~~1000~~

type of decoder to use:  $2^k \times n$

| Decimal | Input<br>$A_2$ $A_1$ $A_0$ | Outputs<br>$B_5$ $B_4$ $B_3$ $B_2$ $B_1$ $B_0$    | Type of ROM<br>$2^k \times 4$<br>18x4 ROM |
|---------|----------------------------|---------------------------------------------------|-------------------------------------------|
| 0       | 0 0 0                      | 0 0 0 0 0 0                                       |                                           |
| 1       | 0 0 1                      | 0 0 0 0 0 1                                       |                                           |
| 4       | 0 1 0                      | 0 0 0 1 0 0                                       |                                           |
| 9       | 0 1 1                      | 0 0 1 0 0 1                                       |                                           |
| 16      | 1 0 0                      | 0 1 0 0 0 0                                       |                                           |
| 25      | 1 0 1                      | 0 1 1 0 0 1                                       | $\Rightarrow$ no. of outputs<br>are 4     |
| 36      | 1 1 0                      | 1 0 0 1 0 0                                       |                                           |
| 49      | 1 1 1                      | 1 1 0 0 0 1<br>0 $\underline{\hspace{1cm}}$ $A_0$ |                                           |

### Block Diagram



### ROM Truth Table

| A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | B <sub>5</sub> | B <sub>4</sub> | B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0              | 0              | 0              | 0              | 0              | -0             | 0              |                |
| 0              | 0              | 1              | 0              | 0              | :0             | 0              |                |
| 0              | 1              | 0              | 0              | 0              | 0              | 1              |                |
| 0              | 1              | 1              | 0              | 0              | 1              | 0              |                |
| 1              | 0              | 0              | 0              | 1              | 0              | 0              |                |
| 1              | 0              | 1              | 0              | 1              | 1              | 0              |                |
| 1              | 1              | 0              | 1              | 0              | 0              | 1              |                |
| 1              | 1              | 1              | 1              | 1              | 0              | 0              |                |

### Logic Circuit



Ex2 Construct a combinational circuit using ROM that implements the following Boolean functions.

$$F_1(A, B, C) = \Sigma(0, 1, 2, 4)$$

$$F_2(A, B, C) = \Sigma(0, 5, 6, 7)$$



ROM implementation for  $F_2$ :

|   | BC | 00 | 01 | 11 | 10 |
|---|----|----|----|----|----|
| A | 0  | 1  | 0  | 1  | 3  |
|   | 1  | 4  | 5  | 7  | 6  |
|   | 4  | 5  | 7  | 1  | 6  |

$$\begin{array}{r} G_1: \\ \begin{array}{r} \begin{array}{rrr} A & B & C \\ 0 & 0 & 0 \\ 0 & 0 & 1 \\ \hline \bar{A} \bar{B} \end{array} \end{array} \end{array}$$

$$\begin{array}{r} G_2: \\ \begin{array}{r} \begin{array}{rrr} A & B & C \\ 0 & 0 & 0 \\ 1 & 0 & 0 \\ \hline \bar{B} \bar{C} \end{array} \end{array} \end{array}$$

$$\begin{array}{r} G_3: \\ \begin{array}{r} \begin{array}{rrr} A & B & C \\ 0 & 0 & 0 \\ 0 & 1 & 0 \\ \hline \bar{A} \bar{C} \end{array} \end{array} \end{array}$$

$$F_2 = AB + AC + A'B'C'$$

Not necessary to simplify

| A    | BC | $F_1$ | $F_2$ |
|------|----|-------|-------|
| 0, 0 | 0  | 1     | 1     |
| 0, 0 | 1  | 1     | -     |
| 0, 1 | 0  | 1     | -     |
| 0, 1 | 1  | -     | -     |
| 1, 0 | 0  | 1     | -     |
| 1, 0 | 1  | -     | -     |
| 1, 1 | 0  | -     | -     |
| 1, 1 | 1  | -     | -     |

## ROM Design

33



Ex3 Design a ROM that implements the following Boolean functions

$$A(x_1, x_2) = \Sigma(1, 2, 4, 6)$$

$$B(x_1, x_2) = \Sigma(0, 1, 6, 7)$$

$$C(x_1, x_2) = \Sigma(2, 6)$$

$$D(x_1, x_2) = \Sigma(1, 2, 3, 5, 7)$$

## ROM Design

Program

| $x_1 x_2$ | A | B | C/D |
|-----------|---|---|-----|
| 0 0 0     | 0 | 1 | 0   |
| 0 0 1     | 1 | 1 | 0   |
| 0 1 0     | 1 | 0 | 1   |
| 0 1 1     | 0 | 0 | 0   |
| 1 0 0     | 1 | 0 | 0   |
| 1 0 1     | 0 | 0 | 0   |
| 1 1 0     | 1 | 1 | 1   |
| 1 1 1     | 0 | 1 | 0   |



## ② Programmable Logic Array (PLA)

- Similar to a PROM, but does not provide full decoding of variables.
- does not generate all the minterms
- the AND and OR gates are programmable.
- the AND gates are programmed to generate any product term
- the product terms are then connected to OR gates to provide the SOP

Ex: Design a PLA circuit for the following Boolean functions

$$F_1 = AB' + AC + A'B'C'$$

$$F_2 = (AC + BC)'$$

### Fuse Map

| Product Table | Product No | Inputs<br>A B C | Output   |          |
|---------------|------------|-----------------|----------|----------|
|               |            |                 | $F_1(T)$ | $F_2(C)$ |
| $AB'$         | 1          | 1 0 -           | 1        | -        |
| $AC$          | 2          | 1 - 1           | 1        | 1        |
| $A'B'C'$      | 3          | 0 1 0           | 1        | 0        |
| $BC$          | 4          | - 1 1           | -        | 1        |

PRA Circuit

No. of AND gates = no. of product terms = 4

No. of OR gates = no. of functions = 2



Ex2 Implement the following 2 Boolean functions with a PRA.

$$F_1(A, B, C) = \Sigma(0, 1, 2, 4)$$

$$F_2(A, B, C) = \Sigma(0, 5, 6, 7)$$

$$\begin{array}{r} G_1: A B C \\ 0 0 0 \\ 0 0 X \\ \hline \overline{A B} \end{array} \quad \begin{array}{r} G_2: A B C \\ 0 0 0 \\ 0 0 0 \\ \hline \overline{B C} \end{array}$$

$$\boxed{F_1 = \overline{A B} + \overline{B C} + \overline{A C}}$$

$$\boxed{F_1' = (A B + B C + A C)'} \quad \boxed{F_2 = \overline{A C}}$$

$$\begin{array}{r} G_3: A B C \\ 0 0 0 \\ 0 1 0 \\ \hline \overline{A C} \end{array} \quad \begin{array}{r} G_1: A B C \\ 0 1 1 \\ 1 1 1 \\ \hline \overline{B C} \end{array}$$

$$\begin{array}{r} G_2: A B C \\ 1 0 1 \\ 1 1 1 \\ \hline \overline{A C} \end{array} \quad \begin{array}{r} G_3: A B C \\ 1 1 1 \\ 1 1 0 \\ \hline \overline{A D} \end{array}$$

| F <sub>1</sub> | 00 | 01 | 11 | 10 |
|----------------|----|----|----|----|
| A              | 0  | 1  | 0  | 1  |
| B              | 1  | 0  | 0  | 0  |

$$F_2(A, B, C) = \Sigma(0, 5, 6, 7)$$

$F_2$

|   | $A$ | $B$ | $C$ | $F_2$ |
|---|-----|-----|-----|-------|
|   | 00  | 01  | 11  | 10    |
| 0 | 1   | 0   | 0   | 0     |
| 1 | 0   | 1   | 1   | 1     |

$$G_1 = \begin{array}{r} A \\ \times \\ 0 \\ 0 \\ 0 \end{array} = A \cdot B \cdot C$$

$$G_2 = \begin{array}{r} A \\ \times \\ 1 \\ 0 \\ 1 \end{array} = \overline{A} \cdot C$$

$$G_3 = \begin{array}{r} A \\ \times \\ 1 \\ 1 \\ 1 \\ \hline 1 \\ 1 \\ 0 \end{array} = \overline{A} \cdot \overline{B}$$

$$F_2 = AB + AC + A'B'C'$$

$F_2'$

$$G_1 = \begin{array}{r} A \\ \times \\ 0 \\ 0 \\ 1 \end{array} = \overline{AC}$$

$$G_2 = \begin{array}{r} A \\ \times \\ 0 \\ 1 \\ 1 \end{array} = \overline{AB}$$

$$G_3 = \begin{array}{r} A \\ \times \\ 1 \\ 0 \\ 0 \end{array} = A'B'C'$$

$$F_2' = \overline{AC} + \overline{AB} + A'B'C'$$

The combination with the least no. of product terms is

$F_1'$  and  $F_2$

Fuse Table

| Product Term | Pt No | Inputs | Outputs  |          |
|--------------|-------|--------|----------|----------|
|              |       | A B C  | $F_1(C)$ | $F_2(T)$ |
| AB           | 1     | 1 1 -  | 1        | 1        |
| BC           | 2     | - 1 1  | 1        | -        |
| AC           | 3     | 1 - 1  | 1        | -        |
| $A'B'C'$     | 4     | 0 0 0  | -        | 1        |

Logic Diagram



### ③ Programmable Array Logic (PAL)

(37)

- a PLD with a fixed OR gate and a programmable AND array.
- easier to program, but not as flexible as a PLA.
- Unlike PLAs, a product term cannot be shared among 2 or more OR gates.
- This means that each function is simplified by itself w/o regard to common product terms.

Ex1 Simplify the following Boolean Functions and design a PAL for the same.

$$w(A, B, C, D) = \Sigma(2, 12, 13)$$

$$x(A, B, C, D) = \Sigma(7, 8, 9, 10, 11, 12, 13, 14, 15)$$

$$y(A, B, C, D) = \Sigma(0, 2, 3, 4, 5, 6, 7, 8, 10, 11, 15)$$

$$z(A, B, C, D) = \Sigma(12, 8, 12, 13)$$

①  $w(A, B, C, D)$

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 1  | 3  | 2  |
| 01 |    | 4  | 5  | -  | 6  |
| 11 |    | 12 | 11 | 15 | 14 |
| 10 |    | 8  | 9  | 11 | 10 |

$$G_1 = \begin{array}{cccc} A & B & C & D \\ 0 & 0 & 1 & 0 \end{array} = A'B'C'D'$$

$$\begin{array}{cccc} A & B & C & D \\ 1 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 \end{array} = A'BC'$$

$w = ABC' + A'B'C'D'$

$$② \quad x(A, B, C, D) = \Sigma(7, 8, 9, 10, 11, 12, 13, 14, 15)$$

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 1  | 3  | 2  |
| 01 |    | 4  | 5  | 7  | 6  |
| 11 |    | 12 | 13 | 15 | 14 |
| 10 |    | 8  | 9  | 11 | 10 |

$$G_1 = \begin{array}{cccc} A & B & C & D \\ 0 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 \end{array}$$

$\overline{BCD}$

$$G_2 = \begin{array}{cccc} A & B & C & D \\ 1 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 \\ 1 & 1 & 1 & 0 \\ 1 & 0 & 0 & 0 \\ 1 & 0 & 0 & 1 \\ 1 & 0 & 1 & 1 \\ 1 & 0 & 1 & 0 \end{array}$$

$\overline{A}$

$$x = A + BCD$$

$$③ \quad y(A, B, C, D) = \Sigma(0, 2, 3, 4, 5, 6, 7, 8, 10, 11, 15)$$

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 1  | 1  | 2  |
| 01 |    | 4  | 5  | 7  | 6  |
| 11 |    | 12 | 13 | 15 | 14 |
| 10 |    | 8  | 9  | 11 | 10 |

$$G_1 = \begin{array}{cccc} A & B & C & D \\ 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 1 & 0 & 0 & 0 \\ 1 & 0 & 1 & 0 \end{array}$$

$\overline{BD}$

$$G_3 = \begin{array}{cc} AB & CD \\ 0 & 1 & 1 \\ 0 & 0 & 1 & 1 \\ 1 & 1 & 1 & 1 \\ 1 & 0 & 1 & 1 \end{array}$$

$\overline{CD}$

$$G_2 = \begin{array}{cccc} A & B & C & D \\ 0 & 1 & 0 & 0 \\ 0 & 1 & 0 & 1 \\ 0 & 1 & 1 & 1 \\ 0 & 1 & 1 & 0 \end{array}$$

$\overline{AB}$

$$y = A'B + CD + B'D$$

$$④ \quad z(A, B, C, D) =$$

$$\Sigma(1, 2, 8, 12, 13)$$

| AB | CD | 00 | 01 | 11 | 10 |
|----|----|----|----|----|----|
| 00 |    | 0  | 1  | 3  | 2  |
| 01 |    | 4  | 5  | 7  | 6  |
| 11 |    | 12 | 13 | 15 | 14 |
| 10 |    | 8  | 9  | 11 | 10 |

$$G_1 = A'B'CD'$$

$$G_2 = A'B'C'D$$

$$G_3 : ABCD$$

$$\begin{array}{cc} 11 & 00 \\ 11 & 01 \end{array}$$

$\overline{ABC'}$

$$G_4 : A B C D$$

$\begin{array}{cc} 1 & 1 \\ 1 & 0 & 0 \\ 1 & 0 & 0 \end{array}$

$\overline{AC'D'}$

$$w = \left\{ \begin{array}{l} A'B'CD' + A'B'C'D \\ ABC' + AC'D' \end{array} \right\}$$

$$z = w + AC'D' + A'B'C'D$$

No. of AND gates required = 3

39

| Term | Product Term No | Input     | Function Output          |
|------|-----------------|-----------|--------------------------|
| 1    | $ABC'$          | 1 1 0 - - | $w = ABC' + A'B'C'D'$    |
| 2    | $A'B'C'D'$      | 0 0 1 0 - |                          |
| 3    | -               | - - - - - |                          |
| 4    | $A$             | 1 - - - - |                          |
| 5    | $BCD$           | - 1 1 1 - | $x = A + BCD$            |
| 6    | -               | - - - - - |                          |
| 7    | $A'B$           | 0 1 - - - |                          |
| 8    | $CD$            | - - 1 1 - | $y = AB + CD + B'D'$     |
| 9    | $B'D'$          | - 0 - 0 - |                          |
| 10   | $w$             | - - - - 1 |                          |
| 11   | $AC'D$          | 1 - 0 0 - | $z = w + AC'D + A'B'C'D$ |
| 12   | $A'B'C'D$       | 0 0 0 1 - |                          |

### Circuit



## \* Sequential Programming Devices

- Digital systems are designed with flip flops and gates.
- Combinational PLD consists of only gates
- It is necessary to include external flip-flops to PLDs.
- Sequential programming devices include both gates & flip-flops

### Major Types

1. Sequential or simple programmable logic device (SPLD)
2. Complex programmable logic device (CPLD)
3. Field programmable gate array (FPGA)

### ① Sequential / Simple PLD

- has flip-flops in addition to and -or gates.
- PAL or PRA combined with flip flops to form a register
- outputs can be taken from OR gates or flip-flops
- D or JK flip flops are used.



## \* FPRS

- Field programmable logic sequencer (FPRS)
- has several outputs to flipflops, the PLA is ~~an~~ FPRS is organized around a PLA
- flexible, can operate with either the JK or D type.

## Disadvantage

- Too many programmable connections
- Did not succeed commercially

## \* Registered PAL

- a PAL with flip-flops
- This is to signify that that the device contains flip flops in addition to AND-OR gates.

## \* Macrocells

- Each section of an SPROM is called a macrocell.
- has an SOP combinational logic function and an optional flip-flop.

Construction → has an AND-OR array as a combinational PAL

- output is driven by an edge-triggered D flip-flop
- Flip flop o/p is connected to a 3-state buffer
- o/p of flip flop fed back into a programmable AND i/p
- functionalities include options to use or bypass the flip flop

Select clock edge polarity etc.



### \*CPLD

→ Digital system design often requires the connection of several PLD devices to produce the complete specification

→ more economical

→ CPLD = Complex PLD

→ consists of a collection of individual PLDs on a single IC.

### Construction

→ multiple PLDs are connected through a programmable switch matrix

→ The I/O blocks provide connections to the IC pins.

→ The switch matrix receives inputs from the I/O block 2 and directs them to individual macrocells.

Only selected outputs from the ~~selected~~ macrocells are sent to the O/Ps.

→ Each PLD has 8-16 macrocells

→ If a macrocell has unused product terms, they can be used by other nearby macrocells.



### \* FPGA - Field Programmable Gate Array

- FPGA → a VLSI circuit that can be programmed at the user's location
- has millions of logic blocks surrounded by programmable I/P and O/P blocks, connected together via programmable interconnections
- An FPGA has lookup table, MUX, gates & flipflops
- A lookup table is a truth table stored in SRAM, and provides combinational out fns. for the logic block of the FPGA.
- FPGA can be reprogrammed every time the power is switched on / off.