]> git.proxmox.com Git - mirror_zfs-debian.git/log
mirror_zfs-debian.git
12 years agoMerge branch 'upstream'
Darik Horn [Sat, 17 Mar 2012 04:40:31 +0000 (23:40 -0500)]
Merge branch 'upstream'

12 years agoZFS 0.6.0-rc7
Brian Behlendorf [Fri, 16 Mar 2012 18:11:40 +0000 (11:11 -0700)]
ZFS 0.6.0-rc7

12 years agoAdd missing NULL in zpl_xattr_handlers
Brian Behlendorf [Wed, 14 Mar 2012 19:36:49 +0000 (12:36 -0700)]
Add missing NULL in zpl_xattr_handlers

The xattr_resolve_name() helper function expects the registered
list of xattr handlers to be NULL terminated.  This NULL was
accidentally missing which could result in a NULL dereference.

Interestingly this issue only manifested itself on certain 32-bit
systems.  Presumably on 64-bit kernels we just always happen to
get lucky and the memory following the structure is zeroed.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #594

12 years agoUse stderr for 'no pools/datasets available' error
Gregor Kopka [Wed, 14 Mar 2012 13:34:00 +0000 (14:34 +0100)]
Use stderr for 'no pools/datasets available' error

The 'zfs list' and 'zpool list' commands output the message
'no datasets/pools available' to stdout.  This should go to
stderr and only the available datasets/pools should go to
stdout.  Returning nothing to stdout is expected behavior
when there is nothing to list.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #581

12 years agoPPA 0.6.0.53-0ubuntu1 release.
Darik Horn [Sat, 10 Mar 2012 02:56:17 +0000 (20:56 -0600)]
PPA 0.6.0.53-0ubuntu1 release.

12 years agoMerge branch 'upstream'
Darik Horn [Sat, 10 Mar 2012 02:52:38 +0000 (20:52 -0600)]
Merge branch 'upstream'

12 years agoAdd sa_spill_rele() interface
Brian Behlendorf [Mon, 5 Mar 2012 23:14:15 +0000 (15:14 -0800)]
Add sa_spill_rele() interface

Add a SA interface which allows us to release the spill block
from a SA handle without destroying the handle.  This is useful
because we can then ensure that a copy of the dirty spill block
is not made at sync time due to the extra hold.  Susequent calls
to sa_update() or sa_lookup() with transparently refetch the
spill block dbuf from the ARC hash.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAdd zio constructor/destructor
Brian Behlendorf [Thu, 23 Feb 2012 23:32:51 +0000 (15:32 -0800)]
Add zio constructor/destructor

Add a standard zio constructor and destructor.  Normally, this is
done to reduce to cost of allocating a new structure by reducing
expensive operations such as memory allocations.  However, in this
case none of the operations moved out of zio_create() were really
very expensive.

This change was principly made as a debug patch (and workaround)
for a zio_destroy() race.  The is good evidence that zio_create()
is reinitializing a mutex which is really still in use by another
thread.  This would completely explain the observed symptoms in
the issue report.

This patch doesn't fix the root cause of the race, but it should
make it less likely by only initializing the mutex once in the
constructor.  Also, this particular flaw might have gone unnoticed
in other zfs implementations due to the specific implementation
details of Linux ticket spinlocks.

Once the real root cause is determined and resolved this change
can be safely reverted.  Until then this should help workaround
the issue.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #496

12 years agoFix distribution detection
Richard Yao [Tue, 28 Feb 2012 21:23:16 +0000 (16:23 -0500)]
Fix distribution detection

Improve the distribution detection by moving the tests for
distribution specific files first.  The Ubuntu and Debian
checks are left for last because they are the least likely
to be unique.  This is particularly true in the case of Debian
since so many distributions are based on Debian.

Since this is currently only used to identify the correct
packaging method for this system the result in many instances
is simply cosmetic.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAlign parition end on 1 MiB boundary
Ned Bass [Wed, 29 Feb 2012 18:08:20 +0000 (10:08 -0800)]
Align parition end on 1 MiB boundary

Some devices have exhibited sensitivity to the ending alignment of
partitions.  In particular, even if the first partition begins at 1
MiB, we have seen many sd driver task abort errors with certain SSDs
if the first partition doesn't end on a 1 MiB boundary.  This occurs
when the vdev label is read during pool creation or importation and
causes a delay of about 30 seconds per device.  It can also be
simulated with dd when the pool isn't imported:

  dd if=/dev/sda1 of=/dev/null bs=262144 count=1

For the record, this problem was observed with SMARTMOD
SG9XCA2E200GE01 200GB SSDs.  Unfortunately I don't have a good
explanation for this behavior. It seems to have something to do with
highly fragmented single-sector requests being issued to the device,
which it may not support.  With end-aligned partitions at least
page-sized requests were queued and issued to the driver according
to blktrace. In any case, aligning the partition end is a fairly
innocuous work-around, wasting at most 1 MiB of space.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #574

12 years agoRemove the DISCLAIMER file from the docs list.
Darik Horn [Sat, 3 Mar 2012 14:34:41 +0000 (08:34 -0600)]
Remove the DISCLAIMER file from the docs list.

The upstream disclaimer was copied into the debian/copyright file
according to DEP-5, which makes the DISCLAIMER file redundant.

12 years agoUse consistent branding in package descriptions.
Darik Horn [Sat, 3 Mar 2012 14:28:37 +0000 (08:28 -0600)]
Use consistent branding in package descriptions.

Change all instances of "OpenSolaris" to "Solaris" in the
debian/control file.

12 years agoUse SA_HDL_PRIVATE for SA xattrs
Brian Behlendorf [Fri, 2 Mar 2012 18:35:50 +0000 (10:35 -0800)]
Use SA_HDL_PRIVATE for SA xattrs

A private SA handle must be used to ensure we can drop the dbuf
hold on the spill block prior to calling dmu_tx_commit().  If we
call dmu_tx_commit() before sa_handle_destroy(), then our hold
will trigger a copy of the dbuf to be made.  This is done to
prevent data from leaking in to the syncing txg.  As a result
the original dirty spill block will remain cached.

