mirror of https://github.com/trapexit/mergerfs.git
Browse Source
Merge pull request #775 from trapexit/inode-calc
Merge pull request #775 from trapexit/inode-calc
add 'inodecalc' option to allow selection of inode calculation algopull/776/head
trapexit
5 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
14 changed files with 474 additions and 134 deletions
-
79README.md
-
177man/mergerfs.1
-
3src/config.cpp
-
2src/config.hpp
-
37src/config_inodecalc.cpp
-
31src/config_inodecalc.hpp
-
164src/fs_inode.cpp
-
39src/fs_inode.hpp
-
5src/fuse_fgetattr.cpp
-
2src/fuse_getattr.cpp
-
17src/fuse_readdir_linux.cpp
-
19src/fuse_readdir_plus_linux.cpp
-
11src/fuse_readdir_plus_posix.cpp
-
8src/fuse_readdir_posix.cpp
@ -0,0 +1,37 @@ |
|||||
|
/*
|
||||
|
ISC License |
||||
|
|
||||
|
Copyright (c) 2020, Antonio SJ Musumeci <trapexit@spawn.link> |
||||
|
|
||||
|
Permission to use, copy, modify, and/or distribute this software for any |
||||
|
purpose with or without fee is hereby granted, provided that the above |
||||
|
copyright notice and this permission notice appear in all copies. |
||||
|
|
||||
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
||||
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
||||
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
||||
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
||||
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
||||
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
||||
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
||||
|
*/ |
||||
|
|
||||
|
#include "config_inodecalc.hpp"
|
||||
|
#include "fs_inode.hpp"
|
||||
|
|
||||
|
InodeCalc::InodeCalc(const std::string &s_) |
||||
|
{ |
||||
|
fs::inode::set_algo(s_); |
||||
|
} |
||||
|
|
||||
|
std::string |
||||
|
InodeCalc::to_string(void) const |
||||
|
{ |
||||
|
return fs::inode::get_algo(); |
||||
|
} |
||||
|
|
||||
|
int |
||||
|
InodeCalc::from_string(const std::string &s_) |
||||
|
{ |
||||
|
return fs::inode::set_algo(s_); |
||||
|
} |
@ -0,0 +1,31 @@ |
|||||
|
/*
|
||||
|
ISC License |
||||
|
|
||||
|
Copyright (c) 2020, Antonio SJ Musumeci <trapexit@spawn.link> |
||||
|
|
||||
|
Permission to use, copy, modify, and/or distribute this software for any |
||||
|
purpose with or without fee is hereby granted, provided that the above |
||||
|
copyright notice and this permission notice appear in all copies. |
||||
|
|
||||
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
||||
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
||||
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
||||
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
||||
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
||||
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
||||
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
||||
|
*/ |
||||
|
|
||||
|
#pragma once
|
||||
|
|
||||
|
#include "tofrom_string.hpp"
|
||||
|
|
||||
|
class InodeCalc : public ToFromString |
||||
|
{ |
||||
|
public: |
||||
|
InodeCalc(const std::string &); |
||||
|
|
||||
|
public: |
||||
|
std::string to_string(void) const; |
||||
|
int from_string(const std::string &); |
||||
|
}; |
@ -0,0 +1,164 @@ |
|||||
|
/*
|
||||
|
ISC License |
||||
|
|
||||
|
Copyright (c) 2020, Antonio SJ Musumeci <trapexit@spawn.link> |
||||
|
|
||||
|
Permission to use, copy, modify, and/or distribute this software for any |
||||
|
purpose with or without fee is hereby granted, provided that the above |
||||
|
copyright notice and this permission notice appear in all copies. |
||||
|
|
||||
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
||||
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
||||
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
||||
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
||||
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
||||
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
||||
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
||||
|
*/ |
||||
|
|
||||
|
#include "ef.hpp"
|
||||
|
#include "fasthash.h"
|
||||
|
#include "fs_inode.hpp"
|
||||
|
|
||||
|
#include <string>
|
||||
|
|
||||
|
#include <pthread.h>
|
||||
|
#include <stdint.h>
|
||||
|
#include <string.h>
|
||||
|
#include <sys/stat.h>
|
||||
|
|
||||
|
typedef uint64_t (*inodefunc_t)(const char*,const uint64_t,const mode_t,const dev_t,const ino_t); |
||||
|
|
||||
|
static uint64_t hybrid_hash(const char*,const uint64_t,const mode_t,const dev_t,const ino_t); |
||||
|
|
||||
|
static inodefunc_t g_func = hybrid_hash; |
||||
|
|
||||
|
static |
||||
|
uint64_t |
||||
|
passthrough(const char *fusepath_, |
||||
|
const uint64_t fusepath_len_, |
||||
|
const mode_t mode_, |
||||
|
const dev_t dev_, |
||||
|
const ino_t ino_) |
||||
|
{ |
||||
|
return ino_; |
||||
|
} |
||||
|
|
||||
|
static |
||||
|
uint64_t |
||||
|
path_hash(const char *fusepath_, |
||||
|
const uint64_t fusepath_len_, |
||||
|
const mode_t mode_, |
||||
|
const dev_t dev_, |
||||
|
const ino_t ino_) |
||||
|
{ |
||||
|
return fasthash64(fusepath_, |
||||
|
fusepath_len_, |
||||
|
fs::inode::MAGIC); |
||||
|
} |
||||
|
|
||||
|
static |
||||
|
uint64_t |
||||
|
devino_hash(const char *fusepath_, |
||||
|
const uint64_t fusepath_len_, |
||||
|
const mode_t mode_, |
||||
|
const dev_t dev_, |
||||
|
const ino_t ino_) |
||||
|
{ |
||||
|
uint64_t buf[2]; |
||||
|
|
||||
|
buf[0] = dev_; |
||||
|
buf[1] = ino_; |
||||
|
|
||||
|
return fasthash64((void*)&buf[0], |
||||
|
sizeof(buf), |
||||
|
fs::inode::MAGIC); |
||||
|
} |
||||
|
|
||||
|
static |
||||
|
uint64_t |
||||
|
hybrid_hash(const char *fusepath_, |
||||
|
const uint64_t fusepath_len_, |
||||
|
const mode_t mode_, |
||||
|
const dev_t dev_, |
||||
|
const ino_t ino_) |
||||
|
{ |
||||
|
return (S_ISDIR(mode_) ? |
||||
|
path_hash(fusepath_,fusepath_len_,mode_,dev_,ino_) : |
||||
|
devino_hash(fusepath_,fusepath_len_,mode_,dev_,ino_)); |
||||
|
} |
||||
|
|
||||
|
|
||||
|
namespace fs |
||||
|
{ |
||||
|
namespace inode |
||||
|
{ |
||||
|
int |
||||
|
set_algo(const std::string &algo_) |
||||
|
{ |
||||
|
if(algo_ == "passthrough") |
||||
|
g_func = passthrough; |
||||
|
ef(algo_ == "path-hash") |
||||
|
g_func = path_hash; |
||||
|
ef(algo_ == "devino-hash") |
||||
|
g_func = devino_hash; |
||||
|
ef(algo_ == "hybrid-hash") |
||||
|
g_func = hybrid_hash; |
||||
|
else |
||||
|
return -EINVAL; |
||||
|
|
||||
|
return 0; |
||||
|
} |
||||
|
|
||||
|
std::string |
||||
|
get_algo(void) |
||||
|
{ |
||||
|
if(g_func == passthrough) |
||||
|
return "passthrough"; |
||||
|
if(g_func == path_hash) |
||||
|
return "path-hash"; |
||||
|
if(g_func == devino_hash) |
||||
|
return "devino-hash"; |
||||
|
if(g_func == hybrid_hash) |
||||
|
return "hybrid-hash"; |
||||
|
|
||||
|
return std::string(); |
||||
|
} |
||||
|
|
||||
|
uint64_t |
||||
|
calc(const char *fusepath_, |
||||
|
const uint64_t fusepath_len_, |
||||
|
const mode_t mode_, |
||||
|
const dev_t dev_, |
||||
|
const ino_t ino_) |
||||
|
{ |
||||
|
return g_func(fusepath_,fusepath_len_,mode_,dev_,ino_); |
||||
|
} |
||||
|
|
||||
|
void |
||||
|
calc(const char *fusepath_, |
||||
|
const uint64_t fusepath_len_, |
||||
|
struct stat *st_) |
||||
|
{ |
||||
|
st_->st_ino = calc(fusepath_, |
||||
|
fusepath_len_, |
||||
|
st_->st_mode, |
||||
|
st_->st_dev, |
||||
|
st_->st_ino); |
||||
|
} |
||||
|
|
||||
|
void |
||||
|
calc(const char *fusepath_, |
||||
|
struct stat *st_) |
||||
|
{ |
||||
|
calc(fusepath_,strlen(fusepath_),st_); |
||||
|
} |
||||
|
|
||||
|
void |
||||
|
calc(const std::string &fusepath_, |
||||
|
struct stat *st_) |
||||
|
{ |
||||
|
calc(fusepath_.c_str(),fusepath_.size(),st_); |
||||
|
} |
||||
|
} |
||||
|
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue