malloc 하다가 죽네요.. ㅠㅠ
malloc 하다가 죽네요.. ㅠㅠ
main에서 thread를 8개 만들어서 돌리고 있습니다.
main thread에서는 Mbyte단위로 malloc을 해도 잘 되는데, thread에서는 1K이상 할당 하려니 프로그램 자체가 죽어버리네요..
(gdb) where
#0 0x00000034464794e9 in _int_malloc () from /lib64/libc.so.6
#1 0x000000344647a9a1 in malloc () from /lib64/libc.so.6
#2 0x000000000040cce7 in ikev2_recv_exch_sa_init (pSession=0x7faa4c0008e0, data=0x7faa5bf40e20 "\331Y\024\004\274\212\211\276", data_len=988) at sess_ike.c:1091
#3 0x0000000000411676 in __session_ikev2_proc (pMsg=0x7faa5bf40de8, is_flag=1) at sess_ike.c:3199
#4 0x000000000041181f in session_ikev2_proc (pMsg=0x7faa5bf40de8, is_flag=1) at sess_ike.c:3253
#5 0x0000000000404921 in SESS_MANAGE_TH (args=0x1) at thrs.c:70
#6 0x0000003446c079d1 in start_thread () from /lib64/libpthread.so.0
#7 0x00000034464e8b5d in clone () from /lib64/libc.so.6
왜 죽을까요? ㅜㅜ
thread heap size 같은거라도 조사 해봐야 하나요?
충돌의 가능성은 없을까요?
예를들어 두 스레드에서 서로 동적할당을 하려 하는데,
찾아낸 비어있는 공간이 두 스레드가 겹치는거죠.
이런 충돌가능성은 고려해보셨나요?
malloc()는 thread safe 합니다. 또한
malloc()는 thread safe 합니다. 또한 별개 문제입니다만, 내부적으로 전역 lock같은 걸로 thread safe를 보장하기 때문에 reentrant하지는 않다고 합니다.
다른 가능성을 살펴보기에 앞서, main thread의 malloc을 다른 thread로 옮기면서 버그가 발생했을 가능성이 높습니다. 다시 코드를 면밀히 검토해 보시기 바랍니다.
그렇군요
단순히 충돌될 일이 없는것이 아니라
내부에서 직접 보장해주는군요.
덕분에 좋은 정보 배워갑니다.
valgrind
십중팔구 프로그램을 잘못 짠 경우입니다. valgrind로 돌려보시면 문제의 원인을 발견할 확률이 매우 높습니다.
댓글 달기