Linux 4.12 compat: fix super_setup_bdi_name() call
Provide a format parameter to super_setup_bdi_name() so we don't create duplicate names in '/devices/virtual/bdi' sysfs namespace which would prevent us from mounting more than one ZFS filesystem at a time. Reviewed-by: Chunwei Chen <david.chen@osnexus.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: loli10K <ezomori.nozomu@gmail.com> Closes #6147
This commit is contained in:
parent
4358afa0f2
commit
3e6c943347
|
@ -74,10 +74,13 @@ truncate_setsize(struct inode *ip, loff_t new)
|
||||||
* 4.12 - x.y, super_setup_bdi_name() new interface.
|
* 4.12 - x.y, super_setup_bdi_name() new interface.
|
||||||
*/
|
*/
|
||||||
#if defined(HAVE_SUPER_SETUP_BDI_NAME)
|
#if defined(HAVE_SUPER_SETUP_BDI_NAME)
|
||||||
|
extern atomic_long_t zfs_bdi_seq;
|
||||||
|
|
||||||
static inline int
|
static inline int
|
||||||
zpl_bdi_setup(struct super_block *sb, char *name)
|
zpl_bdi_setup(struct super_block *sb, char *name)
|
||||||
{
|
{
|
||||||
return (super_setup_bdi_name(sb, name));
|
return super_setup_bdi_name(sb, "%.28s-%ld", name,
|
||||||
|
atomic_long_inc_return(&zfs_bdi_seq));
|
||||||
}
|
}
|
||||||
static inline void
|
static inline void
|
||||||
zpl_bdi_destroy(struct super_block *sb)
|
zpl_bdi_destroy(struct super_block *sb)
|
||||||
|
@ -144,7 +147,6 @@ static inline int
|
||||||
zpl_bdi_setup(struct super_block *sb, char *name)
|
zpl_bdi_setup(struct super_block *sb, char *name)
|
||||||
{
|
{
|
||||||
struct backing_dev_info *bdi;
|
struct backing_dev_info *bdi;
|
||||||
char tmp[32];
|
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
bdi = kmem_zalloc(sizeof (struct backing_dev_info), KM_SLEEP);
|
bdi = kmem_zalloc(sizeof (struct backing_dev_info), KM_SLEEP);
|
||||||
|
@ -157,8 +159,7 @@ zpl_bdi_setup(struct super_block *sb, char *name)
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
|
||||||
sprintf(tmp, "%.28s%s", name, "-%d");
|
error = bdi_register(bdi, NULL, "%.28s-%ld", name,
|
||||||
error = bdi_register(bdi, NULL, tmp,
|
|
||||||
atomic_long_inc_return(&zfs_bdi_seq));
|
atomic_long_inc_return(&zfs_bdi_seq));
|
||||||
if (error) {
|
if (error) {
|
||||||
bdi_destroy(bdi);
|
bdi_destroy(bdi);
|
||||||
|
|
|
@ -1568,8 +1568,7 @@ zfsvfs_teardown(zfsvfs_t *zfsvfs, boolean_t unmounting)
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(HAVE_SUPER_SETUP_BDI_NAME) && \
|
#if !defined(HAVE_2ARGS_BDI_SETUP_AND_REGISTER) && \
|
||||||
!defined(HAVE_2ARGS_BDI_SETUP_AND_REGISTER) && \
|
|
||||||
!defined(HAVE_3ARGS_BDI_SETUP_AND_REGISTER)
|
!defined(HAVE_3ARGS_BDI_SETUP_AND_REGISTER)
|
||||||
atomic_long_t zfs_bdi_seq = ATOMIC_LONG_INIT(0);
|
atomic_long_t zfs_bdi_seq = ATOMIC_LONG_INIT(0);
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue