From 9a14ce43c3d6a9939804215bbbe66de5115ace42 Mon Sep 17 00:00:00 2001 From: Richard Yao Date: Tue, 7 Feb 2023 03:23:45 -0500 Subject: [PATCH] Statically allocate first node of zfsdev_state_list This avoids a call to kmem_alloc() during module load. It also suppresses a defect report from Clang's static analyzer that claims that we will have a NULL pointer dereference in zfsdev_state_init() because it does not understand that this has already been allocated in zfs_kmod_init(). Reviewed-by: Brian Behlendorf Reviewed-by: Brian Atkinson Signed-off-by: Richard Yao Closes #14470 --- module/zfs/zfs_ioctl.c | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/module/zfs/zfs_ioctl.c b/module/zfs/zfs_ioctl.c index a1717d4d6..7b4b0dff8 100644 --- a/module/zfs/zfs_ioctl.c +++ b/module/zfs/zfs_ioctl.c @@ -222,7 +222,7 @@ #include kmutex_t zfsdev_state_lock; -static zfsdev_state_t *zfsdev_state_list; +static zfsdev_state_t zfsdev_state_listhead; /* * Limit maximum nvlist size. We don't want users passing in insane values @@ -7469,7 +7469,7 @@ zfsdev_getminor(zfs_file_t *fp, minor_t *minorp) mutex_enter(&zfsdev_state_lock); - for (zs = zfsdev_state_list; zs != NULL; zs = zs->zs_next) { + for (zs = &zfsdev_state_listhead; zs != NULL; zs = zs->zs_next) { if (zs->zs_minor == -1) continue; @@ -7491,7 +7491,7 @@ zfsdev_get_state(minor_t minor, enum zfsdev_state_type which) { zfsdev_state_t *zs; - for (zs = zfsdev_state_list; zs != NULL; zs = zs->zs_next) { + for (zs = &zfsdev_state_listhead; zs != NULL; zs = zs->zs_next) { if (zs->zs_minor == minor) { membar_consumer(); switch (which) { @@ -7545,7 +7545,7 @@ zfsdev_state_init(void *priv) if (minor == 0) return (SET_ERROR(ENXIO)); - for (zs = zfsdev_state_list; zs != NULL; zs = zs->zs_next) { + for (zs = &zfsdev_state_listhead; zs != NULL; zs = zs->zs_next) { if (zs->zs_minor == -1) break; zsprev = zs; @@ -7829,8 +7829,7 @@ zfs_kmod_init(void) zfs_ioctl_init(); mutex_init(&zfsdev_state_lock, NULL, MUTEX_DEFAULT, NULL); - zfsdev_state_list = kmem_zalloc(sizeof (zfsdev_state_t), KM_SLEEP); - zfsdev_state_list->zs_minor = -1; + zfsdev_state_listhead.zs_minor = -1; if ((error = zfsdev_attach()) != 0) goto out; @@ -7857,7 +7856,7 @@ zfs_kmod_fini(void) mutex_destroy(&zfsdev_state_lock); - for (zs = zfsdev_state_list; zs != NULL; zs = zsnext) { + for (zs = &zfsdev_state_listhead; zs != NULL; zs = zsnext) { zsnext = zs->zs_next; if (zs->zs_onexit) zfs_onexit_destroy(zs->zs_onexit);