intel_pstate.c 25.3 KB
Newer Older
1
/*
2
 * intel_pstate.c: Native P state management for Intel processors
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
 *
 * (C) Copyright 2012 Intel Corporation
 * Author: Dirk Brandewie <dirk.j.brandewie@intel.com>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; version 2
 * of the License.
 */

#include <linux/kernel.h>
#include <linux/kernel_stat.h>
#include <linux/module.h>
#include <linux/ktime.h>
#include <linux/hrtimer.h>
#include <linux/tick.h>
#include <linux/slab.h>
#include <linux/sched.h>
#include <linux/list.h>
#include <linux/cpu.h>
#include <linux/cpufreq.h>
#include <linux/sysfs.h>
#include <linux/types.h>
#include <linux/fs.h>
#include <linux/debugfs.h>
28
#include <linux/acpi.h>
29 30 31 32 33 34
#include <trace/events/power.h>

#include <asm/div64.h>
#include <asm/msr.h>
#include <asm/cpu_device_id.h>

35 36 37
#define BYT_RATIOS		0x66a
#define BYT_VIDS		0x66b
#define BYT_TURBO_RATIOS	0x66c
38
#define BYT_TURBO_VIDS		0x66d
39

40
#define FRAC_BITS 8
41 42
#define int_tofp(X) ((int64_t)(X) << FRAC_BITS)
#define fp_toint(X) ((X) >> FRAC_BITS)
43

44 45 46 47 48 49 50 51

static inline int32_t mul_fp(int32_t x, int32_t y)
{
	return ((int64_t)x * (int64_t)y) >> FRAC_BITS;
}

static inline int32_t div_fp(int32_t x, int32_t y)
{
52
	return div_s64((int64_t)x << FRAC_BITS, y);
53 54
}

55 56 57 58 59 60 61 62 63 64 65
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;
}

66
struct sample {
67
	int32_t core_pct_busy;
68 69 70
	u64 aperf;
	u64 mperf;
	int freq;
71
	ktime_t time;
72 73 74 75 76 77
};

struct pstate_data {
	int	current_pstate;
	int	min_pstate;
	int	max_pstate;
78
	int	scaling;
79 80 81
	int	turbo_pstate;
};

82
struct vid_data {
83 84 85
	int min;
	int max;
	int turbo;
86 87 88
	int32_t ratio;
};

89 90 91 92 93 94 95
struct _pid {
	int setpoint;
	int32_t integral;
	int32_t p_gain;
	int32_t i_gain;
	int32_t d_gain;
	int deadband;
96
	int32_t last_err;
97 98 99 100 101 102 103 104
};

struct cpudata {
	int cpu;

	struct timer_list timer;

	struct pstate_data pstate;
105
	struct vid_data vid;
106 107
	struct _pid pid;

108
	ktime_t last_sample_time;
109 110
	u64	prev_aperf;
	u64	prev_mperf;
111
	struct sample sample;
112 113 114 115 116 117 118 119 120 121 122 123
};

static struct cpudata **all_cpu_data;
struct pstate_adjust_policy {
	int sample_rate_ms;
	int deadband;
	int setpoint;
	int p_gain_pct;
	int d_gain_pct;
	int i_gain_pct;
};

124 125 126 127
struct pstate_funcs {
	int (*get_max)(void);
	int (*get_min)(void);
	int (*get_turbo)(void);
128
	int (*get_scaling)(void);
129 130
	void (*set)(struct cpudata*, int pstate);
	void (*get_vid)(struct cpudata *);
131 132
};

133 134 135
struct cpu_defaults {
	struct pstate_adjust_policy pid_policy;
	struct pstate_funcs funcs;
136 137
};

138 139
static struct pstate_adjust_policy pid_params;
static struct pstate_funcs pstate_funcs;
D
Dirk Brandewie 已提交
140
static int hwp_active;
141

142 143
struct perf_limits {
	int no_turbo;
144
	int turbo_disabled;
145 146 147 148
	int max_perf_pct;
	int min_perf_pct;
	int32_t max_perf;
	int32_t min_perf;
149 150
	int max_policy_pct;
	int max_sysfs_pct;
151 152 153 154
};

static struct perf_limits limits = {
	.no_turbo = 0,
155
	.turbo_disabled = 0,
156 157 158 159
	.max_perf_pct = 100,
	.max_perf = int_tofp(1),
	.min_perf_pct = 0,
	.min_perf = 0,
160 161
	.max_policy_pct = 100,
	.max_sysfs_pct = 100,
162 163 164
};

static inline void pid_reset(struct _pid *pid, int setpoint, int busy,
165
			     int deadband, int integral) {
166 167 168
	pid->setpoint = setpoint;
	pid->deadband  = deadband;
	pid->integral  = int_tofp(integral);
169
	pid->last_err  = int_tofp(setpoint) - int_tofp(busy);
170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186
}

static inline void pid_p_gain_set(struct _pid *pid, int percent)
{
	pid->p_gain = div_fp(int_tofp(percent), int_tofp(100));
}

static inline void pid_i_gain_set(struct _pid *pid, int percent)
{
	pid->i_gain = div_fp(int_tofp(percent), int_tofp(100));
}

