답변:
DULG DebuggingUBoot 페이지에이 내용이 있습니다.
재배치 후 U-Boot를 디버깅하려면 U-Boot가 재배치되는 주소를 알아야합니다. PRAM과 같은 이국적인 기능이 사용되지 않는 경우이 주소는 일반적으로-CONFIG_SYS_MONITOR_LEN입니다. 16MB RAM 및 CONFIG_SYS_MONITOR_LEN = 192KB의 예에서는 주소 0x1000000-0x30000 = 0xFD0000이 생성됩니다.
텍스트를 계속 읽으면 프로세서 나 보드에 따라 다르며 U-Boot 소스를 확인해야 할 수도 있습니다.
Guruplug에 관하여 :
RAM 측면에서 u-Boot는 처음 8MB를 예약합니다. 나머지는 무료입니다. 일부 개발자는 플래시 프로그래밍을 위해 커널과 파일 시스템을 0x800000으로로드합니다. 또 다른 일반적인 지점은 100MB 경계에 있습니다 (또는 오프셋 0x640000).
사용중인 U-Boot 명령 버전에 따라 사용 가능한 RAM에 문자열을 넣은 다음 해당 문자열에 대한 나머지 RAM을 찾아 메모리에서 U-Boot의 대략적인 위치를 알 수 있습니다.
사용중인 uboot 버전을 시작하면 "가상 커널 메모리 레이아웃"이 자동으로 표시됩니다.
Memory: 859068k/859068k available, 25668k reserved, 0K highmem
Virtual kernel memory layout:
vector : 0xffff0000 - 0xffff1000 ( 4 kB)
fixmap : 0xfff00000 - 0xfffe0000 ( 896 kB)
DMA : 0xf9e00000 - 0xffe00000 ( 96 MB)
vmalloc : 0xe0800000 - 0xf4000000 ( 312 MB)
lowmem : 0x80000000 - 0xe0000000 (1536 MB)
pkmap : 0x7fe00000 - 0x80000000 ( 2 MB)
modules : 0x7f000000 - 0x7fe00000 ( 14 MB)
.init : 0x80008000 - 0x8004d000 ( 276 kB)
.text : 0x8004d000 - 0x808ad000 (8576 kB)
.data : 0x808ce000 - 0x80937a40 ( 423 kB)
대용량 파일을 메모리에로드하는 것과 같이 실행하려는 다양한 유틸리티 프로세스에 lowmem 영역을 사용하는 것이 안전하다는 것을 알았습니다. 이상적으로는, 당신이 그런 종류의 일에 높은 메모리를 사용하고 싶다고 생각하지만 옵션이 없었습니다 (내 출력에서 볼 수 있듯이).