|
@@ -289,7 +289,13 @@ int ubifs_xattr_set(struct inode *host, const char *name, const void *value,
|
|
union ubifs_key key;
|
|
union ubifs_key key;
|
|
int err;
|
|
int err;
|
|
|
|
|
|
- ubifs_assert(inode_is_locked(host));
|
|
|
|
|
|
+ /*
|
|
|
|
+ * Creating an encryption context is done unlocked since we
|
|
|
|
+ * operate on a new inode which is not visible to other users
|
|
|
|
+ * at this point.
|
|
|
|
+ */
|
|
|
|
+ if (strcmp(name, UBIFS_XATTR_NAME_ENCRYPTION_CONTEXT) != 0)
|
|
|
|
+ ubifs_assert(inode_is_locked(host));
|
|
|
|
|
|
if (size > UBIFS_MAX_INO_DATA)
|
|
if (size > UBIFS_MAX_INO_DATA)
|
|
return -ERANGE;
|
|
return -ERANGE;
|