AIX 32bit/64bit 컴파일

OS/리눅스 & 유닉스 2012. 5. 23. 17:00

AIX에서 사용하는 사용하는 컴파일러는 IBM에서 제공하는 xl이라는 Compiler가 쓰인다.


이 xl은 xlc로도 쓰이며 _r 이 붙게 되면 Thread-Safe의 의미가 된다.

정확하게 어떤 부분이 Safe한지는 잘 모르겠다.


xl 씨리즈는 굉장히 많은 종류가 있는데 /usr/vacpp/bin에 보면 C++ 

그리고 /usr/vac/bin에 보면 C에 해당 하는 컴파일러 종류들을 살펴 볼 수 있겠다.


-----------------------------------------------------------------------------------------------------------------------------

Hard Link 

똑같은 파일이 복사되어 있는 것으로 원복을 삭제해도 복사본의 내용은 남아 있으며 복사본의 내용을 추가하면 원본의 내용에도 추가되는 구조.


Symbolic Link

원본의 파일에 대한 위치와 정보만을 갖고 있음.

-----------------------------------------------------------------------------------------------------------------------------

위 컴파일러들은 모두 기본적으로 xlc의 Symbolic Link가 걸려 있는데 각자 자신이 호출된 이름에 맞는 동작을 한다고 한다.

따라서 xlc를 사용한 것과 xlC를 사용하는 부분은 구분해야 한다.



-----------------------------------------------------------------------------------------------------------------------------

출처 : http://susukang98.springnote.com/pages/377244.xhtml


오래된 머신에서는 xlc가 깔려 있다고 한다.

AIX에서 사용하는 옵션을 살펴보자면 


 Version [kernel 2.x, GCC 2.95.x and later] 4.3 and Later

 2a shared library creation flag -bM:SRE

 2b shared library creation (C++) cxx -shared -o

xlC -G (or -qmkshrobj)

obsolete:/usr/vacpp/bin/makeC++SharedLib -G -o

(was in /usr/ibmcxx/bin or /usr/lpp/xlC/bin/)

 2c static archiver (C++) ar

 3b file extension .so (or .a)

 4 executable link options -brtl

-bdynamic

-Lpath -lname

 5a runtime path specification -blibpath:<path>

(by default, it is set to the arguments of -L)

 5b  Does not build the path for shared libraries into the executable -blibpath:/usr/lib:/lib

 7 exports file/link option

(see notes) .exp

 9 runtime library path LIBPATH

 11 runtime debugging LDR_CNTRL

 17 dynamic loading /

dynamic symbol access loadquery/loadbind

(AIX 4.2) dlopen / dlsym

 18 utilities dump -H

ldd (in AIX tools)

 19 documentation man: ld, dump



-----------------------------------------------------------------------------------------------------------------------------


1. 32bit/64bit 컴파일


기본적으로 AIX용 컴파일러는 프로그램을 32bit 모드로 컴파일한다. 원하는 bit 모드를 지정하려면 컴파일러, 아카이버, 링키지 에디터 등을 위해 아래와 같이 bit 모드 옵션이나 환경변수를 사용할 수 있다.


- 컴파일러 옵션: -q32/-q64

- OBJECT_MODE 환경변수: 32/64

- Archive(ar) 옵션: -X32/-X64/-X32_64

- 링키지 에디터(ld) 옵션: -b32/-b64

아래는 64-bit 오브젝트를 생성하도록 컴파일하고 확인하는 예..

$ xlf -c -q64 bt.f

$ dump -ov -X32_64 bt.o

bt.o:

***Object Module Header***

# Sections Symbol Ptr # Symbols Opt Hdr Len Flags

4 0x000026fe 81 0 0x0000

Flags=( )

Timestamp = "Feb 14 11:18:07 2002"

Magic = 0x1f7 (64-bit XCOFF)

위와 같이 dump 명령을 사용하면 실행 파일 또는 오브젝트 파일이 32-bit 모드인지 64-bit 모드인지 확인할 수 있는데, 위의 예에서는 '64-bit XCOFF'로 되어 있으므로 64-bit 오브젝트 파일임을 알 수 있다. 또한, dump 명령의 옵션인 -X32_64, -X32, -X64는 대상 파일의 bit 모드를 지정하는 것으로, 모를 때는 위와 같이 -X32_64를 사용하면 된다.

AIX 4.3 환경에서 컴파일한 64-bit 프로그램은 AIX 5L에서는 실행되지 않으므로 AIX 5L용으로 다시 컴파일 해주어야 하지만, 32-bit 프로그램은 AIX5L 이전의 버전에서 컴파일 된 실행파일을 그대로 사용할 수 있다.

운영체제의 32/64-bit 모드는 'ls -l /unix' 명령으로 확인할 수 있는데 /unix가 /usr/lib/boot/unix_64에 링크되어 있으면 64-bit 커널이고, /usr/lib/boot/unix_mp에 링크되어 있으면 32-bit 커널이다.

xlC는 주석을 엄밀히 확인하고 일반적인 c style의 comment에 대해 warnning하는 경우가 있다.


그리고 char type을 default로 unsigned값으로 보고 있다. char타입에 대해 멀티플렛폼으로 작성할 여부가 있는 프로그램의 경우 변수의 type을 char보다는 __uint8같은 명확한 type으로 명확히 정의함이 괜찮은 방법이다.


"sn3crypt.h", line 338.18: 1540-0804 (W) The characters "/*" are detected in a comment.

"sn3ole.h", line 189.73: 1540-0804 (W) The characters "/*" are detected in a comment.

"sn3pcm.h", line 70.17: 1540-0848 (S) The macro name "SN3_ARCHITECTURE" is already defined with a different definition.

"sn3pcm.h", line 54.17: 1540-0425 (I) "SN3_ARCHITECTURE" is defined on line 54 of "sn3pcm.h".

"sn3xls.h", line 51.49: 1540-0804 (W) The characters "/*" are detected in a comment.

make: 1254-004 The error code from the last command is


aix5, xlC컴파일러에서 next를 실행한 오류

컴파일을 하다가 난 warnning과 error이다. 여러 플렛폼에 있는 다양한 컴파일러로 컴파일을 할때 한번에 되지 않느다면 역시 컴파일러의 옵션을 봐야 한다. 여러종류의 컴파일러를 만났을 때 당황하지 말고 믿을 수 있는 것은 컴파일러에서 생성한 경고나 오류, 그리고 컴파일러 옵션임을 잊지 않는다.

위의 경우는 (W)는 warnning (S)에서 에러를 냈으므로 70 line을 찾는다.


출처 - http://jangpd007.tistory.com/37

: