]> rtime.felk.cvut.cz Git - can-benchmark.git/commitdiff
sterm: Detect stale lock files
authorMichal Sojka <sojkam1@fel.cvut.cz>
Wed, 5 Feb 2014 17:23:23 +0000 (18:23 +0100)
committerMichal Sojka <sojkam1@fel.cvut.cz>
Wed, 5 Feb 2014 17:23:23 +0000 (18:23 +0100)
utils/sterm.c

index a3e9786ab82fd0e3e273b0e79f81f31e7183e7f7..e708a682cc049967e8801909b64f6d0594ceba1e 100644 (file)
@@ -174,9 +174,21 @@ int main(int argc, char *argv[])
                CHECK(write(tmp, pid, strlen(pid)));
                close(tmp);
                snprintf(lockfile, sizeof(lockfile), "/var/lock/LCK..%s", dev + 5);
+       retry:
                if (link(template, lockfile) == -1) {
-                       perror(lockfile);
-                       exit(1);
+                       tmp = CHECK(open(lockfile, O_RDONLY));
+                       CHECK(read(tmp, pid, sizeof(pid)));
+                       close(tmp);
+                       int p = atoi(pid);
+                       char proc[50];
+                       snprintf(proc, sizeof(proc), "/proc/%d", p);
+                       if (access(proc, F_OK) == 0) {
+                               fprintf(stderr, "%s is used by PID %d\n", dev, p);
+                               exit(1);
+                       }
+                       fprintf(stderr, "Stale lock file %s (PID %d) - removing it!\n", lockfile, p);
+                       CHECK(unlink(lockfile));
+                       goto retry;
                }
                rm_file(0, template);
                on_exit(rm_file, lockfile);