static inline void pid_d_gain_set(struct _pid *pid, int percent)
{
	pid->d_gain = div_fp(int_tofp(percent), int_tofp(100));
}

187
static signed int pid_calc(struct _pid *pid, int32_t busy)
188
{
189
	signed int result;
190 191 192
	int32_t pterm, dterm, fp_error;
	int32_t integral_limit;

193
	fp_error = int_tofp(pid->setpoint) - busy;
194

195
	if (abs(fp_error) <= int_tofp(pid->deadband))
196 197 198 199 200 201 202 203 204 205 206 207 208
		return 0;

	pterm = mul_fp(pid->p_gain, fp_error);

	pid->integral += fp_error;

	/* limit the integral term */
	integral_limit = int_tofp(30);
	if (pid->integral > integral_limit)
		pid->integral = integral_limit;
	if (pid->integral < -integral_limit)
		pid->integral = -integral_limit;

209 210
	dterm = mul_fp(pid->d_gain, fp_error - pid->last_err);
	pid->last_err = fp_error;
211 212

	result = pterm + mul_fp(pid->integral, pid->i_gain) + dterm;
213
	result = result + (1 << (FRAC_BITS-1));
214 215 216 217 218
	return (signed int)fp_toint(result);
}

static inline void intel_pstate_busy_pid_reset(struct cpudata *cpu)
{
219 220 221
	pid_p_gain_set(&cpu->pid, pid_params.p_gain_pct);
	pid_d_gain_set(&cpu->pid, pid_params.d_gain_pct);
	pid_i_gain_set(&cpu->pid, pid_params.i_gain_pct);
222

223
	pid_reset(&cpu->pid, pid_params.setpoint, 100, pid_params.deadband, 0);
224 225 226 227 228
}

static inline void intel_pstate_reset_all_pid(void)
{
	unsigned int cpu;
229

230 231 232 233 234 235
	for_each_online_cpu(cpu) {
		if (all_cpu_data[cpu])
			intel_pstate_busy_pid_reset(all_cpu_data[cpu]);
	}
}

236 237 238 239 240 241 242 243 244 245 246 247
static inline void update_turbo_state(void)
{
	u64 misc_en;
	struct cpudata *cpu;

	cpu = all_cpu_data[0];
	rdmsrl(MSR_IA32_MISC_ENABLE, misc_en);
	limits.turbo_disabled =
		(misc_en & MSR_IA32_MISC_ENABLE_TURBO_DISABLE ||
		 cpu->pstate.max_pstate == cpu->pstate.turbo_pstate);
}

D
Dirk Brandewie 已提交
248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275
#define PCT_TO_HWP(x) (x * 255 / 100)
static void intel_pstate_hwp_set(void)
{
	int min, max, cpu;
	u64 value, freq;

	get_online_cpus();

	for_each_online_cpu(cpu) {
		rdmsrl_on_cpu(cpu, MSR_HWP_REQUEST, &value);
		min = PCT_TO_HWP(limits.min_perf_pct);
		value &= ~HWP_MIN_PERF(~0L);
		value |= HWP_MIN_PERF(min);

		max = PCT_TO_HWP(limits.max_perf_pct);
		if (limits.no_turbo) {
			rdmsrl( MSR_HWP_CAPABILITIES, freq);
			max = HWP_GUARANTEED_PERF(freq);
		}

		value &= ~HWP_MAX_PERF(~0L);
		value |= HWP_MAX_PERF(max);
		wrmsrl_on_cpu(cpu, MSR_HWP_REQUEST, value);
	}

	put_online_cpus();
}

276 277 278 279 280 281 282
/************************** debugfs begin ************************/
static int pid_param_set(void *data, u64 val)
{
	*(u32 *)data = val;
	intel_pstate_reset_all_pid();
	return 0;
}
283

284 285 286 287 288
static int pid_param_get(void *data, u64 *val)
{
	*val = *(u32 *)data;
	return 0;
}
289
DEFINE_SIMPLE_ATTRIBUTE(fops_pid_param, pid_param_get, pid_param_set, "%llu\n");
290 291 292 293 294 295 296

struct pid_param {
	char *name;
	void *value;
};

static struct pid_param pid_files[] = {
297 298 299 300 301 302
	{"sample_rate_ms", &pid_params.sample_rate_ms},
	{"d_gain_pct", &pid_params.d_gain_pct},
	{"i_gain_pct", &pid_params.i_gain_pct},
	{"deadband", &pid_params.deadband},
	{"setpoint", &pid_params.setpoint},
	{"p_gain_pct", &pid_params.p_gain_pct},
303 304 305
	{NULL, NULL}
};

306
static void __init intel_pstate_debug_expose_params(void)
307
{
308
	struct dentry *debugfs_parent;
309 310
	int i = 0;

D
Dirk Brandewie 已提交
311 312
	if (hwp_active)
		return;
313 314 315 316 317
	debugfs_parent = debugfs_create_dir("pstate_snb", NULL);
	if (IS_ERR_OR_NULL(debugfs_parent))
		return;
	while (pid_files[i].name) {
		debugfs_create_file(pid_files[i].name, 0660,
318 319
				    debugfs_parent, pid_files[i].value,
				    &fops_pid_param);
320 321 322 323 324 325 326 327 328 329 330 331 332 333
		i++;
	}
}

