blob: 1aedaf9cd52e3620e5a9c03761cfe34c820d296d [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 ZERO_FILL_ELEM_LMUL_SETTING m8
73#define vStr1 v8
74#define vStr2 v16
75
76ENTRY(strncpy_vext)
77
78 mv pDstPtr, pDst
79
80 // copy pSrc to pDstPtr
81L(strcpy_loop):
82 vsetvli iVL, iLength, e8, ELEM_LMUL_SETTING, ta, ma
83 vle8ff.v vStr1, (pSrc)
84 vmseq.vx vMask2, vStr1, zero
85 csrr iCurrentVL, vl
86 vfirst.m iActiveElemPos, vMask2
87 vmsif.m vMask1, vMask2
88 add pSrc, pSrc, iCurrentVL
89 sub iLength, iLength, iCurrentVL
90 vse8.v vStr1, (pDstPtr), vMask1.t
91 add pDstPtr, pDstPtr, iCurrentVL
92 bgez iActiveElemPos, L(fill_zero)
93 bnez iLength, L(strcpy_loop)
94 ret
95
96 # fill the tail zero.
97L(fill_zero):
98 sub iVL, iCurrentVL, iActiveElemPos
99 add iLength, iLength, iVL
100 bnez iLength, 1f
101 ret
1021:
103 sub pDstPtr, pDstPtr, iVL
104 vsetvli zero, iLength, e8, ZERO_FILL_ELEM_LMUL_SETTING, ta, ma
105 vmv.v.x vStr2, zero
106
107L(fill_zero_loop):
108 vsetvli iVL, iLength, e8, ZERO_FILL_ELEM_LMUL_SETTING, ta, ma
109 vse8.v vStr2, (pDstPtr)
110 sub iLength, iLength, iVL
111 add pDstPtr, pDstPtr, iVL
112 bnez iLength, L(fill_zero_loop)
113
114 ret
115
116END(strncpy_vext)
117
118#endif