

# IV-V period Introduction

Marko Kosunen

Department of Micro and Nanosciences
Aalto University, School of Electrical Engineering
marko.kosunen@aalto.fi

February 27, 2022

#### **Outline**

On Digital design

Course arrangements

Content of mandatory exercises

Design assingment: Microcontroller implementaion

Conlusion and next steps

# On Digital design

# **Design implementation methods**

- Logic gates are designed using transistors on device (transistor) level.
- Simple logic functions can be designed with truth tables or Karnaugh maps on gate level, although it is beneficial to synthesize the blocs with automated design tools.
- More complex functions/algorithm implementations or entire systems are modeled with Hardware Description Languages which are used together with a set of automated design tools.
- ► The actual implementation is performed by the tools, so ability to control the tools efficiently is mandatory.
- Current effort is to move to the higher abstraction level while designing (behavioral synthesis from VHDL or System C).

```
F=A·B

AB|F

00|1

01|1

10|1

11|0

F<= NOT (AAND B);
```

```
F = \overline{A \cdot B}
\begin{array}{c} A B | F \\ \hline
0 0 1 \\ 0 1 1 \\ 1 0 1 \\ 1 1 | 0 \end{array} \longrightarrow \begin{array}{c} A \\ B \\ \hline
\end{array} \longrightarrow F
F <= NOT (A AND B);
```

$$F = \overline{A \cdot B}$$

$$A \mid B \mid F \\
0 \mid 0 \mid 1$$

$$0 \mid 1 \mid 1$$

$$1 \mid 0 \mid 1$$

$$1 \mid 1 \mid 0$$

$$F <= NOT (A AND B);$$

$$V \mid D \mid C$$

$$A \mid C \mid F \mid C$$

$$A \mid C \mid C$$

$$B \mid C \mid C$$

$$A \mid$$





Designing digital circuits is mapping logical functions to transistor level equivalents, *implemented* on a chosen platform, ASIC or FPGA.

# Layout-the design database for manufacturing



#### **Synthesis Flow**



## **Course arrangements**

12/40

#### Your teachers

- D.Sc. Marko Kosunen marko.kosunen@aalto.fi "lecturer", TUAS-2190
- M.Sc. Andrei Spelman, andrei.spelman@aalto.fi, assistant.
- Most of the support is provided during the exercise sessions on Mondays 10-12 or Thursdays 10-12 in Slack and Zoom.
- On this we do not have classroom teaching. All teaching is executed remotely.

#### **Course objective**

- Objective is to learn to implement digital circuits on higher abstraction level than the transistor
- Modeling of complex functions/algorithms or entire systems with hardware description language (HDL)
- Translation into gate-level netlist and circuit layout with automated synthesis and place-and-route software tools
- Consider the following:
  - Examples of digital circuits, what are they?
  - How the digital circuits are designed and implemented?
  - Examples of design methods?
  - Examples of implementation methods?

#### Course structure

- ► This is a self-learning course: there will be only one lecture besides this one.
- Of course, help will be provided upon request
- Material:
  - ➤ To finish the exercises, you need a book: Peter J Ashenden, "The designer's guide to VHDL", 3rd edition.
  - Slides, tutorials, instructions, etc. available in MyCourses and Aalto version

#### Course structure

- Six mandatory pass/fail graded exercises
  - Topics of the exercises are given in Aalto Version.
  - For every exercise, a "pre-exercise task" is given in order to prepare yourself for the actual exercise time.
- Design assignment: implementation of PIC16F84A microcontroller
  - Learn the complete design flow of a complex digital system (VHDL + synthesis + place-and-route)
  - Final course grade = design assignment grade

#### Course rules and schedule

