繁体   English   中英

C-当调用sigqueue时,Valgrind报告“ Syscall参数指向未初始化的字节”

[英]C - Valgrind reporting “Syscall param points to uninitialised byte” when sigqueue call

得到了一个程序,其中子进程需要向父亲发送一些信号。 然而,瓦尔格朗德在电话会议上大喊大叫。 现在已经阅读了一段时间,但我找不到答案。

这是子进程的作用:

void cajero(int id){
    FILE *fp, *fp_caja;
    char filename[MAXBUFF], filename_caja[MAXBUFF], price[8];
    float p;
    union sigval val;
    bool booleano;

    ...

    val.sival_int = id;

    while(fgets(price, sizeof(price), fp)){
        p = atof(price);

        ...

        sigqueue(getppid(), SIGMONEY, val); //sigqueue Call

    }
    ...

    sigqueue(getppid(), SIGDONE, val); //sigqueue Call
    fclose(fp);
    exit(EXIT_SUCCESS);
}

这是一个孩子的valgrind报告(它在内部sigqueue中进行两次调用,在外部sigqueue中进行一次调用:

==14688== HEAP SUMMARY:
==14688==     in use at exit: 0 bytes in 0 blocks
==14688==   total heap usage: 48 allocs, 48 frees, 107,460 bytes allocated
==14688== 
==14688== All heap blocks were freed -- no leaks are possible
==14688== 
==14688== ERROR SUMMARY: 3 errors from 2 contexts (suppressed: 0 from 0)
==14688== 
==14688== 1 errors in context 1 of 2:
==14688== Syscall param rt_sigqueueinfo(uinfo) points to uninitialised byte(s)
==14688==    at 0x508DBE4: sigqueue (sigqueue.c:43)
==14688==    by 0x401B3A: cajero (ejercicio9.c:316)
==14688==    by 0x40130C: main (ejercicio9.c:181)
==14688==  Address 0xffefff67c is on thread 1's stack
==14688==  in frame #0, created by sigqueue (sigqueue.c:30)
==14688==  Uninitialised value was created by a stack allocation
==14688==    at 0x4018D7: cajero (ejercicio9.c:284)
==14688== 
==14688== 
==14688== 2 errors in context 2 of 2:
==14688== Syscall param rt_sigqueueinfo(uinfo) points to uninitialised byte(s)
==14688==    at 0x508DBE4: sigqueue (sigqueue.c:43)
==14688==    by 0x401AC1: cajero (ejercicio9.c:311)
==14688==    by 0x40130C: main (ejercicio9.c:181)
==14688==  Address 0xffefff67c is on thread 1's stack
==14688==  in frame #0, created by sigqueue (sigqueue.c:30)
==14688==  Uninitialised value was created by a stack allocation
==14688==    at 0x4018D7: cajero (ejercicio9.c:284)
==14688== 
==14688== ERROR SUMMARY: 3 errors from 2 contexts (suppressed: 0 from 0)

提前致谢。 我现在快死了。

编辑:SIGMONEY和SIGDONE分别是SIGRTMIN和SIGRTMIN + 1。

您没有初始化“ val”联合。 只需更改声明:

union sigval val = {0};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM