isci: fixup SAS iaf protocols data structure
authorDave Jiang <dave.jiang@intel.com>
Thu, 5 May 2011 01:22:33 +0000 (18:22 -0700)
committerDan Williams <dan.j.williams@intel.com>
Sun, 3 Jul 2011 11:04:46 +0000 (04:04 -0700)
Moved the actual data structure that's read from the phy register to phy
header.  Removed the parsing of identify address frame protocol bits as
that seemed not necessary and we can use existing information.

Signed-off-by: Dave Jiang <dave.jiang@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
drivers/scsi/isci/core/intel_sas.h
drivers/scsi/isci/core/scic_phy.h
drivers/scsi/isci/core/scic_port.h
drivers/scsi/isci/core/scic_sds_phy.c
drivers/scsi/isci/core/scic_sds_phy.h
drivers/scsi/isci/core/scic_sds_port.c
drivers/scsi/isci/port.c

index 58bf1fb9b2f5e04558b01b53b13a6294187bf5ed..f2d5ca1c72ed26cc3a04ad4dc994e21c9f080b50 100644 (file)
@@ -84,33 +84,6 @@ struct sci_sas_address {
 
 };
 
-/**
- * struct sci_sas_identify_address_frame_protocols - This structure depicts the
- *    contents of bytes 2 and 3 in the SAS IDENTIFY ADDRESS FRAME (IAF).
- *
- * For specific information on each of these individual fields please reference
- * the SAS specification Link layer section on address frames.
- */
-struct sci_sas_identify_address_frame_protocols {
-       union {
-               struct {
-                       u16 restricted1:1;
-                       u16 smp_initiator:1;
-                       u16 stp_initiator:1;
-                       u16 ssp_initiator:1;
-                       u16 reserved3:4;
-                       u16 restricted2:1;
-                       u16 smp_target:1;
-                       u16 stp_target:1;
-                       u16 ssp_target:1;
-                       u16 reserved4:4;
-               } bits;
-
-               u16 all;
-       } u;
-
-};
-
 /**
  * enum _SCI_SAS_TASK_ATTRIBUTE - This enumeration depicts the SAM/SAS
  *    specification defined task attribute values for a command information
index 3f43e8d69c4f7d87449d10bf6e85f68adda6818a..451d7977bf6d369773da15f27628f9243bcc7848 100644 (file)
@@ -103,6 +103,26 @@ struct scic_phy_cap {
        };
 }  __packed;
 
+/* this data structure reflects the link layer transmit identification reg */
+struct scic_phy_proto {
+       union {
+               struct {
+                       u16 _r_a:1;
+                       u16 smp_iport:1;
+                       u16 stp_iport:1;
+                       u16 ssp_iport:1;
+                       u16 _r_b:4;
+                       u16 _r_c:1;
+                       u16 smp_tport:1;
+                       u16 stp_tport:1;
+                       u16 ssp_tport:1;
+                       u16 _r_d:4;
+               };
+               u16 all;
+       };
+} __packed;
+
+
 /**
  * struct scic_phy_properties - This structure defines the properties common to
  *    all phys that can be retrieved.
@@ -123,17 +143,11 @@ struct scic_phy_properties {
         */
        enum sas_linkrate negotiated_link_rate;
 
-       /**
-        * This field indicates the protocols supported by the phy.
-        */
-       struct sci_sas_identify_address_frame_protocols protocols;
-
        /**
         * This field specifies the index of the phy in relation to other
         * phys within the controller.  This index is zero relative.
         */
        u8 index;
