blob: e9da434f1b30ee9a57753af235de734f948fb88b [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 iLength a2
63#define pDstPtr a3
64
65#define iVL a4
66#define iCurrentVL a5
67#define iActiveElemPos a6
68
69#define ELEM_LMUL_SETTING m1
70#define vMask1 v0
71#define vMask2 v1
72#define vStr1 v8
73#define vStr2 v16
74
75ENTRY(strncat_vext)
76
77 mv pDstPtr, pDst
78
79 // the strlen of dst
80L(strlen_loop):
81 vsetvli iVL, zero, e8, ELEM_LMUL_SETTING, ta, ma
82
83 vle8ff.v vStr1, (pDstPtr)
84 // find the '\0'
85 vmseq.vx vMask1, vStr1, zero
86 csrr iCurrentVL, vl
87 vfirst.m iActiveElemPos, vMask1
88 add pDstPtr, pDstPtr, iCurrentVL
89 bltz iActiveElemPos, L(strlen_loop)
90
91 sub pDstPtr, pDstPtr, iCurrentVL
92 add pDstPtr, pDstPtr, iActiveElemPos
93
94 // copy pSrc to pDstPtr
95L(strcpy_loop):
96 vsetvli iVL, iLength, e8, ELEM_LMUL_SETTING, ta, ma
97
98 vle8ff.v vStr1, (pSrc)
99 vmseq.vx vMask2, vStr1, zero
100 csrr iCurrentVL, vl
101 vfirst.m iActiveElemPos, vMask2
102 vmsif.m vMask1, vMask2
103 add pSrc, pSrc, iCurrentVL
104 sub iLength, iLength, iCurrentVL
105 vse8.v vStr1, (pDstPtr), vMask1.t
106 add pDstPtr, pDstPtr, iCurrentVL
107 beqz iLength, L(fill_zero)
108 bltz iActiveElemPos, L(strcpy_loop)
109
110 ret
111
112L(fill_zero):
113 bgez iActiveElemPos, L(fill_zero_end)
114 sb zero, (pDstPtr)
115
116L(fill_zero_end):
117 ret
118
119END(strncat_vext)
120
121#endif