root/drivers/scsi/ips.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. ips_setup
  2. ips_detect
  3. ips_setup_funclist
  4. ips_release
  5. ips_halt
  6. ips_eh_abort
  7. __ips_eh_reset
  8. ips_eh_reset
  9. ips_queue_lck
  10. DEF_SCSI_QCMD
  11. ips_slave_configure
  12. do_ipsintr
  13. ips_intr_copperhead
  14. ips_intr_morpheus
  15. ips_info
  16. ips_write_info
  17. ips_show_info
  18. ips_is_passthru
  19. ips_alloc_passthru_buffer
  20. ips_make_passthru
  21. ips_flash_copperhead
  22. ips_flash_bios
  23. ips_fill_scb_sg_single
  24. ips_flash_firmware
  25. ips_free_flash_copperhead
  26. ips_usrcmd
  27. ips_cleanup_passthru
  28. ips_host_info
  29. ips_identify_controller
  30. ips_get_bios_version
  31. ips_hainit
  32. ips_next
  33. ips_putq_scb_head
  34. ips_removeq_scb_head
  35. ips_removeq_scb
  36. ips_putq_wait_tail
  37. ips_removeq_wait_head
  38. ips_removeq_wait
  39. ips_putq_copp_tail
  40. ips_removeq_copp_head
  41. ips_removeq_copp
  42. ipsintr_blocking
  43. ipsintr_done
  44. ips_done
  45. ips_map_status
  46. ips_send_wait
  47. ips_scmd_buf_write
  48. ips_scmd_buf_read
  49. ips_send_cmd
  50. ips_chkstatus
  51. ips_online
  52. ips_inquiry
  53. ips_rdcap
  54. ips_msense
  55. ips_reqsen
  56. ips_free
  57. ips_deallocatescbs
  58. ips_allocatescbs
  59. ips_init_scb
  60. ips_getscb
  61. ips_freescb
  62. ips_isinit_copperhead
  63. ips_isinit_copperhead_memio
  64. ips_isinit_morpheus
  65. ips_flush_and_reset
  66. ips_poll_for_flush_complete
  67. ips_enable_int_copperhead
  68. ips_enable_int_copperhead_memio
  69. ips_enable_int_morpheus
  70. ips_init_copperhead
  71. ips_init_copperhead_memio
  72. ips_init_morpheus
  73. ips_reset_copperhead
  74. ips_reset_copperhead_memio
  75. ips_reset_morpheus
  76. ips_statinit
  77. ips_statinit_memio
  78. ips_statupd_copperhead
  79. ips_statupd_copperhead_memio
  80. ips_statupd_morpheus
  81. ips_issue_copperhead
  82. ips_issue_copperhead_memio
  83. ips_issue_i2o
  84. ips_issue_i2o_memio
  85. ips_isintr_copperhead
  86. ips_isintr_copperhead_memio
  87. ips_isintr_morpheus
  88. ips_wait
  89. ips_write_driver_status
  90. ips_read_adapter_status
  91. ips_read_subsystem_parameters
  92. ips_read_config
  93. ips_readwrite_page5
  94. ips_clear_adapter
  95. ips_ffdc_reset
  96. ips_ffdc_time
  97. ips_fix_ffdc_time
  98. ips_erase_bios
  99. ips_erase_bios_memio
  100. ips_program_bios
  101. ips_program_bios_memio
  102. ips_verify_bios
  103. ips_verify_bios_memio
  104. ips_abort_init
  105. ips_shift_controllers
  106. ips_order_controllers
  107. ips_register_scsi
  108. ips_remove_device
  109. ips_module_init
  110. ips_module_exit
  111. ips_insert_device
  112. ips_init_phase1
  113. ips_init_phase2

   1 /*****************************************************************************/
   2 /* ips.c -- driver for the Adaptec / IBM ServeRAID controller                */
   3 /*                                                                           */
   4 /* Written By: Keith Mitchell, IBM Corporation                               */
   5 /*             Jack Hammer, Adaptec, Inc.                                    */
   6 /*             David Jeffery, Adaptec, Inc.                                  */
   7 /*                                                                           */
   8 /* Copyright (C) 2000 IBM Corporation                                        */
   9 /* Copyright (C) 2002,2003 Adaptec, Inc.                                     */
  10 /*                                                                           */
  11 /* This program is free software; you can redistribute it and/or modify      */
  12 /* it under the terms of the GNU General Public License as published by      */
  13 /* the Free Software Foundation; either version 2 of the License, or         */
  14 /* (at your option) any later version.                                       */
  15 /*                                                                           */
  16 /* This program is distributed in the hope that it will be useful,           */
  17 /* but WITHOUT ANY WARRANTY; without even the implied warranty of            */
  18 /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the             */
  19 /* GNU General Public License for more details.                              */
  20 /*                                                                           */
  21 /* NO WARRANTY                                                               */
  22 /* THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR        */
  23 /* CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT      */
  24 /* LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,      */
  25 /* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is    */
  26 /* solely responsible for determining the appropriateness of using and       */
  27 /* distributing the Program and assumes all risks associated with its        */
  28 /* exercise of rights under this Agreement, including but not limited to     */
  29 /* the risks and costs of program errors, damage to or loss of data,         */
  30 /* programs or equipment, and unavailability or interruption of operations.  */
  31 /*                                                                           */
  32 /* DISCLAIMER OF LIABILITY                                                   */
  33 /* NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY   */
  34 /* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL        */
  35 /* DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND   */
  36 /* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR     */
  37 /* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE    */
  38 /* USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED  */
  39 /* HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES             */
  40 /*                                                                           */
  41 /* You should have received a copy of the GNU General Public License         */
  42 /* along with this program; if not, write to the Free Software               */
  43 /* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  44 /*                                                                           */
  45 /* Bugs/Comments/Suggestions about this driver should be mailed to:          */
  46 /*      ipslinux@adaptec.com                                                 */
  47 /*                                                                           */
  48 /* For system support issues, contact your local IBM Customer support.       */
  49 /* Directions to find IBM Customer Support for each country can be found at: */
  50 /*      http://www.ibm.com/planetwide/                                       */
  51 /*                                                                           */
  52 /*****************************************************************************/
  53 
  54 /*****************************************************************************/
  55 /* Change Log                                                                */
  56 /*                                                                           */
  57 /* 0.99.02  - Breakup commands that are bigger than 8 * the stripe size      */
  58 /* 0.99.03  - Make interrupt routine handle all completed request on the     */
  59 /*            adapter not just the first one                                 */
  60 /*          - Make sure passthru commands get woken up if we run out of      */
  61 /*            SCBs                                                           */
  62 /*          - Send all of the commands on the queue at once rather than      */
  63 /*            one at a time since the card will support it.                  */
  64 /* 0.99.04  - Fix race condition in the passthru mechanism -- this required  */
  65 /*            the interface to the utilities to change                       */
  66 /*          - Fix error recovery code                                        */
  67 /* 0.99.05  - Fix an oops when we get certain passthru commands              */
  68 /* 1.00.00  - Initial Public Release                                         */
  69 /*            Functionally equivalent to 0.99.05                             */
  70 /* 3.60.00  - Bump max commands to 128 for use with firmware 3.60            */
  71 /*          - Change version to 3.60 to coincide with release numbering.     */
  72 /* 3.60.01  - Remove bogus error check in passthru routine                   */
  73 /* 3.60.02  - Make DCDB direction based on lookup table                      */
  74 /*          - Only allow one DCDB command to a SCSI ID at a time             */
  75 /* 4.00.00  - Add support for ServeRAID 4                                    */
  76 /* 4.00.01  - Add support for First Failure Data Capture                     */
  77 /* 4.00.02  - Fix problem with PT DCDB with no buffer                        */
  78 /* 4.00.03  - Add alternative passthru interface                             */
  79 /*          - Add ability to flash BIOS                                      */
  80 /* 4.00.04  - Rename structures/constants to be prefixed with IPS_           */
  81 /* 4.00.05  - Remove wish_block from init routine                            */
  82 /*          - Use linux/spinlock.h instead of asm/spinlock.h for kernels     */
  83 /*            2.3.18 and later                                               */
  84 /*          - Sync with other changes from the 2.3 kernels                   */
  85 /* 4.00.06  - Fix timeout with initial FFDC command                          */
  86 /* 4.00.06a - Port to 2.4 (trivial) -- Christoph Hellwig <hch@infradead.org> */
  87 /* 4.10.00  - Add support for ServeRAID 4M/4L                                */
  88 /* 4.10.13  - Fix for dynamic unload and proc file system                    */
  89 /* 4.20.03  - Rename version to coincide with new release schedules          */
  90 /*            Performance fixes                                              */
  91 /*            Fix truncation of /proc files with cat                         */
  92 /*            Merge in changes through kernel 2.4.0test1ac21                 */
  93 /* 4.20.13  - Fix some failure cases / reset code                            */
  94 /*          - Hook into the reboot_notifier to flush the controller cache    */
  95 /* 4.50.01  - Fix problem when there is a hole in logical drive numbering    */
  96 /* 4.70.09  - Use a Common ( Large Buffer ) for Flashing from the JCRM CD    */
  97 /*          - Add IPSSEND Flash Support                                      */
  98 /*          - Set Sense Data for Unknown SCSI Command                        */
  99 /*          - Use Slot Number from NVRAM Page 5                              */
 100 /*          - Restore caller's DCDB Structure                                */
 101 /* 4.70.12  - Corrective actions for bad controller ( during initialization )*/
 102 /* 4.70.13  - Don't Send CDB's if we already know the device is not present  */
 103 /*          - Don't release HA Lock in ips_next() until SC taken off queue   */
 104 /*          - Unregister SCSI device in ips_release()                        */
 105 /* 4.70.15  - Fix Breakup for very large ( non-SG ) requests in ips_done()   */
 106 /* 4.71.00  - Change all memory allocations to not use GFP_DMA flag          */
 107 /*            Code Clean-Up for 2.4.x kernel                                 */
 108 /* 4.72.00  - Allow for a Scatter-Gather Element to exceed MAX_XFER Size     */
 109 /* 4.72.01  - I/O Mapped Memory release ( so "insmod ips" does not Fail )    */
 110 /*          - Don't Issue Internal FFDC Command if there are Active Commands */
 111 /*          - Close Window for getting too many IOCTL's active               */
 112 /* 4.80.00  - Make ia64 Safe                                                 */
 113 /* 4.80.04  - Eliminate calls to strtok() if 2.4.x or greater                */
 114 /*          - Adjustments to Device Queue Depth                              */
 115 /* 4.80.14  - Take all semaphores off stack                                  */
 116 /*          - Clean Up New_IOCTL path                                        */
 117 /* 4.80.20  - Set max_sectors in Scsi_Host structure ( if >= 2.4.7 kernel )  */
 118 /*          - 5 second delay needed after resetting an i960 adapter          */
 119 /* 4.80.26  - Clean up potential code problems ( Arjan's recommendations )   */
 120 /* 4.90.01  - Version Matching for FirmWare, BIOS, and Driver                */
 121 /* 4.90.05  - Use New PCI Architecture to facilitate Hot Plug Development    */
 122 /* 4.90.08  - Increase Delays in Flashing ( Trombone Only - 4H )             */
 123 /* 4.90.08  - Data Corruption if First Scatter Gather Element is > 64K       */
 124 /* 4.90.11  - Don't actually RESET unless it's physically required           */
 125 /*          - Remove unused compile options                                  */
 126 /* 5.00.01  - Sarasota ( 5i ) adapters must always be scanned first          */
 127 /*          - Get rid on IOCTL_NEW_COMMAND code                              */
 128 /*          - Add Extended DCDB Commands for Tape Support in 5I              */
 129 /* 5.10.12  - use pci_dma interfaces, update for 2.5 kernel changes          */
 130 /* 5.10.15  - remove unused code (sem, macros, etc.)                         */
 131 /* 5.30.00  - use __devexit_p()                                              */
 132 /* 6.00.00  - Add 6x Adapters and Battery Flash                              */
 133 /* 6.10.00  - Remove 1G Addressing Limitations                               */
 134 /* 6.11.xx  - Get VersionInfo buffer off the stack !              DDTS 60401 */
 135 /* 6.11.xx  - Make Logical Drive Info structure safe for DMA      DDTS 60639 */
 136 /* 7.10.18  - Add highmem_io flag in SCSI Templete for 2.4 kernels           */
 137 /*          - Fix path/name for scsi_hosts.h include for 2.6 kernels         */
 138 /*          - Fix sort order of 7k                                           */
 139 /*          - Remove 3 unused "inline" functions                             */
 140 /* 7.12.xx  - Use STATIC functions wherever possible                        */
 141 /*          - Clean up deprecated MODULE_PARM calls                          */
 142 /* 7.12.05  - Remove Version Matching per IBM request                        */
 143 /*****************************************************************************/
 144 
 145 /*
 146  * Conditional Compilation directives for this driver:
 147  *
 148  * IPS_DEBUG            - Turn on debugging info
 149  *
 150  * Parameters:
 151  *
 152  * debug:<number>       - Set debug level to <number>
 153  *                        NOTE: only works when IPS_DEBUG compile directive is used.
 154  *       1              - Normal debug messages
 155  *       2              - Verbose debug messages
 156  *       11             - Method trace (non interrupt)
 157  *       12             - Method trace (includes interrupt)
 158  *
 159  * noi2o                - Don't use I2O Queues (ServeRAID 4 only)
 160  * nommap               - Don't use memory mapped I/O
 161  * ioctlsize            - Initial size of the IOCTL buffer
 162  */
 163 
 164 #include <asm/io.h>
 165 #include <asm/byteorder.h>
 166 #include <asm/page.h>
 167 #include <linux/stddef.h>
 168 #include <linux/string.h>
 169 #include <linux/errno.h>
 170 #include <linux/kernel.h>
 171 #include <linux/ioport.h>
 172 #include <linux/slab.h>
 173 #include <linux/delay.h>
 174 #include <linux/pci.h>
 175 #include <linux/proc_fs.h>
 176 #include <linux/reboot.h>
 177 #include <linux/interrupt.h>
 178 
 179 #include <linux/blkdev.h>
 180 #include <linux/types.h>
 181 #include <linux/dma-mapping.h>
 182 
 183 #include <scsi/sg.h>
 184 #include "scsi.h"
 185 #include <scsi/scsi_host.h>
 186 
 187 #include "ips.h"
 188 
 189 #include <linux/module.h>
 190 
 191 #include <linux/stat.h>
 192 
 193 #include <linux/spinlock.h>
 194 #include <linux/init.h>
 195 
 196 #include <linux/smp.h>
 197 
 198 #ifdef MODULE
 199 static char *ips = NULL;
 200 module_param(ips, charp, 0);
 201 #endif
 202 
 203 /*
 204  * DRIVER_VER
 205  */
 206 #define IPS_VERSION_HIGH        IPS_VER_MAJOR_STRING "." IPS_VER_MINOR_STRING
 207 #define IPS_VERSION_LOW         "." IPS_VER_BUILD_STRING " "
 208 
 209 #define IPS_DMA_DIR(scb) ((!scb->scsi_cmd || ips_is_passthru(scb->scsi_cmd) || \
 210                          DMA_NONE == scb->scsi_cmd->sc_data_direction) ? \
 211                          DMA_BIDIRECTIONAL : \
 212                          scb->scsi_cmd->sc_data_direction)
 213 
 214 #ifdef IPS_DEBUG
 215 #define METHOD_TRACE(s, i)    if (ips_debug >= (i+10)) printk(KERN_NOTICE s "\n");
 216 #define DEBUG(i, s)           if (ips_debug >= i) printk(KERN_NOTICE s "\n");
 217 #define DEBUG_VAR(i, s, v...) if (ips_debug >= i) printk(KERN_NOTICE s "\n", v);
 218 #else
 219 #define METHOD_TRACE(s, i)
 220 #define DEBUG(i, s)
 221 #define DEBUG_VAR(i, s, v...)
 222 #endif
 223 
 224 /*
 225  * Function prototypes
 226  */
 227 static int ips_eh_abort(struct scsi_cmnd *);
 228 static int ips_eh_reset(struct scsi_cmnd *);
 229 static int ips_queue(struct Scsi_Host *, struct scsi_cmnd *);
 230 static const char *ips_info(struct Scsi_Host *);
 231 static irqreturn_t do_ipsintr(int, void *);
 232 static int ips_hainit(ips_ha_t *);
 233 static int ips_map_status(ips_ha_t *, ips_scb_t *, ips_stat_t *);
 234 static int ips_send_wait(ips_ha_t *, ips_scb_t *, int, int);
 235 static int ips_send_cmd(ips_ha_t *, ips_scb_t *);
 236 static int ips_online(ips_ha_t *, ips_scb_t *);
 237 static int ips_inquiry(ips_ha_t *, ips_scb_t *);
 238 static int ips_rdcap(ips_ha_t *, ips_scb_t *);
 239 static int ips_msense(ips_ha_t *, ips_scb_t *);
 240 static int ips_reqsen(ips_ha_t *, ips_scb_t *);
 241 static int ips_deallocatescbs(ips_ha_t *, int);
 242 static int ips_allocatescbs(ips_ha_t *);
 243 static int ips_reset_copperhead(ips_ha_t *);
 244 static int ips_reset_copperhead_memio(ips_ha_t *);
 245 static int ips_reset_morpheus(ips_ha_t *);
 246 static int ips_issue_copperhead(ips_ha_t *, ips_scb_t *);
 247 static int ips_issue_copperhead_memio(ips_ha_t *, ips_scb_t *);
 248 static int ips_issue_i2o(ips_ha_t *, ips_scb_t *);
 249 static int ips_issue_i2o_memio(ips_ha_t *, ips_scb_t *);
 250 static int ips_isintr_copperhead(ips_ha_t *);
 251 static int ips_isintr_copperhead_memio(ips_ha_t *);
 252 static int ips_isintr_morpheus(ips_ha_t *);
 253 static int ips_wait(ips_ha_t *, int, int);
 254 static int ips_write_driver_status(ips_ha_t *, int);
 255 static int ips_read_adapter_status(ips_ha_t *, int);
 256 static int ips_read_subsystem_parameters(ips_ha_t *, int);
 257 static int ips_read_config(ips_ha_t *, int);
 258 static int ips_clear_adapter(ips_ha_t *, int);
 259 static int ips_readwrite_page5(ips_ha_t *, int, int);
 260 static int ips_init_copperhead(ips_ha_t *);
 261 static int ips_init_copperhead_memio(ips_ha_t *);
 262 static int ips_init_morpheus(ips_ha_t *);
 263 static int ips_isinit_copperhead(ips_ha_t *);
 264 static int ips_isinit_copperhead_memio(ips_ha_t *);
 265 static int ips_isinit_morpheus(ips_ha_t *);
 266 static int ips_erase_bios(ips_ha_t *);
 267 static int ips_program_bios(ips_ha_t *, char *, uint32_t, uint32_t);
 268 static int ips_verify_bios(ips_ha_t *, char *, uint32_t, uint32_t);
 269 static int ips_erase_bios_memio(ips_ha_t *);
 270 static int ips_program_bios_memio(ips_ha_t *, char *, uint32_t, uint32_t);
 271 static int ips_verify_bios_memio(ips_ha_t *, char *, uint32_t, uint32_t);
 272 static int ips_flash_copperhead(ips_ha_t *, ips_passthru_t *, ips_scb_t *);
 273 static int ips_flash_bios(ips_ha_t *, ips_passthru_t *, ips_scb_t *);
 274 static int ips_flash_firmware(ips_ha_t *, ips_passthru_t *, ips_scb_t *);
 275 static void ips_free_flash_copperhead(ips_ha_t * ha);
 276 static void ips_get_bios_version(ips_ha_t *, int);
 277 static void ips_identify_controller(ips_ha_t *);
 278 static void ips_chkstatus(ips_ha_t *, IPS_STATUS *);
 279 static void ips_enable_int_copperhead(ips_ha_t *);
 280 static void ips_enable_int_copperhead_memio(ips_ha_t *);
 281 static void ips_enable_int_morpheus(ips_ha_t *);
 282 static int ips_intr_copperhead(ips_ha_t *);
 283 static int ips_intr_morpheus(ips_ha_t *);
 284 static void ips_next(ips_ha_t *, int);
 285 static void ipsintr_blocking(ips_ha_t *, struct ips_scb *);
 286 static void ipsintr_done(ips_ha_t *, struct ips_scb *);
 287 static void ips_done(ips_ha_t *, ips_scb_t *);
 288 static void ips_free(ips_ha_t *);
 289 static void ips_init_scb(ips_ha_t *, ips_scb_t *);
 290 static void ips_freescb(ips_ha_t *, ips_scb_t *);
 291 static void ips_setup_funclist(ips_ha_t *);
 292 static void ips_statinit(ips_ha_t *);
 293 static void ips_statinit_memio(ips_ha_t *);
 294 static void ips_fix_ffdc_time(ips_ha_t *, ips_scb_t *, time64_t);
 295 static void ips_ffdc_reset(ips_ha_t *, int);
 296 static void ips_ffdc_time(ips_ha_t *);
 297 static uint32_t ips_statupd_copperhead(ips_ha_t *);
 298 static uint32_t ips_statupd_copperhead_memio(ips_ha_t *);
 299 static uint32_t ips_statupd_morpheus(ips_ha_t *);
 300 static ips_scb_t *ips_getscb(ips_ha_t *);
 301 static void ips_putq_scb_head(ips_scb_queue_t *, ips_scb_t *);
 302 static void ips_putq_wait_tail(ips_wait_queue_entry_t *, struct scsi_cmnd *);
 303 static void ips_putq_copp_tail(ips_copp_queue_t *,
 304                                       ips_copp_wait_item_t *);
 305 static ips_scb_t *ips_removeq_scb_head(ips_scb_queue_t *);
 306 static ips_scb_t *ips_removeq_scb(ips_scb_queue_t *, ips_scb_t *);
 307 static struct scsi_cmnd *ips_removeq_wait_head(ips_wait_queue_entry_t *);
 308 static struct scsi_cmnd *ips_removeq_wait(ips_wait_queue_entry_t *,
 309                                           struct scsi_cmnd *);
 310 static ips_copp_wait_item_t *ips_removeq_copp(ips_copp_queue_t *,
 311                                                      ips_copp_wait_item_t *);
 312 static ips_copp_wait_item_t *ips_removeq_copp_head(ips_copp_queue_t *);
 313 
 314 static int ips_is_passthru(struct scsi_cmnd *);
 315 static int ips_make_passthru(ips_ha_t *, struct scsi_cmnd *, ips_scb_t *, int);
 316 static int ips_usrcmd(ips_ha_t *, ips_passthru_t *, ips_scb_t *);
 317 static void ips_cleanup_passthru(ips_ha_t *, ips_scb_t *);
 318 static void ips_scmd_buf_write(struct scsi_cmnd * scmd, void *data,
 319                                unsigned int count);
 320 static void ips_scmd_buf_read(struct scsi_cmnd * scmd, void *data,
 321                               unsigned int count);
 322 
 323 static int ips_write_info(struct Scsi_Host *, char *, int);
 324 static int ips_show_info(struct seq_file *, struct Scsi_Host *);
 325 static int ips_host_info(ips_ha_t *, struct seq_file *);
 326 static int ips_abort_init(ips_ha_t * ha, int index);
 327 static int ips_init_phase2(int index);
 328 
 329 static int ips_init_phase1(struct pci_dev *pci_dev, int *indexPtr);
 330 static int ips_register_scsi(int index);
 331 
 332 static int  ips_poll_for_flush_complete(ips_ha_t * ha);
 333 static void ips_flush_and_reset(ips_ha_t *ha);
 334 
 335 /*
 336  * global variables
 337  */
 338 static const char ips_name[] = "ips";
 339 static struct Scsi_Host *ips_sh[IPS_MAX_ADAPTERS];      /* Array of host controller structures */
 340 static ips_ha_t *ips_ha[IPS_MAX_ADAPTERS];      /* Array of HA structures */
 341 static unsigned int ips_next_controller;
 342 static unsigned int ips_num_controllers;
 343 static unsigned int ips_released_controllers;
 344 static int ips_hotplug;
 345 static int ips_cmd_timeout = 60;
 346 static int ips_reset_timeout = 60 * 5;
 347 static int ips_force_memio = 1;         /* Always use Memory Mapped I/O    */
 348 static int ips_force_i2o = 1;   /* Always use I2O command delivery */
 349 static int ips_ioctlsize = IPS_IOCTL_SIZE;      /* Size of the ioctl buffer        */
 350 static int ips_cd_boot;                 /* Booting from Manager CD         */
 351 static char *ips_FlashData = NULL;      /* CD Boot - Flash Data Buffer      */
 352 static dma_addr_t ips_flashbusaddr;
 353 static long ips_FlashDataInUse;         /* CD Boot - Flash Data In Use Flag */
 354 static uint32_t MaxLiteCmds = 32;       /* Max Active Cmds for a Lite Adapter */
 355 static struct scsi_host_template ips_driver_template = {
 356         .info                   = ips_info,
 357         .queuecommand           = ips_queue,
 358         .eh_abort_handler       = ips_eh_abort,
 359         .eh_host_reset_handler  = ips_eh_reset,
 360         .proc_name              = "ips",
 361         .show_info              = ips_show_info,
 362         .write_info             = ips_write_info,
 363         .slave_configure        = ips_slave_configure,
 364         .bios_param             = ips_biosparam,
 365         .this_id                = -1,
 366         .sg_tablesize           = IPS_MAX_SG,
 367         .cmd_per_lun            = 3,
 368         .no_write_same          = 1,
 369 };
 370 
 371 
 372 /* This table describes all ServeRAID Adapters */
 373 static struct  pci_device_id  ips_pci_table[] = {
 374         { 0x1014, 0x002E, PCI_ANY_ID, PCI_ANY_ID, 0, 0 },
 375         { 0x1014, 0x01BD, PCI_ANY_ID, PCI_ANY_ID, 0, 0 },
 376         { 0x9005, 0x0250, PCI_ANY_ID, PCI_ANY_ID, 0, 0 },
 377         { 0, }
 378 };
 379 
 380 MODULE_DEVICE_TABLE( pci, ips_pci_table );
 381 
 382 static char ips_hot_plug_name[] = "ips";
 383 
 384 static int  ips_insert_device(struct pci_dev *pci_dev, const struct pci_device_id *ent);
 385 static void ips_remove_device(struct pci_dev *pci_dev);
 386 
 387 static struct pci_driver ips_pci_driver = {
 388         .name           = ips_hot_plug_name,
 389         .id_table       = ips_pci_table,
 390         .probe          = ips_insert_device,
 391         .remove         = ips_remove_device,
 392 };
 393 
 394 
 395 /*
 396  * Necessary forward function protoypes
 397  */
 398 static int ips_halt(struct notifier_block *nb, ulong event, void *buf);
 399 
 400 #define MAX_ADAPTER_NAME 15
 401 
 402 static char ips_adapter_name[][30] = {
 403         "ServeRAID",
 404         "ServeRAID II",
 405         "ServeRAID on motherboard",
 406         "ServeRAID on motherboard",
 407         "ServeRAID 3H",
 408         "ServeRAID 3L",
 409         "ServeRAID 4H",
 410         "ServeRAID 4M",
 411         "ServeRAID 4L",
 412         "ServeRAID 4Mx",
 413         "ServeRAID 4Lx",
 414         "ServeRAID 5i",
 415         "ServeRAID 5i",
 416         "ServeRAID 6M",
 417         "ServeRAID 6i",
 418         "ServeRAID 7t",
 419         "ServeRAID 7k",
 420         "ServeRAID 7M"
 421 };
 422 
 423 static struct notifier_block ips_notifier = {
 424         ips_halt, NULL, 0
 425 };
 426 
 427 /*
 428  * Direction table
 429  */
 430 static char ips_command_direction[] = {
 431         IPS_DATA_NONE, IPS_DATA_NONE, IPS_DATA_IN, IPS_DATA_IN, IPS_DATA_OUT,
 432         IPS_DATA_IN, IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_IN, IPS_DATA_UNK,
 433         IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 434         IPS_DATA_IN, IPS_DATA_NONE, IPS_DATA_NONE, IPS_DATA_IN, IPS_DATA_OUT,
 435         IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_NONE, IPS_DATA_NONE, IPS_DATA_OUT,
 436         IPS_DATA_NONE, IPS_DATA_IN, IPS_DATA_NONE, IPS_DATA_IN, IPS_DATA_OUT,
 437         IPS_DATA_NONE, IPS_DATA_UNK, IPS_DATA_IN, IPS_DATA_UNK, IPS_DATA_IN,
 438         IPS_DATA_UNK, IPS_DATA_OUT, IPS_DATA_IN, IPS_DATA_UNK, IPS_DATA_UNK,
 439         IPS_DATA_IN, IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_NONE, IPS_DATA_UNK,
 440         IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_OUT,
 441         IPS_DATA_OUT, IPS_DATA_NONE, IPS_DATA_IN, IPS_DATA_NONE, IPS_DATA_NONE,
 442         IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_OUT,
 443         IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_OUT,
 444         IPS_DATA_OUT, IPS_DATA_IN, IPS_DATA_IN, IPS_DATA_IN, IPS_DATA_NONE,
 445         IPS_DATA_UNK, IPS_DATA_NONE, IPS_DATA_NONE, IPS_DATA_NONE, IPS_DATA_UNK,
 446         IPS_DATA_NONE, IPS_DATA_OUT, IPS_DATA_IN, IPS_DATA_UNK, IPS_DATA_UNK,
 447         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 448         IPS_DATA_OUT, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 449         IPS_DATA_IN, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 450         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 451         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 452         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 453         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 454         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 455         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 456         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 457         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 458         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 459         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 460         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 461         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 462         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 463         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 464         IPS_DATA_NONE, IPS_DATA_NONE, IPS_DATA_UNK, IPS_DATA_IN, IPS_DATA_NONE,
 465         IPS_DATA_OUT, IPS_DATA_UNK, IPS_DATA_NONE, IPS_DATA_UNK, IPS_DATA_OUT,
 466         IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_OUT, IPS_DATA_NONE,
 467         IPS_DATA_UNK, IPS_DATA_IN, IPS_DATA_OUT, IPS_DATA_IN, IPS_DATA_IN,
 468         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 469         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 470         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 471         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 472         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 473         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 474         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 475         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 476         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 477         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_OUT,
 478         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 479         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 480         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK,
 481         IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK, IPS_DATA_UNK
 482 };
 483 
 484 
 485 /****************************************************************************/
 486 /*                                                                          */
 487 /* Routine Name: ips_setup                                                  */
 488 /*                                                                          */
 489 /* Routine Description:                                                     */
 490 /*                                                                          */
 491 /*   setup parameters to the driver                                         */
 492 /*                                                                          */
 493 /****************************************************************************/
 494 static int
 495 ips_setup(char *ips_str)
 496 {
 497 
 498         int i;
 499         char *key;
 500         char *value;
 501         IPS_OPTION options[] = {
 502                 {"noi2o", &ips_force_i2o, 0},
 503                 {"nommap", &ips_force_memio, 0},
 504                 {"ioctlsize", &ips_ioctlsize, IPS_IOCTL_SIZE},
 505                 {"cdboot", &ips_cd_boot, 0},
 506                 {"maxcmds", &MaxLiteCmds, 32},
 507         };
 508 
 509         /* Don't use strtok() anymore ( if 2.4 Kernel or beyond ) */
 510         /* Search for value */
 511         while ((key = strsep(&ips_str, ",."))) {
 512                 if (!*key)
 513                         continue;
 514                 value = strchr(key, ':');
 515                 if (value)
 516                         *value++ = '\0';
 517                 /*
 518                  * We now have key/value pairs.
 519                  * Update the variables
 520                  */
 521                 for (i = 0; i < ARRAY_SIZE(options); i++) {
 522                         if (strncasecmp
 523                             (key, options[i].option_name,
 524                              strlen(options[i].option_name)) == 0) {
 525                                 if (value)
 526                                         *options[i].option_flag =
 527                                             simple_strtoul(value, NULL, 0);
 528                                 else
 529                                         *options[i].option_flag =
 530                                             options[i].option_value;
 531                                 break;
 532                         }
 533                 }
 534         }
 535 
 536         return (1);
 537 }
 538 
 539 __setup("ips=", ips_setup);
 540 
 541 /****************************************************************************/
 542 /*                                                                          */
 543 /* Routine Name: ips_detect                                                 */
 544 /*                                                                          */
 545 /* Routine Description:                                                     */
 546 /*                                                                          */
 547 /*   Detect and initialize the driver                                       */
 548 /*                                                                          */
 549 /* NOTE: this routine is called under the io_request_lock spinlock          */
 550 /*                                                                          */
 551 /****************************************************************************/
 552 static int
 553 ips_detect(struct scsi_host_template * SHT)
 554 {
 555         int i;
 556 
 557         METHOD_TRACE("ips_detect", 1);
 558 
 559 #ifdef MODULE
 560         if (ips)
 561                 ips_setup(ips);
 562 #endif
 563 
 564         for (i = 0; i < ips_num_controllers; i++) {
 565                 if (ips_register_scsi(i))
 566                         ips_free(ips_ha[i]);
 567                 ips_released_controllers++;
 568         }
 569         ips_hotplug = 1;
 570         return (ips_num_controllers);
 571 }
 572 
 573 /****************************************************************************/
 574 /*   configure the function pointers to use the functions that will work    */
 575 /*   with the found version of the adapter                                  */
 576 /****************************************************************************/
 577 static void
 578 ips_setup_funclist(ips_ha_t * ha)
 579 {
 580 
 581         /*
 582          * Setup Functions
 583          */
 584         if (IPS_IS_MORPHEUS(ha) || IPS_IS_MARCO(ha)) {
 585                 /* morpheus / marco / sebring */
 586                 ha->func.isintr = ips_isintr_morpheus;
 587                 ha->func.isinit = ips_isinit_morpheus;
 588                 ha->func.issue = ips_issue_i2o_memio;
 589                 ha->func.init = ips_init_morpheus;
 590                 ha->func.statupd = ips_statupd_morpheus;
 591                 ha->func.reset = ips_reset_morpheus;
 592                 ha->func.intr = ips_intr_morpheus;
 593                 ha->func.enableint = ips_enable_int_morpheus;
 594         } else if (IPS_USE_MEMIO(ha)) {
 595                 /* copperhead w/MEMIO */
 596                 ha->func.isintr = ips_isintr_copperhead_memio;
 597                 ha->func.isinit = ips_isinit_copperhead_memio;
 598                 ha->func.init = ips_init_copperhead_memio;
 599                 ha->func.statupd = ips_statupd_copperhead_memio;
 600                 ha->func.statinit = ips_statinit_memio;
 601                 ha->func.reset = ips_reset_copperhead_memio;
 602                 ha->func.intr = ips_intr_copperhead;
 603                 ha->func.erasebios = ips_erase_bios_memio;
 604                 ha->func.programbios = ips_program_bios_memio;
 605                 ha->func.verifybios = ips_verify_bios_memio;
 606                 ha->func.enableint = ips_enable_int_copperhead_memio;
 607                 if (IPS_USE_I2O_DELIVER(ha))
 608                         ha->func.issue = ips_issue_i2o_memio;
 609                 else
 610                         ha->func.issue = ips_issue_copperhead_memio;
 611         } else {
 612                 /* copperhead */
 613                 ha->func.isintr = ips_isintr_copperhead;
 614                 ha->func.isinit = ips_isinit_copperhead;
 615                 ha->func.init = ips_init_copperhead;
 616                 ha->func.statupd = ips_statupd_copperhead;
 617                 ha->func.statinit = ips_statinit;
 618                 ha->func.reset = ips_reset_copperhead;
 619                 ha->func.intr = ips_intr_copperhead;
 620                 ha->func.erasebios = ips_erase_bios;
 621                 ha->func.programbios = ips_program_bios;
 622                 ha->func.verifybios = ips_verify_bios;
 623                 ha->func.enableint = ips_enable_int_copperhead;
 624 
 625                 if (IPS_USE_I2O_DELIVER(ha))
 626                         ha->func.issue = ips_issue_i2o;
 627                 else
 628                         ha->func.issue = ips_issue_copperhead;
 629         }
 630 }
 631 
 632 /****************************************************************************/
 633 /*                                                                          */
 634 /* Routine Name: ips_release                                                */
 635 /*                                                                          */
 636 /* Routine Description:                                                     */
 637 /*                                                                          */
 638 /*   Remove a driver                                                        */
 639 /*                                                                          */
 640 /****************************************************************************/
 641 static int
 642 ips_release(struct Scsi_Host *sh)
 643 {
 644         ips_scb_t *scb;
 645         ips_ha_t *ha;
 646         int i;
 647 
 648         METHOD_TRACE("ips_release", 1);
 649 
 650         scsi_remove_host(sh);
 651 
 652         for (i = 0; i < IPS_MAX_ADAPTERS && ips_sh[i] != sh; i++) ;
 653 
 654         if (i == IPS_MAX_ADAPTERS) {
 655                 printk(KERN_WARNING
 656                        "(%s) release, invalid Scsi_Host pointer.\n", ips_name);
 657                 BUG();
 658                 return (FALSE);
 659         }
 660 
 661         ha = IPS_HA(sh);
 662 
 663         if (!ha)
 664                 return (FALSE);
 665 
 666         /* flush the cache on the controller */
 667         scb = &ha->scbs[ha->max_cmds - 1];
 668 
 669         ips_init_scb(ha, scb);
 670 
 671         scb->timeout = ips_cmd_timeout;
 672         scb->cdb[0] = IPS_CMD_FLUSH;
 673 
 674         scb->cmd.flush_cache.op_code = IPS_CMD_FLUSH;
 675         scb->cmd.flush_cache.command_id = IPS_COMMAND_ID(ha, scb);
 676         scb->cmd.flush_cache.state = IPS_NORM_STATE;
 677         scb->cmd.flush_cache.reserved = 0;
 678         scb->cmd.flush_cache.reserved2 = 0;
 679         scb->cmd.flush_cache.reserved3 = 0;
 680         scb->cmd.flush_cache.reserved4 = 0;
 681 
 682         IPS_PRINTK(KERN_WARNING, ha->pcidev, "Flushing Cache.\n");
 683 
 684         /* send command */
 685         if (ips_send_wait(ha, scb, ips_cmd_timeout, IPS_INTR_ON) == IPS_FAILURE)
 686                 IPS_PRINTK(KERN_WARNING, ha->pcidev, "Incomplete Flush.\n");
 687 
 688         IPS_PRINTK(KERN_WARNING, ha->pcidev, "Flushing Complete.\n");
 689 
 690         ips_sh[i] = NULL;
 691         ips_ha[i] = NULL;
 692 
 693         /* free extra memory */
 694         ips_free(ha);
 695 
 696         /* free IRQ */
 697         free_irq(ha->pcidev->irq, ha);
 698 
 699         scsi_host_put(sh);
 700 
 701         ips_released_controllers++;
 702 
 703         return (FALSE);
 704 }
 705 
 706 /****************************************************************************/
 707 /*                                                                          */
 708 /* Routine Name: ips_halt                                                   */
 709 /*                                                                          */
 710 /* Routine Description:                                                     */
 711 /*                                                                          */
 712 /*   Perform cleanup when the system reboots                                */
 713 /*                                                                          */
 714 /****************************************************************************/
 715 static int
 716 ips_halt(struct notifier_block *nb, ulong event, void *buf)
 717 {
 718         ips_scb_t *scb;
 719         ips_ha_t *ha;
 720         int i;
 721 
 722         if ((event != SYS_RESTART) && (event != SYS_HALT) &&
 723             (event != SYS_POWER_OFF))
 724                 return (NOTIFY_DONE);
 725 
 726         for (i = 0; i < ips_next_controller; i++) {
 727                 ha = (ips_ha_t *) ips_ha[i];
 728 
 729                 if (!ha)
 730                         continue;
 731 
 732                 if (!ha->active)
 733                         continue;
 734 
 735                 /* flush the cache on the controller */
 736                 scb = &ha->scbs[ha->max_cmds - 1];
 737 
 738                 ips_init_scb(ha, scb);
 739 
 740                 scb->timeout = ips_cmd_timeout;
 741                 scb->cdb[0] = IPS_CMD_FLUSH;
 742 
 743                 scb->cmd.flush_cache.op_code = IPS_CMD_FLUSH;
 744                 scb->cmd.flush_cache.command_id = IPS_COMMAND_ID(ha, scb);
 745                 scb->cmd.flush_cache.state = IPS_NORM_STATE;
 746                 scb->cmd.flush_cache.reserved = 0;
 747                 scb->cmd.flush_cache.reserved2 = 0;
 748                 scb->cmd.flush_cache.reserved3 = 0;
 749                 scb->cmd.flush_cache.reserved4 = 0;
 750 
 751                 IPS_PRINTK(KERN_WARNING, ha->pcidev, "Flushing Cache.\n");
 752 
 753                 /* send command */
 754                 if (ips_send_wait(ha, scb, ips_cmd_timeout, IPS_INTR_ON) ==
 755                     IPS_FAILURE)
 756                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
 757                                    "Incomplete Flush.\n");
 758                 else
 759                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
 760                                    "Flushing Complete.\n");
 761         }
 762 
 763         return (NOTIFY_OK);
 764 }
 765 
 766 /****************************************************************************/
 767 /*                                                                          */
 768 /* Routine Name: ips_eh_abort                                               */
 769 /*                                                                          */
 770 /* Routine Description:                                                     */
 771 /*                                                                          */
 772 /*   Abort a command (using the new error code stuff)                       */
 773 /* Note: this routine is called under the io_request_lock                   */
 774 /****************************************************************************/
 775 int ips_eh_abort(struct scsi_cmnd *SC)
 776 {
 777         ips_ha_t *ha;
 778         ips_copp_wait_item_t *item;
 779         int ret;
 780         struct Scsi_Host *host;
 781 
 782         METHOD_TRACE("ips_eh_abort", 1);
 783 
 784         if (!SC)
 785                 return (FAILED);
 786 
 787         host = SC->device->host;
 788         ha = (ips_ha_t *) SC->device->host->hostdata;
 789 
 790         if (!ha)
 791                 return (FAILED);
 792 
 793         if (!ha->active)
 794                 return (FAILED);
 795 
 796         spin_lock(host->host_lock);
 797 
 798         /* See if the command is on the copp queue */
 799         item = ha->copp_waitlist.head;
 800         while ((item) && (item->scsi_cmd != SC))
 801                 item = item->next;
 802 
 803         if (item) {
 804                 /* Found it */
 805                 ips_removeq_copp(&ha->copp_waitlist, item);
 806                 ret = (SUCCESS);
 807 
 808                 /* See if the command is on the wait queue */
 809         } else if (ips_removeq_wait(&ha->scb_waitlist, SC)) {
 810                 /* command not sent yet */
 811                 ret = (SUCCESS);
 812         } else {
 813                 /* command must have already been sent */
 814                 ret = (FAILED);
 815         }
 816 
 817         spin_unlock(host->host_lock);
 818         return ret;
 819 }
 820 
 821 /****************************************************************************/
 822 /*                                                                          */
 823 /* Routine Name: ips_eh_reset                                               */
 824 /*                                                                          */
 825 /* Routine Description:                                                     */
 826 /*                                                                          */
 827 /*   Reset the controller (with new eh error code)                          */
 828 /*                                                                          */
 829 /* NOTE: this routine is called under the io_request_lock spinlock          */
 830 /*                                                                          */
 831 /****************************************************************************/
 832 static int __ips_eh_reset(struct scsi_cmnd *SC)
 833 {
 834         int ret;
 835         int i;
 836         ips_ha_t *ha;
 837         ips_scb_t *scb;
 838         ips_copp_wait_item_t *item;
 839 
 840         METHOD_TRACE("ips_eh_reset", 1);
 841 
 842 #ifdef NO_IPS_RESET
 843         return (FAILED);
 844 #else
 845 
 846         if (!SC) {
 847                 DEBUG(1, "Reset called with NULL scsi command");
 848 
 849                 return (FAILED);
 850         }
 851 
 852         ha = (ips_ha_t *) SC->device->host->hostdata;
 853 
 854         if (!ha) {
 855                 DEBUG(1, "Reset called with NULL ha struct");
 856 
 857                 return (FAILED);
 858         }
 859 
 860         if (!ha->active)
 861                 return (FAILED);
 862 
 863         /* See if the command is on the copp queue */
 864         item = ha->copp_waitlist.head;
 865         while ((item) && (item->scsi_cmd != SC))
 866                 item = item->next;
 867 
 868         if (item) {
 869                 /* Found it */
 870                 ips_removeq_copp(&ha->copp_waitlist, item);
 871                 return (SUCCESS);
 872         }
 873 
 874         /* See if the command is on the wait queue */
 875         if (ips_removeq_wait(&ha->scb_waitlist, SC)) {
 876                 /* command not sent yet */
 877                 return (SUCCESS);
 878         }
 879 
 880         /* An explanation for the casual observer:                              */
 881         /* Part of the function of a RAID controller is automatic error         */
 882         /* detection and recovery.  As such, the only problem that physically   */
 883         /* resetting an adapter will ever fix is when, for some reason,         */
 884         /* the driver is not successfully communicating with the adapter.       */
 885         /* Therefore, we will attempt to flush this adapter.  If that succeeds, */
 886         /* then there's no real purpose in a physical reset. This will complete */
 887         /* much faster and avoids any problems that might be caused by a        */
 888         /* physical reset ( such as having to fail all the outstanding I/O's ). */
 889 
 890         if (ha->ioctl_reset == 0) {     /* IF Not an IOCTL Requested Reset */
 891                 scb = &ha->scbs[ha->max_cmds - 1];
 892 
 893                 ips_init_scb(ha, scb);
 894 
 895                 scb->timeout = ips_cmd_timeout;
 896                 scb->cdb[0] = IPS_CMD_FLUSH;
 897 
 898                 scb->cmd.flush_cache.op_code = IPS_CMD_FLUSH;
 899                 scb->cmd.flush_cache.command_id = IPS_COMMAND_ID(ha, scb);
 900                 scb->cmd.flush_cache.state = IPS_NORM_STATE;
 901                 scb->cmd.flush_cache.reserved = 0;
 902                 scb->cmd.flush_cache.reserved2 = 0;
 903                 scb->cmd.flush_cache.reserved3 = 0;
 904                 scb->cmd.flush_cache.reserved4 = 0;
 905 
 906                 /* Attempt the flush command */
 907                 ret = ips_send_wait(ha, scb, ips_cmd_timeout, IPS_INTR_IORL);
 908                 if (ret == IPS_SUCCESS) {
 909                         IPS_PRINTK(KERN_NOTICE, ha->pcidev,
 910                                    "Reset Request - Flushed Cache\n");
 911                         return (SUCCESS);
 912                 }
 913         }
 914 
 915         /* Either we can't communicate with the adapter or it's an IOCTL request */
 916         /* from a utility.  A physical reset is needed at this point.            */
 917 
 918         ha->ioctl_reset = 0;    /* Reset the IOCTL Requested Reset Flag */
 919 
 920         /*
 921          * command must have already been sent
 922          * reset the controller
 923          */
 924         IPS_PRINTK(KERN_NOTICE, ha->pcidev, "Resetting controller.\n");
 925         ret = (*ha->func.reset) (ha);
 926 
 927         if (!ret) {
 928                 struct scsi_cmnd *scsi_cmd;
 929 
 930                 IPS_PRINTK(KERN_NOTICE, ha->pcidev,
 931                            "Controller reset failed - controller now offline.\n");
 932 
 933                 /* Now fail all of the active commands */
 934                 DEBUG_VAR(1, "(%s%d) Failing active commands",
 935                           ips_name, ha->host_num);
 936 
 937                 while ((scb = ips_removeq_scb_head(&ha->scb_activelist))) {
 938                         scb->scsi_cmd->result = DID_ERROR << 16;
 939                         scb->scsi_cmd->scsi_done(scb->scsi_cmd);
 940                         ips_freescb(ha, scb);
 941                 }
 942 
 943                 /* Now fail all of the pending commands */
 944                 DEBUG_VAR(1, "(%s%d) Failing pending commands",
 945                           ips_name, ha->host_num);
 946 
 947                 while ((scsi_cmd = ips_removeq_wait_head(&ha->scb_waitlist))) {
 948                         scsi_cmd->result = DID_ERROR;
 949                         scsi_cmd->scsi_done(scsi_cmd);
 950                 }
 951 
 952                 ha->active = FALSE;
 953                 return (FAILED);
 954         }
 955 
 956         if (!ips_clear_adapter(ha, IPS_INTR_IORL)) {
 957                 struct scsi_cmnd *scsi_cmd;
 958 
 959                 IPS_PRINTK(KERN_NOTICE, ha->pcidev,
 960                            "Controller reset failed - controller now offline.\n");
 961 
 962                 /* Now fail all of the active commands */
 963                 DEBUG_VAR(1, "(%s%d) Failing active commands",
 964                           ips_name, ha->host_num);
 965 
 966                 while ((scb = ips_removeq_scb_head(&ha->scb_activelist))) {
 967                         scb->scsi_cmd->result = DID_ERROR << 16;
 968                         scb->scsi_cmd->scsi_done(scb->scsi_cmd);
 969                         ips_freescb(ha, scb);
 970                 }
 971 
 972                 /* Now fail all of the pending commands */
 973                 DEBUG_VAR(1, "(%s%d) Failing pending commands",
 974                           ips_name, ha->host_num);
 975 
 976                 while ((scsi_cmd = ips_removeq_wait_head(&ha->scb_waitlist))) {
 977                         scsi_cmd->result = DID_ERROR << 16;
 978                         scsi_cmd->scsi_done(scsi_cmd);
 979                 }
 980 
 981                 ha->active = FALSE;
 982                 return (FAILED);
 983         }
 984 
 985         /* FFDC */
 986         if (le32_to_cpu(ha->subsys->param[3]) & 0x300000) {
 987                 ha->last_ffdc = ktime_get_real_seconds();
 988                 ha->reset_count++;
 989                 ips_ffdc_reset(ha, IPS_INTR_IORL);
 990         }
 991 
 992         /* Now fail all of the active commands */
 993         DEBUG_VAR(1, "(%s%d) Failing active commands", ips_name, ha->host_num);
 994 
 995         while ((scb = ips_removeq_scb_head(&ha->scb_activelist))) {
 996                 scb->scsi_cmd->result = DID_RESET << 16;
 997                 scb->scsi_cmd->scsi_done(scb->scsi_cmd);
 998                 ips_freescb(ha, scb);
 999         }
1000 
1001         /* Reset DCDB active command bits */
1002         for (i = 1; i < ha->nbus; i++)
1003                 ha->dcdb_active[i - 1] = 0;
1004 
1005         /* Reset the number of active IOCTLs */
1006         ha->num_ioctl = 0;
1007 
1008         ips_next(ha, IPS_INTR_IORL);
1009 
1010         return (SUCCESS);
1011 #endif                          /* NO_IPS_RESET */
1012 
1013 }
1014 
1015 static int ips_eh_reset(struct scsi_cmnd *SC)
1016 {
1017         int rc;
1018 
1019         spin_lock_irq(SC->device->host->host_lock);
1020         rc = __ips_eh_reset(SC);
1021         spin_unlock_irq(SC->device->host->host_lock);
1022 
1023         return rc;
1024 }
1025 
1026 /****************************************************************************/
1027 /*                                                                          */
1028 /* Routine Name: ips_queue                                                  */
1029 /*                                                                          */
1030 /* Routine Description:                                                     */
1031 /*                                                                          */
1032 /*   Send a command to the controller                                       */
1033 /*                                                                          */
1034 /* NOTE:                                                                    */
1035 /*    Linux obtains io_request_lock before calling this function            */
1036 /*                                                                          */
1037 /****************************************************************************/
1038 static int ips_queue_lck(struct scsi_cmnd *SC, void (*done) (struct scsi_cmnd *))
1039 {
1040         ips_ha_t *ha;
1041         ips_passthru_t *pt;
1042 
1043         METHOD_TRACE("ips_queue", 1);
1044 
1045         ha = (ips_ha_t *) SC->device->host->hostdata;
1046 
1047         if (!ha)
1048                 return (1);
1049 
1050         if (!ha->active)
1051                 return (DID_ERROR);
1052 
1053         if (ips_is_passthru(SC)) {
1054                 if (ha->copp_waitlist.count == IPS_MAX_IOCTL_QUEUE) {
1055                         SC->result = DID_BUS_BUSY << 16;
1056                         done(SC);
1057 
1058                         return (0);
1059                 }
1060         } else if (ha->scb_waitlist.count == IPS_MAX_QUEUE) {
1061                 SC->result = DID_BUS_BUSY << 16;
1062                 done(SC);
1063 
1064                 return (0);
1065         }
1066 
1067         SC->scsi_done = done;
1068 
1069         DEBUG_VAR(2, "(%s%d): ips_queue: cmd 0x%X (%d %d %d)",
1070                   ips_name,
1071                   ha->host_num,
1072                   SC->cmnd[0],
1073                   SC->device->channel, SC->device->id, SC->device->lun);
1074 
1075         /* Check for command to initiator IDs */
1076         if ((scmd_channel(SC) > 0)
1077             && (scmd_id(SC) == ha->ha_id[scmd_channel(SC)])) {
1078                 SC->result = DID_NO_CONNECT << 16;
1079                 done(SC);
1080 
1081                 return (0);
1082         }
1083 
1084         if (ips_is_passthru(SC)) {
1085 
1086                 ips_copp_wait_item_t *scratch;
1087 
1088                 /* A Reset IOCTL is only sent by the boot CD in extreme cases.           */
1089                 /* There can never be any system activity ( network or disk ), but check */
1090                 /* anyway just as a good practice.                                       */
1091                 pt = (ips_passthru_t *) scsi_sglist(SC);
1092                 if ((pt->CoppCP.cmd.reset.op_code == IPS_CMD_RESET_CHANNEL) &&
1093                     (pt->CoppCP.cmd.reset.adapter_flag == 1)) {
1094                         if (ha->scb_activelist.count != 0) {
1095                                 SC->result = DID_BUS_BUSY << 16;
1096                                 done(SC);
1097                                 return (0);
1098                         }
1099                         ha->ioctl_reset = 1;    /* This reset request is from an IOCTL */
1100                         __ips_eh_reset(SC);
1101                         SC->result = DID_OK << 16;
1102                         SC->scsi_done(SC);
1103                         return (0);
1104                 }
1105 
1106                 /* allocate space for the scribble */
1107                 scratch = kmalloc(sizeof (ips_copp_wait_item_t), GFP_ATOMIC);
1108 
1109                 if (!scratch) {
1110                         SC->result = DID_ERROR << 16;
1111                         done(SC);
1112 
1113                         return (0);
1114                 }
1115 
1116                 scratch->scsi_cmd = SC;
1117                 scratch->next = NULL;
1118 
1119                 ips_putq_copp_tail(&ha->copp_waitlist, scratch);
1120         } else {
1121                 ips_putq_wait_tail(&ha->scb_waitlist, SC);
1122         }
1123 
1124         ips_next(ha, IPS_INTR_IORL);
1125 
1126         return (0);
1127 }
1128 
1129 static DEF_SCSI_QCMD(ips_queue)
1130 
1131 /****************************************************************************/
1132 /*                                                                          */
1133 /* Routine Name: ips_biosparam                                              */
1134 /*                                                                          */
1135 /* Routine Description:                                                     */
1136 /*                                                                          */
1137 /*   Set bios geometry for the controller                                   */
1138 /*                                                                          */
1139 /****************************************************************************/
1140 static int ips_biosparam(struct scsi_device *sdev, struct block_device *bdev,
1141                          sector_t capacity, int geom[])
1142 {
1143         ips_ha_t *ha = (ips_ha_t *) sdev->host->hostdata;
1144         int heads;
1145         int sectors;
1146         int cylinders;
1147 
1148         METHOD_TRACE("ips_biosparam", 1);
1149 
1150         if (!ha)
1151                 /* ?!?! host adater info invalid */
1152                 return (0);
1153 
1154         if (!ha->active)
1155                 return (0);
1156 
1157         if (!ips_read_adapter_status(ha, IPS_INTR_ON))
1158                 /* ?!?! Enquiry command failed */
1159                 return (0);
1160 
1161         if ((capacity > 0x400000) && ((ha->enq->ucMiscFlag & 0x8) == 0)) {
1162                 heads = IPS_NORM_HEADS;
1163                 sectors = IPS_NORM_SECTORS;
1164         } else {
1165                 heads = IPS_COMP_HEADS;
1166                 sectors = IPS_COMP_SECTORS;
1167         }
1168 
1169         cylinders = (unsigned long) capacity / (heads * sectors);
1170 
1171         DEBUG_VAR(2, "Geometry: heads: %d, sectors: %d, cylinders: %d",
1172                   heads, sectors, cylinders);
1173 
1174         geom[0] = heads;
1175         geom[1] = sectors;
1176         geom[2] = cylinders;
1177 
1178         return (0);
1179 }
1180 
1181 /****************************************************************************/
1182 /*                                                                          */
1183 /* Routine Name: ips_slave_configure                                        */
1184 /*                                                                          */
1185 /* Routine Description:                                                     */
1186 /*                                                                          */
1187 /*   Set queue depths on devices once scan is complete                      */
1188 /*                                                                          */
1189 /****************************************************************************/
1190 static int
1191 ips_slave_configure(struct scsi_device * SDptr)
1192 {
1193         ips_ha_t *ha;
1194         int min;
1195 
1196         ha = IPS_HA(SDptr->host);
1197         if (SDptr->tagged_supported && SDptr->type == TYPE_DISK) {
1198                 min = ha->max_cmds / 2;
1199                 if (ha->enq->ucLogDriveCount <= 2)
1200                         min = ha->max_cmds - 1;
1201                 scsi_change_queue_depth(SDptr, min);
1202         }
1203 
1204         SDptr->skip_ms_page_8 = 1;
1205         SDptr->skip_ms_page_3f = 1;
1206         return 0;
1207 }
1208 
1209 /****************************************************************************/
1210 /*                                                                          */
1211 /* Routine Name: do_ipsintr                                                 */
1212 /*                                                                          */
1213 /* Routine Description:                                                     */
1214 /*                                                                          */
1215 /*   Wrapper for the interrupt handler                                      */
1216 /*                                                                          */
1217 /****************************************************************************/
1218 static irqreturn_t
1219 do_ipsintr(int irq, void *dev_id)
1220 {
1221         ips_ha_t *ha;
1222         struct Scsi_Host *host;
1223         int irqstatus;
1224 
1225         METHOD_TRACE("do_ipsintr", 2);
1226 
1227         ha = (ips_ha_t *) dev_id;
1228         if (!ha)
1229                 return IRQ_NONE;
1230         host = ips_sh[ha->host_num];
1231         /* interrupt during initialization */
1232         if (!host) {
1233                 (*ha->func.intr) (ha);
1234                 return IRQ_HANDLED;
1235         }
1236 
1237         spin_lock(host->host_lock);
1238 
1239         if (!ha->active) {
1240                 spin_unlock(host->host_lock);
1241                 return IRQ_HANDLED;
1242         }
1243 
1244         irqstatus = (*ha->func.intr) (ha);
1245 
1246         spin_unlock(host->host_lock);
1247 
1248         /* start the next command */
1249         ips_next(ha, IPS_INTR_ON);
1250         return IRQ_RETVAL(irqstatus);
1251 }
1252 
1253 /****************************************************************************/
1254 /*                                                                          */
1255 /* Routine Name: ips_intr_copperhead                                        */
1256 /*                                                                          */
1257 /* Routine Description:                                                     */
1258 /*                                                                          */
1259 /*   Polling interrupt handler                                              */
1260 /*                                                                          */
1261 /*   ASSUMES interrupts are disabled                                        */
1262 /*                                                                          */
1263 /****************************************************************************/
1264 int
1265 ips_intr_copperhead(ips_ha_t * ha)
1266 {
1267         ips_stat_t *sp;
1268         ips_scb_t *scb;
1269         IPS_STATUS cstatus;
1270         int intrstatus;
1271 
1272         METHOD_TRACE("ips_intr", 2);
1273 
1274         if (!ha)
1275                 return 0;
1276 
1277         if (!ha->active)
1278                 return 0;
1279 
1280         intrstatus = (*ha->func.isintr) (ha);
1281 
1282         if (!intrstatus) {
1283                 /*
1284                  * Unexpected/Shared interrupt
1285                  */
1286 
1287                 return 0;
1288         }
1289 
1290         while (TRUE) {
1291                 sp = &ha->sp;
1292 
1293                 intrstatus = (*ha->func.isintr) (ha);
1294 
1295                 if (!intrstatus)
1296                         break;
1297                 else
1298                         cstatus.value = (*ha->func.statupd) (ha);
1299 
1300                 if (cstatus.fields.command_id > (IPS_MAX_CMDS - 1)) {
1301                         /* Spurious Interrupt ? */
1302                         continue;
1303                 }
1304 
1305                 ips_chkstatus(ha, &cstatus);
1306                 scb = (ips_scb_t *) sp->scb_addr;
1307 
1308                 /*
1309                  * use the callback function to finish things up
1310                  * NOTE: interrupts are OFF for this
1311                  */
1312                 (*scb->callback) (ha, scb);
1313         }                       /* end while */
1314         return 1;
1315 }
1316 
1317 /****************************************************************************/
1318 /*                                                                          */
1319 /* Routine Name: ips_intr_morpheus                                          */
1320 /*                                                                          */
1321 /* Routine Description:                                                     */
1322 /*                                                                          */
1323 /*   Polling interrupt handler                                              */
1324 /*                                                                          */
1325 /*   ASSUMES interrupts are disabled                                        */
1326 /*                                                                          */
1327 /****************************************************************************/
1328 int
1329 ips_intr_morpheus(ips_ha_t * ha)
1330 {
1331         ips_stat_t *sp;
1332         ips_scb_t *scb;
1333         IPS_STATUS cstatus;
1334         int intrstatus;
1335 
1336         METHOD_TRACE("ips_intr_morpheus", 2);
1337 
1338         if (!ha)
1339                 return 0;
1340 
1341         if (!ha->active)
1342                 return 0;
1343 
1344         intrstatus = (*ha->func.isintr) (ha);
1345 
1346         if (!intrstatus) {
1347                 /*
1348                  * Unexpected/Shared interrupt
1349                  */
1350 
1351                 return 0;
1352         }
1353 
1354         while (TRUE) {
1355                 sp = &ha->sp;
1356 
1357                 intrstatus = (*ha->func.isintr) (ha);
1358 
1359                 if (!intrstatus)
1360                         break;
1361                 else
1362                         cstatus.value = (*ha->func.statupd) (ha);
1363 
1364                 if (cstatus.value == 0xffffffff)
1365                         /* No more to process */
1366                         break;
1367 
1368                 if (cstatus.fields.command_id > (IPS_MAX_CMDS - 1)) {
1369                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
1370                                    "Spurious interrupt; no ccb.\n");
1371 
1372                         continue;
1373                 }
1374 
1375                 ips_chkstatus(ha, &cstatus);
1376                 scb = (ips_scb_t *) sp->scb_addr;
1377 
1378                 /*
1379                  * use the callback function to finish things up
1380                  * NOTE: interrupts are OFF for this
1381                  */
1382                 (*scb->callback) (ha, scb);
1383         }                       /* end while */
1384         return 1;
1385 }
1386 
1387 /****************************************************************************/
1388 /*                                                                          */
1389 /* Routine Name: ips_info                                                   */
1390 /*                                                                          */
1391 /* Routine Description:                                                     */
1392 /*                                                                          */
1393 /*   Return info about the driver                                           */
1394 /*                                                                          */
1395 /****************************************************************************/
1396 static const char *
1397 ips_info(struct Scsi_Host *SH)
1398 {
1399         static char buffer[256];
1400         char *bp;
1401         ips_ha_t *ha;
1402 
1403         METHOD_TRACE("ips_info", 1);
1404 
1405         ha = IPS_HA(SH);
1406 
1407         if (!ha)
1408                 return (NULL);
1409 
1410         bp = &buffer[0];
1411         memset(bp, 0, sizeof (buffer));
1412 
1413         sprintf(bp, "%s%s%s Build %d", "IBM PCI ServeRAID ",
1414                 IPS_VERSION_HIGH, IPS_VERSION_LOW, IPS_BUILD_IDENT);
1415 
1416         if (ha->ad_type > 0 && ha->ad_type <= MAX_ADAPTER_NAME) {
1417                 strcat(bp, " <");
1418                 strcat(bp, ips_adapter_name[ha->ad_type - 1]);
1419                 strcat(bp, ">");
1420         }
1421 
1422         return (bp);
1423 }
1424 
1425 static int
1426 ips_write_info(struct Scsi_Host *host, char *buffer, int length)
1427 {
1428         int i;
1429         ips_ha_t *ha = NULL;
1430 
1431         /* Find our host structure */
1432         for (i = 0; i < ips_next_controller; i++) {
1433                 if (ips_sh[i]) {
1434                         if (ips_sh[i] == host) {
1435                                 ha = (ips_ha_t *) ips_sh[i]->hostdata;
1436                                 break;
1437                         }
1438                 }
1439         }
1440 
1441         if (!ha)
1442                 return (-EINVAL);
1443 
1444         return 0;
1445 }
1446 
1447 static int
1448 ips_show_info(struct seq_file *m, struct Scsi_Host *host)
1449 {
1450         int i;
1451         ips_ha_t *ha = NULL;
1452 
1453         /* Find our host structure */
1454         for (i = 0; i < ips_next_controller; i++) {
1455                 if (ips_sh[i]) {
1456                         if (ips_sh[i] == host) {
1457                                 ha = (ips_ha_t *) ips_sh[i]->hostdata;
1458                                 break;
1459                         }
1460                 }
1461         }
1462 
1463         if (!ha)
1464                 return (-EINVAL);
1465 
1466         return ips_host_info(ha, m);
1467 }
1468 
1469 /*--------------------------------------------------------------------------*/
1470 /* Helper Functions                                                         */
1471 /*--------------------------------------------------------------------------*/
1472 
1473 /****************************************************************************/
1474 /*                                                                          */
1475 /* Routine Name: ips_is_passthru                                            */
1476 /*                                                                          */
1477 /* Routine Description:                                                     */
1478 /*                                                                          */
1479 /*   Determine if the specified SCSI command is really a passthru command   */
1480 /*                                                                          */
1481 /****************************************************************************/
1482 static int ips_is_passthru(struct scsi_cmnd *SC)
1483 {
1484         unsigned long flags;
1485 
1486         METHOD_TRACE("ips_is_passthru", 1);
1487 
1488         if (!SC)
1489                 return (0);
1490 
1491         if ((SC->cmnd[0] == IPS_IOCTL_COMMAND) &&
1492             (SC->device->channel == 0) &&
1493             (SC->device->id == IPS_ADAPTER_ID) &&
1494             (SC->device->lun == 0) && scsi_sglist(SC)) {
1495                 struct scatterlist *sg = scsi_sglist(SC);
1496                 char  *buffer;
1497 
1498                 /* kmap_atomic() ensures addressability of the user buffer.*/
1499                 /* local_irq_save() protects the KM_IRQ0 address slot.     */
1500                 local_irq_save(flags);
1501                 buffer = kmap_atomic(sg_page(sg)) + sg->offset;
1502                 if (buffer && buffer[0] == 'C' && buffer[1] == 'O' &&
1503                     buffer[2] == 'P' && buffer[3] == 'P') {
1504                         kunmap_atomic(buffer - sg->offset);
1505                         local_irq_restore(flags);
1506                         return 1;
1507                 }
1508                 kunmap_atomic(buffer - sg->offset);
1509                 local_irq_restore(flags);
1510         }
1511         return 0;
1512 }
1513 
1514 /****************************************************************************/
1515 /*                                                                          */
1516 /* Routine Name: ips_alloc_passthru_buffer                                  */
1517 /*                                                                          */
1518 /* Routine Description:                                                     */
1519 /*   allocate a buffer large enough for the ioctl data if the ioctl buffer  */
1520 /*   is too small or doesn't exist                                          */
1521 /****************************************************************************/
1522 static int
1523 ips_alloc_passthru_buffer(ips_ha_t * ha, int length)
1524 {
1525         void *bigger_buf;
1526         dma_addr_t dma_busaddr;
1527 
1528         if (ha->ioctl_data && length <= ha->ioctl_len)
1529                 return 0;
1530         /* there is no buffer or it's not big enough, allocate a new one */
1531         bigger_buf = dma_alloc_coherent(&ha->pcidev->dev, length, &dma_busaddr,
1532                         GFP_KERNEL);
1533         if (bigger_buf) {
1534                 /* free the old memory */
1535                 dma_free_coherent(&ha->pcidev->dev, ha->ioctl_len,
1536                                   ha->ioctl_data, ha->ioctl_busaddr);
1537                 /* use the new memory */
1538                 ha->ioctl_data = (char *) bigger_buf;
1539                 ha->ioctl_len = length;
1540                 ha->ioctl_busaddr = dma_busaddr;
1541         } else {
1542                 return -1;
1543         }
1544         return 0;
1545 }
1546 
1547 /****************************************************************************/
1548 /*                                                                          */
1549 /* Routine Name: ips_make_passthru                                          */
1550 /*                                                                          */
1551 /* Routine Description:                                                     */
1552 /*                                                                          */
1553 /*   Make a passthru command out of the info in the Scsi block              */
1554 /*                                                                          */
1555 /****************************************************************************/
1556 static int
1557 ips_make_passthru(ips_ha_t *ha, struct scsi_cmnd *SC, ips_scb_t *scb, int intr)
1558 {
1559         ips_passthru_t *pt;
1560         int length = 0;
1561         int i, ret;
1562         struct scatterlist *sg = scsi_sglist(SC);
1563 
1564         METHOD_TRACE("ips_make_passthru", 1);
1565 
1566         scsi_for_each_sg(SC, sg, scsi_sg_count(SC), i)
1567                 length += sg->length;
1568 
1569         if (length < sizeof (ips_passthru_t)) {
1570                 /* wrong size */
1571                 DEBUG_VAR(1, "(%s%d) Passthru structure wrong size",
1572                           ips_name, ha->host_num);
1573                 return (IPS_FAILURE);
1574         }
1575         if (ips_alloc_passthru_buffer(ha, length)) {
1576                 /* allocation failure!  If ha->ioctl_data exists, use it to return
1577                    some error codes.  Return a failed command to the scsi layer. */
1578                 if (ha->ioctl_data) {
1579                         pt = (ips_passthru_t *) ha->ioctl_data;
1580                         ips_scmd_buf_read(SC, pt, sizeof (ips_passthru_t));
1581                         pt->BasicStatus = 0x0B;
1582                         pt->ExtendedStatus = 0x00;
1583                         ips_scmd_buf_write(SC, pt, sizeof (ips_passthru_t));
1584                 }
1585                 return IPS_FAILURE;
1586         }
1587         ha->ioctl_datasize = length;
1588 
1589         ips_scmd_buf_read(SC, ha->ioctl_data, ha->ioctl_datasize);
1590         pt = (ips_passthru_t *) ha->ioctl_data;
1591 
1592         /*
1593          * Some notes about the passthru interface used
1594          *
1595          * IF the scsi op_code == 0x0d then we assume
1596          * that the data came along with/goes with the
1597          * packet we received from the sg driver. In this
1598          * case the CmdBSize field of the pt structure is
1599          * used for the size of the buffer.
1600          */
1601 
1602         switch (pt->CoppCmd) {
1603         case IPS_NUMCTRLS:
1604                 memcpy(ha->ioctl_data + sizeof (ips_passthru_t),
1605                        &ips_num_controllers, sizeof (int));
1606                 ips_scmd_buf_write(SC, ha->ioctl_data,
1607                                    sizeof (ips_passthru_t) + sizeof (int));
1608                 SC->result = DID_OK << 16;
1609 
1610                 return (IPS_SUCCESS_IMM);
1611 
1612         case IPS_COPPUSRCMD:
1613         case IPS_COPPIOCCMD:
1614                 if (SC->cmnd[0] == IPS_IOCTL_COMMAND) {
1615                         if (length < (sizeof (ips_passthru_t) + pt->CmdBSize)) {
1616                                 /* wrong size */
1617                                 DEBUG_VAR(1,
1618                                           "(%s%d) Passthru structure wrong size",
1619                                           ips_name, ha->host_num);
1620 
1621                                 return (IPS_FAILURE);
1622                         }
1623 
1624                         if (ha->pcidev->device == IPS_DEVICEID_COPPERHEAD &&
1625                             pt->CoppCP.cmd.flashfw.op_code ==
1626                             IPS_CMD_RW_BIOSFW) {
1627                                 ret = ips_flash_copperhead(ha, pt, scb);
1628                                 ips_scmd_buf_write(SC, ha->ioctl_data,
1629                                                    sizeof (ips_passthru_t));
1630                                 return ret;
1631                         }
1632                         if (ips_usrcmd(ha, pt, scb))
1633                                 return (IPS_SUCCESS);
1634                         else
1635                                 return (IPS_FAILURE);
1636                 }
1637 
1638                 break;
1639 
1640         }                       /* end switch */
1641 
1642         return (IPS_FAILURE);
1643 }
1644 
1645 /****************************************************************************/
1646 /* Routine Name: ips_flash_copperhead                                       */
1647 /* Routine Description:                                                     */
1648 /*   Flash the BIOS/FW on a Copperhead style controller                     */
1649 /****************************************************************************/
1650 static int
1651 ips_flash_copperhead(ips_ha_t * ha, ips_passthru_t * pt, ips_scb_t * scb)
1652 {
1653         int datasize;
1654 
1655         /* Trombone is the only copperhead that can do packet flash, but only
1656          * for firmware. No one said it had to make sense. */
1657         if (IPS_IS_TROMBONE(ha) && pt->CoppCP.cmd.flashfw.type == IPS_FW_IMAGE) {
1658                 if (ips_usrcmd(ha, pt, scb))
1659                         return IPS_SUCCESS;
1660                 else
1661                         return IPS_FAILURE;
1662         }
1663         pt->BasicStatus = 0x0B;
1664         pt->ExtendedStatus = 0;
1665         scb->scsi_cmd->result = DID_OK << 16;
1666         /* IF it's OK to Use the "CD BOOT" Flash Buffer, then you can     */
1667         /* avoid allocating a huge buffer per adapter ( which can fail ). */
1668         if (pt->CoppCP.cmd.flashfw.type == IPS_BIOS_IMAGE &&
1669             pt->CoppCP.cmd.flashfw.direction == IPS_ERASE_BIOS) {
1670                 pt->BasicStatus = 0;
1671                 return ips_flash_bios(ha, pt, scb);
1672         } else if (pt->CoppCP.cmd.flashfw.packet_num == 0) {
1673                 if (ips_FlashData && !test_and_set_bit(0, &ips_FlashDataInUse)){
1674                         ha->flash_data = ips_FlashData;
1675                         ha->flash_busaddr = ips_flashbusaddr;
1676                         ha->flash_len = PAGE_SIZE << 7;
1677                         ha->flash_datasize = 0;
1678                 } else if (!ha->flash_data) {
1679                         datasize = pt->CoppCP.cmd.flashfw.total_packets *
1680                             pt->CoppCP.cmd.flashfw.count;
1681                         ha->flash_data = dma_alloc_coherent(&ha->pcidev->dev,
1682                                         datasize, &ha->flash_busaddr, GFP_KERNEL);
1683                         if (!ha->flash_data){
1684                                 printk(KERN_WARNING "Unable to allocate a flash buffer\n");
1685                                 return IPS_FAILURE;
1686                         }
1687                         ha->flash_datasize = 0;
1688                         ha->flash_len = datasize;
1689                 } else
1690                         return IPS_FAILURE;
1691         } else {
1692                 if (pt->CoppCP.cmd.flashfw.count + ha->flash_datasize >
1693                     ha->flash_len) {
1694                         ips_free_flash_copperhead(ha);
1695                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
1696                                    "failed size sanity check\n");
1697                         return IPS_FAILURE;
1698                 }
1699         }
1700         if (!ha->flash_data)
1701                 return IPS_FAILURE;
1702         pt->BasicStatus = 0;
1703         memcpy(&ha->flash_data[ha->flash_datasize], pt + 1,
1704                pt->CoppCP.cmd.flashfw.count);
1705         ha->flash_datasize += pt->CoppCP.cmd.flashfw.count;
1706         if (pt->CoppCP.cmd.flashfw.packet_num ==
1707             pt->CoppCP.cmd.flashfw.total_packets - 1) {
1708                 if (pt->CoppCP.cmd.flashfw.type == IPS_BIOS_IMAGE)
1709                         return ips_flash_bios(ha, pt, scb);
1710                 else if (pt->CoppCP.cmd.flashfw.type == IPS_FW_IMAGE)
1711                         return ips_flash_firmware(ha, pt, scb);
1712         }
1713         return IPS_SUCCESS_IMM;
1714 }
1715 
1716 /****************************************************************************/
1717 /* Routine Name: ips_flash_bios                                             */
1718 /* Routine Description:                                                     */
1719 /*   flashes the bios of a copperhead adapter                               */
1720 /****************************************************************************/
1721 static int
1722 ips_flash_bios(ips_ha_t * ha, ips_passthru_t * pt, ips_scb_t * scb)
1723 {
1724 
1725         if (pt->CoppCP.cmd.flashfw.type == IPS_BIOS_IMAGE &&
1726             pt->CoppCP.cmd.flashfw.direction == IPS_WRITE_BIOS) {
1727                 if ((!ha->func.programbios) || (!ha->func.erasebios) ||
1728                     (!ha->func.verifybios))
1729                         goto error;
1730                 if ((*ha->func.erasebios) (ha)) {
1731                         DEBUG_VAR(1,
1732                                   "(%s%d) flash bios failed - unable to erase flash",
1733                                   ips_name, ha->host_num);
1734                         goto error;
1735                 } else
1736                     if ((*ha->func.programbios) (ha,
1737                                                  ha->flash_data +
1738                                                  IPS_BIOS_HEADER,
1739                                                  ha->flash_datasize -
1740                                                  IPS_BIOS_HEADER, 0)) {
1741                         DEBUG_VAR(1,
1742                                   "(%s%d) flash bios failed - unable to flash",
1743                                   ips_name, ha->host_num);
1744                         goto error;
1745                 } else
1746                     if ((*ha->func.verifybios) (ha,
1747                                                 ha->flash_data +
1748                                                 IPS_BIOS_HEADER,
1749                                                 ha->flash_datasize -
1750                                                 IPS_BIOS_HEADER, 0)) {
1751                         DEBUG_VAR(1,
1752                                   "(%s%d) flash bios failed - unable to verify flash",
1753                                   ips_name, ha->host_num);
1754                         goto error;
1755                 }
1756                 ips_free_flash_copperhead(ha);
1757                 return IPS_SUCCESS_IMM;
1758         } else if (pt->CoppCP.cmd.flashfw.type == IPS_BIOS_IMAGE &&
1759                    pt->CoppCP.cmd.flashfw.direction == IPS_ERASE_BIOS) {
1760                 if (!ha->func.erasebios)
1761                         goto error;
1762                 if ((*ha->func.erasebios) (ha)) {
1763                         DEBUG_VAR(1,
1764                                   "(%s%d) flash bios failed - unable to erase flash",
1765                                   ips_name, ha->host_num);
1766                         goto error;
1767                 }
1768                 return IPS_SUCCESS_IMM;
1769         }
1770       error:
1771         pt->BasicStatus = 0x0B;
1772         pt->ExtendedStatus = 0x00;
1773         ips_free_flash_copperhead(ha);
1774         return IPS_FAILURE;
1775 }
1776 
1777 /****************************************************************************/
1778 /*                                                                          */
1779 /* Routine Name: ips_fill_scb_sg_single                                     */
1780 /*                                                                          */
1781 /* Routine Description:                                                     */
1782 /*   Fill in a single scb sg_list element from an address                   */
1783 /*   return a -1 if a breakup occurred                                      */
1784 /****************************************************************************/
1785 static int
1786 ips_fill_scb_sg_single(ips_ha_t * ha, dma_addr_t busaddr,
1787                        ips_scb_t * scb, int indx, unsigned int e_len)
1788 {
1789 
1790         int ret_val = 0;
1791 
1792         if ((scb->data_len + e_len) > ha->max_xfer) {
1793                 e_len = ha->max_xfer - scb->data_len;
1794                 scb->breakup = indx;
1795                 ++scb->sg_break;
1796                 ret_val = -1;
1797         } else {
1798                 scb->breakup = 0;
1799                 scb->sg_break = 0;
1800         }
1801         if (IPS_USE_ENH_SGLIST(ha)) {
1802                 scb->sg_list.enh_list[indx].address_lo =
1803                     cpu_to_le32(lower_32_bits(busaddr));
1804                 scb->sg_list.enh_list[indx].address_hi =
1805                     cpu_to_le32(upper_32_bits(busaddr));
1806                 scb->sg_list.enh_list[indx].length = cpu_to_le32(e_len);
1807         } else {
1808                 scb->sg_list.std_list[indx].address =
1809                     cpu_to_le32(lower_32_bits(busaddr));
1810                 scb->sg_list.std_list[indx].length = cpu_to_le32(e_len);
1811         }
1812 
1813         ++scb->sg_len;
1814         scb->data_len += e_len;
1815         return ret_val;
1816 }
1817 
1818 /****************************************************************************/
1819 /* Routine Name: ips_flash_firmware                                         */
1820 /* Routine Description:                                                     */
1821 /*   flashes the firmware of a copperhead adapter                           */
1822 /****************************************************************************/
1823 static int
1824 ips_flash_firmware(ips_ha_t * ha, ips_passthru_t * pt, ips_scb_t * scb)
1825 {
1826         IPS_SG_LIST sg_list;
1827         uint32_t cmd_busaddr;
1828 
1829         if (pt->CoppCP.cmd.flashfw.type == IPS_FW_IMAGE &&
1830             pt->CoppCP.cmd.flashfw.direction == IPS_WRITE_FW) {
1831                 memset(&pt->CoppCP.cmd, 0, sizeof (IPS_HOST_COMMAND));
1832                 pt->CoppCP.cmd.flashfw.op_code = IPS_CMD_DOWNLOAD;
1833                 pt->CoppCP.cmd.flashfw.count = cpu_to_le32(ha->flash_datasize);
1834         } else {
1835                 pt->BasicStatus = 0x0B;
1836                 pt->ExtendedStatus = 0x00;
1837                 ips_free_flash_copperhead(ha);
1838                 return IPS_FAILURE;
1839         }
1840         /* Save the S/G list pointer so it doesn't get clobbered */
1841         sg_list.list = scb->sg_list.list;
1842         cmd_busaddr = scb->scb_busaddr;
1843         /* copy in the CP */
1844         memcpy(&scb->cmd, &pt->CoppCP.cmd, sizeof (IPS_IOCTL_CMD));
1845         /* FIX stuff that might be wrong */
1846         scb->sg_list.list = sg_list.list;
1847         scb->scb_busaddr = cmd_busaddr;
1848         scb->bus = scb->scsi_cmd->device->channel;
1849         scb->target_id = scb->scsi_cmd->device->id;
1850         scb->lun = scb->scsi_cmd->device->lun;
1851         scb->sg_len = 0;
1852         scb->data_len = 0;
1853         scb->flags = 0;
1854         scb->op_code = 0;
1855         scb->callback = ipsintr_done;
1856         scb->timeout = ips_cmd_timeout;
1857 
1858         scb->data_len = ha->flash_datasize;
1859         scb->data_busaddr =
1860             dma_map_single(&ha->pcidev->dev, ha->flash_data, scb->data_len,
1861                            IPS_DMA_DIR(scb));
1862         scb->flags |= IPS_SCB_MAP_SINGLE;
1863         scb->cmd.flashfw.command_id = IPS_COMMAND_ID(ha, scb);
1864         scb->cmd.flashfw.buffer_addr = cpu_to_le32(scb->data_busaddr);
1865         if (pt->TimeOut)
1866                 scb->timeout = pt->TimeOut;
1867         scb->scsi_cmd->result = DID_OK << 16;
1868         return IPS_SUCCESS;
1869 }
1870 
1871 /****************************************************************************/
1872 /* Routine Name: ips_free_flash_copperhead                                  */
1873 /* Routine Description:                                                     */
1874 /*   release the memory resources used to hold the flash image              */
1875 /****************************************************************************/
1876 static void
1877 ips_free_flash_copperhead(ips_ha_t * ha)
1878 {
1879         if (ha->flash_data == ips_FlashData)
1880                 test_and_clear_bit(0, &ips_FlashDataInUse);
1881         else if (ha->flash_data)
1882                 dma_free_coherent(&ha->pcidev->dev, ha->flash_len,
1883                                   ha->flash_data, ha->flash_busaddr);
1884         ha->flash_data = NULL;
1885 }
1886 
1887 /****************************************************************************/
1888 /*                                                                          */
1889 /* Routine Name: ips_usrcmd                                                 */
1890 /*                                                                          */
1891 /* Routine Description:                                                     */
1892 /*                                                                          */
1893 /*   Process a user command and make it ready to send                       */
1894 /*                                                                          */
1895 /****************************************************************************/
1896 static int
1897 ips_usrcmd(ips_ha_t * ha, ips_passthru_t * pt, ips_scb_t * scb)
1898 {
1899         IPS_SG_LIST sg_list;
1900         uint32_t cmd_busaddr;
1901 
1902         METHOD_TRACE("ips_usrcmd", 1);
1903 
1904         if ((!scb) || (!pt) || (!ha))
1905                 return (0);
1906 
1907         /* Save the S/G list pointer so it doesn't get clobbered */
1908         sg_list.list = scb->sg_list.list;
1909         cmd_busaddr = scb->scb_busaddr;
1910         /* copy in the CP */
1911         memcpy(&scb->cmd, &pt->CoppCP.cmd, sizeof (IPS_IOCTL_CMD));
1912         memcpy(&scb->dcdb, &pt->CoppCP.dcdb, sizeof (IPS_DCDB_TABLE));
1913 
1914         /* FIX stuff that might be wrong */
1915         scb->sg_list.list = sg_list.list;
1916         scb->scb_busaddr = cmd_busaddr;
1917         scb->bus = scb->scsi_cmd->device->channel;
1918         scb->target_id = scb->scsi_cmd->device->id;
1919         scb->lun = scb->scsi_cmd->device->lun;
1920         scb->sg_len = 0;
1921         scb->data_len = 0;
1922         scb->flags = 0;
1923         scb->op_code = 0;
1924         scb->callback = ipsintr_done;
1925         scb->timeout = ips_cmd_timeout;
1926         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
1927 
1928         /* we don't support DCDB/READ/WRITE Scatter Gather */
1929         if ((scb->cmd.basic_io.op_code == IPS_CMD_READ_SG) ||
1930             (scb->cmd.basic_io.op_code == IPS_CMD_WRITE_SG) ||
1931             (scb->cmd.basic_io.op_code == IPS_CMD_DCDB_SG))
1932                 return (0);
1933 
1934         if (pt->CmdBSize) {
1935                 scb->data_len = pt->CmdBSize;
1936                 scb->data_busaddr = ha->ioctl_busaddr + sizeof (ips_passthru_t);
1937         } else {
1938                 scb->data_busaddr = 0L;
1939         }
1940 
1941         if (scb->cmd.dcdb.op_code == IPS_CMD_DCDB)
1942                 scb->cmd.dcdb.dcdb_address = cpu_to_le32(scb->scb_busaddr +
1943                                                          (unsigned long) &scb->
1944                                                          dcdb -
1945                                                          (unsigned long) scb);
1946 
1947         if (pt->CmdBSize) {
1948                 if (scb->cmd.dcdb.op_code == IPS_CMD_DCDB)
1949                         scb->dcdb.buffer_pointer =
1950                             cpu_to_le32(scb->data_busaddr);
1951                 else
1952                         scb->cmd.basic_io.sg_addr =
1953                             cpu_to_le32(scb->data_busaddr);
1954         }
1955 
1956         /* set timeouts */
1957         if (pt->TimeOut) {
1958                 scb->timeout = pt->TimeOut;
1959 
1960                 if (pt->TimeOut <= 10)
1961                         scb->dcdb.cmd_attribute |= IPS_TIMEOUT10;
1962                 else if (pt->TimeOut <= 60)
1963                         scb->dcdb.cmd_attribute |= IPS_TIMEOUT60;
1964                 else
1965                         scb->dcdb.cmd_attribute |= IPS_TIMEOUT20M;
1966         }
1967 
1968         /* assume success */
1969         scb->scsi_cmd->result = DID_OK << 16;
1970 
1971         /* success */
1972         return (1);
1973 }
1974 
1975 /****************************************************************************/
1976 /*                                                                          */
1977 /* Routine Name: ips_cleanup_passthru                                       */
1978 /*                                                                          */
1979 /* Routine Description:                                                     */
1980 /*                                                                          */
1981 /*   Cleanup after a passthru command                                       */
1982 /*                                                                          */
1983 /****************************************************************************/
1984 static void
1985 ips_cleanup_passthru(ips_ha_t * ha, ips_scb_t * scb)
1986 {
1987         ips_passthru_t *pt;
1988 
1989         METHOD_TRACE("ips_cleanup_passthru", 1);
1990 
1991         if ((!scb) || (!scb->scsi_cmd) || (!scsi_sglist(scb->scsi_cmd))) {
1992                 DEBUG_VAR(1, "(%s%d) couldn't cleanup after passthru",
1993                           ips_name, ha->host_num);
1994 
1995                 return;
1996         }
1997         pt = (ips_passthru_t *) ha->ioctl_data;
1998 
1999         /* Copy data back to the user */
2000         if (scb->cmd.dcdb.op_code == IPS_CMD_DCDB)      /* Copy DCDB Back to Caller's Area */
2001                 memcpy(&pt->CoppCP.dcdb, &scb->dcdb, sizeof (IPS_DCDB_TABLE));
2002 
2003         pt->BasicStatus = scb->basic_status;
2004         pt->ExtendedStatus = scb->extended_status;
2005         pt->AdapterType = ha->ad_type;
2006 
2007         if (ha->pcidev->device == IPS_DEVICEID_COPPERHEAD &&
2008             (scb->cmd.flashfw.op_code == IPS_CMD_DOWNLOAD ||
2009              scb->cmd.flashfw.op_code == IPS_CMD_RW_BIOSFW))
2010                 ips_free_flash_copperhead(ha);
2011 
2012         ips_scmd_buf_write(scb->scsi_cmd, ha->ioctl_data, ha->ioctl_datasize);
2013 }
2014 
2015 /****************************************************************************/
2016 /*                                                                          */
2017 /* Routine Name: ips_host_info                                              */
2018 /*                                                                          */
2019 /* Routine Description:                                                     */
2020 /*                                                                          */
2021 /*   The passthru interface for the driver                                  */
2022 /*                                                                          */
2023 /****************************************************************************/
2024 static int
2025 ips_host_info(ips_ha_t *ha, struct seq_file *m)
2026 {
2027         METHOD_TRACE("ips_host_info", 1);
2028 
2029         seq_puts(m, "\nIBM ServeRAID General Information:\n\n");
2030 
2031         if ((le32_to_cpu(ha->nvram->signature) == IPS_NVRAM_P5_SIG) &&
2032             (le16_to_cpu(ha->nvram->adapter_type) != 0))
2033                 seq_printf(m, "\tController Type                   : %s\n",
2034                           ips_adapter_name[ha->ad_type - 1]);
2035         else
2036                 seq_puts(m, "\tController Type                   : Unknown\n");
2037 
2038         if (ha->io_addr)
2039                 seq_printf(m,
2040                           "\tIO region                         : 0x%x (%d bytes)\n",
2041                           ha->io_addr, ha->io_len);
2042 
2043         if (ha->mem_addr) {
2044                 seq_printf(m,
2045                           "\tMemory region                     : 0x%x (%d bytes)\n",
2046                           ha->mem_addr, ha->mem_len);
2047                 seq_printf(m,
2048                           "\tShared memory address             : 0x%lx\n",
2049                           (unsigned long)ha->mem_ptr);
2050         }
2051 
2052         seq_printf(m, "\tIRQ number                        : %d\n", ha->pcidev->irq);
2053 
2054     /* For the Next 3 lines Check for Binary 0 at the end and don't include it if it's there. */
2055     /* That keeps everything happy for "text" operations on the proc file.                    */
2056 
2057         if (le32_to_cpu(ha->nvram->signature) == IPS_NVRAM_P5_SIG) {
2058         if (ha->nvram->bios_low[3] == 0) {
2059                 seq_printf(m,
2060                           "\tBIOS Version                      : %c%c%c%c%c%c%c\n",
2061                           ha->nvram->bios_high[0], ha->nvram->bios_high[1],
2062                           ha->nvram->bios_high[2], ha->nvram->bios_high[3],
2063                           ha->nvram->bios_low[0], ha->nvram->bios_low[1],
2064                           ha->nvram->bios_low[2]);
2065 
2066         } else {
2067                 seq_printf(m,
2068                           "\tBIOS Version                      : %c%c%c%c%c%c%c%c\n",
2069                           ha->nvram->bios_high[0], ha->nvram->bios_high[1],
2070                           ha->nvram->bios_high[2], ha->nvram->bios_high[3],
2071                           ha->nvram->bios_low[0], ha->nvram->bios_low[1],
2072                           ha->nvram->bios_low[2], ha->nvram->bios_low[3]);
2073         }
2074 
2075     }
2076 
2077     if (ha->enq->CodeBlkVersion[7] == 0) {
2078         seq_printf(m,
2079                   "\tFirmware Version                  : %c%c%c%c%c%c%c\n",
2080                   ha->enq->CodeBlkVersion[0], ha->enq->CodeBlkVersion[1],
2081                   ha->enq->CodeBlkVersion[2], ha->enq->CodeBlkVersion[3],
2082                   ha->enq->CodeBlkVersion[4], ha->enq->CodeBlkVersion[5],
2083                   ha->enq->CodeBlkVersion[6]);
2084     } else {
2085         seq_printf(m,
2086                   "\tFirmware Version                  : %c%c%c%c%c%c%c%c\n",
2087                   ha->enq->CodeBlkVersion[0], ha->enq->CodeBlkVersion[1],
2088                   ha->enq->CodeBlkVersion[2], ha->enq->CodeBlkVersion[3],
2089                   ha->enq->CodeBlkVersion[4], ha->enq->CodeBlkVersion[5],
2090                   ha->enq->CodeBlkVersion[6], ha->enq->CodeBlkVersion[7]);
2091     }
2092 
2093     if (ha->enq->BootBlkVersion[7] == 0) {
2094         seq_printf(m,
2095                   "\tBoot Block Version                : %c%c%c%c%c%c%c\n",
2096                   ha->enq->BootBlkVersion[0], ha->enq->BootBlkVersion[1],
2097                   ha->enq->BootBlkVersion[2], ha->enq->BootBlkVersion[3],
2098                   ha->enq->BootBlkVersion[4], ha->enq->BootBlkVersion[5],
2099                   ha->enq->BootBlkVersion[6]);
2100     } else {
2101         seq_printf(m,
2102                   "\tBoot Block Version                : %c%c%c%c%c%c%c%c\n",
2103                   ha->enq->BootBlkVersion[0], ha->enq->BootBlkVersion[1],
2104                   ha->enq->BootBlkVersion[2], ha->enq->BootBlkVersion[3],
2105                   ha->enq->BootBlkVersion[4], ha->enq->BootBlkVersion[5],
2106                   ha->enq->BootBlkVersion[6], ha->enq->BootBlkVersion[7]);
2107     }
2108 
2109         seq_printf(m, "\tDriver Version                    : %s%s\n",
2110                   IPS_VERSION_HIGH, IPS_VERSION_LOW);
2111 
2112         seq_printf(m, "\tDriver Build                      : %d\n",
2113                   IPS_BUILD_IDENT);
2114 
2115         seq_printf(m, "\tMax Physical Devices              : %d\n",
2116                   ha->enq->ucMaxPhysicalDevices);
2117         seq_printf(m, "\tMax Active Commands               : %d\n",
2118                   ha->max_cmds);
2119         seq_printf(m, "\tCurrent Queued Commands           : %d\n",
2120                   ha->scb_waitlist.count);
2121         seq_printf(m, "\tCurrent Active Commands           : %d\n",
2122                   ha->scb_activelist.count - ha->num_ioctl);
2123         seq_printf(m, "\tCurrent Queued PT Commands        : %d\n",
2124                   ha->copp_waitlist.count);
2125         seq_printf(m, "\tCurrent Active PT Commands        : %d\n",
2126                   ha->num_ioctl);
2127 
2128         seq_putc(m, '\n');
2129 
2130         return 0;
2131 }
2132 
2133 /****************************************************************************/
2134 /*                                                                          */
2135 /* Routine Name: ips_identify_controller                                    */
2136 /*                                                                          */
2137 /* Routine Description:                                                     */
2138 /*                                                                          */
2139 /*   Identify this controller                                               */
2140 /*                                                                          */
2141 /****************************************************************************/
2142 static void
2143 ips_identify_controller(ips_ha_t * ha)
2144 {
2145         METHOD_TRACE("ips_identify_controller", 1);
2146 
2147         switch (ha->pcidev->device) {
2148         case IPS_DEVICEID_COPPERHEAD:
2149                 if (ha->pcidev->revision <= IPS_REVID_SERVERAID) {
2150                         ha->ad_type = IPS_ADTYPE_SERVERAID;
2151                 } else if (ha->pcidev->revision == IPS_REVID_SERVERAID2) {
2152                         ha->ad_type = IPS_ADTYPE_SERVERAID2;
2153                 } else if (ha->pcidev->revision == IPS_REVID_NAVAJO) {
2154                         ha->ad_type = IPS_ADTYPE_NAVAJO;
2155                 } else if ((ha->pcidev->revision == IPS_REVID_SERVERAID2)
2156                            && (ha->slot_num == 0)) {
2157                         ha->ad_type = IPS_ADTYPE_KIOWA;
2158                 } else if ((ha->pcidev->revision >= IPS_REVID_CLARINETP1) &&
2159                            (ha->pcidev->revision <= IPS_REVID_CLARINETP3)) {
2160                         if (ha->enq->ucMaxPhysicalDevices == 15)
2161                                 ha->ad_type = IPS_ADTYPE_SERVERAID3L;
2162                         else
2163                                 ha->ad_type = IPS_ADTYPE_SERVERAID3;
2164                 } else if ((ha->pcidev->revision >= IPS_REVID_TROMBONE32) &&
2165                            (ha->pcidev->revision <= IPS_REVID_TROMBONE64)) {
2166                         ha->ad_type = IPS_ADTYPE_SERVERAID4H;
2167                 }
2168                 break;
2169 
2170         case IPS_DEVICEID_MORPHEUS:
2171                 switch (ha->pcidev->subsystem_device) {
2172                 case IPS_SUBDEVICEID_4L:
2173                         ha->ad_type = IPS_ADTYPE_SERVERAID4L;
2174                         break;
2175 
2176                 case IPS_SUBDEVICEID_4M:
2177                         ha->ad_type = IPS_ADTYPE_SERVERAID4M;
2178                         break;
2179 
2180                 case IPS_SUBDEVICEID_4MX:
2181                         ha->ad_type = IPS_ADTYPE_SERVERAID4MX;
2182                         break;
2183 
2184                 case IPS_SUBDEVICEID_4LX:
2185                         ha->ad_type = IPS_ADTYPE_SERVERAID4LX;
2186                         break;
2187 
2188                 case IPS_SUBDEVICEID_5I2:
2189                         ha->ad_type = IPS_ADTYPE_SERVERAID5I2;
2190                         break;
2191 
2192                 case IPS_SUBDEVICEID_5I1:
2193                         ha->ad_type = IPS_ADTYPE_SERVERAID5I1;
2194                         break;
2195                 }
2196 
2197                 break;
2198 
2199         case IPS_DEVICEID_MARCO:
2200                 switch (ha->pcidev->subsystem_device) {
2201                 case IPS_SUBDEVICEID_6M:
2202                         ha->ad_type = IPS_ADTYPE_SERVERAID6M;
2203                         break;
2204                 case IPS_SUBDEVICEID_6I:
2205                         ha->ad_type = IPS_ADTYPE_SERVERAID6I;
2206                         break;
2207                 case IPS_SUBDEVICEID_7k:
2208                         ha->ad_type = IPS_ADTYPE_SERVERAID7k;
2209                         break;
2210                 case IPS_SUBDEVICEID_7M:
2211                         ha->ad_type = IPS_ADTYPE_SERVERAID7M;
2212                         break;
2213                 }
2214                 break;
2215         }
2216 }
2217 
2218 /****************************************************************************/
2219 /*                                                                          */
2220 /* Routine Name: ips_get_bios_version                                       */
2221 /*                                                                          */
2222 /* Routine Description:                                                     */
2223 /*                                                                          */
2224 /*   Get the BIOS revision number                                           */
2225 /*                                                                          */
2226 /****************************************************************************/
2227 static void
2228 ips_get_bios_version(ips_ha_t * ha, int intr)
2229 {
2230         ips_scb_t *scb;
2231         int ret;
2232         uint8_t major;
2233         uint8_t minor;
2234         uint8_t subminor;
2235         uint8_t *buffer;
2236 
2237         METHOD_TRACE("ips_get_bios_version", 1);
2238 
2239         major = 0;
2240         minor = 0;
2241 
2242         strncpy(ha->bios_version, "       ?", 8);
2243 
2244         if (ha->pcidev->device == IPS_DEVICEID_COPPERHEAD) {
2245                 if (IPS_USE_MEMIO(ha)) {
2246                         /* Memory Mapped I/O */
2247 
2248                         /* test 1st byte */
2249                         writel(0, ha->mem_ptr + IPS_REG_FLAP);
2250                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2251                                 udelay(25);     /* 25 us */
2252 
2253                         if (readb(ha->mem_ptr + IPS_REG_FLDP) != 0x55)
2254                                 return;
2255 
2256                         writel(1, ha->mem_ptr + IPS_REG_FLAP);
2257                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2258                                 udelay(25);     /* 25 us */
2259 
2260                         if (readb(ha->mem_ptr + IPS_REG_FLDP) != 0xAA)
2261                                 return;
2262 
2263                         /* Get Major version */
2264                         writel(0x1FF, ha->mem_ptr + IPS_REG_FLAP);
2265                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2266                                 udelay(25);     /* 25 us */
2267 
2268                         major = readb(ha->mem_ptr + IPS_REG_FLDP);
2269 
2270                         /* Get Minor version */
2271                         writel(0x1FE, ha->mem_ptr + IPS_REG_FLAP);
2272                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2273                                 udelay(25);     /* 25 us */
2274                         minor = readb(ha->mem_ptr + IPS_REG_FLDP);
2275 
2276                         /* Get SubMinor version */
2277                         writel(0x1FD, ha->mem_ptr + IPS_REG_FLAP);
2278                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2279                                 udelay(25);     /* 25 us */
2280                         subminor = readb(ha->mem_ptr + IPS_REG_FLDP);
2281 
2282                 } else {
2283                         /* Programmed I/O */
2284 
2285                         /* test 1st byte */
2286                         outl(0, ha->io_addr + IPS_REG_FLAP);
2287                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2288                                 udelay(25);     /* 25 us */
2289 
2290                         if (inb(ha->io_addr + IPS_REG_FLDP) != 0x55)
2291                                 return;
2292 
2293                         outl(1, ha->io_addr + IPS_REG_FLAP);
2294                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2295                                 udelay(25);     /* 25 us */
2296 
2297                         if (inb(ha->io_addr + IPS_REG_FLDP) != 0xAA)
2298                                 return;
2299 
2300                         /* Get Major version */
2301                         outl(0x1FF, ha->io_addr + IPS_REG_FLAP);
2302                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2303                                 udelay(25);     /* 25 us */
2304 
2305                         major = inb(ha->io_addr + IPS_REG_FLDP);
2306 
2307                         /* Get Minor version */
2308                         outl(0x1FE, ha->io_addr + IPS_REG_FLAP);
2309                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2310                                 udelay(25);     /* 25 us */
2311 
2312                         minor = inb(ha->io_addr + IPS_REG_FLDP);
2313 
2314                         /* Get SubMinor version */
2315                         outl(0x1FD, ha->io_addr + IPS_REG_FLAP);
2316                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
2317                                 udelay(25);     /* 25 us */
2318 
2319                         subminor = inb(ha->io_addr + IPS_REG_FLDP);
2320 
2321                 }
2322         } else {
2323                 /* Morpheus Family - Send Command to the card */
2324 
2325                 buffer = ha->ioctl_data;
2326 
2327                 memset(buffer, 0, 0x1000);
2328 
2329                 scb = &ha->scbs[ha->max_cmds - 1];
2330 
2331                 ips_init_scb(ha, scb);
2332 
2333                 scb->timeout = ips_cmd_timeout;
2334                 scb->cdb[0] = IPS_CMD_RW_BIOSFW;
2335 
2336                 scb->cmd.flashfw.op_code = IPS_CMD_RW_BIOSFW;
2337                 scb->cmd.flashfw.command_id = IPS_COMMAND_ID(ha, scb);
2338                 scb->cmd.flashfw.type = 1;
2339                 scb->cmd.flashfw.direction = 0;
2340                 scb->cmd.flashfw.count = cpu_to_le32(0x800);
2341                 scb->cmd.flashfw.total_packets = 1;
2342                 scb->cmd.flashfw.packet_num = 0;
2343                 scb->data_len = 0x1000;
2344                 scb->cmd.flashfw.buffer_addr = ha->ioctl_busaddr;
2345 
2346                 /* issue the command */
2347                 if (((ret =
2348                       ips_send_wait(ha, scb, ips_cmd_timeout,
2349                                     intr)) == IPS_FAILURE)
2350                     || (ret == IPS_SUCCESS_IMM)
2351                     || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1)) {
2352                         /* Error occurred */
2353 
2354                         return;
2355                 }
2356 
2357                 if ((buffer[0xC0] == 0x55) && (buffer[0xC1] == 0xAA)) {
2358                         major = buffer[0x1ff + 0xC0];   /* Offset 0x1ff after the header (0xc0) */
2359                         minor = buffer[0x1fe + 0xC0];   /* Offset 0x1fe after the header (0xc0) */
2360                         subminor = buffer[0x1fd + 0xC0];        /* Offset 0x1fd after the header (0xc0) */
2361                 } else {
2362                         return;
2363                 }
2364         }
2365 
2366         ha->bios_version[0] = hex_asc_upper_hi(major);
2367         ha->bios_version[1] = '.';
2368         ha->bios_version[2] = hex_asc_upper_lo(major);
2369         ha->bios_version[3] = hex_asc_upper_lo(subminor);
2370         ha->bios_version[4] = '.';
2371         ha->bios_version[5] = hex_asc_upper_hi(minor);
2372         ha->bios_version[6] = hex_asc_upper_lo(minor);
2373         ha->bios_version[7] = 0;
2374 }
2375 
2376 /****************************************************************************/
2377 /*                                                                          */
2378 /* Routine Name: ips_hainit                                                 */
2379 /*                                                                          */
2380 /* Routine Description:                                                     */
2381 /*                                                                          */
2382 /*   Initialize the controller                                              */
2383 /*                                                                          */
2384 /* NOTE: Assumes to be called from with a lock                              */
2385 /*                                                                          */
2386 /****************************************************************************/
2387 static int
2388 ips_hainit(ips_ha_t * ha)
2389 {
2390         int i;
2391 
2392         METHOD_TRACE("ips_hainit", 1);
2393 
2394         if (!ha)
2395                 return (0);
2396 
2397         if (ha->func.statinit)
2398                 (*ha->func.statinit) (ha);
2399 
2400         if (ha->func.enableint)
2401                 (*ha->func.enableint) (ha);
2402 
2403         /* Send FFDC */
2404         ha->reset_count = 1;
2405         ha->last_ffdc = ktime_get_real_seconds();
2406         ips_ffdc_reset(ha, IPS_INTR_IORL);
2407 
2408         if (!ips_read_config(ha, IPS_INTR_IORL)) {
2409                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
2410                            "unable to read config from controller.\n");
2411 
2412                 return (0);
2413         }
2414         /* end if */
2415         if (!ips_read_adapter_status(ha, IPS_INTR_IORL)) {
2416                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
2417                            "unable to read controller status.\n");
2418 
2419                 return (0);
2420         }
2421 
2422         /* Identify this controller */
2423         ips_identify_controller(ha);
2424 
2425         if (!ips_read_subsystem_parameters(ha, IPS_INTR_IORL)) {
2426                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
2427                            "unable to read subsystem parameters.\n");
2428 
2429                 return (0);
2430         }
2431 
2432         /* write nvram user page 5 */
2433         if (!ips_write_driver_status(ha, IPS_INTR_IORL)) {
2434                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
2435                            "unable to write driver info to controller.\n");
2436 
2437                 return (0);
2438         }
2439 
2440         /* If there are Logical Drives and a Reset Occurred, then an EraseStripeLock is Needed */
2441         if ((ha->conf->ucLogDriveCount > 0) && (ha->requires_esl == 1))
2442                 ips_clear_adapter(ha, IPS_INTR_IORL);
2443 
2444         /* set limits on SID, LUN, BUS */
2445         ha->ntargets = IPS_MAX_TARGETS + 1;
2446         ha->nlun = 1;
2447         ha->nbus = (ha->enq->ucMaxPhysicalDevices / IPS_MAX_TARGETS) + 1;
2448 
2449         switch (ha->conf->logical_drive[0].ucStripeSize) {
2450         case 4:
2451                 ha->max_xfer = 0x10000;
2452                 break;
2453 
2454         case 5:
2455                 ha->max_xfer = 0x20000;
2456                 break;
2457 
2458         case 6:
2459                 ha->max_xfer = 0x40000;
2460                 break;
2461 
2462         case 7:
2463         default:
2464                 ha->max_xfer = 0x80000;
2465                 break;
2466         }
2467 
2468         /* setup max concurrent commands */
2469         if (le32_to_cpu(ha->subsys->param[4]) & 0x1) {
2470                 /* Use the new method */
2471                 ha->max_cmds = ha->enq->ucConcurrentCmdCount;
2472         } else {
2473                 /* use the old method */
2474                 switch (ha->conf->logical_drive[0].ucStripeSize) {
2475                 case 4:
2476                         ha->max_cmds = 32;
2477                         break;
2478 
2479                 case 5:
2480                         ha->max_cmds = 16;
2481                         break;
2482 
2483                 case 6:
2484                         ha->max_cmds = 8;
2485                         break;
2486 
2487                 case 7:
2488                 default:
2489                         ha->max_cmds = 4;
2490                         break;
2491                 }
2492         }
2493 
2494         /* Limit the Active Commands on a Lite Adapter */
2495         if ((ha->ad_type == IPS_ADTYPE_SERVERAID3L) ||
2496             (ha->ad_type == IPS_ADTYPE_SERVERAID4L) ||
2497             (ha->ad_type == IPS_ADTYPE_SERVERAID4LX)) {
2498                 if ((ha->max_cmds > MaxLiteCmds) && (MaxLiteCmds))
2499                         ha->max_cmds = MaxLiteCmds;
2500         }
2501 
2502         /* set controller IDs */
2503         ha->ha_id[0] = IPS_ADAPTER_ID;
2504         for (i = 1; i < ha->nbus; i++) {
2505                 ha->ha_id[i] = ha->conf->init_id[i - 1] & 0x1f;
2506                 ha->dcdb_active[i - 1] = 0;
2507         }
2508 
2509         return (1);
2510 }
2511 
2512 /****************************************************************************/
2513 /*                                                                          */
2514 /* Routine Name: ips_next                                                   */
2515 /*                                                                          */
2516 /* Routine Description:                                                     */
2517 /*                                                                          */
2518 /*   Take the next command off the queue and send it to the controller      */
2519 /*                                                                          */
2520 /****************************************************************************/
2521 static void
2522 ips_next(ips_ha_t * ha, int intr)
2523 {
2524         ips_scb_t *scb;
2525         struct scsi_cmnd *SC;
2526         struct scsi_cmnd *p;
2527         struct scsi_cmnd *q;
2528         ips_copp_wait_item_t *item;
2529         int ret;
2530         struct Scsi_Host *host;
2531         METHOD_TRACE("ips_next", 1);
2532 
2533         if (!ha)
2534                 return;
2535         host = ips_sh[ha->host_num];
2536         /*
2537          * Block access to the queue function so
2538          * this command won't time out
2539          */
2540         if (intr == IPS_INTR_ON)
2541                 spin_lock(host->host_lock);
2542 
2543         if ((ha->subsys->param[3] & 0x300000)
2544             && (ha->scb_activelist.count == 0)) {
2545                 time64_t now = ktime_get_real_seconds();
2546                 if (now - ha->last_ffdc > IPS_SECS_8HOURS) {
2547                         ha->last_ffdc = now;
2548                         ips_ffdc_time(ha);
2549                 }
2550         }
2551 
2552         /*
2553          * Send passthru commands
2554          * These have priority over normal I/O
2555          * but shouldn't affect performance too much
2556          * since we limit the number that can be active
2557          * on the card at any one time
2558          */
2559         while ((ha->num_ioctl < IPS_MAX_IOCTL) &&
2560                (ha->copp_waitlist.head) && (scb = ips_getscb(ha))) {
2561 
2562                 item = ips_removeq_copp_head(&ha->copp_waitlist);
2563                 ha->num_ioctl++;
2564                 if (intr == IPS_INTR_ON)
2565                         spin_unlock(host->host_lock);
2566                 scb->scsi_cmd = item->scsi_cmd;
2567                 kfree(item);
2568 
2569                 ret = ips_make_passthru(ha, scb->scsi_cmd, scb, intr);
2570 
2571                 if (intr == IPS_INTR_ON)
2572                         spin_lock(host->host_lock);
2573                 switch (ret) {
2574                 case IPS_FAILURE:
2575                         if (scb->scsi_cmd) {
2576                                 scb->scsi_cmd->result = DID_ERROR << 16;
2577                                 scb->scsi_cmd->scsi_done(scb->scsi_cmd);
2578                         }
2579 
2580                         ips_freescb(ha, scb);
2581                         break;
2582                 case IPS_SUCCESS_IMM:
2583                         if (scb->scsi_cmd) {
2584                                 scb->scsi_cmd->result = DID_OK << 16;
2585                                 scb->scsi_cmd->scsi_done(scb->scsi_cmd);
2586                         }
2587 
2588                         ips_freescb(ha, scb);
2589                         break;
2590                 default:
2591                         break;
2592                 }               /* end case */
2593 
2594                 if (ret != IPS_SUCCESS) {
2595                         ha->num_ioctl--;
2596                         continue;
2597                 }
2598 
2599                 ret = ips_send_cmd(ha, scb);
2600 
2601                 if (ret == IPS_SUCCESS)
2602                         ips_putq_scb_head(&ha->scb_activelist, scb);
2603                 else
2604                         ha->num_ioctl--;
2605 
2606                 switch (ret) {
2607                 case IPS_FAILURE:
2608                         if (scb->scsi_cmd) {
2609                                 scb->scsi_cmd->result = DID_ERROR << 16;
2610                         }
2611 
2612                         ips_freescb(ha, scb);
2613                         break;
2614                 case IPS_SUCCESS_IMM:
2615                         ips_freescb(ha, scb);
2616                         break;
2617                 default:
2618                         break;
2619                 }               /* end case */
2620 
2621         }
2622 
2623         /*
2624          * Send "Normal" I/O commands
2625          */
2626 
2627         p = ha->scb_waitlist.head;
2628         while ((p) && (scb = ips_getscb(ha))) {
2629                 if ((scmd_channel(p) > 0)
2630                     && (ha->
2631                         dcdb_active[scmd_channel(p) -
2632                                     1] & (1 << scmd_id(p)))) {
2633                         ips_freescb(ha, scb);
2634                         p = (struct scsi_cmnd *) p->host_scribble;
2635                         continue;
2636                 }
2637 
2638                 q = p;
2639                 SC = ips_removeq_wait(&ha->scb_waitlist, q);
2640 
2641                 if (intr == IPS_INTR_ON)
2642                         spin_unlock(host->host_lock);   /* Unlock HA after command is taken off queue */
2643 
2644                 SC->result = DID_OK;
2645                 SC->host_scribble = NULL;
2646 
2647                 scb->target_id = SC->device->id;
2648                 scb->lun = SC->device->lun;
2649                 scb->bus = SC->device->channel;
2650                 scb->scsi_cmd = SC;
2651                 scb->breakup = 0;
2652                 scb->data_len = 0;
2653                 scb->callback = ipsintr_done;
2654                 scb->timeout = ips_cmd_timeout;
2655                 memset(&scb->cmd, 0, 16);
2656 
2657                 /* copy in the CDB */
2658                 memcpy(scb->cdb, SC->cmnd, SC->cmd_len);
2659 
2660                 scb->sg_count = scsi_dma_map(SC);
2661                 BUG_ON(scb->sg_count < 0);
2662                 if (scb->sg_count) {
2663                         struct scatterlist *sg;
2664                         int i;
2665 
2666                         scb->flags |= IPS_SCB_MAP_SG;
2667 
2668                         scsi_for_each_sg(SC, sg, scb->sg_count, i) {
2669                                 if (ips_fill_scb_sg_single
2670                                     (ha, sg_dma_address(sg), scb, i,
2671                                      sg_dma_len(sg)) < 0)
2672                                         break;
2673                         }
2674                         scb->dcdb.transfer_length = scb->data_len;
2675                 } else {
2676                         scb->data_busaddr = 0L;
2677                         scb->sg_len = 0;
2678                         scb->data_len = 0;
2679                         scb->dcdb.transfer_length = 0;
2680                 }
2681 
2682                 scb->dcdb.cmd_attribute =
2683                     ips_command_direction[scb->scsi_cmd->cmnd[0]];
2684 
2685                 /* Allow a WRITE BUFFER Command to Have no Data */
2686                 /* This is Used by Tape Flash Utilites          */
2687                 if ((scb->scsi_cmd->cmnd[0] == WRITE_BUFFER) &&
2688                                 (scb->data_len == 0))
2689                         scb->dcdb.cmd_attribute = 0;
2690 
2691                 if (!(scb->dcdb.cmd_attribute & 0x3))
2692                         scb->dcdb.transfer_length = 0;
2693 
2694                 if (scb->data_len >= IPS_MAX_XFER) {
2695                         scb->dcdb.cmd_attribute |= IPS_TRANSFER64K;
2696                         scb->dcdb.transfer_length = 0;
2697                 }
2698                 if (intr == IPS_INTR_ON)
2699                         spin_lock(host->host_lock);
2700 
2701                 ret = ips_send_cmd(ha, scb);
2702 
2703                 switch (ret) {
2704                 case IPS_SUCCESS:
2705                         ips_putq_scb_head(&ha->scb_activelist, scb);
2706                         break;
2707                 case IPS_FAILURE:
2708                         if (scb->scsi_cmd) {
2709                                 scb->scsi_cmd->result = DID_ERROR << 16;
2710                                 scb->scsi_cmd->scsi_done(scb->scsi_cmd);
2711                         }
2712 
2713                         if (scb->bus)
2714                                 ha->dcdb_active[scb->bus - 1] &=
2715                                     ~(1 << scb->target_id);
2716 
2717                         ips_freescb(ha, scb);
2718                         break;
2719                 case IPS_SUCCESS_IMM:
2720                         if (scb->scsi_cmd)
2721                                 scb->scsi_cmd->scsi_done(scb->scsi_cmd);
2722 
2723                         if (scb->bus)
2724                                 ha->dcdb_active[scb->bus - 1] &=
2725                                     ~(1 << scb->target_id);
2726 
2727                         ips_freescb(ha, scb);
2728                         break;
2729                 default:
2730                         break;
2731                 }               /* end case */
2732 
2733                 p = (struct scsi_cmnd *) p->host_scribble;
2734 
2735         }                       /* end while */
2736 
2737         if (intr == IPS_INTR_ON)
2738                 spin_unlock(host->host_lock);
2739 }
2740 
2741 /****************************************************************************/
2742 /*                                                                          */
2743 /* Routine Name: ips_putq_scb_head                                          */
2744 /*                                                                          */
2745 /* Routine Description:                                                     */
2746 /*                                                                          */
2747 /*   Add an item to the head of the queue                                   */
2748 /*                                                                          */
2749 /* ASSUMED to be called from within the HA lock                             */
2750 /*                                                                          */
2751 /****************************************************************************/
2752 static void
2753 ips_putq_scb_head(ips_scb_queue_t * queue, ips_scb_t * item)
2754 {
2755         METHOD_TRACE("ips_putq_scb_head", 1);
2756 
2757         if (!item)
2758                 return;
2759 
2760         item->q_next = queue->head;
2761         queue->head = item;
2762 
2763         if (!queue->tail)
2764                 queue->tail = item;
2765 
2766         queue->count++;
2767 }
2768 
2769 /****************************************************************************/
2770 /*                                                                          */
2771 /* Routine Name: ips_removeq_scb_head                                       */
2772 /*                                                                          */
2773 /* Routine Description:                                                     */
2774 /*                                                                          */
2775 /*   Remove the head of the queue                                           */
2776 /*                                                                          */
2777 /* ASSUMED to be called from within the HA lock                             */
2778 /*                                                                          */
2779 /****************************************************************************/
2780 static ips_scb_t *
2781 ips_removeq_scb_head(ips_scb_queue_t * queue)
2782 {
2783         ips_scb_t *item;
2784 
2785         METHOD_TRACE("ips_removeq_scb_head", 1);
2786 
2787         item = queue->head;
2788 
2789         if (!item) {
2790                 return (NULL);
2791         }
2792 
2793         queue->head = item->q_next;
2794         item->q_next = NULL;
2795 
2796         if (queue->tail == item)
2797                 queue->tail = NULL;
2798 
2799         queue->count--;
2800 
2801         return (item);
2802 }
2803 
2804 /****************************************************************************/
2805 /*                                                                          */
2806 /* Routine Name: ips_removeq_scb                                            */
2807 /*                                                                          */
2808 /* Routine Description:                                                     */
2809 /*                                                                          */
2810 /*   Remove an item from a queue                                            */
2811 /*                                                                          */
2812 /* ASSUMED to be called from within the HA lock                             */
2813 /*                                                                          */
2814 /****************************************************************************/
2815 static ips_scb_t *
2816 ips_removeq_scb(ips_scb_queue_t * queue, ips_scb_t * item)
2817 {
2818         ips_scb_t *p;
2819 
2820         METHOD_TRACE("ips_removeq_scb", 1);
2821 
2822         if (!item)
2823                 return (NULL);
2824 
2825         if (item == queue->head) {
2826                 return (ips_removeq_scb_head(queue));
2827         }
2828 
2829         p = queue->head;
2830 
2831         while ((p) && (item != p->q_next))
2832                 p = p->q_next;
2833 
2834         if (p) {
2835                 /* found a match */
2836                 p->q_next = item->q_next;
2837 
2838                 if (!item->q_next)
2839                         queue->tail = p;
2840 
2841                 item->q_next = NULL;
2842                 queue->count--;
2843 
2844                 return (item);
2845         }
2846 
2847         return (NULL);
2848 }
2849 
2850 /****************************************************************************/
2851 /*                                                                          */
2852 /* Routine Name: ips_putq_wait_tail                                         */
2853 /*                                                                          */
2854 /* Routine Description:                                                     */
2855 /*                                                                          */
2856 /*   Add an item to the tail of the queue                                   */
2857 /*                                                                          */
2858 /* ASSUMED to be called from within the HA lock                             */
2859 /*                                                                          */
2860 /****************************************************************************/
2861 static void ips_putq_wait_tail(ips_wait_queue_entry_t *queue, struct scsi_cmnd *item)
2862 {
2863         METHOD_TRACE("ips_putq_wait_tail", 1);
2864 
2865         if (!item)
2866                 return;
2867 
2868         item->host_scribble = NULL;
2869 
2870         if (queue->tail)
2871                 queue->tail->host_scribble = (char *) item;
2872 
2873         queue->tail = item;
2874 
2875         if (!queue->head)
2876                 queue->head = item;
2877 
2878         queue->count++;
2879 }
2880 
2881 /****************************************************************************/
2882 /*                                                                          */
2883 /* Routine Name: ips_removeq_wait_head                                      */
2884 /*                                                                          */
2885 /* Routine Description:                                                     */
2886 /*                                                                          */
2887 /*   Remove the head of the queue                                           */
2888 /*                                                                          */
2889 /* ASSUMED to be called from within the HA lock                             */
2890 /*                                                                          */
2891 /****************************************************************************/
2892 static struct scsi_cmnd *ips_removeq_wait_head(ips_wait_queue_entry_t *queue)
2893 {
2894         struct scsi_cmnd *item;
2895 
2896         METHOD_TRACE("ips_removeq_wait_head", 1);
2897 
2898         item = queue->head;
2899 
2900         if (!item) {
2901                 return (NULL);
2902         }
2903 
2904         queue->head = (struct scsi_cmnd *) item->host_scribble;
2905         item->host_scribble = NULL;
2906 
2907         if (queue->tail == item)
2908                 queue->tail = NULL;
2909 
2910         queue->count--;
2911 
2912         return (item);
2913 }
2914 
2915 /****************************************************************************/
2916 /*                                                                          */
2917 /* Routine Name: ips_removeq_wait                                           */
2918 /*                                                                          */
2919 /* Routine Description:                                                     */
2920 /*                                                                          */
2921 /*   Remove an item from a queue                                            */
2922 /*                                                                          */
2923 /* ASSUMED to be called from within the HA lock                             */
2924 /*                                                                          */
2925 /****************************************************************************/
2926 static struct scsi_cmnd *ips_removeq_wait(ips_wait_queue_entry_t *queue,
2927                                           struct scsi_cmnd *item)
2928 {
2929         struct scsi_cmnd *p;
2930 
2931         METHOD_TRACE("ips_removeq_wait", 1);
2932 
2933         if (!item)
2934                 return (NULL);
2935 
2936         if (item == queue->head) {
2937                 return (ips_removeq_wait_head(queue));
2938         }
2939 
2940         p = queue->head;
2941 
2942         while ((p) && (item != (struct scsi_cmnd *) p->host_scribble))
2943                 p = (struct scsi_cmnd *) p->host_scribble;
2944 
2945         if (p) {
2946                 /* found a match */
2947                 p->host_scribble = item->host_scribble;
2948 
2949                 if (!item->host_scribble)
2950                         queue->tail = p;
2951 
2952                 item->host_scribble = NULL;
2953                 queue->count--;
2954 
2955                 return (item);
2956         }
2957 
2958         return (NULL);
2959 }
2960 
2961 /****************************************************************************/
2962 /*                                                                          */
2963 /* Routine Name: ips_putq_copp_tail                                         */
2964 /*                                                                          */
2965 /* Routine Description:                                                     */
2966 /*                                                                          */
2967 /*   Add an item to the tail of the queue                                   */
2968 /*                                                                          */
2969 /* ASSUMED to be called from within the HA lock                             */
2970 /*                                                                          */
2971 /****************************************************************************/
2972 static void
2973 ips_putq_copp_tail(ips_copp_queue_t * queue, ips_copp_wait_item_t * item)
2974 {
2975         METHOD_TRACE("ips_putq_copp_tail", 1);
2976 
2977         if (!item)
2978                 return;
2979 
2980         item->next = NULL;
2981 
2982         if (queue->tail)
2983                 queue->tail->next = item;
2984 
2985         queue->tail = item;
2986 
2987         if (!queue->head)
2988                 queue->head = item;
2989 
2990         queue->count++;
2991 }
2992 
2993 /****************************************************************************/
2994 /*                                                                          */
2995 /* Routine Name: ips_removeq_copp_head                                      */
2996 /*                                                                          */
2997 /* Routine Description:                                                     */
2998 /*                                                                          */
2999 /*   Remove the head of the queue                                           */
3000 /*                                                                          */
3001 /* ASSUMED to be called from within the HA lock                             */
3002 /*                                                                          */
3003 /****************************************************************************/
3004 static ips_copp_wait_item_t *
3005 ips_removeq_copp_head(ips_copp_queue_t * queue)
3006 {
3007         ips_copp_wait_item_t *item;
3008 
3009         METHOD_TRACE("ips_removeq_copp_head", 1);
3010 
3011         item = queue->head;
3012 
3013         if (!item) {
3014                 return (NULL);
3015         }
3016 
3017         queue->head = item->next;
3018         item->next = NULL;
3019 
3020         if (queue->tail == item)
3021                 queue->tail = NULL;
3022 
3023         queue->count--;
3024 
3025         return (item);
3026 }
3027 
3028 /****************************************************************************/
3029 /*                                                                          */
3030 /* Routine Name: ips_removeq_copp                                           */
3031 /*                                                                          */
3032 /* Routine Description:                                                     */
3033 /*                                                                          */
3034 /*   Remove an item from a queue                                            */
3035 /*                                                                          */
3036 /* ASSUMED to be called from within the HA lock                             */
3037 /*                                                                          */
3038 /****************************************************************************/
3039 static ips_copp_wait_item_t *
3040 ips_removeq_copp(ips_copp_queue_t * queue, ips_copp_wait_item_t * item)
3041 {
3042         ips_copp_wait_item_t *p;
3043 
3044         METHOD_TRACE("ips_removeq_copp", 1);
3045 
3046         if (!item)
3047                 return (NULL);
3048 
3049         if (item == queue->head) {
3050                 return (ips_removeq_copp_head(queue));
3051         }
3052 
3053         p = queue->head;
3054 
3055         while ((p) && (item != p->next))
3056                 p = p->next;
3057 
3058         if (p) {
3059                 /* found a match */
3060                 p->next = item->next;
3061 
3062                 if (!item->next)
3063                         queue->tail = p;
3064 
3065                 item->next = NULL;
3066                 queue->count--;
3067 
3068                 return (item);
3069         }
3070 
3071         return (NULL);
3072 }
3073 
3074 /****************************************************************************/
3075 /*                                                                          */
3076 /* Routine Name: ipsintr_blocking                                           */
3077 /*                                                                          */
3078 /* Routine Description:                                                     */
3079 /*                                                                          */
3080 /*   Finalize an interrupt for internal commands                            */
3081 /*                                                                          */
3082 /****************************************************************************/
3083 static void
3084 ipsintr_blocking(ips_ha_t * ha, ips_scb_t * scb)
3085 {
3086         METHOD_TRACE("ipsintr_blocking", 2);
3087 
3088         ips_freescb(ha, scb);
3089         if ((ha->waitflag == TRUE) && (ha->cmd_in_progress == scb->cdb[0])) {
3090                 ha->waitflag = FALSE;
3091 
3092                 return;
3093         }
3094 }
3095 
3096 /****************************************************************************/
3097 /*                                                                          */
3098 /* Routine Name: ipsintr_done                                               */
3099 /*                                                                          */
3100 /* Routine Description:                                                     */
3101 /*                                                                          */
3102 /*   Finalize an interrupt for non-internal commands                        */
3103 /*                                                                          */
3104 /****************************************************************************/
3105 static void
3106 ipsintr_done(ips_ha_t * ha, ips_scb_t * scb)
3107 {
3108         METHOD_TRACE("ipsintr_done", 2);
3109 
3110         if (!scb) {
3111                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
3112                            "Spurious interrupt; scb NULL.\n");
3113 
3114                 return;
3115         }
3116 
3117         if (scb->scsi_cmd == NULL) {
3118                 /* unexpected interrupt */
3119                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
3120                            "Spurious interrupt; scsi_cmd not set.\n");
3121 
3122                 return;
3123         }
3124 
3125         ips_done(ha, scb);
3126 }
3127 
3128 /****************************************************************************/
3129 /*                                                                          */
3130 /* Routine Name: ips_done                                                   */
3131 /*                                                                          */
3132 /* Routine Description:                                                     */
3133 /*                                                                          */
3134 /*   Do housekeeping on completed commands                                  */
3135 /*  ASSUMED to be called form within the request lock                       */
3136 /****************************************************************************/
3137 static void
3138 ips_done(ips_ha_t * ha, ips_scb_t * scb)
3139 {
3140         int ret;
3141 
3142         METHOD_TRACE("ips_done", 1);
3143 
3144         if (!scb)
3145                 return;
3146 
3147         if ((scb->scsi_cmd) && (ips_is_passthru(scb->scsi_cmd))) {
3148                 ips_cleanup_passthru(ha, scb);
3149                 ha->num_ioctl--;
3150         } else {
3151                 /*
3152                  * Check to see if this command had too much
3153                  * data and had to be broke up.  If so, queue
3154                  * the rest of the data and continue.
3155                  */
3156                 if ((scb->breakup) || (scb->sg_break)) {
3157                         struct scatterlist *sg;
3158                         int i, sg_dma_index, ips_sg_index = 0;
3159 
3160                         /* we had a data breakup */
3161                         scb->data_len = 0;
3162 
3163                         sg = scsi_sglist(scb->scsi_cmd);
3164 
3165                         /* Spin forward to last dma chunk */
3166                         sg_dma_index = scb->breakup;
3167                         for (i = 0; i < scb->breakup; i++)
3168                                 sg = sg_next(sg);
3169 
3170                         /* Take care of possible partial on last chunk */
3171                         ips_fill_scb_sg_single(ha,
3172                                                sg_dma_address(sg),
3173                                                scb, ips_sg_index++,
3174                                                sg_dma_len(sg));
3175 
3176                         for (; sg_dma_index < scsi_sg_count(scb->scsi_cmd);
3177                              sg_dma_index++, sg = sg_next(sg)) {
3178                                 if (ips_fill_scb_sg_single
3179                                     (ha,
3180                                      sg_dma_address(sg),
3181                                      scb, ips_sg_index++,
3182                                      sg_dma_len(sg)) < 0)
3183                                         break;
3184                         }
3185 
3186                         scb->dcdb.transfer_length = scb->data_len;
3187                         scb->dcdb.cmd_attribute |=
3188                             ips_command_direction[scb->scsi_cmd->cmnd[0]];
3189 
3190                         if (!(scb->dcdb.cmd_attribute & 0x3))
3191                                 scb->dcdb.transfer_length = 0;
3192 
3193                         if (scb->data_len >= IPS_MAX_XFER) {
3194                                 scb->dcdb.cmd_attribute |= IPS_TRANSFER64K;
3195                                 scb->dcdb.transfer_length = 0;
3196                         }
3197 
3198                         ret = ips_send_cmd(ha, scb);
3199 
3200                         switch (ret) {
3201                         case IPS_FAILURE:
3202                                 if (scb->scsi_cmd) {
3203                                         scb->scsi_cmd->result = DID_ERROR << 16;
3204                                         scb->scsi_cmd->scsi_done(scb->scsi_cmd);
3205                                 }
3206 
3207                                 ips_freescb(ha, scb);
3208                                 break;
3209                         case IPS_SUCCESS_IMM:
3210                                 if (scb->scsi_cmd) {
3211                                         scb->scsi_cmd->result = DID_ERROR << 16;
3212                                         scb->scsi_cmd->scsi_done(scb->scsi_cmd);
3213                                 }
3214 
3215                                 ips_freescb(ha, scb);
3216                                 break;
3217                         default:
3218                                 break;
3219                         }       /* end case */
3220 
3221                         return;
3222                 }
3223         }                       /* end if passthru */
3224 
3225         if (scb->bus) {
3226                 ha->dcdb_active[scb->bus - 1] &= ~(1 << scb->target_id);
3227         }
3228 
3229         scb->scsi_cmd->scsi_done(scb->scsi_cmd);
3230 
3231         ips_freescb(ha, scb);
3232 }
3233 
3234 /****************************************************************************/
3235 /*                                                                          */
3236 /* Routine Name: ips_map_status                                             */
3237 /*                                                                          */
3238 /* Routine Description:                                                     */
3239 /*                                                                          */
3240 /*   Map Controller Error codes to Linux Error Codes                        */
3241 /*                                                                          */
3242 /****************************************************************************/
3243 static int
3244 ips_map_status(ips_ha_t * ha, ips_scb_t * scb, ips_stat_t * sp)
3245 {
3246         int errcode;
3247         int device_error;
3248         uint32_t transfer_len;
3249         IPS_DCDB_TABLE_TAPE *tapeDCDB;
3250         IPS_SCSI_INQ_DATA inquiryData;
3251 
3252         METHOD_TRACE("ips_map_status", 1);
3253 
3254         if (scb->bus) {
3255                 DEBUG_VAR(2,
3256                           "(%s%d) Physical device error (%d %d %d): %x %x, Sense Key: %x, ASC: %x, ASCQ: %x",
3257                           ips_name, ha->host_num,
3258                           scb->scsi_cmd->device->channel,
3259                           scb->scsi_cmd->device->id, scb->scsi_cmd->device->lun,
3260                           scb->basic_status, scb->extended_status,
3261                           scb->extended_status ==
3262                           IPS_ERR_CKCOND ? scb->dcdb.sense_info[2] & 0xf : 0,
3263                           scb->extended_status ==
3264                           IPS_ERR_CKCOND ? scb->dcdb.sense_info[12] : 0,
3265                           scb->extended_status ==
3266                           IPS_ERR_CKCOND ? scb->dcdb.sense_info[13] : 0);
3267         }
3268 
3269         /* default driver error */
3270         errcode = DID_ERROR;
3271         device_error = 0;
3272 
3273         switch (scb->basic_status & IPS_GSC_STATUS_MASK) {
3274         case IPS_CMD_TIMEOUT:
3275                 errcode = DID_TIME_OUT;
3276                 break;
3277 
3278         case IPS_INVAL_OPCO:
3279         case IPS_INVAL_CMD_BLK:
3280         case IPS_INVAL_PARM_BLK:
3281         case IPS_LD_ERROR:
3282         case IPS_CMD_CMPLT_WERROR:
3283                 break;
3284 
3285         case IPS_PHYS_DRV_ERROR:
3286                 switch (scb->extended_status) {
3287                 case IPS_ERR_SEL_TO:
3288                         if (scb->bus)
3289                                 errcode = DID_NO_CONNECT;
3290 
3291                         break;
3292 
3293                 case IPS_ERR_OU_RUN:
3294                         if ((scb->cmd.dcdb.op_code == IPS_CMD_EXTENDED_DCDB) ||
3295                             (scb->cmd.dcdb.op_code ==
3296                              IPS_CMD_EXTENDED_DCDB_SG)) {
3297                                 tapeDCDB = (IPS_DCDB_TABLE_TAPE *) & scb->dcdb;
3298                                 transfer_len = tapeDCDB->transfer_length;
3299                         } else {
3300                                 transfer_len =
3301                                     (uint32_t) scb->dcdb.transfer_length;
3302                         }
3303 
3304                         if ((scb->bus) && (transfer_len < scb->data_len)) {
3305                                 /* Underrun - set default to no error */
3306                                 errcode = DID_OK;
3307 
3308                                 /* Restrict access to physical DASD */
3309                                 if (scb->scsi_cmd->cmnd[0] == INQUIRY) {
3310                                     ips_scmd_buf_read(scb->scsi_cmd,
3311                                       &inquiryData, sizeof (inquiryData));
3312                                     if ((inquiryData.DeviceType & 0x1f) == TYPE_DISK) {
3313                                         errcode = DID_TIME_OUT;
3314                                         break;
3315                                     }
3316                                 }
3317                         } else
3318                                 errcode = DID_ERROR;
3319 
3320                         break;
3321 
3322                 case IPS_ERR_RECOVERY:
3323                         /* don't fail recovered errors */
3324                         if (scb->bus)
3325                                 errcode = DID_OK;
3326 
3327                         break;
3328 
3329                 case IPS_ERR_HOST_RESET:
3330                 case IPS_ERR_DEV_RESET:
3331                         errcode = DID_RESET;
3332                         break;
3333 
3334                 case IPS_ERR_CKCOND:
3335                         if (scb->bus) {
3336                                 if ((scb->cmd.dcdb.op_code ==
3337                                      IPS_CMD_EXTENDED_DCDB)
3338                                     || (scb->cmd.dcdb.op_code ==
3339                                         IPS_CMD_EXTENDED_DCDB_SG)) {
3340                                         tapeDCDB =
3341                                             (IPS_DCDB_TABLE_TAPE *) & scb->dcdb;
3342                                         memcpy(scb->scsi_cmd->sense_buffer,
3343                                                tapeDCDB->sense_info,
3344                                                SCSI_SENSE_BUFFERSIZE);
3345                                 } else {
3346                                         memcpy(scb->scsi_cmd->sense_buffer,
3347                                                scb->dcdb.sense_info,
3348                                                SCSI_SENSE_BUFFERSIZE);
3349                                 }
3350                                 device_error = 2;       /* check condition */
3351                         }
3352 
3353                         errcode = DID_OK;
3354 
3355                         break;
3356 
3357                 default:
3358                         errcode = DID_ERROR;
3359                         break;
3360 
3361                 }               /* end switch */
3362         }                       /* end switch */
3363 
3364         scb->scsi_cmd->result = device_error | (errcode << 16);
3365 
3366         return (1);
3367 }
3368 
3369 /****************************************************************************/
3370 /*                                                                          */
3371 /* Routine Name: ips_send_wait                                              */
3372 /*                                                                          */
3373 /* Routine Description:                                                     */
3374 /*                                                                          */
3375 /*   Send a command to the controller and wait for it to return             */
3376 /*                                                                          */
3377 /*   The FFDC Time Stamp use this function for the callback, but doesn't    */
3378 /*   actually need to wait.                                                 */
3379 /****************************************************************************/
3380 static int
3381 ips_send_wait(ips_ha_t * ha, ips_scb_t * scb, int timeout, int intr)
3382 {
3383         int ret;
3384 
3385         METHOD_TRACE("ips_send_wait", 1);
3386 
3387         if (intr != IPS_FFDC) { /* Won't be Waiting if this is a Time Stamp */
3388                 ha->waitflag = TRUE;
3389                 ha->cmd_in_progress = scb->cdb[0];
3390         }
3391         scb->callback = ipsintr_blocking;
3392         ret = ips_send_cmd(ha, scb);
3393 
3394         if ((ret == IPS_FAILURE) || (ret == IPS_SUCCESS_IMM))
3395                 return (ret);
3396 
3397         if (intr != IPS_FFDC)   /* Don't Wait around if this is a Time Stamp */
3398                 ret = ips_wait(ha, timeout, intr);
3399 
3400         return (ret);
3401 }
3402 
3403 /****************************************************************************/
3404 /*                                                                          */
3405 /* Routine Name: ips_scmd_buf_write                                         */
3406 /*                                                                          */
3407 /* Routine Description:                                                     */
3408 /*  Write data to struct scsi_cmnd request_buffer at proper offsets         */
3409 /****************************************************************************/
3410 static void
3411 ips_scmd_buf_write(struct scsi_cmnd *scmd, void *data, unsigned int count)
3412 {
3413         unsigned long flags;
3414 
3415         local_irq_save(flags);
3416         scsi_sg_copy_from_buffer(scmd, data, count);
3417         local_irq_restore(flags);
3418 }
3419 
3420 /****************************************************************************/
3421 /*                                                                          */
3422 /* Routine Name: ips_scmd_buf_read                                          */
3423 /*                                                                          */
3424 /* Routine Description:                                                     */
3425 /*  Copy data from a struct scsi_cmnd to a new, linear buffer               */
3426 /****************************************************************************/
3427 static void
3428 ips_scmd_buf_read(struct scsi_cmnd *scmd, void *data, unsigned int count)
3429 {
3430         unsigned long flags;
3431 
3432         local_irq_save(flags);
3433         scsi_sg_copy_to_buffer(scmd, data, count);
3434         local_irq_restore(flags);
3435 }
3436 
3437 /****************************************************************************/
3438 /*                                                                          */
3439 /* Routine Name: ips_send_cmd                                               */
3440 /*                                                                          */
3441 /* Routine Description:                                                     */
3442 /*                                                                          */
3443 /*   Map SCSI commands to ServeRAID commands for logical drives             */
3444 /*                                                                          */
3445 /****************************************************************************/
3446 static int
3447 ips_send_cmd(ips_ha_t * ha, ips_scb_t * scb)
3448 {
3449         int ret;
3450         char *sp;
3451         int device_error;
3452         IPS_DCDB_TABLE_TAPE *tapeDCDB;
3453         int TimeOut;
3454 
3455         METHOD_TRACE("ips_send_cmd", 1);
3456 
3457         ret = IPS_SUCCESS;
3458 
3459         if (!scb->scsi_cmd) {
3460                 /* internal command */
3461 
3462                 if (scb->bus > 0) {
3463                         /* Controller commands can't be issued */
3464                         /* to real devices -- fail them        */
3465                         if ((ha->waitflag == TRUE) &&
3466                             (ha->cmd_in_progress == scb->cdb[0])) {
3467                                 ha->waitflag = FALSE;
3468                         }
3469 
3470                         return (1);
3471                 }
3472         } else if ((scb->bus == 0) && (!ips_is_passthru(scb->scsi_cmd))) {
3473                 /* command to logical bus -- interpret */
3474                 ret = IPS_SUCCESS_IMM;
3475 
3476                 switch (scb->scsi_cmd->cmnd[0]) {
3477                 case ALLOW_MEDIUM_REMOVAL:
3478                 case REZERO_UNIT:
3479                 case ERASE:
3480                 case WRITE_FILEMARKS:
3481                 case SPACE:
3482                         scb->scsi_cmd->result = DID_ERROR << 16;
3483                         break;
3484 
3485                 case START_STOP:
3486                         scb->scsi_cmd->result = DID_OK << 16;
3487                         break;
3488 
3489                 case TEST_UNIT_READY:
3490                 case INQUIRY:
3491                         if (scb->target_id == IPS_ADAPTER_ID) {
3492                                 /*
3493                                  * Either we have a TUR
3494                                  * or we have a SCSI inquiry
3495                                  */
3496                                 if (scb->scsi_cmd->cmnd[0] == TEST_UNIT_READY)
3497                                         scb->scsi_cmd->result = DID_OK << 16;
3498 
3499                                 if (scb->scsi_cmd->cmnd[0] == INQUIRY) {
3500                                         IPS_SCSI_INQ_DATA inquiry;
3501 
3502                                         memset(&inquiry, 0,
3503                                                sizeof (IPS_SCSI_INQ_DATA));
3504 
3505                                         inquiry.DeviceType =
3506                                             IPS_SCSI_INQ_TYPE_PROCESSOR;
3507                                         inquiry.DeviceTypeQualifier =
3508                                             IPS_SCSI_INQ_LU_CONNECTED;
3509                                         inquiry.Version = IPS_SCSI_INQ_REV2;
3510                                         inquiry.ResponseDataFormat =
3511                                             IPS_SCSI_INQ_RD_REV2;
3512                                         inquiry.AdditionalLength = 31;
3513                                         inquiry.Flags[0] =
3514                                             IPS_SCSI_INQ_Address16;
3515                                         inquiry.Flags[1] =
3516                                             IPS_SCSI_INQ_WBus16 |
3517                                             IPS_SCSI_INQ_Sync;
3518                                         strncpy(inquiry.VendorId, "IBM     ",
3519                                                 8);
3520                                         strncpy(inquiry.ProductId,
3521                                                 "SERVERAID       ", 16);
3522                                         strncpy(inquiry.ProductRevisionLevel,
3523                                                 "1.00", 4);
3524 
3525                                         ips_scmd_buf_write(scb->scsi_cmd,
3526                                                            &inquiry,
3527                                                            sizeof (inquiry));
3528 
3529                                         scb->scsi_cmd->result = DID_OK << 16;
3530                                 }
3531                         } else {
3532                                 scb->cmd.logical_info.op_code = IPS_CMD_GET_LD_INFO;
3533                                 scb->cmd.logical_info.command_id = IPS_COMMAND_ID(ha, scb);
3534                                 scb->cmd.logical_info.reserved = 0;
3535                                 scb->cmd.logical_info.reserved2 = 0;
3536                                 scb->data_len = sizeof (IPS_LD_INFO);
3537                                 scb->data_busaddr = ha->logical_drive_info_dma_addr;
3538                                 scb->flags = 0;
3539                                 scb->cmd.logical_info.buffer_addr = scb->data_busaddr;
3540                                 ret = IPS_SUCCESS;
3541                         }
3542 
3543                         break;
3544 
3545                 case REQUEST_SENSE:
3546                         ips_reqsen(ha, scb);
3547                         scb->scsi_cmd->result = DID_OK << 16;
3548                         break;
3549 
3550                 case READ_6:
3551                 case WRITE_6:
3552                         if (!scb->sg_len) {
3553                                 scb->cmd.basic_io.op_code =
3554                                     (scb->scsi_cmd->cmnd[0] ==
3555                                      READ_6) ? IPS_CMD_READ : IPS_CMD_WRITE;
3556                                 scb->cmd.basic_io.enhanced_sg = 0;
3557                                 scb->cmd.basic_io.sg_addr =
3558                                     cpu_to_le32(scb->data_busaddr);
3559                         } else {
3560                                 scb->cmd.basic_io.op_code =
3561                                     (scb->scsi_cmd->cmnd[0] ==
3562                                      READ_6) ? IPS_CMD_READ_SG :
3563                                     IPS_CMD_WRITE_SG;
3564                                 scb->cmd.basic_io.enhanced_sg =
3565                                     IPS_USE_ENH_SGLIST(ha) ? 0xFF : 0;
3566                                 scb->cmd.basic_io.sg_addr =
3567                                     cpu_to_le32(scb->sg_busaddr);
3568                         }
3569 
3570                         scb->cmd.basic_io.segment_4G = 0;
3571                         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
3572                         scb->cmd.basic_io.log_drv = scb->target_id;
3573                         scb->cmd.basic_io.sg_count = scb->sg_len;
3574 
3575                         if (scb->cmd.basic_io.lba)
3576                                 le32_add_cpu(&scb->cmd.basic_io.lba,
3577                                                 le16_to_cpu(scb->cmd.basic_io.
3578                                                             sector_count));
3579                         else
3580                                 scb->cmd.basic_io.lba =
3581                                     (((scb->scsi_cmd->
3582                                        cmnd[1] & 0x1f) << 16) | (scb->scsi_cmd->
3583                                                                  cmnd[2] << 8) |
3584                                      (scb->scsi_cmd->cmnd[3]));
3585 
3586                         scb->cmd.basic_io.sector_count =
3587                             cpu_to_le16(scb->data_len / IPS_BLKSIZE);
3588 
3589                         if (le16_to_cpu(scb->cmd.basic_io.sector_count) == 0)
3590                                 scb->cmd.basic_io.sector_count =
3591                                     cpu_to_le16(256);
3592 
3593                         ret = IPS_SUCCESS;
3594                         break;
3595 
3596                 case READ_10:
3597                 case WRITE_10:
3598                         if (!scb->sg_len) {
3599                                 scb->cmd.basic_io.op_code =
3600                                     (scb->scsi_cmd->cmnd[0] ==
3601                                      READ_10) ? IPS_CMD_READ : IPS_CMD_WRITE;
3602                                 scb->cmd.basic_io.enhanced_sg = 0;
3603                                 scb->cmd.basic_io.sg_addr =
3604                                     cpu_to_le32(scb->data_busaddr);
3605                         } else {
3606                                 scb->cmd.basic_io.op_code =
3607                                     (scb->scsi_cmd->cmnd[0] ==
3608                                      READ_10) ? IPS_CMD_READ_SG :
3609                                     IPS_CMD_WRITE_SG;
3610                                 scb->cmd.basic_io.enhanced_sg =
3611                                     IPS_USE_ENH_SGLIST(ha) ? 0xFF : 0;
3612                                 scb->cmd.basic_io.sg_addr =
3613                                     cpu_to_le32(scb->sg_busaddr);
3614                         }
3615 
3616                         scb->cmd.basic_io.segment_4G = 0;
3617                         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
3618                         scb->cmd.basic_io.log_drv = scb->target_id;
3619                         scb->cmd.basic_io.sg_count = scb->sg_len;
3620 
3621                         if (scb->cmd.basic_io.lba)
3622                                 le32_add_cpu(&scb->cmd.basic_io.lba,
3623                                                 le16_to_cpu(scb->cmd.basic_io.
3624                                                             sector_count));
3625                         else
3626                                 scb->cmd.basic_io.lba =
3627                                     ((scb->scsi_cmd->cmnd[2] << 24) | (scb->
3628                                                                        scsi_cmd->
3629                                                                        cmnd[3]
3630                                                                        << 16) |
3631                                      (scb->scsi_cmd->cmnd[4] << 8) | scb->
3632                                      scsi_cmd->cmnd[5]);
3633 
3634                         scb->cmd.basic_io.sector_count =
3635                             cpu_to_le16(scb->data_len / IPS_BLKSIZE);
3636 
3637                         if (cpu_to_le16(scb->cmd.basic_io.sector_count) == 0) {
3638                                 /*
3639                                  * This is a null condition
3640                                  * we don't have to do anything
3641                                  * so just return
3642                                  */
3643                                 scb->scsi_cmd->result = DID_OK << 16;
3644                         } else
3645                                 ret = IPS_SUCCESS;
3646 
3647                         break;
3648 
3649                 case RESERVE:
3650                 case RELEASE:
3651                         scb->scsi_cmd->result = DID_OK << 16;
3652                         break;
3653 
3654                 case MODE_SENSE:
3655                         scb->cmd.basic_io.op_code = IPS_CMD_ENQUIRY;
3656                         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
3657                         scb->cmd.basic_io.segment_4G = 0;
3658                         scb->cmd.basic_io.enhanced_sg = 0;
3659                         scb->data_len = sizeof (*ha->enq);
3660                         scb->cmd.basic_io.sg_addr = ha->enq_busaddr;
3661                         ret = IPS_SUCCESS;
3662                         break;
3663 
3664                 case READ_CAPACITY:
3665                         scb->cmd.logical_info.op_code = IPS_CMD_GET_LD_INFO;
3666                         scb->cmd.logical_info.command_id = IPS_COMMAND_ID(ha, scb);
3667                         scb->cmd.logical_info.reserved = 0;
3668                         scb->cmd.logical_info.reserved2 = 0;
3669                         scb->cmd.logical_info.reserved3 = 0;
3670                         scb->data_len = sizeof (IPS_LD_INFO);
3671                         scb->data_busaddr = ha->logical_drive_info_dma_addr;
3672                         scb->flags = 0;
3673                         scb->cmd.logical_info.buffer_addr = scb->data_busaddr;
3674                         ret = IPS_SUCCESS;
3675                         break;
3676 
3677                 case SEND_DIAGNOSTIC:
3678                 case REASSIGN_BLOCKS:
3679                 case FORMAT_UNIT:
3680                 case SEEK_10:
3681                 case VERIFY:
3682                 case READ_DEFECT_DATA:
3683                 case READ_BUFFER:
3684                 case WRITE_BUFFER:
3685                         scb->scsi_cmd->result = DID_OK << 16;
3686                         break;
3687 
3688                 default:
3689                         /* Set the Return Info to appear like the Command was */
3690                         /* attempted, a Check Condition occurred, and Sense   */
3691                         /* Data indicating an Invalid CDB OpCode is returned. */
3692                         sp = (char *) scb->scsi_cmd->sense_buffer;
3693 
3694                         sp[0] = 0x70;   /* Error Code               */
3695                         sp[2] = ILLEGAL_REQUEST;        /* Sense Key 5 Illegal Req. */
3696                         sp[7] = 0x0A;   /* Additional Sense Length  */
3697                         sp[12] = 0x20;  /* ASC = Invalid OpCode     */
3698                         sp[13] = 0x00;  /* ASCQ                     */
3699 
3700                         device_error = 2;       /* Indicate Check Condition */
3701                         scb->scsi_cmd->result = device_error | (DID_OK << 16);
3702                         break;
3703                 }               /* end switch */
3704         }
3705         /* end if */
3706         if (ret == IPS_SUCCESS_IMM)
3707                 return (ret);
3708 
3709         /* setup DCDB */
3710         if (scb->bus > 0) {
3711 
3712                 /* If we already know the Device is Not there, no need to attempt a Command   */
3713                 /* This also protects an NT FailOver Controller from getting CDB's sent to it */
3714                 if (ha->conf->dev[scb->bus - 1][scb->target_id].ucState == 0) {
3715                         scb->scsi_cmd->result = DID_NO_CONNECT << 16;
3716                         return (IPS_SUCCESS_IMM);
3717                 }
3718 
3719                 ha->dcdb_active[scb->bus - 1] |= (1 << scb->target_id);
3720                 scb->cmd.dcdb.command_id = IPS_COMMAND_ID(ha, scb);
3721                 scb->cmd.dcdb.dcdb_address = cpu_to_le32(scb->scb_busaddr +
3722                                                          (unsigned long) &scb->
3723                                                          dcdb -
3724                                                          (unsigned long) scb);
3725                 scb->cmd.dcdb.reserved = 0;
3726                 scb->cmd.dcdb.reserved2 = 0;
3727                 scb->cmd.dcdb.reserved3 = 0;
3728                 scb->cmd.dcdb.segment_4G = 0;
3729                 scb->cmd.dcdb.enhanced_sg = 0;
3730 
3731                 TimeOut = scb->scsi_cmd->request->timeout;
3732 
3733                 if (ha->subsys->param[4] & 0x00100000) {        /* If NEW Tape DCDB is Supported */
3734                         if (!scb->sg_len) {
3735                                 scb->cmd.dcdb.op_code = IPS_CMD_EXTENDED_DCDB;
3736                         } else {
3737                                 scb->cmd.dcdb.op_code =
3738                                     IPS_CMD_EXTENDED_DCDB_SG;
3739                                 scb->cmd.dcdb.enhanced_sg =
3740                                     IPS_USE_ENH_SGLIST(ha) ? 0xFF : 0;
3741                         }
3742 
3743                         tapeDCDB = (IPS_DCDB_TABLE_TAPE *) & scb->dcdb; /* Use Same Data Area as Old DCDB Struct */
3744                         tapeDCDB->device_address =
3745                             ((scb->bus - 1) << 4) | scb->target_id;
3746                         tapeDCDB->cmd_attribute |= IPS_DISCONNECT_ALLOWED;
3747                         tapeDCDB->cmd_attribute &= ~IPS_TRANSFER64K;    /* Always Turn OFF 64K Size Flag */
3748 
3749                         if (TimeOut) {
3750                                 if (TimeOut < (10 * HZ))
3751                                         tapeDCDB->cmd_attribute |= IPS_TIMEOUT10;       /* TimeOut is 10 Seconds */
3752                                 else if (TimeOut < (60 * HZ))
3753                                         tapeDCDB->cmd_attribute |= IPS_TIMEOUT60;       /* TimeOut is 60 Seconds */
3754                                 else if (TimeOut < (1200 * HZ))
3755                                         tapeDCDB->cmd_attribute |= IPS_TIMEOUT20M;      /* TimeOut is 20 Minutes */
3756                         }
3757 
3758                         tapeDCDB->cdb_length = scb->scsi_cmd->cmd_len;
3759                         tapeDCDB->reserved_for_LUN = 0;
3760                         tapeDCDB->transfer_length = scb->data_len;
3761                         if (scb->cmd.dcdb.op_code == IPS_CMD_EXTENDED_DCDB_SG)
3762                                 tapeDCDB->buffer_pointer =
3763                                     cpu_to_le32(scb->sg_busaddr);
3764                         else
3765                                 tapeDCDB->buffer_pointer =
3766                                     cpu_to_le32(scb->data_busaddr);
3767                         tapeDCDB->sg_count = scb->sg_len;
3768                         tapeDCDB->sense_length = sizeof (tapeDCDB->sense_info);
3769                         tapeDCDB->scsi_status = 0;
3770                         tapeDCDB->reserved = 0;
3771                         memcpy(tapeDCDB->scsi_cdb, scb->scsi_cmd->cmnd,
3772                                scb->scsi_cmd->cmd_len);
3773                 } else {
3774                         if (!scb->sg_len) {
3775                                 scb->cmd.dcdb.op_code = IPS_CMD_DCDB;
3776                         } else {
3777                                 scb->cmd.dcdb.op_code = IPS_CMD_DCDB_SG;
3778                                 scb->cmd.dcdb.enhanced_sg =
3779                                     IPS_USE_ENH_SGLIST(ha) ? 0xFF : 0;
3780                         }
3781 
3782                         scb->dcdb.device_address =
3783                             ((scb->bus - 1) << 4) | scb->target_id;
3784                         scb->dcdb.cmd_attribute |= IPS_DISCONNECT_ALLOWED;
3785 
3786                         if (TimeOut) {
3787                                 if (TimeOut < (10 * HZ))
3788                                         scb->dcdb.cmd_attribute |= IPS_TIMEOUT10;       /* TimeOut is 10 Seconds */
3789                                 else if (TimeOut < (60 * HZ))
3790                                         scb->dcdb.cmd_attribute |= IPS_TIMEOUT60;       /* TimeOut is 60 Seconds */
3791                                 else if (TimeOut < (1200 * HZ))
3792                                         scb->dcdb.cmd_attribute |= IPS_TIMEOUT20M;      /* TimeOut is 20 Minutes */
3793                         }
3794 
3795                         scb->dcdb.transfer_length = scb->data_len;
3796                         if (scb->dcdb.cmd_attribute & IPS_TRANSFER64K)
3797                                 scb->dcdb.transfer_length = 0;
3798                         if (scb->cmd.dcdb.op_code == IPS_CMD_DCDB_SG)
3799                                 scb->dcdb.buffer_pointer =
3800                                     cpu_to_le32(scb->sg_busaddr);
3801                         else
3802                                 scb->dcdb.buffer_pointer =
3803                                     cpu_to_le32(scb->data_busaddr);
3804                         scb->dcdb.cdb_length = scb->scsi_cmd->cmd_len;
3805                         scb->dcdb.sense_length = sizeof (scb->dcdb.sense_info);
3806                         scb->dcdb.sg_count = scb->sg_len;
3807                         scb->dcdb.reserved = 0;
3808                         memcpy(scb->dcdb.scsi_cdb, scb->scsi_cmd->cmnd,
3809                                scb->scsi_cmd->cmd_len);
3810                         scb->dcdb.scsi_status = 0;
3811                         scb->dcdb.reserved2[0] = 0;
3812                         scb->dcdb.reserved2[1] = 0;
3813                         scb->dcdb.reserved2[2] = 0;
3814                 }
3815         }
3816 
3817         return ((*ha->func.issue) (ha, scb));
3818 }
3819 
3820 /****************************************************************************/
3821 /*                                                                          */
3822 /* Routine Name: ips_chk_status                                             */
3823 /*                                                                          */
3824 /* Routine Description:                                                     */
3825 /*                                                                          */
3826 /*   Check the status of commands to logical drives                         */
3827 /*   Assumed to be called with the HA lock                                  */
3828 /****************************************************************************/
3829 static void
3830 ips_chkstatus(ips_ha_t * ha, IPS_STATUS * pstatus)
3831 {
3832         ips_scb_t *scb;
3833         ips_stat_t *sp;
3834         uint8_t basic_status;
3835         uint8_t ext_status;
3836         int errcode;
3837         IPS_SCSI_INQ_DATA inquiryData;
3838 
3839         METHOD_TRACE("ips_chkstatus", 1);
3840 
3841         scb = &ha->scbs[pstatus->fields.command_id];
3842         scb->basic_status = basic_status =
3843             pstatus->fields.basic_status & IPS_BASIC_STATUS_MASK;
3844         scb->extended_status = ext_status = pstatus->fields.extended_status;
3845 
3846         sp = &ha->sp;
3847         sp->residue_len = 0;
3848         sp->scb_addr = (void *) scb;
3849 
3850         /* Remove the item from the active queue */
3851         ips_removeq_scb(&ha->scb_activelist, scb);
3852 
3853         if (!scb->scsi_cmd)
3854                 /* internal commands are handled in do_ipsintr */
3855                 return;
3856 
3857         DEBUG_VAR(2, "(%s%d) ips_chkstatus: cmd 0x%X id %d (%d %d %d)",
3858                   ips_name,
3859                   ha->host_num,
3860                   scb->cdb[0],
3861                   scb->cmd.basic_io.command_id,
3862                   scb->bus, scb->target_id, scb->lun);
3863 
3864         if ((scb->scsi_cmd) && (ips_is_passthru(scb->scsi_cmd)))
3865                 /* passthru - just returns the raw result */
3866                 return;
3867 
3868         errcode = DID_OK;
3869 
3870         if (((basic_status & IPS_GSC_STATUS_MASK) == IPS_CMD_SUCCESS) ||
3871             ((basic_status & IPS_GSC_STATUS_MASK) == IPS_CMD_RECOVERED_ERROR)) {
3872 
3873                 if (scb->bus == 0) {
3874                         if ((basic_status & IPS_GSC_STATUS_MASK) ==
3875                             IPS_CMD_RECOVERED_ERROR) {
3876                                 DEBUG_VAR(1,
3877                                           "(%s%d) Recovered Logical Drive Error OpCode: %x, BSB: %x, ESB: %x",
3878                                           ips_name, ha->host_num,
3879                                           scb->cmd.basic_io.op_code,
3880                                           basic_status, ext_status);
3881                         }
3882 
3883                         switch (scb->scsi_cmd->cmnd[0]) {
3884                         case ALLOW_MEDIUM_REMOVAL:
3885                         case REZERO_UNIT:
3886                         case ERASE:
3887                         case WRITE_FILEMARKS:
3888                         case SPACE:
3889                                 errcode = DID_ERROR;
3890                                 break;
3891 
3892                         case START_STOP:
3893                                 break;
3894 
3895                         case TEST_UNIT_READY:
3896                                 if (!ips_online(ha, scb)) {
3897                                         errcode = DID_TIME_OUT;
3898                                 }
3899                                 break;
3900 
3901                         case INQUIRY:
3902                                 if (ips_online(ha, scb)) {
3903                                         ips_inquiry(ha, scb);
3904                                 } else {
3905                                         errcode = DID_TIME_OUT;
3906                                 }
3907                                 break;
3908 
3909                         case REQUEST_SENSE:
3910                                 ips_reqsen(ha, scb);
3911                                 break;
3912 
3913                         case READ_6:
3914                         case WRITE_6:
3915                         case READ_10:
3916                         case WRITE_10:
3917                         case RESERVE:
3918                         case RELEASE:
3919                                 break;
3920 
3921                         case MODE_SENSE:
3922                                 if (!ips_online(ha, scb)
3923                                     || !ips_msense(ha, scb)) {
3924                                         errcode = DID_ERROR;
3925                                 }
3926                                 break;
3927 
3928                         case READ_CAPACITY:
3929                                 if (ips_online(ha, scb))
3930                                         ips_rdcap(ha, scb);
3931                                 else {
3932                                         errcode = DID_TIME_OUT;
3933                                 }
3934                                 break;
3935 
3936                         case SEND_DIAGNOSTIC:
3937                         case REASSIGN_BLOCKS:
3938                                 break;
3939 
3940                         case FORMAT_UNIT:
3941                                 errcode = DID_ERROR;
3942                                 break;
3943 
3944                         case SEEK_10:
3945                         case VERIFY:
3946                         case READ_DEFECT_DATA:
3947                         case READ_BUFFER:
3948                         case WRITE_BUFFER:
3949                                 break;
3950 
3951                         default:
3952                                 errcode = DID_ERROR;
3953                         }       /* end switch */
3954 
3955                         scb->scsi_cmd->result = errcode << 16;
3956                 } else {        /* bus == 0 */
3957                         /* restrict access to physical drives */
3958                         if (scb->scsi_cmd->cmnd[0] == INQUIRY) {
3959                             ips_scmd_buf_read(scb->scsi_cmd,
3960                                   &inquiryData, sizeof (inquiryData));
3961                             if ((inquiryData.DeviceType & 0x1f) == TYPE_DISK)
3962                                 scb->scsi_cmd->result = DID_TIME_OUT << 16;
3963                         }
3964                 }               /* else */
3965         } else {                /* recovered error / success */
3966                 if (scb->bus == 0) {
3967                         DEBUG_VAR(1,
3968                                   "(%s%d) Unrecovered Logical Drive Error OpCode: %x, BSB: %x, ESB: %x",
3969                                   ips_name, ha->host_num,
3970                                   scb->cmd.basic_io.op_code, basic_status,
3971                                   ext_status);
3972                 }
3973 
3974                 ips_map_status(ha, scb, sp);
3975         }                       /* else */
3976 }
3977 
3978 /****************************************************************************/
3979 /*                                                                          */
3980 /* Routine Name: ips_online                                                 */
3981 /*                                                                          */
3982 /* Routine Description:                                                     */
3983 /*                                                                          */
3984 /*   Determine if a logical drive is online                                 */
3985 /*                                                                          */
3986 /****************************************************************************/
3987 static int
3988 ips_online(ips_ha_t * ha, ips_scb_t * scb)
3989 {
3990         METHOD_TRACE("ips_online", 1);
3991 
3992         if (scb->target_id >= IPS_MAX_LD)
3993                 return (0);
3994 
3995         if ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1) {
3996                 memset(ha->logical_drive_info, 0, sizeof (IPS_LD_INFO));
3997                 return (0);
3998         }
3999 
4000         if (ha->logical_drive_info->drive_info[scb->target_id].state !=
4001             IPS_LD_OFFLINE
4002             && ha->logical_drive_info->drive_info[scb->target_id].state !=
4003             IPS_LD_FREE
4004             && ha->logical_drive_info->drive_info[scb->target_id].state !=
4005             IPS_LD_CRS
4006             && ha->logical_drive_info->drive_info[scb->target_id].state !=
4007             IPS_LD_SYS)
4008                 return (1);
4009         else
4010                 return (0);
4011 }
4012 
4013 /****************************************************************************/
4014 /*                                                                          */
4015 /* Routine Name: ips_inquiry                                                */
4016 /*                                                                          */
4017 /* Routine Description:                                                     */
4018 /*                                                                          */
4019 /*   Simulate an inquiry command to a logical drive                         */
4020 /*                                                                          */
4021 /****************************************************************************/
4022 static int
4023 ips_inquiry(ips_ha_t * ha, ips_scb_t * scb)
4024 {
4025         IPS_SCSI_INQ_DATA inquiry;
4026 
4027         METHOD_TRACE("ips_inquiry", 1);
4028 
4029         memset(&inquiry, 0, sizeof (IPS_SCSI_INQ_DATA));
4030 
4031         inquiry.DeviceType = IPS_SCSI_INQ_TYPE_DASD;
4032         inquiry.DeviceTypeQualifier = IPS_SCSI_INQ_LU_CONNECTED;
4033         inquiry.Version = IPS_SCSI_INQ_REV2;
4034         inquiry.ResponseDataFormat = IPS_SCSI_INQ_RD_REV2;
4035         inquiry.AdditionalLength = 31;
4036         inquiry.Flags[0] = IPS_SCSI_INQ_Address16;
4037         inquiry.Flags[1] =
4038             IPS_SCSI_INQ_WBus16 | IPS_SCSI_INQ_Sync | IPS_SCSI_INQ_CmdQue;
4039         strncpy(inquiry.VendorId, "IBM     ", 8);
4040         strncpy(inquiry.ProductId, "SERVERAID       ", 16);
4041         strncpy(inquiry.ProductRevisionLevel, "1.00", 4);
4042 
4043         ips_scmd_buf_write(scb->scsi_cmd, &inquiry, sizeof (inquiry));
4044 
4045         return (1);
4046 }
4047 
4048 /****************************************************************************/
4049 /*                                                                          */
4050 /* Routine Name: ips_rdcap                                                  */
4051 /*                                                                          */
4052 /* Routine Description:                                                     */
4053 /*                                                                          */
4054 /*   Simulate a read capacity command to a logical drive                    */
4055 /*                                                                          */
4056 /****************************************************************************/
4057 static int
4058 ips_rdcap(ips_ha_t * ha, ips_scb_t * scb)
4059 {
4060         IPS_SCSI_CAPACITY cap;
4061 
4062         METHOD_TRACE("ips_rdcap", 1);
4063 
4064         if (scsi_bufflen(scb->scsi_cmd) < 8)
4065                 return (0);
4066 
4067         cap.lba =
4068             cpu_to_be32(le32_to_cpu
4069                         (ha->logical_drive_info->
4070                          drive_info[scb->target_id].sector_count) - 1);
4071         cap.len = cpu_to_be32((uint32_t) IPS_BLKSIZE);
4072 
4073         ips_scmd_buf_write(scb->scsi_cmd, &cap, sizeof (cap));
4074 
4075         return (1);
4076 }
4077 
4078 /****************************************************************************/
4079 /*                                                                          */
4080 /* Routine Name: ips_msense                                                 */
4081 /*                                                                          */
4082 /* Routine Description:                                                     */
4083 /*                                                                          */
4084 /*   Simulate a mode sense command to a logical drive                       */
4085 /*                                                                          */
4086 /****************************************************************************/
4087 static int
4088 ips_msense(ips_ha_t * ha, ips_scb_t * scb)
4089 {
4090         uint16_t heads;
4091         uint16_t sectors;
4092         uint32_t cylinders;
4093         IPS_SCSI_MODE_PAGE_DATA mdata;
4094 
4095         METHOD_TRACE("ips_msense", 1);
4096 
4097         if (le32_to_cpu(ha->enq->ulDriveSize[scb->target_id]) > 0x400000 &&
4098             (ha->enq->ucMiscFlag & 0x8) == 0) {
4099                 heads = IPS_NORM_HEADS;
4100                 sectors = IPS_NORM_SECTORS;
4101         } else {
4102                 heads = IPS_COMP_HEADS;
4103                 sectors = IPS_COMP_SECTORS;
4104         }
4105 
4106         cylinders =
4107             (le32_to_cpu(ha->enq->ulDriveSize[scb->target_id]) -
4108              1) / (heads * sectors);
4109 
4110         memset(&mdata, 0, sizeof (IPS_SCSI_MODE_PAGE_DATA));
4111 
4112         mdata.hdr.BlockDescLength = 8;
4113 
4114         switch (scb->scsi_cmd->cmnd[2] & 0x3f) {
4115         case 0x03:              /* page 3 */
4116                 mdata.pdata.pg3.PageCode = 3;
4117                 mdata.pdata.pg3.PageLength = sizeof (IPS_SCSI_MODE_PAGE3);
4118                 mdata.hdr.DataLength =
4119                     3 + mdata.hdr.BlockDescLength + mdata.pdata.pg3.PageLength;
4120                 mdata.pdata.pg3.TracksPerZone = 0;
4121                 mdata.pdata.pg3.AltSectorsPerZone = 0;
4122                 mdata.pdata.pg3.AltTracksPerZone = 0;
4123                 mdata.pdata.pg3.AltTracksPerVolume = 0;
4124                 mdata.pdata.pg3.SectorsPerTrack = cpu_to_be16(sectors);
4125                 mdata.pdata.pg3.BytesPerSector = cpu_to_be16(IPS_BLKSIZE);
4126                 mdata.pdata.pg3.Interleave = cpu_to_be16(1);
4127                 mdata.pdata.pg3.TrackSkew = 0;
4128                 mdata.pdata.pg3.CylinderSkew = 0;
4129                 mdata.pdata.pg3.flags = IPS_SCSI_MP3_SoftSector;
4130                 break;
4131 
4132         case 0x4:
4133                 mdata.pdata.pg4.PageCode = 4;
4134                 mdata.pdata.pg4.PageLength = sizeof (IPS_SCSI_MODE_PAGE4);
4135                 mdata.hdr.DataLength =
4136                     3 + mdata.hdr.BlockDescLength + mdata.pdata.pg4.PageLength;
4137                 mdata.pdata.pg4.CylindersHigh =
4138                     cpu_to_be16((cylinders >> 8) & 0xFFFF);
4139                 mdata.pdata.pg4.CylindersLow = (cylinders & 0xFF);
4140                 mdata.pdata.pg4.Heads = heads;
4141                 mdata.pdata.pg4.WritePrecompHigh = 0;
4142                 mdata.pdata.pg4.WritePrecompLow = 0;
4143                 mdata.pdata.pg4.ReducedWriteCurrentHigh = 0;
4144                 mdata.pdata.pg4.ReducedWriteCurrentLow = 0;
4145                 mdata.pdata.pg4.StepRate = cpu_to_be16(1);
4146                 mdata.pdata.pg4.LandingZoneHigh = 0;
4147                 mdata.pdata.pg4.LandingZoneLow = 0;
4148                 mdata.pdata.pg4.flags = 0;
4149                 mdata.pdata.pg4.RotationalOffset = 0;
4150                 mdata.pdata.pg4.MediumRotationRate = 0;
4151                 break;
4152         case 0x8:
4153                 mdata.pdata.pg8.PageCode = 8;
4154                 mdata.pdata.pg8.PageLength = sizeof (IPS_SCSI_MODE_PAGE8);
4155                 mdata.hdr.DataLength =
4156                     3 + mdata.hdr.BlockDescLength + mdata.pdata.pg8.PageLength;
4157                 /* everything else is left set to 0 */
4158                 break;
4159 
4160         default:
4161                 return (0);
4162         }                       /* end switch */
4163 
4164         ips_scmd_buf_write(scb->scsi_cmd, &mdata, sizeof (mdata));
4165 
4166         return (1);
4167 }
4168 
4169 /****************************************************************************/
4170 /*                                                                          */
4171 /* Routine Name: ips_reqsen                                                 */
4172 /*                                                                          */
4173 /* Routine Description:                                                     */
4174 /*                                                                          */
4175 /*   Simulate a request sense command to a logical drive                    */
4176 /*                                                                          */
4177 /****************************************************************************/
4178 static int
4179 ips_reqsen(ips_ha_t * ha, ips_scb_t * scb)
4180 {
4181         IPS_SCSI_REQSEN reqsen;
4182 
4183         METHOD_TRACE("ips_reqsen", 1);
4184 
4185         memset(&reqsen, 0, sizeof (IPS_SCSI_REQSEN));
4186 
4187         reqsen.ResponseCode =
4188             IPS_SCSI_REQSEN_VALID | IPS_SCSI_REQSEN_CURRENT_ERR;
4189         reqsen.AdditionalLength = 10;
4190         reqsen.AdditionalSenseCode = IPS_SCSI_REQSEN_NO_SENSE;
4191         reqsen.AdditionalSenseCodeQual = IPS_SCSI_REQSEN_NO_SENSE;
4192 
4193         ips_scmd_buf_write(scb->scsi_cmd, &reqsen, sizeof (reqsen));
4194 
4195         return (1);
4196 }
4197 
4198 /****************************************************************************/
4199 /*                                                                          */
4200 /* Routine Name: ips_free                                                   */
4201 /*                                                                          */
4202 /* Routine Description:                                                     */
4203 /*                                                                          */
4204 /*   Free any allocated space for this controller                           */
4205 /*                                                                          */
4206 /****************************************************************************/
4207 static void
4208 ips_free(ips_ha_t * ha)
4209 {
4210 
4211         METHOD_TRACE("ips_free", 1);
4212 
4213         if (ha) {
4214                 if (ha->enq) {
4215                         dma_free_coherent(&ha->pcidev->dev, sizeof(IPS_ENQ),
4216                                             ha->enq, ha->enq_busaddr);
4217                         ha->enq = NULL;
4218                 }
4219 
4220                 kfree(ha->conf);
4221                 ha->conf = NULL;
4222 
4223                 if (ha->adapt) {
4224                         dma_free_coherent(&ha->pcidev->dev,
4225                                             sizeof (IPS_ADAPTER) +
4226                                             sizeof (IPS_IO_CMD), ha->adapt,
4227                                             ha->adapt->hw_status_start);
4228                         ha->adapt = NULL;
4229                 }
4230 
4231                 if (ha->logical_drive_info) {
4232                         dma_free_coherent(&ha->pcidev->dev,
4233                                             sizeof (IPS_LD_INFO),
4234                                             ha->logical_drive_info,
4235                                             ha->logical_drive_info_dma_addr);
4236                         ha->logical_drive_info = NULL;
4237                 }
4238 
4239                 kfree(ha->nvram);
4240                 ha->nvram = NULL;
4241 
4242                 kfree(ha->subsys);
4243                 ha->subsys = NULL;
4244 
4245                 if (ha->ioctl_data) {
4246                         dma_free_coherent(&ha->pcidev->dev, ha->ioctl_len,
4247                                             ha->ioctl_data, ha->ioctl_busaddr);
4248                         ha->ioctl_data = NULL;
4249                         ha->ioctl_datasize = 0;
4250                         ha->ioctl_len = 0;
4251                 }
4252                 ips_deallocatescbs(ha, ha->max_cmds);
4253 
4254                 /* free memory mapped (if applicable) */
4255                 if (ha->mem_ptr) {
4256                         iounmap(ha->ioremap_ptr);
4257                         ha->ioremap_ptr = NULL;
4258                         ha->mem_ptr = NULL;
4259                 }
4260 
4261                 ha->mem_addr = 0;
4262 
4263         }
4264 }
4265 
4266 /****************************************************************************/
4267 /*                                                                          */
4268 /* Routine Name: ips_deallocatescbs                                         */
4269 /*                                                                          */
4270 /* Routine Description:                                                     */
4271 /*                                                                          */
4272 /*   Free the command blocks                                                */
4273 /*                                                                          */
4274 /****************************************************************************/
4275 static int
4276 ips_deallocatescbs(ips_ha_t * ha, int cmds)
4277 {
4278         if (ha->scbs) {
4279                 dma_free_coherent(&ha->pcidev->dev,
4280                                     IPS_SGLIST_SIZE(ha) * IPS_MAX_SG * cmds,
4281                                     ha->scbs->sg_list.list,
4282                                     ha->scbs->sg_busaddr);
4283                 dma_free_coherent(&ha->pcidev->dev, sizeof (ips_scb_t) * cmds,
4284                                     ha->scbs, ha->scbs->scb_busaddr);
4285                 ha->scbs = NULL;
4286         }                       /* end if */
4287         return 1;
4288 }
4289 
4290 /****************************************************************************/
4291 /*                                                                          */
4292 /* Routine Name: ips_allocatescbs                                           */
4293 /*                                                                          */
4294 /* Routine Description:                                                     */
4295 /*                                                                          */
4296 /*   Allocate the command blocks                                            */
4297 /*                                                                          */
4298 /****************************************************************************/
4299 static int
4300 ips_allocatescbs(ips_ha_t * ha)
4301 {
4302         ips_scb_t *scb_p;
4303         IPS_SG_LIST ips_sg;
4304         int i;
4305         dma_addr_t command_dma, sg_dma;
4306 
4307         METHOD_TRACE("ips_allocatescbs", 1);
4308 
4309         /* Allocate memory for the SCBs */
4310         ha->scbs = dma_alloc_coherent(&ha->pcidev->dev,
4311                         ha->max_cmds * sizeof (ips_scb_t),
4312                         &command_dma, GFP_KERNEL);
4313         if (ha->scbs == NULL)
4314                 return 0;
4315         ips_sg.list = dma_alloc_coherent(&ha->pcidev->dev,
4316                         IPS_SGLIST_SIZE(ha) * IPS_MAX_SG * ha->max_cmds,
4317                         &sg_dma, GFP_KERNEL);
4318         if (ips_sg.list == NULL) {
4319                 dma_free_coherent(&ha->pcidev->dev,
4320                                     ha->max_cmds * sizeof (ips_scb_t), ha->scbs,
4321                                     command_dma);
4322                 return 0;
4323         }
4324 
4325         memset(ha->scbs, 0, ha->max_cmds * sizeof (ips_scb_t));
4326 
4327         for (i = 0; i < ha->max_cmds; i++) {
4328                 scb_p = &ha->scbs[i];
4329                 scb_p->scb_busaddr = command_dma + sizeof (ips_scb_t) * i;
4330                 /* set up S/G list */
4331                 if (IPS_USE_ENH_SGLIST(ha)) {
4332                         scb_p->sg_list.enh_list =
4333                             ips_sg.enh_list + i * IPS_MAX_SG;
4334                         scb_p->sg_busaddr =
4335                             sg_dma + IPS_SGLIST_SIZE(ha) * IPS_MAX_SG * i;
4336                 } else {
4337                         scb_p->sg_list.std_list =
4338                             ips_sg.std_list + i * IPS_MAX_SG;
4339                         scb_p->sg_busaddr =
4340                             sg_dma + IPS_SGLIST_SIZE(ha) * IPS_MAX_SG * i;
4341                 }
4342 
4343                 /* add to the free list */
4344                 if (i < ha->max_cmds - 1) {
4345                         scb_p->q_next = ha->scb_freelist;
4346                         ha->scb_freelist = scb_p;
4347                 }
4348         }
4349 
4350         /* success */
4351         return (1);
4352 }
4353 
4354 /****************************************************************************/
4355 /*                                                                          */
4356 /* Routine Name: ips_init_scb                                               */
4357 /*                                                                          */
4358 /* Routine Description:                                                     */
4359 /*                                                                          */
4360 /*   Initialize a CCB to default values                                     */
4361 /*                                                                          */
4362 /****************************************************************************/
4363 static void
4364 ips_init_scb(ips_ha_t * ha, ips_scb_t * scb)
4365 {
4366         IPS_SG_LIST sg_list;
4367         uint32_t cmd_busaddr, sg_busaddr;
4368         METHOD_TRACE("ips_init_scb", 1);
4369 
4370         if (scb == NULL)
4371                 return;
4372 
4373         sg_list.list = scb->sg_list.list;
4374         cmd_busaddr = scb->scb_busaddr;
4375         sg_busaddr = scb->sg_busaddr;
4376         /* zero fill */
4377         memset(scb, 0, sizeof (ips_scb_t));
4378         memset(ha->dummy, 0, sizeof (IPS_IO_CMD));
4379 
4380         /* Initialize dummy command bucket */
4381         ha->dummy->op_code = 0xFF;
4382         ha->dummy->ccsar = cpu_to_le32(ha->adapt->hw_status_start
4383                                        + sizeof (IPS_ADAPTER));
4384         ha->dummy->command_id = IPS_MAX_CMDS;
4385 
4386         /* set bus address of scb */
4387         scb->scb_busaddr = cmd_busaddr;
4388         scb->sg_busaddr = sg_busaddr;
4389         scb->sg_list.list = sg_list.list;
4390 
4391         /* Neptune Fix */
4392         scb->cmd.basic_io.cccr = cpu_to_le32((uint32_t) IPS_BIT_ILE);
4393         scb->cmd.basic_io.ccsar = cpu_to_le32(ha->adapt->hw_status_start
4394                                               + sizeof (IPS_ADAPTER));
4395 }
4396 
4397 /****************************************************************************/
4398 /*                                                                          */
4399 /* Routine Name: ips_get_scb                                                */
4400 /*                                                                          */
4401 /* Routine Description:                                                     */
4402 /*                                                                          */
4403 /*   Initialize a CCB to default values                                     */
4404 /*                                                                          */
4405 /* ASSUMED to be called from within a lock                                 */
4406 /*                                                                          */
4407 /****************************************************************************/
4408 static ips_scb_t *
4409 ips_getscb(ips_ha_t * ha)
4410 {
4411         ips_scb_t *scb;
4412 
4413         METHOD_TRACE("ips_getscb", 1);
4414 
4415         if ((scb = ha->scb_freelist) == NULL) {
4416 
4417                 return (NULL);
4418         }
4419 
4420         ha->scb_freelist = scb->q_next;
4421         scb->flags = 0;
4422         scb->q_next = NULL;
4423 
4424         ips_init_scb(ha, scb);
4425 
4426         return (scb);
4427 }
4428 
4429 /****************************************************************************/
4430 /*                                                                          */
4431 /* Routine Name: ips_free_scb                                               */
4432 /*                                                                          */
4433 /* Routine Description:                                                     */
4434 /*                                                                          */
4435 /*   Return an unused CCB back to the free list                             */
4436 /*                                                                          */
4437 /* ASSUMED to be called from within a lock                                  */
4438 /*                                                                          */
4439 /****************************************************************************/
4440 static void
4441 ips_freescb(ips_ha_t * ha, ips_scb_t * scb)
4442 {
4443 
4444         METHOD_TRACE("ips_freescb", 1);
4445         if (scb->flags & IPS_SCB_MAP_SG)
4446                 scsi_dma_unmap(scb->scsi_cmd);
4447         else if (scb->flags & IPS_SCB_MAP_SINGLE)
4448                 dma_unmap_single(&ha->pcidev->dev, scb->data_busaddr,
4449                                  scb->data_len, IPS_DMA_DIR(scb));
4450 
4451         /* check to make sure this is not our "special" scb */
4452         if (IPS_COMMAND_ID(ha, scb) < (ha->max_cmds - 1)) {
4453                 scb->q_next = ha->scb_freelist;
4454                 ha->scb_freelist = scb;
4455         }
4456 }
4457 
4458 /****************************************************************************/
4459 /*                                                                          */
4460 /* Routine Name: ips_isinit_copperhead                                      */
4461 /*                                                                          */
4462 /* Routine Description:                                                     */
4463 /*                                                                          */
4464 /*   Is controller initialized ?                                            */
4465 /*                                                                          */
4466 /****************************************************************************/
4467 static int
4468 ips_isinit_copperhead(ips_ha_t * ha)
4469 {
4470         uint8_t scpr;
4471         uint8_t isr;
4472 
4473         METHOD_TRACE("ips_isinit_copperhead", 1);
4474 
4475         isr = inb(ha->io_addr + IPS_REG_HISR);
4476         scpr = inb(ha->io_addr + IPS_REG_SCPR);
4477 
4478         if (((isr & IPS_BIT_EI) == 0) && ((scpr & IPS_BIT_EBM) == 0))
4479                 return (0);
4480         else
4481                 return (1);
4482 }
4483 
4484 /****************************************************************************/
4485 /*                                                                          */
4486 /* Routine Name: ips_isinit_copperhead_memio                                */
4487 /*                                                                          */
4488 /* Routine Description:                                                     */
4489 /*                                                                          */
4490 /*   Is controller initialized ?                                            */
4491 /*                                                                          */
4492 /****************************************************************************/
4493 static int
4494 ips_isinit_copperhead_memio(ips_ha_t * ha)
4495 {
4496         uint8_t isr = 0;
4497         uint8_t scpr;
4498 
4499         METHOD_TRACE("ips_is_init_copperhead_memio", 1);
4500 
4501         isr = readb(ha->mem_ptr + IPS_REG_HISR);
4502         scpr = readb(ha->mem_ptr + IPS_REG_SCPR);
4503 
4504         if (((isr & IPS_BIT_EI) == 0) && ((scpr & IPS_BIT_EBM) == 0))
4505                 return (0);
4506         else
4507                 return (1);
4508 }
4509 
4510 /****************************************************************************/
4511 /*                                                                          */
4512 /* Routine Name: ips_isinit_morpheus                                        */
4513 /*                                                                          */
4514 /* Routine Description:                                                     */
4515 /*                                                                          */
4516 /*   Is controller initialized ?                                            */
4517 /*                                                                          */
4518 /****************************************************************************/
4519 static int
4520 ips_isinit_morpheus(ips_ha_t * ha)
4521 {
4522         uint32_t post;
4523         uint32_t bits;
4524 
4525         METHOD_TRACE("ips_is_init_morpheus", 1);
4526 
4527         if (ips_isintr_morpheus(ha))
4528             ips_flush_and_reset(ha);
4529 
4530         post = readl(ha->mem_ptr + IPS_REG_I960_MSG0);
4531         bits = readl(ha->mem_ptr + IPS_REG_I2O_HIR);
4532 
4533         if (post == 0)
4534                 return (0);
4535         else if (bits & 0x3)
4536                 return (0);
4537         else
4538                 return (1);
4539 }
4540 
4541 /****************************************************************************/
4542 /*                                                                          */
4543 /* Routine Name: ips_flush_and_reset                                        */
4544 /*                                                                          */
4545 /* Routine Description:                                                     */
4546 /*                                                                          */
4547 /*   Perform cleanup ( FLUSH and RESET ) when the adapter is in an unknown  */
4548 /*   state ( was trying to INIT and an interrupt was already pending ) ...  */
4549 /*                                                                          */
4550 /****************************************************************************/
4551 static void
4552 ips_flush_and_reset(ips_ha_t *ha)
4553 {
4554         ips_scb_t *scb;
4555         int  ret;
4556         int  time;
4557         int  done;
4558         dma_addr_t command_dma;
4559 
4560         /* Create a usuable SCB */
4561         scb = dma_alloc_coherent(&ha->pcidev->dev, sizeof(ips_scb_t),
4562                         &command_dma, GFP_KERNEL);
4563         if (scb) {
4564             memset(scb, 0, sizeof(ips_scb_t));
4565             ips_init_scb(ha, scb);
4566             scb->scb_busaddr = command_dma;
4567 
4568             scb->timeout = ips_cmd_timeout;
4569             scb->cdb[0] = IPS_CMD_FLUSH;
4570 
4571             scb->cmd.flush_cache.op_code = IPS_CMD_FLUSH;
4572             scb->cmd.flush_cache.command_id = IPS_MAX_CMDS;   /* Use an ID that would otherwise not exist */
4573             scb->cmd.flush_cache.state = IPS_NORM_STATE;
4574             scb->cmd.flush_cache.reserved = 0;
4575             scb->cmd.flush_cache.reserved2 = 0;
4576             scb->cmd.flush_cache.reserved3 = 0;
4577             scb->cmd.flush_cache.reserved4 = 0;
4578 
4579             ret = ips_send_cmd(ha, scb);                      /* Send the Flush Command */
4580 
4581             if (ret == IPS_SUCCESS) {
4582                 time = 60 * IPS_ONE_SEC;                      /* Max Wait time is 60 seconds */
4583                 done = 0;
4584 
4585                 while ((time > 0) && (!done)) {
4586                    done = ips_poll_for_flush_complete(ha);
4587                    /* This may look evil, but it's only done during extremely rare start-up conditions ! */
4588                    udelay(1000);
4589                    time--;
4590                 }
4591         }
4592         }
4593 
4594         /* Now RESET and INIT the adapter */
4595         (*ha->func.reset) (ha);
4596 
4597         dma_free_coherent(&ha->pcidev->dev, sizeof(ips_scb_t), scb, command_dma);
4598         return;
4599 }
4600 
4601 /****************************************************************************/
4602 /*                                                                          */
4603 /* Routine Name: ips_poll_for_flush_complete                                */
4604 /*                                                                          */
4605 /* Routine Description:                                                     */
4606 /*                                                                          */
4607 /*   Poll for the Flush Command issued by ips_flush_and_reset() to complete */
4608 /*   All other responses are just taken off the queue and ignored           */
4609 /*                                                                          */
4610 /****************************************************************************/
4611 static int
4612 ips_poll_for_flush_complete(ips_ha_t * ha)
4613 {
4614         IPS_STATUS cstatus;
4615 
4616         while (TRUE) {
4617             cstatus.value = (*ha->func.statupd) (ha);
4618 
4619             if (cstatus.value == 0xffffffff)      /* If No Interrupt to process */
4620                         break;
4621 
4622             /* Success is when we see the Flush Command ID */
4623             if (cstatus.fields.command_id == IPS_MAX_CMDS)
4624                 return 1;
4625          }
4626 
4627         return 0;
4628 }
4629 
4630 /****************************************************************************/
4631 /*                                                                          */
4632 /* Routine Name: ips_enable_int_copperhead                                  */
4633 /*                                                                          */
4634 /* Routine Description:                                                     */
4635 /*   Turn on interrupts                                                     */
4636 /*                                                                          */
4637 /****************************************************************************/
4638 static void
4639 ips_enable_int_copperhead(ips_ha_t * ha)
4640 {
4641         METHOD_TRACE("ips_enable_int_copperhead", 1);
4642 
4643         outb(ha->io_addr + IPS_REG_HISR, IPS_BIT_EI);
4644         inb(ha->io_addr + IPS_REG_HISR);        /*Ensure PCI Posting Completes*/
4645 }
4646 
4647 /****************************************************************************/
4648 /*                                                                          */
4649 /* Routine Name: ips_enable_int_copperhead_memio                            */
4650 /*                                                                          */
4651 /* Routine Description:                                                     */
4652 /*   Turn on interrupts                                                     */
4653 /*                                                                          */
4654 /****************************************************************************/
4655 static void
4656 ips_enable_int_copperhead_memio(ips_ha_t * ha)
4657 {
4658         METHOD_TRACE("ips_enable_int_copperhead_memio", 1);
4659 
4660         writeb(IPS_BIT_EI, ha->mem_ptr + IPS_REG_HISR);
4661         readb(ha->mem_ptr + IPS_REG_HISR);      /*Ensure PCI Posting Completes*/
4662 }
4663 
4664 /****************************************************************************/
4665 /*                                                                          */
4666 /* Routine Name: ips_enable_int_morpheus                                    */
4667 /*                                                                          */
4668 /* Routine Description:                                                     */
4669 /*   Turn on interrupts                                                     */
4670 /*                                                                          */
4671 /****************************************************************************/
4672 static void
4673 ips_enable_int_morpheus(ips_ha_t * ha)
4674 {
4675         uint32_t Oimr;
4676 
4677         METHOD_TRACE("ips_enable_int_morpheus", 1);
4678 
4679         Oimr = readl(ha->mem_ptr + IPS_REG_I960_OIMR);
4680         Oimr &= ~0x08;
4681         writel(Oimr, ha->mem_ptr + IPS_REG_I960_OIMR);
4682         readl(ha->mem_ptr + IPS_REG_I960_OIMR); /*Ensure PCI Posting Completes*/
4683 }
4684 
4685 /****************************************************************************/
4686 /*                                                                          */
4687 /* Routine Name: ips_init_copperhead                                        */
4688 /*                                                                          */
4689 /* Routine Description:                                                     */
4690 /*                                                                          */
4691 /*   Initialize a copperhead controller                                     */
4692 /*                                                                          */
4693 /****************************************************************************/
4694 static int
4695 ips_init_copperhead(ips_ha_t * ha)
4696 {
4697         uint8_t Isr;
4698         uint8_t Cbsp;
4699         uint8_t PostByte[IPS_MAX_POST_BYTES];
4700         uint8_t ConfigByte[IPS_MAX_CONFIG_BYTES];
4701         int i, j;
4702 
4703         METHOD_TRACE("ips_init_copperhead", 1);
4704 
4705         for (i = 0; i < IPS_MAX_POST_BYTES; i++) {
4706                 for (j = 0; j < 45; j++) {
4707                         Isr = inb(ha->io_addr + IPS_REG_HISR);
4708                         if (Isr & IPS_BIT_GHI)
4709                                 break;
4710 
4711                         /* Delay for 1 Second */
4712                         MDELAY(IPS_ONE_SEC);
4713                 }
4714 
4715                 if (j >= 45)
4716                         /* error occurred */
4717                         return (0);
4718 
4719                 PostByte[i] = inb(ha->io_addr + IPS_REG_ISPR);
4720                 outb(Isr, ha->io_addr + IPS_REG_HISR);
4721         }
4722 
4723         if (PostByte[0] < IPS_GOOD_POST_STATUS) {
4724                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
4725                            "reset controller fails (post status %x %x).\n",
4726                            PostByte[0], PostByte[1]);
4727 
4728                 return (0);
4729         }
4730 
4731         for (i = 0; i < IPS_MAX_CONFIG_BYTES; i++) {
4732                 for (j = 0; j < 240; j++) {
4733                         Isr = inb(ha->io_addr + IPS_REG_HISR);
4734                         if (Isr & IPS_BIT_GHI)
4735                                 break;
4736 
4737                         /* Delay for 1 Second */
4738                         MDELAY(IPS_ONE_SEC);
4739                 }
4740 
4741                 if (j >= 240)
4742                         /* error occurred */
4743                         return (0);
4744 
4745                 ConfigByte[i] = inb(ha->io_addr + IPS_REG_ISPR);
4746                 outb(Isr, ha->io_addr + IPS_REG_HISR);
4747         }
4748 
4749         for (i = 0; i < 240; i++) {
4750                 Cbsp = inb(ha->io_addr + IPS_REG_CBSP);
4751 
4752                 if ((Cbsp & IPS_BIT_OP) == 0)
4753                         break;
4754 
4755                 /* Delay for 1 Second */
4756                 MDELAY(IPS_ONE_SEC);
4757         }
4758 
4759         if (i >= 240)
4760                 /* reset failed */
4761                 return (0);
4762 
4763         /* setup CCCR */
4764         outl(0x1010, ha->io_addr + IPS_REG_CCCR);
4765 
4766         /* Enable busmastering */
4767         outb(IPS_BIT_EBM, ha->io_addr + IPS_REG_SCPR);
4768 
4769         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
4770                 /* fix for anaconda64 */
4771                 outl(0, ha->io_addr + IPS_REG_NDAE);
4772 
4773         /* Enable interrupts */
4774         outb(IPS_BIT_EI, ha->io_addr + IPS_REG_HISR);
4775 
4776         return (1);
4777 }
4778 
4779 /****************************************************************************/
4780 /*                                                                          */
4781 /* Routine Name: ips_init_copperhead_memio                                  */
4782 /*                                                                          */
4783 /* Routine Description:                                                     */
4784 /*                                                                          */
4785 /*   Initialize a copperhead controller with memory mapped I/O              */
4786 /*                                                                          */
4787 /****************************************************************************/
4788 static int
4789 ips_init_copperhead_memio(ips_ha_t * ha)
4790 {
4791         uint8_t Isr = 0;
4792         uint8_t Cbsp;
4793         uint8_t PostByte[IPS_MAX_POST_BYTES];
4794         uint8_t ConfigByte[IPS_MAX_CONFIG_BYTES];
4795         int i, j;
4796 
4797         METHOD_TRACE("ips_init_copperhead_memio", 1);
4798 
4799         for (i = 0; i < IPS_MAX_POST_BYTES; i++) {
4800                 for (j = 0; j < 45; j++) {
4801                         Isr = readb(ha->mem_ptr + IPS_REG_HISR);
4802                         if (Isr & IPS_BIT_GHI)
4803                                 break;
4804 
4805                         /* Delay for 1 Second */
4806                         MDELAY(IPS_ONE_SEC);
4807                 }
4808 
4809                 if (j >= 45)
4810                         /* error occurred */
4811                         return (0);
4812 
4813                 PostByte[i] = readb(ha->mem_ptr + IPS_REG_ISPR);
4814                 writeb(Isr, ha->mem_ptr + IPS_REG_HISR);
4815         }
4816 
4817         if (PostByte[0] < IPS_GOOD_POST_STATUS) {
4818                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
4819                            "reset controller fails (post status %x %x).\n",
4820                            PostByte[0], PostByte[1]);
4821 
4822                 return (0);
4823         }
4824 
4825         for (i = 0; i < IPS_MAX_CONFIG_BYTES; i++) {
4826                 for (j = 0; j < 240; j++) {
4827                         Isr = readb(ha->mem_ptr + IPS_REG_HISR);
4828                         if (Isr & IPS_BIT_GHI)
4829                                 break;
4830 
4831                         /* Delay for 1 Second */
4832                         MDELAY(IPS_ONE_SEC);
4833                 }
4834 
4835                 if (j >= 240)
4836                         /* error occurred */
4837                         return (0);
4838 
4839                 ConfigByte[i] = readb(ha->mem_ptr + IPS_REG_ISPR);
4840                 writeb(Isr, ha->mem_ptr + IPS_REG_HISR);
4841         }
4842 
4843         for (i = 0; i < 240; i++) {
4844                 Cbsp = readb(ha->mem_ptr + IPS_REG_CBSP);
4845 
4846                 if ((Cbsp & IPS_BIT_OP) == 0)
4847                         break;
4848 
4849                 /* Delay for 1 Second */
4850                 MDELAY(IPS_ONE_SEC);
4851         }
4852 
4853         if (i >= 240)
4854                 /* error occurred */
4855                 return (0);
4856 
4857         /* setup CCCR */
4858         writel(0x1010, ha->mem_ptr + IPS_REG_CCCR);
4859 
4860         /* Enable busmastering */
4861         writeb(IPS_BIT_EBM, ha->mem_ptr + IPS_REG_SCPR);
4862 
4863         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
4864                 /* fix for anaconda64 */
4865                 writel(0, ha->mem_ptr + IPS_REG_NDAE);
4866 
4867         /* Enable interrupts */
4868         writeb(IPS_BIT_EI, ha->mem_ptr + IPS_REG_HISR);
4869 
4870         /* if we get here then everything went OK */
4871         return (1);
4872 }
4873 
4874 /****************************************************************************/
4875 /*                                                                          */
4876 /* Routine Name: ips_init_morpheus                                          */
4877 /*                                                                          */
4878 /* Routine Description:                                                     */
4879 /*                                                                          */
4880 /*   Initialize a morpheus controller                                       */
4881 /*                                                                          */
4882 /****************************************************************************/
4883 static int
4884 ips_init_morpheus(ips_ha_t * ha)
4885 {
4886         uint32_t Post;
4887         uint32_t Config;
4888         uint32_t Isr;
4889         uint32_t Oimr;
4890         int i;
4891 
4892         METHOD_TRACE("ips_init_morpheus", 1);
4893 
4894         /* Wait up to 45 secs for Post */
4895         for (i = 0; i < 45; i++) {
4896                 Isr = readl(ha->mem_ptr + IPS_REG_I2O_HIR);
4897 
4898                 if (Isr & IPS_BIT_I960_MSG0I)
4899                         break;
4900 
4901                 /* Delay for 1 Second */
4902                 MDELAY(IPS_ONE_SEC);
4903         }
4904 
4905         if (i >= 45) {
4906                 /* error occurred */
4907                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
4908                            "timeout waiting for post.\n");
4909 
4910                 return (0);
4911         }
4912 
4913         Post = readl(ha->mem_ptr + IPS_REG_I960_MSG0);
4914 
4915         if (Post == 0x4F00) {   /* If Flashing the Battery PIC         */
4916                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
4917                            "Flashing Battery PIC, Please wait ...\n");
4918 
4919                 /* Clear the interrupt bit */
4920                 Isr = (uint32_t) IPS_BIT_I960_MSG0I;
4921                 writel(Isr, ha->mem_ptr + IPS_REG_I2O_HIR);
4922 
4923                 for (i = 0; i < 120; i++) {     /*    Wait Up to 2 Min. for Completion */
4924                         Post = readl(ha->mem_ptr + IPS_REG_I960_MSG0);
4925                         if (Post != 0x4F00)
4926                                 break;
4927                         /* Delay for 1 Second */
4928                         MDELAY(IPS_ONE_SEC);
4929                 }
4930 
4931                 if (i >= 120) {
4932                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
4933                                    "timeout waiting for Battery PIC Flash\n");
4934                         return (0);
4935                 }
4936 
4937         }
4938 
4939         /* Clear the interrupt bit */
4940         Isr = (uint32_t) IPS_BIT_I960_MSG0I;
4941         writel(Isr, ha->mem_ptr + IPS_REG_I2O_HIR);
4942 
4943         if (Post < (IPS_GOOD_POST_STATUS << 8)) {
4944                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
4945                            "reset controller fails (post status %x).\n", Post);
4946 
4947                 return (0);
4948         }
4949 
4950         /* Wait up to 240 secs for config bytes */
4951         for (i = 0; i < 240; i++) {
4952                 Isr = readl(ha->mem_ptr + IPS_REG_I2O_HIR);
4953 
4954                 if (Isr & IPS_BIT_I960_MSG1I)
4955                         break;
4956 
4957                 /* Delay for 1 Second */
4958                 MDELAY(IPS_ONE_SEC);
4959         }
4960 
4961         if (i >= 240) {
4962                 /* error occurred */
4963                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
4964                            "timeout waiting for config.\n");
4965 
4966                 return (0);
4967         }
4968 
4969         Config = readl(ha->mem_ptr + IPS_REG_I960_MSG1);
4970 
4971         /* Clear interrupt bit */
4972         Isr = (uint32_t) IPS_BIT_I960_MSG1I;
4973         writel(Isr, ha->mem_ptr + IPS_REG_I2O_HIR);
4974 
4975         /* Turn on the interrupts */
4976         Oimr = readl(ha->mem_ptr + IPS_REG_I960_OIMR);
4977         Oimr &= ~0x8;
4978         writel(Oimr, ha->mem_ptr + IPS_REG_I960_OIMR);
4979 
4980         /* if we get here then everything went OK */
4981 
4982         /* Since we did a RESET, an EraseStripeLock may be needed */
4983         if (Post == 0xEF10) {
4984                 if ((Config == 0x000F) || (Config == 0x0009))
4985                         ha->requires_esl = 1;
4986         }
4987 
4988         return (1);
4989 }
4990 
4991 /****************************************************************************/
4992 /*                                                                          */
4993 /* Routine Name: ips_reset_copperhead                                       */
4994 /*                                                                          */
4995 /* Routine Description:                                                     */
4996 /*                                                                          */
4997 /*   Reset the controller                                                   */
4998 /*                                                                          */
4999 /****************************************************************************/
5000 static int
5001 ips_reset_copperhead(ips_ha_t * ha)
5002 {
5003         int reset_counter;
5004 
5005         METHOD_TRACE("ips_reset_copperhead", 1);
5006 
5007         DEBUG_VAR(1, "(%s%d) ips_reset_copperhead: io addr: %x, irq: %d",
5008                   ips_name, ha->host_num, ha->io_addr, ha->pcidev->irq);
5009 
5010         reset_counter = 0;
5011 
5012         while (reset_counter < 2) {
5013                 reset_counter++;
5014 
5015                 outb(IPS_BIT_RST, ha->io_addr + IPS_REG_SCPR);
5016 
5017                 /* Delay for 1 Second */
5018                 MDELAY(IPS_ONE_SEC);
5019 
5020                 outb(0, ha->io_addr + IPS_REG_SCPR);
5021 
5022                 /* Delay for 1 Second */
5023                 MDELAY(IPS_ONE_SEC);
5024 
5025                 if ((*ha->func.init) (ha))
5026                         break;
5027                 else if (reset_counter >= 2) {
5028 
5029                         return (0);
5030                 }
5031         }
5032 
5033         return (1);
5034 }
5035 
5036 /****************************************************************************/
5037 /*                                                                          */
5038 /* Routine Name: ips_reset_copperhead_memio                                 */
5039 /*                                                                          */
5040 /* Routine Description:                                                     */
5041 /*                                                                          */
5042 /*   Reset the controller                                                   */
5043 /*                                                                          */
5044 /****************************************************************************/
5045 static int
5046 ips_reset_copperhead_memio(ips_ha_t * ha)
5047 {
5048         int reset_counter;
5049 
5050         METHOD_TRACE("ips_reset_copperhead_memio", 1);
5051 
5052         DEBUG_VAR(1, "(%s%d) ips_reset_copperhead_memio: mem addr: %x, irq: %d",
5053                   ips_name, ha->host_num, ha->mem_addr, ha->pcidev->irq);
5054 
5055         reset_counter = 0;
5056 
5057         while (reset_counter < 2) {
5058                 reset_counter++;
5059 
5060                 writeb(IPS_BIT_RST, ha->mem_ptr + IPS_REG_SCPR);
5061 
5062                 /* Delay for 1 Second */
5063                 MDELAY(IPS_ONE_SEC);
5064 
5065                 writeb(0, ha->mem_ptr + IPS_REG_SCPR);
5066 
5067                 /* Delay for 1 Second */
5068                 MDELAY(IPS_ONE_SEC);
5069 
5070                 if ((*ha->func.init) (ha))
5071                         break;
5072                 else if (reset_counter >= 2) {
5073 
5074                         return (0);
5075                 }
5076         }
5077 
5078         return (1);
5079 }
5080 
5081 /****************************************************************************/
5082 /*                                                                          */
5083 /* Routine Name: ips_reset_morpheus                                         */
5084 /*                                                                          */
5085 /* Routine Description:                                                     */
5086 /*                                                                          */
5087 /*   Reset the controller                                                   */
5088 /*                                                                          */
5089 /****************************************************************************/
5090 static int
5091 ips_reset_morpheus(ips_ha_t * ha)
5092 {
5093         int reset_counter;
5094         uint8_t junk;
5095 
5096         METHOD_TRACE("ips_reset_morpheus", 1);
5097 
5098         DEBUG_VAR(1, "(%s%d) ips_reset_morpheus: mem addr: %x, irq: %d",
5099                   ips_name, ha->host_num, ha->mem_addr, ha->pcidev->irq);
5100 
5101         reset_counter = 0;
5102 
5103         while (reset_counter < 2) {
5104                 reset_counter++;
5105 
5106                 writel(0x80000000, ha->mem_ptr + IPS_REG_I960_IDR);
5107 
5108                 /* Delay for 5 Seconds */
5109                 MDELAY(5 * IPS_ONE_SEC);
5110 
5111                 /* Do a PCI config read to wait for adapter */
5112                 pci_read_config_byte(ha->pcidev, 4, &junk);
5113 
5114                 if ((*ha->func.init) (ha))
5115                         break;
5116                 else if (reset_counter >= 2) {
5117 
5118                         return (0);
5119                 }
5120         }
5121 
5122         return (1);
5123 }
5124 
5125 /****************************************************************************/
5126 /*                                                                          */
5127 /* Routine Name: ips_statinit                                               */
5128 /*                                                                          */
5129 /* Routine Description:                                                     */
5130 /*                                                                          */
5131 /*   Initialize the status queues on the controller                         */
5132 /*                                                                          */
5133 /****************************************************************************/
5134 static void
5135 ips_statinit(ips_ha_t * ha)
5136 {
5137         uint32_t phys_status_start;
5138 
5139         METHOD_TRACE("ips_statinit", 1);
5140 
5141         ha->adapt->p_status_start = ha->adapt->status;
5142         ha->adapt->p_status_end = ha->adapt->status + IPS_MAX_CMDS;
5143         ha->adapt->p_status_tail = ha->adapt->status;
5144 
5145         phys_status_start = ha->adapt->hw_status_start;
5146         outl(phys_status_start, ha->io_addr + IPS_REG_SQSR);
5147         outl(phys_status_start + IPS_STATUS_Q_SIZE,
5148              ha->io_addr + IPS_REG_SQER);
5149         outl(phys_status_start + IPS_STATUS_SIZE,
5150              ha->io_addr + IPS_REG_SQHR);
5151         outl(phys_status_start, ha->io_addr + IPS_REG_SQTR);
5152 
5153         ha->adapt->hw_status_tail = phys_status_start;
5154 }
5155 
5156 /****************************************************************************/
5157 /*                                                                          */
5158 /* Routine Name: ips_statinit_memio                                         */
5159 /*                                                                          */
5160 /* Routine Description:                                                     */
5161 /*                                                                          */
5162 /*   Initialize the status queues on the controller                         */
5163 /*                                                                          */
5164 /****************************************************************************/
5165 static void
5166 ips_statinit_memio(ips_ha_t * ha)
5167 {
5168         uint32_t phys_status_start;
5169 
5170         METHOD_TRACE("ips_statinit_memio", 1);
5171 
5172         ha->adapt->p_status_start = ha->adapt->status;
5173         ha->adapt->p_status_end = ha->adapt->status + IPS_MAX_CMDS;
5174         ha->adapt->p_status_tail = ha->adapt->status;
5175 
5176         phys_status_start = ha->adapt->hw_status_start;
5177         writel(phys_status_start, ha->mem_ptr + IPS_REG_SQSR);
5178         writel(phys_status_start + IPS_STATUS_Q_SIZE,
5179                ha->mem_ptr + IPS_REG_SQER);
5180         writel(phys_status_start + IPS_STATUS_SIZE, ha->mem_ptr + IPS_REG_SQHR);
5181         writel(phys_status_start, ha->mem_ptr + IPS_REG_SQTR);
5182 
5183         ha->adapt->hw_status_tail = phys_status_start;
5184 }
5185 
5186 /****************************************************************************/
5187 /*                                                                          */
5188 /* Routine Name: ips_statupd_copperhead                                     */
5189 /*                                                                          */
5190 /* Routine Description:                                                     */
5191 /*                                                                          */
5192 /*   Remove an element from the status queue                                */
5193 /*                                                                          */
5194 /****************************************************************************/
5195 static uint32_t
5196 ips_statupd_copperhead(ips_ha_t * ha)
5197 {
5198         METHOD_TRACE("ips_statupd_copperhead", 1);
5199 
5200         if (ha->adapt->p_status_tail != ha->adapt->p_status_end) {
5201                 ha->adapt->p_status_tail++;
5202                 ha->adapt->hw_status_tail += sizeof (IPS_STATUS);
5203         } else {
5204                 ha->adapt->p_status_tail = ha->adapt->p_status_start;
5205                 ha->adapt->hw_status_tail = ha->adapt->hw_status_start;
5206         }
5207 
5208         outl(ha->adapt->hw_status_tail,
5209              ha->io_addr + IPS_REG_SQTR);
5210 
5211         return (ha->adapt->p_status_tail->value);
5212 }
5213 
5214 /****************************************************************************/
5215 /*                                                                          */
5216 /* Routine Name: ips_statupd_copperhead_memio                               */
5217 /*                                                                          */
5218 /* Routine Description:                                                     */
5219 /*                                                                          */
5220 /*   Remove an element from the status queue                                */
5221 /*                                                                          */
5222 /****************************************************************************/
5223 static uint32_t
5224 ips_statupd_copperhead_memio(ips_ha_t * ha)
5225 {
5226         METHOD_TRACE("ips_statupd_copperhead_memio", 1);
5227 
5228         if (ha->adapt->p_status_tail != ha->adapt->p_status_end) {
5229                 ha->adapt->p_status_tail++;
5230                 ha->adapt->hw_status_tail += sizeof (IPS_STATUS);
5231         } else {
5232                 ha->adapt->p_status_tail = ha->adapt->p_status_start;
5233                 ha->adapt->hw_status_tail = ha->adapt->hw_status_start;
5234         }
5235 
5236         writel(ha->adapt->hw_status_tail, ha->mem_ptr + IPS_REG_SQTR);
5237 
5238         return (ha->adapt->p_status_tail->value);
5239 }
5240 
5241 /****************************************************************************/
5242 /*                                                                          */
5243 /* Routine Name: ips_statupd_morpheus                                       */
5244 /*                                                                          */
5245 /* Routine Description:                                                     */
5246 /*                                                                          */
5247 /*   Remove an element from the status queue                                */
5248 /*                                                                          */
5249 /****************************************************************************/
5250 static uint32_t
5251 ips_statupd_morpheus(ips_ha_t * ha)
5252 {
5253         uint32_t val;
5254 
5255         METHOD_TRACE("ips_statupd_morpheus", 1);
5256 
5257         val = readl(ha->mem_ptr + IPS_REG_I2O_OUTMSGQ);
5258 
5259         return (val);
5260 }
5261 
5262 /****************************************************************************/
5263 /*                                                                          */
5264 /* Routine Name: ips_issue_copperhead                                       */
5265 /*                                                                          */
5266 /* Routine Description:                                                     */
5267 /*                                                                          */
5268 /*   Send a command down to the controller                                  */
5269 /*                                                                          */
5270 /****************************************************************************/
5271 static int
5272 ips_issue_copperhead(ips_ha_t * ha, ips_scb_t * scb)
5273 {
5274         uint32_t TimeOut;
5275         uint32_t val;
5276 
5277         METHOD_TRACE("ips_issue_copperhead", 1);
5278 
5279         if (scb->scsi_cmd) {
5280                 DEBUG_VAR(2, "(%s%d) ips_issue: cmd 0x%X id %d (%d %d %d)",
5281                           ips_name,
5282                           ha->host_num,
5283                           scb->cdb[0],
5284                           scb->cmd.basic_io.command_id,
5285                           scb->bus, scb->target_id, scb->lun);
5286         } else {
5287                 DEBUG_VAR(2, KERN_NOTICE "(%s%d) ips_issue: logical cmd id %d",
5288                           ips_name, ha->host_num, scb->cmd.basic_io.command_id);
5289         }
5290 
5291         TimeOut = 0;
5292 
5293         while ((val =
5294                 le32_to_cpu(inl(ha->io_addr + IPS_REG_CCCR))) & IPS_BIT_SEM) {
5295                 udelay(1000);
5296 
5297                 if (++TimeOut >= IPS_SEM_TIMEOUT) {
5298                         if (!(val & IPS_BIT_START_STOP))
5299                                 break;
5300 
5301                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
5302                                    "ips_issue val [0x%x].\n", val);
5303                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
5304                                    "ips_issue semaphore chk timeout.\n");
5305 
5306                         return (IPS_FAILURE);
5307                 }               /* end if */
5308         }                       /* end while */
5309 
5310         outl(scb->scb_busaddr, ha->io_addr + IPS_REG_CCSAR);
5311         outw(IPS_BIT_START_CMD, ha->io_addr + IPS_REG_CCCR);
5312 
5313         return (IPS_SUCCESS);
5314 }
5315 
5316 /****************************************************************************/
5317 /*                                                                          */
5318 /* Routine Name: ips_issue_copperhead_memio                                 */
5319 /*                                                                          */
5320 /* Routine Description:                                                     */
5321 /*                                                                          */
5322 /*   Send a command down to the controller                                  */
5323 /*                                                                          */
5324 /****************************************************************************/
5325 static int
5326 ips_issue_copperhead_memio(ips_ha_t * ha, ips_scb_t * scb)
5327 {
5328         uint32_t TimeOut;
5329         uint32_t val;
5330 
5331         METHOD_TRACE("ips_issue_copperhead_memio", 1);
5332 
5333         if (scb->scsi_cmd) {
5334                 DEBUG_VAR(2, "(%s%d) ips_issue: cmd 0x%X id %d (%d %d %d)",
5335                           ips_name,
5336                           ha->host_num,
5337                           scb->cdb[0],
5338                           scb->cmd.basic_io.command_id,
5339                           scb->bus, scb->target_id, scb->lun);
5340         } else {
5341                 DEBUG_VAR(2, "(%s%d) ips_issue: logical cmd id %d",
5342                           ips_name, ha->host_num, scb->cmd.basic_io.command_id);
5343         }
5344 
5345         TimeOut = 0;
5346 
5347         while ((val = readl(ha->mem_ptr + IPS_REG_CCCR)) & IPS_BIT_SEM) {
5348                 udelay(1000);
5349 
5350                 if (++TimeOut >= IPS_SEM_TIMEOUT) {
5351                         if (!(val & IPS_BIT_START_STOP))
5352                                 break;
5353 
5354                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
5355                                    "ips_issue val [0x%x].\n", val);
5356                         IPS_PRINTK(KERN_WARNING, ha->pcidev,
5357                                    "ips_issue semaphore chk timeout.\n");
5358 
5359                         return (IPS_FAILURE);
5360                 }               /* end if */
5361         }                       /* end while */
5362 
5363         writel(scb->scb_busaddr, ha->mem_ptr + IPS_REG_CCSAR);
5364         writel(IPS_BIT_START_CMD, ha->mem_ptr + IPS_REG_CCCR);
5365 
5366         return (IPS_SUCCESS);
5367 }
5368 
5369 /****************************************************************************/
5370 /*                                                                          */
5371 /* Routine Name: ips_issue_i2o                                              */
5372 /*                                                                          */
5373 /* Routine Description:                                                     */
5374 /*                                                                          */
5375 /*   Send a command down to the controller                                  */
5376 /*                                                                          */
5377 /****************************************************************************/
5378 static int
5379 ips_issue_i2o(ips_ha_t * ha, ips_scb_t * scb)
5380 {
5381 
5382         METHOD_TRACE("ips_issue_i2o", 1);
5383 
5384         if (scb->scsi_cmd) {
5385                 DEBUG_VAR(2, "(%s%d) ips_issue: cmd 0x%X id %d (%d %d %d)",
5386                           ips_name,
5387                           ha->host_num,
5388                           scb->cdb[0],
5389                           scb->cmd.basic_io.command_id,
5390                           scb->bus, scb->target_id, scb->lun);
5391         } else {
5392                 DEBUG_VAR(2, "(%s%d) ips_issue: logical cmd id %d",
5393                           ips_name, ha->host_num, scb->cmd.basic_io.command_id);
5394         }
5395 
5396         outl(scb->scb_busaddr, ha->io_addr + IPS_REG_I2O_INMSGQ);
5397 
5398         return (IPS_SUCCESS);
5399 }
5400 
5401 /****************************************************************************/
5402 /*                                                                          */
5403 /* Routine Name: ips_issue_i2o_memio                                        */
5404 /*                                                                          */
5405 /* Routine Description:                                                     */
5406 /*                                                                          */
5407 /*   Send a command down to the controller                                  */
5408 /*                                                                          */
5409 /****************************************************************************/
5410 static int
5411 ips_issue_i2o_memio(ips_ha_t * ha, ips_scb_t * scb)
5412 {
5413 
5414         METHOD_TRACE("ips_issue_i2o_memio", 1);
5415 
5416         if (scb->scsi_cmd) {
5417                 DEBUG_VAR(2, "(%s%d) ips_issue: cmd 0x%X id %d (%d %d %d)",
5418                           ips_name,
5419                           ha->host_num,
5420                           scb->cdb[0],
5421                           scb->cmd.basic_io.command_id,
5422                           scb->bus, scb->target_id, scb->lun);
5423         } else {
5424                 DEBUG_VAR(2, "(%s%d) ips_issue: logical cmd id %d",
5425                           ips_name, ha->host_num, scb->cmd.basic_io.command_id);
5426         }
5427 
5428         writel(scb->scb_busaddr, ha->mem_ptr + IPS_REG_I2O_INMSGQ);
5429 
5430         return (IPS_SUCCESS);
5431 }
5432 
5433 /****************************************************************************/
5434 /*                                                                          */
5435 /* Routine Name: ips_isintr_copperhead                                      */
5436 /*                                                                          */
5437 /* Routine Description:                                                     */
5438 /*                                                                          */
5439 /*   Test to see if an interrupt is for us                                  */
5440 /*                                                                          */
5441 /****************************************************************************/
5442 static int
5443 ips_isintr_copperhead(ips_ha_t * ha)
5444 {
5445         uint8_t Isr;
5446 
5447         METHOD_TRACE("ips_isintr_copperhead", 2);
5448 
5449         Isr = inb(ha->io_addr + IPS_REG_HISR);
5450 
5451         if (Isr == 0xFF)
5452                 /* ?!?! Nothing really there */
5453                 return (0);
5454 
5455         if (Isr & IPS_BIT_SCE)
5456                 return (1);
5457         else if (Isr & (IPS_BIT_SQO | IPS_BIT_GHI)) {
5458                 /* status queue overflow or GHI */
5459                 /* just clear the interrupt */
5460                 outb(Isr, ha->io_addr + IPS_REG_HISR);
5461         }
5462 
5463         return (0);
5464 }
5465 
5466 /****************************************************************************/
5467 /*                                                                          */
5468 /* Routine Name: ips_isintr_copperhead_memio                                */
5469 /*                                                                          */
5470 /* Routine Description:                                                     */
5471 /*                                                                          */
5472 /*   Test to see if an interrupt is for us                                  */
5473 /*                                                                          */
5474 /****************************************************************************/
5475 static int
5476 ips_isintr_copperhead_memio(ips_ha_t * ha)
5477 {
5478         uint8_t Isr;
5479 
5480         METHOD_TRACE("ips_isintr_memio", 2);
5481 
5482         Isr = readb(ha->mem_ptr + IPS_REG_HISR);
5483 
5484         if (Isr == 0xFF)
5485                 /* ?!?! Nothing really there */
5486                 return (0);
5487 
5488         if (Isr & IPS_BIT_SCE)
5489                 return (1);
5490         else if (Isr & (IPS_BIT_SQO | IPS_BIT_GHI)) {
5491                 /* status queue overflow or GHI */
5492                 /* just clear the interrupt */
5493                 writeb(Isr, ha->mem_ptr + IPS_REG_HISR);
5494         }
5495 
5496         return (0);
5497 }
5498 
5499 /****************************************************************************/
5500 /*                                                                          */
5501 /* Routine Name: ips_isintr_morpheus                                        */
5502 /*                                                                          */
5503 /* Routine Description:                                                     */
5504 /*                                                                          */
5505 /*   Test to see if an interrupt is for us                                  */
5506 /*                                                                          */
5507 /****************************************************************************/
5508 static int
5509 ips_isintr_morpheus(ips_ha_t * ha)
5510 {
5511         uint32_t Isr;
5512 
5513         METHOD_TRACE("ips_isintr_morpheus", 2);
5514 
5515         Isr = readl(ha->mem_ptr + IPS_REG_I2O_HIR);
5516 
5517         if (Isr & IPS_BIT_I2O_OPQI)
5518                 return (1);
5519         else
5520                 return (0);
5521 }
5522 
5523 /****************************************************************************/
5524 /*                                                                          */
5525 /* Routine Name: ips_wait                                                   */
5526 /*                                                                          */
5527 /* Routine Description:                                                     */
5528 /*                                                                          */
5529 /*   Wait for a command to complete                                         */
5530 /*                                                                          */
5531 /****************************************************************************/
5532 static int
5533 ips_wait(ips_ha_t * ha, int time, int intr)
5534 {
5535         int ret;
5536         int done;
5537 
5538         METHOD_TRACE("ips_wait", 1);
5539 
5540         ret = IPS_FAILURE;
5541         done = FALSE;
5542 
5543         time *= IPS_ONE_SEC;    /* convert seconds */
5544 
5545         while ((time > 0) && (!done)) {
5546                 if (intr == IPS_INTR_ON) {
5547                         if (ha->waitflag == FALSE) {
5548                                 ret = IPS_SUCCESS;
5549                                 done = TRUE;
5550                                 break;
5551                         }
5552                 } else if (intr == IPS_INTR_IORL) {
5553                         if (ha->waitflag == FALSE) {
5554                                 /*
5555                                  * controller generated an interrupt to
5556                                  * acknowledge completion of the command
5557                                  * and ips_intr() has serviced the interrupt.
5558                                  */
5559                                 ret = IPS_SUCCESS;
5560                                 done = TRUE;
5561                                 break;
5562                         }
5563 
5564                         /*
5565                          * NOTE: we already have the io_request_lock so
5566                          * even if we get an interrupt it won't get serviced
5567                          * until after we finish.
5568                          */
5569 
5570                         (*ha->func.intr) (ha);
5571                 }
5572 
5573                 /* This looks like a very evil loop, but it only does this during start-up */
5574                 udelay(1000);
5575                 time--;
5576         }
5577 
5578         return (ret);
5579 }
5580 
5581 /****************************************************************************/
5582 /*                                                                          */
5583 /* Routine Name: ips_write_driver_status                                    */
5584 /*                                                                          */
5585 /* Routine Description:                                                     */
5586 /*                                                                          */
5587 /*   Write OS/Driver version to Page 5 of the nvram on the controller       */
5588 /*                                                                          */
5589 /****************************************************************************/
5590 static int
5591 ips_write_driver_status(ips_ha_t * ha, int intr)
5592 {
5593         METHOD_TRACE("ips_write_driver_status", 1);
5594 
5595         if (!ips_readwrite_page5(ha, FALSE, intr)) {
5596                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
5597                            "unable to read NVRAM page 5.\n");
5598 
5599                 return (0);
5600         }
5601 
5602         /* check to make sure the page has a valid */
5603         /* signature */
5604         if (le32_to_cpu(ha->nvram->signature) != IPS_NVRAM_P5_SIG) {
5605                 DEBUG_VAR(1,
5606                           "(%s%d) NVRAM page 5 has an invalid signature: %X.",
5607                           ips_name, ha->host_num, ha->nvram->signature);
5608                 ha->nvram->signature = IPS_NVRAM_P5_SIG;
5609         }
5610 
5611         DEBUG_VAR(2,
5612                   "(%s%d) Ad Type: %d, Ad Slot: %d, BIOS: %c%c%c%c %c%c%c%c.",
5613                   ips_name, ha->host_num, le16_to_cpu(ha->nvram->adapter_type),
5614                   ha->nvram->adapter_slot, ha->nvram->bios_high[0],
5615                   ha->nvram->bios_high[1], ha->nvram->bios_high[2],
5616                   ha->nvram->bios_high[3], ha->nvram->bios_low[0],
5617                   ha->nvram->bios_low[1], ha->nvram->bios_low[2],
5618                   ha->nvram->bios_low[3]);
5619 
5620         ips_get_bios_version(ha, intr);
5621 
5622         /* change values (as needed) */
5623         ha->nvram->operating_system = IPS_OS_LINUX;
5624         ha->nvram->adapter_type = ha->ad_type;
5625         strncpy((char *) ha->nvram->driver_high, IPS_VERSION_HIGH, 4);
5626         strncpy((char *) ha->nvram->driver_low, IPS_VERSION_LOW, 4);
5627         strncpy((char *) ha->nvram->bios_high, ha->bios_version, 4);
5628         strncpy((char *) ha->nvram->bios_low, ha->bios_version + 4, 4);
5629 
5630         ha->nvram->versioning = 0;      /* Indicate the Driver Does Not Support Versioning */
5631 
5632         /* now update the page */
5633         if (!ips_readwrite_page5(ha, TRUE, intr)) {
5634                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
5635                            "unable to write NVRAM page 5.\n");
5636 
5637                 return (0);
5638         }
5639 
5640         /* IF NVRAM Page 5 is OK, Use it for Slot Number Info Because Linux Doesn't Do Slots */
5641         ha->slot_num = ha->nvram->adapter_slot;
5642 
5643         return (1);
5644 }
5645 
5646 /****************************************************************************/
5647 /*                                                                          */
5648 /* Routine Name: ips_read_adapter_status                                    */
5649 /*                                                                          */
5650 /* Routine Description:                                                     */
5651 /*                                                                          */
5652 /*   Do an Inquiry command to the adapter                                   */
5653 /*                                                                          */
5654 /****************************************************************************/
5655 static int
5656 ips_read_adapter_status(ips_ha_t * ha, int intr)
5657 {
5658         ips_scb_t *scb;
5659         int ret;
5660 
5661         METHOD_TRACE("ips_read_adapter_status", 1);
5662 
5663         scb = &ha->scbs[ha->max_cmds - 1];
5664 
5665         ips_init_scb(ha, scb);
5666 
5667         scb->timeout = ips_cmd_timeout;
5668         scb->cdb[0] = IPS_CMD_ENQUIRY;
5669 
5670         scb->cmd.basic_io.op_code = IPS_CMD_ENQUIRY;
5671         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
5672         scb->cmd.basic_io.sg_count = 0;
5673         scb->cmd.basic_io.lba = 0;
5674         scb->cmd.basic_io.sector_count = 0;
5675         scb->cmd.basic_io.log_drv = 0;
5676         scb->data_len = sizeof (*ha->enq);
5677         scb->cmd.basic_io.sg_addr = ha->enq_busaddr;
5678 
5679         /* send command */
5680         if (((ret =
5681               ips_send_wait(ha, scb, ips_cmd_timeout, intr)) == IPS_FAILURE)
5682             || (ret == IPS_SUCCESS_IMM)
5683             || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1))
5684                 return (0);
5685 
5686         return (1);
5687 }
5688 
5689 /****************************************************************************/
5690 /*                                                                          */
5691 /* Routine Name: ips_read_subsystem_parameters                              */
5692 /*                                                                          */
5693 /* Routine Description:                                                     */
5694 /*                                                                          */
5695 /*   Read subsystem parameters from the adapter                             */
5696 /*                                                                          */
5697 /****************************************************************************/
5698 static int
5699 ips_read_subsystem_parameters(ips_ha_t * ha, int intr)
5700 {
5701         ips_scb_t *scb;
5702         int ret;
5703 
5704         METHOD_TRACE("ips_read_subsystem_parameters", 1);
5705 
5706         scb = &ha->scbs[ha->max_cmds - 1];
5707 
5708         ips_init_scb(ha, scb);
5709 
5710         scb->timeout = ips_cmd_timeout;
5711         scb->cdb[0] = IPS_CMD_GET_SUBSYS;
5712 
5713         scb->cmd.basic_io.op_code = IPS_CMD_GET_SUBSYS;
5714         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
5715         scb->cmd.basic_io.sg_count = 0;
5716         scb->cmd.basic_io.lba = 0;
5717         scb->cmd.basic_io.sector_count = 0;
5718         scb->cmd.basic_io.log_drv = 0;
5719         scb->data_len = sizeof (*ha->subsys);
5720         scb->cmd.basic_io.sg_addr = ha->ioctl_busaddr;
5721 
5722         /* send command */
5723         if (((ret =
5724               ips_send_wait(ha, scb, ips_cmd_timeout, intr)) == IPS_FAILURE)
5725             || (ret == IPS_SUCCESS_IMM)
5726             || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1))
5727                 return (0);
5728 
5729         memcpy(ha->subsys, ha->ioctl_data, sizeof(*ha->subsys));
5730         return (1);
5731 }
5732 
5733 /****************************************************************************/
5734 /*                                                                          */
5735 /* Routine Name: ips_read_config                                            */
5736 /*                                                                          */
5737 /* Routine Description:                                                     */
5738 /*                                                                          */
5739 /*   Read the configuration on the adapter                                  */
5740 /*                                                                          */
5741 /****************************************************************************/
5742 static int
5743 ips_read_config(ips_ha_t * ha, int intr)
5744 {
5745         ips_scb_t *scb;
5746         int i;
5747         int ret;
5748 
5749         METHOD_TRACE("ips_read_config", 1);
5750 
5751         /* set defaults for initiator IDs */
5752         for (i = 0; i < 4; i++)
5753                 ha->conf->init_id[i] = 7;
5754 
5755         scb = &ha->scbs[ha->max_cmds - 1];
5756 
5757         ips_init_scb(ha, scb);
5758 
5759         scb->timeout = ips_cmd_timeout;
5760         scb->cdb[0] = IPS_CMD_READ_CONF;
5761 
5762         scb->cmd.basic_io.op_code = IPS_CMD_READ_CONF;
5763         scb->cmd.basic_io.command_id = IPS_COMMAND_ID(ha, scb);
5764         scb->data_len = sizeof (*ha->conf);
5765         scb->cmd.basic_io.sg_addr = ha->ioctl_busaddr;
5766 
5767         /* send command */
5768         if (((ret =
5769               ips_send_wait(ha, scb, ips_cmd_timeout, intr)) == IPS_FAILURE)
5770             || (ret == IPS_SUCCESS_IMM)
5771             || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1)) {
5772 
5773                 memset(ha->conf, 0, sizeof (IPS_CONF));
5774 
5775                 /* reset initiator IDs */
5776                 for (i = 0; i < 4; i++)
5777                         ha->conf->init_id[i] = 7;
5778 
5779                 /* Allow Completed with Errors, so JCRM can access the Adapter to fix the problems */
5780                 if ((scb->basic_status & IPS_GSC_STATUS_MASK) ==
5781                     IPS_CMD_CMPLT_WERROR)
5782                         return (1);
5783 
5784                 return (0);
5785         }
5786 
5787         memcpy(ha->conf, ha->ioctl_data, sizeof(*ha->conf));
5788         return (1);
5789 }
5790 
5791 /****************************************************************************/
5792 /*                                                                          */
5793 /* Routine Name: ips_readwrite_page5                                        */
5794 /*                                                                          */
5795 /* Routine Description:                                                     */
5796 /*                                                                          */
5797 /*   Read nvram page 5 from the adapter                                     */
5798 /*                                                                          */
5799 /****************************************************************************/
5800 static int
5801 ips_readwrite_page5(ips_ha_t * ha, int write, int intr)
5802 {
5803         ips_scb_t *scb;
5804         int ret;
5805 
5806         METHOD_TRACE("ips_readwrite_page5", 1);
5807 
5808         scb = &ha->scbs[ha->max_cmds - 1];
5809 
5810         ips_init_scb(ha, scb);
5811 
5812         scb->timeout = ips_cmd_timeout;
5813         scb->cdb[0] = IPS_CMD_RW_NVRAM_PAGE;
5814 
5815         scb->cmd.nvram.op_code = IPS_CMD_RW_NVRAM_PAGE;
5816         scb->cmd.nvram.command_id = IPS_COMMAND_ID(ha, scb);
5817         scb->cmd.nvram.page = 5;
5818         scb->cmd.nvram.write = write;
5819         scb->cmd.nvram.reserved = 0;
5820         scb->cmd.nvram.reserved2 = 0;
5821         scb->data_len = sizeof (*ha->nvram);
5822         scb->cmd.nvram.buffer_addr = ha->ioctl_busaddr;
5823         if (write)
5824                 memcpy(ha->ioctl_data, ha->nvram, sizeof(*ha->nvram));
5825 
5826         /* issue the command */
5827         if (((ret =
5828               ips_send_wait(ha, scb, ips_cmd_timeout, intr)) == IPS_FAILURE)
5829             || (ret == IPS_SUCCESS_IMM)
5830             || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1)) {
5831 
5832                 memset(ha->nvram, 0, sizeof (IPS_NVRAM_P5));
5833 
5834                 return (0);
5835         }
5836         if (!write)
5837                 memcpy(ha->nvram, ha->ioctl_data, sizeof(*ha->nvram));
5838         return (1);
5839 }
5840 
5841 /****************************************************************************/
5842 /*                                                                          */
5843 /* Routine Name: ips_clear_adapter                                          */
5844 /*                                                                          */
5845 /* Routine Description:                                                     */
5846 /*                                                                          */
5847 /*   Clear the stripe lock tables                                           */
5848 /*                                                                          */
5849 /****************************************************************************/
5850 static int
5851 ips_clear_adapter(ips_ha_t * ha, int intr)
5852 {
5853         ips_scb_t *scb;
5854         int ret;
5855 
5856         METHOD_TRACE("ips_clear_adapter", 1);
5857 
5858         scb = &ha->scbs[ha->max_cmds - 1];
5859 
5860         ips_init_scb(ha, scb);
5861 
5862         scb->timeout = ips_reset_timeout;
5863         scb->cdb[0] = IPS_CMD_CONFIG_SYNC;
5864 
5865         scb->cmd.config_sync.op_code = IPS_CMD_CONFIG_SYNC;
5866         scb->cmd.config_sync.command_id = IPS_COMMAND_ID(ha, scb);
5867         scb->cmd.config_sync.channel = 0;
5868         scb->cmd.config_sync.source_target = IPS_POCL;
5869         scb->cmd.config_sync.reserved = 0;
5870         scb->cmd.config_sync.reserved2 = 0;
5871         scb->cmd.config_sync.reserved3 = 0;
5872 
5873         /* issue command */
5874         if (((ret =
5875               ips_send_wait(ha, scb, ips_reset_timeout, intr)) == IPS_FAILURE)
5876             || (ret == IPS_SUCCESS_IMM)
5877             || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1))
5878                 return (0);
5879 
5880         /* send unlock stripe command */
5881         ips_init_scb(ha, scb);
5882 
5883         scb->cdb[0] = IPS_CMD_ERROR_TABLE;
5884         scb->timeout = ips_reset_timeout;
5885 
5886         scb->cmd.unlock_stripe.op_code = IPS_CMD_ERROR_TABLE;
5887         scb->cmd.unlock_stripe.command_id = IPS_COMMAND_ID(ha, scb);
5888         scb->cmd.unlock_stripe.log_drv = 0;
5889         scb->cmd.unlock_stripe.control = IPS_CSL;
5890         scb->cmd.unlock_stripe.reserved = 0;
5891         scb->cmd.unlock_stripe.reserved2 = 0;
5892         scb->cmd.unlock_stripe.reserved3 = 0;
5893 
5894         /* issue command */
5895         if (((ret =
5896               ips_send_wait(ha, scb, ips_cmd_timeout, intr)) == IPS_FAILURE)
5897             || (ret == IPS_SUCCESS_IMM)
5898             || ((scb->basic_status & IPS_GSC_STATUS_MASK) > 1))
5899                 return (0);
5900 
5901         return (1);
5902 }
5903 
5904 /****************************************************************************/
5905 /*                                                                          */
5906 /* Routine Name: ips_ffdc_reset                                             */
5907 /*                                                                          */
5908 /* Routine Description:                                                     */
5909 /*                                                                          */
5910 /*   FFDC: write reset info                                                 */
5911 /*                                                                          */
5912 /****************************************************************************/
5913 static void
5914 ips_ffdc_reset(ips_ha_t * ha, int intr)
5915 {
5916         ips_scb_t *scb;
5917 
5918         METHOD_TRACE("ips_ffdc_reset", 1);
5919 
5920         scb = &ha->scbs[ha->max_cmds - 1];
5921 
5922         ips_init_scb(ha, scb);
5923 
5924         scb->timeout = ips_cmd_timeout;
5925         scb->cdb[0] = IPS_CMD_FFDC;
5926         scb->cmd.ffdc.op_code = IPS_CMD_FFDC;
5927         scb->cmd.ffdc.command_id = IPS_COMMAND_ID(ha, scb);
5928         scb->cmd.ffdc.reset_count = ha->reset_count;
5929         scb->cmd.ffdc.reset_type = 0x80;
5930 
5931         /* convert time to what the card wants */
5932         ips_fix_ffdc_time(ha, scb, ha->last_ffdc);
5933 
5934         /* issue command */
5935         ips_send_wait(ha, scb, ips_cmd_timeout, intr);
5936 }
5937 
5938 /****************************************************************************/
5939 /*                                                                          */
5940 /* Routine Name: ips_ffdc_time                                              */
5941 /*                                                                          */
5942 /* Routine Description:                                                     */
5943 /*                                                                          */
5944 /*   FFDC: write time info                                                  */
5945 /*                                                                          */
5946 /****************************************************************************/
5947 static void
5948 ips_ffdc_time(ips_ha_t * ha)
5949 {
5950         ips_scb_t *scb;
5951 
5952         METHOD_TRACE("ips_ffdc_time", 1);
5953 
5954         DEBUG_VAR(1, "(%s%d) Sending time update.", ips_name, ha->host_num);
5955 
5956         scb = &ha->scbs[ha->max_cmds - 1];
5957 
5958         ips_init_scb(ha, scb);
5959 
5960         scb->timeout = ips_cmd_timeout;
5961         scb->cdb[0] = IPS_CMD_FFDC;
5962         scb->cmd.ffdc.op_code = IPS_CMD_FFDC;
5963         scb->cmd.ffdc.command_id = IPS_COMMAND_ID(ha, scb);
5964         scb->cmd.ffdc.reset_count = 0;
5965         scb->cmd.ffdc.reset_type = 0;
5966 
5967         /* convert time to what the card wants */
5968         ips_fix_ffdc_time(ha, scb, ha->last_ffdc);
5969 
5970         /* issue command */
5971         ips_send_wait(ha, scb, ips_cmd_timeout, IPS_FFDC);
5972 }
5973 
5974 /****************************************************************************/
5975 /*                                                                          */
5976 /* Routine Name: ips_fix_ffdc_time                                          */
5977 /*                                                                          */
5978 /* Routine Description:                                                     */
5979 /*   Adjust time_t to what the card wants                                   */
5980 /*                                                                          */
5981 /****************************************************************************/
5982 static void
5983 ips_fix_ffdc_time(ips_ha_t * ha, ips_scb_t * scb, time64_t current_time)
5984 {
5985         struct tm tm;
5986 
5987         METHOD_TRACE("ips_fix_ffdc_time", 1);
5988 
5989         time64_to_tm(current_time, 0, &tm);
5990 
5991         scb->cmd.ffdc.hour   = tm.tm_hour;
5992         scb->cmd.ffdc.minute = tm.tm_min;
5993         scb->cmd.ffdc.second = tm.tm_sec;
5994         scb->cmd.ffdc.yearH  = (tm.tm_year + 1900) / 100;
5995         scb->cmd.ffdc.yearL  = tm.tm_year % 100;
5996         scb->cmd.ffdc.month  = tm.tm_mon + 1;
5997         scb->cmd.ffdc.day    = tm.tm_mday;
5998 }
5999 
6000 /****************************************************************************
6001  * BIOS Flash Routines                                                      *
6002  ****************************************************************************/
6003 
6004 /****************************************************************************/
6005 /*                                                                          */
6006 /* Routine Name: ips_erase_bios                                             */
6007 /*                                                                          */
6008 /* Routine Description:                                                     */
6009 /*   Erase the BIOS on the adapter                                          */
6010 /*                                                                          */
6011 /****************************************************************************/
6012 static int
6013 ips_erase_bios(ips_ha_t * ha)
6014 {
6015         int timeout;
6016         uint8_t status = 0;
6017 
6018         METHOD_TRACE("ips_erase_bios", 1);
6019 
6020         status = 0;
6021 
6022         /* Clear the status register */
6023         outl(0, ha->io_addr + IPS_REG_FLAP);
6024         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6025                 udelay(25);     /* 25 us */
6026 
6027         outb(0x50, ha->io_addr + IPS_REG_FLDP);
6028         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6029                 udelay(25);     /* 25 us */
6030 
6031         /* Erase Setup */
6032         outb(0x20, ha->io_addr + IPS_REG_FLDP);
6033         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6034                 udelay(25);     /* 25 us */
6035 
6036         /* Erase Confirm */
6037         outb(0xD0, ha->io_addr + IPS_REG_FLDP);
6038         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6039                 udelay(25);     /* 25 us */
6040 
6041         /* Erase Status */
6042         outb(0x70, ha->io_addr + IPS_REG_FLDP);
6043         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6044                 udelay(25);     /* 25 us */
6045 
6046         timeout = 80000;        /* 80 seconds */
6047 
6048         while (timeout > 0) {
6049                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64) {
6050                         outl(0, ha->io_addr + IPS_REG_FLAP);
6051                         udelay(25);     /* 25 us */
6052                 }
6053 
6054                 status = inb(ha->io_addr + IPS_REG_FLDP);
6055 
6056                 if (status & 0x80)
6057                         break;
6058 
6059                 MDELAY(1);
6060                 timeout--;
6061         }
6062 
6063         /* check for timeout */
6064         if (timeout <= 0) {
6065                 /* timeout */
6066 
6067                 /* try to suspend the erase */
6068                 outb(0xB0, ha->io_addr + IPS_REG_FLDP);
6069                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6070                         udelay(25);     /* 25 us */
6071 
6072                 /* wait for 10 seconds */
6073                 timeout = 10000;
6074                 while (timeout > 0) {
6075                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64) {
6076                                 outl(0, ha->io_addr + IPS_REG_FLAP);
6077                                 udelay(25);     /* 25 us */
6078                         }
6079 
6080                         status = inb(ha->io_addr + IPS_REG_FLDP);
6081 
6082                         if (status & 0xC0)
6083                                 break;
6084 
6085                         MDELAY(1);
6086                         timeout--;
6087                 }
6088 
6089                 return (1);
6090         }
6091 
6092         /* check for valid VPP */
6093         if (status & 0x08)
6094                 /* VPP failure */
6095                 return (1);
6096 
6097         /* check for successful flash */
6098         if (status & 0x30)
6099                 /* sequence error */
6100                 return (1);
6101 
6102         /* Otherwise, we were successful */
6103         /* clear status */
6104         outb(0x50, ha->io_addr + IPS_REG_FLDP);
6105         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6106                 udelay(25);     /* 25 us */
6107 
6108         /* enable reads */
6109         outb(0xFF, ha->io_addr + IPS_REG_FLDP);
6110         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6111                 udelay(25);     /* 25 us */
6112 
6113         return (0);
6114 }
6115 
6116 /****************************************************************************/
6117 /*                                                                          */
6118 /* Routine Name: ips_erase_bios_memio                                       */
6119 /*                                                                          */
6120 /* Routine Description:                                                     */
6121 /*   Erase the BIOS on the adapter                                          */
6122 /*                                                                          */
6123 /****************************************************************************/
6124 static int
6125 ips_erase_bios_memio(ips_ha_t * ha)
6126 {
6127         int timeout;
6128         uint8_t status;
6129 
6130         METHOD_TRACE("ips_erase_bios_memio", 1);
6131 
6132         status = 0;
6133 
6134         /* Clear the status register */
6135         writel(0, ha->mem_ptr + IPS_REG_FLAP);
6136         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6137                 udelay(25);     /* 25 us */
6138 
6139         writeb(0x50, ha->mem_ptr + IPS_REG_FLDP);
6140         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6141                 udelay(25);     /* 25 us */
6142 
6143         /* Erase Setup */
6144         writeb(0x20, ha->mem_ptr + IPS_REG_FLDP);
6145         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6146                 udelay(25);     /* 25 us */
6147 
6148         /* Erase Confirm */
6149         writeb(0xD0, ha->mem_ptr + IPS_REG_FLDP);
6150         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6151                 udelay(25);     /* 25 us */
6152 
6153         /* Erase Status */
6154         writeb(0x70, ha->mem_ptr + IPS_REG_FLDP);
6155         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6156                 udelay(25);     /* 25 us */
6157 
6158         timeout = 80000;        /* 80 seconds */
6159 
6160         while (timeout > 0) {
6161                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64) {
6162                         writel(0, ha->mem_ptr + IPS_REG_FLAP);
6163                         udelay(25);     /* 25 us */
6164                 }
6165 
6166                 status = readb(ha->mem_ptr + IPS_REG_FLDP);
6167 
6168                 if (status & 0x80)
6169                         break;
6170 
6171                 MDELAY(1);
6172                 timeout--;
6173         }
6174 
6175         /* check for timeout */
6176         if (timeout <= 0) {
6177                 /* timeout */
6178 
6179                 /* try to suspend the erase */
6180                 writeb(0xB0, ha->mem_ptr + IPS_REG_FLDP);
6181                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6182                         udelay(25);     /* 25 us */
6183 
6184                 /* wait for 10 seconds */
6185                 timeout = 10000;
6186                 while (timeout > 0) {
6187                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64) {
6188                                 writel(0, ha->mem_ptr + IPS_REG_FLAP);
6189                                 udelay(25);     /* 25 us */
6190                         }
6191 
6192                         status = readb(ha->mem_ptr + IPS_REG_FLDP);
6193 
6194                         if (status & 0xC0)
6195                                 break;
6196 
6197                         MDELAY(1);
6198                         timeout--;
6199                 }
6200 
6201                 return (1);
6202         }
6203 
6204         /* check for valid VPP */
6205         if (status & 0x08)
6206                 /* VPP failure */
6207                 return (1);
6208 
6209         /* check for successful flash */
6210         if (status & 0x30)
6211                 /* sequence error */
6212                 return (1);
6213 
6214         /* Otherwise, we were successful */
6215         /* clear status */
6216         writeb(0x50, ha->mem_ptr + IPS_REG_FLDP);
6217         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6218                 udelay(25);     /* 25 us */
6219 
6220         /* enable reads */
6221         writeb(0xFF, ha->mem_ptr + IPS_REG_FLDP);
6222         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6223                 udelay(25);     /* 25 us */
6224 
6225         return (0);
6226 }
6227 
6228 /****************************************************************************/
6229 /*                                                                          */
6230 /* Routine Name: ips_program_bios                                           */
6231 /*                                                                          */
6232 /* Routine Description:                                                     */
6233 /*   Program the BIOS on the adapter                                        */
6234 /*                                                                          */
6235 /****************************************************************************/
6236 static int
6237 ips_program_bios(ips_ha_t * ha, char *buffer, uint32_t buffersize,
6238                  uint32_t offset)
6239 {
6240         int i;
6241         int timeout;
6242         uint8_t status = 0;
6243 
6244         METHOD_TRACE("ips_program_bios", 1);
6245 
6246         status = 0;
6247 
6248         for (i = 0; i < buffersize; i++) {
6249                 /* write a byte */
6250                 outl(i + offset, ha->io_addr + IPS_REG_FLAP);
6251                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6252                         udelay(25);     /* 25 us */
6253 
6254                 outb(0x40, ha->io_addr + IPS_REG_FLDP);
6255                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6256                         udelay(25);     /* 25 us */
6257 
6258                 outb(buffer[i], ha->io_addr + IPS_REG_FLDP);
6259                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6260                         udelay(25);     /* 25 us */
6261 
6262                 /* wait up to one second */
6263                 timeout = 1000;
6264                 while (timeout > 0) {
6265                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64) {
6266                                 outl(0, ha->io_addr + IPS_REG_FLAP);
6267                                 udelay(25);     /* 25 us */
6268                         }
6269 
6270                         status = inb(ha->io_addr + IPS_REG_FLDP);
6271 
6272                         if (status & 0x80)
6273                                 break;
6274 
6275                         MDELAY(1);
6276                         timeout--;
6277                 }
6278 
6279                 if (timeout == 0) {
6280                         /* timeout error */
6281                         outl(0, ha->io_addr + IPS_REG_FLAP);
6282                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6283                                 udelay(25);     /* 25 us */
6284 
6285                         outb(0xFF, ha->io_addr + IPS_REG_FLDP);
6286                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6287                                 udelay(25);     /* 25 us */
6288 
6289                         return (1);
6290                 }
6291 
6292                 /* check the status */
6293                 if (status & 0x18) {
6294                         /* programming error */
6295                         outl(0, ha->io_addr + IPS_REG_FLAP);
6296                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6297                                 udelay(25);     /* 25 us */
6298 
6299                         outb(0xFF, ha->io_addr + IPS_REG_FLDP);
6300                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6301                                 udelay(25);     /* 25 us */
6302 
6303                         return (1);
6304                 }
6305         }                       /* end for */
6306 
6307         /* Enable reading */
6308         outl(0, ha->io_addr + IPS_REG_FLAP);
6309         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6310                 udelay(25);     /* 25 us */
6311 
6312         outb(0xFF, ha->io_addr + IPS_REG_FLDP);
6313         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6314                 udelay(25);     /* 25 us */
6315 
6316         return (0);
6317 }
6318 
6319 /****************************************************************************/
6320 /*                                                                          */
6321 /* Routine Name: ips_program_bios_memio                                     */
6322 /*                                                                          */
6323 /* Routine Description:                                                     */
6324 /*   Program the BIOS on the adapter                                        */
6325 /*                                                                          */
6326 /****************************************************************************/
6327 static int
6328 ips_program_bios_memio(ips_ha_t * ha, char *buffer, uint32_t buffersize,
6329                        uint32_t offset)
6330 {
6331         int i;
6332         int timeout;
6333         uint8_t status = 0;
6334 
6335         METHOD_TRACE("ips_program_bios_memio", 1);
6336 
6337         status = 0;
6338 
6339         for (i = 0; i < buffersize; i++) {
6340                 /* write a byte */
6341                 writel(i + offset, ha->mem_ptr + IPS_REG_FLAP);
6342                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6343                         udelay(25);     /* 25 us */
6344 
6345                 writeb(0x40, ha->mem_ptr + IPS_REG_FLDP);
6346                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6347                         udelay(25);     /* 25 us */
6348 
6349                 writeb(buffer[i], ha->mem_ptr + IPS_REG_FLDP);
6350                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6351                         udelay(25);     /* 25 us */
6352 
6353                 /* wait up to one second */
6354                 timeout = 1000;
6355                 while (timeout > 0) {
6356                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64) {
6357                                 writel(0, ha->mem_ptr + IPS_REG_FLAP);
6358                                 udelay(25);     /* 25 us */
6359                         }
6360 
6361                         status = readb(ha->mem_ptr + IPS_REG_FLDP);
6362 
6363                         if (status & 0x80)
6364                                 break;
6365 
6366                         MDELAY(1);
6367                         timeout--;
6368                 }
6369 
6370                 if (timeout == 0) {
6371                         /* timeout error */
6372                         writel(0, ha->mem_ptr + IPS_REG_FLAP);
6373                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6374                                 udelay(25);     /* 25 us */
6375 
6376                         writeb(0xFF, ha->mem_ptr + IPS_REG_FLDP);
6377                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6378                                 udelay(25);     /* 25 us */
6379 
6380                         return (1);
6381                 }
6382 
6383                 /* check the status */
6384                 if (status & 0x18) {
6385                         /* programming error */
6386                         writel(0, ha->mem_ptr + IPS_REG_FLAP);
6387                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6388                                 udelay(25);     /* 25 us */
6389 
6390                         writeb(0xFF, ha->mem_ptr + IPS_REG_FLDP);
6391                         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6392                                 udelay(25);     /* 25 us */
6393 
6394                         return (1);
6395                 }
6396         }                       /* end for */
6397 
6398         /* Enable reading */
6399         writel(0, ha->mem_ptr + IPS_REG_FLAP);
6400         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6401                 udelay(25);     /* 25 us */
6402 
6403         writeb(0xFF, ha->mem_ptr + IPS_REG_FLDP);
6404         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6405                 udelay(25);     /* 25 us */
6406 
6407         return (0);
6408 }
6409 
6410 /****************************************************************************/
6411 /*                                                                          */
6412 /* Routine Name: ips_verify_bios                                            */
6413 /*                                                                          */
6414 /* Routine Description:                                                     */
6415 /*   Verify the BIOS on the adapter                                         */
6416 /*                                                                          */
6417 /****************************************************************************/
6418 static int
6419 ips_verify_bios(ips_ha_t * ha, char *buffer, uint32_t buffersize,
6420                 uint32_t offset)
6421 {
6422         uint8_t checksum;
6423         int i;
6424 
6425         METHOD_TRACE("ips_verify_bios", 1);
6426 
6427         /* test 1st byte */
6428         outl(0, ha->io_addr + IPS_REG_FLAP);
6429         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6430                 udelay(25);     /* 25 us */
6431 
6432         if (inb(ha->io_addr + IPS_REG_FLDP) != 0x55)
6433                 return (1);
6434 
6435         outl(1, ha->io_addr + IPS_REG_FLAP);
6436         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6437                 udelay(25);     /* 25 us */
6438         if (inb(ha->io_addr + IPS_REG_FLDP) != 0xAA)
6439                 return (1);
6440 
6441         checksum = 0xff;
6442         for (i = 2; i < buffersize; i++) {
6443 
6444                 outl(i + offset, ha->io_addr + IPS_REG_FLAP);
6445                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6446                         udelay(25);     /* 25 us */
6447 
6448                 checksum = (uint8_t) checksum + inb(ha->io_addr + IPS_REG_FLDP);
6449         }
6450 
6451         if (checksum != 0)
6452                 /* failure */
6453                 return (1);
6454         else
6455                 /* success */
6456                 return (0);
6457 }
6458 
6459 /****************************************************************************/
6460 /*                                                                          */
6461 /* Routine Name: ips_verify_bios_memio                                      */
6462 /*                                                                          */
6463 /* Routine Description:                                                     */
6464 /*   Verify the BIOS on the adapter                                         */
6465 /*                                                                          */
6466 /****************************************************************************/
6467 static int
6468 ips_verify_bios_memio(ips_ha_t * ha, char *buffer, uint32_t buffersize,
6469                       uint32_t offset)
6470 {
6471         uint8_t checksum;
6472         int i;
6473 
6474         METHOD_TRACE("ips_verify_bios_memio", 1);
6475 
6476         /* test 1st byte */
6477         writel(0, ha->mem_ptr + IPS_REG_FLAP);
6478         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6479                 udelay(25);     /* 25 us */
6480 
6481         if (readb(ha->mem_ptr + IPS_REG_FLDP) != 0x55)
6482                 return (1);
6483 
6484         writel(1, ha->mem_ptr + IPS_REG_FLAP);
6485         if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6486                 udelay(25);     /* 25 us */
6487         if (readb(ha->mem_ptr + IPS_REG_FLDP) != 0xAA)
6488                 return (1);
6489 
6490         checksum = 0xff;
6491         for (i = 2; i < buffersize; i++) {
6492 
6493                 writel(i + offset, ha->mem_ptr + IPS_REG_FLAP);
6494                 if (ha->pcidev->revision == IPS_REVID_TROMBONE64)
6495                         udelay(25);     /* 25 us */
6496 
6497                 checksum =
6498                     (uint8_t) checksum + readb(ha->mem_ptr + IPS_REG_FLDP);
6499         }
6500 
6501         if (checksum != 0)
6502                 /* failure */
6503                 return (1);
6504         else
6505                 /* success */
6506                 return (0);
6507 }
6508 
6509 /****************************************************************************/
6510 /*                                                                          */
6511 /* Routine Name: ips_abort_init                                             */
6512 /*                                                                          */
6513 /* Routine Description:                                                     */
6514 /*   cleanup routine for a failed adapter initialization                    */
6515 /****************************************************************************/
6516 static int
6517 ips_abort_init(ips_ha_t * ha, int index)
6518 {
6519         ha->active = 0;
6520         ips_free(ha);
6521         ips_ha[index] = NULL;
6522         ips_sh[index] = NULL;
6523         return -1;
6524 }
6525 
6526 /****************************************************************************/
6527 /*                                                                          */
6528 /* Routine Name: ips_shift_controllers                                      */
6529 /*                                                                          */
6530 /* Routine Description:                                                     */
6531 /*   helper function for ordering adapters                                  */
6532 /****************************************************************************/
6533 static void
6534 ips_shift_controllers(int lowindex, int highindex)
6535 {
6536         ips_ha_t *ha_sav = ips_ha[highindex];
6537         struct Scsi_Host *sh_sav = ips_sh[highindex];
6538         int i;
6539 
6540         for (i = highindex; i > lowindex; i--) {
6541                 ips_ha[i] = ips_ha[i - 1];
6542                 ips_sh[i] = ips_sh[i - 1];
6543                 ips_ha[i]->host_num = i;
6544         }
6545         ha_sav->host_num = lowindex;
6546         ips_ha[lowindex] = ha_sav;
6547         ips_sh[lowindex] = sh_sav;
6548 }
6549 
6550 /****************************************************************************/
6551 /*                                                                          */
6552 /* Routine Name: ips_order_controllers                                      */
6553 /*                                                                          */
6554 /* Routine Description:                                                     */
6555 /*   place controllers is the "proper" boot order                           */
6556 /****************************************************************************/
6557 static void
6558 ips_order_controllers(void)
6559 {
6560         int i, j, tmp, position = 0;
6561         IPS_NVRAM_P5 *nvram;
6562         if (!ips_ha[0])
6563                 return;
6564         nvram = ips_ha[0]->nvram;
6565 
6566         if (nvram->adapter_order[0]) {
6567                 for (i = 1; i <= nvram->adapter_order[0]; i++) {
6568                         for (j = position; j < ips_num_controllers; j++) {
6569                                 switch (ips_ha[j]->ad_type) {
6570                                 case IPS_ADTYPE_SERVERAID6M:
6571                                 case IPS_ADTYPE_SERVERAID7M:
6572                                         if (nvram->adapter_order[i] == 'M') {
6573                                                 ips_shift_controllers(position,
6574                                                                       j);
6575                                                 position++;
6576                                         }
6577                                         break;
6578                                 case IPS_ADTYPE_SERVERAID4L:
6579                                 case IPS_ADTYPE_SERVERAID4M:
6580                                 case IPS_ADTYPE_SERVERAID4MX:
6581                                 case IPS_ADTYPE_SERVERAID4LX:
6582                                         if (nvram->adapter_order[i] == 'N') {
6583                                                 ips_shift_controllers(position,
6584                                                                       j);
6585                                                 position++;
6586                                         }
6587                                         break;
6588                                 case IPS_ADTYPE_SERVERAID6I:
6589                                 case IPS_ADTYPE_SERVERAID5I2:
6590                                 case IPS_ADTYPE_SERVERAID5I1:
6591                                 case IPS_ADTYPE_SERVERAID7k:
6592                                         if (nvram->adapter_order[i] == 'S') {
6593                                                 ips_shift_controllers(position,
6594                                                                       j);
6595                                                 position++;
6596                                         }
6597                                         break;
6598                                 case IPS_ADTYPE_SERVERAID:
6599                                 case IPS_ADTYPE_SERVERAID2:
6600                                 case IPS_ADTYPE_NAVAJO:
6601                                 case IPS_ADTYPE_KIOWA:
6602                                 case IPS_ADTYPE_SERVERAID3L:
6603                                 case IPS_ADTYPE_SERVERAID3:
6604                                 case IPS_ADTYPE_SERVERAID4H:
6605                                         if (nvram->adapter_order[i] == 'A') {
6606                                                 ips_shift_controllers(position,
6607                                                                       j);
6608                                                 position++;
6609                                         }
6610                                         break;
6611                                 default:
6612                                         break;
6613                                 }
6614                         }
6615                 }
6616                 /* if adapter_order[0], then ordering is complete */
6617                 return;
6618         }
6619         /* old bios, use older ordering */
6620         tmp = 0;
6621         for (i = position; i < ips_num_controllers; i++) {
6622                 if (ips_ha[i]->ad_type == IPS_ADTYPE_SERVERAID5I2 ||
6623                     ips_ha[i]->ad_type == IPS_ADTYPE_SERVERAID5I1) {
6624                         ips_shift_controllers(position, i);
6625                         position++;
6626                         tmp = 1;
6627                 }
6628         }
6629         /* if there were no 5I cards, then don't do any extra ordering */
6630         if (!tmp)
6631                 return;
6632         for (i = position; i < ips_num_controllers; i++) {
6633                 if (ips_ha[i]->ad_type == IPS_ADTYPE_SERVERAID4L ||
6634                     ips_ha[i]->ad_type == IPS_ADTYPE_SERVERAID4M ||
6635                     ips_ha[i]->ad_type == IPS_ADTYPE_SERVERAID4LX ||
6636                     ips_ha[i]->ad_type == IPS_ADTYPE_SERVERAID4MX) {
6637                         ips_shift_controllers(position, i);
6638                         position++;
6639                 }
6640         }
6641 
6642         return;
6643 }
6644 
6645 /****************************************************************************/
6646 /*                                                                          */
6647 /* Routine Name: ips_register_scsi                                          */
6648 /*                                                                          */
6649 /* Routine Description:                                                     */
6650 /*   perform any registration and setup with the scsi layer                 */
6651 /****************************************************************************/
6652 static int
6653 ips_register_scsi(int index)
6654 {
6655         struct Scsi_Host *sh;
6656         ips_ha_t *ha, *oldha = ips_ha[index];
6657         sh = scsi_host_alloc(&ips_driver_template, sizeof (ips_ha_t));
6658         if (!sh) {
6659                 IPS_PRINTK(KERN_WARNING, oldha->pcidev,
6660                            "Unable to register controller with SCSI subsystem\n");
6661                 return -1;
6662         }
6663         ha = IPS_HA(sh);
6664         memcpy(ha, oldha, sizeof (ips_ha_t));
6665         free_irq(oldha->pcidev->irq, oldha);
6666         /* Install the interrupt handler with the new ha */
6667         if (request_irq(ha->pcidev->irq, do_ipsintr, IRQF_SHARED, ips_name, ha)) {
6668                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
6669                            "Unable to install interrupt handler\n");
6670                 goto err_out_sh;
6671         }
6672 
6673         kfree(oldha);
6674 
6675         /* Store away needed values for later use */
6676         sh->unique_id = (ha->io_addr) ? ha->io_addr : ha->mem_addr;
6677         sh->sg_tablesize = sh->hostt->sg_tablesize;
6678         sh->can_queue = sh->hostt->can_queue;
6679         sh->cmd_per_lun = sh->hostt->cmd_per_lun;
6680         sh->max_sectors = 128;
6681 
6682         sh->max_id = ha->ntargets;
6683         sh->max_lun = ha->nlun;
6684         sh->max_channel = ha->nbus - 1;
6685         sh->can_queue = ha->max_cmds - 1;
6686 
6687         if (scsi_add_host(sh, &ha->pcidev->dev))
6688                 goto err_out;
6689 
6690         ips_sh[index] = sh;
6691         ips_ha[index] = ha;
6692 
6693         scsi_scan_host(sh);
6694 
6695         return 0;
6696 
6697 err_out:
6698         free_irq(ha->pcidev->irq, ha);
6699 err_out_sh:
6700         scsi_host_put(sh);
6701         return -1;
6702 }
6703 
6704 /*---------------------------------------------------------------------------*/
6705 /*   Routine Name: ips_remove_device                                         */
6706 /*                                                                           */
6707 /*   Routine Description:                                                    */
6708 /*     Remove one Adapter ( Hot Plugging )                                   */
6709 /*---------------------------------------------------------------------------*/
6710 static void
6711 ips_remove_device(struct pci_dev *pci_dev)
6712 {
6713         struct Scsi_Host *sh = pci_get_drvdata(pci_dev);
6714 
6715         pci_set_drvdata(pci_dev, NULL);
6716 
6717         ips_release(sh);
6718 
6719         pci_release_regions(pci_dev);
6720         pci_disable_device(pci_dev);
6721 }
6722 
6723 /****************************************************************************/
6724 /*                                                                          */
6725 /* Routine Name: ips_module_init                                            */
6726 /*                                                                          */
6727 /* Routine Description:                                                     */
6728 /*   function called on module load                                         */
6729 /****************************************************************************/
6730 static int __init
6731 ips_module_init(void)
6732 {
6733 #if !defined(__i386__) && !defined(__ia64__) && !defined(__x86_64__)
6734         printk(KERN_ERR "ips: This driver has only been tested on the x86/ia64/x86_64 platforms\n");
6735         add_taint(TAINT_CPU_OUT_OF_SPEC, LOCKDEP_STILL_OK);
6736 #endif
6737 
6738         if (pci_register_driver(&ips_pci_driver) < 0)
6739                 return -ENODEV;
6740         ips_driver_template.module = THIS_MODULE;
6741         ips_order_controllers();
6742         if (!ips_detect(&ips_driver_template)) {
6743                 pci_unregister_driver(&ips_pci_driver);
6744                 return -ENODEV;
6745         }
6746         register_reboot_notifier(&ips_notifier);
6747         return 0;
6748 }
6749 
6750 /****************************************************************************/
6751 /*                                                                          */
6752 /* Routine Name: ips_module_exit                                            */
6753 /*                                                                          */
6754 /* Routine Description:                                                     */
6755 /*   function called on module unload                                       */
6756 /****************************************************************************/
6757 static void __exit
6758 ips_module_exit(void)
6759 {
6760         pci_unregister_driver(&ips_pci_driver);
6761         unregister_reboot_notifier(&ips_notifier);
6762 }
6763 
6764 module_init(ips_module_init);
6765 module_exit(ips_module_exit);
6766 
6767 /*---------------------------------------------------------------------------*/
6768 /*   Routine Name: ips_insert_device                                         */
6769 /*                                                                           */
6770 /*   Routine Description:                                                    */
6771 /*     Add One Adapter ( Hot Plug )                                          */
6772 /*                                                                           */
6773 /*   Return Value:                                                           */
6774 /*     0 if Successful, else non-zero                                        */
6775 /*---------------------------------------------------------------------------*/
6776 static int
6777 ips_insert_device(struct pci_dev *pci_dev, const struct pci_device_id *ent)
6778 {
6779         int index = -1;
6780         int rc;
6781 
6782         METHOD_TRACE("ips_insert_device", 1);
6783         rc = pci_enable_device(pci_dev);
6784         if (rc)
6785                 return rc;
6786 
6787         rc = pci_request_regions(pci_dev, "ips");
6788         if (rc)
6789                 goto err_out;
6790 
6791         rc = ips_init_phase1(pci_dev, &index);
6792         if (rc == SUCCESS)
6793                 rc = ips_init_phase2(index);
6794 
6795         if (ips_hotplug)
6796                 if (ips_register_scsi(index)) {
6797                         ips_free(ips_ha[index]);
6798                         rc = -1;
6799                 }
6800 
6801         if (rc == SUCCESS)
6802                 ips_num_controllers++;
6803 
6804         ips_next_controller = ips_num_controllers;
6805 
6806         if (rc < 0) {
6807                 rc = -ENODEV;
6808                 goto err_out_regions;
6809         }
6810 
6811         pci_set_drvdata(pci_dev, ips_sh[index]);
6812         return 0;
6813 
6814 err_out_regions:
6815         pci_release_regions(pci_dev);
6816 err_out:
6817         pci_disable_device(pci_dev);
6818         return rc;
6819 }
6820 
6821 /*---------------------------------------------------------------------------*/
6822 /*   Routine Name: ips_init_phase1                                           */
6823 /*                                                                           */
6824 /*   Routine Description:                                                    */
6825 /*     Adapter Initialization                                                */
6826 /*                                                                           */
6827 /*   Return Value:                                                           */
6828 /*     0 if Successful, else non-zero                                        */
6829 /*---------------------------------------------------------------------------*/
6830 static int
6831 ips_init_phase1(struct pci_dev *pci_dev, int *indexPtr)
6832 {
6833         ips_ha_t *ha;
6834         uint32_t io_addr;
6835         uint32_t mem_addr;
6836         uint32_t io_len;
6837         uint32_t mem_len;
6838         uint8_t bus;
6839         uint8_t func;
6840         int j;
6841         int index;
6842         dma_addr_t dma_address;
6843         char __iomem *ioremap_ptr;
6844         char __iomem *mem_ptr;
6845         uint32_t IsDead;
6846 
6847         METHOD_TRACE("ips_init_phase1", 1);
6848         index = IPS_MAX_ADAPTERS;
6849         for (j = 0; j < IPS_MAX_ADAPTERS; j++) {
6850                 if (ips_ha[j] == NULL) {
6851                         index = j;
6852                         break;
6853                 }
6854         }
6855 
6856         if (index >= IPS_MAX_ADAPTERS)
6857                 return -1;
6858 
6859         /* stuff that we get in dev */
6860         bus = pci_dev->bus->number;
6861         func = pci_dev->devfn;
6862 
6863         /* Init MEM/IO addresses to 0 */
6864         mem_addr = 0;
6865         io_addr = 0;
6866         mem_len = 0;
6867         io_len = 0;
6868 
6869         for (j = 0; j < 2; j++) {
6870                 if (!pci_resource_start(pci_dev, j))
6871                         break;
6872 
6873                 if (pci_resource_flags(pci_dev, j) & IORESOURCE_IO) {
6874                         io_addr = pci_resource_start(pci_dev, j);
6875                         io_len = pci_resource_len(pci_dev, j);
6876                 } else {
6877                         mem_addr = pci_resource_start(pci_dev, j);
6878                         mem_len = pci_resource_len(pci_dev, j);
6879                 }
6880         }
6881 
6882         /* setup memory mapped area (if applicable) */
6883         if (mem_addr) {
6884                 uint32_t base;
6885                 uint32_t offs;
6886 
6887                 base = mem_addr & PAGE_MASK;
6888                 offs = mem_addr - base;
6889                 ioremap_ptr = ioremap(base, PAGE_SIZE);
6890                 if (!ioremap_ptr)
6891                         return -1;
6892                 mem_ptr = ioremap_ptr + offs;
6893         } else {
6894                 ioremap_ptr = NULL;
6895                 mem_ptr = NULL;
6896         }
6897 
6898         /* found a controller */
6899         ha = kzalloc(sizeof (ips_ha_t), GFP_KERNEL);
6900         if (ha == NULL) {
6901                 IPS_PRINTK(KERN_WARNING, pci_dev,
6902                            "Unable to allocate temporary ha struct\n");
6903                 return -1;
6904         }
6905 
6906         ips_sh[index] = NULL;
6907         ips_ha[index] = ha;
6908         ha->active = 1;
6909 
6910         /* Store info in HA structure */
6911         ha->io_addr = io_addr;
6912         ha->io_len = io_len;
6913         ha->mem_addr = mem_addr;
6914         ha->mem_len = mem_len;
6915         ha->mem_ptr = mem_ptr;
6916         ha->ioremap_ptr = ioremap_ptr;
6917         ha->host_num = (uint32_t) index;
6918         ha->slot_num = PCI_SLOT(pci_dev->devfn);
6919         ha->pcidev = pci_dev;
6920 
6921         /*
6922          * Set the pci_dev's dma_mask.  Not all adapters support 64bit
6923          * addressing so don't enable it if the adapter can't support
6924          * it!  Also, don't use 64bit addressing if dma addresses
6925          * are guaranteed to be < 4G.
6926          */
6927         if (sizeof(dma_addr_t) > 4 && IPS_HAS_ENH_SGLIST(ha) &&
6928             !dma_set_mask(&ha->pcidev->dev, DMA_BIT_MASK(64))) {
6929                 (ha)->flags |= IPS_HA_ENH_SG;
6930         } else {
6931                 if (dma_set_mask(&ha->pcidev->dev, DMA_BIT_MASK(32)) != 0) {
6932                         printk(KERN_WARNING "Unable to set DMA Mask\n");
6933                         return ips_abort_init(ha, index);
6934                 }
6935         }
6936         if(ips_cd_boot && !ips_FlashData){
6937                 ips_FlashData = dma_alloc_coherent(&pci_dev->dev,
6938                                 PAGE_SIZE << 7, &ips_flashbusaddr, GFP_KERNEL);
6939         }
6940 
6941         ha->enq = dma_alloc_coherent(&pci_dev->dev, sizeof (IPS_ENQ),
6942                         &ha->enq_busaddr, GFP_KERNEL);
6943         if (!ha->enq) {
6944                 IPS_PRINTK(KERN_WARNING, pci_dev,
6945                            "Unable to allocate host inquiry structure\n");
6946                 return ips_abort_init(ha, index);
6947         }
6948 
6949         ha->adapt = dma_alloc_coherent(&pci_dev->dev,
6950                         sizeof (IPS_ADAPTER) + sizeof (IPS_IO_CMD),
6951                         &dma_address, GFP_KERNEL);
6952         if (!ha->adapt) {
6953                 IPS_PRINTK(KERN_WARNING, pci_dev,
6954                            "Unable to allocate host adapt & dummy structures\n");
6955                 return ips_abort_init(ha, index);
6956         }
6957         ha->adapt->hw_status_start = dma_address;
6958         ha->dummy = (void *) (ha->adapt + 1);
6959 
6960 
6961 
6962         ha->logical_drive_info = dma_alloc_coherent(&pci_dev->dev,
6963                         sizeof (IPS_LD_INFO), &dma_address, GFP_KERNEL);
6964         if (!ha->logical_drive_info) {
6965                 IPS_PRINTK(KERN_WARNING, pci_dev,
6966                            "Unable to allocate logical drive info structure\n");
6967                 return ips_abort_init(ha, index);
6968         }
6969         ha->logical_drive_info_dma_addr = dma_address;
6970 
6971 
6972         ha->conf = kmalloc(sizeof (IPS_CONF), GFP_KERNEL);
6973 
6974         if (!ha->conf) {
6975                 IPS_PRINTK(KERN_WARNING, pci_dev,
6976                            "Unable to allocate host conf structure\n");
6977                 return ips_abort_init(ha, index);
6978         }
6979 
6980         ha->nvram = kmalloc(sizeof (IPS_NVRAM_P5), GFP_KERNEL);
6981 
6982         if (!ha->nvram) {
6983                 IPS_PRINTK(KERN_WARNING, pci_dev,
6984                            "Unable to allocate host NVRAM structure\n");
6985                 return ips_abort_init(ha, index);
6986         }
6987 
6988         ha->subsys = kmalloc(sizeof (IPS_SUBSYS), GFP_KERNEL);
6989 
6990         if (!ha->subsys) {
6991                 IPS_PRINTK(KERN_WARNING, pci_dev,
6992                            "Unable to allocate host subsystem structure\n");
6993                 return ips_abort_init(ha, index);
6994         }
6995 
6996         /* the ioctl buffer is now used during adapter initialization, so its
6997          * successful allocation is now required */
6998         if (ips_ioctlsize < PAGE_SIZE)
6999                 ips_ioctlsize = PAGE_SIZE;
7000 
7001         ha->ioctl_data = dma_alloc_coherent(&pci_dev->dev, ips_ioctlsize,
7002                         &ha->ioctl_busaddr, GFP_KERNEL);
7003         ha->ioctl_len = ips_ioctlsize;
7004         if (!ha->ioctl_data) {
7005                 IPS_PRINTK(KERN_WARNING, pci_dev,
7006                            "Unable to allocate IOCTL data\n");
7007                 return ips_abort_init(ha, index);
7008         }
7009 
7010         /*
7011          * Setup Functions
7012          */
7013         ips_setup_funclist(ha);
7014 
7015         if ((IPS_IS_MORPHEUS(ha)) || (IPS_IS_MARCO(ha))) {
7016                 /* If Morpheus appears dead, reset it */
7017                 IsDead = readl(ha->mem_ptr + IPS_REG_I960_MSG1);
7018                 if (IsDead == 0xDEADBEEF) {
7019                         ips_reset_morpheus(ha);
7020                 }
7021         }
7022 
7023         /*
7024          * Initialize the card if it isn't already
7025          */
7026 
7027         if (!(*ha->func.isinit) (ha)) {
7028                 if (!(*ha->func.init) (ha)) {
7029                         /*
7030                          * Initialization failed
7031                          */
7032                         IPS_PRINTK(KERN_WARNING, pci_dev,
7033                                    "Unable to initialize controller\n");
7034                         return ips_abort_init(ha, index);
7035                 }
7036         }
7037 
7038         *indexPtr = index;
7039         return SUCCESS;
7040 }
7041 
7042 /*---------------------------------------------------------------------------*/
7043 /*   Routine Name: ips_init_phase2                                           */
7044 /*                                                                           */
7045 /*   Routine Description:                                                    */
7046 /*     Adapter Initialization Phase 2                                        */
7047 /*                                                                           */
7048 /*   Return Value:                                                           */
7049 /*     0 if Successful, else non-zero                                        */
7050 /*---------------------------------------------------------------------------*/
7051 static int
7052 ips_init_phase2(int index)
7053 {
7054         ips_ha_t *ha;
7055 
7056         ha = ips_ha[index];
7057 
7058         METHOD_TRACE("ips_init_phase2", 1);
7059         if (!ha->active) {
7060                 ips_ha[index] = NULL;
7061                 return -1;
7062         }
7063 
7064         /* Install the interrupt handler */
7065         if (request_irq(ha->pcidev->irq, do_ipsintr, IRQF_SHARED, ips_name, ha)) {
7066                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
7067                            "Unable to install interrupt handler\n");
7068                 return ips_abort_init(ha, index);
7069         }
7070 
7071         /*
7072          * Allocate a temporary SCB for initialization
7073          */
7074         ha->max_cmds = 1;
7075         if (!ips_allocatescbs(ha)) {
7076                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
7077                            "Unable to allocate a CCB\n");
7078                 free_irq(ha->pcidev->irq, ha);
7079                 return ips_abort_init(ha, index);
7080         }
7081 
7082         if (!ips_hainit(ha)) {
7083                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
7084                            "Unable to initialize controller\n");
7085                 free_irq(ha->pcidev->irq, ha);
7086                 return ips_abort_init(ha, index);
7087         }
7088         /* Free the temporary SCB */
7089         ips_deallocatescbs(ha, 1);
7090 
7091         /* allocate CCBs */
7092         if (!ips_allocatescbs(ha)) {
7093                 IPS_PRINTK(KERN_WARNING, ha->pcidev,
7094                            "Unable to allocate CCBs\n");
7095                 free_irq(ha->pcidev->irq, ha);
7096                 return ips_abort_init(ha, index);
7097         }
7098 
7099         return SUCCESS;
7100 }
7101 
7102 MODULE_LICENSE("GPL");
7103 MODULE_DESCRIPTION("IBM ServeRAID Adapter Driver " IPS_VER_STRING);
7104 MODULE_VERSION(IPS_VER_STRING);
7105 
7106 
7107 /*
7108  * Overrides for Emacs so that we almost follow Linus's tabbing style.
7109  * Emacs will notice this stuff at the end of the file and automatically
7110  * adjust the settings for this buffer only.  This must remain at the end
7111  * of the file.
7112  * ---------------------------------------------------------------------------
7113  * Local variables:
7114  * c-indent-level: 2
7115  * c-brace-imaginary-offset: 0
7116  * c-brace-offset: -2
7117  * c-argdecl-indent: 2
7118  * c-label-offset: -2
7119  * c-continued-statement-offset: 2
7120  * c-continued-brace-offset: 0
7121  * indent-tabs-mode: nil
7122  * tab-width: 8
7123  * End:
7124  */

/* [<][>][^][v][top][bottom][index][help] */