fs/ntfs3: Use macros NTFS_LABEL_MAX_LENGTH instead of hardcoded value
To check the length of the volume label, the existing constant NTFS_LABEL_MAX_LENGTH could be used. Signed-off-by: Konstantin Komarov <almaz.alexandrovich@paragon-software.com>
This commit is contained in:
parent
220cf0498b
commit
2c2814d0da
@ -2650,8 +2650,8 @@ int ntfs_set_label(struct ntfs_sb_info *sbi, u8 *label, int len)
|
||||
{
|
||||
int err;
|
||||
struct ATTRIB *attr;
|
||||
u32 uni_bytes;
|
||||
struct ntfs_inode *ni = sbi->volume.ni;
|
||||
const u8 max_ulen = 0x80; /* TODO: use attrdef to get maximum length */
|
||||
/* Allocate PATH_MAX bytes. */
|
||||
struct cpu_str *uni = __getname();
|
||||
|
||||
@ -2663,7 +2663,8 @@ int ntfs_set_label(struct ntfs_sb_info *sbi, u8 *label, int len)
|
||||
if (err < 0)
|
||||
goto out;
|
||||
|
||||
if (uni->len > max_ulen) {
|
||||
uni_bytes = uni->len * sizeof(u16);
|
||||
if (uni_bytes > NTFS_LABEL_MAX_LENGTH * sizeof(u16)) {
|
||||
ntfs_warn(sbi->sb, "new label is too long");
|
||||
err = -EFBIG;
|
||||
goto out;
|
||||
@ -2674,13 +2675,13 @@ int ntfs_set_label(struct ntfs_sb_info *sbi, u8 *label, int len)
|
||||
/* Ignore any errors. */
|
||||
ni_remove_attr(ni, ATTR_LABEL, NULL, 0, false, NULL);
|
||||
|
||||
err = ni_insert_resident(ni, uni->len * sizeof(u16), ATTR_LABEL, NULL,
|
||||
0, &attr, NULL, NULL);
|
||||
err = ni_insert_resident(ni, uni_bytes, ATTR_LABEL, NULL, 0, &attr,
|
||||
NULL, NULL);
|
||||
if (err < 0)
|
||||
goto unlock_out;
|
||||
|
||||
/* write new label in on-disk struct. */
|
||||
memcpy(resident_data(attr), uni->name, uni->len * sizeof(u16));
|
||||
memcpy(resident_data(attr), uni->name, uni_bytes);
|
||||
|
||||
/* update cached value of current label. */
|
||||
if (len >= ARRAY_SIZE(sbi->volume.label))
|
||||
|
Loading…
Reference in New Issue
Block a user