|
|
BSD 4.3reno
/* * Copyright (c) 1983 Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that: (1) source distributions retain this entire copyright * notice and comment, and (2) distributions including binaries display * the following acknowledgement: ``This product includes software * developed by the University of California, Berkeley and its contributors'' * in the documentation or other materials provided with the distribution * and in all advertising materials mentioning features or use of this * software. Neither the name of the University nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ #if defined(LIBC_SCCS) && !defined(lint) .asciz "@(#)strcat.s 5.6 (Berkeley) 6/1/90" #endif /* LIBC_SCCS and not lint */ /* * Concatenate string s2 to the end of s1 * and return the base of s1. * * char * * strcat(s1, s2) * char *s1, *s2; */ #include "DEFS.h" ENTRY(strcat, R6|R7) movq 4(ap), r6 # r6 = s1; r7 = s2 movl r6,r1 0: locc $0,$65535,(r1) # look for '\0' beql 0b movl r1,r3 # save end of s1 1: locc $0,$65535,(r7) # find length of s2 bneq 2f movc3 $65535,(r7),(r3)# copy full block movl r1,r7 jbr 1b 2: subl2 r7,r1 # calculate length incl r1 movc3 r1,(r7),(r3) # copy remainder movl r6,r0 ret
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.