annotate src/lib/file-set-size.c @ 6569:b7d8695d864d HEAD

If file_set_size() fails for any other reason than "not enough disk space/quota", log the syscall that caused the error.
author Timo Sirainen <tss@iki.fi>
date Sat, 20 Oct 2007 20:51:30 +0300
parents 65c69a53a7be
children a9dfe05dfadd
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6429
65c69a53a7be Replaced my Copyright notices. The year range always ends with 2007 now.
Timo Sirainen <tss@iki.fi>
parents: 5667
diff changeset
1 /* Copyright (c) 2002-2007 Dovecot authors, see the included COPYING file */
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
2
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
3 #define _XOPEN_SOURCE 600 /* Required by glibc */
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
4 #include "lib.h"
222
cf4d065f2f85 lots of cleanups. also index/datafile is now capable of staying in memory,
Timo Sirainen <tss@iki.fi>
parents: 221
diff changeset
5 #include "file-set-size.h"
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
6
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
7 #include <unistd.h>
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
8 #include <fcntl.h>
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
9 #include <sys/stat.h>
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
10
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
11 int file_set_size(int fd, off_t size)
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
12 {
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
13 #ifndef HAVE_POSIX_FALLOCATE
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
14 char block[4096];
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
15 off_t offset;
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
16 ssize_t ret;
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
17 #endif
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
18 struct stat st;
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
19
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
20 i_assert(size >= 0);
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
21
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
22 if (fstat(fd, &st) < 0) {
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
23 i_error("fstat() failed: %m");
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
24 return -1;
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
25 }
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
26
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
27 if (size < st.st_size) {
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
28 if (ftruncate(fd, size) < 0) {
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
29 i_error("ftruncate() failed: %m");
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
30 return -1;
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
31 }
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
32 return 0;
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
33 }
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
34 if (size == st.st_size)
252
14bad0a48eb4 file_set_size() was buggy when it was supposed to shrink file
Timo Sirainen <tss@iki.fi>
parents: 222
diff changeset
35 return 0;
222
cf4d065f2f85 lots of cleanups. also index/datafile is now capable of staying in memory,
Timo Sirainen <tss@iki.fi>
parents: 221
diff changeset
36
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
37 #ifdef HAVE_POSIX_FALLOCATE
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
38 if (posix_fallocate(fd, st.st_size, size - st.st_size) < 0) {
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
39 if (!ENOSPACE(errno))
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
40 i_error("posix_fallocate() failed: %m");
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
41 return -1;
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
42 }
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
43 #else
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
44 /* start growing the file */
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
45 offset = st.st_size;
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
46 memset(block, 0, I_MIN((ssize_t)sizeof(block), size - offset));
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
47
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
48 while (offset < size) {
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
49 ret = pwrite(fd, block,
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
50 I_MIN((ssize_t)sizeof(block), size - offset),
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
51 offset);
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
52 if (ret < 0) {
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
53 if (!ENOSPACE(errno))
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
54 i_error("pwrite() failed: %m");
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
55 return -1;
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
56 }
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
57 offset += size;
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
58 }
6569
b7d8695d864d If file_set_size() fails for any other reason than "not enough disk
Timo Sirainen <tss@iki.fi>
parents: 6429
diff changeset
59 #endif
5456
3660736f8163 Use posix_fallocate() if possible. Also did minor optimizations to the
Timo Sirainen <tss@iki.fi>
parents: 1741
diff changeset
60 return 0;
221
ed0d5b17c7a4 Added extra functions for easier printing of error messages. Moved
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
61 }