首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用malloc/free时的__lll_lock_wait_private ()

使用malloc/free时的__lll_lock_wait_private ()
EN

Stack Overflow用户
提问于 2015-07-26 14:14:47
回答 1查看 5K关注 0票数 0

我有一个用户级别的线程库,我更改了一个基准程序,使用mythread而不是pthread,但它总是卡在代码中有malloc或free函数的地方。

这是gdb的输出:

代码语言:javascript
复制
^C
Program received signal SIGINT, Interrupt.
__lll_lock_wait_private ()
    at ../sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:95
95  ../sysdeps/unix/sysv/linux/x86_64/lowlevellock.S: No such file or directory.
(gdb) where
#0  __lll_lock_wait_private ()
    at ../sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:95
#1  0x00007ffff7569bb3 in _int_free (av=0x7ffff78adc00 <main_arena>, 
    p=0x6f1f40, have_lock=0) at malloc.c:3929
#2  0x00007ffff756d89c in __GI___libc_free (mem=<optimized out>)
    at malloc.c:2950
#3  0x000000000040812d in mbuffer_free (m=m@entry=0x6a7660) at mbuffer.c:209
#4  0x00000000004038a8 in write_chunk_to_file (chunk=0x6a7610, 
    fd=<optimized out>) at encoder.c:279
#5  Reorder (targs=0x7fffffffab60, 
    targs@entry=<error reading variable: value has been optimized out>)
    at encoder.c:1292
#6  0x000000000040b069 in wrapper_function (func=<optimized out>, 
    arg=<optimized out>) at gtthread.c:75
#7  0x00007ffff7532620 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#8  0x0000000000000000 in ?? ()
(gdb) 

下面是一些代码

代码语言:javascript
复制
mbuffer.c
208    if(ref==0) {
209        pausee();
210        free(m->mcb->ptr);
211        resume();
212        m->mcb->ptr=NULL;
213        free(m->mcb);
214        m->mcb=NULL;
215    }

暂停和恢复功能

代码语言:javascript
复制
void pausee(){
    //printf("pauseeing\n");
    sigemptyset(&mask);
    sigaddset(&mask, SIGPROF);   // block SIGPROF...
    if (sigprocmask(SIG_BLOCK, &mask, &orig_mask) < 0) {
        perror ("sigprocmask");
        exit(1);
    }
}
void resume(){
    //printf("restarting\n");
    sigemptyset(&mask);
    sigaddset(&mask, SIGPROF);   // unblock SIGPROF...
    if (sigprocmask(SIG_SETMASK, &orig_mask, NULL) < 0) {
        perror ("sigprocmask");
        exit(1);
    }
}

我不确定这是否与我的问题有关,但是对于线程的调度,我使用了SIGPROF信号和一个处理函数。我尝试在每个malloc/free函数之前阻塞SIGPROF,但没有效果。

我没有任何并发线程,一次只有一个线程运行。

任何帮助或想法都将非常感谢。

EN

回答 1

Stack Overflow用户

发布于 2015-07-26 16:32:27

作为您的代码mbuffer.c,没有任何错误。我建议您测试一下mbuffer.c,除了您的猜测。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31634255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档