-
 };
 
 /**
index 56d05073f9c59a06ac0cc0899e16bd76b0cb03e8..4ae9b6cdf04f0beefec273ac26ce0d26aa88b896 100644 (file)
@@ -57,6 +57,7 @@
 #define _SCIC_PORT_H_
 
 #include "sci_status.h"
+#include "scic_phy.h"
 #include "intel_sas.h"
 
 struct scic_sds_port;
@@ -72,8 +73,7 @@ enum scic_port_not_ready_reason_code {
 
 struct scic_port_end_point_properties {
        struct sci_sas_address sas_address;
-       struct sci_sas_identify_address_frame_protocols protocols;
-
+       struct scic_phy_proto protocols;
 };
 
 struct scic_port_properties {
index 4afdb422ab98e4070bd3ac6b3701b140179f270c..b9d6fc7e8ae06ae7ac70ba9e707ea79cb832d470 100644 (file)
@@ -442,37 +442,15 @@ void scic_sds_phy_get_attached_sas_address(struct scic_sds_phy *sci_phy,
        memcpy(sas_address, iaf->sas_addr, SAS_ADDR_SIZE);
 }
 
-void scic_sds_phy_get_protocols(
-       struct scic_sds_phy *sci_phy,
-       struct sci_sas_identify_address_frame_protocols *protocols)
+void scic_sds_phy_get_protocols(struct scic_sds_phy *sci_phy,
+                               struct scic_phy_proto *protocols)
 {
-       protocols->u.all =
+       protocols->all =
                (u16)(readl(&sci_phy->
                        link_layer_registers->transmit_identification) &
                                0x0000FFFF);
 }
 
-void scic_sds_phy_get_attached_phy_protocols(
-       struct scic_sds_phy *sci_phy,
-       struct sci_sas_identify_address_frame_protocols *protocols)
-{
-       protocols->u.all = 0;
-
-       if (sci_phy->protocol == SCIC_SDS_PHY_PROTOCOL_SAS) {
-               struct isci_phy *iphy = sci_phy->iphy;
-               struct sas_identify_frame *iaf;
-
-               iaf = &iphy->frame_rcvd.iaf;
-               memcpy(&protocols->u.all, &iaf->initiator_bits, 2);
-       } else if (sci_phy->protocol == SCIC_SDS_PHY_PROTOCOL_SATA)
-               protocols->u.bits.stp_target = 1;
-}
-
-/*
- * *****************************************************************************
- * * SCIC SDS PHY Handler Redirects
- * ***************************************************************************** */
-
 /**
  * This method will attempt to start the phy object. This request is only valid
  *    when the phy is in the stopped state
index e91f28316c004bebbc5e6c115172d6fb67b614c3..b0cebdc669eb8720504054853bfb30634c20ebdf 100644 (file)
@@ -57,6 +57,7 @@
 #define _SCIC_SDS_PHY_H_
 
 #include "intel_sas.h"
+#include "scic_phy.h"
 #include "scu_registers.h"
 #include "sci_base_state_machine.h"
 #include <scsi/libsas.h>
@@ -438,11 +439,7 @@ void scic_sds_phy_get_attached_sas_address(
        struct sci_sas_address *sas_address);
 
 void scic_sds_phy_get_protocols(
-       struct scic_sds_phy *this_phy,
-       struct sci_sas_identify_address_frame_protocols *protocols);
-
-void scic_sds_phy_get_attached_phy_protocols(
-       struct scic_sds_phy *this_phy,
-       struct sci_sas_identify_address_frame_protocols *protocols);
+       struct scic_sds_phy *sci_phy,
+       struct scic_phy_proto *protocols);
 
 #endif /* _SCIC_SDS_PHY_H_ */
index 3697211e7ca937714c18be80d07581d588b62871..05bc3bff4f6f12400194d68f132bc49bb1b2b13f 100644 (file)
@@ -53,6 +53,7 @@
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  */
 
+#include "sas.h"
 #include "intel_sas.h"
 #include "scic_controller.h"
 #include "scic_phy.h"
@@ -362,33 +363,32 @@ void scic_sds_port_get_sas_address(
        }
 }
 
-/**
- * This method will indicate which protocols are supported by this port.
+/*
+ * This function will indicate which protocols are supported by this port.
  * @sci_port: a handle corresponding to the SAS port for which to return the
  *    supported protocols.
- * @protocols: This parameter specifies a pointer to an IAF protocol field
- *    structure into which the core will copy the protocol values for the port.
- *     The values are returned as part of a bit mask in order to allow for
- *    multi-protocol support.
- *
+ * @protocols: This parameter specifies a pointer to a data structure
+ *    which the core will copy the protocol values for the port from the
+ *    transmit_identification register.
  */
-static void scic_sds_port_get_protocols(
-       struct scic_sds_port *sci_port,
-       struct sci_sas_identify_address_frame_protocols *protocols)
+static void
+scic_sds_port_get_protocols(struct scic_sds_port *sci_port,
+                           struct scic_phy_proto *protocols)
 {
        u8 index;
 
-       protocols->u.all = 0;
+       protocols->all = 0;
 
        for (index = 0; index < SCI_MAX_PHYS; index++) {
                if (sci_port->phy_table[index] != NULL) {
-                       scic_sds_phy_get_protocols(sci_port->phy_table[index], protocols);
+                       scic_sds_phy_get_protocols(sci_port->phy_table[index],
+                                                  protocols);
                }
        }
 }
 
