134 lines
2.6 KiB
PHP
134 lines
2.6 KiB
PHP
/* 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
|