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 | 30% coursework, 70% written exam, with the possibility of exemption. There will be a total of four assignments and two class tests. The assignments and the class tests each contribute 50% of the coursework mark. An exam exemption will be granted to students who achieve a coursework mark of at least 60% and have demonstrated diligence by handing in all assignments and passing (scoring at least 40% in) both of the class tests. Discretion will be exercised in favour of students who fail the diligence criteria in extenuating circumstances. The final class mark for exempt students is the coursework mark. Non-exempt students are required to sit the degree exam: their final class mark is weighted 30% coursework mark, 70% degree exam. |
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: 2022-09-09 13:40:19