Difference between revisions of "Main Page"
|  (→Lab Specific Information) |  (update participance link) | ||
| (31 intermediate revisions by 4 users not shown) | |||
| Line 4: | Line 4: | ||
| Welcome to the wiki for the SoC Design course! We started this series of labs/projects in 2014 and we are upgrading and fixing problems every year to make it better. | Welcome to the wiki for the SoC Design course! We started this series of labs/projects in 2014 and we are upgrading and fixing problems every year to make it better. | ||
| − | Slides for the introductory presentation are available [https://docs.google.com/presentation/d/ | + | Slides for the introductory presentation are available [https://docs.google.com/presentation/d/1n4VfibjQcfBR-hYUb8m64C-zhhVq0kOHvIEwQkTPN8I/edit?usp=sharing here] | 
| ==Learning Objectives== | ==Learning Objectives== | ||
| − | After the completion of the labs, you  | + | After the completion of the labs, you will be able to: | 
| {| | {| | ||
| Line 35: | Line 35: | ||
| * Component reuse and system improvement   | * Component reuse and system improvement   | ||
| * Functional test and analysis | * Functional test and analysis | ||
| − | *  | + | * Work in a team | 
| |} | |} | ||
| Line 49: | Line 49: | ||
| '''Important dates''' | '''Important dates''' | ||
| − | * <span style="color:#FF0000">'''Week 2  | + | * <span style="color:#FF0000">'''Week 2''':</span> Lab 1 | 
| − | * <span style="color:#FF0000">'''Week 5''':</span> Lab 2 | + | * <span style="color:#FF0000">'''Week 3 ... week 5''':</span> Lab 2 | 
| * <span style="color:#FF0000">'''Week 6 ... week 9''':</span> Lab 3 | * <span style="color:#FF0000">'''Week 6 ... week 9''':</span> Lab 3 | ||
| * <span style="color:#FF0000">'''Week 10, week 11''':</span> Lab 4 | * <span style="color:#FF0000">'''Week 10, week 11''':</span> Lab 4 | ||
| Line 64: | Line 64: | ||
| '''Lab Grading  Policy''' | '''Lab Grading  Policy''' | ||
| * Tutorials (Pass/Fail - prerequisite for project) | * Tutorials (Pass/Fail - prerequisite for project) | ||
| − | * Project (50% of grade) | + | * Project (50% of the grade) | 
| − | * Examination (50% of grade) | + | * Examination (50% of the grade) | 
| '''In order to pass the course, you have to get a positive result in both the project and the exam.''' | '''In order to pass the course, you have to get a positive result in both the project and the exam.''' | ||
| Line 81: | Line 81: | ||
| ==Rules and Regulations== | ==Rules and Regulations== | ||
| + | <big><big>For your programs, <span style="color:green"> '''please follow the coding style:''' [https://blue.pri.ee/ttu/resources/coding-style/ [LINK]] </span></big></big> | ||
| + | |||
| <span style="color:red"> '''Please read the following page before you start the course:''' </span> | <span style="color:red"> '''Please read the following page before you start the course:''' </span> | ||
| ===Timing and Plans=== | ===Timing and Plans=== | ||
| − | '''Please note that the project  | + | '''Please note that the project's (strong) deadline is on the last lab session, no extension will be made!''' | 
| ===General Rules=== | ===General Rules=== | ||
| * <span style="color:red">'''Unplugging any cables from the lab computers is NOT ALLOWED!'''</span> If you use your own computer, please use Wi-Fi. | * <span style="color:red">'''Unplugging any cables from the lab computers is NOT ALLOWED!'''</span> If you use your own computer, please use Wi-Fi. | ||
| − | * It is '''OK''' to discuss your code with  | + | * It is '''OK''' to discuss your code with colleagues during the labs. | 
| − | * Copying  | + | * Copying a colleague's code '''is not''' OK! You need to write your own code. | 
| − | * You '''must understand''' the code you write! We will check  | + | * You '''must understand''' the code you write! We will check that you do! | 
| + | |||
| + | ===When writing Code=== | ||
| + | * '''The first thing your code MUST do is print out your name, ''otherwise you are not allowed defend the lab!''''' Kernel modules should print your name when they are inserted. | ||
| + | (This requirement only applies for code that you have modified or written yourself) | ||
| − | + | Have in mind that you or someone else might want to reuse your code! | |
| − | + | * '''Use comments in your code.''' Even you, as the author of the code, may not understand it in the future. | |
| − | + | * '''Write a proper doc-string for the functions.''' It makes your life and of others much easier. | |
| − | + | * '''Use meaningful variable names.''' A variable named "counterMaxValue" is much easier to understand than one for the same purpose named "cMNum", for example. | |
| − | * '''Use comments in your code.''' Even you, as the  | + | |
| − | * '''Write a proper doc-string for the functions.''' It makes  | + | |
| − | * '''Use meaningful variable names.'''  | + | |
| ===In Case of Problems=== | ===In Case of Problems=== | ||
| Line 115: | Line 118: | ||
| {| | {| | ||
| ! rowspan="2" | [[File:statistics-512.png|70px|left]] | ! rowspan="2" | [[File:statistics-512.png|70px|left]] | ||
| − | ! style="text-align:left;" | You can view you current lab results and statistics [https://docs.google.com/spreadsheets/d/ | + | ! style="text-align:left;" | You can view you current lab results and statistics [https://docs.google.com/spreadsheets/d/1SNz374ugnoOz7gOVyeVOstkL7urm5Ag0qIDqhYE2UK8/edit?usp=sharing'''here'''] | 
| |} | |} | ||
| Line 123: | Line 126: | ||
| {| | {| | ||
| ! rowspan="2" | [[File:redphone.png|70px|left]] | ! rowspan="2" | [[File:redphone.png|70px|left]] | ||
| − | |||
| |- | |- | ||
| | style="text-align:left;" | '''• [http://ati.ttu.ee/socdesign/index.php/User:madker Madis Kerner]''' | | style="text-align:left;" | '''• [http://ati.ttu.ee/socdesign/index.php/User:madker Madis Kerner]''' | ||
| Line 131: | Line 133: | ||
| ==Lab Tutorials== | ==Lab Tutorials== | ||
| Here you can find lab manuals for the tutorials: | Here you can find lab manuals for the tutorials: | ||
| − | *[[Lab 1|Lab 1: Building  | + | *[[Lab 1|Lab 1: Building Custom SoC on ZedBoard]] | 
| − | *[[Lab 2|Lab 2: Kernel Driver]]  | + | *[[Lab 2|Lab 2: Kernel Driver]] | 
| − | *[[Lab 3|Lab 3: Custom IP creation]]  | + | *[[Lab 3|Lab 3: Custom IP creation]]   | 
| − | *[[Lab 4|Lab 4: Setup 1 board system for the lab]]  | + | *[[Lab 4|Lab 4: Setup 1 board system for the lab]] | 
| ==Additional Material== | ==Additional Material== | ||
| Line 141: | Line 143: | ||
| ===Lab Specific Information=== | ===Lab Specific Information=== | ||
| − | *[[Lab1  | + | *[[Lab1 Additional Material]] | 
| *[[Lab2 Additional Material]] | *[[Lab2 Additional Material]] | ||
| − | *[[Lab3 additional material]]  | + | *[[Lab3 additional material]] | 
| − | *[[Lab4 additional material]] <span style="color:red"> TBU </span> | + | *[[Lab4 additional material]] <!--<span style="color:red"> TBU </span>--> | 
| ===General Information=== | ===General Information=== | ||
Latest revision as of 13:32, 15 September 2025
Contents
Introduction
Welcome to the wiki for the SoC Design course! We started this series of labs/projects in 2014 and we are upgrading and fixing problems every year to make it better.
Slides for the introductory presentation are available here
Learning Objectives
After the completion of the labs, you will be able to:
| Tutorials: 
 | 
 | Project: 
 | 
Requirements for Taking the Labs
For these labs we assume that you have basic knowledge of the following:
- C language <- This is a must!
- Digital Systems Design
- Embedded Systems Programming
Lab Organization
| Important dates 
 | 
 | Lab Grading Policy 
 In order to pass the course, you have to get a positive result in both the project and the exam. You cannot finish the project without passing all tutorial labs! | 
 
 | 
Rules and Regulations
For your programs, please follow the coding style: [LINK]
Please read the following page before you start the course:
Timing and Plans
Please note that the project's (strong) deadline is on the last lab session, no extension will be made!
General Rules
- Unplugging any cables from the lab computers is NOT ALLOWED! If you use your own computer, please use Wi-Fi.
- It is OK to discuss your code with colleagues during the labs.
- Copying a colleague's code is not OK! You need to write your own code.
- You must understand the code you write! We will check that you do!
When writing Code
- The first thing your code MUST do is print out your name, otherwise you are not allowed defend the lab! Kernel modules should print your name when they are inserted.
(This requirement only applies for code that you have modified or written yourself)
Have in mind that you or someone else might want to reuse your code!
- Use comments in your code. Even you, as the author of the code, may not understand it in the future.
- Write a proper doc-string for the functions. It makes your life and of others much easier.
- Use meaningful variable names. A variable named "counterMaxValue" is much easier to understand than one for the same purpose named "cMNum", for example.
In Case of Problems
Please use the following methods in the following order for solving your issues:
- Check the current lab's additional materials.
- Re-read the lab manual to make sure you did not miss anything.
- Google your problems
- Ask the lab assistants for help.
NOTE: In case you find a problem with the documentation, please tell the assistants. Then we can fix the problem and everyone will be happy :)
Lab Results
| You can view you current lab results and statistics here | 
|---|
Contact Us
In case of any questions, please contact us:
| • Madis Kerner | 
Labs
Lab Tutorials
Here you can find lab manuals for the tutorials:
- Lab 1: Building Custom SoC on ZedBoard
- Lab 2: Kernel Driver
- Lab 3: Custom IP creation
- Lab 4: Setup 1 board system for the lab
Additional Material
Additional reading materials and more information about the labs can be found here:
Lab Specific Information
General Information
Audio Mixer Project
Design project is defined in each round for System on Chip design(IAY0550) students with the aim of providing them with real world experience of working on a SoC project, teamwork and project management. This wiki will serve as a platform for students to pass-on their designs and documents to students in the next round of course. Full description of the project can be found on the Project Description page
- Project Description page.
Using Own Computer for the Labs
You can find some information about using your own computer on the Using Own Computer page.
Please note that using any other computer than the ones in lab is not officially supported. The information on this page is not checked by the lab supervisors and might not be up-to-date and might not work! We recommend not to rely your course progress on getting the systems running on your personal machine and use the lab computers!
However, if you decide to follow the instructions on the page, please let us know about the problems you encounter, so we can update the manual for the benefit of other students.
Git
The project code should be stored in git. Every component of the project should be uploaded as a separate branch.
There exists a dedicated Github repository for the course, that can be accessed here: [1]
Archive
Tutorials:
Design project:







