현재 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 22252
517 alloc과 free함수에 대해서 질문입니다. [1] 정재훈 2011.06.28 93661
516 안드로이드 system 폴더안의 파일을 인식못하는데.. [5] 김영일 2011.04.14 69702
515 x86에서 ZONE_DMA 영역의 사용 [1] 홍문화 2011.05.02 58326
514 커널에서 page alloc에 관해서 [1] 미다리로23 2017.02.05 34577
513 디바이스 드라이버 모듈에서 작성한 함수를 커널에서 사용하는 방법 [1] 개짖는소리 2017.02.06 27052
512 Linux kernel의 CFS(Completely Fair Scheduling) 스케줄러에서 time slice 구하는 방법? [10] 김재호 2010.04.30 25225
511 "만들면서 배우는 OS..." 4장 kernel.asm 중 idtr 설정 질문드립니다 쿨쿨 2013.06.18 24961
510 리눅스 스케줄러 관련 [9] 홍문화 2011.02.23 22949
509 NFS NAS SAN 이란 무엇인가? file 박은병 2010.04.13 21882
508 s3c2440기반의 리눅스 커널 분석 중 MM관련 질문입니다. 유태경 2007.09.02 21523
507 /dev 폴더에 있는 node파일 중에서 어떤 것을 open해야 플래쉬를 사용할 수 있을까요? [1] 박종주 2012.02.17 19849
506 sparsemem에 대한 질문이 있습니다. [5] 안정모 2010.03.20 19719
505 16기 리눅스 커널 스터디 C조 18주차 질문입니다. [3] cien 2019.10.12 18831
504 tty, tty0, console, vc 는 각각 뭐하는 디바이스인지? [3] 이창만 2008.12.04 18557
503 ARM A8 이상의 프로세서를 공부할 때 스터디 방향 [4] 유강희 2011.06.15 18519
502 임베디드 OS 만들기 내용과 관련하여 문의드립니다. [5] 송인재 2010.03.25 18321
501 far call 이란 무엇인가요? [4] 박한범 2010.04.13 17841
500 파일시스템에 관한 질문(Htree [6] 사앙조 2017.05.22 17072
499 SMP관련 질문입니다. [2] 컴퓨터 2017.04.13 16586
XE Login