gdb에서 bt 사용시에 ??가 나오는데요...
글쓴이: dorado2 / 작성시간: 금, 2005/06/03 - 4:13오후
현재, linux 상에서 ns라는 시뮬레이터로 작업중인데요.
시뮬레이션을 돌리면 도중에 세그멘테이션 에러가 나옵니다.
그런데, 제가 짜거나 추가한 부분은 아직 없고, 제공되는 코드를 돌리는데 저 문제가 나서, 어디쯤에서 문제가 나는지 알 수 없네요.
모든 부분에 다 printf 를 해줄수도 없는 노릇이고...
gdb 상에서 run 해주면
#0 0x4019ecd3 in strlen () from /lib/libc.so.6
에러가 나구요. bt 명령을 해보면 아래처럼 나옵니다.
그런데 마지막에 ?? 라고 나와서, 어디 문제인지 알 수가 없네요.
#0 0x4019ecd3 in strlen () from /lib/libc.so.6 #1 0x40175975 in vfprintf () from /lib/libc.so.6 #2 0x4018d5cb in vsprintf () from /lib/libc.so.6 #3 0x08175d2d in rcsid () #4 0xbfffcf10 in ?? () #5 0x083eb15c in ?? ()
gdb 매뉴얼 사이트를 봐도...
(http://database.sarang.net/study/gdb/html/gdb-man.html)
해당 메모리 주소가 어떤 함수 내에 위치하는지 보는 명령어를 못 찾겠네요.
적당한 방법이 없을지요? 도움을 부탁드립니다.
Forums:
[quote]#0 0x4019ecd3 in strlen () from
0번이라고 되어있는 스택이 가장 마지막에 실행된 스택아닌가요?
#5번이 가장 먼저 호출된거구 그 함수 안에서 #4번호출,
#4번에서 #3번 rcsid()를 호출 이런식으로 해서
가장 나중에 #0 strlen()이 호출되었다는 내용인거 같은데...
strlen에서 에러가 난다면... 뭐가문제일까? 버퍼에 쓰레기 값이 들어있어서 그 쓰레기값이 정상적인 주소로 알고 접근해서 발생하는게 아닐까 하는 생각이 드는데요...
결국 그렇다면 rcsid에 인자로 줄때부터 쓰레기 값이 들어있는 버퍼를 인자로 준게 아닌지 의심스럽네요.. 문제는 rcsid()가 어디에서 호출 되었느냐인데... ??로 나오는것을 볼때는 컴파일할때 -g옵션을 빼고 했나봅니다.
rcsid...
먼저 답변 주셔서 감사드립니다.
근데, rcsid 라는게, 함수는 아니구요, 소스 상에서 여러군데 cc 파일에 포함되어 있는건데요.
보면 그냥 static char 배열이거든요... 함수가 아니고... 그래서 이유를 더더욱 잘 모르겠고, 앞에서, strlen 에러나 vsprintf에서 from /lib/libc.so.6 이라고 되어있는건 크게 고려치 않아도 되나요?
저것도 결국 소스 내의 vsprintf나 strlen 때문 인 것 맞죠? 소스에서 사용한 라이브러리 내의 함수가 내부적으로 콜한 게 아니라?
흠, 더 찾아봐야겠네요. rcsid 가 변수인데 vsprintf를 콜할 일도 없을텐데...
-g 옵션 확실히 주셨나요?
-g 옵션 확실히 주셨나요?
----
jai guru deva om...
댓글 달기