- Purpose of exercise sessions:
  - Main time to ask for help
  - During the exercise time, you should ask for help for the problematic parts, and finish the exercise.
  - If questions outside exercise sessions should be posted to slack.
  - Excellent time to "return" completed exercises
  - ► Returning outside exercise session is possible, if your testbench can be ran with a single command, and the simulation is flawless.
  - In this case, the exercise is returned as a Gitlab issue, and assigned to assistant for review.
  - Do not send emails, unless the question is related to personal matter or course administration.

#### Course rules and schedule

- Exercises can be time-consuming, so exercise session times are not sufficient you must work also independently between the sessions
- Exercises must be returned in order
  - Not possible to e.g. return exercise 2 before 1

#### How to pass

- Complete all six exercises and get them accepted by the teacher or assistant
- Complete the design assignment and submit it via MyCourses (Code should be submitted to Aalto Version)
- Firm deadline for the project and everything is: 31st May 2018

#### **Content of mandatory exercises**

# Six mandatory exercises

- Exercise will be carried out and completed during a Slack Hack session.
- Assistant/lecturer will be there to help you and accept your exercise to be completed.
- ► Time is limited, therefore, completing the pre-exercise task beforehand is recommended.
- Exercises will be performed through X2Go NX-client and ssh from computer class to computing machine vspace of Department of MNT. Computer accounts required.
- Connection accessible only from Aalto network (e.g., computer classrooms and through VPN)
- Tools to be used: git, gvim or emacs, Mentor Graphics Questasim.

#### On text editors

- The text editor is the most important tool you will ever use.
- I strongly suggest that you choose vim (or emacs) as your text editor.
  - Decent setup for vim will be provided with skeleton git project at https://version.aalto.fi/gitlab/elec-e3540-exec/skeleton
  - Go through "gvimtutor" to learn the basics.

#### **Exercise topics**

**Exercise 1:** Test benches. Book chapters 1.1-1.4, 2.1-2.2, 2.5, 5.1-5.2.

**Things to learn:** Types: bit, bit\_vector, boolean, integer. Signals, process, variables, sensitivity lists of the processes, process as a part of a test bench, wait-statement, self-terminating simulation.

Workload: 2+4=6h

Exercise 2: For loops and file IO, Book chapters 3.4, 5.3,13.1, 16.1

**Things to learn:** Components, File-IO, For loops, Using the previously written test bench.

Workload: 2+4=6h

#### **Exercise topics**

**Exercise 3:** Book chapters 9.1-9.2, 4.1-4.4, 14.1-14.2

Things to learn: Libraries, Vectors and arrays, Records,

for-if-generate, Indexing

Workload: 2+4=6h

**Exercise 4:** Operation decoder for PIC. Book chapters 3.1-3.5,

2.2.5, 5.2, 21.5

Things to learn: State machines, Edge sensitive processes,

Synchronous logic, if and case, assert.

Workload: 2+8=10h

#### **Exercise topics**

Exercise 5: ALU Design. Book chapters 6.1-6.6

**Things to learn:** Procedures and functions, structure of ALU of the PIC16F84A microcontroller.

Workload: 2+8=10h

Exercise 6: Memory design. Book chapters 21 particularly 21.6.
 Things to earn: Memory implementations, Design for synthesis
 Workload: (about) 2+8=10h

Requirement for passing the course is participation and accepted results of the exercises. Pass/Fail grading.

# Design assingment: Microcontroller implementaion

# **Design assingment: Microcontroller implementaion**

- ▶ Perform the whole digital IC implementation flow of part of the PIC16F84A microcontroller VHDL modeling + synthesis
- Starting year 2021, Place and route will be separated to course ow it's own.
- ► PIC chosen because of its simple structure, and because assembler compiler is available
- Nevertheless, learning its functionality is not very straightforward, so start studying immediately! datasheet available in MyCourses

# **Design Assignment: Microcontroller implementation** with VHDL

- Course will be graded based on study diary and documentation of the design
- the study diary should document and describe the phases of the design flow, difficulties encountered and how they were solved
- Things to be graded:
  - Quality of the code, clear structure, commented, easy to read.
  - Gained understanding of the subject. This should be visible in your study diary.
  - ▶ 100% functionality is not required to pass, but you should show that you have tried your best and learned something.

