Author: avg
Date: Wed Jun 19 20:29:02 2019
New Revision: 349216
URL: https://svnweb.freebsd.org/changeset/base/349216

Log:
  MFC r348772: Restore ARC MFU/MRU pressure
  
  Submitted by: Slawa Olhovchenkov <[email protected]>
  Sponsored by: Integros [integros.com]

Modified:
  stable/11/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c
Directory Properties:
  stable/11/   (props changed)

Modified: stable/11/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c
==============================================================================
--- stable/11/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c      Wed Jun 
19 20:27:31 2019        (r349215)
+++ stable/11/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c      Wed Jun 
19 20:29:02 2019        (r349216)
@@ -1483,14 +1483,14 @@ static kmutex_t l2arc_feed_thr_lock;
 static kcondvar_t l2arc_feed_thr_cv;
 static uint8_t l2arc_thread_exit;
 
-static abd_t *arc_get_data_abd(arc_buf_hdr_t *, uint64_t, void *);
+static abd_t *arc_get_data_abd(arc_buf_hdr_t *, uint64_t, void *, boolean_t);
 static void *arc_get_data_buf(arc_buf_hdr_t *, uint64_t, void *);
-static void arc_get_data_impl(arc_buf_hdr_t *, uint64_t, void *);
+static void arc_get_data_impl(arc_buf_hdr_t *, uint64_t, void *, boolean_t);
 static void arc_free_data_abd(arc_buf_hdr_t *, abd_t *, uint64_t, void *);
 static void arc_free_data_buf(arc_buf_hdr_t *, void *, uint64_t, void *);
 static void arc_free_data_impl(arc_buf_hdr_t *hdr, uint64_t size, void *tag);
 static void arc_hdr_free_pabd(arc_buf_hdr_t *);
-static void arc_hdr_alloc_pabd(arc_buf_hdr_t *);
+static void arc_hdr_alloc_pabd(arc_buf_hdr_t *, boolean_t);
 static void arc_access(arc_buf_hdr_t *, kmutex_t *);
 static boolean_t arc_is_overflowing();
 static void arc_buf_watch(arc_buf_t *);
@@ -3214,14 +3214,14 @@ arc_buf_destroy_impl(arc_buf_t *buf)
 }
 
 static void
-arc_hdr_alloc_pabd(arc_buf_hdr_t *hdr)
+arc_hdr_alloc_pabd(arc_buf_hdr_t *hdr, boolean_t do_adapt)
 {
        ASSERT3U(HDR_GET_LSIZE(hdr), >, 0);
        ASSERT(HDR_HAS_L1HDR(hdr));
        ASSERT(!HDR_SHARED_DATA(hdr));
 
        ASSERT3P(hdr->b_l1hdr.b_pabd, ==, NULL);
-       hdr->b_l1hdr.b_pabd = arc_get_data_abd(hdr, arc_hdr_size(hdr), hdr);
+       hdr->b_l1hdr.b_pabd = arc_get_data_abd(hdr, arc_hdr_size(hdr), hdr, 
do_adapt);
        hdr->b_l1hdr.b_byteswap = DMU_BSWAP_NUMFUNCS;
        ASSERT3P(hdr->b_l1hdr.b_pabd, !=, NULL);
 
@@ -3285,7 +3285,7 @@ arc_hdr_alloc(uint64_t spa, int32_t psize, int32_t lsi
         * the compressed or uncompressed data depending on the block
         * it references and compressed arc enablement.
         */
-       arc_hdr_alloc_pabd(hdr);
+       arc_hdr_alloc_pabd(hdr, B_TRUE);
        ASSERT(refcount_is_zero(&hdr->b_l1hdr.b_refcnt));
 
        return (hdr);
@@ -4850,11 +4850,11 @@ arc_is_overflowing(void)
 }
 
 static abd_t *
-arc_get_data_abd(arc_buf_hdr_t *hdr, uint64_t size, void *tag)
+arc_get_data_abd(arc_buf_hdr_t *hdr, uint64_t size, void *tag, boolean_t 
do_adapt)
 {
        arc_buf_contents_t type = arc_buf_type(hdr);
 
-       arc_get_data_impl(hdr, size, tag);
+       arc_get_data_impl(hdr, size, tag, do_adapt);
        if (type == ARC_BUFC_METADATA) {
                return (abd_alloc(size, B_TRUE));
        } else {
@@ -4868,7 +4868,7 @@ arc_get_data_buf(arc_buf_hdr_t *hdr, uint64_t size, vo
 {
        arc_buf_contents_t type = arc_buf_type(hdr);
 
-       arc_get_data_impl(hdr, size, tag);
+       arc_get_data_impl(hdr, size, tag, B_TRUE);
        if (type == ARC_BUFC_METADATA) {
                return (zio_buf_alloc(size));
        } else {
@@ -4884,12 +4884,13 @@ arc_get_data_buf(arc_buf_hdr_t *hdr, uint64_t size, vo
  * limit, we'll only signal the reclaim thread and continue on.
  */
 static void
-arc_get_data_impl(arc_buf_hdr_t *hdr, uint64_t size, void *tag)
+arc_get_data_impl(arc_buf_hdr_t *hdr, uint64_t size, void *tag, boolean_t 
do_adapt)
 {
        arc_state_t *state = hdr->b_l1hdr.b_state;
        arc_buf_contents_t type = arc_buf_type(hdr);
 
-       arc_adapt(size, state);
+       if (do_adapt)
+               arc_adapt(size, state);
 
        /*
         * If arc_size is currently overflowing, and has grown past our
@@ -5636,8 +5637,9 @@ top:
                         * do this after we've called arc_access() to
                         * avoid hitting an assert in remove_reference().
                         */
+                       arc_adapt(arc_hdr_size(hdr), hdr->b_l1hdr.b_state);
                        arc_access(hdr, hash_lock);
-                       arc_hdr_alloc_pabd(hdr);
+                       arc_hdr_alloc_pabd(hdr, B_FALSE);
                }
                ASSERT3P(hdr->b_l1hdr.b_pabd, !=, NULL);
                size = arc_hdr_size(hdr);
@@ -6013,7 +6015,7 @@ arc_release(arc_buf_t *buf, void *tag)
                        if (arc_can_share(hdr, lastbuf)) {
                                arc_share_buf(hdr, lastbuf);
                        } else {
-                               arc_hdr_alloc_pabd(hdr);
+                               arc_hdr_alloc_pabd(hdr, B_TRUE);
                                abd_copy_from_buf(hdr->b_l1hdr.b_pabd,
                                    buf->b_data, psize);
                        }
@@ -6176,7 +6178,7 @@ arc_write_ready(zio_t *zio)
         * the data into it; otherwise, we share the data directly if we can.
         */
        if (zfs_abd_scatter_enabled || !arc_can_share(hdr, buf)) {
-               arc_hdr_alloc_pabd(hdr);
+               arc_hdr_alloc_pabd(hdr, B_TRUE);
 
                /*
                 * Ideally, we would always copy the io_abd into b_pabd, but the
_______________________________________________
[email protected] mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "[email protected]"

Reply via email to