]> git.llucax.com Git - z.facultad/75.74/practicos.git/blobdiff - practicas/practica2/P02e1201.cpp
Bugfix.
[z.facultad/75.74/practicos.git] / practicas / practica2 / P02e1201.cpp
index ea486f7d793ff07ec37e28b127e3e568cdf7be3a..5600630801b3e312d10f96affc2c7ba3787f2a19 100644 (file)
@@ -62,29 +62,31 @@ int main(int argc, char *argv[])
     int proc = atoi(argv[1]);
 
     // Shared memory
-    int shm_id = shmget(SHM_KEY, sizeof(Molinete), IPC_CREAT | 0666);
-    if (shm_id == -1)
+    int shm_id;
+    do
     {
-        cerr << "Error al crea/obtener shared memory.\n";
-        return 2;
+        shm_id = shmget(SHM_KEY, sizeof(Molinete),
+            (proc ? 0 : IPC_CREAT) | 0666); // crea solo si es el proceso 0
     }
+    while (proc != 0 && shm_id == -1);
     Molinete* molinete = (Molinete*) shmat(shm_id, NULL, 0);
     if (molinete == (Molinete*) -1)
     {
         cerr << "Error al attachear shared memory.\n";
         return 3;
     }
-    cout << "Shared memory id = " << shm_id << "\n";
 
     // Semaforo
-    int sem_id = semget(SEM_KEY, 1, 0666 | IPC_CREAT);
-    if (sem_id == -1)
+    int sem_id;
+    do
     {
-        cerr << "Error al crea/obtener semaforo.\n";
-        return 4;
+        sem_id = semget(SEM_KEY, 1,
+            (proc ? 0 : IPC_CREAT) | 0666); // crea solo si es el proceso 0
     }
+    while (proc != 0 && sem_id == -1);
+
     // Si es el primero, inicializo
-    if (!proc)
+    if (proc == 0)
     {
         *molinete = 0;
         if (semctl(sem_id, 0, SETVAL, 1) < 0) // pongo 1 en el sem
@@ -92,17 +94,12 @@ int main(int argc, char *argv[])
             cerr << "No se pudo inicializar semaforo.\n";
             return 5;
         }
-        cout << "Semaforo inicializado id = " << sem_id << "\n";
-    }
-    else // Si soy otro espero un poco por las dudas para que corra el 1ro
-    {
-        usleep(1000);
     }
 
     srand(getpid());
 
     // Maxima cantidad de iteraciones (puede venir por parametro)
-    int max_iter = 100;
+    int max_iter = 10;
     if (argc > 2)
         max_iter = atoi(argv[2]);