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

안녕하세요.


이것 저것 다 해보았는데 문제가 끊이 질 않네요.. ㅜㅜ;;;


U-BOOT의 arm_boot 함수에서 특정 기능을 하는 FW(main_go() 함수)를 호출하는 부분을 Porting 했는데요.


BSS 영역의 특정 Global 변수를 접근하면 Data Abort가 발생합니다.


ARMCC로 컴파일 되던 소스를 GCC로 변환 시키는 작업이라 굳이 U-BOOT을 사용하게 되었네요.


작업은 s3c6410 보드로 하였습니다.

Floating Point(64Bit 연산)을 위해서 -mabi=apcs-gnu 를 aapcs로 변환 시키고, 관련 library를 추가 해 주었습니다.

그리고, U-BOOT RAM Address관련 사항을 base 0x5000 0000 + 0x07e0 0000을 + 0x0010 0000으로 변경 해주었습니다.

Nor 부팅을 이용해서 DNW로 램영역 0x5010 0000에 다운로드 시켜서 특정 BSS영역의 Global변수를 호출 할 때까지 정상 동작을 합니다.

 

처음에는 4byte align이 안 맞아서 생기는 문제 인 줄 알았는데, structure type과 union type 등 __packed을 사용해서 맞춰 준 것 같은데, 다른 Global 변수를 호출 할 때 Data Abort가 발생하더군요. (structure type 변수 pass 후 u8 배열 변수에서 Data Abort, 변수 배열 사이즈(기존 4Mbyte) 조절하면 다른 곳에서 발생... ㅜㅜ;;;)

memory map을 봐도 문제 되는 부분은 4byte align이 잘 맞고 있습니다.

(좀 이상한 부분이 Data Abort 발생 지점의 상위 단의 변수인 

0x0000 000c g_time

0x0000 000d g_day

이런 식으로 u8 데이타가 존재하는 부분이 있습니다.

하지만 이 부분 접근 시에는 별다른 문제가 없네요.

)


Bootloader라서 Ram의 초기화가 안될 수도 있어서 보니 128MByte 영역을 모두 초기화 해주는 것 같습니다.

실제로 Global 변수 사이즈를 조절해서 봐도 특정 address를 어느 때는 접근 가능하고 어느 때는 Data Abort가 뜹니다.

그리고, link Script 부분도 이것 저것 수정해 봤는데 역시 변화는 없더군요.


FW 내부에서 GPIO 및 기타 Kernel에서 하는 초기화 루틴이 있는데 clock 변경 등... 

큰 문제는 없는데 뭔가 불안하네요.


이렇게 Global 변수를 접근 시에 Data Abort가 발생 할 경우, Check해봐야 하는 부분이 뭐가 있을 까요??

U-BOOT의 특성을 타는 건지 모르겠네요... 


약간의 힌트라도 답변 부탁드립니다. ㅜㅜ


은민아빠

2014.11.20 19:44:35
*.245.242.234

https://github.com/theopolis/u-boot-sboot/blob/master/doc/README.arm-unaligned-accesses

uboot 관련문서들을 참조해 보시면 도움이 되지 않을까 합니다.

정확히 어떤 문제로 data abort가 발생되는지는 저도 잘 모르겠네요.. 추측만 할뿐...ㅠㅠ

유희재

2014.11.20 23:48:43
*.103.2.150

-marm 옵션 확인해 보세요 썸모드로 컴파일 되었다면 그럴 수 있습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수sort
6148 오드로이드에서 Rootfs [1] 김성수 2010-03-27 477
6147 오드로이드에서 32bit 그래픽 사용 질문입니다. [1] 권도홍 2010-03-27 477
6146 s5pc100 & android-2.1 can't play 3gp file [1] stiff 2010-04-29 477
6145 bluetooth device driver에 대한 질문입니다. [1] 김동래 2010-05-05 477
6144 C100 개발보드 개발환경 [1] 현쓰 2010-05-12 477
6143 device file 관련 문의 [1] 서정구 2010-08-28 477
6142 app 실행 문제에 대한 로그.. file [1] 은재아빠 2010-11-08 477
6141 LCD 관련 문의 드립니다. [1] 조남희 2011-02-09 477
6140 device.c 퍼미션 수정.. [1] skean 2011-03-04 477
6139 Gingerbread의 qcom 폴더 문의 [1] LeonardKim 2011-04-26 477
6138 aESOP의 문서양식이 있나요? [2] just4you 2010-01-05 478
6137 omap_hsmmc driver 문의입니다. file [1] 김병종 2010-01-21 478
6136 [MFC]Bit Processor?? [1] 안드러오니 2010-02-02 478
6135 오드로이드 플랫폼 개발자용 밖에 안파네요? 그런건가요? [1] 거지깽깽이 2010-03-06 478
6134 qt 에러 ....2440보드 문제 입니다 file [1] 지승화 2010-03-18 478
6133 6410에서 SDIO작업하는중인데.. [1] 박상민 2010-05-25 478
6132 AESOP6410보드에서 SD메모리하고 관련된 Channel를 바꾸고 싶은데... 허경 2010-05-29 478
6131 serial port를 통해 flash로 download할수있나요? [1] 김태현 2010-06-15 478
6130 android에서 new product 만들고 compile하기 실습에서...??? [1] 전현철 2010-07-03 478
6129 혹시, ov2655 사용해 보신 분 있으신가요.. [1] kinsw 2010-09-08 478

사용자 로그인