sci_dev->rnc.remote_node_index = remote_node_index;
- scic_sds_port_get_attached_sas_address(sci_port, &sci_dev->device_address);
-
if (dev->dev_type == SAS_END_DEV)
sci_dev->has_ready_substate_machine = false;
else if (dev->dev_type == SATA_DEV || (dev->tproto & SAS_PROTOCOL_STP)) {
enum sci_status status;
scic_remote_device_construct(sci_port, sci_dev);
- memcpy(&sci_dev->device_address, dev->sas_addr, SAS_ADDR_SIZE);
status = scic_sds_controller_allocate_remote_node_context(
scic, sci_dev, &sci_dev->rnc.remote_node_index);
*/
enum sas_linkrate connection_rate;
- /**
- * This field contains the device SAS address.
- */
- struct sci_sas_address device_address;
-
/**
* This filed is assinged the value of true if the device is directly
* attached to the port.
struct domain_device *dev = sci_dev_to_domain(sci_dev);
union scu_remote_node_context *rnc;
struct scic_sds_controller *scic;
+ __le64 sas_addr;
scic = scic_sds_remote_device_get_controller(sci_dev);
rnc->ssp.logical_port_index =
scic_sds_remote_device_get_port_index(sci_dev);
- /* address is always big endian, destination is always little */
- rnc->ssp.remote_sas_address_hi = swab32(sci_dev->device_address.high);
- rnc->ssp.remote_sas_address_lo = swab32(sci_dev->device_address.low);
+ /* sas address is __be64, context ram format is __le64 */
+ sas_addr = cpu_to_le64(SAS_ADDR(dev->sas_addr));
+ rnc->ssp.remote_sas_address_hi = upper_32_bits(sas_addr);
+ rnc->ssp.remote_sas_address_lo = lower_32_bits(sas_addr);
rnc->ssp.nexus_loss_timer_enable = true;
rnc->ssp.check_bit = false;