Additionally, relying on the shared zp->z_sa_hdl is unsafe in
the xattr context because the znode may be asynchronously dropped
from the cache.  It's far safer and simpler just to use a private
handle for xattrs.  Plus any additional overhead is offset by
the avoidance of the previously mentioned memory copy.

These forever dirty buffers can be noticed in the arcstats under
the anon_size.  On a quiescent system the value should be zero.
Without this fix and a SA xattr write workload you will see
anon_size increase.  Eventually, if enough dirty data builds up
your system it will appear to hang.  This occurs because the dmu
won't allow new txs to be assigned until that dirty data is
flushed, and it won't be because it's not part of an assigned tx.

As an aside, I typically see anon_size lurk around 16k so I think
there is another place in the code which needs a similar fix.
However, this value doesn't grow over time so it isn't critical.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #503
Issue #513

12 years agoRemove the /etc/default/zfsload configuration file
Darik Horn [Fri, 2 Mar 2012 19:12:52 +0000 (13:12 -0600)]
Remove the /etc/default/zfsload configuration file

The zfsload file is a relic of the ZoL 0.5 release series that was
deprecated in the ZoL 0.6 packaging. Delete zfsload if it is still
registered as a configuration file.

12 years agoSplit /etc/init.d/zfs into zfs-mount and zfs-share
Darik Horn [Fri, 2 Mar 2012 15:23:41 +0000 (09:23 -0600)]
Split /etc/init.d/zfs into zfs-mount and zfs-share

ZFS depends on two distinct events during Linux system start:

 * Local storage for `zfs mount -a`.
   (eg: init $local_fs or upstart local-filesystems)

 * NFS or CIFS services for `zfs share -a`.
   (eg: nfsd or smbd events if they happen; otherwise init $network.)

Handling both events in a single `/etc/init.d/zfs` script is
unreliable, so split it into separate `/etc/init.d/zfs-mount`
and `/etc/init.d/zfs-share` scripts.

Also set sensible sysv sequence numbers for Debian and Ubuntu systems.

12 years agoAdd machine readable debian/copyright file.
Darik Horn [Tue, 28 Feb 2012 19:30:50 +0000 (13:30 -0600)]
Add machine readable debian/copyright file.

Update the copyright file for DEP-5 policy conformance:

  http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/

12 years agoPPA 0.6.0.52-0ubuntu1 release.
Darik Horn [Tue, 28 Feb 2012 01:36:21 +0000 (19:36 -0600)]
PPA 0.6.0.52-0ubuntu1 release.

12 years agoRefresh debian/patches after upstream merge.
Darik Horn [Tue, 28 Feb 2012 01:35:05 +0000 (19:35 -0600)]
Refresh debian/patches after upstream merge.

12 years agoMerge branch 'upstream'
Darik Horn [Tue, 28 Feb 2012 01:33:06 +0000 (19:33 -0600)]
Merge branch 'upstream'

12 years agoCleanly support debug packages
Brian Behlendorf [Mon, 27 Feb 2012 18:12:40 +0000 (10:12 -0800)]
Cleanly support debug packages

Allow a source rpm to be rebuilt with debugging enabled.  This
avoids the need to have to manually modify the spec file.  By
default debugging is still largely disabled.  To enable specific
debugging features use the following options with rpmbuild.

  '--with debug'               - Enables ASSERTs

  # For example:
  $ rpmbuild --rebuild --with debug zfs-modules-0.6.0-rc6.src.rpm

Additionally, ZFS_CONFIG has been added to zfs_config.h for
packages which build against these headers.  This is critical
to ensure both zfs and the dependant package are using the same
prototype and structure definitions.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAdd 'dmu_tx' kstats entry
Brian Behlendorf [Fri, 20 Jan 2012 18:58:57 +0000 (10:58 -0800)]
Add 'dmu_tx' kstats entry

Keep counters for the various reasons that a thread may end up
in txg_wait_open() waiting on a new txg.  This can be useful
when attempting to determine why a particular workload is
under performing.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAdd arc_state_t stats to arcstats
Brian Behlendorf [Mon, 30 Jan 2012 21:28:40 +0000 (13:28 -0800)]
Add arc_state_t stats to arcstats

To ensure the arc is behaving properly we need greater visibility
in to exactly how it's managing the systems memory.  This patch
takes one step in that direction be adding the current arc_state_t
for the anon, mru, mru_ghost, mfu, and mfs_ghost lists.  The l2
arc_state_t is already well represented in the arcstats.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoReturn success from check_slice() if device doesn't exist
Ned Bass [Sat, 25 Feb 2012 00:37:41 +0000 (16:37 -0800)]
Return success from check_slice() if device doesn't exist

When creating a new pool, make_root_vdev() calls check_in_use() to
ensure that none of the consituent disks are in use.  If the disk
contains a valid vdev label it is read to retrieve the list of its
child vdevs and these are checked recursively.  However, the
partitions stored in the vdev label my no longer exist, for example
if the partition table has since been altered.  In any such case we
would want the pool creation to proceed, so this change removes the
check from check_slice() that returns an error if the device doesn't
exist.  As an added assurance, the Solaris implementation also
returns sucess on ENOENT.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoChange POST_INSTALL to POST_BUILD in dkms.conf
Darik Horn [Sat, 25 Feb 2012 18:10:04 +0000 (12:10 -0600)]
Change POST_INSTALL to POST_BUILD in dkms.conf

Install zfs_config.h and Module.symvers earlier so that they can be
used by consumers before the zfs module is activated by dkms.

See also dajhorn/pkg-spl@a68ebb5f24d073aca5f336b2681ee0a64c1a83d8.

12 years agoExport symbols for zero-copy
Alex Zhuravlev [Fri, 17 Feb 2012 20:09:21 +0000 (12:09 -0800)]
Export symbols for zero-copy

Export additional symbols to make use of the DMU's zero-copy
API.  This allows external modules to move data in to and out of
the ARC without incurring the cost of a memory copy.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoSupport ashift=13 for 8KB SSD block sizes
Richard Yao [Mon, 13 Feb 2012 15:38:58 +0000 (10:38 -0500)]
Support ashift=13 for 8KB SSD block sizes

