[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v5 12/15] xen: Add SET_CPUFREQ_HWP xen_sysctl_pm_op
On 06.07.2023 20:54, Jason Andryuk wrote: > @@ -531,6 +535,103 @@ int get_hwp_para(unsigned int cpu, > return 0; > } > > +int set_hwp_para(struct cpufreq_policy *policy, > + struct xen_set_cppc_para *set_cppc) > +{ > + unsigned int cpu = policy->cpu; > + struct hwp_drv_data *data = per_cpu(hwp_drv_data, cpu); > + bool cleared_act_window = false; > + > + if ( data == NULL ) > + return -EINVAL; I don't think EINVAL is appropriate here. EOPNOTSUPP might be, or ENOENT, or EIO, or perhaps a few others. > + /* Validate all parameters - Disallow reserved bits. */ > + if ( set_cppc->minimum > 255 || > + set_cppc->maximum > 255 || > + set_cppc->desired > 255 || > + set_cppc->energy_perf > 255 || > + set_cppc->set_params & ~XEN_SYSCTL_CPPC_SET_PARAM_MASK || > + set_cppc->activity_window & ~XEN_SYSCTL_CPPC_ACT_WINDOW_MASK ) Nit: Parentheses again please around the operands of &. > + return -EINVAL; > + > + /* Only allow values if params bit is set. */ > + if ( (!(set_cppc->set_params & XEN_SYSCTL_CPPC_SET_DESIRED) && > + set_cppc->desired) || > + (!(set_cppc->set_params & XEN_SYSCTL_CPPC_SET_MINIMUM) && > + set_cppc->minimum) || > + (!(set_cppc->set_params & XEN_SYSCTL_CPPC_SET_MAXIMUM) && > + set_cppc->maximum) || > + (!(set_cppc->set_params & XEN_SYSCTL_CPPC_SET_ENERGY_PERF) && > + set_cppc->energy_perf) || > + (!(set_cppc->set_params & XEN_SYSCTL_CPPC_SET_ACT_WINDOW) && > + set_cppc->activity_window) ) > + return -EINVAL; > + > + /* Clear out activity window if lacking HW supported. */ > + if ( (set_cppc->set_params & XEN_SYSCTL_CPPC_SET_ACT_WINDOW) && > + !feature_hwp_activity_window ) { > + set_cppc->set_params &= ~XEN_SYSCTL_CPPC_SET_ACT_WINDOW; > + cleared_act_window = true; > + } > + > + /* Return if there is nothing to do. */ > + if ( set_cppc->set_params == 0 ) > + return cleared_act_window ? 0 : -EINVAL; Is it really necessary to return an error when there's nothing to do? We have various hypercalls which can degenerate to no-ops under certain conditions, and which simply return success then. > --- a/xen/drivers/acpi/pmstat.c > +++ b/xen/drivers/acpi/pmstat.c > @@ -400,6 +400,19 @@ static int set_cpufreq_para(struct xen_sysctl_pm_op *op) > return ret; > } > > +static int set_cpufreq_cppc(struct xen_sysctl_pm_op *op) > +{ > + struct cpufreq_policy *policy = per_cpu(cpufreq_cpu_policy, op->cpuid); > + > + if ( !policy || !policy->governor ) > + return -EINVAL; > + > + if ( !hwp_active() ) > + return -EINVAL; In both cases I again wonder in how far EINVAL is really appropriate. > --- a/xen/include/public/sysctl.h > +++ b/xen/include/public/sysctl.h > @@ -351,6 +351,68 @@ struct xen_cppc_para { > uint32_t activity_window; > }; > > +/* > + * Set CPPC values. > + * > + * Configure the parameters for CPPC. Set bits in set_params control which > + * values are applied. If a bit is not set in set_params, the field must be > + * zero. > + * > + * For HWP specifically, values must be limited to 0-255 or within > + * XEN_SYSCTL_CPPC_ACT_WINDOW_MASK for activity window. Set bits outside the > + * range will be returned as -EINVAL. > + * > + * Activity Window may not be supported by the hardware. In that case, the > + * returned set_params will clear XEN_SYSCTL_CPPC_SET_ACT_WINDOW to indicate > + * that it was not applied - though the rest of the values will be applied. > + * > + * There are a set of presets along with individual fields. Presets are > + * applied first, and then individual fields. This allows customizing > + * a preset without having to specify every value. > + * > + * The preset options values are as follows: > + * > + * preset | minimum | maxium | energy_perf > + * ------------+---------+---------+---------------- > + * powersave | lowest | lowest | powersave (255) > + * ------------+---------+---------+---------------- > + * balance | lowest | highest | balance (128) > + * ------------+---------+---------+---------------- > + * performance | highest | highest | performance (0) > + * > + * desired and activity_window are set to 0, hardware selected. > + */ > +struct xen_set_cppc_para { > +#define XEN_SYSCTL_CPPC_SET_MINIMUM (1U << 0) > +#define XEN_SYSCTL_CPPC_SET_MAXIMUM (1U << 1) > +#define XEN_SYSCTL_CPPC_SET_DESIRED (1U << 2) > +#define XEN_SYSCTL_CPPC_SET_ENERGY_PERF (1U << 3) > +#define XEN_SYSCTL_CPPC_SET_ACT_WINDOW (1U << 4) > +#define XEN_SYSCTL_CPPC_SET_PRESET_MASK 0xf0000000 > +#define XEN_SYSCTL_CPPC_SET_PRESET_NONE 0x00000000 > +#define XEN_SYSCTL_CPPC_SET_PRESET_BALANCE 0x10000000 > +#define XEN_SYSCTL_CPPC_SET_PRESET_POWERSAVE 0x20000000 > +#define XEN_SYSCTL_CPPC_SET_PRESET_PERFORMANCE 0x30000000 As corrections for the respective Misra rule are in the process of being merged, please add U suffixes here (at the very least on the _MASK). Jan
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |