Jump to content

The necessities in SOC Design

From Wikiversity

Overview

[edit | edit source]
  • SoC in the wikipedia pages (pdf)

Fabrication of VLSI Circuits

[edit | edit source]
  • Fabrication in the wikipedia pages (pdf)
  • Wafer (pdf)
  • Mask (pdf)
  • Package (pdf)
  • Test (pdf)
  • CMOS Fabrication (pdf)

Device Level Design

[edit | edit source]
  • MOSFET Transistor (pdf)
  • CMOS Inverter (pdf)
  • Digital Implementation (pdf) - ASIC, FPGA
  • Analog Implementation (pdf) - Linear IC, Power IC, RF IC, Mixed Signal IC

Performance Metrics

[edit | edit source]
  • Device R, C (pdf)
  • Device Size (pdf)
  • Device Delay (pdf)
  • Device Power (pdf)

Device Level Design Tools

[edit | edit source]
  • Spice Simulator
  • VLSI CAD tools - Layout, Floorplanning, Placement and Routing, Physical Verification (LVS/DRC/ERC)


Transistor Level Design

[edit | edit source]
  • Combinational Designs (pdf)
  • Sequential Designs (pdf)
  • Subsystem
    • Arithmetic Subsystem (pdf)
    • Memory Array Subsystem (pdf)
    • Logic Array Subsystem

Performance Metric

[edit | edit source]
  • Gate Area (pdf)
  • Gate Delay (pdf)
  • Gate Power (pdf)

Design Issues

[edit | edit source]
  • Clock
  • PLL & DLL
  • I/O

Transistor Level Design Tools

[edit | edit source]
  • Spice


Gate Level Design

[edit | edit source]
  • Combinational Designs (pdf)
  • Sequential Designs (pdf)
  • Subsystem
    • Arithmetic Subsystem (pdf)
    • Memory Array Subsystem (pdf)
    • Logic Array Subsystem

Performance Metric

[edit | edit source]
  • Gate Count
  • Path Delay (pdf)
  • Switch Activity (pdf)

Design Issues

[edit | edit source]
  • Static Timing Analysis
  • Scan and Boundary Scan Cells
  • Formal Verification

Gate Level Design Tools

[edit | edit source]
  • Verilog
  • VHDL
  • Static Timing Analysis
  • Formal Verification


RTL Level Design

[edit | edit source]
  • Register (pdf)
  • FSM (pdf)
  • One Hot Controller
  • Pipeline (pdf)

Performance Metric

[edit | edit source]
  • Estimation of
    • Gate Count
    • Critical Path
    • Power
  • Latency
  • Throughput

Design Issues

[edit | edit source]
  • Partitioning and Coding Style
  • Constraining Designs
  • Optimizing Designs
  • Design for Test (DFT)
  • Pre-layout & Post-layout Simulation

RTL Design Tools

[edit | edit source]
  • Verilog
  • VHDL
  • Logic Synthesis


Architecture Level Design

[edit | edit source]

Background: Tiny CPU Examples

[edit | edit source]


  • Processors (pdf)
  • Memories (pdf)
- Cache Memory
Readings (pdf)
Cache Note (pdf)
See also Content Addressable Memory (pdf), Address Partition (pdf), Cache Mapping (pdf)
- Virtual Memory
Readings (pdf)
- DRAM
Readings (pdf)
See also RAM Structure (pdf), RAM Timing (pdf), FPGA RAM (pdf)
  • Interconnecting Buses
- AMBA AHB & APB
Readings (pdf)


  • CISC, RISC, VLIW, Dataflow (1.pdf)
  • CPU, DSP, GPU, NPU (2.pdf)
  • MCU, ASIP, TTA (3.pdf)


Design Issues

[edit | edit source]
  • Memory Hierarchy
  • Storage and I/O
  • Instruction Level Parallelism
  • Data Level Parallelism
  • Thread Level Parallelism


Design Tools

[edit | edit source]
  • ADL (Architecture Design Language)
- LISA, EXPRESSION, nML, ArchC
  • SystemC TLM (Transaction Level Modeling)