/************************** debugfs end ************************/

/************************** sysfs begin ************************/
#define show_one(file_name, object)					\
	static ssize_t show_##file_name					\
	(struct kobject *kobj, struct attribute *attr, char *buf)	\
	{								\
		return sprintf(buf, "%u\n", limits.object);		\
	}

334 335 336 337 338 339 340 341 342 343 344 345 346 347
static ssize_t show_no_turbo(struct kobject *kobj,
			     struct attribute *attr, char *buf)
{
	ssize_t ret;

	update_turbo_state();
	if (limits.turbo_disabled)
		ret = sprintf(buf, "%u\n", limits.turbo_disabled);
	else
		ret = sprintf(buf, "%u\n", limits.no_turbo);

	return ret;
}

348
static ssize_t store_no_turbo(struct kobject *a, struct attribute *b,
349
			      const char *buf, size_t count)
350 351 352
{
	unsigned int input;
	int ret;
353

354 355 356
	ret = sscanf(buf, "%u", &input);
	if (ret != 1)
		return -EINVAL;
357 358

	update_turbo_state();
359 360
	if (limits.turbo_disabled) {
		pr_warn("Turbo disabled by BIOS or unavailable on processor\n");
361
		return -EPERM;
362
	}
D
Dirk Brandewie 已提交
363

364 365
	limits.no_turbo = clamp_t(int, input, 0, 1);

D
Dirk Brandewie 已提交
366 367 368
	if (hwp_active)
		intel_pstate_hwp_set();

369 370 371 372
	return count;
}

static ssize_t store_max_perf_pct(struct kobject *a, struct attribute *b,
373
				  const char *buf, size_t count)
374 375 376
{
	unsigned int input;
	int ret;
377

378 379 380 381
	ret = sscanf(buf, "%u", &input);
	if (ret != 1)
		return -EINVAL;

382 383
	limits.max_sysfs_pct = clamp_t(int, input, 0 , 100);
	limits.max_perf_pct = min(limits.max_policy_pct, limits.max_sysfs_pct);
384
	limits.max_perf = div_fp(int_tofp(limits.max_perf_pct), int_tofp(100));
385

D
Dirk Brandewie 已提交
386 387
	if (hwp_active)
		intel_pstate_hwp_set();
388 389 390 391
	return count;
}

static ssize_t store_min_perf_pct(struct kobject *a, struct attribute *b,
392
				  const char *buf, size_t count)
393 394 395
{
	unsigned int input;
	int ret;
396

397 398 399 400 401 402
	ret = sscanf(buf, "%u", &input);
	if (ret != 1)
		return -EINVAL;
	limits.min_perf_pct = clamp_t(int, input, 0 , 100);
	limits.min_perf = div_fp(int_tofp(limits.min_perf_pct), int_tofp(100));

D
Dirk Brandewie 已提交
403 404
	if (hwp_active)
		intel_pstate_hwp_set();
405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425
	return count;
}

show_one(max_perf_pct, max_perf_pct);
show_one(min_perf_pct, min_perf_pct);

define_one_global_rw(no_turbo);
define_one_global_rw(max_perf_pct);
define_one_global_rw(min_perf_pct);

static struct attribute *intel_pstate_attributes[] = {
	&no_turbo.attr,
	&max_perf_pct.attr,
	&min_perf_pct.attr,
	NULL
};

static struct attribute_group intel_pstate_attr_group = {
	.attrs = intel_pstate_attributes,
};

426
static void __init intel_pstate_sysfs_expose_params(void)
427
{
428
	struct kobject *intel_pstate_kobject;
429 430 431 432 433
	int rc;

	intel_pstate_kobject = kobject_create_and_add("intel_pstate",
						&cpu_subsys.dev_root->kobj);
	BUG_ON(!intel_pstate_kobject);
434
	rc = sysfs_create_group(intel_pstate_kobject, &intel_pstate_attr_group);
435 436 437
	BUG_ON(rc);
}
/************************** sysfs end ************************/
D
Dirk Brandewie 已提交
438 439 440 441 442 443 444 445 446

static void intel_pstate_hwp_enable(void)
{
	hwp_active++;
	pr_info("intel_pstate HWP enabled\n");

	wrmsrl( MSR_PM_ENABLE, 0x1);
}

447 448 449
static int byt_get_min_pstate(void)
{
	u64 value;
450

451
	rdmsrl(BYT_RATIOS, value);
D
Dirk Brandewie 已提交
452
	return (value >> 8) & 0x7F;
453 454 455 456 457
}

static int byt_get_max_pstate(void)
{
	u64 value;
458

459
	rdmsrl(BYT_RATIOS, value);
D
Dirk Brandewie 已提交
460
	return (value >> 16) & 0x7F;
461
}
462

463 464 465
static int byt_get_turbo_pstate(void)
{
	u64 value;
466

467
	rdmsrl(BYT_TURBO_RATIOS, value);
D
Dirk Brandewie 已提交
468
	return value & 0x7F;
469 470
}

471 472 473 474 475 476 477
static void byt_set_pstate(struct cpudata *cpudata, int pstate)
{
	u64 val;
	int32_t vid_fp;
	u32 vid;

	val = pstate << 8;
478
	if (limits.no_turbo && !limits.turbo_disabled)
479 480 481 482 483 484 485
		val |= (u64)1 << 32;

	vid_fp = cpudata->vid.min + mul_fp(
		int_tofp(pstate - cpudata->pstate.min_pstate),
		cpudata->vid.ratio);

	vid_fp = clamp_t(int32_t, vid_fp, cpudata->vid.min, cpudata->vid.max);
486
	vid = ceiling_fp(vid_fp);
487

488 489 490
	if (pstate > cpudata->pstate.max_pstate)
		vid = cpudata->vid.turbo;

491 492 493 494 495
	val |= vid;

	wrmsrl(MSR_IA32_PERF_CTL, val);
}

496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511
#define BYT_BCLK_FREQS 5
static int byt_freq_table[BYT_BCLK_FREQS] = { 833, 1000, 1333, 1167, 800};

static int byt_get_scaling(void)
{
	u64 value;
	int i;

	rdmsrl(MSR_FSB_FREQ, value);
	i = value & 0x3;

	BUG_ON(i > BYT_BCLK_FREQS);

	return byt_freq_table[i] * 100;
}

512 513 514 515 516
static void byt_get_vid(struct cpudata *cpudata)
{
	u64 value;

	rdmsrl(BYT_VIDS, value);
D
Dirk Brandewie 已提交
517 518
	cpudata->vid.min = int_tofp((value >> 8) & 0x7f);
	cpudata->vid.max = int_tofp((value >> 16) & 0x7f);
519 520 521 522
	cpudata->vid.ratio = div_fp(
		cpudata->vid.max - cpudata->vid.min,
		int_tofp(cpudata->pstate.max_pstate -
			cpudata->pstate.min_pstate));
523 524 525

	rdmsrl(BYT_TURBO_VIDS, value);
	cpudata->vid.turbo = value & 0x7f;
526 527
}

528
static int core_get_min_pstate(void)
529 530
{
	u64 value;
531

532
	rdmsrl(MSR_PLATFORM_INFO, value);
533 534 535
	return (value >> 40) & 0xFF;
}

536
static int core_get_max_pstate(void)
537 538
{
	u64 value;
539

540
	rdmsrl(MSR_PLATFORM_INFO, value);
541 542 543
	return (value >> 8) & 0xFF;
}

544
static int core_get_turbo_pstate(void)
545 546 547
{
	u64 value;
	int nont, ret;
548

549
	rdmsrl(MSR_NHM_TURBO_RATIO_LIMIT, value);
550
	nont = core_get_max_pstate();
551
	ret = (value) & 255;
552 553 554 555 556
	if (ret <= nont)
		ret = nont;
	return ret;
}

557 558 559 560 561
static inline int core_get_scaling(void)
{
	return 100000;
}

562
static void core_set_pstate(struct cpudata *cpudata, int pstate)
563 564 565 566
{
	u64 val;

	val = pstate << 8;
567
	if (limits.no_turbo && !limits.turbo_disabled)
568 569
		val |= (u64)1 << 32;

570
	wrmsrl_on_cpu(cpudata->cpu, MSR_IA32_PERF_CTL, val);
571 572 573 574 575 576 577 578 579 580 581 582 583 584 585
}

static struct cpu_defaults core_params = {
	.pid_policy = {
		.sample_rate_ms = 10,
		.deadband = 0,
		.setpoint = 97,
		.p_gain_pct = 20,
		.d_gain_pct = 0,
		.i_gain_pct = 0,
	},
	.funcs = {
		.get_max = core_get_max_pstate,
		.get_min = core_get_min_pstate,
		.get_turbo = core_get_turbo_pstate,
586
		.get_scaling = core_get_scaling,
587 588 589 590
		.set = core_set_pstate,
	},
};

591 592 593 594 595 596 597 598 599 600 601 602
static struct cpu_defaults byt_params = {
	.pid_policy = {
		.sample_rate_ms = 10,
		.deadband = 0,
		.setpoint = 97,
		.p_gain_pct = 14,
		.d_gain_pct = 0,
		.i_gain_pct = 4,
	},
	.funcs = {
		.get_max = byt_get_max_pstate,
		.get_min = byt_get_min_pstate,
603
		.get_turbo = byt_get_turbo_pstate,
604
		.set = byt_set_pstate,
605
		.get_scaling = byt_get_scaling,
606
		.get_vid = byt_get_vid,
607 608 609
	},
};

610 611 612
static void intel_pstate_get_min_max(struct cpudata *cpu, int *min, int *max)
{
	int max_perf = cpu->pstate.turbo_pstate;
613
	int max_perf_adj;
614
	int min_perf;
615

616
	if (limits.no_turbo || limits.turbo_disabled)
617 618
		max_perf = cpu->pstate.max_pstate;

619 620
	max_perf_adj = fp_toint(mul_fp(int_tofp(max_perf), limits.max_perf));
	*max = clamp_t(int, max_perf_adj,
621 622 623
			cpu->pstate.min_pstate, cpu->pstate.turbo_pstate);

	min_perf = fp_toint(mul_fp(int_tofp(max_perf), limits.min_perf));
624
	*min = clamp_t(int, min_perf, cpu->pstate.min_pstate, max_perf);
625 626 627 628 629 630
}