New SSDs are now available which use an internal 8k block size.
To make sure ZFS can get the maximum performance out of these
devices we're increasing the maximum ashift to 13 (8KB).

This value is still small enough that we can fit 16 uberblocks
in the vdev ring label.  However, I don't want to increase this
any futher or it will limit the ability the safely roll back a
pool to recover it.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #565

12 years agoAdd 'fsid' mount option to allowed options.
Turbo Fredriksson [Mon, 13 Feb 2012 09:27:01 +0000 (10:27 +0100)]
Add 'fsid' mount option to allowed options.

Resolves nfs-utils-1.0.x compatibility issue which requires
that the fsid be set in the export options.

  exportfs: Warning: /tank/dir requires fsid= for NFS export

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #570

12 years agoPPA 0.6.0.51-0ubuntu1 release.
Darik Horn [Mon, 13 Feb 2012 01:30:21 +0000 (19:30 -0600)]
PPA 0.6.0.51-0ubuntu1 release.

12 years agoRefresh debian/patches after upstream merge.
Darik Horn [Mon, 13 Feb 2012 01:27:35 +0000 (19:27 -0600)]
Refresh debian/patches after upstream merge.

12 years agoMerge branch 'upstream'
Darik Horn [Mon, 13 Feb 2012 01:18:01 +0000 (19:18 -0600)]
Merge branch 'upstream'

12 years agoExport symbols for zero-copy
Brian Behlendorf [Fri, 10 Feb 2012 19:53:09 +0000 (11:53 -0800)]
Export symbols for zero-copy

Exported the required symbols to make use of the DMU's zero-copy
API.  This allows external modules to move data in to and out of
the ARC without incurring the cost of a memory copy.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoUse spl_debug_* helpers
Brian Behlendorf [Fri, 10 Feb 2012 00:33:55 +0000 (16:33 -0800)]
Use spl_debug_* helpers

When configuring the spl debug log support use the provided wrapper
functions.  This ensures that if --disable-debug-log was used when
buiding the spl the functions will have no effect.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAdd support for DISCARD to ZVOLs.
Etienne Dechamps [Fri, 2 Sep 2011 13:23:12 +0000 (15:23 +0200)]
Add support for DISCARD to ZVOLs.

DISCARD (REQ_DISCARD, BLKDISCARD) is useful for thin provisioning.
It allows ZVOL clients to discard (unmap, trim) block ranges from
a ZVOL, thus optimizing disk space usage by allowing a ZVOL to
shrink instead of just grow.

We can't use zfs_space() or zfs_freesp() here, since these functions
only work on regular files, not volumes. Fortunately we can use the
low-level function dmu_free_long_range() which does exactly what we
want.

Currently the discard operation is not added to the log. That's not
a big deal since losing discard requests cannot result in data
corruption. It would however result in disk space usage higher than
it should be. Thus adding log support to zvol_discard() is probably
a good idea for a future improvement.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoSupport the fallocate() file operation.
Etienne Dechamps [Fri, 2 Sep 2011 07:42:07 +0000 (09:42 +0200)]
Support the fallocate() file operation.

Currently only the (FALLOC_FL_PUNCH_HOLE) flag combination is
supported, since it's the only one that matches the behavior of
zfs_space(). This makes it pretty much useless in its current
form, but it's a start.

To support other flag combinations we would need to modify
zfs_space() to make it more flexible, or emulate the desired
functionality in zpl_fallocate().

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #334

12 years agoCheck permissions in zfs_space().
Etienne Dechamps [Fri, 2 Sep 2011 07:37:53 +0000 (09:37 +0200)]
Check permissions in zfs_space().

This isn't done on Solaris because on this OS zfs_space() can
only be called with an opened file handle. Since the addition of
zpl_truncate_range() this isn't the case anymore, so we need to
enforce access rights.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #334

12 years agoImplement the truncate_range() inode operation.
Etienne Dechamps [Thu, 1 Sep 2011 11:59:41 +0000 (13:59 +0200)]
Implement the truncate_range() inode operation.

This operation allows "hole punching" in ZFS files. On Solaris this
is done via the vop_space() system call, which maps to the zfs_space()
function. So we just need to write zpl_truncate_range() as a wrapper
around zfs_space().

Note that this only works for regular files, not ZVOLs.

This is currently an insecure implementation without permission
checking, although this isn't that big of a deal since truncate_range()
isn't even callable from userspace.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #334

12 years agoFix zconfig.sh non-optimal alignment
Brian Behlendorf [Thu, 9 Feb 2012 18:38:03 +0000 (10:38 -0800)]
Fix zconfig.sh non-optimal alignment

The recent zvol improvements have changed default suggested alignment
for zvols from 512b (default) to 8k (zvol blocksize).  Because of this
the zconfig.sh tests which create paritions are now generating a
warning about non-optimal alignments.

This change updates the need zconfig.sh tests such that a partition
will be properly aligned.  In the process, it shifts from using the
sfdisk utility to the parted utility to create partitions.  It also
moves the creation of labels, partitions, and filesystems in to
generic functions in common.sh.in.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoPPA 0.6.0.50-0ubuntu1 release.
Darik Horn [Wed, 8 Feb 2012 23:57:38 +0000 (17:57 -0600)]
PPA 0.6.0.50-0ubuntu1 release.

12 years agoRefresh debian/patches after upstream merge.
Darik Horn [Wed, 8 Feb 2012 23:55:26 +0000 (17:55 -0600)]
Refresh debian/patches after upstream merge.

12 years agoMerge branch 'upstream'
Darik Horn [Wed, 8 Feb 2012 23:52:00 +0000 (17:52 -0600)]
Merge branch 'upstream'

12 years agoUse 32 as the default number of zvol threads.
Etienne Dechamps [Wed, 8 Feb 2012 21:41:41 +0000 (22:41 +0100)]
Use 32 as the default number of zvol threads.

Currently, the `zvol_threads` variable, which controls the number of worker
threads which process items from the ZVOL queues, is set to the number of
available CPUs.

