CS107 - Fundamentals of Computer Systems
TIMETABLE | TEACHING MATERIAL |
Credits | 10 |
Level | 1 |
Semester | Semester 2 |
Availability | Not available as an elective |
Prerequisites | The student should have developed an understanding of:
|
Learning Activities Breakdown | 22 lectures with 10 tutorials and 10 practicals |
Assessment | This class is assessed entirely by coursework. Usually this consists of one practical assignment worth 30%, a class test worth 50% and 10 short weekly quizzes worth 2% each. |
Lecturer | Alasdair Lambert |
Aims and Objectives
To further the student’s knowledge of the design parameters of a typical computer system and the impact these have on the functionality, and implementation, of the hardware and software components.
Learning Outcomes
On completion of the class, a student should be able to:
- Demonstrate their knowledge of data/number/information representations and the limitations of such representations.
- Appreciate how a CPU may be constructed from combinational and sequential logic circuits.
- Understand the relationship between instruction set architecture, micro-architecture, and system architecture and their roles in the development of the computer.
- Understand the differences between the two main types of instruction set architecture and be aware of the major strengths and weaknesses of the alternative types of ISA.
- Appreciate how conditional operations are implemented at the machine level.
- Understand the way in which subroutines are invoked, how their parameters are passed and how their local workspace is created and accessed, and how they return to the point of invocation.
- Appreciate how an ISA has an impact on high-level languages and the design of compilers.
- Understand the basic principles of operation of the memory, I/O and network subsystems of a typical computer.
- Appreciate how future developments in computer systems may be influenced by current trends and technologies.
Syllabus
- Introduction to instruction set architecture, micro-architecture and system architecture.
- Processor instruction set architecture: instruction types and formats, register sets, addressing modes.
- Processor structures: memory-to-register architectures; load/store architectures; overview of Flynn’s classification of computer architectures.
- The relationship between low-level and high-level programming languages.
- Instruction sequencing, flow-of-control, subroutine call and return mechanisms.
- Low-level architectural support for high-level languages.
- Low-level architectural support for operating systems.
- Low-level architectural support for concurrency.
- Memory: types of memory, overview of the memory hierarchy.
- Input/Output: types of I/O; overview of common I/O devices and interfaces.
- Networks: types of network; overview of common network standards, protocols, and interfaces.
- Current and future trends in computer systems: an overview of the current trends in state-of-the-art computer systems and an extrapolation of these (in an attempt) to predict future developments
Recommended Reading
This list is indicative only – the class lecturer may recommend alternative reading material. Please do not purchase any of the reading material listed below until you have confirmed with the class lecturer that it will be used for this class.
The Essentials of Computer Organisation and Architecture, 2nd edition, Linda Null and Julia Lobur, Jones and Bartlett, 2006, 0763737696
Last updated: 2024-02-05 14:42:05