기존 이솝 임베디드 포럼의 지식인 서비스가 게시판 형태로 변경되었습니다.

안녕하세요.


Kernel을 컴파일하다가 이상한일을 겪게 되었는데 혼자서는 힘들어서 염치불구하고 게시판에 물어보게되었습니다.


상황은 이렇습니다.


하나의 Kernel Source가 있습니다. 똑같은 config을 하고 kernel을 컴파일하면 kernel/arch/arm/boot/ 디렉터리에 Image 파일이랑 zImage이 파일이 생성이 됩니다.


이렇게 생긴 Image파일이랑 zImage랑 백업폴더에 백업을 해둡니다.


그다음에 Kernel 디렉터리에서  make distclean, make mrproper을 하고 다시 첫번째와 동일하게 config 설정을 하고 


다시 Kernel을 Compile합니다. 두번째의 Compile에서도 역시 kernel/arch/arm/boot/ 디렉터리에 Image파일이랑 zImage파일이 생성됩니다.


그런데 이렇게 각각 생긴 생긴 Image파일끼리 hex 데이터를 비교하고 zImage파일끼리 hex데이터를 비교하면 다른 파일로 나타납니다.


44444444.png


위의 그림은 Image를 Ultra Edit 로 비교한 모습입니다. 


hex 데이터를 까보니 시간정보가 들어가져 있는 부분이 있었습니다.



 

이렇게 된 경우라면 같은 Kernel Source를 가지고 컴파일을 하는 사람에 따라서 다른결과가 나올 수 있는 것 같은데요. 


이런 현상을 막을려면 어떻게 해야하나요?






이동희

2014.11.07 18:46:24
*.90.129.146

kernel/scripts/mkcompile_h 파일에서

kernel을 build 한 host 정보와 build time을 갖고 kernel에 version정보로 추가 됩니다.

또한, 같은 시간이라도 다른 host 및 user가 달라져도 해당 정보로 인하여 달라집니다.

kernel/scripts/mkcompile_h 파일에서

TIMESTAMP=$KBUILD_BUILD_TIMESTAMP 에서 build time 정보를 구합니다.

TIMESTAMP 항목을 고정된 문자열로 대치를 하면 됩니다.

xoduddk123

2014.11.07 23:38:12
*.216.145.10

안녕하세요?

댓글에 말씀해주신것처럼 kernel/scripts/mkcompile_h 에 가서 보니 TIMESTAMP가 있었습니다. 더불어 이러한 TIMESTAMP값을 바꿔주면 kernel/include/generated/compile.h의 헤더정보가 자동으로 바껴지는것도 알아내었습니다.


아래의 사진은 차례로 kernel/scripts/mkcompile_h 와  컴파일완료후 kernel/include/generated/compile.h의 내용입니다. TIMESTAMP값은 쉽게 알아볼수있도록 시간값을 모두 1로 통일 시켰습니다.1111.png

333333.png


이렇게 컴파일을 하여도 적용전과 적용후를 비교하였을때의 arch/arm/boot/Image의 시간정보값은 저 TIMESTAMP값이 아닌 현재 컴파일된 시간값으로 써졌습니다. 아래의 사진은 적용 전과 적용후를 비교한 모습입니다.

555.png


이상해서 컴파일하여 나온 zImage로 통하여 부팅한후 uname -a 명령어를 통하여 시간값도 Image에 써진 시간값으로 나오는지 확인하였는데 uname -a 로 본 시간값이 TIMESTAMP에 적은 시간으로 반영이 되어있었습니다.

888.png


해본 결과 TIMESTAMP에 적힌 값은 Image의 바이너리파일에 적히는 시간과는 다르게 적용되는것 같은데 다른 방법은 없을까요  ? ? ?









첨부
List of Articles
번호 제목 글쓴이 날짜sort 조회 수
6148 SDL cpp file 컴파일 관련 [2] 김증일 2006-11-17 757
6147 풀 스크린 개념 ... 런쳐 에 관해서.. [2] 오용석 2006-11-19 936
6146 [re] [긴급]I2C Interface 변효현 2006-11-21 823
6145 제품 양산시 커널을 어떻게 줄이나요??<====[완료] [3] 윤현승 2006-11-21 1068
6144 u-boot UImage 질문입니다. [완료] [1] 김유석 2006-11-23 1021
6143 간단한 리눅스 환경변수 변경문제 물어볼께요.. [2] 이재훈 2006-11-24 1160
6142 부팅 문제 질문 드립니다. [완료] [8] 김유석 2006-11-27 961
6141 MMSP2 보드에 USB HOST 포팅 질문입니다. <== [완료] [4] 이영재 2006-11-27 918
6140 커널의 make menuconfig에서... 고현철 2006-11-28 1156
6139 질문드립니다.. RAM안의 내용이 이상해 졌습니다. [완료] [5] 김영곤 2006-11-28 658
6138 [완료]터치 관련 질문입니다. [3] 김증일 2006-11-28 831
6137 [re] 커널의 make menuconfig에서... [2] 김유석 2006-11-28 907
6136 LED 제어 관련해서 질문드려요~ [완료] [1] 김재우 2006-11-30 787
6135 kernel 부팅중에 멈춤 현상 때문에 질문 드립니다. [완료] [2] 옥윤필 2006-11-30 1282
6134 [완료]터치 관련 질문2 [1] 김증일 2006-11-30 740
6133 [완료]또 터치 관련 질문 드립니다. 죄송~ [5] 김증일 2006-11-30 1294
6132 USB host (OHCI) probe 함수가 불려지지 않는 이유를 찾고 있습... [2] 이영재 2006-11-30 922
6131 RAM 내용을 NAND에 COPY할때 특정 부분에서만 에러가 나에요 ... [4] 김영곤 2006-12-01 881
6130 이솝보드에서 ram K4S561632B 2개를 따로 구입할 수 있을까요? [1] 성진호 2006-12-01 705
6129 이솝보드에서 자바 개발 가능한지요? [3] 이광식 2006-12-01 744

사용자 로그인