list_create(&zf->zf_stream, sizeof (zstream_t),
offsetof(zstream_t, zs_node));
- rw_init(&zf->zf_rwlock, NULL, RW_DEFAULT, NULL);
+ mutex_init(&zf->zf_lock, NULL, MUTEX_DEFAULT, NULL);
}
static void
dmu_zfetch_stream_remove(zfetch_t *zf, zstream_t *zs)
{
- ASSERT(RW_WRITE_HELD(&zf->zf_rwlock));
+ ASSERT(MUTEX_HELD(&zf->zf_lock));
list_remove(&zf->zf_stream, zs);
mutex_destroy(&zs->zs_lock);
kmem_free(zs, sizeof (*zs));
{
zstream_t *zs;
- ASSERT(!RW_LOCK_HELD(&zf->zf_rwlock));
-
- rw_enter(&zf->zf_rwlock, RW_WRITER);
+ mutex_enter(&zf->zf_lock);
while ((zs = list_head(&zf->zf_stream)) != NULL)
dmu_zfetch_stream_remove(zf, zs);
- rw_exit(&zf->zf_rwlock);
+ mutex_exit(&zf->zf_lock);
list_destroy(&zf->zf_stream);
- rw_destroy(&zf->zf_rwlock);
+ mutex_destroy(&zf->zf_lock);
zf->zf_dnode = NULL;
}
zstream_t *zs_next;
int numstreams = 0;
- ASSERT(RW_WRITE_HELD(&zf->zf_rwlock));
+ ASSERT(MUTEX_HELD(&zf->zf_lock));
/*
* Clean up old streams.
uint64_t end_of_access_blkid;
end_of_access_blkid = blkid + nblks;
spa_t *spa = zf->zf_dnode->dn_objset->os_spa;
- krw_t rw = RW_READER;
if (zfs_prefetch_disable)
return;
if (blkid == 0)
return;
-retry:
if (!have_lock)
rw_enter(&zf->zf_dnode->dn_struct_rwlock, RW_READER);
- rw_enter(&zf->zf_rwlock, rw);
+ mutex_enter(&zf->zf_lock);
/*
* Find matching prefetch stream. Depending on whether the accesses
if (nblks == 0) {
/* Already prefetched this before. */
mutex_exit(&zs->zs_lock);
- rw_exit(&zf->zf_rwlock);
+ mutex_exit(&zf->zf_lock);
if (!have_lock) {
rw_exit(&zf->zf_dnode->
dn_struct_rwlock);
* a new stream for it.
*/
ZFETCHSTAT_BUMP(zfetchstat_misses);
- if (rw == RW_READER && !rw_tryupgrade(&zf->zf_rwlock)) {
- rw_exit(&zf->zf_rwlock);
- if (!have_lock)
- rw_exit(&zf->zf_dnode->dn_struct_rwlock);
- rw = RW_WRITER;
- goto retry;
- }
dmu_zfetch_stream_create(zf, end_of_access_blkid);
- rw_exit(&zf->zf_rwlock);
+ mutex_exit(&zf->zf_lock);
if (!have_lock)
rw_exit(&zf->zf_dnode->dn_struct_rwlock);
return;
zs->zs_atime = gethrtime();
zs->zs_blkid = end_of_access_blkid;
mutex_exit(&zs->zs_lock);
- rw_exit(&zf->zf_rwlock);
+ mutex_exit(&zf->zf_lock);
/*
* dbuf_prefetch() is asynchronous (even when it needs to read