Skip to main content
Sign in
Snippets Groups Projects
Select Git revision
  • af43cd033c64384c521a9cb1fb68660d7799435c
  • master default protected
  • android-7.1.2_r28_klist
  • oreo-mr1-iot-release
  • sdk-release
  • pie-cts-dev
  • pie-cts-release
  • pie-vts-release
  • nougat-iot-release
  • pie-gsi
  • pie-platform-release
  • pie-r2-release
  • pie-r2-s1-release
  • pie-release
  • pie-dev
  • oreo-m4-s4-release
  • o-mr1-iot-preview-8
  • oreo-m2-s2-release
  • oreo-m2-s1-release
  • oreo-m6-s2-release
  • oreo-m6-s3-release
  • android-o-mr1-iot-release-1.0.4
  • android-9.0.0_r8
  • android-9.0.0_r7
  • android-9.0.0_r6
  • android-9.0.0_r5
  • android-8.1.0_r46
  • android-8.1.0_r45
  • android-n-iot-release-smart-display-r2
  • android-vts-8.1_r5
  • android-cts-8.1_r8
  • android-cts-8.0_r12
  • android-cts-7.1_r20
  • android-cts-7.0_r24
  • android-cts-6.0_r31
  • android-o-mr1-iot-release-1.0.3
  • android-cts-9.0_r1
  • android-8.1.0_r43
  • android-8.1.0_r42
  • android-n-iot-release-smart-display
  • android-p-preview-5
41 results

cmp.c

Blame
  • signal.c 1.32 KiB
    #include "die.h"
    #include <signal.h>
    #include <sys/types.h>
    #include <sys/wait.h>
    #include <unistd.h>
    
    static void sigchldHandler(int sig);
    int i;
    
    int main() {
        struct sigaction handleSIGCHLD =
            {
            .sa_handler = sigchldHandler,
            .sa_flags   = SA_RESTART,
            };
        if( sigaction(SIGCHLD, &handleSIGCHLD, NULL) != 0 ) die("Could not set sigaction");
    
        //mask sigchld
        sigset_t newMask_Itr;
        sigset_t oldMask_Itr;
        sigemptyset(&newMask_Itr);
        sigaddset(&newMask_Itr, SIGCHLD);
        if (sigprocmask(SIG_BLOCK, &newMask_Itr, &oldMask_Itr) == -1) die("sigprocmask");
    
        //do critical stuff
    
        //alte signal mask wiederherstellen
        if (sigprocmask(SIG_SETMASK, &oldMask_Itr, NULL) == -1) die("sigprocmask");
    
        pid_t pid = fork();
        if(pid < 0) die("fork");
        if(pid == 0) {
            sleep(5);
            exit(EXIT_SUCCESS);
        }
    
        //passives warten
        i = 1;
        if (sigprocmask(SIG_BLOCK, &newMask_Itr, &oldMask_Itr) == -1) die("sigprocmask");
        while (i > 0) {
            sigsuspend(&oldMask_Itr);
        }
    }
    
    static void sigchldHandler(int sig) {
        // Collect zombie processes
        (void)sig; //unused param
        pid_t pid;
        int event;
        while ((pid = waitpid(-1, &event, WNOHANG)) > 0) {
            // collect all zombies (prevent zombies if signal got lost because of masking)
            i--;
        }
    }