X-Git-Url: http://git.vrable.net/?a=blobdiff_plain;f=nfs3%2Fnfsd.c;h=e4beac1ad37e7a72e815341b33558778937597b8;hb=98effa493bca2b6e97d98035be602993da27d26b;hp=7a0338d6d2fbb50b08d1a123f66938a4a5d20a69;hpb=2246171d841d34e6368e340a6b76b7ee9d9a1084;p=bluesky.git diff --git a/nfs3/nfsd.c b/nfs3/nfsd.c index 7a0338d..e4beac1 100644 --- a/nfs3/nfsd.c +++ b/nfs3/nfsd.c @@ -17,15 +17,35 @@ #include #include #include +#include + +#include "bluesky.h" void register_rpc(); +BlueSkyFS *fs; +BlueSkyStore *store; + int main(int argc, char *argv[]) { + int i; + bluesky_init(); register_rpc(); - svc_run (); - fprintf (stderr, "%s", "svc_run returned"); - exit (1); - /* NOTREACHED */ + store = bluesky_store_new("file"); + fs = bluesky_init_fs("export", store); + + BlueSkyInode *root; + 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"); + exit(1); }