Course syllabus

Course-PM

MCC093 Introduction to integrated circuit design lp1 HT25 (7.5 hp)

Course is offered by the department of Microtechnology and Nanoscience

Contact details (see also under People in left menu)

Examiner and lecturer: Lena Peterson 

Email: lenap ”at” chalmers.se, phone: 031-772 1822, or 0706-268907
Office: C616 on 6th floor of MC2 building. (Ring the doorbell or call me if you visit since the corridor doors are locked)

Additional teachers

Lab sessions and postlab sessions and some problems-of-the-week sessions : Siavash Mowlavi

E-mail: mowlavi "at" chalmers.se phone: 031-772 1790
Office: B625 on 6th floor of MC2 building. (Ring the doorbell or call if you visit since the corridor doors are locked)

Lab sessions and some problem-of-the-week sessions. Xiaomeng Zhang

E-mail: xiazhang "at" chalmers.se phone: 

Office: C617 on 6th floor of MC2 building, next door to Lena's. (Ring the doorbell or call me if you visit since the corridor doors are locked)

Some problems-of-the-week sessions: Stavros Giannakopoulos

E-mail: stagia "at" chalmers.se 

Office: Has no office at Chalmers

Lab teaching assistants (all second-year MPEES students):

Ruxuan Wen

Harshit 

Guest lecturer:

Victor Åberg, who is now at Lund University: https://www.eit.lth.se/staff/victor.aberg

Information about Victor's research at Chalmers: https://research.chalmers.se/person/abergv

Course purpose

Aim

The overall aim of the course is to introduce the student to the field of CMOS integrated circuit design and to give some introductory training in the use of industrial Electronic Design Automation (EDA) tools and in understanding their role in the integrated circuit design flow. Technology node independent performance models for power and speed are presented, giving the student generic tools to estimate cost and performance properties in circuits of present and future CMOS technologies.

Schedule

Note that sometimes the schedule in TimeEdit does not exactly correspond to the one listed in the Modules here; we may use fewer hours than listed sometimes. The teachers cannot update the times in the TimeEdit schedule themselves. We use the Canvas calendar for the detailed description of each session.

Course literature

The textbook is Weste and Harris: ”Integrated Circuit Design”, 4th Edition. Unfortunately, it is currently unavailable as a physical book from Pearson. You can buy the expensive hardback version”CMOS VLSI Design” from Amazon. 

You can subscribe to the e-book for a minimum of four months via Pearson+. I have tried it and it works from Sweden (previously it did not). Seems you can also buy it as an e-book for Kindle (this I have not tried, so cannot guarantee it).

This book is the international edition of the more expensive hardback book ”CMOS VLSI Design” 4th edition. There is a companion web site for the book at
http://www.cmosvlsi.com.

Some chapters are available in electronic form there and we will use those. The bibliography has links to original papers, most which you can access via Chalmers library.

Reading instructions for the textbook and other material are posted per theme under each module. There is also a page with the compiled reading instructions (this course-PM gets too long if we put them here).

The exercises will be compiled in a document made :

Version for 2025 to be added

Course design and organization

The course runs during study period 1 and gives 7.5 credit points. It is organized as a bottom-up course complemented with the later course DAt110 which is organized top-down and concentrates on methods  and tools. The course takes you from the basic building block, the MOS field-effect transistor (MOSFET), through CMOS logic gates to sub-systems such as adders and data paths. You will derive technology-node–independent performance models for power and speed; those models are generic tools to estimate cost and performance properties of present and future CMOS technologies (but no longer in a far-away distance).

The course is organized with weekly lectures and exercise sessions  and one or two circuit-design tasks organized as a series of hands-on laboratory exercises,  with related pre-lab assignments,using industrial electronic design automation (EDA) tools from Cadence. Most lecture topics have accompanying movies that we expect you to watch before the lectures. Each laboratory session is associated with a pre-lab home assignment, the on-time submission of which before the lab session is a prerequisite for being allowed to the lab hall. Starting last year we use optional post-lab quizzes to assign the  bonus point related to each of the labs.

