The necessities in SOC Design

Overview

edit
  • SoC in the wikipedia pages (pdf)

Fabrication of VLSI Circuits

edit
  • Fabrication in the wikipedia pages (pdf)
  • Wafer (pdf)
  • Mask (pdf)
  • Package (pdf)
  • Test (pdf)
  • CMOS Fabrication (pdf)

Device Level Design

edit
  • 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
  • Device R, C (pdf)
  • Device Size (pdf)
  • Device Delay (pdf)
  • Device Power (pdf)

Device Level Design Tools

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


Transistor Level Design

edit
  • Combinational Designs (pdf)
  • Sequential Designs (pdf)
  • Subsystem
    • Arithmetic Subsystem (pdf)
    • Memory Array Subsystem (pdf)
    • Logic Array Subsystem

Performance Metric

edit
  • Gate Area (pdf)
  • Gate Delay (pdf)
  • Gate Power (pdf)

Design Issues

edit
  • Clock
  • PLL & DLL
  • I/O

Transistor Level Design Tools

edit
  • Spice


Gate Level Design

edit
  • Combinational Designs (pdf)
  • Sequential Designs (pdf)
  • Subsystem
    • Arithmetic Subsystem (pdf)
    • Memory Array Subsystem (pdf)
    • Logic Array Subsystem

Performance Metric

edit
  • Gate Count
  • Path Delay (pdf)
  • Switch Activity (pdf)

Design Issues

edit
  • Static Timing Analysis
  • Scan and Boundary Scan Cells
  • Formal Verification

Gate Level Design Tools

edit
  • Verilog
  • VHDL
  • Static Timing Analysis
  • Formal Verification


RTL Level Design

edit
  • Register (pdf)
  • FSM (pdf)
  • One Hot Controller
  • Pipeline (pdf)

Performance Metric

edit
  • Estimation of
    • Gate Count
    • Critical Path
    • Power
  • Latency
  • Throughput

Design Issues

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

RTL Design Tools

edit
  • Verilog
  • VHDL
  • Logic Synthesis


Architecture Level Design

edit

Background: Tiny CPU Examples

edit


  • 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
  • Memory Hierarchy
  • Storage and I/O
  • Instruction Level Parallelism
  • Data Level Parallelism
  • Thread Level Parallelism


Design Tools

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


System Level Design

edit
  • IP : OCP-IP, OpenCore


Typical SOC's

edit
  • Embedded System
  • MPSOC
  • NoC


Design Issues

edit
  • 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
  • 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

HW/SW Design Examples : Traffic Controller Design

edit
  • 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
  • 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
  • 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


Test

edit
  • 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
  • Assertion Based Verification
  • Transaction Level Models
  • Formal Property Verification



2016 Spring Class

edit
  • 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


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