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 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 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