Merge commit 'refs/top-bases/linux-have-uio-rw' into linux-have-uio-rw
This commit is contained in:
commit
5b421bb734
|
@ -181,7 +181,7 @@ struct spa {
|
||||||
refcount_t spa_refcount; /* number of opens */
|
refcount_t spa_refcount; /* number of opens */
|
||||||
};
|
};
|
||||||
|
|
||||||
extern const char *spa_config_path;
|
extern char *spa_config_path;
|
||||||
|
|
||||||
#define BOOTFS_COMPRESS_VALID(compress) \
|
#define BOOTFS_COMPRESS_VALID(compress) \
|
||||||
((compress) == ZIO_COMPRESS_LZJB || \
|
((compress) == ZIO_COMPRESS_LZJB || \
|
||||||
|
|
|
@ -62,7 +62,7 @@ static uint64_t spa_config_generation = 1;
|
||||||
* This can be overridden in userland to preserve an alternate namespace for
|
* This can be overridden in userland to preserve an alternate namespace for
|
||||||
* userland pools when doing testing.
|
* userland pools when doing testing.
|
||||||
*/
|
*/
|
||||||
const char *spa_config_path = ZPOOL_CACHE;
|
char *spa_config_path = ZPOOL_CACHE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Called when the module is first loaded, this routine loads the configuration
|
* Called when the module is first loaded, this routine loads the configuration
|
||||||
|
@ -450,4 +450,7 @@ EXPORT_SYMBOL(spa_all_configs);
|
||||||
EXPORT_SYMBOL(spa_config_set);
|
EXPORT_SYMBOL(spa_config_set);
|
||||||
EXPORT_SYMBOL(spa_config_generate);
|
EXPORT_SYMBOL(spa_config_generate);
|
||||||
EXPORT_SYMBOL(spa_config_update);
|
EXPORT_SYMBOL(spa_config_update);
|
||||||
|
|
||||||
|
module_param(spa_config_path, charp, 0444);
|
||||||
|
MODULE_PARM_DESC(spa_config_path, "SPA config file (/etc/zfs/zpool.cache)");
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -20,9 +20,9 @@ check:
|
||||||
@$(ZFS) -u
|
@$(ZFS) -u
|
||||||
@echo
|
@echo
|
||||||
@echo
|
@echo
|
||||||
@echo -n "===================================="
|
@echo -n "==================================="
|
||||||
@echo -n " ZCONFIG "
|
@echo -n " ZCONFIG "
|
||||||
@echo "===================================="
|
@echo "==================================="
|
||||||
@echo
|
@echo
|
||||||
@$(ZCONFIG)
|
@$(ZCONFIG)
|
||||||
@echo
|
@echo
|
||||||
|
|
|
@ -53,32 +53,66 @@ zconfig_test1() {
|
||||||
POOL_NAME=test1
|
POOL_NAME=test1
|
||||||
TMP_FILE1=`mktemp`
|
TMP_FILE1=`mktemp`
|
||||||
TMP_FILE2=`mktemp`
|
TMP_FILE2=`mktemp`
|
||||||
|
TMP_CACHE=`mktemp -p /tmp zpool.cache.XXXXXXXX`
|
||||||
|
|
||||||
echo -n "test 1 - persistent zpool.cache: "
|
echo -n "test 1 - persistent zpool.cache: "
|
||||||
|
|
||||||
# Create a pool save its status for comparison.
|
# Create a pool save its status for comparison.
|
||||||
${ZFS_SH} || fail 1
|
${ZFS_SH} zfs="spa_config_path=${TMP_CACHE}" || fail 1
|
||||||
${ZPOOL_CREATE_SH} -p ${POOL_NAME} -c lo-raidz2 || fail 2
|
${ZPOOL_CREATE_SH} -p ${POOL_NAME} -c lo-raidz2 || fail 2
|
||||||
${ZPOOL} status ${POOL_NAME} >${TMP_FILE1} || fail 3
|
${ZPOOL} status ${POOL_NAME} >${TMP_FILE1} || fail 3
|
||||||
|
|
||||||
# Unload/load the module stack to clear any configuration state
|
# Unload/load the module stack to clear any configuration state
|
||||||
# then verify that the pool can be imported and is online.
|
# then verify the pool is defined in the cache file, it can be
|
||||||
|
# imported without error, and it matches the original pool.
|
||||||
${ZFS_SH} -u || fail 4
|
${ZFS_SH} -u || fail 4
|
||||||
${ZFS_SH} || fail 5
|
${ZFS_SH} zfs="spa_config_path=${TMP_CACHE}" || fail 5
|
||||||
${ZPOOL} import ${POOL_NAME} || fail 6
|
${ZPOOL} import -c ${TMP_CACHE} | grep ${POOL_NAME} >/dev/null||fail 6
|
||||||
${ZPOOL} status ${POOL_NAME} >${TMP_FILE2} || fail 7
|
${ZPOOL} import -c ${TMP_CACHE} ${POOL_NAME} || fail 7
|
||||||
|
${ZPOOL} status ${POOL_NAME} >${TMP_FILE2} || fail 8
|
||||||
|
cmp ${TMP_FILE1} ${TMP_FILE2} || fail 9
|
||||||
|
|
||||||
# Compare the original and imported pool status they should match
|
# Cleanup the test pool and temporary files
|
||||||
cmp ${TMP_FILE1} ${TMP_FILE2} || fail 8
|
${ZPOOL_CREATE_SH} -p ${POOL_NAME} -c lo-raidz2 -d || fail 10
|
||||||
|
rm -f ${TMP_FILE1} ${TMP_FILE2} ${TMP_CACHE} || fail 11
|
||||||
# Cleanup the test pool and temporary file
|
${ZFS_SH} -u || fail 12
|
||||||
${ZPOOL_CREATE_SH} -p ${POOL_NAME} -c lo-raidz2 -d || fail 9
|
|
||||||
rm -f ${TMP_FILE1} ${TMP_FILE2} || fail 10
|
|
||||||
${ZFS_SH} -u || fail 11
|
|
||||||
|
|
||||||
pass
|
pass
|
||||||
}
|
}
|
||||||
|
|
||||||
zconfig_test1
|
zconfig_test1
|
||||||
|
|
||||||
|
# Validate ZFS disk scanning and import w/out zpool.cache configuration.
|
||||||
|
zconfig_test2() {
|
||||||
|
POOL_NAME=test2
|
||||||
|
TMP_FILE1=`mktemp`
|
||||||
|
TMP_FILE2=`mktemp`
|
||||||
|
TMP_CACHE=`mktemp -p /tmp zpool.cache.XXXXXXXX`
|
||||||
|
|
||||||
|
echo -n "test 2 - scan disks for pools to import: "
|
||||||
|
|
||||||
|
# Create a pool save its status for comparison.
|
||||||
|
${ZFS_SH} zfs="spa_config_path=${TMP_CACHE}" || fail 1
|
||||||
|
${ZPOOL_CREATE_SH} -p ${POOL_NAME} -c lo-raidz2 || fail 2
|
||||||
|
${ZPOOL} status ${POOL_NAME} >${TMP_FILE1} || fail 3
|
||||||
|
|
||||||
|
# Unload/load the module stack to clear any configuration state
|
||||||
|
# then remove the cache file, probe the disks for pools, import
|
||||||
|
# the pool without error, and match it against the original pool.
|
||||||
|
${ZFS_SH} -u || fail 4
|
||||||
|
rm -f ${TMP_CACHE} || fail 5
|
||||||
|
${ZFS_SH} zfs="spa_config_path=${TMP_CACHE}" || fail 6
|
||||||
|
${ZPOOL} import | grep ${POOL_NAME} >/dev/null || fail 7
|
||||||
|
${ZPOOL} import ${POOL_NAME} || fail 8
|
||||||
|
${ZPOOL} status ${POOL_NAME} >${TMP_FILE2} || fail 9
|
||||||
|
cmp ${TMP_FILE1} ${TMP_FILE2} || fail 10
|
||||||
|
|
||||||
|
# Cleanup the test pool and temporary files
|
||||||
|
${ZPOOL_CREATE_SH} -p ${POOL_NAME} -c lo-raidz2 -d || fail 11
|
||||||
|
rm -f ${TMP_FILE1} ${TMP_FILE2} || fail 12
|
||||||
|
${ZFS_SH} -u || fail 13
|
||||||
|
|
||||||
|
pass
|
||||||
|
}
|
||||||
|
zconfig_test2
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|
Loading…
Reference in New Issue