1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
/* IA-64 assembly version of the standard strcat() function.
This file is part of the GNU C Library.
Copyright (C) 2000 Free Software Foundation, Inc.
Contributed by Dan Pop <Dan.Pop@cern.ch>.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
/* Return: dest
Inputs:
in0: dest
in1: src
A straightforword implementation: strcpy(dest + strlen(dest), src).
Could be marginally optimised by inlining the code of strcpy() and
strlen(), to avoid the two function calls. OTOH, by not doing that,
we avoid L1I cache pollution (code using strcat() is likely to also
use strcpy() and strlen(), so we already have a copy of these functions
in the cache). */
#include <sysdep.h>
#undef ret
#define src in1
#define dest in0
#define save_pfs loc0
#define save_b0 loc1
#define tmp loc2
#define rc ret0
ENTRY(strcat)
alloc save_pfs = ar.pfs, 2, 3, 2, 0
mov save_b0 = b0
mov out0 = dest
mov tmp = gp ;;
br.call.sptk.many b0 = strlen# ;; // rc = strlen(dest);
mov gp = tmp
add out0 = dest, rc
mov out1 = src
br.call.sptk.many b0 = strcpy# ;; // strcpy(dest + strlen(dest), src)
mov gp = tmp
mov rc = dest
mov b0 = save_b0
mov ar.pfs = save_pfs
br.ret.sptk.many b0
END(strcat)
|