Scheduled times and activities

Time                                 Activity                         Week/Room

Mondays 8-11.45 AM                         Lab group 1                                     study weeks 3-5 & 7 in F6302 aka Jeppson lab

Tuesdays 8-11.45 PM                         Lab group 2                                     study weeks 3-5 & 7 in F6302 aka Jeppson lab

 

Tuesdays 1.15-4(5)PM                       Lecture/tutorial                               study weeks  1-8 in room FL51 except E-studio once      

Thursdays 1.15-5PM                         Lecture + problem of the week session    study weeks 1-8  in room FL51 except E-studio once

Friday 13.15-15.00                            Lecture  / problem of the week session     only study weeks 1 & 7  - in EA and EC

We will let you know of any changes to the schedule here in Canvas.

For each theme there will be a "problem-of the-week" session, which is on Thursdays 15.15-17.00, and for the adder theme, where it is on the Friday of study week 7. In that session the teacher will solve some problems from MCC092 Exercises 2025 with your input.  Which problems that are to be solved is specified in each Theme module here in Canvas. Before the POTW session we expect you to have read through the specified problems and have thought through how to solve them.

See more info for each of the eight themes under "Modules".

Pre-lab preparations

There will one optional intro assignment in the form of a quiz and one pre-lab preparation for each of the four labs: all in all four solution sets to hand in and five optional quizzes to answer. You must hand in your solutions no later than the deadlines shown in the table below. All submissions are individual because they are part of the assessment in the course. You may work together with one other student when you complete the prelab assignemnts, but each of you must write and hand in your own solution. If you worked with another student this way, that person must be identified on your submitted solution. You must be able to explain your solution at our request. If we detect deficiencies in your solutions you get a return and you will have revise and resubmit.

Lab sessions

The lab sessions are on in study weeks 3-5 and 7  They will take place in our new lab F6203 (aka the Jeppson lab), which is in Fysik Forskarhuset. On the Friday before the first lab  there will be a session in the same computer room where we make sure that the VNC setup works correctly.

The labs are to be performed in groups of two students, so called lab pairs. The teachers will decide who gets assigned to which session and on the lab pairs. The groups will be posted on the course web page no later than by Friday night in study week 2. The labs are compulsory. If you fall ill and cannot complete the lab as planned, or if other unforeseen things happen to you very late, please send a text message or an e-mail message to Lena and Siavash.

In the labs you will use Cadence tools for schematic entry and simulation. The tools are made available to you through university contract with Cadence. These tools run under Linux and can only be run on a special server, due to the contract requirements, and  therefore they are not available to run on your own computers. However, when you are at Chalmers (or are logged into Chalmers via VPN)  it is possible to run the tools on this server. How to run the tools are explained in the lab-memos and related documents.

Note! If you have not submitted your pre-lab assignment on time, you will not be allowed to do the lab.

Submissions, feedback, returns and re-submissions

Submissions

You should always write down your own solution! Include enough of your calculations so that we can understand how you arrived at your results. You are not allowed to copy other students’ solutions, even though you are allowed to work on the problems with one other student. That one other student should be identified in your submission. You must be able to explain your solution at our request.

Submit all your solutions to home-assignment problems and pre-lab assignments via Canvas. Only submissions through Canvas will be considered since we are several teachers who cooperate on grading and giving feedback. E-mail submission is allowed only if there is a problem with Canvas.

Submit your solutions as pdf files. If your hand-in solution comprises more than one file, you can zip them into one file; it is also possible to submit first one file and then another one in Canvas. However, we prefer if you merge your separate pdf files into one file (with the pages in the right order) if possible.

Make your submissions readable. We prefer typed solutions since they are easier to read; however we accept hand-written solutions that have been scanned or photographed into a pdf file. If you write by hand, you have to write legibly so we can read it. If you take photos of your hand-written solutions make sure the photos are clear enough for the text to be read.

