Author: delphij
Date: Mon Dec 15 07:52:23 2014
New Revision: 275782
URL: https://svnweb.freebsd.org/changeset/base/275782

Log:
  MFV r275551:
  
  Remove "dbuf phys" db->db_data pointer aliases.
  
  Use function accessors that cast db->db_data to the appropriate
  "phys" type, removing the need for clients of the dmu buf user
  API to keep properly typed pointer aliases to db->db_data in order
  to conveniently access their data.
  
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap_leaf.c:
          In zap_leaf() and zap_leaf_byteswap, now that the pointer alias
          field l_phys has been removed, use the db_data field in an on
          stack dmu_buf_t to point to the leaf's phys data.
  
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dbuf.c:
          Remove the db_user_data_ptr_ptr field from dbuf and all logic
          to maintain it.
  
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dbuf.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dnode.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dbuf.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dmu.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dir.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sa.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap_micro.c:
          Modify the DMU buf user API to remove the ability to specify
          a db_data aliasing pointer (db_user_data_ptr_ptr).
  
  cddl/contrib/opensolaris/cmd/zdb/zdb.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_diff.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_objset.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_send.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_traverse.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_tx.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_bookmark.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_deadlist.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_deleg.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_destroy.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dir.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_pool.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_prop.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_scan.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_synctask.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_userhold.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sa.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa_history.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap_leaf.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap_micro.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ioctl.c:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dsl_dataset.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dsl_dir.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zap_impl.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zap_leaf.h:
          Create and use the new "phys data" accessor functions
          dsl_dir_phys(), dsl_dataset_phys(), zap_m_phys(),
          zap_f_phys(), and zap_leaf_phys().
  
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dsl_dataset.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dsl_dir.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zap_impl.h:
  sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zap_leaf.h:
          Remove now unused "phys pointer" aliases to db->db_data
          from clients of the DMU buf user API.
  
  Illumos issue:
      5314 Remove "dbuf phys" db->db_data pointer aliases in ZFS
  
  MFC after:    2 weeks

Modified:
  head/cddl/contrib/opensolaris/cmd/zdb/zdb.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dbuf.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_diff.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_objset.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_send.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_traverse.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_tx.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dnode.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_bookmark.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_deadlist.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_deleg.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_destroy.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dir.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_pool.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_prop.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_scan.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_synctask.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_userhold.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sa.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/spa_history.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dbuf.h
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dmu.h
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dsl_dataset.h
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/dsl_dir.h
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zap_impl.h
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/sys/zap_leaf.h
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap_leaf.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zap_micro.c
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_ioctl.c
Directory Properties:
  head/cddl/contrib/opensolaris/   (props changed)
  head/sys/cddl/contrib/opensolaris/   (props changed)

Modified: head/cddl/contrib/opensolaris/cmd/zdb/zdb.c
==============================================================================
--- head/cddl/contrib/opensolaris/cmd/zdb/zdb.c Mon Dec 15 05:10:55 2014        
(r275781)
+++ head/cddl/contrib/opensolaris/cmd/zdb/zdb.c Mon Dec 15 07:52:23 2014        
(r275782)
@@ -1884,8 +1884,8 @@ dump_dir(objset_t *os)
        if (dds.dds_type == DMU_OST_META) {
                dds.dds_creation_txg = TXG_INITIAL;
                usedobjs = BP_GET_FILL(os->os_rootbp);
-               refdbytes = os->os_spa->spa_dsl_pool->
-                   dp_mos_dir->dd_phys->dd_used_bytes;
+               refdbytes = dsl_dir_phys(os->os_spa->spa_dsl_pool->dp_mos_dir)->
+                   dd_used_bytes;
        } else {
                dmu_objset_space(os, &refdbytes, &scratch, &usedobjs, &scratch);
        }

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dbuf.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dbuf.c  Mon Dec 15 
05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dbuf.c  Mon Dec 15 
07:52:23 2014        (r275782)
@@ -223,11 +223,8 @@ dbuf_evict_user(dmu_buf_impl_t *db)
        if (db->db_level != 0 || db->db_evict_func == NULL)
                return;
 
-       if (db->db_user_data_ptr_ptr)
-               *db->db_user_data_ptr_ptr = db->db.db_data;
        db->db_evict_func(&db->db, db->db_user_ptr);
        db->db_user_ptr = NULL;
-       db->db_user_data_ptr_ptr = NULL;
        db->db_evict_func = NULL;
 }
 
@@ -418,16 +415,6 @@ dbuf_verify(dmu_buf_impl_t *db)
 #endif
 
 static void
