mirror_zfs/lib/libzfs
Serapheim Dimitropoulos 43a8536260 Race condition between spa async threads and export
In the past we've seen multiple race conditions that have
to do with open-context threads async threads and concurrent
calls to spa_export()/spa_destroy() (including the one
referenced in issue #9015).

This patch ensures that only one thread can execute the
main body of spa_export_common() at a time, with subsequent
threads returning with a new error code created just for
this situation, eliminating this way any race condition
bugs introduced by concurrent calls to this function.

Reviewed by: Matt Ahrens <matt@delphix.com>
Reviewed by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Serapheim Dimitropoulos <serapheim@delphix.com>
Closes #9015 
Closes #9044
2019-07-18 13:02:33 -07:00
..
.gitignore
libzfs_changelist.c
libzfs_config.c
libzfs_core.pc.in
libzfs_crypto.c
libzfs_dataset.c OpenZFS 9318 - vol_volsize_to_reservation does not account for raidz skip blocks 2019-07-05 15:35:15 -07:00
libzfs_diff.c
libzfs_import.c
libzfs_iter.c
libzfs_mount.c Fix race in parallel mount's thread dispatching algorithm 2019-07-09 09:31:46 -07:00
libzfs_pool.c
libzfs_sendrecv.c zfs send does not handle invalid input gracefully 2019-07-08 15:10:23 -07:00
libzfs_status.c
libzfs_util.c Race condition between spa async threads and export 2019-07-18 13:02:33 -07:00
libzfs.pc.in
Makefile.am
THIRDPARTYLICENSE.openssl
THIRDPARTYLICENSE.openssl.descrip