Annotation of rpl/src/daemon.c, revision 1.66

1.1       bertrand    1: /*
                      2: ================================================================================
1.66    ! bertrand    3:   RPL/2 (R) version 4.1.25
        !             4:   Copyright (C) 1989-2016 Dr. BERTRAND Joël
1.1       bertrand    5: 
                      6:   This file is part of RPL/2.
                      7: 
                      8:   RPL/2 is free software; you can redistribute it and/or modify it
                      9:   under the terms of the CeCILL V2 License as published by the french
                     10:   CEA, CNRS and INRIA.
                     11:  
                     12:   RPL/2 is distributed in the hope that it will be useful, but WITHOUT
                     13:   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
                     14:   FITNESS FOR A PARTICULAR PURPOSE.  See the CeCILL V2 License
                     15:   for more details.
                     16:  
                     17:   You should have received a copy of the CeCILL License
                     18:   along with RPL/2. If not, write to info@cecill.info.
                     19: ================================================================================
                     20: */
                     21: 
                     22: 
1.12      bertrand   23: #include "rpl-conv.h"
1.1       bertrand   24: 
                     25: 
                     26: /*
                     27: ================================================================================
                     28:   Fonction de bascule vers un mode de fonctionnement de daemon
                     29: ================================================================================
                     30:   Entrées : pointeur sur une structure
                     31: --------------------------------------------------------------------------------
                     32:   Sorties :
                     33: --------------------------------------------------------------------------------
                     34:   Effets de bord : néant
                     35: ================================================================================
                     36: */
                     37: 
                     38: void
                     39: lancement_daemon(struct_processus *s_etat_processus)
                     40: {
                     41:    pid_t               pid;
                     42:    pid_t               sid;
                     43: 
                     44:    /*
                     45:     * Si le processus en cours est déjà un daemon (dont le père est init),
                     46:     * on ne fait rien.
                     47:     */
                     48: 
1.7       bertrand   49:    if (getppid() == (pid_t) 1)
1.1       bertrand   50:    {
                     51:        return;
                     52:    }
                     53: 
                     54:    /*
                     55:     * Premier fork pour lancer un setsid(). Le fork() n'est pas protégé par
                     56:     * un mutex car on ne peut transformer en daemon que le processus de
                     57:     * lancement du RPL/2.
                     58:     */
                     59: 
                     60:    fflush(NULL);
1.15      bertrand   61: 
1.1       bertrand   62:    pid = fork();
                     63: 
                     64:    if (pid < 0)
                     65:    {
                     66:        (*s_etat_processus).erreur_systeme = d_es_processus;
                     67:        return;
                     68:    }
                     69: 
                     70:    if (pid > 0)
                     71:    {
                     72:        // Fin du processus père.
1.34      bertrand   73: 
                     74:        // À noter : dans le cas où l'on utilise l'émulation des
                     75:        // sémaphores anonymes POSIX ou la sémantique SysV, il faut
                     76:        // détruire les sémaphores et les recréer dans le processus fils.
                     77: 
1.56      bertrand   78: #      ifndef SEMAPHORES_NOMMES
1.34      bertrand   79:        sem_post(&((*s_etat_processus).semaphore_fork));
                     80:        sem_destroy(&((*s_etat_processus).semaphore_fork));
                     81: #      else
                     82:        sem_post((*s_etat_processus).semaphore_fork);
                     83:        sem_destroy3((*s_etat_processus).semaphore_fork, getpid(),
                     84:                pthread_self(), SEM_FORK);
                     85: #      endif
                     86: 
1.31      bertrand   87:        destruction_queue_signaux(s_etat_processus);
1.1       bertrand   88:        _exit(EXIT_SUCCESS);
                     89:    }
                     90: 
                     91:    sid = setsid();
                     92: 
                     93:    if (sid < 0)
                     94:    {
                     95:        (*s_etat_processus).erreur_systeme = d_es_processus;
                     96:        return;
                     97:    }
                     98: 
                     99:    if ((chdir((*s_etat_processus).chemin_fichiers_temporaires)) < 0)
                    100:    {
                    101:        (*s_etat_processus).erreur_systeme = d_es_processus;
                    102:        return;
                    103:    }
                    104: 
1.57      bertrand  105: #  pragma GCC diagnostic push
                    106: #  pragma GCC diagnostic ignored "-Wunused-result"
1.37      bertrand  107:    freopen("/dev/null", "r", stdin);
                    108:    freopen("/dev/null", "w", stdout);
                    109:    freopen("/dev/null", "w", stderr);
1.57      bertrand  110: #  pragma GCC diagnostic pop
1.1       bertrand  111: 
                    112:    /*
                    113:     * Second fork pour ne plus être un session leader.
                    114:     */
                    115: 
                    116:    fflush(NULL);
                    117:    pid = fork();
                    118: 
                    119:    if (pid < 0)
                    120:    {
                    121:        (*s_etat_processus).erreur_systeme = d_es_processus;
                    122:        return;
                    123:    }
                    124: 
                    125:    if (pid > 0)
                    126:    {
                    127:        // Fin du processus père.
                    128:        _exit(EXIT_SUCCESS);
                    129:    }
                    130: 
                    131:    (*s_etat_processus).pid_processus_pere = getpid();
1.31      bertrand  132:    creation_queue_signaux(s_etat_processus);
1.1       bertrand  133:    modification_pid_thread_pere(s_etat_processus);
                    134: 
                    135:    return;
                    136: }
                    137: 
                    138: // vim: ts=4

CVSweb interface <joel.bertrand@systella.fr>