aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pci/hotplug/shpchp_hpc.c
diff options
context:
space:
mode:
authorKenji Kaneshige <kaneshige.kenji@jp.fujitsu.com>2006-05-01 22:10:37 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2006-06-19 17:13:23 -0400
commit5858759c2098c6792af1afa6d5ded94044740f9c (patch)
tree673a917583ba1f4e8c16027f0aa712bc04fb4b48 /drivers/pci/hotplug/shpchp_hpc.c
parent2b34da7e61383b4b7773d2d4e776e58725794347 (diff)
[PATCH] SHPC: Cleanup SHPC Logical Slot Register bits access
This patch cleans up the code to access bits in slot logical registers. This patch has no functional change. Signed-off-by: Kenji Kaneshige <kaneshige.kenji@jp.fujitsu.com> Cc: Kristen Accardi <kristen.c.accardi@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/pci/hotplug/shpchp_hpc.c')
-rw-r--r--drivers/pci/hotplug/shpchp_hpc.c151
1 files changed, 64 insertions, 87 deletions
diff --git a/drivers/pci/hotplug/shpchp_hpc.c b/drivers/pci/hotplug/shpchp_hpc.c
index a5337cf1436d..9731ee8224f2 100644
--- a/drivers/pci/hotplug/shpchp_hpc.c
+++ b/drivers/pci/hotplug/shpchp_hpc.c
@@ -95,43 +95,40 @@
95 */ 95 */
96#define SLOT_REG(i) (SLOT1 + (4 * i)) 96#define SLOT_REG(i) (SLOT1 + (4 * i))
97 97
98/* Slot Status Field Definitions */ 98#define SLOT_STATE_SHIFT (0)
99/* Slot State */ 99#define SLOT_STATE_MASK (3 << 0)
100#define PWR_ONLY 0x0001 100#define SLOT_STATE_PWRONLY (1)
101#define ENABLED 0x0002 101#define SLOT_STATE_ENABLED (2)
102#define DISABLED 0x0003 102#define SLOT_STATE_DISABLED (3)
103 103#define PWR_LED_STATE_SHIFT (2)
104/* Power Indicator State */ 104#define PWR_LED_STATE_MASK (3 << 2)
105#define PWR_LED_ON 0x0004 105#define ATN_LED_STATE_SHIFT (4)
106#define PWR_LED_BLINK 0x0008 106#define ATN_LED_STATE_MASK (3 << 4)
107#define PWR_LED_OFF 0x000c 107#define ATN_LED_STATE_ON (1)
108 108#define ATN_LED_STATE_BLINK (2)
109/* Attention Indicator State */ 109#define ATN_LED_STATE_OFF (3)
110#define ATTEN_LED_ON 0x0010 110#define POWER_FAULT (1 << 6)
111#define ATTEN_LED_BLINK 0x0020 111#define ATN_BUTTON (1 << 7)
112#define ATTEN_LED_OFF 0x0030 112#define MRL_SENSOR (1 << 8)
113 113#define MHZ66_CAP (1 << 9)
114/* Power Fault */ 114#define PRSNT_SHIFT (10)
115#define pwr_fault 0x0040 115#define PRSNT_MASK (3 << 10)
116 116#define PCIX_CAP_SHIFT (12)
117/* Attention Button */ 117#define PCIX_CAP_MASK_PI1 (3 << 12)
118#define ATTEN_BUTTON 0x0080 118#define PCIX_CAP_MASK_PI2 (7 << 12)
119 119#define PRSNT_CHANGE_DETECTED (1 << 16)
120/* MRL Sensor */ 120#define ISO_PFAULT_DETECTED (1 << 17)
121#define MRL_SENSOR 0x0100 121#define BUTTON_PRESS_DETECTED (1 << 18)
122 122#define MRL_CHANGE_DETECTED (1 << 19)
123/* 66 MHz Capable */ 123#define CON_PFAULT_DETECTED (1 << 20)
124#define IS_66MHZ_CAP 0x0200 124#define PRSNT_CHANGE_INTR_MASK (1 << 24)
125 125#define ISO_PFAULT_INTR_MASK (1 << 25)
126/* PRSNT1#/PRSNT2# */ 126#define BUTTON_PRESS_INTR_MASK (1 << 26)
127#define SLOT_EMP 0x0c00 127#define MRL_CHANGE_INTR_MASK (1 << 27)
128 128#define CON_PFAULT_INTR_MASK (1 << 28)
129/* PCI-X Capability */ 129#define MRL_CHANGE_SERR_MASK (1 << 29)
130#define NON_PCIX 0x0000 130#define CON_PFAULT_SERR_MASK (1 << 30)
131#define PCIX_66 0x1000 131#define SLOT_REG_RSVDZ_MASK (1 << 15) | (7 << 21)
132#define PCIX_133 0x3000
133#define PCIX_266 0x4000 /* For PI = 2 only */
134#define PCIX_533 0x5000 /* For PI = 2 only */
135 132
136/* SHPC 'write' operations/commands */ 133/* SHPC 'write' operations/commands */
137 134
@@ -428,8 +425,7 @@ static int hpc_get_attention_status(struct slot *slot, u8 *status)
428{ 425{
429 struct controller *ctrl = slot->ctrl; 426 struct controller *ctrl = slot->ctrl;
430 u32 slot_reg; 427 u32 slot_reg;
431 u16 slot_status; 428 u8 state;
432 u8 atten_led_state;
433 429
434 DBG_ENTER_ROUTINE 430 DBG_ENTER_ROUTINE
435 431
@@ -439,24 +435,20 @@ static int hpc_get_attention_status(struct slot *slot, u8 *status)
439 } 435 }
440 436
441 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot)); 437 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot));
442 slot_status = (u16) slot_reg; 438 state = (slot_reg & ATN_LED_STATE_MASK) >> ATN_LED_STATE_SHIFT;
443 atten_led_state = (slot_status & 0x0030) >> 4;
444 439
445 switch (atten_led_state) { 440 switch (state) {
446 case 0: 441 case ATN_LED_STATE_ON:
447 *status = 0xFF; /* Reserved */
448 break;
449 case 1:
450 *status = 1; /* On */ 442 *status = 1; /* On */
451 break; 443 break;
452 case 2: 444 case ATN_LED_STATE_BLINK:
453 *status = 2; /* Blink */ 445 *status = 2; /* Blink */
454 break; 446 break;
455 case 3: 447 case ATN_LED_STATE_OFF:
456 *status = 0; /* Off */ 448 *status = 0; /* Off */
457 break; 449 break;
458 default: 450 default:
459 *status = 0xFF; 451 *status = 0xFF; /* Reserved */
460 break; 452 break;
461 } 453 }
462 454
@@ -468,9 +460,7 @@ static int hpc_get_power_status(struct slot * slot, u8 *status)
468{ 460{
469 struct controller *ctrl = slot->ctrl; 461 struct controller *ctrl = slot->ctrl;
470 u32 slot_reg; 462 u32 slot_reg;
471 u16 slot_status; 463 u8 state;
472 u8 slot_state;
473 int retval = 0;
474 464
475 DBG_ENTER_ROUTINE 465 DBG_ENTER_ROUTINE
476 466
@@ -480,29 +470,25 @@ static int hpc_get_power_status(struct slot * slot, u8 *status)
480 } 470 }
481 471
482 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot)); 472 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot));
483 slot_status = (u16) slot_reg; 473 state = (slot_reg & SLOT_STATE_MASK) >> SLOT_STATE_SHIFT;
484 slot_state = (slot_status & 0x0003);
485 474
486 switch (slot_state) { 475 switch (state) {
487 case 0: 476 case SLOT_STATE_PWRONLY:
488 *status = 0xFF;
489 break;
490 case 1:
491 *status = 2; /* Powered only */ 477 *status = 2; /* Powered only */
492 break; 478 break;
493 case 2: 479 case SLOT_STATE_ENABLED:
494 *status = 1; /* Enabled */ 480 *status = 1; /* Enabled */
495 break; 481 break;
496 case 3: 482 case SLOT_STATE_DISABLED:
497 *status = 0; /* Disabled */ 483 *status = 0; /* Disabled */
498 break; 484 break;
499 default: 485 default:
500 *status = 0xFF; 486 *status = 0xFF; /* Reserved */
501 break; 487 break;
502 } 488 }
503 489
504 DBG_LEAVE_ROUTINE 490 DBG_LEAVE_ROUTINE
505 return retval; 491 return 0;
506} 492}
507 493
508 494
@@ -510,7 +496,6 @@ static int hpc_get_latch_status(struct slot *slot, u8 *status)
510{ 496{
511 struct controller *ctrl = slot->ctrl; 497 struct controller *ctrl = slot->ctrl;
512 u32 slot_reg; 498 u32 slot_reg;
513 u16 slot_status;
514 499
515 DBG_ENTER_ROUTINE 500 DBG_ENTER_ROUTINE
516 501
@@ -520,10 +505,7 @@ static int hpc_get_latch_status(struct slot *slot, u8 *status)
520 } 505 }
521 506
522 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot)); 507 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot));
523 slot_status = (u16)slot_reg; 508 *status = !!(slot_reg & MRL_SENSOR); /* 0 -> close; 1 -> open */
524
525 *status = ((slot_status & 0x0100) == 0) ? 0 : 1; /* 0 -> close; 1 -> open */
526
527 509
528 DBG_LEAVE_ROUTINE 510 DBG_LEAVE_ROUTINE
529 return 0; 511 return 0;
@@ -533,8 +515,7 @@ static int hpc_get_adapter_status(struct slot *slot, u8 *status)
533{ 515{
534 struct controller *ctrl = slot->ctrl; 516 struct controller *ctrl = slot->ctrl;
535 u32 slot_reg; 517 u32 slot_reg;
536 u16 slot_status; 518 u8 state;
537 u8 card_state;
538 519
539 DBG_ENTER_ROUTINE 520 DBG_ENTER_ROUTINE
540 521
@@ -544,9 +525,8 @@ static int hpc_get_adapter_status(struct slot *slot, u8 *status)
544 } 525 }
545 526
546 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot)); 527 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot));
547 slot_status = (u16)slot_reg; 528 state = (slot_reg & PRSNT_MASK) >> PRSNT_SHIFT;
548 card_state = (u8)((slot_status & 0x0C00) >> 10); 529 *status = (state != 0x3) ? 1 : 0;
549 *status = (card_state != 0x3) ? 1 : 0;
550 530
551 DBG_LEAVE_ROUTINE 531 DBG_LEAVE_ROUTINE
552 return 0; 532 return 0;
@@ -574,8 +554,8 @@ static int hpc_get_adapter_speed(struct slot *slot, enum pci_bus_speed *value)
574 int retval = 0; 554 int retval = 0;
575 struct controller *ctrl = slot->ctrl; 555 struct controller *ctrl = slot->ctrl;
576 u32 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot)); 556 u32 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot));
577 u8 pcix_cap = (slot_reg >> 12) & 7; 557 u8 pcix_cap = (slot_reg & PCIX_CAP_MASK_PI2) >> PCIX_CAP_SHIFT;
578 u8 m66_cap = (slot_reg >> 9) & 1; 558 u8 m66_cap = !!(slot_reg & MHZ66_CAP);
579 559
580 DBG_ENTER_ROUTINE 560 DBG_ENTER_ROUTINE
581 561
@@ -643,8 +623,6 @@ static int hpc_query_power_fault(struct slot * slot)
643{ 623{
644 struct controller *ctrl = slot->ctrl; 624 struct controller *ctrl = slot->ctrl;
645 u32 slot_reg; 625 u32 slot_reg;
646 u16 slot_status;
647 u8 pwr_fault_state, status;
648 626
649 DBG_ENTER_ROUTINE 627 DBG_ENTER_ROUTINE
650 628
@@ -654,13 +632,10 @@ static int hpc_query_power_fault(struct slot * slot)
654 } 632 }
655 633
656 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot)); 634 slot_reg = shpc_readl(ctrl, SLOT_REG(slot->hp_slot));
657 slot_status = (u16) slot_reg;
658 pwr_fault_state = (slot_status & 0x0040) >> 7;
659 status = (pwr_fault_state == 1) ? 0 : 1;
660 635
661 DBG_LEAVE_ROUTINE 636 DBG_LEAVE_ROUTINE
662 /* Note: Logic 0 => fault */ 637 /* Note: Logic 0 => fault */
663 return status; 638 return !(slot_reg & POWER_FAULT);
664} 639}
665 640
666static int hpc_set_attention_status(struct slot *slot, u8 value) 641static int hpc_set_attention_status(struct slot *slot, u8 value)
@@ -1019,7 +994,6 @@ static irqreturn_t shpc_isr(int IRQ, void *dev_id, struct pt_regs *regs)
1019 struct controller *ctrl = NULL; 994 struct controller *ctrl = NULL;
1020 struct php_ctlr_state_s *php_ctlr; 995 struct php_ctlr_state_s *php_ctlr;
1021 u8 schedule_flag = 0; 996 u8 schedule_flag = 0;
1022 u8 temp_byte;
1023 u32 temp_dword, intr_loc, intr_loc2; 997 u32 temp_dword, intr_loc, intr_loc2;
1024 int hp_slot; 998 int hp_slot;
1025 999
@@ -1080,17 +1054,20 @@ static irqreturn_t shpc_isr(int IRQ, void *dev_id, struct pt_regs *regs)
1080 temp_dword = shpc_readl(ctrl, SLOT_REG(hp_slot)); 1054 temp_dword = shpc_readl(ctrl, SLOT_REG(hp_slot));
1081 dbg("%s: Slot %x with intr, slot register = %x\n", 1055 dbg("%s: Slot %x with intr, slot register = %x\n",
1082 __FUNCTION__, hp_slot, temp_dword); 1056 __FUNCTION__, hp_slot, temp_dword);
1083 temp_byte = (temp_dword >> 16) & 0xFF; 1057 if ((php_ctlr->switch_change_callback) &&
1084 if ((php_ctlr->switch_change_callback) && (temp_byte & 0x08)) 1058 (temp_dword & MRL_CHANGE_DETECTED))
1085 schedule_flag += php_ctlr->switch_change_callback( 1059 schedule_flag += php_ctlr->switch_change_callback(
1086 hp_slot, php_ctlr->callback_instance_id); 1060 hp_slot, php_ctlr->callback_instance_id);
1087 if ((php_ctlr->attention_button_callback) && (temp_byte & 0x04)) 1061 if ((php_ctlr->attention_button_callback) &&
1062 (temp_dword & BUTTON_PRESS_DETECTED))
1088 schedule_flag += php_ctlr->attention_button_callback( 1063 schedule_flag += php_ctlr->attention_button_callback(
1089 hp_slot, php_ctlr->callback_instance_id); 1064 hp_slot, php_ctlr->callback_instance_id);
1090 if ((php_ctlr->presence_change_callback) && (temp_byte & 0x01)) 1065 if ((php_ctlr->presence_change_callback) &&
1066 (temp_dword & PRSNT_CHANGE_DETECTED))
1091 schedule_flag += php_ctlr->presence_change_callback( 1067 schedule_flag += php_ctlr->presence_change_callback(
1092 hp_slot , php_ctlr->callback_instance_id); 1068 hp_slot , php_ctlr->callback_instance_id);
1093 if ((php_ctlr->power_fault_callback) && (temp_byte & 0x12)) 1069 if ((php_ctlr->power_fault_callback) &&
1070 (temp_dword & (ISO_PFAULT_DETECTED | CON_PFAULT_DETECTED)))
1094 schedule_flag += php_ctlr->power_fault_callback( 1071 schedule_flag += php_ctlr->power_fault_callback(
1095 hp_slot, php_ctlr->callback_instance_id); 1072 hp_slot, php_ctlr->callback_instance_id);
1096 1073