#include #include #include "flashfs.h" int convJ2M(Jrec *j, uchar *buff) { int m, n; switch(j->type) { case FT_create: if(j->mode & (1 << 8)) { if(j->mode & DMDIR) j->type = FT_DCREATE1; else j->type = FT_FCREATE1; } else { if(j->mode & DMDIR) j->type = FT_DCREATE0; else j->type = FT_FCREATE0; } case FT_FCREATE0: case FT_FCREATE1: case FT_DCREATE0: case FT_DCREATE1: n = putc3(&buff[0], j->fnum); goto create; case FT_chmod: if(j->mode & (1 << 8)) j->type = FT_CHMOD1; else j->type = FT_CHMOD0; case FT_CHMOD0: case FT_CHMOD1: n = putc3(&buff[0], j->fnum); buff[n++] = j->mode; return n + putc3(&buff[n], j->mnum); case FT_REMOVE: return putc3(&buff[0], j->fnum); case FT_WRITE: n = putc3(&buff[0], j->fnum); n += putc3(&buff[n], j->mtime); n += putc3(&buff[n], j->offset); return n + putc3(&buff[n], j->size - 1); case FT_AWRITE: n = putc3(&buff[0], j->fnum); n += putc3(&buff[n], j->offset); return n + putc3(&buff[n], j->size - 1); case FT_trunc: if(j->mode & (1 << 8)) j->type = FT_TRUNC1; else j->type = FT_TRUNC0; case FT_TRUNC0: case FT_TRUNC1: n = putc3(&buff[0], j->fnum); n += putc3(&buff[n], j->tnum); goto create; case FT_SUMMARY: case FT_SUMBEG: return putc3(&buff[0], j->seq); case FT_SUMEND: return 0; create: buff[n++] = j->mode; n += putc3(&buff[n], j->mtime); n += putc3(&buff[n], j->parent); m = strlen(j->name); memmove(&buff[n], j->name, m); n += m; buff[n++] = '\0'; return n; } return -1; } int convM2J(Jrec *j, uchar *buff) { int m, n; j->type = buff[0]; switch(j->type) { case FT_FCREATE0: case FT_FCREATE1: case FT_DCREATE0: case FT_DCREATE1: n = 1 + getc3(&buff[1], &j->fnum); j->mode = buff[n++]; switch(j->type) { case FT_FCREATE0: break; case FT_FCREATE1: j->mode |= 1 << 8; break; case FT_DCREATE0: j->mode |= DMDIR; break; case FT_DCREATE1: j->mode |= DMDIR | (1 << 8); break; } j->type = FT_create; goto create; case FT_CHMOD0: case FT_CHMOD1: n = 1 + getc3(&buff[1], &j->fnum); j->mode = buff[n++]; switch(j->type) { case FT_CHMOD0: break; case FT_CHMOD1: j->mode |= 1 << 8; break; } j->type = FT_chmod; return n + getc3(&buff[n], &j->mnum); case FT_REMOVE: return 1 + getc3(&buff[1], &j->fnum); case FT_WRITE: n = 1 + getc3(&buff[1], &j->fnum); n += getc3(&buff[n], &j->mtime); n += getc3(&buff[n], &j->offset); n += getc3(&buff[n], &j->size); j->size++; return n; case FT_AWRITE: n = 1 + getc3(&buff[1], &j->fnum); n += getc3(&buff[n], &j->offset); n += getc3(&buff[n], &j->size); j->size++; return n; case FT_TRUNC0: case FT_TRUNC1: n = 1 + getc3(&buff[1], &j->fnum); n += getc3(&buff[n], &j->tnum); j->mode = buff[n++]; switch(j->type) { case FT_TRUNC0: break; case FT_TRUNC1: j->mode |= 1 << 8; break; } j->type = FT_trunc; goto create; case FT_SUMMARY: case FT_SUMBEG: return 1 + getc3(&buff[1], &j->seq); case FT_SUMEND: return 1; create: n += getc3(&buff[n], &j->mtime); n += getc3(&buff[n], &j->parent); memmove(j->name, &buff[n], MAXNSIZE+1); j->name[MAXNSIZE+1] = '\0'; m = strlen(j->name); if(m > MAXNSIZE) return -1; return n + m + 1; } return -1; } int Jconv(va_list *arg, Fconv *fp) { Jrec *j; char buf[256]; j = va_arg(*arg, Jrec *); switch(j->type) { case FT_create: case FT_FCREATE0: case FT_FCREATE1: case FT_DCREATE0: case FT_DCREATE1: snprint(buf, sizeof(buf), "create f %ld p %ld t %lud m %ulo %s", j->fnum, j->parent, j->mtime, j->mode, j->name); break; case FT_chmod: case FT_CHMOD0: case FT_CHMOD1: snprint(buf, sizeof(buf), "chmod f %ld m %ulo #%ld", j->fnum, j->mode, j->mnum); break; case FT_REMOVE: snprint(buf, sizeof(buf), "remove f %ld", j->fnum); break; case FT_WRITE: snprint(buf, sizeof(buf), "write f %ld z %ld o %ld t %uld", j->fnum, j->size, j->offset, j->mtime); break; case FT_AWRITE: snprint(buf, sizeof(buf), "awrite f %ld z %ld o %ld", j->fnum, j->size, j->offset); break; case FT_trunc: case FT_TRUNC0: case FT_TRUNC1: snprint(buf, sizeof(buf), "trunc f %ld o %ld p %ld t %ld m %ulo %s", j->fnum, j->tnum, j->parent, j->mtime, j->mode, j->name); break; case FT_SUMMARY: snprint(buf, sizeof(buf), "summary %ld", j->seq); break; case FT_SUMBEG: snprint(buf, sizeof(buf), "sumbeg %ld", j->seq); break; case FT_SUMEND: strcpy(buf, "end"); break; default: snprint(buf, sizeof(buf), "?type %d", j->type); } strconv(buf, fp); return 0; }