CS395: Computer Security (Prof. Szajda) Exam 2 November 15, 2006
Name:______
Note: This exam is closed book, closed note. You are to complete without the aid of your colleagues. The Honor Code applies. Your completed test is to be returned to my office by no later than 5:00pm on Tuesday, November 28, 2006.
Please keep your answers concise and to the point.
- (12 points) Explain in some detail (though without going into assembly code of the like) why buffer overflow attacks are possible, and how they are implemented.
- What is meant by the term type-safe as applied to a programming language? How does strong typing help increase the security of a language?
- What is meant by the term incomplete mediation?
- Explain the general notion of a TOCTOU vulnerability?
- What is meant by the term privilege escalation?
- What is a covert channel? Explain how a file-lock covert channel might work.
- Explain in some detail each of the following compute virus related terms:
- Boot sector infector
- Executable infector
- Multipartite virus
- TSR virus
- Stealth virus
- Encrypted virus
- Polymorphic virus
- Macro virus.
- Rabbit (a.k.a. Bacteria)
- Logic Bomb
- What property of macro viruses make them potentially much more effective from an attacker's perspective?
- Explain in some detail how the Internet Worm worked. In particular, your discussion should include consideration of the particular routines and applications the vulnerability exploited, as well as the propagation mechanism (including the means through which potential new targets were chosen and the mechanics of infection).
- We have discussed that providing protection in operating systems can be difficult because of the need to enforce both separation of objects and sharing of some of those objects. Two methods of accomplishing this balance are sharing via access limitations and sharing via capabilities. Explain what capabilities are, and the important differences between capabilities and sharing via access limitations. In particular, what kinds of protection measures do capabilities allow that are not allowed by sharing via access limitation?
- Regarding access control mechanisms, discuss the differences between directories and access control lists. You should of course explain what each of the two mechanisms is, and then address in particular the types of operations that are more efficient (or inefficient, or problematic) for each access control mechanism (and why the particular operations are efficient/inefficient/problematic).
- ``Although secure in theory, human practice often degrades quality of this means of authentication.'' Explain in some detail.
- Discuss the fundamental conflict between the desire to allow longer passwords and the desire to implement practical security.
- Discuss the primary points of the paper Biometric Authentication Revisited. In particular, I would like to see you mention the lessons that the paper advocates regarding the use of biometric authentication.
- You are trying to crack a target's password (which you may assume is at most 10 ASCII characters in length). Discuss your plan of attack including the specific strategies you will use, the order in which you will use them, and why you will use them.
- List three reasons why it is not a good idea for an operating system to employ a plaintex system password list, even if the OS access control mechanisms restrict read permissions to system level processes.
- (12 points) Explain in detail what a TCP sequence number attack involves. Be sure to discuss in particular:
- The TCP three-way handshake initialization protocol that two parties go through to set up a TCP connection.
- Why the granularity of the rate of change of the initial sequence number is more important than the average rate of change.
- Why is this attack not practical for an intruder targeting one of the Internet backbone routers?
- (6 points) What exactly is a TCP source routing attack? Be sure to explain why it (sometimes) works.
- (12 points) Explain what is meant by each of the following four secure system design principles. For each principle, describe why it is considered good security practice.
- Least Privilege
- Complete Mediation
- Open Design
- Psychological Acceptability