EEL 410038 – Sistemas Digitais e Dispositivos Lógicos Reconfiguráveis


Trimestre 2013/2
Curso: Programa de Pós-Graduação em Engenharia Elétrica
Código da disciplina: EEL 410038
Número de créditos: 3
Professores: Eduardo Augusto Bezerra e Djones Vinicius Lettnin


Horário das aulas

  • Seg 13:00-16:20

Ementa

Conceitos introdutórios de sistemas digitais; Circuitos combinacionais e sequenciais; Projeto de sistemas digitais no nível de transferência entre registradores (RT); Modelo clássico de CPU com bloco de dados e bloco de controle; Dispositivos lógicos reconfiguráveis; Prototipação de sistemas digitais.


Metodologia

  • O conteúdo programático será desenvolvido por meio de aulas expositivas com auxílio de recursos multimídia.
  • Aulas teóricas, expositivas, com slides preparados a partir do livro texto da disciplina.
  • Exercícios teóricos a serem resolvidos em aula e extra-classe pelos alunos.
  • Aulas práticas, em laboratório, onde os alunos seguirão tutoriais fornecidos pelo professor com instruções para utilização de ferramentas e placas de desenvolvimento.
  • Leitura e discussão de artigos científicos clássicos e no estado da arte.
  • Apresentação de seminários preparados pelos alunos.
  • O material utilizado nas aulas práticas e teóricas será disponibilizado na página da disciplina e na plataforma Moodle.
  • Ao longo do curso, far-se-á uso de HDLs para descrever os circuitos e sistemas digitais apresentados.

Programa

  1. Introdução
    • Circuitos combinacionais
    • Circuitos sequenciais
    • Lógica reconfigurável
    • Fluxo de projeto de sistemas digitais com ferramentas de EDA
  2. Sistemas digitais e linguagens de descrição de hardware
    • Álgebra de Boole e funções booleanas
    • Codificadores, decodificadores, multiplexadores, demultiplexadores
    • Circuitos aritméticos, somadores, comparadores, contadores, deslocadores, multiplicadores
    • Unidade Lógico e Aritmética (ULA): síntese e simulação com uma linguagem de descrição de hardware
  3. Circuitos sequenciais e controladores
    • Latches e flip-flops
    • Finite State Machines (FSMs)
    • Projeto de controladores utilizando FSMs
    • Síntese de FSMs com uma linguagem de descrição de hardware
  4. Estudo de caso
    • Projeto do bloco de dados (data path) e do bloco de controle de uma unidade de processamento
    • Descrição no nível RTL (Register Transfer Level) de uma unidade de processamento utilizando uma linguagem de descrição de hardware
    • Simulação, síntese lógica, síntese física e prototipação em hardware da unidade de processamento

Avaliação

  • A média geral do trimestre (MT) é obtida a partir da média geométrica: MT = sqrt( T x (S + P)/2 ), onde T é a nota do trabalho teórico/prático, S é a nota da preparação/apresentação dos seminários, e P é a nota de uma prova.
  • Condições para a aprovação: freqüência > 75% e MS >= 6,0

Bibliografia

  • Frank Vahid, “Sistemas Digitais: projeto, otimização e HDLs”, Bookman, 2008.
  • Frank Vahid, “Digital Design”, 1st ed., Wiley, 2007.
  • Randy Katz, Gaetano Borrielo, “Contemporary Logic Design””, 2nd ed., Prentice Hall, 2005.
  • John P. Uyemura, “Sistemas digitais: Uma abordagem integrada”, Thomson, 2002.
  • John F. Wakerly, “Digital design: Principles and practices”, Prentice Hall, 2005.
  • Volnei A. Pedroni, “Circuit Design with VHDL”, The MIT Press, 2004.
  • Frank Vahid, “VHDL for Digital Design”, 1st ed., Wiley, 2007.
  • Pong P. Chu, “FPGA Prototyping by VHDL Examples: Xilinx Spartan-3 Version”, Wiley-Interscience, 2008.
  • David A. Patterson, John L. Hennessy, “Computer Organization and Design: The Hardware/Software Interface”, Morgan Kaufmann, 4th edition, 2008.
  • Advancing the SystemC Analog/Mixed-Signal (AMS) Extensions – Introducing Dynamic Timed Data Flow“; Martin Barnasconi, Karsten Einwich, Christoph Grimm, Torsten Maehne, Alain Vachoux; September 2011.
  • Electronic System Level Design: An Open-Source Approach“; Sandro Rigo, Rodolfo Azevedo, Luiz Santos.
  • “SystemC Synthesizable Subset”
  • IP-XACT
  • Open Verification Library (OVL)

Ferramentas e materiais


Trabalho prático


Organização das aulas de laboratório

Aula Data – Hora Conteúdo
1 17/06 Apresentação da disciplina. Introdução aos dispositivos lógicos programáveis. Material de apoio:[SLIDES LAB 1] – Fluxo Quartus II Esquemático

[SLIDES LAB 2] – Introdução a VHDL

 

– Introdução FPGAs (slides)

Capítulo 1, Tutorial esquemático detalhado

 

– Capítulo 2, Tutorial VHDL detalhado

 

Manual DE2 – pinagem do FPGA

– Introdução DE2Manual DE2
– Pinos.csv

2 24/06 Sistemas digitais e síntese em VHDL para FPGAsSlides da Altera (PDF)
Enunciados dos exercícios (DOC)
Templates Quartus II (VHDL)
Soluções (VHDL)
3 01/07 Sistemas digitais e síntese em VHDL para FPGAs
4 08/07 Sistemas digitais e síntese em VHDL para FPGAs
5 15/07 Sistemas digitais e síntese em VHDL para FPGAs- Exercícios na DE2: Multiplicador dos slides da Altera; Controlador da vending machine; Photoshop em hardware.
6 22/07 Revisão de C++ e Introdução ao SystemC
7 29/07 Descrição do funcionamento de uma arquitetura multiciclo.Descrição e início do desenvolvimento do trabalho final.

 

Material para a aula: Slides Patterson e Hennessy (“Chapter 1 – slide 8“, “Chapter 2 – slides 1-36; 48-80“; “Chapter 4 – slides 1-29“); Página Prof. Ney Calazans (ver BD_vhdl_exercicios.pdf e o_cleo.pdf); e Material Cleopatra.

8 05/08 Arquitetura esperada para o circuito do trabalho final (memória, I/O, BD, BC).Descrição de memória em VHDL (RAM e ROM). Simulador da Cleopatra. Exercícios 1 e 2 pg. 15.
9 12/08 Introdução ao SystemC
10 19/08 System C – Transaction-level modeling (TLM)
11 26/08 Apresentações de seminários:1:00-1:15 – Artigo 1, Tiago Franzen
1:15-1:30 – Artigo 1, Igor Cruz
1:30-1:45 – Artigo 1, Felipe Sabino
1:45-2:00 – Artigo 1, Douglas Melo
2:00-2:15 – Artigo 1, Julian Lopez
2:15-2:30 – Artigo 1, Adriano Pires
2:30-2:45 – Artigo 1, Luis Alves
2:45-3:00 – Artigo 1, Marcelo Zapella
3:00-3:15 – Artigo 1, Luiz Alberto Melek
3:15-3:30 – Intervalo
3:30-3:45 – Artigo 2, Tiago Franzen
3:45-4:00 – Artigo 2, Igor Cruz
4:00-4:15 – Artigo 2, Felipe Sabino
4:15-4:30 – Artigo 2, Douglas Melo
4:30-4:45 – Artigo 2, Julian Lopez
4:45-5:00 – Artigo 2, Adriano Pires
5:00-5:15 – Artigo 2, Luis Alves
5:15-5:30 – Artigo 2, Marcelo Zapella
5:30-5:45 – Artigo 2, Luiz Alberto Melek
12 02/09 [SBCCI’13] Desenvolvimento do trabalho final
13 09/09 Desenvolvimento do trabalho final
14 10/09 Entrega do trabalho final (Moodle)
15 11/09 Apresentação do trabalho final (agendar data/hora com os professores)

Artigos selecionados para apresentação de seminários em 2013/2:

  • Tiago Franzen
  1. FPGA architectural research: a survey; Brown, S.; IEEE Design & Test of Computers; Vol 13; issue 4; pp. 9; 1996.
  2. FPGA supercomputing platforms: A survey; Awad, M.; FPL 2009; pp. 564; Aug. 2009.
  • Igor Cruz
  1. Architecture of field-programmable gate arrays; Rose, J. El Gamal, A. Sangiovanni-Vincentelli, A.; Proceedings of the IEEE; Vol. 81; Issue 7; Jul. 1993.
  2.  Reconfigurable computing architecture survey and introduction; Azarian, A. Ahmadi, M.; ICCSIT 2009; pp. 269; 8-11 Aug. 2009.
  • Felipe Sabino
  1. Survey of New Trends in Industry for Programmable Hardware: FPGAs, MPPAs, MPSoCs, Structured ASICs, eFPGAs and New Wave of Innovation in FPGAs“; S.Z. Ahmed et. al.; FPL 2010; Aug. 31 2010-Sept 2 2010.
  2.  A guide to migrating from microprocessor to FPGA: coping with the support tool limitations; E.A.Bezerra and M.P.Gough; Microprocessors and Microsystems; Vol 23; pp 561-572; March 2000.
  • Douglas Melo
  1. Area-Efficient FPGA Logic Elements: Architecture and Synthesis
  2. Creation of Partial FPGA Configurations at Run-Time; Silva, M.L. Ferreira, J.C.; DSD 2010; pp. 80; Sept. 2010.
  • Julian Lopez
  1. Low Power State Machine Design on FPGAs
  2. A CubeSat Design to Validate the Virtex-5 FPGA for Spaceborne Image Processing
  • Adriano Pires
  1. Design of high speed data acquisition system based on FPGA and DSP; Zhang Baofeng Wang Ya Zhu Juncha ; ICAie 2010; pp. 132; Oct. 2010.
  2. A Real/Complex Logarithmic Number System ALU; Arnold, M.G. Collange, S.; IEEE Transactions on Computers; pp. 202; Vol. 60 Issue 2; Feb. 2011.
  • Luis Alves
  1. Hardware Design in Independent Experiment Platform on FPGA.
  2. Design and Implementation of HDLC Protocol and Manchester Encoding Based on FPGA in Train Communication Network.
  • Marcelo Zapella
  1. A SystemC-Based Transaction Level Modeling of On-Chip-Bus
  2. Formal Techniques for SystemC Verification
  • Luiz Alberto Melek
  1. SystemC-AMS high-level modeling of linear analog blocks with power consumption information
  2. Applying Model-Checking to Post-Silicon-Verification: Bridging the Specification-Realisation Gap

Conjunto de artigos: