## Section 2

# Course Delivery Details

### 2.1 Weekly Course Structure and Workload

| [ C          | /D'                | D          |                                                     |
|--------------|--------------------|------------|-----------------------------------------------------|
| Session      | Time               | Duration - | Content                                             |
|              |                    | Minutes    |                                                     |
| Presentation | $4\mathrm{pm}$     | 50         | Online Live Lecture                                 |
| Presentation | 5pm                | 50         | Online Live Lecture                                 |
| Coffee       | 6pm                | 15         | Rest and informal live Q&A                          |
| Workshop     | $6.15 \mathrm{pm}$ | 45         | Elective Workshop - Working together to de-         |
|              |                    |            | sign or code or understand an assignment – In-      |
|              |                    |            | structor led. This is an elective for students that |
|              |                    |            | may need extra coaching/tuition to ascend the       |
|              |                    |            | learning curve initially.                           |
| Study and    | Participant        | 1 hours    | Second reading of course material and/or view-      |
| Reading      | Chosen             |            | ing of recorded lecture. Involvement in technical   |
| Time         |                    |            | discussion forum.                                   |
| Design       | Participant        | 8 hours    | Homework Assigments - hands on Experience of        |
| Work         | Chosen             |            | designing and coding and synthesis.                 |
| Assessment   | 5 minutes          | _          | 1x1 Individual student feedback per week.           |
| Feedback     | per student        |            | _                                                   |
| Total        | _                  | 11 hours   | For average student - some will be less and some    |
| Student      |                    |            | more.                                               |
| Workload     |                    |            |                                                     |
| Total        |                    | 8 hours    | 3 Hours – Online Lectures                           |
| Lecturer     |                    |            | 2 Hours – Online Discussion                         |
| Workload     |                    |            | 1.75 – Hours Marking/Grading Homework/As-           |
|              |                    |            | signments, 7 minutes per student                    |
|              |                    |            | 1.25 Hours – 1x1 Feedback each week on average      |

Table 2.1: Indicative Weekly Course Plan

An indicative weekly course delivery structure is given in table 2.1. The durations given are approximate and will vary depending on class size and class competence and the number of questions arising.

#### 2.2 Course Content Outline

| Section Name      | Content                                                            |
|-------------------|--------------------------------------------------------------------|
| Context and       | State of the art in Digital Design Technology, CPU, SOC, ASIC,     |
| Background Ma-    | FPGA, Memory. Overview of Digital Systems Design, Flow and         |
| terial            | Tools.                                                             |
|                   | Review of Digital Logic Basic Elements - Logic Gates, Multiplexor, |
|                   | Flip-Flop, decoders. Use of Timing Diagrams to test behaviour of   |
|                   | logic citcuits.                                                    |
| Verilog1 – Essen- | Introduction to Basic Verilog Modelling of combinational logic and |
| tials             | synchronous logic. Different coding methods.                       |
| Verilog2 – FSM    | Verilog Coding of FSMs - different styles of coding.               |
| Coding            |                                                                    |
| Verilog3 – Test-  | Coding of a basic functional testbench. Correct Application of     |
| benches           | stimulus to UUT. Self-Checking testbench. Building up testbench    |
|                   | complexity.                                                        |
| Verification1     | Test Specifications. Unit testing and system testing. Use of Lint- |
|                   | ing. Testing Silicon - Functional testing, BIST, SCAN and pro-     |
|                   | duction testing. Description of Verification Methodologies - UVM.  |
|                   | Verilog and UPF in verification.                                   |
| Digital Design1 – | Introduction to Finite State Machines (FSMs). Logic derivation     |
| FSMs              | from FSMs. Application of FSMs to design solutions to various      |
|                   | problems e.g. simple UART receive and transmit, Sequence De-       |
|                   | tect, Memory Controller, Memory Arbitration.                       |
| Digital Design2 – | Introduction to Top Down Design Methodology and application        |
| Top Down1         | to Design of 16x8 FIFO from Flips-Flops or similar.                |
| Digital Design3 - | ARM and AMBA, APB, AHBLite and AXI4 buses, how they work           |
| Bus Protocols     | and compare. Design of AMBA bus DMA controller using one of        |
|                   | the AMBA protocols.                                                |
| Digital Design4 - | Timing Analysis(STA) of digital blocks. Minimum and maximum        |
| Timing Analysis1  | time calculations. Chip I/O timing and PLL application.            |
| Digital Design5 - | Single bit Asynchronous Inputs to FSMs and synchronization         |
| Asynchronous1     | methods. Metastability and Reliability of single bit and double    |
|                   | synchronisation methods. Design Method to safely facilitate bus    |
|                   | crossing asynchronous interface – method 1.                        |
| Digital Design6 - | Efficient Data Bus Crossing of asynchronous interfaces using       |
| Asynchronous2     | FIFO.                                                              |
| Digital Design7 - | Design of a simple Microprocessor or similar project.              |
| Top Down2         |                                                                    |
| Digital Design8 - | FPGAs - Overview of the architecture and building blocks of XIL-   |
| Realisation1      | INX, Altera(Intel) and Microsemi FPGAs. Comparison of FPGA         |
|                   | to ASIC development. IO Standards, DDR Memory and DDR              |
|                   | interfacing.                                                       |

Table 2.2: Outline of Course Lecture Content

#### 2.2.1 Indicative Assessment Content

This module will be assessed using 100% Continuous Assessment(CA). Some of the **indicative** type of assignments/assessments are shown in table 2.3. Assignments 6a and 6b are elective i.e. student chooses either 6a or 6b.

| Section Name              | Content                                                                                                                                                                  |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Assignment1               | Instructor Led – Verilog Coding of a logic schematic with switches and LEDs. Writing verilog self-checking testbench to test schematic. Marks 8%.                        |
| Assignment2               | Participant Led – Design an FSM to solve simple problem e.g. Transmit UART. Coding and self-checking testbench to test this design. Marks 8%.                            |
| Assignment3               | Design, Document, Code and test of a 16x8 FIFO (from flip-flops) with back-pressure to the source. Marks 12%.                                                            |
| Assignment4               | Design, Document, Code and Test of memory controller to simple asynchronous SRAM. Code and test this design including bus functional model (BFM) of the SRAM. Marks 12%. |
| Assignment5               | Design, Document, Code and Test of AHBLite DMA Controller. Marks 30%.                                                                                                    |
| Elective 1 – Assignment6a | Design, Document, Code and Test of asynchronous bus interface clock crossing using a FIFO. Marks 30%.                                                                    |
| Elective 2 – Assignment6b | Design, Code and test of a simple Microprocessor (or similar). Marks 30%.                                                                                                |

Table 2.3: Indicative - Course Assessment Content