lseek(2)


lseek, lseek64 -- move read/write file pointer

Synopsis

   #include <sys/types.h> 
   #include <unistd.h> 
   

off_t lseek(int fildes, off_t offset, int whence);

off64_t lseek64(int fildes, off64_t offset, int whence);

Description

lseek moves a read/write file pointer. fildes is a file descriptor returned from a creat(2), open(2), dup(2), fcntl(2), pipe(2) or ioctl(2) system call. lseek sets the file pointer associated with fildes as follows:

On success, lseek returns the resulting pointer location, as measured in bytes from the beginning of the file.

lseek allows the file pointer to be set beyond the existing data in the file. If data is later written at this point, subsequent reads in the gap between the previous end of data and the newly written data return bytes of value 0 until data is written into the gap.

Return values

On success, lseek and lseek64 return a non-negative integer indicating the file pointer value. On failure, lseek and lseek64 return -1, set errno to identify the error, and the file pointer remains unchanged.

Some devices are incapable of seeking. The value of the file pointer associated with such a device is undefined.

Errors

In the following conditions, lseek fails and sets errno to:

EOVERFLOW
The resulting file offset would be a value which cannot be represented correctly in an object of type off_t. The file pointer is not moved.

In the following conditions, lseek and lseek64 fail and set errno to:

EBADF
fildes is not an open file descriptor.

ESPIPE
fildes is associated with a pipe, fifo or socket.

EINVAL
The resulting file pointer would be negative.

fildes is a remote file descriptor accessed using NFS, the Network File System, and the resulting file pointer would be negative.

ENOSYS
The device for fstype does not support lseek or lseek64.

References

creat(2), dup(2), fcntl(2), intro(2), open(2)

Notices

Considerations for threads programming

Open file descriptors are a process resource and available to any sibling thread; if used concurrently, actions by one thread can interfere with those of a sibling. For example, the position of the file pointer is maintained per file descriptor, not per thread.

The pread(2) and pwrite(2) system calls combine positioning and I/O in a single operation.

Considerations for Large File Support

lseek64 supports large files, but is otherwise identical to lseek. For details on programming for large file capable applications, see ``Large File Support'' on intro(2).


30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.