# **Design Assignment: Microcontroller implementation** with VHDL

- On this course you will learn VHDL and the whole digital IC implementation flow while designing a PIC16F84A Microcontroller.
- You learn the required skills during the first six exercises, contents of which also supports the PIC design task.
- Learning the functionality of PIC is hard, so start studying the PIC-datasheet immediately.



- PIC16F84A has been chosen because
  - Simple structure
  - Small instruction set
  - Simple ALU
  - Assembler compiler available

- Design process of the microcontroller should be documented in a study diary describing the design process, methods, difficulties and sources of information.
- ► The designed microcontroller will be also synthesized to logic.
- Things to be graded
  - Quality of the code, clear structure, commented, easy to read.
  - Understanding of the subject gained. This should be visible in your study diary.
  - ▶ 100% functionality is not a required, but you should show that you have tried your best and learned something.
  - The grade of the PIC design assignment is the grade of the course.

#### part to be implemented



OSC1/CLKIN



## **Advice: Stages of command execution**

- ▶ **IFETCH**: Fetch instruction from program memory and decode it.
- Mread: Read operand from memory, if required.
- Execute: Perform operation.
- Mwrite: Increment PC, write data to memory or register.

```
IFtch Mread Exec Mwrite
```

- Every instruction can be divided in "stages". Maximum number is four, since PIC datasheet describes execution in max four clock cycles.
- Only Mwrite is strictly synchronous operation, but in order to make things easier, advice is to implement the steps with a synchronous state machine.
- Every command does not require every step.

# **Conlusion and next steps**

In the beginning of the course I had never even seen VHDL code before and we were warned that this course would take alot of time. This did not turn out to be an overstatement. Only the major developments and complications were reported in this diary, since if I would have given full disclosure this diary would probably be double or triple the current length. Although, this course was one of the most exhausting courses I have been to, I did learn alot of things.

This project has been quite a challenge since, every thing was done for the first time. At the start of this course, I completely had zero idea on VHDL, and digital flow. At the end, I am very confident to try out challenging tasks and set my career at digital design field. Overall, although quite hectic workload, I am completely satisfied with what I have achieved.

Lets also summarize some other aspects learned during the process :

- ▶ I have advanced in Vim editor environment to some extent . It made re-writing and debugging my code very easy. I insist on every designer to know to use any editor very well.
- ► VHDL codes are not like the programming. The way to think is to think hardware. Same structure can be implemented using different commands, but it will effect how RTL is synthesized. Its upto designer to choose command to best fit performance.
- ▶ While writing HDL codes, insted of giving fancy complicated code, its more healthy habit to follow basic synthesizable template.

- Digital design flow is very automatic process. The software will do the routing and generate reports. So its necessary to know how to use the software so that correct results are obtained.
- ▶ Digital design is very lengthy type of repetitive process, to prevent loss of enormous time and frustation, TCL scripting knowledge will prove to be very handy
- Another point would I emphasize while on starting to write HDL is to proper test bench. Once made so that it will fit the purpose of whole project, it shall save lot of time.
- Proper use of case statement and If else statement is very tricky in VHDL. Deeper understanding in use of these statements can lead to more optimized design

#### How to start?

- Establish X2Go connection to vspace.ecdl.hut.fi
- Add your vspace ssh key to Aalto version https://version.aalto.fi/gitlab/profile/keys Instructions are also provided there.
- Go to https://version.aalto.fi/gitlab/elec-e3540-exec/skeleton, read the Readme.
- Clone it to your home directory with git clone gitversion.aalto.fi:elec-e3540-exec/skeleton.git and do the setups as instructed in the readme.
- ▶ Go to https://version.aalto.fi/gitlab/elec-e3540-exec/exercise\_template, and read the Readme.