Blame view

kernel/linux-rt-4.4.41/arch/m32r/include/asm/dcache_clear.h 1.01 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
  /*
   * 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) 2001  Hiroyuki Kondo, Hirokazu Takata, and Hitoshi Yamamoto
   * Copyright (C) 2004, 2006  Hirokazu Takata <takata at linux-m32r.org>
   */
  #ifndef _ASM_M32R_DCACHE_CLEAR_H
  #define _ASM_M32R_DCACHE_CLEAR_H
  
  #ifdef CONFIG_CHIP_M32700_TS1
  #define DCACHE_CLEAR(reg0, reg1, addr)				\
  	"seth	"reg1", #high(dcache_dummy);		
  \t"	\
  	"or3	"reg1", "reg1", #low(dcache_dummy);	
  \t"	\
  	"lock	"reg0", @"reg1";			
  \t"	\
  	"add3	"reg0", "addr", #0x1000;		
  \t"	\
  	"ld	"reg0", @"reg0";			
  \t"	\
  	"add3	"reg0", "addr", #0x2000;		
  \t"	\
  	"ld	"reg0", @"reg0";			
  \t"	\
  	"unlock	"reg0", @"reg1";			
  \t"
  	/* FIXME: This workaround code cannot handle kernel modules
  	 * correctly under SMP environment.
  	 */
  #else	/* CONFIG_CHIP_M32700_TS1 */
  #define DCACHE_CLEAR(reg0, reg1, addr)
  #endif	/* CONFIG_CHIP_M32700_TS1 */
  
  #endif /* _ASM_M32R_DCACHE_CLEAR_H */