[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

RE: [Xen-devel] [PATCH] x86: add hypercall to query current underlying pCPU's frequency



Guanqun will make out a simple dom0 utility to the list
by utilizing sysctl this week. maybe call it 'lspm'.

Thanks,
Kevin

>From: Keir Fraser
>Sent: 2008年9月20日 16:34
>
>I still consider this not a useful or informative operation.
>
> -- Keir
>
>On 19/9/08 14:10, "Jan Beulich" <jbeulich@xxxxxxxxxx> wrote:
>
>> Signed-off-by: Jan Beulich <jbeulich@xxxxxxxxxx>
>>
>> Index: 2008-09-19/xen/arch/x86/platform_hypercall.c
>> ===================================================================
>> --- 2008-09-19.orig/xen/arch/x86/platform_hypercall.c 2008-09-19
>> 14:12:02.000000000 +0200
>> +++ 2008-09-19/xen/arch/x86/platform_hypercall.c 2008-09-19
>14:12:56.000000000
>> +0200
>> @@ -21,7 +21,7 @@
>>  #include <xen/acpi.h>
>>  #include <asm/current.h>
>>  #include <public/platform.h>
>> -#include <acpi/cpufreq/processor_perf.h>
>> +#include <acpi/cpufreq/cpufreq.h>
>>  #include <asm/edd.h>
>>  #include <asm/mtrr.h>
>>  #include "cpu/mtrr/mtrr.h"
>> @@ -55,6 +55,7 @@ static long cpu_frequency_change_helper(
>>  ret_t do_platform_op(XEN_GUEST_HANDLE(xen_platform_op_t) u_xenpf_op)
>>  {
>>      ret_t ret = 0;
>> +    struct vcpu *v;
>>      struct xen_platform_op curop, *op = &curop;
>>
>>      if ( !IS_PRIV(current->domain) )
>> @@ -312,7 +313,6 @@ ret_t do_platform_op(XEN_GUEST_HANDLE(xe
>>      {
>>          uint32_t cpu;
>>          uint64_t idletime, now = NOW();
>> -        struct vcpu *v;
>>          struct xenctl_cpumap ctlmap;
>>          cpumask_t cpumap;
>>          XEN_GUEST_HANDLE(uint8) cpumap_bitmap;
>> @@ -482,6 +482,20 @@ ret_t do_platform_op(XEN_GUEST_HANDLE(xe
>>              break;
>>          }
>>          break;
>> +
>> +    case XENPF_get_cpu_freq:
>> +        if ( op->u.get_cpu_freq.vcpu >= MAX_VIRT_CPUS ||
>> +             !(v = current->domain->vcpu[op->u.get_cpu_freq.vcpu]) )
>> +        {
>> +            ret = -EINVAL;
>> +            break;
>> +        }
>> +
>> +        op->u.get_cpu_freq.freq = cpufreq_cpu_policy[v->processor] ?
>> +            cpufreq_cpu_policy[v->processor]->cur : 0;
>> +        if ( copy_field_to_guest(u_xenpf_op, op,
>u.get_cpu_freq.freq) )
>> +            ret = -EFAULT;
>> +        break;
>>
>>      default:
>>          ret = -ENOSYS;
>> Index: 2008-09-19/xen/arch/x86/x86_64/platform_hypercall.c
>> ===================================================================
>> --- 2008-09-19.orig/xen/arch/x86/x86_64/platform_hypercall.c
>2008-09-19
>> 14:12:02.000000000 +0200
>> +++ 2008-09-19/xen/arch/x86/x86_64/platform_hypercall.c 2008-09-19
>> 13:59:35.000000000 +0200
>> @@ -21,6 +21,8 @@ DEFINE_XEN_GUEST_HANDLE(compat_platform_
>>  #define xen_processor_power_t   compat_processor_power_t
>>  #define set_cx_pminfo           compat_set_cx_pminfo
>>
>> +#define xenpf_get_cpu_freq      compat_pf_get_cpu_freq
>> +
>>  #define xenpf_enter_acpi_sleep compat_pf_enter_acpi_sleep
>>
>>  #define COMPAT
>> Index: 2008-09-19/xen/include/public/platform.h
>> ===================================================================
>> --- 2008-09-19.orig/xen/include/public/platform.h 2008-09-19
>> 14:12:02.000000000 +0200
>> +++ 2008-09-19/xen/include/public/platform.h 2008-09-19
>13:59:35.000000000
>> +0200
>> @@ -312,6 +312,16 @@ struct xenpf_set_processor_pminfo {
>>  typedef struct xenpf_set_processor_pminfo
>xenpf_set_processor_pminfo_t;
>>  DEFINE_XEN_GUEST_HANDLE(xenpf_set_processor_pminfo_t);
>>
>> +#define XENPF_get_cpu_freq        55
>> +struct xenpf_get_cpu_freq {
>> +    /* IN variables */
>> +    uint32_t vcpu;
>> +    /* OUT variables */
>> +    uint32_t freq; /* in kHz */
>> +};
>> +typedef struct xenpf_get_cpu_freq xenpf_get_cpu_freq_t;
>> +DEFINE_XEN_GUEST_HANDLE(xenpf_get_cpu_freq_t);
>> +
>>  struct xen_platform_op {
>>      uint32_t cmd;
>>      uint32_t interface_version; /* XENPF_INTERFACE_VERSION */
>> @@ -327,6 +337,7 @@ struct xen_platform_op {
>>          struct xenpf_change_freq       change_freq;
>>          struct xenpf_getidletime       getidletime;
>>          struct xenpf_set_processor_pminfo set_pminfo;
>> +        struct xenpf_get_cpu_freq      get_cpu_freq;
>>          uint8_t                        pad[128];
>>      } u;
>>  };
>>
>>
>>
>>
>> _______________________________________________
>> Xen-devel mailing list
>> Xen-devel@xxxxxxxxxxxxxxxxxxx
>> http://lists.xensource.com/xen-devel
>
>
>
>_______________________________________________
>Xen-devel mailing list
>Xen-devel@xxxxxxxxxxxxxxxxxxx
>http://lists.xensource.com/xen-devel
>
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.