현재 preserve_boot_args를 보던 중 inval_dcache_area의 동작이 제대로 이해가 가지 않아서 질문드립니다.

 

제가 이해한 바로는

1. x0에는 bootargs의 주소값이, x1에는 32바이트가 더해진 주소값이 들어가있다

2. 시스템의 캐시라인 사이즈를 가져와서 bootargs+32바이트 값이 시스템 캐시라인 사이즈와 일치하는지 확인한다

3. tst연산으로 Z를 set,clear하고 bic를 통해 x1을 캐시라인 시작주소와 같게 만들어 준 뒤, 조건문에 따라 분기하며  캐시를 c&i한다.

4. 이를 반복하며 최종 bootargs+32바이트까지 캐시를 클리어하고 리턴한다.

 

위 해석은 일단 눈치껏 이해한대로 작성하였는데, 아마 틀렸다고 생각됩니다. 자꾸 이런식으로 넘어가게 되면 마음도 불편하고

공부를 진행하는데 계속 만나게 될 코드라서 확실하게 이해하고 넘어가고 싶은 마음에 염치없지만

아래의 __inval_dcache_area 프로시저의 코드를 간단하게라도 설명해주시면 정말 감사드리겠습니다...

 

162     add x1, x1, x0

163     dcache_line_size x2, x3 

164     sub x3, x2, #1          

165     tst x1, x3              // end cache line aligned?

166     bic x1, x1, x3

167     b.eq    1f 

168     dc  civac, x1           // clean & invalidate D / U line

169 1:  tst x0, x3              // start cache line aligned?

170     bic x0, x0, x3

171     b.eq    2f 

172     dc  civac, x0           /

173     clean & invalidate D / U line

174     b   3f

175 2:  dc  ivac, x0            // invalidate D / U line

176 3:  add x0, x0, x2

177     cmp x0, x1

178     b.lo    2b

179     dsb sy

180     ret

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 프로그래밍 관련 Q&A 게시판 입니다. woos 2016.04.09 22240
498 ___reserved_mem_reserve_reg 관련 질문 [4] DEWH 2020.03.09 12850
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
488 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 1158
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
» __inval_dcache_area의 동작에 대해 질문드립니다. [2] dfx 2019.07.08 228
XE Login