MN10300: Create general kernel debugger cache flushing
Create general kernel debugger cache flushing for MN10300 and get rid of the old stuff that gdbstub was using. Signed-off-by: David Howells <dhowells@redhat.com>
This commit is contained in:
47
arch/mn10300/mm/cache-dbg-inv.S
Normal file
47
arch/mn10300/mm/cache-dbg-inv.S
Normal file
@@ -0,0 +1,47 @@
|
||||
/* MN10300 CPU cache invalidation routines
|
||||
*
|
||||
* Copyright (C) 2011 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.
|
||||
*/
|
||||
#include <linux/sys.h>
|
||||
#include <linux/linkage.h>
|
||||
#include <asm/smp.h>
|
||||
#include <asm/page.h>
|
||||
#include <asm/cache.h>
|
||||
#include <asm/irqflags.h>
|
||||
#include <asm/cacheflush.h>
|
||||
#include "cache.inc"
|
||||
|
||||
.am33_2
|
||||
|
||||
.globl debugger_local_cache_flushinv
|
||||
|
||||
###############################################################################
|
||||
#
|
||||
# void debugger_local_cache_flushinv(void)
|
||||
#
|
||||
# Invalidate the entire icache
|
||||
#
|
||||
###############################################################################
|
||||
ALIGN
|
||||
.globl debugger_local_cache_flushinv
|
||||
.type debugger_local_cache_flushinv,@function
|
||||
debugger_local_cache_flushinv:
|
||||
#
|
||||
# we only need to invalidate the icache in this cache mode
|
||||
#
|
||||
mov CHCTR,a0
|
||||
movhu (a0),d0
|
||||
btst CHCTR_ICEN,d0
|
||||
beq debugger_local_cache_flushinv_end
|
||||
|
||||
invalidate_icache 1
|
||||
|
||||
debugger_local_cache_flushinv_end:
|
||||
ret [],0
|
||||
.size debugger_local_cache_flushinv,.-debugger_local_cache_flushinv
|
Reference in New Issue
Block a user