⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 callout_page_1136.s

📁 Centrality Atlas II development software
💻 S
字号:
## Copyright 2007, 2008, QNX Software Systems. # # Licensed under the Apache License, Version 2.0 (the "License"). You # may not reproduce, modify or distribute this software except in # compliance with the License. You may obtain a copy of the License # at: http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" basis, # WITHOUT WARRANTIES OF ANY KIND, either express or implied.## This file may contain contributions from others, either as # contributors under the License or as licensors under other terms.  # Please review this entire file for other proprietary rights or license # notices, as well as the QNX Development Suite License Guide at # http://licensing.qnx.com/license-guide/ for other information.#/* * ARM1136 specific page flush callouts */#include "callout.ah"/* * int	page_flush(unsigned vaddr, int cache) * * FIXME_v6: this code needs to be reworked when we enable the full *           ARMv6 MMU support instead of the v5/FCSE implementation. * * This routine is called to flush the caches and TLBs for a single page. * vaddr. If the processor cannot flush cache lines or TLB entries by address, * those caches and TLBs can be flushed in page_flush_deferred() * * vaddr is the virtual address of the page * cache is non-zero if the cache needs to be flushed * * Returns 0 if all caches/TLBs were flushed. *         1 if the page_flush_deferred() callout needs to be called. */CALLOUT_START(page_flush_1136, 0, 0)	mov		r2, r0	teq		r1, #0	beq		1f									// only flush TLBs	bic		r0, r0, #0xff						// kernel sets ASID in vaddr	mov		r1, #4096							// page size0:	mcr		p15, 0, r0, c7, c14, 1				// clean/inval Dcache line	add		r0, r0, #32							// next cache line	subs	r1, r1, #32	bne		0b	mcr		p15, 0, r1, c7, c10, 4				// drain write buffer1:	// Note: kernel sets ASID in bottom 7 bits of address	mcr		p15, 0, r2, c8, c7, 1				// flush TLB by MVA	/*	 * FIXME: some 1136 have errata where Icache is not always flushed	 *        by flush by MVA operation. To work around this, flush	 *        the Icache in page_flush_deferred.	 *        May need to create separate callouts based on CPU revision	 *        to avoid flushing whole Icache for cpus without the errata.	 */	mov		r0, #1								// flush Icache later	mov		pc, lrCALLOUT_END(page_flush_1136)/* * void	page_flush_deferred(int cache) * * This routine performs any cache/TLB flushing that could not be done in * the page_flush() callout. * * cache is non-zero if the cache needs to be flushed */CALLOUT_START(page_flush_deferred_1136, 0, 0)	/*	 * FIXME: some 1136 have errata where Icache is not always flushed	 *        by flush by MVA operation. To work around this, flush	 *        the Icache in page_flush_deferred.	 *        May need to create separate callouts based on CPU revision	 *        to avoid flushing whole Icache for cpus without the errata.	 */	mcr		p15, 0, r0, c7, c5, 0				// flush Icache and BTB	mov		pc, lrCALLOUT_END(page_flush_deferred_1136)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -