MPCS 51081 Home Page
MPCS 51081 Unix Systems Programming
(aka The Unix Programming Environment)
CSPP 51081 is a UNIX systems programming course which explores various and sundry topics in systems programming using the Unix platform. Topics to be covered in detail will include:
Unix History and Philosophy
Unix File I/O
Static and Shared Libraries
Processes and Signals (fork, etc.)
Pipes (unnamed and FIFOs)
System V IPC (semaphores, message queues, shared memory)
In addition to the traditional systems programming topics, this course will also introduce students to a significant level of detail in the use of Sun RPC (Remote Procedure Calls) and multithreaded programming, including operating system support and models (1-1, many-1, many-many). Students will be exposed to the numerous issues involved in safe and efficient multithreading strategies using the POSIX pThreads API as implemented by Linux's clone() and Solaris threads. Multithreading architectures will be discussed as well as advanced issues such as mutexes, semaphores, race conditions, deadlocks, etc. Berkeley socket programming will be covered in detail, as well as the creation and use of shared libraries.
Various tools used in developing software in C on Unix will be
covered, including gcc, gdb, ddd, gprof, cvs, etc.
Because this is a programming course, students will be expected to know the C programming language upon course entry.
J. Mark Shacklette,
NOTE: ALL non-confidential email should be addressed to piazza.)
(Office hours listed on the syllabus )
Details of the course can be found in the course syllabus
Students are required to know basic C programming. Prior
minimal exposure to Unix is recommended.
Online Sources of Relevant Information:
To join piazza for this course, go here.
I can be reached at several email addresses, among them: