s->s_maxbytes = path.dentry->d_sb->s_maxbytes;
s->s_blocksize = path.dentry->d_sb->s_blocksize;
s->s_magic = ECRYPTFS_SUPER_MAGIC;
- s->s_stack_depth = path.dentry->d_sb->s_stack_depth + 1;
-
- rc = -EINVAL;
- if (s->s_stack_depth > FILESYSTEM_MAX_STACK_DEPTH) {
- printk(KERN_ERR "eCryptfs: maximum fs stacking depth exceeded\n");
- goto out_free;
- }
inode = ecryptfs_get_inode(path.dentry->d_inode, s);
rc = PTR_ERR(inode);
!S_ISDIR(lowerpath.dentry->d_inode->i_mode))
goto out_put_lowerpath;
- sb->s_stack_depth = max(upperpath.mnt->mnt_sb->s_stack_depth,
- lowerpath.mnt->mnt_sb->s_stack_depth) + 1;
-
- err = -EINVAL;
- if (sb->s_stack_depth > FILESYSTEM_MAX_STACK_DEPTH) {
- printk(KERN_ERR "overlayfs: maximum fs stacking depth exceeded\n");
- goto out_put_lowerpath;
- }
-
-
ufs->upper_mnt = clone_private_mount(&upperpath);
err = PTR_ERR(ufs->upper_mnt);
if (IS_ERR(ufs->upper_mnt)) {
*/
#include <linux/quota.h>
-/*
- * Maximum number of layers of fs stack. Needs to be limited to
- * prevent kernel stack overflow
- */
-#define FILESYSTEM_MAX_STACK_DEPTH 2
-
/**
* enum positive_aop_returns - aop return codes with specific semantics
*
int cleancache_poolid;
struct shrinker s_shrink; /* per-sb shrinker handle */
-
- /*
- * Indicates how deep in a filesystem stack this SB is
- */
- int s_stack_depth;
};
/* superblock cache pruning functions */