const struct inode *context_inode)
 {
        struct inode *inode;
-       const struct qstr qname = QSTR_INIT(name, strlen(name));
        int error;
 
        inode = alloc_anon_inode(anon_inode_mnt->mnt_sb);
        if (IS_ERR(inode))
                return inode;
        inode->i_flags &= ~S_PRIVATE;
-       error = security_inode_init_security_anon(inode, &qname, context_inode);
+       error = security_inode_init_security_anon(inode, &QSTR(name),
+                                                 context_inode);
        if (error) {
                iput(inode);
                return ERR_PTR(error);
 
                return ret;
 
        struct bch_hash_info dir_hash = bch2_hash_info_init(c, &lostfound);
-       struct qstr name = (struct qstr) QSTR(name_buf);
+       struct qstr name = QSTR(name_buf);
 
        inode->bi_dir = lostfound.bi_inum;
 
 
 #include <linux/sort.h>
 #include <linux/stat.h>
 
-#define QSTR(n) { { { .len = strlen(n) } }, .name = n }
-
 void bch2_btree_lost_data(struct bch_fs *c, enum btree_id btree)
 {
        if (btree >= BTREE_ID_NR_MAX)
 
 
 #include <linux/uuid.h>
 
-#define QSTR(n) { { { .len = strlen(n) } }, .name = n }
-
 static inline bool qstr_eq(const struct qstr l, const struct qstr r)
 {
        return l.len == r.len && !memcmp(l.name, r.name, l.len);
 
        }
 
        it.index = index;
-       it.name = (struct qstr)QSTR_INIT(name, strlen(name));
+       it.name = QSTR(name);
        if (it.name.len > EROFS_NAME_LEN)
                return -ERANGE;
 
 
 static inline int alloc_path_pseudo(const char *name, struct inode *inode,
                                    struct vfsmount *mnt, struct path *path)
 {
-       struct qstr this = QSTR_INIT(name, strlen(name));
-
-       path->dentry = d_alloc_pseudo(mnt->mnt_sb, &this);
+       path->dentry = d_alloc_pseudo(mnt->mnt_sb, &QSTR(name));
        if (!path->dentry)
                return -ENOMEM;
        path->mnt = mntget(mnt);
 
                if (!inode)
                        continue;
 
-               name = (struct qstr)QSTR_INIT(kn->name, strlen(kn->name));
+               name = QSTR(kn->name);
                parent = kernfs_get_parent(kn);
                if (parent) {
                        p_inode = ilookup(info->sb, kernfs_ino(parent));
 
 };
 
 #define QSTR_INIT(n,l) { { { .len = l } }, .name = n }
+#define QSTR(n) (struct qstr)QSTR_INIT(n, strlen(n))
 
 extern const struct qstr empty_name;
 extern const struct qstr slash_name;
 
        struct file *file;
        struct inode *inode;
        const char *anon_name = "[secretmem]";
-       const struct qstr qname = QSTR_INIT(anon_name, strlen(anon_name));
        int err;
 
        inode = alloc_anon_inode(secretmem_mnt->mnt_sb);
        if (IS_ERR(inode))
                return ERR_CAST(inode);
 
-       err = security_inode_init_security_anon(inode, &qname, NULL);
+       err = security_inode_init_security_anon(inode, &QSTR(anon_name), NULL);
        if (err) {
                file = ERR_PTR(err);
                goto err_free_inode;
 
 static struct dentry *__rpc_lookup_create_exclusive(struct dentry *parent,
                                          const char *name)
 {
-       struct qstr q = QSTR_INIT(name, strlen(name));
+       struct qstr q = QSTR(name);
        struct dentry *dentry = d_hash_and_lookup(parent, &q);
        if (!dentry) {
                dentry = d_alloc(parent, &q);
 struct dentry *rpc_d_lookup_sb(const struct super_block *sb,
                               const unsigned char *dir_name)
 {
-       struct qstr dir = QSTR_INIT(dir_name, strlen(dir_name));
-       return d_hash_and_lookup(sb->s_root, &dir);
+       return d_hash_and_lookup(sb->s_root, &QSTR(dir_name));
 }
 EXPORT_SYMBOL_GPL(rpc_d_lookup_sb);
 
        struct dentry *gssd_dentry;
        struct dentry *clnt_dentry = NULL;
        struct dentry *pipe_dentry = NULL;
-       struct qstr q = QSTR_INIT(files[RPCAUTH_gssd].name,
-                                 strlen(files[RPCAUTH_gssd].name));
 
        /* We should never get this far if "gssd" doesn't exist */
-       gssd_dentry = d_hash_and_lookup(root, &q);
+       gssd_dentry = d_hash_and_lookup(root, &QSTR(files[RPCAUTH_gssd].name));
        if (!gssd_dentry)
                return ERR_PTR(-ENOENT);
 
                goto out;
        }
 
-       q.name = gssd_dummy_clnt_dir[0].name;
-       q.len = strlen(gssd_dummy_clnt_dir[0].name);
-       clnt_dentry = d_hash_and_lookup(gssd_dentry, &q);
+       clnt_dentry = d_hash_and_lookup(gssd_dentry,
+                                       &QSTR(gssd_dummy_clnt_dir[0].name));
        if (!clnt_dentry) {
                __rpc_depopulate(gssd_dentry, gssd_dummy_clnt_dir, 0, 1);
                pipe_dentry = ERR_PTR(-ENOENT);