aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/acpi/processor_throttling.c60
1 files changed, 39 insertions, 21 deletions
diff --git a/drivers/acpi/processor_throttling.c b/drivers/acpi/processor_throttling.c
index 20d82f55ce5f..5c96ef18e94c 100644
--- a/drivers/acpi/processor_throttling.c
+++ b/drivers/acpi/processor_throttling.c
@@ -376,16 +376,23 @@ static int acpi_processor_get_throttling_fadt(struct acpi_processor *pr)
376 return 0; 376 return 0;
377} 377}
378 378
379static int acpi_read_throttling_status(struct acpi_processor_throttling 379static int acpi_read_throttling_status(struct acpi_processor *pr,
380 *throttling) 380 acpi_integer *value)
381{ 381{
382 int value = -1; 382 u64 ptc_value;
383 struct acpi_processor_throttling *throttling;
384 int ret = -1;
385
386 throttling = &pr->throttling;
383 switch (throttling->status_register.space_id) { 387 switch (throttling->status_register.space_id) {
384 case ACPI_ADR_SPACE_SYSTEM_IO: 388 case ACPI_ADR_SPACE_SYSTEM_IO:
389 ptc_value = 0;
385 acpi_os_read_port((acpi_io_address) throttling->status_register. 390 acpi_os_read_port((acpi_io_address) throttling->status_register.
386 address, &value, 391 address, (u32 *) &ptc_value,
387 (u32) throttling->status_register.bit_width * 392 (u32) throttling->status_register.bit_width *
388 8); 393 8);
394 *value = (acpi_integer) ptc_value;
395 ret = 0;
389 break; 396 break;
390 case ACPI_ADR_SPACE_FIXED_HARDWARE: 397 case ACPI_ADR_SPACE_FIXED_HARDWARE:
391 printk(KERN_ERR PREFIX 398 printk(KERN_ERR PREFIX
@@ -395,18 +402,22 @@ static int acpi_read_throttling_status(struct acpi_processor_throttling
395 printk(KERN_ERR PREFIX "Unknown addr space %d\n", 402 printk(KERN_ERR PREFIX "Unknown addr space %d\n",
396 (u32) (throttling->status_register.space_id)); 403 (u32) (throttling->status_register.space_id));
397 } 404 }
398 return value; 405 return ret;
399} 406}
400 407
401static int acpi_write_throttling_state(struct acpi_processor_throttling 408static int acpi_write_throttling_state(struct acpi_processor *pr,
402 *throttling, int value) 409 acpi_integer value)
403{ 410{
411 u64 ptc_value;
412 struct acpi_processor_throttling *throttling;
404 int ret = -1; 413 int ret = -1;
405 414
415 throttling = &pr->throttling;
406 switch (throttling->control_register.space_id) { 416 switch (throttling->control_register.space_id) {
407 case ACPI_ADR_SPACE_SYSTEM_IO: 417 case ACPI_ADR_SPACE_SYSTEM_IO:
418 ptc_value = value;
408 acpi_os_write_port((acpi_io_address) throttling-> 419 acpi_os_write_port((acpi_io_address) throttling->
409 control_register.address, value, 420 control_register.address, (u32) ptc_value,
410 (u32) throttling->control_register. 421 (u32) throttling->control_register.
411 bit_width * 8); 422 bit_width * 8);
412 ret = 0; 423 ret = 0;
@@ -422,7 +433,8 @@ static int acpi_write_throttling_state(struct acpi_processor_throttling
422 return ret; 433 return ret;
423} 434}
424 435
425static int acpi_get_throttling_state(struct acpi_processor *pr, int value) 436static int acpi_get_throttling_state(struct acpi_processor *pr,
437 acpi_integer value)
426{ 438{
427 int i; 439 int i;
428 440
@@ -438,22 +450,26 @@ static int acpi_get_throttling_state(struct acpi_processor *pr, int value)
438 return i; 450 return i;
439} 451}
440 452
441static int acpi_get_throttling_value(struct acpi_processor *pr, int state) 453static int acpi_get_throttling_value(struct acpi_processor *pr,
454 int state, acpi_integer *value)
442{ 455{
443 int value = -1; 456 int ret = -1;
457
444 if (state >= 0 && state <= pr->throttling.state_count) { 458 if (state >= 0 && state <= pr->throttling.state_count) {
445 struct acpi_processor_tx_tss *tx = 459 struct acpi_processor_tx_tss *tx =
446 (struct acpi_processor_tx_tss *)&(pr->throttling. 460 (struct acpi_processor_tx_tss *)&(pr->throttling.
447 states_tss[state]); 461 states_tss[state]);
448 value = tx->control; 462 *value = tx->control;
463 ret = 0;
449 } 464 }
450 return value; 465 return ret;
451} 466}
452 467
453static int acpi_processor_get_throttling_ptc(struct acpi_processor *pr) 468static int acpi_processor_get_throttling_ptc(struct acpi_processor *pr)
454{ 469{
455 int state = 0; 470 int state = 0;
456 u32 value = 0; 471 int ret;
472 acpi_integer value;
457 473
458 if (!pr) 474 if (!pr)
459 return -EINVAL; 475 return -EINVAL;
@@ -463,8 +479,9 @@ static int acpi_processor_get_throttling_ptc(struct acpi_processor *pr)
463 479
464 pr->throttling.state = 0; 480 pr->throttling.state = 0;
465 local_irq_disable(); 481 local_irq_disable();
466 value = acpi_read_throttling_status(&pr->throttling); 482 value = 0;
467 if (value >= 0) { 483 ret = acpi_read_throttling_status(pr, &value);
484 if (ret >= 0) {
468 state = acpi_get_throttling_state(pr, value); 485 state = acpi_get_throttling_state(pr, value);
469 pr->throttling.state = state; 486 pr->throttling.state = state;
470 } 487 }
@@ -588,7 +605,8 @@ static int acpi_processor_set_throttling_fadt(struct acpi_processor *pr,
588static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr, 605static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr,
589 int state) 606 int state)
590{ 607{
591 u32 value = 0; 608 int ret;
609 acpi_integer value;
592 610
593 if (!pr) 611 if (!pr)
594 return -EINVAL; 612 return -EINVAL;
@@ -606,10 +624,10 @@ static int acpi_processor_set_throttling_ptc(struct acpi_processor *pr,
606 return -EPERM; 624 return -EPERM;
607 625
608 local_irq_disable(); 626 local_irq_disable();
609 627 value = 0;
610 value = acpi_get_throttling_value(pr, state); 628 ret = acpi_get_throttling_value(pr, state, &value);
611 if (value >= 0) { 629 if (ret >= 0) {
612 acpi_write_throttling_state(&pr->throttling, value); 630 acpi_write_throttling_state(pr, value);
613 pr->throttling.state = state; 631 pr->throttling.state = state;
614 } 632 }
615 local_irq_enable(); 633 local_irq_enable();