static void intel_pstate_set_pstate(struct cpudata *cpu, int pstate)
{
	int max_perf, min_perf;

631 632
	update_turbo_state();

633 634 635 636 637 638 639
	intel_pstate_get_min_max(cpu, &min_perf, &max_perf);

	pstate = clamp_t(int, pstate, min_perf, max_perf);

	if (pstate == cpu->pstate.current_pstate)
		return;

640
	trace_cpu_frequency(pstate * cpu->pstate.scaling, cpu->cpu);
641

642 643
	cpu->pstate.current_pstate = pstate;

644
	pstate_funcs.set(cpu, pstate);
645 646 647 648
}

static void intel_pstate_get_cpu_pstates(struct cpudata *cpu)
{
649 650 651
	cpu->pstate.min_pstate = pstate_funcs.get_min();
	cpu->pstate.max_pstate = pstate_funcs.get_max();
	cpu->pstate.turbo_pstate = pstate_funcs.get_turbo();
652
	cpu->pstate.scaling = pstate_funcs.get_scaling();
653

654 655
	if (pstate_funcs.get_vid)
		pstate_funcs.get_vid(cpu);
656
	intel_pstate_set_pstate(cpu, cpu->pstate.min_pstate);
657 658
}

659
static inline void intel_pstate_calc_busy(struct cpudata *cpu)
660
{
661
	struct sample *sample = &cpu->sample;
662
	int64_t core_pct;
663

664
	core_pct = int_tofp(sample->aperf) * int_tofp(100);
665
	core_pct = div64_u64(core_pct, int_tofp(sample->mperf));
666

667
	sample->freq = fp_toint(
668 669 670
		mul_fp(int_tofp(
			cpu->pstate.max_pstate * cpu->pstate.scaling / 100),
			core_pct));
671

672
	sample->core_pct_busy = (int32_t)core_pct;
673 674 675 676 677
}

static inline void intel_pstate_sample(struct cpudata *cpu)
{
	u64 aperf, mperf;
678
	unsigned long flags;
679

680
	local_irq_save(flags);
681 682
	rdmsrl(MSR_IA32_APERF, aperf);
	rdmsrl(MSR_IA32_MPERF, mperf);
683
	local_irq_restore(flags);
684

685 686
	cpu->last_sample_time = cpu->sample.time;
	cpu->sample.time = ktime_get();
687 688 689 690
	cpu->sample.aperf = aperf;
	cpu->sample.mperf = mperf;
	cpu->sample.aperf -= cpu->prev_aperf;
	cpu->sample.mperf -= cpu->prev_mperf;
691

692
	intel_pstate_calc_busy(cpu);
693 694 695 696 697

	cpu->prev_aperf = aperf;
	cpu->prev_mperf = mperf;
}

D
Dirk Brandewie 已提交
698 699 700 701 702 703 704 705
static inline void intel_hwp_set_sample_time(struct cpudata *cpu)
{
	int delay;

	delay = msecs_to_jiffies(50);
	mod_timer_pinned(&cpu->timer, jiffies + delay);
}

706 707
static inline void intel_pstate_set_sample_time(struct cpudata *cpu)
{
708
	int delay;
709

710
	delay = msecs_to_jiffies(pid_params.sample_rate_ms);
711 712 713
	mod_timer_pinned(&cpu->timer, jiffies + delay);
}

714
static inline int32_t intel_pstate_get_scaled_busy(struct cpudata *cpu)
715
{
716 717 718
	int32_t core_busy, max_pstate, current_pstate, sample_ratio;
	u32 duration_us;
	u32 sample_time;
719

720
	core_busy = cpu->sample.core_pct_busy;
721
	max_pstate = int_tofp(cpu->pstate.max_pstate);
722
	current_pstate = int_tofp(cpu->pstate.current_pstate);
723
	core_busy = mul_fp(core_busy, div_fp(max_pstate, current_pstate));
724

725
	sample_time = pid_params.sample_rate_ms  * USEC_PER_MSEC;
726
	duration_us = (u32) ktime_us_delta(cpu->sample.time,
727
					   cpu->last_sample_time);
728 729
	if (duration_us > sample_time * 3) {
		sample_ratio = div_fp(int_tofp(sample_time),
730
				      int_tofp(duration_us));
731 732 733
		core_busy = mul_fp(core_busy, sample_ratio);
	}

734
	return core_busy;
735 736 737 738
}

static inline void intel_pstate_adjust_busy_pstate(struct cpudata *cpu)
{
739
	int32_t busy_scaled;
740
	struct _pid *pid;
741
	signed int ctl;
742 743 744 745 746 747

	pid = &cpu->pid;
	busy_scaled = intel_pstate_get_scaled_busy(cpu);

	ctl = pid_calc(pid, busy_scaled);

748 749
	/* Negative values of ctl increase the pstate and vice versa */
	intel_pstate_set_pstate(cpu, cpu->pstate.current_pstate - ctl);
750 751
}

