CS 241
CS 241 - System Programming
Spring 2018
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 | Lawrence Angrave |
System Programming | CS241 | ADB | 48069 | DIS | 0 | 1030 - 1150 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADC | 48070 | DIS | 0 | 1200 - 1320 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADD | 48071 | DIS | 0 | 1330 - 1450 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADE | 48072 | DIS | 0 | 1500 - 1620 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADF | 48073 | DIS | 0 | 1630 - 1750 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADG | 48075 | DIS | 0 | 1800 - 1920 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADH | 50109 | DIS | 0 | 1930 - 2050 | R | 0218 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADJ | 56807 | DIS | 0 | 1200 - 1320 | R | 0222 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADK | 63637 | DIS | 0 | 1330 - 1450 | R | 0222 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | ADL | 63638 | DIS | 0 | 1500 - 1620 | R | 0222 Siebel Center for Comp Sci | Lawrence Angrave |
System Programming | CS241 | AL1 | 43556 | LEC | 4 | 1400 - 1450 | M W F | 1320 Digital Computer Laboratory | Lawrence Angrave |
System Programming | CS241 | AL2 | 63636 | LEC | 4 | 1500 - 1550 | M W F | 1320 Digital Computer Laboratory | Lawrence Angrave |
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)
Assessment and Revisions
Revisions in last 6 years | Approximately when revision was done | Reason for revision | Data or documentation available? |
Standardized class content and teaching material (slides) | Fall 2008 - present | Students were frustrated by content that changed from semster to semster. | informal discussions |
Standardized class content and teaching material (programming assignments) | Fall 2008 - present | Students were frustrated by new programming assignments that were not well-vetted. | informal discussions |
Adpted programming assignments to reflect real-world problems (including memory management, map-reduce, web servers) | Fall 2008 - present | Students wanted to understand how systems programming is tied to the real world. | |
Introduced the use of undergraduate lab assistants to help on programming assignments | Spring 2011 | Students needed more help during the work on their projects. | informal discussions |
Introduced mini programming assignments into discussion sections to help prepapre students for programming assignments | Fall 2011 - present | Students needed more help on how to start their projects. | informal discussions |
Moved lectures on memory to the beginning of the semester | Spring 2012 | The sudents needed a better understanding of memory for their programming projects. | informal discussions |
Introduced a programming contest for one of the projects | Fall 2010 | Get the students excited. | informal discussions |
Introduced an extra independent study project for interested students | Fall 2010 | Allow students to get involved in more complex projects or with on-going research projects. | informal discussions |
Required, Elective, or Selected Elective
Required.