Term: Fall 2024

Instructor: Aline Normoyle

Course Info

Welcome to CS223: Systems Programming!

matrix original

Systems programming is the foundation of all software and toolkits that serve as infrastructure for other software, such as compilers, operating systems, networking APIs, and graphics engines. Systems programming directly interacts with machine characteristics and low-level data types. Class topics include pointers, bit representations of data, x86_64 assembly, memory management, processes, and threads. In this class, students will gain hands-on experience implementing low-level algorithms and data structures using C. Additionally, students will build technical skills related to makefiles, interactive debugging, version control, and command-line shell interaction. C++ and STL will be introduced at the end of the course.

Meeting Times

Activity Location Time

Lecture

Park 159

Tuesday and Thursday 11:40 AM - 1:00 PM

Lab

Park 230

Thursday 2:40 PM - 4:00 PM

Office Hours - Prof. Aline Normoyle

Park 200B

Fridays, 2-3 PM (But often will be available until 5 PM)

Office Hours - Paprika Chen

Park 231

Tuesdays, 7-8 PM

Office Hours - Yue Chen

Park 231

Thursdays, 7-8 PM

Schedule

The syllabus may change during the semester. Please check here every week for updates on lecture content, worksheets, and assignments.

Week Date Agenda

1

September 3, 5

Introductions, Hello C

2

Sept 10, 12

More C, Introduction to Pointers

3

Sept 17, 19

Pointers, malloc/free

4

Sept 24, 26

Pointer-based data structures. Debugging.

5

Oct 1,3

Binary and Data Representation I

6

Oct 8, 10

Binary and Data Representation II, Intro to Assembly

7

Oct 16,19

Fall Break

  • NO LECTURES, LABS, HOMEWORKS

8

Oct 22, 24

Assembly

9

Oct 29,31

The operating system, Processes

10

Nov 5, 7

Threads I

11

Nov 12, 14

Threads II

12

Nov 19,21

Threads III

13

Nov 26

Threads IV

  • Nov 28: Thanksgiving, NO CLASS

14

Dec 3,5

Memory, Code optimization

15

Dec 10,12

C++

Text and Tools

  • Dive into Systems by Suzanne J. Matthews, Tia Newhall, and Kevin C. Webb. Available free online from Dive into Systems

  • Data Structures in C by Mark Allen Weiss

  • Github Account Please go to github.com and register. You will be using github to submit assignments.

  • Slack Please go to slack.com. Our workspace is BrynMawr-CS223-F24. You can ask questions and request one-on-one help over zoom using this course’s slack channel.

Grading Policies

All graded work will receive a grade, 4.0, 3.7, 3.3, 3.0, 2.7, 2.3, 2.0, 1.7, 1.3, 1.0, or 0.0. At the end of the semester, final grades will be calculated as a weighted average of all grades according to the following weights:

45%

Final Exam

25%

Assignments

25%

Lab work and Quizzes (Code Jams)

5%

Participation

Labs and exams

In labs, we will have practice quizzes for the final exam, each structured like a mini-code jam where you work together in teams. Each quiz will have a study guide so you know what types of questions to expect. During lab, you will be randomly assigned a partner and given 40 minutes to complete the questions. The following week in lab, we will go over answers for the previous week.

If you cannot attend a lab, please let the instructor know in advance. There are no make-up opportunities for labs — the missing work will be re-weighted to be part of your final exam.

There will be one final exam for the semester. Details and dates will be released during the semester. Please read the section on accomodations if you are in need of extra time. You must inform us of accommodations or conflicts at least 2 weeks in advance of the exam.

Quizzes and exams will be open book. You will be given sample questions beforehand to help you study. Warning! Do not rely heavily on your notes for quizzes. You will need to have concepts memorized in order to finish within the time limit.

Homeworks and exercises

This course features weekly lab exercises and assignments which are an important component of the class.

Lab exercises will be passed out in lab. These exercises are intended to be short and will typically ask you to reproduce demos from class or tackle concepts you will need for your assignment. Lab exercises should be handed in at the end of lab.

Class exercises will be passed out in class. These exercises are intended to be short and will typically ask you to practice concepts from lecture.

Assignments will be posted Saturdays and due Friday before midnight. You are strongly encouraged to start early so that you can ask questions. See the syllabus for links to the assignments.

You will submit your assignments electronically using git.

Late Policy

Because practice is so important for learning how to program, we will do frequent exercises, assignments, and quizzes throughout the term.

The purpose of this work is to give you hands on experience with the topics from class. Most of this work will be due in lecture or labs. The weekly time commitment for this course is aimed to be approximately 10 hours per week.

