440 likes | 1.07k Views
ALTERA TOOL 을 활용한 디지털시스템 설계. 이 상 훈 경남대학교 전기전자공학부. 강좌목표. 디지털 회로의 설계기법을 배우고 ALTERA 사의 MAX PLUS II TOOL 을 활용하여 이들 회로들을 회로도 입력 방법과 VHDL Coding 방법으로 직접 설계하여 시뮬레이션을 통한 설계한 회로의 검증작업을 통해 FPGA 및 ASIC 칩에 대한 설계능력을 얻고자 한다. 교재 및 참고문헌.
E N D
ALTERA TOOL을 활용한 디지털시스템 설계 이 상 훈 경남대학교 전기전자공학부
강좌목표 • 디지털 회로의 설계기법을 배우고 ALTERA사의 MAX PLUS II TOOL을 활용하여 이들 회로들을 회로도 입력 방법과 VHDL Coding 방법으로 직접 설계하여 시뮬레이션을 통한 설계한 회로의 검증작업을 통해 FPGA 및 ASIC 칩에 대한 설계능력을 얻고자 한다.
교재 및 참고문헌 • Dueck, “Digital Design with CPLD Applications and VHDL”, Delmar, 2001 • “Altera MAX+PLUS II”, Free download, www.altera.com • M. Morris Mano and Charles R. Kime, “Logic and Computer Design Fundamentals”, Prentice Hall, 2000
목차 1. Introduction 2. Altera MAX+PLUS II Tool 3. Combinational Logic Design 4. Digital Arithmetic and Arithmetic Circuits 5. Introduction to Sequential Logic 6. Introduction to PLA 7. Counter Design 8. State Machine Design
목차(cont’d) 9. Logic Gate Interface 10. Analog and Digital Interface Circuits 11. Memory System
1장 개요 • PLDs(Programmable Logic Devices) • ROM(Read-Only Memory) • PLA(Programmable Logic Array) • PAL(Programmable Array Logic) and GAL(Generic Array Logic) • CPLD(Complex Programmable Logic Device) • FPGA(Field-Programmable Gate Array) • ASIC(Application Specific Integrated Circuit) • Summary
PLDs(Programmable Logic Devices) • PLDs – ROM(Read-Only Memory), PLA(Programmable Logic Array), • PAL(Programmable Array Logic), GAL(Generic Array Logic), • CPLD(Complex Programmable Logic Device), FPGA(Field- • Programmable Gate Array) • Programming Technology • Permanent Type(Nonvolatile) ; • Fuse(normal on) - ‘CLOSE(intact)’ ‘OPEN(blown)’ • Mask programming - Mask ROM • Antifuse(normal off) - just the opposite of a FUSE • Nonpermanent Type ; • SRAM bit driving + n-MOS Tr. (Volatile) • Building Look-up Table using SRAM (Volatile) - Logic inputs(SRAM addr.), Logic outputs(stored SRAM table data) • MOS Tr. Switching Control using Floating Gate (Nonvolatile) - EPROM, EEPROM
ROM(Read-Only Memory) • 비휘발성 • 32 x 8 ROM 내부 논리도 2k x n크기의 ROM - k-to-2k의 Decoder - n 개의 OR Gate
ROM(Read-Only Memory) • 조합논리의 구현 • k개의 입력을 갖는 디코더 : 2k개의 minterm 발생 • ROM : 디코더 + OR 게이트 A7(I4 I3 I2 I1 I0 )= m(0, 2,3, …,29)
ROM(Read-Only Memory) • ROM Programming according to prior table
ROM(Read-Only Memory) • 조합논리의 구현 응용 • 복잡한 조합논리 구현 : 보통의 입력과 대량의 출력 • 코드변환, 산술연산 • 설계 <-- 진리표 (논리도 불필요) • 예 : 3비트 2진수의 제곱을 구하는 회로
프로그램 표 PLA(Programmable Logic Array) • PROM과 유사 - 차이점 : Programmable AND Array • 3입력, 4곱항, 2출력의 PLA 출력을 반전 X 1 = X’ F1 = AB’ + AC + A’BC’ F2 = (AC + BC)’
PLA(Programmable Logic Array) • PLA의 크기 - 입력의 개수, 곱의 항의 개수, 출력의 개수 - 예 : 16 입력, 48 곱의 항, 8 출력 • PLA를 이용한 설계 <--프로그램 표 • 마스크 프로그램과 현장 프로그램(FPLA)이 가능 • 설계 시 유의 사항 : - 곱의 항 개수 최소화 - 불필요한 변수 제거
PLA(Programmable Logic Array) • 예제 : 다음의 부울 함수 설계 • F1(A, B, C) = m(0, 1, 2, 4) • F2(A, B, C) = m(0, 5, 6, 7) • 간략화 • F1 = (AB + AC + BC)’ • F2 = AB + AC + A’B’C’
PAL*(Programmable Array Logic) 피드백 회로 : 순차회로 구성에 이용 • 고정된 OR + 프로그램 가능한 AND 배열로 된 PLD • 프로그램이 쉽지만, 유연하지는 못함 • OTP(One Time Programmable) *PAL(Advaced Micro Devices Inc.)
PAL(Programmable Array Logic) • 예 : W(A, B, C, D) = m(2, 12, 13) • X(A, B, C, D) = m(7, 8, 9, 10, 11, 12, 13, 14, 15) • Y(A, B, C, D) = m(0, 2, 3, 4, 5, 6, 7, 8, 10, 11, 15) • Z(A, B, C, D) = m(1, 2, 8, 12, 13) 피드백
PAL(Programmable Array Logic) • 내부 연결도 피드백
GAL*(Generic Array Logic) or Universal PAL** • Most PAL/PLA Devices are OTP while a GAL or EPLD can be erased and reprogrammed(called a universal PAL). • Most GALs can use I/O pins for either an Input or an Output(not fixed as a PAL). • Outputs can be configured as Combinational or Registered and whose programming matrix is based on Electrically Erasable Cells (not Fuses). • The main section of the GAL Macrocell is the D-FF and 4 to 1 Multiplexers that determine the Output Enable(OE) and the Feedback. *GAL(Lattice Semiconductor), **Universal PAL(Vantis Co.)
GAL or Universal PAL GAL Device Numbering • GAL Devices are numbered as 22V10 with the 22 being the total I/O Pins available and the 10 is the maximum number of Outputs or macrocells available. • A PALCE22V10 could have 10 Outputs (MC) and 22-10= 12 Inputs OR it could have 1 Output and 22-1 = 21 Inputs.
GAL or Universal PAL • Macrocell for a PALCE16V8 Universal PAL
GAL or Universal PAL • GAL22V10 OLMC(Output Logic Macrocell)
CPLD(Complex Programmable Logic Device) and FPGA • PLD의 장점 : 복잡한 논리회로를 하나의 IC로 구현 가능 • 보다 큰 규모의 복잡한 회로 : VLSI 이용 • VLSI 설계방식 - 완전주문 맞춤(Full Custom Design) : 고집적, 고속, 고비용 - 표준 셀 설계(Standard Cell Design) - 게이트 배열(Gate Array) : SOG, CMOS, BiCMOS, ECL, GaAs • CPLD와 FPGA - 1,000에서 2,000,000 게이트의 Gate Array가 가능 - 프로그램 가능한 조합논리 - 사전에 제작된 FF내장 - 프로그램 가능한 연결 부분(입출력 등)
CPLD and FPGA • Altera MAX 7000CPLD • EEPROM의 부유 게이트 기술 16 Logic Array block - 16 macrocell (1FF + 기본 조합회로) 3 상태 버퍼
CPLD and FPGA • Altera MAX 7000CPLD Block Diagram
CPLD and FPGA • Altera MAX 7000CPLD Macrocell
CPLD and FPGA • Altera FLEX10K Block Diagram - SRAM based technology(volatile), 66MHz, up to 200,000 gates, 0.22u 5-metal layers - APEX series : 125MHz, up to 2,000,000 gates
CPLD and FPGA • Altera FLEX10K Logic Element
CPLD and FPGA 논리모듈 I/O 모듈 • Actel ACT 3 FPGA • Gate Array와 유사한 구조 • Antifuse 기술 : 영구적이면서 비휘발성 프로그래밍 • OTP • 크기가 작고 속도가 빠름
CPLD and FPGA MUX에 의한 조합논리 구현 - 최대 8변수 함수 • Actel 의 논리모듈
CPLD and FPGA • Xilinx XC4000 - SRAM 기술 이용 - 프로그램 로드 기능(<-- PROM) - 프로그램 모드, 동작모드
CPLD and FPGA • SRAM 비트를 이용한 논리구현의 세가지 기법 If (A,B,C)=(0,0,0) 1st SRAM cell의 내용이 선택 출력됨l 하나의 SRAM cell
CPLD and FPGA • Xilinx의 연결 방식 - 선로 세그먼트(수평, 수직) - 장거리 선로(long line) • Xilinx의 switch Matrix
CPLD and FPGA • Xilinx 논리회로 : CLB와 IOB 내에 존재 • CLB(Configurable Logic Block) 개략도
CPLD and FPGA • Xilinx IOB(Input/Output Block) 구조
CPLD and FPGA • FPGA Design Flow Functional Simulation Post-Layout Simulation
ASIC ? 특정 사용자를 위하여 특정 용도로 설계, 제작되는 고객 사양의 집적 회로 (IC) 로 시스템이나 설계전문업체가 개발하여 반도체 제조업체가 칩으로 생산하여 특정제품에 사용됨. 광의의 정의로써 비메모리 분야의 모든 IC를 ASIC라 통칭하기도 함. 주문 제작된 IC가 여러 사용자에 의해 사용되는 경우에는 ASSP (Application Specific Standard Product ) 로 구분. ASIC(Application Specific Integrated Circuit)
ASIC ASIC(광의) ASCP(협의) ASSP Full Programmable Semi- 통신용 AV용 Custom IC custom IC IC PLD FPGA Standard cell Gate array ASCP(Application Specific Custom Product) ASSP(Application Specific Standard Product)
ASIC(Application Specific Integrated Circuit) • ASIC Design Flow Functional Simulation Post-Layout Simulation
ASIC • ASIC 현황 • 우리 나라의 반도체 메모리 부분은 총 수출의 6.9% • 세계 반도체 시장의 비메모리 산업부문은 79% 나라 미국 일본 한국(수입의존도) 비메모리생산비중 91% 78% 12%(90%) • 정보통신기기의 ASIC의대부분 수입(국산화율) • 휴대폰 53% • 디지털 TV 30% * 자료출처 : ADA(ASIC Design-company Association)
EDA(Electronics Design Automation) Tool Vendors Tools Altera MAX PLUS II Mentor Graphics Leonardo, IC Graph OrCAD OrCAD Capture QuickLogic Quickworks Summit Design Visual HDL, VHDL Synopsys FPGA Express Viewlogic Systems ViewPLD Xilinx Foundation series , Alliance Series Cadence SPW, Verilog-XL, Composer, Gate Ensemble Avanti Hspice, Polaris-COM, Apollo, Compass HP HPADS(MMIC Design) ETRI LODECAP Seodu Logic MyCAD series
SUMMARY • PLDs(Programmable Logic Devices) - ROM, PLA, PAL, GAL, CPLD, FPGA • ASIC • EDA Tool