blob: 790c07ab2b3499bf548bb66879c726f561ef43dc [file] [log] [blame]
Yun Hsiang40a82d02023-05-26 10:10:40 +08001/*
2 * Copyright (C) 2023 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28/*
29 * Copyright (c) 2023 SiFive, Inc.
30 * All rights reserved.
31 *
32 * Redistribution and use in source and binary forms, with or without
33 * modification, are permitted provided that the following conditions
34 * are met:
35 * 1. Redistributions of source code must retain the above copyright
36 * notice, this list of conditions and the following disclaimer.
37 * 2. Redistributions in binary form must reproduce the above copyright
38 * notice, this list of conditions and the following disclaimer in the
39 * documentation and/or other materials provided with the distribution.
40 * 3. The name of the company may not be used to endorse or promote
41 * products derived from this software without specific prior written
42 * permission.
43 *
44 * THIS SOFTWARE IS PROVIDED BY SIFIVE INC ``AS IS'' AND ANY EXPRESS OR IMPLIED
45 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
46 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
47 * IN NO EVENT SHALL SIFIVE INC BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
48 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
49 * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
50 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
51 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
52 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
53 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
54 */
55
56#if defined(__riscv_v)
57
58#include "sys/asm.h"
59
60#define pDst a0
61#define pSrc a1
62#define pDstPtr a2
63
64#define iVL a3
65#define iCurrentVL a4
66#define iActiveElemPos a5
67
68#define ELEM_LMUL_SETTING m1
69#define vMask1 v0
70#define vMask2 v1
71#define vStr1 v8
72#define vStr2 v16
73
74ENTRY(strcat_vext)
75
76 mv pDstPtr, pDst
77
78 // the strlen of dst
79L(strlen_loop):
80 vsetvli iVL, zero, e8, ELEM_LMUL_SETTING, ta, ma
81
82 vle8ff.v vStr1, (pDstPtr)
83 // find the '\0'
84 vmseq.vx vMask1, vStr1, zero
85 csrr iCurrentVL, vl
86 vfirst.m iActiveElemPos, vMask1
87 add pDstPtr, pDstPtr, iCurrentVL
88 bltz iActiveElemPos, L(strlen_loop)
89
90 sub pDstPtr, pDstPtr, iCurrentVL
91 add pDstPtr, pDstPtr, iActiveElemPos
92
93 // copy pSrc to pDstPtr
94L(strcpy_loop):
95 vsetvli iVL, zero, e8, ELEM_LMUL_SETTING, ta, ma
96
97 vle8ff.v vStr1, (pSrc)
98 vmseq.vx vMask2, vStr1, zero
99 csrr iCurrentVL, vl
100 vfirst.m iActiveElemPos, vMask2
101 vmsif.m vMask1, vMask2
102 add pSrc, pSrc, iCurrentVL
103 vse8.v vStr1, (pDstPtr), vMask1.t
104 add pDstPtr, pDstPtr, iCurrentVL
105 bltz iActiveElemPos, L(strcpy_loop)
106
107 ret
108
109END(strcat_vext)
110
111#endif