Submission                                         Deadline

1 Quiz 1  - course intro                                                      Mon Sept 8 11.59PM (midnight)

2 Pre-lab 1                                                                           Fri Sept 12 3 PM

3 Pre-lab 2                                                                           Fri Sept 19 3 PM

4 Pre-lab 3                                                                           Fri Sept 26 3 PM

5 Pre-lab 4                                                                           Thur Oct 9 11.59PM (midnight)                                             

Note: The last prelab has a different deadline due to Friday Oct. 10 is a non-scheduled day due to re-sit exams.

See also the Canvas assignments at the bottom of this page. The deadlines there should be the same as the ones above.

Feedback

We will give feedback on your submission in Canvas: your submission will either be approved or rejected; if rejected you must revise it and resubmitted in Canvas for approval. The feedback will say which of the tasks you need to resubmit. You should resubmit in the same assignment in Canvas.

If you submit your pre-lab assignments on time, we shall give you feedback no later than at the beginning of your Monday lab session. For solutions to home-assignment problem sets that you hand in on Mondays, you shall receive feedback no later than by the start of the lecture on the following Thursday. You can follow your progress in Canvas. You will be able to see if you passed or if you got a return and have to revise, as well as the number of bonus points you have received.

Revisions

If you get a return, we want your resubmission within one week from when you received our feedback. The final deadline for any resubmissions or late submissions that are to be included in the examination for period 1 2024 is Friday November 20  (that is, about three weeks after the exam). After that we will not grade any re-submissions until the re-sit exam period in January 2025, unless there are special circumstances such as illness.

Changes made since last year

  • Last year we added prelab quizzes. We got feedback that that 24 hours was too short a tome to complete them so we have doubled the time.
  • We have added some more time about adders and power in week 7 since we got feedback that it was too rushed.
  • We have clarified prelab 2 after feedback from students that it was not that clear.
  • Adder exercises have been updated somewhat.
  • We use a new lab room, but the difference should be minimal.

Learning objectives and syllabus

Learning objectives

After completion of the course the student should be able to

  • design static CMOS logic gates (pull-up and pull-down networks) and implement these as standard cells.
  • from simple MOS transistor models, estimate static and dynamic properties of CMOS inverters and use these properties to model more complex gates.
  • derive logical-effort normalized-delay parameters from circuit diagrams or layout, and use these parameters to estimate and trade off performance measures such as critical-path delays and power dissipation in present and future CMOS technologies. 
  • find critical paths in more complex combinatorial circuits, such as adders, and determine and minimise their delays.
  • analyse wire-delay-dominated cases such as clock distribution and global interconnect, and suggest suitable buffering schemes to minimize delay or delay spread. 
  • design simple sequential systems that meet set-up and hold time constraints for timing circuits, including the effect of metastability in synchronisation.
  • use industrial-type design automation tools to design, implement and verify basic CMOS circuit elements following the design flow supported by such tools.

Contents

  • Introduction to CMOS integrated circuit design; basic building blocks, technology platforms and design tools.
  • Introduction to the circuit design flow: schematic capture, circuit simulation, layout, rule checking, and layout-vs-schematic verification. Hands-on design skill training using industrial electronic design automation (EDA) tools.
  • The MOSFET as a digital switch. The square-law model.
  • The inverter as the basic digital and analog building block
    • Static properties - the voltage transfer characteristics, switching voltage, noise margins.
    • Dynamic properties - the RC delay model, buffer sizing, process corners.
    • Dynamic switching power and static leakage power.
  • Static CMOS logic gates. Designing logic gates with pull-up and pull-down networks.
    • The two-port as a dynamic switching model. Input load capacitances and output driving capability.
    • Technology independent delay measures. Definition of logical effort, parasitic delay and electrical effort (fanout).
    • Critical path delays. Sizing gates for minimum path delay.
  • Basic layout using standard-cell layout templates.
  • The adder as a design demonstrator. Ripple carry, carry look-ahead, and prefix-tree adders.
  • Interconnect and wire delay. The RC two-port wire model. Elmore's delay model. Repeaters.
  • Latches and flip-flops. Set-up and hold time requirements. Metastability.
  • Static and dynamic power consumption. Power and clock distribution. Power gating. Clock gating.

These parts are taken from the syllabus:

 

Examination form

The course’s 7.5 credits are divided into three course elements (Sw. kursmoment):

Course element

Credits

What you have to do to earn these credits

0111 Written examination

3

Pass the final exam

0211 Laboratory

3

Pass the four pre-lab problem sets and pass the four in-lab sessions

0311 Home assignments

1.5

Pass the three home-assignment problem sets (where the first one is now a quiz)

The examination is designed to encourage you to work continuously throughout the course with the material, since we know that it is hard to grasp the contents otherwise. The prelabs are there to make sure you get the most learning from the in-lab sessions. All tasks are individual since you have quite varying knowledge at the start of the course. However, you will work in pairs in the lab (as explained in more detail above).

 

Your grade is determined by the final exam (for details, see below).

The final exam

The final exam is a five-hour exam. It is a closed-book exam, but you are allowed to bring one A4 page of hand-written notes (you can write on both sides). You are also allowed to bring a calculator.

The exam comprises six problems with total maximum score of 60 points. You need at least 50 points to earn the grade 5, 40 points for the grade 4 and 30 points for the grade 3, which is the grade required to pass. If you have less than 30 points you fail the exam (usually recorded as U in the grading records). Any bonus points (see below) will be added to your score before the resulting higher grade is determined once you have reached 30 points on the exam. So, bonus points can give you a higher grade, but cannot be used to pass the course.

If you have not signed up you will not be allowed to take the exam.

Bonus points

Good hand-in problem-set submitted on time and complete prelab solutions submitted on time & successful post-lab quizzes  will earn you bonus points - one point per hand-in and per  pre-lab problem set + post-lab quiz . All in all, you can earn seven bonus points.

Again: this year we have changed the assigning of bonus points for the labs so that it comes AFTER the completed lab via a post-lab quiz - but you still have to turn on your complete prelab assignment on time to be prepared for the lab.

For the prelab assignment / postlab quiz you have to this to earn a bonus point.

Before the lab you have to do the prelab assignment:

  1. hand it in on time
  2. complete (you have reasonably tried to solve all problems, but the solutions do not have to be correct)
  3. legibly written (so we can read what you wrote).

And within 53 hours after the Tuesday post-lab session you have to complete the post-lab quiz with a score not lower than 80 %. You are only allowed to take the quiz once for the bonus point.

To earn you a bonus point for a a hand-in problem-set solution must be

  1. handed in on time
  2. complete
  3. legibly written
  4. comprehensible (that is, we must understand what you mean)
  5. substantially correct (that is only minor mistakes that do not require resubmission)

Your submissions should be written in English. For the quiz that replaces hand-in problem set 1, one bonus point will be allotted for results that are 75% correct or higher (that is, at least 16 out of 22 marks).

Workload

A 7.5-credit course is to correspond to 1/8 of an academic year, that is to a work load of 1600/8=200 hours. During the nine weeks of a study period this corresponds to 22 hours a week. Hence, with two courses running in parallel the nominal workload is 44 hours/week. The time scheduled for this course is 69 hours, 16 hrs. for lab sessions and 53 hrs. for lectures and exercises. Estimated time for the five home assignments and prelabs are 25 hours (5 hrs/assignment, but some may take longer depending on your background). The remaining around 100 hours are allotted for self-studies, reading the textbook, etc. That means that in addition to home assignments we expect you to work around 12 hours per week on your own.

 

Course summary:

Course Summary
Date Details Due