This choice seems to be based on the assumption that ZVOL threads are
CPU-bound. This is not necessarily true, especially for synchronous writes.
Consider the situation described in the comments for `zil_commit()`, which is
called inside `zvol_write()` for synchronous writes:

> itxs are committed in batches. In a heavily stressed zil there will be a
> commit writer thread who is writing out a bunch of itxs to the log for a
> set of committing threads (cthreads) in the same batch as the writer.
> Those cthreads are all waiting on the same cv for that batch.
>
> There will also be a different and growing batch of threads that are
> waiting to commit (qthreads). When the committing batch completes a
> transition occurs such that the cthreads exit and the qthreads become
> cthreads. One of the new cthreads becomes he writer thread for the batch.
> Any new threads arriving become new qthreads.

We can easily deduce that, in the case of ZVOLs, there can be a maximum of
`zvol_threads` cthreads and qthreads. The default value for `zvol_threads` is
typically between 1 and 8, which is way too low in this case. This means
there will be a lot of small commits to the ZIL, which is very inefficient
compared to a few big commits, especially since we have to wait for the data
to be on stable storage. Increasing the number of threads will increase the
amount of data waiting to be commited and thus the size of the individual
commits.

On my system, in the context of VM disk image storage (lots of small
synchronous writes), increasing `zvol_threads` from 8 to 32 results in a 50%
increase in sequential synchronous write performance.

We should choose a more sensible default for `zvol_threads`. Unfortunately
the optimal value is difficult to determine automatically, since it depends
on the synchronous write latency of the underlying storage devices. In any
case, a hardcoded value of 32 would probably be better than the current
situation. Having a lot of ZVOL threads doesn't seem to have any real
downside anyway.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Fixes #392

12 years agoImprove ZVOL queue behavior.
Etienne Dechamps [Mon, 5 Sep 2011 13:15:45 +0000 (15:15 +0200)]
Improve ZVOL queue behavior.

The Linux block device queue subsystem exposes a number of configurable
settings described in Linux block/blk-settings.c. The defaults for these
settings are tuned for hard drives, and are not optimized for ZVOLs. Proper
configuration of these options would allow upper layers (I/O scheduler) to
take better decisions about write merging and ordering.

Detailed rationale:

 - max_hw_sectors is set to unlimited (UINT_MAX). zvol_write() is able to
   handle writes of any size, so there's no reason to impose a limit. Let the
   upper layer decide.

 - max_segments and max_segment_size are set to unlimited. zvol_write() will
   copy the requests' contents into a dbuf anyway, so the number and size of
   the segments are irrelevant. Let the upper layer decide.

 - physical_block_size and io_opt are set to the ZVOL's block size. This
   has the potential to somewhat alleviate issue #361 for ZVOLs, by warning
   the upper layers that writes smaller than the volume's block size will be
   slow.

 - The NONROT flag is set to indicate this isn't a rotational device.
   Although the backing zpool might be composed of rotational devices, the
   resulting ZVOL often doesn't exhibit the same behavior due to the COW
   mechanisms used by ZFS. Setting this flag will prevent upper layers from
   making useless decisions (such as reordering writes) based on incorrect
   assumptions about the behavior of the ZVOL.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoFix synchronicity for ZVOLs.
Etienne Dechamps [Mon, 5 Sep 2011 09:11:38 +0000 (11:11 +0200)]
Fix synchronicity for ZVOLs.

zvol_write() assumes that the write request must be written to stable storage
if rq_is_sync() is true. Unfortunately, this assumption is incorrect. Indeed,
"sync" does *not* mean what we think it means in the context of the Linux
block layer. This is well explained in linux/fs.h:

    WRITE:       A normal async write. Device will be plugged.
    WRITE_SYNC:  Synchronous write. Identical to WRITE, but passes down
                 the hint that someone will be waiting on this IO
                 shortly.
    WRITE_FLUSH: Like WRITE_SYNC but with preceding cache flush.
    WRITE_FUA:   Like WRITE_SYNC but data is guaranteed to be on
                 non-volatile media on completion.

In other words, SYNC does not *mean* that the write must be on stable storage
on completion. It just means that someone is waiting on us to complete the
write request. Thus triggering a ZIL commit for each SYNC write request on a
ZVOL is unnecessary and harmful for performance. To make matters worse, ZVOL
users have no way to express that they actually want data to be written to
stable storage, which means the ZIL is broken for ZVOLs.

The request for stable storage is expressed by the FUA flag, so we must
commit the ZIL after the write if the FUA flag is set. In addition, we must
commit the ZIL before the write if the FLUSH flag is set.

Also, we must inform the block layer that we actually support FLUSH and FUA.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoSupport "sync=always" for ZVOLs.
Etienne Dechamps [Fri, 2 Sep 2011 07:57:35 +0000 (09:57 +0200)]
Support "sync=always" for ZVOLs.

Currently the "sync=always" property works for regular ZFS datasets, but not
for ZVOLs. This patch remedies that.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Fixes #374.

12 years agoLet libnvpair be linked independently of libzfs.
Darik Horn [Sun, 5 Feb 2012 02:54:43 +0000 (20:54 -0600)]
Let libnvpair be linked independently of libzfs.

Autoconf will fail to detect the ZoL libnvpair on systems that do not
implicitly link library runtime dependencies, which is anything that
has the GCC 4.5 DCO update.

Build libuutil before libnvpair, and put it on the the LDADD line of
the libnvpair automake template.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes: #560
12 years agoPPA 0.6.0.49-0ubuntu1 release.
Darik Horn [Fri, 3 Feb 2012 21:42:18 +0000 (15:42 -0600)]
PPA 0.6.0.49-0ubuntu1 release.

12 years agoAdd patch: Improve the --with-spl error
Darik Horn [Fri, 3 Feb 2012 21:39:31 +0000 (15:39 -0600)]
Add patch: Improve the --with-spl error

If the SPL module is unavailable, then the operator gets an error
message that does not apply to installations that are mananged by
DKMS. Change the error message to fit apt-get systems.

A better solution would be to implement a dependency model in DKMS,
or to bundle SPL into the ZFS package.

