mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-13 11:40:25 +03:00
Cleanup: spa vdev processing should check NULL pointers
The PVS Studio 2016 FreeBSD kernel report stated: \contrib\opensolaris\uts\common\fs\zfs\spa.c (1341): error V595: The 'spa->spa_spares.sav_vdevs' pointer was utilized before it was verified against nullptr. Check lines: 1341, 1342. \sys\cddl\contrib\opensolaris\uts\common\fs\zfs\spa.c (1355): error V595: The 'spa->spa_l2cache.sav_vdevs' pointer was utilized before it was verified against nullptr. Check lines: 1355, 1357. \sys\cddl\contrib\opensolaris\uts\common\fs\zfs\spa.c (1398): error V595: The 'spa->spa_spares.sav_vdevs' pointer was utilized before it was verified against nullptr. Check lines: 1398, 1408. \sys\cddl\contrib\opensolaris\uts\common\fs\zfs\spa.c (1583): error V595: The 'oldvdevs' pointer was utilized before it was verified against nullptr. Check lines: 1583, 1595. In practice, all of these uses were safe because a NULL pointer implied a 0 vdev count, which kept us from iterating over vdevs. However, rearranging the code to check the pointer first is not a terrible micro-optimization and makes it more readable, so let us do that. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Brian Atkinson <batkinson@lanl.gov> Signed-off-by: Richard Yao <richard.yao@alumni.stonybrook.edu> Closes #14456
This commit is contained in:
parent
3a7d2a0ce0
commit
cfb49616cd
@ -1714,9 +1714,9 @@ spa_unload(spa_t *spa)
|
||||
*/
|
||||
spa_l2cache_drop(spa);
|
||||
|
||||
if (spa->spa_spares.sav_vdevs) {
|
||||
for (int i = 0; i < spa->spa_spares.sav_count; i++)
|
||||
vdev_free(spa->spa_spares.sav_vdevs[i]);
|
||||
if (spa->spa_spares.sav_vdevs) {
|
||||
kmem_free(spa->spa_spares.sav_vdevs,
|
||||
spa->spa_spares.sav_count * sizeof (void *));
|
||||
spa->spa_spares.sav_vdevs = NULL;
|
||||
@ -1727,11 +1727,11 @@ spa_unload(spa_t *spa)
|
||||
}
|
||||
spa->spa_spares.sav_count = 0;
|
||||
|
||||
if (spa->spa_l2cache.sav_vdevs) {
|
||||
for (int i = 0; i < spa->spa_l2cache.sav_count; i++) {
|
||||
vdev_clear_stats(spa->spa_l2cache.sav_vdevs[i]);
|
||||
vdev_free(spa->spa_l2cache.sav_vdevs[i]);
|
||||
}
|
||||
if (spa->spa_l2cache.sav_vdevs) {
|
||||
kmem_free(spa->spa_l2cache.sav_vdevs,
|
||||
spa->spa_l2cache.sav_count * sizeof (void *));
|
||||
spa->spa_l2cache.sav_vdevs = NULL;
|
||||
@ -1789,6 +1789,7 @@ spa_load_spares(spa_t *spa)
|
||||
/*
|
||||
* First, close and free any existing spare vdevs.
|
||||
*/
|
||||
if (spa->spa_spares.sav_vdevs) {
|
||||
for (i = 0; i < spa->spa_spares.sav_count; i++) {
|
||||
vd = spa->spa_spares.sav_vdevs[i];
|
||||
|
||||
@ -1800,9 +1801,9 @@ spa_load_spares(spa_t *spa)
|
||||
vdev_free(vd);
|
||||
}
|
||||
|
||||
if (spa->spa_spares.sav_vdevs)
|
||||
kmem_free(spa->spa_spares.sav_vdevs,
|
||||
spa->spa_spares.sav_count * sizeof (void *));
|
||||
}
|
||||
|
||||
if (spa->spa_spares.sav_config == NULL)
|
||||
nspares = 0;
|
||||
@ -2013,6 +2014,7 @@ out:
|
||||
/*
|
||||
* Purge vdevs that were dropped
|
||||
*/
|
||||
if (oldvdevs) {
|
||||
for (i = 0; i < oldnvdevs; i++) {
|
||||
uint64_t pool;
|
||||
|
||||
@ -2028,8 +2030,8 @@ out:
|
||||
}
|
||||
}
|
||||
|
||||
if (oldvdevs)
|
||||
kmem_free(oldvdevs, oldnvdevs * sizeof (void *));
|
||||
}
|
||||
|
||||
for (i = 0; i < sav->sav_count; i++)
|
||||
nvlist_free(l2cache[i]);
|
||||
|
Loading…
Reference in New Issue
Block a user