X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=nfs3%2Fnfsd.c;h=e3862aa74abbb81983ab7ccd5b22303e45974197;hb=45a4f324927f8fe3b7e689dd0c9a28716d0d1e93;hp=8ba3ef04193d22129fb6799c0b049146f62a0c23;hpb=a5a9eca66728d271a442125ac52098378c70cf42;p=bluesky.git diff --git a/nfs3/nfsd.c b/nfs3/nfsd.c index 8ba3ef0..e3862aa 100644 --- a/nfs3/nfsd.c +++ b/nfs3/nfsd.c @@ -44,17 +44,14 @@ int main(int argc, char *argv[]) fs->encryption_key = filesystem_key; BlueSkyInode *root; - root = bluesky_new_inode(BLUESKY_ROOT_INUM, fs, BLUESKY_DIRECTORY); - root->nlink = 1; - root->mode = 0755; - bluesky_insert_inode(fs, root); - - BlueSkyInode *file; - file = bluesky_new_inode(bluesky_fs_alloc_inode(fs), fs, BLUESKY_REGULAR); - file->nlink = 1; - file->mode = 0755; - bluesky_insert_inode(fs, file); - bluesky_directory_insert(root, "demo", file->inum); + root = bluesky_get_inode(fs, BLUESKY_ROOT_INUM); + if (root == NULL) { + printf("Initializing fresh root inode...\n"); + root = bluesky_new_inode(BLUESKY_ROOT_INUM, fs, BLUESKY_DIRECTORY); + root->nlink = 1; + root->mode = 0755; + bluesky_insert_inode(fs, root); + } svc_run(); fprintf(stderr, "%s", "svc_run returned");