X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=nfs3%2Fnfsd.c;h=16011f4ab7bd8c5dc091e9188ab56490eeb8df55;hb=7bb8900e1209a2abf3d83e7f06e2dfb314cef61e;hp=abd10509814f19f02ac598e6ddfc1282a940b7ba;hpb=e1fcdf3f1a7a2de0289526a5481009c3380f7547;p=bluesky.git diff --git a/nfs3/nfsd.c b/nfs3/nfsd.c index abd1050..16011f4 100644 --- a/nfs3/nfsd.c +++ b/nfs3/nfsd.c @@ -24,26 +24,28 @@ void register_rpc(); BlueSkyFS *fs; +BlueSkyStore *store; int main(int argc, char *argv[]) { - g_thread_init(NULL); + int i; + bluesky_init(); register_rpc(); - fs = bluesky_new_fs("export"); + bluesky_options.synchronous_stores = 1; + + store = bluesky_store_new("file"); + fs = bluesky_init_fs("export", store); BlueSkyInode *root; - root = bluesky_new_inode(BLUESKY_ROOT_INUM, BLUESKY_DIRECTORY); - root->nlink = 1; - root->mode = 0755; - bluesky_insert_inode(fs, root); - - BlueSkyInode *file; - file = bluesky_new_inode(bluesky_fs_alloc_inode(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");