초짜 프로그래머의 디버깅 하는 방법..

jesusace의 이미지

안녕하세요~

저는 대학교를 놀고먹자 하고 이제 막 회사에 취업한 프로그래머 입니다.
말은 프로그래머라는 이름을 달고 있지만 아무것도 모르는 말그대로의 초짜입니다.

일단 C/C++ 기본은 깊숙히는 몰라도 어느정도 알고 있는 상황입니다.
후아~ 들어오자마자 프로젝트에 투입되니 난감해서 죽겠습니다.

임베디드 장비에서 돌아가는 프로그램을 수정하는 일인데
소스 분석하는데만 한달 조금 넘었구요. 지금도 분석중입니다. ^^;

문제는 디버깅입니다.
kdevelop에서 코딩하고 컴파일은 합니다.
컴파일 에러는 메세지 보고 수정하겠는데 컴파일이 완료된 후
실행되는 과정에서의 에러는 어떻게 처리해야 할지 난감하네요.

프로그램은 C++가 대부분이고 C로 약간 혼합된 형태로 짜여져있구요.
실행은 ARM 기반의 임베디드 보드에서 합니다.

Segmentation Fault가 발생했는데 어느부분에서 어느 메모리를 접근하다가 Fault가 났는지 알고싶은데 디버깅 방법을 전혀 모르니 난감하네요 ㅠ.ㅜ

일단 하나하나 printf를 삽입해야할까요? ㅠ.ㅜ

이야기가 너무 두서없어서 정리가 안되겠네요.
일단

1. 임베디드 보드에서 실행되는 파일의 디버깅 방법
2. 무작정 printf만 사용하면 되나?

입니다.

선배 프로그래머님들의 많은 도움 부탁드립니다.
감사합니다.

espereto의 이미지

printf로라도 잘만 잡으면 ... ㅡ.ㅡ;;

컴파일러를 gcc를 쓰고 있고, 보드에 gdb가 동작이 가능하다면, gdb를 네트웍으로나 혹은 시리얼포트 같은 것으로 PC와 연동시켜서 디버깅 하는 방법도 있는 걸로 압니다.

전, 리눅스나 유닉스에서 디버깅 할 때, gdb가 없는 환경이 많아 printf 줄기차게 써서(혹은 파일로 로깅하는 함수를 만들어서), 대부분의 segmentation fault를 잡은 기억이 있습니다... 쉽지만은 않았습니다만...

espereto의 이미지

혹은 선임자 분들께 여쭤보세요. 디버깅은 어떻게 하냐고......

aswip의 이미지

Segmentation fault 같은 경우,

배열, 나눗셈 연산, 잘못된 포인터 연산, 지역 포인터의 반환,
잘못된 메모리 해제, (free, delete) 등에서 발생하며,

저 같은 경우,

문제가 될만한 부분을 각 단위별로 try ~ catch 로 묶어 놓고
테스트를 진행합니다.

예)

try
{

}
catch ( ... )
{
printf("Something wrong [%d]\n", __LINE__ );
getchar();
}

만약, 위와 같이 해서 버그가 발견되지 않을 경우, 좀 더
Detail 하게 try ~ catch () 구문을 추가하고 있습니다.

그래도 안될경우, 각 함수 별로 단위 테스트를 진행하며,
BoundChecker와 같은 상용툴을 사용하여, 메모리 Leak
체크를 점검합니다.

만약, 그래도 안될 경우... 로직을 의심하며,
연필과 종이를 꺼내놓고, 흐름도를 다시 그려가며
로직을 검증합니다. ^^ :D

- 인생은 스스로 -

cinsk의 이미지

embedded board에 network device가 있고 메모리가 충분하다면, NFS를 설치하고, arm gdb를 host에 설치, embedded board에서 NFS mount한 다음, gdb로 debugging하면 됩니다.

잘 알려진 CPU라면 remote gdb를 쓰는 것도 좋은 방법입니다.

익명 사용자의 이미지

gdb만으로도 잘 쓰시는 분들도 계시지만..
저는 아무래도 GUI에 익숙하다보니..

ddd를 쓰게 되더군요. ^^;

ddd 기능이야 뭐 충분하죠. ㅎㅎㅎ

불량도ㅐㅈㅣ의 이미지

gdb도 꽤 쓸만하데요. 문제는 적응이지만...ㅋㅋ

아~~ 이 끝이 안 보이는 임베디드..쩝..ㅡ.ㅡ

문근영 너무 귀여워~~

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.