| /* | 
|  * This file is subject to the terms and conditions of the GNU General Public | 
|  * License.  See the file "COPYING" in the main directory of this archive | 
|  * for more details. | 
|  * | 
|  * Copyright (C) 1995 - 1999 Ralf Baechle | 
|  * Copyright (C) 1999 Silicon Graphics, Inc. | 
|  * | 
|  * Cache error handler | 
|  */ | 
| #include <asm/asm.h> | 
| #include <asm/regdef.h> | 
| #include <asm/mipsregs.h> | 
| #include <asm/stackframe.h> | 
|   | 
| /* | 
|  * Game over.  Go to the button.  Press gently.     Swear where allowed by | 
|  * legislation. | 
|  */ | 
|     LEAF(except_vec2_generic) | 
|     .set    noreorder | 
|     .set    noat | 
|     .set    mips0 | 
|     /* | 
|      * This is a very bad place to be.  Our cache error | 
|      * detection has triggered.  If we have write-back data | 
|      * in the cache, we may not be able to recover.     As a | 
|      * first-order desperate measure, turn off KSEG0 cacheing. | 
|      */ | 
|     mfc0    k0,CP0_CONFIG | 
|     li    k1,~CONF_CM_CMASK | 
|     and    k0,k0,k1 | 
|     ori    k0,k0,CONF_CM_UNCACHED | 
|     mtc0    k0,CP0_CONFIG | 
|     /* Give it a few cycles to sink in... */ | 
|     nop | 
|     nop | 
|     nop | 
|   | 
|     j    cache_parity_error | 
|     nop | 
|     END(except_vec2_generic) |