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;
71 pname = strdup(argv[0]);
72 progname = basename(argv[0]);
75 fprintf(stderr, usage_fmt, progname);
79 for (i = 1; i <= 10; i++) {
82 fprintf(stderr, "error: %s: #%d - %s\n", argv[0], i,
83 strerror(rc = errno));
89 printf("%s: thread #%d (PID %d) started\n", argv[0], i, rc);
96 fname = malloc(INAME_LEN);
97 CHECK_IT(fname, "malloc() failed");
99 rc = snprintf(fname, INAME_LEN,
100 "%s/%d", mtpt, getpid());
101 CHECK_SNPRINTF(rc, INAME_LEN);
103 rc = mkdir(fname, 0644);
105 fprintf(stderr, "%s:%d: mkdir(%s) failed: %s\n",
106 __FILE__, __LINE__, fname, strerror(errno));
110 fname_iname = get_iname(fname, mtpt);
112 dir = malloc(INAME_LEN);
113 CHECK_IT(dir, "malloc() failed");
115 rc = snprintf(dir, INAME_LEN, "%s/dir", fname_iname);
116 CHECK_SNPRINTF(rc, INAME_LEN);
118 foo = malloc(INAME_LEN);
119 CHECK_IT(foo, "malloc() failed");
121 bar = malloc(INAME_LEN);
122 CHECK_IT(bar, "malloc() failed");
124 for (i = 0; i < 1000; i++) {
125 rc = mkdir(dir, 0644);
127 fprintf(stderr, "%s:%d: mkdir(%s) failed: %s\n",
128 __FILE__, __LINE__, dir,
133 dir_iname = get_iname(dir, mtpt);
135 rc = snprintf(foo, INAME_LEN, "%s/bar", dir_iname);
136 CHECK_SNPRINTF(rc, INAME_LEN);
138 rc = snprintf(bar, INAME_LEN, "%s/bar", dir_iname);
139 CHECK_SNPRINTF(rc, INAME_LEN);
141 fd = open(foo, O_CREAT, 0644);
143 fprintf(stderr, "%s:%d: open(%s) failed: %s\n",
144 __FILE__, __LINE__, foo,
150 fprintf(stderr, "%s:%d: close() failed: %s\n",
151 __FILE__, __LINE__, strerror(errno));
155 rc = rename(foo, bar);
157 fprintf(stderr, "%s:%d: rename(%s, %s) failed: "
158 "%s\n", __FILE__, __LINE__, foo, bar,
165 fprintf(stderr, "%s:%d: unlink(%s) failed: "
166 "%s\n", __FILE__, __LINE__, bar,
172 fprintf(stderr, "%s:%d: rmdir(%s) failed: %s\n",
173 __FILE__, __LINE__, dir,
181 for ( i=0; i<10; i++)
182 waitpid(pidlist[i], NULL, 0);