12 years agoRefresh patches after upstream merge.
Darik Horn [Fri, 3 Feb 2012 21:37:53 +0000 (15:37 -0600)]
Refresh patches after upstream merge.

12 years agoMerge branch 'upstream'
Darik Horn [Fri, 3 Feb 2012 20:57:14 +0000 (14:57 -0600)]
Merge branch 'upstream'

12 years agoRevert "Manually sync scripts/ with the upstream release."
Darik Horn [Fri, 3 Feb 2012 19:33:58 +0000 (13:33 -0600)]
Revert "Manually sync scripts/ with the upstream release."

This reverts commit ae1cd09777a9fb4060fabf830df4c32824951f24
to keep pkg-zfs limited to the debian/ overlay.

These symlinks were dereferenced in pkg-zfs so that the zfs-linux
source package could be diffed directly onto the vanilla upstream
tarball, but the orig tarball produced by git-buildpackage from the
upstream/* git tags is now being published to the PPA instead.

12 years agoRevert lib/libspl/asm-generic/atomic.S deletion.
Darik Horn [Fri, 3 Feb 2012 18:52:53 +0000 (12:52 -0600)]
Revert lib/libspl/asm-generic/atomic.S deletion.

The atomic.S file was deleted when pkg-zfs was converted to a
git-buildpackage project more than a year ago, and I don't remember
whether the deletion was pertinent or accidental.

Regardless, this is a packaging policy violation because it touches a
file outside of the debian/ overlay, and it is not currently required
for building pkg-zfs.

Restore the atomic.S file by revering commit
pkg-zfs/dajhorn@7e4739a203c107ba58ab755eedd20c9f35c1fbf8
"Initial master branch for git-buildpackage."
and discarding all other merge conflicts.

12 years agoLinux 3.3 compat, sops->show_options()
Brian Behlendorf [Thu, 2 Feb 2012 19:55:48 +0000 (11:55 -0800)]
Linux 3.3 compat, sops->show_options()

The second argument of sops->show_options() was changed from a
'struct vfsmount *' to a 'struct dentry *'.  Add an autoconf check
to detect the API change and then conditionally define the expected
interface.  In either case we are only interested in the zfs_sb_t.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #549

12 years agoCleanup ZFS debug infrastructure
Brian Behlendorf [Fri, 20 Jan 2012 23:02:57 +0000 (15:02 -0800)]
Cleanup ZFS debug infrastructure

Historically the internal zfs debug infrastructure has been
scattered throughout the code.  Since we expect to start making
more use of this code this patch performs some cleanup.

* Consolidate the zfs debug infrastructure in the zfs_debug.[ch]
  files.  This includes moving the zfs_flags and zfs_recover
  variables, plus moving the zfs_panic_recover() function.

* Remove the existing unused functionality in zfs_debug.c and
  replace it with code which correctly utilized the spl logging
  infrastructure.

* Remove the __dprintf() function from zfs_ioctl.c.  This is
  dead code, the dprintf() functionality in the kernel relies
  on the spl log support.

* Remove dprintf() from hdr_recl().  This wasn't particularly
  useful and was missing the required format specifier anyway.

* Subsequent patches should unify the dprintf() and zfs_dbgmsg()
  functions.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAllow multiple values per directory entry
Brian Behlendorf [Fri, 27 Jan 2012 21:43:23 +0000 (13:43 -0800)]
Allow multiple values per directory entry

When using zfs to back a Lustre filesystem it's advantageous to
to store a fid with the object id in the directory zap.  The only
technical impediment to doing this is that the zpl code expects
a single value in the zap per directory entry.

This change relaxes that requirement such that multiple entries
are allowed provided the first one is the object id.  The zpl
code will just ignore additional entries.  This allows the ZoL
count to mount datasets which are being used as Lustre server
backends.

Once the upstream feature flags support is merged in this change
should be updated to a read-only feature.  Until this occurs
other zfs implementations will not be able to read the zfs
filesystems created by Lustre.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoExport symbol zfs_attr_table
Brian Behlendorf [Fri, 27 Jan 2012 17:15:42 +0000 (09:15 -0800)]
Export symbol zfs_attr_table

Export the zfs_attr_table symbol so it may be used by non-zpl
consumers which are still interested in writing a zpl compatible
dataset (e.g. Lustre).

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoPPA 0.6.0.48-0ubuntu1 release.
Darik Horn [Fri, 20 Jan 2012 02:25:28 +0000 (20:25 -0600)]
PPA 0.6.0.48-0ubuntu1 release.

12 years agoDisable dh_autotools-dev_updateconfig.
Darik Horn [Fri, 20 Jan 2012 02:22:16 +0000 (20:22 -0600)]
Disable dh_autotools-dev_updateconfig.

Calling `dh $@ --with autotools_dev` causes a FTBFS on Ubuntu 10.04
Lucid Lynx and is currently unnecessary for later releases.

12 years agoMerge branch 'upstream'
Darik Horn [Fri, 20 Jan 2012 02:21:20 +0000 (20:21 -0600)]
Merge branch 'upstream'

12 years agoIgnore dataset if the dds_type is DMU_OST_OTHER
Prakash Surya [Wed, 18 Jan 2012 23:31:52 +0000 (15:31 -0800)]
Ignore dataset if the dds_type is DMU_OST_OTHER

Since the zpios and potentially other ZFS tests use the
DMU_OST_OTHER type to label their datasets, the zpool and
zfs commands should gracefully handle this type when it is
encountered.  This patch modifies the commands' behavior
to ignore any datasets with a dds_type of DMU_OST_OTHER.

Signed-off-by: Prakash Surya <surya1@llnl.gov>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #536

12 years agoPPA 0.6.0.47-0ubuntu1 release.
Darik Horn [Thu, 19 Jan 2012 02:41:55 +0000 (20:41 -0600)]
PPA 0.6.0.47-0ubuntu1 release.

12 years agoDelete packaging for recomposed libraries.
Darik Horn [Sun, 1 Jan 2012 02:36:26 +0000 (20:36 -0600)]
Delete packaging for recomposed libraries.

The spl, avl, efi, share, and unicode libraries are now part of the
uutil, nvpair, zpool, and zfs libraries.

See zfsonlinux/zfs@750562833f5009e1602e3b7d8f10497ee683f611.

12 years agoRemove distdir stubbing for DKMS module sources.
Darik Horn [Thu, 19 Jan 2012 01:53:00 +0000 (19:53 -0600)]
Remove distdir stubbing for DKMS module sources.

Instead of implementing a new distir_modules rule, the existing
distdir rule is now patched to create the DKMS module sources in a
way that minimizes the number of Lintian complaints.

12 years agoRefresh debian/patches after upstream merge.
Darik Horn [Thu, 19 Jan 2012 01:15:15 +0000 (19:15 -0600)]
Refresh debian/patches after upstream merge.

12 years agoAdd libtool to Build-Depends.
Darik Horn [Thu, 19 Jan 2012 00:25:53 +0000 (18:25 -0600)]
Add libtool to Build-Depends.

The libtool package provides macros that are used by autogen.

12 years agoMerge branch 'upstream'
Darik Horn [Thu, 19 Jan 2012 00:25:31 +0000 (18:25 -0600)]
Merge branch 'upstream'

12 years agoFix rpm dependencies
Brian Behlendorf [Wed, 18 Jan 2012 00:20:43 +0000 (16:20 -0800)]
Fix rpm dependencies

This change updates the rpm spec files to have strictly correct
package dependencies.  That means a few things:

* The zfs-modules package is now tied to a specific build of
  the spl-modules packages based on the kernel version.  This
  ensures that the correct spl-modules packages will always get
  installed and not just the newest.

* The zfs package now requires both the zfs-modules and spl
  packages.  Thus a 'yum install zfs' will pull in the minimal
  set of packages required for a functional system.

* The zfs-devel packages now require the zfs package to be
  installed which is normal behavior for -devel packages.

* Remove the redundant distribution release extension.  This
  is already added once because it is part of the kernel package
  release name.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAdd the release component to headers
Brian Behlendorf [Wed, 18 Jan 2012 00:19:43 +0000 (16:19 -0800)]
Add the release component to headers

When the original build system code was added the release
component was accidentally omited from the development header
install path.  This patch adds the missing path component so
it's always clear exactly what release your compiling against.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoPPA 0.6.0.46-0ubuntu1 release.
Darik Horn [Wed, 18 Jan 2012 20:02:44 +0000 (14:02 -0600)]
PPA 0.6.0.46-0ubuntu1 release.

12 years agoMerge branch 'upstream'
Darik Horn [Wed, 18 Jan 2012 19:56:47 +0000 (13:56 -0600)]
Merge branch 'upstream'

12 years agoDisable zfs-dracut packaging.
Darik Horn [Wed, 18 Jan 2012 19:46:48 +0000 (13:46 -0600)]
Disable zfs-dracut packaging.

The dracut/ component broke deb systems when it first added to the
upstream ZoL repository, had a near-zero download count when it was
fixed, seems to be unmaintained, and is incompatible with the
dracut-005 package that is currently published in Debian and Ubuntu.

12 years agoMove debian/patches into a separate branch.
Darik Horn [Wed, 18 Jan 2012 19:40:19 +0000 (13:40 -0600)]
Move debian/patches into a separate branch.

Using git to automatically rediff the patches is easier than using
`quilt refresh` and manually resolving conflicts, especially because
most submissions for this project come from git remotes.

It is also faster to pull and later discard experimental topic branches.

This also keeps the packaging master history clean and concise, and avoids
accidentally conflating the upstream master. Reverting a commit that changed
something outside of the debian/ overlay is ugly.

12 years agoAllow GPT+EFI vdev replacement in boot pools.
Darik Horn [Wed, 18 Jan 2012 18:28:11 +0000 (12:28 -0600)]
Allow GPT+EFI vdev replacement in boot pools.

Commit zfsonlinux/zfs@57a4eddc4d5e1e6c10d8d7dcf87a9fc27398adcd
allows the bootfs property to be set on any pool, but does not
accommodate subsequent vdev changes. For example:

# zpool replace rpool /dev/sda /dev/sdb
operation not supported on this type of pool
property 'bootfs' is not supported on EFI labeled devices

For non-Solaris builds, disable the check that emits this error.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoCombine libraries: spl, avl, efi, share, unicode.
Darik Horn [Sat, 31 Dec 2011 23:30:52 +0000 (17:30 -0600)]
Combine libraries: spl, avl, efi, share, unicode.

These libraries, which are an artifact of the ZoL development
process, conflict with packages that are already in distribution:

  * libspl: SPL Programming Language
  * libavl: AVL for Linux
  * libefi: GRUB

And these libraries are potential conflicts:

  * libshare: the Linux Mount Manager
  * libunicode: Perl and Python

Recompose these five ZoL components into the four libraries that are
conventionally provided by Solaris and FreeBSD systems:

  + libnvpair
  + libuutil
  + libzpool
  + libzfs

This change resolves the name conflict, makes ZoL more compatible
with existing software that uses autotools to detect ZFS, and allows
pkg-zfs to better reflect the official Debian kFreeBSD packaging.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes: #430
12 years agoAllow setting bootfs on any pool
Richard Laager [Fri, 13 Jan 2012 22:24:15 +0000 (16:24 -0600)]
Allow setting bootfs on any pool

The vdev_is_bootable() restrictions are no longer necessary
with recent GRUB2 code.  FreeBSD has implemented the same
change, except that I moved the Solaris comment to be inside
the #ifdef __sun__ block.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #317

12 years agoRun autogen for packaged builds.
Darik Horn [Tue, 17 Jan 2012 17:09:07 +0000 (11:09 -0600)]
Run autogen for packaged builds.

Add to autoconf, automake, and autogen to the Build-Depends
field in the debian/control file, and run `./autogen.sh`
before `./configure` in the debian/rules file.

12 years agoReduce number of zio free threads
Ned Bass [Fri, 13 Jan 2012 21:51:39 +0000 (13:51 -0800)]
Reduce number of zio free threads

As described in Issue #458 and #258, unlinking large amounts of data
can cause the threads in the zio free wait queue to start spinning.
Reducing the number of z_fr_iss threads from a fixed value of 100 to 1
per cpu signficantly reduces contention on the taskq spinlock and
improves throughput.

Instrumenting the taskq code showed that __taskq_dispatch() can spend
a long time holding tq->tq_lock if there are a large number of threads
in the queue.  It turns out the time spent in wake_up() scales
linearly with the number of threads in the queue.  When a large number
of short work items are dispatched, as seems to be the case with
unlink, the worker threads drain the queue faster than the dispatcher
can fill it.  They then all pile into the work wait queue to wait for
new work items.  So if 100 threads are in the queue, wake_up() takes
about 100 times as long, and the woken threads have to spin until the
dispatcher releases the lock.

Reducing the number of threads helps with the symptoms, but doesn't
get to the root of the problem.  It would seem that wake_up()
shouldn't scale linearly in time with queue depth, particularly if we
are only trying to wake up one thread.  In that vein, I tried making
all of the waiting processes exclusive to prevent the scheduler from
iterating over the entire list, but I still saw the linear time
scaling.  So further investigation is needed, but in the meantime
reducing the thread count is an easy workaround.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #258
Issue #458

12 years agoPPA 0.6.0.45-0ubuntu1 release.
Darik Horn [Mon, 16 Jan 2012 00:44:50 +0000 (18:44 -0600)]
PPA 0.6.0.45-0ubuntu1 release.

12 years agoMerge branch 'fhs'
Darik Horn [Mon, 16 Jan 2012 00:30:27 +0000 (18:30 -0600)]
Merge branch 'fhs'

Conflicts:
debian/zfs-dkms.dkms

12 years agoAdd Allow-setting-bootfs-on-any-pool.patch
Darik Horn [Mon, 16 Jan 2012 00:27:47 +0000 (18:27 -0600)]
Add Allow-setting-bootfs-on-any-pool.patch

From 884959bab92d18139e40b30daa53fd6a713c995e Mon Sep 17 00:00:00 2001
From: Richard Laager <rlaager@wiktel.com>
Date: Fri, 13 Jan 2012 16:24:15 -0600
Subject: [PATCH] Allow setting bootfs on any pool

The vdev_is_bootable() restrictions are no longer necessary with recent
GRUB2 code.  FreeBSD has implemented the same change, except that I
moved the Solaris comment to be inside the #ifdef __sun__ block.

12 years agoMerge branch 'upstream'
Darik Horn [Mon, 16 Jan 2012 00:22:14 +0000 (18:22 -0600)]
Merge branch 'upstream'

12 years agoFHS conformance and DKMS multiarch, ZFS interface.
Darik Horn [Sat, 14 Jan 2012 06:15:03 +0000 (00:15 -0600)]
FHS conformance and DKMS multiarch, ZFS interface.

Improve FHS conformance by installing intermediary build products --
currently the zfs_config.h and Module.symvers files -- into the
/var/lib/dkms area instead of /usr/src.

This has the beneficial side-effect of enabling DKMS multiarch
support for ZFS because the autoconf templates and `make install`
rules are not aware of the target architecture.

Mitigates: zfsonlinux/zfs#511

12 years agoWrap long lines in the dkms.conf file.
Darik Horn [Sat, 14 Jan 2012 06:03:11 +0000 (00:03 -0600)]
Wrap long lines in the dkms.conf file.

12 years agoIncrease link count limit to 2^31-1
Brian Behlendorf [Fri, 13 Jan 2012 19:35:05 +0000 (11:35 -0800)]
Increase link count limit to 2^31-1

Originally, the per-file link limit was set to 65536 because the
exact Linux VFS limit was unclear.  Internally ZFS is able to
support 64-bit link counts.  After a more careful investigation
the limit can be safely raised to 2^31-1.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #514

12 years agoRun ZFS_AC_PACMAN only if $VENDOR is "arch"
Prakash Surya [Fri, 13 Jan 2012 01:24:05 +0000 (17:24 -0800)]
Run ZFS_AC_PACMAN only if $VENDOR is "arch"

Unfortunately, Arch's package manager `pacman` shares it's name with a
popular arcade video game. Thus, in order to refrain from executing the
video game when we mean to execute the package manager, ZFS_AC_PACMAN is
now only run when $VENDOR is determined to be "arch".

Signed-off-by: Prakash Surya <surya1@llnl.gov>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #517

12 years agoPPA 0.6.0.44-0ubuntu1 release.
Darik Horn [Fri, 13 Jan 2012 01:37:58 +0000 (19:37 -0600)]
PPA 0.6.0.44-0ubuntu1 release.

12 years agoRefresh debian/patches after upstream merge.
Darik Horn [Fri, 13 Jan 2012 01:34:06 +0000 (19:34 -0600)]
Refresh debian/patches after upstream merge.

12 years agoRevert "Add security_inode_init_security.patch"
Darik Horn [Fri, 13 Jan 2012 01:31:38 +0000 (19:31 -0600)]
Revert "Add security_inode_init_security.patch"

This reverts commit 071df06b6a6b7f22149d883b57f30ff1acdc84d5.

12 years agoMerge branch 'upstream'
Darik Horn [Fri, 13 Jan 2012 01:30:46 +0000 (19:30 -0600)]
Merge branch 'upstream'

12 years agoAdd overlay(-O) mount option support
Suman Chakravartula [Thu, 12 Jan 2012 00:48:02 +0000 (16:48 -0800)]
Add overlay(-O) mount option support

Linux supports mounting over non-empty directories by default.
In Solaris this is not the case and -O option is required for
zfs mount to mount a zfs filesystem over a non-empty directory.

For compatibility, I've added support for -O option to mount
zfs filesystems over non-empty directories if the user wants
to, just like in Solaris.

I've defined MS_OVERLAY to record it in the flags variable if
the -O option is supplied.  The flags variable passes through
a few functions and its checked before performing the empty
directory check in zfs_mount function.  If -O is given, the
check is not performed.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #473

12 years agoApply the ZoL coding standard to zpl_xattr.c
Darik Horn [Thu, 5 Jan 2012 20:27:36 +0000 (14:27 -0600)]
Apply the ZoL coding standard to zpl_xattr.c

Make the indenting in the zpl_xattr.c file consistent with the Sun
coding standard by removing soft tabs.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoLinux 3.2 compat, security_inode_init_security()
Brian Behlendorf [Thu, 12 Jan 2012 21:59:44 +0000 (13:59 -0800)]
Linux 3.2 compat, security_inode_init_security()

The security_inode_init_security() API has been changed to include
a filesystem specific callback to write security extended attributes.
This was done to support the initialization of multiple LSM xattrs
and the EVM xattr.

This change updates the code to use the new API when it's available.
Otherwise it falls back to the previous implementation.

In addition, the ZFS_AC_KERNEL_6ARGS_SECURITY_INODE_INIT_SECURITY
autoconf test has been made more rigerous by passing the expected
types.  This is done to ensure we always properly the detect the
correct form for the security_inode_init_security() API.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #516

12 years agoTreat /dev/vd* as whole disks
Richard Laager [Mon, 9 Jan 2012 22:50:26 +0000 (16:50 -0600)]
Treat /dev/vd* as whole disks

Correctly detect /dev/vd devices as whole disks and attempt to
create an EFI partition table.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
12 years agoAvoid using awk in the zpool_id script.
Darik Horn [Fri, 30 Dec 2011 20:18:58 +0000 (14:18 -0600)]
Avoid using awk in the zpool_id script.

Some implementations of `awk` incorrectly parse the \< and \> regex
symbols, so use a `while read` loop and regular globbing instead.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes: #259
12 years agoLinux 3.1 compat, super_block->s_shrink
Brian Behlendorf [Thu, 22 Dec 2011 20:20:43 +0000 (12:20 -0800)]
Linux 3.1 compat, super_block->s_shrink

The Linux 3.1 kernel has introduced the concept of per-filesystem
shrinkers which are directly assoicated with a super block.  Prior
to this change there was one shared global shrinker.

The zfs code relied on being able to call the global shrinker when
the arc_meta_limit was exceeded.  This would cause the VFS to drop
references on a fraction of the dentries in the dcache.  The ARC
could then safely reclaim the memory used by these entries and
honor the arc_meta_limit.  Unfortunately, when per-filesystem
shrinkers were added the old interfaces were made unavailable.

This change adds support to use the new per-filesystem shrinker
interface so we can continue to honor the arc_meta_limit.  The
major benefit of the new interface is that we can now target
only the zfs filesystem for dentry and inode pruning.  Thus we
can minimize any impact on the caching of other filesystems.

In the context of making this change several other important
issues related to managing the ARC were addressed, they include:

* The dnlc_reduce_cache() function which was called by the ARC
to drop dentries for the Posix layer was replaced with a generic
zfs_prune_t callback.  The ZPL layer now registers a callback to
drop these dentries removing a layering violation which dates
back to the Solaris code.  This callback can also be used by
other ARC consumers such as Lustre.

  arc_add_prune_callback()
  arc_remove_prune_callback()

* The arc_reduce_dnlc_percent module option has been changed to
arc_meta_prune for clarity.  The dnlc functions are specific to
Solaris's VFS and have already been largely eliminated already.
The replacement tunable now represents the number of bytes the
prune callback will request when invoked.

* Less aggressively invoke the prune callback.  We used to call
this whenever we exceeded the arc_meta_limit however that's not
strictly correct since it results in over zeleous reclaim of
dentries and inodes.  It is now only called once the arc_meta_limit
is exceeded and every effort has been made to evict other data from
the ARC cache.

* More promptly manage exceeding the arc_meta_limit.  When reading
meta data in to the cache if a buffer was unable to be recycled
notify the arc_reclaim thread to invoke the required prune.

* Added arcstat_prune kstat which is incremented when the ARC
is forced to request that a consumer prune its cache.  Remember
this will only occur when the ARC has no other choice.  If it
can evict buffers safely without invoking the prune callback
it will.

* This change is also expected to resolve the unexpect collapses
of the ARC cache.  This would occur because when exceeded just the
arc_meta_limit reclaim presure would be excerted on the arc_c
value via arc_shrink().  This effectively shrunk the entire cache
when really we just needed to reclaim meta data.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #466
Closes #292

12 years agoAdd /sbin/blkid to the initramfs manifest.
Darik Horn [Sun, 8 Jan 2012 16:58:01 +0000 (10:58 -0600)]
Add /sbin/blkid to the initramfs manifest.

If the root pool contains a zvol, then udev tries /sbin/blkid and
emits a warning, which is usually invisible because it happens
after GRUB changes the console mode for Plymouth.

Adding /sbin/blkid to the initramfs manifest satisfies the udev
warning and results in a small boot time improvement.

12 years agoMerge branch 'issue9'
Darik Horn [Sat, 7 Jan 2012 19:47:58 +0000 (13:47 -0600)]
Merge branch 'issue9'

12 years agoPPA 0.6.0.43-0ubuntu1 release.
Darik Horn [Sat, 7 Jan 2012 17:06:26 +0000 (11:06 -0600)]
PPA 0.6.0.43-0ubuntu1 release.

12 years agoAdd precise to the PPA build list.
Darik Horn [Sat, 7 Jan 2012 17:03:08 +0000 (11:03 -0600)]
Add precise to the PPA build list.

Begin building packages for the Ubuntu 12.04 LTS Precise Pangolin
alpha release.

The linux-image-3.2.0-8-generic kernel package is the first Ubuntu
P-series release that is compatible and somewhat stable with ZFS.

12 years agoAdd security_inode_init_security.patch
Darik Horn [Sat, 7 Jan 2012 16:59:02 +0000 (10:59 -0600)]
Add security_inode_init_security.patch

Add an interim fix for issue #516, which is required for running ZoL
on a Linux 3.2 kernel.

12 years agoAdd bash command completion to zfsutils.
Darik Horn [Thu, 5 Jan 2012 18:55:05 +0000 (12:55 -0600)]
Add bash command completion to zfsutils.