annotate usr/src/uts/common/io/sata/impl/sata.c @ 1940:c302ad4d1aa7

6404894 Informational exceptions log parameter should be 4 bytes 6412375 Need to add support for tagged queuing in the marvell88sx driver 6412380 sata framework doesn't always utilize correct queuing mode 6412384 queue depth is incorrect for SATA controllers 6412386 Some SATA disks do no use the 19th entry in the self test log 6412390 SATA LOG SENSE results can be incorrect 6412398 allow scatter/gather list length for marvell88sx to be tunable 6420987 sata_hba_ioctl() may hold mutex upon exit
author ls24207
date Fri, 05 May 2006 13:30:06 -0700
parents 1005b1d56b1c
children 01f4efa62f05
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2 * CDDL HEADER START
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4 * The contents of this file are subject to the terms of the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5 * Common Development and Distribution License (the "License").
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6 * You may not use this file except in compliance with the License.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9 * or http://www.opensolaris.org/os/licensing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10 * See the License for the specific language governing permissions
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
11 * and limitations under the License.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
12 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
13 * When distributing Covered Code, include this CDDL HEADER in each
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
15 * If applicable, add the following below this CDDL HEADER, with the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
16 * fields enclosed by brackets "[]" replaced with your own identifying
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
17 * information: Portions Copyright [yyyy] [name of copyright owner]
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
18 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
19 * CDDL HEADER END
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
20 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
21
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
22 /*
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
23 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
24 * Use is subject to license terms.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
25 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
26
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
27 #pragma ident "%Z%%M% %I% %E% SMI"
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
28
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
29 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
30 * SATA Framework
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
31 * Generic SATA Host Adapter Implementation
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
32 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
33 * NOTE: THIS VERSION DOES NOT SUPPORT ATAPI DEVICES,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
34 * although there is some code related to these devices.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
35 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
36 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
37 #include <sys/conf.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
38 #include <sys/file.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
39 #include <sys/ddi.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
40 #include <sys/sunddi.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
41 #include <sys/modctl.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
42 #include <sys/cmn_err.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
43 #include <sys/errno.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
44 #include <sys/thread.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
45 #include <sys/kstat.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
46 #include <sys/note.h>
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
47 #include <sys/sysevent.h>
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
48 #include <sys/sysevent/eventdefs.h>
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
49 #include <sys/sysevent/dr.h>
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
50 #include <sys/taskq.h>
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
51
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
52 #include <sys/sata/impl/sata.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
53 #include <sys/sata/sata_hba.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
54 #include <sys/sata/sata_defs.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
55 #include <sys/sata/sata_cfgadm.h>
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
56
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
57
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
58 /* Debug flags - defined in sata.h */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
59 int sata_debug_flags = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
60 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
61 * Flags enabling selected SATA HBA framework functionality
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
62 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
63 #define SATA_ENABLE_QUEUING 1
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
64 #define SATA_ENABLE_NCQ 2
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
65 #define SATA_ENABLE_PROCESS_EVENTS 4
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
66 int sata_func_enable = SATA_ENABLE_PROCESS_EVENTS | SATA_ENABLE_QUEUING;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
67
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
68 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
69 #define SATA_LOG_D(args) sata_log args
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
70 #else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
71 #define SATA_LOG_D(arg)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
72 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
73
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
74
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
75 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
76 * SATA cb_ops functions
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
77 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
78 static int sata_hba_open(dev_t *, int, int, cred_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
79 static int sata_hba_close(dev_t, int, int, cred_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
80 static int sata_hba_ioctl(dev_t, int, intptr_t, int, cred_t *, int *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
81
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
82 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
83 * SCSA required entry points
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
84 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
85 static int sata_scsi_tgt_init(dev_info_t *, dev_info_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
86 scsi_hba_tran_t *, struct scsi_device *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
87 static int sata_scsi_tgt_probe(struct scsi_device *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
88 int (*callback)(void));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
89 static void sata_scsi_tgt_free(dev_info_t *, dev_info_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
90 scsi_hba_tran_t *, struct scsi_device *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
91 static int sata_scsi_start(struct scsi_address *, struct scsi_pkt *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
92 static int sata_scsi_abort(struct scsi_address *, struct scsi_pkt *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
93 static int sata_scsi_reset(struct scsi_address *, int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
94 static int sata_scsi_getcap(struct scsi_address *, char *, int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
95 static int sata_scsi_setcap(struct scsi_address *, char *, int, int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
96 static struct scsi_pkt *sata_scsi_init_pkt(struct scsi_address *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
97 struct scsi_pkt *, struct buf *, int, int, int, int, int (*)(caddr_t),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
98 caddr_t);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
99 static void sata_scsi_destroy_pkt(struct scsi_address *, struct scsi_pkt *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
100 static void sata_scsi_dmafree(struct scsi_address *, struct scsi_pkt *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
101 static void sata_scsi_sync_pkt(struct scsi_address *, struct scsi_pkt *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
102
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
103
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
104 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
105 * Local functions
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
106 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
107 static void sata_remove_hba_instance(dev_info_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
108 static int sata_validate_sata_hba_tran(dev_info_t *, sata_hba_tran_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
109 static void sata_probe_ports(sata_hba_inst_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
110 static int sata_reprobe_port(sata_hba_inst_t *, sata_device_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
111 static void sata_make_device_nodes(dev_info_t *, sata_hba_inst_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
112 static dev_info_t *sata_create_target_node(dev_info_t *, sata_hba_inst_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
113 sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
114 static int sata_validate_scsi_address(sata_hba_inst_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
115 struct scsi_address *, sata_device_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
116 static int sata_validate_sata_address(sata_hba_inst_t *, int, int, int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
117 static sata_pkt_t *sata_pkt_alloc(sata_pkt_txlate_t *, int (*)(caddr_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
118 static void sata_pkt_free(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
119 static int sata_dma_buf_setup(sata_pkt_txlate_t *, int, int (*)(caddr_t),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
120 caddr_t, ddi_dma_attr_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
121 static int sata_probe_device(sata_hba_inst_t *, sata_device_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
122 static sata_drive_info_t *sata_get_device_info(sata_hba_inst_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
123 sata_device_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
124 static int sata_identify_device(sata_hba_inst_t *, sata_drive_info_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
125 static struct buf *sata_alloc_local_buffer(sata_pkt_txlate_t *, int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
126 static void sata_free_local_buffer(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
127 static uint64_t sata_check_capacity(sata_drive_info_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
128 void sata_adjust_dma_attr(sata_drive_info_t *, ddi_dma_attr_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
129 ddi_dma_attr_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
130 static int sata_fetch_device_identify_data(sata_hba_inst_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
131 sata_drive_info_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
132 static void sata_update_port_info(sata_hba_inst_t *, sata_device_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
133 static void sata_update_port_scr(sata_port_scr_t *, sata_device_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
134 static int sata_set_udma_mode(sata_hba_inst_t *, sata_drive_info_t *);
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
135 static int sata_set_cache_mode(sata_hba_inst_t *, sata_drive_info_t *, int);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
136 static int sata_set_drive_features(sata_hba_inst_t *,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
137 sata_drive_info_t *, int flag);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
138 static int sata_init_write_cache_mode(sata_hba_inst_t *,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
139 sata_drive_info_t *sdinfo);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
140 static int sata_initialize_device(sata_hba_inst_t *, sata_drive_info_t *);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
141
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
142 /* Event processing functions */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
143 static void sata_event_daemon(void *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
144 static void sata_event_thread_control(int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
145 static void sata_process_controller_events(sata_hba_inst_t *sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
146 static void sata_process_device_reset(sata_hba_inst_t *, sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
147 static void sata_process_port_failed_event(sata_hba_inst_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
148 sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
149 static void sata_process_port_link_events(sata_hba_inst_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
150 sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
151 static void sata_process_device_detached(sata_hba_inst_t *, sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
152 static void sata_process_device_attached(sata_hba_inst_t *, sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
153 static void sata_process_port_pwr_change(sata_hba_inst_t *, sata_address_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
154 static void sata_process_cntrl_pwr_level_change(sata_hba_inst_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
155
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
156 /* Local functions for ioctl */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
157 static int32_t sata_get_port_num(sata_hba_inst_t *, struct devctl_iocdata *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
158 static void sata_cfgadm_state(sata_hba_inst_t *, int32_t,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
159 devctl_ap_state_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
160 static dev_info_t *sata_get_target_dip(dev_info_t *, int32_t);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
161 static dev_info_t *sata_devt_to_devinfo(dev_t);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
162
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
163 /* Local translation functions */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
164 static int sata_txlt_inquiry(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
165 static int sata_txlt_test_unit_ready(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
166 static int sata_txlt_start_stop_unit(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
167 static int sata_txlt_read_capacity(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
168 static int sata_txlt_request_sense(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
169 static int sata_txlt_read(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
170 static int sata_txlt_write(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
171 static int sata_txlt_atapi(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
172 static int sata_txlt_log_sense(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
173 static int sata_txlt_log_select(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
174 static int sata_txlt_mode_sense(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
175 static int sata_txlt_mode_select(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
176 static int sata_txlt_synchronize_cache(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
177 static int sata_txlt_nodata_cmd_immediate(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
178
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
179 static int sata_hba_start(sata_pkt_txlate_t *, int *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
180 static int sata_txlt_invalid_command(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
181 static int sata_txlt_lba_out_of_range(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
182 static void sata_txlt_rw_completion(sata_pkt_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
183 static void sata_txlt_atapi_completion(sata_pkt_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
184 static void sata_txlt_nodata_cmd_completion(sata_pkt_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
185
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
186 static struct scsi_extended_sense *sata_immediate_error_response(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
187 sata_pkt_txlate_t *, int);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
188 static struct scsi_extended_sense *sata_arq_sense(sata_pkt_txlate_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
189
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
190 /* Local functions */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
191 static void sata_identdev_to_inquiry(sata_hba_inst_t *, sata_drive_info_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
192 uint8_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
193 static int sata_build_msense_page_1(sata_drive_info_t *, int, uint8_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
194 static int sata_build_msense_page_8(sata_drive_info_t *, int, uint8_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
195 static int sata_build_msense_page_1a(sata_drive_info_t *, int, uint8_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
196 static int sata_build_msense_page_1c(sata_drive_info_t *, int, uint8_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
197 static int sata_mode_select_page_8(sata_pkt_txlate_t *,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
198 struct mode_cache_scsi3 *, int, int *, int *, int *);
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
199 static int sata_mode_select_page_1c(sata_pkt_txlate_t *,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
200 struct mode_info_excpt_page *, int, int *, int *, int *);
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
201 static int sata_build_lsense_page_0(sata_drive_info_t *, uint8_t *);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
202 static int sata_build_lsense_page_10(sata_drive_info_t *, uint8_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
203 sata_hba_inst_t *);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
204 static int sata_build_lsense_page_2f(sata_drive_info_t *, uint8_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
205 sata_hba_inst_t *);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
206 static int sata_build_lsense_page_30(sata_drive_info_t *, uint8_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
207 sata_hba_inst_t *);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
208 static void sata_save_drive_settings(sata_drive_info_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
209 static void sata_show_drive_info(sata_hba_inst_t *, sata_drive_info_t *);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
210 static void sata_log(sata_hba_inst_t *, uint_t, char *fmt, ...);
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
211 static int sata_fetch_smart_return_status(sata_hba_inst_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
212 sata_drive_info_t *);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
213 static int sata_fetch_smart_data(sata_hba_inst_t *, sata_drive_info_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
214 struct smart_data *);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
215 static int sata_smart_selftest_log(sata_hba_inst_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
216 sata_drive_info_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
217 struct smart_selftest_log *);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
218 static int sata_ext_smart_selftest_read_log(sata_hba_inst_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
219 sata_drive_info_t *, struct smart_ext_selftest_log *, uint16_t);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
220 static int sata_smart_read_log(sata_hba_inst_t *, sata_drive_info_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
221 uint8_t *, uint8_t, uint8_t);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
222 static int sata_read_log_ext_directory(sata_hba_inst_t *, sata_drive_info_t *,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
223 struct read_log_ext_directory *);
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
224 static void sata_gen_sysevent(sata_hba_inst_t *, sata_address_t *, int);
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
225 static void sata_xlate_errors(sata_pkt_txlate_t *);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
226
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
227 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
228 * SATA Framework will ignore SATA HBA driver cb_ops structure and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
229 * register following one with SCSA framework.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
230 * Open & close are provided, so scsi framework will not use its own
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
231 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
232 static struct cb_ops sata_cb_ops = {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
233 sata_hba_open, /* open */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
234 sata_hba_close, /* close */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
235 nodev, /* strategy */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
236 nodev, /* print */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
237 nodev, /* dump */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
238 nodev, /* read */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
239 nodev, /* write */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
240 sata_hba_ioctl, /* ioctl */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
241 nodev, /* devmap */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
242 nodev, /* mmap */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
243 nodev, /* segmap */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
244 nochpoll, /* chpoll */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
245 ddi_prop_op, /* cb_prop_op */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
246 0, /* streamtab */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
247 D_NEW | D_MP, /* cb_flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
248 CB_REV, /* rev */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
249 nodev, /* aread */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
250 nodev /* awrite */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
251 };
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
252
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
253
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
254 extern struct mod_ops mod_miscops;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
255 extern uchar_t scsi_cdb_size[];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
256
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
257 static struct modlmisc modlmisc = {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
258 &mod_miscops, /* Type of module */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
259 "Generic SATA Driver v%I%" /* module name */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
260 };
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
261
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
262
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
263 static struct modlinkage modlinkage = {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
264 MODREV_1,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
265 (void *)&modlmisc,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
266 NULL
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
267 };
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
268
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
269 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
270 * Default sata pkt timeout. Used when a target driver scsi_pkt time is zero,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
271 * i.e. when scsi_pkt has not timeout specified.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
272 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
273 static int sata_default_pkt_time = 60; /* 60 seconds */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
274
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
275 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
276 * Mutexes protecting structures in multithreaded operations.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
277 * Because events are relatively rare, a single global mutex protecting
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
278 * data structures should be sufficient. To increase performance, add
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
279 * separate mutex per each sata port and use global mutex only to protect
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
280 * common data structures.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
281 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
282 static kmutex_t sata_mutex; /* protects sata_hba_list */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
283 static kmutex_t sata_log_mutex; /* protects log */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
284
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
285 static char sata_log_buf[256];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
286
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
287 /* Default write cache setting */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
288 int sata_write_cache = 1;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
289
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
290 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
291 * Linked list of HBA instances
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
292 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
293 static sata_hba_inst_t *sata_hba_list = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
294 static sata_hba_inst_t *sata_hba_list_tail = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
295 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
296 * Pointer to per-instance SATA HBA soft structure is stored in sata_hba_tran
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
297 * structure and in sata soft state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
298 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
299
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
300 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
301 * Event daemon related variables
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
302 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
303 static kmutex_t sata_event_mutex;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
304 static kcondvar_t sata_event_cv;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
305 static kthread_t *sata_event_thread = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
306 static int sata_event_thread_terminate = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
307 static int sata_event_pending = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
308 static int sata_event_thread_active = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
309 extern pri_t minclsyspri;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
310
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
311 /* Warlock directives */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
312
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
313 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", scsi_hba_tran))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
314 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", scsi_device))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
315 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", dev_ops))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
316 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", scsi_extended_sense))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
317 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", scsi_arq_status))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
318 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", ddi_dma_attr))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
319 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", ddi_dma_cookie_t))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
320 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", devctl_ap_state))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
321 _NOTE(MUTEX_PROTECTS_DATA(sata_mutex, sata_hba_list))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
322 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_hba_list))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
323 _NOTE(MUTEX_PROTECTS_DATA(sata_mutex, sata_hba_inst::satahba_next))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
324 _NOTE(MUTEX_PROTECTS_DATA(sata_mutex, sata_hba_inst::satahba_prev))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
325 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", \
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
326 sata_hba_inst::satahba_scsi_tran))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
327 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", sata_hba_inst::satahba_tran))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
328 _NOTE(SCHEME_PROTECTS_DATA("No Mutex Needed", sata_hba_inst::satahba_dip))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
329 _NOTE(SCHEME_PROTECTS_DATA("Scheme", sata_hba_inst::satahba_attached))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
330 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_hba_inst::satahba_dev_port))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
331 _NOTE(MUTEX_PROTECTS_DATA(sata_hba_inst::satahba_mutex,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
332 sata_hba_inst::satahba_event_flags))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
333 _NOTE(MUTEX_PROTECTS_DATA(sata_cport_info::cport_mutex, \
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
334 sata_cport_info::cport_devp))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
335 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_cport_info::cport_devp))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
336 _NOTE(SCHEME_PROTECTS_DATA("Scheme", sata_cport_info::cport_addr))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
337 _NOTE(MUTEX_PROTECTS_DATA(sata_cport_info::cport_mutex, \
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
338 sata_cport_info::cport_dev_type))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
339 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_cport_info::cport_dev_type))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
340 _NOTE(MUTEX_PROTECTS_DATA(sata_cport_info::cport_mutex, \
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
341 sata_cport_info::cport_state))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
342 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_cport_info::cport_state))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
343 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_pmport_info::pmport_dev_type))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
344 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_pmport_info::pmport_sata_drive))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
345 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_pmult_info::pmult_dev_port))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
346 _NOTE(DATA_READABLE_WITHOUT_LOCK(sata_pmult_info::pmult_num_dev_ports))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
347
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
348 /* End of warlock directives */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
349
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
350 /* ************** loadable module configuration functions ************** */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
351
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
352 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
353 _init()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
354 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
355 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
356
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
357 mutex_init(&sata_mutex, NULL, MUTEX_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
358 mutex_init(&sata_event_mutex, NULL, MUTEX_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
359 mutex_init(&sata_log_mutex, NULL, MUTEX_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
360 cv_init(&sata_event_cv, NULL, CV_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
361 if ((rval = mod_install(&modlinkage)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
362 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
363 cmn_err(CE_WARN, "sata: _init: mod_install failed\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
364 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
365 mutex_destroy(&sata_log_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
366 cv_destroy(&sata_event_cv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
367 mutex_destroy(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
368 mutex_destroy(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
369 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
370 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
371 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
372
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
373 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
374 _fini()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
375 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
376 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
377
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
378 if ((rval = mod_remove(&modlinkage)) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
379 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
380
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
381 mutex_destroy(&sata_log_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
382 cv_destroy(&sata_event_cv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
383 mutex_destroy(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
384 mutex_destroy(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
385 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
386 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
387
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
388 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
389 _info(struct modinfo *modinfop)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
390 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
391 return (mod_info(&modlinkage, modinfop));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
392 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
393
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
394
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
395
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
396 /* ********************* SATA HBA entry points ********************* */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
397
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
398
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
399 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
400 * Called by SATA HBA from _init().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
401 * Registers HBA driver instance/sata framework pair with scsi framework, by
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
402 * calling scsi_hba_init().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
403 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
404 * SATA HBA driver cb_ops are ignored - SATA HBA framework cb_ops are used
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
405 * instead. SATA HBA framework cb_ops pointer overwrites SATA HBA driver
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
406 * cb_ops pointer in SATA HBA driver dev_ops structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
407 * SATA HBA framework cb_ops supplies cb_open cb_close and cb_ioctl vectors.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
408 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
409 * Return status of the scsi_hba_init() is returned to a calling SATA HBA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
410 * driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
411 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
412 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
413 sata_hba_init(struct modlinkage *modlp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
414 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
415 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
416 struct dev_ops *hba_ops;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
417
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
418 SATADBG1(SATA_DBG_HBA_IF, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
419 "sata_hba_init: name %s \n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
420 ((struct modldrv *)(modlp->ml_linkage[0]))->drv_linkinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
421 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
422 * Fill-up cb_ops and dev_ops when necessary
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
423 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
424 hba_ops = ((struct modldrv *)(modlp->ml_linkage[0]))->drv_dev_ops;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
425 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
426 * Provide pointer to SATA dev_ops
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
427 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
428 hba_ops->devo_cb_ops = &sata_cb_ops;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
429
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
430 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
431 * Register SATA HBA with SCSI framework
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
432 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
433 if ((rval = scsi_hba_init(modlp)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
434 SATADBG1(SATA_DBG_HBA_IF, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
435 "sata_hba_init: scsi hba init failed\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
436 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
437 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
438
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
439 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
440 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
441
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
442
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
443 /* HBA attach stages */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
444 #define HBA_ATTACH_STAGE_SATA_HBA_INST 1
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
445 #define HBA_ATTACH_STAGE_SCSI_ATTACHED 2
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
446 #define HBA_ATTACH_STAGE_SETUP 4
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
447 #define HBA_ATTACH_STAGE_LINKED 8
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
448
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
449
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
450 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
451 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
452 * Called from SATA HBA driver's attach routine to attach an instance of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
453 * the HBA.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
454 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
455 * For DDI_ATTACH command:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
456 * sata_hba_inst structure is allocated here and initialized with pointers to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
457 * SATA framework implementation of required scsi tran functions.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
458 * The scsi_tran's tran_hba_private field is used by SATA Framework to point
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
459 * to the soft structure (sata_hba_inst) allocated by SATA framework for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
460 * SATA HBA instance related data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
461 * The scsi_tran's tran_hba_private field is used by SATA framework to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
462 * store a pointer to per-HBA-instance of sata_hba_inst structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
463 * The sata_hba_inst structure is cross-linked to scsi tran structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
464 * Among other info, a pointer to sata_hba_tran structure is stored in
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
465 * sata_hba_inst. The sata_hba_inst structures for different HBA instances are
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
466 * linked together into the list, pointed to by sata_hba_list.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
467 * On the first HBA instance attach the sata event thread is initialized.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
468 * Attachment points are created for all SATA ports of the HBA being attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
469 * All HBA instance's SATA ports are probed and type of plugged devices is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
470 * determined. For each device of a supported type, a target node is created.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
471 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
472 * DDI_SUCCESS is returned when attachment process is successful,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
473 * DDI_FAILURE is returned otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
474 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
475 * For DDI_RESUME command:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
476 * Not implemented at this time (postponed until phase 2 of the development).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
477 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
478 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
479 sata_hba_attach(dev_info_t *dip, sata_hba_tran_t *sata_tran,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
480 ddi_attach_cmd_t cmd)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
481 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
482 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
483 scsi_hba_tran_t *scsi_tran = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
484 int hba_attach_state = 0;
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
485 char taskq_name[MAXPATHLEN];
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
486
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
487 SATADBG3(SATA_DBG_HBA_IF, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
488 "sata_hba_attach: node %s (%s%d)\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
489 ddi_node_name(dip), ddi_driver_name(dip),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
490 ddi_get_instance(dip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
491
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
492 if (cmd == DDI_RESUME) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
493 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
494 * Postponed until phase 2 of the development
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
495 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
496 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
497 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
498
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
499 if (cmd != DDI_ATTACH) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
500 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
501 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
502
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
503 /* cmd == DDI_ATTACH */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
504
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
505 if (sata_validate_sata_hba_tran(dip, sata_tran) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
506 SATA_LOG_D((NULL, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
507 "sata_hba_attach: invalid sata_hba_tran"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
508 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
509 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
510 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
511 * Allocate and initialize SCSI tran structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
512 * SATA copy of tran_bus_config is provided to create port nodes.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
513 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
514 scsi_tran = scsi_hba_tran_alloc(dip, SCSI_HBA_CANSLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
515 if (scsi_tran == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
516 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
517 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
518 * Allocate soft structure for SATA HBA instance.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
519 * There is a separate softstate for each HBA instance.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
520 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
521 sata_hba_inst = kmem_zalloc(sizeof (struct sata_hba_inst), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
522 ASSERT(sata_hba_inst != NULL); /* this should not fail */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
523 mutex_init(&sata_hba_inst->satahba_mutex, NULL, MUTEX_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
524 hba_attach_state |= HBA_ATTACH_STAGE_SATA_HBA_INST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
525
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
526 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
527 * scsi_trans's tran_hba_private is used by SATA Framework to point to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
528 * soft structure allocated by SATA framework for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
529 * SATA HBA instance related data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
530 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
531 scsi_tran->tran_hba_private = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
532 scsi_tran->tran_tgt_private = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
533
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
534 scsi_tran->tran_tgt_init = sata_scsi_tgt_init;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
535 scsi_tran->tran_tgt_probe = sata_scsi_tgt_probe;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
536 scsi_tran->tran_tgt_free = sata_scsi_tgt_free;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
537
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
538 scsi_tran->tran_start = sata_scsi_start;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
539 scsi_tran->tran_reset = sata_scsi_reset;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
540 scsi_tran->tran_abort = sata_scsi_abort;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
541 scsi_tran->tran_getcap = sata_scsi_getcap;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
542 scsi_tran->tran_setcap = sata_scsi_setcap;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
543 scsi_tran->tran_init_pkt = sata_scsi_init_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
544 scsi_tran->tran_destroy_pkt = sata_scsi_destroy_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
545
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
546 scsi_tran->tran_dmafree = sata_scsi_dmafree;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
547 scsi_tran->tran_sync_pkt = sata_scsi_sync_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
548
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
549 scsi_tran->tran_reset_notify = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
550 scsi_tran->tran_get_bus_addr = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
551 scsi_tran->tran_quiesce = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
552 scsi_tran->tran_unquiesce = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
553 scsi_tran->tran_bus_reset = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
554
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
555 if (scsi_hba_attach_setup(dip, sata_tran->sata_tran_hba_dma_attr,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
556 scsi_tran, 0) != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
557 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
558 cmn_err(CE_WARN, "?SATA: %s%d hba scsi attach failed",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
559 ddi_driver_name(dip), ddi_get_instance(dip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
560 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
561 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
562 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
563 hba_attach_state |= HBA_ATTACH_STAGE_SCSI_ATTACHED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
564
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
565 if (!ddi_prop_exists(DDI_DEV_T_ANY, dip, DDI_PROP_DONTPASS, "sata")) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
566 if (ddi_prop_update_int(DDI_DEV_T_NONE, dip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
567 "sata", 1) != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
568 SATA_LOG_D((NULL, CE_WARN, "sata_hba_attach: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
569 "failed to create hba sata prop"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
570 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
571 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
572 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
573
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
574 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
575 * Save pointers in hba instance soft state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
576 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
577 sata_hba_inst->satahba_scsi_tran = scsi_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
578 sata_hba_inst->satahba_tran = sata_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
579 sata_hba_inst->satahba_dip = dip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
580
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
581 /*
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
582 * Create a task queue to handle emulated commands completion
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
583 * Use node name, dash, instance number as the queue name.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
584 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
585 taskq_name[0] = '\0';
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
586 (void) strlcat(taskq_name, DEVI(dip)->devi_node_name,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
587 sizeof (taskq_name));
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
588 (void) snprintf(taskq_name + strlen(taskq_name),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
589 sizeof (taskq_name) - strlen(taskq_name),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
590 "-%d", DEVI(dip)->devi_instance);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
591 sata_hba_inst->satahba_taskq = taskq_create(taskq_name, 1,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
592 minclsyspri, 1, sata_tran->sata_tran_hba_num_cports,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
593 TASKQ_DYNAMIC);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
594
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
595 hba_attach_state |= HBA_ATTACH_STAGE_SETUP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
596
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
597 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
598 * Create events thread if not created yet.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
599 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
600 sata_event_thread_control(1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
601
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
602 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
603 * Link this hba instance into the list.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
604 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
605 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
606
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
607
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
608 sata_hba_inst->satahba_next = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
609 sata_hba_inst->satahba_prev = sata_hba_list_tail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
610 if (sata_hba_list == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
611 sata_hba_list = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
612 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
613 if (sata_hba_list_tail != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
614 sata_hba_list_tail->satahba_next = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
615 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
616 sata_hba_list_tail = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
617 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
618 hba_attach_state |= HBA_ATTACH_STAGE_LINKED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
619
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
620 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
621 * Create SATA HBA devctl minor node for sata_hba_open, close, ioctl
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
622 * SATA HBA driver should not use its own open/close entry points.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
623 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
624 * Make sure that instance number doesn't overflow
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
625 * when forming minor numbers.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
626 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
627 ASSERT(ddi_get_instance(dip) <= (L_MAXMIN >> INST_MINOR_SHIFT));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
628 if (ddi_create_minor_node(dip, "devctl", S_IFCHR,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
629 INST2DEVCTL(ddi_get_instance(dip)),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
630 DDI_NT_SATA_NEXUS, 0) != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
631 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
632 cmn_err(CE_WARN, "sata_hba_attach: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
633 "cannot create devctl minor node");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
634 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
635 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
636 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
637
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
638
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
639 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
640 * Set-up kstats here, if necessary.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
641 * (postponed until phase 2 of the development).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
642 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
643
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
644
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
645 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
646 * Probe controller ports. This operation will describe a current
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
647 * controller/port/multipliers/device configuration and will create
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
648 * attachment points.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
649 * We may end-up with just a controller with no devices attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
650 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
651 sata_probe_ports(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
652
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
653 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
654 * Create child nodes for all possible target devices currently
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
655 * attached to controller's ports and port multiplier device ports.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
656 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
657 sata_make_device_nodes(sata_tran->sata_tran_hba_dip, sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
658
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
659 sata_hba_inst->satahba_attached = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
660 return (DDI_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
661
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
662 fail:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
663 if (hba_attach_state & HBA_ATTACH_STAGE_LINKED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
664 (void) sata_remove_hba_instance(dip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
665 if (sata_hba_list == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
666 sata_event_thread_control(0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
667 }
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
668
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
669 if (hba_attach_state & HBA_ATTACH_STAGE_SETUP) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
670 (void) ddi_prop_remove(DDI_DEV_T_ANY, dip, "sata");
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
671 taskq_destroy(sata_hba_inst->satahba_taskq);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
672 }
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
673
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
674 if (hba_attach_state & HBA_ATTACH_STAGE_SCSI_ATTACHED)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
675 (void) scsi_hba_detach(dip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
676
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
677 if (hba_attach_state & HBA_ATTACH_STAGE_SATA_HBA_INST) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
678 mutex_destroy(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
679 kmem_free((void *)sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
680 sizeof (struct sata_hba_inst));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
681 scsi_hba_tran_free(scsi_tran);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
682 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
683
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
684 sata_log(NULL, CE_WARN, "?SATA: %s%d hba attach failed",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
685 ddi_driver_name(dip), ddi_get_instance(dip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
686
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
687 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
688 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
689
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
690
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
691 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
692 * Called by SATA HBA from to detach an instance of the driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
693 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
694 * For DDI_DETACH command:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
695 * Free local structures allocated for SATA HBA instance during
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
696 * sata_hba_attach processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
697 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
698 * Returns DDI_SUCCESS when HBA was detached, DDI_FAILURE otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
699 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
700 * For DDI_SUSPEND command:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
701 * Not implemented at this time (postponed until phase 2 of the development)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
702 * Returnd DDI_SUCCESS.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
703 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
704 * When the last HBA instance is detached, the event daemon is terminated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
705 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
706 * NOTE: cport support only, no port multiplier support.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
707 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
708 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
709 sata_hba_detach(dev_info_t *dip, ddi_detach_cmd_t cmd)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
710 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
711 dev_info_t *tdip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
712 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
713 scsi_hba_tran_t *scsi_hba_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
714 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
715 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
716 int ncport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
717
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
718 SATADBG3(SATA_DBG_HBA_IF, NULL, "sata_hba_detach: node %s (%s%d)\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
719 ddi_node_name(dip), ddi_driver_name(dip), ddi_get_instance(dip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
720
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
721 switch (cmd) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
722 case DDI_DETACH:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
723
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
724 if ((scsi_hba_tran = ddi_get_driver_private(dip)) == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
725 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
726
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
727 sata_hba_inst = scsi_hba_tran->tran_hba_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
728 if (sata_hba_inst == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
729 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
730
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
731 if (scsi_hba_detach(dip) == DDI_FAILURE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
732 sata_hba_inst->satahba_attached = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
733 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
734 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
735
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
736 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
737 * Free all target nodes - at this point
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
738 * devices should be at least offlined
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
739 * otherwise scsi_hba_detach() should not be called.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
740 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
741 for (ncport = 0; ncport < SATA_NUM_CPORTS(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
742 ncport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
743 cportinfo = SATA_CPORT_INFO(sata_hba_inst, ncport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
744 if (cportinfo->cport_dev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
745 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
746 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
747 tdip = sata_get_target_dip(dip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
748 ncport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
749 if (tdip != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
750 if (ndi_devi_offline(tdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
751 NDI_DEVI_REMOVE) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
752 NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
753 SATA_LOG_D((
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
754 sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
755 CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
756 "sata_hba_detach: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
757 "Target node not "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
758 "removed !"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
759 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
760 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
761 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
762 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
763 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
764 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
765 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
766 * Disable sata event daemon processing for this HBA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
767 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
768 sata_hba_inst->satahba_attached = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
769
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
770 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
771 * Remove event daemon thread, if it is last HBA instance.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
772 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
773
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
774 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
775 if (sata_hba_list->satahba_next == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
776 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
777 sata_event_thread_control(0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
778 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
779 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
780 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
781
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
782 /* Remove this HBA instance from the HBA list */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
783 sata_remove_hba_instance(dip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
784
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
785 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
786 * At this point there should be no target nodes attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
787 * Detach and destroy device and port info structures.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
788 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
789 for (ncport = 0; ncport < SATA_NUM_CPORTS(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
790 ncport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
791 cportinfo = SATA_CPORT_INFO(sata_hba_inst, ncport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
792 if (cportinfo->cport_dev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
793 sdinfo =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
794 cportinfo->cport_devp.cport_sata_drive;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
795 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
796 /* Release device structure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
797 kmem_free(sdinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
798 sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
799 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
800 /* Release cport info */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
801 mutex_destroy(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
802 kmem_free(cportinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
803 sizeof (sata_cport_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
804 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
805 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
806
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
807 scsi_hba_tran_free(sata_hba_inst->satahba_scsi_tran);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
808
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
809 (void) ddi_prop_remove(DDI_DEV_T_ANY, dip, "sata");
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
810
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
811 taskq_destroy(sata_hba_inst->satahba_taskq);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
812
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
813 mutex_destroy(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
814 kmem_free((void *)sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
815 sizeof (struct sata_hba_inst));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
816
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
817 return (DDI_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
818
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
819 case DDI_SUSPEND:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
820 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
821 * Postponed until phase 2
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
822 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
823 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
824
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
825 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
826 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
827 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
828 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
829
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
830
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
831 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
832 * Called by an HBA drive from _fini() routine.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
833 * Unregisters SATA HBA instance/SATA framework pair from the scsi framework.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
834 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
835 void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
836 sata_hba_fini(struct modlinkage *modlp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
837 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
838 SATADBG1(SATA_DBG_HBA_IF, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
839 "sata_hba_fini: name %s\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
840 ((struct modldrv *)(modlp->ml_linkage[0]))->drv_linkinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
841
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
842 scsi_hba_fini(modlp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
843 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
844
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
845
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
846 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
847 * Default open and close routine for sata_hba framework.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
848 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
849 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
850 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
851 * Open devctl node.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
852 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
853 * Returns:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
854 * 0 if node was open successfully, error code otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
855 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
856 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
857 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
858
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
859 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
860 sata_hba_open(dev_t *devp, int flags, int otyp, cred_t *credp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
861 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
862 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
863 _NOTE(ARGUNUSED(credp))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
864 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
865 int rv = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
866 dev_info_t *dip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
867 scsi_hba_tran_t *scsi_hba_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
868 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
869
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
870 SATADBG1(SATA_DBG_IOCTL_IF, NULL, "sata_hba_open: entered", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
871
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
872 if (otyp != OTYP_CHR)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
873 return (EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
874
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
875 dip = sata_devt_to_devinfo(*devp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
876 if (dip == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
877 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
878
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
879 if ((scsi_hba_tran = ddi_get_driver_private(dip)) == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
880 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
881
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
882 sata_hba_inst = scsi_hba_tran->tran_hba_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
883 if (sata_hba_inst == NULL || sata_hba_inst->satahba_attached == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
884 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
885
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
886 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
887 if (flags & FEXCL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
888 if (sata_hba_inst->satahba_open_flag != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
889 rv = EBUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
890 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
891 sata_hba_inst->satahba_open_flag =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
892 SATA_DEVCTL_EXOPENED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
893 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
894 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
895 if (sata_hba_inst->satahba_open_flag == SATA_DEVCTL_EXOPENED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
896 rv = EBUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
897 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
898 sata_hba_inst->satahba_open_flag =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
899 SATA_DEVCTL_SOPENED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
900 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
901 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
902 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
903
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
904 return (rv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
905 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
906
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
907
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
908 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
909 * Close devctl node.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
910 * Returns:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
911 * 0 if node was closed successfully, error code otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
912 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
913 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
914
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
915 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
916 sata_hba_close(dev_t dev, int flag, int otyp, cred_t *credp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
917 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
918 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
919 _NOTE(ARGUNUSED(credp))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
920 _NOTE(ARGUNUSED(flag))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
921 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
922 dev_info_t *dip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
923 scsi_hba_tran_t *scsi_hba_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
924 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
925
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
926 SATADBG1(SATA_DBG_IOCTL_IF, NULL, "sata_hba_close: entered", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
927
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
928 if (otyp != OTYP_CHR)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
929 return (EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
930
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
931 dip = sata_devt_to_devinfo(dev);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
932 if (dip == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
933 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
934
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
935 if ((scsi_hba_tran = ddi_get_driver_private(dip)) == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
936 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
937
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
938 sata_hba_inst = scsi_hba_tran->tran_hba_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
939 if (sata_hba_inst == NULL || sata_hba_inst->satahba_attached == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
940 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
941
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
942 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
943 sata_hba_inst->satahba_open_flag = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
944 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
945 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
946 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
947
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
948
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
949
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
950 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
951 * Standard IOCTL commands for SATA hotplugging.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
952 * Implemented DEVCTL_AP commands:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
953 * DEVCTL_AP_CONNECT
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
954 * DEVCTL_AP_DISCONNECT
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
955 * DEVCTL_AP_CONFIGURE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
956 * DEVCTL_UNCONFIGURE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
957 * DEVCTL_AP_CONTROL
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
958 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
959 * Commands passed to default ndi ioctl handler:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
960 * DEVCTL_DEVICE_GETSTATE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
961 * DEVCTL_DEVICE_ONLINE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
962 * DEVCTL_DEVICE_OFFLINE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
963 * DEVCTL_DEVICE_REMOVE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
964 * DEVCTL_DEVICE_INSERT
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
965 * DEVCTL_BUS_GETSTATE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
966 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
967 * All other cmds are passed to HBA if it provide ioctl handler, or failed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
968 * if not.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
969 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
970 * Returns:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
971 * 0 if successful,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
972 * error code if operation failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
973 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
974 * NOTE: Port Multiplier is not supported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
975 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
976 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
977
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
978 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
979 sata_hba_ioctl(dev_t dev, int cmd, intptr_t arg, int mode, cred_t *credp,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
980 int *rvalp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
981 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
982 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
983 _NOTE(ARGUNUSED(credp))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
984 _NOTE(ARGUNUSED(rvalp))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
985 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
986 int rv = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
987 int32_t comp_port = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
988 dev_info_t *dip, *tdip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
989 devctl_ap_state_t ap_state;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
990 struct devctl_iocdata *dcp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
991 scsi_hba_tran_t *scsi_hba_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
992 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
993 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
994 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
995 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
996 int cport, pmport, qual;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
997 int rval = SATA_SUCCESS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
998
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
999 dip = sata_devt_to_devinfo(dev);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1000 if (dip == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1001 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1002
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1003 if ((scsi_hba_tran = ddi_get_driver_private(dip)) == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1004 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1005
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1006 sata_hba_inst = scsi_hba_tran->tran_hba_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1007 if (sata_hba_inst == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1008 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1009
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1010 if (sata_hba_inst->satahba_tran == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1011 return (ENXIO);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1012
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1013 switch (cmd) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1014
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1015 case DEVCTL_DEVICE_GETSTATE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1016 case DEVCTL_DEVICE_ONLINE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1017 case DEVCTL_DEVICE_OFFLINE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1018 case DEVCTL_DEVICE_REMOVE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1019 case DEVCTL_BUS_GETSTATE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1020 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1021 * There may be more cases that we want to pass to default
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1022 * handler rather then fail them.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1023 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1024 return (ndi_devctl_ioctl(dip, cmd, arg, mode, 0));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1025 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1026
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1027 /* read devctl ioctl data */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1028 if (cmd != DEVCTL_AP_CONTROL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1029 if (ndi_dc_allochdl((void *)arg, &dcp) != NDI_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1030 return (EFAULT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1031
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1032 if ((comp_port = sata_get_port_num(sata_hba_inst, dcp)) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1033 -1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1034 if (dcp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1035 ndi_dc_freehdl(dcp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1036 return (EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1037 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1038
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1039 cport = SCSI_TO_SATA_CPORT(comp_port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1040 pmport = SCSI_TO_SATA_PMPORT(comp_port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1041 /* Only cport is considered now, i.e. SATA_ADDR_CPORT */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1042 qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1043 if (sata_validate_sata_address(sata_hba_inst, cport, pmport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1044 qual) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1045 ndi_dc_freehdl(dcp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1046 return (EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1047 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1048
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1049 cportinfo = SATA_CPORT_INFO(sata_hba_inst, cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1050 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1051 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1052 if (cportinfo->cport_event_flags & SATA_EVNT_LOCK_PORT_BUSY) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1053 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1054 * Cannot process ioctl request now. Come back later.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1055 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1056 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1057 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1058 ndi_dc_freehdl(dcp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1059 return (EBUSY);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1060 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1061 /* Block event processing for this port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1062 cportinfo->cport_event_flags |= SATA_APCTL_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1063 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1064
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1065 sata_device.satadev_addr.cport = cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1066 sata_device.satadev_addr.pmport = pmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1067 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1068 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1069 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1070
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1071 switch (cmd) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1072
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1073 case DEVCTL_AP_DISCONNECT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1074 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1075 * Normally, cfgadm sata plugin will try to offline
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1076 * (unconfigure) device before this request. Nevertheless,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1077 * if a device is still configured, we need to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1078 * attempt to offline and unconfigure device first, and we will
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1079 * deactivate the port regardless of the unconfigure
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1080 * operation results.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1081 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1082 * DEVCTL_AP_DISCONNECT invokes
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1083 * sata_hba_inst->satahba_tran->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1084 * sata_tran_hotplug_ops->sata_tran_port_deactivate().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1085 * If successful, the device structure (if any) attached
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1086 * to a port is removed and state of the port marked
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1087 * appropriately.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1088 * Failure of the port_deactivate may keep port in
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1089 * the active state, or may fail the port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1090 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1091
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1092 /* Check the current state of the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1093 if (sata_reprobe_port(sata_hba_inst, &sata_device) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1094 SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1095 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1096 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1097 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1098 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1099 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1100 if (cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1101 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1102 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1103 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1104 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1105 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1106 }
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1107 /* Sanity check */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1108 if (SATA_PORT_DEACTIVATE_FUNC(sata_hba_inst) == NULL) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
1109 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
1110 cport_mutex);
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1111 /* No physical port deactivation supported. */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1112 break;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1113 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1114
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1115 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1116 * set port's dev_state to not ready - this will disable
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1117 * an access to an attached device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1118 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1119 cportinfo->cport_state &= ~SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1120
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1121 if (cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1122 sdinfo = cportinfo->cport_devp.cport_sata_drive;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1123 ASSERT(sdinfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1124 if ((sdinfo->satadrv_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1125 (SATA_VALID_DEV_TYPE))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1126 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1127 * If a target node exists, try to offline
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1128 * a device and remove target node.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1129 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1130 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1131 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1132 tdip = sata_get_target_dip(dip, comp_port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1133 if (tdip != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1134 /* target node exist */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1135 if (ndi_devi_offline(tdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1136 NDI_DEVI_REMOVE) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1137 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1138 * Problem
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1139 * A target node remained
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1140 * attached. This happens when
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1141 * the file was open or a node
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1142 * was waiting for resources.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1143 * Cannot do anything about it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1144 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1145 SATA_LOG_D((sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1146 CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1147 "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1148 "disconnect: cannot "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1149 "remove target node!!!"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1150 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1151 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1152 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1153 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1154 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1155 * Remove and release sata_drive_info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1156 * structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1157 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1158 if (SATA_CPORTINFO_DRV_INFO(cportinfo) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1159 NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1160 SATA_CPORTINFO_DRV_INFO(cportinfo) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1161 NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1162 (void) kmem_free((void *)sdinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1163 sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1164 cportinfo->cport_dev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1165 SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1166 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1167 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1168 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1169 * Note: PMult info requires different handling.
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1170 * Put PMult handling code here, when PMult is
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1171 * supported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1172 */
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1173
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1174 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1175 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1176 /* Just ask HBA driver to deactivate port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1177 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1178
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1179 rval = (*SATA_PORT_DEACTIVATE_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1180 (dip, &sata_device);
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1181
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1182 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1183 * Generate sysevent - EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1184 * without the hint.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1185 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1186 sata_gen_sysevent(sata_hba_inst,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1187 &sata_device.satadev_addr, SE_NO_HINT);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1188
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1189 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1190 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1191 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1192
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1193 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1194 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1195 * Port deactivation failure - do not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1196 * change port state unless the state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1197 * returned by HBA indicates a port failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1198 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1199 if (sata_device.satadev_state & SATA_PSTATE_FAILED)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1200 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1201 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1202 } else {
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1203 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1204 * Deactivation succeded. From now on the framework
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1205 * will not know what is happening to the device, until
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1206 * the port is activated again.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1207 */
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1208 cportinfo->cport_state |= SATA_PSTATE_SHUTDOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1209 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1210 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1211 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1212
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1213 case DEVCTL_AP_UNCONFIGURE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1214
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1215 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1216 * The unconfigure operation uses generic nexus operation to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1217 * offline a device. It leaves a target device node attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1218 * and obviously sata_drive_info attached as well, because
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1219 * from the hardware point of view nothing has changed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1220 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1221 if ((tdip = sata_get_target_dip(dip, comp_port)) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1222
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1223 if (ndi_devi_offline(tdip, NDI_UNCONFIG) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1224 NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1225 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1226 "sata_hba_ioctl: unconfigure: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1227 "failed to unconfigure "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1228 "device at cport %d", cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1229 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1230 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1231 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1232 * The target node devi_state should be marked with
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1233 * DEVI_DEVICE_OFFLINE by ndi_devi_offline().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1234 * This would be the indication for cfgadm that
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1235 * the AP node occupant state is 'unconfigured'.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1236 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1237
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1238 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1239 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1240 * This would indicate a failure on the part of cfgadm
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1241 * to detect correct state of the node prior to this
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1242 * call - one cannot unconfigure non-existing device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1243 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1244 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1245 "sata_hba_ioctl: unconfigure: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1246 "attempt to unconfigure non-existing device "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1247 "at cport %d", cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1248 rv = ENXIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1249 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1250
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1251 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1252
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1253 case DEVCTL_AP_CONNECT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1254 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1255 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1256 * The sata cfgadm pluging will invoke this operation only if
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1257 * port was found in the disconnect state (failed state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1258 * is also treated as the disconnected state).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1259 * DEVCTL_AP_CONNECT would invoke
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1260 * sata_hba_inst->satahba_tran->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1261 * sata_tran_hotplug_ops->sata_tran_port_activate().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1262 * If successful and a device is found attached to the port,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1263 * the initialization sequence is executed to attach
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1264 * a device structure to a port structure. The device is not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1265 * set in configured state (system-wise) by this operation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1266 * The state of the port and a device would be set
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1267 * appropriately.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1268 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1269 * Note, that activating the port may generate link events,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1270 * so is is important that following processing and the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1271 * event processing does not interfere with each other!
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1272 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1273 * This operation may remove port failed state and will
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1274 * try to make port active and in good standing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1275 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1276
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1277 /* We only care about host sata cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1278
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1279 if (SATA_PORT_ACTIVATE_FUNC(sata_hba_inst) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1280 /* Just let HBA driver to activate port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1281
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1282 if ((*SATA_PORT_ACTIVATE_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1283 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1284 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1285 * Port activation failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1286 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1287 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1288 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1289 sata_update_port_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1290 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1291 if (sata_device.satadev_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1292 SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1293 cportinfo->cport_state =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1294 SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1295 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1296 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1297 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1298 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1299 "sata_hba_ioctl: connect: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1300 "failed to activate SATA cport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1301 cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1302 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1303 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1304 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1305 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1306 /* Virgin port state - will be updated by the port re-probe. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1307 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1308 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1309 cportinfo->cport_state = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1310 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1311 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1312
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1313 if (sata_reprobe_port(sata_hba_inst, &sata_device) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1314 SATA_FAILURE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1315 rv = EIO;
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1316 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1317 * Generate sysevent - EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1318 * without the hint
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1319 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1320 sata_gen_sysevent(sata_hba_inst,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1321 &sata_device.satadev_addr, SE_NO_HINT);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1322 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1323 * If there is a device attached to the port, emit
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1324 * a message.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1325 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1326 if (cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1327 sata_log(sata_hba_inst, CE_WARN,
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1328 "SATA device detected at port %d", cport);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1329 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1330 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1331 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1332
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1333 case DEVCTL_AP_CONFIGURE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1334 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1335 boolean_t target = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1336
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1337 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1338 * A port may be in an active or shutdown state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1339 * If port is in a failed state, operation is aborted - one
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1340 * has to use explicit connect or port activate request
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1341 * to try to get a port into non-failed mode.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1342 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1343 * If a port is in a shutdown state, arbitrarily invoke
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1344 * sata_tran_port_activate() prior to any other operation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1345 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1346 * Verify that port state is READY and there is a device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1347 * of a supported type attached to this port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1348 * If target node exists, a device was most likely offlined.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1349 * If target node does not exist, create a target node an
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1350 * attempt to online it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1351 * *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1352 * NO PMult or devices beyond PMult are supported yet.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1353 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1354
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1355 /* We only care about host controller's sata cport for now. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1356 if (cportinfo->cport_state & SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1357 rv = ENXIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1358 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1359 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1360 /* Check the current state of the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1361 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1362
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1363 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1364 (dip, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1365 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1366 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1367 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1368 if (rval != SATA_SUCCESS ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1369 (sata_device.satadev_state & SATA_PSTATE_FAILED)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1370 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1371 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1372 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1373 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1374 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1375 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1376 if (cportinfo->cport_state & SATA_PSTATE_SHUTDOWN) {
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1377 target = FALSE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1378 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1379 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1380
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1381 if (SATA_PORT_ACTIVATE_FUNC(sata_hba_inst) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1382 /* Just let HBA driver to activate port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1383 if ((*SATA_PORT_ACTIVATE_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1384 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1385 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1386 * Port activation failure - do not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1387 * change port state unless the state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1388 * returned by HBA indicates a port
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1389 * failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1390 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1391 mutex_enter(&SATA_CPORT_INFO(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1392 sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1393 sata_update_port_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1394 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1395 if (sata_device.satadev_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1396 SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1397 cportinfo->cport_state =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1398 SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1399 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1400 mutex_exit(&SATA_CPORT_INFO(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1401 sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1402 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1403 "sata_hba_ioctl: configure: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1404 "failed to activate SATA cport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1405 cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1406 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1407 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1408 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1409 }
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1410 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1411 * Generate sysevent - EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1412 * without the hint.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1413 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1414 sata_gen_sysevent(sata_hba_inst,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1415 &sata_device.satadev_addr, SE_NO_HINT);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1416
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1417 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1418 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1419 /* Virgin port state */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1420 cportinfo->cport_state = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1421 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1422 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1423 * Always reprobe port, to get current device info.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1424 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1425 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1426 if (sata_reprobe_port(sata_hba_inst, &sata_device) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1427 SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1428 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1429 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1430 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1431 if (target == FALSE &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1432 cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1433 /*
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1434 * That's the transition from "inactive" port
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1435 * to active one with device attached.
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1436 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1437 sata_log(sata_hba_inst, CE_WARN,
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1438 "SATA device detected at port %d",
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1439 cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1440 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1441
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1442 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1443 * This is where real configure starts.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1444 * Change following check for PMult support.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1445 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1446 if (!(sata_device.satadev_type & SATA_VALID_DEV_TYPE)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1447 /* No device to configure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1448 rv = ENXIO; /* No device to configure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1449 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1450 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1451
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1452 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1453 * Here we may have a device in reset condition,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1454 * but because we are just configuring it, there is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1455 * no need to process the reset other than just
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1456 * to clear device reset condition in the HBA driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1457 * Setting the flag SATA_EVNT_CLEAR_DEVICE_RESET will
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1458 * cause a first command sent the HBA driver with the request
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1459 * to clear device reset condition.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1460 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1461 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1462 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1463 sdinfo = sata_get_device_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1464 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1465 rv = ENXIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1466 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1467 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1468 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1469 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1470 if (sdinfo->satadrv_event_flags &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1471 (SATA_EVNT_DEVICE_RESET | SATA_EVNT_INPROC_DEVICE_RESET))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1472 sdinfo->satadrv_event_flags = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1473 sdinfo->satadrv_event_flags |= SATA_EVNT_CLEAR_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1474 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1475
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1476 if ((tdip = sata_get_target_dip(dip, comp_port)) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1477 /* target node still exists */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1478 if (ndi_devi_online(tdip, 0) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1479 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1480 "sata_hba_ioctl: configure: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1481 "onlining device at cport %d failed",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1482 cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1483 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1484 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1485 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1486 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1487 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1488 * No target node - need to create a new target node.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1489 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1490 tdip = sata_create_target_node(dip, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1491 &sata_device.satadev_addr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1492 if (tdip == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1493 /* configure failed */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1494 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1495 "sata_hba_ioctl: configure: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1496 "configuring device at cport %d "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1497 "failed", cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1498 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1499 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1500 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1501 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1502
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1503 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1504 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1505
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1506 case DEVCTL_AP_GETSTATE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1507
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1508 sata_cfgadm_state(sata_hba_inst, comp_port, &ap_state);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1509
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1510 ap_state.ap_last_change = (time_t)-1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1511 ap_state.ap_error_code = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1512 ap_state.ap_in_transition = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1513
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1514 /* Copy the return AP-state information to the user space */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1515 if (ndi_dc_return_ap_state(&ap_state, dcp) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1516 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1517 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1518 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1519
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1520 case DEVCTL_AP_CONTROL:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1521 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1522 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1523 * Generic devctl for hardware specific functionality
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1524 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1525 sata_ioctl_data_t ioc;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1526
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1527 ASSERT(dcp == NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1528
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1529 /* Copy in user ioctl data first */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1530 #ifdef _MULTI_DATAMODEL
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1531 if (ddi_model_convert_from(mode & FMODELS) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1532 DDI_MODEL_ILP32) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1533
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1534 sata_ioctl_data_32_t ioc32;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1535
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1536 if (ddi_copyin((void *)arg, (void *)&ioc32,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1537 sizeof (ioc32), mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1538 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1539 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1540 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1541 ioc.cmd = (uint_t)ioc32.cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1542 ioc.port = (uint_t)ioc32.port;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1543 ioc.get_size = (uint_t)ioc32.get_size;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1544 ioc.buf = (caddr_t)(uintptr_t)ioc32.buf;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1545 ioc.bufsiz = (uint_t)ioc32.bufsiz;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1546 ioc.misc_arg = (uint_t)ioc32.misc_arg;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1547 } else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1548 #endif /* _MULTI_DATAMODEL */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1549 if (ddi_copyin((void *)arg, (void *)&ioc, sizeof (ioc),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1550 mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1551 return (EFAULT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1552 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1553
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1554 SATADBG2(SATA_DBG_IOCTL_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1555 "sata_hba_ioctl: DEVCTL_AP_CONTROL "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1556 "cmd 0x%x, port 0x%x", ioc.cmd, ioc.port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1557
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1558 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1559 * To avoid BE/LE and 32/64 issues, a get_size always returns
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1560 * a 32-bit number.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1561 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1562 if (ioc.get_size != 0 && ioc.bufsiz != (sizeof (uint32_t))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1563 return (EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1564 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1565 /* validate address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1566 cport = SCSI_TO_SATA_CPORT(ioc.port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1567 pmport = SCSI_TO_SATA_PMPORT(ioc.port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1568 qual = SCSI_TO_SATA_ADDR_QUAL(ioc.port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1569
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1570 /* Override address qualifier - handle cport only for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1571 qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1572
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1573 if (sata_validate_sata_address(sata_hba_inst, cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1574 pmport, qual) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1575 return (EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1576
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1577 cportinfo = SATA_CPORT_INFO(sata_hba_inst, cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1578 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1579 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1580 /* Is the port locked by event processing daemon ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1581 if (cportinfo->cport_event_flags & SATA_EVNT_LOCK_PORT_BUSY) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1582 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1583 * Cannot process ioctl request now. Come back later
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1584 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1585 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1586 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1587 return (EBUSY);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1588 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1589 /* Block event processing for this port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1590 cportinfo->cport_event_flags |= SATA_APCTL_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1591 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1592
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1593
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1594 sata_device.satadev_addr.cport = cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1595 sata_device.satadev_addr.pmport = pmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1596 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1597
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1598 switch (ioc.cmd) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1599
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1600 case SATA_CFGA_RESET_PORT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1601 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1602 * There is no protection here for configured
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1603 * device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1604 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1605
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1606 /* Sanity check */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1607 if (SATA_RESET_DPORT_FUNC(sata_hba_inst) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1608 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1609 "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1610 "sata_hba_tran missing required "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1611 "function sata_tran_reset_dport"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1612 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1613 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1614 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1615
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1616 /* handle cport only for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1617 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1618 if ((*SATA_RESET_DPORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1619 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1620 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1621 "sata_hba_ioctl: reset port: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1622 "failed cport %d pmport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1623 cport, pmport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1624 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1625 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1626 sata_update_port_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1627 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1628 SATA_CPORT_STATE(sata_hba_inst, cport) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1629 SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1630 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1631 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1632 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1633 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1634 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1635 * Since the port was reset, it should be probed and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1636 * attached device reinitialized. At this point the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1637 * port state is unknown - it's state is HBA-specific.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1638 * Re-probe port to get its state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1639 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1640 if (sata_reprobe_port(sata_hba_inst, &sata_device) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1641 SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1642 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1643 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1644 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1645 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1646
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1647 case SATA_CFGA_RESET_DEVICE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1648 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1649 * There is no protection here for configured
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1650 * device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1651 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1652
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1653 /* Sanity check */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1654 if (SATA_RESET_DPORT_FUNC(sata_hba_inst) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1655 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1656 "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1657 "sata_hba_tran missing required "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1658 "function sata_tran_reset_dport"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1659 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1660 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1661 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1662
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1663 /* handle only device attached to cports, for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1664 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1665
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1666 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1667 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1668 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1669 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1670 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1671 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1672 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1673 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1674 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1675 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1676 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1677 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1678
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1679 /* only handle cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1680 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1681 if ((*SATA_RESET_DPORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1682 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1683 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1684 "sata_hba_ioctl: reset device: failed "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1685 "cport %d pmport %d", cport, pmport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1686 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1687 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1688 sata_update_port_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1689 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1690 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1691 * Device info structure remains
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1692 * attached. Another device reset or
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1693 * port disconnect/connect and re-probing is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1694 * needed to change it's state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1695 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1696 sdinfo->satadrv_state &= ~SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1697 sdinfo->satadrv_state |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1698 SATA_DSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1699 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1700 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1701 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1702 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1703 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1704 * Since the device was reset, we expect reset event
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1705 * to be reported and processed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1706 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1707 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1708
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1709 case SATA_CFGA_RESET_ALL:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1710 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1711 int tcport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1712
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1713 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1714 * There is no protection here for configured
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1715 * devices.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1716 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1717 /* Sanity check */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1718 if (SATA_RESET_DPORT_FUNC(sata_hba_inst) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1719 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1720 "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1721 "sata_hba_tran missing required "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1722 "function sata_tran_reset_dport"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1723 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1724 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1725 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1726
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1727 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1728 * Need to lock all ports, not just one.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1729 * If any port is locked by event processing, fail
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1730 * the whole operation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1731 * One port is already locked, but for simplicity
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1732 * lock it again.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1733 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1734 for (tcport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1735 tcport < SATA_NUM_CPORTS(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1736 tcport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1737 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1738 tcport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1739 if (((SATA_CPORT_INFO(sata_hba_inst, tcport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1740 cport_event_flags) &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1741 SATA_EVNT_LOCK_PORT_BUSY) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1742 rv = EBUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1743 mutex_exit(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1744 &SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1745 tcport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1746 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1747 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1748 SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1749 tcport)->cport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1750 SATA_APCTL_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1751 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1752 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1753 tcport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1754 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1755
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1756 if (rv == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1757 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1758 * All cports successfully locked.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1759 * Reset main SATA controller only for now -
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1760 * no PMult.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1761 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1762 sata_device.satadev_addr.qual =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1763 SATA_ADDR_CNTRL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1764
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1765 if ((*SATA_RESET_DPORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1766 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1767 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1768 "sata_hba_ioctl: reset controller "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1769 "failed"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1770 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1771 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1772
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1773 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1774 * Since ports were reset, they should be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1775 * re-probed and attached devices
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1776 * reinitialized.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1777 * At this point port states are unknown,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1778 * Re-probe ports to get their state -
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1779 * cports only for now.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1780 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1781 for (tcport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1782 tcport < SATA_NUM_CPORTS(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1783 tcport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1784 sata_device.satadev_addr.cport =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1785 tcport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1786 sata_device.satadev_addr.qual =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1787 SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1788
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1789 if (sata_reprobe_port(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1790 &sata_device) != SATA_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1791 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1792
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1793 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1794 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1795 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1796 * Unlock all ports
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1797 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1798 for (tcport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1799 tcport < SATA_NUM_CPORTS(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1800 tcport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1801 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1802 tcport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1803 SATA_CPORT_INFO(sata_hba_inst, tcport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1804 cport_event_flags &=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1805 ~SATA_APCTL_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1806 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1807 tcport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1808 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1809
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1810 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1811 * This operation returns EFAULT if either reset
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1812 * controller failed or a re-probbing of any ports
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1813 * failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1814 * We return here, because common return is for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1815 * a single cport operation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1816 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1817 return (rv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1818 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1819
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1820 case SATA_CFGA_PORT_DEACTIVATE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1821 /* Sanity check */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1822 if (SATA_PORT_DEACTIVATE_FUNC(sata_hba_inst) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1823 rv = ENOTSUP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1824 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1825 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1826 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1827 * Arbitrarily unconfigure attached device, if any.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1828 * Even if the unconfigure fails, proceed with the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1829 * port deactivation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1830 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1831
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1832 /* Handle only device attached to cports, for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1833 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1834
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1835 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1836 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1837 cportinfo->cport_state &= ~SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1838 if (cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1839 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1840 * Handle only device attached to cports,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1841 * for now
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1842 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1843 sata_device.satadev_addr.qual =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1844 SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1845 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1846 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1847 if (sdinfo != NULL &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1848 (sdinfo->satadrv_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1849 SATA_VALID_DEV_TYPE)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1850 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1851 * If a target node exists, try to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1852 * offline a device and remove target
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1853 * node.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1854 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1855 mutex_exit(&SATA_CPORT_INFO(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1856 sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1857 tdip = sata_get_target_dip(dip, cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1858 if (tdip != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1859 /* target node exist */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1860 SATADBG1(SATA_DBG_IOCTL_IF,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1861 sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1862 "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1863 "port deactivate: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1864 "target node exists.",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1865 NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1866
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1867 if (ndi_devi_offline(tdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1868 NDI_UNCONFIG) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1869 NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1870 SATA_LOG_D((
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1871 sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1872 CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1873 "sata_hba_ioctl:"
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1874 "port deactivate: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1875 "failed to "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1876 "unconfigure "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1877 "device at cport "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1878 "%d", cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1879 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1880 if (ndi_devi_offline(tdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1881 NDI_DEVI_REMOVE) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1882 NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1883 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1884 * Problem;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1885 * target node remained
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1886 * attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1887 * Too bad...
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1888 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1889 SATA_LOG_D((
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1890 sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1891 CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1892 "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1893 "port deactivate: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1894 "failed to "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1895 "unconfigure "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1896 "device at "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1897 "cport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1898 cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1899 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1900 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1901 mutex_enter(&SATA_CPORT_INFO(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1902 sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1903 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1904 * In any case,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1905 * remove and release sata_drive_info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1906 * structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1907 * (cport attached device ony, for now)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1908 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1909 SATA_CPORTINFO_DRV_INFO(cportinfo) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1910 NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1911 (void) kmem_free((void *)sdinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1912 sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1913 cportinfo->cport_dev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1914 SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1915 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1916 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1917 * Note: PMult info requires different
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1918 * handling. This comment is a placeholder for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1919 * a code handling PMult, to be implemented
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1920 * in phase 2.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1921 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1922 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1923 cportinfo->cport_state &= ~(SATA_STATE_PROBED |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1924 SATA_STATE_PROBING);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1925 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1926 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1927 /* handle cport only for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1928 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1929 /* Just let HBA driver to deactivate port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1930 rval = (*SATA_PORT_DEACTIVATE_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1931 (dip, &sata_device);
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1932 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1933 * Generate sysevent -
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1934 * EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1935 * without the hint
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1936 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1937 sata_gen_sysevent(sata_hba_inst,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1938 &sata_device.satadev_addr, SE_NO_HINT);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
1939
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1940 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1941 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1942 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1943 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1944 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1945 * Port deactivation failure - do not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1946 * change port state unless the state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1947 * returned by HBA indicates a port failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1948 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1949 if (sata_device.satadev_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1950 SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1951 SATA_CPORT_STATE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1952 cport) = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1953 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1954 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1955 "sata_hba_ioctl: port deactivate: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1956 "cannot deactivate SATA cport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1957 cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1958 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1959 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1960 cportinfo->cport_state |= SATA_PSTATE_SHUTDOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1961 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1962 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1963 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1964
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1965 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1966
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1967 case SATA_CFGA_PORT_ACTIVATE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1968 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1969 boolean_t dev_existed = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1970
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1971 /* Sanity check */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1972 if (SATA_PORT_ACTIVATE_FUNC(sata_hba_inst) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1973 rv = ENOTSUP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1974 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1975 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1976 /* handle cport only for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1977 if (cportinfo->cport_state & SATA_PSTATE_SHUTDOWN ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1978 cportinfo->cport_dev_type == SATA_DTYPE_NONE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1979 dev_existed = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1980
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1981 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1982 /* Just let HBA driver to activate port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1983 if ((*SATA_PORT_ACTIVATE_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1984 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1985 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1986 * Port activation failure - do not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1987 * change port state unless the state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1988 * returned by HBA indicates a port failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1989 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1990 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1991 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1992 sata_update_port_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1993 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1994 if (sata_device.satadev_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1995 SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1996 SATA_CPORT_STATE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1997 cport) = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1998 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
1999 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2000 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2001 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2002 "sata_hba_ioctl: port activate: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2003 "cannot activate SATA cport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2004 cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2005 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2006 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2007 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2008 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2009 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2010 cportinfo->cport_state &= ~SATA_PSTATE_SHUTDOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2011 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2012 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2013
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2014 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2015 * Re-probe port to find its current state and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2016 * possibly attached device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2017 * Port re-probing may change the cportinfo device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2018 * type if device is found attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2019 * If port probing failed, the device type would be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2020 * set to SATA_DTYPE_NONE.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2021 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2022 (void) sata_reprobe_port(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2023
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2024 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2025 * Generate sysevent -
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2026 * EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2027 * without the hint.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2028 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2029 sata_gen_sysevent(sata_hba_inst,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2030 &sata_device.satadev_addr, SE_NO_HINT);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2031
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2032 if (dev_existed == FALSE &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2033 cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2034 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2035 * That's the transition from "inactive" port
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2036 * state or active port without a device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2037 * attached to the active port state with
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2038 * a device attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2039 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2040 sata_log(sata_hba_inst, CE_WARN,
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
2041 "SATA device detected at port %d", cport);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2042 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2043
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2044 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2045 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2046
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2047 case SATA_CFGA_PORT_SELF_TEST:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2048
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2049 /* Sanity check */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2050 if (SATA_SELFTEST_FUNC(sata_hba_inst) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2051 rv = ENOTSUP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2052 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2053 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2054 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2055 * There is no protection here for a configured
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2056 * device attached to this port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2057 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2058
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2059 /* only handle cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2060 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2061
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2062 if ((*SATA_SELFTEST_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2063 (dip, &sata_device) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2064 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2065 "sata_hba_ioctl: port selftest: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2066 "failed cport %d pmport %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2067 cport, pmport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2068 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2069 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2070 sata_update_port_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2071 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2072 SATA_CPORT_STATE(sata_hba_inst, cport) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2073 SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2074 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2075 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2076 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2077 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2078 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2079 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2080 * Since the port was reset, it should be probed and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2081 * attached device reinitialized. At this point the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2082 * port state is unknown - it's state is HBA-specific.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2083 * Force port re-probing to get it into a known state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2084 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2085 if (sata_reprobe_port(sata_hba_inst, &sata_device) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2086 SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2087 rv = EIO;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2088 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2089 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2090 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2091
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2092 case SATA_CFGA_GET_DEVICE_PATH:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2093 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2094 char path[MAXPATHLEN];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2095 uint32_t size;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2096
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2097 (void) strcpy(path, "/devices");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2098 if ((tdip = sata_get_target_dip(dip, ioc.port)) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2099 NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2100
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2101 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2102 * No such device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2103 * If this is a request for a size, do not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2104 * return EINVAL for non-exisiting target,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2105 * because cfgadm will indicate a meaningless
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2106 * ioctl failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2107 * If this is a real request for a path,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2108 * indicate invalid argument.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2109 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2110 if (!ioc.get_size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2111 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2112 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2113 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2114 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2115 (void) ddi_pathname(tdip, path + strlen(path));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2116 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2117 size = strlen(path) + 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2118
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2119 if (ioc.get_size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2120 if (ddi_copyout((void *)&size,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2121 ioc.buf, ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2122 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2123 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2124 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2125 if (ioc.bufsiz != size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2126 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2127 } else if (ddi_copyout((void *)&path,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2128 ioc.buf, ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2129 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2130 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2131 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2132 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2133 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2134
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2135 case SATA_CFGA_GET_AP_TYPE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2136 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2137 uint32_t type_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2138 const char *ap_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2139
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2140 /* cport only, no port multiplier support */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2141 switch (SATA_CPORT_DEV_TYPE(sata_hba_inst, cport)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2142 case SATA_DTYPE_NONE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2143 ap_type = "port";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2144 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2145
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2146 case SATA_DTYPE_ATADISK:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2147 ap_type = "disk";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2148 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2149
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2150 case SATA_DTYPE_ATAPICD:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2151 ap_type = "cd/dvd";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2152 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2153
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2154 case SATA_DTYPE_PMULT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2155 ap_type = "pmult";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2156 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2157
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2158 case SATA_DTYPE_UNKNOWN:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2159 ap_type = "unknown";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2160 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2161
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2162 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2163 ap_type = "unsupported";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2164 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2165
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2166 } /* end of dev_type switch */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2167
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2168 type_len = strlen(ap_type) + 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2169
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2170 if (ioc.get_size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2171 if (ddi_copyout((void *)&type_len,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2172 ioc.buf, ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2173 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2174 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2175 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2176 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2177 if (ioc.bufsiz != type_len) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2178 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2179 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2180 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2181 if (ddi_copyout((void *)ap_type, ioc.buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2182 ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2183 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2184 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2185 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2186 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2187
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2188 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2189 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2190
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2191 case SATA_CFGA_GET_MODEL_INFO:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2192 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2193 uint32_t info_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2194 char ap_info[sizeof (sdinfo->satadrv_id.ai_model) + 1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2195
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2196 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2197 * This operation should return to cfgadm the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2198 * device model information string
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2199 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2200 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2201 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2202 /* only handle device connected to cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2203 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2204 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2205 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2206 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2207 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2208 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2209 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2210 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2211 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2212 bcopy(sdinfo->satadrv_id.ai_model, ap_info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2213 sizeof (sdinfo->satadrv_id.ai_model));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2214 swab(ap_info, ap_info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2215 sizeof (sdinfo->satadrv_id.ai_model));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2216 ap_info[sizeof (sdinfo->satadrv_id.ai_model)] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2217
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2218 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2219 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2220
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2221 info_len = strlen(ap_info) + 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2222
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2223 if (ioc.get_size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2224 if (ddi_copyout((void *)&info_len,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2225 ioc.buf, ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2226 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2227 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2228 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2229 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2230 if (ioc.bufsiz < info_len) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2231 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2232 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2233 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2234 if (ddi_copyout((void *)ap_info, ioc.buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2235 ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2236 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2237 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2238 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2239 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2240
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2241 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2242 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2243
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2244 case SATA_CFGA_GET_REVFIRMWARE_INFO:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2245 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2246 uint32_t info_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2247 char ap_info[
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2248 sizeof (sdinfo->satadrv_id.ai_fw) + 1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2249
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2250 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2251 * This operation should return to cfgadm the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2252 * device firmware revision information string
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2253 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2254 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2255 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2256 /* only handle device connected to cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2257 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2259 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2260 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2261 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2262 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2263 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2264 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2265 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2266 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2267 bcopy(sdinfo->satadrv_id.ai_fw, ap_info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2268 sizeof (sdinfo->satadrv_id.ai_fw));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2269 swab(ap_info, ap_info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2270 sizeof (sdinfo->satadrv_id.ai_fw));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2271 ap_info[sizeof (sdinfo->satadrv_id.ai_fw)] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2272
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2273 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2274 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2275
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2276 info_len = strlen(ap_info) + 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2277
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2278 if (ioc.get_size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2279 if (ddi_copyout((void *)&info_len,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2280 ioc.buf, ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2281 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2282 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2283 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2284 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2285 if (ioc.bufsiz < info_len) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2286 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2287 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2288 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2289 if (ddi_copyout((void *)ap_info, ioc.buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2290 ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2291 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2292 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2293 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2294 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2295
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2296 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2297 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2298
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2299 case SATA_CFGA_GET_SERIALNUMBER_INFO:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2300 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2301 uint32_t info_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2302 char ap_info[
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2303 sizeof (sdinfo->satadrv_id.ai_drvser) + 1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2304
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2305 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2306 * This operation should return to cfgadm the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2307 * device serial number information string
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2308 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2309 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2310 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2311 /* only handle device connected to cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2312 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2313
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2314 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2315 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2316 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2317 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2318 cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2319 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2320 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2321 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2322 bcopy(sdinfo->satadrv_id.ai_drvser, ap_info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2323 sizeof (sdinfo->satadrv_id.ai_drvser));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2324 swab(ap_info, ap_info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2325 sizeof (sdinfo->satadrv_id.ai_drvser));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2326 ap_info[sizeof (sdinfo->satadrv_id.ai_drvser)] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2327
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2328 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2329 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2330
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2331 info_len = strlen(ap_info) + 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2332
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2333 if (ioc.get_size) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2334 if (ddi_copyout((void *)&info_len,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2335 ioc.buf, ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2336 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2337 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2338 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2339 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2340 if (ioc.bufsiz < info_len) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2341 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2342 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2343 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2344 if (ddi_copyout((void *)ap_info, ioc.buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2345 ioc.bufsiz, mode) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2346 rv = EFAULT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2347 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2348 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2349 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2350
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2351 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2352 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2353
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2354 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2355 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2356 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2357
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2358 } /* End of DEVCTL_AP_CONTROL cmd switch */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2359
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2360 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2361 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2362
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2363 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2364 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2365 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2366 * If we got here, we got an IOCTL that SATA HBA Framework
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2367 * does not recognize. Pass ioctl to HBA driver, in case
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2368 * it could process it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2369 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2370 sata_hba_tran_t *sata_tran = sata_hba_inst->satahba_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2371 dev_info_t *mydip = SATA_DIP(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2372
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2373 SATADBG1(SATA_DBG_IOCTL_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2374 "IOCTL 0x%2x not supported in SATA framework, "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2375 "passthrough to HBA", cmd);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2376
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2377 if (sata_tran->sata_tran_ioctl == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2378 rv = EINVAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2379 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2380 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2381 rval = (*sata_tran->sata_tran_ioctl)(mydip, cmd, arg);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2382 if (rval != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2383 SATADBG1(SATA_DBG_IOCTL_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2384 "IOCTL 0x%2x failed in HBA", cmd);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2385 rv = rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2386 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2387 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2388 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2389
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2390 } /* End of main IOCTL switch */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2391
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2392 if (dcp) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2393 ndi_dc_freehdl(dcp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2394 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2395 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2396 cportinfo->cport_event_flags &= ~SATA_APCTL_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2397 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2398
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2399 return (rv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2400 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2401
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2402
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2403
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2404
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2405 /* ****************** SCSA required entry points *********************** */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2406
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2407 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2408 * Implementation of scsi tran_tgt_init.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2409 * sata_scsi_tgt_init() initializes scsi_device structure
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2410 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2411 * If successful, DDI_SUCCESS is returned.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2412 * DDI_FAILURE is returned if addressed device does not exist
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2413 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2414
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2415 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2416 sata_scsi_tgt_init(dev_info_t *hba_dip, dev_info_t *tgt_dip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2417 scsi_hba_tran_t *hba_tran, struct scsi_device *sd)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2418 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2419 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2420 _NOTE(ARGUNUSED(hba_dip))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2421 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2422 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2423 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2424 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2425
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2426 sata_hba_inst = (sata_hba_inst_t *)(hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2427
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2428 /* Validate scsi device address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2429 if (sata_validate_scsi_address(sata_hba_inst, &sd->sd_address,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2430 &sata_device) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2431 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2432
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2433 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2434 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2435
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2436 /* sata_device now contains a valid sata address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2437 sdinfo = sata_get_device_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2438 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2439 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2440 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2441 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2442 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2443 if (sata_device.satadev_type == SATA_DTYPE_ATAPICD) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2444 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2445 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2446 if (ndi_prop_update_string(DDI_DEV_T_NONE, tgt_dip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2447 "variant", "atapi") != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2448 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2449 "sata_scsi_tgt_init: variant atapi "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2450 "property could not be created"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2451 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2452 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2453 return (DDI_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2454 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2455 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2456 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2457 return (DDI_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2458 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2459
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2460 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2461 * Implementation of scsi tran_tgt_probe.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2462 * Probe target, by calling default scsi routine scsi_hba_probe()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2463 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2464 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2465 sata_scsi_tgt_probe(struct scsi_device *sd, int (*callback)(void))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2466 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2467 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2468 (sata_hba_inst_t *)(sd->sd_address.a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2469 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2470
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2471 rval = scsi_hba_probe(sd, callback);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2472
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2473 if (rval == SCSIPROBE_EXISTS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2474 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2475 * Set property "pm-capable" on the target device node, so that
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2476 * the target driver will not try to fetch scsi cycle counters
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2477 * before enabling device power-management.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2478 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2479 if ((ddi_prop_update_int(DDI_DEV_T_NONE, sd->sd_dev,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2480 "pm-capable", 1)) != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2481 sata_log(sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2482 "device at port %d: will not be power-managed ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2483 SCSI_TO_SATA_CPORT(sd->sd_address.a_target));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2484 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2485 "failure updating pm-capable property"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2486 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2487 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2488 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2489 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2490
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2491 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2492 * Implementation of scsi tran_tgt_free.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2493 * Release all resources allocated for scsi_device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2494 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2495 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2496 sata_scsi_tgt_free(dev_info_t *hba_dip, dev_info_t *tgt_dip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2497 scsi_hba_tran_t *hba_tran, struct scsi_device *sd)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2498 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2499 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2500 _NOTE(ARGUNUSED(hba_dip))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2501 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2502 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2503 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2504 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2505
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2506 sata_hba_inst = (sata_hba_inst_t *)(hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2507
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2508 /* Validate scsi device address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2509 if (sata_validate_scsi_address(sata_hba_inst, &sd->sd_address,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2510 &sata_device) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2511 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2512
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2513 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2514 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2515
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2516 /* sata_device now should contain a valid sata address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2517 sdinfo = sata_get_device_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2518 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2519 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2520 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2521 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2522 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2523 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2524 * We did not allocate any resources in sata_scsi_tgt_init()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2525 * other than property for ATAPI device, if any
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2526 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2527 if (sata_device.satadev_type == SATA_DTYPE_ATAPICD) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2528 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2529 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2530 if (ndi_prop_remove(DDI_DEV_T_NONE, tgt_dip, "variant") !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2531 DDI_PROP_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2532 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2533 "sata_scsi_tgt_free: variant atapi "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2534 "property could not be removed"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2535 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2536 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2537 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2538 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2539 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2540
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2541 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2542 * Implementation of scsi tran_init_pkt
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2543 * Upon successful return, scsi pkt buffer has DMA resources allocated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2544 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2545 * It seems that we should always allocate pkt, even if the address is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2546 * for non-existing device - just use some default for dma_attr.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2547 * The reason is that there is no way to communicate this to a caller here.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2548 * Subsequent call to sata_scsi_start may fail appropriately.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2549 * Simply returning NULL does not seem to discourage a target driver...
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2550 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2551 * Returns a pointer to initialized scsi_pkt, or NULL otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2552 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2553 static struct scsi_pkt *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2554 sata_scsi_init_pkt(struct scsi_address *ap, struct scsi_pkt *pkt,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2555 struct buf *bp, int cmdlen, int statuslen, int tgtlen, int flags,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2556 int (*callback)(caddr_t), caddr_t arg)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2557 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2558 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2559 (sata_hba_inst_t *)(ap->a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2560 dev_info_t *dip = SATA_DIP(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2561 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2562 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2563 sata_pkt_txlate_t *spx;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2564 ddi_dma_attr_t cur_dma_attr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2565 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2566 boolean_t new_pkt = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2567
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2568 ASSERT(ap->a_hba_tran->tran_hba_dip == dip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2569
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2570 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2571 * We need to translate the address, even if it could be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2572 * a bogus one, for a non-existing device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2573 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2574 sata_device.satadev_addr.qual = SCSI_TO_SATA_ADDR_QUAL(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2575 sata_device.satadev_addr.cport = SCSI_TO_SATA_CPORT(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2576 sata_device.satadev_addr.pmport = SCSI_TO_SATA_PMPORT(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2577 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2578
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2579 if (pkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2580 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2581 * Have to allocate a brand new scsi packet.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2582 * We need to operate with auto request sense enabled.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2583 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2584 pkt = scsi_hba_pkt_alloc(dip, ap, cmdlen,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2585 MAX(statuslen, sizeof (struct scsi_arq_status)),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2586 tgtlen, sizeof (sata_pkt_txlate_t), callback, arg);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2587
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2588 if (pkt == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2589 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2590
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2591 /* Fill scsi packet structure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2592 pkt->pkt_comp = (void (*)())NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2593 pkt->pkt_time = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2594 pkt->pkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2595 pkt->pkt_statistics = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2596 pkt->pkt_reason = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2597
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2598 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2599 * pkt_hba_private will point to sata pkt txlate structure
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2600 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2601 spx = (sata_pkt_txlate_t *)pkt->pkt_ha_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2602 bzero(spx, sizeof (sata_pkt_txlate_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2603
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2604 spx->txlt_scsi_pkt = pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2605 spx->txlt_sata_hba_inst = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2606
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2607 /* Allocate sata_pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2608 spx->txlt_sata_pkt = sata_pkt_alloc(spx, callback);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2609 if (spx->txlt_sata_pkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2610 /* Could not allocate sata pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2611 scsi_hba_pkt_free(ap, pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2612 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2613 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2614 /* Set sata address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2615 spx->txlt_sata_pkt->satapkt_device = sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2616
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2617 if ((bp == NULL) || (bp->b_bcount == 0))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2618 return (pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2619
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2620 spx->txlt_total_residue = bp->b_bcount;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2621 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2622 new_pkt = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2623 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2624 * Packet was preallocated/initialized by previous call
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2625 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2626 spx = (sata_pkt_txlate_t *)pkt->pkt_ha_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2627
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2628 if ((bp == NULL) || (bp->b_bcount == 0)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2629 return (pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2630 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2631 ASSERT(spx->txlt_buf_dma_handle != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2632
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2633 /* Pkt is available already: spx->txlt_scsi_pkt == pkt; */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2634 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2635
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2636 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2637
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2638 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2639 * We use an adjusted version of the dma_attr, to account
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2640 * for device addressing limitations.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2641 * sata_adjust_dma_attr() will handle sdinfo == NULL which may
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2642 * happen when a device is not yet configured.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2643 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2644 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2645 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2646 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2647 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2648 /* NULL sdinfo may be passsed to sata_adjust_dma_attr() */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2649 sata_adjust_dma_attr(sdinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2650 SATA_DMA_ATTR(spx->txlt_sata_hba_inst), &cur_dma_attr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2651 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2652 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2653 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2654 * Allocate necessary DMA resources for the packet's buffer
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2655 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2656 if ((rval = sata_dma_buf_setup(spx, flags, callback, arg,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2657 &cur_dma_attr)) != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2658 sata_pkt_free(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2659 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2660 * If a DMA allocation request fails with
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2661 * DDI_DMA_NOMAPPING, indicate the error by calling
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2662 * bioerror(9F) with bp and an error code of EFAULT.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2663 * If a DMA allocation request fails with
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2664 * DDI_DMA_TOOBIG, indicate the error by calling
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2665 * bioerror(9F) with bp and an error code of EINVAL.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2666 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2667 switch (rval) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2668 case DDI_DMA_NORESOURCES:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2669 bioerror(bp, 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2670 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2671 case DDI_DMA_NOMAPPING:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2672 case DDI_DMA_BADATTR:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2673 bioerror(bp, EFAULT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2674 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2675 case DDI_DMA_TOOBIG:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2676 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2677 bioerror(bp, EINVAL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2678 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2679 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2680 if (new_pkt == TRUE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2681 sata_pkt_free(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2682 scsi_hba_pkt_free(ap, pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2683 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2684 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2685 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2686 /* Set number of bytes that are not yet accounted for */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2687 pkt->pkt_resid = spx->txlt_total_residue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2688 ASSERT(pkt->pkt_resid >= 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2689
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2690 return (pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2691 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2692
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2693 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2694 * Implementation of scsi tran_start.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2695 * Translate scsi cmd into sata operation and return status.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2696 * Supported scsi commands:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2697 * SCMD_INQUIRY
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2698 * SCMD_TEST_UNIT_READY
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2699 * SCMD_START_STOP
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2700 * SCMD_READ_CAPACITY
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2701 * SCMD_REQUEST_SENSE
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
2702 * SCMD_LOG_SENSE_G1
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
2703 * SCMD_LOG_SELECT_G1
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2704 * SCMD_MODE_SENSE (specific pages)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2705 * SCMD_MODE_SENSE_G1 (specific pages)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2706 * SCMD_MODE_SELECT (specific pages)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2707 * SCMD_MODE_SELECT_G1 (specific pages)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2708 * SCMD_SYNCHRONIZE_CACHE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2709 * SCMD_SYNCHRONIZE_CACHE_G1
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2710 * SCMD_READ
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2711 * SCMD_READ_G1
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2712 * SCMD_READ_G4
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2713 * SCMD_READ_G5
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2714 * SCMD_WRITE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2715 * SCMD_WRITE_G1
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2716 * SCMD_WRITE_G4
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2717 * SCMD_WRITE_G5
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2718 * SCMD_SEEK (noop)
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
2719 * SCMD_SDIAG
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2720 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2721 * All other commands are rejected as unsupported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2722 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2723 * Returns:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2724 * TRAN_ACCEPT if command was executed successfully or accepted by HBA driver
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2725 * for execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2726 * TRAN_BADPKT if cmd was directed to invalid address.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2727 * TRAN_FATAL_ERROR is command was rejected due to hardware error, including
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2728 * unexpected removal of a device or some other unspecified error.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2729 * TRAN_BUSY if command could not be executed becasue HBA driver or SATA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2730 * framework was busy performing some other operation(s).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2731 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2732 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2733 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2734 sata_scsi_start(struct scsi_address *ap, struct scsi_pkt *pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2735 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2736 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2737 (sata_hba_inst_t *)(ap->a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2738 sata_pkt_txlate_t *spx = (sata_pkt_txlate_t *)pkt->pkt_ha_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2739 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2740 struct buf *bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2741 int cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2742 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2743
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2744 SATADBG1(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2745 "sata_scsi_start: cmd 0x%02x\n", pkt->pkt_cdbp[0]);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2746
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2747 ASSERT(spx != NULL &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2748 spx->txlt_scsi_pkt == pkt && spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2749
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2750 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2751 * Mutex-protected section below is just to identify device type
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2752 * and switch to ATAPI processing, if necessary
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2753 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2754 cport = SCSI_TO_SATA_CPORT(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2755
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2756 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2757
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2758 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2759 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2760 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2761 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2762 spx->txlt_scsi_pkt->pkt_reason = CMD_DEV_GONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2763 return (TRAN_FATAL_ERROR);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2764 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2765
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2766 if (sdinfo->satadrv_type == SATA_DTYPE_ATAPICD) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2767 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2768 rval = sata_txlt_atapi(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2769 SATADBG1(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2770 "sata_scsi_start atapi: rval %d\n", rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2771 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2772 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2773 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2774
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2775 /* ATA Disk commands processing starts here */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2776
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2777 bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2778
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2779 switch (pkt->pkt_cdbp[0]) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2780
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2781 case SCMD_INQUIRY:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2782 /* Mapped to identify device */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2783 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2784 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2785 rval = sata_txlt_inquiry(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2786 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2787
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2788 case SCMD_TEST_UNIT_READY:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2789 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2790 * SAT "SATA to ATA Translation" doc specifies translation
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2791 * to ATA CHECK POWER MODE.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2792 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2793 rval = sata_txlt_test_unit_ready(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2794 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2795
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2796 case SCMD_START_STOP:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2797 /* Mapping depends on the command */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2798 rval = sata_txlt_start_stop_unit(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2799 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2800
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2801 case SCMD_READ_CAPACITY:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2802 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2803 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2804 rval = sata_txlt_read_capacity(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2805 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2806
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2807 case SCMD_REQUEST_SENSE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2808 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2809 * Always No Sense, since we force ARQ
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2810 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2811 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2812 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2813 rval = sata_txlt_request_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2814 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2815
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2816 case SCMD_LOG_SENSE_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2817 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2818 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2819 rval = sata_txlt_log_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2820 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2821
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2822 case SCMD_LOG_SELECT_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2823 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2824 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2825 rval = sata_txlt_log_select(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2826 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2827
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2828 case SCMD_MODE_SENSE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2829 case SCMD_MODE_SENSE_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2830 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2831 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2832 rval = sata_txlt_mode_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2833 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2834
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2835
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2836 case SCMD_MODE_SELECT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2837 case SCMD_MODE_SELECT_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2838 if (bp != NULL && (bp->b_flags & (B_PHYS | B_PAGEIO)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2839 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2840 rval = sata_txlt_mode_select(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2841 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2842
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2843 case SCMD_SYNCHRONIZE_CACHE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2844 case SCMD_SYNCHRONIZE_CACHE_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2845 rval = sata_txlt_synchronize_cache(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2846 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2847
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2848 case SCMD_READ:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2849 case SCMD_READ_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2850 case SCMD_READ_G4:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2851 case SCMD_READ_G5:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2852 rval = sata_txlt_read(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2853 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2854
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2855 case SCMD_WRITE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2856 case SCMD_WRITE_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2857 case SCMD_WRITE_G4:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2858 case SCMD_WRITE_G5:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2859 rval = sata_txlt_write(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2860 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2861
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2862 case SCMD_SEEK:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2863 rval = sata_txlt_nodata_cmd_immediate(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2864 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2865
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2866 /* Other cases will be filed later */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2867 /* postponed until phase 2 of the development */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2868 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2869 rval = sata_txlt_invalid_command(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2870 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2871 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2872
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2873 SATADBG1(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2874 "sata_scsi_start: rval %d\n", rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2875
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2876 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2877 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2878
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2879 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2880 * Implementation of scsi tran_abort.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2881 * Abort specific pkt or all packets.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2882 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2883 * Returns 1 if one or more packets were aborted, returns 0 otherwise
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2884 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2885 * May be called from an interrupt level.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2886 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2887 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2888 sata_scsi_abort(struct scsi_address *ap, struct scsi_pkt *scsi_pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2889 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2890 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2891 (sata_hba_inst_t *)(ap->a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2892 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2893 sata_pkt_t *sata_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2894
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2895 SATADBG2(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2896 "sata_scsi_abort: %s at target: 0x%x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2897 scsi_pkt == NULL ? "all packets" : "one pkt", ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2898
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2899 /* Validate address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2900 if (sata_validate_scsi_address(sata_hba_inst, ap, &sata_device) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2901 /* Invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2902 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2903
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2904 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2905 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2906 if (sata_get_device_info(sata_hba_inst, &sata_device) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2907 /* invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2908 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2909 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2910 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2911 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2912 if (scsi_pkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2913 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2914 * Abort all packets.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2915 * Although we do not have specific packet, we still need
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2916 * dummy packet structure to pass device address to HBA.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2917 * Allocate one, without sleeping. Fail if pkt cannot be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2918 * allocated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2919 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2920 sata_pkt = kmem_zalloc(sizeof (sata_pkt_t), KM_NOSLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2921 if (sata_pkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2922 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2923 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2924 SATA_LOG_D((sata_hba_inst, CE_WARN, "sata_pkt_abort: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2925 "could not allocate sata_pkt"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2926 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2927 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2928 sata_pkt->satapkt_rev = SATA_PKT_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2929 sata_pkt->satapkt_device = sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2930 sata_pkt->satapkt_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2931 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2932 if (scsi_pkt->pkt_ha_private == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2933 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2934 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2935 return (0); /* Bad scsi pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2936 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2937 /* extract pointer to sata pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2938 sata_pkt = ((sata_pkt_txlate_t *)scsi_pkt->pkt_ha_private)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2939 txlt_sata_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2940 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2941
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2942 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2943 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2944 /* Send abort request to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2945 if ((*SATA_ABORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2946 (SATA_DIP(sata_hba_inst), sata_pkt,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2947 scsi_pkt == NULL ? SATA_ABORT_ALL_PACKETS : SATA_ABORT_PACKET) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2948 SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2949 if (scsi_pkt == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2950 kmem_free(sata_pkt, sizeof (sata_pkt_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2951 /* Success */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2952 return (1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2953 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2954 /* Else, something did not go right */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2955 if (scsi_pkt == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2956 kmem_free(sata_pkt, sizeof (sata_pkt_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2957 /* Failure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2958 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2959 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2960
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2961
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2962 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2963 * Implementation os scsi tran_reset.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2964 * RESET_ALL request is translated into port reset.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2965 * RESET_TARGET requests is translated into a device reset,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2966 * RESET_LUN request is accepted only for LUN 0 and translated into
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2967 * device reset.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2968 * The target reset should cause all HBA active and queued packets to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2969 * be terminated and returned with pkt reason SATA_PKT_RESET prior to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2970 * the return. HBA should report reset event for the device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2971 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2972 * Returns 1 upon success, 0 upon failure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2973 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2974 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2975 sata_scsi_reset(struct scsi_address *ap, int level)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2976 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2977 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2978 (sata_hba_inst_t *)(ap->a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2979 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2980 int val;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2981
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2982 SATADBG2(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2983 "sata_scsi_reset: level %d target: 0x%x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2984 level, ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2985
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2986 /* Validate address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2987 val = sata_validate_scsi_address(sata_hba_inst, ap, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2988 if (val == -1)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2989 /* Invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2990 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2991
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2992 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2993 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2994 if (sata_get_device_info(sata_hba_inst, &sata_device) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2995 /* invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2996 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2997 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2998 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
2999 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3000 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3001 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3002 if (level == RESET_ALL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3003 /* port reset - cport only */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3004 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3005 if ((*SATA_RESET_DPORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3006 (SATA_DIP(sata_hba_inst), &sata_device) == SATA_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3007 return (1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3008 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3009 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3010
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3011 } else if (val == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3012 (level == RESET_TARGET || level == RESET_LUN)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3013 /* reset device (device attached) */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3014 if ((*SATA_RESET_DPORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3015 (SATA_DIP(sata_hba_inst), &sata_device) == SATA_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3016 return (1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3017 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3018 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3019 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3020 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3021 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3022
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3023
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3024 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3025 * Implementation of scsi tran_getcap (get transport/device capabilities).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3026 * Supported capabilities:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3027 * auto-rqsense (always supported)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3028 * tagged-qing (supported if HBA supports it)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3029 * dma_max
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3030 * interconnect-type (INTERCONNECT_SATA)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3031 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3032 * Request for other capabilities is rejected as unsupported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3033 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3034 * Returns supported capability value, or -1 if capability is unsuppported or
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3035 * the address is invalid (no device).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3036 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3037
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3038 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3039 sata_scsi_getcap(struct scsi_address *ap, char *cap, int whom)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3040 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3041
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3042 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3043 (sata_hba_inst_t *)(ap->a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3044 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3045 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3046 ddi_dma_attr_t adj_dma_attr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3047 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3048
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3049 SATADBG2(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3050 "sata_scsi_getcap: target: 0x%x, cap: %s\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3051 ap->a_target, cap);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3052
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3053 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3054 * We want to process the capabilities on per port granularity.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3055 * So, we are specifically restricting ourselves to whom != 0
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3056 * to exclude the controller wide handling.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3057 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3058 if (cap == NULL || whom == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3059 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3060
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3061 if (sata_validate_scsi_address(sata_hba_inst, ap, &sata_device) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3062 /* Invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3063 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3064 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3065 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3066 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3067 if ((sdinfo = sata_get_device_info(sata_hba_inst, &sata_device)) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3068 NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3069 /* invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3070 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3071 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3072 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3073 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3074
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3075 switch (scsi_hba_lookup_capstr(cap)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3076 case SCSI_CAP_ARQ:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3077 rval = 1; /* ARQ supported, turned on */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3078 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3079
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3080 case SCSI_CAP_SECTOR_SIZE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3081 if (sdinfo->satadrv_type == SATA_DTYPE_ATADISK)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3082 rval = SATA_DISK_SECTOR_SIZE; /* fixed size */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3083 else if (sdinfo->satadrv_type == SATA_DTYPE_ATAPICD)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3084 rval = SATA_ATAPI_SECTOR_SIZE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3085 else rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3086 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3087
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3088 case SCSI_CAP_TAGGED_QING:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3089 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3090 * It is enough if the controller supports queuing, regardless
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3091 * of the device. NCQ support is an internal implementation
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3092 * feature used between HBA and the device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3093 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3094 if (SATA_QDEPTH(sata_hba_inst) > 1)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3095 rval = 1; /* Queuing supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3096 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3097 rval = -1; /* Queuing not supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3098 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3099
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3100 case SCSI_CAP_DMA_MAX:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3101 sata_adjust_dma_attr(sdinfo, SATA_DMA_ATTR(sata_hba_inst),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3102 &adj_dma_attr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3103 rval = (int)adj_dma_attr.dma_attr_maxxfer;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3104 /* We rely on the fact that dma_attr_maxxfer < 0x80000000 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3105 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3106
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3107 case SCSI_CAP_INTERCONNECT_TYPE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3108 rval = INTERCONNECT_SATA; /* SATA interconnect type */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3109 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3110
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3111 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3112 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3113 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3114 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3115 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3116 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3117 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3118 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3119
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3120 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3121 * Implementation of scsi tran_setcap
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3122 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3123 * All supported capabilities are fixed/unchangeable.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3124 * Returns 0 for all supported capabilities and valid device, -1 otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3125 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3126 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3127 sata_scsi_setcap(struct scsi_address *ap, char *cap, int value, int whom)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3128 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3129 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3130 _NOTE(ARGUNUSED(value))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3131 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3132 sata_hba_inst_t *sata_hba_inst =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3133 (sata_hba_inst_t *)(ap->a_hba_tran->tran_hba_private);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3134 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3135 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3136
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3137 SATADBG2(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3138 "sata_scsi_setcap: target: 0x%x, cap: %s\n", ap->a_target, cap);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3139
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3140 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3141 * We want to process the capabilities on per port granularity.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3142 * So, we are specifically restricting ourselves to whom != 0
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3143 * to exclude the controller wide handling.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3144 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3145 if (cap == NULL || whom == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3146 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3147 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3148
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3149 if (sata_validate_scsi_address(sata_hba_inst, ap, &sata_device) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3150 /* Invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3151 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3152 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3153 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3154 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3155 if (sata_get_device_info(sata_hba_inst, &sata_device) == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3156 /* invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3157 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3158 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3159 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3160 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3161 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3162 sata_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3163
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3164 switch (scsi_hba_lookup_capstr(cap)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3165 case SCSI_CAP_ARQ:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3166 case SCSI_CAP_SECTOR_SIZE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3167 case SCSI_CAP_TAGGED_QING:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3168 case SCSI_CAP_DMA_MAX:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3169 case SCSI_CAP_INTERCONNECT_TYPE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3170 rval = 0; /* Capability cannot be changed */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3171 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3172
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3173 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3174 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3175 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3176 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3177 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3178 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3179
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3180 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3181 * Implementations of scsi tran_destroy_pkt.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3182 * Free resources allocated by sata_scsi_init_pkt()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3183 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3184 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3185 sata_scsi_destroy_pkt(struct scsi_address *ap, struct scsi_pkt *pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3186 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3187 sata_pkt_txlate_t *spx;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3188
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3189 ASSERT(pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3190 spx = (sata_pkt_txlate_t *)pkt->pkt_ha_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3191
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3192 if (spx->txlt_buf_dma_handle != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3193 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3194 * Free DMA resources - cookies and handles
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3195 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3196 ASSERT(spx->txlt_dma_cookie_list != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3197 (void) kmem_free(spx->txlt_dma_cookie_list,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3198 spx->txlt_dma_cookie_list_len * sizeof (ddi_dma_cookie_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3199 (void) ddi_dma_unbind_handle(spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3200 (void) ddi_dma_free_handle(&spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3201 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3202 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3203 sata_pkt_free(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3204
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3205 scsi_hba_pkt_free(ap, pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3206 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3207
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3208 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3209 * Implementation of scsi tran_dmafree.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3210 * Free DMA resources allocated by sata_scsi_init_pkt()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3211 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3212
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3213 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3214 sata_scsi_dmafree(struct scsi_address *ap, struct scsi_pkt *pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3215 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3216 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3217 _NOTE(ARGUNUSED(ap))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3218 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3219 sata_pkt_txlate_t *spx;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3220
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3221 ASSERT(pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3222 spx = (sata_pkt_txlate_t *)pkt->pkt_ha_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3223
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3224 if (spx->txlt_buf_dma_handle != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3225 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3226 * Free DMA resources - cookies and handles
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3227 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3228 ASSERT(spx->txlt_dma_cookie_list != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3229 (void) kmem_free(spx->txlt_dma_cookie_list,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3230 spx->txlt_dma_cookie_list_len * sizeof (ddi_dma_cookie_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3231 (void) ddi_dma_unbind_handle(spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3232 (void) ddi_dma_free_handle(&spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3233 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3234 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3235
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3236 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3237 * Implementation of scsi tran_sync_pkt.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3238 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3239 * The assumption below is that pkt is unique - there is no need to check ap
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3240 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3241 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3242 sata_scsi_sync_pkt(struct scsi_address *ap, struct scsi_pkt *pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3243 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3244 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3245 _NOTE(ARGUNUSED(ap))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3246 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3247 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3248 sata_pkt_txlate_t *spx = (sata_pkt_txlate_t *)pkt->pkt_ha_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3249
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3250 if (spx->txlt_buf_dma_handle != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3251 if (spx->txlt_sata_pkt != NULL &&
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3252 spx->txlt_sata_pkt->satapkt_cmd.satacmd_flags.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3253 sata_data_direction != SATA_DIR_NODATA_XFER) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3254 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3255 (spx->txlt_sata_pkt->satapkt_cmd.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3256 satacmd_flags.sata_data_direction &
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3257 SATA_DIR_WRITE) ?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3258 DDI_DMA_SYNC_FORDEV : DDI_DMA_SYNC_FORCPU);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3259 if (rval == DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3260 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3261 "sata_scsi_sync_pkt: sync pkt failed"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3262 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3263 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3264 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3265 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3266
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3267
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3268
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3269 /* ******************* SATA - SCSI Translation functions **************** */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3270 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3271 * SCSI to SATA pkt and command translation and SATA to SCSI status/error
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3272 * translation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3273 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3274
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3275 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3276 * Checks if a device exists and can be access and translates common
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3277 * scsi_pkt data to sata_pkt data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3278 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3279 * Returns TRAN_ACCEPT if device exists and sata_pkt was set-up.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3280 * Returns other TRAN_XXXXX values when error occured.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3281 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3282 * This function should be called with port mutex held.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3283 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3284 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3285 sata_txlt_generic_pkt_info(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3286 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3287 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3288 sata_device_t sata_device;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3289 const struct sata_cmd_flags sata_initial_cmd_flags = {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3290 SATA_DIR_NODATA_XFER,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3291 /* all other values to 0/FALSE */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3292 };
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3293
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3294 /* Validate address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3295 switch (sata_validate_scsi_address(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3296 &spx->txlt_scsi_pkt->pkt_address, &sata_device)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3297
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3298 case -1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3299 /* Invalid address or invalid device type */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3300 return (TRAN_BADPKT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3301 case 1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3302 /* valid address but no device - it has disappeared ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3303 spx->txlt_scsi_pkt->pkt_reason = CMD_DEV_GONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3304 return (TRAN_FATAL_ERROR);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3305 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3306 /* all OK */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3307 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3308 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3309 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3310 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3311
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3312 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3313 * If device is in reset condition, reject the packet with
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3314 * TRAN_BUSY
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3315 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3316 if (sdinfo->satadrv_event_flags &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3317 (SATA_EVNT_DEVICE_RESET | SATA_EVNT_INPROC_DEVICE_RESET)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3318 spx->txlt_scsi_pkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3319 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3320 "sata_scsi_start: rejecting command because "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3321 "of device reset state\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3322 return (TRAN_BUSY);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3323 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3324
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3325 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3326 * Fix the dev_type in the sata_pkt->satapkt_device. It was not set by
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3327 * sata_scsi_pkt_init() because pkt init had to work also with
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3328 * non-existing devices.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3329 * Now we know that the packet was set-up for a real device, so its
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3330 * type is known.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3331 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3332 spx->txlt_sata_pkt->satapkt_device.satadev_type = sdinfo->satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3333
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3334 spx->txlt_sata_pkt->satapkt_cmd.satacmd_flags = sata_initial_cmd_flags;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3335
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3336 spx->txlt_scsi_pkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3337
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3338 if ((spx->txlt_scsi_pkt->pkt_flags & FLAG_NOINTR) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3339 /* Synchronous execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3340 spx->txlt_sata_pkt->satapkt_op_mode = SATA_OPMODE_SYNCH |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3341 SATA_OPMODE_POLLING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3342 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3343 /* Asynchronous execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3344 spx->txlt_sata_pkt->satapkt_op_mode = SATA_OPMODE_ASYNCH |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3345 SATA_OPMODE_INTERRUPTS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3346 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3347 /* Convert queuing information */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3348 if (spx->txlt_scsi_pkt->pkt_flags & FLAG_STAG)
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3349 spx->txlt_sata_pkt->satapkt_cmd.satacmd_flags.sata_queue_stag =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3350 B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3351 else if (spx->txlt_scsi_pkt->pkt_flags &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3352 (FLAG_OTAG | FLAG_HTAG | FLAG_HEAD))
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3353 spx->txlt_sata_pkt->satapkt_cmd.satacmd_flags.sata_queue_otag =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3354 B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3355
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3356 /* Always limit pkt time */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3357 if (spx->txlt_scsi_pkt->pkt_time == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3358 spx->txlt_sata_pkt->satapkt_time = sata_default_pkt_time;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3359 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3360 /* Pass on scsi_pkt time */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3361 spx->txlt_sata_pkt->satapkt_time =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3362 spx->txlt_scsi_pkt->pkt_time;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3363
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3364 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3365 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3366
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3367
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3368 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3369 * Translate ATA(ATAPI) Identify (Packet) Device data to SCSI Inquiry data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3370 * SATA Identify Device data has to be valid in sata_rive_info.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3371 * Buffer has to accomodate the inquiry length (36 bytes).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3372 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3373 * This function should be called with a port mutex held.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3374 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3375 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3376 sata_identdev_to_inquiry(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3377 sata_drive_info_t *sdinfo, uint8_t *buf)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3378 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3379
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3380 struct scsi_inquiry *inq = (struct scsi_inquiry *)buf;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3381 struct sata_id *sid = &sdinfo->satadrv_id;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3382
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3383 /* Start with a nice clean slate */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3384 bzero((void *)inq, sizeof (struct scsi_inquiry));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3385
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3386 /* Rely on the dev_type for setting paripheral qualifier */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3387 /* Does DTYPE_RODIRECT apply to CD/DVD R/W devices ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3388 inq->inq_dtype = sdinfo->satadrv_type == SATA_DTYPE_ATADISK ?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3389 DTYPE_DIRECT : DTYPE_RODIRECT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3390
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3391 inq->inq_rmb = sid->ai_config & SATA_REM_MEDIA ? 1 : 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3392 inq->inq_qual = 0; /* Device type qualifier (obsolete in SCSI3? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3393 inq->inq_iso = 0; /* ISO version */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3394 inq->inq_ecma = 0; /* ECMA version */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3395 inq->inq_ansi = 3; /* ANSI version - SCSI 3 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3396 inq->inq_aenc = 0; /* Async event notification cap. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3397 inq->inq_trmiop = 0; /* Supports TERMINATE I/O PROC msg ??? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3398 inq->inq_normaca = 0; /* setting NACA bit supported - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3399 inq->inq_rdf = RDF_SCSI2; /* Response data format- SPC-3 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3400 inq->inq_len = 31; /* Additional length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3401 inq->inq_dualp = 0; /* dual port device - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3402 inq->inq_reladdr = 0; /* Supports relative addressing - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3403 inq->inq_sync = 0; /* Supports synchronous data xfers - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3404 inq->inq_linked = 0; /* Supports linked commands - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3405 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3406 * Queuing support - controller has to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3407 * support some sort of command queuing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3408 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3409 if (SATA_QDEPTH(sata_hba_inst) > 1)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3410 inq->inq_cmdque = 1; /* Supports command queueing - YES */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3411 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3412 inq->inq_cmdque = 0; /* Supports command queueing - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3413 inq->inq_sftre = 0; /* Supports Soft Reset option - NO ??? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3414 inq->inq_wbus32 = 0; /* Supports 32 bit wide data xfers - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3415 inq->inq_wbus16 = 0; /* Supports 16 bit wide data xfers - NO */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3416
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3417 #ifdef _LITTLE_ENDIAN
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3418 /* Swap text fields to match SCSI format */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3419 bcopy("ATA ", inq->inq_vid, 8); /* Vendor ID */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3420 swab(sid->ai_model, inq->inq_pid, 16); /* Product ID */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3421 if (strncmp(&sid->ai_fw[4], " ", 4) == 0)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3422 swab(sid->ai_fw, inq->inq_revision, 4); /* Revision level */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3423 else
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3424 swab(&sid->ai_fw[4], inq->inq_revision, 4); /* Rev. level */
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3425 #else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3426 bcopy(sid->ai_model, inq->inq_vid, 8); /* Vendor ID */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3427 bcopy(&sid->ai_model[8], inq->inq_pid, 16); /* Product ID */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3428 if (strncmp(&sid->ai_fw[4], " ", 4) == 0)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3429 bcopy(sid->ai_fw, inq->inq_revision, 4); /* Revision level */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3430 else
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3431 bcopy(&sid->ai_fw[4], inq->inq_revision, 4); /* Rev. level */
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3432 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3433 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3434
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3435
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3436 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3437 * Scsi response set up for invalid command (command not supported)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3438 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3439 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3440 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3441 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3442 sata_txlt_invalid_command(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3443 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3444 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3445 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3446
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3447 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3448 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3449 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3450
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3451 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3452
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3453 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3454 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3455 sense->es_add_code = SD_SCSI_INVALID_COMMAND_CODE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3456
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3457 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3458 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3459
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3460 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3461 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3462 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3463 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3464 (task_func_t *)spx->txlt_scsi_pkt->pkt_comp,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3465 (void *)spx->txlt_scsi_pkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3466 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3467 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3468 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3469 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3470 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3471
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3472 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3473 * Scsi response setup for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3474 * emulated non-data command that requires no action/return data
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3475 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3476 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3477 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3478 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3479 sata_txlt_nodata_cmd_immediate(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3480 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3481 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3482
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3483 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3484
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3485 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3486 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3487 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3488 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3489 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3490
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3491 spx->txlt_scsi_pkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3492 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3493 spx->txlt_scsi_pkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3494 *(spx->txlt_scsi_pkt->pkt_scbp) = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3495
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3496 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3497 "Scsi_pkt completion reason %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3498 spx->txlt_scsi_pkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3499
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3500 if ((spx->txlt_scsi_pkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3501 spx->txlt_scsi_pkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3502 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3503 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3504 (task_func_t *)spx->txlt_scsi_pkt->pkt_comp,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3505 (void *)spx->txlt_scsi_pkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3506 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3507 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3508 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3509 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3510 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3511
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3512
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3513 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3514 * SATA translate command: Inquiry / Identify Device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3515 * Use cached Identify Device data for now, rather then issuing actual
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3516 * Device Identify cmd request. If device is detached and re-attached,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3517 * asynchromous event processing should fetch and refresh Identify Device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3518 * data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3519 * Two VPD pages are supported now:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3520 * Vital Product Data page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3521 * Unit Serial Number page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3522 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3523 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3524 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3525
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3526 #define EVPD 1 /* Extended Vital Product Data flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3527 #define CMDDT 2 /* Command Support Data - Obsolete */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3528 #define INQUIRY_SUP_VPD_PAGE 0 /* Supported VDP Pages Page COde */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3529 #define INQUIRY_USN_PAGE 0x80 /* Unit Serial Number Page Code */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3530 #define INQUIRY_DEV_IDENTIFICATION_PAGE 0x83 /* Not needed yet */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3531
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3532 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3533 sata_txlt_inquiry(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3534 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3535 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3536 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3537 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3538 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3539 int count;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3540 uint8_t *p;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3541 int i, j;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3542 uint8_t page_buf[0xff]; /* Max length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3543 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3544
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3545 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3546
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3547 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3548 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3549 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3550 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3551
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3552 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3553 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3554
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3555 ASSERT(sdinfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3556
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3557 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3558 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3559 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3560
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3561 /* Reject not supported request */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3562 if (scsipkt->pkt_cdbp[1] & CMDDT) { /* No support for this bit */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3563 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3564 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3565 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3566 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3567 goto done;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3568 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3569
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3570 /* Valid Inquiry request */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3571 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3572
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3573 if (bp != NULL && bp->b_un.b_addr && bp->b_bcount) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3574
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3575 if (!(scsipkt->pkt_cdbp[1] & EVPD)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3576 /* Standard Inquiry Data request */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3577 struct scsi_inquiry inq;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3578 unsigned int bufsize;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3579
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3580 sata_identdev_to_inquiry(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3581 sdinfo, (uint8_t *)&inq);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3582 /* Copy no more than requested */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3583 count = MIN(bp->b_bcount,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3584 sizeof (struct scsi_inquiry));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3585 bufsize = scsipkt->pkt_cdbp[4];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3586 bufsize |= scsipkt->pkt_cdbp[3] << 8;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3587 count = MIN(count, bufsize);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3588 bcopy(&inq, bp->b_un.b_addr, count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3589
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3590 scsipkt->pkt_state |= STATE_XFERRED_DATA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3591 scsipkt->pkt_resid = scsipkt->pkt_cdbp[4] > count ?
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
3592 bufsize - count : 0;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3593 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3594 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3595 * peripheral_qualifier = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3596 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3597 * We are dealing only with HD and will be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3598 * dealing with CD/DVD devices soon
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3599 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3600 uint8_t peripheral_device_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3601 sdinfo->satadrv_type == SATA_DTYPE_ATADISK ?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3602 DTYPE_DIRECT : DTYPE_RODIRECT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3603
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3604 switch ((uint_t)scsipkt->pkt_cdbp[2]) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3605 case INQUIRY_SUP_VPD_PAGE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3606 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3607 * Request for suported Vital Product Data
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3608 * pages - assuming only 2 page codes
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3609 * supported
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3610 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3611 page_buf[0] = peripheral_device_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3612 page_buf[1] = INQUIRY_SUP_VPD_PAGE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3613 page_buf[2] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3614 page_buf[3] = 2; /* page length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3615 page_buf[4] = INQUIRY_SUP_VPD_PAGE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3616 page_buf[5] = INQUIRY_USN_PAGE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3617 /* Copy no more than requested */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3618 count = MIN(bp->b_bcount, 6);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3619 bcopy(page_buf, bp->b_un.b_addr, count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3620 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3621 case INQUIRY_USN_PAGE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3622 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3623 * Request for Unit Serial Number page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3624 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3625 page_buf[0] = peripheral_device_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3626 page_buf[1] = INQUIRY_USN_PAGE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3627 page_buf[2] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3628 page_buf[3] = 20; /* remaining page length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3629 p = (uint8_t *)(sdinfo->satadrv_id.ai_drvser);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3630 #ifdef _LITTLE_ENDIAN
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3631 swab(p, &page_buf[4], 20);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3632 #else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3633 bcopy(p, &page_buf[4], 20);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3634 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3635 for (i = 0; i < 20; i++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3636 if (page_buf[4 + i] == '\0' ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3637 page_buf[4 + i] == '\040') {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3638 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3639 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3640 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3641 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3642 * 'i' contains string length.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3643 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3644 * Least significant character of the serial
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3645 * number shall appear as the last byte,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3646 * according to SBC-3 spec.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3647 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3648 p = &page_buf[20 + 4 - 1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3649 for (j = i; j > 0; j--, p--) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3650 *p = *(p - 20 + i);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3651 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3652 p = &page_buf[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3653 for (j = 20 - i; j > 0; j--) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3654 *p++ = '\040';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3655 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3656 count = MIN(bp->b_bcount, 24);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3657 bcopy(page_buf, bp->b_un.b_addr, count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3658 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3659
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3660 case INQUIRY_DEV_IDENTIFICATION_PAGE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3661 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3662 * We may want to implement this page, when
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3663 * identifiers are common for SATA devices
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3664 * But not now.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3665 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3666 /*FALLTHRU*/
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3667
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3668 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3669 /* Request for unsupported VPD page */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3670 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3671 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3672 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3673 sense->es_add_code =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3674 SD_SCSI_INVALID_FIELD_IN_CDB;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3675 goto done;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3676 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3677 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3678 scsipkt->pkt_state |= STATE_XFERRED_DATA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3679 scsipkt->pkt_resid = scsipkt->pkt_cdbp[4] > count ?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3680 scsipkt->pkt_cdbp[4] - count : 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3681 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3682 done:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3683 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3684
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3685 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3686 "Scsi_pkt completion reason %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3687 scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3688
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3689 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3690 scsipkt->pkt_comp != NULL) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3691 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3692 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3693 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3694 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3695 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3696 return (TRAN_BUSY);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3697 }
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3698 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3699 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3700
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3701 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3702 * SATA translate command: Request Sense
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3703 * emulated command (ATA version so far, no ATAPI)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3704 * Always NO SENSE, because any sense data should be reported by ARQ sense.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3705 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3706 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3707 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3708 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3709 sata_txlt_request_sense(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3710 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3711 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3712 struct scsi_extended_sense sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3713 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3714 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3715
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3716 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3717
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3718 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3719 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3720 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3721 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3722 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3723
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3724
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3725 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3726 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3727 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3728 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3729
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3730 if (bp != NULL && bp->b_un.b_addr && bp->b_bcount) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3731 int count = MIN(bp->b_bcount,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3732 sizeof (struct scsi_extended_sense));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3733 bzero(&sense, sizeof (struct scsi_extended_sense));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3734 sense.es_valid = 0; /* Valid LBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3735 sense.es_class = 7; /* Response code 0x70 - current err */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3736 sense.es_key = KEY_NO_SENSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3737 sense.es_add_len = 6; /* Additional length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3738 /* Copy no more than requested */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3739 bcopy(&sense, bp->b_un.b_addr, count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3740 scsipkt->pkt_state |= STATE_XFERRED_DATA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3741 scsipkt->pkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3742 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3743
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3744 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3745 "Scsi_pkt completion reason %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3746 scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3747
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3748 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3749 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3750 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3751 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3752 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3753 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3754 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3755 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3756 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3757 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3758
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3759 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3760 * SATA translate command: Test Unit Ready
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3761 * At the moment this is an emulated command (ATA version so far, no ATAPI).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3762 * May be translated into Check Power Mode command in the future
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3763 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3764 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3765 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3766 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3767 sata_txlt_test_unit_ready(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3768 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3769 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3770 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3771 int power_state;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3772 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3773
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3774 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3775
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3776 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3777 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3778 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3779 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3780 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3781
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3782 /* At this moment, emulate it rather than execute anything */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3783 power_state = SATA_PWRMODE_ACTIVE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3784
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3785 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3786 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3787 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3788
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3789 switch (power_state) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3790 case SATA_PWRMODE_ACTIVE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3791 case SATA_PWRMODE_IDLE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3792 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3793 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3794 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3795 /* PWR mode standby */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3796 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3797 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3798 sense->es_key = KEY_NOT_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3799 sense->es_add_code = SD_SCSI_LU_NOT_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3800 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3801 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3802
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3803 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3804 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3805
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3806 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3807 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3808 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3809 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3810 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3811 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3812 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3813 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3814
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3815 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3816 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3817
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3818
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3819 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3820 * SATA translate command: Start Stop Unit
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3821 * Translation depends on a command:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3822 * Start Unit translated into Idle Immediate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3823 * Stop Unit translated into Standby Immediate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3824 * Unload Media / NOT SUPPORTED YET
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3825 * Load Media / NOT SUPPROTED YET
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3826 * Power condition bits are ignored, so is Immediate bit
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3827 * Requesting synchronous execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3828 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3829 * Returns TRAN_ACCEPT or code returned by sata_hba_start() and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3830 * appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3831 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3832 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3833 sata_txlt_start_stop_unit(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3834 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3835 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3836 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3837 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3838 sata_hba_inst_t *shi = SATA_TXLT_HBA_INST(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3839 int cport = SATA_TXLT_CPORT(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3840 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3841 int synch;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3842
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3843 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3844 "sata_txlt_start_stop_unit: %d\n", scsipkt->pkt_scbp[4] & 1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3845
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3846 mutex_enter(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3847
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3848 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3849 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3850 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3851 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3852
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3853 if (scsipkt->pkt_cdbp[4] & 2) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3854 /* Load/Unload Media - invalid request */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3855 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3856 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3857 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3858 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3859 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3860
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3861 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3862 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3863
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3864 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3865 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3866 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3867 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3868 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3869 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3870 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3871 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3872
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3873 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3874 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3875 scmd->satacmd_addr_type = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3876 scmd->satacmd_sec_count_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3877 scmd->satacmd_lba_low_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3878 scmd->satacmd_lba_mid_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3879 scmd->satacmd_lba_high_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3880 scmd->satacmd_features_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3881 scmd->satacmd_device_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3882 scmd->satacmd_status_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3883 if (scsipkt->pkt_cdbp[4] & 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3884 /* Start Unit */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3885 scmd->satacmd_cmd_reg = SATAC_IDLE_IM;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3886 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3887 /* Stop Unit */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3888 scmd->satacmd_cmd_reg = SATAC_STANDBY_IM;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3889 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3890
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3891 if (!(spx->txlt_sata_pkt->satapkt_op_mode & SATA_OPMODE_SYNCH)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3892 /* Need to set-up a callback function */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3893 spx->txlt_sata_pkt->satapkt_comp =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3894 sata_txlt_nodata_cmd_completion;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3895 synch = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3896 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3897 spx->txlt_sata_pkt->satapkt_op_mode = SATA_OPMODE_SYNCH;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3898 synch = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3899 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3900
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3901 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3902 if (sata_hba_start(spx, &rval) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3903 /* Pkt not accepted for execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3904 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3905 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3906 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3907
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3908 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3909 * If execution is non-synchronous,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3910 * a callback function will handle potential errors, translate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3911 * the response and will do a callback to a target driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3912 * If it was synchronous, check execution status using the same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3913 * framework callback.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3914 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3915 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3916 if (synch) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3917 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3918 "synchronous execution status %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3919 spx->txlt_sata_pkt->satapkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3920
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3921 sata_txlt_nodata_cmd_completion(spx->txlt_sata_pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3922 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3923 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3924
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3925 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3926
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3927
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3928 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3929 * SATA translate command: Read Capacity.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3930 * Emulated command for SATA disks.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3931 * Capacity is retrieved from cached Idenifty Device data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3932 * Identify Device data shows effective disk capacity, not the native
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3933 * capacity, which may be limitted by Set Max Address command.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3934 * This is ATA version (non-ATAPI).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3935 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3936 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3937 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3938 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3939 sata_txlt_read_capacity(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3940 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3941 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3942 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3943 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3944 uint64_t val;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3945 uchar_t *rbuf;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3946 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3947
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3948 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3949 "sata_txlt_read_capacity: ", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3950
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3951 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3952
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3953 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3954 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3955 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3956 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3957
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3958 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3959 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3960 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3961 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3962 if (bp != NULL && bp->b_un.b_addr && bp->b_bcount) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3963 sdinfo = sata_get_device_info(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3964 spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3965 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3966 /* Last logical block address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3967 val = sdinfo->satadrv_capacity - 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3968 rbuf = (uchar_t *)bp->b_un.b_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3969 /* Need to swap endians to match scsi format */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3970 rbuf[0] = (val >> 24) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3971 rbuf[1] = (val >> 16) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3972 rbuf[2] = (val >> 8) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3973 rbuf[3] = val & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3974 /* block size - always 512 bytes, for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3975 rbuf[4] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3976 rbuf[5] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3977 rbuf[6] = 0x02;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3978 rbuf[7] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3979 scsipkt->pkt_state |= STATE_XFERRED_DATA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3980 scsipkt->pkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3981
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3982 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst, "%d\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3983 sdinfo->satadrv_capacity -1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3984 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3985 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3986 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3987 * If a callback was requested, do it now.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3988 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3989 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3990 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3991
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3992 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3993 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
3994 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3995 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3996 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3997 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3998 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
3999 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4000
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4001 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4002 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4003
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4004 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4005 * SATA translate command: Mode Sense.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4006 * Translated into appropriate SATA command or emulated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4007 * Saved Values Page Control (03) are not supported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4008 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4009 * NOTE: only caching mode sense page is currently implemented.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4010 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4011 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4012 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4013
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4014 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4015 sata_txlt_mode_sense(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4016 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4017 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4018 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4019 sata_drive_info_t *sdinfo;
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4020 sata_id_t *sata_id;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4021 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4022 int len, bdlen, count, alc_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4023 int pc; /* Page Control code */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4024 uint8_t *buf; /* mode sense buffer */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4025 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4026
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4027 SATADBG2(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4028 "sata_txlt_mode_sense, pc %x page code 0x%02x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4029 spx->txlt_scsi_pkt->pkt_cdbp[2] >> 6,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4030 spx->txlt_scsi_pkt->pkt_cdbp[2] & 0x3f);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4031
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4032 buf = kmem_zalloc(1024, KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4033
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4034 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4035
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4036 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4037 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4038 kmem_free(buf, 1024);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4039 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4040 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4041
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4042 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4043 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4044 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4045
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4046 pc = scsipkt->pkt_cdbp[2] >> 6;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4047
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4048 if (bp != NULL && bp->b_un.b_addr && bp->b_bcount) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4049 len = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4050 bdlen = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4051 if (!(scsipkt->pkt_cdbp[1] & 8)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4052 if (scsipkt->pkt_cdbp[0] == SCMD_MODE_SENSE_G1 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4053 (scsipkt->pkt_cdbp[0] & 0x10))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4054 bdlen = 16;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4055 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4056 bdlen = 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4057 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4058 /* Build mode parameter header */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4059 if (spx->txlt_scsi_pkt->pkt_cdbp[0] == SCMD_MODE_SENSE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4060 /* 4-byte mode parameter header */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4061 buf[len++] = 0; /* mode data length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4062 buf[len++] = 0; /* medium type */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4063 buf[len++] = 0; /* dev-specific param */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4064 buf[len++] = bdlen; /* Block Descriptor length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4065 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4066 /* 8-byte mode parameter header */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4067 buf[len++] = 0; /* mode data length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4068 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4069 buf[len++] = 0; /* medium type */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4070 buf[len++] = 0; /* dev-specific param */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4071 if (bdlen == 16)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4072 buf[len++] = 1; /* long lba descriptor */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4073 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4074 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4075 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4076 buf[len++] = 0; /* Block Descriptor length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4077 buf[len++] = bdlen;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4078 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4079
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4080 sdinfo = sata_get_device_info(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4081 spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4082 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4083
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4084 /* Build block descriptor only if not disabled (DBD) */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4085 if ((scsipkt->pkt_cdbp[1] & 0x08) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4086 /* Block descriptor - direct-access device format */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4087 if (bdlen == 8) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4088 /* build regular block descriptor */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4089 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4090 (sdinfo->satadrv_capacity >> 24) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4091 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4092 (sdinfo->satadrv_capacity >> 16) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4093 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4094 (sdinfo->satadrv_capacity >> 8) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4095 buf[len++] = sdinfo->satadrv_capacity & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4096 buf[len++] = 0; /* density code */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4097 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4098 if (sdinfo->satadrv_type ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4099 SATA_DTYPE_ATADISK)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4100 buf[len++] = 2;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4101 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4102 /* ATAPI */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4103 buf[len++] = 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4104 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4105 } else if (bdlen == 16) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4106 /* Long LBA Accepted */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4107 /* build long lba block descriptor */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4108 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4109 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4110 (sdinfo->satadrv_capacity >> 56) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4111 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4112 (sdinfo->satadrv_capacity >> 48) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4113 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4114 (sdinfo->satadrv_capacity >> 40) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4115 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4116 (sdinfo->satadrv_capacity >> 32) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4117 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4118 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4119 (sdinfo->satadrv_capacity >> 24) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4120 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4121 (sdinfo->satadrv_capacity >> 16) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4122 buf[len++] =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4123 (sdinfo->satadrv_capacity >> 8) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4124 buf[len++] = sdinfo->satadrv_capacity & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4125 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4126 buf[len++] = 0; /* density code */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4127 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4128 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4129 if (sdinfo->satadrv_type ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4130 SATA_DTYPE_ATADISK)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4131 buf[len++] = 2;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4132 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4133 /* ATAPI */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4134 buf[len++] = 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4135 buf[len++] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4136 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4137 }
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4138
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4139 sata_id = &sdinfo->satadrv_id;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4140
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4141 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4142 * Add requested pages.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4143 * Page 3 and 4 are obsolete and we are not supporting them.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4144 * We deal now with:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4145 * caching (read/write cache control).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4146 * We should eventually deal with following mode pages:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4147 * error recovery (0x01),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4148 * power condition (0x1a),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4149 * exception control page (enables SMART) (0x1c),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4150 * enclosure management (ses),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4151 * protocol-specific port mode (port control).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4152 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4153 switch (scsipkt->pkt_cdbp[2] & 0x3f) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4154 case MODEPAGE_RW_ERRRECOV:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4155 /* DAD_MODE_ERR_RECOV */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4156 /* R/W recovery */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4157 len += sata_build_msense_page_1(sdinfo, pc, buf+len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4158 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4159 case MODEPAGE_CACHING:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4160 /* DAD_MODE_CACHE */
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4161 /* Reject not supported request for saved parameters */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4162 if (pc == 3) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4163 *scsipkt->pkt_scbp = STATUS_CHECK;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4164 sense = sata_arq_sense(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4165 sense->es_key = KEY_ILLEGAL_REQUEST;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4166 sense->es_add_code =
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4167 SD_SCSI_SAVING_PARAMS_NOT_SUP;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4168 goto done;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4169 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4170
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4171 /* caching */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4172 len += sata_build_msense_page_8(sdinfo, pc, buf+len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4173 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4174 case MODEPAGE_INFO_EXCPT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4175 /* exception cntrl */
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4176 if (sata_id->ai_cmdset82 & SATA_SMART_SUPPORTED) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4177 len += sata_build_msense_page_1c(sdinfo, pc,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4178 buf+len);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4179 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4180 else
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4181 goto err;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4182 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4183 case MODEPAGE_POWER_COND:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4184 /* DAD_MODE_POWER_COND */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4185 /* power condition */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4186 len += sata_build_msense_page_1a(sdinfo, pc, buf+len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4187 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4188 case MODEPAGE_ALLPAGES:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4189 /* all pages */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4190 len += sata_build_msense_page_1(sdinfo, pc, buf+len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4191 len += sata_build_msense_page_8(sdinfo, pc, buf+len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4192 len += sata_build_msense_page_1a(sdinfo, pc, buf+len);
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4193 if (sata_id->ai_cmdset82 & SATA_SMART_SUPPORTED) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4194 len += sata_build_msense_page_1c(sdinfo, pc,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4195 buf+len);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4196 }
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4197 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4198 default:
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4199 err:
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4200 /* Invalid request */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4201 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4202 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4203 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4204 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4205 goto done;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4206 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4207
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4208 /* fix total mode data length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4209 if (spx->txlt_scsi_pkt->pkt_cdbp[0] == SCMD_MODE_SENSE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4210 /* 4-byte mode parameter header */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4211 buf[0] = len - 1; /* mode data length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4212 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4213 buf[0] = (len -2) >> 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4214 buf[1] = (len -2) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4215 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4216
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4217
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4218 /* Check allocation length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4219 if (scsipkt->pkt_cdbp[0] == SCMD_MODE_SENSE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4220 alc_len = scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4221 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4222 alc_len = scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4223 alc_len = (len << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4224 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4225 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4226 * We do not check for possible parameters truncation
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4227 * (alc_len < len) assuming that the target driver works
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4228 * correctly. Just avoiding overrun.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4229 * Copy no more than requested and possible, buffer-wise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4230 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4231 count = MIN(alc_len, len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4232 count = MIN(bp->b_bcount, count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4233 bcopy(buf, bp->b_un.b_addr, count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4234
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4235 scsipkt->pkt_state |= STATE_XFERRED_DATA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4236 scsipkt->pkt_resid = alc_len > count ? alc_len - count : 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4237 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4238 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4239 done:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4240 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4241 (void) kmem_free(buf, 1024);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4242
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4243 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4244 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4245
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4246 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4247 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4248 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4249 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4250 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4251 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4252 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4253 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4254
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4255 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4256 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4257
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4259 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4260 * SATA translate command: Mode Select.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4261 * Translated into appropriate SATA command or emulated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4262 * Saving parameters is not supported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4263 * Changing device capacity is not supported (although theoretically
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4264 * possible by executing SET FEATURES/SET MAX ADDRESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4265 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4266 * Assumption is that the target driver is working correctly.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4267 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4268 * More than one SATA command may be executed to perform operations specified
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4269 * by mode select pages. The first error terminates further execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4270 * Operations performed successully are not backed-up in such case.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4271 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4272 * NOTE: only caching mode select page is implemented.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4273 * Caching setup is remembered so it could be re-stored in case of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4274 * an unexpected device reset.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4275 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4276 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4277 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4278
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4279 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4280 sata_txlt_mode_select(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4281 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4282 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4283 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4284 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4285 int len, pagelen, count, pllen;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4286 uint8_t *buf; /* mode select buffer */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4287 int rval, stat;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4288 uint_t nointr_flag;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4289 int dmod = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4290
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4291 SATADBG2(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4292 "sata_txlt_mode_select, pc %x page code 0x%02x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4293 spx->txlt_scsi_pkt->pkt_cdbp[2] >> 6,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4294 spx->txlt_scsi_pkt->pkt_cdbp[2] & 0x3f);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4295
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4296 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4297
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4298 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4299 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4300 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4301 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4302
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4303 rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4304
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4305 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4306 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4307 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4308
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4309 /* Reject not supported request */
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4310 if (! (scsipkt->pkt_cdbp[1] & 0x10)) { /* No support for PF bit = 0 */
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4311 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4312 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4313 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4314 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4315 goto done;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4316 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4317
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4318 if (scsipkt->pkt_cdbp[0] == SCMD_MODE_SELECT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4319 pllen = scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4320 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4321 pllen = scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4322 pllen = (pllen << 8) | scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4323 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4324
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4325 *scsipkt->pkt_scbp = STATUS_GOOD; /* Presumed outcome */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4326
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4327 if (bp != NULL && bp->b_un.b_addr && bp->b_bcount && pllen != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4328 buf = (uint8_t *)bp->b_un.b_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4329 count = MIN(bp->b_bcount, pllen);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4330 scsipkt->pkt_state |= STATE_XFERRED_DATA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4331 scsipkt->pkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4332 pllen = count;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4333
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4334 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4335 * Check the header to skip the block descriptor(s) - we
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4336 * do not support setting device capacity.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4337 * Existing macros do not recognize long LBA dscriptor,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4338 * hence manual calculation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4339 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4340 if (scsipkt->pkt_cdbp[0] == SCMD_MODE_SELECT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4341 /* 6-bytes CMD, 4 bytes header */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4342 if (count <= 4)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4343 goto done; /* header only */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4344 len = buf[3] + 4;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4345 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4346 /* 10-bytes CMD, 8 bytes header */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4347 if (count <= 8)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4348 goto done; /* header only */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4349 len = buf[6];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4350 len = (len << 8) + buf[7] + 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4351 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4352 if (len >= count)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4353 goto done; /* header + descriptor(s) only */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4354
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4355 pllen -= len; /* remaining data length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4356
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4357 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4358 * We may be executing SATA command and want to execute it
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4359 * in SYNCH mode, regardless of scsi_pkt setting.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4360 * Save scsi_pkt setting and indicate SYNCH mode
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4361 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4362 nointr_flag = scsipkt->pkt_flags & FLAG_NOINTR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4363 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4364 scsipkt->pkt_comp != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4365 scsipkt->pkt_flags |= FLAG_NOINTR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4366 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4367 spx->txlt_sata_pkt->satapkt_op_mode = SATA_OPMODE_SYNCH;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4368
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4369 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4370 * len is now the offset to a first mode select page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4371 * Process all pages
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4372 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4373 while (pllen > 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4374 switch ((int)buf[len]) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4375 case MODEPAGE_CACHING:
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4376 /* No support for SP (saving) */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4377 if (scsipkt->pkt_cdbp[1] & 0x01) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4378 *scsipkt->pkt_scbp = STATUS_CHECK;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4379 sense = sata_arq_sense(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4380 sense->es_key = KEY_ILLEGAL_REQUEST;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4381 sense->es_add_code =
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4382 SD_SCSI_INVALID_FIELD_IN_CDB;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4383 goto done;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4384 }
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4385 stat = sata_mode_select_page_8(spx,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4386 (struct mode_cache_scsi3 *)&buf[len],
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4387 pllen, &pagelen, &rval, &dmod);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4388 /*
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4389 * The pagelen value indicates the number of
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4390 * parameter bytes already processed.
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4391 * The rval is the return value from
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4392 * sata_tran_start().
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4393 * The stat indicates the overall status of
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4394 * the operation(s).
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4395 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4396 if (stat != SATA_SUCCESS)
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4397 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4398 * Page processing did not succeed -
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4399 * all error info is already set-up,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4400 * just return
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4401 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4402 pllen = 0; /* this breaks the loop */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4403 else {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4404 len += pagelen;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4405 pllen -= pagelen;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4406 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4407 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4408
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4409 case MODEPAGE_INFO_EXCPT:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4410 stat = sata_mode_select_page_1c(spx,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4411 (struct mode_info_excpt_page *)&buf[len],
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4412 pllen, &pagelen, &rval, &dmod);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4413 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4414 * The pagelen value indicates the number of
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4415 * parameter bytes already processed.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
4416 * The rval is the return value from
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4417 * sata_tran_start().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4418 * The stat indicates the overall status of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4419 * the operation(s).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4420 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4421 if (stat != SATA_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4422 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4423 * Page processing did not succeed -
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4424 * all error info is already set-up,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4425 * just return
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4426 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4427 pllen = 0; /* this breaks the loop */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4428 else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4429 len += pagelen;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4430 pllen -= pagelen;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4431 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4432 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4433
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4434 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4435 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4436 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4437 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4438 sense->es_add_code =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4439 SD_SCSI_INVALID_FIELD_IN_PARAMETER_LIST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4440 goto done;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4441 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4442 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4443 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4444 done:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4445 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4446 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4447 * If device parameters were modified, fetch and store the new
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4448 * Identify Device data. Since port mutex could have been released
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4449 * for accessing HBA driver, we need to re-check device existence.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4450 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4451 if (dmod != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4452 sata_drive_info_t new_sdinfo, *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4453 int rv;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4454
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4455 new_sdinfo.satadrv_addr =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4456 spx->txlt_sata_pkt->satapkt_device.satadev_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4457 rv = sata_fetch_device_identify_data(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4458 &new_sdinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4459
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4460 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4461 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4462 * Since port mutex could have been released when
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4463 * accessing HBA driver, we need to re-check that the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4464 * framework still holds the device info structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4465 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4466 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4467 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4468 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4469 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4470 * Device still has info structure in the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4471 * sata framework. Copy newly fetched info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4472 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4473 if (rv == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4474 sdinfo->satadrv_id = new_sdinfo.satadrv_id;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4475 sata_save_drive_settings(sdinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4476 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4477 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4478 * Could not fetch new data - invalidate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4479 * sata_drive_info. That makes device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4480 * unusable.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4481 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4482 sdinfo->satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4483 sdinfo->satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4484 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4485 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4486 if (rv != 0 || sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4487 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4488 * This changes the overall mode select completion
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4489 * reason to a failed one !!!!!
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4490 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4491 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4492 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4493 scsipkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4494 rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4495 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4496 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4497 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4498 /* Restore the scsi pkt flags */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4499 scsipkt->pkt_flags &= ~FLAG_NOINTR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4500 scsipkt->pkt_flags |= nointr_flag;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4501
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4502 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4503 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4504
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4505 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4506 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4507 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4508 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4509 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4510 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4511 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4512 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4513
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4514 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4515 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4516
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4517
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4518
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4519 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4520 * Translate command: Log Sense
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4521 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4522 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4523 sata_txlt_log_sense(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4524 {
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4525 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4526 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4527 sata_drive_info_t *sdinfo;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4528 struct scsi_extended_sense *sense;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4529 int len, count, alc_len;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4530 int pc; /* Page Control code */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4531 int page_code; /* Page code */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4532 uint8_t *buf; /* log sense buffer */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4533 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4534 #define MAX_LOG_SENSE_PAGE_SIZE 512
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4535
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4536 SATADBG2(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4537 "sata_txlt_log_sense, pc 0x%x, page code 0x%x\n",
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4538 spx->txlt_scsi_pkt->pkt_cdbp[2] >> 6,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4539 spx->txlt_scsi_pkt->pkt_cdbp[2] & 0x3f);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4540
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4541 buf = kmem_zalloc(MAX_LOG_SENSE_PAGE_SIZE, KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4542
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4543 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4544
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4545 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4546 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4547 kmem_free(buf, MAX_LOG_SENSE_PAGE_SIZE);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4548 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4549 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4550
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4551 scsipkt->pkt_reason = CMD_CMPLT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4552 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4553 STATE_SENT_CMD | STATE_GOT_STATUS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4554
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4555 pc = scsipkt->pkt_cdbp[2] >> 6;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4556 page_code = scsipkt->pkt_cdbp[2] & 0x3f;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4557
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4558 /* Reject not supported request for all but cummulative values */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4559 switch (pc) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4560 case PC_CUMMULATIVE_VALUES:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4561 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4562 default:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4563 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4564 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4565 sense->es_key = KEY_ILLEGAL_REQUEST;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4566 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4567 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4568 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4569
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4570 switch (page_code) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4571 case PAGE_CODE_GET_SUPPORTED_LOG_PAGES:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4572 case PAGE_CODE_SELF_TEST_RESULTS:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4573 case PAGE_CODE_INFORMATION_EXCEPTIONS:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4574 case PAGE_CODE_SMART_READ_DATA:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4575 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4576 default:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4577 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4578 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4579 sense->es_key = KEY_ILLEGAL_REQUEST;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4580 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4581 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4582 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4583
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4584 if (bp != NULL && bp->b_un.b_addr && bp->b_bcount) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4585 sata_id_t *sata_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4586 len = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4587
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4588 /* Build log parameter header */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4589 buf[len++] = page_code; /* page code as in the CDB */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4590 buf[len++] = 0; /* reserved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4591 buf[len++] = 0; /* Zero out page length for now (MSB) */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4592 buf[len++] = 0; /* (LSB) */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4593
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4594 sdinfo = sata_get_device_info(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4595 spx->txlt_sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4596 &spx->txlt_sata_pkt->satapkt_device);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4597
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4598
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4599 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4600 * Add requested pages.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4601 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4602 switch (page_code) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4603 case PAGE_CODE_GET_SUPPORTED_LOG_PAGES:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4604 len = sata_build_lsense_page_0(sdinfo, buf + len);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4605 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4606 case PAGE_CODE_SELF_TEST_RESULTS:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4607 sata_id = &sdinfo->satadrv_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4608 if ((! (sata_id->ai_cmdset84 &
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4609 SATA_SMART_SELF_TEST_SUPPORTED)) ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4610 (! (sata_id->ai_features87 &
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4611 SATA_SMART_SELF_TEST_SUPPORTED))) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4612 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4613 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4614 sense->es_key = KEY_ILLEGAL_REQUEST;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4615 sense->es_add_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4616 SD_SCSI_INVALID_FIELD_IN_CDB;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4617
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4618 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4619 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4620 len = sata_build_lsense_page_10(sdinfo, buf + len,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4621 spx->txlt_sata_hba_inst);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4622 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4623 case PAGE_CODE_INFORMATION_EXCEPTIONS:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4624 sata_id = &sdinfo->satadrv_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4625 if (! (sata_id->ai_cmdset82 & SATA_SMART_SUPPORTED)) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4626 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4627 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4628 sense->es_key = KEY_ILLEGAL_REQUEST;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4629 sense->es_add_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4630 SD_SCSI_INVALID_FIELD_IN_CDB;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4631
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4632 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4633 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4634 if (! (sata_id->ai_features85 & SATA_SMART_ENABLED)) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4635 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4636 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4637 sense->es_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4638 sense->es_add_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4639 SCSI_ASC_ATA_DEV_FEAT_NOT_ENABLED;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4640 sense->es_qual_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4641 SCSI_ASCQ_ATA_DEV_FEAT_NOT_ENABLED;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4642
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4643 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4644 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4645
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4646 len = sata_build_lsense_page_2f(sdinfo, buf + len,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4647 spx->txlt_sata_hba_inst);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4648 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4649 case PAGE_CODE_SMART_READ_DATA:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4650 sata_id = &sdinfo->satadrv_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4651 if (! (sata_id->ai_cmdset82 & SATA_SMART_SUPPORTED)) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4652 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4653 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4654 sense->es_key = KEY_ILLEGAL_REQUEST;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4655 sense->es_add_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4656 SD_SCSI_INVALID_FIELD_IN_CDB;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4657
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4658 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4659 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4660 if (! (sata_id->ai_features85 & SATA_SMART_ENABLED)) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4661 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4662 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4663 sense->es_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4664 sense->es_add_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4665 SCSI_ASC_ATA_DEV_FEAT_NOT_ENABLED;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4666 sense->es_qual_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4667 SCSI_ASCQ_ATA_DEV_FEAT_NOT_ENABLED;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4668
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4669 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4670 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4671
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4672 /* This page doesn't include a page header */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4673 len = sata_build_lsense_page_30(sdinfo, buf,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4674 spx->txlt_sata_hba_inst);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4675 goto no_header;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4676 default:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4677 /* Invalid request */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4678 *scsipkt->pkt_scbp = STATUS_CHECK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4679 sense = sata_arq_sense(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4680 sense->es_key = KEY_ILLEGAL_REQUEST;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4681 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4682 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4683 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4684
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4685 /* set parameter log sense data length */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4686 buf[2] = len >> 8; /* log sense length (MSB) */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4687 buf[3] = len & 0xff; /* log sense length (LSB) */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4688
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4689 len += SCSI_LOG_PAGE_HDR_LEN;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4690 ASSERT(len <= MAX_LOG_SENSE_PAGE_SIZE);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4691
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4692 no_header:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4693 /* Check allocation length */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4694 alc_len = scsipkt->pkt_cdbp[7];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4695 alc_len = (len << 8) | scsipkt->pkt_cdbp[8];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4696
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4697 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4698 * We do not check for possible parameters truncation
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4699 * (alc_len < len) assuming that the target driver works
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4700 * correctly. Just avoiding overrun.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4701 * Copy no more than requested and possible, buffer-wise.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4702 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4703 count = MIN(alc_len, len);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4704 count = MIN(bp->b_bcount, count);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4705 bcopy(buf, bp->b_un.b_addr, count);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4706
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4707 scsipkt->pkt_state |= STATE_XFERRED_DATA;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4708 scsipkt->pkt_resid = alc_len > count ? alc_len - count : 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4709 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4710 *scsipkt->pkt_scbp = STATUS_GOOD;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4711 done:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4712 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4713 (void) kmem_free(buf, MAX_LOG_SENSE_PAGE_SIZE);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4714
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4715 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4716 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4717
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4718 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4719 scsipkt->pkt_comp != NULL)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4720 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4721 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4722 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4723 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4724 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
4725 return (TRAN_BUSY);
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4726
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4727 return (TRAN_ACCEPT);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4728 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4729
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4730 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4731 * Translate command: Log Select
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4732 * Not implemented at this time - returns invalid command response.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4733 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4734 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4735 sata_txlt_log_select(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4736 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4737 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4738 "sata_txlt_log_select\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4739
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4740 return (sata_txlt_invalid_command(spx));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4741 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4742
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4743
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4744 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4745 * Translate command: Read (various types).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4746 * Translated into appropriate type of ATA READ command
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4747 * (NO ATAPI implementation yet).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4748 * Both the device capabilities and requested operation mode are
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4749 * considered.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4750 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4751 * Following scsi cdb fields are ignored:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4752 * rdprotect, dpo, fua, fua_nv, group_number.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4753 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4754 * If SATA_ENABLE_QUEUING flag is set (in the global SATA HBA framework
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4755 * enable variable sata_func_enable), the capability of the controller and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4756 * capability of a device are checked and if both support queueing, read
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4757 * request will be translated to READ_DMA_QUEUEING or READ_DMA_QUEUEING_EXT
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4758 * command rather than plain READ_XXX command.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4759 * If SATA_ENABLE_NCQ flag is set in addition to SATA_ENABLE_QUEUING flag and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4760 * both the controller and device suport such functionality, the read
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4761 * request will be translated to READ_FPDMA_QUEUED command.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4762 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4763 * Returns TRAN_ACCEPT or code returned by sata_hba_start() and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4764 * appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4765 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4766 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4767 sata_txlt_read(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4768 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4769 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4770 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4771 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4772 sata_hba_inst_t *shi = SATA_TXLT_HBA_INST(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4773 int cport = SATA_TXLT_CPORT(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4774 uint16_t sec_count;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4775 uint64_t lba;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4776 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4777 int synch;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4778
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4779 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4780
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4781 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4782 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4783 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4784 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4785
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4786 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4787 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4788
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4789 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4790 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4791 * Build cmd block depending on the device capability and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4792 * requested operation mode.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4793 * Do not bother with non-dma mode.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4794 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4795 switch ((uint_t)scsipkt->pkt_cdbp[0]) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4796 case SCMD_READ:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4797 /* 6-byte scsi read cmd : 0x08 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4798 lba = (scsipkt->pkt_cdbp[1] & 0x1f);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4799 lba = (lba << 8) | scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4800 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4801 sec_count = scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4802 /* sec_count 0 will be interpreted as 256 by a device */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4803 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4804 case SCMD_READ_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4805 /* 10-bytes scsi read command : 0x28 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4806 lba = scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4807 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4808 lba = (lba << 8) | scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4809 lba = (lba << 8) | scsipkt->pkt_cdbp[5];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4810 sec_count = scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4811 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4812 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4813 case SCMD_READ_G5:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4814 /* 12-bytes scsi read command : 0xA8 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4815 lba = scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4816 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4817 lba = (lba << 8) | scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4818 lba = (lba << 8) | scsipkt->pkt_cdbp[5];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4819 sec_count = scsipkt->pkt_cdbp[6];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4820 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4821 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4822 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[9];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4823 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4824 case SCMD_READ_G4:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4825 /* 16-bytes scsi read command : 0x88 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4826 lba = scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4827 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4828 lba = (lba << 8) | scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4829 lba = (lba << 8) | scsipkt->pkt_cdbp[5];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4830 lba = (lba << 8) | scsipkt->pkt_cdbp[6];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4831 lba = (lba << 8) | scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4832 lba = (lba << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4833 lba = (lba << 8) | scsipkt->pkt_cdbp[9];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4834 sec_count = scsipkt->pkt_cdbp[10];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4835 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[11];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4836 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[12];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4837 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[13];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4838 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4839 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4840 /* Unsupported command */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4841 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4842 return (sata_txlt_invalid_command(spx));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4843 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4844
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4845 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4846 * Check if specified address exceeds device capacity
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4847 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4848 if ((lba >= sdinfo->satadrv_capacity) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4849 ((lba + sec_count) >= sdinfo->satadrv_capacity)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4850 /* LBA out of range */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4851 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4852 return (sata_txlt_lba_out_of_range(spx));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4853 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4854
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4855 scmd->satacmd_addr_type = ATA_ADDR_LBA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4856 scmd->satacmd_device_reg = SATA_ADH_LBA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4857 scmd->satacmd_cmd_reg = SATAC_READ_DMA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4858 if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA48) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4859 scmd->satacmd_addr_type = ATA_ADDR_LBA48;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4860 scmd->satacmd_cmd_reg = SATAC_READ_DMA_EXT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4861 scmd->satacmd_sec_count_msb = sec_count >> 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4862 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4863 scmd->satacmd_lba_low_msb = (lba >> 24) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4864 scmd->satacmd_lba_mid_msb = (lba >> 32) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4865 scmd->satacmd_lba_high_msb = lba >> 40;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4866 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4867 } else if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA28) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4868 scmd->satacmd_addr_type = ATA_ADDR_LBA28;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4869 scmd->satacmd_device_reg = SATA_ADH_LBA | ((lba >> 24) & 0xf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4870 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4871 scmd->satacmd_sec_count_lsb = sec_count & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4872 scmd->satacmd_lba_low_lsb = lba & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4873 scmd->satacmd_lba_mid_lsb = (lba >> 8) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4874 scmd->satacmd_lba_high_lsb = (lba >> 16) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4875 scmd->satacmd_features_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4876 scmd->satacmd_status_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4877 scmd->satacmd_error_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4878
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4879 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4880 * Check if queueing commands should be used and switch
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4881 * to appropriate command if possible
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4882 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4883 if (sata_func_enable & SATA_ENABLE_QUEUING) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4884 boolean_t using_queuing;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4885
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4886 /* Queuing supported by controller and device? */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4887 if ((sata_func_enable & SATA_ENABLE_NCQ) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4888 (sdinfo->satadrv_features_support &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4889 SATA_DEV_F_NCQ) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4890 (SATA_FEATURES(spx->txlt_sata_hba_inst) &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4891 SATA_CTLF_NCQ)) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4892 using_queuing = B_TRUE;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4893
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4894 /* NCQ supported - use FPDMA READ */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4895 scmd->satacmd_cmd_reg =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4896 SATAC_READ_FPDMA_QUEUED;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4897 scmd->satacmd_features_reg_ext =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4898 scmd->satacmd_sec_count_msb;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4899 scmd->satacmd_sec_count_msb = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4900 scmd->satacmd_rle_sata_cmd = NULL;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4901 } else if ((sdinfo->satadrv_features_support &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4902 SATA_DEV_F_TCQ) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4903 (SATA_FEATURES(spx->txlt_sata_hba_inst) &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4904 SATA_CTLF_QCMD)) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4905 using_queuing = B_TRUE;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4906
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4907 /* Legacy queueing */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4908 if (sdinfo->satadrv_features_support &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4909 SATA_DEV_F_LBA48) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4910 scmd->satacmd_cmd_reg =
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4911 SATAC_READ_DMA_QUEUED_EXT;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4912 scmd->satacmd_features_reg_ext =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4913 scmd->satacmd_sec_count_msb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4914 scmd->satacmd_sec_count_msb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4915 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4916 scmd->satacmd_cmd_reg =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4917 SATAC_READ_DMA_QUEUED;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4918 }
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4919 } else /* Queuing not supported */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4920 using_queuing = B_FALSE;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4921
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4922 /*
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4923 * If queuing, the sector count goes in the features register
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4924 * and the secount count will contain the tag.
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4925 */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
4926 if (using_queuing) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4927 scmd->satacmd_features_reg =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4928 scmd->satacmd_sec_count_lsb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4929 scmd->satacmd_sec_count_lsb = 0;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
4930 scmd->satacmd_flags.sata_queued = B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4931 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4932 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4933
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4934 SATADBG3(SATA_DBG_HBA_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4935 "sata_txlt_read cmd 0x%2x, lba %llx, sec count %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4936 scmd->satacmd_cmd_reg, lba, sec_count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4937
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4938 if (!(spx->txlt_sata_pkt->satapkt_op_mode & SATA_OPMODE_SYNCH)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4939 /* Need callback function */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4940 spx->txlt_sata_pkt->satapkt_comp = sata_txlt_rw_completion;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4941 synch = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4942 } else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4943 synch = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4944
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4945 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4946 if (sata_hba_start(spx, &rval) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4947 /* Pkt not accepted for execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4948 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4949 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4950 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4951 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4952 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4953 * If execution is non-synchronous,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4954 * a callback function will handle potential errors, translate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4955 * the response and will do a callback to a target driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4956 * If it was synchronous, check execution status using the same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4957 * framework callback.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4958 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4959 if (synch) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4960 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4961 "synchronous execution status %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4962 spx->txlt_sata_pkt->satapkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4963 sata_txlt_rw_completion(spx->txlt_sata_pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4964 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4965 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4966 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4967
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4968
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4969 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4970 * SATA translate command: Write (various types)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4971 * Translated into appropriate type of ATA WRITE command
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4972 * (NO ATAPI implementation yet).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4973 * Both the device capabilities and requested operation mode are
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4974 * considered.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4975 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4976 * Following scsi cdb fields are ignored:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4977 * rwprotect, dpo, fua, fua_nv, group_number.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4978 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4979 * Returns TRAN_ACCEPT or code returned by sata_hba_start() and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4980 * appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4981 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4982 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4983 sata_txlt_write(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4984 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4985 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4986 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4987 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4988 sata_hba_inst_t *shi = SATA_TXLT_HBA_INST(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4989 int cport = SATA_TXLT_CPORT(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4990 uint16_t sec_count;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4991 uint64_t lba;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4992 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4993 int synch;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4994
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4995 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4996
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4997 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4998 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
4999 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5000 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5001
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5002 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5003 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5004
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5005 scmd->satacmd_flags.sata_data_direction = SATA_DIR_WRITE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5006 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5007 * Build cmd block depending on the device capability and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5008 * requested operation mode.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5009 * Do not bother with non-dma mode.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5010 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5011 switch ((uint_t)scsipkt->pkt_cdbp[0]) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5012 case SCMD_WRITE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5013 /* 6-byte scsi read cmd : 0x0A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5014 lba = (scsipkt->pkt_cdbp[1] & 0x1f);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5015 lba = (lba << 8) | scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5016 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5017 sec_count = scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5018 /* sec_count 0 will be interpreted as 256 by a device */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5019 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5020 case SCMD_WRITE_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5021 /* 10-bytes scsi write command : 0x2A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5022 lba = scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5023 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5024 lba = (lba << 8) | scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5025 lba = (lba << 8) | scsipkt->pkt_cdbp[5];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5026 sec_count = scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5027 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5028 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5029 case SCMD_WRITE_G5:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5030 /* 12-bytes scsi read command : 0xAA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5031 lba = scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5032 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5033 lba = (lba << 8) | scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5034 lba = (lba << 8) | scsipkt->pkt_cdbp[5];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5035 sec_count = scsipkt->pkt_cdbp[6];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5036 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5037 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5038 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[9];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5039 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5040 case SCMD_WRITE_G4:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5041 /* 16-bytes scsi write command : 0x8A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5042 lba = scsipkt->pkt_cdbp[2];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5043 lba = (lba << 8) | scsipkt->pkt_cdbp[3];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5044 lba = (lba << 8) | scsipkt->pkt_cdbp[4];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5045 lba = (lba << 8) | scsipkt->pkt_cdbp[5];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5046 lba = (lba << 8) | scsipkt->pkt_cdbp[6];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5047 lba = (lba << 8) | scsipkt->pkt_cdbp[7];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5048 lba = (lba << 8) | scsipkt->pkt_cdbp[8];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5049 lba = (lba << 8) | scsipkt->pkt_cdbp[9];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5050 sec_count = scsipkt->pkt_cdbp[10];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5051 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[11];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5052 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[12];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5053 sec_count = (sec_count << 8) | scsipkt->pkt_cdbp[13];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5054 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5055 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5056 /* Unsupported command */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5057 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5058 return (sata_txlt_invalid_command(spx));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5059 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5060
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5061 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5062 * Check if specified address and length exceeds device capacity
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5063 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5064 if ((lba >= sdinfo->satadrv_capacity) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5065 ((lba + sec_count) >= sdinfo->satadrv_capacity)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5066 /* LBA out of range */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5067 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5068 return (sata_txlt_lba_out_of_range(spx));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5069 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5070
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5071 scmd->satacmd_addr_type = ATA_ADDR_LBA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5072 scmd->satacmd_device_reg = SATA_ADH_LBA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5073 scmd->satacmd_cmd_reg = SATAC_WRITE_DMA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5074 if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA48) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5075 scmd->satacmd_addr_type = ATA_ADDR_LBA48;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5076 scmd->satacmd_cmd_reg = SATAC_WRITE_DMA_EXT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5077 scmd->satacmd_sec_count_msb = sec_count >> 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5078 scmd->satacmd_lba_low_msb = (lba >> 24) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5079 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5080 scmd->satacmd_lba_mid_msb = (lba >> 32) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5081 scmd->satacmd_lba_high_msb = lba >> 40;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5082 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5083 } else if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA28) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5084 scmd->satacmd_addr_type = ATA_ADDR_LBA28;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5085 scmd->satacmd_device_reg = SATA_ADH_LBA | ((lba >> 24) & 0xf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5086 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5087 scmd->satacmd_sec_count_lsb = sec_count & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5088 scmd->satacmd_lba_low_lsb = lba & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5089 scmd->satacmd_lba_mid_lsb = (lba >> 8) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5090 scmd->satacmd_lba_high_lsb = (lba >> 16) & 0xff;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5091 scmd->satacmd_features_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5092 scmd->satacmd_status_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5093 scmd->satacmd_error_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5094
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5095 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5096 * Check if queueing commands should be used and switch
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5097 * to appropriate command if possible
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5098 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5099 if (sata_func_enable & SATA_ENABLE_QUEUING) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5100 boolean_t using_queuing;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5101
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5102 /* Queuing supported by controller and device? */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5103 if ((sata_func_enable & SATA_ENABLE_NCQ) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5104 (sdinfo->satadrv_features_support &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5105 SATA_DEV_F_NCQ) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5106 (SATA_FEATURES(spx->txlt_sata_hba_inst) &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5107 SATA_CTLF_NCQ)) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5108 using_queuing = B_TRUE;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5109
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5110 /* NCQ supported - use FPDMA WRITE */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5111 scmd->satacmd_cmd_reg =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5112 SATAC_WRITE_FPDMA_QUEUED;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5113 scmd->satacmd_features_reg_ext =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5114 scmd->satacmd_sec_count_msb;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5115 scmd->satacmd_sec_count_msb = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5116 scmd->satacmd_rle_sata_cmd = NULL;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5117 } else if ((sdinfo->satadrv_features_support &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5118 SATA_DEV_F_TCQ) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5119 (SATA_FEATURES(spx->txlt_sata_hba_inst) &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5120 SATA_CTLF_QCMD)) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5121 using_queuing = B_TRUE;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5122
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5123 /* Legacy queueing */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5124 if (sdinfo->satadrv_features_support &
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5125 SATA_DEV_F_LBA48) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5126 scmd->satacmd_cmd_reg =
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5127 SATAC_WRITE_DMA_QUEUED_EXT;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5128 scmd->satacmd_features_reg_ext =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5129 scmd->satacmd_sec_count_msb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5130 scmd->satacmd_sec_count_msb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5131 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5132 scmd->satacmd_cmd_reg =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5133 SATAC_WRITE_DMA_QUEUED;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5134 }
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5135 } else /* Queuing not supported */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5136 using_queuing = B_FALSE;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5137
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
5138 if (using_queuing) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5139 scmd->satacmd_features_reg =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5140 scmd->satacmd_sec_count_lsb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5141 scmd->satacmd_sec_count_lsb = 0;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5142 scmd->satacmd_flags.sata_queued = B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5143 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5144 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5145
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5146 SATADBG3(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5147 "sata_txlt_write cmd 0x%2x, lba %llx, sec count %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5148 scmd->satacmd_cmd_reg, lba, sec_count);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5149
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5150 if (!(spx->txlt_sata_pkt->satapkt_op_mode & SATA_OPMODE_SYNCH)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5151 /* Need callback function */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5152 spx->txlt_sata_pkt->satapkt_comp = sata_txlt_rw_completion;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5153 synch = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5154 } else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5155 synch = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5156
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5157 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5158 if (sata_hba_start(spx, &rval) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5159 /* Pkt not accepted for execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5160 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5161 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5162 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5163 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5164
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5165 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5166 * If execution is non-synchronous,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5167 * a callback function will handle potential errors, translate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5168 * the response and will do a callback to a target driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5169 * If it was synchronous, check execution status using the same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5170 * framework callback.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5171 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5172 if (synch) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5173 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5174 "synchronous execution status %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5175 spx->txlt_sata_pkt->satapkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5176 sata_txlt_rw_completion(spx->txlt_sata_pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5177 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5178 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5179 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5180
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5181
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5182 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5183 * NOTE: NOT FUNCTIONAL IMPLEMENTATION. THIS IS A PLACEHOLDER for the function
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5184 * that will be fixed in phase 2 of the development.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5185 * Currently ATAPI is not supported. ATAPI devices are threated as not-valid
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5186 * devices.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5187 * This function is not called, since scsi_sata_start() will bail-out prior
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5188 * to calling it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5189 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5190 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5191 sata_txlt_atapi(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5192 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5193 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5194 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5195 struct buf *bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5196 sata_hba_inst_t *shi = SATA_TXLT_HBA_INST(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5197 int cport = SATA_TXLT_CPORT(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5198 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5199 int synch;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5200 union scsi_cdb *cdbp = (union scsi_cdb *)scsipkt->pkt_cdbp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5201
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5202 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5203
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5204 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5205 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5206 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5207 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5208
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5209 /*
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5210 * scmd->satacmd_flags.sata_data_direction default -
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5211 * SATA_DIR_NODATA_XFER - is set by
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5212 * sata_txlt_generic_pkt_info().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5213 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5214 if (scmd->satacmd_bp) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5215 if (scmd->satacmd_bp->b_flags & B_READ) {
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5216 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5217 } else {
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5218 scmd->satacmd_flags.sata_data_direction =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5219 SATA_DIR_WRITE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5220 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5221 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5222
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5223 scmd->satacmd_acdb_len = scsi_cdb_size[GETGROUP(cdbp)];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5224 scmd->satacmd_cmd_reg = SATAC_PACKET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5225 bcopy(cdbp, scmd->satacmd_acdb, 16);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5226
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5227 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5228 * For non-read/write commands we need to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5229 * map buffer
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5230 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5231 switch ((uint_t)scsipkt->pkt_cdbp[0]) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5232 case SCMD_READ:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5233 case SCMD_READ_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5234 case SCMD_READ_G5:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5235 case SCMD_READ_G4:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5236 case SCMD_WRITE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5237 case SCMD_WRITE_G1:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5238 case SCMD_WRITE_G5:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5239 case SCMD_WRITE_G4:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5240 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5241 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5242 if (bp->b_flags & (B_PHYS | B_PAGEIO))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5243 bp_mapin(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5244 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5245 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5246
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5247 if (!(spx->txlt_sata_pkt->satapkt_op_mode & SATA_OPMODE_SYNCH)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5248 /* Need callback function */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5249 spx->txlt_sata_pkt->satapkt_comp = sata_txlt_atapi_completion;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5250 synch = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5251 } else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5252 synch = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5253
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5254 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5255 if (sata_hba_start(spx, &rval) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5256 /* Pkt not accepted for execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5257 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5258 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5259 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5260 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5261 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5262 * If execution is non-synchronous,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5263 * a callback function will handle potential errors, translate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5264 * the response and will do a callback to a target driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5265 * If it was synchronous, check execution status using the same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5266 * framework callback.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5267 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5268 if (synch) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5269 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5270 "synchronous execution status %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5271 spx->txlt_sata_pkt->satapkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5272 sata_txlt_atapi_completion(spx->txlt_sata_pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5273 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5274 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5275 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5276
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5277 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5278 * Translate command: Synchronize Cache.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5279 * Translates into Flush Cache command.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5280 * (NO ATAPI implementation yet).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5281 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5282 * NOTE: We should check if Flush Cache is supported by the device (ATAPI
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5283 * devices)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5284 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5285 * Returns TRAN_ACCEPT or code returned by sata_hba_start() and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5286 * appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5287 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5288 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5289 sata_txlt_synchronize_cache(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5290 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5291 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5292 sata_hba_inst_t *shi = SATA_TXLT_HBA_INST(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5293 int cport = SATA_TXLT_CPORT(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5294 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5295 int synch;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5296
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5297 mutex_enter(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5298
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5299 if ((rval = sata_txlt_generic_pkt_info(spx)) != TRAN_ACCEPT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5300 mutex_exit(&(SATA_TXLT_CPORT_MUTEX(spx)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5301 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5302 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5303
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5304 scmd->satacmd_addr_type = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5305 scmd->satacmd_cmd_reg = SATAC_FLUSH_CACHE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5306 scmd->satacmd_device_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5307 scmd->satacmd_sec_count_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5308 scmd->satacmd_lba_low_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5309 scmd->satacmd_lba_mid_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5310 scmd->satacmd_lba_high_lsb = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5311 scmd->satacmd_features_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5312 scmd->satacmd_status_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5313 scmd->satacmd_error_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5314
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5315 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5316 "sata_txlt_synchronize_cache\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5317
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5318 if (!(spx->txlt_sata_pkt->satapkt_op_mode & SATA_OPMODE_SYNCH)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5319 /* Need to set-up a callback function */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5320 spx->txlt_sata_pkt->satapkt_comp =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5321 sata_txlt_nodata_cmd_completion;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5322 synch = FALSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5323 } else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5324 synch = TRUE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5325
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5326 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5327 if (sata_hba_start(spx, &rval) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5328 /* Pkt not accepted for execution */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5329 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5330 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5331 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5332 mutex_exit(&SATA_CPORT_MUTEX(shi, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5333
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5334 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5335 * If execution non-synchronous, it had to be completed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5336 * a callback function will handle potential errors, translate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5337 * the response and will do a callback to a target driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5338 * If it was synchronous, check status, using the same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5339 * framework callback.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5340 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5341 if (synch) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5342 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5343 "synchronous execution status %x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5344 spx->txlt_sata_pkt->satapkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5345 sata_txlt_nodata_cmd_completion(spx->txlt_sata_pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5346 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5347 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5348 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5349
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5350 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5351 * Send pkt to SATA HBA driver
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5352 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5353 * This function may be called only if the operation is requested by scsi_pkt,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5354 * i.e. scsi_pkt is not NULL.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5355 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5356 * This function has to be called with cport mutex held. It does release
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5357 * the mutex when it calls HBA driver sata_tran_start function and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5358 * re-acquires it afterwards.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5359 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5360 * If return value is 0, pkt was accepted, -1 otherwise
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5361 * rval is set to appropriate sata_scsi_start return value.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5362 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5363 * Note 1:If HBA driver returns value other than TRAN_ACCEPT, it should not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5364 * have called the sata_pkt callback function for this packet.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5365 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5366 * The scsi callback has to be performed by the caller of this routine.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5367 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5368 * Note 2: No port multiplier support for now.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5369 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5370 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5371 sata_hba_start(sata_pkt_txlate_t *spx, int *rval)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5372 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5373 int stat;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5374 sata_hba_inst_t *sata_hba_inst = spx->txlt_sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5375 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5376 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5377 uint8_t cmd;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5378 struct sata_cmd_flags cmd_flags;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5379
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5380 ASSERT(spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5381 ASSERT(mutex_owned(&SATA_CPORT_MUTEX(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5382 spx->txlt_sata_pkt->satapkt_device.satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5383
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5384 sdinfo = sata_get_device_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5385 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5386 ASSERT(sdinfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5387
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5388 /* Clear device reset state? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5389 if (sdinfo->satadrv_event_flags & SATA_EVNT_CLEAR_DEVICE_RESET) {
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5390 spx->txlt_sata_pkt->satapkt_cmd.satacmd_flags.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5391 sata_clear_dev_reset = B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5392 sdinfo->satadrv_event_flags &= ~SATA_EVNT_CLEAR_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5393 SATADBG1(SATA_DBG_EVENTS, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5394 "sata_hba_start: clearing device reset state\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5395 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5396 cmd = spx->txlt_sata_pkt->satapkt_cmd.satacmd_cmd_reg;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5397 cmd_flags = spx->txlt_sata_pkt->satapkt_cmd.satacmd_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5398 sata_device = spx->txlt_sata_pkt->satapkt_device; /* local copy */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5399
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5400 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5401 sdinfo->satadrv_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5402
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5403 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5404 "Sata cmd 0x%2x\n", cmd);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5405
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5406 stat = (*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5407 spx->txlt_sata_pkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5408
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5409 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5410 sdinfo->satadrv_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5411 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5412 * If sata pkt was accepted and executed in asynchronous mode, i.e.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5413 * with the sata callback, the sata_pkt could be already destroyed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5414 * by the time we check ther return status from the hba_start()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5415 * function, because sata_scsi_destroy_pkt() could have been already
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5416 * called (perhaps in the interrupt context). So, in such case, there
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5417 * should be no references to it. In other cases, sata_pkt still
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5418 * exists.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5419 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5420 switch (stat) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5421 case SATA_TRAN_ACCEPTED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5422 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5423 * pkt accepted for execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5424 * If it was executed synchronously, it is already completed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5425 * and pkt completion_reason indicates completion status.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5426 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5427 *rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5428 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5429
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5430 case SATA_TRAN_QUEUE_FULL:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5431 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5432 * Controller detected queue full condition.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5433 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5434 SATADBG1(SATA_DBG_HBA_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5435 "sata_hba_start: queue full\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5436
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5437 spx->txlt_scsi_pkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5438 *spx->txlt_scsi_pkt->pkt_scbp = STATUS_QFULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5439
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5440 *rval = TRAN_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5441 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5442
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5443 case SATA_TRAN_PORT_ERROR:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5444 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5445 * Communication/link with device or general port error
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5446 * detected before pkt execution begun.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5447 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5448 if (spx->txlt_sata_pkt->satapkt_device.satadev_addr.qual ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5449 SATA_ADDR_CPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5450 sata_log(sata_hba_inst, CE_CONT,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5451 "port %d error",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5452 sata_device.satadev_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5453 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5454 sata_log(sata_hba_inst, CE_CONT,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5455 "port %d pmport %d error\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5456 sata_device.satadev_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5457 sata_device.satadev_addr.pmport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5458
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5459 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5460 * Update the port/device structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5461 * sata_pkt should be still valid. Since port error is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5462 * returned, sata_device content should reflect port
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5463 * state - it means, that sata address have been changed,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5464 * because original packet's sata address refered to a device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5465 * attached to some port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5466 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5467 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5468 spx->txlt_scsi_pkt->pkt_reason = CMD_TRAN_ERR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5469 *rval = TRAN_FATAL_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5470 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5471
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5472 case SATA_TRAN_CMD_UNSUPPORTED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5473 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5474 * Command rejected by HBA as unsupported. It was HBA driver
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5475 * that rejected the command, command was not sent to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5476 * an attached device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5477 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5478 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5479 sdinfo->satadrv_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5480 (void) sata_txlt_invalid_command(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5481 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5482 sdinfo->satadrv_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5483
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5484 if (sdinfo->satadrv_state & SATA_DSTATE_RESET)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5485 SATADBG1(SATA_DBG_EVENTS, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5486 "sat_hba_start: cmd 0x%2x rejected "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5487 "with SATA_TRAN_CMD_UNSUPPORTED status\n", cmd);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5488
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5489 *rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5490 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5491
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5492 case SATA_TRAN_BUSY:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5493 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5494 * Command rejected by HBA because other operation prevents
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5495 * accepting the packet, or device is in RESET condition.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5496 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5497 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5498 sdinfo->satadrv_state =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5499 spx->txlt_sata_pkt->satapkt_device.satadev_state;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5500
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5501 if (sdinfo->satadrv_state & SATA_DSTATE_RESET) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5502 SATADBG1(SATA_DBG_EVENTS, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5503 "sata_hba_start: cmd 0x%2x rejected "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5504 "because of device reset condition\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5505 cmd);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5506 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5507 SATADBG1(SATA_DBG_EVENTS, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5508 "sata_hba_start: cmd 0x%2x rejected "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5509 "with SATA_TRAN_BUSY status\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5510 cmd);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5511 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5512 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5513 spx->txlt_scsi_pkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5514 *rval = TRAN_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5515 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5516
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5517 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5518 /* Unrecognized HBA response */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5519 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5520 "sata_hba_start: unrecognized HBA response "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5521 "to cmd : 0x%2x resp 0x%x", cmd, rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5522 spx->txlt_scsi_pkt->pkt_reason = CMD_TRAN_ERR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5523 *rval = TRAN_FATAL_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5524 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5525 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5526
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5527 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5528 * If we got here, the packet was rejected.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5529 * Check if we need to remember reset state clearing request
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5530 */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5531 if (cmd_flags.sata_clear_dev_reset) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5532 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5533 * Check if device is still configured - it may have
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5534 * disapeared from the configuration
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5535 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5536 sdinfo = sata_get_device_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5537 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5538 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5539 * Restore the flag that requests clearing of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5540 * the device reset state,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5541 * so the next sata packet may carry it to HBA.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5542 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5543 sdinfo->satadrv_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5544 SATA_EVNT_CLEAR_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5545 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5546 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5547 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5548 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5549
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5550 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5551 * Scsi response setup for invalid LBA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5552 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5553 * Returns TRAN_ACCEPT and appropriate values in scsi_pkt fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5554 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5555 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5556 sata_txlt_lba_out_of_range(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5557 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5558 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5559 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5560
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5561 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5562 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5563 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5564 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5565
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5566 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5567 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5568 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5569 sense->es_add_code = SD_SCSI_LBA_OUT_OF_RANGE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5570
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5571 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5572 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5573
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5574 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5575 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5576 /* scsi callback required */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
5577 if (taskq_dispatch(SATA_TXLT_TASKQ(spx),
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
5578 (task_func_t *)scsipkt->pkt_comp, (void *) scsipkt,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
5579 TQ_SLEEP) == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
5580 /* Scheduling the callback failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
5581 return (TRAN_BUSY);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5582 return (TRAN_ACCEPT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5583 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5584
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5585
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5586 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5587 * Analyze device status and error registers and translate them into
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5588 * appropriate scsi sense codes.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5589 * NOTE: non-packet commands only for now
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5590 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5591 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5592 sata_decode_device_error(sata_pkt_txlate_t *spx,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5593 struct scsi_extended_sense *sense)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5594 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5595 uint8_t err_reg = spx->txlt_sata_pkt->satapkt_cmd.satacmd_error_reg;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5596
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5597 ASSERT(sense != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5598 ASSERT(spx->txlt_sata_pkt->satapkt_cmd.satacmd_status_reg &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5599 SATA_STATUS_ERR);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5600
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5601
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5602 if (err_reg & SATA_ERROR_ICRC) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5603 sense->es_key = KEY_ABORTED_COMMAND;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5604 sense->es_add_code = 0x08; /* Communication failure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5605 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5606 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5607
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5608 if (err_reg & SATA_ERROR_UNC) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5609 sense->es_key = KEY_MEDIUM_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5610 /* Information bytes (LBA) need to be set by a caller */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5611 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5612 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5613
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5614 /* ADD HERE: MC error bit handling for ATAPI CD/DVD */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5615 if (err_reg & (SATA_ERROR_MCR | SATA_ERROR_NM)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5616 sense->es_key = KEY_UNIT_ATTENTION;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5617 sense->es_add_code = 0x3a; /* No media present */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5618 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5619 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5620
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5621 if (err_reg & SATA_ERROR_IDNF) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5622 if (err_reg & SATA_ERROR_ABORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5623 sense->es_key = KEY_ABORTED_COMMAND;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5624 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5625 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5626 sense->es_add_code = 0x21; /* LBA out of range */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5627 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5628 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5629 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5630
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5631 if (err_reg & SATA_ERROR_ABORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5632 ASSERT(spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5633 sense->es_key = KEY_ABORTED_COMMAND;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5634 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5635 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5636 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5637
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5638 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5639 * Extract error LBA from sata_pkt.satapkt_cmd register fields
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5640 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5641 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5642 sata_extract_error_lba(sata_pkt_txlate_t *spx, uint64_t *lba)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5643 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5644 sata_cmd_t *sata_cmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5645
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5646 *lba = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5647 if (sata_cmd->satacmd_addr_type == ATA_ADDR_LBA48) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5648 *lba = sata_cmd->satacmd_lba_high_msb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5649 *lba = (*lba << 8) | sata_cmd->satacmd_lba_mid_msb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5650 *lba = (*lba << 8) | sata_cmd->satacmd_lba_low_msb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5651 } else if (sata_cmd->satacmd_addr_type == ATA_ADDR_LBA28) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5652 *lba = sata_cmd->satacmd_device_reg & 0xf;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5653 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5654 *lba = (*lba << 8) | sata_cmd->satacmd_lba_high_lsb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5655 *lba = (*lba << 8) | sata_cmd->satacmd_lba_mid_lsb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5656 *lba = (*lba << 8) | sata_cmd->satacmd_lba_high_lsb;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5657 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5658
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5659 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5660 * This is fixed sense format - if LBA exceeds the info field size,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5661 * no valid info will be returned (valid bit in extended sense will
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5662 * be set to 0).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5663 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5664 static struct scsi_extended_sense *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5665 sata_arq_sense(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5666 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5667 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5668 struct scsi_arq_status *arqs;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5669 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5670
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5671 /* Fill ARQ sense data */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5672 scsipkt->pkt_state |= STATE_ARQ_DONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5673 arqs = (struct scsi_arq_status *)scsipkt->pkt_scbp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5674 *(uchar_t *)&arqs->sts_status = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5675 *(uchar_t *)&arqs->sts_rqpkt_status = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5676 arqs->sts_rqpkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5677 arqs->sts_rqpkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5678 STATE_XFERRED_DATA | STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5679 arqs->sts_rqpkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5680 sense = &arqs->sts_sensedata;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5681 bzero(sense, sizeof (struct scsi_extended_sense));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5682 sense->es_valid = 1; /* Valid sense */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5683 sense->es_class = 7; /* Response code 0x70 - current err */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5684 sense->es_key = KEY_NO_SENSE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5685 sense->es_info_1 = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5686 sense->es_info_2 = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5687 sense->es_info_3 = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5688 sense->es_info_4 = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5689 sense->es_add_len = 6; /* Additional length */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5690 sense->es_cmd_info[0] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5691 sense->es_cmd_info[1] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5692 sense->es_cmd_info[2] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5693 sense->es_cmd_info[3] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5694 sense->es_add_code = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5695 sense->es_qual_code = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5696 return (sense);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5697 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5698
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5699
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5700 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5701 * Translate completion status of SATA read/write commands into scsi response.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5702 * pkt completion_reason is checked to determine the completion status.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5703 * Do scsi callback if necessary.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5704 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5705 * Note: this function may be called also for synchronously executed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5706 * commands.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5707 * This function may be used only if scsi_pkt is non-NULL.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5708 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5709 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5710 sata_txlt_rw_completion(sata_pkt_t *sata_pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5711 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5712 sata_pkt_txlate_t *spx =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5713 (sata_pkt_txlate_t *)sata_pkt->satapkt_framework_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5714 sata_cmd_t *scmd = &sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5715 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5716 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5717 uint64_t lba;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5718
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5719 if (sata_pkt->satapkt_reason == SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5720 /* Normal completion */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5721 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5722 STATE_SENT_CMD | STATE_XFERRED_DATA | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5723 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5724 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5725 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5726 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5727 * Something went wrong - analyze return
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5728 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5729 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5730 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5731 scsipkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5732 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5733 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5734 ASSERT(sense != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5735
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5736 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5737 * SATA_PKT_DEV_ERROR is the only case where we may be able to
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
5738 * extract from device registers the failing LBA.
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5739 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5740 if (sata_pkt->satapkt_reason == SATA_PKT_DEV_ERROR) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5741 if ((scmd->satacmd_addr_type == ATA_ADDR_LBA48) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5742 (scmd->satacmd_lba_mid_msb != 0 ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5743 scmd->satacmd_lba_high_msb != 0)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5744 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5745 * We have problem reporting this cmd LBA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5746 * in fixed sense data format, because of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5747 * the size of the scsi LBA fields.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5748 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5749 sense->es_valid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5750 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5751 sata_extract_error_lba(spx, &lba);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5752 sense->es_info_1 = (lba & 0xFF000000) >> 24;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5753 sense->es_info_1 = (lba & 0xFF0000) >> 16;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5754 sense->es_info_1 = (lba & 0xFF00) >> 8;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5755 sense->es_info_1 = lba & 0xFF;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5756 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5757 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5758 /* Invalid extended sense info */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5759 sense->es_valid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5760 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5761
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5762 switch (sata_pkt->satapkt_reason) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5763 case SATA_PKT_PORT_ERROR:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5764 /* We may want to handle DEV GONE state as well */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5765 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5766 * We have no device data. Assume no data transfered.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5767 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5768 sense->es_key = KEY_HARDWARE_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5769 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5770
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5771 case SATA_PKT_DEV_ERROR:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5772 if (sata_pkt->satapkt_cmd.satacmd_status_reg &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5773 SATA_STATUS_ERR) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5774 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5775 * determine dev error reason from error
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5776 * reg content
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5777 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5778 sata_decode_device_error(spx, sense);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5779 if (sense->es_key == KEY_MEDIUM_ERROR) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5780 switch (scmd->satacmd_cmd_reg) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5781 case SATAC_READ_DMA:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5782 case SATAC_READ_DMA_EXT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5783 case SATAC_READ_DMA_QUEUED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5784 case SATAC_READ_DMA_QUEUED_EXT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5785 case SATAC_READ_FPDMA_QUEUED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5786 /* Unrecovered read error */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5787 sense->es_add_code =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5788 SD_SCSI_UNREC_READ_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5789 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5790 case SATAC_WRITE_DMA:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5791 case SATAC_WRITE_DMA_EXT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5792 case SATAC_WRITE_DMA_QUEUED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5793 case SATAC_WRITE_DMA_QUEUED_EXT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5794 case SATAC_WRITE_FPDMA_QUEUED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5795 /* Write error */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5796 sense->es_add_code =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5797 SD_SCSI_WRITE_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5798 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5799 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5800 /* Internal error */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5801 SATA_LOG_D((
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5802 spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5803 CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5804 "sata_txlt_rw_completion :"
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5805 "internal error - invalid "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5806 "command 0x%2x",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5807 scmd->satacmd_cmd_reg));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5808 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5809 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5810 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5811 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5812 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5813 /* No extended sense key - no info available */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5814 scsipkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5815 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5816
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5817 case SATA_PKT_TIMEOUT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5818 /* scsipkt->pkt_reason = CMD_TIMEOUT; */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5819 scsipkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5820 /* No extended sense key ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5821 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5822
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5823 case SATA_PKT_ABORTED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5824 scsipkt->pkt_reason = CMD_ABORTED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5825 /* No extended sense key ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5826 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5827
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5828 case SATA_PKT_RESET:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5829 scsipkt->pkt_reason = CMD_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5830 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5831
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5832 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5833 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5834 "sata_txlt_rw_completion: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5835 "invalid packet completion reason"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5836 scsipkt->pkt_reason = CMD_TRAN_ERR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5837 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5838 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5839 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5840 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5841 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5842
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5843 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5844 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5845 /* scsi callback required */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5846 (*scsipkt->pkt_comp)(scsipkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5847
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5848 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5849
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5850 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5851 * NON FUNCTIONAL IMPLEMENTATION. THIS IS A PLACE HOLDER.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5852 * ATAPI devices are not supported currently (are not be attached recognized
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5853 * as valid devices).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5854 * Will be fixed in phase 2 of the development.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5855 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5856 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5857 sata_txlt_atapi_completion(sata_pkt_t *sata_pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5858 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5859 sata_pkt_txlate_t *spx =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5860 (sata_pkt_txlate_t *)sata_pkt->satapkt_framework_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5861 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5862 struct scsi_arq_status *arqs;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5863
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5864 if (sata_pkt->satapkt_reason == SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5865 /* Normal completion */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5866 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5867 STATE_SENT_CMD | STATE_XFERRED_DATA | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5868 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5869 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5870 scsipkt->pkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5871 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5872 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5873 * Something went wrong - analyze return
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5874 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5875 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5876 STATE_SENT_CMD | STATE_GOT_STATUS | STATE_ARQ_DONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5877 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5878
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5879 arqs = (struct scsi_arq_status *)scsipkt->pkt_scbp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5880 *(uchar_t *)&arqs->sts_status = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5881 *(uchar_t *)&arqs->sts_rqpkt_status = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5882 arqs->sts_rqpkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5883 arqs->sts_rqpkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5884 STATE_XFERRED_DATA | STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5885 arqs->sts_rqpkt_resid = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5886
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5887 bcopy(sata_pkt->satapkt_cmd.satacmd_rqsense,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5888 &arqs->sts_sensedata, SATA_ATAPI_RQSENSE_LEN);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5889 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5890 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5891 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5892
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5893 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5894 scsipkt->pkt_comp != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5895 /* scsi callback required */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5896 (*scsipkt->pkt_comp)(scsipkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5897 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5898 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5899
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5900
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5901 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5902 * Translate completion status of non-data commands (i.e. commands returning
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5903 * no data).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5904 * pkt completion_reason is checked to determine the completion status.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5905 * Do scsi callback if necessary (FLAG_NOINTR == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5906 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5907 * Note: this function may be called also for synchronously executed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5908 * commands.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5909 * This function may be used only if scsi_pkt is non-NULL.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5910 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5911
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5912 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5913 sata_txlt_nodata_cmd_completion(sata_pkt_t *sata_pkt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5914 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5915 sata_pkt_txlate_t *spx =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5916 (sata_pkt_txlate_t *)sata_pkt->satapkt_framework_private;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5917 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5918 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5919
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5920 scsipkt->pkt_state = STATE_GOT_BUS | STATE_GOT_TARGET |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5921 STATE_SENT_CMD | STATE_GOT_STATUS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5922 if (sata_pkt->satapkt_reason == SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5923 /* Normal completion */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5924 scsipkt->pkt_reason = CMD_CMPLT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5925 *scsipkt->pkt_scbp = STATUS_GOOD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5926 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5927 /* Something went wrong */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5928 scsipkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5929 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5930 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5931 switch (sata_pkt->satapkt_reason) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5932 case SATA_PKT_PORT_ERROR:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5933 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5934 * We have no device data. Assume no data transfered.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5935 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5936 sense->es_key = KEY_HARDWARE_ERROR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5937 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5938
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5939 case SATA_PKT_DEV_ERROR:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5940 if (sata_pkt->satapkt_cmd.satacmd_status_reg &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5941 SATA_STATUS_ERR) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5942 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5943 * determine dev error reason from error
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5944 * reg content
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5945 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5946 sata_decode_device_error(spx, sense);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5947 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5948 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5949 /* No extended sense key - no info available */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5950 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5951
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5952 case SATA_PKT_TIMEOUT:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5953 /* scsipkt->pkt_reason = CMD_TIMEOUT; */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5954 scsipkt->pkt_reason = CMD_INCOMPLETE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5955 /* No extended sense key ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5956 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5957
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5958 case SATA_PKT_ABORTED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5959 scsipkt->pkt_reason = CMD_ABORTED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5960 /* No extended sense key ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5961 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5962
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5963 case SATA_PKT_RESET:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5964 /* pkt aborted by an explicit reset from a host */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5965 scsipkt->pkt_reason = CMD_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5966 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5967
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5968 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5969 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5970 "sata_txlt_nodata_cmd_completion: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5971 "invalid packet completion reason %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5972 sata_pkt->satapkt_reason));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5973 scsipkt->pkt_reason = CMD_TRAN_ERR;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5974 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5975 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5976
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5977 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5978 SATADBG1(SATA_DBG_SCSI_IF, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5979 "Scsi_pkt completion reason %x\n", scsipkt->pkt_reason);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5980
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5981 if ((scsipkt->pkt_flags & FLAG_NOINTR) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5982 scsipkt->pkt_comp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5983 /* scsi callback required */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5984 (*scsipkt->pkt_comp)(scsipkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5985 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5986
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5987
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5988 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5989 * Build Mode sense R/W recovery page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5990 * NOT IMPLEMENTED
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5991 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5992
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5993 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5994 sata_build_msense_page_1(sata_drive_info_t *sdinfo, int pcntrl, uint8_t *buf)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5995 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5996 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5997 _NOTE(ARGUNUSED(sdinfo))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5998 _NOTE(ARGUNUSED(pcntrl))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
5999 _NOTE(ARGUNUSED(buf))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6000 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6001 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6002 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6003
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6004 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6005 * Build Mode sense caching page - scsi-3 implementation.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6006 * Page length distinguishes previous format from scsi-3 format.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6007 * buf must have space for 0x12 bytes.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6008 * Only DRA (disable read ahead ) and WCE (write cache enable) are changeable.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6009 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6010 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6011 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6012 sata_build_msense_page_8(sata_drive_info_t *sdinfo, int pcntrl, uint8_t *buf)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6013 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6014 struct mode_cache_scsi3 *page = (struct mode_cache_scsi3 *)buf;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6015 sata_id_t *sata_id = &sdinfo->satadrv_id;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6016
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6017 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6018 * Most of the fields are set to 0, being not supported and/or disabled
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6019 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6020 bzero(buf, PAGELENGTH_DAD_MODE_CACHE_SCSI3);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6021
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6022 /* Saved paramters not supported */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6023 if (pcntrl == 3)
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6024 return (0);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6025 if (pcntrl == 0 || pcntrl == 2) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6026 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6027 * For now treat current and default parameters as same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6028 * That may have to change, if target driver will complain
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6029 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6030 page->mode_page.code = MODEPAGE_CACHING; /* PS = 0 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6031 page->mode_page.length = PAGELENGTH_DAD_MODE_CACHE_SCSI3;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6032
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6033 if ((sata_id->ai_cmdset82 & SATA_LOOK_AHEAD) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6034 !(sata_id->ai_features85 & SATA_LOOK_AHEAD)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6035 page->dra = 1; /* Read Ahead disabled */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6036 page->rcd = 1; /* Read Cache disabled */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6037 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6038 if ((sata_id->ai_cmdset82 & SATA_WRITE_CACHE) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6039 (sata_id->ai_features85 & SATA_WRITE_CACHE))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6040 page->wce = 1; /* Write Cache enabled */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6041 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6042 /* Changeable parameters */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6043 page->mode_page.code = MODEPAGE_CACHING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6044 page->mode_page.length = PAGELENGTH_DAD_MODE_CACHE_SCSI3;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6045 if (sata_id->ai_cmdset82 & SATA_LOOK_AHEAD) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6046 page->dra = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6047 page->rcd = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6048 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6049 if (sata_id->ai_cmdset82 & SATA_WRITE_CACHE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6050 page->wce = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6051 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6052 return (PAGELENGTH_DAD_MODE_CACHE_SCSI3 +
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6053 sizeof (struct mode_page));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6054 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6055
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6056 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6057 * Build Mode sense exception cntrl page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6058 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6059 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6060 sata_build_msense_page_1c(sata_drive_info_t *sdinfo, int pcntrl, uint8_t *buf)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6061 {
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6062 struct mode_info_excpt_page *page = (struct mode_info_excpt_page *)buf;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6063 sata_id_t *sata_id = &sdinfo->satadrv_id;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6064
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6065 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6066 * Most of the fields are set to 0, being not supported and/or disabled
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6067 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6068 bzero(buf, PAGELENGTH_INFO_EXCPT);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6069
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6070 page->mode_page.code = MODEPAGE_INFO_EXCPT;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6071 page->mode_page.length = PAGELENGTH_INFO_EXCPT;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6072
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6073 /* Indicate that this is page is saveable */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6074 page->mode_page.ps = 1;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6075
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6076 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6077 * We will return the same data for default, current and saved page.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6078 * The only changeable bit is dexcpt and that bit is required
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6079 * by the ATA specification to be preserved across power cycles.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6080 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6081 if (pcntrl != 1) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6082 page->dexcpt = !(sata_id->ai_features85 & SATA_SMART_SUPPORTED);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6083 page->mrie = MRIE_ONLY_ON_REQUEST;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6084 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6085 else
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6086 page->dexcpt = 1; /* Only changeable parameter */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6087
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6088 return (PAGELENGTH_INFO_EXCPT + sizeof (struct mode_info_excpt_page));
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6089 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6090
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6091
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6092 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6093 * Build Mode sense power condition page
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6094 * NOT IMPLEMENTED.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6095 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6096 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6097 sata_build_msense_page_1a(sata_drive_info_t *sdinfo, int pcntrl, uint8_t *buf)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6098 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6099 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6100 _NOTE(ARGUNUSED(sdinfo))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6101 _NOTE(ARGUNUSED(pcntrl))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6102 _NOTE(ARGUNUSED(buf))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6103 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6104 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6105 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6106
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6107
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6108 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6109 * Process mode select caching page 8 (scsi3 format only).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6110 * Read Ahead (same as read cache) and Write Cache may be turned on and off
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6111 * if these features are supported by the device. If these features are not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6112 * supported, quietly ignore them.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6113 * This function fails only if the SET FEATURE command sent to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6114 * the device fails. The page format is not varified, assuming that the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6115 * target driver operates correctly - if parameters length is too short,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6116 * we just drop the page.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6117 * Two command may be sent if both Read Cache/Read Ahead and Write Cache
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6118 * setting have to be changed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6119 * SET FEATURE command is executed synchronously, i.e. we wait here until
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6120 * it is completed, regardless of the scsi pkt directives.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6121 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6122 * Note: Mode Select Caching page RCD and DRA bits are tied together, i.e.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6123 * changing DRA will change RCD.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6124 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6125 * More than one SATA command may be executed to perform operations specified
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6126 * by mode select pages. The first error terminates further execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6127 * Operations performed successully are not backed-up in such case.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6128 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6129 * Return SATA_SUCCESS if operation succeeded, SATA_FAILURE otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6130 * If operation resulted in changing device setup, dmod flag should be set to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6131 * one (1). If parameters were not changed, dmod flag should be set to 0.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6132 * Upon return, if operation required sending command to the device, the rval
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6133 * should be set to the value returned by sata_hba_start. If operation
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6134 * did not require device access, rval should be set to TRAN_ACCEPT.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6135 * The pagelen should be set to the length of the page.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6136 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6137 * This function has to be called with a port mutex held.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6138 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6139 * Returns SATA_SUCCESS if operation was successful, SATA_FAILURE otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6140 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6141 int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6142 sata_mode_select_page_8(sata_pkt_txlate_t *spx, struct mode_cache_scsi3 *page,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6143 int parmlen, int *pagelen, int *rval, int *dmod)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6144 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6145 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6146 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6147 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6148 sata_id_t *sata_id;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6149 struct scsi_extended_sense *sense;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6150 int wce, dra; /* Current settings */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6151
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6152 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6153 &spx->txlt_sata_pkt->satapkt_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6154 sata_id = &sdinfo->satadrv_id;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6155 *dmod = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6156
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6157 /* Verify parameters length. If too short, drop it */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6158 if (PAGELENGTH_DAD_MODE_CACHE_SCSI3 +
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6159 sizeof (struct mode_page) < parmlen) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6160 *scsipkt->pkt_scbp = STATUS_CHECK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6161 sense = sata_arq_sense(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6162 sense->es_key = KEY_ILLEGAL_REQUEST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6163 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_PARAMETER_LIST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6164 *pagelen = parmlen;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6165 *rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6166 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6167 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6168
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6169 *pagelen = PAGELENGTH_DAD_MODE_CACHE_SCSI3 + sizeof (struct mode_page);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6170
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6171 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6172 * We can manipulate only write cache and read ahead
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6173 * (read cache) setting.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6174 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6175 if (!(sata_id->ai_cmdset82 & SATA_LOOK_AHEAD) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6176 !(sata_id->ai_cmdset82 & SATA_WRITE_CACHE)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6177 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6178 * None of the features is supported - ignore
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6179 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6180 *rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6181 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6182 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6183
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6184 /* Current setting of Read Ahead (and Read Cache) */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6185 if (sata_id->ai_features85 & SATA_LOOK_AHEAD)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6186 dra = 0; /* 0 == not disabled */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6187 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6188 dra = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6189 /* Current setting of Write Cache */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6190 if (sata_id->ai_features85 & SATA_WRITE_CACHE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6191 wce = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6192 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6193 wce = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6194
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6195 if (page->dra == dra && page->wce == wce && page->rcd == dra) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6196 /* nothing to do */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6197 *rval = TRAN_ACCEPT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6198 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6199 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6200 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6201 * Need to flip some setting
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6202 * Set-up Internal SET FEATURES command(s)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6203 */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6204 scmd->satacmd_flags.sata_data_direction = SATA_DIR_NODATA_XFER;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6205 scmd->satacmd_addr_type = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6206 scmd->satacmd_device_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6207 scmd->satacmd_status_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6208 scmd->satacmd_error_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6209 scmd->satacmd_cmd_reg = SATAC_SET_FEATURES;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6210 if (page->dra != dra || page->rcd != dra) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6211 /* Need to flip read ahead setting */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6212 if (dra == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6213 /* Disable read ahead / read cache */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6214 scmd->satacmd_features_reg =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6215 SATAC_SF_DISABLE_READ_AHEAD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6216 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6217 /* Enable read ahead / read cache */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6218 scmd->satacmd_features_reg =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6219 SATAC_SF_ENABLE_READ_AHEAD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6220
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6221 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6222 if (sata_hba_start(spx, rval) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6223 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6224 * Pkt not accepted for execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6225 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6226 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6227
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6228 *dmod = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6229
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6230 /* Now process return */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6231 if (spx->txlt_sata_pkt->satapkt_reason !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6232 SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6233 goto failure; /* Terminate */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6234 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6235 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6236
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6237 /* Note that the packet is not removed, so it could be re-used */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6238 if (page->wce != wce) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6239 /* Need to flip Write Cache setting */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6240 if (page->wce == 1)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6241 /* Enable write cache */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6242 scmd->satacmd_features_reg =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6243 SATAC_SF_ENABLE_WRITE_CACHE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6244 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6245 /* Disable write cache */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6246 scmd->satacmd_features_reg =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6247 SATAC_SF_DISABLE_WRITE_CACHE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6248
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6249 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6250 if (sata_hba_start(spx, rval) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6251 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6252 * Pkt not accepted for execution.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6253 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6254 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6255
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6256 *dmod = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6257
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6258 /* Now process return */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6259 if (spx->txlt_sata_pkt->satapkt_reason !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6260 SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6261 goto failure;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6262 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6263 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6264 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6265
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6266 failure:
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6267 sata_xlate_errors(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6268
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6269 return (SATA_FAILURE);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6270 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6271
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6272 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6273 * Process mode select informational exceptions control page 0x1c
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6274 *
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6275 * The only changeable bit is dexcpt (disable exceptions).
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6276 * MRIE (method of reporting informational exceptions) must be
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6277 * "only on request".
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6278 *
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6279 * Return SATA_SUCCESS if operation succeeded, SATA_FAILURE otherwise.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6280 * If operation resulted in changing device setup, dmod flag should be set to
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6281 * one (1). If parameters were not changed, dmod flag should be set to 0.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6282 * Upon return, if operation required sending command to the device, the rval
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6283 * should be set to the value returned by sata_hba_start. If operation
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6284 * did not require device access, rval should be set to TRAN_ACCEPT.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6285 * The pagelen should be set to the length of the page.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6286 *
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6287 * This function has to be called with a port mutex held.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6288 *
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6289 * Returns SATA_SUCCESS if operation was successful, SATA_FAILURE otherwise.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6290 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6291 static int
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6292 sata_mode_select_page_1c(
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6293 sata_pkt_txlate_t *spx,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6294 struct mode_info_excpt_page *page,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6295 int parmlen,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6296 int *pagelen,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6297 int *rval,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6298 int *dmod)
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6299 {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6300 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6301 sata_cmd_t *scmd = &spx->txlt_sata_pkt->satapkt_cmd;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6302 sata_drive_info_t *sdinfo;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6303 sata_id_t *sata_id;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6304 struct scsi_extended_sense *sense;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6305
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6306 sdinfo = sata_get_device_info(spx->txlt_sata_hba_inst,
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6307 &spx->txlt_sata_pkt->satapkt_device);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6308 sata_id = &sdinfo->satadrv_id;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6309
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6310 *dmod = 0;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6311
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6312 /* Verify parameters length. If too short, drop it */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6313 if (((PAGELENGTH_INFO_EXCPT + sizeof (struct mode_page)) < parmlen) ||
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6314 page->perf || page->test || (page->mrie != MRIE_ONLY_ON_REQUEST)) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6315 *scsipkt->pkt_scbp = STATUS_CHECK;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6316 sense = sata_arq_sense(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6317 sense->es_key = KEY_ILLEGAL_REQUEST;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6318 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_PARAMETER_LIST;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6319 *pagelen = parmlen;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6320 *rval = TRAN_ACCEPT;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6321 return (SATA_FAILURE);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6322 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6323
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6324 *pagelen = PAGELENGTH_INFO_EXCPT + sizeof (struct mode_page);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6325
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6326 if (! (sata_id->ai_cmdset82 & SATA_SMART_SUPPORTED)) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6327 *scsipkt->pkt_scbp = STATUS_CHECK;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6328 sense = sata_arq_sense(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6329 sense->es_key = KEY_ILLEGAL_REQUEST;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6330 sense->es_add_code = SD_SCSI_INVALID_FIELD_IN_CDB;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6331 *pagelen = parmlen;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6332 *rval = TRAN_ACCEPT;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6333 return (SATA_FAILURE);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6334 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6335
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6336 /* If already in the state requested, we are done */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6337 if (page->dexcpt == ! (sata_id->ai_features85 & SATA_SMART_ENABLED)) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6338 /* nothing to do */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6339 *rval = TRAN_ACCEPT;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6340 return (SATA_SUCCESS);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6341 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6342
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6343 scmd->satacmd_flags.sata_data_direction = SATA_DIR_NODATA_XFER;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6344
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6345 /* Build SMART_ENABLE or SMART_DISABLE command */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6346 scmd->satacmd_addr_type = 0; /* N/A */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6347 scmd->satacmd_lba_mid_lsb = SMART_MAGIC_VAL_1;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6348 scmd->satacmd_lba_high_lsb = SMART_MAGIC_VAL_2;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6349 scmd->satacmd_features_reg = page->dexcpt ?
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6350 SATA_SMART_DISABLE_OPS : SATA_SMART_ENABLE_OPS;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6351 scmd->satacmd_device_reg = 0; /* Always device 0 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6352 scmd->satacmd_cmd_reg = SATAC_SMART;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6353
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6354 /* Transfer command to HBA */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6355 if (sata_hba_start(spx, rval) != 0)
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6356 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6357 * Pkt not accepted for execution.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6358 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6359 return (SATA_FAILURE);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6360
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6361 *dmod = 1; /* At least may have been modified */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6362
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6363 /* Now process return */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6364 if (spx->txlt_sata_pkt->satapkt_reason == SATA_PKT_COMPLETED)
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6365 return (SATA_SUCCESS);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6366
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6367 /* Packet did not complete successfully */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6368 sata_xlate_errors(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
6369
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6370 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6371 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6372
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6373 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6374 * sata_build_lsense_page0() is used to create the
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6375 * SCSI LOG SENSE page 0 (supported log pages)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6376 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6377 * Currently supported pages are 0, 0x10, 0x2f and 0x30
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6378 * (supported log pages, self-test results, informational exceptions
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6379 * and Sun vendor specific ATA SMART data).
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6380 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6381 * Takes a sata_drive_info t * and the address of a buffer
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6382 * in which to create the page information.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6383 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6384 * Returns the number of bytes valid in the buffer.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6385 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6386 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6387 sata_build_lsense_page_0(sata_drive_info_t *sdinfo, uint8_t *buf)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6388 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6389 struct log_parameter *lpp = (struct log_parameter *)buf;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6390 uint8_t *page_ptr = (uint8_t *)lpp->param_values;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6391 int num_pages_supported = 1; /* Always have GET_SUPPORTED_LOG_PAGES */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6392 sata_id_t *sata_id = &sdinfo->satadrv_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6393
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6394 lpp->param_code[0] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6395 lpp->param_code[1] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6396 lpp->param_ctrl_flags = LOG_CTRL_LP | LOG_CTRL_LBIN;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6397 *page_ptr++ = PAGE_CODE_GET_SUPPORTED_LOG_PAGES;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6398
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6399 if (sata_id->ai_cmdset82 & SATA_SMART_SUPPORTED) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6400 if (sata_id->ai_cmdset84 & SATA_SMART_SELF_TEST_SUPPORTED) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6401 *page_ptr++ = PAGE_CODE_SELF_TEST_RESULTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6402 ++num_pages_supported;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6403 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6404 *page_ptr++ = PAGE_CODE_INFORMATION_EXCEPTIONS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6405 ++num_pages_supported;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6406 *page_ptr++ = PAGE_CODE_SMART_READ_DATA;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6407 ++num_pages_supported;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6408 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6409
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6410 lpp->param_len = num_pages_supported;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6411
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6412 return ((&lpp->param_values[0] - (uint8_t *)lpp) +
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6413 num_pages_supported);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6414 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6415
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6416 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6417 * sata_build_lsense_page_10() is used to create the
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6418 * SCSI LOG SENSE page 0x10 (self-test results)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6419 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6420 * Takes a sata_drive_info t * and the address of a buffer
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6421 * in which to create the page information as well as a sata_hba_inst_t *.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6422 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6423 * Returns the number of bytes valid in the buffer.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6424 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6425 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6426 sata_build_lsense_page_10(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6427 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6428 uint8_t *buf,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6429 sata_hba_inst_t *sata_hba_inst)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6430 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6431 struct log_parameter *lpp = (struct log_parameter *)buf;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6432 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6433
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6434 if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA48) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6435 struct smart_ext_selftest_log *ext_selftest_log;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6436
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6437 ext_selftest_log = kmem_zalloc(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6438 sizeof (struct smart_ext_selftest_log), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6439
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6440 rval = sata_ext_smart_selftest_read_log(sata_hba_inst, sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6441 ext_selftest_log, 0);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6442 if (rval == 0) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6443 int index, start_index;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6444 struct smart_ext_selftest_log_entry *entry;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6445 static const struct smart_ext_selftest_log_entry empty =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6446 {0};
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6447 uint16_t block_num;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6448 int count;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6449 boolean_t only_one_block = B_FALSE;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6450
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6451 index = ext_selftest_log->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6452 smart_ext_selftest_log_index[0];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6453 index |= ext_selftest_log->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6454 smart_ext_selftest_log_index[1] << 8;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6455 if (index == 0)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6456 goto out;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6457
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6458 --index; /* Correct for 0 origin */
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6459 start_index = index; /* remember where we started */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6460 block_num = index / ENTRIES_PER_EXT_SELFTEST_LOG_BLK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6461 if (block_num != 0) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6462 rval = sata_ext_smart_selftest_read_log(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6463 sata_hba_inst, sdinfo, ext_selftest_log,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6464 block_num);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6465 if (rval != 0)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6466 goto out;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6467 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6468 index %= ENTRIES_PER_EXT_SELFTEST_LOG_BLK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6469 entry =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6470 &ext_selftest_log->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6471 smart_ext_selftest_log_entries[index];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6472
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6473 for (count = 1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6474 count <= SCSI_ENTRIES_IN_LOG_SENSE_SELFTEST_RESULTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6475 ++count) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6476 uint8_t status;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6477 uint8_t code;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6478 uint8_t sense_key;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6479 uint8_t add_sense_code;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6480 uint8_t add_sense_code_qual;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6481
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6482 /* If this is an unused entry, we are done */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6483 if (bcmp(entry, &empty, sizeof (empty)) == 0) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6484 /* Broken firmware on some disks */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6485 if (index + 1 ==
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6486 ENTRIES_PER_EXT_SELFTEST_LOG_BLK) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6487 --entry;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6488 --index;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6489 if (bcmp(entry, &empty,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6490 sizeof (empty)) == 0)
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6491 goto out;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6492 } else
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6493 goto out;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6494 }
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6495
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6496 if (only_one_block &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6497 start_index == index)
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6498 goto out;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6499
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6500 lpp->param_code[0] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6501 lpp->param_code[1] = count;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6502 lpp->param_ctrl_flags =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6503 LOG_CTRL_LP | LOG_CTRL_LBIN;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6504 lpp->param_len =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6505 SCSI_LOG_SENSE_SELFTEST_PARAM_LEN;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6506
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6507 status = entry->smart_ext_selftest_log_status;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6508 status >>= 4;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6509 switch (status) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6510 case 0:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6511 default:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6512 sense_key = KEY_NO_SENSE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6513 add_sense_code = SD_SCSI_NO_ADD_SENSE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6514 add_sense_code_qual = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6515 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6516 case 1:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6517 sense_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6518 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6519 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6520 add_sense_code_qual = SCSI_COMPONENT_81;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6521 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6522 case 2:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6523 sense_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6524 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6525 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6526 add_sense_code_qual = SCSI_COMPONENT_82;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6527 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6528 case 3:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6529 sense_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6530 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6531 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6532 add_sense_code_qual = SCSI_COMPONENT_83;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6533 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6534 case 4:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6535 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6536 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6537 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6538 add_sense_code_qual = SCSI_COMPONENT_84;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6539 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6540 case 5:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6541 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6542 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6543 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6544 add_sense_code_qual = SCSI_COMPONENT_85;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6545 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6546 case 6:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6547 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6548 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6549 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6550 add_sense_code_qual = SCSI_COMPONENT_86;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6551 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6552 case 7:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6553 sense_key = KEY_MEDIUM_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6554 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6555 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6556 add_sense_code_qual = SCSI_COMPONENT_87;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6557 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6558 case 8:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6559 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6560 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6561 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6562 add_sense_code_qual = SCSI_COMPONENT_88;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6563 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6564 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6565 code = 0; /* unspecified */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6566 status |= (code << 4);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6567 lpp->param_values[0] = status;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6568 lpp->param_values[1] = 0; /* unspecified */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6569 lpp->param_values[2] = entry->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6570 smart_ext_selftest_log_timestamp[1];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6571 lpp->param_values[3] = entry->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6572 smart_ext_selftest_log_timestamp[0];
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6573 if (status != 0) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6574 lpp->param_values[4] = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6575 lpp->param_values[5] = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6576 lpp->param_values[6] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6577 smart_ext_selftest_log_failing_lba
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6578 [5];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6579 lpp->param_values[7] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6580 smart_ext_selftest_log_failing_lba
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6581 [4];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6582 lpp->param_values[8] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6583 smart_ext_selftest_log_failing_lba
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6584 [3];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6585 lpp->param_values[9] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6586 smart_ext_selftest_log_failing_lba
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6587 [2];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6588 lpp->param_values[10] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6589 smart_ext_selftest_log_failing_lba
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6590 [1];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6591 lpp->param_values[11] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6592 smart_ext_selftest_log_failing_lba
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6593 [0];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6594 } else { /* No bad block address */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6595 lpp->param_values[4] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6596 lpp->param_values[5] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6597 lpp->param_values[6] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6598 lpp->param_values[7] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6599 lpp->param_values[8] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6600 lpp->param_values[9] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6601 lpp->param_values[10] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6602 lpp->param_values[11] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6603 }
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6604
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6605 lpp->param_values[12] = sense_key;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6606 lpp->param_values[13] = add_sense_code;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6607 lpp->param_values[14] = add_sense_code_qual;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6608 lpp->param_values[15] = 0; /* undefined */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6609
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6610 lpp = (struct log_parameter *)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6611 (((uint8_t *)lpp) +
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6612 SCSI_LOG_PARAM_HDR_LEN +
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6613 SCSI_LOG_SENSE_SELFTEST_PARAM_LEN);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6614
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6615 --index; /* Back up to previous entry */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6616 if (index < 0) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6617 if (block_num > 0) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6618 --block_num;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6619 } else {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6620 struct read_log_ext_directory
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6621 logdir;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6622
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6623 rval =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6624 sata_read_log_ext_directory(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6625 sata_hba_inst, sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6626 &logdir);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6627 if (rval == -1)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6628 goto out;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6629 if ((logdir.read_log_ext_vers
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6630 [0] == 0) &&
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6631 (logdir.read_log_ext_vers
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6632 [1] == 0))
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6633 goto out;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6634 block_num =
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6635 logdir.read_log_ext_nblks
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6636 [EXT_SMART_SELFTEST_LOG_PAGE
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6637 - 1][0];
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6638 block_num |= logdir.
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6639 read_log_ext_nblks
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6640 [EXT_SMART_SELFTEST_LOG_PAGE
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6641 - 1][1] << 8;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6642 --block_num;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6643 only_one_block =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6644 (block_num == 0);
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6645 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6646 rval = sata_ext_smart_selftest_read_log(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6647 sata_hba_inst, sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6648 ext_selftest_log, block_num);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6649 if (rval != 0)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6650 goto out;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6651
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6652 index =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6653 ENTRIES_PER_EXT_SELFTEST_LOG_BLK -
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6654 1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6655 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6656 index %= ENTRIES_PER_EXT_SELFTEST_LOG_BLK;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6657 entry = &ext_selftest_log->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6658 smart_ext_selftest_log_entries[index];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6659 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6660 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6661 out:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6662 kmem_free(ext_selftest_log,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6663 sizeof (struct smart_ext_selftest_log));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6664 } else {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6665 struct smart_selftest_log *selftest_log;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6666
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6667 selftest_log = kmem_zalloc(sizeof (struct smart_selftest_log),
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6668 KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6669
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6670 rval = sata_smart_selftest_log(sata_hba_inst, sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6671 selftest_log);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6672
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6673 if (rval == 0) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6674 int index;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6675 int count;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6676 struct smart_selftest_log_entry *entry;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6677 static const struct smart_selftest_log_entry empty =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6678 { 0 };
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6679
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6680 index = selftest_log->smart_selftest_log_index;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6681 if (index == 0)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6682 goto done;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6683 --index; /* Correct for 0 origin */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6684 entry = &selftest_log->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6685 smart_selftest_log_entries[index];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6686 for (count = 1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6687 count <= SCSI_ENTRIES_IN_LOG_SENSE_SELFTEST_RESULTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6688 ++count) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6689 uint8_t status;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6690 uint8_t code;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6691 uint8_t sense_key;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6692 uint8_t add_sense_code;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6693 uint8_t add_sense_code_qual;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6694
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6695 if (bcmp(entry, &empty, sizeof (empty)) == 0)
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6696 goto done;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6697
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6698 lpp->param_code[0] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6699 lpp->param_code[1] = count;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6700 lpp->param_ctrl_flags =
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6701 LOG_CTRL_LP | LOG_CTRL_LBIN;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6702 lpp->param_len =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6703 SCSI_LOG_SENSE_SELFTEST_PARAM_LEN;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6704
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6705 status = entry->smart_selftest_log_status;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6706 status >>= 4;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6707 switch (status) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6708 case 0:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6709 default:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6710 sense_key = KEY_NO_SENSE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6711 add_sense_code = SD_SCSI_NO_ADD_SENSE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6712 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6713 case 1:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6714 sense_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6715 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6716 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6717 add_sense_code_qual = SCSI_COMPONENT_81;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6718 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6719 case 2:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6720 sense_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6721 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6722 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6723 add_sense_code_qual = SCSI_COMPONENT_82;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6724 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6725 case 3:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6726 sense_key = KEY_ABORTED_COMMAND;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6727 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6728 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6729 add_sense_code_qual = SCSI_COMPONENT_83;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6730 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6731 case 4:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6732 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6733 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6734 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6735 add_sense_code_qual = SCSI_COMPONENT_84;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6736 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6737 case 5:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6738 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6739 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6740 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6741 add_sense_code_qual = SCSI_COMPONENT_85;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6742 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6743 case 6:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6744 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6745 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6746 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6747 add_sense_code_qual = SCSI_COMPONENT_86;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6748 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6749 case 7:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6750 sense_key = KEY_MEDIUM_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6751 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6752 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6753 add_sense_code_qual = SCSI_COMPONENT_87;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6754 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6755 case 8:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6756 sense_key = KEY_HARDWARE_ERROR;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6757 add_sense_code =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6758 DIAGNOSTIC_FAILURE_ON_COMPONENT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6759 add_sense_code_qual = SCSI_COMPONENT_88;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6760 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6761 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6762 code = 0; /* unspecified */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6763 status |= (code << 4);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6764 lpp->param_values[0] = status;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6765 lpp->param_values[1] = 0; /* unspecified */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6766 lpp->param_values[2] = entry->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6767 smart_selftest_log_timestamp[1];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6768 lpp->param_values[3] = entry->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6769 smart_selftest_log_timestamp[0];
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6770 if (status != 0) {
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6771 lpp->param_values[4] = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6772 lpp->param_values[5] = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6773 lpp->param_values[6] = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6774 lpp->param_values[7] = 0;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6775 lpp->param_values[8] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6776 smart_selftest_log_failing_lba[3];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6777 lpp->param_values[9] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6778 smart_selftest_log_failing_lba[2];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6779 lpp->param_values[10] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6780 smart_selftest_log_failing_lba[1];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6781 lpp->param_values[11] = entry->
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6782 smart_selftest_log_failing_lba[0];
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6783 } else { /* No block address */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6784 lpp->param_values[4] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6785 lpp->param_values[5] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6786 lpp->param_values[6] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6787 lpp->param_values[7] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6788 lpp->param_values[8] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6789 lpp->param_values[9] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6790 lpp->param_values[10] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6791 lpp->param_values[11] = 0xff;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6792 }
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6793 lpp->param_values[12] = sense_key;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6794 lpp->param_values[13] = add_sense_code;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6795 lpp->param_values[14] = add_sense_code_qual;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6796 lpp->param_values[15] = 0; /* undefined */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6797
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6798 lpp = (struct log_parameter *)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6799 (((uint8_t *)lpp) +
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6800 SCSI_LOG_PARAM_HDR_LEN +
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6801 SCSI_LOG_SENSE_SELFTEST_PARAM_LEN);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6802 --index; /* back up to previous entry */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6803 if (index < 0) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6804 index =
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6805 NUM_SMART_SELFTEST_LOG_ENTRIES - 1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6806 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6807 entry = &selftest_log->
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6808 smart_selftest_log_entries[index];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6809 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6810 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6811 done:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6812 kmem_free(selftest_log, sizeof (struct smart_selftest_log));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6813 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6814
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6815 return ((SCSI_LOG_PARAM_HDR_LEN + SCSI_LOG_SENSE_SELFTEST_PARAM_LEN) *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6816 SCSI_ENTRIES_IN_LOG_SENSE_SELFTEST_RESULTS);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6817 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6818
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6819 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6820 * sata_build_lsense_page_2f() is used to create the
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6821 * SCSI LOG SENSE page 0x10 (informational exceptions)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6822 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6823 * Takes a sata_drive_info t * and the address of a buffer
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6824 * in which to create the page information as well as a sata_hba_inst_t *.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6825 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6826 * Returns the number of bytes valid in the buffer.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6827 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6828 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6829 sata_build_lsense_page_2f(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6830 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6831 uint8_t *buf,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6832 sata_hba_inst_t *sata_hba_inst)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6833 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6834 struct log_parameter *lpp = (struct log_parameter *)buf;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6835 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6836 uint8_t *smart_data;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6837 uint8_t temp;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6838 sata_id_t *sata_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6839 #define SMART_NO_TEMP 0xff
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6840
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6841 lpp->param_code[0] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6842 lpp->param_code[1] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6843 lpp->param_ctrl_flags = LOG_CTRL_LP | LOG_CTRL_LBIN;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6844
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6845 /* Now get the SMART status w.r.t. threshold exceeded */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6846 rval = sata_fetch_smart_return_status(sata_hba_inst, sdinfo);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6847 switch (rval) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6848 case 1:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6849 lpp->param_values[0] = SCSI_PREDICTED_FAILURE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6850 lpp->param_values[1] = SCSI_GENERAL_HD_FAILURE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6851 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6852 case 0:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6853 case -1: /* failed to get data */
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6854 lpp->param_values[0] = 0; /* No failure predicted */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6855 lpp->param_values[1] = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6856 break;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6857 #if defined(SATA_DEBUG)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6858 default:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6859 cmn_err(CE_PANIC, "sata_build_lsense_page_2f bad return value");
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6860 /* NOTREACHED */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6861 #endif
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6862 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6863
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6864 sata_id = &sdinfo->satadrv_id;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6865 if (! (sata_id->ai_sctsupport & SATA_SCT_CMD_TRANS_SUP))
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6866 temp = SMART_NO_TEMP;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6867 else {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6868 /* Now get the temperature */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6869 smart_data = kmem_zalloc(512, KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6870 rval = sata_smart_read_log(sata_hba_inst, sdinfo, smart_data,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6871 SCT_STATUS_LOG_PAGE, 1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6872 if (rval == -1)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6873 temp = SMART_NO_TEMP;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6874 else {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6875 temp = smart_data[200];
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6876 if (temp & 0x80) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6877 if (temp & 0x7f)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6878 temp = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6879 else
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6880 temp = SMART_NO_TEMP;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6881 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6882 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6883 kmem_free(smart_data, 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6884 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6885
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6886 lpp->param_values[2] = temp; /* most recent temperature */
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
6887 lpp->param_values[3] = 0; /* required vendor specific byte */
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6888
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6889 lpp->param_len = SCSI_INFO_EXCEPTIONS_PARAM_LEN;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6890
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6891
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6892 return (SCSI_INFO_EXCEPTIONS_PARAM_LEN + SCSI_LOG_PARAM_HDR_LEN);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6893 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6894
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6895 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6896 * sata_build_lsense_page_30() is used to create the
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6897 * SCSI LOG SENSE page 0x30 (Sun's vendor specific page for ATA SMART data).
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6898 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6899 * Takes a sata_drive_info t * and the address of a buffer
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6900 * in which to create the page information as well as a sata_hba_inst_t *.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6901 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6902 * Returns the number of bytes valid in the buffer.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6903 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6904 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6905 sata_build_lsense_page_30(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6906 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6907 uint8_t *buf,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6908 sata_hba_inst_t *sata_hba_inst)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6909 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6910 struct smart_data *smart_data = (struct smart_data *)buf;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6911 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6912
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6913 /* Now do the SMART READ DATA */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6914 rval = sata_fetch_smart_data(sata_hba_inst, sdinfo, smart_data);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6915 if (rval == -1)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6916 return (0);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6917
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6918 return (sizeof (struct smart_data));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6919 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
6920
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6921
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6922
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6923
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6924
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6925 /* ************************** LOCAL FUNCTIONS ************************** */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6926
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6927 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6928 * Validate sata_tran info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6929 * SATA_FAILURE returns if structure is inconsistent or structure revision
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6930 * does not match one used by the framework.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6931 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6932 * Returns SATA_SUCCESS if sata_hba_tran has matching revision and contains
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6933 * required function pointers.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6934 * Returns SATA_FAILURE otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6935 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6936 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6937 sata_validate_sata_hba_tran(dev_info_t *dip, sata_hba_tran_t *sata_tran)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6938 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6939 if (sata_tran->sata_tran_hba_rev != SATA_TRAN_HBA_REV) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6940 sata_log(NULL, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6941 "sata: invalid sata_hba_tran version %d for driver %s",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6942 sata_tran->sata_tran_hba_rev, ddi_driver_name(dip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6943 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6944 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6945
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6946 if (dip != sata_tran->sata_tran_hba_dip) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6947 SATA_LOG_D((NULL, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6948 "sata: inconsistent sata_tran_hba_dip "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6949 "%p / %p", sata_tran->sata_tran_hba_dip, dip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6950 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6951 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6952
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6953 if (sata_tran->sata_tran_probe_port == NULL ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6954 sata_tran->sata_tran_start == NULL ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6955 sata_tran->sata_tran_abort == NULL ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6956 sata_tran->sata_tran_reset_dport == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6957 SATA_LOG_D((NULL, CE_WARN, "sata: sata_hba_tran missing "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6958 "required functions"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6959 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6960 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6961 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6962
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6963 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6964 * Remove HBA instance from sata_hba_list.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6965 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6966 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6967 sata_remove_hba_instance(dev_info_t *dip)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6968 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6969 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6970
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6971 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6972 for (sata_hba_inst = sata_hba_list;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6973 sata_hba_inst != (struct sata_hba_inst *)NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6974 sata_hba_inst = sata_hba_inst->satahba_next) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6975 if (sata_hba_inst->satahba_dip == dip)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6976 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6977 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6978
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6979 if (sata_hba_inst == (struct sata_hba_inst *)NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6980 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6981 cmn_err(CE_WARN, "sata_remove_hba_instance: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6982 "unknown HBA instance\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6983 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6984 ASSERT(FALSE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6985 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6986 if (sata_hba_inst == sata_hba_list) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6987 sata_hba_list = sata_hba_inst->satahba_next;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6988 if (sata_hba_list) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6989 sata_hba_list->satahba_prev =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6990 (struct sata_hba_inst *)NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6991 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6992 if (sata_hba_inst == sata_hba_list_tail) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6993 sata_hba_list_tail = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6994 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6995 } else if (sata_hba_inst == sata_hba_list_tail) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6996 sata_hba_list_tail = sata_hba_inst->satahba_prev;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6997 if (sata_hba_list_tail) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6998 sata_hba_list_tail->satahba_next =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
6999 (struct sata_hba_inst *)NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7000 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7001 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7002 sata_hba_inst->satahba_prev->satahba_next =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7003 sata_hba_inst->satahba_next;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7004 sata_hba_inst->satahba_next->satahba_prev =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7005 sata_hba_inst->satahba_prev;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7006 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7007 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7008 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7009
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7010
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7011
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7012
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7013
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7014 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7015 * Probe all SATA ports of the specified HBA instance.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7016 * This function is called only from sata_hba_attach(). It does not have to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7017 * be protected by controller mutex, because the hba_attached flag is not set
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7018 * yet and no one would be touching this HBA instance other then this thread.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7019 * Determines if port is active and what type of the device is attached
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7020 * (if any). Allocates necessary structures for each port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7021 * Creates attachment point minor node for each non-failed port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7022 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7023
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7024 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7025 sata_probe_ports(sata_hba_inst_t *sata_hba_inst)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7026 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7027 dev_info_t *dip = SATA_DIP(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7028 int ncport, npmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7029 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7030 sata_drive_info_t *drive;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7031 sata_pmult_info_t *pminfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7032 sata_pmport_info_t *pmportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7033 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7034 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7035 dev_t minor_number;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7036 char name[16];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7037
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7038 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7039 * Probe controller ports first, to find port status and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7040 * any port multiplier attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7041 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7042 for (ncport = 0; ncport < SATA_NUM_CPORTS(sata_hba_inst); ncport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7043 /* allocate cport structure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7044 cportinfo = kmem_zalloc(sizeof (sata_cport_info_t), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7045 ASSERT(cportinfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7046 mutex_init(&cportinfo->cport_mutex, NULL, MUTEX_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7047
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7048 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7049
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7050 cportinfo->cport_addr.cport = ncport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7051 cportinfo->cport_addr.pmport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7052 cportinfo->cport_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7053 cportinfo->cport_state &= ~SATA_PORT_STATE_CLEAR_MASK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7054 cportinfo->cport_state |= SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7055 SATA_CPORT_INFO(sata_hba_inst, ncport) = cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7056
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7057 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7058 * Regardless if a port is usable or not, create
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7059 * an attachment point
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7060 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7061 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7062 minor_number =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7063 SATA_MAKE_AP_MINOR(ddi_get_instance(dip), ncport, 0, 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7064 (void) sprintf(name, "%d", ncport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7065 if (ddi_create_minor_node(dip, name, S_IFCHR,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7066 minor_number, DDI_NT_SATA_ATTACHMENT_POINT, 0) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7067 DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7068 sata_log(sata_hba_inst, CE_WARN, "sata_hba_attach: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7069 "cannot create sata attachment point for port %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7070 ncport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7071 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7072
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7073 /* Probe port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7074 sata_device.satadev_addr.cport = ncport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7075 sata_device.satadev_addr.pmport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7076 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7077 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7078
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7079 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7080 (dip, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7081
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7082 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7083 sata_update_port_scr(&cportinfo->cport_scr, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7084 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7085 /* Something went wrong? Fail the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7086 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7087 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7088 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7089 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7090 cportinfo->cport_state &= ~SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7091 cportinfo->cport_state |= SATA_STATE_PROBED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7092 cportinfo->cport_dev_type = sata_device.satadev_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7093
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7094 cportinfo->cport_state |= SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7095 if (cportinfo->cport_dev_type == SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7096 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7097 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7098 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7099 if (cportinfo->cport_dev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7100 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7101 * There is some device attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7102 * Allocate device info structure
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7103 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7104 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7105 drive = kmem_zalloc(sizeof (sata_drive_info_t),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7106 KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7107 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7108 SATA_CPORTINFO_DRV_INFO(cportinfo) = drive;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7109 drive->satadrv_addr = cportinfo->cport_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7110 drive->satadrv_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7111 drive->satadrv_type = cportinfo->cport_dev_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7112 drive->satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7113 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7114 ASSERT(cportinfo->cport_dev_type == SATA_DTYPE_PMULT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7115 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7116 pminfo = kmem_zalloc(sizeof (sata_pmult_info_t),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7117 KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7118 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7119 ASSERT(pminfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7120 SATA_CPORTINFO_PMULT_INFO(cportinfo) = pminfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7121 pminfo->pmult_addr.cport = cportinfo->cport_addr.cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7122 pminfo->pmult_addr.pmport = SATA_PMULT_HOSTPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7123 pminfo->pmult_addr.qual = SATA_ADDR_PMPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7124 pminfo->pmult_num_dev_ports =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7125 sata_device.satadev_add_info;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7126 mutex_init(&pminfo->pmult_mutex, NULL, MUTEX_DRIVER,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7127 NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7128 pminfo->pmult_state = SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7129
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7130 /* Probe Port Multiplier ports */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7131 for (npmport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7132 npmport < pminfo->pmult_num_dev_ports;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7133 npmport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7134 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7135 pmportinfo = kmem_zalloc(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7136 sizeof (sata_pmport_info_t), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7137 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7138 ASSERT(pmportinfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7139 pmportinfo->pmport_addr.cport = ncport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7140 pmportinfo->pmport_addr.pmport = npmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7141 pmportinfo->pmport_addr.qual =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7142 SATA_ADDR_PMPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7143 pminfo->pmult_dev_port[npmport] = pmportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7144 mutex_init(&pmportinfo->pmport_mutex, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7145 MUTEX_DRIVER, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7146
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7147 sata_device.satadev_addr.pmport = npmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7148 sata_device.satadev_addr.qual =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7149 SATA_ADDR_PMPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7150
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7151 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7152 /* Create an attachment point */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7153 minor_number = SATA_MAKE_AP_MINOR(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7154 ddi_get_instance(dip), ncport, npmport, 1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7155 (void) sprintf(name, "%d.%d", ncport, npmport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7156 if (ddi_create_minor_node(dip, name, S_IFCHR,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7157 minor_number, DDI_NT_SATA_ATTACHMENT_POINT,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7158 0) != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7159 sata_log(sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7160 "sata_hba_attach: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7161 "cannot create sata attachment "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7162 "point for port %d pmult port %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7163 ncport, npmport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7164 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7165 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7166 (dip, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7167 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7168
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7169 /* sata_update_port_info() */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7170 sata_update_port_scr(&pmportinfo->pmport_scr,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7171 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7172
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7173 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7174 pmportinfo->pmport_state =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7175 SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7176 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7177 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7178 pmportinfo->pmport_state &=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7179 ~SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7180 pmportinfo->pmport_state |= SATA_STATE_PROBED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7181 pmportinfo->pmport_dev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7182 sata_device.satadev_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7183
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7184 pmportinfo->pmport_state |= SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7185 if (pmportinfo->pmport_dev_type ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7186 SATA_DTYPE_NONE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7187 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7188
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7189 /* Port multipliers cannot be chained */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7190 ASSERT(pmportinfo->pmport_dev_type !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7191 SATA_DTYPE_PMULT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7192 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7193 * There is something attached to Port
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7194 * Multiplier device port
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7195 * Allocate device info structure
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7196 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7197 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7198 drive = kmem_zalloc(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7199 sizeof (sata_drive_info_t), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7200 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7201 (dip, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7202 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7203
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7204 /* sata_update_port_info() */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7205 sata_update_port_scr(&pmportinfo->pmport_scr,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7206 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7207
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7208 pmportinfo->pmport_sata_drive = drive;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7209 drive->satadrv_addr.cport =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7210 pmportinfo->pmport_addr.cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7211 drive->satadrv_addr.pmport = npmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7212 drive->satadrv_addr.qual = SATA_ADDR_DPMPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7213 drive->satadrv_type = pmportinfo->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7214 pmport_dev_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7215 drive->satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7216 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7217 pmportinfo->pmport_state =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7218 SATA_STATE_PROBED | SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7219 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7220 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7221 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7222 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7223
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7224
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7225
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7226 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7227 * Create SATA device nodes for specified HBA instance (SCSI target
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7228 * device nodes).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7229 * This function is called only from sata_hba_attach(). The hba_attached flag
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7230 * is not set yet, so no ports or device data structures would be touched
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7231 * by anyone other then this thread, therefore per-port mutex protection is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7232 * not needed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7233 * The assumption is that there are no target and attachment point minor nodes
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7234 * created by the boot subsystems, so we do not need to prune device tree.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7235 * An AP (Attachement Point) node is created for each SATA device port even
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7236 * when there is no device attached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7237 * A target node is created when there is a supported type of device attached,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7238 * but may be removed if it cannot be put online.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7239 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7240 * This function cannot be called from an interrupt context.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7241 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7242 * ONLY DISK TARGET NODES ARE CREATED NOW
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7243 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7244 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7245 sata_make_device_nodes(dev_info_t *pdip, sata_hba_inst_t *sata_hba_inst)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7246 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7247 int ncport, npmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7248 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7249 sata_pmult_info_t *pminfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7250 sata_pmport_info_t *pmportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7251 dev_info_t *cdip; /* child dip */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7252 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7253 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7254
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7255 /*
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7256 * Walk through pre-probed sata ports info in sata_hba_inst structure
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7257 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7258 for (ncport = 0; ncport < SATA_NUM_CPORTS(sata_hba_inst); ncport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7259 cportinfo = SATA_CPORT_INFO(sata_hba_inst, ncport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7260 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7261 if (!(cportinfo->cport_state & SATA_STATE_PROBED)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7262 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7263 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7264 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7265 if (cportinfo->cport_state == SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7266 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7267 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7268 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7269 if (cportinfo->cport_dev_type == SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7270 /* No device attached to the controller port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7271 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7272 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7273 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7274 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7275 * Some device is attached to a controller port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7276 * We rely on controllers distinquishing between no-device,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7277 * attached port multiplier and other kind of attached device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7278 * We need to get Identify Device data and determine
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7279 * positively the dev type before trying to attach
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7280 * the target driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7281 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7282 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7283 if (cportinfo->cport_dev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7284 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7285 * Not port multiplier.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7286 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7287 sata_device.satadev_addr = cportinfo->cport_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7288 sata_device.satadev_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7289 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7290 rval = sata_probe_device(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7291 if (rval != SATA_SUCCESS ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7292 sata_device.satadev_type == SATA_DTYPE_UNKNOWN)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7293 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7294
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7295 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7296 if ((sata_device.satadev_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7297 SATA_VALID_DEV_TYPE) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7298 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7299 * Could not determine device type or
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7300 * a device is not supported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7301 * Degrade this device to unknown.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7302 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7303 cportinfo->cport_dev_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7304 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7305 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7306 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7307 cportinfo->cport_dev_type = sata_device.satadev_type;
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7308 mutex_exit(&cportinfo->cport_mutex);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7309
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7310 if (sata_initialize_device(sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7311 SATA_CPORTINFO_DRV_INFO(cportinfo)) != SATA_SUCCESS)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7312 /* Retry */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7313 (void) sata_initialize_device(sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7314 SATA_CPORTINFO_DRV_INFO(cportinfo));
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7315
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7316 mutex_enter(&cportinfo->cport_mutex);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7317 sata_show_drive_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7318 SATA_CPORTINFO_DRV_INFO(cportinfo));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7319 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7320 cdip = sata_create_target_node(pdip, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7321 &sata_device.satadev_addr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7322 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7323 if (cdip == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7324 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7325 * Attaching target node failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7326 * We retain sata_drive_info structure...
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7327 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7328 (SATA_CPORTINFO_DRV_INFO(cportinfo))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7329 satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7330 (SATA_CPORTINFO_DRV_INFO(cportinfo))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7331 satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7332 cportinfo->cport_dev_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7333 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7334 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7335 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7336 (SATA_CPORTINFO_DRV_INFO(cportinfo))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7337 satadrv_state = SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7338 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7339 /* This must be Port Multiplier type */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7340 if (cportinfo->cport_dev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7341 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7342 "sata_make_device_nodes: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7343 "unknown dev type %x",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7344 cportinfo->cport_dev_type));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7345 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7346 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7347 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7348 pminfo = SATA_CPORTINFO_PMULT_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7349 for (npmport = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7350 npmport < pminfo->pmult_num_dev_ports;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7351 npmport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7352 pmportinfo = pminfo->pmult_dev_port[npmport];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7353 if (pmportinfo->pmport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7354 SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7355 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7356 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7357 if (pmportinfo->pmport_dev_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7358 SATA_DTYPE_NONE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7359 /* No device attached */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7360 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7361
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7362 sata_device.satadev_addr =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7363 pmportinfo->pmport_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7364 sata_device.satadev_addr.qual =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7365 SATA_ADDR_DPMPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7366 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7367 rval = sata_probe_device(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7368 &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7369 if (rval != SATA_SUCCESS ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7370 sata_device.satadev_type ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7371 SATA_DTYPE_UNKNOWN) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7372 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7373 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7374 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7375 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7376 if ((sata_device.satadev_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7377 SATA_VALID_DEV_TYPE) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7378 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7379 * Could not determine device type.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7380 * Degrade this device to unknown.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7381 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7382 pmportinfo->pmport_dev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7383 SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7384 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7385 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7386 pmportinfo->pmport_dev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7387 sata_device.satadev_type;
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7388 mutex_exit(&cportinfo->cport_mutex);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7389 if (sata_initialize_device(sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7390 pmportinfo->pmport_sata_drive) !=
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7391 SATA_SUCCESS)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7392 /* Retry */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7393 (void) sata_initialize_device(
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7394 sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7395 pmportinfo->pmport_sata_drive);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7396
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7397 mutex_enter(&cportinfo->cport_mutex);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7398 sata_show_drive_info(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7399 pmportinfo->pmport_sata_drive);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7400 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7401 cdip = sata_create_target_node(pdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7402 sata_hba_inst, &sata_device.satadev_addr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7403 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7404 if (cdip == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7405 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7406 * Attaching target node failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7407 * We retain sata_drive_info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7408 * structure...
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7409 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7410 pmportinfo->pmport_sata_drive->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7411 satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7412 pmportinfo->pmport_sata_drive->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7413 satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7414 pmportinfo->pmport_dev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7415 SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7416 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7417 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7418 pmportinfo->pmport_sata_drive->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7419 satadrv_state |= SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7420 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7421 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7422 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7423 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7424 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7425
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7426
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7427
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7428 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7429 * Create scsi target node for attached device, create node properties and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7430 * attach the node.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7431 * The node could be removed if the device onlining fails.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7432 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7433 * A dev_info_t pointer is returned if operation is successful, NULL is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7434 * returned otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7435 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7436
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7437 static dev_info_t *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7438 sata_create_target_node(dev_info_t *dip, sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7439 sata_address_t *sata_addr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7440 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7441 dev_info_t *cdip = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7442 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7443 char *nname = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7444 char **compatible = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7445 int ncompatible;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7446 struct scsi_inquiry inq;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7447 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7448 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7449 int target;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7450 int i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7451
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7452 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7453 sata_device.satadev_addr = *sata_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7454
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7455 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst, sata_addr->cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7456
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7457 sdinfo = sata_get_device_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7458
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7459 target = SATA_TO_SCSI_TARGET(sata_addr->cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7460 sata_addr->pmport, sata_addr->qual);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7461
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7462 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7463 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7464 sata_addr->cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7465 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7466 "sata_create_target_node: no sdinfo for target %x",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7467 target));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7468 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7469 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7470
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7471 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7472 * create scsi inquiry data, expected by
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7473 * scsi_hba_nodename_compatible_get()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7474 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7475 sata_identdev_to_inquiry(sata_hba_inst, sdinfo, (uint8_t *)&inq);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7476 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, sata_addr->cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7477
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7478 /* determine the node name and compatible */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7479 scsi_hba_nodename_compatible_get(&inq, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7480 inq.inq_dtype, NULL, &nname, &compatible, &ncompatible);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7481
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7482 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7483 if (sata_debug_flags & SATA_DBG_NODES) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7484 if (nname == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7485 cmn_err(CE_NOTE, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7486 "cannot determine nodename for target %d\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7487 target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7488 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7489 cmn_err(CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7490 "target %d nodename: %s\n", target, nname);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7491 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7492 if (compatible == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7493 cmn_err(CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7494 "sata_create_target_node: no compatible name\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7495 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7496 for (i = 0; i < ncompatible; i++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7497 cmn_err(CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7498 "compatible name: %s\n", compatible[i]);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7499 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7500 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7501 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7502 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7503
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7504 /* if nodename can't be determined, log error and exit */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7505 if (nname == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7506 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7507 "sata_create_target_node: cannot determine nodename "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7508 "for target %d\n", target));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7509 scsi_hba_nodename_compatible_free(nname, compatible);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7510 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7511 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7512 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7513 * Create scsi target node
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7514 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7515 ndi_devi_alloc_sleep(dip, nname, (pnode_t)DEVI_SID_NODEID, &cdip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7516 rval = ndi_prop_update_string(DDI_DEV_T_NONE, cdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7517 "device-type", "scsi");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7518
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7519 if (rval != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7520 SATA_LOG_D((sata_hba_inst, CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7521 "updating device_type prop failed %d", rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7522 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7523 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7524
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7525 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7526 * Create target node properties: target & lun
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7527 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7528 rval = ndi_prop_update_int(DDI_DEV_T_NONE, cdip, "target", target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7529 if (rval != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7530 SATA_LOG_D((sata_hba_inst, CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7531 "updating target prop failed %d", rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7532 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7533 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7534 rval = ndi_prop_update_int(DDI_DEV_T_NONE, cdip, "lun", 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7535 if (rval != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7536 SATA_LOG_D((sata_hba_inst, CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7537 "updating target prop failed %d", rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7538 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7539 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7540
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7541 /* decorate the node with compatible */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7542 if (ndi_prop_update_string_array(DDI_DEV_T_NONE, cdip, "compatible",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7543 compatible, ncompatible) != DDI_PROP_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7544 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7545 "sata_create_target_node: FAIL compatible props cdip 0x%p",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7546 (void *)cdip));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7547 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7548 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7549
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7550 /*
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7551 * Set default write cache mode
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7552 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7553 rval = sata_init_write_cache_mode(sata_hba_inst, sdinfo);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7554 if (rval != SATA_SUCCESS) {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7555 sata_log(sata_hba_inst, CE_WARN, "sata_create_target_node: "
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7556 "cannot set deafult write cache mode for "
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7557 "device at port %d", sata_addr->cport);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7558 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7559
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7560 /*
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7561 * Now, try to attach the driver. If probing of the device fails,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7562 * the target node may be removed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7563 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7564 rval = ndi_devi_online(cdip, NDI_ONLINE_ATTACH);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7565
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7566 scsi_hba_nodename_compatible_free(nname, compatible);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7567
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7568 if (rval == NDI_SUCCESS)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7569 return (cdip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7570
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7571 /* target node was removed - are we sure? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7572 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7573
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7574 fail:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7575 scsi_hba_nodename_compatible_free(nname, compatible);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7576 ddi_prop_remove_all(cdip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7577 rval = ndi_devi_free(cdip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7578 if (rval != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7579 SATA_LOG_D((sata_hba_inst, CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7580 "node removal failed %d", rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7581 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7582 sata_log(sata_hba_inst, CE_WARN, "sata_create_target_node: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7583 "cannot create target node for device at port %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7584 sata_addr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7585 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7586 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7587
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7588
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7589
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7590 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7591 * Re-probe sata port, check for a device and attach necessary info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7592 * structures when necessary. Identify Device data is fetched, if possible.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7593 * Assumption: sata address is already validated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7594 * SATA_SUCCESS is returned if port is re-probed sucessfully, regardless of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7595 * the presence of a device and its type.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7596 * SATA_FAILURE is returned if one of the operations failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7597 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7598 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7599 sata_reprobe_port(sata_hba_inst_t *sata_hba_inst, sata_device_t *sata_device)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7600 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7601 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7602 sata_drive_info_t *sdinfo;
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7603 boolean_t init_device = B_FALSE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7604 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7605
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7606 /* We only care about host sata cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7607 cportinfo = SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7608 sata_device->satadev_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7609 /* probe port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7610 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7611 cportinfo->cport_state &= ~SATA_PORT_STATE_CLEAR_MASK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7612 cportinfo->cport_state |= SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7613 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7614
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7615 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7616 (SATA_DIP(sata_hba_inst), sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7617
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7618 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7619 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7620 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7621 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7622 SATA_LOG_D((sata_hba_inst, CE_WARN, "sata_hba_ioctl: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7623 "connect: port probbing failed"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7624 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7625 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7626
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7627 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7628 * update sata port state and set device type
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7629 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7630 sata_update_port_info(sata_hba_inst, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7631 cportinfo->cport_state |= SATA_STATE_PROBED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7632
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7633 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7634 * Sanity check - Port is active? Is the link active?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7635 * Is there any device attached?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7636 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7637 if ((cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7638 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7639 (cportinfo->cport_scr.sstatus & SATA_PORT_DEVLINK_UP_MASK) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7640 SATA_PORT_DEVLINK_UP) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7641 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7642 * Port in non-usable state or no link active/no device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7643 * Free info structure if necessary (direct attached drive
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7644 * only, for now!
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7645 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7646 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7647 SATA_CPORTINFO_DRV_INFO(cportinfo) = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7648 /* Add here differentiation for device attached or not */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7649 cportinfo->cport_dev_type = SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7650 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7651 if (sdinfo != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7652 kmem_free(sdinfo, sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7653 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7654 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7655
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7656 cportinfo->cport_state |= SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7657 cportinfo->cport_dev_type = sata_device->satadev_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7658 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7659
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7660 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7661 * If we are re-probing the port, there may be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7662 * sata_drive_info structure attached
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7663 * (or sata_pm_info, if PMult is supported).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7664 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7665 if (sata_device->satadev_type == SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7666 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7667 * There is no device, so remove device info structure,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7668 * if necessary. Direct attached drive only!
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7669 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7670 SATA_CPORTINFO_DRV_INFO(cportinfo) = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7671 cportinfo->cport_dev_type = SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7672 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7673 kmem_free(sdinfo, sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7674 sata_log(sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7675 "SATA device detached "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7676 "from port %d", cportinfo->cport_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7677 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7678 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7679 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7680 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7681
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7682 if (sata_device->satadev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7683 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7684 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7685 * There is some device attached, but there is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7686 * no sata_drive_info structure - allocate one
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7687 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7688 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7689 sdinfo = kmem_zalloc(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7690 sizeof (sata_drive_info_t), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7691 mutex_enter(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7692 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7693 * Recheck, if port state did not change when we
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7694 * released mutex.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7695 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7696 if (cportinfo->cport_state & SATA_STATE_READY) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7697 SATA_CPORTINFO_DRV_INFO(cportinfo) = sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7698 sdinfo->satadrv_addr = cportinfo->cport_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7699 sdinfo->satadrv_addr.qual = SATA_ADDR_DCPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7700 sdinfo->satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7701 sdinfo->satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7702 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7703 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7704 * Port is not in ready state, we
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7705 * cannot attach a device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7706 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7707 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7708 kmem_free(sdinfo, sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7709 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7710 }
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7711 /*
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7712 * Since we are adding device, presumably new one,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7713 * indicate that it should be initalized,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7714 * as well as some internal framework states).
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7715 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7716 init_device = B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7717 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7718
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7719 cportinfo->cport_dev_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7720 sata_device->satadev_addr.qual = sdinfo->satadrv_addr.qual;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7721 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7722 cportinfo->cport_dev_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7723 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7724 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7725 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7726 mutex_exit(&cportinfo->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7727 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7728 * Figure out what kind of device we are really
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7729 * dealing with.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7730 */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7731 rval = sata_probe_device(sata_hba_inst, sata_device);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7732
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7733 /* Set initial device features, if necessary */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7734 if (rval == SATA_SUCCESS && init_device == B_TRUE) {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7735 if (sata_initialize_device(sata_hba_inst, sdinfo) !=
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7736 SATA_SUCCESS)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7737 /* retry */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7738 (void) sata_initialize_device(sata_hba_inst, sdinfo);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7739 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7740 return (rval);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7741 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7742
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7743 /*
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7744 * Initialize device
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7745 * Specified device is initialized to a default state.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7746 * At this point only read cache and UDMA modes are set here.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7747 * Write cache mode should be set when a disk is configured.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7748 *
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7749 * Only SATA disks are initialized for now.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7750 *
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7751 * Returns SATA_SUCCESS if all device features are set successfully,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7752 * SATA_FAILURE otherwise
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7753 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7754 static int
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7755 sata_initialize_device(sata_hba_inst_t *sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7756 sata_drive_info_t *sdinfo)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7757 {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7758
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7759 sata_save_drive_settings(sdinfo);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7760
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7761 sdinfo->satadrv_settings |= SATA_DEV_READ_AHEAD;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7762
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7763 return (sata_set_drive_features(sata_hba_inst, sdinfo, 0));
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7764 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7765
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7766
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7767 /*
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7768 * Initialize write cache mode.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7769 *
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7770 * The default write cache setting is provided by sata_write_cache
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7771 * static variable:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7772 * 1 - enable
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7773 * 0 - disable
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7774 * any other value - current drive setting
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7775 *
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7776 * In the future, it may be overridden by the
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7777 * disk-write-cache-enable property setting, if it is defined.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7778 * Returns SATA_SUCCESS if all device features are set successfully,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7779 * SATA_FAILURE otherwise.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7780 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7781 static int
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7782 sata_init_write_cache_mode(sata_hba_inst_t *sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7783 sata_drive_info_t *sdinfo)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7784 {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7785 if (sata_write_cache == 1)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7786 sdinfo->satadrv_settings |= SATA_DEV_WRITE_CACHE;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7787 else if (sata_write_cache == 0)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7788 sdinfo->satadrv_settings &= ~SATA_DEV_WRITE_CACHE;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7789 /*
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7790 * When sata_write_cache value is not 0 or 1,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7791 * a current setting of the drive's write cache is used.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7792 *
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7793 * Now set the write cache mode
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7794 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
7795 return (sata_set_drive_features(sata_hba_inst, sdinfo, 0));
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7796 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7797
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7798
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7799 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7800 * Validate sata address.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7801 * Specified cport, pmport and qualifier has to match
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7802 * passed sata_scsi configuration info.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7803 * The presence of an attached device is not verified.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7804 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7805 * Returns 0 when address is valid, -1 otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7806 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7807 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7808 sata_validate_sata_address(sata_hba_inst_t *sata_hba_inst, int cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7809 int pmport, int qual)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7810 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7811 if (qual == SATA_ADDR_DCPORT && pmport != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7812 goto invalid_address;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7813 if (cport >= SATA_NUM_CPORTS(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7814 goto invalid_address;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7815 if ((qual == SATA_ADDR_DPMPORT || qual == SATA_ADDR_PMPORT) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7816 ((SATA_CPORT_DEV_TYPE(sata_hba_inst, cport) != SATA_DTYPE_PMULT) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7817 (SATA_PMULT_INFO(sata_hba_inst, cport) == NULL) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7818 (pmport >= SATA_NUM_PMPORTS(sata_hba_inst, cport))))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7819 goto invalid_address;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7820
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7821 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7822
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7823 invalid_address:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7824 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7825
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7826 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7827
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7828 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7829 * Validate scsi address
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7830 * SCSI target address is translated into SATA cport/pmport and compared
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7831 * with a controller port/device configuration. LUN has to be 0.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7832 * Returns 0 if a scsi target refers to an attached device,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7833 * returns 1 if address is valid but device is not attached,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7834 * returns -1 if bad address or device is of an unsupported type.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7835 * Upon return sata_device argument is set.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7836 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7837 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7838 sata_validate_scsi_address(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7839 struct scsi_address *ap, sata_device_t *sata_device)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7840 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7841 int cport, pmport, qual, rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7842
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7843 rval = -1; /* Invalid address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7844 if (ap->a_lun != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7845 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7846
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7847 qual = SCSI_TO_SATA_ADDR_QUAL(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7848 cport = SCSI_TO_SATA_CPORT(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7849 pmport = SCSI_TO_SATA_PMPORT(ap->a_target);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7850
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7851 if (qual != SATA_ADDR_DCPORT && qual != SATA_ADDR_DPMPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7852 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7853
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7854 if (sata_validate_sata_address(sata_hba_inst, cport, pmport, qual) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7855 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7856
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7857 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7858 sata_pmult_info_t *pmultinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7859 sata_drive_info_t *sdinfo = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7860
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7861 rval = 1; /* Valid sata address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7862
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7863 cportinfo = SATA_CPORT_INFO(sata_hba_inst, cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7864 if (qual == SATA_ADDR_DCPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7865 if (cportinfo == NULL ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7866 cportinfo->cport_dev_type == SATA_DTYPE_NONE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7867 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7868
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7869 if (cportinfo->cport_dev_type == SATA_DTYPE_PMULT ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7870 (cportinfo->cport_dev_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7871 SATA_VALID_DEV_TYPE) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7872 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7873 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7874 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7875 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7876
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7877 } else if (qual == SATA_ADDR_DPMPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7878 pmultinfo = SATA_CPORTINFO_PMULT_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7879 if (pmultinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7880 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7881 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7882 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7883 if (SATA_PMPORT_INFO(sata_hba_inst, cport, pmport) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7884 NULL ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7885 SATA_PMPORT_DEV_TYPE(sata_hba_inst, cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7886 pmport) == SATA_DTYPE_NONE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7887 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7888
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7889 sdinfo = SATA_PMPORT_DRV_INFO(sata_hba_inst, cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7890 pmport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7891 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7892 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7893 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7894 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7895 if ((sdinfo == NULL) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7896 (sdinfo->satadrv_type & SATA_VALID_DEV_TYPE) == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7897 goto out;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7898
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7899 sata_device->satadev_type = sdinfo->satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7900 sata_device->satadev_addr.qual = qual;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7901 sata_device->satadev_addr.cport = cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7902 sata_device->satadev_addr.pmport = pmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7903 sata_device->satadev_rev = SATA_DEVICE_REV_1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7904 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7905 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7906 out:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7907 if (rval == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7908 SATADBG2(SATA_DBG_SCSI_IF, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7909 "sata_validate_scsi_address: no valid target %x lun %x",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7910 ap->a_target, ap->a_lun);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7911 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7912 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7913 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7914
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7915 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7916 * Find dip corresponding to passed device number
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7917 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7918 * Returns NULL if invalid device number is passed or device cannot be found,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7919 * Returns dip is device is found.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7920 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7921 static dev_info_t *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7922 sata_devt_to_devinfo(dev_t dev)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7923 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7924 dev_info_t *dip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7925 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7926 struct devnames *dnp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7927 major_t major = getmajor(dev);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7928 int instance = SATA_MINOR2INSTANCE(getminor(dev));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7929
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7930 if (major >= devcnt)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7931 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7932
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7933 dnp = &devnamesp[major];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7934 LOCK_DEV_OPS(&(dnp->dn_lock));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7935 dip = dnp->dn_head;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7936 while (dip && (ddi_get_instance(dip) != instance)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7937 dip = ddi_get_next(dip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7938 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7939 UNLOCK_DEV_OPS(&(dnp->dn_lock));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7940 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7941
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7942 return (dip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7943 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7944
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7945
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7946 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7947 * Probe device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7948 * This function issues Identify Device command and initialize local
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7949 * sata_drive_info structure if the device can be identified.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7950 * The device type is determined by examining Identify Device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7951 * command response.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7952 * If the sata_hba_inst has linked drive info structure for this
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7953 * device address, the Identify Device data is stored into sata_drive_info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7954 * structure linked to the port info structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7955 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7956 * sata_device has to refer to the valid sata port(s) for HBA described
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7957 * by sata_hba_inst structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7958 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7959 * Returns: SATA_SUCCESS if device type was successfully probed and port-linked
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7960 * drive info structure was updated;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7961 * SATA_FAILURE if there is no device, or device was not probed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7962 * successully.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7963 * If a device cannot be identified, sata_device's dev_state and dev_type
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7964 * fields are set to unknown.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7965 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7966 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7967
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7968 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7969 sata_probe_device(sata_hba_inst_t *sata_hba_inst, sata_device_t *sata_device)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7970 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7971 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7972 sata_drive_info_t new_sdinfo; /* local drive info struct */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7973 int retry_cnt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7974
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7975 ASSERT((SATA_CPORT_STATE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7976 sata_device->satadev_addr.cport) &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7977 (SATA_STATE_PROBED | SATA_STATE_READY)) != 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7978
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7979 sata_device->satadev_type = SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7980
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7981 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7982 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7983
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7984 /* Get pointer to port-linked sata device info structure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7985 sdinfo = sata_get_device_info(sata_hba_inst, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7986 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7987 sdinfo->satadrv_state &=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7988 ~(SATA_STATE_PROBED | SATA_STATE_READY);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7989 sdinfo->satadrv_state |= SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7990 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7991 /* No device to probe */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7992 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7993 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7994 sata_device->satadev_type = SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7995 sata_device->satadev_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7996 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7997 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7998 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
7999 * Need to issue both types of identify device command and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8000 * determine device type by examining retreived data/status.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8001 * First, ATA Identify Device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8002 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8003 bzero(&new_sdinfo, sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8004 new_sdinfo.satadrv_addr = sata_device->satadev_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8005 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8006 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8007 for (retry_cnt = 0; retry_cnt <= SATA_DEVICE_IDENTIFY_RETRY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8008 retry_cnt++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8009 new_sdinfo.satadrv_type = SATA_DTYPE_ATADISK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8010 if (sata_identify_device(sata_hba_inst, &new_sdinfo) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8011 /* Got something responding to ATA Identify Device */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8012 sata_device->satadev_type = new_sdinfo.satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8013 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8014 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8015 if (SATA_FEATURES(sata_hba_inst) & SATA_CTLF_ATAPI) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8016 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8017 * HBA supports ATAPI - try to issue Identify Packet
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8018 * Device command.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8019 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8020 new_sdinfo.satadrv_type = SATA_DTYPE_ATAPICD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8021 if (sata_identify_device(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8022 &new_sdinfo) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8023 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8024 * Got something responding to Identify Packet
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8025 * Device cmd.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8026 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8027 /* Set UDMA mode here as well ? - phase 2 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8028 sata_device->satadev_type =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8029 new_sdinfo.satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8030 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8031 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8032 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8033 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8034 if (retry_cnt <= SATA_DEVICE_IDENTIFY_RETRY) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8035 /* save device info, if possible */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8036 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8037 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8038 sdinfo = sata_get_device_info(sata_hba_inst, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8039 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8040 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8041 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8042 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8043 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8044 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8045 * Copy drive info into the port-linked drive info structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8046 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8047 *sdinfo = new_sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8048 sdinfo->satadrv_state &= ~SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8049 sdinfo->satadrv_state |= SATA_STATE_PROBED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8050 if (sata_device->satadev_addr.qual == SATA_ADDR_DCPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8051 SATA_CPORT_DEV_TYPE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8052 sata_device->satadev_addr.cport) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8053 sdinfo->satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8054 else /* SATA_ADDR_DPMPORT */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8055 SATA_PMPORT_DEV_TYPE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8056 sata_device->satadev_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8057 sata_device->satadev_addr.pmport) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8058 sdinfo->satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8059 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8060 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8061 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8062 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8063
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8064 failure:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8065 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8066 * Looks like we cannot determine the device type.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8067 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8068 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8069 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8070 sdinfo = sata_get_device_info(sata_hba_inst, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8071 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8072 sata_device->satadev_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8073 sdinfo->satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8074 sdinfo->satadrv_state &= ~SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8075 sdinfo->satadrv_state = SATA_STATE_PROBED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8076 if (sata_device->satadev_addr.qual == SATA_ADDR_DCPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8077 SATA_CPORT_DEV_TYPE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8078 sata_device->satadev_addr.cport) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8079 SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8080 else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8081 /* SATA_ADDR_DPMPORT */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8082 if ((SATA_PMULT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8083 sata_device->satadev_addr.cport) != NULL) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8084 (SATA_PMPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8085 sata_device->satadev_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8086 sata_device->satadev_addr.pmport) != NULL))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8087 SATA_PMPORT_DEV_TYPE(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8088 sata_device->satadev_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8089 sata_device->satadev_addr.pmport) =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8090 SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8091 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8092 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8093 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8094 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8095 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8096 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8097
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8098
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8099 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8100 * Get pointer to sata_drive_info structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8101 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8102 * The sata_device has to contain address (cport, pmport and qualifier) for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8103 * specified sata_scsi structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8104 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8105 * Returns NULL if device address is not valid for this HBA configuration.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8106 * Otherwise, returns a pointer to sata_drive_info structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8107 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8108 * This function should be called with a port mutex held.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8109 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8110 static sata_drive_info_t *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8111 sata_get_device_info(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8112 sata_device_t *sata_device)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8113 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8114 uint8_t cport = sata_device->satadev_addr.cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8115 uint8_t pmport = sata_device->satadev_addr.pmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8116 uint8_t qual = sata_device->satadev_addr.qual;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8117
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8118 if (cport >= SATA_NUM_CPORTS(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8119 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8120
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8121 if (!(SATA_CPORT_STATE(sata_hba_inst, cport) &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8122 (SATA_STATE_PROBED | SATA_STATE_READY)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8123 /* Port not probed yet */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8124 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8125
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8126 if (SATA_CPORT_DEV_TYPE(sata_hba_inst, cport) == SATA_DTYPE_NONE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8127 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8128
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8129 if (qual == SATA_ADDR_DCPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8130 /* Request for a device on a controller port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8131 if (SATA_CPORT_DEV_TYPE(sata_hba_inst, cport) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8132 SATA_DTYPE_PMULT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8133 /* Port multiplier attached */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8134 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8135 return (SATA_CPORT_DRV_INFO(sata_hba_inst, cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8136 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8137 if (qual == SATA_ADDR_DPMPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8138 if (SATA_CPORT_DEV_TYPE(sata_hba_inst, cport) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8139 SATA_DTYPE_PMULT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8140 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8141
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8142 if (pmport > SATA_NUM_PMPORTS(sata_hba_inst, cport))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8143 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8144
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8145 return (SATA_PMPORT_DRV_INFO(sata_hba_inst, cport, pmport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8146 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8147
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8148 /* we should not get here */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8149 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8150 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8151
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8152
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8153 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8154 * sata_identify_device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8155 * Send Identify Device command to SATA HBA driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8156 * If command executes successfully, update sata_drive_info structure pointed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8157 * to by sdinfo argument, including Identify Device data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8158 * If command fails, invalidate data in sata_drive_info.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8159 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8160 * Cannot be called from interrupt level.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8161 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8162 * Returns 0 if device was identified as supported device, -1 otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8163 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8164 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8165 sata_identify_device(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8166 sata_drive_info_t *sdinfo)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8167 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8168 uint16_t cfg_word;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8169 int i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8170
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8171 /* fetch device identify data */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8172 if (sata_fetch_device_identify_data(sata_hba_inst, sdinfo) != 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8173 goto fail_unknown;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8174
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8175 cfg_word = sdinfo->satadrv_id.ai_config;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8176 if (sdinfo->satadrv_type == SATA_DTYPE_ATADISK &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8177 (cfg_word & SATA_ATA_TYPE_MASK) != SATA_ATA_TYPE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8178 /* Change device type to reflect Identify Device data */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8179 if (((cfg_word & SATA_ATAPI_TYPE_MASK) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8180 SATA_ATAPI_TYPE) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8181 ((cfg_word & SATA_ATAPI_ID_DEV_TYPE) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8182 SATA_ATAPI_CDROM_DEV)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8183 sdinfo->satadrv_type = SATA_DTYPE_ATAPICD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8184 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8185 sdinfo->satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8186 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8187 } else if (sdinfo->satadrv_type == SATA_DTYPE_ATAPICD &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8188 (((cfg_word & SATA_ATAPI_TYPE_MASK) != SATA_ATAPI_TYPE) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8189 ((cfg_word & SATA_ATAPI_ID_DEV_TYPE) != SATA_ATAPI_CDROM_DEV))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8190 /* Change device type to reflect Identify Device data ! */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8191 if ((sdinfo->satadrv_id.ai_config & SATA_ATA_TYPE_MASK) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8192 SATA_ATA_TYPE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8193 sdinfo->satadrv_type = SATA_DTYPE_ATADISK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8194 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8195 sdinfo->satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8196 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8197 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8198 if (sdinfo->satadrv_type == SATA_DTYPE_ATADISK) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8199 if (sdinfo->satadrv_capacity == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8200 /* Non-LBA disk. Too bad... */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8201 sata_log(sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8202 "SATA disk device at port %d does not support LBA",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8203 sdinfo->satadrv_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8204 goto fail_unknown;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8205 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8206 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8207 /* Check for Ultra DMA modes 6 through 0 being supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8208 for (i = 6; i >= 0; --i) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8209 if (sdinfo->satadrv_id.ai_ultradma & (1 << i))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8210 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8211 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8212 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8213 * At least UDMA 4 mode has to be supported. If mode 4 or
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8214 * higher are not supported by the device, fail this
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8215 * device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8216 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8217 if (i < 4) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8218 /* No required Ultra DMA mode supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8219 sata_log(sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8220 "SATA disk device at port %d does not support UDMA "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8221 "mode 4 or higher", sdinfo->satadrv_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8222 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8223 "mode 4 or higher required, %d supported", i));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8224 goto fail_unknown;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8225 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8226
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8227 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8228
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8229 fail_unknown:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8230 /* Invalidate sata_drive_info ? */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8231 sdinfo->satadrv_type = SATA_DTYPE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8232 sdinfo->satadrv_state = SATA_STATE_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8233 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8234 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8235
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8236 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8237 * Log/display device information
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8238 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8239 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8240 sata_show_drive_info(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8241 sata_drive_info_t *sdinfo)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8242 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8243 int valid_version;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8244 char msg_buf[MAXPATHLEN];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8245
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8246 /* Show HBA path */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8247 (void) ddi_pathname(SATA_DIP(sata_hba_inst), msg_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8248
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8249 cmn_err(CE_CONT, "?%s :\n", msg_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8250
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8251 if (sdinfo->satadrv_type == SATA_DTYPE_UNKNOWN) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8252 (void) sprintf(msg_buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8253 "Unsupported SATA device type (cfg 0x%x) at ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8254 sdinfo->satadrv_id.ai_config);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8255 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8256 (void) sprintf(msg_buf, "SATA %s device at",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8257 sdinfo->satadrv_type == SATA_DTYPE_ATADISK ?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8258 "disk":"CD/DVD (ATAPI)");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8259 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8260 if (sdinfo->satadrv_addr.qual == SATA_ADDR_DCPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8261 cmn_err(CE_CONT, "?\t%s port %d\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8262 msg_buf, sdinfo->satadrv_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8263 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8264 cmn_err(CE_CONT, "?\t%s port %d pmport %d\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8265 msg_buf, sdinfo->satadrv_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8266 sdinfo->satadrv_addr.pmport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8267
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8268 bcopy(&sdinfo->satadrv_id.ai_model, msg_buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8269 sizeof (sdinfo->satadrv_id.ai_model));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8270 swab(msg_buf, msg_buf, sizeof (sdinfo->satadrv_id.ai_model));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8271 msg_buf[sizeof (sdinfo->satadrv_id.ai_model)] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8272 cmn_err(CE_CONT, "?\tmodel %s\n", msg_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8273
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8274 bcopy(&sdinfo->satadrv_id.ai_fw, msg_buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8275 sizeof (sdinfo->satadrv_id.ai_fw));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8276 swab(msg_buf, msg_buf, sizeof (sdinfo->satadrv_id.ai_fw));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8277 msg_buf[sizeof (sdinfo->satadrv_id.ai_fw)] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8278 cmn_err(CE_CONT, "?\tfirmware %s\n", msg_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8279
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8280 bcopy(&sdinfo->satadrv_id.ai_drvser, msg_buf,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8281 sizeof (sdinfo->satadrv_id.ai_drvser));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8282 swab(msg_buf, msg_buf, sizeof (sdinfo->satadrv_id.ai_drvser));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8283 msg_buf[sizeof (sdinfo->satadrv_id.ai_drvser)] = '\0';
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8284 cmn_err(CE_CONT, "?\tserial number %s\n", msg_buf);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8285
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8286 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8287 if (sdinfo->satadrv_id.ai_majorversion != 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8288 sdinfo->satadrv_id.ai_majorversion != 0xffff) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8289 int i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8290 for (i = 14; i >= 2; i--) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8291 if (sdinfo->satadrv_id.ai_majorversion & (1 << i)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8292 valid_version = i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8293 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8294 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8295 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8296 cmn_err(CE_CONT,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8297 "?\tATA/ATAPI-%d supported, majver 0x%x minver 0x%x\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8298 valid_version,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8299 sdinfo->satadrv_id.ai_majorversion,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8300 sdinfo->satadrv_id.ai_minorversion);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8301 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8302 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8303 /* Log some info */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8304 cmn_err(CE_CONT, "?\tsupported features:\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8305 msg_buf[0] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8306 if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA48)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8307 (void) strlcat(msg_buf, "48-bit LBA", MAXPATHLEN);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8308 else if (sdinfo->satadrv_features_support & SATA_DEV_F_LBA28)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8309 (void) strlcat(msg_buf, "28-bit LBA", MAXPATHLEN);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8310 if (sdinfo->satadrv_features_support & SATA_DEV_F_DMA)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8311 (void) strlcat(msg_buf, ", DMA", MAXPATHLEN);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8312 if (sdinfo->satadrv_features_support & SATA_DEV_F_NCQ)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8313 (void) strlcat(msg_buf, ", Native Command Queueing",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8314 MAXPATHLEN);
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
8315 if (sdinfo->satadrv_features_support & SATA_DEV_F_TCQ)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8316 (void) strlcat(msg_buf, ", Queuing", MAXPATHLEN);
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8317 if ((sdinfo->satadrv_id.ai_cmdset82 & SATA_SMART_SUPPORTED) &&
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8318 (sdinfo->satadrv_id.ai_features85 & SATA_SMART_ENABLED))
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8319 (void) strlcat(msg_buf, ", SMART", MAXPATHLEN);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8320 if ((sdinfo->satadrv_id.ai_cmdset84 & SATA_SMART_SELF_TEST_SUPPORTED) &&
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8321 (sdinfo->satadrv_id.ai_features87 & SATA_SMART_SELF_TEST_SUPPORTED))
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8322 (void) strlcat(msg_buf, ", SMART self-test", MAXPATHLEN);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8323 cmn_err(CE_CONT, "?\t %s\n", msg_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8324 if (sdinfo->satadrv_features_support & SATA_DEV_F_SATA2)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8325 cmn_err(CE_CONT, "?\tSATA1 & SATA2 compatible\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8326 else if (sdinfo->satadrv_features_support & SATA_DEV_F_SATA1)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8327 cmn_err(CE_CONT, "?\tSATA1 compatible\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8328
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8329 #ifdef __i386
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8330 (void) sprintf(msg_buf, "\tcapacity = %llu sectors\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8331 sdinfo->satadrv_capacity);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8332 #else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8333 (void) sprintf(msg_buf, "\tcapacity = %lu sectors\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8334 sdinfo->satadrv_capacity);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8335 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8336 cmn_err(CE_CONT, "?%s", msg_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8337 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8338
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8339
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8340 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8341 * sata_save_drive_settings extracts current setting of the device and stores
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8342 * it for future reference, in case the device setup would need to be restored
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8343 * after the device reset.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8344 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8345 * At the moment only read ahead and write cache settings are saved, if the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8346 * device supports these features at all.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8347 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8348 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8349 sata_save_drive_settings(sata_drive_info_t *sdinfo)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8350 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8351 if (!(sdinfo->satadrv_id.ai_cmdset82 & SATA_LOOK_AHEAD) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8352 !(sdinfo->satadrv_id.ai_cmdset82 & SATA_WRITE_CACHE)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8353 /* None of the features is supported - do nothing */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8354 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8355 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8356
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8357 /* Current setting of Read Ahead (and Read Cache) */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8358 if (sdinfo->satadrv_id.ai_features85 & SATA_LOOK_AHEAD)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8359 sdinfo->satadrv_settings |= SATA_DEV_READ_AHEAD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8360 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8361 sdinfo->satadrv_settings &= ~SATA_DEV_READ_AHEAD;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8362
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8363 /* Current setting of Write Cache */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8364 if (sdinfo->satadrv_id.ai_features85 & SATA_WRITE_CACHE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8365 sdinfo->satadrv_settings |= SATA_DEV_WRITE_CACHE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8366 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8367 sdinfo->satadrv_settings &= ~SATA_DEV_WRITE_CACHE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8368 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8369
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8370
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8371 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8372 * sata_check_capacity function determines a disk capacity
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8373 * and addressing mode (LBA28/LBA48) by examining a disk identify device data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8374 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8375 * NOTE: CHS mode is not supported! If a device does not support LBA,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8376 * this function is not called.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8377 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8378 * Returns device capacity in number of blocks, i.e. largest addressable LBA+1
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8379 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8380 static uint64_t
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8381 sata_check_capacity(sata_drive_info_t *sdinfo)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8382 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8383 uint64_t capacity = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8384 int i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8385
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8386 if (sdinfo->satadrv_type != SATA_DTYPE_ATADISK ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8387 !sdinfo->satadrv_id.ai_cap & SATA_LBA_SUPPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8388 /* Capacity valid only for LBA-addressable disk devices */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8389 return (0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8390
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8391 if ((sdinfo->satadrv_id.ai_validinfo & SATA_VALIDINFO_88) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8392 (sdinfo->satadrv_id.ai_cmdset83 & SATA_EXT48) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8393 (sdinfo->satadrv_id.ai_features86 & SATA_EXT48)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8394 /* LBA48 mode supported and enabled */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8395 sdinfo->satadrv_features_support |= SATA_DEV_F_LBA48 |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8396 SATA_DEV_F_LBA28;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8397 for (i = 3; i >= 0; --i) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8398 capacity <<= 16;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8399 capacity += sdinfo->satadrv_id.ai_addrsecxt[i];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8400 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8401 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8402 capacity = sdinfo->satadrv_id.ai_addrsec[1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8403 capacity <<= 16;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8404 capacity += sdinfo->satadrv_id.ai_addrsec[0];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8405 if (capacity >= 0x1000000)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8406 /* LBA28 mode */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8407 sdinfo->satadrv_features_support |= SATA_DEV_F_LBA28;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8408 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8409 return (capacity);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8410 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8411
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8412
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8413 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8414 * Allocate consistent buffer for DMA transfer
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8415 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8416 * Cannot be called from interrupt level or with mutex held - it may sleep.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8417 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8418 * Returns pointer to allocated buffer structure, or NULL if allocation failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8419 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8420 static struct buf *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8421 sata_alloc_local_buffer(sata_pkt_txlate_t *spx, int len)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8422 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8423 struct scsi_address ap;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8424 struct buf *bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8425 ddi_dma_attr_t cur_dma_attr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8426
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8427 ASSERT(spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8428 ap.a_hba_tran = spx->txlt_sata_hba_inst->satahba_scsi_tran;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8429 ap.a_target = SATA_TO_SCSI_TARGET(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8430 spx->txlt_sata_pkt->satapkt_device.satadev_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8431 spx->txlt_sata_pkt->satapkt_device.satadev_addr.pmport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8432 spx->txlt_sata_pkt->satapkt_device.satadev_addr.qual);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8433 ap.a_lun = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8434
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8435 bp = scsi_alloc_consistent_buf(&ap, NULL, len,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8436 B_READ, SLEEP_FUNC, NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8437
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8438 if (bp != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8439 /* Allocate DMA resources for this buffer */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8440 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8441 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8442 * We use a local version of the dma_attr, to account
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8443 * for a device addressing limitations.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8444 * sata_adjust_dma_attr() will handle sdinfo == NULL which
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8445 * will cause dma attributes to be adjusted to a lowest
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8446 * acceptable level.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8447 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8448 sata_adjust_dma_attr(NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8449 SATA_DMA_ATTR(spx->txlt_sata_hba_inst), &cur_dma_attr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8450
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8451 if (sata_dma_buf_setup(spx, PKT_CONSISTENT,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8452 SLEEP_FUNC, NULL, &cur_dma_attr) != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8453 scsi_free_consistent_buf(bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8454 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8455 bp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8456 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8457 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8458 return (bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8459 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8460
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8461 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8462 * Release local buffer (consistent buffer for DMA transfer) allocated
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8463 * via sata_alloc_local_buffer().
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8464 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8465 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8466 sata_free_local_buffer(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8467 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8468 ASSERT(spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8469 ASSERT(spx->txlt_dma_cookie_list != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8470 ASSERT(spx->txlt_dma_cookie_list_len != 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8471 ASSERT(spx->txlt_buf_dma_handle != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8472 ASSERT(spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8473
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8474 spx->txlt_sata_pkt->satapkt_cmd.satacmd_num_dma_cookies = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8475 spx->txlt_sata_pkt->satapkt_cmd.satacmd_dma_cookie_list = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8476
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8477 /* Free DMA resources */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8478 (void) ddi_dma_unbind_handle(spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8479 ddi_dma_free_handle(&spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8480 spx->txlt_buf_dma_handle = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8481
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8482 kmem_free(spx->txlt_dma_cookie_list,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8483 spx->txlt_dma_cookie_list_len * sizeof (ddi_dma_cookie_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8484 spx->txlt_dma_cookie_list = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8485 spx->txlt_dma_cookie_list_len = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8486
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8487 /* Free buffer */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8488 scsi_free_consistent_buf(spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8489 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8490
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8491
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8492
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8493
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8494 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8495 * Allocate sata_pkt
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8496 * Pkt structure version and embedded strcutures version are initialized.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8497 * sata_pkt and sata_pkt_txlate structures are cross-linked.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8498 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8499 * Since this may be called in interrupt context by sata_scsi_init_pkt,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8500 * callback argument determines if it can sleep or not.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8501 * Hence, it should not be called from interrupt context.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8502 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8503 * If successful, non-NULL pointer to a sata pkt is returned.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8504 * Upon failure, NULL pointer is returned.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8505 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8506 static sata_pkt_t *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8507 sata_pkt_alloc(sata_pkt_txlate_t *spx, int (*callback)(caddr_t))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8508 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8509 sata_pkt_t *spkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8510 int kmsflag;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8511
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8512 kmsflag = (callback == SLEEP_FUNC) ? KM_SLEEP : KM_NOSLEEP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8513 spkt = kmem_zalloc(sizeof (sata_pkt_t), kmsflag);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8514 if (spkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8515 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8516 "sata_pkt_alloc: failed"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8517 return (NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8518 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8519 spkt->satapkt_rev = SATA_PKT_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8520 spkt->satapkt_cmd.satacmd_rev = SATA_CMD_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8521 spkt->satapkt_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8522 spkt->satapkt_framework_private = spx;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8523 spx->txlt_sata_pkt = spkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8524 return (spkt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8525 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8526
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8527 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8528 * Free sata pkt allocated via sata_pkt_alloc()
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8529 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8530 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8531 sata_pkt_free(sata_pkt_txlate_t *spx)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8532 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8533 ASSERT(spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8534 ASSERT(spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp == NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8535 kmem_free(spx->txlt_sata_pkt, sizeof (sata_pkt_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8536 spx->txlt_sata_pkt = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8537 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8538
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8539
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8540 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8541 * Adjust DMA attributes.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8542 * SCSI cmds block count is up to 24 bits, SATA cmd block count vary
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8543 * from 8 bits to 16 bits, depending on a command being used.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8544 * Limiting max block count arbitrarily to 256 for all read/write
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8545 * commands may affects performance, so check both the device and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8546 * controller capability before adjusting dma attributes.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8547 * For ATAPI CD/DVD dma granularity has to be adjusted as well,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8548 * because these devices support block size of 2k rather
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8549 * then 512 bytes.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8550 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8551 void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8552 sata_adjust_dma_attr(sata_drive_info_t *sdinfo, ddi_dma_attr_t *dma_attr,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8553 ddi_dma_attr_t *adj_dma_attr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8554 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8555 uint32_t count_max;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8556
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8557 /* Copy original attributes */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8558 *adj_dma_attr = *dma_attr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8559
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8560 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8561 * Things to consider: device addressing capability,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8562 * "excessive" controller DMA capabilities.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8563 * If a device is being probed/initialized, there are
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8564 * no device info - use default limits then.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8565 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8566 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8567 count_max = dma_attr->dma_attr_granular * 0x100;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8568 if (dma_attr->dma_attr_count_max > count_max)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8569 adj_dma_attr->dma_attr_count_max = count_max;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8570 if (dma_attr->dma_attr_maxxfer > count_max)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8571 adj_dma_attr->dma_attr_maxxfer = count_max;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8572 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8573 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8574 if (sdinfo->satadrv_type == SATA_DTYPE_ATAPICD) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8575 /* arbitrarily modify controller dma granularity */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8576 adj_dma_attr->dma_attr_granular = SATA_ATAPI_SECTOR_SIZE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8577 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8578
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8579 if (sdinfo->satadrv_features_support & (SATA_DEV_F_LBA48)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8580 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8581 * 16-bit sector count may be used - we rely on
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8582 * the assumption that only read and write cmds
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8583 * will request more than 256 sectors worth of data
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8584 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8585 count_max = adj_dma_attr->dma_attr_granular * 0x10000;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8586 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8587 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8588 * 8-bit sector count will be used - default limits
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8589 * for dma attributes
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8590 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8591 count_max = adj_dma_attr->dma_attr_granular * 0x100;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8592 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8593
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8594
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8595 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8596 * Adjust controler dma attributes, if necessary
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8597 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8598 if (dma_attr->dma_attr_count_max > count_max)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8599 adj_dma_attr->dma_attr_count_max = count_max;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8600 if (dma_attr->dma_attr_maxxfer > count_max)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8601 adj_dma_attr->dma_attr_maxxfer = count_max;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8602 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8603
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8604
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8605 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8606 * Allocate DMA resources for the buffer
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8607 * This function handles initial DMA resource allocation as well as
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8608 * DMA window shift and may be called repeatedly for the same DMA window
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8609 * until all DMA cookies in the DMA window are processed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8610 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8611 * Returns DDI_SUCCESS upon successful operation,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8612 * returns failure code returned by failing commands or DDI_FAILURE when
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8613 * internal cleanup failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8614 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8615 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8616 sata_dma_buf_setup(sata_pkt_txlate_t *spx, int flags,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8617 int (*callback)(caddr_t), caddr_t arg,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8618 ddi_dma_attr_t *cur_dma_attr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8619 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8620 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8621 ddi_dma_cookie_t cookie;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8622 off_t offset;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8623 size_t size;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8624 int max_sg_len, req_sg_len, i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8625 uint_t dma_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8626 struct buf *bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8627 uint64_t max_txfer_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8628 uint64_t cur_txfer_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8629
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8630 ASSERT(spx->txlt_sata_pkt != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8631 bp = spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8632 ASSERT(bp != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8633
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8634
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8635 if (spx->txlt_buf_dma_handle == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8636 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8637 * No DMA resources allocated so far - this is a first call
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8638 * for this sata pkt.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8639 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8640 rval = ddi_dma_alloc_handle(SATA_DIP(spx->txlt_sata_hba_inst),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8641 cur_dma_attr, callback, arg, &spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8642
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8643 if (rval != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8644 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8645 "sata_dma_buf_setup: no buf DMA resources %x",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8646 rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8647 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8648 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8649
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8650 if (bp->b_flags & B_READ)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8651 dma_flags = DDI_DMA_READ;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8652 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8653 dma_flags = DDI_DMA_WRITE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8654
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8655 if (flags & PKT_CONSISTENT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8656 dma_flags |= DDI_DMA_CONSISTENT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8657
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8658 if (flags & PKT_DMA_PARTIAL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8659 dma_flags |= DDI_DMA_PARTIAL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8660
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8661 rval = ddi_dma_buf_bind_handle(spx->txlt_buf_dma_handle,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8662 bp, dma_flags, callback, arg,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8663 &cookie, &spx->txlt_curwin_num_dma_cookies);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8664
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8665 switch (rval) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8666 case DDI_DMA_PARTIAL_MAP:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8667 SATADBG1(SATA_DBG_DMA_SETUP, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8668 "sata_dma_buf_setup: DMA Partial Map\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8669 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8670 * Partial DMA mapping.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8671 * Retrieve number of DMA windows for this request.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8672 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8673 if (ddi_dma_numwin(spx->txlt_buf_dma_handle,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8674 &spx->txlt_num_dma_win) != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8675 (void) ddi_dma_unbind_handle(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8676 spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8677 (void) ddi_dma_free_handle(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8678 &spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8679 spx->txlt_buf_dma_handle = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8680 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8681 "sata_dma_buf_setup: numwin failed\n"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8682 return (DDI_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8683 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8684 spx->txlt_cur_dma_win = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8685 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8686
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8687 case DDI_DMA_MAPPED:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8688 /* DMA fully mapped */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8689 spx->txlt_num_dma_win = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8690 spx->txlt_cur_dma_win = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8691 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8692
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8693 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8694 /* DMA mapping failed */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8695 (void) ddi_dma_free_handle(&spx->txlt_buf_dma_handle);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8696 spx->txlt_buf_dma_handle = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8697 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8698 "sata_dma_buf_setup: buf dma handle binding "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8699 "failed %x\n", rval));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8700 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8701 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8702 spx->txlt_curwin_processed_dma_cookies = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8703 spx->txlt_dma_cookie_list = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8704 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8705 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8706 * DMA setup is reused. Check if we need to process more
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8707 * cookies in current window, or to get next window, if any.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8708 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8709
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8710 ASSERT(spx->txlt_curwin_processed_dma_cookies <=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8711 spx->txlt_curwin_num_dma_cookies);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8712
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8713 if (spx->txlt_curwin_processed_dma_cookies ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8714 spx->txlt_curwin_num_dma_cookies) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8715 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8716 * All cookies from current DMA window were processed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8717 * Get next DMA window.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8718 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8719 spx->txlt_cur_dma_win++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8720 if (spx->txlt_cur_dma_win < spx->txlt_num_dma_win) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8721 (void) ddi_dma_getwin(spx->txlt_buf_dma_handle,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8722 spx->txlt_cur_dma_win, &offset, &size,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8723 &cookie,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8724 &spx->txlt_curwin_num_dma_cookies);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8725 spx->txlt_curwin_processed_dma_cookies = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8726
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8727 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8728 /* No more windows! End of request! */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8729 /* What to do? - panic for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8730 ASSERT(spx->txlt_cur_dma_win >=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8731 spx->txlt_num_dma_win);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8732
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8733 spx->txlt_curwin_num_dma_cookies = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8734 spx->txlt_curwin_processed_dma_cookies = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8735 spx->txlt_sata_pkt->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8736 satapkt_cmd.satacmd_num_dma_cookies = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8737 return (DDI_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8738 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8739 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8740 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8741 /* There better be at least one DMA cookie */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8742 ASSERT((spx->txlt_curwin_num_dma_cookies -
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8743 spx->txlt_curwin_processed_dma_cookies) > 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8744
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8745 if (spx->txlt_curwin_processed_dma_cookies == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8746 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8747 * Processing a new DMA window - set-up dma cookies list.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8748 * We may reuse previously allocated cookie array if it is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8749 * possible.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8750 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8751 if (spx->txlt_dma_cookie_list != NULL &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8752 spx->txlt_dma_cookie_list_len <
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8753 spx->txlt_curwin_num_dma_cookies) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8754 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8755 * New DMA window contains more cookies than
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8756 * the previous one. We need larger cookie list - free
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8757 * the old one.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8758 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8759 (void) kmem_free(spx->txlt_dma_cookie_list,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8760 spx->txlt_dma_cookie_list_len *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8761 sizeof (ddi_dma_cookie_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8762 spx->txlt_dma_cookie_list = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8763 spx->txlt_dma_cookie_list_len = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8764 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8765 if (spx->txlt_dma_cookie_list == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8766 /* Allocate new dma cookie array */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8767 spx->txlt_dma_cookie_list = kmem_zalloc(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8768 sizeof (ddi_dma_cookie_t) *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8769 spx->txlt_curwin_num_dma_cookies, KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8770 spx->txlt_dma_cookie_list_len =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8771 spx->txlt_curwin_num_dma_cookies;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8772 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8773 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8774 * Copy all DMA cookies into local list, so we will know their
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8775 * dma_size in advance of setting the sata_pkt.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8776 * One cookie was already fetched, so copy it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8777 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8778 *(&spx->txlt_dma_cookie_list[0]) = cookie;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8779 for (i = 1; i < spx->txlt_curwin_num_dma_cookies; i++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8780 ddi_dma_nextcookie(spx->txlt_buf_dma_handle, &cookie);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8781 *(&spx->txlt_dma_cookie_list[i]) = cookie;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8782 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8783 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8784 SATADBG2(SATA_DBG_DMA_SETUP, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8785 "sata_dma_buf_setup: sliding within DMA window, "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8786 "cur cookie %d, total cookies %d\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8787 spx->txlt_curwin_processed_dma_cookies,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8788 spx->txlt_curwin_num_dma_cookies);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8789 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8790
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8791 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8792 * Set-up sata_pkt cookie list.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8793 * No single cookie transfer size would exceed max transfer size of
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8794 * an ATA command used for addressed device (tha adjustment of the dma
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8795 * attributes took care of this). But there may be more
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8796 * then one cookie, so the cmd cookie list has to be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8797 * constrained by both a maximum scatter gather list length and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8798 * a maximum transfer size restriction of an ATA command.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8799 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8800
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8801 max_sg_len = cur_dma_attr->dma_attr_sgllen;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8802 req_sg_len = MIN(max_sg_len,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8803 (spx->txlt_curwin_num_dma_cookies -
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8804 spx->txlt_curwin_processed_dma_cookies));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8805
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8806 ASSERT(req_sg_len > 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8807
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8808 max_txfer_len = MAX((cur_dma_attr->dma_attr_granular * 0x100),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8809 cur_dma_attr->dma_attr_maxxfer);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8810
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8811 /* One cookie should be always available */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8812 spx->txlt_sata_pkt->satapkt_cmd.satacmd_dma_cookie_list =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8813 &spx->txlt_dma_cookie_list[spx->txlt_curwin_processed_dma_cookies];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8814
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8815 spx->txlt_sata_pkt->satapkt_cmd.satacmd_num_dma_cookies = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8816
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8817 cur_txfer_len =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8818 (uint64_t)spx->txlt_dma_cookie_list[
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8819 spx->txlt_curwin_processed_dma_cookies].dmac_size;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8820
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8821 spx->txlt_curwin_processed_dma_cookies++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8822
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8823 ASSERT(cur_txfer_len <= max_txfer_len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8824
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8825 /* Add more cookies to the scatter-gather list */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8826 for (i = 1; i < req_sg_len; i++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8827 if (cur_txfer_len < max_txfer_len) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8828 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8829 * Check if the next cookie could be used by
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8830 * this sata_pkt.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8831 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8832 if ((cur_txfer_len +
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8833 spx->txlt_dma_cookie_list[
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8834 spx->txlt_curwin_processed_dma_cookies].
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8835 dmac_size) <= max_txfer_len) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8836 /* Yes, transfer lenght is within bounds */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8837 spx->txlt_sata_pkt->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8838 satapkt_cmd.satacmd_num_dma_cookies++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8839 cur_txfer_len +=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8840 spx->txlt_dma_cookie_list[
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8841 spx->txlt_curwin_processed_dma_cookies].
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8842 dmac_size;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8843 spx->txlt_curwin_processed_dma_cookies++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8844 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8845 /* No, transfer would exceed max lenght. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8846 SATADBG3(SATA_DBG_DMA_SETUP,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8847 spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8848 "ncookies %d, size 0x%lx, "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8849 "max_size 0x%lx\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8850 spx->txlt_sata_pkt->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8851 satapkt_cmd.satacmd_num_dma_cookies,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8852 cur_txfer_len, max_txfer_len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8853 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8854 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8855 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8856 /* Cmd max transfer length reached */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8857 SATADBG3(SATA_DBG_DMA_SETUP, spx->txlt_sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8858 "Max transfer length? "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8859 "ncookies %d, size 0x%lx, max_size 0x%lx\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8860 spx->txlt_sata_pkt->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8861 satapkt_cmd.satacmd_num_dma_cookies,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8862 cur_txfer_len, max_txfer_len);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8863 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8864 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8865 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8866
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8867 ASSERT(cur_txfer_len != 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8868 spx->txlt_total_residue -= cur_txfer_len;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8869
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8870 return (DDI_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8871 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8872
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8873 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8874 * Fetch Device Identify data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8875 * Send DEVICE IDENTIFY command to a device and get the device identify data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8876 * The device_info structure has to be set to device type (for selecting proper
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8877 * device identify command).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8878 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8879 * Returns 0 if success, -1 otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8880 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8881 * Cannot be called in an interrupt context.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8882 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8883
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8884 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8885 sata_fetch_device_identify_data(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8886 sata_drive_info_t *sdinfo)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8887 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8888 struct buf *bp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8889 sata_pkt_t *spkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8890 sata_cmd_t *scmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8891 sata_pkt_txlate_t *spx;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8892 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8893
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8894 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8895 spx->txlt_sata_hba_inst = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8896 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8897 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8898 if (spkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8899 kmem_free(spx, sizeof (sata_pkt_txlate_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8900 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8901 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8902 /* address is needed now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8903 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8904
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8905 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8906 * Allocate buffer for Identify Data return data
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8907 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8908 bp = sata_alloc_local_buffer(spx, sizeof (sata_id_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8909 if (bp == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8910 sata_pkt_free(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8911 kmem_free(spx, sizeof (sata_pkt_txlate_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8912 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8913 "sata_fetch_device_identify_data: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8914 "cannot allocate buffer for ID"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8915 return (-1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8916 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8917
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8918 /* Fill sata_pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8919 sdinfo->satadrv_state = SATA_STATE_PROBING;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8920 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8921 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8922 /* Synchronous mode, no callback */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8923 spkt->satapkt_comp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8924 /* Timeout 30s */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8925 spkt->satapkt_time = sata_default_pkt_time;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8926
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8927 scmd = &spkt->satapkt_cmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8928 scmd->satacmd_bp = bp;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8929 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
8930 scmd->satacmd_flags.sata_ignore_dev_reset = B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8931
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8932 /* Build Identify Device cmd in the sata_pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8933 scmd->satacmd_addr_type = 0; /* N/A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8934 scmd->satacmd_sec_count_lsb = 0; /* N/A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8935 scmd->satacmd_lba_low_lsb = 0; /* N/A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8936 scmd->satacmd_lba_mid_lsb = 0; /* N/A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8937 scmd->satacmd_lba_high_lsb = 0; /* N/A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8938 scmd->satacmd_features_reg = 0; /* N/A */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8939 scmd->satacmd_device_reg = 0; /* Always device 0 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8940 if (sdinfo->satadrv_type == SATA_DTYPE_ATAPICD) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8941 /* Identify Packet Device cmd */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8942 scmd->satacmd_cmd_reg = SATAC_ID_PACKET_DEVICE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8943 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8944 /* Identify Device cmd - mandatory for all other devices */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8945 scmd->satacmd_cmd_reg = SATAC_ID_DEVICE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8946 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8947
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8948 /* Send pkt to SATA HBA driver */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8949 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8950 SATA_TRAN_ACCEPTED ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8951 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8952 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8953 * Woops, no Identify Data.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8954 * Invalidate sata_drive_info ?
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8955 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8956 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8957 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8958 /* Update sata_drive_info */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8959 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8960 DDI_DMA_SYNC_FORKERNEL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8961 if (rval != DDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8962 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8963 "sata_fetch_device_identify_data: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8964 "sync pkt failed"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8965 rval = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8966 goto fail;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8967 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8968 bcopy(bp->b_un.b_addr, &sdinfo->satadrv_id,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8969 sizeof (sata_id_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8970
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8971 sdinfo->satadrv_features_support = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8972 if (sdinfo->satadrv_type == SATA_DTYPE_ATADISK) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8973 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8974 * Retrieve capacity (disks only) and addressing mode
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8975 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8976 sdinfo->satadrv_capacity = sata_check_capacity(sdinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8977 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8978 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8979 * For ATAPI devices one has to issue Get Capacity cmd
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8980 * (not needed at the moment)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8981 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8982 sdinfo->satadrv_capacity = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8983 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8984 /* Setup supported features flags */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8985 if (sdinfo->satadrv_id.ai_cap & SATA_DMA_SUPPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8986 sdinfo->satadrv_features_support |= SATA_DEV_F_DMA;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8987
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8988 /* Check for NCQ support */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8989 if (sdinfo->satadrv_id.ai_satacap != 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8990 sdinfo->satadrv_id.ai_satacap != 0xffff) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8991 /* SATA compliance */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8992 if (sdinfo->satadrv_id.ai_satacap & SATA_NCQ)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8993 sdinfo->satadrv_features_support |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8994 SATA_DEV_F_NCQ;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8995 if (sdinfo->satadrv_id.ai_satacap &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8996 (SATA_1_SPEED | SATA_2_SPEED)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8997 if (sdinfo->satadrv_id.ai_satacap &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8998 SATA_2_SPEED)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
8999 sdinfo->satadrv_features_support |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9000 SATA_DEV_F_SATA2;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9001 if (sdinfo->satadrv_id.ai_satacap &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9002 SATA_1_SPEED)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9003 sdinfo->satadrv_features_support |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9004 SATA_DEV_F_SATA1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9005 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9006 sdinfo->satadrv_features_support |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9007 SATA_DEV_F_SATA1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9008 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9009 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9010
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9011 sdinfo->satadrv_queue_depth = sdinfo->satadrv_id.ai_qdepth;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9012 if (sdinfo->satadrv_id.ai_cmdset83 & SATA_RW_DMA_QUEUED_CMD)
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
9013 ++sdinfo->satadrv_queue_depth;
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
9014
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
9015 if ((sdinfo->satadrv_id.ai_cmdset83 & SATA_RW_DMA_QUEUED_CMD) &&
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
9016 (sdinfo->satadrv_id.ai_features86 & SATA_RW_DMA_QUEUED_CMD))
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
9017 sdinfo->satadrv_features_support |= SATA_DEV_F_TCQ;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9018
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9019 rval = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9020 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9021 fail:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9022 /* Free allocated resources */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9023 sata_free_local_buffer(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9024 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9025 sata_pkt_free(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9026 kmem_free(spx, sizeof (sata_pkt_txlate_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9027
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9028 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9029 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9030
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9031
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9032 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9033 * SATA spec requires that the device supports at least UDMA 4 mode and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9034 * UDMA mode is selected.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9035 * Some devices (bridged devices) may not come-up with default UDMA mode
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9036 * set correctly, so this function is setting it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9037 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9038 * Returns SATA_SUCCESS if proper UDMA mode is selected.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9039 * Returns SATA_FAILURE if proper UDMA mode could not be selected.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9040 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9041 static int
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9042 sata_set_udma_mode(sata_hba_inst_t *sata_hba_inst, sata_drive_info_t *sdinfo)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9043 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9044 sata_pkt_t *spkt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9045 sata_cmd_t *scmd;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9046 sata_pkt_txlate_t *spx;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9047 int result = SATA_SUCCESS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9048 int i, mode;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9049
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9050 ASSERT(sdinfo != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9051 ASSERT(sata_hba_inst != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9052
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9053 /* Find highest Ultra DMA mode supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9054 for (mode = 6; mode >= 0; --mode) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9055 if (sdinfo->satadrv_id.ai_ultradma & (1 << mode))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9056 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9057 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9058 if (mode < 4)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9059 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9060
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9061 /* Find UDMA mode currently selected */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9062 for (i = 6; i >= 0; --i) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9063 if (sdinfo->satadrv_id.ai_ultradma & (1 << (i + 8)))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9064 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9065 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9066
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9067 if (i < mode) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9068 /* Set UDMA mode via SET FEATURES COMMAND */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9069 /* Prepare packet for SET FEATURES COMMAND */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9070 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9071 spx->txlt_sata_hba_inst = sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9072 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9073 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9074 if (spkt == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9075 result = SATA_FAILURE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9076 goto failure;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9077 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9078 /* Fill sata_pkt */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9079 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9080 /* Timeout 30s */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9081 spkt->satapkt_time = sata_default_pkt_time;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9082 /* Synchronous mode, no callback, interrupts */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9083 spkt->satapkt_op_mode =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9084 SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9085 spkt->satapkt_comp = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9086 scmd = &spkt->satapkt_cmd;
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
9087 scmd->satacmd_flags.sata_data_direction = SATA_DIR_NODATA_XFER;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
9088 scmd->satacmd_flags.sata_ignore_dev_reset = B_TRUE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9089 scmd->satacmd_addr_type = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9090 scmd->satacmd_device_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9091 scmd->satacmd_status_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9092 scmd->satacmd_error_reg = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9093 scmd->satacmd_cmd_reg = SATAC_SET_FEATURES;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9094 scmd->satacmd_features_reg = SATAC_SF_TRANSFER_MODE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9095 scmd->satacmd_sec_count_lsb =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9096 SATAC_TRANSFER_MODE_ULTRA_DMA | mode;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9097
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9098 /* Transfer command to HBA */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9099 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9100 spkt) != SATA_TRAN_ACCEPTED ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9101 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9102 /* Pkt execution failed */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9103 result = SATA_FAILURE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9104 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9105 failure:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9106 if (result == SATA_FAILURE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9107 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9108 "sata_set_udma_mode: could not set UDMA "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9109 "mode %", mode));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9110
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9111 /* Free allocated resources */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9112 if (spkt != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9113 sata_pkt_free(spx);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9114 (void) kmem_free(spx, sizeof (sata_pkt_txlate_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9115 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9116 return (result);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9117 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9118
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9119
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9120 /*
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9121 * Set device caching mode.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9122 * One of the following operations should be specified:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9123 * SATAC_SF_ENABLE_READ_AHEAD
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9124 * SATAC_SF_DISABLE_READ_AHEAD
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9125 * SATAC_SF_ENABLE_WRITE_CACHE
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9126 * SATAC_SF_DISABLE_WRITE_CACHE
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9127 *
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9128 * If operation fails, system log messgage is emitted.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9129 * Returns SATA_SUCCESS when the operation succeeds, SATA_FAILURE otherwise.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9130 */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9131
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9132 static int
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9133 sata_set_cache_mode(sata_hba_inst_t *sata_hba_inst, sata_drive_info_t *sdinfo,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9134 int cache_op)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9135 {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9136 sata_pkt_t *spkt;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9137 sata_cmd_t *scmd;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9138 sata_pkt_txlate_t *spx;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9139 int rval = SATA_SUCCESS;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9140 char *infop;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9141
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9142 ASSERT(sdinfo != NULL);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9143 ASSERT(sata_hba_inst != NULL);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9144 ASSERT(cache_op == SATAC_SF_ENABLE_READ_AHEAD ||
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9145 cache_op == SATAC_SF_DISABLE_READ_AHEAD ||
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9146 cache_op == SATAC_SF_ENABLE_WRITE_CACHE ||
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9147 cache_op == SATAC_SF_DISABLE_WRITE_CACHE);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9148
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9149
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9150 /* Prepare packet for SET FEATURES COMMAND */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9151 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9152 spx->txlt_sata_hba_inst = sata_hba_inst;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9153 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9154 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9155 if (spkt == NULL) {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9156 rval = SATA_FAILURE;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9157 goto failure;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9158 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9159 /* Fill sata_pkt */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9160 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9161 /* Timeout 30s */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9162 spkt->satapkt_time = sata_default_pkt_time;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9163 /* Synchronous mode, no callback, interrupts */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9164 spkt->satapkt_op_mode =
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9165 SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9166 spkt->satapkt_comp = NULL;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9167 scmd = &spkt->satapkt_cmd;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9168 scmd->satacmd_flags.sata_data_direction = SATA_DIR_NODATA_XFER;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9169 scmd->satacmd_flags.sata_ignore_dev_reset = B_TRUE;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9170 scmd->satacmd_addr_type = 0;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9171 scmd->satacmd_device_reg = 0;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9172 scmd->satacmd_status_reg = 0;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9173 scmd->satacmd_error_reg = 0;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9174 scmd->satacmd_cmd_reg = SATAC_SET_FEATURES;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9175 scmd->satacmd_features_reg = cache_op;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9176
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9177 /* Transfer command to HBA */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9178 if (((*SATA_START_FUNC(sata_hba_inst))(
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9179 SATA_DIP(sata_hba_inst), spkt) != 0) ||
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9180 (spkt->satapkt_reason != SATA_PKT_COMPLETED)) {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9181 /* Pkt execution failed */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9182 switch (cache_op) {
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9183 case SATAC_SF_ENABLE_READ_AHEAD:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9184 infop = "enabling read ahead failed";
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9185 break;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9186 case SATAC_SF_DISABLE_READ_AHEAD:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9187 infop = "disabling read ahead failed";
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9188 break;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9189 case SATAC_SF_ENABLE_WRITE_CACHE:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9190 infop = "enabling write cache failed";
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9191 break;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9192 case SATAC_SF_DISABLE_WRITE_CACHE:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9193 infop = "disabling write cache failed";
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9194 break;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9195 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9196 SATA_LOG_D((sata_hba_inst, CE_WARN, "%s", infop));
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9197 rval = SATA_FAILURE;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9198 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9199 failure:
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9200 /* Free allocated resources */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9201 if (spkt != NULL)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9202 sata_pkt_free(spx);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9203 (void) kmem_free(spx, sizeof (sata_pkt_txlate_t));
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9204 return (rval);
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9205 }
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9206
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9207
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9208
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9209 /*
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9210 * Update port SCR block
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9211 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9212 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9213 sata_update_port_scr(sata_port_scr_t *port_scr, sata_device_t *device)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9214 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9215 port_scr->sstatus = device->satadev_scr.sstatus;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9216 port_scr->serror = device->satadev_scr.serror;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9217 port_scr->scontrol = device->satadev_scr.scontrol;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9218 port_scr->sactive = device->satadev_scr.sactive;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9219 port_scr->snotific = device->satadev_scr.snotific;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9220 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9221
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9222 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9223 * Update state and copy port ss* values from passed sata_device structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9224 * sata_address is validated - if not valid, nothing is changed in sata_scsi
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9225 * configuration struct.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9226 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9227 * SATA_PSTATE_SHUTDOWN in port state is not reset to 0 by this function
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9228 * regardless of the state in device argument.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9229 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9230 * Port mutex should be held while calling this function.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9231 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9232 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9233 sata_update_port_info(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9234 sata_device_t *sata_device)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9235 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9236 ASSERT(mutex_owned(&SATA_CPORT_MUTEX(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9237 sata_device->satadev_addr.cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9238
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9239 if (sata_device->satadev_addr.qual == SATA_ADDR_CPORT ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9240 sata_device->satadev_addr.qual == SATA_ADDR_DCPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9241
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9242 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9243
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9244 if (SATA_NUM_CPORTS(sata_hba_inst) <=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9245 sata_device->satadev_addr.cport)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9246 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9247
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9248 cportinfo = SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9249 sata_device->satadev_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9250 sata_update_port_scr(&cportinfo->cport_scr, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9251
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9252 /* Preserve SATA_PSTATE_SHUTDOWN flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9253 cportinfo->cport_state &= ~(SATA_PSTATE_PWRON |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9254 SATA_PSTATE_PWROFF | SATA_PSTATE_FAILED);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9255 cportinfo->cport_state |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9256 sata_device->satadev_state & SATA_PSTATE_VALID;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9257 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9258 sata_pmport_info_t *pmportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9259
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9260 if ((sata_device->satadev_addr.qual != SATA_ADDR_PMPORT) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9261 (sata_device->satadev_addr.qual != SATA_ADDR_DPMPORT) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9262 SATA_NUM_PMPORTS(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9263 sata_device->satadev_addr.cport) <
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9264 sata_device->satadev_addr.pmport)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9265 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9266
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9267 pmportinfo = SATA_PMPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9268 sata_device->satadev_addr.cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9269 sata_device->satadev_addr.pmport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9270 sata_update_port_scr(&pmportinfo->pmport_scr, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9271
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9272 /* Preserve SATA_PSTATE_SHUTDOWN flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9273 pmportinfo->pmport_state &=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9274 ~(SATA_PSTATE_PWRON | SATA_PSTATE_PWROFF |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9275 SATA_PSTATE_FAILED);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9276 pmportinfo->pmport_state |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9277 sata_device->satadev_state & SATA_PSTATE_VALID;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9278 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9279 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9280
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9281
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9282
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9283 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9284 * Extract SATA port specification from an IOCTL argument.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9285 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9286 * This function return the port the user land send us as is, unless it
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9287 * cannot retrieve port spec, then -1 is returned.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9288 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9289 * Note: Only cport - no port multiplier port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9290 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9291 static int32_t
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9292 sata_get_port_num(sata_hba_inst_t *sata_hba_inst, struct devctl_iocdata *dcp)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9293 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9294 int32_t port;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9295
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9296 /* Extract port number from nvpair in dca structure */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9297 if (nvlist_lookup_int32(ndi_dc_get_ap_data(dcp), "port", &port) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9298 SATA_LOG_D((sata_hba_inst, CE_NOTE,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9299 "sata_get_port_num: invalid port spec 0x%x in ioctl",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9300 port));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9301 port = -1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9302 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9303
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9304 return (port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9305 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9306
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9307 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9308 * Get dev_info_t pointer to the device node pointed to by port argument.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9309 * NOTE: target argument is a value used in ioctls to identify
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9310 * the AP - it is not a sata_address.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9311 * It is a combination of cport, pmport and address qualifier, encodded same
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9312 * way as a scsi target number.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9313 * At this moment it carries only cport number.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9314 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9315 * No PMult hotplug support.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9316 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9317 * Returns dev_info_t pointer if target device was found, NULL otherwise.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9318 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9319
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9320 static dev_info_t *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9321 sata_get_target_dip(dev_info_t *dip, int32_t port)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9322 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9323 dev_info_t *cdip = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9324 int target, tgt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9325 int ncport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9326 int circ;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9327
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9328 ncport = port & SATA_CFGA_CPORT_MASK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9329 target = SATA_TO_SCSI_TARGET(ncport, 0, SATA_ADDR_DCPORT);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9330
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9331 ndi_devi_enter(dip, &circ);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9332 for (cdip = ddi_get_child(dip); cdip != NULL; ) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9333 dev_info_t *next = ddi_get_next_sibling(cdip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9334
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9335 tgt = ddi_prop_get_int(DDI_DEV_T_ANY, cdip,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9336 DDI_PROP_DONTPASS, "target", -1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9337 if (tgt == -1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9338 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9339 * This is actually an error condition, but not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9340 * a fatal one. Just continue the search.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9341 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9342 cdip = next;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9343 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9344 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9345
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9346 if (tgt == target)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9347 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9348
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9349 cdip = next;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9350 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9351 ndi_devi_exit(dip, circ);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9352
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9353 return (cdip);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9354 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9355
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9356
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9357 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9358 * sata_cfgadm_state:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9359 * Use the sata port state and state of the target node to figure out
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9360 * the cfgadm_state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9361 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9362 * The port argument is a value with encoded cport,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9363 * pmport and address qualifier, in the same manner as a scsi target number.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9364 * SCSI_TO_SATA_CPORT macro extracts cport number,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9365 * SCSI_TO_SATA_PMPORT extracts pmport number and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9366 * SCSI_TO_SATA_ADDR_QUAL extracts port mulitplier qualifier flag.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9367 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9368 * For now, support is for cports only - no pmultiplier ports.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9369 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9370
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9371 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9372 sata_cfgadm_state(sata_hba_inst_t *sata_hba_inst, int32_t port,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9373 devctl_ap_state_t *ap_state)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9374 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9375 uint16_t cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9376 int port_state;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9377
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9378 /* Cport only */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9379 cport = SCSI_TO_SATA_CPORT(port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9380
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9381 port_state = SATA_CPORT_STATE(sata_hba_inst, cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9382 if (port_state & SATA_PSTATE_SHUTDOWN ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9383 port_state & SATA_PSTATE_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9384 ap_state->ap_rstate = AP_RSTATE_DISCONNECTED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9385 ap_state->ap_ostate = AP_OSTATE_UNCONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9386 if (port_state & SATA_PSTATE_FAILED)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9387 ap_state->ap_condition = AP_COND_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9388 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9389 ap_state->ap_condition = AP_COND_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9390
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9391 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9392 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9393
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9394 /* Need to check pmult device port here as well, when supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9395
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9396 /* Port is enabled and ready */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9397
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9398 switch (SATA_CPORT_DEV_TYPE(sata_hba_inst, cport)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9399 case SATA_DTYPE_NONE:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9400 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9401 /* No device attached */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9402 ap_state->ap_rstate = AP_RSTATE_EMPTY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9403 ap_state->ap_ostate = AP_OSTATE_UNCONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9404 ap_state->ap_condition = AP_COND_OK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9405 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9406 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9407 case SATA_DTYPE_UNKNOWN:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9408 case SATA_DTYPE_ATAPINONCD:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9409 case SATA_DTYPE_PMULT: /* Until PMult is supported */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9410 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9411 /* Unknown device attached */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9412 ap_state->ap_rstate = AP_RSTATE_CONNECTED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9413 ap_state->ap_ostate = AP_OSTATE_UNCONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9414 ap_state->ap_condition = AP_COND_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9415 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9416 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9417 case SATA_DTYPE_ATADISK:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9418 case SATA_DTYPE_ATAPICD:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9419 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9420 dev_info_t *tdip = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9421 dev_info_t *dip = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9422 int circ;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9423
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9424 dip = SATA_DIP(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9425 tdip = sata_get_target_dip(dip, port);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9426 ap_state->ap_rstate = AP_RSTATE_CONNECTED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9427 if (tdip != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9428 ndi_devi_enter(dip, &circ);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9429 mutex_enter(&(DEVI(tdip)->devi_lock));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9430 if ((DEVI_IS_DEVICE_OFFLINE(tdip)) ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9431 (DEVI_IS_DEVICE_DOWN(tdip))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9432 ap_state->ap_ostate = AP_OSTATE_UNCONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9433 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9434 ap_state->ap_ostate = AP_OSTATE_CONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9435 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9436 ap_state->ap_condition = AP_COND_OK;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9437 mutex_exit(&(DEVI(tdip)->devi_lock));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9438 ndi_devi_exit(dip, circ);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9439 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9440 ap_state->ap_ostate = AP_OSTATE_UNCONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9441 ap_state->ap_condition = AP_COND_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9442 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9443 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9444 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9445 default:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9446 ap_state->ap_rstate = AP_RSTATE_CONNECTED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9447 ap_state->ap_ostate = AP_OSTATE_UNCONFIGURED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9448 ap_state->ap_condition = AP_COND_UNKNOWN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9449 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9450 * This is actually internal error condition (non fatal),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9451 * beacuse we already checked all defined device types.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9452 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9453 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9454 "sata_cfgadm_state: Internal error: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9455 "unknown device type"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9456 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9457 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9458 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9459
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9460 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9461 * Start or terminate the thread, depending on flag arg and current state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9462 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9463 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9464 sata_event_thread_control(int startstop)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9465 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9466 static int sata_event_thread_terminating = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9467 static int sata_event_thread_starting = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9468 int i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9469
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9470 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9471
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9472 if (startstop == 0 && (sata_event_thread_starting == 1 ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9473 sata_event_thread_terminating == 1)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9474 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9475 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9476 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9477 if (startstop == 1 && sata_event_thread_starting == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9478 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9479 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9480 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9481 if (startstop == 1 && sata_event_thread_terminating == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9482 sata_event_thread_starting = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9483 /* wait til terminate operation completes */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9484 i = SATA_EVNT_DAEMON_TERM_WAIT/SATA_EVNT_DAEMON_TERM_TIMEOUT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9485 while (sata_event_thread_terminating == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9486 if (i-- <= 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9487 sata_event_thread_starting = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9488 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9489 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9490 cmn_err(CE_WARN, "sata_event_thread_control: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9491 "timeout waiting for thread to terminate");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9492 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9493 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9494 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9495 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9496 delay(drv_usectohz(SATA_EVNT_DAEMON_TERM_TIMEOUT));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9497 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9498 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9499 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9500 if (startstop == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9501 if (sata_event_thread == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9502 sata_event_thread = thread_create(NULL, 0,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9503 (void (*)())sata_event_daemon,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9504 &sata_hba_list, 0, &p0, TS_RUN, minclsyspri);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9505 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9506 sata_event_thread_starting = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9507 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9508 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9509 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9510
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9511 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9512 * If we got here, thread may need to be terminated
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9513 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9514 if (sata_event_thread != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9515 int i;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9516 /* Signal event thread to go away */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9517 sata_event_thread_terminating = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9518 sata_event_thread_terminate = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9519 cv_signal(&sata_event_cv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9520 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9521 * Wait til daemon terminates.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9522 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9523 i = SATA_EVNT_DAEMON_TERM_WAIT/SATA_EVNT_DAEMON_TERM_TIMEOUT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9524 while (sata_event_thread_terminate == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9525 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9526 if (i-- <= 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9527 /* Daemon did not go away !!! */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9528 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9529 cmn_err(CE_WARN, "sata_event_thread_control: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9530 "cannot terminate event daemon thread");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9531 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9532 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9533 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9534 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9535 delay(drv_usectohz(SATA_EVNT_DAEMON_TERM_TIMEOUT));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9536 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9537 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9538 sata_event_thread_terminating = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9539 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9540 ASSERT(sata_event_thread_terminating == 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9541 ASSERT(sata_event_thread_starting == 0);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9542 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9543 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9544
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9545
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9546 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9547 * Log sata message
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9548 * dev pathname msg line preceeds the logged message.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9549 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9550
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9551 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9552 sata_log(sata_hba_inst_t *sata_hba_inst, uint_t level, char *fmt, ...)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9553 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9554 char pathname[128];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9555 dev_info_t *dip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9556 va_list ap;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9557
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9558 mutex_enter(&sata_log_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9559
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9560 va_start(ap, fmt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9561 (void) vsprintf(sata_log_buf, fmt, ap);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9562 va_end(ap);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9563
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9564 if (sata_hba_inst != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9565 dip = SATA_DIP(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9566 (void) ddi_pathname(dip, pathname);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9567 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9568 pathname[0] = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9569 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9570 if (level == CE_CONT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9571 if (sata_debug_flags == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9572 cmn_err(level, "?%s:\n %s\n", pathname, sata_log_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9573 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9574 cmn_err(level, "%s:\n %s\n", pathname, sata_log_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9575 } else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9576 cmn_err(level, "%s:\n %s", pathname, sata_log_buf);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9577
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9578 mutex_exit(&sata_log_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9579 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9580
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9581
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9582 /* ******** Asynchronous HBA events handling & hotplugging support ******** */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9583
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9584 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9585 * SATA HBA event notification function.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9586 * Events reported by SATA HBA drivers per HBA instance relate to a change in
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9587 * a port and/or device state or a controller itself.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9588 * Events for different addresses/addr types cannot be combined.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9589 * A warning message is generated for each event type.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9590 * Events are not processed by this function, so only the
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9591 * event flag(s)is set for an affected entity and the event thread is
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9592 * waken up. Event daemon thread processes all events.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9593 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9594 * NOTE: Since more than one event may be reported at the same time, one
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9595 * cannot determine a sequence of events when opposite event are reported, eg.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9596 * LINK_LOST and LINK_ESTABLISHED. Actual port status during event processing
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9597 * is taking precedence over reported events, i.e. may cause ignoring some
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9598 * events.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9599 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9600 #define SATA_EVENT_MAX_MSG_LENGTH 79
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9601
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9602 void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9603 sata_hba_event_notify(dev_info_t *dip, sata_device_t *sata_device, int event)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9604 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9605 sata_hba_inst_t *sata_hba_inst = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9606 sata_address_t *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9607 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9608 sata_port_stats_t *pstats;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9609 int cport, pmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9610 char buf1[SATA_EVENT_MAX_MSG_LENGTH + 1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9611 char buf2[SATA_EVENT_MAX_MSG_LENGTH + 1];
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9612 char *lcp;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9613 static char *err_msg_evnt_1 =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9614 "sata_hba_event_notify: invalid port event 0x%x ";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9615 static char *err_msg_evnt_2 =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9616 "sata_hba_event_notify: invalid device event 0x%x ";
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9617 int linkevent;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9618
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9619 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9620 * There is a possibility that an event will be generated on HBA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9621 * that has not completed attachment or is detaching.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9622 * HBA driver should prevent this, but just in case it does not,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9623 * we need to ignore events for such HBA.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9624 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9625 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9626 for (sata_hba_inst = sata_hba_list; sata_hba_inst != NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9627 sata_hba_inst = sata_hba_inst->satahba_next) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9628 if (SATA_DIP(sata_hba_inst) == dip)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9629 if (sata_hba_inst->satahba_attached == 1)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9630 break;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9631 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9632 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9633 if (sata_hba_inst == NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9634 /* HBA not attached */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9635 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9636
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9637 ASSERT(sata_device != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9638
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9639 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9640 * Validate address before - do not proceed with invalid address.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9641 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9642 saddr = &sata_device->satadev_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9643 if (saddr->cport >= SATA_NUM_CPORTS(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9644 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9645 if (saddr->qual == SATA_ADDR_PMPORT ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9646 saddr->qual == SATA_ADDR_DPMPORT)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9647 /* Port Multiplier not supported yet */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9648 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9649
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9650 cport = saddr->cport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9651 pmport = saddr->pmport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9652
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9653 buf1[0] = buf2[0] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9654
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9655 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9656 * Events refer to devices, ports and controllers - each has
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9657 * unique address. Events for different addresses cannot be combined.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9658 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9659 if (saddr->qual & (SATA_ADDR_CPORT | SATA_ADDR_PMPORT)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9660
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9661 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9662
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9663 /* qualify this event(s) */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9664 if ((event & SATA_EVNT_PORT_EVENTS) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9665 /* Invalid event for the device port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9666 (void) sprintf(buf2, err_msg_evnt_1,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9667 event & SATA_EVNT_PORT_EVENTS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9668 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9669 goto event_info;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9670 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9671 if (saddr->qual == SATA_ADDR_CPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9672 /* Controller's device port event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9673
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9674 (SATA_CPORT_INFO(sata_hba_inst, cport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9675 cport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9676 event & SATA_EVNT_PORT_EVENTS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9677 pstats =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9678 &(SATA_CPORT_INFO(sata_hba_inst, cport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9679 cport_stats;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9680 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9681 /* Port multiplier's device port event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9682 (SATA_PMPORT_INFO(sata_hba_inst, cport, pmport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9683 pmport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9684 event & SATA_EVNT_PORT_EVENTS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9685 pstats =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9686 &(SATA_PMPORT_INFO(sata_hba_inst, cport, pmport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9687 pmport_stats;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9688 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9689
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9690 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9691 * Add to statistics and log the message. We have to do it
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9692 * here rather than in the event daemon, because there may be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9693 * multiple events occuring before they are processed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9694 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9695 linkevent = event &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9696 (SATA_EVNT_LINK_LOST | SATA_EVNT_LINK_ESTABLISHED);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9697 if (linkevent) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9698 if (linkevent == (SATA_EVNT_LINK_LOST |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9699 SATA_EVNT_LINK_ESTABLISHED)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9700 /* This is likely event combination */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9701 (void) strlcat(buf1, "link lost/established, ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9702 SATA_EVENT_MAX_MSG_LENGTH);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9703
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9704 if (pstats->link_lost < 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9705 pstats->link_lost++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9706 if (pstats->link_established <
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9707 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9708 pstats->link_established++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9709 linkevent = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9710 } else if (linkevent & SATA_EVNT_LINK_LOST) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9711 (void) strlcat(buf1, "link lost, ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9712 SATA_EVENT_MAX_MSG_LENGTH);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9713
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9714 if (pstats->link_lost < 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9715 pstats->link_lost++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9716 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9717 (void) strlcat(buf1, "link established, ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9718 SATA_EVENT_MAX_MSG_LENGTH);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9719 if (pstats->link_established <
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9720 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9721 pstats->link_established++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9722 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9723 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9724 if (event & SATA_EVNT_DEVICE_ATTACHED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9725 (void) strlcat(buf1, "device attached, ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9726 SATA_EVENT_MAX_MSG_LENGTH);
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9727 if (pstats->device_attached < 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9728 pstats->device_attached++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9729 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9730 if (event & SATA_EVNT_DEVICE_DETACHED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9731 (void) strlcat(buf1, "device detached, ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9732 SATA_EVENT_MAX_MSG_LENGTH);
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9733 if (pstats->device_detached < 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9734 pstats->device_detached++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9735 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9736 if (event & SATA_EVNT_PWR_LEVEL_CHANGED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9737 SATADBG1(SATA_DBG_EVENTS, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9738 "port %d power level changed", cport);
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9739 if (pstats->port_pwr_changed < 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9740 pstats->port_pwr_changed++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9741 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9742
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9743 if ((event & ~SATA_EVNT_PORT_EVENTS) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9744 /* There should be no other events for this address */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9745 (void) sprintf(buf2, err_msg_evnt_1,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9746 event & ~SATA_EVNT_PORT_EVENTS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9747 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9748 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9749
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9750 } else if (saddr->qual & (SATA_ADDR_DCPORT | SATA_ADDR_DPMPORT)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9751 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9752
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9753 /* qualify this event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9754 if ((event & SATA_EVNT_DEVICE_RESET) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9755 /* Invalid event for a device */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9756 (void) sprintf(buf2, err_msg_evnt_2,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9757 event & SATA_EVNT_DEVICE_RESET);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9758 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9759 goto event_info;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9760 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9761 /* drive event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9762 sdinfo = sata_get_device_info(sata_hba_inst, sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9763 if (sdinfo != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9764 if (event & SATA_EVNT_DEVICE_RESET) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9765 (void) strlcat(buf1, "device reset, ",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9766 SATA_EVENT_MAX_MSG_LENGTH);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9767 if (sdinfo->satadrv_stats.drive_reset <
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9768 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9769 sdinfo->satadrv_stats.drive_reset++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9770 sdinfo->satadrv_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9771 SATA_EVNT_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9772 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9773 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9774 if ((event & ~SATA_EVNT_DEVICE_RESET) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9775 /* Invalid event for a device */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9776 (void) sprintf(buf2, err_msg_evnt_2,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9777 event & ~SATA_EVNT_DRIVE_EVENTS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9778 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9779 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, cport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9780 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9781 if (saddr->qual != SATA_ADDR_NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9782 /* Wrong address qualifier */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9783 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9784 "sata_hba_event_notify: invalid address 0x%x",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9785 *(uint32_t *)saddr));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9786 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9787 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9788 if ((event & SATA_EVNT_CONTROLLER_EVENTS) == 0 ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9789 (event & ~SATA_EVNT_CONTROLLER_EVENTS) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9790 /* Invalid event for the controller */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9791 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9792 "sata_hba_event_notify: invalid event 0x%x for "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9793 "controller",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9794 event & SATA_EVNT_CONTROLLER_EVENTS));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9795 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9796 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9797 buf1[0] = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9798 /* This may be a frequent and not interesting event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9799 SATADBG1(SATA_DBG_EVENTS, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9800 "controller power level changed\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9801
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9802 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9803 if (sata_hba_inst->satahba_stats.ctrl_pwr_change <
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
9804 0xffffffffffffffffULL)
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9805 sata_hba_inst->satahba_stats.ctrl_pwr_change++;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9806
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9807 sata_hba_inst->satahba_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9808 SATA_EVNT_PWR_LEVEL_CHANGED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9809 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9810 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9811 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9812 * If we got here, there is something to do with this HBA
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9813 * instance.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9814 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9815 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9816 sata_hba_inst->satahba_event_flags |= SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9817 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9818 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9819 sata_event_pending |= SATA_EVNT_MAIN; /* global event indicator */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9820 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9821
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9822 /* Tickle event thread */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9823 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9824 if (sata_event_thread_active == 0)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9825 cv_signal(&sata_event_cv);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9826 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9827
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9828 event_info:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9829 if (buf1[0] != '\0') {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9830 lcp = strrchr(buf1, ',');
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9831 if (lcp != NULL)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9832 *lcp = '\0';
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9833 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9834 if (saddr->qual == SATA_ADDR_CPORT ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9835 saddr->qual == SATA_ADDR_DCPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9836 if (buf1[0] != '\0') {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9837 sata_log(sata_hba_inst, CE_NOTE, "port %d: %s\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9838 cport, buf1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9839 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9840 if (buf2[0] != '\0') {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9841 sata_log(sata_hba_inst, CE_NOTE, "port %d: %s\n",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9842 cport, buf2);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9843 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9844 } else if (saddr->qual == SATA_ADDR_PMPORT ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9845 saddr->qual == SATA_ADDR_DPMPORT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9846 if (buf1[0] != '\0') {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9847 sata_log(sata_hba_inst, CE_NOTE,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9848 "port %d pmport %d: %s\n", cport, pmport, buf1);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9849 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9850 if (buf2[0] != '\0') {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9851 sata_log(sata_hba_inst, CE_NOTE,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9852 "port %d pmport %d: %s\n", cport, pmport, buf2);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9853 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9854 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9855 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9856
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9857
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9858 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9859 * Event processing thread.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9860 * Arg is a pointer to the sata_hba_list pointer.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9861 * It is not really needed, because sata_hba_list is global and static
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9862 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9863 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9864 sata_event_daemon(void *arg)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9865 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9866 #ifndef __lock_lint
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9867 _NOTE(ARGUNUSED(arg))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9868 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9869 sata_hba_inst_t *sata_hba_inst;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9870 clock_t lbolt;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9871
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9872 SATADBG1(SATA_DBG_EVENTS_DAEMON, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9873 "SATA event daemon started\n", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9874 loop:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9875 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9876 * Process events here. Walk through all registered HBAs
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9877 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9878 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9879 for (sata_hba_inst = sata_hba_list; sata_hba_inst != NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9880 sata_hba_inst = sata_hba_inst->satahba_next) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9881 ASSERT(sata_hba_inst != NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9882 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9883 if (sata_hba_inst->satahba_attached != 1 ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9884 (sata_hba_inst->satahba_event_flags &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9885 SATA_EVNT_SKIP) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9886 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9887 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9888 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9889 if (sata_hba_inst->satahba_event_flags & SATA_EVNT_MAIN) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9890 sata_hba_inst->satahba_event_flags |= SATA_EVNT_SKIP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9891 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9892 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9893 /* Got the controller with pending event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9894 sata_process_controller_events(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9895 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9896 * Since global mutex was released, there is a
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9897 * possibility that HBA list has changed, so start
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9898 * over from the top. Just processed controller
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9899 * will be passed-over because of the SKIP flag.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9900 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9901 goto loop;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9902 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9903 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9904 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9905 /* Clear SKIP flag in all controllers */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9906 for (sata_hba_inst = sata_hba_list; sata_hba_inst != NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9907 sata_hba_inst = sata_hba_inst->satahba_next) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9908 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9909 sata_hba_inst->satahba_event_flags &= ~SATA_EVNT_SKIP;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9910 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9911 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9912 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9913
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9914 SATADBG1(SATA_DBG_EVENTS_DAEMON, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9915 "SATA EVENT DAEMON suspending itself", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9916
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9917 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9918 if ((sata_func_enable & SATA_ENABLE_PROCESS_EVENTS) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9919 sata_log(sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9920 "SATA EVENTS PROCESSING DISABLED\n");
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9921 thread_exit(); /* Daemon will not run again */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9922 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9923 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9924 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9925 sata_event_thread_active = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9926 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9927 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9928 * Go to sleep/suspend itself and wake up either because new event or
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9929 * wait timeout. Exit if there is a termination request (driver
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9930 * unload).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9931 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9932 do {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9933 lbolt = ddi_get_lbolt();
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9934 lbolt += drv_usectohz(SATA_EVNT_DAEMON_SLEEP_TIME);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9935 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9936 (void) cv_timedwait(&sata_event_cv, &sata_event_mutex, lbolt);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9937
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9938 if (sata_event_thread_active != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9939 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9940 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9941 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9942
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9943 /* Check if it is time to go away */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9944 if (sata_event_thread_terminate == 1) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9945 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9946 * It is up to the thread setting above flag to make
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9947 * sure that this thread is not killed prematurely.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9948 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9949 sata_event_thread_terminate = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9950 sata_event_thread = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9951 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9952 SATADBG1(SATA_DBG_EVENTS_DAEMON, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9953 "SATA_EVENT_DAEMON_TERMINATING", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9954 thread_exit(); { _NOTE(NOT_REACHED) }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9955 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9956 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9957 } while (!(sata_event_pending & SATA_EVNT_MAIN));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9958
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9959 mutex_enter(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9960 sata_event_thread_active = 1;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9961 mutex_exit(&sata_event_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9962
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9963 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9964 sata_event_pending &= ~SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9965 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9966
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9967 SATADBG1(SATA_DBG_EVENTS_DAEMON, NULL,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9968 "SATA EVENT DAEMON READY TO PROCESS EVENT", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9969
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9970 goto loop;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9971 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9972
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9973 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9974 * Specific HBA instance event processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9975 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9976 * NOTE: At the moment, device event processing is limited to hard disks
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9977 * only.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9978 * cports only are supported - no pmports.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9979 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9980 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9981 sata_process_controller_events(sata_hba_inst_t *sata_hba_inst)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9982 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9983 int ncport;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9984 uint32_t event_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9985 sata_address_t *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9986
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9987 SATADBG1(SATA_DBG_EVENTS_CNTRL, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9988 "Processing controller %d event(s)",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9989 ddi_get_instance(SATA_DIP(sata_hba_inst)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9990
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9991 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9992 sata_hba_inst->satahba_event_flags &= ~SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9993 event_flags = sata_hba_inst->satahba_event_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9994 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9995 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9996 * Process controller power change first
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9997 * HERE
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9998 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
9999 if (event_flags & SATA_EVNT_PWR_LEVEL_CHANGED)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10000 sata_process_cntrl_pwr_level_change(sata_hba_inst);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10001
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10002 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10003 * Search through ports/devices to identify affected port/device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10004 * We may have to process events for more than one port/device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10005 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10006 for (ncport = 0; ncport < SATA_NUM_CPORTS(sata_hba_inst); ncport++) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10007 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst, ncport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10008 event_flags = (SATA_CPORT_INFO(sata_hba_inst, ncport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10009 cport_event_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10010 /* Check if port was locked by IOCTL processing */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10011 if (event_flags & SATA_APCTL_LOCK_PORT_BUSY) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10012 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10013 * We ignore port events because port is busy
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10014 * with AP control processing. Set again
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10015 * controller and main event flag, so that
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10016 * events may be processed by the next daemon
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10017 * run.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10018 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10019 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, ncport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10020 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10021 sata_hba_inst->satahba_event_flags |= SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10022 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10023 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10024 sata_event_pending |= SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10025 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10026 SATADBG1(SATA_DBG_EVENTS_PROCPST, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10027 "Event processing postponed until "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10028 "AP control processing completes",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10029 NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10030 /* Check other ports */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10031 continue;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10032 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10033 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10034 * Set BSY flag so that AP control would not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10035 * interfere with events processing for
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10036 * this port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10037 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10038 (SATA_CPORT_INFO(sata_hba_inst, ncport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10039 cport_event_flags |= SATA_EVNT_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10040 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10041 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, ncport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10042
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10043 saddr = &(SATA_CPORT_INFO(sata_hba_inst, ncport))->cport_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10044
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10045 if ((event_flags &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10046 (SATA_EVNT_PORT_EVENTS | SATA_EVNT_DRIVE_EVENTS)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10047 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10048 * Got port event.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10049 * We need some hierarchy of event processing as they
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10050 * are affecting each other:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10051 * 1. port failed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10052 * 2. device detached/attached
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10053 * 3. link events - link events may trigger device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10054 * detached or device attached events in some
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10055 * circumstances.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10056 * 4. port power level changed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10057 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10058 if (event_flags & SATA_EVNT_PORT_FAILED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10059 sata_process_port_failed_event(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10060 saddr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10061 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10062 if (event_flags & SATA_EVNT_DEVICE_DETACHED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10063 sata_process_device_detached(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10064 saddr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10065 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10066 if (event_flags & SATA_EVNT_DEVICE_ATTACHED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10067 sata_process_device_attached(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10068 saddr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10069 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10070 if (event_flags &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10071 (SATA_EVNT_LINK_ESTABLISHED |
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10072 SATA_EVNT_LINK_LOST)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10073 sata_process_port_link_events(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10074 saddr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10075 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10076 if (event_flags & SATA_EVNT_PWR_LEVEL_CHANGED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10077 sata_process_port_pwr_change(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10078 saddr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10079 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10080 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10081 if (SATA_CPORT_DEV_TYPE(sata_hba_inst, ncport) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10082 SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10083 /* May have device event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10084 sata_process_device_reset(sata_hba_inst, saddr);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10085 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10086 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst, ncport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10087 /* Release PORT_BUSY flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10088 (SATA_CPORT_INFO(sata_hba_inst, ncport))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10089 cport_event_flags &= ~SATA_EVNT_LOCK_PORT_BUSY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10090 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst, ncport)));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10091
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10092 } /* End of loop through the controller SATA ports */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10093 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10094
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10095 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10096 * Process HBA power level change reported by HBA driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10097 * Not implemented at this time - event is ignored.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10098 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10099 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10100 sata_process_cntrl_pwr_level_change(sata_hba_inst_t *sata_hba_inst)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10101 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10102 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10103 "Processing controller power level change", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10104
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10105 /* Ignoring it for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10106 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10107 sata_hba_inst->satahba_event_flags &= ~SATA_EVNT_PWR_LEVEL_CHANGED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10108 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10109 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10110
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10111 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10112 * Process port power level change reported by HBA driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10113 * Not implemented at this time - event is ignored.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10114 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10115 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10116 sata_process_port_pwr_change(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10117 sata_address_t *saddr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10118 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10119 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10120
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10121 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10122 "Processing port power level change", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10123
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10124 cportinfo = SATA_CPORT_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10125 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10126 /* Reset event flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10127 cportinfo->cport_event_flags &= ~SATA_EVNT_PWR_LEVEL_CHANGED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10128 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10129 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10130
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10131 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10132 * Process port failure reported by HBA driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10133 * cports support only - no pmports.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10134 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10135 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10136 sata_process_port_failed_event(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10137 sata_address_t *saddr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10138 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10139 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10140
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10141 cportinfo = SATA_CPORT_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10142 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10143 /* Reset event flag first */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10144 cportinfo->cport_event_flags &= ~SATA_EVNT_PORT_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10145 /* If the port is in SHUTDOWN or FAILED state, ignore this event. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10146 if ((cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10147 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10148 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10149 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10150 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10151 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10152 /* Fail the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10153 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10154 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10155 sata_log(sata_hba_inst, CE_WARN, "port %d failed", saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10156 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10157
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10158 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10159 * Device Reset Event processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10160 * The seqeunce is managed by 3 stage flags:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10161 * - reset event reported,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10162 * - reset event being processed,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10163 * - request to clear device reset state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10164 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10165 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10166 sata_process_device_reset(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10167 sata_address_t *saddr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10168 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10169 sata_drive_info_t old_sdinfo; /* local copy of the drive info */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10170 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10171 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10172 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10173 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10174
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10175 /* We only care about host sata cport for now */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10176 cportinfo = SATA_CPORT_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10177
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10178 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10179
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10180 /* If the port is in SHUTDOWN or FAILED state, ignore reset event. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10181 if ((cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10182 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10183 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10184 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10185 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10186 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10187
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10188 if ((SATA_CPORT_DEV_TYPE(sata_hba_inst, saddr->cport) &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10189 SATA_VALID_DEV_TYPE) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10190 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10191 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10192 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10193 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10194 sdinfo = SATA_CPORT_DRV_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10195 if (sdinfo == NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10196 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10197 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10198 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10199 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10200
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10201 if ((sdinfo->satadrv_event_flags & SATA_EVNT_DEVICE_RESET) == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10202 /* Nothing to do */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10203 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10204 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10205 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10206 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10207
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10208 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10209 "Processing port %d device reset", saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10210
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10211 if (sdinfo->satadrv_event_flags & SATA_EVNT_INPROC_DEVICE_RESET) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10212 /* Something is weird - new device reset event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10213 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10214 "Overlapping device reset events!", NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10215 /* Just leave */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10216 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10217 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10218 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10219 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10220
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10221 /* Clear event flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10222 sdinfo->satadrv_event_flags &= ~SATA_EVNT_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10223
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10224 /* It seems that we always need to check the port state first */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10225 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10226 sata_device.satadev_addr = *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10227 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10228 * We have to exit mutex, because the HBA probe port function may
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10229 * block on its own mutex.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10230 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10231 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10232 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10233 (SATA_DIP(sata_hba_inst), &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10234 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10235 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10236 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10237 /* Something went wrong? Fail the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10238 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10239 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10240 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10241 SATA_LOG_D((sata_hba_inst, CE_WARN, "Port %d probing failed",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10242 saddr->cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10243 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10244 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10245 if ((sata_device.satadev_scr.sstatus &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10246 SATA_PORT_DEVLINK_UP_MASK) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10247 SATA_PORT_DEVLINK_UP ||
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10248 sata_device.satadev_type == SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10249 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10250 * No device to process, anymore. Some other event processing
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10251 * would or have already performed port info cleanup.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10252 * To be safe (HBA may need it), request clearing device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10253 * reset condition.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10254 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10255 sdinfo->satadrv_event_flags = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10256 sdinfo->satadrv_event_flags |= SATA_EVNT_CLEAR_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10257 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10258 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10259 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10260 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10261
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10262 /* Mark device reset processing as active */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10263 sdinfo->satadrv_event_flags |= SATA_EVNT_INPROC_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10264
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10265 old_sdinfo = *sdinfo; /* local copy of the drive info */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10266 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10267
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10268 if (sata_set_drive_features(sata_hba_inst, &old_sdinfo, 1) ==
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10269 SATA_FAILURE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10270 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10271 * Restoring drive setting failed.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10272 * Probe the port first, to check if the port state has changed
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10273 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10274 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10275 sata_device.satadev_addr = *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10276 sata_device.satadev_addr.qual = SATA_ADDR_CPORT;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10277 /* probe port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10278 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10279 (SATA_DIP(sata_hba_inst), &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10280 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10281 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10282 if (rval == SATA_SUCCESS &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10283 (sata_device.satadev_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10284 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) == 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10285 (sata_device.satadev_scr.sstatus &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10286 SATA_PORT_DEVLINK_UP_MASK) == SATA_PORT_DEVLINK_UP &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10287 (sata_device.satadev_type & SATA_DTYPE_ATADISK) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10288 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10289 * We may retry this a bit later - reinstate reset
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10290 * condition
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10291 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10292 if ((cportinfo->cport_dev_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10293 SATA_VALID_DEV_TYPE) != 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10294 SATA_CPORTINFO_DRV_INFO(cportinfo) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10295 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10296 sdinfo->satadrv_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10297 SATA_EVNT_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10298 sdinfo->satadrv_event_flags &=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10299 ~SATA_EVNT_INPROC_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10300 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10301 saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10302 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10303 sata_hba_inst->satahba_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10304 SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10305 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10306 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10307 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10308 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10309 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10310 * No point of retrying - some other event processing
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10311 * would or already did port info cleanup.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10312 * To be safe (HBA may need it),
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10313 * request clearing device reset condition.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10314 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10315 sdinfo->satadrv_event_flags = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10316 sdinfo->satadrv_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10317 SATA_EVNT_CLEAR_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10318 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10319 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10320 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10321 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10322 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10323
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10324 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10325 * Raise the flag indicating that the next sata command could
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10326 * be sent with SATA_CLEAR_DEV_RESET_STATE flag, if no new device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10327 * reset is reported.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10328 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10329 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10330 if ((cportinfo->cport_dev_type & SATA_VALID_DEV_TYPE) != 0 &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10331 SATA_CPORTINFO_DRV_INFO(cportinfo) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10332 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10333 sdinfo->satadrv_event_flags &= ~SATA_EVNT_INPROC_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10334 sdinfo->satadrv_event_flags |= SATA_EVNT_CLEAR_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10335 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10336 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10337 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10338
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10339
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10340 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10341 * Port Link Events processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10342 * Every link established event may involve device reset (due to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10343 * COMRESET signal, equivalent of the hard reset) so arbitrarily
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10344 * set device reset event for an attached device (if any).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10345 * If the port is in SHUTDOWN or FAILED state, ignore link events.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10346 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10347 * The link established event processing varies, depending on the state
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10348 * of the target node, HBA hotplugging capabilities, state of the port.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10349 * If the link is not active, the link established event is ignored.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10350 * If HBA cannot detect device attachment and there is no target node,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10351 * the link established event triggers device attach event processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10352 * Else, link established event triggers device reset event processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10353 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10354 * The link lost event processing varies, depending on a HBA hotplugging
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10355 * capability and the state of the port (link active or not active).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10356 * If the link is active, the lost link event is ignored.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10357 * If HBA cannot detect device removal, the lost link event triggers
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10358 * device detached event processing after link lost timeout.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10359 * Else, the event is ignored.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10360 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10361 * NOTE: Only cports are processed for now, i.e. no port multiplier ports
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10362 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10363 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10364 sata_process_port_link_events(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10365 sata_address_t *saddr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10366 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10367 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10368 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10369 sata_drive_info_t *sdinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10370 int event_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10371 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10372
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10373 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10374 "Processing port %d link event(s)", saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10375
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10376 cportinfo = SATA_CPORT_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10377 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10378 event_flags = cportinfo->cport_event_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10379
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10380 /* Reset event flags first */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10381 cportinfo->cport_event_flags &=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10382 ~(SATA_EVNT_LINK_ESTABLISHED | SATA_EVNT_LINK_LOST);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10383
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10384 /* If the port is in SHUTDOWN or FAILED state, ignore link events. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10385 if ((cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10386 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10387 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10388 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10389 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10390 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10391
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10392 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10393 * For the sanity sake get current port state.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10394 * Set device address only. Other sata_device fields should be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10395 * set by HBA driver.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10396 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10397 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10398 sata_device.satadev_addr = *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10399 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10400 * We have to exit mutex, because the HBA probe port function may
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10401 * block on its own mutex.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10402 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10403 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10404 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10405 (SATA_DIP(sata_hba_inst), &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10406 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10407 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10408 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10409 /* Something went wrong? Fail the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10410 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10411 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10412 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10413 SATA_LOG_D((sata_hba_inst, CE_WARN, "Port %d probing failed",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10414 saddr->cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10415 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10416 * We may want to release device info structure, but
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10417 * it is not necessary.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10418 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10419 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10420 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10421 /* port probed successfully */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10422 cportinfo->cport_state |= SATA_STATE_PROBED | SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10423 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10424 if (event_flags & SATA_EVNT_LINK_ESTABLISHED) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10425
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10426 if ((sata_device.satadev_scr.sstatus &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10427 SATA_PORT_DEVLINK_UP_MASK) != SATA_PORT_DEVLINK_UP) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10428 /* Ignore event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10429 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10430 "Ignoring port %d link established event - "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10431 "link down",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10432 saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10433 goto linklost;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10434 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10435
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10436 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10437 "Processing port %d link established event",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10438 saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10439
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10440 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10441 * For the sanity sake check if a device is attached - check
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10442 * return state of a port probing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10443 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10444 if (sata_device.satadev_type != SATA_DTYPE_NONE &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10445 sata_device.satadev_type != SATA_DTYPE_PMULT) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10446 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10447 * HBA port probe indicated that there is a device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10448 * attached. Check if the framework had device info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10449 * structure attached for this device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10450 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10451 if (cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10452 ASSERT(SATA_CPORTINFO_DRV_INFO(cportinfo) !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10453 NULL);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10454
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10455 sdinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10456 if ((sdinfo->satadrv_type &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10457 SATA_VALID_DEV_TYPE) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10458 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10459 * Dev info structure is present.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10460 * If dev_type is set to known type in
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10461 * the framework's drive info struct
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10462 * then the device existed before and
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10463 * the link was probably lost
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10464 * momentarily - in such case
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10465 * we may want to check device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10466 * identity.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10467 * Identity check is not supported now.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10468 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10469 * Link established event
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10470 * triggers device reset event.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10471 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10472 (SATA_CPORTINFO_DRV_INFO(cportinfo))->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10473 satadrv_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10474 SATA_EVNT_DEVICE_RESET;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10475 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10476 } else if (cportinfo->cport_dev_type ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10477 SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10478 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10479 * We got new device attached! If HBA does not
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10480 * generate device attached events, trigger it
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10481 * here.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10482 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10483 if (!(SATA_FEATURES(sata_hba_inst) &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10484 SATA_CTLF_HOTPLUG)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10485 cportinfo->cport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10486 SATA_EVNT_DEVICE_ATTACHED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10487 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10488 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10489 /* Reset link lost timeout */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10490 cportinfo->cport_link_lost_time = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10491 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10492 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10493 linklost:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10494 if (event_flags & SATA_EVNT_LINK_LOST) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10495 if ((sata_device.satadev_scr.sstatus &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10496 SATA_PORT_DEVLINK_UP_MASK) == SATA_PORT_DEVLINK_UP) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10497 /* Ignore event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10498 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10499 "Ignoring port %d link lost event - link is up",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10500 saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10501 goto done;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10502 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10503 #ifdef SATA_DEBUG
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10504 if (cportinfo->cport_link_lost_time == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10505 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10506 "Processing port %d link lost event",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10507 saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10508 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10509 #endif
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10510 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10511 * When HBA cannot generate device attached/detached events,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10512 * we need to track link lost time and eventually generate
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10513 * device detach event.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10514 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10515 if (!(SATA_FEATURES(sata_hba_inst) & SATA_CTLF_HOTPLUG)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10516 /* We are tracking link lost time */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10517 if (cportinfo->cport_link_lost_time == 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10518 /* save current time (lbolt value) */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10519 cportinfo->cport_link_lost_time =
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10520 ddi_get_lbolt();
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10521 /* just keep link lost event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10522 cportinfo->cport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10523 SATA_EVNT_LINK_LOST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10524 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10525 clock_t cur_time = ddi_get_lbolt();
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10526 if ((cur_time -
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10527 cportinfo->cport_link_lost_time) >=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10528 drv_usectohz(
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10529 SATA_EVNT_LINK_LOST_TIMEOUT)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10530 /* trigger device detach event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10531 cportinfo->cport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10532 SATA_EVNT_DEVICE_DETACHED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10533 cportinfo->cport_link_lost_time = 0;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10534 SATADBG1(SATA_DBG_EVENTS,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10535 sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10536 "Triggering port %d "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10537 "device detached event",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10538 saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10539 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10540 /* keep link lost event */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10541 cportinfo->cport_event_flags |=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10542 SATA_EVNT_LINK_LOST;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10543 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10544 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10545 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10546 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10547 * We could change port state to disable/delay access to
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10548 * the attached device until the link is recovered.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10549 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10550 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10551 done:
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10552 event_flags = cportinfo->cport_event_flags;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10553 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10554 if (event_flags != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10555 mutex_enter(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10556 sata_hba_inst->satahba_event_flags |= SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10557 mutex_exit(&sata_hba_inst->satahba_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10558 mutex_enter(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10559 sata_event_pending |= SATA_EVNT_MAIN;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10560 mutex_exit(&sata_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10561 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10562 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10563
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10564 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10565 * Device Detached Event processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10566 * Port is probed to find if a device is really gone. If so,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10567 * the device info structure is detached from the SATA port info structure
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10568 * and released.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10569 * Port status is updated.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10570 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10571 * NOTE: Process cports event only, no port multiplier ports.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10572 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10573 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10574 sata_process_device_detached(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10575 sata_address_t *saddr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10576 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10577 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10578 sata_drive_info_t *sdevinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10579 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10580 dev_info_t *tdip;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10581 int rval;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10582
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10583 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10584 "Processing port %d device detached", saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10585
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10586 cportinfo = SATA_CPORT_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10587 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10588 /* Clear event flag */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10589 cportinfo->cport_event_flags &= ~SATA_EVNT_DEVICE_DETACHED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10590
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10591 /* If the port is in SHUTDOWN or FAILED state, ignore detach event. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10592 if ((cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10593 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10594 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10595 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10596 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10597 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10598 /* For sanity, re-probe the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10599 sata_device.satadev_rev = SATA_DEVICE_REV;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10600 sata_device.satadev_addr = *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10601
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10602 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10603 * We have to exit mutex, because the HBA probe port function may
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10604 * block on its own mutex.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10605 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10606 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10607 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10608 (SATA_DIP(sata_hba_inst), &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10609 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10610 sata_update_port_info(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10611 if (rval != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10612 /* Something went wrong? Fail the port */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10613 cportinfo->cport_state = SATA_PSTATE_FAILED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10614 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10615 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10616 SATA_LOG_D((sata_hba_inst, CE_WARN, "Port %d probing failed",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10617 saddr->cport));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10618 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10619 * We may want to release device info structure, but
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10620 * it is not necessary.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10621 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10622 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10623 } else {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10624 /* port probed successfully */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10625 cportinfo->cport_state |= SATA_STATE_PROBED | SATA_STATE_READY;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10626 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10627 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10628 * Check if a device is still attached. For sanity, check also
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10629 * link status - if no link, there is no device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10630 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10631 if ((sata_device.satadev_scr.sstatus & SATA_PORT_DEVLINK_UP_MASK) ==
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10632 SATA_PORT_DEVLINK_UP && sata_device.satadev_type !=
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10633 SATA_DTYPE_NONE) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10634 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10635 * Device is still attached - ignore detach event.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10636 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10637 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10638 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10639 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10640 "Ignoring detach - device still attached to port %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10641 sata_device.satadev_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10642 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10643 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10644 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10645 * We need to detach and release device info structure here
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10646 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10647 if (SATA_CPORTINFO_DRV_INFO(cportinfo) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10648 sdevinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10649 SATA_CPORTINFO_DRV_INFO(cportinfo) = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10650 (void) kmem_free((void *)sdevinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10651 sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10652 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10653 cportinfo->cport_dev_type = SATA_DTYPE_NONE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10654 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10655 * Device cannot be reached anymore, even if the target node may be
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10656 * still present.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10657 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10658
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10659 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10660 sata_log(sata_hba_inst, CE_WARN, "SATA device detached at port %d",
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10661 sata_device.satadev_addr.cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10662
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10663 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10664 * Try to offline a device and remove target node if it still exists
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10665 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10666 tdip = sata_get_target_dip(SATA_DIP(sata_hba_inst), saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10667 if (tdip != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10668 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10669 * target node exist - unconfigure device first, then remove
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10670 * the node
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10671 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10672 if (ndi_devi_offline(tdip, NDI_UNCONFIG) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10673 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10674 * PROBLEM - no device, but target node remained
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10675 * This happens when the file was open or node was
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10676 * waiting for resources.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10677 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10678 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10679 "sata_process_device_detached: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10680 "Failed to unconfigure removed device."));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10681 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10682 if (ndi_devi_offline(tdip, NDI_DEVI_REMOVE) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10683 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10684 * PROBLEM - no device, but target node remained
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10685 * This happens when the file was open or node was
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10686 * waiting for resources.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10687 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10688 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10689 "sata_process_device_detached: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10690 "Failed to remove target node for "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10691 "removed device."));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10692 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10693 }
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10694 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10695 * Generate sysevent - EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10696 * with the hint: SE_HINT_REMOVE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10697 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10698 sata_gen_sysevent(sata_hba_inst, saddr, SE_HINT_REMOVE);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10699 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10700
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10701
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10702 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10703 * Device Attached Event processing.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10704 * Port state is checked to verify that a device is really attached. If so,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10705 * the device info structure is created and attached to the SATA port info
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10706 * structure.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10707 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10708 * This function cannot be called in interrupt context (it may sleep).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10709 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10710 * NOTE: Process cports event only, no port multiplier ports.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10711 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10712 static void
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10713 sata_process_device_attached(sata_hba_inst_t *sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10714 sata_address_t *saddr)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10715 {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10716 sata_cport_info_t *cportinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10717 sata_drive_info_t *sdevinfo;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10718 sata_device_t sata_device;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10719 dev_info_t *tdip;
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10720 int rval;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10721
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10722 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10723 "Processing port %d device attached", saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10724
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10725 cportinfo = SATA_CPORT_INFO(sata_hba_inst, saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10726 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10727
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10728 /* Clear event flag first */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10729 cportinfo->cport_event_flags &= ~SATA_EVNT_DEVICE_ATTACHED;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10730 /* If the port is in SHUTDOWN or FAILED state, ignore event. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10731 if ((cportinfo->cport_state &
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10732 (SATA_PSTATE_SHUTDOWN | SATA_PSTATE_FAILED)) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10733 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10734 cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10735 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10736 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10737
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10738 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10739 * If the sata_drive_info structure is found attached to the port info,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10740 * something went wrong in the event reporting and processing sequence.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10741 * To recover, arbitrarily release device info structure and issue
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10742 * a warning.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10743 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10744 if (SATA_CPORTINFO_DRV_INFO(cportinfo) != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10745 sdevinfo = SATA_CPORTINFO_DRV_INFO(cportinfo);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10746 SATA_CPORTINFO_DRV_INFO(cportinfo) = NULL;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10747 (void) kmem_free((void *)sdevinfo,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10748 sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10749 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10750 "Arbitrarily detaching old device info."));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10751 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10752 cportinfo->cport_dev_type = SATA_DTYPE_NONE;
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10753
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10754 /* For sanity, re-probe the port */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10755 sata_device.satadev_rev = SATA_DEVICE_REV;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10756 sata_device.satadev_addr = *saddr;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10757
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10758 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10759 * We have to exit mutex, because the HBA probe port function may
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10760 * block on its own mutex.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10761 */
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10762 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10763 rval = (*SATA_PROBE_PORT_FUNC(sata_hba_inst))
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10764 (SATA_DIP(sata_hba_inst), &sata_device);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10765 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10766 sata_update_port_info(sata_hba_inst, &sata_device);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10767 if (rval != SATA_SUCCESS) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10768 /* Something went wrong? Fail the port */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10769 cportinfo->cport_state = SATA_PSTATE_FAILED;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10770 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10771 cport_mutex);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10772 SATA_LOG_D((sata_hba_inst, CE_WARN, "Port %d probing failed",
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10773 saddr->cport));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10774 return;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10775 } else {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10776 /* port probed successfully */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10777 cportinfo->cport_state |= SATA_STATE_PROBED | SATA_STATE_READY;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10778 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10779 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10780 * Check if a device is still attached. For sanity, check also
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10781 * link status - if no link, there is no device.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10782 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10783 if ((sata_device.satadev_scr.sstatus & SATA_PORT_DEVLINK_UP_MASK) !=
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10784 SATA_PORT_DEVLINK_UP || sata_device.satadev_type ==
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10785 SATA_DTYPE_NONE) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10786 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10787 * No device - ignore attach event.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10788 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10789 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10790 cport_mutex);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10791 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10792 "Ignoring attach - no device connected to port %d",
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10793 sata_device.satadev_addr.cport);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10794 return;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10795 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10796
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10797 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10798 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10799 * Generate sysevent - EC_DR / ESC_DR_AP_STATE_CHANGE
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10800 * with the hint: SE_HINT_INSERT
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10801 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10802 sata_gen_sysevent(sata_hba_inst, saddr, SE_HINT_INSERT);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10803
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10804 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10805 * Make sure that there is no target node for that device.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10806 * If so, release it. It should not happen, unless we had problem
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10807 * removing the node when device was detached.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10808 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10809 tdip = sata_get_target_dip(SATA_DIP(sata_hba_inst), saddr->cport);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10810 if (tdip != NULL) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10811
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10812 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10813 "sata_process_device_attached: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10814 "old device target node exists!!!"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10815 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10816 * target node exist - unconfigure device first, then remove
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10817 * the node
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10818 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10819 if (ndi_devi_offline(tdip, NDI_UNCONFIG) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10820 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10821 * PROBLEM - no device, but target node remained
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10822 * This happens when the file was open or node was
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10823 * waiting for resources.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10824 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10825 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10826 "sata_process_device_attached: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10827 "Failed to unconfigure old target node!"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10828 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10829 /* Following call will retry node offlining and removing it */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10830 if (ndi_devi_offline(tdip, NDI_DEVI_REMOVE) != NDI_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10831 /* PROBLEM - no device, but target node remained */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10832 SATA_LOG_D((sata_hba_inst, CE_WARN,
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10833 "sata_process_device_attached: "
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10834 "Failed to remove old target node!"));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10835 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10836 * It is not clear, what should be done here.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10837 * For now, we will not attach a new device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10838 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10839 return;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10840 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10841 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10842
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10843 /*
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10844 * Reprobing port will take care of the creation of the device info
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10845 * structure and determination of the device type.
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10846 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10847 sata_device.satadev_addr = *saddr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10848 (void) sata_reprobe_port(sata_hba_inst, &sata_device);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10849 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10850 * If device was successfully attached, an explicit
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10851 * 'configure' command is needed to configure it.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10852 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10853 mutex_enter(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10854 if ((cportinfo->cport_state & SATA_STATE_READY) &&
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10855 cportinfo->cport_dev_type != SATA_DTYPE_NONE) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10856 sata_log(sata_hba_inst, CE_WARN,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10857 "SATA device attached at port %d", saddr->cport);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10858
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10859 if (SATA_CPORTINFO_DRV_INFO(cportinfo) != NULL) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10860 sata_drive_info_t new_sdinfo;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10861
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10862 /* Log device info data */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10863 new_sdinfo = *(SATA_CPORTINFO_DRV_INFO(cportinfo));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10864 sata_show_drive_info(sata_hba_inst, &new_sdinfo);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10865 }
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10866 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10867 mutex_exit(&SATA_CPORT_INFO(sata_hba_inst, saddr->cport)->cport_mutex);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10868 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10869
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10870
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10871 /*
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10872 * sata_set_drive_featues function compares current device features setting
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10873 * with the saved device features settings and, if there is a difference,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10874 * it restores device features setting to the previously saved state.
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10875 * Device Identify data has to be current.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10876 * At the moment only read ahead and write cache settings are considered.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10877 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10878 * This function cannot be called in the interrupt context (it may sleep).
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10879 *
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10880 * The input argument sdinfo should point to the drive info structure
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10881 * to be updated after features are set.
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10882 *
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10883 * Returns TRUE if successful or there was nothing to do.
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10884 * Returns FALSE if device features cound not be set .
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10885 *
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10886 * Note: This function may fail the port, making it inaccessible.
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10887 * Explicit port disconnect/connect or physical device
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10888 * detach/attach is required to re-evaluate it's state afterwards
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10889 */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10890
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10891 static int
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10892 sata_set_drive_features(sata_hba_inst_t *sata_hba_inst,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10893 sata_drive_info_t *sdinfo, int restore)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10894 {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10895 int rval = SATA_SUCCESS;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10896 sata_drive_info_t new_sdinfo;
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10897 char *finfo = "sata_set_drive_features: cannot";
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10898 char *finfox;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10899 int cache_op;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10900
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10901 bzero(&new_sdinfo, sizeof (sata_drive_info_t));
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10902 new_sdinfo.satadrv_addr = sdinfo->satadrv_addr;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10903 new_sdinfo.satadrv_type = sdinfo->satadrv_type;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10904 if (sata_fetch_device_identify_data(sata_hba_inst, &new_sdinfo) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10905 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10906 * Cannot get device identification - retry later
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10907 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10908 SATA_LOG_D((sata_hba_inst, CE_WARN,
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10909 "%s fetch device identify data\n", finfo));
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10910 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10911 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10912 /* Arbitrarily set UDMA mode */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10913 if (sata_set_udma_mode(sata_hba_inst, &new_sdinfo) != SATA_SUCCESS) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10914 SATA_LOG_D((sata_hba_inst, CE_WARN,
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10915 "%s set UDMA mode\n", finfo));
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10916 return (SATA_FAILURE);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10917 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10918
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10919 if (!(new_sdinfo.satadrv_id.ai_cmdset82 & SATA_LOOK_AHEAD) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10920 !(new_sdinfo.satadrv_id.ai_cmdset82 & SATA_WRITE_CACHE)) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10921 /* None of the features is supported - do nothing */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10922 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10923 "settable features not supported\n", NULL);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10924 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10925 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10926
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10927 if (((new_sdinfo.satadrv_id.ai_features85 & SATA_LOOK_AHEAD) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10928 (sdinfo->satadrv_settings & SATA_DEV_READ_AHEAD)) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10929 ((new_sdinfo.satadrv_id.ai_features85 & SATA_WRITE_CACHE) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10930 (sdinfo->satadrv_settings & SATA_DEV_WRITE_CACHE))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10931 /* Nothing to do */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10932 SATADBG1(SATA_DBG_EVENTS_PROC, sata_hba_inst,
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10933 "no device features to set\n", NULL);
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10934 return (SATA_SUCCESS);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10935 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10936
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10937 finfox = (restore != 0) ? " restore device features" :
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10938 " initialize device features\n";
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10939
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10940 if (!((new_sdinfo.satadrv_id.ai_features85 & SATA_LOOK_AHEAD) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10941 (sdinfo->satadrv_settings & SATA_DEV_READ_AHEAD))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10942 if (sdinfo->satadrv_settings & SATA_DEV_READ_AHEAD)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10943 /* Enable read ahead / read cache */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10944 cache_op = SATAC_SF_ENABLE_READ_AHEAD;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10945 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10946 /* Disable read ahead / read cache */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10947 cache_op = SATAC_SF_DISABLE_READ_AHEAD;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10948
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10949 /* Try to set read cache mode */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10950 if (sata_set_cache_mode(sata_hba_inst, &new_sdinfo,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10951 cache_op) != SATA_SUCCESS) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10952 /* Pkt execution failed */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10953 rval = SATA_FAILURE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10954 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10955 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10956
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10957 if (!((new_sdinfo.satadrv_id.ai_features85 & SATA_WRITE_CACHE) &&
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10958 (sdinfo->satadrv_settings & SATA_DEV_WRITE_CACHE))) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10959 if (sdinfo->satadrv_settings & SATA_DEV_WRITE_CACHE)
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10960 /* Enable write cache */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10961 cache_op = SATAC_SF_ENABLE_WRITE_CACHE;
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10962 else
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10963 /* Disable write cache */
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10964 cache_op = SATAC_SF_DISABLE_WRITE_CACHE;
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10965
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10966 /* Try to set write cache mode */
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10967 if (sata_set_cache_mode(sata_hba_inst, &new_sdinfo,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10968 cache_op) != SATA_SUCCESS) {
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10969 /* Pkt execution failed */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10970 rval = SATA_FAILURE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10971 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10972 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10973
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10974 if (rval == SATA_FAILURE)
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10975 SATA_LOG_D((sata_hba_inst, CE_WARN,
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10976 "%s %s", finfo, finfox));
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10977
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10978 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10979 * We need to fetch Device Identify data again
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10980 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10981 if (sata_fetch_device_identify_data(sata_hba_inst, &new_sdinfo) != 0) {
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10982 /*
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10983 * Cannot get device identification - retry later
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10984 */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10985 SATA_LOG_D((sata_hba_inst, CE_WARN,
1781
1005b1d56b1c 6397649 hotplugging sata disk may disable write and read cache
pawelw
parents: 1675
diff changeset
10986 "%s cannot re-fetch device identify data\n"));
1258
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10987 rval = SATA_FAILURE;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10988 }
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10989 /* Copy device sata info. */
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10990 sdinfo->satadrv_id = new_sdinfo.satadrv_id;
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10991
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10992 return (rval);
9961d7d3ec8c PSARC/2004/779 SATA HBA Framework Support
mlf
parents:
diff changeset
10993 }
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10994
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
10995
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
10996 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
10997 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
10998 * Returns 1 if threshold exceeded, 0 if threshold no exceeded, -1 if
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
10999 * unable to determine.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11000 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11001 * Cannot be called in an interrupt context.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11002 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11003 * Called by sata_build_lsense_page_2f()
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11004 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11005
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11006 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11007 sata_fetch_smart_return_status(sata_hba_inst_t *sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11008 sata_drive_info_t *sdinfo)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11009 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11010 sata_pkt_t *spkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11011 sata_cmd_t *scmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11012 sata_pkt_txlate_t *spx;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11013 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11014
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11015 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11016 spx->txlt_sata_hba_inst = sata_hba_inst;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11017 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11018 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11019 if (spkt == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11020 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11021 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11022 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11023 /* address is needed now */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11024 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11025
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11026
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11027 /* Fill sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11028 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11029 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11030 /* Synchronous mode, no callback */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11031 spkt->satapkt_comp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11032 /* Timeout 30s */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11033 spkt->satapkt_time = sata_default_pkt_time;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11034
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11035 scmd = &spkt->satapkt_cmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11036 scmd->satacmd_flags.sata_special_regs = B_TRUE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11037 scmd->satacmd_flags.sata_data_direction = SATA_DIR_NODATA_XFER;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11038
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11039 /* Set up which registers need to be returned */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11040 scmd->satacmd_flags.sata_copy_out_lba_mid_lsb = B_TRUE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11041 scmd->satacmd_flags.sata_copy_out_lba_high_lsb = B_TRUE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11042
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11043 /* Build SMART_RETURN_STATUS cmd in the sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11044 scmd->satacmd_addr_type = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11045 scmd->satacmd_sec_count_lsb = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11046 scmd->satacmd_lba_low_lsb = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11047 scmd->satacmd_lba_mid_lsb = SMART_MAGIC_VAL_1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11048 scmd->satacmd_lba_high_lsb = SMART_MAGIC_VAL_2;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11049 scmd->satacmd_features_reg = SATA_SMART_RETURN_STATUS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11050 scmd->satacmd_device_reg = 0; /* Always device 0 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11051 scmd->satacmd_cmd_reg = SATAC_SMART;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11052 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11053 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11054
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11055
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11056 /* Send pkt to SATA HBA driver */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11057 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11058 SATA_TRAN_ACCEPTED ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11059 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11060 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11061 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11062 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11063 * Whoops, no SMART RETURN STATUS
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11064 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11065 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11066 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11067 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11068 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11069 if (scmd->satacmd_error_reg & SATA_ERROR_ABORT) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11070 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11071 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11072 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11073 if (scmd->satacmd_status_reg & SATA_STATUS_ERR) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11074 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11075 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11076 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11077 if ((scmd->satacmd_lba_mid_lsb == SMART_MAGIC_VAL_1) &&
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11078 (scmd->satacmd_lba_high_lsb == SMART_MAGIC_VAL_2))
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11079 rval = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11080 else if ((scmd->satacmd_lba_mid_lsb == SMART_MAGIC_VAL_3) &&
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11081 (scmd->satacmd_lba_high_lsb == SMART_MAGIC_VAL_4))
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11082 rval = 1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11083 else {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11084 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11085 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11086 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11087 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11088 fail:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11089 /* Free allocated resources */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11090 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11091 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11092
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11093 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11094 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11095
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11096 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11097 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11098 * Returns 0 if succeeded, -1 otherwise
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11099 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11100 * Cannot be called in an interrupt context.
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11101 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11102 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11103 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11104 sata_fetch_smart_data(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11105 sata_hba_inst_t *sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11106 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11107 struct smart_data *smart_data)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11108 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11109 sata_pkt_t *spkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11110 sata_cmd_t *scmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11111 sata_pkt_txlate_t *spx;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11112 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11113
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11114 #if ! defined(lint)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11115 ASSERT(sizeof (struct smart_data) == 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11116 #endif
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11117
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11118 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11119 spx->txlt_sata_hba_inst = sata_hba_inst;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11120 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11121 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11122 if (spkt == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11123 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11124 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11125 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11126 /* address is needed now */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11127 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11128
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11129
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11130 /* Fill sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11131 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11132 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11133 /* Synchronous mode, no callback */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11134 spkt->satapkt_comp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11135 /* Timeout 30s */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11136 spkt->satapkt_time = sata_default_pkt_time;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11137
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11138 scmd = &spkt->satapkt_cmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11139 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11140
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11141 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11142 * Allocate buffer for SMART data
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11143 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11144 scmd->satacmd_bp = sata_alloc_local_buffer(spx,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11145 sizeof (struct smart_data));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11146 if (scmd->satacmd_bp == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11147 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11148 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11149 SATA_LOG_D((sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11150 "sata_fetch_smart_data: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11151 "cannot allocate buffer"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11152 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11153 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11154
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11155
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11156 /* Build SMART_READ_DATA cmd in the sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11157 scmd->satacmd_addr_type = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11158 scmd->satacmd_sec_count_lsb = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11159 scmd->satacmd_lba_low_lsb = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11160 scmd->satacmd_lba_mid_lsb = SMART_MAGIC_VAL_1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11161 scmd->satacmd_lba_high_lsb = SMART_MAGIC_VAL_2;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11162 scmd->satacmd_features_reg = SATA_SMART_READ_DATA;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11163 scmd->satacmd_device_reg = 0; /* Always device 0 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11164 scmd->satacmd_cmd_reg = SATAC_SMART;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11165 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11166 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11167
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11168 /* Send pkt to SATA HBA driver */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11169 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11170 SATA_TRAN_ACCEPTED ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11171 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11172 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11173 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11174 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11175 * Whoops, no SMART DATA available
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11176 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11177 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11178 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11179 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11180 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11181 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11182 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11183 DDI_DMA_SYNC_FORKERNEL);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11184 if (rval != DDI_SUCCESS) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11185 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11186 "sata_fetch_smart_data: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11187 "sync pkt failed"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11188 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11189 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11190 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11191 bcopy(scmd->satacmd_bp->b_un.b_addr, (uint8_t *)smart_data,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11192 sizeof (struct smart_data));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11193 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11194
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11195 fail:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11196 /* Free allocated resources */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11197 sata_free_local_buffer(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11198 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11199 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11200 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11201
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11202 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11203 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11204
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11205 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11206 * Used by LOG SENSE page 0x10
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11207 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11208 * return 0 for success, -1 otherwise
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11209 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11210 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11211 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11212 sata_ext_smart_selftest_read_log(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11213 sata_hba_inst_t *sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11214 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11215 struct smart_ext_selftest_log *ext_selftest_log,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11216 uint16_t block_num)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11217 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11218 sata_pkt_txlate_t *spx;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11219 sata_pkt_t *spkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11220 sata_cmd_t *scmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11221 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11222
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11223 #if ! defined(lint)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11224 ASSERT(sizeof (struct smart_ext_selftest_log) == 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11225 #endif
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11226
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11227 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11228 spx->txlt_sata_hba_inst = sata_hba_inst;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11229 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11230 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11231 if (spkt == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11232 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11233 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11234 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11235 /* address is needed now */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11236 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11237
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11238
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11239 /* Fill sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11240 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11241 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11242 /* Synchronous mode, no callback */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11243 spkt->satapkt_comp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11244 /* Timeout 30s */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11245 spkt->satapkt_time = sata_default_pkt_time;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11246
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11247 scmd = &spkt->satapkt_cmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11248 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11249
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11250 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11251 * Allocate buffer for SMART extended self-test log
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11252 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11253 scmd->satacmd_bp = sata_alloc_local_buffer(spx,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11254 sizeof (struct smart_ext_selftest_log));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11255 if (scmd->satacmd_bp == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11256 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11257 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11258 SATA_LOG_D((sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11259 "sata_ext_smart_selftest_log: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11260 "cannot allocate buffer"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11261 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11262 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11263
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11264 /* Build READ LOG EXT w/ extended self-test log cmd in the sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11265 scmd->satacmd_addr_type = ATA_ADDR_LBA48;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11266 scmd->satacmd_sec_count_lsb = 1; /* One sector of selftest log */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11267 scmd->satacmd_sec_count_msb = 0; /* One sector of selftest log */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11268 scmd->satacmd_lba_low_lsb = EXT_SMART_SELFTEST_LOG_PAGE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11269 scmd->satacmd_lba_low_msb = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11270 scmd->satacmd_lba_mid_lsb = block_num & 0xff;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11271 scmd->satacmd_lba_mid_msb = block_num >> 8;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11272 scmd->satacmd_device_reg = 0; /* Always device 0 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11273 scmd->satacmd_cmd_reg = SATAC_READ_LOG_EXT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11274
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11275 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11276 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11277
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11278 /* Send pkt to SATA HBA driver */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11279 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11280 SATA_TRAN_ACCEPTED ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11281 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11282 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11283 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11284
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11285 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11286 * Whoops, no SMART selftest log info available
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11287 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11288 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11289 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11290 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11291 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11292 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11293
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11294 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11295 DDI_DMA_SYNC_FORKERNEL);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11296 if (rval != DDI_SUCCESS) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11297 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11298 "sata_ext_smart_selftest_log: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11299 "sync pkt failed"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11300 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11301 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11302 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11303 bcopy(scmd->satacmd_bp->b_un.b_addr,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11304 (uint8_t *)ext_selftest_log,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11305 sizeof (struct smart_ext_selftest_log));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11306 rval = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11307 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11308
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11309 fail:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11310 /* Free allocated resources */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11311 sata_free_local_buffer(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11312 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11313 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11314 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11315
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11316 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11317 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11318
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11319 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11320 * Returns 0 for success, -1 otherwise
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11321 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11322 * SMART self-test log data is returned in buffer pointed to by selftest_log
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11323 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11324 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11325 sata_smart_selftest_log(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11326 sata_hba_inst_t *sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11327 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11328 struct smart_selftest_log *selftest_log)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11329 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11330 sata_pkt_t *spkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11331 sata_cmd_t *scmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11332 sata_pkt_txlate_t *spx;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11333 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11334
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11335 #if ! defined(lint)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11336 ASSERT(sizeof (struct smart_selftest_log) == 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11337 #endif
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11338
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11339 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11340 spx->txlt_sata_hba_inst = sata_hba_inst;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11341 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11342 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11343 if (spkt == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11344 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11345 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11346 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11347 /* address is needed now */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11348 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11349
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11350
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11351 /* Fill sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11352 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11353 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11354 /* Synchronous mode, no callback */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11355 spkt->satapkt_comp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11356 /* Timeout 30s */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11357 spkt->satapkt_time = sata_default_pkt_time;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11358
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11359 scmd = &spkt->satapkt_cmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11360 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11361
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11362 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11363 * Allocate buffer for Identify Data return data
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11364 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11365 scmd->satacmd_bp = sata_alloc_local_buffer(spx,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11366 sizeof (struct smart_selftest_log));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11367 if (scmd->satacmd_bp == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11368 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11369 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11370 SATA_LOG_D((sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11371 "sata_smart_selftest_log: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11372 "cannot allocate buffer"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11373 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11374 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11375
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11376 /* Build SMART_READ_DATA cmd in the sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11377 scmd->satacmd_addr_type = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11378 scmd->satacmd_sec_count_lsb = 1; /* One sector of SMART log */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11379 scmd->satacmd_lba_low_lsb = SMART_SELFTEST_LOG_PAGE;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11380 scmd->satacmd_lba_mid_lsb = SMART_MAGIC_VAL_1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11381 scmd->satacmd_lba_high_lsb = SMART_MAGIC_VAL_2;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11382 scmd->satacmd_features_reg = SATA_SMART_READ_LOG;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11383 scmd->satacmd_device_reg = 0; /* Always device 0 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11384 scmd->satacmd_cmd_reg = SATAC_SMART;
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11385 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11386 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11387
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11388 /* Send pkt to SATA HBA driver */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11389 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11390 SATA_TRAN_ACCEPTED ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11391 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11392 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11393 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11394 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11395 * Whoops, no SMART DATA available
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11396 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11397 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11398 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11399 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11400 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11401 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11402 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11403 DDI_DMA_SYNC_FORKERNEL);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11404 if (rval != DDI_SUCCESS) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11405 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11406 "sata_smart_selftest_log: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11407 "sync pkt failed"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11408 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11409 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11410 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11411 bcopy(scmd->satacmd_bp->b_un.b_addr, (uint8_t *)selftest_log,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11412 sizeof (struct smart_selftest_log));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11413 rval = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11414 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11415
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11416 fail:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11417 /* Free allocated resources */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11418 sata_free_local_buffer(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11419 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11420 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11421 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11422
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11423 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11424 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11425
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11426
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11427 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11428 * Returns 0 for success, -1 otherwise
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11429 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11430 * SMART READ LOG data is returned in buffer pointed to by smart_log
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11431 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11432 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11433 sata_smart_read_log(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11434 sata_hba_inst_t *sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11435 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11436 uint8_t *smart_log, /* where the data should be returned */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11437 uint8_t which_log, /* which log should be returned */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11438 uint8_t log_size) /* # of 512 bytes in log */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11439 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11440 sata_pkt_t *spkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11441 sata_cmd_t *scmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11442 sata_pkt_txlate_t *spx;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11443 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11444
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11445 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11446 spx->txlt_sata_hba_inst = sata_hba_inst;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11447 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11448 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11449 if (spkt == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11450 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11451 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11452 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11453 /* address is needed now */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11454 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11455
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11456
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11457 /* Fill sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11458 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11459 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11460 /* Synchronous mode, no callback */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11461 spkt->satapkt_comp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11462 /* Timeout 30s */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11463 spkt->satapkt_time = sata_default_pkt_time;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11464
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11465 scmd = &spkt->satapkt_cmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11466 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11467
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11468 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11469 * Allocate buffer for SMART READ LOG
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11470 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11471 scmd->satacmd_bp = sata_alloc_local_buffer(spx, log_size * 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11472 if (scmd->satacmd_bp == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11473 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11474 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11475 SATA_LOG_D((sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11476 "sata_smart_read_log: " "cannot allocate buffer"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11477 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11478 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11479
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11480 /* Build SMART_READ_DATA cmd in the sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11481 scmd->satacmd_addr_type = 0; /* N/A */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11482 scmd->satacmd_sec_count_lsb = log_size; /* what the caller asked for */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11483 scmd->satacmd_lba_low_lsb = which_log; /* which log page */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11484 scmd->satacmd_lba_mid_lsb = SMART_MAGIC_VAL_1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11485 scmd->satacmd_lba_high_lsb = SMART_MAGIC_VAL_2;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11486 scmd->satacmd_features_reg = SATA_SMART_READ_LOG;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11487 scmd->satacmd_device_reg = 0; /* Always device 0 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11488 scmd->satacmd_cmd_reg = SATAC_SMART;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11489
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11490 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11491 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11492
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11493 /* Send pkt to SATA HBA driver */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11494 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11495 SATA_TRAN_ACCEPTED ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11496 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11497 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11498 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11499
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11500 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11501 * Whoops, no SMART DATA available
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11502 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11503 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11504 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11505 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11506 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11507 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11508
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11509 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11510 DDI_DMA_SYNC_FORKERNEL);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11511 if (rval != DDI_SUCCESS) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11512 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11513 "sata_smart_read_log: " "sync pkt failed"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11514 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11515 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11516 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11517 bcopy(scmd->satacmd_bp->b_un.b_addr, smart_log, log_size * 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11518 rval = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11519 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11520
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11521 fail:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11522 /* Free allocated resources */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11523 sata_free_local_buffer(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11524 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11525 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11526 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11527
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11528 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11529 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11530
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11531 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11532 * Used by LOG SENSE page 0x10
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11533 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11534 * return 0 for success, -1 otherwise
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11535 *
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11536 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11537 static int
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11538 sata_read_log_ext_directory(
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11539 sata_hba_inst_t *sata_hba_inst,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11540 sata_drive_info_t *sdinfo,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11541 struct read_log_ext_directory *logdir)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11542 {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11543 sata_pkt_txlate_t *spx;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11544 sata_pkt_t *spkt;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11545 sata_cmd_t *scmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11546 int rval;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11547
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11548 #if ! defined(lint)
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11549 ASSERT(sizeof (struct read_log_ext_directory) == 512);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11550 #endif
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11551
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11552 spx = kmem_zalloc(sizeof (sata_pkt_txlate_t), KM_SLEEP);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11553 spx->txlt_sata_hba_inst = sata_hba_inst;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11554 spx->txlt_scsi_pkt = NULL; /* No scsi pkt involved */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11555 spkt = sata_pkt_alloc(spx, SLEEP_FUNC);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11556 if (spkt == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11557 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11558 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11559 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11560
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11561 /* Fill sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11562 spkt->satapkt_device.satadev_addr = sdinfo->satadrv_addr;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11563 spkt->satapkt_op_mode = SATA_OPMODE_SYNCH | SATA_OPMODE_INTERRUPTS;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11564 /* Synchronous mode, no callback */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11565 spkt->satapkt_comp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11566 /* Timeout 30s */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11567 spkt->satapkt_time = sata_default_pkt_time;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11568
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11569 scmd = &spkt->satapkt_cmd;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11570 scmd->satacmd_flags.sata_data_direction = SATA_DIR_READ;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11571
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11572 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11573 * Allocate buffer for SMART extended self-test log
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11574 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11575 scmd->satacmd_bp = sata_alloc_local_buffer(spx,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11576 sizeof (struct read_log_ext_directory));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11577 if (scmd->satacmd_bp == NULL) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11578 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11579 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11580 SATA_LOG_D((sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11581 "sata_read_log_ext_directory: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11582 "cannot allocate buffer"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11583 return (-1);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11584 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11585
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11586 /* Build READ LOG EXT w/ extended self-test log cmd in the sata_pkt */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11587 scmd->satacmd_addr_type = ATA_ADDR_LBA48;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11588 scmd->satacmd_sec_count_lsb = 1; /* One sector of directory */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11589 scmd->satacmd_sec_count_msb = 0; /* One sector of directory */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11590 scmd->satacmd_lba_low_lsb = READ_LOG_EXT_LOG_DIRECTORY;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11591 scmd->satacmd_lba_low_msb = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11592 scmd->satacmd_lba_mid_lsb = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11593 scmd->satacmd_lba_mid_msb = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11594 scmd->satacmd_device_reg = 0; /* Always device 0 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11595 scmd->satacmd_cmd_reg = SATAC_READ_LOG_EXT;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11596
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11597 mutex_exit(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11598 sdinfo->satadrv_addr.cport)));
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11599
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11600 /* Send pkt to SATA HBA driver */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11601 if ((*SATA_START_FUNC(sata_hba_inst))(SATA_DIP(sata_hba_inst), spkt) !=
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11602 SATA_TRAN_ACCEPTED ||
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11603 spkt->satapkt_reason != SATA_PKT_COMPLETED) {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11604 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11605 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11606 /*
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11607 * Whoops, no SMART selftest log info available
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11608 */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11609 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11610 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11611 } else {
1940
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11612 mutex_enter(&(SATA_CPORT_MUTEX(sata_hba_inst,
c302ad4d1aa7 6404894 Informational exceptions log parameter should be 4 bytes
ls24207
parents: 1781
diff changeset
11613 sdinfo->satadrv_addr.cport)));
1612
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11614 rval = ddi_dma_sync(spx->txlt_buf_dma_handle, 0, 0,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11615 DDI_DMA_SYNC_FORKERNEL);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11616 if (rval != DDI_SUCCESS) {
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11617 SATA_LOG_D((spx->txlt_sata_hba_inst, CE_WARN,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11618 "sata_read_log_ext_directory: "
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11619 "sync pkt failed"));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11620 rval = -1;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11621 goto fail;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11622 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11623 bcopy(scmd->satacmd_bp->b_un.b_addr, (uint8_t *)logdir,
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11624 sizeof (struct read_log_ext_directory));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11625 rval = 0;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11626 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11627
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11628 fail:
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11629 /* Free allocated resources */
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11630 sata_free_local_buffer(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11631 spx->txlt_sata_pkt->satapkt_cmd.satacmd_bp = NULL;
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11632 sata_pkt_free(spx);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11633 kmem_free(spx, sizeof (sata_pkt_txlate_t));
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11634
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11635 return (rval);
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11636 }
f22bd5bc2aff 6369698 sata framework needs to support SCSI LOG SENSE command
ls24207
parents: 1529
diff changeset
11637
1529
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11638 static void
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11639 sata_gen_sysevent(sata_hba_inst_t *sata_hba_inst, sata_address_t *saddr,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11640 int hint)
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11641 {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11642 char ap[MAXPATHLEN];
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11643 nvlist_t *ev_attr_list = NULL;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11644 int err;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11645
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11646 /* Allocate and build sysevent attribute list */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11647 err = nvlist_alloc(&ev_attr_list, NV_UNIQUE_NAME_TYPE, DDI_NOSLEEP);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11648 if (err != 0) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11649 SATA_LOG_D((sata_hba_inst, CE_WARN,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11650 "sata_gen_sysevent: "
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11651 "cannot allocate memory for sysevent attributes\n"));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11652 return;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11653 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11654 /* Add hint attribute */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11655 err = nvlist_add_string(ev_attr_list, DR_HINT, SE_HINT2STR(hint));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11656 if (err != 0) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11657 SATA_LOG_D((sata_hba_inst, CE_WARN,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11658 "sata_gen_sysevent: "
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11659 "failed to add DR_HINT attr for sysevent"));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11660 nvlist_free(ev_attr_list);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11661 return;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11662 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11663 /*
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11664 * Add AP attribute.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11665 * Get controller pathname and convert it into AP pathname by adding
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11666 * a target number.
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11667 */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11668 (void) snprintf(ap, MAXPATHLEN, "/devices");
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11669 (void) ddi_pathname(SATA_DIP(sata_hba_inst), ap + strlen(ap));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11670 (void) snprintf(ap + strlen(ap), MAXPATHLEN - strlen(ap), ":%d",
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11671 SATA_MAKE_AP_NUMBER(saddr->cport, saddr->pmport, saddr->qual));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11672
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11673 err = nvlist_add_string(ev_attr_list, DR_AP_ID, ap);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11674 if (err != 0) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11675 SATA_LOG_D((sata_hba_inst, CE_WARN,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11676 "sata_gen_sysevent: "
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11677 "failed to add DR_AP_ID attr for sysevent"));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11678 nvlist_free(ev_attr_list);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11679 return;
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11680 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11681
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11682 /* Generate/log sysevent */
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11683 err = ddi_log_sysevent(SATA_DIP(sata_hba_inst), DDI_VENDOR_SUNW, EC_DR,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11684 ESC_DR_AP_STATE_CHANGE, ev_attr_list, NULL, DDI_NOSLEEP);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11685 if (err != DDI_SUCCESS) {
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11686 SATA_LOG_D((sata_hba_inst, CE_WARN,
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11687 "sata_gen_sysevent: "
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11688 "cannot log sysevent, err code %x\n", err));
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11689 }
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11690
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11691 nvlist_free(ev_attr_list);
4fa3374f2b9d 6386938 sata framework should generate sysevent when device is plugged or unplugged
pawelw
parents: 1258
diff changeset
11692 }
1675
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11693
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11694 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11695 * sata_xlate_errors() is used to translate (S)ATA error
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11696 * information to SCSI information returned in the SCSI
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11697 * packet.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11698 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11699 static void
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11700 sata_xlate_errors(sata_pkt_txlate_t *spx)
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11701 {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11702 struct scsi_pkt *scsipkt = spx->txlt_scsi_pkt;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11703 struct scsi_extended_sense *sense;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11704
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11705 scsipkt->pkt_reason = CMD_INCOMPLETE;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11706 *scsipkt->pkt_scbp = STATUS_CHECK;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11707 sense = sata_arq_sense(spx);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11708
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11709 switch (spx->txlt_sata_pkt->satapkt_reason) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11710 case SATA_PKT_PORT_ERROR:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11711 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11712 * We have no device data. Assume no data transfered.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11713 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11714 sense->es_key = KEY_HARDWARE_ERROR;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11715 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11716
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11717 case SATA_PKT_DEV_ERROR:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11718 if (spx->txlt_sata_pkt->satapkt_cmd.satacmd_status_reg &
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11719 SATA_STATUS_ERR) {
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11720 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11721 * determine dev error reason from error
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11722 * reg content
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11723 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11724 sata_decode_device_error(spx, sense);
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11725 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11726 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11727 /* No extended sense key - no info available */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11728 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11729
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11730 case SATA_PKT_TIMEOUT:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11731 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11732 * scsipkt->pkt_reason = CMD_TIMEOUT; This causes problems.
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11733 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11734 scsipkt->pkt_reason = CMD_INCOMPLETE;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11735 /* No extended sense key */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11736 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11737
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11738 case SATA_PKT_ABORTED:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11739 scsipkt->pkt_reason = CMD_ABORTED;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11740 /* No extended sense key */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11741 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11742
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11743 case SATA_PKT_RESET:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11744 /*
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11745 * pkt aborted either by an explicit reset request from
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11746 * a host, or due to error recovery
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11747 */
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11748 scsipkt->pkt_reason = CMD_RESET;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11749 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11750
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11751 default:
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11752 scsipkt->pkt_reason = CMD_TRAN_ERR;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11753 break;
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11754 }
5791e75682d0 6397847 sata framework has to support Informational Exception Control page
ls24207
parents: 1612
diff changeset
11755 }