aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/pci/hotplug/shpchp_hpc.c98
1 files changed, 48 insertions, 50 deletions
diff --git a/drivers/pci/hotplug/shpchp_hpc.c b/drivers/pci/hotplug/shpchp_hpc.c
index e0f8c1bbaf12..f6b3bf3ee7ca 100644
--- a/drivers/pci/hotplug/shpchp_hpc.c
+++ b/drivers/pci/hotplug/shpchp_hpc.c
@@ -147,39 +147,37 @@
147#define CON_PFAULT_SERR_MASK (1 << 30) 147#define CON_PFAULT_SERR_MASK (1 << 30)
148#define SLOT_REG_RSVDZ_MASK (1 << 15) | (7 << 21) 148#define SLOT_REG_RSVDZ_MASK (1 << 15) | (7 << 21)
149 149
150/* SHPC 'write' operations/commands */ 150/*
151 151 * SHPC Command Code definitnions
152/* Slot operation - 0x00h to 0x3Fh */ 152 *
153 153 * Slot Operation 00h - 3Fh
154#define NO_CHANGE 0x00 154 * Set Bus Segment Speed/Mode A 40h - 47h
155 155 * Power-Only All Slots 48h
156/* Slot state - Bits 0 & 1 of controller command register */ 156 * Enable All Slots 49h
157#define SET_SLOT_PWR 0x01 157 * Set Bus Segment Speed/Mode B (PI=2) 50h - 5Fh
158#define SET_SLOT_ENABLE 0x02 158 * Reserved Command Codes 60h - BFh
159#define SET_SLOT_DISABLE 0x03 159 * Vendor Specific Commands C0h - FFh
160 160 */
161/* Power indicator state - Bits 2 & 3 of controller command register*/ 161#define SET_SLOT_PWR 0x01 /* Slot Operation */
162#define SET_PWR_ON 0x04 162#define SET_SLOT_ENABLE 0x02
163#define SET_PWR_BLINK 0x08 163#define SET_SLOT_DISABLE 0x03
164#define SET_PWR_OFF 0x0C 164#define SET_PWR_ON 0x04
165 165#define SET_PWR_BLINK 0x08
166/* Attention indicator state - Bits 4 & 5 of controller command register*/ 166#define SET_PWR_OFF 0x0c
167#define SET_ATTN_ON 0x010 167#define SET_ATTN_ON 0x10
168#define SET_ATTN_BLINK 0x020 168#define SET_ATTN_BLINK 0x20
169#define SET_ATTN_OFF 0x030 169#define SET_ATTN_OFF 0x30
170 170#define SETA_PCI_33MHZ 0x40 /* Set Bus Segment Speed/Mode A */
171/* Set bus speed/mode A - 0x40h to 0x47h */
172#define SETA_PCI_33MHZ 0x40
173#define SETA_PCI_66MHZ 0x41 171#define SETA_PCI_66MHZ 0x41
174#define SETA_PCIX_66MHZ 0x42 172#define SETA_PCIX_66MHZ 0x42
175#define SETA_PCIX_100MHZ 0x43 173#define SETA_PCIX_100MHZ 0x43
176#define SETA_PCIX_133MHZ 0x44 174#define SETA_PCIX_133MHZ 0x44
177#define RESERV_1 0x45 175#define SETA_RESERVED1 0x45
178#define RESERV_2 0x46 176#define SETA_RESERVED2 0x46
179#define RESERV_3 0x47 177#define SETA_RESERVED3 0x47
180 178#define SET_PWR_ONLY_ALL 0x48 /* Power-Only All Slots */
181/* Set bus speed/mode B - 0x50h to 0x5fh */ 179#define SET_ENABLE_ALL 0x49 /* Enable All Slots */
182#define SETB_PCI_33MHZ 0x50 180#define SETB_PCI_33MHZ 0x50 /* Set Bus Segment Speed/Mode B */
183#define SETB_PCI_66MHZ 0x51 181#define SETB_PCI_66MHZ 0x51
184#define SETB_PCIX_66MHZ_PM 0x52 182#define SETB_PCIX_66MHZ_PM 0x52
185#define SETB_PCIX_100MHZ_PM 0x53 183#define SETB_PCIX_100MHZ_PM 0x53
@@ -193,23 +191,21 @@
193#define SETB_PCIX_66MHZ_533 0x5b 191#define SETB_PCIX_66MHZ_533 0x5b
194#define SETB_PCIX_100MHZ_533 0x5c 192#define SETB_PCIX_100MHZ_533 0x5c
195#define SETB_PCIX_133MHZ_533 0x5d 193#define SETB_PCIX_133MHZ_533 0x5d
194#define SETB_RESERVED1 0x5e
195#define SETB_RESERVED2 0x5f
196 196
197 197/*
198/* Power-on all slots - 0x48h */ 198 * SHPC controller command error code
199#define SET_PWR_ON_ALL 0x48 199 */
200
201/* Enable all slots - 0x49h */
202#define SET_ENABLE_ALL 0x49
203
204/* SHPC controller command error code */
205#define SWITCH_OPEN 0x1 200#define SWITCH_OPEN 0x1
206#define INVALID_CMD 0x2 201#define INVALID_CMD 0x2
207#define INVALID_SPEED_MODE 0x4 202#define INVALID_SPEED_MODE 0x4
208 203
209/* For accessing SHPC Working Register Set */ 204/*
205 * For accessing SHPC Working Register Set via PCI Configuration Space
206 */
210#define DWORD_SELECT 0x2 207#define DWORD_SELECT 0x2
211#define DWORD_DATA 0x4 208#define DWORD_DATA 0x4
212#define BASE_OFFSET 0x0
213 209
214/* Field Offset in Logical Slot Register - byte boundary */ 210/* Field Offset in Logical Slot Register - byte boundary */
215#define SLOT_EVENT_LATCH 0x2 211#define SLOT_EVENT_LATCH 0x2
@@ -630,13 +626,13 @@ static int hpc_set_attention_status(struct slot *slot, u8 value)
630 626
631 switch (value) { 627 switch (value) {
632 case 0 : 628 case 0 :
633 slot_cmd = 0x30; /* OFF */ 629 slot_cmd = SET_ATTN_OFF; /* OFF */
634 break; 630 break;
635 case 1: 631 case 1:
636 slot_cmd = 0x10; /* ON */ 632 slot_cmd = SET_ATTN_ON; /* ON */
637 break; 633 break;
638 case 2: 634 case 2:
639 slot_cmd = 0x20; /* BLINK */ 635 slot_cmd = SET_ATTN_BLINK; /* BLINK */
640 break; 636 break;
641 default: 637 default:
642 return -1; 638 return -1;
@@ -648,17 +644,17 @@ static int hpc_set_attention_status(struct slot *slot, u8 value)
648 644
649static void hpc_set_green_led_on(struct slot *slot) 645static void hpc_set_green_led_on(struct slot *slot)
650{ 646{
651 shpc_write_cmd(slot, slot->hp_slot, 0x04); 647 shpc_write_cmd(slot, slot->hp_slot, SET_PWR_ON);
652} 648}
653 649
654static void hpc_set_green_led_off(struct slot *slot) 650static void hpc_set_green_led_off(struct slot *slot)
655{ 651{
656 shpc_write_cmd(slot, slot->hp_slot, 0x0c); 652 shpc_write_cmd(slot, slot->hp_slot, SET_PWR_OFF);
657} 653}
658 654
659static void hpc_set_green_led_blink(struct slot *slot) 655static void hpc_set_green_led_blink(struct slot *slot)
660{ 656{
661 shpc_write_cmd(slot, slot->hp_slot, 0x08); 657 shpc_write_cmd(slot, slot->hp_slot, SET_PWR_BLINK);
662} 658}
663 659
664int shpc_get_ctlr_slot_config(struct controller *ctrl, 660int shpc_get_ctlr_slot_config(struct controller *ctrl,
@@ -769,7 +765,7 @@ static int hpc_power_on_slot(struct slot * slot)
769 765
770 DBG_ENTER_ROUTINE 766 DBG_ENTER_ROUTINE
771 767
772 retval = shpc_write_cmd(slot, slot->hp_slot, 0x01); 768 retval = shpc_write_cmd(slot, slot->hp_slot, SET_SLOT_PWR);
773 if (retval) { 769 if (retval) {
774 err("%s: Write command failed!\n", __FUNCTION__); 770 err("%s: Write command failed!\n", __FUNCTION__);
775 return retval; 771 return retval;
@@ -786,8 +782,9 @@ static int hpc_slot_enable(struct slot * slot)
786 782
787 DBG_ENTER_ROUTINE 783 DBG_ENTER_ROUTINE
788 784
789 /* 3A => Slot - Enable, Power Indicator - Blink, Attention Indicator - Off */ 785 /* Slot - Enable, Power Indicator - Blink, Attention Indicator - Off */
790 retval = shpc_write_cmd(slot, slot->hp_slot, 0x3a); 786 retval = shpc_write_cmd(slot, slot->hp_slot,
787 SET_SLOT_ENABLE | SET_PWR_BLINK | SET_ATTN_OFF);
791 if (retval) { 788 if (retval) {
792 err("%s: Write command failed!\n", __FUNCTION__); 789 err("%s: Write command failed!\n", __FUNCTION__);
793 return retval; 790 return retval;
@@ -803,8 +800,9 @@ static int hpc_slot_disable(struct slot * slot)
803 800
804 DBG_ENTER_ROUTINE 801 DBG_ENTER_ROUTINE
805 802
806 /* 1F => Slot - Disable, Power Indicator - Off, Attention Indicator - On */ 803 /* Slot - Disable, Power Indicator - Off, Attention Indicator - On */
807 retval = shpc_write_cmd(slot, slot->hp_slot, 0x1f); 804 retval = shpc_write_cmd(slot, slot->hp_slot,
805 SET_SLOT_DISABLE | SET_PWR_OFF | SET_ATTN_ON);
808 if (retval) { 806 if (retval) {
809 err("%s: Write command failed!\n", __FUNCTION__); 807 err("%s: Write command failed!\n", __FUNCTION__);
810 return retval; 808 return retval;