Commit d7b90fc3 authored by Dave Jiang's avatar Dave Jiang Committed by Dan Williams

isci: fixup SAS iaf protocols data structure

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: default avatarDave Jiang <dave.jiang@intel.com>
Signed-off-by: default avatarDan Williams <dan.j.williams@intel.com>
parent f700ad43
...@@ -84,33 +84,6 @@ struct sci_sas_address { ...@@ -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 * enum _SCI_SAS_TASK_ATTRIBUTE - This enumeration depicts the SAM/SAS
* specification defined task attribute values for a command information * specification defined task attribute values for a command information
......
...@@ -103,6 +103,26 @@ struct scic_phy_cap { ...@@ -103,6 +103,26 @@ struct scic_phy_cap {
}; };
} __packed; } __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 * struct scic_phy_properties - This structure defines the properties common to
* all phys that can be retrieved. * all phys that can be retrieved.
...@@ -123,17 +143,11 @@ struct scic_phy_properties { ...@@ -123,17 +143,11 @@ struct scic_phy_properties {
*/ */
enum sas_linkrate negotiated_link_rate; 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 * This field specifies the index of the phy in relation to other
* phys within the controller. This index is zero relative. * phys within the controller. This index is zero relative.
*/ */
u8 index; u8 index;
}; };
/** /**
......
...@@ -57,6 +57,7 @@ ...@@ -57,6 +57,7 @@
#define _SCIC_PORT_H_ #define _SCIC_PORT_H_
#include "sci_status.h" #include "sci_status.h"
#include "scic_phy.h"
#include "intel_sas.h" #include "intel_sas.h"
struct scic_sds_port; struct scic_sds_port;
...@@ -72,8 +73,7 @@ enum scic_port_not_ready_reason_code { ...@@ -72,8 +73,7 @@ enum scic_port_not_ready_reason_code {
struct scic_port_end_point_properties { struct scic_port_end_point_properties {
struct sci_sas_address sas_address; struct sci_sas_address sas_address;
struct sci_sas_identify_address_frame_protocols protocols; struct scic_phy_proto protocols;
}; };
struct scic_port_properties { struct scic_port_properties {
......
...@@ -442,37 +442,15 @@ void scic_sds_phy_get_attached_sas_address(struct scic_sds_phy *sci_phy, ...@@ -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); memcpy(sas_address, iaf->sas_addr, SAS_ADDR_SIZE);
} }
void scic_sds_phy_get_protocols( void scic_sds_phy_get_protocols(struct scic_sds_phy *sci_phy,
struct scic_sds_phy *sci_phy, struct scic_phy_proto *protocols)
struct sci_sas_identify_address_frame_protocols *protocols)
{ {
protocols->u.all = protocols->all =
(u16)(readl(&sci_phy-> (u16)(readl(&sci_phy->
link_layer_registers->transmit_identification) & link_layer_registers->transmit_identification) &
0x0000FFFF); 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 * This method will attempt to start the phy object. This request is only valid
* when the phy is in the stopped state * when the phy is in the stopped state
......
...@@ -57,6 +57,7 @@ ...@@ -57,6 +57,7 @@
#define _SCIC_SDS_PHY_H_ #define _SCIC_SDS_PHY_H_
#include "intel_sas.h" #include "intel_sas.h"
#include "scic_phy.h"
#include "scu_registers.h" #include "scu_registers.h"
#include "sci_base_state_machine.h" #include "sci_base_state_machine.h"
#include <scsi/libsas.h> #include <scsi/libsas.h>
...@@ -438,11 +439,7 @@ void scic_sds_phy_get_attached_sas_address( ...@@ -438,11 +439,7 @@ void scic_sds_phy_get_attached_sas_address(
struct sci_sas_address *sas_address); struct sci_sas_address *sas_address);
void scic_sds_phy_get_protocols( void scic_sds_phy_get_protocols(
struct scic_sds_phy *this_phy, struct scic_sds_phy *sci_phy,
struct sci_sas_identify_address_frame_protocols *protocols); struct scic_phy_proto *protocols);
void scic_sds_phy_get_attached_phy_protocols(
struct scic_sds_phy *this_phy,
struct sci_sas_identify_address_frame_protocols *protocols);
#endif /* _SCIC_SDS_PHY_H_ */ #endif /* _SCIC_SDS_PHY_H_ */
...@@ -53,6 +53,7 @@ ...@@ -53,6 +53,7 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/ */
#include "sas.h"
#include "intel_sas.h" #include "intel_sas.h"
#include "scic_controller.h" #include "scic_controller.h"
#include "scic_phy.h" #include "scic_phy.h"
...@@ -362,33 +363,32 @@ void scic_sds_port_get_sas_address( ...@@ -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 * @sci_port: a handle corresponding to the SAS port for which to return the
* supported protocols. * supported protocols.
* @protocols: This parameter specifies a pointer to an IAF protocol field * @protocols: This parameter specifies a pointer to a data structure
* structure into which the core will copy the protocol values for the port. * which the core will copy the protocol values for the port from the
* The values are returned as part of a bit mask in order to allow for * transmit_identification register.
* multi-protocol support.
*
*/ */
static void scic_sds_port_get_protocols( static void
struct scic_sds_port *sci_port, scic_sds_port_get_protocols(struct scic_sds_port *sci_port,
struct sci_sas_identify_address_frame_protocols *protocols) struct scic_phy_proto *protocols)
{ {
u8 index; u8 index;
protocols->u.all = 0; protocols->all = 0;
for (index = 0; index < SCI_MAX_PHYS; index++) { for (index = 0; index < SCI_MAX_PHYS; index++) {
if (sci_port->phy_table[index] != NULL) { 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. * this SAS port.
* @sci_port: a handle corresponding to the SAS port for which to return the * @sci_port: a handle corresponding to the SAS port for which to return the
* SAS address. * SAS address.
...@@ -401,21 +401,20 @@ void scic_sds_port_get_attached_sas_address( ...@@ -401,21 +401,20 @@ void scic_sds_port_get_attached_sas_address(
struct scic_sds_port *sci_port, struct scic_sds_port *sci_port,
struct sci_sas_address *sas_address) struct sci_sas_address *sas_address)
{ {
struct sci_sas_identify_address_frame_protocols protocols; struct scic_sds_phy *sci_phy;
struct scic_sds_phy *phy;
/* /*
* Ensure that the phy is both part of the port and currently * Ensure that the phy is both part of the port and currently
* connected to the remote end-point. */ * connected to the remote end-point.
phy = scic_sds_port_get_a_connected_phy(sci_port); */
if (phy != NULL) { sci_phy = scic_sds_port_get_a_connected_phy(sci_port);
scic_sds_phy_get_attached_phy_protocols(phy, &protocols); if (sci_phy) {
if (sci_phy->protocol != SCIC_SDS_PHY_PROTOCOL_SATA) {
if (!protocols.u.bits.stp_target) { scic_sds_phy_get_attached_sas_address(sci_phy,
scic_sds_phy_get_attached_sas_address(phy, sas_address); sas_address);
} else { } else {
scic_sds_phy_get_sas_address(phy, sas_address); scic_sds_phy_get_sas_address(sci_phy, sas_address);
sas_address->low += phy->phy_index; sas_address->low += sci_phy->phy_index;
} }
} else { } else {
sas_address->high = 0; sas_address->high = 0;
...@@ -423,33 +422,6 @@ void scic_sds_port_get_attached_sas_address( ...@@ -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 * scic_sds_port_construct_dummy_rnc() - create dummy rnc for si workaround
* *
...@@ -595,7 +567,6 @@ enum sci_status scic_port_get_properties( ...@@ -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_sas_address(port, &prop->local.sas_address);
scic_sds_port_get_protocols(port, &prop->local.protocols); 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_sas_address(port, &prop->remote.sas_address);
scic_sds_port_get_attached_protocols(port, &prop->remote.protocols);
return SCI_SUCCESS; return SCI_SUCCESS;
} }
...@@ -655,14 +626,10 @@ static void scic_sds_port_activate_phy(struct scic_sds_port *sci_port, ...@@ -655,14 +626,10 @@ static void scic_sds_port_activate_phy(struct scic_sds_port *sci_port,
struct scic_sds_phy *sci_phy, struct scic_sds_phy *sci_phy,
bool do_notify_user) bool do_notify_user)
{ {
struct scic_sds_controller *scic = scic_sds_port_get_controller(sci_port); struct scic_sds_controller *scic = sci_port->owning_controller;
struct sci_sas_identify_address_frame_protocols protocols;
struct isci_host *ihost = scic->ihost; struct isci_host *ihost = scic->ihost;
scic_sds_phy_get_attached_phy_protocols(sci_phy, &protocols); if (sci_phy->protocol != SCIC_SDS_PHY_PROTOCOL_SATA)
/* If this is sata port then the phy has already been resumed */
if (!protocols.u.bits.stp_target)
scic_sds_phy_resume(sci_phy); scic_sds_phy_resume(sci_phy);
sci_port->active_phy_mask |= 1 << sci_phy->phy_index; sci_port->active_phy_mask |= 1 << sci_phy->phy_index;
...@@ -803,15 +770,9 @@ bool scic_sds_port_link_detected( ...@@ -803,15 +770,9 @@ bool scic_sds_port_link_detected(
struct scic_sds_port *sci_port, struct scic_sds_port *sci_port,
struct scic_sds_phy *sci_phy) struct scic_sds_phy *sci_phy)
{ {
struct sci_sas_identify_address_frame_protocols protocols; if ((sci_port->logical_port_index != SCIC_SDS_DUMMY_PORT) &&
(sci_phy->protocol == SCIC_SDS_PHY_PROTOCOL_SATA) &&
scic_sds_phy_get_attached_phy_protocols(sci_phy, &protocols); scic_sds_port_is_wide(sci_port)) {
if (
(sci_port->logical_port_index != SCIC_SDS_DUMMY_PORT)
&& (protocols.u.bits.stp_target)
&& scic_sds_port_is_wide(sci_port)
) {
scic_sds_port_invalid_link_up(sci_port, sci_phy); scic_sds_port_invalid_link_up(sci_port, sci_phy);
return false; return false;
......
...@@ -187,7 +187,7 @@ void isci_port_link_up( ...@@ -187,7 +187,7 @@ void isci_port_link_up(
scic_port_get_properties(port, &properties); 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; u64 attached_sas_address;
isci_phy->sas_phy.oob_mode = SATA_OOB_MODE; isci_phy->sas_phy.oob_mode = SATA_OOB_MODE;
...@@ -207,9 +207,7 @@ void isci_port_link_up( ...@@ -207,9 +207,7 @@ void isci_port_link_up(
memcpy(&isci_phy->sas_phy.attached_sas_addr, memcpy(&isci_phy->sas_phy.attached_sas_addr,
&attached_sas_address, sizeof(attached_sas_address)); &attached_sas_address, sizeof(attached_sas_address));
} else if (phy->protocol == SCIC_SDS_PHY_PROTOCOL_SAS) {
} else if (properties.remote.protocols.u.bits.ssp_target ||
properties.remote.protocols.u.bits.smp_target) {
isci_phy->sas_phy.oob_mode = SAS_OOB_MODE; isci_phy->sas_phy.oob_mode = SAS_OOB_MODE;
isci_phy->sas_phy.frame_rcvd_size = sizeof(struct sas_identify_frame); isci_phy->sas_phy.frame_rcvd_size = sizeof(struct sas_identify_frame);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment