[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v3 13/14 RESEND] xenpm: Add set-cpufreq-hwp subcommand
On Mon, May 8, 2023 at 7:56 AM Jan Beulich <jbeulich@xxxxxxxx> wrote: > > On 01.05.2023 21:30, Jason Andryuk wrote: > > @@ -67,6 +68,27 @@ void show_help(void) > > " set-max-cstate <num>|'unlimited' > > [<num2>|'unlimited']\n" > > " set the C-State > > limitation (<num> >= 0) and\n" > > " optionally the > > C-sub-state limitation (<num2> >= 0)\n" > > + " set-cpufreq-hwp [cpuid] > > [balance|performance|powersave] <param:val>*\n" > > + " set Hardware P-State > > (HWP) parameters\n" > > + " optionally a preset of > > one of\n" > > + " > > balance|performance|powersave\n" > > + " an optional list of > > param:val arguments\n" > > + " minimum:N lowest ... > > highest\n" > > + " maximum:N lowest ... > > highest\n" > > + " desired:N lowest ... > > highest\n" > > Personally I consider these three uses of "lowest ... highest" confusing: > It's not clear at all whether they're part of the option or merely mean > to express the allowable range for N (which I think they do). Perhaps ... > > > + " Set explicit > > performance target.\n" > > + " non-zero disables > > auto-HWP mode.\n" > > + " energy-perf:0-255 (or > > 0-15)\n" > > ..., also taking this into account: > > " energy-perf:N (0-255 or > 0-15)\n" > > and then use parentheses as well for the earlier value range explanations > (and again below)? lowest and highest were supposed to reference the values from `xenpm get-cpufreq-para`. You removed some later lines that state "get-cpufreq-para returns lowest/highest". However, they aren't enforced limits. You can program from the range 0-255 and the hardware is supposed to clip internally, so your idea of "energy-perf:N (0-255)" seems good to me. > Also up from here you suddenly start having full stops on the lines. I > guess you also want to be consistent in your use of capital letters at > the start of lines (I didn't go check how consistent pre-existing code > is in this regard). Looks like the existing code is consistently non-capital letters, but the full stops are inconsistent. I'll go with non-capital and full stop for this addition. > > @@ -1299,6 +1321,213 @@ void disable_turbo_mode(int argc, char *argv[]) > > errno, strerror(errno)); > > } > > > > +/* > > + * Parse activity_window:NNN{us,ms,s} and validate range. > > + * > > + * Activity window is a 7bit mantissa (0-127) with a 3bit exponent (0-7) > > base > > + * 10 in microseconds. So the range is 1 microsecond to 1270 seconds. A > > value > > + * of 0 lets the hardware autonomously select the window. > > + * > > + * Return 0 on success > > + * -1 on error > > + */ > > +static int parse_activity_window(xc_set_hwp_para_t *set_hwp, unsigned long > > u, > > + const char *suffix) > > +{ > > + unsigned int exponent = 0; > > + unsigned int multiplier = 1; > > + > > + if ( suffix && suffix[0] ) > > + { > > + if ( strcasecmp(suffix, "s") == 0 ) > > + { > > + multiplier = 1000 * 1000; > > + exponent = 6; > > + } > > + else if ( strcasecmp(suffix, "ms") == 0 ) > > + { > > + multiplier = 1000; > > + exponent = 3; > > + } > > + else if ( strcasecmp(suffix, "us") == 0 ) > > + { > > + multiplier = 1; > > + exponent = 0; > > + } > > Considering the initializers, this "else if" body isn't really needed, > and ... > > > + else > > ... instead this could become "else if ( strcmp() != 0 )". > > Note also that I use strcmp() there - none of s, ms, or us are commonly > expressed by capital letters. That sounds fine. > (I wonder though whether μs shouldn't also > be recognized.) While that makes sense, I do not plan to change it. I don't know the proper way to deal with unicode from C. (I suppose a memcmp with the UTF-8 encoding would be possible, but I don't know if there are corner cases I'm overlooking.) > > + { > > + fprintf(stderr, "invalid activity window units: \"%s\"\n", > > suffix); > > + > > + return -1; > > + } > > + } > > + > > + /* u * multipler > 1270 * 1000 * 1000 transformed to avoid overflow. */ > > + if ( u > 1270 * 1000 * 1000 / multiplier ) > > + { > > + fprintf(stderr, "activity window is too large\n"); > > + > > + return -1; > > + } > > + > > + /* looking for 7 bits of mantissa and 3 bits of exponent */ > > + while ( u > 127 ) > > + { > > + u += 5; /* Round up to mitigate truncation rounding down > > + e.g. 128 -> 120 vs 128 -> 130. */ > > + u /= 10; > > + exponent += 1; > > + } > > + > > + set_hwp->activity_window = (exponent & HWP_ACT_WINDOW_EXPONENT_MASK) << > > + HWP_ACT_WINDOW_EXPONENT_SHIFT | > > The shift wants parenthesizing against the | and the shift amount wants > indenting slightly less. (Really this would want to be MASK_INSR().) I'll use MASK_INSR. > > + (u & HWP_ACT_WINDOW_MANTISSA_MASK); > > + set_hwp->set_params |= XEN_SYSCTL_HWP_SET_ACT_WINDOW; > > + > > + return 0; > > +} > > + > > +static int parse_hwp_opts(xc_set_hwp_para_t *set_hwp, int *cpuid, > > + int argc, char *argv[]) > > +{ > > + int i = 0; > > + > > + if ( argc < 1 ) { > > + fprintf(stderr, "Missing arguments\n"); > > + return -1; > > + } > > + > > + if ( parse_cpuid_non_fatal(argv[i], cpuid) == 0 ) > > + { > > + i++; > > + } > > I don't think you need the earlier patch and the separate helper: > Whether a CPU number is present can be told by checking > isdigit(argv[i][0]). > Hmm, yes, there is "all", but your help text doesn't mention it and > since you're handling a variable number of arguments anyway, there's > not need for anyone to say "all" - they can simply omit the optional > argument. Most xenpm commands take "all" or a numeric cpuid, so I intended to be consistent with them. That was the whole point of parse_cpuid_non_fatal() - to reuse the existing parsing code for consistency. I didn't read the other help text carefully enough to see that the numeric cpuid and "all" handling was repeated. For consistency, I would retain parse_cpuid_non_fatal() and expand the help text. If you don't want that, I'll switch to isdigit(argv[i][0]) and have the omission of a digit indicate all CPUs as you suggest. Just let me know what you want. > Also (nit) note how you're mixing brace placement throughout this > function. Will fix. Regards, Jason
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |