Print this page
3749 zfs event processing should work on R/O root filesystems
Submitted by:   Justin Gibbs <justing@spectralogic.com>

*** 75,84 **** --- 75,90 ---- #endif /* _KERNEL */ #include "zfs_prop.h" #include "zfs_comutil.h" + /* + * The interval at which failed configuration cache file writes + * should be retried. + */ + static int zfs_ccw_retry_interval = 300; + typedef enum zti_modes { ZTI_MODE_FIXED, /* value is # of threads (min 1) */ ZTI_MODE_ONLINE_PERCENT, /* value is % of online CPUs */ ZTI_MODE_BATCH, /* cpu-intensive; value is ignored */ ZTI_MODE_NULL, /* don't create a taskq */
*** 5659,5675 **** ASSERT(spa->spa_async_suspended != 0); spa->spa_async_suspended--; mutex_exit(&spa->spa_async_lock); } static void spa_async_dispatch(spa_t *spa) { mutex_enter(&spa->spa_async_lock); ! if (spa->spa_async_tasks && !spa->spa_async_suspended && spa->spa_async_thread == NULL && ! rootdir != NULL && !vn_is_readonly(rootdir)) spa->spa_async_thread = thread_create(NULL, 0, spa_async_thread, spa, 0, &p0, TS_RUN, maxclsyspri); mutex_exit(&spa->spa_async_lock); } --- 5665,5701 ---- ASSERT(spa->spa_async_suspended != 0); spa->spa_async_suspended--; mutex_exit(&spa->spa_async_lock); } + static int + spa_async_tasks_pending(spa_t *spa) + { + u_int non_config_tasks; + u_int config_task; + boolean_t config_task_suspended; + + non_config_tasks = spa->spa_async_tasks & ~SPA_ASYNC_CONFIG_UPDATE; + config_task = spa->spa_async_tasks & SPA_ASYNC_CONFIG_UPDATE; + if (spa->spa_ccw_fail_time == 0) + config_task_suspended = B_FALSE; + else + config_task_suspended = + (ddi_get_lbolt64() - spa->spa_ccw_fail_time) + < (zfs_ccw_retry_interval * hz); + + return (non_config_tasks || (config_task && !config_task_suspended)); + } + static void spa_async_dispatch(spa_t *spa) { mutex_enter(&spa->spa_async_lock); ! if (spa_async_tasks_pending(spa) && ! !spa->spa_async_suspended && spa->spa_async_thread == NULL && ! rootdir != NULL) spa->spa_async_thread = thread_create(NULL, 0, spa_async_thread, spa, 0, &p0, TS_RUN, maxclsyspri); mutex_exit(&spa->spa_async_lock); }