Commit Graph

20554 Commits

Author SHA1 Message Date
Brian Behlendorf 019953e0b7 Update zconfig to check partitions
Update the zconfig.sh test script to verify not only that volumes,
snapshots, and clones are created and removed properly.  But also
verify that the partition information for each of these types of
devices is properly enumerated by the kernel.

Tests 4 and 5 now also create two partitions on the original volume
and these partitions are expected to also exist on the snapshot and
the clone.  Correctness is verified after import/export, module
load/unload, dataset creation, and pool destruction.

Additionally, the code to create a partition table was refactored
in to a small helper function to simplify the test cases.  And
finally all of the function variables were flagged 'local' to ensure
their scope is limited.  This should have been done a while ago.
2010-08-05 11:22:33 -07:00
Brian Behlendorf 5222cdac37 Merge branch 'linux-kernel-disk' into refs/top-bases/linux-zfs-branch 2010-08-04 16:10:44 -07:00
Brian Behlendorf f3aa3b93df Fix zvol partition creation during module load
Partitions for a zvol device were not appearing in /dev/zvol/<pool>/
at module load time for a couple of reasons.

1) The Linux block layer expects a block device to have a non-zero
   capacity during add_disk().  If the capacity is zero it does not
   attempt to open the device which means we never trigger a partition
   scan.  The device capacity was just being set during the first open.

2) Because we expect to be adding a block device to the zvol_state_list
   during zvol_create_minor() the zvol_state_lock() is held.  This
   can result in a deadlock in add_disk() when it attempts to open
   the block device via zvol_open() which also takes this same lock.
   To avoid this issue special handling has been added to zvol_open()
   and zvol_release() to allow the mutex owner to enter these functions
   without retaking the lock.

3) In __zvol_create_minor() the call to dmu_objset_disown() must occur
   before the call to add_disk().  As mentioned above add_disk() results
   in a call to zvol_open() which will attempt to call dmu_objset_own()
   again on the objset.  If the objset is already open it will fail
   resulting in a failed open.  This in turn means the kernel will be
   unable to read the partition information from the device.