D
Dirk Brandewie 已提交
752 753 754 755 756 757 758 759
static void intel_hwp_timer_func(unsigned long __data)
{
	struct cpudata *cpu = (struct cpudata *) __data;

	intel_pstate_sample(cpu);
	intel_hwp_set_sample_time(cpu);
}

760 761 762
static void intel_pstate_timer_func(unsigned long __data)
{
	struct cpudata *cpu = (struct cpudata *) __data;
763
	struct sample *sample;
764 765

	intel_pstate_sample(cpu);
766

767
	sample = &cpu->sample;
768

769
	intel_pstate_adjust_busy_pstate(cpu);
770 771 772 773 774 775 776 777

	trace_pstate_sample(fp_toint(sample->core_pct_busy),
			fp_toint(intel_pstate_get_scaled_busy(cpu)),
			cpu->pstate.current_pstate,
			sample->mperf,
			sample->aperf,
			sample->freq);

778 779 780 781
	intel_pstate_set_sample_time(cpu);
}

#define ICPU(model, policy) \
782 783
	{ X86_VENDOR_INTEL, 6, model, X86_FEATURE_APERFMPERF,\
			(unsigned long)&policy }
784 785

static const struct x86_cpu_id intel_pstate_cpu_ids[] = {
786 787
	ICPU(0x2a, core_params),
	ICPU(0x2d, core_params),
788
	ICPU(0x37, byt_params),
789 790
	ICPU(0x3a, core_params),
	ICPU(0x3c, core_params),
791
	ICPU(0x3d, core_params),
792 793 794 795
	ICPU(0x3e, core_params),
	ICPU(0x3f, core_params),
	ICPU(0x45, core_params),
	ICPU(0x46, core_params),
796
	ICPU(0x4c, byt_params),
797 798
	ICPU(0x4f, core_params),
	ICPU(0x56, core_params),
799 800 801 802
	{}
};
MODULE_DEVICE_TABLE(x86cpu, intel_pstate_cpu_ids);

D
Dirk Brandewie 已提交
803 804 805 806 807
static const struct x86_cpu_id intel_pstate_cpu_oob_ids[] = {
	ICPU(0x56, core_params),
	{}
};

808 809 810 811
static int intel_pstate_init_cpu(unsigned int cpunum)
{
	struct cpudata *cpu;

812 813 814
	if (!all_cpu_data[cpunum])
		all_cpu_data[cpunum] = kzalloc(sizeof(struct cpudata),
					       GFP_KERNEL);
815 816 817 818 819 820
	if (!all_cpu_data[cpunum])
		return -ENOMEM;

	cpu = all_cpu_data[cpunum];

	cpu->cpu = cpunum;
821
	intel_pstate_get_cpu_pstates(cpu);
822

823
	init_timer_deferrable(&cpu->timer);
824
	cpu->timer.data = (unsigned long)cpu;
825
	cpu->timer.expires = jiffies + HZ/100;
D
Dirk Brandewie 已提交
826 827 828 829 830 831

	if (!hwp_active)
		cpu->timer.function = intel_pstate_timer_func;
	else
		cpu->timer.function = intel_hwp_timer_func;

832 833 834 835 836
	intel_pstate_busy_pid_reset(cpu);
	intel_pstate_sample(cpu);

	add_timer_on(&cpu->timer, cpunum);

837
	pr_debug("Intel pstate controlling: cpu %d\n", cpunum);
838 839 840 841 842 843 844 845 846 847 848 849

	return 0;
}

static unsigned int intel_pstate_get(unsigned int cpu_num)
{
	struct sample *sample;
	struct cpudata *cpu;

	cpu = all_cpu_data[cpu_num];
	if (!cpu)
		return 0;
850
	sample = &cpu->sample;
851 852 853 854 855
	return sample->freq;
}

static int intel_pstate_set_policy(struct cpufreq_policy *policy)
{
856 857 858
	if (!policy->cpuinfo.max_freq)
		return -ENODEV;

859 860 861
	if (policy->policy == CPUFREQ_POLICY_PERFORMANCE) {
		limits.min_perf_pct = 100;
		limits.min_perf = int_tofp(1);
862
		limits.max_policy_pct = 100;
863 864
		limits.max_perf_pct = 100;
		limits.max_perf = int_tofp(1);
865
		limits.no_turbo = 0;
866
		return 0;
867
	}
D
Dirk Brandewie 已提交
868

869 870 871 872
	limits.min_perf_pct = (policy->min * 100) / policy->cpuinfo.max_freq;
	limits.min_perf_pct = clamp_t(int, limits.min_perf_pct, 0 , 100);
	limits.min_perf = div_fp(int_tofp(limits.min_perf_pct), int_tofp(100));

873
	limits.max_policy_pct = (policy->max * 100) / policy->cpuinfo.max_freq;
874 875
	limits.max_policy_pct = clamp_t(int, limits.max_policy_pct, 0 , 100);
	limits.max_perf_pct = min(limits.max_policy_pct, limits.max_sysfs_pct);
876
	limits.max_perf = div_fp(int_tofp(limits.max_perf_pct), int_tofp(100));
877

D
Dirk Brandewie 已提交
878 879 880
	if (hwp_active)
		intel_pstate_hwp_set();

881 882 883 884 885
	return 0;
}

static int intel_pstate_verify_policy(struct cpufreq_policy *policy)
{
886
	cpufreq_verify_within_cpu_limits(policy);
887

888
	if (policy->policy != CPUFREQ_POLICY_POWERSAVE &&
889
	    policy->policy != CPUFREQ_POLICY_PERFORMANCE)
890 891 892 893 894
		return -EINVAL;

	return 0;
}

895
static void intel_pstate_stop_cpu(struct cpufreq_policy *policy)
896
{
897 898
	int cpu_num = policy->cpu;
	struct cpudata *cpu = all_cpu_data[cpu_num];
899

900 901
	pr_info("intel_pstate CPU %d exiting\n", cpu_num);

902
	del_timer_sync(&all_cpu_data[cpu_num]->timer);
D
Dirk Brandewie 已提交
903 904 905
	if (hwp_active)
		return;

906
	intel_pstate_set_pstate(cpu, cpu->pstate.min_pstate);
907 908
}

909
static int intel_pstate_cpu_init(struct cpufreq_policy *policy)
910 911
{
	struct cpudata *cpu;
912
	int rc;
913 914 915 916 917 918 919

	rc = intel_pstate_init_cpu(policy->cpu);
	if (rc)
		return rc;

	cpu = all_cpu_data[policy->cpu];

920
	if (limits.min_perf_pct == 100 && limits.max_perf_pct == 100)
921 922 923 924
		policy->policy = CPUFREQ_POLICY_PERFORMANCE;
	else
		policy->policy = CPUFREQ_POLICY_POWERSAVE;

925 926
	policy->min = cpu->pstate.min_pstate * cpu->pstate.scaling;
	policy->max = cpu->pstate.turbo_pstate * cpu->pstate.scaling;
927 928

	/* cpuinfo and default policy values */
929 930 931
	policy->cpuinfo.min_freq = cpu->pstate.min_pstate * cpu->pstate.scaling;
	policy->cpuinfo.max_freq =
		cpu->pstate.turbo_pstate * cpu->pstate.scaling;
932 933 934 935 936 937 938 939 940 941 942 943
	policy->cpuinfo.transition_latency = CPUFREQ_ETERNAL;
	cpumask_set_cpu(policy->cpu, policy->cpus);

	return 0;
}

static struct cpufreq_driver intel_pstate_driver = {
	.flags		= CPUFREQ_CONST_LOOPS,
	.verify		= intel_pstate_verify_policy,
	.setpolicy	= intel_pstate_set_policy,
	.get		= intel_pstate_get,
	.init		= intel_pstate_cpu_init,
944
	.stop_cpu	= intel_pstate_stop_cpu,
945 946 947
	.name		= "intel_pstate",
};

948
static int __initdata no_load;
D
Dirk Brandewie 已提交
949
static int __initdata no_hwp;
950

951 952 953 954 955 956 957 958
static int intel_pstate_msrs_not_valid(void)
{
	/* Check that all the msr's we are using are valid. */
	u64 aperf, mperf, tmp;

	rdmsrl(MSR_IA32_APERF, aperf);
	rdmsrl(MSR_IA32_MPERF, mperf);

959
	if (!pstate_funcs.get_max() ||
960 961
	    !pstate_funcs.get_min() ||
	    !pstate_funcs.get_turbo())
962 963 964 965 966 967 968 969 970 971 972 973
		return -ENODEV;

	rdmsrl(MSR_IA32_APERF, tmp);
	if (!(tmp - aperf))
		return -ENODEV;

	rdmsrl(MSR_IA32_MPERF, tmp);
	if (!(tmp - mperf))
		return -ENODEV;

	return 0;
}
974

975
static void copy_pid_params(struct pstate_adjust_policy *policy)
976 977 978 979 980 981 982 983 984
{
	pid_params.sample_rate_ms = policy->sample_rate_ms;
	pid_params.p_gain_pct = policy->p_gain_pct;
	pid_params.i_gain_pct = policy->i_gain_pct;
	pid_params.d_gain_pct = policy->d_gain_pct;
	pid_params.deadband = policy->deadband;
	pid_params.setpoint = policy->setpoint;
}

985
static void copy_cpu_funcs(struct pstate_funcs *funcs)
986 987 988 989
{
	pstate_funcs.get_max   = funcs->get_max;
	pstate_funcs.get_min   = funcs->get_min;
	pstate_funcs.get_turbo = funcs->get_turbo;
990
	pstate_funcs.get_scaling = funcs->get_scaling;
991
	pstate_funcs.set       = funcs->set;
992
	pstate_funcs.get_vid   = funcs->get_vid;
993 994
}

995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042
#if IS_ENABLED(CONFIG_ACPI)
#include <acpi/processor.h>

