Gitweb:     
http://git.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=147d6a37500348b6bda5738453d84c46678209cf
Commit:     147d6a37500348b6bda5738453d84c46678209cf
Parent:     2fd30be8dae25386fc5167c34c6d73201334a8d4
Author:     Linas Vepstas <[EMAIL PROTECTED]>
AuthorDate: Mon Mar 19 14:54:21 2007 -0500
Committer:  Paul Mackerras <[EMAIL PROTECTED]>
CommitDate: Thu Mar 22 22:52:52 2007 +1100

    [POWERPC] EEH: support ibm,get-config-addr-info2 RTAS call
    
    Provide support for the new ibm,get-config-addr-info2 RTAS token,
    whenever it is actually available.
    
    Signed-off-by: Linas Vepstas <[EMAIL PROTECTED]>
    Signed-off-by: Paul Mackerras <[EMAIL PROTECTED]>
---
 arch/powerpc/platforms/pseries/eeh.c |   44 +++++++++++++++++++++++++++-------
 1 files changed, 35 insertions(+), 9 deletions(-)

diff --git a/arch/powerpc/platforms/pseries/eeh.c 
b/arch/powerpc/platforms/pseries/eeh.c
index 2d0a43f..44aae91 100644
--- a/arch/powerpc/platforms/pseries/eeh.c
+++ b/arch/powerpc/platforms/pseries/eeh.c
@@ -83,6 +83,7 @@ static int ibm_read_slot_reset_state;
 static int ibm_read_slot_reset_state2;
 static int ibm_slot_error_detail;
 static int ibm_get_config_addr_info;
+static int ibm_get_config_addr_info2;
 static int ibm_configure_bridge;
 
 int eeh_subsystem_enabled;
@@ -744,6 +745,38 @@ struct eeh_early_enable_info {
        unsigned int buid_lo;
 };
 
+static int get_pe_addr (int config_addr,
+                        struct eeh_early_enable_info *info)
+{
+       unsigned int rets[3];
+       int ret;
+
+       /* Use latest config-addr token on power6 */
+       if (ibm_get_config_addr_info2 != RTAS_UNKNOWN_SERVICE) {
+               /* Make sure we have a PE in hand */
+               ret = rtas_call (ibm_get_config_addr_info2, 4, 2, rets,
+                       config_addr, info->buid_hi, info->buid_lo, 1);
+               if (ret || (rets[0]==0))
+                       return 0;
+
+               ret = rtas_call (ibm_get_config_addr_info2, 4, 2, rets,
+                       config_addr, info->buid_hi, info->buid_lo, 0);
+               if (ret)
+                       return 0;
+               return rets[0];
+       }
+
+       /* Use older config-addr token on power5 */
+       if (ibm_get_config_addr_info != RTAS_UNKNOWN_SERVICE) {
+               ret = rtas_call (ibm_get_config_addr_info, 4, 2, rets,
+                       config_addr, info->buid_hi, info->buid_lo, 0);
+               if (ret)
+                       return 0;
+               return rets[0];
+       }
+       return 0;
+}
+
 /* Enable eeh for the given device node. */
 static void *early_enable_eeh(struct device_node *dn, void *data)
 {
@@ -810,15 +843,7 @@ static void *early_enable_eeh(struct device_node *dn, void 
*data)
 
                        /* If the newer, better, ibm,get-config-addr-info is 
supported, 
                         * then use that instead. */
-                       pdn->eeh_pe_config_addr = 0;
-                       if (ibm_get_config_addr_info != RTAS_UNKNOWN_SERVICE) {
-                               ret = rtas_call (ibm_get_config_addr_info, 4, 
2, rets, 
-                                       pdn->eeh_config_addr, 
-                                       info->buid_hi, info->buid_lo,
-                                       0);
-                               if (ret == 0)
-                                       pdn->eeh_pe_config_addr = rets[0];
-                       }
+                       pdn->eeh_pe_config_addr = 
get_pe_addr(pdn->eeh_config_addr, info);
 
                        /* Some older systems (Power4) allow the
                         * ibm,set-eeh-option call to succeed even on nodes
@@ -889,6 +914,7 @@ void __init eeh_init(void)
        ibm_read_slot_reset_state = rtas_token("ibm,read-slot-reset-state");
        ibm_slot_error_detail = rtas_token("ibm,slot-error-detail");
        ibm_get_config_addr_info = rtas_token("ibm,get-config-addr-info");
+       ibm_get_config_addr_info2 = rtas_token("ibm,get-config-addr-info2");
        ibm_configure_bridge = rtas_token ("ibm,configure-bridge");
 
        if (ibm_set_eeh_option == RTAS_UNKNOWN_SERVICE)
-
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to