콜스택이 깨진거 디버깅
개발중에 어떤부분에 Print문을 넣을경우는 Assert가 발생하지 않고 빼면 죽는경우가 있어
coredump를 했지만 콜스택이 ?? 이런식으로 깨져나옵니다.
그래서 어디서 찾아보니 아래와 같이 하여
(gdb) maint info sections .text
Exec file:
`/home/coner74/hj153.kim_Barcelona_EU_6900_Prj_int/Prd_Barcelona/B-BARBSPUSC/Build/BIN/exeDSP', file type elf32-littlearm.
0x00530320->0x0179c4a0 at 0x00528320: .text ALLOC LOAD READONLY CODE HAS_CONTENTS
위와 같이 나왔습니다.
0x00530320->0x0179c4a0 이 문제라고 하여
(gdb) define findsymbols
Type commands for definition of "findsymbols".
End with a line saying just "end".
>set $textbegin = $arg0
>set $textend = $arg1
>set $si = $arg2
>set $ei = $arg3
>while $si < $ei
>set $value = *(int*)$si
>if ($textbegin <= $value && $value <= $textend)
>printf "[0x%08x] ", $si
>info symbol $value
>end
>set $si = $si + sizeof(void*)
>end
>end
(gdb) findsymbols 0x00530320 0x0179c4a0 $esp-1024 $esp+1024
이렇게 실행을 했는데요~~~~
Argument to arithmetic operation not a number or boolean.
이렇게 나오고 안됩니다.
혹시 $esp-1024 $esp+1024 무엇인지 도움을 요청드립니다.
감사합니다.
본문에 대한 직접
본문에 대한 직접 대답은 아니고요,
콜스택이 깨졌다면, 로컬변수로 잡은 배열의 인덱스를 벗어난 곳에 무언가 썼을 확률이 큽니다.
printf 를 넣거나 넣지 않을때의 차이는.. 어떤 함수 호출로 인한 side effect로 오류상황이 무시되는 경우겠지요.
소스관점에서 다시 한번 디버깅 해보시기 바랍니다.
아. 콜스택이 ??로 나타나는 것은 디버깅 정보가 없고, strip을 해버려서 그럴 수 있습니다.
strip 안하게 막으시고, gcc -g 옵션으로 디버깅 정보도 넣으시길 바랍니다.
----
참고로,
$esp는 x86에서 스택 포인터에 해당합니다. $esp-1024, +1024는 스택 앞뒤 1024바이트에 해당하겠지요.
언제나 삽질 - http://tisphie.net/typo/
프로그래밍 언어 개발 - http://langdev.net
언제나 삽질 - http://tisphie.net/typo/
프로그래밍 언어 개발 - http://langdev.net
댓글 달기