1*8fd04b83SRoger A. Faulkner /*
2*8fd04b83SRoger A. Faulkner * CDDL HEADER START
3*8fd04b83SRoger A. Faulkner *
4*8fd04b83SRoger A. Faulkner * The contents of this file are subject to the terms of the
5*8fd04b83SRoger A. Faulkner * Common Development and Distribution License (the "License").
6*8fd04b83SRoger A. Faulkner * You may not use this file except in compliance with the License.
7*8fd04b83SRoger A. Faulkner *
8*8fd04b83SRoger A. Faulkner * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*8fd04b83SRoger A. Faulkner * or http://www.opensolaris.org/os/licensing.
10*8fd04b83SRoger A. Faulkner * See the License for the specific language governing permissions
11*8fd04b83SRoger A. Faulkner * and limitations under the License.
12*8fd04b83SRoger A. Faulkner *
13*8fd04b83SRoger A. Faulkner * When distributing Covered Code, include this CDDL HEADER in each
14*8fd04b83SRoger A. Faulkner * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*8fd04b83SRoger A. Faulkner * If applicable, add the following below this CDDL HEADER, with the
16*8fd04b83SRoger A. Faulkner * fields enclosed by brackets "[]" replaced with your own identifying
17*8fd04b83SRoger A. Faulkner * information: Portions Copyright [yyyy] [name of copyright owner]
18*8fd04b83SRoger A. Faulkner *
19*8fd04b83SRoger A. Faulkner * CDDL HEADER END
20*8fd04b83SRoger A. Faulkner */
21*8fd04b83SRoger A. Faulkner
22*8fd04b83SRoger A. Faulkner /*
23*8fd04b83SRoger A. Faulkner * Copyright 2010 Sun Microsystems, Inc. All rights reserved.
24*8fd04b83SRoger A. Faulkner * Use is subject to license terms.
25*8fd04b83SRoger A. Faulkner */
26*8fd04b83SRoger A. Faulkner
27*8fd04b83SRoger A. Faulkner #include "lint.h"
28*8fd04b83SRoger A. Faulkner #include <stdio.h>
29*8fd04b83SRoger A. Faulkner #include <unistd.h>
30*8fd04b83SRoger A. Faulkner #include <sys/syscall.h>
31*8fd04b83SRoger A. Faulkner #include <sys/fcntl.h>
32*8fd04b83SRoger A. Faulkner
33*8fd04b83SRoger A. Faulkner int
renameat(int oldfd,const char * oldname,int newfd,const char * newname)34*8fd04b83SRoger A. Faulkner renameat(int oldfd, const char *oldname, int newfd, const char *newname)
35*8fd04b83SRoger A. Faulkner {
36*8fd04b83SRoger A. Faulkner return (syscall(SYS_renameat, oldfd, oldname, newfd, newname));
37*8fd04b83SRoger A. Faulkner }
38*8fd04b83SRoger A. Faulkner
39*8fd04b83SRoger A. Faulkner #pragma weak _rename = rename
40*8fd04b83SRoger A. Faulkner int
rename(const char * oldname,const char * newname)41*8fd04b83SRoger A. Faulkner rename(const char *oldname, const char *newname)
42*8fd04b83SRoger A. Faulkner {
43*8fd04b83SRoger A. Faulkner #if defined(_RETAIN_OLD_SYSCALLS)
44*8fd04b83SRoger A. Faulkner return (syscall(SYS_rename, oldname, newname));
45*8fd04b83SRoger A. Faulkner #else
46*8fd04b83SRoger A. Faulkner return (renameat(AT_FDCWD, oldname, AT_FDCWD, newname));
47*8fd04b83SRoger A. Faulkner #endif
48*8fd04b83SRoger A. Faulkner }
49