summaryrefslogtreecommitdiff
path: root/mysys/my_open.c
diff options
context:
space:
mode:
authorunknown <serg@serg.mylan>2005-01-11 00:14:46 +0100
committerunknown <serg@serg.mylan>2005-01-11 00:14:46 +0100
commit5e75c1fe36066b80336aa8cc168da07c06e7500c (patch)
treea1a3b3c5271193b389f4898d27e2a4d267bc1571 /mysys/my_open.c
parente3c7697431c144215af2f752d5c23b5b06e29982 (diff)
downloadmariadb-git-5e75c1fe36066b80336aa8cc168da07c06e7500c.tar.gz
my_close(), my_sync(): retry if EINTR
mysys/my_open.c: my_close(): retry if EINTR mysys/my_sync.c: fsync(): retry if EINTR
Diffstat (limited to 'mysys/my_open.c')
-rw-r--r--mysys/my_open.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/mysys/my_open.c b/mysys/my_open.c
index ca5c0d8683f..a5cd3811bbf 100644
--- a/mysys/my_open.c
+++ b/mysys/my_open.c
@@ -69,7 +69,7 @@ File my_open(const char *FileName, int Flags, myf MyFlags)
my_close()
fd File sescriptor
myf Special Flags
-
+
*/
int my_close(File fd, myf MyFlags)
@@ -79,7 +79,12 @@ int my_close(File fd, myf MyFlags)
DBUG_PRINT("my",("fd: %d MyFlags: %d",fd, MyFlags));
pthread_mutex_lock(&THR_LOCK_open);
- if ((err = close(fd)))
+ do
+ {
+ err= close(fd);
+ } while (err == -1 && errno == EINTR);
+
+ if (err)
{
DBUG_PRINT("error",("Got error %d on close",err));
my_errno=errno;