| /* MN10300 CPU core caching macros -*- asm -*- | 
 |  * | 
 |  * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved. | 
 |  * Written by David Howells (dhowells@redhat.com) | 
 |  * | 
 |  * This program is free software; you can redistribute it and/or | 
 |  * modify it under the terms of the GNU General Public Licence | 
 |  * as published by the Free Software Foundation; either version | 
 |  * 2 of the Licence, or (at your option) any later version. | 
 |  */ | 
 |  | 
 |  | 
 | ############################################################################### | 
 | # | 
 | # Invalidate the instruction cache. | 
 | #	A0: Should hold CHCTR | 
 | #	D0: Should have been read from CHCTR | 
 | #	D1: Will be clobbered | 
 | # | 
 | # On some cores it is necessary to disable the icache whilst we do this. | 
 | # | 
 | ############################################################################### | 
 | 	.macro invalidate_icache,disable_irq | 
 |  | 
 | #if defined(CONFIG_AM33_2) || defined(CONFIG_AM33_3) | 
 | 	.if \disable_irq | 
 | 	# don't want an interrupt routine seeing a disabled cache | 
 | 	mov	epsw,d1 | 
 | 	and	~EPSW_IE,epsw | 
 | 	or	EPSW_NMID,epsw | 
 | 	nop | 
 | 	nop | 
 | 	.endif | 
 |  | 
 | 	# disable the icache | 
 | 	and	~CHCTR_ICEN,d0 | 
 | 	movhu	d0,(a0) | 
 |  | 
 | 	# and wait for it to calm down | 
 | 	setlb | 
 | 	movhu	(a0),d0 | 
 | 	btst	CHCTR_ICBUSY,d0 | 
 | 	lne | 
 |  | 
 | 	# invalidate | 
 | 	or	CHCTR_ICINV,d0 | 
 | 	movhu	d0,(a0) | 
 |  | 
 | 	# wait for the cache to finish | 
 | 	setlb | 
 | 	movhu	(a0),d0 | 
 | 	btst	CHCTR_ICBUSY,d0 | 
 | 	lne | 
 |  | 
 | 	# and reenable it | 
 | 	or	CHCTR_ICEN,d0 | 
 | 	movhu	d0,(a0) | 
 | 	movhu	(a0),d0 | 
 |  | 
 | 	.if \disable_irq | 
 | 	LOCAL_IRQ_RESTORE(d1) | 
 | 	.endif | 
 |  | 
 | #else /* CONFIG_AM33_2 || CONFIG_AM33_3 */ | 
 |  | 
 | 	# invalidate | 
 | 	or	CHCTR_ICINV,d0 | 
 | 	movhu	d0,(a0) | 
 | 	movhu	(a0),d0 | 
 |  | 
 | #endif /* CONFIG_AM33_2 || CONFIG_AM33_3 */ | 
 | 	.endm | 
 |  | 
 | ############################################################################### | 
 | # | 
 | # Invalidate the data cache. | 
 | #	A0: Should hold CHCTR | 
 | #	D0: Should have been read from CHCTR | 
 | #	D1: Will be clobbered | 
 | # | 
 | # On some cores it is necessary to disable the dcache whilst we do this. | 
 | # | 
 | ############################################################################### | 
 | 	.macro invalidate_dcache,disable_irq | 
 |  | 
 | #if defined(CONFIG_AM33_2) || defined(CONFIG_AM33_3) | 
 | 	.if \disable_irq | 
 | 	# don't want an interrupt routine seeing a disabled cache | 
 | 	mov	epsw,d1 | 
 | 	and	~EPSW_IE,epsw | 
 | 	or	EPSW_NMID,epsw | 
 | 	nop | 
 | 	nop | 
 | 	.endif | 
 | 	 | 
 | 	# disable the dcache | 
 | 	and	~CHCTR_DCEN,d0 | 
 | 	movhu	d0,(a0) | 
 |  | 
 | 	# and wait for it to calm down | 
 | 	setlb | 
 | 	movhu	(a0),d0 | 
 | 	btst	CHCTR_DCBUSY,d0 | 
 | 	lne | 
 |  | 
 | 	# invalidate | 
 | 	or	CHCTR_DCINV,d0 | 
 | 	movhu	d0,(a0) | 
 |  | 
 | 	# wait for the cache to finish | 
 | 	setlb | 
 | 	movhu	(a0),d0 | 
 | 	btst	CHCTR_DCBUSY,d0 | 
 | 	lne | 
 |  | 
 | 	# and reenable it | 
 | 	or	CHCTR_DCEN,d0 | 
 | 	movhu	d0,(a0) | 
 | 	movhu	(a0),d0 | 
 |  | 
 | 	.if \disable_irq | 
 | 	LOCAL_IRQ_RESTORE(d1) | 
 | 	.endif | 
 |  | 
 | #else /* CONFIG_AM33_2 || CONFIG_AM33_3 */ | 
 |  | 
 | 	# invalidate | 
 | 	or	CHCTR_DCINV,d0 | 
 | 	movhu	d0,(a0) | 
 | 	movhu	(a0),d0 | 
 |  | 
 | #endif /* CONFIG_AM33_2 || CONFIG_AM33_3 */ | 
 | 	.endm |