# Embedded Systems Architecture

Session #6

### Moore's Law

 "The number of transistors on an integrated circuit doubles every 24 months."

## Small Scale Integration (SSI)

- Fixed logic (7400, 5400 series families)
  - AND, OR, INV logic gates
  - Flip-flops
- Memory devices

### <u>Truth Table</u>

- A tabular method for describing the response of digital outputs to digital inputs.
- Strictly combinatorial (no internal memory).

# Truth Table Example

| Α | В | R | С |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

# Truth Table Logic



# Lookup Table



# Lookup Table Example

| <b>A1</b> (A) | <b>A0</b> (B) | D1(R) | D0(C) |
|---------------|---------------|-------|-------|
| 0             | 0             | 0     | 0     |
| 0             | 1             | 1     | 0     |
| 1             | 0             | 1     | 0     |
| 1             | 1             | 0     | 1     |

# Lookup Table



## Programmable Logic Device (PLD)

- Programmable Array Logic (PAL)
- Complex PLD (CPLD)
- Field-programmable gate array (FPGA)

### 16L8 PAL



Fuse number = First fuse number + In trement

## 16L8 PAL



### 16R8 PAL



# 22V10 Macro Cell



### **CPLD**



#### FPGA

- □ Configuration Memory
- □ Programmable Logic Blocks <a> (PLBs)</a>
- □ Programmable Input/Output Cells
- □ Programmable Interconnect



Typical Complexity = 5 million - 1 billion transistors

## Programmable Logic Block



# SoC (System on Chip)

- SoC Definition
- SoC Choice Considerations
- SoC Fabrication
- Hardcore vs. Softcore
- SoC Processors

### **SoC Definition**

 Integration of processor, memory, bus, DMA, and peripherals into a single IC chip.

#### **SoC Choice Considerations**

- Advantages
  - Physically smaller.
  - Less cost at higher volumes.
  - Greater speed.
  - Greater reliability.
- Disadvantages
  - Greater development time.

### SoC Fabrication

- Application-specific integrated circuit (ASIC)
  - Full-custom
  - Standard cell
  - Structured
- FPGA (PSoC)

### Hardcore vs. Softcore

- This is a FPGA specific issue.
- A hardcore resource like a processor, multiplier, block RAM, or I/O peripheral consists of silicon real estate dedicated towards that particular function.
- A softcore resource is implemented using the normal gate array logic resources.

#### **SoC Processors**

- ARM
- <u>PowerPC</u>
- MicroBlaze / PicoBlaze
- Nios II
- OpenRISC
- SPARC
  - <u>Leon</u> (<u>Leox</u>)
  - OpenSPARC
  - UltraSPARC T1

# SoC (Continued)

- SoC Buses
- SoC Peripherals
- SoC Operating Systems

### SoC Buses

- CoreConnect
- Wishbone
- <u>AMBA</u>
- Avalon
- OCP-IP

#### CoreConnect



**AMBA** 



## SoC Peripherals

- Analog interface converters
- Ethernet controllers
- UARTs
- PS2 keyboard & mouse interfaces
- VGA

# SoC Operating Systems

- FreeRTOS
- eCos
- uClinux
- µC/OS-II
- Xilkernal

# Other Online SoC Resources

- Open Collector
- Design and Reuse
- OpenCores

### Lab Session #6



Architecture Model#1

#### **Architecture Model**

- Architecture template
- Symbols
  - Architecture module
  - Information flow vector
  - Information flow channel

## Architecture Template

- Adds 4 perspectives to the requirements model:
  - Input processing.
  - Output processing.
  - User interface processing.
  - Maintenance or self-test processing.

## Architecture Template



### Architecture Module Symbol

- Contains allocation of requirements processes, flows, & stores to a physical module.
- Symbol: a rectangle with rounded corners.
- Naming convention: noun with no verbs.

## Information Flow Vector Symbol

- Represents all the flows between architecture modules.
- Symbol: same as that of control and data flows.

# Information Flow Channel Symbol

- Shows the physical means by which information flows between architecture modules.
- Symbol should be indicative of physical channel.
- Naming convention is the same that of information flow vector.