1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2 * vim:expandtab:shiftwidth=8:tabstop=8:
17 const char usage_fmt[] = "Usage: %s <mountpoint>\n";
18 #define INAME_LEN (PATH_MAX + 1)
20 #define CHECK_IT(exp, pstr) \
22 fprintf(stderr, "%s: at %s:%d: ", progname, __FILE__, __LINE__); \
27 #define CHECK_SNPRINTF(rc, len) \
28 CHECK_IT((rc) > 0 && (rc) <= (len), "snprintf() failed")
30 static char *get_iname(char *fname, const char *mtpt)
36 iname = malloc(INAME_LEN);
37 CHECK_IT(iname, "malloc() failed");
39 fd = open(fname, O_CREAT, 0644);
40 if (fd < 0 && errno != EISDIR) {
41 fprintf(stderr, "%s:%d: open(%s) failed: %s\n", __FILE__,
42 __LINE__, fname, strerror(errno));
49 rc = stat(fname, &buf);
51 fprintf(stderr, "%s:%d: stat(%s) failed: %s\n", __FILE__,
52 __LINE__, fname, strerror(errno));
56 rc = snprintf(iname, INAME_LEN,
57 "%s/__iopen__/%lu", mtpt, (unsigned long)buf.st_ino);
58 CHECK_SNPRINTF(rc, INAME_LEN);
63 int main(int argc, char *argv[])
65 char *fname, *mtpt, *pname;
66 char *fname_iname, *dir;
67 char *dir_iname = NULL, *foo = NULL, *bar = NULL;
68 int rc, fd, i, thread = 0;
70 pname = strdup(argv[0]);
71 progname = basename(argv[0]);
74 fprintf(stderr, usage_fmt, progname);
78 for (i = 1; i <= 10; i++) {
81 fprintf(stderr, "error: %s: #%d - %s\n", argv[0], i,
82 strerror(rc = errno));
88 printf("%s: thread #%d (PID %d) started\n", argv[0], i, rc);
94 fname = malloc(INAME_LEN);
95 CHECK_IT(fname, "malloc() failed");
97 rc = snprintf(fname, INAME_LEN,
98 "%s/%d", mtpt, getpid());
99 CHECK_SNPRINTF(rc, INAME_LEN);
101 rc = mkdir(fname, 0644);
103 fprintf(stderr, "%s:%d: mkdir(%s) failed: %s\n",
104 __FILE__, __LINE__, fname, strerror(errno));
108 fname_iname = get_iname(fname, mtpt);
110 dir = malloc(INAME_LEN);
111 CHECK_IT(dir, "malloc() failed");
113 rc = snprintf(dir, INAME_LEN, "%s/dir", fname_iname);
114 CHECK_SNPRINTF(rc, INAME_LEN);
116 foo = malloc(INAME_LEN);
117 CHECK_IT(foo, "malloc() failed");
119 bar = malloc(INAME_LEN);
120 CHECK_IT(bar, "malloc() failed");
122 for (i = 0; i < 1000; i++) {
123 rc = mkdir(dir, 0644);
125 fprintf(stderr, "%s:%d: mkdir(%s) failed: %s\n",
126 __FILE__, __LINE__, dir,
131 dir_iname = get_iname(dir, mtpt);
133 rc = snprintf(foo, INAME_LEN, "%s/bar", dir_iname);
134 CHECK_SNPRINTF(rc, INAME_LEN);
136 rc = snprintf(bar, INAME_LEN, "%s/bar", dir_iname);
137 CHECK_SNPRINTF(rc, INAME_LEN);
139 fd = open(foo, O_CREAT, 0644);
141 fprintf(stderr, "%s:%d: open(%s) failed: %s\n",
142 __FILE__, __LINE__, foo,
148 fprintf(stderr, "%s:%d: close() failed: %s\n",
149 __FILE__, __LINE__, strerror(errno));
153 rc = rename(foo, bar);
155 fprintf(stderr, "%s:%d: rename(%s, %s) failed: "
156 "%s\n", __FILE__, __LINE__, foo, bar,
163 fprintf(stderr, "%s:%d: unlink(%s) failed: "
164 "%s\n", __FILE__, __LINE__, bar,
170 fprintf(stderr, "%s:%d: rmdir(%s) failed: %s\n",
171 __FILE__, __LINE__, dir,