Commit 
4dc7e675bb (Don't unhash name in FORGET) broke the forget logic in a
subtle way, resulting in "fuse internal error: node NNN not found" and causing
the filesystem daemon to abort.
Fix by incrementing the node refcount if nlookup goes from zero to one.
Reported by Kyle Lippincott
+2012-08-14  Miklos Szeredi <miklos@szeredi.hu>
+
+       * Not unhashing the name in forget (commit on 2011-12-09) broke
+       the forget logic in a subtle way, resulting in "fuse internal
+       error: node NNN not found" and causing the filesystem daemon to
+       abort.  Fix by incrementing the node refcount if nlookup goes from
+       zero to one.  Reported by Kyle Lippincott
+
 2012-08-13  Miklos Szeredi <miklos@szeredi.hu>
 
        * Fix linking against GNU libiconv.  Patch by Natanael Copa
 
        return NULL;
 }
 
+static void inc_nlookup(struct node *node)
+{
+       if (!node->nlookup)
+               node->refctr++;
+       node->nlookup++;
+}
+
 static struct node *find_node(struct fuse *f, fuse_ino_t parent,
                              const char *name)
 {
                if (node == NULL)
                        goto out_err;
 
-               if (f->conf.remember)
-                       node->nlookup = 1;
-               node->refctr = 1;
+               node->refctr = 0;
                node->nodeid = next_id(f);
                node->generation = f->generation;
                node->open_count = 0;
                node->is_hidden = 0;
                node->treelock = 0;
                node->ticket = 0;
+               if (f->conf.remember)
+                       inc_nlookup(node);
+
                if (hash_name(f, node, parent, name) == -1) {
                        free_node(f, node);
                        node = NULL;
        } else if (lru_enabled(f) && node->nlookup == 1) {
                remove_node_lru(node);
        }
-       node->nlookup ++;
+       inc_nlookup(node);
 out_err:
        pthread_mutex_unlock(&f->lock);
        return node;