diff options
Diffstat (limited to 'libglusterfs')
-rw-r--r-- | libglusterfs/src/common-utils.c | 31 | ||||
-rw-r--r-- | libglusterfs/src/common-utils.h | 7 | ||||
-rw-r--r-- | libglusterfs/src/glusterfs.h | 10 |
3 files changed, 48 insertions, 0 deletions
diff --git a/libglusterfs/src/common-utils.c b/libglusterfs/src/common-utils.c index cb51dd17537..08efb5c9f03 100644 --- a/libglusterfs/src/common-utils.c +++ b/libglusterfs/src/common-utils.c @@ -3111,3 +3111,34 @@ out: fclose (file); return running; } + +static inline int +dht_is_linkfile_key (dict_t *this, char *key, data_t *value, void *data) +{ + gf_boolean_t *linkfile_key_found = NULL; + + if (!data) + goto out; + + linkfile_key_found = data; + + *linkfile_key_found = _gf_true; +out: + return 0; +} + + +inline gf_boolean_t +dht_is_linkfile (struct iatt *buf, dict_t *dict) +{ + gf_boolean_t linkfile_key_found = _gf_false; + + if (!IS_DHT_LINKFILE_MODE (buf)) + return _gf_false; + + dict_foreach_fnmatch (dict, "*."DHT_LINKFILE_STR, dht_is_linkfile_key, + &linkfile_key_found); + + return linkfile_key_found; +} + diff --git a/libglusterfs/src/common-utils.h b/libglusterfs/src/common-utils.h index b50d3ac380e..05e4d5b348d 100644 --- a/libglusterfs/src/common-utils.h +++ b/libglusterfs/src/common-utils.h @@ -619,4 +619,11 @@ gf_boolean_t gf_is_service_running (char *pidfile, int *pid); int gf_skip_header_section (int fd, int header_len); + +struct iatt; +struct _dict; + +inline gf_boolean_t +dht_is_linkfile (struct iatt *buf, struct _dict *dict); + #endif /* _COMMON_UTILS_H */ diff --git a/libglusterfs/src/glusterfs.h b/libglusterfs/src/glusterfs.h index 8f05a222d58..99709738491 100644 --- a/libglusterfs/src/glusterfs.h +++ b/libglusterfs/src/glusterfs.h @@ -171,6 +171,16 @@ */ #define DEFAULT_GLUSTERD_SOCKFILE DATADIR "/run/glusterd.socket" +/* features/marker-quota also needs to have knowledge of link-files so as to + * exclude them from accounting. + */ +#define DHT_LINKFILE_MODE (S_ISVTX) + +#define IS_DHT_LINKFILE_MODE(iabuf) ((st_mode_from_ia ((iabuf)->ia_prot, \ + (iabuf)->ia_type) & ~S_IFMT)\ + == DHT_LINKFILE_MODE) +#define DHT_LINKFILE_STR "linkto" + /* NOTE: add members ONLY at the end (just before _MAXVALUE) */ typedef enum { GF_FOP_NULL = 0, |