2007-04-06 01:09:06 +00:00
|
|
|
/*
|
|
|
|
* CDDL HEADER START
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the terms of the
|
Update ZFS from version 6 to 13 and bring some FreeBSD-specific changes.
This bring huge amount of changes, I'll enumerate only user-visible changes:
- Delegated Administration
Allows regular users to perform ZFS operations, like file system
creation, snapshot creation, etc.
- L2ARC
Level 2 cache for ZFS - allows to use additional disks for cache.
Huge performance improvements mostly for random read of mostly
static content.
- slog
Allow to use additional disks for ZFS Intent Log to speed up
operations like fsync(2).
- vfs.zfs.super_owner
Allows regular users to perform privileged operations on files stored
on ZFS file systems owned by him. Very careful with this one.
- chflags(2)
Not all the flags are supported. This still needs work.
- ZFSBoot
Support to boot off of ZFS pool. Not finished, AFAIK.
Submitted by: dfr
- Snapshot properties
- New failure modes
Before if write requested failed, system paniced. Now one
can select from one of three failure modes:
- panic - panic on write error
- wait - wait for disk to reappear
- continue - serve read requests if possible, block write requests
- Refquota, refreservation properties
Just quota and reservation properties, but don't count space consumed
by children file systems, clones and snapshots.
- Sparse volumes
ZVOLs that don't reserve space in the pool.
- External attributes
Compatible with extattr(2).
- NFSv4-ACLs
Not sure about the status, might not be complete yet.
Submitted by: trasz
- Creation-time properties
- Regression tests for zpool(8) command.
Obtained from: OpenSolaris
2008-11-17 20:49:29 +00:00
|
|
|
* Common Development and Distribution License (the "License").
|
|
|
|
* You may not use this file except in compliance with the License.
|
2007-04-06 01:09:06 +00:00
|
|
|
*
|
|
|
|
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
|
|
|
* or http://www.opensolaris.org/os/licensing.
|
|
|
|
* See the License for the specific language governing permissions
|
|
|
|
* and limitations under the License.
|
|
|
|
*
|
|
|
|
* When distributing Covered Code, include this CDDL HEADER in each
|
|
|
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
|
|
|
* If applicable, add the following below this CDDL HEADER, with the
|
|
|
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
|
|
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
|
|
|
*
|
|
|
|
* CDDL HEADER END
|
|
|
|
*/
|
|
|
|
/*
|
2011-02-27 19:41:40 +00:00
|
|
|
* Copyright 2010 Sun Microsystems, Inc. All rights reserved.
|
2007-04-06 01:09:06 +00:00
|
|
|
* Use is subject to license terms.
|
|
|
|
*/
|
2013-11-26 09:26:18 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2011 Nexenta Systems, Inc. All rights reserved.
|
2014-11-09 01:42:28 +00:00
|
|
|
* Copyright 2012 Garrett D'Amore <garrett@damore.org>. All rights reserved.
|
2014-11-08 06:34:37 +00:00
|
|
|
* Copyright (c) 2014 by Delphix. All rights reserved.
|
2013-11-26 09:26:18 +00:00
|
|
|
*/
|
2007-04-06 01:09:06 +00:00
|
|
|
|
|
|
|
#include <sys/zfs_context.h>
|
|
|
|
|
|
|
|
int taskq_now;
|
Import OpenSolaris revision 7837:001de5627df3
It includes the following changes:
- parallel reads in traversal code (Bug ID 6333409)
- faster traversal for zfs send (Bug ID 6418042)
- traversal code cleanup (Bug ID 6725675)
- fix for two scrub related bugs (Bug ID 6729696, 6730101)
- fix assertion in dbuf_verify (Bug ID 6752226)
- fix panic during zfs send with i/o errors (Bug ID 6577985)
- replace P2CROSS with P2BOUNDARY (Bug ID 6725680)
List of OpenSolaris Bug IDs:
6333409, 6418042, 6757112, 6725668, 6725675, 6725680,
6725698, 6729696, 6730101, 6752226, 6577985, 6755042
Approved by: pjd, delphij (mentor)
Obtained from: OpenSolaris (multiple Bug IDs)
MFC after: 1 week
2010-05-13 20:32:56 +00:00
|
|
|
taskq_t *system_taskq;
|
2007-04-06 01:09:06 +00:00
|
|
|
|
|
|
|
#define TASKQ_ACTIVE 0x00010000
|
2014-11-08 06:34:37 +00:00
|
|
|
#define TASKQ_NAMELEN 31
|
2007-04-06 01:09:06 +00:00
|
|
|
|
|
|
|
struct taskq {
|
2014-11-08 06:34:37 +00:00
|
|
|
char tq_name[TASKQ_NAMELEN + 1];
|
2007-04-06 01:09:06 +00:00
|
|
|
kmutex_t tq_lock;
|
|
|
|
krwlock_t tq_threadlock;
|
|
|
|
kcondvar_t tq_dispatch_cv;
|
|
|
|
kcondvar_t tq_wait_cv;
|
|
|
|
thread_t *tq_threadlist;
|
|
|
|
int tq_flags;
|
|
|
|
int tq_active;
|
|
|
|
int tq_nthreads;
|
|
|
|
int tq_nalloc;
|
|
|
|
int tq_minalloc;
|
|
|
|
int tq_maxalloc;
|
2011-02-27 19:41:40 +00:00
|
|
|
kcondvar_t tq_maxalloc_cv;
|
|
|
|
int tq_maxalloc_wait;
|
2013-11-26 09:26:18 +00:00
|
|
|
taskq_ent_t *tq_freelist;
|
|
|
|
taskq_ent_t tq_task;
|
2007-04-06 01:09:06 +00:00
|
|
|
};
|
|
|
|
|
2013-11-26 09:26:18 +00:00
|
|
|
static taskq_ent_t *
|
2007-04-06 01:09:06 +00:00
|
|
|
task_alloc(taskq_t *tq, int tqflags)
|
|
|
|
{
|
2013-11-26 09:26:18 +00:00
|
|
|
taskq_ent_t *t;
|
2011-02-27 19:41:40 +00:00
|
|
|
int rv;
|
2007-04-06 01:09:06 +00:00
|
|
|
|
2011-02-27 19:41:40 +00:00
|
|
|
again: if ((t = tq->tq_freelist) != NULL && tq->tq_nalloc >= tq->tq_minalloc) {
|
2013-11-26 09:26:18 +00:00
|
|
|
tq->tq_freelist = t->tqent_next;
|
2007-04-06 01:09:06 +00:00
|
|
|
} else {
|
|
|
|
if (tq->tq_nalloc >= tq->tq_maxalloc) {
|
2011-02-27 19:41:40 +00:00
|
|
|
if (!(tqflags & KM_SLEEP))
|
2007-04-06 01:09:06 +00:00
|
|
|
return (NULL);
|
2011-02-27 19:41:40 +00:00
|
|
|
|
2007-04-06 01:09:06 +00:00
|
|
|
/*
|
|
|
|
* We don't want to exceed tq_maxalloc, but we can't
|
|
|
|
* wait for other tasks to complete (and thus free up
|
|
|
|
* task structures) without risking deadlock with
|
|
|
|
* the caller. So, we just delay for one second
|
2011-02-27 19:41:40 +00:00
|
|
|
* to throttle the allocation rate. If we have tasks
|
|
|
|
* complete before one second timeout expires then
|
|
|
|
* taskq_ent_free will signal us and we will
|
|
|
|
* immediately retry the allocation.
|
2007-04-06 01:09:06 +00:00
|
|
|
*/
|
2011-02-27 19:41:40 +00:00
|
|
|
tq->tq_maxalloc_wait++;
|
|
|
|
rv = cv_timedwait(&tq->tq_maxalloc_cv,
|
|
|
|
&tq->tq_lock, ddi_get_lbolt() + hz);
|
|
|
|
tq->tq_maxalloc_wait--;
|
|
|
|
if (rv > 0)
|
|
|
|
goto again; /* signaled */
|
2007-04-06 01:09:06 +00:00
|
|
|
}
|
2011-02-27 19:41:40 +00:00
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
|
2013-11-26 09:26:18 +00:00
|
|
|
t = kmem_alloc(sizeof (taskq_ent_t), tqflags & KM_SLEEP);
|
2011-02-27 19:41:40 +00:00
|
|
|
|
2007-04-06 01:09:06 +00:00
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
if (t != NULL)
|
|
|
|
tq->tq_nalloc++;
|
|
|
|
}
|
|
|
|
return (t);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2013-11-26 09:26:18 +00:00
|
|
|
task_free(taskq_t *tq, taskq_ent_t *t)
|
2007-04-06 01:09:06 +00:00
|
|
|
{
|
|
|
|
if (tq->tq_nalloc <= tq->tq_minalloc) {
|
2013-11-26 09:26:18 +00:00
|
|
|
t->tqent_next = tq->tq_freelist;
|
2007-04-06 01:09:06 +00:00
|
|
|
tq->tq_freelist = t;
|
|
|
|
} else {
|
|
|
|
tq->tq_nalloc--;
|
|
|
|
mutex_exit(&tq->tq_lock);
|
2013-11-26 09:26:18 +00:00
|
|
|
kmem_free(t, sizeof (taskq_ent_t));
|
2007-04-06 01:09:06 +00:00
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
}
|
2011-02-27 19:41:40 +00:00
|
|
|
|
|
|
|
if (tq->tq_maxalloc_wait)
|
|
|
|
cv_signal(&tq->tq_maxalloc_cv);
|
2007-04-06 01:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
taskqid_t
|
|
|
|
taskq_dispatch(taskq_t *tq, task_func_t func, void *arg, uint_t tqflags)
|
|
|
|
{
|
2013-11-26 09:26:18 +00:00
|
|
|
taskq_ent_t *t;
|
2007-04-06 01:09:06 +00:00
|
|
|
|
|
|
|
if (taskq_now) {
|
|
|
|
func(arg);
|
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
ASSERT(tq->tq_flags & TASKQ_ACTIVE);
|
|
|
|
if ((t = task_alloc(tq, tqflags)) == NULL) {
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
return (0);
|
|
|
|
}
|
2011-02-27 19:41:40 +00:00
|
|
|
if (tqflags & TQ_FRONT) {
|
2013-11-26 09:26:18 +00:00
|
|
|
t->tqent_next = tq->tq_task.tqent_next;
|
|
|
|
t->tqent_prev = &tq->tq_task;
|
2011-02-27 19:41:40 +00:00
|
|
|
} else {
|
2013-11-26 09:26:18 +00:00
|
|
|
t->tqent_next = &tq->tq_task;
|
|
|
|
t->tqent_prev = tq->tq_task.tqent_prev;
|
2011-02-27 19:41:40 +00:00
|
|
|
}
|
2013-11-26 09:26:18 +00:00
|
|
|
t->tqent_next->tqent_prev = t;
|
|
|
|
t->tqent_prev->tqent_next = t;
|
|
|
|
t->tqent_func = func;
|
|
|
|
t->tqent_arg = arg;
|
2014-11-09 01:42:28 +00:00
|
|
|
t->tqent_flags = 0;
|
2007-04-06 01:09:06 +00:00
|
|
|
cv_signal(&tq->tq_dispatch_cv);
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
return (1);
|
|
|
|
}
|
|
|
|
|
2013-11-26 09:26:18 +00:00
|
|
|
void
|
|
|
|
taskq_dispatch_ent(taskq_t *tq, task_func_t func, void *arg, uint_t flags,
|
|
|
|
taskq_ent_t *t)
|
|
|
|
{
|
|
|
|
ASSERT(func != NULL);
|
|
|
|
ASSERT(!(tq->tq_flags & TASKQ_DYNAMIC));
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Mark it as a prealloc'd task. This is important
|
|
|
|
* to ensure that we don't free it later.
|
|
|
|
*/
|
|
|
|
t->tqent_flags |= TQENT_FLAG_PREALLOC;
|
|
|
|
/*
|
|
|
|
* Enqueue the task to the underlying queue.
|
|
|
|
*/
|
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
|
|
|
|
if (flags & TQ_FRONT) {
|
|
|
|
t->tqent_next = tq->tq_task.tqent_next;
|
|
|
|
t->tqent_prev = &tq->tq_task;
|
|
|
|
} else {
|
|
|
|
t->tqent_next = &tq->tq_task;
|
|
|
|
t->tqent_prev = tq->tq_task.tqent_prev;
|
|
|
|
}
|
|
|
|
t->tqent_next->tqent_prev = t;
|
|
|
|
t->tqent_prev->tqent_next = t;
|
|
|
|
t->tqent_func = func;
|
|
|
|
t->tqent_arg = arg;
|
|
|
|
cv_signal(&tq->tq_dispatch_cv);
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
}
|
|
|
|
|
2007-04-06 01:09:06 +00:00
|
|
|
void
|
|
|
|
taskq_wait(taskq_t *tq)
|
|
|
|
{
|
|
|
|
mutex_enter(&tq->tq_lock);
|
2013-11-26 09:26:18 +00:00
|
|
|
while (tq->tq_task.tqent_next != &tq->tq_task || tq->tq_active != 0)
|
2007-04-06 01:09:06 +00:00
|
|
|
cv_wait(&tq->tq_wait_cv, &tq->tq_lock);
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *
|
|
|
|
taskq_thread(void *arg)
|
|
|
|
{
|
|
|
|
taskq_t *tq = arg;
|
2013-11-26 09:26:18 +00:00
|
|
|
taskq_ent_t *t;
|
|
|
|
boolean_t prealloc;
|
2007-04-06 01:09:06 +00:00
|
|
|
|
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
while (tq->tq_flags & TASKQ_ACTIVE) {
|
2013-11-26 09:26:18 +00:00
|
|
|
if ((t = tq->tq_task.tqent_next) == &tq->tq_task) {
|
2007-04-06 01:09:06 +00:00
|
|
|
if (--tq->tq_active == 0)
|
|
|
|
cv_broadcast(&tq->tq_wait_cv);
|
|
|
|
cv_wait(&tq->tq_dispatch_cv, &tq->tq_lock);
|
|
|
|
tq->tq_active++;
|
|
|
|
continue;
|
|
|
|
}
|
2013-11-26 09:26:18 +00:00
|
|
|
t->tqent_prev->tqent_next = t->tqent_next;
|
|
|
|
t->tqent_next->tqent_prev = t->tqent_prev;
|
|
|
|
t->tqent_next = NULL;
|
|
|
|
t->tqent_prev = NULL;
|
|
|
|
prealloc = t->tqent_flags & TQENT_FLAG_PREALLOC;
|
2007-04-06 01:09:06 +00:00
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
|
|
|
|
rw_enter(&tq->tq_threadlock, RW_READER);
|
2013-11-26 09:26:18 +00:00
|
|
|
t->tqent_func(t->tqent_arg);
|
2007-04-06 01:09:06 +00:00
|
|
|
rw_exit(&tq->tq_threadlock);
|
|
|
|
|
|
|
|
mutex_enter(&tq->tq_lock);
|
2013-11-26 09:26:18 +00:00
|
|
|
if (!prealloc)
|
|
|
|
task_free(tq, t);
|
2007-04-06 01:09:06 +00:00
|
|
|
}
|
|
|
|
tq->tq_nthreads--;
|
|
|
|
cv_broadcast(&tq->tq_wait_cv);
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
return (NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*ARGSUSED*/
|
|
|
|
taskq_t *
|
|
|
|
taskq_create(const char *name, int nthreads, pri_t pri,
|
|
|
|
int minalloc, int maxalloc, uint_t flags)
|
|
|
|
{
|
|
|
|
taskq_t *tq = kmem_zalloc(sizeof (taskq_t), KM_SLEEP);
|
|
|
|
int t;
|
|
|
|
|
Merge ZFS version 15 and almost all OpenSolaris bugfixes referenced
in Solaris 10 updates 141445-09 and 142901-14.
Detailed information:
(OpenSolaris revisions and Bug IDs, Solaris 10 patch numbers)
7844:effed23820ae
6755435 zfs_open() and zfs_close() needs to use ZFS_ENTER/ZFS_VERIFY_ZP (141445-01)
7897:e520d8258820
6748436 inconsistent zpool.cache in boot_archive could panic a zfs root filesystem upon boot-up (141445-01)
7965:b795da521357
6740164 zpool attach can create an illegal root pool (141909-02)
8084:b811cc60d650
6769612 zpool_import() will continue to write to cachefile even if altroot is set (N/A)
8121:7fd09d4ebd9c
6757430 want an option for zdb to disable space map loading and leak tracking (141445-01)
8129:e4f45a0bfbb0
6542860 ASSERT: reason != VDEV_LABEL_REMOVE||vdev_inuse(vd, crtxg, reason, 0) (141445-01)
8188:fd00c0a81e80
6761100 want zdb option to select older uberblocks (141445-01)
8190:6eeea43ced42
6774886 zfs_setattr() won't allow ndmp to restore SUNWattr_rw (141445-01)
8225:59a9961c2aeb
6737463 panic while trying to write out config file if root pool import fails (141445-01)
8227:f7d7be9b1f56
6765294 Refactor replay (141445-01)
8228:51e9ca9ee3a5
6572357 libzfs should do more to avoid mnttab lookups (141909-01)
6572376 zfs_iter_filesystems and zfs_iter_snapshots get objset stats twice (141909-01)
8241:5a60f16123ba
6328632 zpool offline is a bit too conservative (141445-01)
6739487 ASSERT: txg <= spa_final_txg due to scrub/export race (141445-01)
6767129 ASSERT: cvd->vdev_isspare, in spa_vdev_detach() (141445-01)
6747698 checksum failures after offline -t / export / import / scrub (141445-01)
6745863 ZFS writes to disk after it has been offlined (141445-01)
6722540 50% slowdown on scrub/resilver with certain vdev configurations (141445-01)
6759999 resilver logic rewrites ditto blocks on both source and destination (141445-01)
6758107 I/O should never suspend during spa_load() (141445-01)
6776548 codereview(1) runs off the page when faced with multi-line comments (N/A)
6761406 AMD errata 91 workaround doesn't work on 64-bit systems (141445-01)
8242:e46e4b2f0a03
6770866 GRUB/ZFS should require physical path or devid, but not both (141445-01)
8269:03a7e9050cfd
6674216 "zfs share" doesn't work, but "zfs set sharenfs=on" does (141445-01)
6621164 $SRC/cmd/zfs/zfs_main.c seems to have a syntax error in the translation note (141445-01)
6635482 i18n problems in libzfs_dataset.c and zfs_main.c (141445-01)
6595194 "zfs get" VALUE column is as wide as NAME (141445-01)
6722991 vdev_disk.c: error checking for ddi_pathname_to_dev_t() must test for NODEV (141445-01)
6396518 ASSERT strings shouldn't be pre-processed (141445-01)
8274:846b39508aff
6713916 scrub/resilver needlessly decompress data (141445-01)
8343:655db2375fed
6739553 libzfs_status msgid table is out of sync (141445-01)
6784104 libzfs unfairly rejects numerical values greater than 2^63 (141445-01)
6784108 zfs_realloc() should not free original memory on failure (141445-01)
8525:e0e0e525d0f8
6788830 set large value to reservation cause core dump (141445-01)
6791064 want sysevents for ZFS scrub (141445-01)
6791066 need to be able to set cachefile on faulted pools (141445-01)
6791071 zpool_do_import() should not enable datasets on faulted pools (141445-01)
6792134 getting multiple properties on a faulted pool leads to confusion (141445-01)
8547:bcc7b46e5ff7
6792884 Vista clients cannot access .zfs (141445-01)
8632:36ef517870a3
6798384 It can take a village to raise a zio (141445-01)
8636:7e4ce9158df3
6551866 deadlock between zfs_write(), zfs_freesp(), and zfs_putapage() (141909-01)
6504953 zfs_getpage() misunderstands VOP_GETPAGE() interface (141909-01)
6702206 ZFS read/writer lock contention throttles sendfile() benchmark (141445-01)
6780491 Zone on a ZFS filesystem has poor fork/exec performance (141445-01)
6747596 assertion failed: DVA_EQUAL(BP_IDENTITY(&zio->io_bp_orig), BP_IDENTITY(zio->io_bp))); (141445-01)
8692:692d4668b40d
6801507 ZFS read aggregation should not mind the gap (141445-01)
8697:e62d2612c14d
6633095 creating a filesystem with many properties set is slow (141445-01)
8768:dfecfdbb27ed
6775697 oracle crashes when overwriting after hitting quota on zfs (141909-01)
8811:f8deccf701cf
6790687 libzfs mnttab caching ignores external changes (141445-01)
6791101 memory leak from libzfs_mnttab_init (141445-01)
8845:91af0d9c0790
6800942 smb_session_create() incorrectly stores IP addresses (N/A)
6582163 Access Control List (ACL) for shares (141445-01)
6804954 smb_search - shortname field should be space padded following the NULL terminator (N/A)
6800184 Panic at smb_oplock_conflict+0x35() (N/A)
8876:59d2e67b4b65
6803822 Reboot after replacement of system disk in a ZFS mirror drops to grub> prompt (141445-01)
8924:5af812f84759
6789318 coredump when issue zdb -uuuu poolname/ (141445-01)
6790345 zdb -dddd -e poolname coredump (141445-01)
6797109 zdb: 'zdb -dddddd pool_name/fs_name inode' coredump if the file with inode was deleted (141445-01)
6797118 zdb: 'zdb -dddddd poolname inum' coredump if I miss the fs name (141445-01)
6803343 shareiscsi=on failed, iscsitgtd failed request to share (141445-01)
9030:243fd360d81f
6815893 hang mounting a dataset after booting into a new boot environment (141445-01)
9056:826e1858a846
6809691 'zpool create -f' no longer overwrites ufs infomation (141445-01)
9179:d8fbd96b79b3
6790064 zfs needs to determine uid and gid earlier in create process (141445-01)
9214:8d350e5d04aa
6604992 forced unmount + being in .zfs/snapshot/<snap1> = not happy (141909-01)
6810367 assertion failed: dvp->v_flag & VROOT, file: ../../common/fs/gfs.c, line: 426 (141909-01)
9229:e3f8b41e5db4
6807765 ztest_dsl_dataset_promote_busy needs to clean up after ENOSPC (141445-01)
9230:e4561e3eb1ef
6821169 offlining a device results in checksum errors (141445-01)
6821170 ZFS should not increment error stats for unavailable devices (141445-01)
6824006 need to increase issue and interrupt taskqs threads in zfs (141445-01)
9234:bffdc4fc05c4
6792139 recovering from a suspended pool needs some work (141445-01)
6794830 reboot command hangs on a failed zfs pool (141445-01)
9246:67c03c93c071
6824062 System panicked in zfs_mount due to NULL pointer dereference when running btts and svvs tests (141909-01)
9276:a8a7fc849933
6816124 System crash running zpool destroy on broken zpool (141445-03)
9355:09928982c591
6818183 zfs snapshot -r is slow due to set_snap_props() doing txg_wait_synced() for each new snapshot (141445-03)
9391:413d0661ef33
6710376 log device can show incorrect status when other parts of pool are degraded (141445-03)
9396:f41cf682d0d3 (part already merged)
6501037 want user/group quotas on ZFS (141445-03)
6827260 assertion failed in arc_read(): hdr == pbuf->b_hdr (141445-03)
6815592 panic: No such hold X on refcount Y from zfs_znode_move (141445-03)
6759986 zfs list shows temporary %clone when doing online zfs recv (141445-03)
9404:319573cd93f8
6774713 zfs ignores canmount=noauto when sharenfs property != off (141445-03)
9412:4aefd8704ce0
6717022 ZFS DMU needs zero-copy support (141445-03)
9425:e7ffacaec3a8
6799895 spa_add_spares() needs to be protected by config lock (141445-03)
6826466 want to post sysevents on hot spare activation (141445-03)
6826468 spa 'allowfaulted' needs some work (141445-03)
6826469 kernel support for storing vdev FRU information (141445-03)
6826470 skip posting checksum errors from DTL regions of leaf vdevs (141445-03)
6826471 I/O errors after device remove probe can confuse FMA (141445-03)
6826472 spares should enjoy some of the benefits of cache devices (141445-03)
9443:2a96d8478e95
6833711 gang leaders shouldn't have to be logical (141445-03)
9463:d0bd231c7518
6764124 want zdb to be able to checksum metadata blocks only (141445-03)
9465:8372081b8019
6830237 zfs panic in zfs_groupmember() (141445-03)
9466:1fdfd1fed9c4
6833162 phantom log device in zpool status (141445-03)
9469:4f68f041ddcd
6824968 add ZFS userquota support to rquotad (141445-03)
9470:6d827468d7b5
6834217 godfather I/O should reexecute (141445-03)
9480:fcff33da767f
6596237 Stop looking and start ganging (141909-02)
9493:9933d599bc93
6623978 lwb->lwb_buf != NULL, file ../../../uts/common/fs/zfs/zil.c, line 787, function zil_lwb_commit (141445-06)
9512:64cafcbcc337
6801810 Commit of aligned streaming rewrites to ZIL device causes unwanted disk reads (N/A)
9515:d3b739d9d043
6586537 async zio taskqs can block out userland commands (142901-09)
9554:787363635b6a
6836768 zfs_userspace() callback has no way to indicate failure (N/A)
9574:1eb6a6ab2c57
6838062 zfs panics when an error is encountered in space_map_load() (141909-02)
9583:b0696cd037cc
6794136 Panic BAD TRAP: type=e when importing degraded zraid pool. (141909-03)
9630:e25a03f552e0
6776104 "zfs import" deadlock between spa_unload() and spa_async_thread() (141445-06)
9653:a70048a304d1
6664765 Unable to remove files when using fat-zap and quota exceeded on ZFS filesystem (141445-06)
9688:127be1845343
6841321 zfs userspace / zfs get userused@ doesn't work on mounted snapshot (N/A)
6843069 zfs get userused@S-1-... doesn't work (N/A)
9873:8ddc892eca6e
6847229 assertion failed: refcount_count(&tx->tx_space_written) + delta <= tx->tx_space_towrite in dmu_tx.c (141445-06)
9904:d260bd3fd47c
6838344 kernel heap corruption detected on zil while stress testing (141445-06)
9951:a4895b3dd543
6844900 zfs_ioc_userspace_upgrade leaks (N/A)
10040:38b25aeeaf7a
6857012 zfs panics on zpool import (141445-06)
10000:241a51d8720c
6848242 zdb -e no longer works as expected (N/A)
10100:4a6965f6bef8
6856634 snv_117 not booting: zfs_parse_bootfs: error2 (141445-07)
10160:a45b03783d44
6861983 zfs should use new name <-> SID interfaces (N/A)
6862984 userquota commands can hang (141445-06)
10299:80845694147f
6696858 zfs receive of incremental replication stream can dereference NULL pointer and crash (N/A)
10302:a9e3d1987706
6696858 zfs receive of incremental replication stream can dereference NULL pointer and crash (fix lint) (N/A)
10575:2a8816c5173b (partial merge)
6882227 spa_async_remove() shouldn't do a full clear (142901-14)
10800:469478b180d9
6880764 fsync on zfs is broken if writes are greater than 32kb on a hard crash and no log attached (142901-09)
6793430 zdb -ivvvv assertion failure: bp->blk_cksum.zc_word[2] == dmu_objset_id(zilog->zl_os) (N/A)
10801:e0bf032e8673 (partial merge)
6822816 assertion failed: zap_remove_int(ds_next_clones_obj) returns ENOENT (142901-09)
10810:b6b161a6ae4a
6892298 buf->b_hdr->b_state != arc_anon, file: ../../common/fs/zfs/arc.c, line: 2849 (142901-09)
10890:499786962772
6807339 spurious checksum errors when replacing a vdev (142901-13)
11249:6c30f7dfc97b
6906110 bad trap panic in zil_replay_log_record (142901-13)
6906946 zfs replay isn't handling uid/gid correctly (142901-13)
11454:6e69bacc1a5a
6898245 suspended zpool should not cause rest of the zfs/zpool commands to hang (142901-10)
11546:42ea6be8961b (partial merge)
6833999 3-way deadlock in dsl_dataset_hold_ref() and dsl_sync_task_group_sync() (142901-09)
Discussed with: pjd
Approved by: delphij (mentor)
Obtained from: OpenSolaris (multiple Bug IDs)
MFC after: 2 months
2010-07-12 23:49:04 +00:00
|
|
|
if (flags & TASKQ_THREADS_CPU_PCT) {
|
|
|
|
int pct;
|
|
|
|
ASSERT3S(nthreads, >=, 0);
|
|
|
|
ASSERT3S(nthreads, <=, 100);
|
|
|
|
pct = MIN(nthreads, 100);
|
|
|
|
pct = MAX(pct, 0);
|
|
|
|
|
|
|
|
nthreads = (sysconf(_SC_NPROCESSORS_ONLN) * pct) / 100;
|
|
|
|
nthreads = MAX(nthreads, 1); /* need at least 1 thread */
|
|
|
|
} else {
|
|
|
|
ASSERT3S(nthreads, >=, 1);
|
|
|
|
}
|
|
|
|
|
2007-04-06 01:09:06 +00:00
|
|
|
rw_init(&tq->tq_threadlock, NULL, RW_DEFAULT, NULL);
|
Update ZFS from version 6 to 13 and bring some FreeBSD-specific changes.
This bring huge amount of changes, I'll enumerate only user-visible changes:
- Delegated Administration
Allows regular users to perform ZFS operations, like file system
creation, snapshot creation, etc.
- L2ARC
Level 2 cache for ZFS - allows to use additional disks for cache.
Huge performance improvements mostly for random read of mostly
static content.
- slog
Allow to use additional disks for ZFS Intent Log to speed up
operations like fsync(2).
- vfs.zfs.super_owner
Allows regular users to perform privileged operations on files stored
on ZFS file systems owned by him. Very careful with this one.
- chflags(2)
Not all the flags are supported. This still needs work.
- ZFSBoot
Support to boot off of ZFS pool. Not finished, AFAIK.
Submitted by: dfr
- Snapshot properties
- New failure modes
Before if write requested failed, system paniced. Now one
can select from one of three failure modes:
- panic - panic on write error
- wait - wait for disk to reappear
- continue - serve read requests if possible, block write requests
- Refquota, refreservation properties
Just quota and reservation properties, but don't count space consumed
by children file systems, clones and snapshots.
- Sparse volumes
ZVOLs that don't reserve space in the pool.
- External attributes
Compatible with extattr(2).
- NFSv4-ACLs
Not sure about the status, might not be complete yet.
Submitted by: trasz
- Creation-time properties
- Regression tests for zpool(8) command.
Obtained from: OpenSolaris
2008-11-17 20:49:29 +00:00
|
|
|
mutex_init(&tq->tq_lock, NULL, MUTEX_DEFAULT, NULL);
|
|
|
|
cv_init(&tq->tq_dispatch_cv, NULL, CV_DEFAULT, NULL);
|
|
|
|
cv_init(&tq->tq_wait_cv, NULL, CV_DEFAULT, NULL);
|
2011-02-27 19:41:40 +00:00
|
|
|
cv_init(&tq->tq_maxalloc_cv, NULL, CV_DEFAULT, NULL);
|
2014-11-08 06:34:37 +00:00
|
|
|
(void) strncpy(tq->tq_name, name, TASKQ_NAMELEN + 1);
|
2007-04-06 01:09:06 +00:00
|
|
|
tq->tq_flags = flags | TASKQ_ACTIVE;
|
|
|
|
tq->tq_active = nthreads;
|
|
|
|
tq->tq_nthreads = nthreads;
|
|
|
|
tq->tq_minalloc = minalloc;
|
|
|
|
tq->tq_maxalloc = maxalloc;
|
2013-11-26 09:26:18 +00:00
|
|
|
tq->tq_task.tqent_next = &tq->tq_task;
|
|
|
|
tq->tq_task.tqent_prev = &tq->tq_task;
|
2007-04-06 01:09:06 +00:00
|
|
|
tq->tq_threadlist = kmem_alloc(nthreads * sizeof (thread_t), KM_SLEEP);
|
|
|
|
|
|
|
|
if (flags & TASKQ_PREPOPULATE) {
|
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
while (minalloc-- > 0)
|
|
|
|
task_free(tq, task_alloc(tq, KM_SLEEP));
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (t = 0; t < nthreads; t++)
|
|
|
|
(void) thr_create(0, 0, taskq_thread,
|
|
|
|
tq, THR_BOUND, &tq->tq_threadlist[t]);
|
|
|
|
|
|
|
|
return (tq);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
taskq_destroy(taskq_t *tq)
|
|
|
|
{
|
|
|
|
int t;
|
|
|
|
int nthreads = tq->tq_nthreads;
|
|
|
|
|
|
|
|
taskq_wait(tq);
|
|
|
|
|
|
|
|
mutex_enter(&tq->tq_lock);
|
|
|
|
|
|
|
|
tq->tq_flags &= ~TASKQ_ACTIVE;
|
|
|
|
cv_broadcast(&tq->tq_dispatch_cv);
|
|
|
|
|
|
|
|
while (tq->tq_nthreads != 0)
|
|
|
|
cv_wait(&tq->tq_wait_cv, &tq->tq_lock);
|
|
|
|
|
|
|
|
tq->tq_minalloc = 0;
|
|
|
|
while (tq->tq_nalloc != 0) {
|
|
|
|
ASSERT(tq->tq_freelist != NULL);
|
|
|
|
task_free(tq, task_alloc(tq, KM_SLEEP));
|
|
|
|
}
|
|
|
|
|
|
|
|
mutex_exit(&tq->tq_lock);
|
|
|
|
|
|
|
|
for (t = 0; t < nthreads; t++)
|
|
|
|
(void) thr_join(tq->tq_threadlist[t], NULL, NULL);
|
|
|
|
|
|
|
|
kmem_free(tq->tq_threadlist, nthreads * sizeof (thread_t));
|
|
|
|
|
|
|
|
rw_destroy(&tq->tq_threadlock);
|
Update ZFS from version 6 to 13 and bring some FreeBSD-specific changes.
This bring huge amount of changes, I'll enumerate only user-visible changes:
- Delegated Administration
Allows regular users to perform ZFS operations, like file system
creation, snapshot creation, etc.
- L2ARC
Level 2 cache for ZFS - allows to use additional disks for cache.
Huge performance improvements mostly for random read of mostly
static content.
- slog
Allow to use additional disks for ZFS Intent Log to speed up
operations like fsync(2).
- vfs.zfs.super_owner
Allows regular users to perform privileged operations on files stored
on ZFS file systems owned by him. Very careful with this one.
- chflags(2)
Not all the flags are supported. This still needs work.
- ZFSBoot
Support to boot off of ZFS pool. Not finished, AFAIK.
Submitted by: dfr
- Snapshot properties
- New failure modes
Before if write requested failed, system paniced. Now one
can select from one of three failure modes:
- panic - panic on write error
- wait - wait for disk to reappear
- continue - serve read requests if possible, block write requests
- Refquota, refreservation properties
Just quota and reservation properties, but don't count space consumed
by children file systems, clones and snapshots.
- Sparse volumes
ZVOLs that don't reserve space in the pool.
- External attributes
Compatible with extattr(2).
- NFSv4-ACLs
Not sure about the status, might not be complete yet.
Submitted by: trasz
- Creation-time properties
- Regression tests for zpool(8) command.
Obtained from: OpenSolaris
2008-11-17 20:49:29 +00:00
|
|
|
mutex_destroy(&tq->tq_lock);
|
|
|
|
cv_destroy(&tq->tq_dispatch_cv);
|
|
|
|
cv_destroy(&tq->tq_wait_cv);
|
2011-02-27 19:41:40 +00:00
|
|
|
cv_destroy(&tq->tq_maxalloc_cv);
|
2007-04-06 01:09:06 +00:00
|
|
|
|
|
|
|
kmem_free(tq, sizeof (taskq_t));
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
taskq_member(taskq_t *tq, void *t)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (taskq_now)
|
|
|
|
return (1);
|
|
|
|
|
|
|
|
for (i = 0; i < tq->tq_nthreads; i++)
|
|
|
|
if (tq->tq_threadlist[i] == (thread_t)(uintptr_t)t)
|
|
|
|
return (1);
|
|
|
|
|
|
|
|
return (0);
|
|
|
|
}
|
Import OpenSolaris revision 7837:001de5627df3
It includes the following changes:
- parallel reads in traversal code (Bug ID 6333409)
- faster traversal for zfs send (Bug ID 6418042)
- traversal code cleanup (Bug ID 6725675)
- fix for two scrub related bugs (Bug ID 6729696, 6730101)
- fix assertion in dbuf_verify (Bug ID 6752226)
- fix panic during zfs send with i/o errors (Bug ID 6577985)
- replace P2CROSS with P2BOUNDARY (Bug ID 6725680)
List of OpenSolaris Bug IDs:
6333409, 6418042, 6757112, 6725668, 6725675, 6725680,
6725698, 6729696, 6730101, 6752226, 6577985, 6755042
Approved by: pjd, delphij (mentor)
Obtained from: OpenSolaris (multiple Bug IDs)
MFC after: 1 week
2010-05-13 20:32:56 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
system_taskq_init(void)
|
|
|
|
{
|
|
|
|
system_taskq = taskq_create("system_taskq", 64, minclsyspri, 4, 512,
|
|
|
|
TASKQ_DYNAMIC | TASKQ_PREPOPULATE);
|
|
|
|
}
|
2011-02-27 19:41:40 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
system_taskq_fini(void)
|
|
|
|
{
|
|
|
|
taskq_destroy(system_taskq);
|
|
|
|
system_taskq = NULL; /* defensive */
|
|
|
|
}
|