CSE466: Computer Systems Security Syllabus (Fall 2013)
Catalog Data:
Countermeasures to attacks to computer systems from miscreants (or
hackers) and basic topics of cryptography and network security.
Textbook:
None
Course Objectives
The structure and operating of software systems that allow hackers to
penetrate and malware to operate. A comprehensive study of vulnerabilities,
object-code level attacks, security measures, software shortcomings and
forms of attacks and countermeasures.
Course Outcomes:
After the course the student will be able to:
1. Understand the underlying vulnerabilities of systems from a software
standpoint.
2. Understand the structure of bits and bytes, data and programs, stored
at the object code level in memory and files.
3. Understand the basic of cryptography and computer security.
4. Understand the techniques used to hack into computer systems.
5. Understand the concepts secure programming.
6. Understand how to program and deploy countermeasures for keeping
software systems secure
Evaluation:
Students are assessed on grades received in projects, homeworks, exams.
The grades are curved for determining grade cutoff points on an A, B, C
scale. The weight distribution is Assignments: 35%; Mid-Term Exam: 30%;
Final Exam: 35%.
Topics:
1.
Risks and Trust
Risks of Computer Systems
Vulnerabilities and System Design
How to steal information
Basics of Attacks
The Shared Secret Problem
2.
-
Threat Models
Internet Threat Model
Ken Thompson and Software Trust
Viral Threat Model
3.
-
Attacks
Attack Mechanisms
System attacks and Network Attacks
Virus, Trojan, Worms, Spyware, Adware, Browser attacks
Buffer Overflows
The RootKit Attack
Malicious processes and computational power
Network based attacks (man in the middle, denial of service,
pharming)
4.
-
Data and Code Formats
How memory is organized
Code, data and other in-core structures
How the computer operates at the binary level
Binary and I/O conversions
File data and how data movement occurs
5.
-
Basic Cryptography
Random numbers, Cryptographic Hashes
Symmetric Encryption
Asymmetric Encryption
Digital Signatures
Digital Certificates
Certificate Authorities and Certificate Chains
Secure Sockets Layer (SSL) and IPSec
6.
-
Safe Programming Techniques
Coding practices and safety
Code bloat and safety
Feature Creep
Versatility and Vulnerabilities
Overall Design of Complex Systems
7.
-
Operating System Mechanisms
Identity and Authentication
Protection in Operating Systems
Interrupt handlers and System calls
Redirecting services
Reliable bootstrap, Address space protection
8.
-
Virtual Machine Systems
Types of Virtual Machines
How they work
Host Operating Systems and VMM interactions
Trust and Virtual Machines
Using Virtual Machines for Integrity Enforcement
9.
10.
-
Hardware Security Enforcers
Trust and Hardware Modules
The TCG approach
The CoPilot approach
Secure wallets
Secure co-processors
Application Security
Firewalls
Virus Detection
Fallibility of Virus detection
Signatures and Software
Integrity checking of software
Combining schemes to harden the software environment
11. Personal Security
How safe is your information?
What is valuable to others?
Protecting privacy
Protecting finances
Repudiation, spoofing and identity theft
Devices for personal safety and identity
12. Smart Card Systems
Types of Smartcards
Personal Security and Smartcards
Risks and Vulnerabilities of Smart Cards
Financial Transactions
Mobile Authentication
System verification
Trust model
Further Information: Will be provided on the class web-site.