Browse Source

Merge pull request #1392 from trapexit/usr1

Send invalidate node request outside lock
pull/1398/head
trapexit 2 weeks ago
committed by GitHub
parent
commit
bc382e0fd2
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 26
      libfuse/lib/fuse.cpp

26
libfuse/lib/fuse.cpp

@ -27,6 +27,9 @@
#include "fuse_pollhandle.h" #include "fuse_pollhandle.h"
#include "fuse_msgbuf.hpp" #include "fuse_msgbuf.hpp"
#include <vector>
#include <string>
#include <assert.h> #include <assert.h>
#include <dlfcn.h> #include <dlfcn.h>
#include <errno.h> #include <errno.h>
@ -3902,8 +3905,7 @@ void
fuse_invalidate_all_nodes() fuse_invalidate_all_nodes()
{ {
struct fuse *f = fuse_get_fuse_obj(); struct fuse *f = fuse_get_fuse_obj();
syslog(LOG_INFO,"invalidating file entries");
std::vector<std::string> names;
pthread_mutex_lock(&f->lock); pthread_mutex_lock(&f->lock);
for(size_t i = 0; i < f->id_table.size; i++) for(size_t i = 0; i < f->id_table.size; i++)
@ -3914,16 +3916,28 @@ fuse_invalidate_all_nodes()
{ {
if(node->nodeid == FUSE_ROOT_ID) if(node->nodeid == FUSE_ROOT_ID)
continue; continue;
if(node->name == NULL)
continue;
if(node->parent == NULL)
continue;
if(node->parent->nodeid != FUSE_ROOT_ID) if(node->parent->nodeid != FUSE_ROOT_ID)
continue; continue;
fuse_lowlevel_notify_inval_entry(f->se->ch,
node->parent->nodeid,
node->name,
strlen(node->name));
names.emplace_back(node->name);
} }
} }
pthread_mutex_unlock(&f->lock); pthread_mutex_unlock(&f->lock);
syslog(LOG_INFO,
"invalidating %ld file entries",
names.size());
for(auto &name : names)
{
fuse_lowlevel_notify_inval_entry(f->se->ch,
FUSE_ROOT_ID,
name.c_str(),
name.size());
}
} }
void void

Loading…
Cancel
Save