Miaouuuu
This commit is contained in:
parent
9285a20e35
commit
07dae4049c
3 changed files with 17 additions and 7 deletions
|
|
@ -6,11 +6,12 @@
|
||||||
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/06/10 00:23:09 by rparodi #+# #+# */
|
/* Created: 2024/06/10 00:23:09 by rparodi #+# #+# */
|
||||||
/* Updated: 2024/07/24 14:16:00 by rparodi ### ########.fr */
|
/* Updated: 2024/07/24 16:09:21 by rparodi ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "../includes/philo.h"
|
#include "../includes/philo.h"
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
void ft_logs(t_str msg, t_philo *philo)
|
void ft_logs(t_str msg, t_philo *philo)
|
||||||
{
|
{
|
||||||
|
|
@ -45,7 +46,7 @@ t_error ft_start_eating(t_philo *philo)
|
||||||
usleep(50);
|
usleep(50);
|
||||||
return (NO_ERROR);
|
return (NO_ERROR);
|
||||||
}
|
}
|
||||||
if (philo->id % 2 == 0)
|
if (philo->id % 2 == 1)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(philo->r_fork);
|
pthread_mutex_lock(philo->r_fork);
|
||||||
ft_logs("has taken a fork\n", philo);
|
ft_logs("has taken a fork\n", philo);
|
||||||
|
|
@ -56,8 +57,6 @@ t_error ft_start_eating(t_philo *philo)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(philo->l_fork);
|
pthread_mutex_lock(philo->l_fork);
|
||||||
ft_logs("has taken a fork\n", philo);
|
ft_logs("has taken a fork\n", philo);
|
||||||
if (philo->nb_philo == 1)
|
|
||||||
return ((void)pthread_mutex_unlock(philo->l_fork), NO_ERROR);
|
|
||||||
pthread_mutex_lock(philo->r_fork);
|
pthread_mutex_lock(philo->r_fork);
|
||||||
ft_logs("has taken a fork\n", philo);
|
ft_logs("has taken a fork\n", philo);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/06/04 11:30:25 by rparodi #+# #+# */
|
/* Created: 2024/06/04 11:30:25 by rparodi #+# #+# */
|
||||||
/* Updated: 2024/07/24 14:07:27 by rparodi ### ########.fr */
|
/* Updated: 2024/07/24 16:15:16 by rparodi ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -15,12 +15,18 @@
|
||||||
void *ft_routine(void *ptr)
|
void *ft_routine(void *ptr)
|
||||||
{
|
{
|
||||||
t_philo *philo;
|
t_philo *philo;
|
||||||
|
t_usize nb_group;
|
||||||
|
|
||||||
|
nb_group = 2;
|
||||||
philo = (t_philo *) ptr;
|
philo = (t_philo *) ptr;
|
||||||
if (philo == NULL)
|
if (philo == NULL)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
if (philo->nb_philo % 2)
|
||||||
|
nb_group = 3;
|
||||||
while (philo->start_time > ft_time())
|
while (philo->start_time > ft_time())
|
||||||
usleep(500);
|
usleep(500);
|
||||||
|
if (philo->id % nb_group)
|
||||||
|
usleep(philo->t_eat * 800);
|
||||||
while (!dead_loop(philo))
|
while (!dead_loop(philo))
|
||||||
{
|
{
|
||||||
if (dead_loop(philo) == false)
|
if (dead_loop(philo) == false)
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/06/04 11:42:37 by rparodi #+# #+# */
|
/* Created: 2024/06/04 11:42:37 by rparodi #+# #+# */
|
||||||
/* Updated: 2024/07/24 14:23:03 by rparodi ### ########.fr */
|
/* Updated: 2024/07/24 16:05:12 by rparodi ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
@ -80,11 +80,16 @@ t_error ft_init_philo(t_i32 argc, t_str *argv, t_program *prog, t_mutex *forks)
|
||||||
prog->philos[i].meal_lock = &prog->meal_lock;
|
prog->philos[i].meal_lock = &prog->meal_lock;
|
||||||
prog->philos[i].dead_check = false;
|
prog->philos[i].dead_check = false;
|
||||||
prog->philos[i].check_eating_count = &prog->check_eating_count;
|
prog->philos[i].check_eating_count = &prog->check_eating_count;
|
||||||
prog->philos[i].l_fork = &forks[i];
|
|
||||||
if (i == 0)
|
if (i == 0)
|
||||||
prog->philos[i].r_fork = &forks[prog->philos[i].nb_philo - 1];
|
prog->philos[i].r_fork = &forks[prog->philos[i].nb_philo - 1];
|
||||||
else
|
else
|
||||||
prog->philos[i].r_fork = &forks[i - 1];
|
prog->philos[i].r_fork = &forks[i - 1];
|
||||||
|
if (prog->philos[0].nb_philo % 2 == 1 && i == prog->philos[0].nb_philo)
|
||||||
|
{
|
||||||
|
prog->philos[i].l_fork = &forks[0];
|
||||||
|
prog->philos[i].r_fork = &forks[i];
|
||||||
|
}
|
||||||
|
prog->philos[i].l_fork = &forks[i];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
return (ft_parsing_args(argc, argv, prog->philos));
|
return (ft_parsing_args(argc, argv, prog->philos));
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue