r326394 is calling malloc with M_WAITOK under a lock, revert for now

Reported by:	andrew
This commit is contained in:
Emmanuel Vadot 2017-11-30 14:06:54 +00:00
parent 31e8b07376
commit 38c9c65ee4
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=326395

View file

@ -98,18 +98,19 @@ devfs_dir_ref(const char *dir)
if (*dir == '\0')
return;
dle_new = malloc(sizeof(*dle), M_DEVFS4, M_WAITOK);
dle_new->dir = strdup(dir, M_DEVFS4);
dle_new->refcnt = 1;
mtx_lock(&dirlist_mtx);
dle = devfs_dir_findent_locked(dir);
if (dle != NULL) {
dle->refcnt++;
mtx_unlock(&dirlist_mtx);
free(dle_new->dir, M_DEVFS4);
free(dle_new, M_DEVFS4);
return;
}
dle_new = malloc(sizeof(*dle), M_DEVFS4, M_WAITOK);
dle_new->dir = strdup(dir, M_DEVFS4);
dle_new->refcnt = 1;
LIST_INSERT_HEAD(&devfs_dirlist, dle_new, link);
mtx_unlock(&dirlist_mtx);
}