physfs_platform_posix.c: Retry on EINTR
This commit is contained in:
parent
52c3f19e17
commit
3c32cd5600
|
@ -6,8 +6,6 @@
|
||||||
* This file written by Ryan C. Gordon.
|
* This file written by Ryan C. Gordon.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* !!! FIXME: check for EINTR? */
|
|
||||||
|
|
||||||
#define __PHYSICSFS_INTERNAL__
|
#define __PHYSICSFS_INTERNAL__
|
||||||
#include "physfs_platforms.h"
|
#include "physfs_platforms.h"
|
||||||
|
|
||||||
|
@ -167,7 +165,9 @@ static void *doOpen(const char *filename, int mode)
|
||||||
/* O_APPEND doesn't actually behave as we'd like. */
|
/* O_APPEND doesn't actually behave as we'd like. */
|
||||||
mode &= ~O_APPEND;
|
mode &= ~O_APPEND;
|
||||||
|
|
||||||
|
do {
|
||||||
fd = open(filename, mode, S_IRUSR | S_IWUSR);
|
fd = open(filename, mode, S_IRUSR | S_IWUSR);
|
||||||
|
} while ((fd < 0) && (errno == EINTR));
|
||||||
BAIL_IF(fd < 0, errcodeFromErrno(), NULL);
|
BAIL_IF(fd < 0, errcodeFromErrno(), NULL);
|
||||||
|
|
||||||
if (appending)
|
if (appending)
|
||||||
|
@ -219,7 +219,9 @@ PHYSFS_sint64 __PHYSFS_platformRead(void *opaque, void *buffer,
|
||||||
if (!__PHYSFS_ui64FitsAddressSpace(len))
|
if (!__PHYSFS_ui64FitsAddressSpace(len))
|
||||||
BAIL(PHYSFS_ERR_INVALID_ARGUMENT, -1);
|
BAIL(PHYSFS_ERR_INVALID_ARGUMENT, -1);
|
||||||
|
|
||||||
|
do {
|
||||||
rc = read(fd, buffer, (size_t) len);
|
rc = read(fd, buffer, (size_t) len);
|
||||||
|
} while ((rc == -1) && (errno == EINTR));
|
||||||
BAIL_IF(rc == -1, errcodeFromErrno(), -1);
|
BAIL_IF(rc == -1, errcodeFromErrno(), -1);
|
||||||
assert(rc >= 0);
|
assert(rc >= 0);
|
||||||
assert(rc <= len);
|
assert(rc <= len);
|
||||||
|
@ -236,7 +238,9 @@ PHYSFS_sint64 __PHYSFS_platformWrite(void *opaque, const void *buffer,
|
||||||
if (!__PHYSFS_ui64FitsAddressSpace(len))
|
if (!__PHYSFS_ui64FitsAddressSpace(len))
|
||||||
BAIL(PHYSFS_ERR_INVALID_ARGUMENT, -1);
|
BAIL(PHYSFS_ERR_INVALID_ARGUMENT, -1);
|
||||||
|
|
||||||
|
do {
|
||||||
rc = write(fd, (void *) buffer, (size_t) len);
|
rc = write(fd, (void *) buffer, (size_t) len);
|
||||||
|
} while ((rc == -1) && (errno == EINTR));
|
||||||
BAIL_IF(rc == -1, errcodeFromErrno(), rc);
|
BAIL_IF(rc == -1, errcodeFromErrno(), rc);
|
||||||
assert(rc >= 0);
|
assert(rc >= 0);
|
||||||
assert(rc <= len);
|
assert(rc <= len);
|
||||||
|
@ -275,8 +279,13 @@ PHYSFS_sint64 __PHYSFS_platformFileLength(void *opaque)
|
||||||
int __PHYSFS_platformFlush(void *opaque)
|
int __PHYSFS_platformFlush(void *opaque)
|
||||||
{
|
{
|
||||||
const int fd = *((int *) opaque);
|
const int fd = *((int *) opaque);
|
||||||
if ((fcntl(fd, F_GETFL) & O_ACCMODE) != O_RDONLY)
|
int rc = -1;
|
||||||
BAIL_IF(fsync(fd) == -1, errcodeFromErrno(), 0);
|
if ((fcntl(fd, F_GETFL) & O_ACCMODE) != O_RDONLY) {
|
||||||
|
do {
|
||||||
|
rc = fsync(fd);
|
||||||
|
} while ((rc == -1) && (errno == EINTR));
|
||||||
|
BAIL_IF(rc == -1, errcodeFromErrno(), 0);
|
||||||
|
}
|
||||||
return 1;
|
return 1;
|
||||||
} /* __PHYSFS_platformFlush */
|
} /* __PHYSFS_platformFlush */
|
||||||
|
|
||||||
|
@ -284,7 +293,10 @@ int __PHYSFS_platformFlush(void *opaque)
|
||||||
void __PHYSFS_platformClose(void *opaque)
|
void __PHYSFS_platformClose(void *opaque)
|
||||||
{
|
{
|
||||||
const int fd = *((int *) opaque);
|
const int fd = *((int *) opaque);
|
||||||
(void) close(fd); /* we don't check this. You should have used flush! */
|
int rc = -1;
|
||||||
|
do {
|
||||||
|
rc = close(fd); /* we don't check this. You should have used flush! */
|
||||||
|
} while ((rc == -1) && (errno == EINTR));
|
||||||
allocator.Free(opaque);
|
allocator.Free(opaque);
|
||||||
} /* __PHYSFS_platformClose */
|
} /* __PHYSFS_platformClose */
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue