CS 241
CS 241 - System Programming
Spring 2020
| Title | Rubric | Section | CRN | Type | Hours | Times | Days | Location | Instructor |
|---|---|---|---|---|---|---|---|---|---|
| System Programming | CS241 | ADA | 53753 | DIS | 0 | 0900 - 1020 | R | 0218 Siebel Center for Comp Sci | Beitong Tian |
| System Programming | CS241 | ADB | 48069 | DIS | 0 | 1030 - 1150 | R | 0218 Siebel Center for Comp Sci | Beitong Tian |
| System Programming | CS241 | ADC | 48070 | DIS | 0 | 1200 - 1320 | R | 0218 Siebel Center for Comp Sci | Aaron Gregory Green |
| System Programming | CS241 | ADD | 48071 | DIS | 0 | 1330 - 1450 | R | 0218 Siebel Center for Comp Sci | Arnav Sankaran |
| System Programming | CS241 | ADE | 48072 | DIS | 0 | 1500 - 1620 | R | 0218 Siebel Center for Comp Sci | Aaron Gregory Green |
| System Programming | CS241 | ADF | 48073 | DIS | 0 | 1430 - 1550 | W | 0222 Siebel Center for Comp Sci | Arnav Sankaran |
| System Programming | CS241 | ADG | 48075 | DIS | 0 | 1600 - 1720 | W | 0222 Siebel Center for Comp Sci | Arnav Sankaran |
| System Programming | CS241 | ADH | 50109 | DIS | 0 | 0930 - 1050 | R | 0222 Siebel Center for Comp Sci | Noor Sultan Michael |
| System Programming | CS241 | ADJ | 56807 | DIS | 0 | 1100 - 1220 | R | 0222 Siebel Center for Comp Sci | Noor Sultan Michael |
| System Programming | CS241 | ADK | 63637 | DIS | 0 | 1230 - 1350 | R | 0222 Siebel Center for Comp Sci | Harrison Ding |
| System Programming | CS241 | ADL | 63638 | DIS | 0 | 1400 - 1520 | R | 0222 Siebel Center for Comp Sci | Harrison Ding |
| System Programming | CS241 | AL1 | 43556 | LEC | 4 | 1000 - 1050 | M W F | 1320 Digital Computer Laboratory | Lawrence Angrave |
| System Programming | CS241 | AL2 | 63636 | LEC | 4 | 1100 - 1150 | M W F | 1320 Digital Computer Laboratory | Lawrence Angrave |
| System Programming | CS241 | PRO | 69992 | LEC | 4 | - |
See full schedule from Course Explorer
Official Description
Course Director
Text(s)
Learning Goals
Interact with a POSIX operating system in C via system calls to create system applications (2), (6)
Implement and evaluate a dynamic memory allocator (2), (6)
Analyze and implement a virtual memory subsystem (2), (6)
Create system applications that manipulate processes and threads (1), (2), (6)
Evaluate how OS schedules processes and threads (6)
Communicate and synchronize between threads and processes to create robust system applications (1), (2), (6)
Use synchronization to identify and fix potential deadlock and race conditions in concurrent programs (2), (6)
Manipulate filesystem structures (inodes etc.) (2), (6)
Design and create client and server programs to communicate across networks (1), (2), (6)
Understands and uses system security mechanisms to build secure programs (1), (2), (6)
Can analyze how a specific security error (e.g. buffer overflow, file access control, page access control) impacts the Confidentiality, Integrity and/or Availability of data or service. (1)
Can identify multiple development practices (e.g. design reviews, code reviews, testing) as important practices to build secure programs. (6)
Can briefly describe well-known security case studies (e.g. network protocol implementation errors, CPU side channel attacks) and how they comprise the Confidentiality, Integrity and/or Availability of data or service. (6)
Topic List
Basic internal structure and purpose of operating systems
Input-output, file, and directory structures
Memory allocation and deallocation
Virtual memory
Interaction with the operating system kernel via system calls
Multi-process programming and inter-process communication
Multi-thread programming and inter-thread communication
Synchronization primitives including semaphores and mutexes
Deadlock causes and avoidance
Multi-core scheduling algorithms
Network programming with TCP/IP
Security elementary principles and practices (programming practices, protocols and well-known case studies)
Required, Elective, or Selected Elective
Required.