From 200b1b4fe01a6788fc5e9f2d4ff081fab95e7b29 Mon Sep 17 00:00:00 2001 From: Lukas Jiriste Date: Thu, 23 May 2024 09:32:26 +0200 Subject: [PATCH] Make semaphores close properly, fix array access --- philo_bonus/mem_management.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/philo_bonus/mem_management.c b/philo_bonus/mem_management.c index 25d5e28..a8a3cd8 100644 --- a/philo_bonus/mem_management.c +++ b/philo_bonus/mem_management.c @@ -48,7 +48,7 @@ int init(unsigned int count, pid_t **philo_pids, sem_t *semaphores[sem_num]) i = 0; while (i < count) { - *philo_pids[i] = 0; + (*philo_pids)[i] = 0; sem_wait(semaphores[death]); sem_wait(semaphores[fed]); ++i; @@ -63,11 +63,11 @@ void cleanup(pid_t *philo_pids, sem_t *semaphores[sem_num]) i = 0; while (i < sem_num) - { - if (semaphores[i] != SEM_FAILED) - sem_close(semaphores[i]); - ++i; - } + sem_close(semaphores[i++]); + sem_unlink(FORKS_SEM); + sem_unlink(WELL_FED_SEM); + sem_unlink(DEATH_SEM); + sem_unlink(TERM_SEM); free(philo_pids); return ; } -- 2.30.2