















## Real power saving implies specialized hardware • H.264 video decoder implementations in software vs. hardware • the power/energy savings could be 100 to 1000 fold but our mind set is that hardware design is: • Difficult, risky • Increases time-to-market • Inflexible, brittle, error prone, ... • Difficult to deal with changing standards, ... New design flows and tools can change this mind set







Hardware design today is like programming was in the fifties, i.e., before the invention of high-level languages







# Bluespec A new way of expressing behavior A formal method of composing modules with parallel interfaces (ports) Compiler manages muxing of ports and associated control Powerful and zero-cost parameterization of modules Encapsulation of C and Verilog codes using Bluespec wrappers Helps Transaction Level modeling → Smaller, simpler, clearer, more correct code → not just simulation, synthesis as well



























# FPGAs: a new opportunity \* "Big" FPGAs have become widely available • A multicore can be emulated on one FPGA • but the programming model is RTL and not too many people design hardware \* Enable the use of FPGAs via Bluespec



### 6.375 Complex Digital Systems: past projects

- Optical flow in Harvard Robo Bee project
- Spinal Codes for Wireless Communication
- Beat tracker
- H.265 Motion Estimation for video compression
  - A chip was fabricated later
- Hard Viterbi Decoder
- Video motion magnification
- RSA
- Programmable packet filter for 1Gbps stream

6 weeks of individual lab work+ 6-week group projects

Fun: Design systems that you thought you would never design in a course

February 3, 2016

http://csg.csail.mit.edu/6.375

01-3

### Resources – beyond TA, mentors and classmates

- Lecture slides (with animation)
  - Make sure you sure you understand the lectures before exploring other materials
  - http://csg.csail.mit.edu/6.375/handouts.html
- Computer Architecture: A Constructive Approach, Arvind, Rishiyur S. Nikhil, Joel S. Emer, and Murali Vijayaraghavan (2012)
  - Uses Executable and Synthesizable processor Specifications
- BSV By Example, Rishiyur S. Nikhil and Kathy R. Czeck (2010)
- Bluespec System Verilog Reference manual
  - You will need to refer to this often
- Bluespec System Verilog Users guide
  - How to use all the tools for developing BSV programs

February 3, 2016

http://csg.csail.mit.edu/6.375

01-34