|
@@ -52,6 +52,17 @@ static inline int32_t div_fp(int32_t x, int32_t y)
|
|
|
return div_s64((int64_t)x << FRAC_BITS, y);
|
|
|
}
|
|
|
|
|
|
+static inline int ceiling_fp(int32_t x)
|
|
|
+{
|
|
|
+ int mask, ret;
|
|
|
+
|
|
|
+ ret = fp_toint(x);
|
|
|
+ mask = (1 << FRAC_BITS) - 1;
|
|
|
+ if (x & mask)
|
|
|
+ ret += 1;
|
|
|
+ return ret;
|
|
|
+}
|
|
|
+
|
|
|
struct sample {
|
|
|
int32_t core_pct_busy;
|
|
|
u64 aperf;
|
|
@@ -425,7 +436,7 @@ static void byt_set_pstate(struct cpudata *cpudata, int pstate)
|
|
|
cpudata->vid.ratio);
|
|
|
|
|
|
vid_fp = clamp_t(int32_t, vid_fp, cpudata->vid.min, cpudata->vid.max);
|
|
|
- vid = fp_toint(vid_fp);
|
|
|
+ vid = ceiling_fp(vid_fp);
|
|
|
|
|
|
if (pstate > cpudata->pstate.max_pstate)
|
|
|
vid = cpudata->vid.turbo;
|