|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen staging] tools/libxc: Rework xc_cpuid_set() to use {get, set}_cpu_policy()
commit e5b02b085e61c43a6b8346b7bb9e0c0ee1f30ef4
Author: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
AuthorDate: Tue Sep 10 17:08:13 2019 +0100
Commit: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
CommitDate: Thu Sep 26 13:40:18 2019 +0100
tools/libxc: Rework xc_cpuid_set() to use {get,set}_cpu_policy()
The purpose of this change is to stop using xc_cpuid_do_domctl(), and to
stop
basing decisions on a local CPUID instruction. This is not an appropriate
way
to construct policy information for other domains.
Obtain the host and domain-max policies from Xen, and mix the results as
before. Provide rather more error logging than before.
No semantics changes to xc_cpuid_set(). There are conceptual problems with
how the function works, which will be addressed in future toolstack work.
Signed-off-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx>
Release-acked-by: Juergen Gross <jgross@xxxxxxxx>
---
tools/libxc/xc_cpuid_x86.c | 95 ++++++++++++++++++++++++++++++++++++++++------
1 file changed, 84 insertions(+), 11 deletions(-)
diff --git a/tools/libxc/xc_cpuid_x86.c b/tools/libxc/xc_cpuid_x86.c
index 226edc0c34..43bda10d96 100644
--- a/tools/libxc/xc_cpuid_x86.c
+++ b/tools/libxc/xc_cpuid_x86.c
@@ -922,20 +922,80 @@ int xc_cpuid_set(
const char **config, char **config_transformed)
{
int rc;
- unsigned int i, j, regs[4], polregs[4];
- struct cpuid_domain_info info = {};
+ unsigned int i, j, regs[4] = {}, polregs[4] = {};
+ xc_dominfo_t di;
+ xen_cpuid_leaf_t *leaves = NULL;
+ unsigned int nr_leaves, policy_leaves, nr_msrs;
+ uint32_t err_leaf = -1, err_subleaf = -1, err_msr = -1;
for ( i = 0; i < 4; ++i )
config_transformed[i] = NULL;
- rc = get_cpuid_domain_info(xch, domid, &info, NULL, 0);
+ if ( xc_domain_getinfo(xch, domid, 1, &di) != 1 ||
+ di.domid != domid )
+ {
+ ERROR("Failed to obtain d%d info", domid);
+ rc = -ESRCH;
+ goto fail;
+ }
+
+ rc = xc_get_cpu_policy_size(xch, &nr_leaves, &nr_msrs);
if ( rc )
- goto out;
+ {
+ PERROR("Failed to obtain policy info size");
+ rc = -errno;
+ goto fail;
+ }
- cpuid(input, regs);
+ rc = -ENOMEM;
+ if ( (leaves = calloc(nr_leaves, sizeof(*leaves))) == NULL )
+ {
+ ERROR("Unable to allocate memory for %u CPUID leaves", nr_leaves);
+ goto fail;
+ }
- memcpy(polregs, regs, sizeof(regs));
- xc_cpuid_policy(&info, input, polregs);
+ /* Get the domain's max policy. */
+ nr_msrs = 0;
+ policy_leaves = nr_leaves;
+ rc = xc_get_system_cpu_policy(xch, di.hvm ? XEN_SYSCTL_cpu_policy_hvm_max
+ : XEN_SYSCTL_cpu_policy_pv_max,
+ &policy_leaves, leaves, &nr_msrs, NULL);
+ if ( rc )
+ {
+ PERROR("Failed to obtain %s max policy", di.hvm ? "hvm" : "pv");
+ rc = -errno;
+ goto fail;
+ }
+ for ( i = 0; i < policy_leaves; ++i )
+ if ( leaves[i].leaf == input[0] && leaves[i].subleaf == input[1] )
+ {
+ polregs[0] = leaves[i].a;
+ polregs[1] = leaves[i].b;
+ polregs[2] = leaves[i].c;
+ polregs[3] = leaves[i].d;
+ break;
+ }
+
+ /* Get the host policy. */
+ nr_msrs = 0;
+ policy_leaves = nr_leaves;
+ rc = xc_get_system_cpu_policy(xch, XEN_SYSCTL_cpu_policy_host,
+ &policy_leaves, leaves, &nr_msrs, NULL);
+ if ( rc )
+ {
+ PERROR("Failed to obtain host policy");
+ rc = -errno;
+ goto fail;
+ }
+ for ( i = 0; i < policy_leaves; ++i )
+ if ( leaves[i].leaf == input[0] && leaves[i].subleaf == input[1] )
+ {
+ regs[0] = leaves[i].a;
+ regs[1] = leaves[i].b;
+ regs[2] = leaves[i].c;
+ regs[3] = leaves[i].d;
+ break;
+ }
for ( i = 0; i < 4; i++ )
{
@@ -986,9 +1046,21 @@ int xc_cpuid_set(
}
}
- rc = xc_cpuid_do_domctl(xch, domid, input, regs);
- if ( rc == 0 )
- goto out;
+ /* Feed the transformed leaf back up to Xen. */
+ leaves[0] = (xen_cpuid_leaf_t){ input[0], input[1],
+ regs[0], regs[1], regs[2], regs[3] };
+ rc = xc_set_domain_cpu_policy(xch, domid, 1, leaves, 0, NULL,
+ &err_leaf, &err_subleaf, &err_msr);
+ if ( rc )
+ {
+ PERROR("Failed to set d%d's policy (err leaf %#x, subleaf %#x, msr
%#x)",
+ domid, err_leaf, err_subleaf, err_msr);
+ rc = -errno;
+ goto fail;
+ }
+
+ /* Success! */
+ goto out;
fail:
for ( i = 0; i < 4; i++ )
@@ -998,6 +1070,7 @@ int xc_cpuid_set(
}
out:
- free_cpuid_domain_info(&info);
+ free(leaves);
+
return rc;
}
--
generated by git-patchbot for /home/xen/git/xen.git#staging
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |