/**************************************************************************** * libs/libc/unistd/lib_posix_fallocate.c * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. The * ASF licenses this file to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance with the * License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. * ****************************************************************************/ /**************************************************************************** * Included Files ****************************************************************************/ #include <fcntl.h> #include <errno.h> #include <unistd.h> #include <sys/stat.h> #ifndef CONFIG_DISABLE_MOUNTPOINT /**************************************************************************** * Public Functions ****************************************************************************/ /**************************************************************************** * Name: posix_fallocate * * Description: * The posix_fallocate() function shall ensure that any required storage for * regular file data starting at offset and continuing for len bytes is * allocated on the file system storage media. If posix_fallocate() returns * successfully, subsequent writes to the specified file data shall not fail * due to the lack of free space on the file system storage media. * * If the offset+len is beyond the current file size, then posix_fallocate() * shall adjust the file size to offset+len. Otherwise, the file size shall * not be changed. * * It is implementation-defined whether a previous posix_fadvise() call * influences allocation strategy. * * Space allocated via posix_fallocate() shall be freed by a successful call * to creat() or open() that truncates the size of the file. Space allocated * via posix_fallocate() may be freed by a successful call to ftruncate() * that reduces the file size to a size smaller than offset+ len. * * Returned Value: * Upon successful completion, posix_fallocate() shall return zero; * otherwise, an error number shall be returned to indicate the error. * ****************************************************************************/ int posix_fallocate(int fd, off_t offset, off_t len) { struct stat st; if (offset < 0 || len < 0) { return EINVAL; } len += offset; if (len < 0) { return EFBIG; } if (fstat(fd, &st) != 0) { return get_errno(); } if (st.st_size < len) { if (ftruncate(fd, len) != 0) { return get_errno(); } } return 0; } #endif /* !CONFIG_DISABLE_MOUNTPOINT */