Blame view

kernel/linux-rt-4.4.41/arch/arm/include/asm/neon.h 1.16 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
  /*
   * linux/arch/arm/include/asm/neon.h
   *
   * Copyright (C) 2013 Linaro Ltd <ard.biesheuvel@linaro.org>
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   */
  
  #include <asm/hwcap.h>
  
  #define cpu_has_neon()		(!!(elf_hwcap & HWCAP_NEON))
  
  #ifdef __ARM_NEON__
  
  /*
   * If you are affected by the BUILD_BUG below, it probably means that you are
   * using NEON code /and/ calling the kernel_neon_begin() function from the same
   * compilation unit. To prevent issues that may arise from GCC reordering or
   * generating(1) NEON instructions outside of these begin/end functions, the
   * only supported way of using NEON code in the kernel is by isolating it in a
   * separate compilation unit, and calling it from another unit from inside a
   * kernel_neon_begin/kernel_neon_end pair.
   *
   * (1) Current GCC (4.7) might generate NEON instructions at O3 level if
   *     -mpfu=neon is set.
   */
  
  #define kernel_neon_begin() \
  	BUILD_BUG_ON_MSG(1, "kernel_neon_begin() called from NEON code")
  
  #else
  void kernel_neon_begin(void);
  #endif
  void kernel_neon_end(void);