[질문] relocation error (다른 버전일때)

ylmoon의 이미지

안녕하세요..

리눅스는 아니지만.. 올려도 될지 모르겠네요..

선오에스 5.6(솔라리스 2.6)환경에서 만든 실행파일을 ..선오에스5.5.1(솔라리스 2.5.1)에서 실행시켰을 때 relocation error가 나옵니다..

실행시켰을 때 다음과 같은 메시지가 나오고 프로그램이 죽습니다.

------------- 다음 -------------------------

ld.so.1: 파일경로/실행파일명: fatal: relocation error: file 파일경로/실행파일명: symbol vsnprintf: referenced symbol not found Killed

제 생각으로(나름대로 공부해보니..) 공유라이브러리 링크 문제 인거 같습니다.

ldd를 해보니깐 다음과 같이 나오내요..
------------- 다음 -------------------------
libCrun.so.1 => /usr/lib/libCrun.so.1
libm.so.1 => /usr/lib/libm.so.1
libw.so.1 => /usr/lib/libw.so.1
libc.so.1 => /usr/lib/libc.so.1
libc.so.1 (SUNW_1.1) => (version not found)
libc.so.1 (SUNWprivate_1.1) => (version not found)
libdl.so.1 => /usr/lib/libdl.so.1

어떤 현상인거구.. 어떻게 처리를 해야할지 잘 모르겠습니다..

좋은 답변 부탁드립니다.

그럼.. 좋은하루되세여.

체스맨의 이미지

vsnprintf 가 표준이긴 하지만 비교적 근래에 만들어진 함수라서
운영체제나 컴파일러마다 C 표준 라이브러리에 포함되지 않은 경우도
있습니다. 그러니까 직접 컴파일, 링크한 경우 unresolved symbol
과 같은 오류로 여겨지네요.

라이브러리를 업데이트 하시거나, vsnprintf 를 따로 만들어서 없는 경우
직접 만든 걸 호출하도록 해야 될 것 같습니다.

Orion Project : http://orionids.org

ylmoon의 이미지

5.6에서 컴파일한 다른 응용프로그램(A 프로그램이라 할 경우)의 경우 실행이 되거덩여..

물른 A프로그램에서도 vsprintf를 사용하였습니다.

혹시, 컴파일 옵션의 차이가 아닌가 해서 makefile를 찾아봤는데..

A프로그램의 옵션은 -compat=4 -g -c 과 compat=4 -g -o 를 사용했고,

안돼는 요 프로그램은 -xF -g -o 과 -w -g -c -compat=4를 사용했습니다.

그리고 하나더, 지금 확인해보니깐, 잘 되는 듯한 A프로그램의 ldd 결과가 이렇내요.

libsocket.so.1 => /usr/lib/libsocket.so.1
libsocket.so.1 (SISCD_2.3) => (version not found)
libnsl.so.1 => /usr/lib/libnsl.so.1
libnsl.so.1 (SISCD_2.3) => (version not found)
libposix4.so.1 => /usr/lib/libposix4.so.1
libposix4.so.1 (SUNW_0.7) => (version not found)
libC.so.5 => /usr/lib/libC.so.5
libm.so.1 => /usr/lib/libm.so.1
libw.so.1 => /usr/lib/libw.so.1
libc.so.1 => /usr/lib/libc.so.1
libc.so.1 (SUNW_0.7) => (version not found)
libc.so.1 (SUNWprivate_1.1) => (version not found)
libdl.so.1 => /usr/lib/libdl.so.1
libintl.so.1 => /usr/lib/libintl.so.1
libmp.so.1 => /usr/lib/libmp.so.1

이것도 마찬가지로 version not found가 나오내여...

음... 참. 그리고 라이브러리의 업데이트를 어떻게 합니까..
(혹시나 해서 libc.so.1를 5.6거로 카피해서 해봤썼는데.. 안돼더라구여..)

그럼..좋은 의견 부탁드립니다..

체스맨의 이미지

ylmoon wrote:

물른 A프로그램에서도 vsprintf를 사용하였습니다.

vsprintf 인가요, vsnprintf 인가요?
처음 쓰신 글은 vsnprintf 가 찾아지지 않았다고 돼 있는데요.

Orion Project : http://orionids.org

ylmoon의 이미지

소스상에는 vsnprintf 이게 아니라 vsprintf만을 사용하였습니다.

그런데도 relocation error 관련된 symbol은 vsnprintf 이걸루 나옵니다.

혹시...

답변시 더 자세한 사항이 필요하시다면 얘기해주세여..

제가 초보자라서여..

그럼... 좋은 의견 부탁드립니다...

체스맨의 이미지

일단, 솔라리스 2.6에서 링크한 실행파일은 vsnprintf 가 resolved
된 것으로 보여집니다.

우선 솔라리스 2.6 헤더에서 vsprintf 선언부를 찾아보시구요,
vsprintf 가 #define 되어서 실제로 vsnprintf 를 호출하고 있지 않나
예상되네요.

제겐 참조할 솔라리스 시스템이 없으니, 우선 솔라리스 2.6과 2.5.1 에서
말씀드린 사항을 살펴보세요.

첨언:
솔라리스 2.6에서 preprocessor 를 돌려서 vsprintf 가 실제로
무엇이 호출되는 지 보시는 게 빠르겠습니다.

Orion Project : http://orionids.org

ylmoon의 이미지

2.6에서..

[2.6] grep vsprintf *
stdio.h:extern int vsprintf(char *, const char *, __va_list);
stdio.h:extern int vsprintf();

[2.6] grep vsnprintf *
stdio.h:extern int vsnprintf(char *, size_t, const char *, __va_list);

2.5.1에서..

2.5.1> grep vsprintf *
stdio.h:extern int vsprintf(char *, const char *, __va_list);
stdio.h:extern int vsprintf();

2.5.1> grep vsnprintf *
stdio.h:extern int vsnprintf(char *, size_t, const char *, __va_list);

음.. 두 개다 똑같은 구조(??)인듯 합니다..

근데, 낼 아침에 2.6으로 다시 깐다고 합니다. ㅠ..ㅠ

다른 문제때문에요..

그래도, 궁금합니다.

제 생각엔, 다시 깔아두 이런 문제가 제기될 가능성이 있습니다..

왜냐면, 2.6으로 깔지만.

다른 응용프로그램에 의해(??) 그 프로그램이 필요한 몇개의 라이브러리가 2.5.1버전으로 재설치될 가능성이 있기 때문입니다.

좀 복잡하내요..

그럼.. 좋은 의견 부탁드립니다...

체스맨의 이미지

세 가지 확인 바랍니다.

(1) 솔라리스 2.6에서 소스에 c preprocessor 를 적용해서 vsprintf 가 실제로 호출 된 것이 맞는 지 확인.

(2) 처음 질문에서 ldd 는 솔라리스 2.5.1에서 한 결과 인 것 같은데, 솔라리스 2.6에서 ldd 한 결과

(3) 솔라리스 2.5.1 에서 vsnprintf 가 잘 작동 하는 지 테스트

이 정도 해서 단서가 안찾아지면 저는 모르겠습니다.
특히 (3)이 잘 된다면 실제로 상황을 보지 않고서는 잘 모를 가능성이
높습니다. -_-;;;

아, 한가지 더요...
어셈블리 코드 생성이 가능하다면 (1) 대신 어셈블리 코드에서
vsprintf 호출 되는 부분을 보여주시는 것도 좋겠습니다.

Orion Project : http://orionids.org

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.