From: Yi Sun <yi.y.sun@linux.intel.com>
To: xen-devel@lists.xenproject.org
Cc: Yi Sun <yi.y.sun@linux.intel.com>, jbeulich@suse.com
Subject: [PATCH] dom_ids array implementation.
Date: Thu, 20 Apr 2017 13:38:24 +0800 [thread overview]
Message-ID: <1492666704-6626-1-git-send-email-yi.y.sun@linux.intel.com> (raw)
In-Reply-To: <1491054836-30488-10-git-send-email-yi.y.sun@linux.intel.com>
Hi, Jan,
Please help to review this patch. Thank you!
Signed-off-by: Yi Sun <yi.y.sun@linux.intel.com>
---
xen/arch/x86/psr.c | 135 ++++++++++++++++++++++-------------------------------
1 file changed, 55 insertions(+), 80 deletions(-)
diff --git a/xen/arch/x86/psr.c b/xen/arch/x86/psr.c
index a85ea99..7bc212f 100644
--- a/xen/arch/x86/psr.c
+++ b/xen/arch/x86/psr.c
@@ -125,6 +125,8 @@ struct feat_node {
uint32_t cos_reg_val[MAX_COS_REG_CNT];
};
+#define PSR_DOM_IDS_NUM ((DOMID_IDLE + 1) / sizeof(uint32_t))
+
/*
* PSR features are managed per socket. Below structure defines the members
* used to manage these features.
@@ -134,9 +136,11 @@ struct feat_node {
* COS ID. Every entry of cos_ref corresponds to one COS ID.
*/
struct psr_socket_info {
- struct feat_node *features[PSR_SOCKET_MAX_FEAT];
spinlock_t ref_lock;
+ spinlock_t dom_ids_lock;
+ struct feat_node *features[PSR_SOCKET_MAX_FEAT];
unsigned int cos_ref[MAX_COS_REG_CNT];
+ uint32_t dom_ids[PSR_DOM_IDS_NUM];
};
struct psr_assoc {
@@ -194,26 +198,11 @@ static void free_socket_resources(unsigned int socket)
{
unsigned int i;
struct psr_socket_info *info = socket_info + socket;
- struct domain *d;
+ unsigned long flag;
if ( !info )
return;
- /* Restore domain cos id to 0 when socket is offline. */
- for_each_domain ( d )
- {
- unsigned int cos = d->arch.psr_cos_ids[socket];
- if ( cos == 0 )
- continue;
-
- spin_lock(&info->ref_lock);
- ASSERT(!cos || info->cos_ref[cos]);
- info->cos_ref[cos]--;
- spin_unlock(&info->ref_lock);
-
- d->arch.psr_cos_ids[socket] = 0;
- }
-
/*
* Free resources of features. The global feature object, e.g. feat_l3_cat,
* may not be freed here if it is not added into array. It is simply being
@@ -221,12 +210,17 @@ static void free_socket_resources(unsigned int socket)
*/
for ( i = 0; i < PSR_SOCKET_MAX_FEAT; i++ )
{
- if ( !info->features[i] )
- continue;
-
xfree(info->features[i]);
info->features[i] = NULL;
}
+
+ spin_lock(&info->ref_lock);
+ memset(info->cos_ref, 0, MAX_COS_REG_CNT * sizeof(unsigned int));
+ spin_unlock(&info->ref_lock);
+
+ spin_lock_irqsave(&info->dom_ids_lock, flag);
+ memset(info->dom_ids, 0, PSR_DOM_IDS_NUM * sizeof(uint32_t));
+ spin_unlock_irqrestore(&info->dom_ids_lock, flag);
}
static bool feat_init_done(const struct psr_socket_info *info)
@@ -682,9 +676,37 @@ void psr_ctxt_switch_to(struct domain *d)
psr_assoc_rmid(®, d->arch.psr_rmid);
if ( psra->cos_mask )
- psr_assoc_cos(®, d->arch.psr_cos_ids ?
- d->arch.psr_cos_ids[cpu_to_socket(smp_processor_id())] :
- 0, psra->cos_mask);
+ {
+ unsigned int socket = cpu_to_socket(smp_processor_id());
+ struct psr_socket_info *info = socket_info + socket;
+
+ if ( test_bit(d->domain_id, info->dom_ids) )
+ goto set_assoc;
+
+ spin_lock(&info->dom_ids_lock);
+
+ int old_bit = test_and_set_bit(d->domain_id, info->dom_ids);
+
+ /*
+ * If old_bit is 0, that means this is the first time the domain is
+ * switched to this socket or domain's COS ID has not been set since
+ * the socket is online. So, the domain's COS ID on this socket should
+ * be default value, 0. If not, that means this socket has been offline
+ * and the domain's COS ID has been set when the socket was online. So,
+ * this COS ID is invalid and we have to restore it to 0.
+ */
+ if ( d->arch.psr_cos_ids &&
+ old_bit == 0 &&
+ d->arch.psr_cos_ids[socket] != 0 )
+ d->arch.psr_cos_ids[socket] = 0;
+
+ spin_unlock(&info->dom_ids_lock);
+
+ set_assoc:
+ psr_assoc_cos(®,
+ d->arch.psr_cos_ids ? d->arch.psr_cos_ids[socket] : 0,
+ psra->cos_mask);
+ }
if ( reg != psra->val )
{
@@ -1146,40 +1168,6 @@ static int write_psr_msr(unsigned int socket, unsigned int cos,
return 0;
}
-static void restore_default_val(unsigned int socket, unsigned int cos,
- enum psr_feat_type feat_type)
-{
- unsigned int i, j;
- uint32_t default_val;
- const struct psr_socket_info *info = get_socket_info(socket);
-
- for ( i = 0; i < PSR_SOCKET_MAX_FEAT; i++ )
- {
- const struct feat_node *feat = info->features[i];
- /*
- * There are four judgements:
- * 1. Input 'feat_type' is valid so we have to get feature according to
- * it. If current feature type (i) does not match 'feat_type', we
- * need skip it, so continue to check next feature.
- * 2. Input 'feat_type' is 'PSR_SOCKET_MAX_FEAT' which means we should
- * handle all features in this case. So, go to next loop.
- * 3. Do not need restore the COS value back to default if cos_num is 1,
- * e.g. L3 CAT. Because next value setting will overwrite it.
- * 4. 'feat' we got is NULL, continue.
- */
- if ( ( feat_type != PSR_SOCKET_MAX_FEAT && feat_type != i ) ||
- !feat || feat->props->cos_num == 1 )
- continue;
-
- for ( j = 0; j < feat->props->cos_num; j++ )
- {
- feat->props->get_val(feat, 0, feat->props->type[j], &default_val);
- write_psr_msr(socket, cos, default_val,
- feat->props->type[j], i);
- }
- }
-}
-
/* The whole set process is protected by domctl_lock. */
int psr_set_val(struct domain *d, unsigned int socket,
uint32_t val, enum cbm_type type)
@@ -1191,6 +1179,7 @@ int psr_set_val(struct domain *d, unsigned int socket,
struct psr_socket_info *info = get_socket_info(socket);
unsigned int array_len;
enum psr_feat_type feat_type;
+ unsigned long flag;
if ( IS_ERR(info) )
return PTR_ERR(info);
@@ -1286,22 +1275,6 @@ int psr_set_val(struct domain *d, unsigned int socket,
ASSERT(!cos || ref[cos]);
ASSERT(!old_cos || ref[old_cos]);
ref[old_cos]--;
-
- /*
- * Step 6:
- * For features, e.g. CDP, which cos_num is more than 1, we have to
- * restore the old_cos value back to default when ref[old_cos] is 0.
- * Otherwise, user will see wrong values when this COS ID is reused. E.g.
- * user wants to set DATA to 0x3ff for a new domain. He hopes to see the
- * DATA is set to 0x3ff and CODE should be the default value, 0x7ff. But
- * if the COS ID picked for this action is the one that has been used by
- * other domain and the CODE has been set to 0x1ff. Then, user will see
- * DATA: 0x3ff, CODE: 0x1ff. So, we have to restore COS values for features
- * using multiple COSs.
- */
- if ( old_cos && !ref[old_cos] )
- restore_default_val(socket, old_cos, feat_type);
-
spin_unlock(&info->ref_lock);
/*
@@ -1310,7 +1283,10 @@ int psr_set_val(struct domain *d, unsigned int socket,
* which COS the domain is using on the socket. One domain can only use
* one COS ID at same time on each socket.
*/
+ spin_lock_irqsave(&info->dom_ids_lock, flag);
d->arch.psr_cos_ids[socket] = cos;
+ test_and_set_bit(d->domain_id, info->dom_ids);
+ spin_unlock_irqrestore(&info->dom_ids_lock, flag);
xfree(val_array);
return ret;
@@ -1336,6 +1312,7 @@ static void psr_free_cos(struct domain *d)
for ( socket = 0; socket < nr_sockets; socket++ )
{
struct psr_socket_info *info;
+ unsigned long flag;
/* cos 0 is default one which does not need be handled. */
cos = d->arch.psr_cos_ids[socket];
@@ -1346,14 +1323,11 @@ static void psr_free_cos(struct domain *d)
spin_lock(&info->ref_lock);
ASSERT(!cos || info->cos_ref[cos]);
info->cos_ref[cos]--;
- /*
- * The 'cos_ref[cos]' of 'd' is 0 now so we need restore corresponding
- * COS registers to default value. Because this case happens when a
- * domain is destroied, we need restore all features.
- */
- if ( !info->cos_ref[cos] )
- restore_default_val(socket, cos, PSR_SOCKET_MAX_FEAT);
spin_unlock(&info->ref_lock);
+
+ spin_lock_irqsave(&info->dom_ids_lock, flag);
+ clear_bit(d->domain_id, info->dom_ids);
+ spin_unlock_irqrestore(&info->dom_ids_lock, flag);
}
xfree(d->arch.psr_cos_ids);
@@ -1453,6 +1427,7 @@ static void psr_cpu_init(void)
goto assoc_init;
spin_lock_init(&info->ref_lock);
+ spin_lock_init(&info->dom_ids_lock);
cpuid_count_leaf(PSR_CPUID_LEVEL_CAT, 0, ®s);
if ( regs.b & PSR_RESOURCE_TYPE_L3 )
--
1.9.1
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xen.org
https://lists.xen.org/xen-devel
next prev parent reply other threads:[~2017-04-20 5:46 UTC|newest]
Thread overview: 114+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-04-01 13:53 [PATCH v10 00/25] Enable L2 Cache Allocation Technology & Refactor psr.c Yi Sun
2017-04-01 13:53 ` [PATCH v10 01/25] docs: create Cache Allocation Technology (CAT) and Code and Data Prioritization (CDP) feature document Yi Sun
2017-04-01 13:53 ` [PATCH v10 02/25] x86: refactor psr: remove L3 CAT/CDP codes Yi Sun
2017-04-01 13:53 ` [PATCH v10 03/25] x86: refactor psr: implement main data structures Yi Sun
2017-04-03 15:50 ` Jan Beulich
2017-04-05 3:12 ` Yi Sun
2017-04-05 8:20 ` Jan Beulich
2017-04-05 8:45 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 04/25] x86: move cpuid_count_leaf from cpuid.c to processor.h Yi Sun
2017-04-01 13:53 ` [PATCH v10 05/25] x86: refactor psr: L3 CAT: implement CPU init and free flow Yi Sun
2017-04-05 15:10 ` Jan Beulich
2017-04-06 5:49 ` Yi Sun
2017-04-06 8:32 ` Jan Beulich
2017-04-06 9:22 ` Yi Sun
2017-04-06 9:34 ` Jan Beulich
2017-04-06 10:02 ` Yi Sun
2017-04-06 14:02 ` Jan Beulich
2017-04-07 5:17 ` Yi Sun
2017-04-07 8:48 ` Jan Beulich
2017-04-07 9:08 ` Yi Sun
2017-04-07 9:46 ` Jan Beulich
2017-04-10 3:27 ` Yi Sun
2017-04-10 12:43 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 06/25] x86: refactor psr: L3 CAT: implement Domain init/free and schedule flows Yi Sun
2017-04-05 15:23 ` Jan Beulich
2017-04-06 6:01 ` Yi Sun
2017-04-06 8:34 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 07/25] x86: refactor psr: L3 CAT: implement get hw info flow Yi Sun
2017-04-05 15:37 ` Jan Beulich
2017-04-06 6:05 ` Yi Sun
2017-04-06 8:36 ` Jan Beulich
2017-04-06 11:16 ` Yi Sun
2017-04-06 14:04 ` Jan Beulich
2017-04-07 5:39 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 08/25] x86: refactor psr: L3 CAT: implement get value flow Yi Sun
2017-04-05 15:51 ` Jan Beulich
2017-04-06 6:10 ` Yi Sun
2017-04-06 8:40 ` Jan Beulich
2017-04-06 11:13 ` Yi Sun
2017-04-06 14:08 ` Jan Beulich
2017-04-07 5:40 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 09/25] x86: refactor psr: L3 CAT: set value: implement framework Yi Sun
2017-04-11 15:01 ` Jan Beulich
2017-04-12 5:53 ` Yi Sun
2017-04-12 9:09 ` Jan Beulich
2017-04-12 12:23 ` Yi Sun
2017-04-12 12:42 ` Jan Beulich
2017-04-13 8:11 ` Yi Sun
2017-04-13 9:41 ` Jan Beulich
2017-04-13 10:49 ` Yi Sun
2017-04-13 10:58 ` Jan Beulich
2017-04-13 11:11 ` Yi Sun
2017-04-13 11:26 ` Yi Sun
2017-04-13 11:31 ` Jan Beulich
2017-04-13 11:44 ` Yi Sun
2017-04-13 11:50 ` Jan Beulich
2017-04-18 10:55 ` Yi Sun
2017-04-18 11:46 ` Jan Beulich
2017-04-19 8:22 ` Yi Sun
2017-04-19 9:00 ` Jan Beulich
2017-04-20 2:14 ` Yi Sun
2017-04-20 9:43 ` Jan Beulich
2017-04-20 13:02 ` Lars Kurth
2017-04-20 13:21 ` Jan Beulich
2017-04-20 16:52 ` Lars Kurth
2017-04-21 6:11 ` Jan Beulich
2017-04-21 1:13 ` Konrad Rzeszutek Wilk
2017-04-21 6:18 ` Jan Beulich
2017-04-24 6:40 ` Yi Sun
2017-04-24 6:55 ` Jan Beulich
2017-04-25 7:15 ` Yi Sun
2017-04-25 8:24 ` Jan Beulich
2017-04-25 8:40 ` Yi Sun
2017-04-20 5:38 ` Yi Sun [this message]
2017-04-26 10:04 ` [PATCH] dom_ids array implementation Jan Beulich
2017-04-27 2:38 ` Yi Sun
2017-04-27 6:48 ` Jan Beulich
2017-04-27 9:30 ` Yi Sun
2017-04-27 9:39 ` Jan Beulich
2017-04-27 12:03 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 10/25] x86: refactor psr: L3 CAT: set value: assemble features value array Yi Sun
2017-04-11 15:11 ` Jan Beulich
2017-04-12 5:55 ` Yi Sun
2017-04-12 9:13 ` Jan Beulich
2017-04-12 12:26 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 11/25] x86: refactor psr: L3 CAT: set value: implement cos finding flow Yi Sun
2017-04-11 15:17 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 12/25] x86: refactor psr: L3 CAT: set value: implement cos id picking flow Yi Sun
2017-04-11 15:20 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 13/25] x86: refactor psr: L3 CAT: set value: implement write msr flow Yi Sun
2017-04-11 15:25 ` Jan Beulich
2017-04-12 6:04 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 14/25] x86: refactor psr: CDP: implement CPU init and free flow Yi Sun
2017-04-01 13:53 ` [PATCH v10 15/25] x86: refactor psr: CDP: implement get hw info flow Yi Sun
2017-04-01 13:53 ` [PATCH v10 16/25] x86: refactor psr: CDP: implement get value flow Yi Sun
2017-04-11 15:39 ` Jan Beulich
2017-04-12 6:05 ` Yi Sun
2017-04-12 9:14 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 17/25] x86: refactor psr: CDP: implement set value callback functions Yi Sun
2017-04-11 16:03 ` Jan Beulich
2017-04-12 6:14 ` Yi Sun
2017-04-01 13:53 ` [PATCH v10 18/25] x86: L2 CAT: implement CPU init and free flow Yi Sun
2017-04-12 15:18 ` Jan Beulich
2017-04-13 8:12 ` Yi Sun
2017-04-13 8:16 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 19/25] x86: L2 CAT: implement get hw info flow Yi Sun
2017-04-01 13:53 ` [PATCH v10 20/25] x86: L2 CAT: implement get value flow Yi Sun
2017-04-01 13:53 ` [PATCH v10 21/25] x86: L2 CAT: implement set " Yi Sun
2017-04-12 15:23 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 22/25] tools: L2 CAT: support get HW info for L2 CAT Yi Sun
2017-04-12 15:24 ` Jan Beulich
2017-04-01 13:53 ` [PATCH v10 23/25] tools: L2 CAT: support show cbm " Yi Sun
2017-04-01 13:53 ` [PATCH v10 24/25] tools: L2 CAT: support set " Yi Sun
2017-04-01 13:53 ` [PATCH v10 25/25] docs: add L2 CAT description in docs Yi Sun
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1492666704-6626-1-git-send-email-yi.y.sun@linux.intel.com \
--to=yi.y.sun@linux.intel.com \
--cc=jbeulich@suse.com \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).