[질문] relocation error (다른 버전일때)
안녕하세요..
리눅스는 아니지만.. 올려도 될지 모르겠네요..
선오에스 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
어떤 현상인거구.. 어떻게 처리를 해야할지 잘 모르겠습니다..
좋은 답변 부탁드립니다.
그럼.. 좋은하루되세여.
Re: [질문] relocation error (다른 버전일때)
vsnprintf 가 표준이긴 하지만 비교적 근래에 만들어진 함수라서
운영체제나 컴파일러마다 C 표준 라이브러리에 포함되지 않은 경우도
있습니다. 그러니까 직접 컴파일, 링크한 경우 unresolved symbol
과 같은 오류로 여겨지네요.
라이브러리를 업데이트 하시거나, vsnprintf 를 따로 만들어서 없는 경우
직접 만든 걸 호출하도록 해야 될 것 같습니다.
Orion Project : http://orionids.org
5.6에서 컴파일한 다른 응용프로그램(A 프로그램이라 할 경우)의 경우
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거로 카피해서 해봤썼는데.. 안돼더라구여..)
그럼..좋은 의견 부탁드립니다..
[quote="ylmoon"] 물른 A프로그램에서도 vsprintf를
vsprintf 인가요, vsnprintf 인가요?
처음 쓰신 글은 vsnprintf 가 찾아지지 않았다고 돼 있는데요.
Orion Project : http://orionids.org
[답변]
소스상에는 vsnprintf 이게 아니라 vsprintf만을 사용하였습니다.
그런데도 relocation error 관련된 symbol은 vsnprintf 이걸루 나옵니다.
혹시...
답변시 더 자세한 사항이 필요하시다면 얘기해주세여..
제가 초보자라서여..
그럼... 좋은 의견 부탁드립니다...
Re: [답변]
일단, 솔라리스 2.6에서 링크한 실행파일은 vsnprintf 가 resolved
된 것으로 보여집니다.
우선 솔라리스 2.6 헤더에서 vsprintf 선언부를 찾아보시구요,
vsprintf 가 #define 되어서 실제로 vsnprintf 를 호출하고 있지 않나
예상되네요.
제겐 참조할 솔라리스 시스템이 없으니, 우선 솔라리스 2.6과 2.5.1 에서
말씀드린 사항을 살펴보세요.
첨언:
솔라리스 2.6에서 preprocessor 를 돌려서 vsprintf 가 실제로
무엇이 호출되는 지 보시는 게 빠르겠습니다.
Orion Project : http://orionids.org
[확인 결과]
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버전으로 재설치될 가능성이 있기 때문입니다.
좀 복잡하내요..
그럼.. 좋은 의견 부탁드립니다...
Re: [확인 결과]
세 가지 확인 바랍니다.
(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
댓글 달기