1/* SPDX-License-Identifier: GPL-2.0-or-later */ 2/* 3 * Copyright (C) 2023 WANG Xuerui <git@xen0n.name> 4 */ 5#ifndef _ASM_LOONGARCH_XOR_SIMD_H 6#define _ASM_LOONGARCH_XOR_SIMD_H 7 8#ifdef CONFIG_CPU_HAS_LSX 9void xor_lsx_2(unsigned long bytes, unsigned long * __restrict p1, 10 const unsigned long * __restrict p2); 11void xor_lsx_3(unsigned long bytes, unsigned long * __restrict p1, 12 const unsigned long * __restrict p2, const unsigned long * __restrict p3); 13void xor_lsx_4(unsigned long bytes, unsigned long * __restrict p1, 14 const unsigned long * __restrict p2, const unsigned long * __restrict p3, 15 const unsigned long * __restrict p4); 16void xor_lsx_5(unsigned long bytes, unsigned long * __restrict p1, 17 const unsigned long * __restrict p2, const unsigned long * __restrict p3, 18 const unsigned long * __restrict p4, const unsigned long * __restrict p5); 19#endif /* CONFIG_CPU_HAS_LSX */ 20 21#ifdef CONFIG_CPU_HAS_LASX 22void xor_lasx_2(unsigned long bytes, unsigned long * __restrict p1, 23 const unsigned long * __restrict p2); 24void xor_lasx_3(unsigned long bytes, unsigned long * __restrict p1, 25 const unsigned long * __restrict p2, const unsigned long * __restrict p3); 26void xor_lasx_4(unsigned long bytes, unsigned long * __restrict p1, 27 const unsigned long * __restrict p2, const unsigned long * __restrict p3, 28 const unsigned long * __restrict p4); 29void xor_lasx_5(unsigned long bytes, unsigned long * __restrict p1, 30 const unsigned long * __restrict p2, const unsigned long * __restrict p3, 31 const unsigned long * __restrict p4, const unsigned long * __restrict p5); 32#endif /* CONFIG_CPU_HAS_LASX */ 33 34#endif /* _ASM_LOONGARCH_XOR_SIMD_H */ 35