/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* event.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: cacharle +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2020/02/14 21:37:50 by cacharle #+# #+# */ /* Updated: 2021/01/01 16:29:31 by charles ### ########.fr */ /* */ /* ************************************************************************** */ #include "philo_three.h" void event_take_fork(t_philo *philo) { sem_wait(philo->forks); sem_wait(philo->sem_stdout); philo_put(philo->id, EVENT_FORK); sem_post(philo->sem_stdout); } void event_eat(t_philo *philo) { sem_wait(philo->sem_stdout); philo_put(philo->id, EVENT_EAT); sem_post(philo->sem_stdout); usleep(philo->conf->timeout_eat * 1000); } void event_think(t_philo *philo) { sem_wait(philo->sem_stdout); philo_put(philo->id, EVENT_THINK); sem_post(philo->sem_stdout); } void event_sleep(t_philo *philo) { sem_wait(philo->sem_stdout); philo_put(philo->id, EVENT_SLEEP); sem_post(philo->sem_stdout); sem_post(philo->forks); sem_post(philo->forks); usleep(philo->conf->timeout_sleep * 1000); } void event_die(t_philo *philo) { long int i; sem_wait(philo->sem_stdout); philo_put(philo->id, EVENT_DIE); if (philo->conf->meal_num == -1) sem_post(philo->sem_finish); else { i = -1; while (++i < philo->conf->philo_num) sem_post(philo->sem_finish); } }