Alien-Libjio
view release on metacpan or search on metacpan
libjio/libjio/check.c view on Meta::CPAN
filelen = lseek(tfd, 0, SEEK_END);
if (filelen == 0) {
res->broken++;
goto loop;
} else if (filelen < 0) {
ret = J_EIO;
goto exit;
}
/* no overflow problems because we know the transaction size
* is limited to SSIZE_MAX */
map = mmap((void *) 0, filelen, PROT_READ, MAP_SHARED, tfd, 0);
if (map == MAP_FAILED) {
map = NULL;
ret = J_EIO;
goto exit;
}
rv = fill_trans(map, filelen, curts);
if (rv == -1) {
res->broken++;
goto loop;
} else if (rv == -2) {
res->corrupt++;
goto loop;
}
/* remove flags from the transaction, so we don't have issues
* re-committing */
curts->flags = 0;
rv = jtrans_commit(curts);
if (rv < 0) {
ret = J_EIO;
goto exit;
}
res->reapplied++;
loop:
if (unlink(tname) != 0) {
ret = J_EIO;
goto exit;
}
nounlink_loop:
if (tfd >= 0) {
close(tfd);
tfd = -1;
}
if (map != NULL)
munmap(map, filelen);
while (curts->op != NULL) {
tmpop = curts->op->next;
if (curts->op->pdata)
free(curts->op->pdata);
free(curts->op);
curts->op = tmpop;
}
pthread_mutex_destroy(&(curts->lock));
free(curts);
res->total++;
}
if (flags & J_CLEANUP) {
if (jfsck_cleanup(name, fs.jdir) < 0) {
ret = J_ECLEANUP;
}
}
exit:
if (fs.fd >= 0)
close(fs.fd);
if (fs.jfd >= 0)
close(fs.jfd);
if (fs.jdirfd >= 0)
close(fs.jdirfd);
if (fs.jdir)
free(fs.jdir);
if (dir != NULL)
closedir(dir);
if (fs.jmap != MAP_FAILED)
munmap(fs.jmap, sizeof(unsigned int));
return ret;
}
( run in 0.402 second using v1.01-cache-2.11-cpan-5b529ec07f3 )