static bool intel_pstate_no_acpi_pss(void)
{
	int i;

	for_each_possible_cpu(i) {
		acpi_status status;
		union acpi_object *pss;
		struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL };
		struct acpi_processor *pr = per_cpu(processors, i);

		if (!pr)
			continue;

		status = acpi_evaluate_object(pr->handle, "_PSS", NULL, &buffer);
		if (ACPI_FAILURE(status))
			continue;

		pss = buffer.pointer;
		if (pss && pss->type == ACPI_TYPE_PACKAGE) {
			kfree(pss);
			return false;
		}

		kfree(pss);
	}

	return true;
}

struct hw_vendor_info {
	u16  valid;
	char oem_id[ACPI_OEM_ID_SIZE];
	char oem_table_id[ACPI_OEM_TABLE_ID_SIZE];
};

/* Hardware vendor-specific info that has its own power management modes */
static struct hw_vendor_info vendor_info[] = {
	{1, "HP    ", "ProLiant"},
	{0, "", ""},
};

static bool intel_pstate_platform_pwr_mgmt_exists(void)
{
	struct acpi_table_header hdr;
	struct hw_vendor_info *v_info;
D
Dirk Brandewie 已提交
1043 1044 1045 1046 1047 1048 1049 1050 1051
	const struct x86_cpu_id *id;
	u64 misc_pwr;

	id = x86_match_cpu(intel_pstate_cpu_oob_ids);
	if (id) {
		rdmsrl(MSR_MISC_PWR_MGMT, misc_pwr);
		if ( misc_pwr & (1 << 8))
			return true;
	}
1052

1053 1054
	if (acpi_disabled ||
	    ACPI_FAILURE(acpi_get_table_header(ACPI_SIG_FADT, 0, &hdr)))
1055 1056 1057
		return false;

	for (v_info = vendor_info; v_info->valid; v_info++) {
1058 1059 1060
		if (!strncmp(hdr.oem_id, v_info->oem_id, ACPI_OEM_ID_SIZE) &&
		    !strncmp(hdr.oem_table_id, v_info->oem_table_id, ACPI_OEM_TABLE_ID_SIZE) &&
		    intel_pstate_no_acpi_pss())
1061 1062 1063 1064 1065 1066 1067 1068 1069
			return true;
	}

	return false;
}
#else /* CONFIG_ACPI not enabled */
static inline bool intel_pstate_platform_pwr_mgmt_exists(void) { return false; }
#endif /* CONFIG_ACPI */

1070 1071
static int __init intel_pstate_init(void)
{
1072
	int cpu, rc = 0;
1073
	const struct x86_cpu_id *id;
1074
	struct cpu_defaults *cpu_info;
D
Dirk Brandewie 已提交
1075
	struct cpuinfo_x86 *c = &boot_cpu_data;
1076

1077 1078 1079
	if (no_load)
		return -ENODEV;

1080 1081 1082 1083
	id = x86_match_cpu(intel_pstate_cpu_ids);
	if (!id)
		return -ENODEV;

1084 1085 1086 1087 1088 1089 1090
	/*
	 * The Intel pstate driver will be ignored if the platform
	 * firmware has its own power management modes.
	 */
	if (intel_pstate_platform_pwr_mgmt_exists())
		return -ENODEV;

1091 1092 1093 1094 1095
	cpu_info = (struct cpu_defaults *)id->driver_data;

	copy_pid_params(&cpu_info->pid_policy);
	copy_cpu_funcs(&cpu_info->funcs);

1096 1097 1098
	if (intel_pstate_msrs_not_valid())
		return -ENODEV;

1099 1100
	pr_info("Intel P-state driver initializing.\n");

1101
	all_cpu_data = vzalloc(sizeof(void *) * num_possible_cpus());
1102 1103 1104
	if (!all_cpu_data)
		return -ENOMEM;

D
Dirk Brandewie 已提交
1105 1106 1107
	if (cpu_has(c,X86_FEATURE_HWP) && !no_hwp)
		intel_pstate_hwp_enable();

1108 1109 1110 1111 1112 1113
	rc = cpufreq_register_driver(&intel_pstate_driver);
	if (rc)
		goto out;

	intel_pstate_debug_expose_params();
	intel_pstate_sysfs_expose_params();
1114

1115 1116
	return rc;
out:
1117 1118 1119 1120 1121 1122 1123 1124 1125 1126
	get_online_cpus();
	for_each_online_cpu(cpu) {
		if (all_cpu_data[cpu]) {
			del_timer_sync(&all_cpu_data[cpu]->timer);
			kfree(all_cpu_data[cpu]);
		}
	}

	put_online_cpus();
	vfree(all_cpu_data);
1127 1128 1129 1130
	return -ENODEV;
}
device_initcall(intel_pstate_init);

1131 1132 1133 1134 1135 1136 1137
static int __init intel_pstate_setup(char *str)
{
	if (!str)
		return -EINVAL;

	if (!strcmp(str, "disable"))
		no_load = 1;
D
Dirk Brandewie 已提交
1138 1139
	if (!strcmp(str, "no_hwp"))
		no_hwp = 1;
1140 1141 1142 1143
	return 0;
}
early_param("intel_pstate", intel_pstate_setup);

1144 1145 1146
MODULE_AUTHOR("Dirk Brandewie <dirk.j.brandewie@intel.com>");
MODULE_DESCRIPTION("'intel_pstate' - P state driver Intel Core processors");
MODULE_LICENSE("GPL");