-dbuf_update_data(dmu_buf_impl_t *db)
-{
-       ASSERT(MUTEX_HELD(&db->db_mtx));
-       if (db->db_level == 0 && db->db_user_data_ptr_ptr) {
-               ASSERT(!refcount_is_zero(&db->db_holds));
-               *db->db_user_data_ptr_ptr = db->db.db_data;
-       }
-}
-
-static void
 dbuf_set_data(dmu_buf_impl_t *db, arc_buf_t *buf)
 {
        ASSERT(MUTEX_HELD(&db->db_mtx));
@@ -437,7 +424,6 @@ dbuf_set_data(dmu_buf_impl_t *db, arc_bu
                db->db.db_data = buf->b_data;
                if (!arc_released(buf))
                        arc_set_callback(buf, dbuf_do_evict, db);
-               dbuf_update_data(db);
        } else {
                dbuf_evict_user(db);
                db->db.db_data = NULL;
@@ -543,7 +529,6 @@ dbuf_read_impl(dmu_buf_impl_t *db, zio_t
                if (bonuslen)
                        bcopy(DN_BONUS(dn->dn_phys), db->db.db_data, bonuslen);
                DB_DNODE_EXIT(db);
-               dbuf_update_data(db);
                db->db_state = DB_CACHED;
                mutex_exit(&db->db_mtx);
                return;
@@ -1726,7 +1711,6 @@ dbuf_create(dnode_t *dn, uint8_t level, 
        db->db_blkptr = blkptr;
 
        db->db_user_ptr = NULL;
-       db->db_user_data_ptr_ptr = NULL;
        db->db_evict_func = NULL;
        db->db_immediate_evict = 0;
        db->db_freed_in_flight = 0;
@@ -1971,7 +1955,6 @@ top:
        }
 
        (void) refcount_add(&db->db_holds, tag);
-       dbuf_update_data(db);
        DBUF_VERIFY(db);
        mutex_exit(&db->db_mtx);
 
@@ -2182,27 +2165,25 @@ dbuf_refcount(dmu_buf_impl_t *db)
 }
 
 void *
-dmu_buf_set_user(dmu_buf_t *db_fake, void *user_ptr, void *user_data_ptr_ptr,
+dmu_buf_set_user(dmu_buf_t *db_fake, void *user_ptr,
     dmu_buf_evict_func_t *evict_func)
 {
-       return (dmu_buf_update_user(db_fake, NULL, user_ptr,
-           user_data_ptr_ptr, evict_func));
+       return (dmu_buf_update_user(db_fake, NULL, user_ptr, evict_func));
 }
 
 void *
-dmu_buf_set_user_ie(dmu_buf_t *db_fake, void *user_ptr, void 
*user_data_ptr_ptr,
+dmu_buf_set_user_ie(dmu_buf_t *db_fake, void *user_ptr,
     dmu_buf_evict_func_t *evict_func)
 {
        dmu_buf_impl_t *db = (dmu_buf_impl_t *)db_fake;
 
        db->db_immediate_evict = TRUE;
-       return (dmu_buf_update_user(db_fake, NULL, user_ptr,
-           user_data_ptr_ptr, evict_func));
+       return (dmu_buf_update_user(db_fake, NULL, user_ptr, evict_func));
 }
 
 void *
 dmu_buf_update_user(dmu_buf_t *db_fake, void *old_user_ptr, void *user_ptr,
-    void *user_data_ptr_ptr, dmu_buf_evict_func_t *evict_func)
+    dmu_buf_evict_func_t *evict_func)
 {
        dmu_buf_impl_t *db = (dmu_buf_impl_t *)db_fake;
        ASSERT(db->db_level == 0);
@@ -2213,10 +2194,7 @@ dmu_buf_update_user(dmu_buf_t *db_fake, 
 
        if (db->db_user_ptr == old_user_ptr) {
                db->db_user_ptr = user_ptr;
-               db->db_user_data_ptr_ptr = user_data_ptr_ptr;
                db->db_evict_func = evict_func;
-
-               dbuf_update_data(db);
        } else {
                old_user_ptr = db->db_user_ptr;
        }

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_diff.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_diff.c      Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_diff.c      Mon Dec 
15 07:52:23 2014        (r275782)
@@ -221,7 +221,7 @@ dmu_diff(const char *tosnap_name, const 
                return (SET_ERROR(EXDEV));
        }
 
-       fromtxg = fromsnap->ds_phys->ds_creation_txg;
+       fromtxg = dsl_dataset_phys(fromsnap)->ds_creation_txg;
        dsl_dataset_rele(fromsnap, FTAG);
 
        dsl_dataset_long_hold(tosnap, FTAG);

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_objset.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_objset.c    Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_objset.c    Mon Dec 
15 07:52:23 2014        (r275782)
@@ -1479,12 +1479,12 @@ dmu_snapshot_realname(objset_t *os, char
        dsl_dataset_t *ds = os->os_dsl_dataset;
        uint64_t ignored;
 
-       if (ds->ds_phys->ds_snapnames_zapobj == 0)
+       if (dsl_dataset_phys(ds)->ds_snapnames_zapobj == 0)
                return (SET_ERROR(ENOENT));
 
        return (zap_lookup_norm(ds->ds_dir->dd_pool->dp_meta_objset,
-           ds->ds_phys->ds_snapnames_zapobj, name, 8, 1, &ignored, MT_FIRST,
-           real, maxlen, conflict));
+           dsl_dataset_phys(ds)->ds_snapnames_zapobj, name, 8, 1, &ignored,
+           MT_FIRST, real, maxlen, conflict));
 }
 
 int
@@ -1497,12 +1497,12 @@ dmu_snapshot_list_next(objset_t *os, int
 
        ASSERT(dsl_pool_config_held(dmu_objset_pool(os)));
 
-       if (ds->ds_phys->ds_snapnames_zapobj == 0)
+       if (dsl_dataset_phys(ds)->ds_snapnames_zapobj == 0)
                return (SET_ERROR(ENOENT));
 
        zap_cursor_init_serialized(&cursor,
            ds->ds_dir->dd_pool->dp_meta_objset,
-           ds->ds_phys->ds_snapnames_zapobj, *offp);
+           dsl_dataset_phys(ds)->ds_snapnames_zapobj, *offp);
 
        if (zap_cursor_retrieve(&cursor, &attr) != 0) {
                zap_cursor_fini(&cursor);
@@ -1536,12 +1536,12 @@ dmu_dir_list_next(objset_t *os, int name
 
        /* there is no next dir on a snapshot! */
        if (os->os_dsl_dataset->ds_object !=
-           dd->dd_phys->dd_head_dataset_obj)
+           dsl_dir_phys(dd)->dd_head_dataset_obj)
                return (SET_ERROR(ENOENT));
 
        zap_cursor_init_serialized(&cursor,
            dd->dd_pool->dp_meta_objset,
-           dd->dd_phys->dd_child_dir_zapobj, *offp);
+           dsl_dir_phys(dd)->dd_child_dir_zapobj, *offp);
 
        if (zap_cursor_retrieve(&cursor, &attr) != 0) {
                zap_cursor_fini(&cursor);
@@ -1589,7 +1589,7 @@ dmu_objset_find_dp(dsl_pool_t *dp, uint6
                return (0);
        }
 
-       thisobj = dd->dd_phys->dd_head_dataset_obj;
+       thisobj = dsl_dir_phys(dd)->dd_head_dataset_obj;
        attr = kmem_alloc(sizeof (zap_attribute_t), KM_SLEEP);
 
        /*
@@ -1597,7 +1597,7 @@ dmu_objset_find_dp(dsl_pool_t *dp, uint6
         */
        if (flags & DS_FIND_CHILDREN) {
                for (zap_cursor_init(&zc, dp->dp_meta_objset,
-                   dd->dd_phys->dd_child_dir_zapobj);
+                   dsl_dir_phys(dd)->dd_child_dir_zapobj);
                    zap_cursor_retrieve(&zc, attr) == 0;
                    (void) zap_cursor_advance(&zc)) {
                        ASSERT3U(attr->za_integer_length, ==,
@@ -1626,7 +1626,9 @@ dmu_objset_find_dp(dsl_pool_t *dp, uint6
                err = dsl_dataset_hold_obj(dp, thisobj, FTAG, &ds);
 
                if (err == 0) {
-                       uint64_t snapobj = ds->ds_phys->ds_snapnames_zapobj;
+                       uint64_t snapobj;
+
+                       snapobj = dsl_dataset_phys(ds)->ds_snapnames_zapobj;
                        dsl_dataset_rele(ds, FTAG);
 
                        for (zap_cursor_init(&zc, dp->dp_meta_objset, snapobj);
@@ -1701,7 +1703,7 @@ dmu_objset_find_impl(spa_t *spa, const c
                return (0);
        }
 
-       thisobj = dd->dd_phys->dd_head_dataset_obj;
+       thisobj = dsl_dir_phys(dd)->dd_head_dataset_obj;
        attr = kmem_alloc(sizeof (zap_attribute_t), KM_SLEEP);
 
        /*
@@ -1709,7 +1711,7 @@ dmu_objset_find_impl(spa_t *spa, const c
         */
        if (flags & DS_FIND_CHILDREN) {
                for (zap_cursor_init(&zc, dp->dp_meta_objset,
-                   dd->dd_phys->dd_child_dir_zapobj);
+                   dsl_dir_phys(dd)->dd_child_dir_zapobj);
                    zap_cursor_retrieve(&zc, attr) == 0;
                    (void) zap_cursor_advance(&zc)) {
                        ASSERT3U(attr->za_integer_length, ==,
@@ -1742,7 +1744,9 @@ dmu_objset_find_impl(spa_t *spa, const c
                err = dsl_dataset_hold_obj(dp, thisobj, FTAG, &ds);
 
                if (err == 0) {
-                       uint64_t snapobj = ds->ds_phys->ds_snapnames_zapobj;
+                       uint64_t snapobj;
+
+                       snapobj = dsl_dataset_phys(ds)->ds_snapnames_zapobj;
                        dsl_dataset_rele(ds, FTAG);
 
                        for (zap_cursor_init(&zc, dp->dp_meta_objset, snapobj);

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_send.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_send.c      Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_send.c      Mon Dec 
15 07:52:23 2014        (r275782)
@@ -623,12 +623,12 @@ dmu_send_impl(void *tag, dsl_pool_t *dp,
            featureflags);
 
        drr->drr_u.drr_begin.drr_creation_time =
-           ds->ds_phys->ds_creation_time;
+           dsl_dataset_phys(ds)->ds_creation_time;
        drr->drr_u.drr_begin.drr_type = dmu_objset_type(os);
        if (is_clone)
                drr->drr_u.drr_begin.drr_flags |= DRR_FLAG_CLONE;
-       drr->drr_u.drr_begin.drr_toguid = ds->ds_phys->ds_guid;
-       if (ds->ds_phys->ds_flags & DS_FLAG_CI_DATASET)
+       drr->drr_u.drr_begin.drr_toguid = dsl_dataset_phys(ds)->ds_guid;
+       if (dsl_dataset_phys(ds)->ds_flags & DS_FLAG_CI_DATASET)
                drr->drr_u.drr_begin.drr_flags |= DRR_FLAG_CI_DATA;
 
        if (fromzb != NULL) {
@@ -650,7 +650,7 @@ dmu_send_impl(void *tag, dsl_pool_t *dp,
        dsp->dsa_fp = fp;
        dsp->dsa_os = os;
        dsp->dsa_off = off;
-       dsp->dsa_toguid = ds->ds_phys->ds_guid;
+       dsp->dsa_toguid = dsl_dataset_phys(ds)->ds_guid;
        ZIO_SET_CHECKSUM(&dsp->dsa_zc, 0, 0, 0, 0);
        dsp->dsa_pending_op = PENDING_NONE;
        dsp->dsa_incremental = (fromzb != NULL);
@@ -740,9 +740,10 @@ dmu_send_obj(const char *pool, uint64_t 
                }
                if (!dsl_dataset_is_before(ds, fromds, 0))
                        err = SET_ERROR(EXDEV);
-               zb.zbm_creation_time = fromds->ds_phys->ds_creation_time;
-               zb.zbm_creation_txg = fromds->ds_phys->ds_creation_txg;
-               zb.zbm_guid = fromds->ds_phys->ds_guid;
+               zb.zbm_creation_time =
+                   dsl_dataset_phys(fromds)->ds_creation_time;
+               zb.zbm_creation_txg = dsl_dataset_phys(fromds)->ds_creation_txg;
+               zb.zbm_guid = dsl_dataset_phys(fromds)->ds_guid;
                is_clone = (fromds->ds_dir != ds->ds_dir);
                dsl_dataset_rele(fromds, FTAG);
                err = dmu_send_impl(FTAG, dp, ds, &zb, is_clone,
@@ -813,10 +814,10 @@ dmu_send(const char *tosnap, const char 
                                if (!dsl_dataset_is_before(ds, fromds, 0))
                                        err = SET_ERROR(EXDEV);
                                zb.zbm_creation_time =
-                                   fromds->ds_phys->ds_creation_time;
+                                   dsl_dataset_phys(fromds)->ds_creation_time;
                                zb.zbm_creation_txg =
-                                   fromds->ds_phys->ds_creation_txg;
-                               zb.zbm_guid = fromds->ds_phys->ds_guid;
+                                   dsl_dataset_phys(fromds)->ds_creation_txg;
+                               zb.zbm_guid = dsl_dataset_phys(fromds)->ds_guid;
                                is_clone = (ds->ds_dir != fromds->ds_dir);
                                dsl_dataset_rele(fromds, FTAG);
                        }
@@ -863,7 +864,7 @@ dmu_send_estimate(dsl_dataset_t *ds, dsl
 
        /* Get uncompressed size estimate of changed data. */
        if (fromds == NULL) {
-               size = ds->ds_phys->ds_uncompressed_bytes;
+               size = dsl_dataset_phys(ds)->ds_uncompressed_bytes;
        } else {
                uint64_t used, comp;
                err = dsl_dataset_space_written(fromds, ds,
@@ -918,15 +919,15 @@ recv_begin_check_existing_impl(dmu_recv_
 
        /* temporary clone name must not exist */
        error = zap_lookup(dp->dp_meta_objset,
-           ds->ds_dir->dd_phys->dd_child_dir_zapobj, recv_clone_name,
+           dsl_dir_phys(ds->ds_dir)->dd_child_dir_zapobj, recv_clone_name,
            8, 1, &val);
        if (error != ENOENT)
                return (error == 0 ? EBUSY : error);
 
        /* new snapshot name must not exist */
        error = zap_lookup(dp->dp_meta_objset,
-           ds->ds_phys->ds_snapnames_zapobj, drba->drba_cookie->drc_tosnap,
-           8, 1, &val);
+           dsl_dataset_phys(ds)->ds_snapnames_zapobj,
+           drba->drba_cookie->drc_tosnap, 8, 1, &val);
        if (error != ENOENT)
                return (error == 0 ? EEXIST : error);
 
@@ -946,7 +947,7 @@ recv_begin_check_existing_impl(dmu_recv_
 
        if (fromguid != 0) {
                dsl_dataset_t *snap;
-               uint64_t obj = ds->ds_phys->ds_prev_snap_obj;
+               uint64_t obj = dsl_dataset_phys(ds)->ds_prev_snap_obj;
 
                /* Find snapshot in this dir that matches fromguid. */
                while (obj != 0) {
@@ -958,9 +959,9 @@ recv_begin_check_existing_impl(dmu_recv_
                                dsl_dataset_rele(snap, FTAG);
                                return (SET_ERROR(ENODEV));
                        }
-                       if (snap->ds_phys->ds_guid == fromguid)
+                       if (dsl_dataset_phys(snap)->ds_guid == fromguid)
                                break;
-                       obj = snap->ds_phys->ds_prev_snap_obj;
+                       obj = dsl_dataset_phys(snap)->ds_prev_snap_obj;
                        dsl_dataset_rele(snap, FTAG);
                }
                if (obj == 0)
@@ -983,9 +984,9 @@ recv_begin_check_existing_impl(dmu_recv_
                dsl_dataset_rele(snap, FTAG);
        } else {
                /* if full, most recent snapshot must be $ORIGIN */
-               if (ds->ds_phys->ds_prev_snap_txg >= TXG_INITIAL)
+               if (dsl_dataset_phys(ds)->ds_prev_snap_txg >= TXG_INITIAL)
                        return (SET_ERROR(ENODEV));
-               drba->drba_snapobj = ds->ds_phys->ds_prev_snap_obj;
+               drba->drba_snapobj = dsl_dataset_phys(ds)->ds_prev_snap_obj;
        }
 
        return (0);
@@ -1103,7 +1104,7 @@ dmu_recv_begin_check(void *arg, dmu_tx_t
                                dsl_dataset_rele(ds, FTAG);
                                return (SET_ERROR(EINVAL));
                        }
-                       if (origin->ds_phys->ds_guid != fromguid) {
+                       if (dsl_dataset_phys(origin)->ds_guid != fromguid) {
                                dsl_dataset_rele(origin, FTAG);
                                dsl_dataset_rele(ds, FTAG);
                                return (SET_ERROR(ENODEV));
@@ -1174,7 +1175,7 @@ dmu_recv_begin_sync(void *arg, dmu_tx_t 
        }
 
        dmu_buf_will_dirty(newds->ds_dbuf, tx);
-       newds->ds_phys->ds_flags |= DS_FLAG_INCONSISTENT;
+       dsl_dataset_phys(newds)->ds_flags |= DS_FLAG_INCONSISTENT;
 
        /*
         * If we actually created a non-clone, we need to create the
@@ -1837,7 +1838,7 @@ dmu_recv_stream(dmu_recv_cookie_t *drc, 
         */
        VERIFY0(dmu_objset_from_ds(drc->drc_ds, &os));
 
-       ASSERT(drc->drc_ds->ds_phys->ds_flags & DS_FLAG_INCONSISTENT);
+       ASSERT(dsl_dataset_phys(drc->drc_ds)->ds_flags & DS_FLAG_INCONSISTENT);
 
        featureflags = DMU_GET_FEATUREFLAGS(drc->drc_drrb->drr_versioninfo);
 
@@ -2000,8 +2001,11 @@ dmu_recv_end_check(void *arg, dmu_tx_t *
                         * the snap before drc_ds, because drc_ds can not
                         * have any snaps of its own).
                         */
-                       uint64_t obj = origin_head->ds_phys->ds_prev_snap_obj;
-                       while (obj != drc->drc_ds->ds_phys->ds_prev_snap_obj) {
+                       uint64_t obj;
+
+                       obj = dsl_dataset_phys(origin_head)->ds_prev_snap_obj;
+                       while (obj !=
+                           dsl_dataset_phys(drc->drc_ds)->ds_prev_snap_obj) {
                                dsl_dataset_t *snap;
                                error = dsl_dataset_hold_obj(dp, obj, FTAG,
                                    &snap);
@@ -2013,7 +2017,7 @@ dmu_recv_end_check(void *arg, dmu_tx_t *
                                        error = dsl_destroy_snapshot_check_impl(
                                            snap, B_FALSE);
                                }
-                               obj = snap->ds_phys->ds_prev_snap_obj;
+                               obj = dsl_dataset_phys(snap)->ds_prev_snap_obj;
                                dsl_dataset_rele(snap, FTAG);
                                if (error != 0)
                                        return (error);
@@ -2059,13 +2063,16 @@ dmu_recv_end_sync(void *arg, dmu_tx_t *t
                         * Destroy any snapshots of drc_tofs (origin_head)
                         * after the origin (the snap before drc_ds).
                         */
-                       uint64_t obj = origin_head->ds_phys->ds_prev_snap_obj;
-                       while (obj != drc->drc_ds->ds_phys->ds_prev_snap_obj) {
+                       uint64_t obj;
+
+                       obj = dsl_dataset_phys(origin_head)->ds_prev_snap_obj;
+                       while (obj !=
+                           dsl_dataset_phys(drc->drc_ds)->ds_prev_snap_obj) {
                                dsl_dataset_t *snap;
                                VERIFY0(dsl_dataset_hold_obj(dp, obj, FTAG,
                                    &snap));
                                ASSERT3P(snap->ds_dir, ==, origin_head->ds_dir);
-                               obj = snap->ds_phys->ds_prev_snap_obj;
+                               obj = dsl_dataset_phys(snap)->ds_prev_snap_obj;
                                dsl_destroy_snapshot_sync_impl(snap,
                                    B_FALSE, tx);
                                dsl_dataset_rele(snap, FTAG);
@@ -2081,15 +2088,16 @@ dmu_recv_end_sync(void *arg, dmu_tx_t *t
 
                /* set snapshot's creation time and guid */
                dmu_buf_will_dirty(origin_head->ds_prev->ds_dbuf, tx);
-               origin_head->ds_prev->ds_phys->ds_creation_time =
+               dsl_dataset_phys(origin_head->ds_prev)->ds_creation_time =
                    drc->drc_drrb->drr_creation_time;
-               origin_head->ds_prev->ds_phys->ds_guid =
+               dsl_dataset_phys(origin_head->ds_prev)->ds_guid =
                    drc->drc_drrb->drr_toguid;
-               origin_head->ds_prev->ds_phys->ds_flags &=
+               dsl_dataset_phys(origin_head->ds_prev)->ds_flags &=
                    ~DS_FLAG_INCONSISTENT;
 
                dmu_buf_will_dirty(origin_head->ds_dbuf, tx);
-               origin_head->ds_phys->ds_flags &= ~DS_FLAG_INCONSISTENT;
+               dsl_dataset_phys(origin_head)->ds_flags &=
+                   ~DS_FLAG_INCONSISTENT;
 
                dsl_dataset_rele(origin_head, FTAG);
                dsl_destroy_head_sync_impl(drc->drc_ds, tx);
@@ -2103,15 +2111,17 @@ dmu_recv_end_sync(void *arg, dmu_tx_t *t
 
                /* set snapshot's creation time and guid */
                dmu_buf_will_dirty(ds->ds_prev->ds_dbuf, tx);
-               ds->ds_prev->ds_phys->ds_creation_time =
+               dsl_dataset_phys(ds->ds_prev)->ds_creation_time =
                    drc->drc_drrb->drr_creation_time;
-               ds->ds_prev->ds_phys->ds_guid = drc->drc_drrb->drr_toguid;
-               ds->ds_prev->ds_phys->ds_flags &= ~DS_FLAG_INCONSISTENT;
+               dsl_dataset_phys(ds->ds_prev)->ds_guid =
+                   drc->drc_drrb->drr_toguid;
+               dsl_dataset_phys(ds->ds_prev)->ds_flags &=
+                   ~DS_FLAG_INCONSISTENT;
 
                dmu_buf_will_dirty(ds->ds_dbuf, tx);
-               ds->ds_phys->ds_flags &= ~DS_FLAG_INCONSISTENT;
+               dsl_dataset_phys(ds)->ds_flags &= ~DS_FLAG_INCONSISTENT;
        }
-       drc->drc_newsnapobj = drc->drc_ds->ds_phys->ds_prev_snap_obj;
+       drc->drc_newsnapobj = dsl_dataset_phys(drc->drc_ds)->ds_prev_snap_obj;
        /*
         * Release the hold from dmu_recv_begin.  This must be done before
         * we return to open context, so that when we free the dataset's dnode,
@@ -2137,7 +2147,7 @@ add_ds_to_guidmap(const char *name, avl_
        gmep = kmem_alloc(sizeof (*gmep), KM_SLEEP);
        err = dsl_dataset_hold_obj(dp, snapobj, gmep, &snapds);
        if (err == 0) {
-               gmep->guid = snapds->ds_phys->ds_guid;
+               gmep->guid = dsl_dataset_phys(snapds)->ds_guid;
                gmep->gme_ds = snapds;
                avl_add(guid_map, gmep);
                dsl_dataset_long_hold(snapds, gmep);

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_traverse.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_traverse.c  Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_traverse.c  Mon Dec 
15 07:52:23 2014        (r275782)
@@ -579,7 +579,7 @@ traverse_dataset(dsl_dataset_t *ds, uint
     blkptr_cb_t func, void *arg)
 {
        return (traverse_impl(ds->ds_dir->dd_pool->dp_spa, ds, ds->ds_object,
-           &ds->ds_phys->ds_bp, txg_start, NULL, flags, func, arg));
+           &dsl_dataset_phys(ds)->ds_bp, txg_start, NULL, flags, func, arg));
 }
 
 int
@@ -634,8 +634,8 @@ traverse_pool(spa_t *spa, uint64_t txg_s
                                        continue;
                                break;
                        }
-                       if (ds->ds_phys->ds_prev_snap_txg > txg)
-                               txg = ds->ds_phys->ds_prev_snap_txg;
+                       if (dsl_dataset_phys(ds)->ds_prev_snap_txg > txg)
+                               txg = dsl_dataset_phys(ds)->ds_prev_snap_txg;
                        err = traverse_dataset(ds, txg, flags, func, arg);
                        dsl_dataset_rele(ds, FTAG);
                        if (err != 0)

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_tx.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_tx.c        Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dmu_tx.c        Mon Dec 
15 07:52:23 2014        (r275782)
@@ -714,6 +714,7 @@ dmu_tx_hold_zap(dmu_tx_t *tx, uint64_t o
 {
        dmu_tx_hold_t *txh;
        dnode_t *dn;
+       dsl_dataset_phys_t *ds_phys;
        uint64_t nblocks;
        int epbs, err;
 
@@ -788,8 +789,9 @@ dmu_tx_hold_zap(dmu_tx_t *tx, uint64_t o
         * we'll have to modify an indirect twig for each.
         */
        epbs = dn->dn_indblkshift - SPA_BLKPTRSHIFT;
+       ds_phys = dsl_dataset_phys(dn->dn_objset->os_dsl_dataset);
        for (nblocks = dn->dn_maxblkid >> epbs; nblocks != 0; nblocks >>= epbs)
-               if (dn->dn_objset->os_dsl_dataset->ds_phys->ds_prev_snap_obj)
+               if (ds_phys->ds_prev_snap_obj)
                        txh->txh_space_towrite += 3 << dn->dn_indblkshift;
                else
                        txh->txh_space_tooverwrite += 3 << dn->dn_indblkshift;

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dnode.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dnode.c Mon Dec 15 
05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dnode.c Mon Dec 15 
07:52:23 2014        (r275782)
@@ -1121,7 +1121,7 @@ dnode_hold_impl(objset_t *os, uint64_t o
                        zrl_init(&dnh[i].dnh_zrlock);
                        dnh[i].dnh_dnode = NULL;
                }
-               if (winner = dmu_buf_set_user(&db->db, children_dnodes, NULL,
+               if (winner = dmu_buf_set_user(&db->db, children_dnodes,
                    dnode_buf_pageout)) {
 
                        for (i = 0; i < epb; i++) {

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_bookmark.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_bookmark.c  Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_bookmark.c  Mon Dec 
15 07:52:23 2014        (r275782)
@@ -65,7 +65,7 @@ dsl_dataset_bmark_lookup(dsl_dataset_t *
        if (bmark_zapobj == 0)
                return (SET_ERROR(ESRCH));
 
-       if (ds->ds_phys->ds_flags & DS_FLAG_CI_DATASET)
+       if (dsl_dataset_phys(ds)->ds_flags & DS_FLAG_CI_DATASET)
                mt = MT_FIRST;
        else
                mt = MT_EXACT;
@@ -208,10 +208,11 @@ dsl_bookmark_create_sync(void *arg, dmu_
                            &bmark_fs->ds_bookmarks, tx));
                }
 
-               bmark_phys.zbm_guid = snapds->ds_phys->ds_guid;
-               bmark_phys.zbm_creation_txg = snapds->ds_phys->ds_creation_txg;
+               bmark_phys.zbm_guid = dsl_dataset_phys(snapds)->ds_guid;
+               bmark_phys.zbm_creation_txg =
+                   dsl_dataset_phys(snapds)->ds_creation_txg;
                bmark_phys.zbm_creation_time =
-                   snapds->ds_phys->ds_creation_time;
+                   dsl_dataset_phys(snapds)->ds_creation_time;
 
                VERIFY0(zap_add(mos, bmark_fs->ds_bookmarks,
                    shortname, sizeof (uint64_t),
@@ -340,7 +341,7 @@ dsl_dataset_bookmark_remove(dsl_dataset_
        uint64_t bmark_zapobj = ds->ds_bookmarks;
        matchtype_t mt;
 
-       if (ds->ds_phys->ds_flags & DS_FLAG_CI_DATASET)
+       if (dsl_dataset_phys(ds)->ds_flags & DS_FLAG_CI_DATASET)
                mt = MT_FIRST;
        else
                mt = MT_EXACT;

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c   Mon Dec 
15 05:10:55 2014        (r275781)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_dataset.c   Mon Dec 
15 07:52:23 2014        (r275782)
@@ -76,6 +76,9 @@ SYSCTL_INT(_vfs_zfs, OID_AUTO, max_recor
 
 #define        DS_REF_MAX      (1ULL << 62)
 
+extern inline dsl_dataset_phys_t *dsl_dataset_phys(dsl_dataset_t *ds);
+extern inline boolean_t dsl_dataset_is_snapshot(dsl_dataset_t *ds);
+
 /*
  * Figure out how much of this delta should be propogated to the dsl_dir
  * layer.  If there's a refreservation, that space has already been
@@ -84,13 +87,15 @@ SYSCTL_INT(_vfs_zfs, OID_AUTO, max_recor
 static int64_t
 parent_delta(dsl_dataset_t *ds, int64_t delta)
 {
+       dsl_dataset_phys_t *ds_phys;
        uint64_t old_bytes, new_bytes;
 
        if (ds->ds_reserved == 0)
                return (delta);
 
-       old_bytes = MAX(ds->ds_phys->ds_unique_bytes, ds->ds_reserved);
-       new_bytes = MAX(ds->ds_phys->ds_unique_bytes + delta, ds->ds_reserved);
+       ds_phys = dsl_dataset_phys(ds);
+       old_bytes = MAX(ds_phys->ds_unique_bytes, ds->ds_reserved);
+       new_bytes = MAX(ds_phys->ds_unique_bytes + delta, ds->ds_reserved);
 
        ASSERT3U(ABS((int64_t)(new_bytes - old_bytes)), <=, ABS(delta));
        return (new_bytes - old_bytes);
@@ -121,10 +126,10 @@ dsl_dataset_block_born(dsl_dataset_t *ds
        dmu_buf_will_dirty(ds->ds_dbuf, tx);
        mutex_enter(&ds->ds_lock);
        delta = parent_delta(ds, used);
-       ds->ds_phys->ds_referenced_bytes += used;
-       ds->ds_phys->ds_compressed_bytes += compressed;
-       ds->ds_phys->ds_uncompressed_bytes += uncompressed;
-       ds->ds_phys->ds_unique_bytes += used;
+       dsl_dataset_phys(ds)->ds_referenced_bytes += used;
+       dsl_dataset_phys(ds)->ds_compressed_bytes += compressed;
+       dsl_dataset_phys(ds)->ds_uncompressed_bytes += uncompressed;
+       dsl_dataset_phys(ds)->ds_unique_bytes += used;
        if (BP_GET_LSIZE(bp) > SPA_OLD_MAXBLOCKSIZE)
                ds->ds_need_large_blocks = B_TRUE;
        mutex_exit(&ds->ds_lock);
@@ -159,17 +164,17 @@ dsl_dataset_block_kill(dsl_dataset_t *ds
        ASSERT(!dsl_dataset_is_snapshot(ds));
        dmu_buf_will_dirty(ds->ds_dbuf, tx);
 
-       if (bp->blk_birth > ds->ds_phys->ds_prev_snap_txg) {
+       if (bp->blk_birth > dsl_dataset_phys(ds)->ds_prev_snap_txg) {
                int64_t delta;
 
                dprintf_bp(bp, "freeing ds=%llu", ds->ds_object);
                dsl_free(tx->tx_pool, tx->tx_txg, bp);
 
                mutex_enter(&ds->ds_lock);
-               ASSERT(ds->ds_phys->ds_unique_bytes >= used ||
+               ASSERT(dsl_dataset_phys(ds)->ds_unique_bytes >= used ||
                    !DS_UNIQUE_IS_ACCURATE(ds));
                delta = parent_delta(ds, -used);
-               ds->ds_phys->ds_unique_bytes -= used;
+               dsl_dataset_phys(ds)->ds_unique_bytes -= used;
                mutex_exit(&ds->ds_lock);
                dsl_dir_diduse_space(ds->ds_dir, DD_USED_HEAD,
                    delta, -compressed, -uncompressed, tx);
@@ -190,15 +195,15 @@ dsl_dataset_block_kill(dsl_dataset_t *ds
                        dsl_deadlist_insert(&ds->ds_deadlist, bp, tx);
                }
                ASSERT3U(ds->ds_prev->ds_object, ==,
-                   ds->ds_phys->ds_prev_snap_obj);
-               ASSERT(ds->ds_prev->ds_phys->ds_num_children > 0);
+                   dsl_dataset_phys(ds)->ds_prev_snap_obj);
+               ASSERT(dsl_dataset_phys(ds->ds_prev)->ds_num_children > 0);
                /* if (bp->blk_birth > prev prev snap txg) prev unique += bs */
-               if (ds->ds_prev->ds_phys->ds_next_snap_obj ==
+               if (dsl_dataset_phys(ds->ds_prev)->ds_next_snap_obj ==
                    ds->ds_object && bp->blk_birth >
-                   ds->ds_prev->ds_phys->ds_prev_snap_txg) {
+                   dsl_dataset_phys(ds->ds_prev)->ds_prev_snap_txg) {
                        dmu_buf_will_dirty(ds->ds_prev->ds_dbuf, tx);
                        mutex_enter(&ds->ds_prev->ds_lock);
-                       ds->ds_prev->ds_phys->ds_unique_bytes += used;
+                       dsl_dataset_phys(ds->ds_prev)->ds_unique_bytes += used;
                        mutex_exit(&ds->ds_prev->ds_lock);
                }
                if (bp->blk_birth > ds->ds_dir->dd_origin_txg) {
@@ -207,12 +212,12 @@ dsl_dataset_block_kill(dsl_dataset_t *ds
                }
        }
        mutex_enter(&ds->ds_lock);
-       ASSERT3U(ds->ds_phys->ds_referenced_bytes, >=, used);
-       ds->ds_phys->ds_referenced_bytes -= used;
-       ASSERT3U(ds->ds_phys->ds_compressed_bytes, >=, compressed);
-       ds->ds_phys->ds_compressed_bytes -= compressed;
-       ASSERT3U(ds->ds_phys->ds_uncompressed_bytes, >=, uncompressed);
-       ds->ds_phys->ds_uncompressed_bytes -= uncompressed;
+       ASSERT3U(dsl_dataset_phys(ds)->ds_referenced_bytes, >=, used);
+       dsl_dataset_phys(ds)->ds_referenced_bytes -= used;
+       ASSERT3U(dsl_dataset_phys(ds)->ds_compressed_bytes, >=, compressed);
+       dsl_dataset_phys(ds)->ds_compressed_bytes -= compressed;
+       ASSERT3U(dsl_dataset_phys(ds)->ds_uncompressed_bytes, >=, uncompressed);
+       dsl_dataset_phys(ds)->ds_uncompressed_bytes -= uncompressed;
        mutex_exit(&ds->ds_lock);
 
        return (used);
@@ -238,7 +243,7 @@ dsl_dataset_prev_snap_txg(dsl_dataset_t 
        if (ds->ds_trysnap_txg >
            spa_last_synced_txg(ds->ds_dir->dd_pool->dp_spa))
                trysnap = ds->ds_trysnap_txg;
-       return (MAX(ds->ds_phys->ds_prev_snap_txg, trysnap));
+       return (MAX(dsl_dataset_phys(ds)->ds_prev_snap_txg, trysnap));
 }
 
 boolean_t
@@ -273,7 +278,7 @@ dsl_dataset_evict(dmu_buf_t *db, void *d
        }
 
        bplist_destroy(&ds->ds_pending_deadlist);
-       if (ds->ds_phys->ds_deadlist_obj != 0)
+       if (dsl_dataset_phys(ds)->ds_deadlist_obj != 0)
                dsl_deadlist_close(&ds->ds_deadlist);
        if (ds->ds_dir)
                dsl_dir_rele(ds->ds_dir, ds);
@@ -303,10 +308,10 @@ dsl_dataset_get_snapname(dsl_dataset_t *
 
        if (ds->ds_snapname[0])
                return (0);
-       if (ds->ds_phys->ds_next_snap_obj == 0)
+       if (dsl_dataset_phys(ds)->ds_next_snap_obj == 0)
                return (0);
 
-       err = dmu_bonus_hold(mos, ds->ds_dir->dd_phys->dd_head_dataset_obj,
+       err = dmu_bonus_hold(mos, dsl_dir_phys(ds->ds_dir)->dd_head_dataset_obj,
            FTAG, &headdbuf);
        if (err != 0)
                return (err);
@@ -321,11 +326,11 @@ int
 dsl_dataset_snap_lookup(dsl_dataset_t *ds, const char *name, uint64_t *value)
 {
        objset_t *mos = ds->ds_dir->dd_pool->dp_meta_objset;
-       uint64_t snapobj = ds->ds_phys->ds_snapnames_zapobj;
+       uint64_t snapobj = dsl_dataset_phys(ds)->ds_snapnames_zapobj;
        matchtype_t mt;
        int err;
 
-       if (ds->ds_phys->ds_flags & DS_FLAG_CI_DATASET)
+       if (dsl_dataset_phys(ds)->ds_flags & DS_FLAG_CI_DATASET)
                mt = MT_FIRST;
        else
                mt = MT_EXACT;
@@ -342,13 +347,13 @@ dsl_dataset_snap_remove(dsl_dataset_t *d
     boolean_t adj_cnt)
 {
        objset_t *mos = ds->ds_dir->dd_pool->dp_meta_objset;
-       uint64_t snapobj = ds->ds_phys->ds_snapnames_zapobj;
+       uint64_t snapobj = dsl_dataset_phys(ds)->ds_snapnames_zapobj;
        matchtype_t mt;
        int err;
 
        dsl_dir_snap_cmtime_update(ds->ds_dir);
 
-       if (ds->ds_phys->ds_flags & DS_FLAG_CI_DATASET)
+       if (dsl_dataset_phys(ds)->ds_flags & DS_FLAG_CI_DATASET)
                mt = MT_FIRST;
        else
                mt = MT_EXACT;
@@ -394,7 +399,6 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
                ds = kmem_zalloc(sizeof (dsl_dataset_t), KM_SLEEP);
                ds->ds_dbuf = dbuf;
                ds->ds_object = dsobj;
-               ds->ds_phys = dbuf->db_data;
 
                mutex_init(&ds->ds_lock, NULL, MUTEX_DEFAULT, NULL);
                mutex_init(&ds->ds_opening_lock, NULL, MUTEX_DEFAULT, NULL);
@@ -403,7 +407,7 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
 
                bplist_create(&ds->ds_pending_deadlist);
                dsl_deadlist_open(&ds->ds_deadlist,
-                   mos, ds->ds_phys->ds_deadlist_obj);
+                   mos, dsl_dataset_phys(ds)->ds_deadlist_obj);
 
                list_create(&ds->ds_sendstreams, sizeof (dmu_sendarg_t),
                    offsetof(dmu_sendarg_t, dsa_link));
@@ -418,7 +422,8 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
 
                if (err == 0) {
                        err = dsl_dir_hold_obj(dp,
-                           ds->ds_phys->ds_dir_obj, NULL, ds, &ds->ds_dir);
+                           dsl_dataset_phys(ds)->ds_dir_obj, NULL, ds,
+                           &ds->ds_dir);
                }
                if (err != 0) {
                        mutex_destroy(&ds->ds_lock);
@@ -434,9 +439,9 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
 
                if (!dsl_dataset_is_snapshot(ds)) {
                        ds->ds_snapname[0] = '\0';
-                       if (ds->ds_phys->ds_prev_snap_obj != 0) {
+                       if (dsl_dataset_phys(ds)->ds_prev_snap_obj != 0) {
                                err = dsl_dataset_hold_obj(dp,
-                                   ds->ds_phys->ds_prev_snap_obj,
+                                   dsl_dataset_phys(ds)->ds_prev_snap_obj,
                                    ds, &ds->ds_prev);
                        }
                        if (doi.doi_type == DMU_OTN_ZAP_METADATA) {
@@ -450,10 +455,11 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
                } else {
                        if (zfs_flags & ZFS_DEBUG_SNAPNAMES)
                                err = dsl_dataset_get_snapname(ds);
-                       if (err == 0 && ds->ds_phys->ds_userrefs_obj != 0) {
+                       if (err == 0 &&
+                           dsl_dataset_phys(ds)->ds_userrefs_obj != 0) {
                                err = zap_count(
                                    ds->ds_dir->dd_pool->dp_meta_objset,
-                                   ds->ds_phys->ds_userrefs_obj,
+                                   dsl_dataset_phys(ds)->ds_userrefs_obj,
                                    &ds->ds_userrefs);
                        }
                }
@@ -472,7 +478,7 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
                }
 
                if (err != 0 || (winner = dmu_buf_set_user_ie(dbuf, ds,
-                   &ds->ds_phys, dsl_dataset_evict)) != NULL) {
+                   dsl_dataset_evict)) != NULL) {
                        bplist_destroy(&ds->ds_pending_deadlist);
                        dsl_deadlist_close(&ds->ds_deadlist);
                        if (ds->ds_prev)
@@ -490,12 +496,12 @@ dsl_dataset_hold_obj(dsl_pool_t *dp, uin
                        ds = winner;
                } else {
                        ds->ds_fsid_guid =
-                           unique_insert(ds->ds_phys->ds_fsid_guid);
+                           unique_insert(dsl_dataset_phys(ds)->ds_fsid_guid);
                }
        }
        ASSERT3P(ds->ds_dbuf, ==, dbuf);
-       ASSERT3P(ds->ds_phys, ==, dbuf->db_data);
-       ASSERT(ds->ds_phys->ds_prev_snap_obj != 0 ||
+       ASSERT3P(dsl_dataset_phys(ds), ==, dbuf->db_data);
+       ASSERT(dsl_dataset_phys(ds)->ds_prev_snap_obj != 0 ||
            spa_version(dp->dp_spa) < SPA_VERSION_ORIGIN ||
            dp->dp_origin_snap == NULL || ds == dp->dp_origin_snap);
        *dsp = ds;
@@ -516,7 +522,7 @@ dsl_dataset_hold(dsl_pool_t *dp, const c
                return (err);
 
        ASSERT(dsl_pool_config_held(dp));
-       obj = dd->dd_phys->dd_head_dataset_obj;
+       obj = dsl_dir_phys(dd)->dd_head_dataset_obj;
        if (obj != 0)
                err = dsl_dataset_hold_obj(dp, obj, tag, dsp);
        else
@@ -683,9 +689,9 @@ dsl_dataset_create_sync_dd(dsl_dir_t *dd
                origin = dp->dp_origin_snap;
 
        ASSERT(origin == NULL || origin->ds_dir->dd_pool == dp);
-       ASSERT(origin == NULL || origin->ds_phys->ds_num_children > 0);
+       ASSERT(origin == NULL || dsl_dataset_phys(origin)->ds_num_children > 0);
        ASSERT(dmu_tx_is_syncing(tx));
-       ASSERT(dd->dd_phys->dd_head_dataset_obj == 0);
+       ASSERT(dsl_dir_phys(dd)->dd_head_dataset_obj == 0);
 
        dsobj = dmu_object_alloc(mos, DMU_OT_DSL_DATASET, 0,
            DMU_OT_DSL_DATASET, sizeof (dsl_dataset_phys_t), tx);
@@ -713,55 +719,58 @@ dsl_dataset_create_sync_dd(dsl_dir_t *dd
 
                dsphys->ds_prev_snap_obj = origin->ds_object;
                dsphys->ds_prev_snap_txg =
-                   origin->ds_phys->ds_creation_txg;
+                   dsl_dataset_phys(origin)->ds_creation_txg;
                dsphys->ds_referenced_bytes =
-                   origin->ds_phys->ds_referenced_bytes;
+                   dsl_dataset_phys(origin)->ds_referenced_bytes;
                dsphys->ds_compressed_bytes =
-                   origin->ds_phys->ds_compressed_bytes;
+                   dsl_dataset_phys(origin)->ds_compressed_bytes;
                dsphys->ds_uncompressed_bytes =
-                   origin->ds_phys->ds_uncompressed_bytes;
-               dsphys->ds_bp = origin->ds_phys->ds_bp;
+                   dsl_dataset_phys(origin)->ds_uncompressed_bytes;
+               dsphys->ds_bp = dsl_dataset_phys(origin)->ds_bp;
 
                /*
                 * Inherit flags that describe the dataset's contents
                 * (INCONSISTENT) or properties (Case Insensitive).
                 */
-               dsphys->ds_flags |= origin->ds_phys->ds_flags &
+               dsphys->ds_flags |= dsl_dataset_phys(origin)->ds_flags &
                    (DS_FLAG_INCONSISTENT | DS_FLAG_CI_DATASET);
 
                if (origin->ds_large_blocks)
                        dsl_dataset_activate_large_blocks_sync_impl(dsobj, tx);
 
                dmu_buf_will_dirty(origin->ds_dbuf, tx);
-               origin->ds_phys->ds_num_children++;
+               dsl_dataset_phys(origin)->ds_num_children++;
 
                VERIFY0(dsl_dataset_hold_obj(dp,
-                   origin->ds_dir->dd_phys->dd_head_dataset_obj, FTAG, &ohds));
+                   dsl_dir_phys(origin->ds_dir)->dd_head_dataset_obj,
+                   FTAG, &ohds));
                dsphys->ds_deadlist_obj = dsl_deadlist_clone(&ohds->ds_deadlist,
                    dsphys->ds_prev_snap_txg, dsphys->ds_prev_snap_obj, tx);
                dsl_dataset_rele(ohds, FTAG);
 
                if (spa_version(dp->dp_spa) >= SPA_VERSION_NEXT_CLONES) {
-                       if (origin->ds_phys->ds_next_clones_obj == 0) {
-                               origin->ds_phys->ds_next_clones_obj =
+                       if (dsl_dataset_phys(origin)->ds_next_clones_obj == 0) {
+                               dsl_dataset_phys(origin)->ds_next_clones_obj =
                                    zap_create(mos,
                                    DMU_OT_NEXT_CLONES, DMU_OT_NONE, 0, tx);
                        }
                        VERIFY0(zap_add_int(mos,
-                           origin->ds_phys->ds_next_clones_obj, dsobj, tx));
+                           dsl_dataset_phys(origin)->ds_next_clones_obj,
+                           dsobj, tx));
                }
 
                dmu_buf_will_dirty(dd->dd_dbuf, tx);
-               dd->dd_phys->dd_origin_obj = origin->ds_object;
+               dsl_dir_phys(dd)->dd_origin_obj = origin->ds_object;
                if (spa_version(dp->dp_spa) >= SPA_VERSION_DIR_CLONES) {
-                       if (origin->ds_dir->dd_phys->dd_clones == 0) {
+                       if (dsl_dir_phys(origin->ds_dir)->dd_clones == 0) {
                                dmu_buf_will_dirty(origin->ds_dir->dd_dbuf, tx);
-                               origin->ds_dir->dd_phys->dd_clones =
+                               dsl_dir_phys(origin->ds_dir)->dd_clones =
                                    zap_create(mos,
                                    DMU_OT_DSL_CLONES, DMU_OT_NONE, 0, tx);
                        }
                        VERIFY0(zap_add_int(mos,
-                           origin->ds_dir->dd_phys->dd_clones, dsobj, tx));
+                           dsl_dir_phys(origin->ds_dir)->dd_clones,
+                           dsobj, tx));
                }
        }
 
@@ -771,7 +780,7 @@ dsl_dataset_create_sync_dd(dsl_dir_t *dd
        dmu_buf_rele(dbuf, FTAG);
 
        dmu_buf_will_dirty(dd->dd_dbuf, tx);
-       dd->dd_phys->dd_head_dataset_obj = dsobj;
+       dsl_dir_phys(dd)->dd_head_dataset_obj = dsobj;
 
        return (dsobj);
 }
@@ -893,20 +902,20 @@ dsl_dataset_recalc_head_uniq(dsl_dataset
 
        ASSERT(!dsl_dataset_is_snapshot(ds));
 
-       if (ds->ds_phys->ds_prev_snap_obj != 0)
-               mrs_used = ds->ds_prev->ds_phys->ds_referenced_bytes;
+       if (dsl_dataset_phys(ds)->ds_prev_snap_obj != 0)
+               mrs_used = dsl_dataset_phys(ds->ds_prev)->ds_referenced_bytes;
        else
                mrs_used = 0;
 
        dsl_deadlist_space(&ds->ds_deadlist, &dlused, &dlcomp, &dluncomp);
 
        ASSERT3U(dlused, <=, mrs_used);
-       ds->ds_phys->ds_unique_bytes =
-           ds->ds_phys->ds_referenced_bytes - (mrs_used - dlused);
+       dsl_dataset_phys(ds)->ds_unique_bytes =
+           dsl_dataset_phys(ds)->ds_referenced_bytes - (mrs_used - dlused);
 
        if (spa_version(ds->ds_dir->dd_pool->dp_spa) >=
            SPA_VERSION_UNIQUE_ACCURATE)
-               ds->ds_phys->ds_flags |= DS_FLAG_UNIQUE_ACCURATE;
+               dsl_dataset_phys(ds)->ds_flags |= DS_FLAG_UNIQUE_ACCURATE;
 }
 
 void
@@ -917,8 +926,9 @@ dsl_dataset_remove_from_next_clones(dsl_
        uint64_t count;
        int err;
 
-       ASSERT(ds->ds_phys->ds_num_children >= 2);
-       err = zap_remove_int(mos, ds->ds_phys->ds_next_clones_obj, obj, tx);
+       ASSERT(dsl_dataset_phys(ds)->ds_num_children >= 2);
+       err = zap_remove_int(mos, dsl_dataset_phys(ds)->ds_next_clones_obj,
+           obj, tx);
        /*
         * The err should not be ENOENT, but a bug in a previous version
         * of the code could cause upgrade_clones_cb() to not set
@@ -931,16 +941,16 @@ dsl_dataset_remove_from_next_clones(dsl_
         */
        if (err != ENOENT)
                VERIFY0(err);
-       ASSERT0(zap_count(mos, ds->ds_phys->ds_next_clones_obj,
+       ASSERT0(zap_count(mos, dsl_dataset_phys(ds)->ds_next_clones_obj,
            &count));
-       ASSERT3U(count, <=, ds->ds_phys->ds_num_children - 2);
+       ASSERT3U(count, <=, dsl_dataset_phys(ds)->ds_num_children - 2);
 }
 
 
 blkptr_t *
 dsl_dataset_get_blkptr(dsl_dataset_t *ds)
 {
-       return (&ds->ds_phys->ds_bp);
+       return (&dsl_dataset_phys(ds)->ds_bp);
 }
 
 void
@@ -952,7 +962,7 @@ dsl_dataset_set_blkptr(dsl_dataset_t *ds
                tx->tx_pool->dp_meta_rootbp = *bp;
        } else {
                dmu_buf_will_dirty(ds->ds_dbuf, tx);
-               ds->ds_phys->ds_bp = *bp;
+               dsl_dataset_phys(ds)->ds_bp = *bp;
        }
 }
 
@@ -972,7 +982,7 @@ dsl_dataset_dirty(dsl_dataset_t *ds, dmu
 
        ASSERT(ds->ds_objset != NULL);
 
-       if (ds->ds_phys->ds_next_snap_obj != 0)
+       if (dsl_dataset_phys(ds)->ds_next_snap_obj != 0)
                panic("dirtying snapshot!");
 
        dp = ds->ds_dir->dd_pool;
@@ -1008,7 +1018,7 @@ dsl_dataset_snapshot_reserve_space(dsl_d
         * outside of the reservation.
         */
        ASSERT(ds->ds_reserved == 0 || DS_UNIQUE_IS_ACCURATE(ds));
-       asize = MIN(ds->ds_phys->ds_unique_bytes, ds->ds_reserved);
+       asize = MIN(dsl_dataset_phys(ds)->ds_unique_bytes, ds->ds_reserved);
        if (asize > dsl_dir_space_available(ds->ds_dir, NULL, 0, TRUE))
                return (SET_ERROR(ENOSPC));
 
@@ -1045,7 +1055,7 @@ dsl_dataset_snapshot_check_impl(dsl_data

*** DIFF OUTPUT TRUNCATED AT 1000 LINES ***
_______________________________________________
[email protected] mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "[email protected]"

Reply via email to