162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2023 WANG Xuerui <git@xen0n.name> 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci#ifndef _ASM_LOONGARCH_XOR_SIMD_H 662306a36Sopenharmony_ci#define _ASM_LOONGARCH_XOR_SIMD_H 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#ifdef CONFIG_CPU_HAS_LSX 962306a36Sopenharmony_civoid xor_lsx_2(unsigned long bytes, unsigned long * __restrict p1, 1062306a36Sopenharmony_ci const unsigned long * __restrict p2); 1162306a36Sopenharmony_civoid xor_lsx_3(unsigned long bytes, unsigned long * __restrict p1, 1262306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3); 1362306a36Sopenharmony_civoid xor_lsx_4(unsigned long bytes, unsigned long * __restrict p1, 1462306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 1562306a36Sopenharmony_ci const unsigned long * __restrict p4); 1662306a36Sopenharmony_civoid xor_lsx_5(unsigned long bytes, unsigned long * __restrict p1, 1762306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 1862306a36Sopenharmony_ci const unsigned long * __restrict p4, const unsigned long * __restrict p5); 1962306a36Sopenharmony_ci#endif /* CONFIG_CPU_HAS_LSX */ 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci#ifdef CONFIG_CPU_HAS_LASX 2262306a36Sopenharmony_civoid xor_lasx_2(unsigned long bytes, unsigned long * __restrict p1, 2362306a36Sopenharmony_ci const unsigned long * __restrict p2); 2462306a36Sopenharmony_civoid xor_lasx_3(unsigned long bytes, unsigned long * __restrict p1, 2562306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3); 2662306a36Sopenharmony_civoid xor_lasx_4(unsigned long bytes, unsigned long * __restrict p1, 2762306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 2862306a36Sopenharmony_ci const unsigned long * __restrict p4); 2962306a36Sopenharmony_civoid xor_lasx_5(unsigned long bytes, unsigned long * __restrict p1, 3062306a36Sopenharmony_ci const unsigned long * __restrict p2, const unsigned long * __restrict p3, 3162306a36Sopenharmony_ci const unsigned long * __restrict p4, const unsigned long * __restrict p5); 3262306a36Sopenharmony_ci#endif /* CONFIG_CPU_HAS_LASX */ 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci#endif /* _ASM_LOONGARCH_XOR_SIMD_H */ 35