Skip to content

Commit 525e2c5

Browse files
agabbasovjankara
authored andcommitted
udf: Parameterize output length in udf_put_filename
Make the desired output length a parameter rather than have it hard-coded to UDF_NAME_LEN. Although all call sites still have this length the same, this parameterization will make the function more universal and also consistent with udf_get_filename. Signed-off-by: Andrew Gabbasov <andrew_gabbasov@mentor.com> Signed-off-by: Jan Kara <jack@suse.cz>
1 parent 7955118 commit 525e2c5

File tree

3 files changed

+13
-11
lines changed

3 files changed

+13
-11
lines changed

fs/udf/namei.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -362,8 +362,9 @@ static struct fileIdentDesc *udf_add_entry(struct inode *dir,
362362
*err = -EINVAL;
363363
goto out_err;
364364
}
365-
namelen = udf_put_filename(sb, dentry->d_name.name, name,
366-
dentry->d_name.len);
365+
namelen = udf_put_filename(sb, dentry->d_name.name,
366+
dentry->d_name.len,
367+
name, UDF_NAME_LEN);
367368
if (!namelen) {
368369
*err = -ENAMETOOLONG;
369370
goto out_err;
@@ -997,8 +998,9 @@ static int udf_symlink(struct inode *dir, struct dentry *dentry,
997998
}
998999

9991000
if (pc->componentType == 5) {
1000-
namelen = udf_put_filename(sb, compstart, name,
1001-
symname - compstart);
1001+
namelen = udf_put_filename(sb, compstart,
1002+
symname - compstart,
1003+
name, UDF_NAME_LEN);
10021004
if (!namelen)
10031005
goto out_no_entry;
10041006

fs/udf/udfdecl.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -216,8 +216,8 @@ udf_get_lb_pblock(struct super_block *sb, struct kernel_lb_addr *loc,
216216
/* unicode.c */
217217
extern int udf_get_filename(struct super_block *, uint8_t *, int, uint8_t *,
218218
int);
219-
extern int udf_put_filename(struct super_block *, const uint8_t *, uint8_t *,
220-
int);
219+
extern int udf_put_filename(struct super_block *, const uint8_t *, int,
220+
uint8_t *, int);
221221
extern int udf_build_ustr(struct ustr *, dstring *, int);
222222
extern int udf_CS0toUTF8(struct ustr *, const struct ustr *);
223223

fs/udf/unicode.c

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -395,22 +395,22 @@ int udf_get_filename(struct super_block *sb, uint8_t *sname, int slen,
395395
return ret;
396396
}
397397

398-
int udf_put_filename(struct super_block *sb, const uint8_t *sname,
399-
uint8_t *dname, int flen)
398+
int udf_put_filename(struct super_block *sb, const uint8_t *sname, int slen,
399+
uint8_t *dname, int dlen)
400400
{
401401
struct ustr unifilename;
402402
int namelen;
403403

404-
if (!udf_char_to_ustr(&unifilename, sname, flen))
404+
if (!udf_char_to_ustr(&unifilename, sname, slen))
405405
return 0;
406406

407407
if (UDF_QUERY_FLAG(sb, UDF_FLAG_UTF8)) {
408-
namelen = udf_UTF8toCS0(dname, &unifilename, UDF_NAME_LEN);
408+
namelen = udf_UTF8toCS0(dname, &unifilename, dlen);
409409
if (!namelen)
410410
return 0;
411411
} else if (UDF_QUERY_FLAG(sb, UDF_FLAG_NLS_MAP)) {
412412
namelen = udf_NLStoCS0(UDF_SB(sb)->s_nls_map, dname,
413-
&unifilename, UDF_NAME_LEN);
413+
&unifilename, dlen);
414414
if (!namelen)
415415
return 0;
416416
} else

0 commit comments

Comments
 (0)