2010-08-04 16:05:25 -07:00
Brian Behlendorf 66391bec96 Merge branch 'linux-libspl' into refs/top-bases/linux-zfs-branch 2010-08-04 09:45:00 -07:00
Ned Bass 80819cc01e remove compiler warning on 32-bit systems
commit 421d95b3ea introduced a compiler
warning on 32-bit systems about casting a pointer to an integer of a
different size.  This commit removes the warning by casting the arguments
to snprintf in the same manner as the original VERIFY3_IMPL macro.
2010-08-04 09:38:44 -07:00
Brian Behlendorf 5348255bbc Merge branch 'linux-have-mlslabel' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:49 -07:00
Brian Behlendorf e0e0ee9862 Merge commit 'refs/top-bases/linux-have-mlslabel' into linux-have-mlslabel 2010-08-03 16:04:47 -07:00
Brian Behlendorf cae3fb7556 Merge branch 'linux-spa-thread' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:42 -07:00
Brian Behlendorf e8871dbfaf Merge commit 'refs/top-bases/linux-spa-thread' into linux-spa-thread 2010-08-03 16:04:40 -07:00
Brian Behlendorf da306ae41d Merge branch 'linux-topology' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:34 -07:00
Brian Behlendorf 8bd970935c Merge commit 'refs/top-bases/linux-topology' into linux-topology 2010-08-03 16:04:32 -07:00
Brian Behlendorf bc57441274 Merge branch 'linux-sha2' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:26 -07:00
Brian Behlendorf 8c051ed3f4 Merge commit 'refs/top-bases/linux-sha2' into linux-sha2 2010-08-03 16:04:24 -07:00
Brian Behlendorf a57d483043 Merge branch 'linux-user-util' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:18 -07:00
Brian Behlendorf e5a61eee9d Merge commit 'refs/top-bases/linux-user-util' into linux-user-util 2010-08-03 16:04:16 -07:00
Brian Behlendorf 8f95bd3853 Merge branch 'linux-events' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:10 -07:00
Brian Behlendorf dc7e820e7f Merge commit 'refs/top-bases/linux-events' into linux-events 2010-08-03 16:04:08 -07:00
Brian Behlendorf 4d2216357c Merge branch 'linux-kernel-module' into refs/top-bases/linux-zfs-branch 2010-08-03 16:04:02 -07:00
Brian Behlendorf bfceec0b53 Merge commit 'refs/top-bases/linux-kernel-module' into linux-kernel-module 2010-08-03 16:04:00 -07:00
Brian Behlendorf bdcf982396 Merge branch 'linux-kernel-device' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:54 -07:00
Brian Behlendorf d48e566806 Merge commit 'refs/top-bases/linux-kernel-device' into linux-kernel-device 2010-08-03 16:03:52 -07:00
Brian Behlendorf ad3a447664 Merge branch 'linux-have-idmap' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:46 -07:00
Brian Behlendorf 88879e6e8d Merge commit 'refs/top-bases/linux-have-idmap' into linux-have-idmap 2010-08-03 16:03:44 -07:00
Brian Behlendorf adc8f9455b Merge branch 'linux-ztest' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:38 -07:00
Brian Behlendorf c2ed58313d Merge commit 'refs/top-bases/linux-ztest' into linux-ztest 2010-08-03 16:03:36 -07:00
Brian Behlendorf 45506f87fd Merge branch 'linux-unused' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:30 -07:00
Brian Behlendorf 30ead1a620 Merge commit 'refs/top-bases/linux-unused' into linux-unused 2010-08-03 16:03:28 -07:00
Brian Behlendorf fda24b60e5 Merge branch 'linux-libspl' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:22 -07:00
Brian Behlendorf a84164e81c Merge commit 'refs/top-bases/linux-libspl' into linux-libspl 2010-08-03 16:03:20 -07:00
Brian Behlendorf 1cd7da3beb Merge branch 'linux-zpios' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:14 -07:00
Brian Behlendorf a469c62186 Merge commit 'refs/top-bases/linux-zpios' into linux-zpios 2010-08-03 16:03:12 -07:00
Brian Behlendorf c891ca01c6 Merge branch 'linux-user-disk' into refs/top-bases/linux-zfs-branch 2010-08-03 16:03:06 -07:00
Brian Behlendorf 072418b458 Merge commit 'refs/top-bases/linux-user-disk' into linux-user-disk 2010-08-03 16:03:04 -07:00
Brian Behlendorf 241b8bba33 Merge branch 'linux-symbol-collisions' into refs/top-bases/linux-zfs-branch 2010-08-03 16:02:58 -07:00
Brian Behlendorf 0a6861870e Merge commit 'refs/top-bases/linux-symbol-collisions' into linux-symbol-collisions 2010-08-03 16:02:56 -07:00
Brian Behlendorf ded874ed39 Merge branch 'linux-kernel-mem' into refs/top-bases/linux-zfs-branch 2010-08-03 16:02:51 -07:00
Brian Behlendorf 9cb6a0067d Merge commit 'refs/top-bases/linux-kernel-mem' into linux-kernel-mem 2010-08-03 16:02:49 -07:00
Brian Behlendorf f216be8859 Merge branch 'linux-kernel-disk' into refs/top-bases/linux-zfs-branch 2010-08-03 16:02:43 -07:00
Brian Behlendorf a54f5dddf1 Merge commit 'refs/top-bases/linux-kernel-disk' into linux-kernel-disk 2010-08-03 16:02:41 -07:00
Brian Behlendorf 34bc488111 Merge branch 'linux-have-spl-debug' into refs/top-bases/linux-zfs-branch 2010-08-03 16:02:33 -07:00
Brian Behlendorf b8c7d3bea4 Merge commit 'refs/top-bases/linux-have-spl-debug' into linux-have-spl-debug 2010-08-03 16:02:31 -07:00
Brian Behlendorf 888942a40f Merge branch 'linux-have-mntent' into refs/top-bases/linux-zfs-branch 2010-08-03 16:02:23 -07:00
Brian Behlendorf 72e9483d97 Merge commit 'refs/top-bases/linux-have-mntent' into linux-have-mntent 2010-08-03 16:02:21 -07:00
Brian Behlendorf 63a645c3c8 Merge commit 'refs/top-bases/zfs-branch' into zfs-branch 2010-08-03 16:02:21 -07:00
Brian Behlendorf 1b9fd31ada Merge branch 'fix-branch' into refs/top-bases/zfs-branch 2010-08-03 16:02:20 -07:00
Brian Behlendorf 3eff30685e Set zv->zv_objset for zil_replay() case
For the case where we have a zil to replay we need to ensure that
zv->zv_objset contains the current objset.  Since the caller has
a hold on the object set it is safe to pass to zil_replay as part
of the zv.  Call path zvol_create_minor()->zil_replay()->
zil_parse()->zil_replay_log_record()->zvol_replay_write().
2010-08-03 15:57:05 -07:00
Brian Behlendorf 2cb5528450 Merge branch 'fix-bpobj_close' into refs/top-bases/fix-branch 2010-08-03 15:56:53 -07:00
Brian Behlendorf 670b33090f Merge commit 'refs/top-bases/fix-branch' into fix-branch 2010-08-03 15:56:53 -07:00
Brian Behlendorf 84eae057e7 New TopGit dependency: fix-bpobj_close 2010-08-03 15:56:49 -07:00
Brian Behlendorf 3253b39fa6 Set bpo->bpo_object = 0 on close to allow retry
During spa_load the spl->spa_deferred_bpobj maybe be opened and closed
multiple times.  It's critical that when the object is closed the
bpo->bpo_object is set to zero to indicate the object is closed.
If it's not during spl_load_retry the spl->spa_deferred_bpobj can
be closes twice resulting in a NULL deref.

This appears to have been fixed upstream the same way.
2010-08-03 15:56:29 -07:00