]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
intel_th: msu: Make contiguous buffers uncached
authorAlexander Shishkin <alexander.shishkin@linux.intel.com>
Mon, 21 Jun 2021 15:12:45 +0000 (18:12 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 24 Jun 2021 13:49:32 +0000 (15:49 +0200)
We already keep the multiblock mode buffers uncached, but forget the
single mode. Address this.

Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Link: https://lore.kernel.org/r/20210621151246.31891-4-alexander.shishkin@linux.intel.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/hwtracing/intel_th/msu.c

index 2edc4666633d0bc974bbe1274cad1a186b2382ad..432ade0842f68724bc9fe2bdde77a8982f67593b 100644 (file)
@@ -1024,33 +1024,49 @@ err_nomem:
 }
 
 #ifdef CONFIG_X86
-static void msc_buffer_set_uc(struct msc_window *win, unsigned int nr_segs)
+static void msc_buffer_set_uc(struct msc *msc)
 {
        struct scatterlist *sg_ptr;
+       struct msc_window *win;
        int i;
 
-       for_each_sg(win->sgt->sgl, sg_ptr, nr_segs, i) {
-               /* Set the page as uncached */
-               set_memory_uc((unsigned long)sg_virt(sg_ptr),
-                             PFN_DOWN(sg_ptr->length));
+       if (msc->mode == MSC_MODE_SINGLE) {
+               set_memory_uc((unsigned long)msc->base, msc->nr_pages);
+               return;
+       }
+
+       list_for_each_entry(win, &msc->win_list, entry) {
+               for_each_sg(win->sgt->sgl, sg_ptr, win->nr_segs, i) {
+                       /* Set the page as uncached */
+                       set_memory_uc((unsigned long)sg_virt(sg_ptr),
+                                       PFN_DOWN(sg_ptr->length));
+               }
        }
 }
 
-static void msc_buffer_set_wb(struct msc_window *win)
+static void msc_buffer_set_wb(struct msc *msc)
 {
        struct scatterlist *sg_ptr;
+       struct msc_window *win;
        int i;
 
-       for_each_sg(win->sgt->sgl, sg_ptr, win->nr_segs, i) {
-               /* Reset the page to write-back */
-               set_memory_wb((unsigned long)sg_virt(sg_ptr),
-                             PFN_DOWN(sg_ptr->length));
+       if (msc->mode == MSC_MODE_SINGLE) {
+               set_memory_wb((unsigned long)msc->base, msc->nr_pages);
+               return;
+       }
+
+       list_for_each_entry(win, &msc->win_list, entry) {
+               for_each_sg(win->sgt->sgl, sg_ptr, win->nr_segs, i) {
+                       /* Reset the page to write-back */
+                       set_memory_wb((unsigned long)sg_virt(sg_ptr),
+                                       PFN_DOWN(sg_ptr->length));
+               }
        }
 }
 #else /* !X86 */
 static inline void
-msc_buffer_set_uc(struct msc_window *win, unsigned int nr_segs) {}
-static inline void msc_buffer_set_wb(struct msc_window *win) {}
+msc_buffer_set_uc(struct msc *msc) {}
+static inline void msc_buffer_set_wb(struct msc *msc) {}
 #endif /* CONFIG_X86 */
 
 /**
@@ -1097,8 +1113,6 @@ static int msc_buffer_win_alloc(struct msc *msc, unsigned int nr_blocks)
        if (ret <= 0)
                goto err_nomem;
 
-       msc_buffer_set_uc(win, ret);
-
        win->nr_segs = ret;
        win->nr_blocks = nr_blocks;
 
@@ -1152,8 +1166,6 @@ static void msc_buffer_win_free(struct msc *msc, struct msc_window *win)
                msc->base_addr = 0;
        }
 
-       msc_buffer_set_wb(win);
-
        if (msc->mbuf && msc->mbuf->free_window)
                msc->mbuf->free_window(msc->mbuf_priv, win->sgt);
        else
@@ -1260,6 +1272,8 @@ static int msc_buffer_multi_alloc(struct msc *msc, unsigned long *nr_pages,
  */
 static void msc_buffer_free(struct msc *msc)
 {
+       msc_buffer_set_wb(msc);
+
        if (msc->mode == MSC_MODE_SINGLE)
                msc_buffer_contig_free(msc);
        else if (msc->mode == MSC_MODE_MULTI)
@@ -1303,6 +1317,8 @@ static int msc_buffer_alloc(struct msc *msc, unsigned long *nr_pages,
        }
 
        if (!ret) {
+               msc_buffer_set_uc(msc);
+
                /* allocation should be visible before the counter goes to 0 */
                smp_mb__before_atomic();