mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

While the GCC and Clang compilers already define __ASSEMBLER__ automatically when compiling assembly code, __ASSEMBLY__ is a macro that only gets defined by the Makefiles in the kernel. This can be very confusing when switching between userspace and kernelspace coding, or when dealing with uapi headers that rather should use __ASSEMBLER__ instead. So let's standardize on the __ASSEMBLER__ macro that is provided by the compilers now. This is mostly a completely mechanical patch (done with a simple "sed -i" statement), except for some manual tweaks in the files arch/parisc/include/asm/smp.h, arch/parisc/include/asm/signal.h, arch/parisc/include/asm/thread_info.h and arch/parisc/include/asm/vdso.h that had the macro spelled in a wrong way. Cc: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> Cc: Helge Deller <deller@gmx.de> Cc: linux-parisc@vger.kernel.org Signed-off-by: Thomas Huth <thuth@redhat.com> Signed-off-by: Helge Deller <deller@gmx.de>
45 lines
1.1 KiB
C
45 lines
1.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* include/asm-parisc/prefetch.h
|
|
*
|
|
* PA 2.0 defines data prefetch instructions on page 6-11 of the Kane book.
|
|
* In addition, many implementations do hardware prefetching of both
|
|
* instructions and data.
|
|
*
|
|
* PA7300LC (page 14-4 of the ERS) also implements prefetching by a load
|
|
* to gr0 but not in a way that Linux can use. If the load would cause an
|
|
* interruption (eg due to prefetching 0), it is suppressed on PA2.0
|
|
* processors, but not on 7300LC.
|
|
*
|
|
*/
|
|
|
|
#ifndef __ASM_PARISC_PREFETCH_H
|
|
#define __ASM_PARISC_PREFETCH_H
|
|
|
|
#ifndef __ASSEMBLER__
|
|
#ifdef CONFIG_PREFETCH
|
|
|
|
#define ARCH_HAS_PREFETCH
|
|
static inline void prefetch(const void *addr)
|
|
{
|
|
__asm__(
|
|
#ifndef CONFIG_PA20
|
|
/* Need to avoid prefetch of NULL on PA7300LC */
|
|
" extrw,u,= %0,31,32,%%r0\n"
|
|
#endif
|
|
" ldw 0(%0), %%r0" : : "r" (addr));
|
|
}
|
|
|
|
/* LDD is a PA2.0 addition. */
|
|
#ifdef CONFIG_PA20
|
|
#define ARCH_HAS_PREFETCHW
|
|
static inline void prefetchw(const void *addr)
|
|
{
|
|
__asm__("ldd 0(%0), %%r0" : : "r" (addr));
|
|
}
|
|
#endif /* CONFIG_PA20 */
|
|
|
|
#endif /* CONFIG_PREFETCH */
|
|
#endif /* __ASSEMBLER__ */
|
|
|
|
#endif /* __ASM_PARISC_PROCESSOR_H */
|