参照元†
返り値†
/*
* v7_dma_clean_range(start,end)
* - start - virtual start address of region
* - end - virtual end address of region
*/
v7_dma_clean_range:
dcache_line_size r2, r3
sub r3, r2, #1
bic r0, r0, r3
#ifdef CONFIG_ARM_ERRATA_764369
ALT_SMP(W(dsb))
ALT_UP(W(nop))
#endif
1:
mcr p15, 0, r0, c7, c10, 1 @ clean D / U line
- cp15 CRn=c7, opc1=0, CRm=c10, opc2=1, DCCMVAC レジスタ
- データまたは統一キャッシュを clean する。
- つまり Dirty なら書き出す。Clean なら何もしない。
- レジスタのデータは仮想アドレスとして解釈される。
- このコードの場合は r0 ですね。
add r0, r0, r2
cmp r0, r1
blo 1b
dsb st
ret lr
ENDPROC(v7_dma_clean_range)
コメント†