An age-old threaded problem in pure C.
A C implementation of the classic Dining Philosophers Problem by Edsger Dijkstra, with threads, mutexes, forks and semaphores.
- Makefile should explicitly name all source files (
make dump_sources
). - Make must compile without relinking
-
make all
shouldn't recompile/rearchive any objects or sources. - Add
.keep
to object dirs
-
- Compiles with workspace's
cc
(clang
version12.0.1
)- Switch Makefile's
clang-12
toCC
before submitting.
- Switch Makefile's
- Test in workspaces
- Written in C.
- Follows
norminette 3.3.51
- Should not quit unexpectedly (segmentation fault, bus error, double free, etc.)
- All allocated heap memory properly freed, no memory leaks.
- Use gcc
-fsanitize=leak
flag. - Check memory leaks with
valgrind
.
- Use gcc
- Compiles with
-Wall -Wextra -Werror
- No global variables.
- Receive 4-5 arguments.
-
number_of_philosophers
: number of philosophers and forks. -
time_to_die
(ms)- Philosophers should die if they didn't eat since the BEGINNING of their last meal/beggining of the simulation.
-
time_to_eat
(ms) -
time_to_sleep
(ms) -
number_of_times_each_philosopher_must_eat
(OPTIONAL)
-
- Index philosophers from 1 to
number_of_philosophers
. - Program log:
-
timestamp_in_ms X has taken a fork
-
timestamp_in_ms X is eating
-
timestamp_in_ms X is sleeping
-
timestamp_in_ms X is thinking
-
timestamp_in_ms X died
-
- Log messages shouldn't mix up with each other.
- Death message should print before 10 ms.
- Philosophers should avoid dying.
- No data races.
- Program name
philo
- Turn in
Makefile
,*.h
,*.c
,.gitignore
in directoryphilo/
- Makefile rules:
$(NAME)
all
clean
fclean
re
- Allowed functions:
-
memset
printf
malloc
free
write
usleep
-
gettimeofday
pthread_create
pthread_detach
-
pthread_join
pthread_mutex_init
pthread_mutex_destroy
-
pthread_mutex_lock
pthread_mutex_unlock
-
libft
FORBIDDEN
-
- Philosophers alternatively
eat
,sleep
orthink
(in that order) - Should calculate if philosopher will die and die.
- There are as many forks as philosophers
- Philosophers need to grab
left_fork
andright_fork
before they can eat. - Create a thread for each philosopher.
- Deal with lone philosopher separately.
- Create a mutex for each fork.
- Program ends when any one philosopher dies from starvation
- Program ends when each philosopher ate
number_of_times_each_philosopher_must_eat
- Guardian Thread:
- Checks whether any philosopher died/should be dead.
- Check if everyone ate their last meal.
- Polling + Mutex
- Pass all testers
- Program name
philo_bonus
- Turn in
Makefile
,*.h
,*.c
,.gitignore
in directoryphilo_bonus/
- Makefile rules:
$(NAME)
all
clean
fclean
re
- Allowed functions:
-
memset
printf
malloc
free
write
fork
kill
exit
-
pthread_create
pthread_detach
pthread_join
usleep
gettimeofday
-
waitpid
sem_open
sem_close
sem_post
sem_wait
sem_unlink
-
libft
FORBIDDEN
-
- Create a process for each philosopher.
- Create a semaphore the forks.
You will need git
, make
and clang-12
:
$ sudo apt-get install git make clang-12
Clone the repo and build with make
:
$ git clone --recurse-submodules /~https://github.com/librity/ft_philosophers.git
$ cd ft_philosophers/philo
$ make
This should create a philo
executable in the root folder:
./philo
Part of the larger 42 Network, 42 São Paulo is a software engineering school that offers a healthy alternative to traditional education:
- It doesn't have any teachers and classes.
- Students learn by cooperating and correcting each other's work (peer-to-peer learning).
- Its focus is as much on social skills as it is on technical skills.
- It's completely free to anyone that passes its selection process - The Piscine
It's an amazing school, and I'm grateful for the opportunity.
- https://man7.org/linux/man-pages/man2/gettimeofday.2.html
- https://stackoverflow.com/questions/60932647/gettimeofday-why-use-both-seconds-and-microseconds
- https://www.wake-up-neo.net/pt/c/como-obter-o-tempo-atual-em-milissegundos-partir-de-c-no-linux/970965963/
- https://man7.org/linux/man-pages/man2/gettimeofday.2.html
- https://www.ibm.com/docs/en/zos/2.2.0?topic=functions-pthread-mutex-lock-wait-lock-mutex-object
- https://www.man7.org/linux/man-pages/man3/pthread_mutex_lock.3p.html
- https://www.man7.org/linux/man-pages/man0/pthread.h.0p.html
- https://randu.org/tutorials/threads/
- http://files.kipr.org/gcer/2009/proceedings/Myers_ApplicationPthreads.pdf
- https://blog.regehr.org/archives/490
- https://docs.oracle.com/cd/E19205-01/820-0619/geojs/index.html#:~:text=A%20data%20race%20occurs%20when,their%20accesses%20to%20that%20memory
- https://man7.org/linux/man-pages/man7/sem_overview.7.html
- https://wikiless.org/wiki/Inter-process_communication?lang=en
- https://www.geeksforgeeks.org/use-posix-semaphores-c/
- https://blog.pantuza.com/artigos/o-jantar-dos-filosofos-problema-de-sincronizacao-em-sistemas-operacionais
- https://www.notion.so/Philosophers-2b872948598e4f0cba91c66d8b5ba821
- https://rodsmade.notion.site/Acelera-Philosophers-a82a52edabe24ea4a382393fae6c4531
- https://excalidraw.com/
- https://miro.com/app/board/o9J_l0AjIkc=/
- https://miro.com/app/board/uXjVOUjzO5Q=/
- https://valgrind.org/docs/manual/drd-manual.html
- https://valgrind.org/docs/manual/hg-manual.html
- http://bl0rg.krunch.be/memleak-pthreads.html
- https://discord.com/channels/706206701598277681/805218621977919498/1021192139272622192
- https://stackoverflow.com/questions/62001623/why-does-helgrind-show-lock-order-violated-error-message
- /~https://github.com/GOAT095/philosophers-tester/blob/master/delay_o_meter.py
- /~https://github.com/nesvoboda/socrates
- /~https://github.com/nesvoboda/socrates/blob/master/delay_o_meter.py
- /~https://github.com/wwwwelton/philosophers/blob/master/test.sh
- https://pastebin.pl/view/85d80008
- https://invidious.weblibre.org/playlist?list=PLfqABt5AS4FmuQf70psXrsMLEDQXNkLq2&dark_mode=true
- https://invidious.weblibre.org/watch?v=-TFqOIqP-_k&ab_channel=JamieKing&dark_mode=true
- https://invidious.weblibre.org/watch?v=2Jmj8F-vpfc&t=109s&dark_mode=true
- https://invidious.weblibre.org/watch?v=9axu8CUvOKY&list=PL9IEJIKnBJjFZxuqyJ9JqVYmuFZHr7CFM&index=3&dark_mode=true
- https://invidious.weblibre.org/watch?v=DoYXn3nd0Ws&dark_mode=true
- https://invidious.weblibre.org/watch?v=GNw3RXr-VJk&dark_mode=true
- https://invidious.weblibre.org/watch?v=NbwbQQB7xNQ&dark_mode=true
- https://invidious.weblibre.org/watch?v=cx1ULv4wYxM&dark_mode=true
- https://invidious.weblibre.org/watch?v=d9s_d28yJq0&dark_mode=true
- https://invidious.weblibre.org/watch?v=sDLQWivf1-I&dark_mode=true
- https://invidious.weblibre.org/watch?v=trdXKhWAGdg&dark_mode=true
- https://yewtu.be/watch?v=ukM_zzrIeXs