aboutsummaryrefslogtreecommitdiff
path: root/philo_one/routine.c
diff options
context:
space:
mode:
authorCharles Cabergs <me@cacharle.xyz>2020-09-29 14:56:27 +0200
committerCharles Cabergs <me@cacharle.xyz>2020-09-29 14:56:27 +0200
commit6bfcd3c6f921e7717e61167b291bb27bd3f66386 (patch)
tree67b2aa4b8a036cb355f90b1f94438b7eb46441f1 /philo_one/routine.c
parentac4278405b7a258010219499cccc0dd978201caf (diff)
downloadphilosophers-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.c55
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);
-}