Assignments will generally be due on Fridays. However, you may request up to one late day (until Saturday) if necessary. No submissions beyond Saturday will be accepted. This allows us time to grade assignments. And it helps prevent you from falling behind. Note that with weekly assignments, you can miss a week or two without losing much points on a final grade.

If you need to miss a quiz, we will not have make-ups. Instead, the missed credit for the quiz will be added to the final exam.

You may need to provide a doctor’s note if you need special accommodations due to a medical emergency. If you require an accommodation for exams and quizzes, this must be submitted to the instructor within the first two weeks or class.

Academic Integrity

Copied and unattributed work will receive zero credit. At Bryn Mawr, we assume students are trustworthy and work with honesty and integrity. Look here for information about Bryn Mawr’s Honor Code.

As you progress in this course, you will see that programming is a creative process, similar to writing. The same problem can be solved in multiple ways. It’s essential that you develop your own skills for developing algorithms and implementing them through programs.

Quizzes and exams will be closed book. You will be able to bring a single cheat sheet with you. The goal of assignments and labs is to help you prepare for quizzes and exams! If you can sit down, focus, and answer sample questions within a time limit, you will ace the exams for this class. Incidentally, you will also be prepared to ace a job interview on this topic!

Integrity Guidelines:

  • DO discuss ideas and approaches with your classmates.

  • DO discuss ideas and approaches with your TAs and instructor.

  • DO search for documentation and sample programs for built-in C functions and C syntax.

  • DO use code from our text books and class (with attribution).

  • DON’T use Chat-GPT (or other LLMs) to generate solutions.

  • DON’T copy full solutions, from online tutorials, previous students, etc

  • DON’T use functions and C syntax that is disallowed by the Makefile. We are deliberately using simple and portable C.

  • DON’T modify any basecode that comes with your assignment.

  • DON’T ever share your code with other students.

It’s ultimately up to you to learn from your assignments! Remember, no one is going to hire you to do work that they can easily do themselves using a search or AI program generator. The programs in this course are simple enough for an AI or search or two to solve. But the next level of programs will not be so simple. You must do the work yourself. This is the only way you will develop the skills and expertise to reach your full potential.

One final point: we will be using open-source repositories for homeworks in this class. Thus, it will be possible to see what other students (and previous students) have submitted. If you copy from others' repositories, it will be obvious to everyone involved! Only look at other solutions after you have finished your own first!

Academic Accommodations

All classes will be recorded and close-captioned. Links to lectures will be posted on the class syllabus.

Any student who has a disability-related need to record this class first must speak with the Director of Access Services, Deb Alder, as part of university policy. Class members need to be aware that this class may be recorded.

To receive an accommodation for a course activity (such as more time on quizzes and exams), you must have an Accommodation Letter from the Office of Student Disability Services and you need to contact us to work out the details of your accommodation at least two weeks prior to the activity. Forms can be emailed to me, the instructor.

You are also welcome to contact us privately to discuss your academic needs. However, all disability-related accommodations must be arranged, in advance, through Student Disability Services.

Students needing academic accommodations for a disability must first register with Access Services. Students can call 610-526-7516 to make an appointment with the Director of Access Services, Deb Alder, or email her at dalder@brynmawr.edu to begin this confidential process. Once registered, students should schedule an appointment with the professor as early in the semester as possible to share the verification form and make appropriate arrangements. Please note that accommodations are not retroactive and require advance notice to implement. More information can be obtained at the Access Services website. (http://www.brynmawr.edu/access-services/)

Covid Policy

Lectures and labs will have a mask-friendly policy. All are welcome to wear a mask if they so wish, but no one is mandated to wear a mask.

If you are symptomatic (coughing, sore throat, or running nose), please either stay at home or come into campus with a mask. Lectures will be recorded so they can be watched later. Missed lab activities and quizzes will have their grade credit transferred to the final.

Academic support

Title IX

Bryn Mawr/Haverford College is committed to fostering a safe and inclusive living and learning environment where all can feel secure and free from harassment. All forms of sexual misconduct, including sexual assault, sexual harassment, stalking, domestic violence, and dating violence are violations of Bryn Mawr/Haverford’s policies, whether they occur on or off campus. Bryn Mawr/Haverford faculty are committed to helping to create a safe learning environment for all students and for the College community as a whole. If you have experienced any form of gender or sex-based discrimination, harassment, or violence, know that help and support are available. Staff members are trained to support students in navigating campus life, accessing health and counseling services, providing academic and housing accommodations, and more.

The College strongly encourages all students to report any incidents of sexual misconduct. Please be aware that all Bryn Mawr/Haverford employees (other than those designated as confidential resources such as counselors, clergy, and healthcare providers) are required to report information about such discrimination and harassment to the Bi-College Title IX Coordinator.

Information about the College’s Sexual Misconduct policy, reporting options, and a list of campus and local resources can be found on the College’s website: