A better solution to avoiding variable sized structs in DEVFS.
This commit is contained in:
parent
c122d758ca
commit
4cfe209335
@ -39,8 +39,6 @@
|
||||
#ifndef _FS_DEVFS_DEVFS_H_
|
||||
#define _FS_DEVFS_DEVFS_H_
|
||||
|
||||
#include "opt_devfs.h"
|
||||
|
||||
#define DEVFS_MAGIC 0xdb0a087a
|
||||
|
||||
/*
|
||||
@ -174,7 +172,7 @@ struct devfs_mount {
|
||||
struct devfs_dirent *dm_rootdir;
|
||||
struct devfs_dirent *dm_basedir;
|
||||
unsigned dm_generation;
|
||||
struct devfs_dirent *dm_dirent[NDEVFSINO];
|
||||
struct devfs_dirent **dm_dirent;
|
||||
struct devfs_dirent **dm_overflow;
|
||||
int dm_inode;
|
||||
struct lock dm_lock;
|
||||
|
@ -79,6 +79,9 @@ devfs_nmount(mp, ndp, td)
|
||||
|
||||
MALLOC(fmp, struct devfs_mount *, sizeof(struct devfs_mount),
|
||||
M_DEVFS, M_WAITOK | M_ZERO);
|
||||
MALLOC(fmp->dm_dirent, struct devfs_dirent **,
|
||||
sizeof(struct devfs_dirent *) * NDEVFSINO,
|
||||
M_DEVFS, M_WAITOK | M_ZERO);
|
||||
lockinit(&fmp->dm_lock, PVFS, "devfs", 0, LK_NOPAUSE);
|
||||
|
||||
mp->mnt_flag |= MNT_LOCAL;
|
||||
@ -133,6 +136,7 @@ devfs_unmount(mp, mntflags, td)
|
||||
devfs_purge(fmp->dm_rootdir);
|
||||
mp->mnt_data = 0;
|
||||
lockdestroy(&fmp->dm_lock);
|
||||
free(fmp->dm_dirent, M_DEVFS);
|
||||
free(fmp, M_DEVFS);
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user