unflatten_dt_nodes 질문

에러 2019.10.12 21:35 조회 수 : 214

안녕하세요 

 

http://jake.dothome.co.kr/unflatten_device_tree/ 에서 unflatten_dt_nodes 에 궁금증이 생겨 질문 올립니다.

 

위 링크에서

 

unflatten_dt_node()  함수에서 29~31줄 line인 for문을 어떻게 빠져 나오는지 궁금합니다.

 

29         for (offset = 0;
30              offset >= 0 && depth >= initial_depth;
31              offset = fdt_next_node(blob, offset, &depth)) {

 

실제 for문을 빠져 나오게 되는 49번 줄에 break를 걸고 변수 값을 확인해 보았을 때

다음과 같이 나왔습니다.

 

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

Thread 1 hit Breakpoint 5, unflatten_dt_nodes (blob=<optimized out>, 
    mem=0xffff80003ddfcff7, dad=<optimized out>, nodepp=0x0) at drivers/of/fdt.c:406
406        if (offset < 0 && offset != -FDT_ERR_NOTFOUND) {
(gdb) p offset
$11 = 7172
(gdb) p depth
$12 = 0
(gdb) p initial_depth
$13 = 0

(gdb) x/10x mem
0xffff80003ddfcff7:    0xbeadde00    0x000000ef    0xe0071300    0xe800007f       //dead?? bead???
0xffff80003ddfd007:    0xe0171300    0xe800007f    0xe0271300    0xe800007f
0xffff80003ddfd017:    0xe0371300    0xe800007f
(gdb) 
-------------------------------------------------------------------------------------------

offset, depth, initial_depth 값을 for문의 조건문에 대입해 보면 조건문은 true 이므로 for문은 빠져 나올 수 없는데

빠져나와있습니다. 

 

error인가 싶어 for문 나온 후 mem 메모리를 보면 beaddeef값까지 들어가 있습니다.

(질문하면서 발견했는데 원래 deaddeef 가 정상이였네요 qemu 문제 일수 도 있을까요??)

 

 

break에 조건문을 아래와 같이 걸어서 분석해보았는데도 잘 모르겠습니다.

 

질문_2.png

 

현재 break가 걸렸을 때 pc 값은 for문에서 조건식에 멈춰있으며, offset, depth 역시 7172에 멈춰있습니다.

 

initial_depth는 초기 선언한 0 그대로 유지하고 있으면 (그렇게 생각한 근거는 for문 나왔을 때 initial_depth = 0, depth =0)

for문을 빠져 나올 수 없는데 next로 진행하면 for문을 빠져 나오게 됩니다

 

어떻게 빠져 나올 수 있었을까요?

 

 

감사합니다.

 

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22240
498 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12851
497 16기 리눅스 커널 스터디 33주차 질문입니다. [5] rnsscman 2020.02.08 357
496 setup_machine_fdt() -> fixmap_remap_fdt() 질문입니다. [2] daeroro 2019.12.24 316
495 early_fixmap_init 질문 [3] file 에러 2019.12.17 288
494 16기 리눅스 커널 스터디 27주차 질문입니다. [1] daeroro 2019.12.18 801
493 16기 리눅스 커널 스터디 25주차 질문입니다. [3] rnsscman 2019.12.03 367
492 16기 리눅스 커널 스터디 C조 23주차 질문입니다. [2] 이파란 2019.11.16 389
491 16기 리눅스 커널 스터디 C조 19주차 질문입니다. (두 번째) [2] rnsscman 2019.10.29 234
490 16기 리눅스 커널 스터디 C조 19주차 질문입니다. [2] 이파란 2019.10.19 400
489 asid 관련해서 질문드립니다. [3] suesueng 2019.10.21 717
» unflatten_dt_nodes 질문 [3] file 에러 2019.10.12 214
487 16기 리눅스 커널 스터디 C조 cpu_bit_bitmap 질문 [2] sjahn 2019.10.05 244
486 16기 리눅스 커널 스터디 C조 cgroup_init_early 부분 질문 [2] 이파란 2019.09.21 262
485 16기 리눅스 커널 스터디 C조 16주차 질문입니다. [2] cien 2019.09.28 1159
484 early_fixmap_init 함수 질문 [2] 에러가왜안뜨지 2019.09.12 345
483 cgroup의 구조 및 학습 방법에대해 질문드립니다. file dfx 2019.08.25 257
482 head.S의 compute_indices 관련 문의 드립니다 [3] cien 2019.07.30 292
481 system register 접근 관련 질문드립니다. [2] cien 2019.07.23 454
480 task를 죽이는 do_exit 함수의 동작 중 이해가 안되는 것이 있어 질문드립니다. [2] 코딩의노예 2019.07.10 534
479 __inval_dcache_area의 동작에 대해 질문드립니다. [2] dfx 2019.07.08 228
XE Login