]> Git Repo - linux.git/commitdiff
x86/intel_rdt: Fix initial allocation to consider CDP
authorReinette Chatre <[email protected]>
Wed, 3 Oct 2018 22:17:03 +0000 (15:17 -0700)
committerIngo Molnar <[email protected]>
Tue, 9 Oct 2018 06:50:47 +0000 (08:50 +0200)
When a new resource group is created it is initialized with a default
allocation that considers which portions of cache are currently
available for sharing across all resource groups or which portions of
cache are currently unused.

If a CDP allocation forms part of a resource group that is in exclusive
mode then it should be ensured that no new allocation overlaps with any
resource that shares the underlying hardware. The current initial
allocation does not take this sharing of hardware into account and
a new allocation in a resource that shares the same
hardware would affect the exclusive resource group.

Fix this by considering the allocation of a peer RDT domain - a RDT
domain sharing the same hardware - as part of the test to determine
which portion of cache is in use and available for use.

Fixes: 95f0b77efa57 ("x86/intel_rdt: Initialize new resource group with sane defaults")
Signed-off-by: Reinette Chatre <[email protected]>
Signed-off-by: Thomas Gleixner <[email protected]>
Acked-by: Fenghua Yu <[email protected]>
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Cc: [email protected]
Link: https://lkml.kernel.org/r/b1f7ec08b1695be067de416a4128466d49684317.1538603665.git.reinette.chatre@intel.com
Signed-off-by: Ingo Molnar <[email protected]>
arch/x86/kernel/cpu/intel_rdt_rdtgroup.c

index 49c47982284448206e0ed833fae4b1989bfadc3d..dbc7fc98b60a0acca9cb1867035520234cdde975 100644 (file)
@@ -2460,14 +2460,16 @@ static void cbm_ensure_valid(u32 *_val, struct rdt_resource *r)
  */
 static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp)
 {
+       struct rdt_resource *r_cdp = NULL;
+       struct rdt_domain *d_cdp = NULL;
        u32 used_b = 0, unused_b = 0;
        u32 closid = rdtgrp->closid;
        struct rdt_resource *r;
        unsigned long tmp_cbm;
        enum rdtgrp_mode mode;
        struct rdt_domain *d;
+       u32 peer_ctl, *ctrl;
        int i, ret;
-       u32 *ctrl;
 
        for_each_alloc_enabled_rdt_resource(r) {
                /*
@@ -2477,6 +2479,7 @@ static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp)
                if (r->rid == RDT_RESOURCE_MBA)
                        continue;
                list_for_each_entry(d, &r->domains, list) {
+                       rdt_cdp_peer_get(r, d, &r_cdp, &d_cdp);
                        d->have_new_ctrl = false;
                        d->new_ctrl = r->cache.shareable_bits;
                        used_b = r->cache.shareable_bits;
@@ -2486,9 +2489,19 @@ static int rdtgroup_init_alloc(struct rdtgroup *rdtgrp)
                                        mode = rdtgroup_mode_by_closid(i);
                                        if (mode == RDT_MODE_PSEUDO_LOCKSETUP)
                                                break;
-                                       used_b |= *ctrl;
+                                       /*
+                                        * If CDP is active include peer
+                                        * domain's usage to ensure there
+                                        * is no overlap with an exclusive
+                                        * group.
+                                        */
+                                       if (d_cdp)
+                                               peer_ctl = d_cdp->ctrl_val[i];
+                                       else
+                                               peer_ctl = 0;
+                                       used_b |= *ctrl | peer_ctl;
                                        if (mode == RDT_MODE_SHAREABLE)
-                                               d->new_ctrl |= *ctrl;
+                                               d->new_ctrl |= *ctrl | peer_ctl;
                                }
                        }
                        if (d->plr && d->plr->cbm > 0)
This page took 0.069826 seconds and 4 git commands to generate.