System Level Design

[edit | edit source]
  • IP : OCP-IP, OpenCore


Typical SOC's

[edit | edit source]
  • Embedded System
  • MPSOC
  • NoC


Design Issues

[edit | edit source]
  • Transaction Level Modeling
  • Hardware Software Partition
  • Hardware Software Co-simulation
  • Integration of Hardware IP Blocks
  • Integration of Software IP Modules
  • FPGA Based Emulation Platform


Design Tools

[edit | edit source]
  • High-Level Synthesis
  • HVL (High-Level Verification Language)
- SystemC Verifcation (SCV) (See "SystemC programming in plain view")
- SystemVerilog
  • Mixed Signal
- VHDL-AMS
- Verilog-AMS
- SystemC-AMS


Design Flow

[edit | edit source]

HW/SW Design Examples : Traffic Controller Design

[edit | edit source]
  • HW/SW Implementation Overview (pdf)

Implementation in Hardware

  • RTL Design Examples (pdf)
  • Gate Level Design Examples (pdf)
  • Transistor Level Design Examples (pdf)

Implementation in Software

  • SW Implementation Without an OS (Bare Machine)
- Overview (pdf)
- Micro-controller Programming (pdf)
  • SW Implementation with an RTOS (pdf)

RTL / Logic Level Design

[edit | edit source]
  • Logic Synthesis
  • Logic Simulation
  • Logic Timing Verification
  • Logic Power Verification
  • Test Synthesis
  • Test Verification
  • Testbench
  • Code Coverage
  • Equivalence Check
  • Timing Verification
  • Design Constraint
  • STA (Static Timing Analysis)
  • Scan Chain
  • Back Annotation
  • ATPG (Automatic Test Pattern Generation)



Physical Design

[edit | edit source]
  • Floorplanning
  • Placement
  • Routing
  • Power Network
  • Clock Distribution
  • Physical Verification
  • DRC (Design Rule Check)
  • DV (Design Verification)
  • GV (Geometry Verification)
  • LVS (Layout Versus Schematic)
  • SV (Schematic Verification)


Printed Circuit Board

[edit | edit source]


Test

[edit | edit source]
  • Design For Test
  • ATPG (Automatic Test Pattern Generation)
  • Analog and Mixed Signal Test
  • JTAG (Joint Test Action Group) IEEE 1149.1
  • Embedded Core Test IEEE 5000
test access mechanisms (TAMs)
Core test language (CTL)


Logical Verification

[edit | edit source]
  • Assertion Based Verification
  • Transaction Level Models
  • Formal Property Verification



2016 Spring Class

[edit | edit source]
  • Some useful links in VLSI design (1.pdf, 2.pdf)
  • SystemC Projects (1.pdf) updated
  • SystemC Installation Guide (pdf)
  • OpenRISC ISS or1ksim Installation Guide (pdf)


  • HW#1 (pdf)
  • HW#2 (pdf)
  • HW#3 (pdf)
  • HW#4 (pdf)
  • HW#6 (pdf)
  • HW#7 (pdf) - Pipeline Burst EDO DRAM
  • finallist (pdf)


go to [ Electrical_&_Computer_Engineering_Studies ]

References

[edit | edit source]


asic-world.com

For ASIC design flow, See
ASIC design flow (lth.edu)

For Tiny CPU, See
Tiny CPU

For general buses, See
PCI bus
general buses
old buses

For AMBA, See
Embedded Processor & AMBA
AMBA overview

For DDR, See
DDR overview
DDR

For UART, See
UART Overview
ARM UART Notes

For DMA, See
DMA OVerview
DMA & IO
DMA & OS

For Embedded Programming, See
Embedded Programming
Discovering STM32 microcontroller
For TLM, See
TLM Overview
TLM
TLM & AMBA


For the final, Computer Arch
VHDL Primer (upenn.edu)
ASIC design flow (lth.edu)
Tiny CPU
Memory
DRAM
GPIO, UART, DMA, Int/Poll
UART Overview
GPIO Programming
AMBA Bus
ARM
TLM
TLM