2011-07-02 22:56:22 -07:00
/*
* This file is provided under a dual BSD / GPLv2 license . When using or
* redistributing this file , you may do so under either license .
*
* GPL LICENSE SUMMARY
*
* Copyright ( c ) 2008 - 2011 Intel Corporation . All rights reserved .
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation .
*
* This program is distributed in the hope that it will be useful , but
* WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin St - Fifth Floor , Boston , MA 02110 - 1301 USA .
* The full GNU General Public License is included in this distribution
* in the file called LICENSE . GPL .
*
* BSD LICENSE
*
* Copyright ( c ) 2008 - 2011 Intel Corporation . All rights reserved .
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
*
* * Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
* * Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in
* the documentation and / or other materials provided with the
* distribution .
* * Neither the name of Intel Corporation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission .
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT , INDIRECT , INCIDENTAL ,
* SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT
* LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*/
2011-05-08 15:49:15 -07:00
# ifndef _SCI_HOST_H_
2011-07-02 22:56:22 -07:00
# define _SCI_HOST_H_
2012-02-01 00:23:10 -08:00
# include <scsi/sas_ata.h>
2011-07-02 22:56:22 -07:00
# include "remote_device.h"
2011-05-08 15:49:15 -07:00
# include "phy.h"
2011-06-02 00:10:50 +00:00
# include "isci.h"
2011-05-08 17:34:44 -07:00
# include "remote_node_table.h"
2011-05-08 21:36:46 -07:00
# include "registers.h"
# include "unsolicited_frame_control.h"
2011-05-10 02:28:46 -07:00
# include "probe_roms.h"
2011-05-08 17:34:44 -07:00
2011-06-27 14:57:03 -07:00
struct isci_request ;
2011-05-08 17:34:44 -07:00
struct scu_task_context ;
2011-05-10 02:28:46 -07:00
2011-05-08 17:34:44 -07:00
/**
2011-06-30 19:14:33 -07:00
* struct sci_power_control -
2011-05-08 17:34:44 -07:00
*
* This structure defines the fields for managing power control for direct
* attached disk devices .
*/
2011-06-30 19:14:33 -07:00
struct sci_power_control {
2011-05-08 17:34:44 -07:00
/**
* This field is set when the power control timer is running and cleared when
* it is not .
*/
bool timer_started ;
/**
2011-05-19 20:17:47 -07:00
* Timer to control when the directed attached disks can consume power .
2011-05-08 17:34:44 -07:00
*/
2011-05-19 20:17:47 -07:00
struct sci_timer timer ;
2011-05-08 17:34:44 -07:00
/**
* This field is used to keep track of how many phys are put into the
* requesters field .
*/
u8 phys_waiting ;
/**
* This field is used to keep track of how many phys have been granted to consume power
*/
u8 phys_granted_power ;
/**
* This field is an array of phys that we are waiting on . The phys are direct
2011-06-30 19:14:33 -07:00
* mapped into requesters via struct sci_phy . phy_index
2011-05-08 17:34:44 -07:00
*/
2011-06-28 15:05:53 -07:00
struct isci_phy * requesters [ SCI_MAX_PHYS ] ;
2011-05-08 17:34:44 -07:00
} ;
2011-06-30 19:14:33 -07:00
struct sci_port_configuration_agent ;
2011-06-30 17:38:32 -07:00
typedef void ( * port_config_fn ) ( struct isci_host * ,
2011-06-30 19:14:33 -07:00
struct sci_port_configuration_agent * ,
2011-06-29 13:09:25 -07:00
struct isci_port * , struct isci_phy * ) ;
2012-02-29 01:07:56 -08:00
bool is_port_config_apc ( struct isci_host * ihost ) ;
bool is_controller_start_complete ( struct isci_host * ihost ) ;
2011-05-10 02:28:46 -07:00
2011-06-30 19:14:33 -07:00
struct sci_port_configuration_agent {
2011-05-10 02:28:46 -07:00
u16 phy_configured_mask ;
u16 phy_ready_mask ;
struct {
u8 min_index ;
u8 max_index ;
} phy_valid_port_range [ SCI_MAX_PHYS ] ;
bool timer_pending ;
port_config_fn link_up_handler ;
port_config_fn link_down_handler ;
2011-05-19 20:00:51 -07:00
struct sci_timer timer ;
2011-05-10 02:28:46 -07:00
} ;
2011-05-08 17:34:44 -07:00
/**
2011-06-30 17:38:32 -07:00
* isci_host - primary host / controller object
* @ timer : timeout start / stop operations
* @ device_table : rni ( hw remote node index ) to remote device lookup table
* @ available_remote_nodes : rni allocator
* @ power_control : manage device spin up
* @ io_request_sequence : generation number for tci ' s ( task contexts )
* @ task_context_table : hw task context table
* @ remote_node_context_table : hw remote node context table
* @ completion_queue : hw - producer driver - consumer communication ring
* @ completion_queue_get : tracks the driver ' head ' of the ring to notify hw
* @ logical_port_entries : min ( { driver | silicon } - supported - port - count )
* @ remote_node_entries : min ( { driver | silicon } - supported - node - count )
* @ task_context_entries : min ( { driver | silicon } - supported - task - count )
* @ phy_timer : phy startup timer
* @ invalid_phy_mask : if an invalid_link_up notification is reported a bit for
* the phy index is set so further notifications are not
* made . Once the phy reports link up and is made part of a
* port then this bit is cleared .
2011-05-08 17:34:44 -07:00
*/
2011-06-30 17:38:32 -07:00
struct isci_host {
2011-06-02 00:10:43 +00:00
struct sci_base_state_machine sm ;
2011-06-30 17:38:32 -07:00
/* XXX can we time this externally */
2011-05-19 11:59:56 +00:00
struct sci_timer timer ;
2011-06-30 17:38:32 -07:00
/* XXX drop reference module params directly */
2011-06-30 19:14:33 -07:00
struct sci_user_parameters user_parameters ;
2011-06-30 17:38:32 -07:00
/* XXX no need to be a union */
2011-06-30 19:14:33 -07:00
struct sci_oem_params oem_parameters ;
struct sci_port_configuration_agent port_agent ;
2011-06-30 16:31:37 -07:00
struct isci_remote_device * device_table [ SCI_MAX_REMOTE_DEVICES ] ;
2011-06-30 19:14:33 -07:00
struct sci_remote_node_table available_remote_nodes ;
struct sci_power_control power_control ;
2011-06-09 11:06:58 -07:00
u8 io_request_sequence [ SCI_MAX_IO_REQUESTS ] ;
2011-05-08 17:34:44 -07:00
struct scu_task_context * task_context_table ;
2012-02-15 13:58:42 -08:00
dma_addr_t tc_dma ;
2011-05-08 17:34:44 -07:00
union scu_remote_node_context * remote_node_context_table ;
2012-02-15 13:58:42 -08:00
dma_addr_t rnc_dma ;
2011-05-08 17:34:44 -07:00
u32 * completion_queue ;
2012-02-15 13:58:42 -08:00
dma_addr_t cq_dma ;
2011-05-08 17:34:44 -07:00
u32 completion_queue_get ;
u32 logical_port_entries ;
u32 remote_node_entries ;
u32 task_context_entries ;
2012-02-15 13:58:42 -08:00
void * ufi_buf ;
dma_addr_t ufi_dma ;
2011-06-30 19:14:33 -07:00
struct sci_unsolicited_frame_control uf_control ;
2011-05-08 17:34:44 -07:00
2011-06-30 17:38:32 -07:00
/* phy startup */
2011-05-19 20:26:02 -07:00
struct sci_timer phy_timer ;
2011-06-30 17:38:32 -07:00
/* XXX kill */
2011-05-08 17:34:44 -07:00
bool phy_startup_timer_pending ;
u32 next_phy_to_start ;
2011-07-01 02:25:15 -07:00
/* XXX convert to unsigned long and use bitops */
2011-05-08 17:34:44 -07:00
u8 invalid_phy_mask ;
2011-06-30 17:38:32 -07:00
/* TODO attempt dynamic interrupt coalescing scheme */
2011-05-08 17:34:44 -07:00
u16 interrupt_coalesce_number ;
u32 interrupt_coalesce_timeout ;
struct smu_registers __iomem * smu_registers ;
struct scu_registers __iomem * scu_registers ;
2011-06-07 18:50:55 -07:00
u16 tci_head ;
u16 tci_tail ;
u16 tci_pool [ SCI_MAX_IO_REQUESTS ] ;
2011-07-02 22:56:22 -07:00
int id ; /* unique within a given pci device */
struct isci_phy phys [ SCI_MAX_PHYS ] ;
2011-05-07 10:11:43 -07:00
struct isci_port ports [ SCI_MAX_PORTS + 1 ] ; /* includes dummy port */
2012-01-03 23:26:08 -08:00
struct asd_sas_port sas_ports [ SCI_MAX_PORTS ] ;
2011-07-02 22:56:22 -07:00
struct sas_ha_struct sas_ha ;
struct pci_dev * pdev ;
2011-02-18 09:25:07 -08:00
# define IHOST_START_PENDING 0
# define IHOST_STOP_PENDING 1
2012-03-01 17:06:24 -08:00
# define IHOST_IRQ_ENABLED 2
2011-02-18 09:25:07 -08:00
unsigned long flags ;
wait_queue_head_t eventq ;
2011-07-02 22:56:22 -07:00
struct tasklet_struct completion_tasklet ;
struct list_head requests_to_complete ;
spinlock_t scic_lock ;
2011-06-17 14:18:39 -07:00
struct isci_request * reqs [ SCI_MAX_IO_REQUESTS ] ;
2011-04-21 18:14:45 -07:00
struct isci_remote_device devices [ SCI_MAX_REMOTE_DEVICES ] ;
2011-07-02 22:56:22 -07:00
} ;
2011-05-08 17:34:44 -07:00
/**
2011-06-30 19:14:33 -07:00
* enum sci_controller_states - This enumeration depicts all the states
2011-05-08 17:34:44 -07:00
* for the common controller state machine .
*/
2011-06-30 19:14:33 -07:00
enum sci_controller_states {
2011-05-08 17:34:44 -07:00
/**
* Simply the initial state for the base controller state machine .
*/
2011-06-02 00:10:43 +00:00
SCIC_INITIAL = 0 ,
2011-05-08 17:34:44 -07:00
/**
* This state indicates that the controller is reset . The memory for
* the controller is in it ' s initial state , but the controller requires
* initialization .
* This state is entered from the INITIAL state .
* This state is entered from the RESETTING state .
*/
2011-06-02 00:10:43 +00:00
SCIC_RESET ,
2011-05-08 17:34:44 -07:00
/**
* This state is typically an action state that indicates the controller
* is in the process of initialization . In this state no new IO operations
* are permitted .
* This state is entered from the RESET state .
*/
2011-06-02 00:10:43 +00:00
SCIC_INITIALIZING ,
2011-05-08 17:34:44 -07:00
/**
* This state indicates that the controller has been successfully
* initialized . In this state no new IO operations are permitted .
* This state is entered from the INITIALIZING state .
*/
2011-06-02 00:10:43 +00:00
SCIC_INITIALIZED ,
2011-05-08 17:34:44 -07:00
/**
* This state indicates the the controller is in the process of becoming
* ready ( i . e . starting ) . In this state no new IO operations are permitted .
* This state is entered from the INITIALIZED state .
*/
2011-06-02 00:10:43 +00:00
SCIC_STARTING ,
2011-05-08 17:34:44 -07:00
/**
* This state indicates the controller is now ready . Thus , the user
* is able to perform IO operations on the controller .
* This state is entered from the STARTING state .
*/
2011-06-02 00:10:43 +00:00
SCIC_READY ,
2011-05-08 17:34:44 -07:00
/**
* This state is typically an action state that indicates the controller
* is in the process of resetting . Thus , the user is unable to perform
* IO operations on the controller . A reset is considered destructive in
* most cases .
* This state is entered from the READY state .
* This state is entered from the FAILED state .
* This state is entered from the STOPPED state .
*/
2011-06-02 00:10:43 +00:00
SCIC_RESETTING ,
2011-05-08 17:34:44 -07:00
/**
* This state indicates that the controller is in the process of stopping .
* In this state no new IO operations are permitted , but existing IO
* operations are allowed to complete .
* This state is entered from the READY state .
*/
2011-06-02 00:10:43 +00:00
SCIC_STOPPING ,
2011-05-08 17:34:44 -07:00
/**
* This state indicates that the controller could not successfully be
* initialized . In this state no new IO operations are permitted .
* This state is entered from the INITIALIZING state .
* This state is entered from the STARTING state .
* This state is entered from the STOPPING state .
* This state is entered from the RESETTING state .
*/
2011-06-02 00:10:43 +00:00
SCIC_FAILED ,
2011-05-08 17:34:44 -07:00
} ;
2011-07-02 22:56:22 -07:00
/**
* struct isci_pci_info - This class represents the pci function containing the
* controllers . Depending on PCI SKU , there could be up to 2 controllers in
* the PCI function .
*/
# define SCI_MAX_MSIX_INT (SCI_NUM_MSI_X_INT*SCI_MAX_CONTROLLERS)
struct isci_pci_info {
struct msix_entry msix_entries [ SCI_MAX_MSIX_INT ] ;
2011-03-07 16:02:25 -08:00
struct isci_host * hosts [ SCI_MAX_CONTROLLERS ] ;
2011-03-08 09:52:49 -08:00
struct isci_orom * orom ;
2011-07-02 22:56:22 -07:00
} ;
static inline struct isci_pci_info * to_pci_info ( struct pci_dev * pdev )
{
return pci_get_drvdata ( pdev ) ;
}
2012-02-25 14:29:49 -08:00
static inline struct Scsi_Host * to_shost ( struct isci_host * ihost )
{
return ihost - > sas_ha . core . shost ;
}
2011-03-07 16:02:25 -08:00
# define for_each_isci_host(id, ihost, pdev) \
for ( id = 0 , ihost = to_pci_info ( pdev ) - > hosts [ id ] ; \
id < ARRAY_SIZE ( to_pci_info ( pdev ) - > hosts ) & & ihost ; \
ihost = to_pci_info ( pdev ) - > hosts [ + + id ] )
2011-07-02 22:56:22 -07:00
2011-02-18 09:25:07 -08:00
static inline void wait_for_start ( struct isci_host * ihost )
{
wait_event ( ihost - > eventq , ! test_bit ( IHOST_START_PENDING , & ihost - > flags ) ) ;
}
static inline void wait_for_stop ( struct isci_host * ihost )
{
wait_event ( ihost - > eventq , ! test_bit ( IHOST_STOP_PENDING , & ihost - > flags ) ) ;
}
2011-03-04 12:10:29 -08:00
static inline void wait_for_device_start ( struct isci_host * ihost , struct isci_remote_device * idev )
{
wait_event ( ihost - > eventq , ! test_bit ( IDEV_START_PENDING , & idev - > flags ) ) ;
}
static inline void wait_for_device_stop ( struct isci_host * ihost , struct isci_remote_device * idev )
{
2011-03-03 17:59:32 -08:00
wait_event ( ihost - > eventq , ! test_bit ( IDEV_STOP_PENDING , & idev - > flags ) ) ;
2011-03-04 12:10:29 -08:00
}
2011-02-18 09:25:07 -08:00
2011-03-31 13:10:44 -07:00
static inline struct isci_host * dev_to_ihost ( struct domain_device * dev )
{
return dev - > port - > ha - > lldd_ha ;
}
2011-07-02 22:56:22 -07:00
2011-07-01 02:25:15 -07:00
/* we always use protocol engine group zero */
# define ISCI_PEG 0
2011-07-02 22:56:22 -07:00
2011-06-30 19:14:33 -07:00
/* see sci_controller_io_tag_allocate|free for how seq and tci are built */
2011-06-09 11:06:58 -07:00
# define ISCI_TAG(seq, tci) (((u16) (seq)) << 12 | tci)
2011-05-08 17:34:44 -07:00
2011-06-09 11:06:58 -07:00
/* these are returned by the hardware, so sanitize them */
# define ISCI_TAG_SEQ(tag) (((tag) >> 12) & (SCI_MAX_SEQ-1))
# define ISCI_TAG_TCI(tag) ((tag) & (SCI_MAX_IO_REQUESTS-1))
2011-05-08 17:34:44 -07:00
2011-07-29 17:17:10 -07:00
/* interrupt coalescing baseline: 9 == 3 to 5us interrupt delay per command */
# define ISCI_COALESCE_BASE 9
2011-05-08 17:34:44 -07:00
/* expander attached sata devices require 3 rnc slots */
2011-06-30 19:14:33 -07:00
static inline int sci_remote_device_node_count ( struct isci_remote_device * idev )
2011-05-08 17:34:44 -07:00
{
2011-06-30 16:31:37 -07:00
struct domain_device * dev = idev - > domain_dev ;
2011-05-08 17:34:44 -07:00
2012-02-01 00:23:10 -08:00
if ( dev_is_sata ( dev ) & & dev - > parent )
2011-05-08 17:34:44 -07:00
return SCU_STP_REMOTE_NODE_COUNT ;
return SCU_SSP_REMOTE_NODE_COUNT ;
}
/**
2011-06-30 19:14:33 -07:00
* sci_controller_clear_invalid_phy ( ) -
2011-05-08 17:34:44 -07:00
*
* This macro will clear the bit in the invalid phy mask for this controller
* object . This is used to control messages reported for invalid link up
* notifications .
*/
2011-06-30 19:14:33 -07:00
# define sci_controller_clear_invalid_phy(controller, phy) \
2011-05-08 17:34:44 -07:00
( ( controller ) - > invalid_phy_mask & = ~ ( 1 < < ( phy ) - > phy_index ) )
2011-06-30 16:31:37 -07:00
static inline struct device * scirdev_to_dev ( struct isci_remote_device * idev )
2011-05-08 17:34:44 -07:00
{
if ( ! idev | | ! idev - > isci_port | | ! idev - > isci_port - > isci_host )
return NULL ;
return & idev - > isci_port - > isci_host - > pdev - > dev ;
}
2011-07-01 11:41:21 -07:00
static inline bool is_a2 ( struct pci_dev * pdev )
2011-05-08 17:34:44 -07:00
{
2011-07-01 11:41:21 -07:00
if ( pdev - > revision < 4 )
return true ;
return false ;
2011-05-08 17:34:44 -07:00
}
2011-07-01 11:41:21 -07:00
static inline bool is_b0 ( struct pci_dev * pdev )
2011-05-08 17:34:44 -07:00
{
2011-07-01 11:41:21 -07:00
if ( pdev - > revision = = 4 )
return true ;
return false ;
2011-06-01 22:31:03 +00:00
}
2011-07-01 11:41:21 -07:00
static inline bool is_c0 ( struct pci_dev * pdev )
2011-06-01 22:31:03 +00:00
{
2012-01-04 01:32:39 -08:00
if ( pdev - > revision = = 5 )
return true ;
return false ;
}
static inline bool is_c1 ( struct pci_dev * pdev )
{
if ( pdev - > revision > = 6 )
2011-07-01 11:41:21 -07:00
return true ;
return false ;
2011-05-08 17:34:44 -07:00
}
2012-01-04 01:32:49 -08:00
enum cable_selections {
short_cable = 0 ,
long_cable = 1 ,
medium_cable = 2 ,
undefined_cable = 3
} ;
# define CABLE_OVERRIDE_DISABLED (0x10000)
static inline int is_cable_select_overridden ( void )
{
return cable_selection_override < CABLE_OVERRIDE_DISABLED ;
}
enum cable_selections decode_cable_selection ( struct isci_host * ihost , int phy ) ;
void validate_cable_selections ( struct isci_host * ihost ) ;
char * lookup_cable_names ( enum cable_selections ) ;
2011-09-01 21:18:31 -07:00
/* set hw control for 'activity', even though active enclosures seem to drive
* the activity led on their own . Skip setting FSENG control on ' status ' due
* to unexpected operation and ' error ' due to not being a supported automatic
* FSENG output
*/
# define SGPIO_HW_CONTROL 0x00000443
static inline int isci_gpio_count ( struct isci_host * ihost )
{
return ARRAY_SIZE ( ihost - > scu_registers - > peg0 . sgpio . output_data_select ) ;
}
2011-06-30 19:14:33 -07:00
void sci_controller_post_request ( struct isci_host * ihost ,
2011-05-08 17:34:44 -07:00
u32 request ) ;
2011-06-30 19:14:33 -07:00
void sci_controller_release_frame ( struct isci_host * ihost ,
2011-05-08 17:34:44 -07:00
u32 frame_index ) ;
2011-06-30 19:14:33 -07:00
void sci_controller_copy_sata_response ( void * response_buffer ,
2011-05-08 17:34:44 -07:00
void * frame_header ,
void * frame_buffer ) ;
2011-06-30 19:14:33 -07:00
enum sci_status sci_controller_allocate_remote_node_context ( struct isci_host * ihost ,
2011-06-30 16:31:37 -07:00
struct isci_remote_device * idev ,
2011-05-08 17:34:44 -07:00
u16 * node_id ) ;
2011-06-30 19:14:33 -07:00
void sci_controller_free_remote_node_context (
2011-06-30 17:38:32 -07:00
struct isci_host * ihost ,
2011-06-30 16:31:37 -07:00
struct isci_remote_device * idev ,
2011-05-08 17:34:44 -07:00
u16 node_id ) ;
2012-02-15 13:58:42 -08:00
struct isci_request * sci_request_by_tag ( struct isci_host * ihost , u16 io_tag ) ;
void sci_controller_power_control_queue_insert ( struct isci_host * ihost ,
struct isci_phy * iphy ) ;
void sci_controller_power_control_queue_remove ( struct isci_host * ihost ,
struct isci_phy * iphy ) ;
void sci_controller_link_up ( struct isci_host * ihost , struct isci_port * iport ,
struct isci_phy * iphy ) ;
void sci_controller_link_down ( struct isci_host * ihost , struct isci_port * iport ,
struct isci_phy * iphy ) ;
void sci_controller_remote_device_stopped ( struct isci_host * ihost ,
struct isci_remote_device * idev ) ;
2011-05-08 17:34:44 -07:00
2011-06-30 19:14:33 -07:00
enum sci_status sci_controller_continue_io ( struct isci_request * ireq ) ;
2011-05-08 17:34:44 -07:00
int isci_host_scan_finished ( struct Scsi_Host * , unsigned long ) ;
void isci_host_scan_start ( struct Scsi_Host * ) ;
2011-06-28 13:47:09 -07:00
u16 isci_alloc_tag ( struct isci_host * ihost ) ;
enum sci_status isci_free_tag ( struct isci_host * ihost , u16 io_tag ) ;
void isci_tci_free ( struct isci_host * ihost , u16 tci ) ;
2011-07-02 22:56:22 -07:00
int isci_host_init ( struct isci_host * ) ;
2012-02-15 13:58:42 -08:00
void isci_host_completion_routine ( unsigned long data ) ;
void isci_host_deinit ( struct isci_host * ) ;
void sci_controller_disable_interrupts ( struct isci_host * ihost ) ;
2012-02-23 01:12:10 -08:00
bool sci_controller_has_remote_devices_stopping ( struct isci_host * ihost ) ;
2012-02-29 01:07:56 -08:00
void sci_controller_transition_to_ready ( struct isci_host * ihost , enum sci_status status ) ;
2011-05-08 17:34:44 -07:00
2011-06-30 19:14:33 -07:00
enum sci_status sci_controller_start_io (
2011-06-30 17:38:32 -07:00
struct isci_host * ihost ,
2011-06-30 16:31:37 -07:00
struct isci_remote_device * idev ,
2011-06-27 14:57:03 -07:00
struct isci_request * ireq ) ;
2011-05-08 17:34:44 -07:00
2011-06-30 19:14:33 -07:00
enum sci_task_status sci_controller_start_task (
2011-06-30 17:38:32 -07:00
struct isci_host * ihost ,
2011-06-30 16:31:37 -07:00
struct isci_remote_device * idev ,
2011-06-27 14:57:03 -07:00
struct isci_request * ireq ) ;
2011-05-08 17:34:44 -07:00
2011-06-30 19:14:33 -07:00
enum sci_status sci_controller_terminate_request (
2011-06-30 17:38:32 -07:00
struct isci_host * ihost ,
2011-06-30 16:31:37 -07:00
struct isci_remote_device * idev ,
2011-06-27 14:57:03 -07:00
struct isci_request * ireq ) ;
2011-05-08 17:34:44 -07:00
2011-06-30 19:14:33 -07:00
enum sci_status sci_controller_complete_io (
2011-06-30 17:38:32 -07:00
struct isci_host * ihost ,
2011-06-30 16:31:37 -07:00
struct isci_remote_device * idev ,
2011-06-27 14:57:03 -07:00
struct isci_request * ireq ) ;
2011-05-08 17:34:44 -07:00
2011-06-30 19:14:33 -07:00
void sci_port_configuration_agent_construct (
struct sci_port_configuration_agent * port_agent ) ;
2011-05-10 02:28:46 -07:00
2011-06-30 19:14:33 -07:00
enum sci_status sci_port_configuration_agent_initialize (
2011-06-30 17:38:32 -07:00
struct isci_host * ihost ,
2011-06-30 19:14:33 -07:00
struct sci_port_configuration_agent * port_agent ) ;
2011-09-01 21:18:31 -07:00
int isci_gpio_write ( struct sas_ha_struct * , u8 reg_type , u8 reg_index ,
u8 reg_count , u8 * write_data ) ;
2011-05-08 17:34:44 -07:00
# endif