162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Simple interface to link xor_simd.c and xor_simd_glue.c 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Separating these files ensures that no SIMD instructions are run outside of 662306a36Sopenharmony_ci * the kfpu critical section. 762306a36Sopenharmony_ci */ 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#ifndef __LOONGARCH_LIB_XOR_SIMD_H 1062306a36Sopenharmony_ci#define __LOONGARCH_LIB_XOR_SIMD_H 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#ifdef CONFIG_CPU_HAS_LSX 1362306a36Sopenharmony_civoid __xor_lsx_2(unsigned long bytes, unsigned long * __restrict p1, 1462306a36Sopenharmony_ci const unsigned long * __restrict p2); 1562306a36Sopenharmony_civoid __xor_lsx_3(unsigned long bytes, unsigned long * __restrict p1, 1662306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3); 1762306a36Sopenharmony_civoid __xor_lsx_4(unsigned long bytes, unsigned long * __restrict p1, 1862306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 1962306a36Sopenharmony_ci const unsigned long * __restrict p4); 2062306a36Sopenharmony_civoid __xor_lsx_5(unsigned long bytes, unsigned long * __restrict p1, 2162306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 2262306a36Sopenharmony_ci const unsigned long * __restrict p4, const unsigned long * __restrict p5); 2362306a36Sopenharmony_ci#endif /* CONFIG_CPU_HAS_LSX */ 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci#ifdef CONFIG_CPU_HAS_LASX 2662306a36Sopenharmony_civoid __xor_lasx_2(unsigned long bytes, unsigned long * __restrict p1, 2762306a36Sopenharmony_ci const unsigned long * __restrict p2); 2862306a36Sopenharmony_civoid __xor_lasx_3(unsigned long bytes, unsigned long * __restrict p1, 2962306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3); 3062306a36Sopenharmony_civoid __xor_lasx_4(unsigned long bytes, unsigned long * __restrict p1, 3162306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 3262306a36Sopenharmony_ci const unsigned long * __restrict p4); 3362306a36Sopenharmony_civoid __xor_lasx_5(unsigned long bytes, unsigned long * __restrict p1, 3462306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 3562306a36Sopenharmony_ci const unsigned long * __restrict p4, const unsigned long * __restrict p5); 3662306a36Sopenharmony_ci#endif /* CONFIG_CPU_HAS_LASX */ 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci#endif /* __LOONGARCH_LIB_XOR_SIMD_H */ 39