aboutsummaryrefslogtreecommitdiff
path: root/philo_two/src/main.c
diff options
context:
space:
mode:
authorCharles Cabergs <me@cacharle.xyz>2020-10-05 15:06:03 +0200
committerCharles Cabergs <me@cacharle.xyz>2020-10-05 15:06:03 +0200
commit473cf5d7576744b679b7a504232b5ebd4b5d689f (patch)
tree6518e4fd26bf4584e5a2d72b9e1289473bce76da /philo_two/src/main.c
parenta237321ee53f44793ebc8b9db26b743f092b5e40 (diff)
downloadphilosophers-473cf5d7576744b679b7a504232b5ebd4b5d689f.tar.gz
philosophers-473cf5d7576744b679b7a504232b5ebd4b5d689f.tar.bz2
philosophers-473cf5d7576744b679b7a504232b5ebd4b5d689f.zip
Norming
Diffstat (limited to 'philo_two/src/main.c')
-rw-r--r--philo_two/src/main.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/philo_two/src/main.c b/philo_two/src/main.c
index c0c9fd6..f53f892 100644
--- a/philo_two/src/main.c
+++ b/philo_two/src/main.c
@@ -6,7 +6,7 @@
/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/02/14 22:45:23 by cacharle #+# #+# */
-/* Updated: 2020/09/30 09:58:01 by cacharle ### ########.fr */
+/* Updated: 2020/10/05 14:31:09 by cacharle ### ########.fr */
/* */
/* ************************************************************************** */
@@ -14,7 +14,7 @@
#define PHILO_SEM_NAME "semaphore_philo_two"
-int main(int argc, char **argv)
+int main(int argc, char **argv)
{
int i;
t_philo_conf conf;
@@ -22,10 +22,12 @@ int main(int argc, char **argv)
sem_t *forks;
pthread_t *threads;
- if (!parse_args((t_philo_args*)&conf, argc, argv))
+ if (!parse_args((t_philo_args *)&conf, argc, argv))
return (1);
+ if (conf.philo_num == 0)
+ return (0);
sem_unlink(PHILO_SEM_NAME);
- forks = sem_open(PHILO_SEM_NAME, O_CREAT | O_EXCL, 0600, conf.philo_num);
+ forks = sem_open(PHILO_SEM_NAME, O_CREAT | O_EXCL, 0700, conf.philo_num);
if (forks == SEM_FAILED)
return (1);
if ((philos = routine_create_philos(&conf, forks)) == NULL)
@@ -34,20 +36,21 @@ int main(int argc, char **argv)
return (1);
conf.all_alive = true;
pthread_mutex_init(&conf.mutex_stdout, NULL);
-
i = -1;
while (++i < conf.philo_num)
- if (pthread_create(threads + i, NULL, (t_routine)routine_philo, philos + i) < 0)
+ if (pthread_create(threads + i, NULL,
+ (t_routine)routine_philo, philos + i) < 0)
return (1);
while (conf.all_alive)
;
-
i = -1;
while (++i < conf.philo_num)
pthread_detach(threads[i]);
+ i = -1;
+ while (++i < conf.philo_num)
+ sem_post(forks);
sem_close(forks);
sem_unlink(PHILO_SEM_NAME);
-
pthread_mutex_destroy(&conf.mutex_stdout);
free(threads);
free(philos);