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

제가 사용하고 있는 Uboot 1.3.4에서 아래와 같이 커널을 부팅하다가 멈췄습니다. 그래서

코드를 따라가 봤더니... do_bootm_linux ()함수 부분에서.. theKernel (0, machid, bd->bi_boot_params); 에서

멈췄습니다. 도대체 이 함수에서 왜? 멈췄는지 고수님들의 친절한 답변 부탁드립니다. ㅠㅠ

 

 

--------------------------U-BOOT LOG-------------------------------------------------------------

## Booting kernel from Legacy Image at 22000000 ...
Image Name: linux-2.6
Image Type: ARM Linux Kernel Image (uncompressed)
Data Size: 1498916 Bytes = 1.4 MB
Load Address: 20008000
Entry Point: 20008000
Verifying Checksum ... OK
Loading Kernel Image ... OK
OK

Starting kernel ...

 

 

 

---------------------------------------do_bootm_linux()함수---------------------------------------------------

void do_bootm_linux (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[],
bootm_headers_t *images)
{
ulong initrd_start, initrd_end;
ulong ep = 0;
bd_t *bd = gd->bd;
char *s;
int machid = bd->bi_arch_number;
void (*theKernel)(int zero, int arch, uint params);
int ret;

#ifdef CONFIG_CMDLINE_TAG
char *commandline = getenv ("bootargs");
#endif

/* find kernel entry point */
if (images->legacy_hdr_valid) {
ep = image_get_ep (&images->legacy_hdr_os_copy);
#if defined(CONFIG_FIT)
} else if (images->fit_uname_os) {
ret = fit_image_get_entry (images->fit_hdr_os,
images->fit_noffset_os, &ep);
if (ret) {
puts ("Can't get entry point property!\n");
goto error;
}
#endif
} else {
puts ("Could not find kernel entry point!\n");
goto error;
}
theKernel = (void (*)(int, int, uint))ep;

s = getenv ("machid");
if (s) {
machid = simple_strtoul (s, NULL, 16);
printf ("Using machid 0x%x from environment\n", machid);
}

ret = boot_get_ramdisk (argc, argv, images, IH_ARCH_ARM,
&initrd_start, &initrd_end);
if (ret)
goto error;

show_boot_progress (15);

debug ("## Transferring control to Linux (at address %08lx) ...\n",
(ulong) theKernel);

#if defined (CONFIG_SETUP_MEMORY_TAGS) || \
defined (CONFIG_CMDLINE_TAG) || \
defined (CONFIG_INITRD_TAG) || \
defined (CONFIG_SERIAL_TAG) || \
defined (CONFIG_REVISION_TAG) || \
defined (CONFIG_LCD) || \
defined (CONFIG_VFD)
setup_start_tag (bd);
#ifdef CONFIG_SERIAL_TAG
setup_serial_tag (&params);
#endif
#ifdef CONFIG_REVISION_TAG
setup_revision_tag (&params);
#endif
#ifdef CONFIG_SETUP_MEMORY_TAGS
setup_memory_tags (bd);
#endif
#ifdef CONFIG_CMDLINE_TAG
setup_commandline_tag (bd, commandline);
#endif
#ifdef CONFIG_INITRD_TAG
if (initrd_start && initrd_end)
setup_initrd_tag (bd, initrd_start, initrd_end);
#endif
#if defined (CONFIG_VFD) || defined (CONFIG_LCD)
setup_videolfb_tag ((gd_t *) gd);
#endif
setup_end_tag (bd);
#endif

/* we assume that the kernel is in place */
printf ("\nStarting kernel ...\n\n");


#ifdef CONFIG_USB_DEVICE
{
extern void udc_disconnect (void);
udc_disconnect ();
}
#endif

cleanup_before_linux ();

theKernel (0, machid, bd->bi_boot_params);


/* does not return */
return;

error:

do_reset (cmdtp, flag, argc, argv);
return;
}


고도리

2012.04.04 22:50:55
*.200.239.234

1. 커널로 부팅 한 것인데 멈춘 것입니다.

2. 여러가지 문제가 있을 수 있습니다.

3. 대부분 kernel과 부트로더 사이의 architecture number 에 문제가 생긴 경우가 가장 많고

4. 시리얼 포트 설정이 잘 못 되어 있는 경우도 있습니다.

5. 정확하게는 여기서부터는 직접 봐야하는 문제입니다.

 

제 디버깅 help는 여기까지입니다...^^

고도리

2012.04.04 22:52:09
*.200.239.234

참, 디버깅은...

 

1. cpu에 따라 틀립니다.

2. 장비가 있으면 훨 편하게 할 수 있습니다.

3. 마지막으로.......kernel의 make menuconfig 옵션에서, kernel hacking -> low level debugging 옵션을 켜서 동작시켜서보면 웬만한 녀석은 보입니다.

 

4. 삼성칩이라면 위의 3번의 경우로 대부분 잡힙니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
5288 S3C6410 삼성 2.6.29 kernel 구하는 곳이 없을까요? [7] Supsupi 2012-04-05 1333
5287 WIFI 인증 테스트 하려고 하는데요... 명령어가 [3] 현쓰 2012-04-05 2405
5286 android USB 질문 입니다. [3] kingdomy 2012-04-05 1276
5285 USB : Bulk In callback 호출 문제 다콩 2012-04-05 844
» uboot에서 멈추는 현상에 대해서 문의 드립니다. [2] 혜민아빠 2012-04-04 1352
5283 u-boot가 다음 메세지까지만 출력하고 멈추게 되면 뭘 의심해야 할까... file [3] 혜민아빠 2012-04-03 1281
5282 uboot에서 sdram메모리 설정은 어디서 해야 할까요? [1] 혜민아빠 2012-04-03 1149
5281 uboot설정을 sdram memory와 맞추기 위해서는 어떻게 해야하는 것일까... file [1] 혜민아빠 2012-04-03 1205
5280 [s5pc110] SsbSipMfcEncAPI.c 사용하여 H264 인코딩 file [4] 차차호드 2012-04-03 2026
5279 WIFI 인증 관련 궁금한점 있습니다. [5] 현쓰 2012-04-03 1454
5278 ramdisk 땜시 허덕이고 있습니다. ㅠㅠ(help me) [2] 혜민아빠 2012-04-03 1182
5277 u-boot의 mtdpart 환경변수값의 의미가 궁금합니다. [2] Supsupi 2012-04-02 1724
5276 안드로이드 자바로 멀티코어 사용 문의 [7] 김장균 2012-04-02 1338
5275 memcpy(); 해황 2012-03-31 791
5274 tftp 이거 가능한건가요?[초보자] file [2] 웅탱곰탱 2012-03-31 1327
5273 memcpy() [1] 해황 2012-03-30 1002
5272 nexus-S에 ics 올리기 [2] 박수민 2012-03-29 1273
5271 스위치관련 질문입니다. sonbong 2012-03-28 704
5270 Origen 리나로 우분투 HDMI 문의 [2] 김장균 2012-03-28 1277
5269 회로도 관련 질문이 있습니다. [7] sonbong 2012-03-27 1514

사용자 로그인