Hi Kevin,

On 27/6/2018 6:33 PM, Kevin Traynor wrote:
On 06/26/2018 12:40 PM, Radu Nicolau wrote:
From: Liang Ma <liang.j...@intel.com>

1. Abstract

--snip--

2.2 There are two phases to establish the power management system:

        a.Initialization/Training phase. There is no traffic pass-through,
          the system will test average empty poll numbers  with
          LOW/MED/HIGH  power state. Those average empty poll numbers
          will be the baseline
          for the normal phase. The system will collect all core's counter
          every 100ms. The Training phase will take 5 seconds.

This is requiring an application to sit for 5 secs in order to train and
align poll numbers with states? That doesn't seem realistic to me.


Thanks for the discussion at DPDK Userspace conference. Since we got back, Liang and
I have discussed the feedback we received, and we have a proposal.

We can split out the training phase into a separate run of the application
which does the training, spits out the threshold numbers, and then
the actual runs will start instantly once the threshold parameters are
provided on the command line, or falls back to hard-coded defaults if
no command line parameters are given.

So there are three ways of running the app
  1. Run without any threshold parameters, in which case the algorithm
      runs with default numbers calculated based on the min and max available frequency.
  2. Run with --train option, which requires no traffic on the NICS, and
      runs the training algorithm, prints out the thresholds for the host CPU, and exits.   3. Take the output of the train phase, and provide the thresholds on the command
      line, and the app runs with the best fit to the running CPU.

That would eliminate the training period at startup, unless the user wanted to fine-tune
for a particular host CPU.

Would that be an adequate solution to the training period concerns?

Regards,
Dave.










Reply via email to