COMP0008 Computer Architecture and Concurrency
This database contains the 2018-19 versions of syllabuses.
Note: Whilst every effort is made to keep the syllabus and assessment records correct, the precise details must be checked with the lecturer(s).
Academic session | 2018-19 |
Module | Computer Architecture and Concurrency |
Code | COMP0008 |
Module delivery | 1819/A5U/T1/COMP0008 Undergraduate |
Related deliveries | None |
Prior deliveries | |
Level | Undergraduate |
FHEQ Level | L5 |
FHEQ credits | 15 |
Term/s | Term 1 |
Module leader | Bryson, Kevin |
Contributors | Bryson, Kevin |
Module administrator | Ball, Louisa |
Aims
To provide a working knowledge of the hardware and architecture of a modern computer system, particularly focusing on concurrency aspects and those that have an impact on writing multithreaded software. Students will gain a fundamental understanding of the concurrency abstraction and how it impact both hardware and software design. We will look at concurrency aspects of hardware: how race conditions in hardware can cause logic glitches; using parallelism to build efficient adder units and CPU pipeline designs. We will also look at hardware aspects that directly impact multithreaded software such as the memory hierarchy, cache coherence/consistency and hardware multithreading. We will learn how to design correct multithreaded Java software based on a solid theoretical understanding of concurrency principles and the Java Memory Model. The module will cover an understanding of concurrency from low-level aspects (such as spin locks implemented with MIPS hardware instructions) to high-level design patterns used within the Java concurrency package.
Learning outcomes
On successful completion of the module, a student will be able to:
- use the concurrency abstraction to reason about concurrent systems (both hardware and software)
- understand combinatorial and sequential digital logic circuits and be able to reason about them
- write and understand MIPS32 assembly language programs
- understand how high-level languages are translated to assembly language and subsequently machine code that drives the MIPS32 processor
- understand the internal structure of processors and different forms of parallelism employed
- develop an appreciation of how modern computers handle memory and input/output including key concurrency aspects such as cache coherence, memory consistency/visibility and interrupt-driven thread switching
- understand how operating systems schedule application level threads onto the hardware resources
- understand how synchronization mechanisms in high-level languages are implemented in terms of more primitive hardware concurrency instructions
- understand and resolve safety aspects of multithreaded Java including interference and visibility issues
- understand the monitor design pattern and how to employ it to write safe and efficient multithreaded Java code using both the traditional concurrency mechanisms and the new Java concurrency package classes
- understand and correctly use the thread-safe data structures and thread control mechanisms within the Java concurrency package
Availability and prerequisites
This module delivery is available for selection on the below-listed programmes. The relevant programme structure will specify whether the module is core, optional, or elective.
In order to be eligible to select this module as optional or elective, where available, students must meet all prerequisite conditions to the satisfaction of the module leader. Places for students taking the module as optional or elective are limited and will be allocated according to the department’s module selection policy.
Programmes on which available: |
|
Prerequisites: |
In order to be eligible to select this module, students need to:
|
Content
- Top-down high level overview of a computer: the main components making up a computer and how they interact.
- The concurrency abstraction applied to hardware and software.
- Fundamentals of hardware: basic electronics, logic gates and logic circuits.
- Combinatorial logic: building adders, subtractors and arithmetic logic units (ALUs).
- Sequential logic: building latches, flip-flops and CPU registers.
- MIPS assembly language and machine code.
- Translation of high-level languages into MIPS machine code.
- Internal structure of a MIPS processor: the control unit (CU) and datapath.
- Parallelism within the CPU.
- Key aspects of how operating systems handle application-level threads.
- Memory hierarchy, cache structure and cache coherence mechanisms.
- Creating and managing Java threads.
- Java traditional synchronization mechanisms (and how they relate to low-level hardware instructions)
- Monitor design patterns and conditional variables.
- Java concurrency package: thread control classes and thread-safe data structures.
- Understanding and reasoning with the Java Memory Model (JMM) specification.
- Reasoning about the correctness of concurrent programs: safety, variable visibility, liveness and deadlocks.
An indicative reading list is available via http://readinglists.ucl.ac.uk/departments/comps_eng.html.
Delivery
The module is delivered through a combination of lectures, electronic coursework and programming exercises.
Assessment
This module delivery is assessed as below:
# | Title | Weight (%) | Notes |
1 | Written examination (2hrs) | 70 |
|
2 | Coursework 1 | 10 |
|
3 | Coursework 2 | 10 |
|
4 | Coursework 3 | 10 |
|
In order to pass this module delivery, students must:
- achieve an overall weighted module mark of at least 40%; and
- achieve a mark of at least 30% in any components of assessment weighed ≥ 30% of the module.
Where a component comprises multiple assessments, the minimum mark applies to the overall component.