diff options
| author | Charles Cabergs <me@cacharle.xyz> | 2020-09-29 14:56:27 +0200 |
|---|---|---|
| committer | Charles Cabergs <me@cacharle.xyz> | 2020-09-29 14:56:27 +0200 |
| commit | 6bfcd3c6f921e7717e61167b291bb27bd3f66386 (patch) | |
| tree | 67b2aa4b8a036cb355f90b1f94438b7eb46441f1 /philo_one/routine.c | |
| parent | ac4278405b7a258010219499cccc0dd978201caf (diff) | |
| download | philosophers-6bfcd3c6f921e7717e61167b291bb27bd3f66386.tar.gz philosophers-6bfcd3c6f921e7717e61167b291bb27bd3f66386.tar.bz2 philosophers-6bfcd3c6f921e7717e61167b291bb27bd3f66386.zip | |
Fixing taking none existing fork in logs
Diffstat (limited to 'philo_one/routine.c')
| -rw-r--r-- | philo_one/routine.c | 55 |
1 files changed, 0 insertions, 55 deletions
diff --git a/philo_one/routine.c b/philo_one/routine.c deleted file mode 100644 index d52fe2e..0000000 --- a/philo_one/routine.c +++ /dev/null @@ -1,55 +0,0 @@ -/* ************************************************************************** */ -/* */ -/* ::: :::::::: */ -/* routine.c :+: :+: :+: */ -/* +:+ +:+ +:+ */ -/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */ -/* +#+#+#+#+#+ +#+ */ -/* Created: 2020/02/10 01:11:27 by cacharle #+# #+# */ -/* Updated: 2020/09/27 10:25:56 by charles ### ########.fr */ -/* */ -/* ************************************************************************** */ - -#include "philo_one.h" - -void *routine_philo(t_routine_arg *arg) -{ - pthread_t thread_death; - - if (!arg->conf->all_alive) - return (NULL); - arg->philo->time_last_eat = h_time_now(); - if (pthread_create(&thread_death, NULL, (void *(*)(void*))routine_death, arg) != 0) - return (NULL); - io_think(arg); - while (arg->conf->all_alive) - { - pthread_mutex_lock(arg->fork_left); - pthread_mutex_lock(arg->fork_right); - arg->philo->time_last_eat = h_time_now(); - io_eat(arg); - pthread_mutex_unlock(arg->fork_right); - pthread_mutex_unlock(arg->fork_left); - io_sleep(arg); - io_think(arg); - } - pthread_join(thread_death, NULL); - return (NULL); -} - -void *routine_death(t_routine_arg *arg) -{ - t_time current; - - current = h_time_now(); - while (arg->conf->all_alive && - current - arg->philo->time_last_eat < arg->conf->timeout_death) - current = h_time_now(); - if (!arg->conf->all_alive) - return (NULL); - pthread_mutex_lock(&arg->conf->mutex_all_alive); - io_die(arg); - arg->conf->all_alive = false; - pthread_mutex_unlock(&arg->conf->mutex_all_alive); - return (NULL); -} |