-/**
- * This method requests the SAS address for the device directly attached to
+/*
+ * This function requests the SAS address for the device directly attached to
  *    this SAS port.
  * @sci_port: a handle corresponding to the SAS port for which to return the
  *    SAS address.
@@ -401,21 +401,20 @@ void scic_sds_port_get_attached_sas_address(
        struct scic_sds_port *sci_port,
        struct sci_sas_address *sas_address)
 {
-       struct sci_sas_identify_address_frame_protocols protocols;
-       struct scic_sds_phy *phy;
+       struct scic_sds_phy *sci_phy;
 
        /*
         * Ensure that the phy is both part of the port and currently
-        * connected to the remote end-point. */
-       phy = scic_sds_port_get_a_connected_phy(sci_port);
-       if (phy != NULL) {
-               scic_sds_phy_get_attached_phy_protocols(phy, &protocols);
-
-               if (!protocols.u.bits.stp_target) {
-                       scic_sds_phy_get_attached_sas_address(phy, sas_address);
+        * connected to the remote end-point.
+        */
+       sci_phy = scic_sds_port_get_a_connected_phy(sci_port);
+       if (sci_phy) {
+               if (sci_phy->protocol != SCIC_SDS_PHY_PROTOCOL_SATA) {
+                       scic_sds_phy_get_attached_sas_address(sci_phy,
+                                                             sas_address);
                } else {
-                       scic_sds_phy_get_sas_address(phy, sas_address);
-                       sas_address->low += phy->phy_index;
+                       scic_sds_phy_get_sas_address(sci_phy, sas_address);
+                       sas_address->low += sci_phy->phy_index;
                }
        } else {
                sas_address->high = 0;
@@ -423,33 +422,6 @@ void scic_sds_port_get_attached_sas_address(
        }
 }
 
-/**
- * This method will indicate which protocols are supported by this remote
- *    device.
- * @sci_port: a handle corresponding to the SAS port for which to return the
- *    supported protocols.
- * @protocols: This parameter specifies a pointer to an IAF protocol field
- *    structure into which the core will copy the protocol values for the port.
- *     The values are returned as part of a bit mask in order to allow for
- *    multi-protocol support.
- *
- */
-static void scic_sds_port_get_attached_protocols(
-       struct scic_sds_port *sci_port,
-       struct sci_sas_identify_address_frame_protocols *protocols)
-{
-       struct scic_sds_phy *phy;
-
-       /*
-        * Ensure that the phy is both part of the port and currently
-        * connected to the remote end-point. */
-       phy = scic_sds_port_get_a_connected_phy(sci_port);
-       if (phy != NULL)
-               scic_sds_phy_get_attached_phy_protocols(phy, protocols);
-       else
-               protocols->u.all = 0;
-}
-
 /**
  * scic_sds_port_construct_dummy_rnc() - create dummy rnc for si workaround
  *
@@ -595,7 +567,6 @@ enum sci_status scic_port_get_properties(
        scic_sds_port_get_sas_address(port, &prop->local.sas_address);
        scic_sds_port_get_protocols(port, &prop->local.protocols);
        scic_sds_port_get_attached_sas_address(port, &prop->remote.sas_address);
-       scic_sds_port_get_attached_protocols(port, &prop->remote.protocols);
 
        return SCI_SUCCESS;
 }
@@ -655,14 +626,10 @@ static void scic_sds_port_activate_phy(struct scic_sds_port *sci_port,
                                       struct scic_sds_phy *sci_phy,
                                       bool do_notify_user)
 {
-       struct scic_sds_controller *scic = scic_sds_port_get_controller(sci_port);
-       struct sci_sas_identify_address_frame_protocols protocols;
+       struct scic_sds_controller *scic = sci_port->owning_controller;
        struct isci_host *ihost = scic->ihost;
 
-       scic_sds_phy_get_attached_phy_protocols(sci_phy, &protocols);
-
-       /* If this is sata port then the phy has already been resumed */
-       if (!protocols.u.bits.stp_target)
+       if (sci_phy->protocol != SCIC_SDS_PHY_PROTOCOL_SATA)
                scic_sds_phy_resume(sci_phy);
 
        sci_port->active_phy_mask |= 1 << sci_phy->phy_index;
@@ -803,15 +770,9 @@ bool scic_sds_port_link_detected(
        struct scic_sds_port *sci_port,
        struct scic_sds_phy *sci_phy)
 {
-       struct sci_sas_identify_address_frame_protocols protocols;
-
-       scic_sds_phy_get_attached_phy_protocols(sci_phy, &protocols);
-
-       if (
-               (sci_port->logical_port_index != SCIC_SDS_DUMMY_PORT)
-               && (protocols.u.bits.stp_target)
-               && scic_sds_port_is_wide(sci_port)
-               ) {
+       if ((sci_port->logical_port_index != SCIC_SDS_DUMMY_PORT) &&
+           (sci_phy->protocol == SCIC_SDS_PHY_PROTOCOL_SATA) &&
+           scic_sds_port_is_wide(sci_port)) {
                scic_sds_port_invalid_link_up(sci_port, sci_phy);
 
                return false;
index 96a2002dadea2e87775ec7fd4c2d17bd3623583a..2decafbeb96899e747ba4de7d3a84a75600c3d58 100644 (file)
@@ -187,7 +187,7 @@ void isci_port_link_up(
 
        scic_port_get_properties(port, &properties);
 
-       if (properties.remote.protocols.u.bits.stp_target) {
+       if (phy->protocol == SCIC_SDS_PHY_PROTOCOL_SATA) {
                u64 attached_sas_address;
 
                isci_phy->sas_phy.oob_mode = SATA_OOB_MODE;
@@ -207,9 +207,7 @@ void isci_port_link_up(
 
                memcpy(&isci_phy->sas_phy.attached_sas_addr,
                       &attached_sas_address, sizeof(attached_sas_address));
-
-       } else if (properties.remote.protocols.u.bits.ssp_target ||
-                  properties.remote.protocols.u.bits.smp_target) {
+       } else if (phy->protocol == SCIC_SDS_PHY_PROTOCOL_SAS) {
                isci_phy->sas_phy.oob_mode = SAS_OOB_MODE;
                isci_phy->sas_phy.frame_rcvd_size = sizeof(struct sas_identify_frame);