1 /* 2 * Copyright (c) 1997-2007 Kenneth D. Merry 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 3. The name of the author may not be used to endorse or promote products 14 * derived from this software without specific prior written permission. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 */ 28 29 #include <sys/cdefs.h> 30 __FBSDID("$FreeBSD$"); 31 32 #include <sys/ioctl.h> 33 #include <sys/stdint.h> 34 #include <sys/types.h> 35 #include <sys/stat.h> 36 #include <sys/endian.h> 37 #include <sys/sbuf.h> 38 39 #include <stdbool.h> 40 #include <stdio.h> 41 #include <stdlib.h> 42 #include <string.h> 43 #include <unistd.h> 44 #include <inttypes.h> 45 #include <limits.h> 46 #include <fcntl.h> 47 #include <ctype.h> 48 #include <err.h> 49 #include <libutil.h> 50 #include <limits.h> 51 #include <inttypes.h> 52 53 #include <cam/cam.h> 54 #include <cam/cam_debug.h> 55 #include <cam/cam_ccb.h> 56 #include <cam/scsi/scsi_all.h> 57 #include <cam/scsi/scsi_da.h> 58 #include <cam/scsi/scsi_pass.h> 59 #include <cam/scsi/scsi_message.h> 60 #include <cam/scsi/smp_all.h> 61 #include <cam/ata/ata_all.h> 62 #include <cam/mmc/mmc_all.h> 63 #include <camlib.h> 64 #include "camcontrol.h" 65 #ifdef WITH_NVME 66 #include "nvmecontrol_ext.h" 67 #endif 68 69 typedef enum { 70 CAM_CMD_NONE, 71 CAM_CMD_DEVLIST, 72 CAM_CMD_TUR, 73 CAM_CMD_INQUIRY, 74 CAM_CMD_STARTSTOP, 75 CAM_CMD_RESCAN, 76 CAM_CMD_READ_DEFECTS, 77 CAM_CMD_MODE_PAGE, 78 CAM_CMD_SCSI_CMD, 79 CAM_CMD_DEVTREE, 80 CAM_CMD_USAGE, 81 CAM_CMD_DEBUG, 82 CAM_CMD_RESET, 83 CAM_CMD_FORMAT, 84 CAM_CMD_TAG, 85 CAM_CMD_RATE, 86 CAM_CMD_DETACH, 87 CAM_CMD_REPORTLUNS, 88 CAM_CMD_READCAP, 89 CAM_CMD_IDENTIFY, 90 CAM_CMD_IDLE, 91 CAM_CMD_STANDBY, 92 CAM_CMD_SLEEP, 93 CAM_CMD_SMP_CMD, 94 CAM_CMD_SMP_RG, 95 CAM_CMD_SMP_PC, 96 CAM_CMD_SMP_PHYLIST, 97 CAM_CMD_SMP_MANINFO, 98 CAM_CMD_DOWNLOAD_FW, 99 CAM_CMD_SECURITY, 100 CAM_CMD_HPA, 101 CAM_CMD_SANITIZE, 102 CAM_CMD_PERSIST, 103 CAM_CMD_APM, 104 CAM_CMD_AAM, 105 CAM_CMD_ATTRIB, 106 CAM_CMD_OPCODES, 107 CAM_CMD_REPROBE, 108 CAM_CMD_ZONE, 109 CAM_CMD_EPC, 110 CAM_CMD_TIMESTAMP, 111 CAM_CMD_MMCSD_CMD, 112 CAM_CMD_POWER_MODE, 113 CAM_CMD_DEVTYPE, 114 CAM_CMD_AMA, 115 CAM_CMD_DEPOP, 116 } cam_cmd; 117 118 typedef enum { 119 CAM_ARG_NONE = 0x00000000, 120 CAM_ARG_VERBOSE = 0x00000001, 121 CAM_ARG_DEVICE = 0x00000002, 122 CAM_ARG_BUS = 0x00000004, 123 CAM_ARG_TARGET = 0x00000008, 124 CAM_ARG_LUN = 0x00000010, 125 CAM_ARG_EJECT = 0x00000020, 126 CAM_ARG_UNIT = 0x00000040, 127 /* unused 0x00000080 */ 128 /* unused 0x00000100 */ 129 /* unused 0x00000200 */ 130 /* unused 0x00000400 */ 131 /* unused 0x00000800 */ 132 CAM_ARG_GET_SERIAL = 0x00001000, 133 CAM_ARG_GET_STDINQ = 0x00002000, 134 CAM_ARG_GET_XFERRATE = 0x00004000, 135 CAM_ARG_INQ_MASK = 0x00007000, 136 /* unused 0x00008000 */ 137 /* unused 0x00010000 */ 138 CAM_ARG_TIMEOUT = 0x00020000, 139 CAM_ARG_CMD_IN = 0x00040000, 140 CAM_ARG_CMD_OUT = 0x00080000, 141 /* unused 0x00100000 */ 142 CAM_ARG_ERR_RECOVER = 0x00200000, 143 CAM_ARG_RETRIES = 0x00400000, 144 CAM_ARG_START_UNIT = 0x00800000, 145 CAM_ARG_DEBUG_INFO = 0x01000000, 146 CAM_ARG_DEBUG_TRACE = 0x02000000, 147 CAM_ARG_DEBUG_SUBTRACE = 0x04000000, 148 CAM_ARG_DEBUG_CDB = 0x08000000, 149 CAM_ARG_DEBUG_XPT = 0x10000000, 150 CAM_ARG_DEBUG_PERIPH = 0x20000000, 151 CAM_ARG_DEBUG_PROBE = 0x40000000, 152 /* unused 0x80000000 */ 153 } cam_argmask; 154 155 struct camcontrol_opts { 156 const char *optname; 157 uint32_t cmdnum; 158 cam_argmask argnum; 159 const char *subopt; 160 }; 161 162 struct ata_set_max_pwd 163 { 164 uint16_t reserved1; 165 uint8_t password[32]; 166 uint16_t reserved2[239]; 167 }; 168 169 static struct scsi_nv task_attrs[] = { 170 { "simple", MSG_SIMPLE_Q_TAG }, 171 { "head", MSG_HEAD_OF_Q_TAG }, 172 { "ordered", MSG_ORDERED_Q_TAG }, 173 { "iwr", MSG_IGN_WIDE_RESIDUE }, 174 { "aca", MSG_ACA_TASK } 175 }; 176 177 static const char scsicmd_opts[] = "a:c:dfi:o:r"; 178 static const char readdefect_opts[] = "f:GPqsS:X"; 179 static const char negotiate_opts[] = "acD:M:O:qR:T:UW:"; 180 static const char smprg_opts[] = "l"; 181 static const char smppc_opts[] = "a:A:d:lm:M:o:p:s:S:T:"; 182 static const char smpphylist_opts[] = "lq"; 183 static char pwd_opt; 184 185 static struct camcontrol_opts option_table[] = { 186 {"tur", CAM_CMD_TUR, CAM_ARG_NONE, NULL}, 187 {"inquiry", CAM_CMD_INQUIRY, CAM_ARG_NONE, "DSR"}, 188 {"identify", CAM_CMD_IDENTIFY, CAM_ARG_NONE, NULL}, 189 {"start", CAM_CMD_STARTSTOP, CAM_ARG_START_UNIT, NULL}, 190 {"stop", CAM_CMD_STARTSTOP, CAM_ARG_NONE, NULL}, 191 {"load", CAM_CMD_STARTSTOP, CAM_ARG_START_UNIT | CAM_ARG_EJECT, NULL}, 192 {"eject", CAM_CMD_STARTSTOP, CAM_ARG_EJECT, NULL}, 193 {"reportluns", CAM_CMD_REPORTLUNS, CAM_ARG_NONE, "clr:"}, 194 {"readcapacity", CAM_CMD_READCAP, CAM_ARG_NONE, "bhHlNqs"}, 195 {"reprobe", CAM_CMD_REPROBE, CAM_ARG_NONE, NULL}, 196 {"rescan", CAM_CMD_RESCAN, CAM_ARG_NONE, NULL}, 197 {"reset", CAM_CMD_RESET, CAM_ARG_NONE, NULL}, 198 {"cmd", CAM_CMD_SCSI_CMD, CAM_ARG_NONE, scsicmd_opts}, 199 {"mmcsdcmd", CAM_CMD_MMCSD_CMD, CAM_ARG_NONE, "c:a:F:f:Wb:l:41S:I"}, 200 {"command", CAM_CMD_SCSI_CMD, CAM_ARG_NONE, scsicmd_opts}, 201 {"smpcmd", CAM_CMD_SMP_CMD, CAM_ARG_NONE, "r:R:"}, 202 {"smprg", CAM_CMD_SMP_RG, CAM_ARG_NONE, smprg_opts}, 203 {"smpreportgeneral", CAM_CMD_SMP_RG, CAM_ARG_NONE, smprg_opts}, 204 {"smppc", CAM_CMD_SMP_PC, CAM_ARG_NONE, smppc_opts}, 205 {"smpphycontrol", CAM_CMD_SMP_PC, CAM_ARG_NONE, smppc_opts}, 206 {"smpplist", CAM_CMD_SMP_PHYLIST, CAM_ARG_NONE, smpphylist_opts}, 207 {"smpphylist", CAM_CMD_SMP_PHYLIST, CAM_ARG_NONE, smpphylist_opts}, 208 {"smpmaninfo", CAM_CMD_SMP_MANINFO, CAM_ARG_NONE, "l"}, 209 {"defects", CAM_CMD_READ_DEFECTS, CAM_ARG_NONE, readdefect_opts}, 210 {"defectlist", CAM_CMD_READ_DEFECTS, CAM_ARG_NONE, readdefect_opts}, 211 {"devlist", CAM_CMD_DEVTREE, CAM_ARG_NONE, "-b"}, 212 {"devtype", CAM_CMD_DEVTYPE, CAM_ARG_NONE, ""}, 213 {"periphlist", CAM_CMD_DEVLIST, CAM_ARG_NONE, NULL}, 214 {"modepage", CAM_CMD_MODE_PAGE, CAM_ARG_NONE, "6bdelm:DLP:"}, 215 {"tags", CAM_CMD_TAG, CAM_ARG_NONE, "N:q"}, 216 {"negotiate", CAM_CMD_RATE, CAM_ARG_NONE, negotiate_opts}, 217 {"rate", CAM_CMD_RATE, CAM_ARG_NONE, negotiate_opts}, 218 {"debug", CAM_CMD_DEBUG, CAM_ARG_NONE, "IPTSXcp"}, 219 {"format", CAM_CMD_FORMAT, CAM_ARG_NONE, "qrwy"}, 220 {"sanitize", CAM_CMD_SANITIZE, CAM_ARG_NONE, "a:c:IP:qrUwy"}, 221 {"idle", CAM_CMD_IDLE, CAM_ARG_NONE, "t:"}, 222 {"standby", CAM_CMD_STANDBY, CAM_ARG_NONE, "t:"}, 223 {"sleep", CAM_CMD_SLEEP, CAM_ARG_NONE, ""}, 224 {"powermode", CAM_CMD_POWER_MODE, CAM_ARG_NONE, ""}, 225 {"apm", CAM_CMD_APM, CAM_ARG_NONE, "l:"}, 226 {"aam", CAM_CMD_AAM, CAM_ARG_NONE, "l:"}, 227 {"fwdownload", CAM_CMD_DOWNLOAD_FW, CAM_ARG_NONE, "f:qsy"}, 228 {"security", CAM_CMD_SECURITY, CAM_ARG_NONE, "d:e:fh:k:l:qs:T:U:y"}, 229 {"hpa", CAM_CMD_HPA, CAM_ARG_NONE, "Pflp:qs:U:y"}, 230 {"ama", CAM_CMD_AMA, CAM_ARG_NONE, "fqs:"}, 231 {"persist", CAM_CMD_PERSIST, CAM_ARG_NONE, "ai:I:k:K:o:ps:ST:U"}, 232 {"attrib", CAM_CMD_ATTRIB, CAM_ARG_NONE, "a:ce:F:p:r:s:T:w:V:"}, 233 {"opcodes", CAM_CMD_OPCODES, CAM_ARG_NONE, "No:s:T"}, 234 {"zone", CAM_CMD_ZONE, CAM_ARG_NONE, "ac:l:No:P:"}, 235 {"epc", CAM_CMD_EPC, CAM_ARG_NONE, "c:dDeHp:Pr:sS:T:"}, 236 {"timestamp", CAM_CMD_TIMESTAMP, CAM_ARG_NONE, "f:mrsUT:"}, 237 {"depop", CAM_CMD_DEPOP, CAM_ARG_NONE, "ac:de:ls"}, 238 {"help", CAM_CMD_USAGE, CAM_ARG_NONE, NULL}, 239 {"-?", CAM_CMD_USAGE, CAM_ARG_NONE, NULL}, 240 {"-h", CAM_CMD_USAGE, CAM_ARG_NONE, NULL}, 241 {NULL, 0, 0, NULL} 242 }; 243 244 struct cam_devitem { 245 struct device_match_result dev_match; 246 int num_periphs; 247 struct periph_match_result *periph_matches; 248 struct scsi_vpd_device_id *device_id; 249 int device_id_len; 250 STAILQ_ENTRY(cam_devitem) links; 251 }; 252 253 struct cam_devlist { 254 STAILQ_HEAD(, cam_devitem) dev_queue; 255 path_id_t path_id; 256 }; 257 258 static cam_argmask arglist; 259 260 static const char *devtype_names[] = { 261 "none", 262 "scsi", 263 "satl", 264 "ata", 265 "nvme", 266 "mmcsd", 267 "unknown", 268 }; 269 270 camcontrol_optret getoption(struct camcontrol_opts *table, char *arg, 271 uint32_t *cmdnum, cam_argmask *argnum, 272 const char **subopt); 273 static int getdevlist(struct cam_device *device); 274 static int getdevtree(int argc, char **argv, char *combinedopt); 275 static int getdevtype(struct cam_device *device); 276 static int print_dev_scsi(struct device_match_result *dev_result, char *tmpstr); 277 static int print_dev_ata(struct device_match_result *dev_result, char *tmpstr); 278 static int print_dev_semb(struct device_match_result *dev_result, char *tmpstr); 279 static int print_dev_mmcsd(struct device_match_result *dev_result, 280 char *tmpstr); 281 #ifdef WITH_NVME 282 static int print_dev_nvme(struct device_match_result *dev_result, char *tmpstr); 283 #endif 284 static int testunitready(struct cam_device *device, int task_attr, 285 int retry_count, int timeout, int quiet); 286 static int scsistart(struct cam_device *device, int startstop, int loadeject, 287 int task_attr, int retry_count, int timeout); 288 static int scsiinquiry(struct cam_device *device, int task_attr, 289 int retry_count, int timeout); 290 static int scsiserial(struct cam_device *device, int task_attr, 291 int retry_count, int timeout); 292 static int parse_btl(char *tstr, path_id_t *bus, target_id_t *target, 293 lun_id_t *lun, cam_argmask *arglst); 294 static int reprobe(struct cam_device *device); 295 static int dorescan_or_reset(int argc, char **argv, int rescan); 296 static int rescan_or_reset_bus(path_id_t bus, int rescan); 297 static int scanlun_or_reset_dev(path_id_t bus, target_id_t target, 298 lun_id_t lun, int scan); 299 static int readdefects(struct cam_device *device, int argc, char **argv, 300 char *combinedopt, int task_attr, int retry_count, 301 int timeout); 302 static void modepage(struct cam_device *device, int argc, char **argv, 303 char *combinedopt, int task_attr, int retry_count, 304 int timeout); 305 static int scsicmd(struct cam_device *device, int argc, char **argv, 306 char *combinedopt, int task_attr, int retry_count, 307 int timeout); 308 static int smpcmd(struct cam_device *device, int argc, char **argv, 309 char *combinedopt, int retry_count, int timeout); 310 static int mmcsdcmd(struct cam_device *device, int argc, char **argv, 311 char *combinedopt, int retry_count, int timeout); 312 static int smpreportgeneral(struct cam_device *device, int argc, char **argv, 313 char *combinedopt, int retry_count, int timeout); 314 static int smpphycontrol(struct cam_device *device, int argc, char **argv, 315 char *combinedopt, int retry_count, int timeout); 316 static int smpmaninfo(struct cam_device *device, int argc, char **argv, 317 char *combinedopt, int retry_count, int timeout); 318 static int getdevid(struct cam_devitem *item); 319 static int buildbusdevlist(struct cam_devlist *devlist); 320 static void freebusdevlist(struct cam_devlist *devlist); 321 static struct cam_devitem *findsasdevice(struct cam_devlist *devlist, 322 uint64_t sasaddr); 323 static int smpphylist(struct cam_device *device, int argc, char **argv, 324 char *combinedopt, int retry_count, int timeout); 325 static int tagcontrol(struct cam_device *device, int argc, char **argv, 326 char *combinedopt); 327 static void cts_print(struct cam_device *device, 328 struct ccb_trans_settings *cts); 329 static void cpi_print(struct ccb_pathinq *cpi); 330 static int get_cpi(struct cam_device *device, struct ccb_pathinq *cpi); 331 static int get_cgd(struct cam_device *device, struct ccb_getdev *cgd); 332 static int get_print_cts(struct cam_device *device, int user_settings, 333 int quiet, struct ccb_trans_settings *cts); 334 static int ratecontrol(struct cam_device *device, int task_attr, 335 int retry_count, int timeout, int argc, char **argv, 336 char *combinedopt); 337 static int scsiformat(struct cam_device *device, int argc, char **argv, 338 char *combinedopt, int task_attr, int retry_count, 339 int timeout); 340 static int sanitize(struct cam_device *device, int argc, char **argv, 341 char *combinedopt, int task_attr, int retry_count, 342 int timeout); 343 static int scsireportluns(struct cam_device *device, int argc, char **argv, 344 char *combinedopt, int task_attr, int retry_count, 345 int timeout); 346 static int scsireadcapacity(struct cam_device *device, int argc, char **argv, 347 char *combinedopt, int task_attr, int retry_count, 348 int timeout); 349 static int atapm(struct cam_device *device, int argc, char **argv, 350 char *combinedopt, int retry_count, int timeout); 351 static int atasecurity(struct cam_device *device, int retry_count, int timeout, 352 int argc, char **argv, char *combinedopt); 353 static int atahpa(struct cam_device *device, int retry_count, int timeout, 354 int argc, char **argv, char *combinedopt); 355 static int ataama(struct cam_device *device, int retry_count, int timeout, 356 int argc, char **argv, char *combinedopt); 357 static int scsiprintoneopcode(struct cam_device *device, int req_opcode, 358 int sa_set, int req_sa, uint8_t *buf, 359 uint32_t valid_len); 360 static int scsiprintopcodes(struct cam_device *device, int td_req, uint8_t *buf, 361 uint32_t valid_len); 362 static int scsiopcodes(struct cam_device *device, int argc, char **argv, 363 char *combinedopt, int task_attr, int retry_count, 364 int timeout, int verbose); 365 366 #ifndef min 367 #define min(a,b) (((a)<(b))?(a):(b)) 368 #endif 369 #ifndef max 370 #define max(a,b) (((a)>(b))?(a):(b)) 371 #endif 372 373 camcontrol_optret 374 getoption(struct camcontrol_opts *table, char *arg, uint32_t *cmdnum, 375 cam_argmask *argnum, const char **subopt) 376 { 377 struct camcontrol_opts *opts; 378 int num_matches = 0; 379 380 for (opts = table; (opts != NULL) && (opts->optname != NULL); 381 opts++) { 382 if (strncmp(opts->optname, arg, strlen(arg)) == 0) { 383 *cmdnum = opts->cmdnum; 384 *argnum = opts->argnum; 385 *subopt = opts->subopt; 386 if (++num_matches > 1) 387 return (CC_OR_AMBIGUOUS); 388 } 389 } 390 391 if (num_matches > 0) 392 return (CC_OR_FOUND); 393 else 394 return (CC_OR_NOT_FOUND); 395 } 396 397 static int 398 getdevlist(struct cam_device *device) 399 { 400 union ccb *ccb; 401 char status[32]; 402 int error = 0; 403 404 ccb = cam_getccb(device); 405 406 ccb->ccb_h.func_code = XPT_GDEVLIST; 407 ccb->ccb_h.flags = CAM_DIR_NONE; 408 ccb->ccb_h.retry_count = 1; 409 ccb->cgdl.index = 0; 410 ccb->cgdl.status = CAM_GDEVLIST_MORE_DEVS; 411 while (ccb->cgdl.status == CAM_GDEVLIST_MORE_DEVS) { 412 if (cam_send_ccb(device, ccb) < 0) { 413 warn("error getting device list"); 414 cam_freeccb(ccb); 415 return (1); 416 } 417 418 status[0] = '\0'; 419 420 switch (ccb->cgdl.status) { 421 case CAM_GDEVLIST_MORE_DEVS: 422 strcpy(status, "MORE"); 423 break; 424 case CAM_GDEVLIST_LAST_DEVICE: 425 strcpy(status, "LAST"); 426 break; 427 case CAM_GDEVLIST_LIST_CHANGED: 428 strcpy(status, "CHANGED"); 429 break; 430 case CAM_GDEVLIST_ERROR: 431 strcpy(status, "ERROR"); 432 error = 1; 433 break; 434 } 435 436 fprintf(stdout, "%s%d: generation: %d index: %d status: %s\n", 437 ccb->cgdl.periph_name, 438 ccb->cgdl.unit_number, 439 ccb->cgdl.generation, 440 ccb->cgdl.index, 441 status); 442 443 /* 444 * If the list has changed, we need to start over from the 445 * beginning. 446 */ 447 if (ccb->cgdl.status == CAM_GDEVLIST_LIST_CHANGED) 448 ccb->cgdl.index = 0; 449 } 450 451 cam_freeccb(ccb); 452 453 return (error); 454 } 455 456 static int 457 getdevtree(int argc, char **argv, char *combinedopt) 458 { 459 union ccb ccb; 460 int bufsize, fd; 461 unsigned int i; 462 int need_close = 0; 463 int error = 0; 464 int skip_device = 0; 465 int busonly = 0; 466 int c; 467 468 while ((c = getopt(argc, argv, combinedopt)) != -1) { 469 switch(c) { 470 case 'b': 471 if ((arglist & CAM_ARG_VERBOSE) == 0) 472 busonly = 1; 473 break; 474 default: 475 break; 476 } 477 } 478 479 if ((fd = open(XPT_DEVICE, O_RDWR)) == -1) { 480 warn("couldn't open %s", XPT_DEVICE); 481 return (1); 482 } 483 484 bzero(&ccb, sizeof(union ccb)); 485 486 ccb.ccb_h.path_id = CAM_XPT_PATH_ID; 487 ccb.ccb_h.target_id = CAM_TARGET_WILDCARD; 488 ccb.ccb_h.target_lun = CAM_LUN_WILDCARD; 489 490 ccb.ccb_h.func_code = XPT_DEV_MATCH; 491 bufsize = sizeof(struct dev_match_result) * 100; 492 ccb.cdm.match_buf_len = bufsize; 493 ccb.cdm.matches = (struct dev_match_result *)malloc(bufsize); 494 if (ccb.cdm.matches == NULL) { 495 warnx("can't malloc memory for matches"); 496 close(fd); 497 return (1); 498 } 499 ccb.cdm.num_matches = 0; 500 501 /* 502 * We fetch all nodes, since we display most of them in the default 503 * case, and all in the verbose case. 504 */ 505 ccb.cdm.num_patterns = 0; 506 ccb.cdm.pattern_buf_len = 0; 507 508 /* 509 * We do the ioctl multiple times if necessary, in case there are 510 * more than 100 nodes in the EDT. 511 */ 512 do { 513 if (ioctl(fd, CAMIOCOMMAND, &ccb) == -1) { 514 warn("error sending CAMIOCOMMAND ioctl"); 515 error = 1; 516 break; 517 } 518 519 if ((ccb.ccb_h.status != CAM_REQ_CMP) 520 || ((ccb.cdm.status != CAM_DEV_MATCH_LAST) 521 && (ccb.cdm.status != CAM_DEV_MATCH_MORE))) { 522 warnx("got CAM error %#x, CDM error %d\n", 523 ccb.ccb_h.status, ccb.cdm.status); 524 error = 1; 525 break; 526 } 527 528 for (i = 0; i < ccb.cdm.num_matches; i++) { 529 switch (ccb.cdm.matches[i].type) { 530 case DEV_MATCH_BUS: { 531 struct bus_match_result *bus_result; 532 533 /* 534 * Only print the bus information if the 535 * user turns on the verbose flag. 536 */ 537 if ((busonly == 0) && 538 (arglist & CAM_ARG_VERBOSE) == 0) 539 break; 540 541 bus_result = 542 &ccb.cdm.matches[i].result.bus_result; 543 544 if (need_close) { 545 fprintf(stdout, ")\n"); 546 need_close = 0; 547 } 548 549 fprintf(stdout, "scbus%d on %s%d bus %d%s\n", 550 bus_result->path_id, 551 bus_result->dev_name, 552 bus_result->unit_number, 553 bus_result->bus_id, 554 (busonly ? "" : ":")); 555 break; 556 } 557 case DEV_MATCH_DEVICE: { 558 struct device_match_result *dev_result; 559 char tmpstr[256]; 560 561 if (busonly == 1) 562 break; 563 564 dev_result = 565 &ccb.cdm.matches[i].result.device_result; 566 567 if ((dev_result->flags 568 & DEV_RESULT_UNCONFIGURED) 569 && ((arglist & CAM_ARG_VERBOSE) == 0)) { 570 skip_device = 1; 571 break; 572 } else 573 skip_device = 0; 574 575 if (dev_result->protocol == PROTO_SCSI) { 576 if (print_dev_scsi(dev_result, 577 &tmpstr[0]) != 0) { 578 skip_device = 1; 579 break; 580 } 581 } else if (dev_result->protocol == PROTO_ATA || 582 dev_result->protocol == PROTO_SATAPM) { 583 if (print_dev_ata(dev_result, 584 &tmpstr[0]) != 0) { 585 skip_device = 1; 586 break; 587 } 588 } else if (dev_result->protocol == PROTO_MMCSD){ 589 if (print_dev_mmcsd(dev_result, 590 &tmpstr[0]) != 0) { 591 skip_device = 1; 592 break; 593 } 594 } else if (dev_result->protocol == PROTO_SEMB) { 595 if (print_dev_semb(dev_result, 596 &tmpstr[0]) != 0) { 597 skip_device = 1; 598 break; 599 } 600 #ifdef WITH_NVME 601 } else if (dev_result->protocol == PROTO_NVME) { 602 if (print_dev_nvme(dev_result, 603 &tmpstr[0]) != 0) { 604 skip_device = 1; 605 break; 606 } 607 #endif 608 } else { 609 sprintf(tmpstr, "<>"); 610 } 611 if (need_close) { 612 fprintf(stdout, ")\n"); 613 need_close = 0; 614 } 615 616 fprintf(stdout, "%-33s at scbus%d " 617 "target %d lun %jx (", 618 tmpstr, 619 dev_result->path_id, 620 dev_result->target_id, 621 (uintmax_t)dev_result->target_lun); 622 623 need_close = 1; 624 625 break; 626 } 627 case DEV_MATCH_PERIPH: { 628 struct periph_match_result *periph_result; 629 630 periph_result = 631 &ccb.cdm.matches[i].result.periph_result; 632 633 if (busonly || skip_device != 0) 634 break; 635 636 if (need_close > 1) 637 fprintf(stdout, ","); 638 639 fprintf(stdout, "%s%d", 640 periph_result->periph_name, 641 periph_result->unit_number); 642 643 need_close++; 644 break; 645 } 646 default: 647 fprintf(stdout, "unknown match type\n"); 648 break; 649 } 650 } 651 652 } while ((ccb.ccb_h.status == CAM_REQ_CMP) 653 && (ccb.cdm.status == CAM_DEV_MATCH_MORE)); 654 655 if (need_close) 656 fprintf(stdout, ")\n"); 657 658 close(fd); 659 660 return (error); 661 } 662 663 static int 664 getdevtype(struct cam_device *cam_dev) 665 { 666 camcontrol_devtype dt; 667 int error; 668 669 /* 670 * Get the device type and report it, request no I/O be done to do this. 671 */ 672 error = get_device_type(cam_dev, -1, 0, 0, &dt); 673 if (error != 0 || (unsigned)dt > CC_DT_UNKNOWN) { 674 fprintf(stdout, "illegal\n"); 675 return (1); 676 } 677 fprintf(stdout, "%s\n", devtype_names[dt]); 678 return (0); 679 } 680 681 static int 682 print_dev_scsi(struct device_match_result *dev_result, char *tmpstr) 683 { 684 char vendor[16], product[48], revision[16]; 685 686 cam_strvis(vendor, dev_result->inq_data.vendor, 687 sizeof(dev_result->inq_data.vendor), sizeof(vendor)); 688 cam_strvis(product, dev_result->inq_data.product, 689 sizeof(dev_result->inq_data.product), sizeof(product)); 690 cam_strvis(revision, dev_result->inq_data.revision, 691 sizeof(dev_result->inq_data.revision), sizeof(revision)); 692 sprintf(tmpstr, "<%s %s %s>", vendor, product, revision); 693 694 return (0); 695 } 696 697 static int 698 print_dev_ata(struct device_match_result *dev_result, char *tmpstr) 699 { 700 char product[48], revision[16]; 701 702 cam_strvis(product, dev_result->ident_data.model, 703 sizeof(dev_result->ident_data.model), sizeof(product)); 704 cam_strvis(revision, dev_result->ident_data.revision, 705 sizeof(dev_result->ident_data.revision), sizeof(revision)); 706 sprintf(tmpstr, "<%s %s>", product, revision); 707 708 return (0); 709 } 710 711 static int 712 print_dev_semb(struct device_match_result *dev_result, char *tmpstr) 713 { 714 struct sep_identify_data *sid; 715 char vendor[16], product[48], revision[16], fw[5]; 716 717 sid = (struct sep_identify_data *)&dev_result->ident_data; 718 cam_strvis(vendor, sid->vendor_id, 719 sizeof(sid->vendor_id), sizeof(vendor)); 720 cam_strvis(product, sid->product_id, 721 sizeof(sid->product_id), sizeof(product)); 722 cam_strvis(revision, sid->product_rev, 723 sizeof(sid->product_rev), sizeof(revision)); 724 cam_strvis(fw, sid->firmware_rev, 725 sizeof(sid->firmware_rev), sizeof(fw)); 726 sprintf(tmpstr, "<%s %s %s %s>", vendor, product, revision, fw); 727 728 return (0); 729 } 730 731 static int 732 print_dev_mmcsd(struct device_match_result *dev_result, char *tmpstr) 733 { 734 union ccb *ccb; 735 struct ccb_dev_advinfo *advi; 736 struct cam_device *dev; 737 struct mmc_params mmc_ident_data; 738 739 dev = cam_open_btl(dev_result->path_id, dev_result->target_id, 740 dev_result->target_lun, O_RDWR, NULL); 741 if (dev == NULL) { 742 warnx("%s", cam_errbuf); 743 return (1); 744 } 745 746 ccb = cam_getccb(dev); 747 if (ccb == NULL) { 748 warnx("couldn't allocate CCB"); 749 cam_close_device(dev); 750 return (1); 751 } 752 753 advi = &ccb->cdai; 754 advi->ccb_h.flags = CAM_DIR_IN; 755 advi->ccb_h.func_code = XPT_DEV_ADVINFO; 756 advi->flags = CDAI_FLAG_NONE; 757 advi->buftype = CDAI_TYPE_MMC_PARAMS; 758 advi->bufsiz = sizeof(struct mmc_params); 759 advi->buf = (uint8_t *)&mmc_ident_data; 760 761 if (cam_send_ccb(dev, ccb) < 0) { 762 warn("error sending XPT_DEV_ADVINFO CCB"); 763 cam_freeccb(ccb); 764 cam_close_device(dev); 765 return (1); 766 } 767 768 if (strlen(mmc_ident_data.model) > 0) { 769 sprintf(tmpstr, "<%s>", mmc_ident_data.model); 770 } else { 771 sprintf(tmpstr, "<%s card>", 772 mmc_ident_data.card_features & 773 CARD_FEATURE_SDIO ? "SDIO" : "unknown"); 774 } 775 776 cam_freeccb(ccb); 777 cam_close_device(dev); 778 return (0); 779 } 780 781 #ifdef WITH_NVME 782 static int 783 nvme_get_cdata(struct cam_device *dev, struct nvme_controller_data *cdata) 784 { 785 union ccb *ccb; 786 struct ccb_dev_advinfo *advi; 787 788 ccb = cam_getccb(dev); 789 if (ccb == NULL) { 790 warnx("couldn't allocate CCB"); 791 cam_close_device(dev); 792 return (1); 793 } 794 795 advi = &ccb->cdai; 796 advi->ccb_h.flags = CAM_DIR_IN; 797 advi->ccb_h.func_code = XPT_DEV_ADVINFO; 798 advi->flags = CDAI_FLAG_NONE; 799 advi->buftype = CDAI_TYPE_NVME_CNTRL; 800 advi->bufsiz = sizeof(struct nvme_controller_data); 801 advi->buf = (uint8_t *)cdata; 802 803 if (cam_send_ccb(dev, ccb) < 0) { 804 warn("error sending XPT_DEV_ADVINFO CCB"); 805 cam_freeccb(ccb); 806 cam_close_device(dev); 807 return(1); 808 } 809 if (advi->ccb_h.status != CAM_REQ_CMP) { 810 warnx("got CAM error %#x", advi->ccb_h.status); 811 cam_freeccb(ccb); 812 cam_close_device(dev); 813 return(1); 814 } 815 cam_freeccb(ccb); 816 return 0; 817 } 818 819 static int 820 print_dev_nvme(struct device_match_result *dev_result, char *tmpstr) 821 { 822 struct cam_device *dev; 823 struct nvme_controller_data cdata; 824 char vendor[64], product[64]; 825 826 dev = cam_open_btl(dev_result->path_id, dev_result->target_id, 827 dev_result->target_lun, O_RDWR, NULL); 828 if (dev == NULL) { 829 warnx("%s", cam_errbuf); 830 return (1); 831 } 832 833 if (nvme_get_cdata(dev, &cdata)) 834 return (1); 835 836 cam_strvis(vendor, cdata.mn, sizeof(cdata.mn), sizeof(vendor)); 837 cam_strvis(product, cdata.fr, sizeof(cdata.fr), sizeof(product)); 838 sprintf(tmpstr, "<%s %s>", vendor, product); 839 840 cam_close_device(dev); 841 return (0); 842 } 843 #endif 844 845 static int 846 testunitready(struct cam_device *device, int task_attr, int retry_count, 847 int timeout, int quiet) 848 { 849 int error = 0; 850 union ccb *ccb; 851 852 ccb = cam_getccb(device); 853 854 scsi_test_unit_ready(&ccb->csio, 855 /* retries */ retry_count, 856 /* cbfcnp */ NULL, 857 /* tag_action */ task_attr, 858 /* sense_len */ SSD_FULL_SIZE, 859 /* timeout */ timeout ? timeout : 5000); 860 861 /* Disable freezing the device queue */ 862 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 863 864 if (arglist & CAM_ARG_ERR_RECOVER) 865 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 866 867 if (cam_send_ccb(device, ccb) < 0) { 868 if (quiet == 0) 869 warn("error sending TEST UNIT READY command"); 870 cam_freeccb(ccb); 871 return (1); 872 } 873 874 if ((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP) { 875 if (quiet == 0) 876 fprintf(stdout, "Unit is ready\n"); 877 } else { 878 if (quiet == 0) 879 fprintf(stdout, "Unit is not ready\n"); 880 error = 1; 881 882 if (arglist & CAM_ARG_VERBOSE) { 883 cam_error_print(device, ccb, CAM_ESF_ALL, 884 CAM_EPF_ALL, stderr); 885 } 886 } 887 888 cam_freeccb(ccb); 889 890 return (error); 891 } 892 893 static int 894 scsistart(struct cam_device *device, int startstop, int loadeject, 895 int task_attr, int retry_count, int timeout) 896 { 897 union ccb *ccb; 898 int error = 0; 899 900 ccb = cam_getccb(device); 901 902 /* 903 * If we're stopping, send an ordered tag so the drive in question 904 * will finish any previously queued writes before stopping. If 905 * the device isn't capable of tagged queueing, or if tagged 906 * queueing is turned off, the tag action is a no-op. We override 907 * the default simple tag, although this also has the effect of 908 * overriding the user's wishes if he wanted to specify a simple 909 * tag. 910 */ 911 if ((startstop == 0) 912 && (task_attr == MSG_SIMPLE_Q_TAG)) 913 task_attr = MSG_ORDERED_Q_TAG; 914 915 scsi_start_stop(&ccb->csio, 916 /* retries */ retry_count, 917 /* cbfcnp */ NULL, 918 /* tag_action */ task_attr, 919 /* start/stop */ startstop, 920 /* load_eject */ loadeject, 921 /* immediate */ 0, 922 /* sense_len */ SSD_FULL_SIZE, 923 /* timeout */ timeout ? timeout : 120000); 924 925 /* Disable freezing the device queue */ 926 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 927 928 if (arglist & CAM_ARG_ERR_RECOVER) 929 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 930 931 if (cam_send_ccb(device, ccb) < 0) { 932 warn("error sending START STOP UNIT command"); 933 cam_freeccb(ccb); 934 return (1); 935 } 936 937 if ((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP) 938 if (startstop) { 939 fprintf(stdout, "Unit started successfully"); 940 if (loadeject) 941 fprintf(stdout,", Media loaded\n"); 942 else 943 fprintf(stdout,"\n"); 944 } else { 945 fprintf(stdout, "Unit stopped successfully"); 946 if (loadeject) 947 fprintf(stdout, ", Media ejected\n"); 948 else 949 fprintf(stdout, "\n"); 950 } 951 else { 952 error = 1; 953 if (startstop) 954 fprintf(stdout, 955 "Error received from start unit command\n"); 956 else 957 fprintf(stdout, 958 "Error received from stop unit command\n"); 959 960 if (arglist & CAM_ARG_VERBOSE) { 961 cam_error_print(device, ccb, CAM_ESF_ALL, 962 CAM_EPF_ALL, stderr); 963 } 964 } 965 966 cam_freeccb(ccb); 967 968 return (error); 969 } 970 971 int 972 scsidoinquiry(struct cam_device *device, int argc, char **argv, 973 char *combinedopt, int task_attr, int retry_count, int timeout) 974 { 975 int c; 976 int error = 0; 977 978 while ((c = getopt(argc, argv, combinedopt)) != -1) { 979 switch(c) { 980 case 'D': 981 arglist |= CAM_ARG_GET_STDINQ; 982 break; 983 case 'R': 984 arglist |= CAM_ARG_GET_XFERRATE; 985 break; 986 case 'S': 987 arglist |= CAM_ARG_GET_SERIAL; 988 break; 989 default: 990 break; 991 } 992 } 993 994 /* 995 * If the user didn't specify any inquiry options, he wants all of 996 * them. 997 */ 998 if ((arglist & CAM_ARG_INQ_MASK) == 0) 999 arglist |= CAM_ARG_INQ_MASK; 1000 1001 if (arglist & CAM_ARG_GET_STDINQ) 1002 error = scsiinquiry(device, task_attr, retry_count, timeout); 1003 1004 if (error != 0) 1005 return (error); 1006 1007 if (arglist & CAM_ARG_GET_SERIAL) 1008 scsiserial(device, task_attr, retry_count, timeout); 1009 1010 if (arglist & CAM_ARG_GET_XFERRATE) 1011 error = camxferrate(device); 1012 1013 return (error); 1014 } 1015 1016 static int 1017 scsiinquiry(struct cam_device *device, int task_attr, int retry_count, 1018 int timeout) 1019 { 1020 union ccb *ccb; 1021 struct scsi_inquiry_data *inq_buf; 1022 int error = 0; 1023 1024 ccb = cam_getccb(device); 1025 1026 if (ccb == NULL) { 1027 warnx("couldn't allocate CCB"); 1028 return (1); 1029 } 1030 1031 inq_buf = (struct scsi_inquiry_data *)malloc( 1032 sizeof(struct scsi_inquiry_data)); 1033 1034 if (inq_buf == NULL) { 1035 cam_freeccb(ccb); 1036 warnx("can't malloc memory for inquiry\n"); 1037 return (1); 1038 } 1039 bzero(inq_buf, sizeof(*inq_buf)); 1040 1041 /* 1042 * Note that although the size of the inquiry buffer is the full 1043 * 256 bytes specified in the SCSI spec, we only tell the device 1044 * that we have allocated SHORT_INQUIRY_LENGTH bytes. There are 1045 * two reasons for this: 1046 * 1047 * - The SCSI spec says that when a length field is only 1 byte, 1048 * a value of 0 will be interpreted as 256. Therefore 1049 * scsi_inquiry() will convert an inq_len (which is passed in as 1050 * a uint32_t, but the field in the CDB is only 1 byte) of 256 1051 * to 0. Evidently, very few devices meet the spec in that 1052 * regard. Some devices, like many Seagate disks, take the 0 as 1053 * 0, and don't return any data. One Pioneer DVD-R drive 1054 * returns more data than the command asked for. 1055 * 1056 * So, since there are numerous devices that just don't work 1057 * right with the full inquiry size, we don't send the full size. 1058 * 1059 * - The second reason not to use the full inquiry data length is 1060 * that we don't need it here. The only reason we issue a 1061 * standard inquiry is to get the vendor name, device name, 1062 * and revision so scsi_print_inquiry() can print them. 1063 * 1064 * If, at some point in the future, more inquiry data is needed for 1065 * some reason, this code should use a procedure similar to the 1066 * probe code. i.e., issue a short inquiry, and determine from 1067 * the additional length passed back from the device how much 1068 * inquiry data the device supports. Once the amount the device 1069 * supports is determined, issue an inquiry for that amount and no 1070 * more. 1071 * 1072 * KDM, 2/18/2000 1073 */ 1074 scsi_inquiry(&ccb->csio, 1075 /* retries */ retry_count, 1076 /* cbfcnp */ NULL, 1077 /* tag_action */ task_attr, 1078 /* inq_buf */ (uint8_t *)inq_buf, 1079 /* inq_len */ SHORT_INQUIRY_LENGTH, 1080 /* evpd */ 0, 1081 /* page_code */ 0, 1082 /* sense_len */ SSD_FULL_SIZE, 1083 /* timeout */ timeout ? timeout : 5000); 1084 1085 /* Disable freezing the device queue */ 1086 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 1087 1088 if (arglist & CAM_ARG_ERR_RECOVER) 1089 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 1090 1091 if (cam_send_ccb(device, ccb) < 0) { 1092 warn("error sending INQUIRY command"); 1093 cam_freeccb(ccb); 1094 return (1); 1095 } 1096 1097 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 1098 error = 1; 1099 1100 if (arglist & CAM_ARG_VERBOSE) { 1101 cam_error_print(device, ccb, CAM_ESF_ALL, 1102 CAM_EPF_ALL, stderr); 1103 } 1104 } 1105 1106 cam_freeccb(ccb); 1107 1108 if (error != 0) { 1109 free(inq_buf); 1110 return (error); 1111 } 1112 1113 fprintf(stdout, "%s%d: ", device->device_name, 1114 device->dev_unit_num); 1115 scsi_print_inquiry(inq_buf); 1116 1117 free(inq_buf); 1118 1119 return (0); 1120 } 1121 1122 static int 1123 scsiserial(struct cam_device *device, int task_attr, int retry_count, 1124 int timeout) 1125 { 1126 union ccb *ccb; 1127 struct scsi_vpd_unit_serial_number *serial_buf; 1128 char serial_num[SVPD_SERIAL_NUM_SIZE + 1]; 1129 int error = 0; 1130 1131 ccb = cam_getccb(device); 1132 1133 if (ccb == NULL) { 1134 warnx("couldn't allocate CCB"); 1135 return (1); 1136 } 1137 1138 serial_buf = (struct scsi_vpd_unit_serial_number *) 1139 malloc(sizeof(*serial_buf)); 1140 1141 if (serial_buf == NULL) { 1142 cam_freeccb(ccb); 1143 warnx("can't malloc memory for serial number"); 1144 return (1); 1145 } 1146 1147 scsi_inquiry(&ccb->csio, 1148 /*retries*/ retry_count, 1149 /*cbfcnp*/ NULL, 1150 /* tag_action */ task_attr, 1151 /* inq_buf */ (uint8_t *)serial_buf, 1152 /* inq_len */ sizeof(*serial_buf), 1153 /* evpd */ 1, 1154 /* page_code */ SVPD_UNIT_SERIAL_NUMBER, 1155 /* sense_len */ SSD_FULL_SIZE, 1156 /* timeout */ timeout ? timeout : 5000); 1157 1158 /* Disable freezing the device queue */ 1159 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 1160 1161 if (arglist & CAM_ARG_ERR_RECOVER) 1162 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 1163 1164 if (cam_send_ccb(device, ccb) < 0) { 1165 warn("error sending INQUIRY command"); 1166 cam_freeccb(ccb); 1167 free(serial_buf); 1168 return (1); 1169 } 1170 1171 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 1172 error = 1; 1173 1174 if (arglist & CAM_ARG_VERBOSE) { 1175 cam_error_print(device, ccb, CAM_ESF_ALL, 1176 CAM_EPF_ALL, stderr); 1177 } 1178 } 1179 1180 cam_freeccb(ccb); 1181 1182 if (error != 0) { 1183 free(serial_buf); 1184 return (error); 1185 } 1186 1187 bcopy(serial_buf->serial_num, serial_num, serial_buf->length); 1188 serial_num[serial_buf->length] = '\0'; 1189 1190 if ((arglist & CAM_ARG_GET_STDINQ) 1191 || (arglist & CAM_ARG_GET_XFERRATE)) 1192 fprintf(stdout, "%s%d: Serial Number ", 1193 device->device_name, device->dev_unit_num); 1194 1195 fprintf(stdout, "%.60s\n", serial_num); 1196 1197 free(serial_buf); 1198 1199 return (0); 1200 } 1201 1202 int 1203 camxferrate(struct cam_device *device) 1204 { 1205 struct ccb_pathinq cpi; 1206 uint32_t freq = 0; 1207 uint32_t speed = 0; 1208 union ccb *ccb; 1209 u_int mb; 1210 int retval = 0; 1211 1212 if ((retval = get_cpi(device, &cpi)) != 0) 1213 return (1); 1214 1215 ccb = cam_getccb(device); 1216 1217 if (ccb == NULL) { 1218 warnx("couldn't allocate CCB"); 1219 return (1); 1220 } 1221 1222 ccb->ccb_h.func_code = XPT_GET_TRAN_SETTINGS; 1223 ccb->cts.type = CTS_TYPE_CURRENT_SETTINGS; 1224 1225 if (((retval = cam_send_ccb(device, ccb)) < 0) 1226 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 1227 const char error_string[] = "error getting transfer settings"; 1228 1229 if (retval < 0) 1230 warn(error_string); 1231 else 1232 warnx(error_string); 1233 1234 if (arglist & CAM_ARG_VERBOSE) 1235 cam_error_print(device, ccb, CAM_ESF_ALL, 1236 CAM_EPF_ALL, stderr); 1237 1238 retval = 1; 1239 1240 goto xferrate_bailout; 1241 1242 } 1243 1244 speed = cpi.base_transfer_speed; 1245 freq = 0; 1246 if (ccb->cts.transport == XPORT_SPI) { 1247 struct ccb_trans_settings_spi *spi = 1248 &ccb->cts.xport_specific.spi; 1249 1250 if ((spi->valid & CTS_SPI_VALID_SYNC_RATE) != 0) { 1251 freq = scsi_calc_syncsrate(spi->sync_period); 1252 speed = freq; 1253 } 1254 if ((spi->valid & CTS_SPI_VALID_BUS_WIDTH) != 0) { 1255 speed *= (0x01 << spi->bus_width); 1256 } 1257 } else if (ccb->cts.transport == XPORT_FC) { 1258 struct ccb_trans_settings_fc *fc = 1259 &ccb->cts.xport_specific.fc; 1260 1261 if (fc->valid & CTS_FC_VALID_SPEED) 1262 speed = fc->bitrate; 1263 } else if (ccb->cts.transport == XPORT_SAS) { 1264 struct ccb_trans_settings_sas *sas = 1265 &ccb->cts.xport_specific.sas; 1266 1267 if (sas->valid & CTS_SAS_VALID_SPEED) 1268 speed = sas->bitrate; 1269 } else if (ccb->cts.transport == XPORT_ATA) { 1270 struct ccb_trans_settings_pata *pata = 1271 &ccb->cts.xport_specific.ata; 1272 1273 if (pata->valid & CTS_ATA_VALID_MODE) 1274 speed = ata_mode2speed(pata->mode); 1275 } else if (ccb->cts.transport == XPORT_SATA) { 1276 struct ccb_trans_settings_sata *sata = 1277 &ccb->cts.xport_specific.sata; 1278 1279 if (sata->valid & CTS_SATA_VALID_REVISION) 1280 speed = ata_revision2speed(sata->revision); 1281 } 1282 1283 mb = speed / 1000; 1284 if (mb > 0) { 1285 fprintf(stdout, "%s%d: %d.%03dMB/s transfers", 1286 device->device_name, device->dev_unit_num, 1287 mb, speed % 1000); 1288 } else { 1289 fprintf(stdout, "%s%d: %dKB/s transfers", 1290 device->device_name, device->dev_unit_num, 1291 speed); 1292 } 1293 1294 if (ccb->cts.transport == XPORT_SPI) { 1295 struct ccb_trans_settings_spi *spi = 1296 &ccb->cts.xport_specific.spi; 1297 1298 if (((spi->valid & CTS_SPI_VALID_SYNC_OFFSET) != 0) 1299 && (spi->sync_offset != 0)) 1300 fprintf(stdout, " (%d.%03dMHz, offset %d", freq / 1000, 1301 freq % 1000, spi->sync_offset); 1302 1303 if (((spi->valid & CTS_SPI_VALID_BUS_WIDTH) != 0) 1304 && (spi->bus_width > 0)) { 1305 if (((spi->valid & CTS_SPI_VALID_SYNC_OFFSET) != 0) 1306 && (spi->sync_offset != 0)) { 1307 fprintf(stdout, ", "); 1308 } else { 1309 fprintf(stdout, " ("); 1310 } 1311 fprintf(stdout, "%dbit)", 8 * (0x01 << spi->bus_width)); 1312 } else if (((spi->valid & CTS_SPI_VALID_SYNC_OFFSET) != 0) 1313 && (spi->sync_offset != 0)) { 1314 fprintf(stdout, ")"); 1315 } 1316 } else if (ccb->cts.transport == XPORT_ATA) { 1317 struct ccb_trans_settings_pata *pata = 1318 &ccb->cts.xport_specific.ata; 1319 1320 printf(" ("); 1321 if (pata->valid & CTS_ATA_VALID_MODE) 1322 printf("%s, ", ata_mode2string(pata->mode)); 1323 if ((pata->valid & CTS_ATA_VALID_ATAPI) && pata->atapi != 0) 1324 printf("ATAPI %dbytes, ", pata->atapi); 1325 if (pata->valid & CTS_ATA_VALID_BYTECOUNT) 1326 printf("PIO %dbytes", pata->bytecount); 1327 printf(")"); 1328 } else if (ccb->cts.transport == XPORT_SATA) { 1329 struct ccb_trans_settings_sata *sata = 1330 &ccb->cts.xport_specific.sata; 1331 1332 printf(" ("); 1333 if (sata->valid & CTS_SATA_VALID_REVISION) 1334 printf("SATA %d.x, ", sata->revision); 1335 else 1336 printf("SATA, "); 1337 if (sata->valid & CTS_SATA_VALID_MODE) 1338 printf("%s, ", ata_mode2string(sata->mode)); 1339 if ((sata->valid & CTS_SATA_VALID_ATAPI) && sata->atapi != 0) 1340 printf("ATAPI %dbytes, ", sata->atapi); 1341 if (sata->valid & CTS_SATA_VALID_BYTECOUNT) 1342 printf("PIO %dbytes", sata->bytecount); 1343 printf(")"); 1344 } 1345 1346 if (ccb->cts.protocol == PROTO_SCSI) { 1347 struct ccb_trans_settings_scsi *scsi = 1348 &ccb->cts.proto_specific.scsi; 1349 if (scsi->valid & CTS_SCSI_VALID_TQ) { 1350 if (scsi->flags & CTS_SCSI_FLAGS_TAG_ENB) { 1351 fprintf(stdout, ", Command Queueing Enabled"); 1352 } 1353 } 1354 } 1355 1356 fprintf(stdout, "\n"); 1357 1358 xferrate_bailout: 1359 1360 cam_freeccb(ccb); 1361 1362 return (retval); 1363 } 1364 1365 static void 1366 atahpa_print(struct ata_params *parm, u_int64_t hpasize, int header) 1367 { 1368 uint32_t lbasize = (uint32_t)parm->lba_size_1 | 1369 ((uint32_t)parm->lba_size_2 << 16); 1370 1371 u_int64_t lbasize48 = ((u_int64_t)parm->lba_size48_1) | 1372 ((u_int64_t)parm->lba_size48_2 << 16) | 1373 ((u_int64_t)parm->lba_size48_3 << 32) | 1374 ((u_int64_t)parm->lba_size48_4 << 48); 1375 1376 if (header) { 1377 printf("\nFeature " 1378 "Support Enabled Value\n"); 1379 } 1380 1381 printf("Host Protected Area (HPA) "); 1382 if (parm->support.command1 & ATA_SUPPORT_PROTECTED) { 1383 u_int64_t lba = lbasize48 ? lbasize48 : lbasize; 1384 printf("yes %s %ju/%ju\n", (hpasize > lba) ? "yes" : "no ", 1385 lba, hpasize); 1386 1387 printf("HPA - Security "); 1388 if (parm->support.command2 & ATA_SUPPORT_MAXSECURITY) 1389 printf("yes %s\n", (parm->enabled.command2 & 1390 ATA_SUPPORT_MAXSECURITY) ? "yes" : "no "); 1391 else 1392 printf("no\n"); 1393 } else { 1394 printf("no\n"); 1395 } 1396 } 1397 1398 static void 1399 ataama_print(struct ata_params *parm, u_int64_t nativesize, int header) 1400 { 1401 uint32_t lbasize = (uint32_t)parm->lba_size_1 | 1402 ((uint32_t)parm->lba_size_2 << 16); 1403 1404 u_int64_t lbasize48 = ((u_int64_t)parm->lba_size48_1) | 1405 ((u_int64_t)parm->lba_size48_2 << 16) | 1406 ((u_int64_t)parm->lba_size48_3 << 32) | 1407 ((u_int64_t)parm->lba_size48_4 << 48); 1408 1409 if (header) { 1410 printf("\nFeature " 1411 "Support Enabled Value\n"); 1412 } 1413 1414 printf("Accessible Max Address Config "); 1415 if (parm->support2 & ATA_SUPPORT_AMAX_ADDR) { 1416 u_int64_t lba = lbasize48 ? lbasize48 : lbasize; 1417 printf("yes %s %ju/%ju\n", 1418 (nativesize > lba) ? "yes" : "no ", lba, nativesize); 1419 } else { 1420 printf("no\n"); 1421 } 1422 } 1423 1424 static int 1425 atasata(struct ata_params *parm) 1426 { 1427 1428 1429 if (parm->satacapabilities != 0xffff && 1430 parm->satacapabilities != 0x0000) 1431 return 1; 1432 1433 return 0; 1434 } 1435 1436 static void 1437 atacapprint(struct ata_params *parm) 1438 { 1439 const char *proto; 1440 uint32_t lbasize = (uint32_t)parm->lba_size_1 | 1441 ((uint32_t)parm->lba_size_2 << 16); 1442 1443 u_int64_t lbasize48 = ((u_int64_t)parm->lba_size48_1) | 1444 ((u_int64_t)parm->lba_size48_2 << 16) | 1445 ((u_int64_t)parm->lba_size48_3 << 32) | 1446 ((u_int64_t)parm->lba_size48_4 << 48); 1447 1448 printf("\n"); 1449 printf("protocol "); 1450 proto = (parm->config == ATA_PROTO_CFA) ? "CFA" : 1451 (parm->config & ATA_PROTO_ATAPI) ? "ATAPI" : "ATA"; 1452 if (ata_version(parm->version_major) == 0) { 1453 printf("%s", proto); 1454 } else if (ata_version(parm->version_major) <= 7) { 1455 printf("%s-%d", proto, 1456 ata_version(parm->version_major)); 1457 } else if (ata_version(parm->version_major) == 8) { 1458 printf("%s8-ACS", proto); 1459 } else { 1460 printf("ACS-%d %s", 1461 ata_version(parm->version_major) - 7, proto); 1462 } 1463 if (parm->satacapabilities && parm->satacapabilities != 0xffff) { 1464 if (parm->satacapabilities & ATA_SATA_GEN3) 1465 printf(" SATA 3.x\n"); 1466 else if (parm->satacapabilities & ATA_SATA_GEN2) 1467 printf(" SATA 2.x\n"); 1468 else if (parm->satacapabilities & ATA_SATA_GEN1) 1469 printf(" SATA 1.x\n"); 1470 else 1471 printf(" SATA\n"); 1472 } 1473 else 1474 printf("\n"); 1475 printf("device model %.40s\n", parm->model); 1476 printf("firmware revision %.8s\n", parm->revision); 1477 printf("serial number %.20s\n", parm->serial); 1478 if (parm->enabled.extension & ATA_SUPPORT_64BITWWN) { 1479 printf("WWN %04x%04x%04x%04x\n", 1480 parm->wwn[0], parm->wwn[1], parm->wwn[2], parm->wwn[3]); 1481 } 1482 printf("additional product id %.8s\n", parm->product_id); 1483 if (parm->enabled.extension & ATA_SUPPORT_MEDIASN) { 1484 printf("media serial number %.30s\n", 1485 parm->media_serial); 1486 } 1487 1488 printf("cylinders %d\n", parm->cylinders); 1489 printf("heads %d\n", parm->heads); 1490 printf("sectors/track %d\n", parm->sectors); 1491 printf("sector size logical %u, physical %lu, offset %lu\n", 1492 ata_logical_sector_size(parm), 1493 (unsigned long)ata_physical_sector_size(parm), 1494 (unsigned long)ata_logical_sector_offset(parm)); 1495 1496 if (parm->config == ATA_PROTO_CFA || 1497 (parm->support.command2 & ATA_SUPPORT_CFA)) 1498 printf("CFA supported\n"); 1499 1500 printf("LBA%ssupported ", 1501 parm->capabilities1 & ATA_SUPPORT_LBA ? " " : " not "); 1502 if (lbasize) 1503 printf("%d sectors\n", lbasize); 1504 else 1505 printf("\n"); 1506 1507 printf("LBA48%ssupported ", 1508 parm->support.command2 & ATA_SUPPORT_ADDRESS48 ? " " : " not "); 1509 if (lbasize48) 1510 printf("%ju sectors\n", (uintmax_t)lbasize48); 1511 else 1512 printf("\n"); 1513 1514 printf("PIO supported PIO"); 1515 switch (ata_max_pmode(parm)) { 1516 case ATA_PIO4: 1517 printf("4"); 1518 break; 1519 case ATA_PIO3: 1520 printf("3"); 1521 break; 1522 case ATA_PIO2: 1523 printf("2"); 1524 break; 1525 case ATA_PIO1: 1526 printf("1"); 1527 break; 1528 default: 1529 printf("0"); 1530 } 1531 if ((parm->capabilities1 & ATA_SUPPORT_IORDY) == 0) 1532 printf(" w/o IORDY"); 1533 printf("\n"); 1534 1535 printf("DMA%ssupported ", 1536 parm->capabilities1 & ATA_SUPPORT_DMA ? " " : " not "); 1537 if (parm->capabilities1 & ATA_SUPPORT_DMA) { 1538 if (parm->mwdmamodes & 0xff) { 1539 printf("WDMA"); 1540 if (parm->mwdmamodes & 0x04) 1541 printf("2"); 1542 else if (parm->mwdmamodes & 0x02) 1543 printf("1"); 1544 else if (parm->mwdmamodes & 0x01) 1545 printf("0"); 1546 printf(" "); 1547 } 1548 if ((parm->atavalid & ATA_FLAG_88) && 1549 (parm->udmamodes & 0xff)) { 1550 printf("UDMA"); 1551 if (parm->udmamodes & 0x40) 1552 printf("6"); 1553 else if (parm->udmamodes & 0x20) 1554 printf("5"); 1555 else if (parm->udmamodes & 0x10) 1556 printf("4"); 1557 else if (parm->udmamodes & 0x08) 1558 printf("3"); 1559 else if (parm->udmamodes & 0x04) 1560 printf("2"); 1561 else if (parm->udmamodes & 0x02) 1562 printf("1"); 1563 else if (parm->udmamodes & 0x01) 1564 printf("0"); 1565 printf(" "); 1566 } 1567 } 1568 printf("\n"); 1569 1570 if (parm->media_rotation_rate == 1) { 1571 printf("media RPM non-rotating\n"); 1572 } else if (parm->media_rotation_rate >= 0x0401 && 1573 parm->media_rotation_rate <= 0xFFFE) { 1574 printf("media RPM %d\n", 1575 parm->media_rotation_rate); 1576 } 1577 1578 printf("Zoned-Device Commands "); 1579 switch (parm->support3 & ATA_SUPPORT_ZONE_MASK) { 1580 case ATA_SUPPORT_ZONE_DEV_MANAGED: 1581 printf("device managed\n"); 1582 break; 1583 case ATA_SUPPORT_ZONE_HOST_AWARE: 1584 printf("host aware\n"); 1585 break; 1586 default: 1587 printf("no\n"); 1588 } 1589 1590 printf("\nFeature " 1591 "Support Enabled Value Vendor\n"); 1592 printf("read ahead %s %s\n", 1593 parm->support.command1 & ATA_SUPPORT_LOOKAHEAD ? "yes" : "no", 1594 parm->enabled.command1 & ATA_SUPPORT_LOOKAHEAD ? "yes" : "no"); 1595 printf("write cache %s %s\n", 1596 parm->support.command1 & ATA_SUPPORT_WRITECACHE ? "yes" : "no", 1597 parm->enabled.command1 & ATA_SUPPORT_WRITECACHE ? "yes" : "no"); 1598 printf("flush cache %s %s\n", 1599 parm->support.command2 & ATA_SUPPORT_FLUSHCACHE ? "yes" : "no", 1600 parm->enabled.command2 & ATA_SUPPORT_FLUSHCACHE ? "yes" : "no"); 1601 printf("Native Command Queuing (NCQ) "); 1602 if (atasata(parm) && (parm->satacapabilities & ATA_SUPPORT_NCQ)) { 1603 printf("yes %d tags\n", 1604 ATA_QUEUE_LEN(parm->queue) + 1); 1605 printf("NCQ Priority Information %s\n", 1606 parm->satacapabilities & ATA_SUPPORT_NCQ_PRIO ? 1607 "yes" : "no"); 1608 printf("NCQ Non-Data Command %s\n", 1609 parm->satacapabilities2 & ATA_SUPPORT_NCQ_NON_DATA ? 1610 "yes" : "no"); 1611 printf("NCQ Streaming %s\n", 1612 parm->satacapabilities2 & ATA_SUPPORT_NCQ_STREAM ? 1613 "yes" : "no"); 1614 printf("Receive & Send FPDMA Queued %s\n", 1615 parm->satacapabilities2 & ATA_SUPPORT_RCVSND_FPDMA_QUEUED ? 1616 "yes" : "no"); 1617 printf("NCQ Autosense %s\n", 1618 parm->satasupport & ATA_SUPPORT_NCQ_AUTOSENSE ? 1619 "yes" : "no"); 1620 } else 1621 printf("no\n"); 1622 1623 printf("SMART %s %s\n", 1624 parm->support.command1 & ATA_SUPPORT_SMART ? "yes" : "no", 1625 parm->enabled.command1 & ATA_SUPPORT_SMART ? "yes" : "no"); 1626 printf("security %s %s\n", 1627 parm->support.command1 & ATA_SUPPORT_SECURITY ? "yes" : "no", 1628 parm->enabled.command1 & ATA_SUPPORT_SECURITY ? "yes" : "no"); 1629 printf("power management %s %s\n", 1630 parm->support.command1 & ATA_SUPPORT_POWERMGT ? "yes" : "no", 1631 parm->enabled.command1 & ATA_SUPPORT_POWERMGT ? "yes" : "no"); 1632 printf("microcode download %s %s\n", 1633 parm->support.command2 & ATA_SUPPORT_MICROCODE ? "yes" : "no", 1634 parm->enabled.command2 & ATA_SUPPORT_MICROCODE ? "yes" : "no"); 1635 printf("advanced power management %s %s", 1636 parm->support.command2 & ATA_SUPPORT_APM ? "yes" : "no", 1637 parm->enabled.command2 & ATA_SUPPORT_APM ? "yes" : "no"); 1638 if (parm->support.command2 & ATA_SUPPORT_APM) { 1639 printf(" %d/0x%02X\n", 1640 parm->apm_value & 0xff, parm->apm_value & 0xff); 1641 } else 1642 printf("\n"); 1643 printf("automatic acoustic management %s %s", 1644 parm->support.command2 & ATA_SUPPORT_AUTOACOUSTIC ? "yes" :"no", 1645 parm->enabled.command2 & ATA_SUPPORT_AUTOACOUSTIC ? "yes" :"no"); 1646 if (parm->support.command2 & ATA_SUPPORT_AUTOACOUSTIC) { 1647 printf(" %d/0x%02X %d/0x%02X\n", 1648 ATA_ACOUSTIC_CURRENT(parm->acoustic), 1649 ATA_ACOUSTIC_CURRENT(parm->acoustic), 1650 ATA_ACOUSTIC_VENDOR(parm->acoustic), 1651 ATA_ACOUSTIC_VENDOR(parm->acoustic)); 1652 } else 1653 printf("\n"); 1654 printf("media status notification %s %s\n", 1655 parm->support.command2 & ATA_SUPPORT_NOTIFY ? "yes" : "no", 1656 parm->enabled.command2 & ATA_SUPPORT_NOTIFY ? "yes" : "no"); 1657 printf("power-up in Standby %s %s\n", 1658 parm->support.command2 & ATA_SUPPORT_STANDBY ? "yes" : "no", 1659 parm->enabled.command2 & ATA_SUPPORT_STANDBY ? "yes" : "no"); 1660 printf("write-read-verify %s %s", 1661 parm->support2 & ATA_SUPPORT_WRITEREADVERIFY ? "yes" : "no", 1662 parm->enabled2 & ATA_SUPPORT_WRITEREADVERIFY ? "yes" : "no"); 1663 if (parm->support2 & ATA_SUPPORT_WRITEREADVERIFY) { 1664 printf(" %d/0x%x\n", 1665 parm->wrv_mode, parm->wrv_mode); 1666 } else 1667 printf("\n"); 1668 printf("unload %s %s\n", 1669 parm->support.extension & ATA_SUPPORT_UNLOAD ? "yes" : "no", 1670 parm->enabled.extension & ATA_SUPPORT_UNLOAD ? "yes" : "no"); 1671 printf("general purpose logging %s %s\n", 1672 parm->support.extension & ATA_SUPPORT_GENLOG ? "yes" : "no", 1673 parm->enabled.extension & ATA_SUPPORT_GENLOG ? "yes" : "no"); 1674 printf("free-fall %s %s\n", 1675 parm->support2 & ATA_SUPPORT_FREEFALL ? "yes" : "no", 1676 parm->enabled2 & ATA_SUPPORT_FREEFALL ? "yes" : "no"); 1677 printf("sense data reporting %s %s\n", 1678 parm->support2 & ATA_SUPPORT_SENSE_REPORT ? "yes" : "no", 1679 parm->enabled2 & ATA_SUPPORT_SENSE_REPORT ? "yes" : "no"); 1680 printf("extended power conditions %s %s\n", 1681 parm->support2 & ATA_SUPPORT_EPC ? "yes" : "no", 1682 parm->enabled2 & ATA_SUPPORT_EPC ? "yes" : "no"); 1683 printf("device statistics notification %s %s\n", 1684 parm->support2 & ATA_SUPPORT_DSN ? "yes" : "no", 1685 parm->enabled2 & ATA_SUPPORT_DSN ? "yes" : "no"); 1686 printf("Data Set Management (DSM/TRIM) "); 1687 if (parm->support_dsm & ATA_SUPPORT_DSM_TRIM) { 1688 printf("yes\n"); 1689 printf("DSM - max 512byte blocks "); 1690 if (parm->max_dsm_blocks == 0x00) 1691 printf("yes not specified\n"); 1692 else 1693 printf("yes %d\n", 1694 parm->max_dsm_blocks); 1695 1696 printf("DSM - deterministic read "); 1697 if (parm->support3 & ATA_SUPPORT_DRAT) { 1698 if (parm->support3 & ATA_SUPPORT_RZAT) 1699 printf("yes zeroed\n"); 1700 else 1701 printf("yes any value\n"); 1702 } else { 1703 printf("no\n"); 1704 } 1705 } else { 1706 printf("no\n"); 1707 } 1708 printf("Trusted Computing %s\n", 1709 ((parm->tcg & 0xc000) == 0x4000) && (parm->tcg & ATA_SUPPORT_TCG) ? 1710 "yes" : "no"); 1711 printf("encrypts all user data %s\n", 1712 parm->support3 & ATA_ENCRYPTS_ALL_USER_DATA ? "yes" : "no"); 1713 printf("Sanitize "); 1714 if (parm->multi & ATA_SUPPORT_SANITIZE) { 1715 printf("yes\t\t%s%s%s\n", 1716 parm->multi & ATA_SUPPORT_BLOCK_ERASE_EXT ? "block, " : "", 1717 parm->multi & ATA_SUPPORT_OVERWRITE_EXT ? "overwrite, " : "", 1718 parm->multi & ATA_SUPPORT_CRYPTO_SCRAMBLE_EXT ? "crypto" : ""); 1719 printf("Sanitize - commands allowed %s\n", 1720 parm->multi & ATA_SUPPORT_SANITIZE_ALLOWED ? "yes" : "no"); 1721 printf("Sanitize - antifreeze lock %s\n", 1722 parm->multi & ATA_SUPPORT_ANTIFREEZE_LOCK_EXT ? "yes" : "no"); 1723 } else { 1724 printf("no\n"); 1725 } 1726 } 1727 1728 static int 1729 scsi_cam_pass_16_send(struct cam_device *device, union ccb *ccb) 1730 { 1731 struct ata_pass_16 *ata_pass_16; 1732 struct ata_cmd ata_cmd; 1733 1734 ata_pass_16 = (struct ata_pass_16 *)ccb->csio.cdb_io.cdb_bytes; 1735 ata_cmd.command = ata_pass_16->command; 1736 ata_cmd.control = ata_pass_16->control; 1737 ata_cmd.features = ata_pass_16->features; 1738 1739 if (arglist & CAM_ARG_VERBOSE) { 1740 warnx("sending ATA %s via pass_16 with timeout of %u msecs", 1741 ata_op_string(&ata_cmd), 1742 ccb->csio.ccb_h.timeout); 1743 } 1744 1745 /* Disable freezing the device queue */ 1746 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 1747 1748 if (arglist & CAM_ARG_ERR_RECOVER) 1749 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 1750 1751 if (cam_send_ccb(device, ccb) < 0) { 1752 warn("error sending ATA %s via pass_16", ata_op_string(&ata_cmd)); 1753 return (1); 1754 } 1755 1756 /* 1757 * Consider any non-CAM_REQ_CMP status as error and report it here, 1758 * unless caller set AP_FLAG_CHK_COND, in which case it is responsible. 1759 */ 1760 if (!(ata_pass_16->flags & AP_FLAG_CHK_COND) && 1761 (ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 1762 warnx("ATA %s via pass_16 failed", ata_op_string(&ata_cmd)); 1763 if (arglist & CAM_ARG_VERBOSE) { 1764 cam_error_print(device, ccb, CAM_ESF_ALL, 1765 CAM_EPF_ALL, stderr); 1766 } 1767 return (1); 1768 } 1769 1770 return (0); 1771 } 1772 1773 1774 static int 1775 ata_cam_send(struct cam_device *device, union ccb *ccb) 1776 { 1777 if (arglist & CAM_ARG_VERBOSE) { 1778 warnx("sending ATA %s with timeout of %u msecs", 1779 ata_op_string(&(ccb->ataio.cmd)), 1780 ccb->ataio.ccb_h.timeout); 1781 } 1782 1783 /* Disable freezing the device queue */ 1784 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 1785 1786 if (arglist & CAM_ARG_ERR_RECOVER) 1787 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 1788 1789 if (cam_send_ccb(device, ccb) < 0) { 1790 warn("error sending ATA %s", ata_op_string(&(ccb->ataio.cmd))); 1791 return (1); 1792 } 1793 1794 /* 1795 * Consider any non-CAM_REQ_CMP status as error and report it here, 1796 * unless caller set AP_FLAG_CHK_COND, in which case it is responsible. 1797 */ 1798 if (!(ccb->ataio.cmd.flags & CAM_ATAIO_NEEDRESULT) && 1799 (ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 1800 warnx("ATA %s failed", ata_op_string(&(ccb->ataio.cmd))); 1801 if (arglist & CAM_ARG_VERBOSE) { 1802 cam_error_print(device, ccb, CAM_ESF_ALL, 1803 CAM_EPF_ALL, stderr); 1804 } 1805 return (1); 1806 } 1807 1808 return (0); 1809 } 1810 1811 static int 1812 ata_do_pass_16(struct cam_device *device, union ccb *ccb, int retries, 1813 uint32_t flags, uint8_t protocol, uint8_t ata_flags, 1814 uint8_t tag_action, uint8_t command, uint16_t features, 1815 u_int64_t lba, uint16_t sector_count, uint8_t *data_ptr, 1816 uint16_t dxfer_len, int timeout) 1817 { 1818 if (data_ptr != NULL) { 1819 if (flags & CAM_DIR_OUT) 1820 ata_flags |= AP_FLAG_TDIR_TO_DEV; 1821 else 1822 ata_flags |= AP_FLAG_TDIR_FROM_DEV; 1823 } else { 1824 ata_flags |= AP_FLAG_TLEN_NO_DATA; 1825 } 1826 1827 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->csio); 1828 1829 scsi_ata_pass_16(&ccb->csio, 1830 retries, 1831 NULL, 1832 flags, 1833 tag_action, 1834 protocol, 1835 ata_flags, 1836 features, 1837 sector_count, 1838 lba, 1839 command, 1840 /*control*/0, 1841 data_ptr, 1842 dxfer_len, 1843 /*sense_len*/SSD_FULL_SIZE, 1844 timeout); 1845 1846 return scsi_cam_pass_16_send(device, ccb); 1847 } 1848 1849 static int 1850 ata_try_pass_16(struct cam_device *device) 1851 { 1852 struct ccb_pathinq cpi; 1853 1854 if (get_cpi(device, &cpi) != 0) { 1855 warnx("couldn't get CPI"); 1856 return (-1); 1857 } 1858 1859 if (cpi.protocol == PROTO_SCSI) { 1860 /* possibly compatible with pass_16 */ 1861 return (1); 1862 } 1863 1864 /* likely not compatible with pass_16 */ 1865 return (0); 1866 } 1867 1868 static int 1869 ata_do_cmd(struct cam_device *device, union ccb *ccb, int retries, 1870 uint32_t flags, uint8_t protocol, uint8_t ata_flags, 1871 uint8_t tag_action, uint8_t command, uint16_t features, 1872 u_int64_t lba, uint16_t sector_count, uint8_t *data_ptr, 1873 uint16_t dxfer_len, int timeout, int force48bit) 1874 { 1875 int retval; 1876 1877 retval = ata_try_pass_16(device); 1878 if (retval == -1) 1879 return (1); 1880 1881 if (retval == 1) { 1882 return (ata_do_pass_16(device, ccb, retries, flags, protocol, 1883 ata_flags, tag_action, command, features, 1884 lba, sector_count, data_ptr, dxfer_len, 1885 timeout)); 1886 } 1887 1888 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->ataio); 1889 cam_fill_ataio(&ccb->ataio, 1890 retries, 1891 NULL, 1892 flags, 1893 tag_action, 1894 data_ptr, 1895 dxfer_len, 1896 timeout); 1897 1898 if (force48bit || lba > ATA_MAX_28BIT_LBA) 1899 ata_48bit_cmd(&ccb->ataio, command, features, lba, sector_count); 1900 else 1901 ata_28bit_cmd(&ccb->ataio, command, features, lba, sector_count); 1902 1903 if (ata_flags & AP_FLAG_CHK_COND) 1904 ccb->ataio.cmd.flags |= CAM_ATAIO_NEEDRESULT; 1905 1906 return ata_cam_send(device, ccb); 1907 } 1908 1909 static void 1910 dump_data(uint16_t *ptr, uint32_t len) 1911 { 1912 u_int i; 1913 1914 for (i = 0; i < len / 2; i++) { 1915 if ((i % 8) == 0) 1916 printf(" %3d: ", i); 1917 printf("%04hx ", ptr[i]); 1918 if ((i % 8) == 7) 1919 printf("\n"); 1920 } 1921 if ((i % 8) != 7) 1922 printf("\n"); 1923 } 1924 1925 static int 1926 atahpa_proc_resp(struct cam_device *device, union ccb *ccb, u_int64_t *hpasize) 1927 { 1928 uint8_t error = 0, ata_device = 0, status = 0; 1929 uint16_t count = 0; 1930 uint64_t lba = 0; 1931 int retval; 1932 1933 retval = get_ata_status(device, ccb, &error, &count, &lba, &ata_device, 1934 &status); 1935 if (retval == 1) { 1936 if (arglist & CAM_ARG_VERBOSE) { 1937 cam_error_print(device, ccb, CAM_ESF_ALL, 1938 CAM_EPF_ALL, stderr); 1939 } 1940 warnx("Can't get ATA command status"); 1941 return (retval); 1942 } 1943 1944 if (status & ATA_STATUS_ERROR) { 1945 if (arglist & CAM_ARG_VERBOSE) { 1946 cam_error_print(device, ccb, CAM_ESF_ALL, 1947 CAM_EPF_ALL, stderr); 1948 } 1949 1950 if (error & ATA_ERROR_ID_NOT_FOUND) { 1951 warnx("Max address has already been set since " 1952 "last power-on or hardware reset"); 1953 } else if (hpasize == NULL) 1954 warnx("Command failed with ATA error"); 1955 1956 return (1); 1957 } 1958 1959 if (hpasize != NULL) { 1960 if (retval == 2 || retval == 6) 1961 return (1); 1962 *hpasize = lba + 1; 1963 } 1964 1965 return (0); 1966 } 1967 1968 static int 1969 ata_read_native_max(struct cam_device *device, int retry_count, 1970 uint32_t timeout, union ccb *ccb, 1971 struct ata_params *parm, u_int64_t *hpasize) 1972 { 1973 int error; 1974 u_int cmd, is48bit; 1975 uint8_t protocol; 1976 1977 is48bit = parm->support.command2 & ATA_SUPPORT_ADDRESS48; 1978 protocol = AP_PROTO_NON_DATA; 1979 1980 if (is48bit) { 1981 cmd = ATA_READ_NATIVE_MAX_ADDRESS48; 1982 protocol |= AP_EXTEND; 1983 } else { 1984 cmd = ATA_READ_NATIVE_MAX_ADDRESS; 1985 } 1986 1987 error = ata_do_cmd(device, 1988 ccb, 1989 retry_count, 1990 /*flags*/CAM_DIR_NONE, 1991 /*protocol*/protocol, 1992 /*ata_flags*/AP_FLAG_CHK_COND, 1993 /*tag_action*/MSG_SIMPLE_Q_TAG, 1994 /*command*/cmd, 1995 /*features*/0, 1996 /*lba*/0, 1997 /*sector_count*/0, 1998 /*data_ptr*/NULL, 1999 /*dxfer_len*/0, 2000 timeout ? timeout : 5000, 2001 is48bit); 2002 2003 if (error) 2004 return (error); 2005 2006 return atahpa_proc_resp(device, ccb, hpasize); 2007 } 2008 2009 static int 2010 atahpa_set_max(struct cam_device *device, int retry_count, 2011 uint32_t timeout, union ccb *ccb, 2012 int is48bit, u_int64_t maxsize, int persist) 2013 { 2014 int error; 2015 u_int cmd; 2016 uint8_t protocol; 2017 2018 protocol = AP_PROTO_NON_DATA; 2019 2020 if (is48bit) { 2021 cmd = ATA_SET_MAX_ADDRESS48; 2022 protocol |= AP_EXTEND; 2023 } else { 2024 cmd = ATA_SET_MAX_ADDRESS; 2025 } 2026 2027 /* lba's are zero indexed so the max lba is requested max - 1 */ 2028 if (maxsize) 2029 maxsize--; 2030 2031 error = ata_do_cmd(device, 2032 ccb, 2033 retry_count, 2034 /*flags*/CAM_DIR_NONE, 2035 /*protocol*/protocol, 2036 /*ata_flags*/AP_FLAG_CHK_COND, 2037 /*tag_action*/MSG_SIMPLE_Q_TAG, 2038 /*command*/cmd, 2039 /*features*/ATA_HPA_FEAT_MAX_ADDR, 2040 /*lba*/maxsize, 2041 /*sector_count*/persist, 2042 /*data_ptr*/NULL, 2043 /*dxfer_len*/0, 2044 timeout ? timeout : 1000, 2045 is48bit); 2046 2047 if (error) 2048 return (error); 2049 2050 return atahpa_proc_resp(device, ccb, NULL); 2051 } 2052 2053 static int 2054 atahpa_password(struct cam_device *device, int retry_count, 2055 uint32_t timeout, union ccb *ccb, 2056 int is48bit, struct ata_set_max_pwd *pwd) 2057 { 2058 u_int cmd; 2059 uint8_t protocol; 2060 2061 protocol = AP_PROTO_PIO_OUT; 2062 cmd = (is48bit) ? ATA_SET_MAX_ADDRESS48 : ATA_SET_MAX_ADDRESS; 2063 2064 return (ata_do_cmd(device, 2065 ccb, 2066 retry_count, 2067 /*flags*/CAM_DIR_OUT, 2068 /*protocol*/protocol, 2069 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2070 AP_FLAG_TLEN_SECT_CNT, 2071 /*tag_action*/MSG_SIMPLE_Q_TAG, 2072 /*command*/cmd, 2073 /*features*/ATA_HPA_FEAT_SET_PWD, 2074 /*lba*/0, 2075 /*sector_count*/sizeof(*pwd) / 512, 2076 /*data_ptr*/(uint8_t*)pwd, 2077 /*dxfer_len*/sizeof(*pwd), 2078 timeout ? timeout : 1000, 2079 is48bit)); 2080 } 2081 2082 static int 2083 atahpa_lock(struct cam_device *device, int retry_count, 2084 uint32_t timeout, union ccb *ccb, int is48bit) 2085 { 2086 u_int cmd; 2087 uint8_t protocol; 2088 2089 protocol = AP_PROTO_NON_DATA; 2090 cmd = (is48bit) ? ATA_SET_MAX_ADDRESS48 : ATA_SET_MAX_ADDRESS; 2091 2092 return (ata_do_cmd(device, 2093 ccb, 2094 retry_count, 2095 /*flags*/CAM_DIR_NONE, 2096 /*protocol*/protocol, 2097 /*ata_flags*/0, 2098 /*tag_action*/MSG_SIMPLE_Q_TAG, 2099 /*command*/cmd, 2100 /*features*/ATA_HPA_FEAT_LOCK, 2101 /*lba*/0, 2102 /*sector_count*/0, 2103 /*data_ptr*/NULL, 2104 /*dxfer_len*/0, 2105 timeout ? timeout : 1000, 2106 is48bit)); 2107 } 2108 2109 static int 2110 atahpa_unlock(struct cam_device *device, int retry_count, 2111 uint32_t timeout, union ccb *ccb, 2112 int is48bit, struct ata_set_max_pwd *pwd) 2113 { 2114 u_int cmd; 2115 uint8_t protocol; 2116 2117 protocol = AP_PROTO_PIO_OUT; 2118 cmd = (is48bit) ? ATA_SET_MAX_ADDRESS48 : ATA_SET_MAX_ADDRESS; 2119 2120 return (ata_do_cmd(device, 2121 ccb, 2122 retry_count, 2123 /*flags*/CAM_DIR_OUT, 2124 /*protocol*/protocol, 2125 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2126 AP_FLAG_TLEN_SECT_CNT, 2127 /*tag_action*/MSG_SIMPLE_Q_TAG, 2128 /*command*/cmd, 2129 /*features*/ATA_HPA_FEAT_UNLOCK, 2130 /*lba*/0, 2131 /*sector_count*/sizeof(*pwd) / 512, 2132 /*data_ptr*/(uint8_t*)pwd, 2133 /*dxfer_len*/sizeof(*pwd), 2134 timeout ? timeout : 1000, 2135 is48bit)); 2136 } 2137 2138 static int 2139 atahpa_freeze_lock(struct cam_device *device, int retry_count, 2140 uint32_t timeout, union ccb *ccb, int is48bit) 2141 { 2142 u_int cmd; 2143 uint8_t protocol; 2144 2145 protocol = AP_PROTO_NON_DATA; 2146 cmd = (is48bit) ? ATA_SET_MAX_ADDRESS48 : ATA_SET_MAX_ADDRESS; 2147 2148 return (ata_do_cmd(device, 2149 ccb, 2150 retry_count, 2151 /*flags*/CAM_DIR_NONE, 2152 /*protocol*/protocol, 2153 /*ata_flags*/0, 2154 /*tag_action*/MSG_SIMPLE_Q_TAG, 2155 /*command*/cmd, 2156 /*features*/ATA_HPA_FEAT_FREEZE, 2157 /*lba*/0, 2158 /*sector_count*/0, 2159 /*data_ptr*/NULL, 2160 /*dxfer_len*/0, 2161 timeout ? timeout : 1000, 2162 is48bit)); 2163 } 2164 2165 static int 2166 ata_get_native_max(struct cam_device *device, int retry_count, 2167 uint32_t timeout, union ccb *ccb, 2168 u_int64_t *nativesize) 2169 { 2170 int error; 2171 2172 error = ata_do_cmd(device, 2173 ccb, 2174 retry_count, 2175 /*flags*/CAM_DIR_NONE, 2176 /*protocol*/AP_PROTO_NON_DATA | AP_EXTEND, 2177 /*ata_flags*/AP_FLAG_CHK_COND, 2178 /*tag_action*/MSG_SIMPLE_Q_TAG, 2179 /*command*/ATA_AMAX_ADDR, 2180 /*features*/ATA_AMAX_ADDR_GET, 2181 /*lba*/0, 2182 /*sector_count*/0, 2183 /*data_ptr*/NULL, 2184 /*dxfer_len*/0, 2185 timeout ? timeout : 30 * 1000, 2186 /*force48bit*/1); 2187 2188 if (error) 2189 return (error); 2190 2191 return atahpa_proc_resp(device, ccb, nativesize); 2192 } 2193 2194 static int 2195 ataama_set(struct cam_device *device, int retry_count, 2196 uint32_t timeout, union ccb *ccb, u_int64_t maxsize) 2197 { 2198 int error; 2199 2200 /* lba's are zero indexed so the max lba is requested max - 1 */ 2201 if (maxsize) 2202 maxsize--; 2203 2204 error = ata_do_cmd(device, 2205 ccb, 2206 retry_count, 2207 /*flags*/CAM_DIR_NONE, 2208 /*protocol*/AP_PROTO_NON_DATA | AP_EXTEND, 2209 /*ata_flags*/AP_FLAG_CHK_COND, 2210 /*tag_action*/MSG_SIMPLE_Q_TAG, 2211 /*command*/ATA_AMAX_ADDR, 2212 /*features*/ATA_AMAX_ADDR_SET, 2213 /*lba*/maxsize, 2214 /*sector_count*/0, 2215 /*data_ptr*/NULL, 2216 /*dxfer_len*/0, 2217 timeout ? timeout : 30 * 1000, 2218 /*force48bit*/1); 2219 2220 if (error) 2221 return (error); 2222 2223 return atahpa_proc_resp(device, ccb, NULL); 2224 } 2225 2226 static int 2227 ataama_freeze(struct cam_device *device, int retry_count, 2228 uint32_t timeout, union ccb *ccb) 2229 { 2230 2231 return (ata_do_cmd(device, 2232 ccb, 2233 retry_count, 2234 /*flags*/CAM_DIR_NONE, 2235 /*protocol*/AP_PROTO_NON_DATA | AP_EXTEND, 2236 /*ata_flags*/0, 2237 /*tag_action*/MSG_SIMPLE_Q_TAG, 2238 /*command*/ATA_AMAX_ADDR, 2239 /*features*/ATA_AMAX_ADDR_FREEZE, 2240 /*lba*/0, 2241 /*sector_count*/0, 2242 /*data_ptr*/NULL, 2243 /*dxfer_len*/0, 2244 timeout ? timeout : 30 * 1000, 2245 /*force48bit*/1)); 2246 } 2247 2248 int 2249 ata_do_identify(struct cam_device *device, int retry_count, int timeout, 2250 union ccb *ccb, struct ata_params** ident_bufp) 2251 { 2252 struct ata_params *ident_buf; 2253 struct ccb_pathinq cpi; 2254 struct ccb_getdev cgd; 2255 u_int i, error; 2256 int16_t *ptr; 2257 uint8_t command, retry_command; 2258 2259 if (get_cpi(device, &cpi) != 0) { 2260 warnx("couldn't get CPI"); 2261 return (-1); 2262 } 2263 2264 /* Neither PROTO_ATAPI or PROTO_SATAPM are used in cpi.protocol */ 2265 if (cpi.protocol == PROTO_ATA) { 2266 if (get_cgd(device, &cgd) != 0) { 2267 warnx("couldn't get CGD"); 2268 return (-1); 2269 } 2270 2271 command = (cgd.protocol == PROTO_ATA) ? 2272 ATA_ATA_IDENTIFY : ATA_ATAPI_IDENTIFY; 2273 retry_command = 0; 2274 } else { 2275 /* We don't know which for sure so try both */ 2276 command = ATA_ATA_IDENTIFY; 2277 retry_command = ATA_ATAPI_IDENTIFY; 2278 } 2279 2280 ptr = (uint16_t *)calloc(1, sizeof(struct ata_params)); 2281 if (ptr == NULL) { 2282 warnx("can't calloc memory for identify\n"); 2283 return (1); 2284 } 2285 2286 retry: 2287 error = ata_do_cmd(device, 2288 ccb, 2289 /*retries*/retry_count, 2290 /*flags*/CAM_DIR_IN, 2291 /*protocol*/AP_PROTO_PIO_IN, 2292 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2293 AP_FLAG_TLEN_SECT_CNT, 2294 /*tag_action*/MSG_SIMPLE_Q_TAG, 2295 /*command*/command, 2296 /*features*/0, 2297 /*lba*/0, 2298 /*sector_count*/sizeof(struct ata_params) / 512, 2299 /*data_ptr*/(uint8_t *)ptr, 2300 /*dxfer_len*/sizeof(struct ata_params), 2301 /*timeout*/timeout ? timeout : 30 * 1000, 2302 /*force48bit*/0); 2303 2304 if (error != 0) { 2305 if (retry_command != 0) { 2306 command = retry_command; 2307 retry_command = 0; 2308 goto retry; 2309 } 2310 free(ptr); 2311 return (1); 2312 } 2313 2314 ident_buf = (struct ata_params *)ptr; 2315 ata_param_fixup(ident_buf); 2316 2317 error = 1; 2318 for (i = 0; i < sizeof(struct ata_params) / 2; i++) { 2319 if (ptr[i] != 0) 2320 error = 0; 2321 } 2322 2323 /* check for invalid (all zero) response */ 2324 if (error != 0) { 2325 warnx("Invalid identify response detected"); 2326 free(ptr); 2327 return (error); 2328 } 2329 2330 *ident_bufp = ident_buf; 2331 2332 return (0); 2333 } 2334 2335 2336 static int 2337 ataidentify(struct cam_device *device, int retry_count, int timeout) 2338 { 2339 union ccb *ccb; 2340 struct ata_params *ident_buf; 2341 u_int64_t hpasize = 0, nativesize = 0; 2342 2343 if ((ccb = cam_getccb(device)) == NULL) { 2344 warnx("couldn't allocate CCB"); 2345 return (1); 2346 } 2347 2348 if (ata_do_identify(device, retry_count, timeout, ccb, &ident_buf) != 0) { 2349 cam_freeccb(ccb); 2350 return (1); 2351 } 2352 2353 if (arglist & CAM_ARG_VERBOSE) { 2354 printf("%s%d: Raw identify data:\n", 2355 device->device_name, device->dev_unit_num); 2356 dump_data((uint16_t *)ident_buf, sizeof(struct ata_params)); 2357 } 2358 2359 if (ident_buf->support.command1 & ATA_SUPPORT_PROTECTED) { 2360 ata_read_native_max(device, retry_count, timeout, ccb, 2361 ident_buf, &hpasize); 2362 } 2363 if (ident_buf->support2 & ATA_SUPPORT_AMAX_ADDR) { 2364 ata_get_native_max(device, retry_count, timeout, ccb, 2365 &nativesize); 2366 } 2367 2368 printf("%s%d: ", device->device_name, device->dev_unit_num); 2369 ata_print_ident(ident_buf); 2370 camxferrate(device); 2371 atacapprint(ident_buf); 2372 atahpa_print(ident_buf, hpasize, 0); 2373 ataama_print(ident_buf, nativesize, 0); 2374 2375 free(ident_buf); 2376 cam_freeccb(ccb); 2377 2378 return (0); 2379 } 2380 2381 #ifdef WITH_NVME 2382 static int 2383 nvmeidentify(struct cam_device *device, int retry_count __unused, int timeout __unused) 2384 { 2385 struct nvme_controller_data cdata; 2386 2387 if (nvme_get_cdata(device, &cdata)) 2388 return (1); 2389 nvme_print_controller(&cdata); 2390 2391 return (0); 2392 } 2393 #endif 2394 2395 static int 2396 identify(struct cam_device *device, int retry_count, int timeout) 2397 { 2398 #ifdef WITH_NVME 2399 struct ccb_pathinq cpi; 2400 2401 if (get_cpi(device, &cpi) != 0) { 2402 warnx("couldn't get CPI"); 2403 return (-1); 2404 } 2405 2406 if (cpi.protocol == PROTO_NVME) { 2407 return (nvmeidentify(device, retry_count, timeout)); 2408 } 2409 #endif 2410 return (ataidentify(device, retry_count, timeout)); 2411 } 2412 2413 2414 enum { 2415 ATA_SECURITY_ACTION_PRINT, 2416 ATA_SECURITY_ACTION_FREEZE, 2417 ATA_SECURITY_ACTION_UNLOCK, 2418 ATA_SECURITY_ACTION_DISABLE, 2419 ATA_SECURITY_ACTION_ERASE, 2420 ATA_SECURITY_ACTION_ERASE_ENHANCED, 2421 ATA_SECURITY_ACTION_SET_PASSWORD 2422 }; 2423 2424 static void 2425 atasecurity_print_time(uint16_t tw) 2426 { 2427 2428 if (tw == 0) 2429 printf("unspecified"); 2430 else if (tw >= 255) 2431 printf("> 508 min"); 2432 else 2433 printf("%i min", 2 * tw); 2434 } 2435 2436 static uint32_t 2437 atasecurity_erase_timeout_msecs(uint16_t timeout) 2438 { 2439 2440 if (timeout == 0) 2441 return 2 * 3600 * 1000; /* default: two hours */ 2442 else if (timeout > 255) 2443 return (508 + 60) * 60 * 1000; /* spec says > 508 minutes */ 2444 2445 return ((2 * timeout) + 5) * 60 * 1000; /* add a 5min margin */ 2446 } 2447 2448 2449 static void 2450 atasecurity_notify(uint8_t command, struct ata_security_password *pwd) 2451 { 2452 struct ata_cmd cmd; 2453 2454 bzero(&cmd, sizeof(cmd)); 2455 cmd.command = command; 2456 printf("Issuing %s", ata_op_string(&cmd)); 2457 2458 if (pwd != NULL) { 2459 /* pwd->password may not be null terminated */ 2460 char pass[sizeof(pwd->password)+1]; 2461 2462 strlcpy(pass, pwd->password, sizeof(pass)); 2463 printf(" password='%s', user='%s'", 2464 pass, 2465 (pwd->ctrl & ATA_SECURITY_PASSWORD_MASTER) ? 2466 "master" : "user"); 2467 2468 if (command == ATA_SECURITY_SET_PASSWORD) { 2469 printf(", mode='%s'", 2470 (pwd->ctrl & ATA_SECURITY_LEVEL_MAXIMUM) ? 2471 "maximum" : "high"); 2472 } 2473 } 2474 2475 printf("\n"); 2476 } 2477 2478 static int 2479 atasecurity_freeze(struct cam_device *device, union ccb *ccb, 2480 int retry_count, uint32_t timeout, int quiet) 2481 { 2482 2483 if (quiet == 0) 2484 atasecurity_notify(ATA_SECURITY_FREEZE_LOCK, NULL); 2485 2486 return ata_do_cmd(device, 2487 ccb, 2488 retry_count, 2489 /*flags*/CAM_DIR_NONE, 2490 /*protocol*/AP_PROTO_NON_DATA, 2491 /*ata_flags*/0, 2492 /*tag_action*/MSG_SIMPLE_Q_TAG, 2493 /*command*/ATA_SECURITY_FREEZE_LOCK, 2494 /*features*/0, 2495 /*lba*/0, 2496 /*sector_count*/0, 2497 /*data_ptr*/NULL, 2498 /*dxfer_len*/0, 2499 /*timeout*/timeout, 2500 /*force48bit*/0); 2501 } 2502 2503 static int 2504 atasecurity_unlock(struct cam_device *device, union ccb *ccb, 2505 int retry_count, uint32_t timeout, 2506 struct ata_security_password *pwd, int quiet) 2507 { 2508 2509 if (quiet == 0) 2510 atasecurity_notify(ATA_SECURITY_UNLOCK, pwd); 2511 2512 return ata_do_cmd(device, 2513 ccb, 2514 retry_count, 2515 /*flags*/CAM_DIR_OUT, 2516 /*protocol*/AP_PROTO_PIO_OUT, 2517 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2518 AP_FLAG_TLEN_SECT_CNT, 2519 /*tag_action*/MSG_SIMPLE_Q_TAG, 2520 /*command*/ATA_SECURITY_UNLOCK, 2521 /*features*/0, 2522 /*lba*/0, 2523 /*sector_count*/sizeof(*pwd) / 512, 2524 /*data_ptr*/(uint8_t *)pwd, 2525 /*dxfer_len*/sizeof(*pwd), 2526 /*timeout*/timeout, 2527 /*force48bit*/0); 2528 } 2529 2530 static int 2531 atasecurity_disable(struct cam_device *device, union ccb *ccb, 2532 int retry_count, uint32_t timeout, 2533 struct ata_security_password *pwd, int quiet) 2534 { 2535 2536 if (quiet == 0) 2537 atasecurity_notify(ATA_SECURITY_DISABLE_PASSWORD, pwd); 2538 return ata_do_cmd(device, 2539 ccb, 2540 retry_count, 2541 /*flags*/CAM_DIR_OUT, 2542 /*protocol*/AP_PROTO_PIO_OUT, 2543 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2544 AP_FLAG_TLEN_SECT_CNT, 2545 /*tag_action*/MSG_SIMPLE_Q_TAG, 2546 /*command*/ATA_SECURITY_DISABLE_PASSWORD, 2547 /*features*/0, 2548 /*lba*/0, 2549 /*sector_count*/sizeof(*pwd) / 512, 2550 /*data_ptr*/(uint8_t *)pwd, 2551 /*dxfer_len*/sizeof(*pwd), 2552 /*timeout*/timeout, 2553 /*force48bit*/0); 2554 } 2555 2556 2557 static int 2558 atasecurity_erase_confirm(struct cam_device *device, 2559 struct ata_params* ident_buf) 2560 { 2561 2562 printf("\nYou are about to ERASE ALL DATA from the following" 2563 " device:\n%s%d,%s%d: ", device->device_name, 2564 device->dev_unit_num, device->given_dev_name, 2565 device->given_unit_number); 2566 ata_print_ident(ident_buf); 2567 2568 for(;;) { 2569 char str[50]; 2570 printf("\nAre you SURE you want to ERASE ALL DATA? (yes/no) "); 2571 2572 if (fgets(str, sizeof(str), stdin) != NULL) { 2573 if (strncasecmp(str, "yes", 3) == 0) { 2574 return (1); 2575 } else if (strncasecmp(str, "no", 2) == 0) { 2576 return (0); 2577 } else { 2578 printf("Please answer \"yes\" or " 2579 "\"no\"\n"); 2580 } 2581 } 2582 } 2583 2584 /* NOTREACHED */ 2585 return (0); 2586 } 2587 2588 static int 2589 atasecurity_erase(struct cam_device *device, union ccb *ccb, 2590 int retry_count, uint32_t timeout, 2591 uint32_t erase_timeout, 2592 struct ata_security_password *pwd, int quiet) 2593 { 2594 int error; 2595 2596 if (quiet == 0) 2597 atasecurity_notify(ATA_SECURITY_ERASE_PREPARE, NULL); 2598 2599 error = ata_do_cmd(device, 2600 ccb, 2601 retry_count, 2602 /*flags*/CAM_DIR_NONE, 2603 /*protocol*/AP_PROTO_NON_DATA, 2604 /*ata_flags*/0, 2605 /*tag_action*/MSG_SIMPLE_Q_TAG, 2606 /*command*/ATA_SECURITY_ERASE_PREPARE, 2607 /*features*/0, 2608 /*lba*/0, 2609 /*sector_count*/0, 2610 /*data_ptr*/NULL, 2611 /*dxfer_len*/0, 2612 /*timeout*/timeout, 2613 /*force48bit*/0); 2614 2615 if (error != 0) 2616 return error; 2617 2618 if (quiet == 0) 2619 atasecurity_notify(ATA_SECURITY_ERASE_UNIT, pwd); 2620 2621 error = ata_do_cmd(device, 2622 ccb, 2623 retry_count, 2624 /*flags*/CAM_DIR_OUT, 2625 /*protocol*/AP_PROTO_PIO_OUT, 2626 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2627 AP_FLAG_TLEN_SECT_CNT, 2628 /*tag_action*/MSG_SIMPLE_Q_TAG, 2629 /*command*/ATA_SECURITY_ERASE_UNIT, 2630 /*features*/0, 2631 /*lba*/0, 2632 /*sector_count*/sizeof(*pwd) / 512, 2633 /*data_ptr*/(uint8_t *)pwd, 2634 /*dxfer_len*/sizeof(*pwd), 2635 /*timeout*/erase_timeout, 2636 /*force48bit*/0); 2637 2638 if (error == 0 && quiet == 0) 2639 printf("\nErase Complete\n"); 2640 2641 return error; 2642 } 2643 2644 static int 2645 atasecurity_set_password(struct cam_device *device, union ccb *ccb, 2646 int retry_count, uint32_t timeout, 2647 struct ata_security_password *pwd, int quiet) 2648 { 2649 2650 if (quiet == 0) 2651 atasecurity_notify(ATA_SECURITY_SET_PASSWORD, pwd); 2652 2653 return ata_do_cmd(device, 2654 ccb, 2655 retry_count, 2656 /*flags*/CAM_DIR_OUT, 2657 /*protocol*/AP_PROTO_PIO_OUT, 2658 /*ata_flags*/AP_FLAG_BYT_BLOK_BLOCKS | 2659 AP_FLAG_TLEN_SECT_CNT, 2660 /*tag_action*/MSG_SIMPLE_Q_TAG, 2661 /*command*/ATA_SECURITY_SET_PASSWORD, 2662 /*features*/0, 2663 /*lba*/0, 2664 /*sector_count*/sizeof(*pwd) / 512, 2665 /*data_ptr*/(uint8_t *)pwd, 2666 /*dxfer_len*/sizeof(*pwd), 2667 /*timeout*/timeout, 2668 /*force48bit*/0); 2669 } 2670 2671 static void 2672 atasecurity_print(struct ata_params *parm) 2673 { 2674 2675 printf("\nSecurity Option Value\n"); 2676 if (arglist & CAM_ARG_VERBOSE) { 2677 printf("status %04x\n", 2678 parm->security_status); 2679 } 2680 printf("supported %s\n", 2681 parm->security_status & ATA_SECURITY_SUPPORTED ? "yes" : "no"); 2682 if (!(parm->security_status & ATA_SECURITY_SUPPORTED)) 2683 return; 2684 printf("enabled %s\n", 2685 parm->security_status & ATA_SECURITY_ENABLED ? "yes" : "no"); 2686 printf("drive locked %s\n", 2687 parm->security_status & ATA_SECURITY_LOCKED ? "yes" : "no"); 2688 printf("security config frozen %s\n", 2689 parm->security_status & ATA_SECURITY_FROZEN ? "yes" : "no"); 2690 printf("count expired %s\n", 2691 parm->security_status & ATA_SECURITY_COUNT_EXP ? "yes" : "no"); 2692 printf("security level %s\n", 2693 parm->security_status & ATA_SECURITY_LEVEL ? "maximum" : "high"); 2694 printf("enhanced erase supported %s\n", 2695 parm->security_status & ATA_SECURITY_ENH_SUPP ? "yes" : "no"); 2696 printf("erase time "); 2697 atasecurity_print_time(parm->erase_time); 2698 printf("\n"); 2699 printf("enhanced erase time "); 2700 atasecurity_print_time(parm->enhanced_erase_time); 2701 printf("\n"); 2702 printf("master password rev %04x%s\n", 2703 parm->master_passwd_revision, 2704 parm->master_passwd_revision == 0x0000 || 2705 parm->master_passwd_revision == 0xFFFF ? " (unsupported)" : ""); 2706 } 2707 2708 /* 2709 * Validates and copies the password in optarg to the passed buffer. 2710 * If the password in optarg is the same length as the buffer then 2711 * the data will still be copied but no null termination will occur. 2712 */ 2713 static int 2714 ata_getpwd(uint8_t *passwd, int max, char opt) 2715 { 2716 int len; 2717 2718 len = strlen(optarg); 2719 if (len > max) { 2720 warnx("-%c password is too long", opt); 2721 return (1); 2722 } else if (len == 0) { 2723 warnx("-%c password is missing", opt); 2724 return (1); 2725 } else if (optarg[0] == '-'){ 2726 warnx("-%c password starts with '-' (generic arg?)", opt); 2727 return (1); 2728 } else if (strlen(passwd) != 0 && strcmp(passwd, optarg) != 0) { 2729 warnx("-%c password conflicts with existing password from -%c", 2730 opt, pwd_opt); 2731 return (1); 2732 } 2733 2734 /* Callers pass in a buffer which does NOT need to be terminated */ 2735 strncpy(passwd, optarg, max); 2736 pwd_opt = opt; 2737 2738 return (0); 2739 } 2740 2741 enum { 2742 ATA_HPA_ACTION_PRINT, 2743 ATA_HPA_ACTION_SET_MAX, 2744 ATA_HPA_ACTION_SET_PWD, 2745 ATA_HPA_ACTION_LOCK, 2746 ATA_HPA_ACTION_UNLOCK, 2747 ATA_HPA_ACTION_FREEZE_LOCK 2748 }; 2749 2750 static int 2751 atahpa_set_confirm(struct cam_device *device, struct ata_params* ident_buf, 2752 u_int64_t maxsize, int persist) 2753 { 2754 printf("\nYou are about to configure HPA to limit the user accessible\n" 2755 "sectors to %ju %s on the device:\n%s%d,%s%d: ", maxsize, 2756 persist ? "persistently" : "temporarily", 2757 device->device_name, device->dev_unit_num, 2758 device->given_dev_name, device->given_unit_number); 2759 ata_print_ident(ident_buf); 2760 2761 for(;;) { 2762 char str[50]; 2763 printf("\nAre you SURE you want to configure HPA? (yes/no) "); 2764 2765 if (NULL != fgets(str, sizeof(str), stdin)) { 2766 if (0 == strncasecmp(str, "yes", 3)) { 2767 return (1); 2768 } else if (0 == strncasecmp(str, "no", 2)) { 2769 return (0); 2770 } else { 2771 printf("Please answer \"yes\" or " 2772 "\"no\"\n"); 2773 } 2774 } 2775 } 2776 2777 /* NOTREACHED */ 2778 return (0); 2779 } 2780 2781 static int 2782 atahpa(struct cam_device *device, int retry_count, int timeout, 2783 int argc, char **argv, char *combinedopt) 2784 { 2785 union ccb *ccb; 2786 struct ata_params *ident_buf; 2787 struct ccb_getdev cgd; 2788 struct ata_set_max_pwd pwd; 2789 int error, confirm, quiet, c, action, actions, persist; 2790 int security, is48bit, pwdsize; 2791 u_int64_t hpasize, maxsize; 2792 2793 actions = 0; 2794 confirm = 0; 2795 quiet = 0; 2796 maxsize = 0; 2797 persist = 0; 2798 security = 0; 2799 2800 memset(&pwd, 0, sizeof(pwd)); 2801 2802 /* default action is to print hpa information */ 2803 action = ATA_HPA_ACTION_PRINT; 2804 pwdsize = sizeof(pwd.password); 2805 2806 while ((c = getopt(argc, argv, combinedopt)) != -1) { 2807 switch(c){ 2808 case 's': 2809 action = ATA_HPA_ACTION_SET_MAX; 2810 maxsize = strtoumax(optarg, NULL, 0); 2811 actions++; 2812 break; 2813 2814 case 'p': 2815 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 2816 return (1); 2817 action = ATA_HPA_ACTION_SET_PWD; 2818 security = 1; 2819 actions++; 2820 break; 2821 2822 case 'l': 2823 action = ATA_HPA_ACTION_LOCK; 2824 security = 1; 2825 actions++; 2826 break; 2827 2828 case 'U': 2829 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 2830 return (1); 2831 action = ATA_HPA_ACTION_UNLOCK; 2832 security = 1; 2833 actions++; 2834 break; 2835 2836 case 'f': 2837 action = ATA_HPA_ACTION_FREEZE_LOCK; 2838 security = 1; 2839 actions++; 2840 break; 2841 2842 case 'P': 2843 persist = 1; 2844 break; 2845 2846 case 'y': 2847 confirm++; 2848 break; 2849 2850 case 'q': 2851 quiet++; 2852 break; 2853 } 2854 } 2855 2856 if (actions > 1) { 2857 warnx("too many hpa actions specified"); 2858 return (1); 2859 } 2860 2861 if (get_cgd(device, &cgd) != 0) { 2862 warnx("couldn't get CGD"); 2863 return (1); 2864 } 2865 2866 ccb = cam_getccb(device); 2867 if (ccb == NULL) { 2868 warnx("couldn't allocate CCB"); 2869 return (1); 2870 } 2871 2872 error = ata_do_identify(device, retry_count, timeout, ccb, &ident_buf); 2873 if (error != 0) { 2874 cam_freeccb(ccb); 2875 return (1); 2876 } 2877 2878 if (quiet == 0) { 2879 printf("%s%d: ", device->device_name, device->dev_unit_num); 2880 ata_print_ident(ident_buf); 2881 camxferrate(device); 2882 } 2883 2884 if (action == ATA_HPA_ACTION_PRINT) { 2885 hpasize = 0; 2886 if (ident_buf->support.command1 & ATA_SUPPORT_PROTECTED) 2887 ata_read_native_max(device, retry_count, timeout, ccb, 2888 ident_buf, &hpasize); 2889 atahpa_print(ident_buf, hpasize, 1); 2890 2891 cam_freeccb(ccb); 2892 free(ident_buf); 2893 return (error); 2894 } 2895 2896 if (!(ident_buf->support.command1 & ATA_SUPPORT_PROTECTED)) { 2897 warnx("HPA is not supported by this device"); 2898 cam_freeccb(ccb); 2899 free(ident_buf); 2900 return (1); 2901 } 2902 2903 if (security && !(ident_buf->support.command2 & ATA_SUPPORT_MAXSECURITY)) { 2904 warnx("HPA Security is not supported by this device"); 2905 cam_freeccb(ccb); 2906 free(ident_buf); 2907 return (1); 2908 } 2909 2910 is48bit = ident_buf->support.command2 & ATA_SUPPORT_ADDRESS48; 2911 2912 /* 2913 * The ATA spec requires: 2914 * 1. Read native max addr is called directly before set max addr 2915 * 2. Read native max addr is NOT called before any other set max call 2916 */ 2917 switch(action) { 2918 case ATA_HPA_ACTION_SET_MAX: 2919 if (confirm == 0 && 2920 atahpa_set_confirm(device, ident_buf, maxsize, 2921 persist) == 0) { 2922 cam_freeccb(ccb); 2923 free(ident_buf); 2924 return (1); 2925 } 2926 2927 error = ata_read_native_max(device, retry_count, timeout, 2928 ccb, ident_buf, &hpasize); 2929 if (error == 0) { 2930 error = atahpa_set_max(device, retry_count, timeout, 2931 ccb, is48bit, maxsize, persist); 2932 if (error == 0) { 2933 if (quiet == 0) { 2934 /* redo identify to get new values */ 2935 error = ata_do_identify(device, 2936 retry_count, timeout, ccb, 2937 &ident_buf); 2938 atahpa_print(ident_buf, hpasize, 1); 2939 } 2940 /* Hint CAM to reprobe the device. */ 2941 reprobe(device); 2942 } 2943 } 2944 break; 2945 2946 case ATA_HPA_ACTION_SET_PWD: 2947 error = atahpa_password(device, retry_count, timeout, 2948 ccb, is48bit, &pwd); 2949 if (error == 0 && quiet == 0) 2950 printf("HPA password has been set\n"); 2951 break; 2952 2953 case ATA_HPA_ACTION_LOCK: 2954 error = atahpa_lock(device, retry_count, timeout, 2955 ccb, is48bit); 2956 if (error == 0 && quiet == 0) 2957 printf("HPA has been locked\n"); 2958 break; 2959 2960 case ATA_HPA_ACTION_UNLOCK: 2961 error = atahpa_unlock(device, retry_count, timeout, 2962 ccb, is48bit, &pwd); 2963 if (error == 0 && quiet == 0) 2964 printf("HPA has been unlocked\n"); 2965 break; 2966 2967 case ATA_HPA_ACTION_FREEZE_LOCK: 2968 error = atahpa_freeze_lock(device, retry_count, timeout, 2969 ccb, is48bit); 2970 if (error == 0 && quiet == 0) 2971 printf("HPA has been frozen\n"); 2972 break; 2973 2974 default: 2975 errx(1, "Option currently not supported"); 2976 } 2977 2978 cam_freeccb(ccb); 2979 free(ident_buf); 2980 2981 return (error); 2982 } 2983 2984 enum { 2985 ATA_AMA_ACTION_PRINT, 2986 ATA_AMA_ACTION_SET_MAX, 2987 ATA_AMA_ACTION_FREEZE_LOCK 2988 }; 2989 2990 static int 2991 ataama(struct cam_device *device, int retry_count, int timeout, 2992 int argc, char **argv, char *combinedopt) 2993 { 2994 union ccb *ccb; 2995 struct ata_params *ident_buf; 2996 struct ccb_getdev cgd; 2997 int error, quiet, c, action, actions; 2998 u_int64_t nativesize, maxsize; 2999 3000 actions = 0; 3001 quiet = 0; 3002 maxsize = 0; 3003 3004 /* default action is to print AMA information */ 3005 action = ATA_AMA_ACTION_PRINT; 3006 3007 while ((c = getopt(argc, argv, combinedopt)) != -1) { 3008 switch(c){ 3009 case 's': 3010 action = ATA_AMA_ACTION_SET_MAX; 3011 maxsize = strtoumax(optarg, NULL, 0); 3012 actions++; 3013 break; 3014 3015 case 'f': 3016 action = ATA_AMA_ACTION_FREEZE_LOCK; 3017 actions++; 3018 break; 3019 3020 case 'q': 3021 quiet++; 3022 break; 3023 } 3024 } 3025 3026 if (actions > 1) { 3027 warnx("too many AMA actions specified"); 3028 return (1); 3029 } 3030 3031 if (get_cgd(device, &cgd) != 0) { 3032 warnx("couldn't get CGD"); 3033 return (1); 3034 } 3035 3036 ccb = cam_getccb(device); 3037 if (ccb == NULL) { 3038 warnx("couldn't allocate CCB"); 3039 return (1); 3040 } 3041 3042 error = ata_do_identify(device, retry_count, timeout, ccb, &ident_buf); 3043 if (error != 0) { 3044 cam_freeccb(ccb); 3045 return (1); 3046 } 3047 3048 if (quiet == 0) { 3049 printf("%s%d: ", device->device_name, device->dev_unit_num); 3050 ata_print_ident(ident_buf); 3051 camxferrate(device); 3052 } 3053 3054 if (action == ATA_AMA_ACTION_PRINT) { 3055 nativesize = 0; 3056 if (ident_buf->support2 & ATA_SUPPORT_AMAX_ADDR) 3057 ata_get_native_max(device, retry_count, timeout, ccb, 3058 &nativesize); 3059 ataama_print(ident_buf, nativesize, 1); 3060 3061 cam_freeccb(ccb); 3062 free(ident_buf); 3063 return (error); 3064 } 3065 3066 if (!(ident_buf->support2 & ATA_SUPPORT_AMAX_ADDR)) { 3067 warnx("Accessible Max Address is not supported by this device"); 3068 cam_freeccb(ccb); 3069 free(ident_buf); 3070 return (1); 3071 } 3072 3073 switch(action) { 3074 case ATA_AMA_ACTION_SET_MAX: 3075 error = ata_get_native_max(device, retry_count, timeout, ccb, 3076 &nativesize); 3077 if (error == 0) { 3078 error = ataama_set(device, retry_count, timeout, 3079 ccb, maxsize); 3080 if (error == 0) { 3081 if (quiet == 0) { 3082 /* redo identify to get new values */ 3083 error = ata_do_identify(device, 3084 retry_count, timeout, ccb, 3085 &ident_buf); 3086 ataama_print(ident_buf, nativesize, 1); 3087 } 3088 /* Hint CAM to reprobe the device. */ 3089 reprobe(device); 3090 } 3091 } 3092 break; 3093 3094 case ATA_AMA_ACTION_FREEZE_LOCK: 3095 error = ataama_freeze(device, retry_count, timeout, 3096 ccb); 3097 if (error == 0 && quiet == 0) 3098 printf("Accessible Max Address has been frozen\n"); 3099 break; 3100 3101 default: 3102 errx(1, "Option currently not supported"); 3103 } 3104 3105 cam_freeccb(ccb); 3106 free(ident_buf); 3107 3108 return (error); 3109 } 3110 3111 static int 3112 atasecurity(struct cam_device *device, int retry_count, int timeout, 3113 int argc, char **argv, char *combinedopt) 3114 { 3115 union ccb *ccb; 3116 struct ata_params *ident_buf; 3117 int error, confirm, quiet, c, action, actions, setpwd; 3118 int security_enabled, erase_timeout, pwdsize; 3119 struct ata_security_password pwd; 3120 3121 actions = 0; 3122 setpwd = 0; 3123 erase_timeout = 0; 3124 confirm = 0; 3125 quiet = 0; 3126 3127 memset(&pwd, 0, sizeof(pwd)); 3128 3129 /* default action is to print security information */ 3130 action = ATA_SECURITY_ACTION_PRINT; 3131 3132 /* user is master by default as its safer that way */ 3133 pwd.ctrl |= ATA_SECURITY_PASSWORD_MASTER; 3134 pwdsize = sizeof(pwd.password); 3135 3136 while ((c = getopt(argc, argv, combinedopt)) != -1) { 3137 switch(c){ 3138 case 'f': 3139 action = ATA_SECURITY_ACTION_FREEZE; 3140 actions++; 3141 break; 3142 3143 case 'U': 3144 if (strcasecmp(optarg, "user") == 0) { 3145 pwd.ctrl |= ATA_SECURITY_PASSWORD_USER; 3146 pwd.ctrl &= ~ATA_SECURITY_PASSWORD_MASTER; 3147 } else if (strcasecmp(optarg, "master") == 0) { 3148 pwd.ctrl |= ATA_SECURITY_PASSWORD_MASTER; 3149 pwd.ctrl &= ~ATA_SECURITY_PASSWORD_USER; 3150 } else { 3151 warnx("-U argument '%s' is invalid (must be " 3152 "'user' or 'master')", optarg); 3153 return (1); 3154 } 3155 break; 3156 3157 case 'l': 3158 if (strcasecmp(optarg, "high") == 0) { 3159 pwd.ctrl |= ATA_SECURITY_LEVEL_HIGH; 3160 pwd.ctrl &= ~ATA_SECURITY_LEVEL_MAXIMUM; 3161 } else if (strcasecmp(optarg, "maximum") == 0) { 3162 pwd.ctrl |= ATA_SECURITY_LEVEL_MAXIMUM; 3163 pwd.ctrl &= ~ATA_SECURITY_LEVEL_HIGH; 3164 } else { 3165 warnx("-l argument '%s' is unknown (must be " 3166 "'high' or 'maximum')", optarg); 3167 return (1); 3168 } 3169 break; 3170 3171 case 'k': 3172 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 3173 return (1); 3174 action = ATA_SECURITY_ACTION_UNLOCK; 3175 actions++; 3176 break; 3177 3178 case 'd': 3179 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 3180 return (1); 3181 action = ATA_SECURITY_ACTION_DISABLE; 3182 actions++; 3183 break; 3184 3185 case 'e': 3186 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 3187 return (1); 3188 action = ATA_SECURITY_ACTION_ERASE; 3189 actions++; 3190 break; 3191 3192 case 'h': 3193 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 3194 return (1); 3195 pwd.ctrl |= ATA_SECURITY_ERASE_ENHANCED; 3196 action = ATA_SECURITY_ACTION_ERASE_ENHANCED; 3197 actions++; 3198 break; 3199 3200 case 's': 3201 if (ata_getpwd(pwd.password, pwdsize, c) != 0) 3202 return (1); 3203 setpwd = 1; 3204 if (action == ATA_SECURITY_ACTION_PRINT) 3205 action = ATA_SECURITY_ACTION_SET_PASSWORD; 3206 /* 3207 * Don't increment action as this can be combined 3208 * with other actions. 3209 */ 3210 break; 3211 3212 case 'y': 3213 confirm++; 3214 break; 3215 3216 case 'q': 3217 quiet++; 3218 break; 3219 3220 case 'T': 3221 erase_timeout = atoi(optarg) * 1000; 3222 break; 3223 } 3224 } 3225 3226 if (actions > 1) { 3227 warnx("too many security actions specified"); 3228 return (1); 3229 } 3230 3231 if ((ccb = cam_getccb(device)) == NULL) { 3232 warnx("couldn't allocate CCB"); 3233 return (1); 3234 } 3235 3236 error = ata_do_identify(device, retry_count, timeout, ccb, &ident_buf); 3237 if (error != 0) { 3238 cam_freeccb(ccb); 3239 return (1); 3240 } 3241 3242 if (quiet == 0) { 3243 printf("%s%d: ", device->device_name, device->dev_unit_num); 3244 ata_print_ident(ident_buf); 3245 camxferrate(device); 3246 } 3247 3248 if (action == ATA_SECURITY_ACTION_PRINT) { 3249 atasecurity_print(ident_buf); 3250 free(ident_buf); 3251 cam_freeccb(ccb); 3252 return (0); 3253 } 3254 3255 if ((ident_buf->support.command1 & ATA_SUPPORT_SECURITY) == 0) { 3256 warnx("Security not supported"); 3257 free(ident_buf); 3258 cam_freeccb(ccb); 3259 return (1); 3260 } 3261 3262 /* default timeout 15 seconds the same as linux hdparm */ 3263 timeout = timeout ? timeout : 15 * 1000; 3264 3265 security_enabled = ident_buf->security_status & ATA_SECURITY_ENABLED; 3266 3267 /* first set the password if requested */ 3268 if (setpwd == 1) { 3269 /* confirm we can erase before setting the password if erasing */ 3270 if (confirm == 0 && 3271 (action == ATA_SECURITY_ACTION_ERASE_ENHANCED || 3272 action == ATA_SECURITY_ACTION_ERASE) && 3273 atasecurity_erase_confirm(device, ident_buf) == 0) { 3274 cam_freeccb(ccb); 3275 free(ident_buf); 3276 return (error); 3277 } 3278 3279 if (pwd.ctrl & ATA_SECURITY_PASSWORD_MASTER) { 3280 pwd.revision = ident_buf->master_passwd_revision; 3281 if (pwd.revision != 0 && pwd.revision != 0xfff && 3282 --pwd.revision == 0) { 3283 pwd.revision = 0xfffe; 3284 } 3285 } 3286 error = atasecurity_set_password(device, ccb, retry_count, 3287 timeout, &pwd, quiet); 3288 if (error != 0) { 3289 cam_freeccb(ccb); 3290 free(ident_buf); 3291 return (error); 3292 } 3293 security_enabled = 1; 3294 } 3295 3296 switch(action) { 3297 case ATA_SECURITY_ACTION_FREEZE: 3298 error = atasecurity_freeze(device, ccb, retry_count, 3299 timeout, quiet); 3300 break; 3301 3302 case ATA_SECURITY_ACTION_UNLOCK: 3303 if (security_enabled) { 3304 if (ident_buf->security_status & ATA_SECURITY_LOCKED) { 3305 error = atasecurity_unlock(device, ccb, 3306 retry_count, timeout, &pwd, quiet); 3307 } else { 3308 warnx("Can't unlock, drive is not locked"); 3309 error = 1; 3310 } 3311 } else { 3312 warnx("Can't unlock, security is disabled"); 3313 error = 1; 3314 } 3315 break; 3316 3317 case ATA_SECURITY_ACTION_DISABLE: 3318 if (security_enabled) { 3319 /* First unlock the drive if its locked */ 3320 if (ident_buf->security_status & ATA_SECURITY_LOCKED) { 3321 error = atasecurity_unlock(device, ccb, 3322 retry_count, 3323 timeout, 3324 &pwd, 3325 quiet); 3326 } 3327 3328 if (error == 0) { 3329 error = atasecurity_disable(device, 3330 ccb, 3331 retry_count, 3332 timeout, 3333 &pwd, 3334 quiet); 3335 } 3336 } else { 3337 warnx("Can't disable security (already disabled)"); 3338 error = 1; 3339 } 3340 break; 3341 3342 case ATA_SECURITY_ACTION_ERASE: 3343 if (security_enabled) { 3344 if (erase_timeout == 0) { 3345 erase_timeout = atasecurity_erase_timeout_msecs( 3346 ident_buf->erase_time); 3347 } 3348 3349 error = atasecurity_erase(device, ccb, retry_count, 3350 timeout, erase_timeout, &pwd, quiet); 3351 } else { 3352 warnx("Can't secure erase (security is disabled)"); 3353 error = 1; 3354 } 3355 break; 3356 3357 case ATA_SECURITY_ACTION_ERASE_ENHANCED: 3358 if (security_enabled) { 3359 if (ident_buf->security_status & ATA_SECURITY_ENH_SUPP) { 3360 if (erase_timeout == 0) { 3361 erase_timeout = 3362 atasecurity_erase_timeout_msecs( 3363 ident_buf->enhanced_erase_time); 3364 } 3365 3366 error = atasecurity_erase(device, ccb, 3367 retry_count, timeout, 3368 erase_timeout, &pwd, 3369 quiet); 3370 } else { 3371 warnx("Enhanced erase is not supported"); 3372 error = 1; 3373 } 3374 } else { 3375 warnx("Can't secure erase (enhanced), " 3376 "(security is disabled)"); 3377 error = 1; 3378 } 3379 break; 3380 } 3381 3382 cam_freeccb(ccb); 3383 free(ident_buf); 3384 3385 return (error); 3386 } 3387 3388 /* 3389 * Convert periph name into a bus, target and lun. 3390 * 3391 * Returns the number of parsed components, or 0. 3392 */ 3393 static int 3394 parse_btl_name(char *tstr, path_id_t *bus, target_id_t *target, lun_id_t *lun, 3395 cam_argmask *arglst) 3396 { 3397 int fd; 3398 union ccb ccb; 3399 3400 bzero(&ccb, sizeof(ccb)); 3401 ccb.ccb_h.func_code = XPT_GDEVLIST; 3402 if (cam_get_device(tstr, ccb.cgdl.periph_name, 3403 sizeof(ccb.cgdl.periph_name), &ccb.cgdl.unit_number) == -1) { 3404 warnx("%s", cam_errbuf); 3405 return (0); 3406 } 3407 3408 /* 3409 * Attempt to get the passthrough device. This ioctl will 3410 * fail if the device name is null, if the device doesn't 3411 * exist, or if the passthrough driver isn't in the kernel. 3412 */ 3413 if ((fd = open(XPT_DEVICE, O_RDWR)) == -1) { 3414 warn("Unable to open %s", XPT_DEVICE); 3415 return (0); 3416 } 3417 if (ioctl(fd, CAMGETPASSTHRU, &ccb) == -1) { 3418 warn("Unable to find bus:target:lun for device %s%d", 3419 ccb.cgdl.periph_name, ccb.cgdl.unit_number); 3420 close(fd); 3421 return (0); 3422 } 3423 close(fd); 3424 if ((ccb.ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 3425 const struct cam_status_entry *entry; 3426 3427 entry = cam_fetch_status_entry(ccb.ccb_h.status); 3428 warnx("Unable to find bus:target_lun for device %s%d, " 3429 "CAM status: %s (%#x)", 3430 ccb.cgdl.periph_name, ccb.cgdl.unit_number, 3431 entry ? entry->status_text : "Unknown", 3432 ccb.ccb_h.status); 3433 return (0); 3434 } 3435 3436 /* 3437 * The kernel fills in the bus/target/lun. We don't 3438 * need the passthrough device name and unit number since 3439 * we aren't going to open it. 3440 */ 3441 *bus = ccb.ccb_h.path_id; 3442 *target = ccb.ccb_h.target_id; 3443 *lun = ccb.ccb_h.target_lun; 3444 *arglst |= CAM_ARG_BUS | CAM_ARG_TARGET | CAM_ARG_LUN; 3445 return (3); 3446 } 3447 3448 /* 3449 * Parse out a bus, or a bus, target and lun in the following 3450 * format: 3451 * bus 3452 * bus:target 3453 * bus:target:lun 3454 * 3455 * Returns the number of parsed components, or 0. 3456 */ 3457 static int 3458 parse_btl(char *tstr, path_id_t *bus, target_id_t *target, lun_id_t *lun, 3459 cam_argmask *arglst) 3460 { 3461 char *tmpstr, *end; 3462 int convs = 0; 3463 3464 *bus = CAM_BUS_WILDCARD; 3465 *target = CAM_TARGET_WILDCARD; 3466 *lun = CAM_LUN_WILDCARD; 3467 3468 while (isspace(*tstr) && (*tstr != '\0')) 3469 tstr++; 3470 3471 if (strncasecmp(tstr, "all", strlen("all")) == 0) { 3472 arglist |= CAM_ARG_BUS; 3473 return (1); 3474 } 3475 3476 if (!isdigit(*tstr)) 3477 return (parse_btl_name(tstr, bus, target, lun, arglst)); 3478 3479 tmpstr = strsep(&tstr, ":"); 3480 if ((tmpstr != NULL) && (*tmpstr != '\0')) { 3481 *bus = strtol(tmpstr, &end, 0); 3482 if (*end != '\0') 3483 return (0); 3484 *arglst |= CAM_ARG_BUS; 3485 convs++; 3486 tmpstr = strsep(&tstr, ":"); 3487 if ((tmpstr != NULL) && (*tmpstr != '\0')) { 3488 *target = strtol(tmpstr, &end, 0); 3489 if (*end != '\0') 3490 return (0); 3491 *arglst |= CAM_ARG_TARGET; 3492 convs++; 3493 tmpstr = strsep(&tstr, ":"); 3494 if ((tmpstr != NULL) && (*tmpstr != '\0')) { 3495 *lun = strtoll(tmpstr, &end, 0); 3496 if (*end != '\0') 3497 return (0); 3498 *arglst |= CAM_ARG_LUN; 3499 convs++; 3500 } 3501 } 3502 } 3503 3504 return convs; 3505 } 3506 3507 static int 3508 dorescan_or_reset(int argc, char **argv, int rescan) 3509 { 3510 static const char must[] = 3511 "you must specify \"all\", a bus, a bus:target:lun or periph to %s"; 3512 int rv, error = 0; 3513 path_id_t bus = CAM_BUS_WILDCARD; 3514 target_id_t target = CAM_TARGET_WILDCARD; 3515 lun_id_t lun = CAM_LUN_WILDCARD; 3516 char *tstr; 3517 3518 if (argc < 3) { 3519 warnx(must, rescan? "rescan" : "reset"); 3520 return (1); 3521 } 3522 3523 tstr = argv[optind]; 3524 while (isspace(*tstr) && (*tstr != '\0')) 3525 tstr++; 3526 if (strncasecmp(tstr, "all", strlen("all")) == 0) 3527 arglist |= CAM_ARG_BUS; 3528 else { 3529 rv = parse_btl(argv[optind], &bus, &target, &lun, &arglist); 3530 if (rv != 1 && rv != 3) { 3531 warnx(must, rescan ? "rescan" : "reset"); 3532 return (1); 3533 } 3534 } 3535 3536 if (arglist & CAM_ARG_LUN) 3537 error = scanlun_or_reset_dev(bus, target, lun, rescan); 3538 else 3539 error = rescan_or_reset_bus(bus, rescan); 3540 3541 return (error); 3542 } 3543 3544 static int 3545 rescan_or_reset_bus(path_id_t bus, int rescan) 3546 { 3547 union ccb *ccb = NULL, *matchccb = NULL; 3548 int fd = -1, retval; 3549 int bufsize; 3550 3551 retval = 0; 3552 3553 if ((fd = open(XPT_DEVICE, O_RDWR)) < 0) { 3554 warnx("error opening transport layer device %s", XPT_DEVICE); 3555 warn("%s", XPT_DEVICE); 3556 return (1); 3557 } 3558 3559 ccb = malloc(sizeof(*ccb)); 3560 if (ccb == NULL) { 3561 warn("failed to allocate CCB"); 3562 retval = 1; 3563 goto bailout; 3564 } 3565 bzero(ccb, sizeof(*ccb)); 3566 3567 if (bus != CAM_BUS_WILDCARD) { 3568 ccb->ccb_h.func_code = rescan ? XPT_SCAN_BUS : XPT_RESET_BUS; 3569 ccb->ccb_h.path_id = bus; 3570 ccb->ccb_h.target_id = CAM_TARGET_WILDCARD; 3571 ccb->ccb_h.target_lun = CAM_LUN_WILDCARD; 3572 ccb->crcn.flags = CAM_FLAG_NONE; 3573 3574 /* run this at a low priority */ 3575 ccb->ccb_h.pinfo.priority = 5; 3576 3577 if (ioctl(fd, CAMIOCOMMAND, ccb) == -1) { 3578 warn("CAMIOCOMMAND ioctl failed"); 3579 retval = 1; 3580 goto bailout; 3581 } 3582 3583 if ((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP) { 3584 fprintf(stdout, "%s of bus %d was successful\n", 3585 rescan ? "Re-scan" : "Reset", bus); 3586 } else { 3587 fprintf(stdout, "%s of bus %d returned error %#x\n", 3588 rescan ? "Re-scan" : "Reset", bus, 3589 ccb->ccb_h.status & CAM_STATUS_MASK); 3590 retval = 1; 3591 } 3592 3593 goto bailout; 3594 } 3595 3596 3597 /* 3598 * The right way to handle this is to modify the xpt so that it can 3599 * handle a wildcarded bus in a rescan or reset CCB. At the moment 3600 * that isn't implemented, so instead we enumerate the buses and 3601 * send the rescan or reset to those buses in the case where the 3602 * given bus is -1 (wildcard). We don't send a rescan or reset 3603 * to the xpt bus; sending a rescan to the xpt bus is effectively a 3604 * no-op, sending a rescan to the xpt bus would result in a status of 3605 * CAM_REQ_INVALID. 3606 */ 3607 matchccb = malloc(sizeof(*matchccb)); 3608 if (matchccb == NULL) { 3609 warn("failed to allocate CCB"); 3610 retval = 1; 3611 goto bailout; 3612 } 3613 bzero(matchccb, sizeof(*matchccb)); 3614 matchccb->ccb_h.func_code = XPT_DEV_MATCH; 3615 matchccb->ccb_h.path_id = CAM_BUS_WILDCARD; 3616 bufsize = sizeof(struct dev_match_result) * 20; 3617 matchccb->cdm.match_buf_len = bufsize; 3618 matchccb->cdm.matches=(struct dev_match_result *)malloc(bufsize); 3619 if (matchccb->cdm.matches == NULL) { 3620 warnx("can't malloc memory for matches"); 3621 retval = 1; 3622 goto bailout; 3623 } 3624 matchccb->cdm.num_matches = 0; 3625 3626 matchccb->cdm.num_patterns = 1; 3627 matchccb->cdm.pattern_buf_len = sizeof(struct dev_match_pattern); 3628 3629 matchccb->cdm.patterns = (struct dev_match_pattern *)malloc( 3630 matchccb->cdm.pattern_buf_len); 3631 if (matchccb->cdm.patterns == NULL) { 3632 warnx("can't malloc memory for patterns"); 3633 retval = 1; 3634 goto bailout; 3635 } 3636 matchccb->cdm.patterns[0].type = DEV_MATCH_BUS; 3637 matchccb->cdm.patterns[0].pattern.bus_pattern.flags = BUS_MATCH_ANY; 3638 3639 do { 3640 unsigned int i; 3641 3642 if (ioctl(fd, CAMIOCOMMAND, matchccb) == -1) { 3643 warn("CAMIOCOMMAND ioctl failed"); 3644 retval = 1; 3645 goto bailout; 3646 } 3647 3648 if ((matchccb->ccb_h.status != CAM_REQ_CMP) 3649 || ((matchccb->cdm.status != CAM_DEV_MATCH_LAST) 3650 && (matchccb->cdm.status != CAM_DEV_MATCH_MORE))) { 3651 warnx("got CAM error %#x, CDM error %d\n", 3652 matchccb->ccb_h.status, matchccb->cdm.status); 3653 retval = 1; 3654 goto bailout; 3655 } 3656 3657 for (i = 0; i < matchccb->cdm.num_matches; i++) { 3658 struct bus_match_result *bus_result; 3659 3660 /* This shouldn't happen. */ 3661 if (matchccb->cdm.matches[i].type != DEV_MATCH_BUS) 3662 continue; 3663 3664 bus_result =&matchccb->cdm.matches[i].result.bus_result; 3665 3666 /* 3667 * We don't want to rescan or reset the xpt bus. 3668 * See above. 3669 */ 3670 if (bus_result->path_id == CAM_XPT_PATH_ID) 3671 continue; 3672 3673 ccb->ccb_h.func_code = rescan ? XPT_SCAN_BUS : 3674 XPT_RESET_BUS; 3675 ccb->ccb_h.path_id = bus_result->path_id; 3676 ccb->ccb_h.target_id = CAM_TARGET_WILDCARD; 3677 ccb->ccb_h.target_lun = CAM_LUN_WILDCARD; 3678 ccb->crcn.flags = CAM_FLAG_NONE; 3679 3680 /* run this at a low priority */ 3681 ccb->ccb_h.pinfo.priority = 5; 3682 3683 if (ioctl(fd, CAMIOCOMMAND, ccb) == -1) { 3684 warn("CAMIOCOMMAND ioctl failed"); 3685 retval = 1; 3686 goto bailout; 3687 } 3688 3689 if ((ccb->ccb_h.status & CAM_STATUS_MASK)==CAM_REQ_CMP){ 3690 fprintf(stdout, "%s of bus %d was successful\n", 3691 rescan? "Re-scan" : "Reset", 3692 bus_result->path_id); 3693 } else { 3694 /* 3695 * Don't bail out just yet, maybe the other 3696 * rescan or reset commands will complete 3697 * successfully. 3698 */ 3699 fprintf(stderr, "%s of bus %d returned error " 3700 "%#x\n", rescan? "Re-scan" : "Reset", 3701 bus_result->path_id, 3702 ccb->ccb_h.status & CAM_STATUS_MASK); 3703 retval = 1; 3704 } 3705 } 3706 } while ((matchccb->ccb_h.status == CAM_REQ_CMP) 3707 && (matchccb->cdm.status == CAM_DEV_MATCH_MORE)); 3708 3709 bailout: 3710 3711 if (fd != -1) 3712 close(fd); 3713 3714 if (matchccb != NULL) { 3715 free(matchccb->cdm.patterns); 3716 free(matchccb->cdm.matches); 3717 free(matchccb); 3718 } 3719 free(ccb); 3720 3721 return (retval); 3722 } 3723 3724 static int 3725 scanlun_or_reset_dev(path_id_t bus, target_id_t target, lun_id_t lun, int scan) 3726 { 3727 union ccb ccb; 3728 struct cam_device *device; 3729 int fd; 3730 3731 device = NULL; 3732 3733 if (bus == CAM_BUS_WILDCARD) { 3734 warnx("invalid bus number %d", bus); 3735 return (1); 3736 } 3737 3738 if (target == CAM_TARGET_WILDCARD) { 3739 warnx("invalid target number %d", target); 3740 return (1); 3741 } 3742 3743 if (lun == CAM_LUN_WILDCARD) { 3744 warnx("invalid lun number %jx", (uintmax_t)lun); 3745 return (1); 3746 } 3747 3748 fd = -1; 3749 3750 bzero(&ccb, sizeof(union ccb)); 3751 3752 if (scan) { 3753 if ((fd = open(XPT_DEVICE, O_RDWR)) < 0) { 3754 warnx("error opening transport layer device %s\n", 3755 XPT_DEVICE); 3756 warn("%s", XPT_DEVICE); 3757 return (1); 3758 } 3759 } else { 3760 device = cam_open_btl(bus, target, lun, O_RDWR, NULL); 3761 if (device == NULL) { 3762 warnx("%s", cam_errbuf); 3763 return (1); 3764 } 3765 } 3766 3767 ccb.ccb_h.func_code = (scan)? XPT_SCAN_LUN : XPT_RESET_DEV; 3768 ccb.ccb_h.path_id = bus; 3769 ccb.ccb_h.target_id = target; 3770 ccb.ccb_h.target_lun = lun; 3771 ccb.ccb_h.timeout = 5000; 3772 ccb.crcn.flags = CAM_FLAG_NONE; 3773 3774 /* run this at a low priority */ 3775 ccb.ccb_h.pinfo.priority = 5; 3776 3777 if (scan) { 3778 if (ioctl(fd, CAMIOCOMMAND, &ccb) < 0) { 3779 warn("CAMIOCOMMAND ioctl failed"); 3780 close(fd); 3781 return (1); 3782 } 3783 } else { 3784 if (cam_send_ccb(device, &ccb) < 0) { 3785 warn("error sending XPT_RESET_DEV CCB"); 3786 cam_close_device(device); 3787 return (1); 3788 } 3789 } 3790 3791 if (scan) 3792 close(fd); 3793 else 3794 cam_close_device(device); 3795 3796 /* 3797 * An error code of CAM_BDR_SENT is normal for a BDR request. 3798 */ 3799 if (((ccb.ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP) 3800 || ((!scan) 3801 && ((ccb.ccb_h.status & CAM_STATUS_MASK) == CAM_BDR_SENT))) { 3802 fprintf(stdout, "%s of %d:%d:%jx was successful\n", 3803 scan? "Re-scan" : "Reset", bus, target, (uintmax_t)lun); 3804 return (0); 3805 } else { 3806 fprintf(stdout, "%s of %d:%d:%jx returned error %#x\n", 3807 scan? "Re-scan" : "Reset", bus, target, (uintmax_t)lun, 3808 ccb.ccb_h.status & CAM_STATUS_MASK); 3809 return (1); 3810 } 3811 } 3812 3813 3814 static struct scsi_nv defect_list_type_map[] = { 3815 { "block", SRDD10_BLOCK_FORMAT }, 3816 { "extbfi", SRDD10_EXT_BFI_FORMAT }, 3817 { "extphys", SRDD10_EXT_PHYS_FORMAT }, 3818 { "longblock", SRDD10_LONG_BLOCK_FORMAT }, 3819 { "bfi", SRDD10_BYTES_FROM_INDEX_FORMAT }, 3820 { "phys", SRDD10_PHYSICAL_SECTOR_FORMAT } 3821 }; 3822 3823 static int 3824 readdefects(struct cam_device *device, int argc, char **argv, 3825 char *combinedopt, int task_attr, int retry_count, int timeout) 3826 { 3827 union ccb *ccb = NULL; 3828 struct scsi_read_defect_data_hdr_10 *hdr10 = NULL; 3829 struct scsi_read_defect_data_hdr_12 *hdr12 = NULL; 3830 size_t hdr_size = 0, entry_size = 0; 3831 uint8_t *defect_list = NULL; 3832 uint8_t list_format = 0; 3833 uint32_t dlist_length = 0; 3834 uint32_t returned_length = 0, valid_len = 0; 3835 uint32_t num_returned = 0, num_valid = 0; 3836 uint32_t max_possible_size = 0, hdr_max = 0; 3837 uint32_t starting_offset = 0; 3838 uint8_t returned_format, returned_type; 3839 unsigned int i; 3840 int c, error = 0; 3841 int mads = 0; 3842 bool summary = false, quiet = false, list_type_set = false; 3843 bool get_length = true, use_12byte = false, first_pass = true; 3844 bool hex_format = false; 3845 3846 while ((c = getopt(argc, argv, combinedopt)) != -1) { 3847 switch(c){ 3848 case 'f': 3849 { 3850 scsi_nv_status status; 3851 int entry_num = 0; 3852 3853 if (list_type_set) { 3854 warnx("%s: -f specified twice", __func__); 3855 error = 1; 3856 goto defect_bailout; 3857 } 3858 3859 status = scsi_get_nv(defect_list_type_map, 3860 sizeof(defect_list_type_map) / 3861 sizeof(defect_list_type_map[0]), optarg, 3862 &entry_num, SCSI_NV_FLAG_IG_CASE); 3863 3864 if (status == SCSI_NV_FOUND) { 3865 list_format |= defect_list_type_map[ 3866 entry_num].value; 3867 list_type_set = true; 3868 } else { 3869 warnx("%s: %s %s option %s", __func__, 3870 (status == SCSI_NV_AMBIGUOUS) ? 3871 "ambiguous" : "invalid", "defect list type", 3872 optarg); 3873 error = 1; 3874 goto defect_bailout; 3875 } 3876 break; 3877 } 3878 case 'G': 3879 list_format |= SRDD10_GLIST; 3880 break; 3881 case 'P': 3882 list_format |= SRDD10_PLIST; 3883 break; 3884 case 'q': 3885 quiet = true; 3886 break; 3887 case 's': 3888 summary = true; 3889 break; 3890 case 'S': { 3891 char *endptr; 3892 3893 starting_offset = strtoul(optarg, &endptr, 0); 3894 if (*endptr != '\0') { 3895 error = 1; 3896 warnx("invalid starting offset %s", optarg); 3897 goto defect_bailout; 3898 } 3899 use_12byte = true; 3900 break; 3901 } 3902 case 'X': 3903 hex_format = true; 3904 break; 3905 default: 3906 break; 3907 } 3908 } 3909 3910 if (!list_type_set) { 3911 error = 1; 3912 warnx("no defect list format specified"); 3913 goto defect_bailout; 3914 } 3915 3916 /* 3917 * This implies a summary, and was the previous behavior. 3918 */ 3919 if ((list_format & ~SRDD10_DLIST_FORMAT_MASK) == 0) 3920 summary = true; 3921 3922 ccb = cam_getccb(device); 3923 3924 /* 3925 * We start off asking for just the header to determine how much defect 3926 * data is available. Some Hitachi drives return an error if you ask 3927 * for more data than the drive has. Once we know the length, we retry 3928 * the command with the returned length. When we're retrying the with 3929 * 12-byte command, we're always changing to the 12-byte command and 3930 * need to get the length. Simplify the logic below by always setting 3931 * use_12byte in this case with this slightly more complex logic here. 3932 */ 3933 if (!use_12byte) { 3934 dlist_length = sizeof(*hdr10); 3935 } else { 3936 retry_12byte: 3937 get_length = true; 3938 use_12byte = true; 3939 dlist_length = sizeof(*hdr12); 3940 } 3941 3942 retry: 3943 if (defect_list != NULL) { 3944 free(defect_list); 3945 defect_list = NULL; 3946 } 3947 defect_list = malloc(dlist_length); 3948 if (defect_list == NULL) { 3949 warnx("can't malloc memory for defect list"); 3950 error = 1; 3951 goto defect_bailout; 3952 } 3953 3954 next_batch: 3955 bzero(defect_list, dlist_length); 3956 3957 /* 3958 * cam_getccb() zeros the CCB header only. So we need to zero the 3959 * payload portion of the ccb. 3960 */ 3961 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->csio); 3962 3963 scsi_read_defects(&ccb->csio, 3964 /*retries*/ retry_count, 3965 /*cbfcnp*/ NULL, 3966 /*tag_action*/ task_attr, 3967 /*list_format*/ list_format, 3968 /*addr_desc_index*/ starting_offset, 3969 /*data_ptr*/ defect_list, 3970 /*dxfer_len*/ dlist_length, 3971 /*minimum_cmd_size*/ use_12byte ? 12 : 0, 3972 /*sense_len*/ SSD_FULL_SIZE, 3973 /*timeout*/ timeout ? timeout : 5000); 3974 3975 /* Disable freezing the device queue */ 3976 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 3977 3978 if (cam_send_ccb(device, ccb) < 0) { 3979 warn("error sending READ DEFECT DATA command"); 3980 error = 1; 3981 goto defect_bailout; 3982 } 3983 3984 valid_len = ccb->csio.dxfer_len - ccb->csio.resid; 3985 3986 if (!use_12byte) { 3987 hdr10 = (struct scsi_read_defect_data_hdr_10 *)defect_list; 3988 hdr_size = sizeof(*hdr10); 3989 hdr_max = SRDDH10_MAX_LENGTH; 3990 3991 if (valid_len >= hdr_size) { 3992 returned_length = scsi_2btoul(hdr10->length); 3993 returned_format = hdr10->format; 3994 } else { 3995 returned_length = 0; 3996 returned_format = 0; 3997 } 3998 } else { 3999 hdr12 = (struct scsi_read_defect_data_hdr_12 *)defect_list; 4000 hdr_size = sizeof(*hdr12); 4001 hdr_max = SRDDH12_MAX_LENGTH; 4002 4003 if (valid_len >= hdr_size) { 4004 returned_length = scsi_4btoul(hdr12->length); 4005 returned_format = hdr12->format; 4006 } else { 4007 returned_length = 0; 4008 returned_format = 0; 4009 } 4010 } 4011 4012 returned_type = returned_format & SRDDH10_DLIST_FORMAT_MASK; 4013 switch (returned_type) { 4014 case SRDD10_BLOCK_FORMAT: 4015 entry_size = sizeof(struct scsi_defect_desc_block); 4016 break; 4017 case SRDD10_LONG_BLOCK_FORMAT: 4018 entry_size = sizeof(struct scsi_defect_desc_long_block); 4019 break; 4020 case SRDD10_EXT_PHYS_FORMAT: 4021 case SRDD10_PHYSICAL_SECTOR_FORMAT: 4022 entry_size = sizeof(struct scsi_defect_desc_phys_sector); 4023 break; 4024 case SRDD10_EXT_BFI_FORMAT: 4025 case SRDD10_BYTES_FROM_INDEX_FORMAT: 4026 entry_size = sizeof(struct scsi_defect_desc_bytes_from_index); 4027 break; 4028 default: 4029 warnx("Unknown defect format 0x%x\n", returned_type); 4030 error = 1; 4031 goto defect_bailout; 4032 break; 4033 } 4034 4035 max_possible_size = (hdr_max / entry_size) * entry_size; 4036 num_returned = returned_length / entry_size; 4037 num_valid = min(returned_length, valid_len - hdr_size); 4038 num_valid /= entry_size; 4039 4040 if (get_length) { 4041 get_length = false; 4042 4043 if ((ccb->ccb_h.status & CAM_STATUS_MASK) == 4044 CAM_SCSI_STATUS_ERROR) { 4045 struct scsi_sense_data *sense; 4046 int error_code, sense_key, asc, ascq; 4047 4048 sense = &ccb->csio.sense_data; 4049 scsi_extract_sense_len(sense, ccb->csio.sense_len - 4050 ccb->csio.sense_resid, &error_code, &sense_key, 4051 &asc, &ascq, /*show_errors*/ 1); 4052 4053 /* 4054 * If the drive is reporting that it just doesn't 4055 * support the defect list format, go ahead and use 4056 * the length it reported. Otherwise, the length 4057 * may not be valid, so use the maximum. 4058 */ 4059 if ((sense_key == SSD_KEY_RECOVERED_ERROR) 4060 && (asc == 0x1c) && (ascq == 0x00) 4061 && (returned_length > 0)) { 4062 if (!use_12byte 4063 && (returned_length >= max_possible_size)) { 4064 goto retry_12byte; 4065 } 4066 dlist_length = returned_length + hdr_size; 4067 } else if ((sense_key == SSD_KEY_RECOVERED_ERROR) 4068 && (asc == 0x1f) && (ascq == 0x00) 4069 && (returned_length > 0)) { 4070 /* Partial defect list transfer */ 4071 /* 4072 * Hitachi drives return this error 4073 * along with a partial defect list if they 4074 * have more defects than the 10 byte 4075 * command can support. Retry with the 12 4076 * byte command. 4077 */ 4078 if (!use_12byte) { 4079 goto retry_12byte; 4080 } 4081 dlist_length = returned_length + hdr_size; 4082 } else if ((sense_key == SSD_KEY_ILLEGAL_REQUEST) 4083 && (asc == 0x24) && (ascq == 0x00)) { 4084 /* Invalid field in CDB */ 4085 /* 4086 * SBC-3 says that if the drive has more 4087 * defects than can be reported with the 4088 * 10 byte command, it should return this 4089 * error and no data. Retry with the 12 4090 * byte command. 4091 */ 4092 if (!use_12byte) { 4093 goto retry_12byte; 4094 } 4095 dlist_length = returned_length + hdr_size; 4096 } else { 4097 /* 4098 * If we got a SCSI error and no valid length, 4099 * just use the 10 byte maximum. The 12 4100 * byte maximum is too large. 4101 */ 4102 if (returned_length == 0) 4103 dlist_length = SRDD10_MAX_LENGTH; 4104 else { 4105 if (!use_12byte 4106 && (returned_length >= 4107 max_possible_size)) { 4108 goto retry_12byte; 4109 } 4110 dlist_length = returned_length + 4111 hdr_size; 4112 } 4113 } 4114 } else if ((ccb->ccb_h.status & CAM_STATUS_MASK) != 4115 CAM_REQ_CMP){ 4116 error = 1; 4117 warnx("Error reading defect header"); 4118 if (arglist & CAM_ARG_VERBOSE) 4119 cam_error_print(device, ccb, CAM_ESF_ALL, 4120 CAM_EPF_ALL, stderr); 4121 goto defect_bailout; 4122 } else { 4123 if (!use_12byte 4124 && (returned_length >= max_possible_size)) { 4125 goto retry_12byte; 4126 } 4127 dlist_length = returned_length + hdr_size; 4128 } 4129 if (summary) { 4130 fprintf(stdout, "%u", num_returned); 4131 if (!quiet) { 4132 fprintf(stdout, " defect%s", 4133 (num_returned != 1) ? "s" : ""); 4134 } 4135 fprintf(stdout, "\n"); 4136 4137 goto defect_bailout; 4138 } 4139 4140 /* 4141 * We always limit the list length to the 10-byte maximum 4142 * length (0xffff). The reason is that some controllers 4143 * can't handle larger I/Os, and we can transfer the entire 4144 * 10 byte list in one shot. For drives that support the 12 4145 * byte read defects command, we'll step through the list 4146 * by specifying a starting offset. For drives that don't 4147 * support the 12 byte command's starting offset, we'll 4148 * just display the first 64K. 4149 */ 4150 dlist_length = min(dlist_length, SRDD10_MAX_LENGTH); 4151 4152 goto retry; 4153 } 4154 4155 4156 if (((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_SCSI_STATUS_ERROR) 4157 && (ccb->csio.scsi_status == SCSI_STATUS_CHECK_COND) 4158 && ((ccb->ccb_h.status & CAM_AUTOSNS_VALID) != 0)) { 4159 struct scsi_sense_data *sense; 4160 int error_code, sense_key, asc, ascq; 4161 4162 sense = &ccb->csio.sense_data; 4163 scsi_extract_sense_len(sense, ccb->csio.sense_len - 4164 ccb->csio.sense_resid, &error_code, &sense_key, &asc, 4165 &ascq, /*show_errors*/ 1); 4166 4167 /* 4168 * According to the SCSI spec, if the disk doesn't support 4169 * the requested format, it will generally return a sense 4170 * key of RECOVERED ERROR, and an additional sense code 4171 * of "DEFECT LIST NOT FOUND". HGST drives also return 4172 * Primary/Grown defect list not found errors. So just 4173 * check for an ASC of 0x1c. 4174 */ 4175 if ((sense_key == SSD_KEY_RECOVERED_ERROR) 4176 && (asc == 0x1c)) { 4177 const char *format_str; 4178 4179 format_str = scsi_nv_to_str(defect_list_type_map, 4180 sizeof(defect_list_type_map) / 4181 sizeof(defect_list_type_map[0]), 4182 list_format & SRDD10_DLIST_FORMAT_MASK); 4183 warnx("requested defect format %s not available", 4184 format_str ? format_str : "unknown"); 4185 4186 format_str = scsi_nv_to_str(defect_list_type_map, 4187 sizeof(defect_list_type_map) / 4188 sizeof(defect_list_type_map[0]), returned_type); 4189 if (format_str != NULL) { 4190 warnx("Device returned %s format", 4191 format_str); 4192 } else { 4193 error = 1; 4194 warnx("Device returned unknown defect" 4195 " data format %#x", returned_type); 4196 goto defect_bailout; 4197 } 4198 } else { 4199 error = 1; 4200 warnx("Error returned from read defect data command"); 4201 if (arglist & CAM_ARG_VERBOSE) 4202 cam_error_print(device, ccb, CAM_ESF_ALL, 4203 CAM_EPF_ALL, stderr); 4204 goto defect_bailout; 4205 } 4206 } else if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 4207 error = 1; 4208 warnx("Error returned from read defect data command"); 4209 if (arglist & CAM_ARG_VERBOSE) 4210 cam_error_print(device, ccb, CAM_ESF_ALL, 4211 CAM_EPF_ALL, stderr); 4212 goto defect_bailout; 4213 } 4214 4215 if (first_pass) { 4216 fprintf(stderr, "Got %d defect", num_returned); 4217 4218 if (!summary || (num_returned == 0)) { 4219 fprintf(stderr, "s.\n"); 4220 goto defect_bailout; 4221 } else if (num_returned == 1) 4222 fprintf(stderr, ":\n"); 4223 else 4224 fprintf(stderr, "s:\n"); 4225 4226 first_pass = false; 4227 } 4228 4229 /* 4230 * XXX KDM I should probably clean up the printout format for the 4231 * disk defects. 4232 */ 4233 switch (returned_type) { 4234 case SRDD10_PHYSICAL_SECTOR_FORMAT: 4235 case SRDD10_EXT_PHYS_FORMAT: 4236 { 4237 struct scsi_defect_desc_phys_sector *dlist; 4238 4239 dlist = (struct scsi_defect_desc_phys_sector *) 4240 (defect_list + hdr_size); 4241 4242 for (i = 0; i < num_valid; i++) { 4243 uint32_t sector; 4244 4245 sector = scsi_4btoul(dlist[i].sector); 4246 if (returned_type == SRDD10_EXT_PHYS_FORMAT) { 4247 mads = (sector & SDD_EXT_PHYS_MADS) ? 4248 0 : 1; 4249 sector &= ~SDD_EXT_PHYS_FLAG_MASK; 4250 } 4251 if (!hex_format) 4252 fprintf(stdout, "%d:%d:%d%s", 4253 scsi_3btoul(dlist[i].cylinder), 4254 dlist[i].head, 4255 scsi_4btoul(dlist[i].sector), 4256 mads ? " - " : "\n"); 4257 else 4258 fprintf(stdout, "0x%x:0x%x:0x%x%s", 4259 scsi_3btoul(dlist[i].cylinder), 4260 dlist[i].head, 4261 scsi_4btoul(dlist[i].sector), 4262 mads ? " - " : "\n"); 4263 mads = 0; 4264 } 4265 if (num_valid < num_returned) { 4266 starting_offset += num_valid; 4267 goto next_batch; 4268 } 4269 break; 4270 } 4271 case SRDD10_BYTES_FROM_INDEX_FORMAT: 4272 case SRDD10_EXT_BFI_FORMAT: 4273 { 4274 struct scsi_defect_desc_bytes_from_index *dlist; 4275 4276 dlist = (struct scsi_defect_desc_bytes_from_index *) 4277 (defect_list + hdr_size); 4278 4279 for (i = 0; i < num_valid; i++) { 4280 uint32_t bfi; 4281 4282 bfi = scsi_4btoul(dlist[i].bytes_from_index); 4283 if (returned_type == SRDD10_EXT_BFI_FORMAT) { 4284 mads = (bfi & SDD_EXT_BFI_MADS) ? 1 : 0; 4285 bfi &= ~SDD_EXT_BFI_FLAG_MASK; 4286 } 4287 if (!hex_format) 4288 fprintf(stdout, "%d:%d:%d%s", 4289 scsi_3btoul(dlist[i].cylinder), 4290 dlist[i].head, 4291 scsi_4btoul(dlist[i].bytes_from_index), 4292 mads ? " - " : "\n"); 4293 else 4294 fprintf(stdout, "0x%x:0x%x:0x%x%s", 4295 scsi_3btoul(dlist[i].cylinder), 4296 dlist[i].head, 4297 scsi_4btoul(dlist[i].bytes_from_index), 4298 mads ? " - " : "\n"); 4299 4300 mads = 0; 4301 } 4302 if (num_valid < num_returned) { 4303 starting_offset += num_valid; 4304 goto next_batch; 4305 } 4306 break; 4307 } 4308 case SRDDH10_BLOCK_FORMAT: 4309 { 4310 struct scsi_defect_desc_block *dlist; 4311 4312 dlist = (struct scsi_defect_desc_block *) 4313 (defect_list + hdr_size); 4314 4315 for (i = 0; i < num_valid; i++) { 4316 if (!hex_format) 4317 fprintf(stdout, "%u\n", 4318 scsi_4btoul(dlist[i].address)); 4319 else 4320 fprintf(stdout, "0x%x\n", 4321 scsi_4btoul(dlist[i].address)); 4322 } 4323 4324 if (num_valid < num_returned) { 4325 starting_offset += num_valid; 4326 goto next_batch; 4327 } 4328 4329 break; 4330 } 4331 case SRDD10_LONG_BLOCK_FORMAT: 4332 { 4333 struct scsi_defect_desc_long_block *dlist; 4334 4335 dlist = (struct scsi_defect_desc_long_block *) 4336 (defect_list + hdr_size); 4337 4338 for (i = 0; i < num_valid; i++) { 4339 if (!hex_format) 4340 fprintf(stdout, "%ju\n", 4341 (uintmax_t)scsi_8btou64( 4342 dlist[i].address)); 4343 else 4344 fprintf(stdout, "0x%jx\n", 4345 (uintmax_t)scsi_8btou64( 4346 dlist[i].address)); 4347 } 4348 4349 if (num_valid < num_returned) { 4350 starting_offset += num_valid; 4351 goto next_batch; 4352 } 4353 break; 4354 } 4355 default: 4356 fprintf(stderr, "Unknown defect format 0x%x\n", 4357 returned_type); 4358 error = 1; 4359 break; 4360 } 4361 defect_bailout: 4362 4363 if (defect_list != NULL) 4364 free(defect_list); 4365 4366 if (ccb != NULL) 4367 cam_freeccb(ccb); 4368 4369 return (error); 4370 } 4371 4372 #if 0 4373 void 4374 reassignblocks(struct cam_device *device, uint32_t *blocks, int num_blocks) 4375 { 4376 union ccb *ccb; 4377 4378 ccb = cam_getccb(device); 4379 4380 cam_freeccb(ccb); 4381 } 4382 #endif 4383 4384 void 4385 mode_sense(struct cam_device *device, int *cdb_len, int dbd, int llbaa, int pc, 4386 int page, int subpage, int task_attr, int retry_count, int timeout, 4387 uint8_t *data, int datalen) 4388 { 4389 union ccb *ccb; 4390 int error_code, sense_key, asc, ascq; 4391 4392 ccb = cam_getccb(device); 4393 if (ccb == NULL) 4394 errx(1, "mode_sense: couldn't allocate CCB"); 4395 4396 retry: 4397 /* 4398 * MODE SENSE(6) can't handle more then 255 bytes. If there are more, 4399 * device must return error, so we should not get truncated data. 4400 */ 4401 if (*cdb_len == 6 && datalen > 255) 4402 datalen = 255; 4403 4404 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->csio); 4405 4406 scsi_mode_sense_subpage(&ccb->csio, 4407 /* retries */ retry_count, 4408 /* cbfcnp */ NULL, 4409 /* tag_action */ task_attr, 4410 /* dbd */ dbd, 4411 /* pc */ pc << 6, 4412 /* page */ page, 4413 /* subpage */ subpage, 4414 /* param_buf */ data, 4415 /* param_len */ datalen, 4416 /* minimum_cmd_size */ *cdb_len, 4417 /* sense_len */ SSD_FULL_SIZE, 4418 /* timeout */ timeout ? timeout : 5000); 4419 if (llbaa && ccb->csio.cdb_len == 10) { 4420 struct scsi_mode_sense_10 *cdb = 4421 (struct scsi_mode_sense_10 *)ccb->csio.cdb_io.cdb_bytes; 4422 cdb->byte2 |= SMS10_LLBAA; 4423 } 4424 4425 /* Record what CDB size the above function really set. */ 4426 *cdb_len = ccb->csio.cdb_len; 4427 4428 if (arglist & CAM_ARG_ERR_RECOVER) 4429 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 4430 4431 /* Disable freezing the device queue */ 4432 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 4433 4434 if (cam_send_ccb(device, ccb) < 0) 4435 err(1, "error sending mode sense command"); 4436 4437 /* In case of ILLEGEL REQUEST try to fall back to 6-byte command. */ 4438 if (*cdb_len != 6 && 4439 ((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_INVALID || 4440 (scsi_extract_sense_ccb(ccb, &error_code, &sense_key, &asc, &ascq) 4441 && sense_key == SSD_KEY_ILLEGAL_REQUEST))) { 4442 *cdb_len = 6; 4443 goto retry; 4444 } 4445 4446 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 4447 if (arglist & CAM_ARG_VERBOSE) { 4448 cam_error_print(device, ccb, CAM_ESF_ALL, 4449 CAM_EPF_ALL, stderr); 4450 } 4451 cam_freeccb(ccb); 4452 cam_close_device(device); 4453 errx(1, "mode sense command returned error"); 4454 } 4455 4456 cam_freeccb(ccb); 4457 } 4458 4459 void 4460 mode_select(struct cam_device *device, int cdb_len, int save_pages, 4461 int task_attr, int retry_count, int timeout, uint8_t *data, int datalen) 4462 { 4463 union ccb *ccb; 4464 int retval; 4465 4466 ccb = cam_getccb(device); 4467 4468 if (ccb == NULL) 4469 errx(1, "mode_select: couldn't allocate CCB"); 4470 4471 scsi_mode_select_len(&ccb->csio, 4472 /* retries */ retry_count, 4473 /* cbfcnp */ NULL, 4474 /* tag_action */ task_attr, 4475 /* scsi_page_fmt */ 1, 4476 /* save_pages */ save_pages, 4477 /* param_buf */ data, 4478 /* param_len */ datalen, 4479 /* minimum_cmd_size */ cdb_len, 4480 /* sense_len */ SSD_FULL_SIZE, 4481 /* timeout */ timeout ? timeout : 5000); 4482 4483 if (arglist & CAM_ARG_ERR_RECOVER) 4484 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 4485 4486 /* Disable freezing the device queue */ 4487 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 4488 4489 if (((retval = cam_send_ccb(device, ccb)) < 0) 4490 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 4491 if (arglist & CAM_ARG_VERBOSE) { 4492 cam_error_print(device, ccb, CAM_ESF_ALL, 4493 CAM_EPF_ALL, stderr); 4494 } 4495 cam_freeccb(ccb); 4496 cam_close_device(device); 4497 4498 if (retval < 0) 4499 err(1, "error sending mode select command"); 4500 else 4501 errx(1, "error sending mode select command"); 4502 4503 } 4504 4505 cam_freeccb(ccb); 4506 } 4507 4508 void 4509 modepage(struct cam_device *device, int argc, char **argv, char *combinedopt, 4510 int task_attr, int retry_count, int timeout) 4511 { 4512 char *str_subpage; 4513 int c, page = -1, subpage = 0, pc = 0, llbaa = 0; 4514 int binary = 0, cdb_len = 10, dbd = 0, desc = 0, edit = 0, list = 0; 4515 4516 while ((c = getopt(argc, argv, combinedopt)) != -1) { 4517 switch(c) { 4518 case '6': 4519 cdb_len = 6; 4520 break; 4521 case 'b': 4522 binary = 1; 4523 break; 4524 case 'd': 4525 dbd = 1; 4526 break; 4527 case 'e': 4528 edit = 1; 4529 break; 4530 case 'l': 4531 list++; 4532 break; 4533 case 'm': 4534 str_subpage = optarg; 4535 strsep(&str_subpage, ","); 4536 page = strtol(optarg, NULL, 0); 4537 if (str_subpage) 4538 subpage = strtol(str_subpage, NULL, 0); 4539 if (page < 0 || page > 0x3f) 4540 errx(1, "invalid mode page %d", page); 4541 if (subpage < 0 || subpage > 0xff) 4542 errx(1, "invalid mode subpage %d", subpage); 4543 break; 4544 case 'D': 4545 desc = 1; 4546 break; 4547 case 'L': 4548 llbaa = 1; 4549 break; 4550 case 'P': 4551 pc = strtol(optarg, NULL, 0); 4552 if ((pc < 0) || (pc > 3)) 4553 errx(1, "invalid page control field %d", pc); 4554 break; 4555 default: 4556 break; 4557 } 4558 } 4559 4560 if (desc && page == -1) 4561 page = SMS_ALL_PAGES_PAGE; 4562 4563 if (page == -1 && list == 0) 4564 errx(1, "you must specify a mode page!"); 4565 4566 if (dbd && desc) 4567 errx(1, "-d and -D are incompatible!"); 4568 4569 if (llbaa && cdb_len != 10) 4570 errx(1, "LLBAA bit is not present in MODE SENSE(6)!"); 4571 4572 if (list != 0) { 4573 mode_list(device, cdb_len, dbd, pc, list > 1, task_attr, 4574 retry_count, timeout); 4575 } else { 4576 mode_edit(device, cdb_len, desc, dbd, llbaa, pc, page, subpage, 4577 edit, binary, task_attr, retry_count, timeout); 4578 } 4579 } 4580 4581 static int 4582 scsicmd(struct cam_device *device, int argc, char **argv, char *combinedopt, 4583 int task_attr, int retry_count, int timeout) 4584 { 4585 union ccb *ccb; 4586 uint32_t flags = CAM_DIR_NONE; 4587 uint8_t *data_ptr = NULL; 4588 uint8_t cdb[20]; 4589 uint8_t atacmd[12]; 4590 struct get_hook hook; 4591 int c, data_bytes = 0, valid_bytes; 4592 int cdb_len = 0; 4593 int atacmd_len = 0; 4594 int dmacmd = 0; 4595 int fpdmacmd = 0; 4596 int need_res = 0; 4597 char *datastr = NULL, *tstr, *resstr = NULL; 4598 int error = 0; 4599 int fd_data = 0, fd_res = 0; 4600 int retval; 4601 4602 ccb = cam_getccb(device); 4603 4604 if (ccb == NULL) { 4605 warnx("scsicmd: error allocating ccb"); 4606 return (1); 4607 } 4608 4609 while ((c = getopt(argc, argv, combinedopt)) != -1) { 4610 switch(c) { 4611 case 'a': 4612 tstr = optarg; 4613 while (isspace(*tstr) && (*tstr != '\0')) 4614 tstr++; 4615 hook.argc = argc - optind; 4616 hook.argv = argv + optind; 4617 hook.got = 0; 4618 atacmd_len = buff_encode_visit(atacmd, sizeof(atacmd), tstr, 4619 iget, &hook); 4620 /* 4621 * Increment optind by the number of arguments the 4622 * encoding routine processed. After each call to 4623 * getopt(3), optind points to the argument that 4624 * getopt should process _next_. In this case, 4625 * that means it points to the first command string 4626 * argument, if there is one. Once we increment 4627 * this, it should point to either the next command 4628 * line argument, or it should be past the end of 4629 * the list. 4630 */ 4631 optind += hook.got; 4632 break; 4633 case 'c': 4634 tstr = optarg; 4635 while (isspace(*tstr) && (*tstr != '\0')) 4636 tstr++; 4637 hook.argc = argc - optind; 4638 hook.argv = argv + optind; 4639 hook.got = 0; 4640 cdb_len = buff_encode_visit(cdb, sizeof(cdb), tstr, 4641 iget, &hook); 4642 /* 4643 * Increment optind by the number of arguments the 4644 * encoding routine processed. After each call to 4645 * getopt(3), optind points to the argument that 4646 * getopt should process _next_. In this case, 4647 * that means it points to the first command string 4648 * argument, if there is one. Once we increment 4649 * this, it should point to either the next command 4650 * line argument, or it should be past the end of 4651 * the list. 4652 */ 4653 optind += hook.got; 4654 break; 4655 case 'd': 4656 dmacmd = 1; 4657 break; 4658 case 'f': 4659 fpdmacmd = 1; 4660 break; 4661 case 'i': 4662 if (arglist & CAM_ARG_CMD_OUT) { 4663 warnx("command must either be " 4664 "read or write, not both"); 4665 error = 1; 4666 goto scsicmd_bailout; 4667 } 4668 arglist |= CAM_ARG_CMD_IN; 4669 flags = CAM_DIR_IN; 4670 data_bytes = strtol(optarg, NULL, 0); 4671 if (data_bytes <= 0) { 4672 warnx("invalid number of input bytes %d", 4673 data_bytes); 4674 error = 1; 4675 goto scsicmd_bailout; 4676 } 4677 hook.argc = argc - optind; 4678 hook.argv = argv + optind; 4679 hook.got = 0; 4680 optind++; 4681 datastr = cget(&hook, NULL); 4682 /* 4683 * If the user supplied "-" instead of a format, he 4684 * wants the data to be written to stdout. 4685 */ 4686 if ((datastr != NULL) 4687 && (datastr[0] == '-')) 4688 fd_data = 1; 4689 4690 data_ptr = (uint8_t *)malloc(data_bytes); 4691 if (data_ptr == NULL) { 4692 warnx("can't malloc memory for data_ptr"); 4693 error = 1; 4694 goto scsicmd_bailout; 4695 } 4696 break; 4697 case 'o': 4698 if (arglist & CAM_ARG_CMD_IN) { 4699 warnx("command must either be " 4700 "read or write, not both"); 4701 error = 1; 4702 goto scsicmd_bailout; 4703 } 4704 arglist |= CAM_ARG_CMD_OUT; 4705 flags = CAM_DIR_OUT; 4706 data_bytes = strtol(optarg, NULL, 0); 4707 if (data_bytes <= 0) { 4708 warnx("invalid number of output bytes %d", 4709 data_bytes); 4710 error = 1; 4711 goto scsicmd_bailout; 4712 } 4713 hook.argc = argc - optind; 4714 hook.argv = argv + optind; 4715 hook.got = 0; 4716 datastr = cget(&hook, NULL); 4717 data_ptr = (uint8_t *)malloc(data_bytes); 4718 if (data_ptr == NULL) { 4719 warnx("can't malloc memory for data_ptr"); 4720 error = 1; 4721 goto scsicmd_bailout; 4722 } 4723 bzero(data_ptr, data_bytes); 4724 /* 4725 * If the user supplied "-" instead of a format, he 4726 * wants the data to be read from stdin. 4727 */ 4728 if ((datastr != NULL) 4729 && (datastr[0] == '-')) 4730 fd_data = 1; 4731 else 4732 buff_encode_visit(data_ptr, data_bytes, datastr, 4733 iget, &hook); 4734 optind += hook.got; 4735 break; 4736 case 'r': 4737 need_res = 1; 4738 hook.argc = argc - optind; 4739 hook.argv = argv + optind; 4740 hook.got = 0; 4741 resstr = cget(&hook, NULL); 4742 if ((resstr != NULL) && (resstr[0] == '-')) 4743 fd_res = 1; 4744 optind += hook.got; 4745 break; 4746 default: 4747 break; 4748 } 4749 } 4750 4751 /* 4752 * If fd_data is set, and we're writing to the device, we need to 4753 * read the data the user wants written from stdin. 4754 */ 4755 if ((fd_data == 1) && (arglist & CAM_ARG_CMD_OUT)) { 4756 ssize_t amt_read; 4757 int amt_to_read = data_bytes; 4758 uint8_t *buf_ptr = data_ptr; 4759 4760 for (amt_read = 0; amt_to_read > 0; 4761 amt_read = read(STDIN_FILENO, buf_ptr, amt_to_read)) { 4762 if (amt_read == -1) { 4763 warn("error reading data from stdin"); 4764 error = 1; 4765 goto scsicmd_bailout; 4766 } 4767 amt_to_read -= amt_read; 4768 buf_ptr += amt_read; 4769 } 4770 } 4771 4772 if (arglist & CAM_ARG_ERR_RECOVER) 4773 flags |= CAM_PASS_ERR_RECOVER; 4774 4775 /* Disable freezing the device queue */ 4776 flags |= CAM_DEV_QFRZDIS; 4777 4778 if (cdb_len) { 4779 /* 4780 * This is taken from the SCSI-3 draft spec. 4781 * (T10/1157D revision 0.3) 4782 * The top 3 bits of an opcode are the group code. 4783 * The next 5 bits are the command code. 4784 * Group 0: six byte commands 4785 * Group 1: ten byte commands 4786 * Group 2: ten byte commands 4787 * Group 3: reserved 4788 * Group 4: sixteen byte commands 4789 * Group 5: twelve byte commands 4790 * Group 6: vendor specific 4791 * Group 7: vendor specific 4792 */ 4793 switch((cdb[0] >> 5) & 0x7) { 4794 case 0: 4795 cdb_len = 6; 4796 break; 4797 case 1: 4798 case 2: 4799 cdb_len = 10; 4800 break; 4801 case 3: 4802 case 6: 4803 case 7: 4804 /* computed by buff_encode_visit */ 4805 break; 4806 case 4: 4807 cdb_len = 16; 4808 break; 4809 case 5: 4810 cdb_len = 12; 4811 break; 4812 } 4813 4814 /* 4815 * We should probably use csio_build_visit or something like that 4816 * here, but it's easier to encode arguments as you go. The 4817 * alternative would be skipping the CDB argument and then encoding 4818 * it here, since we've got the data buffer argument by now. 4819 */ 4820 bcopy(cdb, &ccb->csio.cdb_io.cdb_bytes, cdb_len); 4821 4822 cam_fill_csio(&ccb->csio, 4823 /*retries*/ retry_count, 4824 /*cbfcnp*/ NULL, 4825 /*flags*/ flags, 4826 /*tag_action*/ task_attr, 4827 /*data_ptr*/ data_ptr, 4828 /*dxfer_len*/ data_bytes, 4829 /*sense_len*/ SSD_FULL_SIZE, 4830 /*cdb_len*/ cdb_len, 4831 /*timeout*/ timeout ? timeout : 5000); 4832 } else { 4833 atacmd_len = 12; 4834 bcopy(atacmd, &ccb->ataio.cmd.command, atacmd_len); 4835 if (need_res) 4836 ccb->ataio.cmd.flags |= CAM_ATAIO_NEEDRESULT; 4837 if (dmacmd) 4838 ccb->ataio.cmd.flags |= CAM_ATAIO_DMA; 4839 if (fpdmacmd) 4840 ccb->ataio.cmd.flags |= CAM_ATAIO_FPDMA; 4841 4842 cam_fill_ataio(&ccb->ataio, 4843 /*retries*/ retry_count, 4844 /*cbfcnp*/ NULL, 4845 /*flags*/ flags, 4846 /*tag_action*/ 0, 4847 /*data_ptr*/ data_ptr, 4848 /*dxfer_len*/ data_bytes, 4849 /*timeout*/ timeout ? timeout : 5000); 4850 } 4851 4852 if (((retval = cam_send_ccb(device, ccb)) < 0) 4853 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 4854 const char warnstr[] = "error sending command"; 4855 4856 if (retval < 0) 4857 warn(warnstr); 4858 else 4859 warnx(warnstr); 4860 4861 if (arglist & CAM_ARG_VERBOSE) { 4862 cam_error_print(device, ccb, CAM_ESF_ALL, 4863 CAM_EPF_ALL, stderr); 4864 } 4865 4866 error = 1; 4867 goto scsicmd_bailout; 4868 } 4869 4870 if (atacmd_len && need_res) { 4871 if (fd_res == 0) { 4872 buff_decode_visit(&ccb->ataio.res.status, 11, resstr, 4873 arg_put, NULL); 4874 fprintf(stdout, "\n"); 4875 } else { 4876 fprintf(stdout, 4877 "%02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X\n", 4878 ccb->ataio.res.status, 4879 ccb->ataio.res.error, 4880 ccb->ataio.res.lba_low, 4881 ccb->ataio.res.lba_mid, 4882 ccb->ataio.res.lba_high, 4883 ccb->ataio.res.device, 4884 ccb->ataio.res.lba_low_exp, 4885 ccb->ataio.res.lba_mid_exp, 4886 ccb->ataio.res.lba_high_exp, 4887 ccb->ataio.res.sector_count, 4888 ccb->ataio.res.sector_count_exp); 4889 fflush(stdout); 4890 } 4891 } 4892 4893 if (cdb_len) 4894 valid_bytes = ccb->csio.dxfer_len - ccb->csio.resid; 4895 else 4896 valid_bytes = ccb->ataio.dxfer_len - ccb->ataio.resid; 4897 if (((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP) 4898 && (arglist & CAM_ARG_CMD_IN) 4899 && (valid_bytes > 0)) { 4900 if (fd_data == 0) { 4901 buff_decode_visit(data_ptr, valid_bytes, datastr, 4902 arg_put, NULL); 4903 fprintf(stdout, "\n"); 4904 } else { 4905 ssize_t amt_written; 4906 int amt_to_write = valid_bytes; 4907 uint8_t *buf_ptr = data_ptr; 4908 4909 for (amt_written = 0; (amt_to_write > 0) && 4910 (amt_written =write(1, buf_ptr,amt_to_write))> 0;){ 4911 amt_to_write -= amt_written; 4912 buf_ptr += amt_written; 4913 } 4914 if (amt_written == -1) { 4915 warn("error writing data to stdout"); 4916 error = 1; 4917 goto scsicmd_bailout; 4918 } else if ((amt_written == 0) 4919 && (amt_to_write > 0)) { 4920 warnx("only wrote %u bytes out of %u", 4921 valid_bytes - amt_to_write, valid_bytes); 4922 } 4923 } 4924 } 4925 4926 scsicmd_bailout: 4927 4928 if ((data_bytes > 0) && (data_ptr != NULL)) 4929 free(data_ptr); 4930 4931 cam_freeccb(ccb); 4932 4933 return (error); 4934 } 4935 4936 static int 4937 camdebug(int argc, char **argv, char *combinedopt) 4938 { 4939 int c, fd; 4940 path_id_t bus = CAM_BUS_WILDCARD; 4941 target_id_t target = CAM_TARGET_WILDCARD; 4942 lun_id_t lun = CAM_LUN_WILDCARD; 4943 char *tstr; 4944 union ccb ccb; 4945 int error = 0, rv; 4946 4947 bzero(&ccb, sizeof(union ccb)); 4948 4949 while ((c = getopt(argc, argv, combinedopt)) != -1) { 4950 switch(c) { 4951 case 'I': 4952 arglist |= CAM_ARG_DEBUG_INFO; 4953 ccb.cdbg.flags |= CAM_DEBUG_INFO; 4954 break; 4955 case 'P': 4956 arglist |= CAM_ARG_DEBUG_PERIPH; 4957 ccb.cdbg.flags |= CAM_DEBUG_PERIPH; 4958 break; 4959 case 'S': 4960 arglist |= CAM_ARG_DEBUG_SUBTRACE; 4961 ccb.cdbg.flags |= CAM_DEBUG_SUBTRACE; 4962 break; 4963 case 'T': 4964 arglist |= CAM_ARG_DEBUG_TRACE; 4965 ccb.cdbg.flags |= CAM_DEBUG_TRACE; 4966 break; 4967 case 'X': 4968 arglist |= CAM_ARG_DEBUG_XPT; 4969 ccb.cdbg.flags |= CAM_DEBUG_XPT; 4970 break; 4971 case 'c': 4972 arglist |= CAM_ARG_DEBUG_CDB; 4973 ccb.cdbg.flags |= CAM_DEBUG_CDB; 4974 break; 4975 case 'p': 4976 arglist |= CAM_ARG_DEBUG_PROBE; 4977 ccb.cdbg.flags |= CAM_DEBUG_PROBE; 4978 break; 4979 default: 4980 break; 4981 } 4982 } 4983 4984 argc -= optind; 4985 argv += optind; 4986 4987 if (argc <= 0) { 4988 warnx("you must specify \"off\", \"all\" or a bus,"); 4989 warnx("bus:target, bus:target:lun or periph"); 4990 return (1); 4991 } 4992 4993 tstr = *argv; 4994 while (isspace(*tstr) && (*tstr != '\0')) 4995 tstr++; 4996 4997 if (strncmp(tstr, "off", 3) == 0) { 4998 ccb.cdbg.flags = CAM_DEBUG_NONE; 4999 arglist &= ~(CAM_ARG_DEBUG_INFO|CAM_ARG_DEBUG_PERIPH| 5000 CAM_ARG_DEBUG_TRACE|CAM_ARG_DEBUG_SUBTRACE| 5001 CAM_ARG_DEBUG_XPT|CAM_ARG_DEBUG_PROBE); 5002 } else { 5003 rv = parse_btl(tstr, &bus, &target, &lun, &arglist); 5004 if (rv < 1) { 5005 warnx("you must specify \"all\", \"off\", or a bus,"); 5006 warnx("bus:target, bus:target:lun or periph to debug"); 5007 return (1); 5008 } 5009 } 5010 5011 if ((fd = open(XPT_DEVICE, O_RDWR)) < 0) { 5012 warnx("error opening transport layer device %s", XPT_DEVICE); 5013 warn("%s", XPT_DEVICE); 5014 return (1); 5015 } 5016 5017 ccb.ccb_h.func_code = XPT_DEBUG; 5018 ccb.ccb_h.path_id = bus; 5019 ccb.ccb_h.target_id = target; 5020 ccb.ccb_h.target_lun = lun; 5021 5022 if (ioctl(fd, CAMIOCOMMAND, &ccb) == -1) { 5023 warn("CAMIOCOMMAND ioctl failed"); 5024 error = 1; 5025 } else { 5026 if ((ccb.ccb_h.status & CAM_STATUS_MASK) == 5027 CAM_FUNC_NOTAVAIL) { 5028 warnx("CAM debugging not available"); 5029 warnx("you need to put options CAMDEBUG in" 5030 " your kernel config file!"); 5031 error = 1; 5032 } else if ((ccb.ccb_h.status & CAM_STATUS_MASK) != 5033 CAM_REQ_CMP) { 5034 warnx("XPT_DEBUG CCB failed with status %#x", 5035 ccb.ccb_h.status); 5036 error = 1; 5037 } else { 5038 if (ccb.cdbg.flags == CAM_DEBUG_NONE) { 5039 fprintf(stderr, 5040 "Debugging turned off\n"); 5041 } else { 5042 fprintf(stderr, 5043 "Debugging enabled for " 5044 "%d:%d:%jx\n", 5045 bus, target, (uintmax_t)lun); 5046 } 5047 } 5048 } 5049 close(fd); 5050 5051 return (error); 5052 } 5053 5054 static int 5055 tagcontrol(struct cam_device *device, int argc, char **argv, 5056 char *combinedopt) 5057 { 5058 int c; 5059 union ccb *ccb; 5060 int numtags = -1; 5061 int retval = 0; 5062 int quiet = 0; 5063 char pathstr[1024]; 5064 5065 ccb = cam_getccb(device); 5066 5067 if (ccb == NULL) { 5068 warnx("tagcontrol: error allocating ccb"); 5069 return (1); 5070 } 5071 5072 while ((c = getopt(argc, argv, combinedopt)) != -1) { 5073 switch(c) { 5074 case 'N': 5075 numtags = strtol(optarg, NULL, 0); 5076 if (numtags < 0) { 5077 warnx("tag count %d is < 0", numtags); 5078 retval = 1; 5079 goto tagcontrol_bailout; 5080 } 5081 break; 5082 case 'q': 5083 quiet++; 5084 break; 5085 default: 5086 break; 5087 } 5088 } 5089 5090 cam_path_string(device, pathstr, sizeof(pathstr)); 5091 5092 if (numtags >= 0) { 5093 ccb->ccb_h.func_code = XPT_REL_SIMQ; 5094 ccb->ccb_h.flags = CAM_DEV_QFREEZE; 5095 ccb->crs.release_flags = RELSIM_ADJUST_OPENINGS; 5096 ccb->crs.openings = numtags; 5097 5098 5099 if (cam_send_ccb(device, ccb) < 0) { 5100 warn("error sending XPT_REL_SIMQ CCB"); 5101 retval = 1; 5102 goto tagcontrol_bailout; 5103 } 5104 5105 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 5106 warnx("XPT_REL_SIMQ CCB failed"); 5107 cam_error_print(device, ccb, CAM_ESF_ALL, 5108 CAM_EPF_ALL, stderr); 5109 retval = 1; 5110 goto tagcontrol_bailout; 5111 } 5112 5113 5114 if (quiet == 0) 5115 fprintf(stdout, "%stagged openings now %d\n", 5116 pathstr, ccb->crs.openings); 5117 } 5118 5119 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->cgds); 5120 5121 ccb->ccb_h.func_code = XPT_GDEV_STATS; 5122 5123 if (cam_send_ccb(device, ccb) < 0) { 5124 warn("error sending XPT_GDEV_STATS CCB"); 5125 retval = 1; 5126 goto tagcontrol_bailout; 5127 } 5128 5129 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 5130 warnx("XPT_GDEV_STATS CCB failed"); 5131 cam_error_print(device, ccb, CAM_ESF_ALL, 5132 CAM_EPF_ALL, stderr); 5133 retval = 1; 5134 goto tagcontrol_bailout; 5135 } 5136 5137 if (arglist & CAM_ARG_VERBOSE) { 5138 fprintf(stdout, "%s", pathstr); 5139 fprintf(stdout, "dev_openings %d\n", ccb->cgds.dev_openings); 5140 fprintf(stdout, "%s", pathstr); 5141 fprintf(stdout, "dev_active %d\n", ccb->cgds.dev_active); 5142 fprintf(stdout, "%s", pathstr); 5143 fprintf(stdout, "allocated %d\n", ccb->cgds.allocated); 5144 fprintf(stdout, "%s", pathstr); 5145 fprintf(stdout, "queued %d\n", ccb->cgds.queued); 5146 fprintf(stdout, "%s", pathstr); 5147 fprintf(stdout, "held %d\n", ccb->cgds.held); 5148 fprintf(stdout, "%s", pathstr); 5149 fprintf(stdout, "mintags %d\n", ccb->cgds.mintags); 5150 fprintf(stdout, "%s", pathstr); 5151 fprintf(stdout, "maxtags %d\n", ccb->cgds.maxtags); 5152 } else { 5153 if (quiet == 0) { 5154 fprintf(stdout, "%s", pathstr); 5155 fprintf(stdout, "device openings: "); 5156 } 5157 fprintf(stdout, "%d\n", ccb->cgds.dev_openings + 5158 ccb->cgds.dev_active); 5159 } 5160 5161 tagcontrol_bailout: 5162 5163 cam_freeccb(ccb); 5164 return (retval); 5165 } 5166 5167 static void 5168 cts_print(struct cam_device *device, struct ccb_trans_settings *cts) 5169 { 5170 char pathstr[1024]; 5171 5172 cam_path_string(device, pathstr, sizeof(pathstr)); 5173 5174 if (cts->transport == XPORT_SPI) { 5175 struct ccb_trans_settings_spi *spi = 5176 &cts->xport_specific.spi; 5177 5178 if ((spi->valid & CTS_SPI_VALID_SYNC_RATE) != 0) { 5179 5180 fprintf(stdout, "%ssync parameter: %d\n", pathstr, 5181 spi->sync_period); 5182 5183 if (spi->sync_offset != 0) { 5184 u_int freq; 5185 5186 freq = scsi_calc_syncsrate(spi->sync_period); 5187 fprintf(stdout, "%sfrequency: %d.%03dMHz\n", 5188 pathstr, freq / 1000, freq % 1000); 5189 } 5190 } 5191 5192 if (spi->valid & CTS_SPI_VALID_SYNC_OFFSET) { 5193 fprintf(stdout, "%soffset: %d\n", pathstr, 5194 spi->sync_offset); 5195 } 5196 5197 if (spi->valid & CTS_SPI_VALID_BUS_WIDTH) { 5198 fprintf(stdout, "%sbus width: %d bits\n", pathstr, 5199 (0x01 << spi->bus_width) * 8); 5200 } 5201 5202 if (spi->valid & CTS_SPI_VALID_DISC) { 5203 fprintf(stdout, "%sdisconnection is %s\n", pathstr, 5204 (spi->flags & CTS_SPI_FLAGS_DISC_ENB) ? 5205 "enabled" : "disabled"); 5206 } 5207 } 5208 if (cts->transport == XPORT_FC) { 5209 struct ccb_trans_settings_fc *fc = 5210 &cts->xport_specific.fc; 5211 5212 if (fc->valid & CTS_FC_VALID_WWNN) 5213 fprintf(stdout, "%sWWNN: 0x%llx\n", pathstr, 5214 (long long) fc->wwnn); 5215 if (fc->valid & CTS_FC_VALID_WWPN) 5216 fprintf(stdout, "%sWWPN: 0x%llx\n", pathstr, 5217 (long long) fc->wwpn); 5218 if (fc->valid & CTS_FC_VALID_PORT) 5219 fprintf(stdout, "%sPortID: 0x%x\n", pathstr, fc->port); 5220 if (fc->valid & CTS_FC_VALID_SPEED) 5221 fprintf(stdout, "%stransfer speed: %d.%03dMB/s\n", 5222 pathstr, fc->bitrate / 1000, fc->bitrate % 1000); 5223 } 5224 if (cts->transport == XPORT_SAS) { 5225 struct ccb_trans_settings_sas *sas = 5226 &cts->xport_specific.sas; 5227 5228 if (sas->valid & CTS_SAS_VALID_SPEED) 5229 fprintf(stdout, "%stransfer speed: %d.%03dMB/s\n", 5230 pathstr, sas->bitrate / 1000, sas->bitrate % 1000); 5231 } 5232 if (cts->transport == XPORT_ATA) { 5233 struct ccb_trans_settings_pata *pata = 5234 &cts->xport_specific.ata; 5235 5236 if ((pata->valid & CTS_ATA_VALID_MODE) != 0) { 5237 fprintf(stdout, "%sATA mode: %s\n", pathstr, 5238 ata_mode2string(pata->mode)); 5239 } 5240 if ((pata->valid & CTS_ATA_VALID_ATAPI) != 0) { 5241 fprintf(stdout, "%sATAPI packet length: %d\n", pathstr, 5242 pata->atapi); 5243 } 5244 if ((pata->valid & CTS_ATA_VALID_BYTECOUNT) != 0) { 5245 fprintf(stdout, "%sPIO transaction length: %d\n", 5246 pathstr, pata->bytecount); 5247 } 5248 } 5249 if (cts->transport == XPORT_SATA) { 5250 struct ccb_trans_settings_sata *sata = 5251 &cts->xport_specific.sata; 5252 5253 if ((sata->valid & CTS_SATA_VALID_REVISION) != 0) { 5254 fprintf(stdout, "%sSATA revision: %d.x\n", pathstr, 5255 sata->revision); 5256 } 5257 if ((sata->valid & CTS_SATA_VALID_MODE) != 0) { 5258 fprintf(stdout, "%sATA mode: %s\n", pathstr, 5259 ata_mode2string(sata->mode)); 5260 } 5261 if ((sata->valid & CTS_SATA_VALID_ATAPI) != 0) { 5262 fprintf(stdout, "%sATAPI packet length: %d\n", pathstr, 5263 sata->atapi); 5264 } 5265 if ((sata->valid & CTS_SATA_VALID_BYTECOUNT) != 0) { 5266 fprintf(stdout, "%sPIO transaction length: %d\n", 5267 pathstr, sata->bytecount); 5268 } 5269 if ((sata->valid & CTS_SATA_VALID_PM) != 0) { 5270 fprintf(stdout, "%sPMP presence: %d\n", pathstr, 5271 sata->pm_present); 5272 } 5273 if ((sata->valid & CTS_SATA_VALID_TAGS) != 0) { 5274 fprintf(stdout, "%sNumber of tags: %d\n", pathstr, 5275 sata->tags); 5276 } 5277 if ((sata->valid & CTS_SATA_VALID_CAPS) != 0) { 5278 fprintf(stdout, "%sSATA capabilities: %08x\n", pathstr, 5279 sata->caps); 5280 } 5281 } 5282 if (cts->protocol == PROTO_ATA) { 5283 struct ccb_trans_settings_ata *ata= 5284 &cts->proto_specific.ata; 5285 5286 if (ata->valid & CTS_ATA_VALID_TQ) { 5287 fprintf(stdout, "%stagged queueing: %s\n", pathstr, 5288 (ata->flags & CTS_ATA_FLAGS_TAG_ENB) ? 5289 "enabled" : "disabled"); 5290 } 5291 } 5292 if (cts->protocol == PROTO_SCSI) { 5293 struct ccb_trans_settings_scsi *scsi= 5294 &cts->proto_specific.scsi; 5295 5296 if (scsi->valid & CTS_SCSI_VALID_TQ) { 5297 fprintf(stdout, "%stagged queueing: %s\n", pathstr, 5298 (scsi->flags & CTS_SCSI_FLAGS_TAG_ENB) ? 5299 "enabled" : "disabled"); 5300 } 5301 } 5302 #ifdef WITH_NVME 5303 if (cts->protocol == PROTO_NVME) { 5304 struct ccb_trans_settings_nvme *nvmex = 5305 &cts->xport_specific.nvme; 5306 5307 if (nvmex->valid & CTS_NVME_VALID_SPEC) { 5308 fprintf(stdout, "%sNVMe Spec: %d.%d\n", pathstr, 5309 NVME_MAJOR(nvmex->spec), 5310 NVME_MINOR(nvmex->spec)); 5311 } 5312 if (nvmex->valid & CTS_NVME_VALID_LINK) { 5313 fprintf(stdout, "%sPCIe lanes: %d (%d max)\n", pathstr, 5314 nvmex->lanes, nvmex->max_lanes); 5315 fprintf(stdout, "%sPCIe Generation: %d (%d max)\n", pathstr, 5316 nvmex->speed, nvmex->max_speed); 5317 } 5318 } 5319 #endif 5320 } 5321 5322 /* 5323 * Get a path inquiry CCB for the specified device. 5324 */ 5325 static int 5326 get_cpi(struct cam_device *device, struct ccb_pathinq *cpi) 5327 { 5328 union ccb *ccb; 5329 int retval = 0; 5330 5331 ccb = cam_getccb(device); 5332 if (ccb == NULL) { 5333 warnx("get_cpi: couldn't allocate CCB"); 5334 return (1); 5335 } 5336 ccb->ccb_h.func_code = XPT_PATH_INQ; 5337 if (cam_send_ccb(device, ccb) < 0) { 5338 warn("get_cpi: error sending Path Inquiry CCB"); 5339 retval = 1; 5340 goto get_cpi_bailout; 5341 } 5342 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 5343 if (arglist & CAM_ARG_VERBOSE) 5344 cam_error_print(device, ccb, CAM_ESF_ALL, 5345 CAM_EPF_ALL, stderr); 5346 retval = 1; 5347 goto get_cpi_bailout; 5348 } 5349 bcopy(&ccb->cpi, cpi, sizeof(struct ccb_pathinq)); 5350 5351 get_cpi_bailout: 5352 cam_freeccb(ccb); 5353 return (retval); 5354 } 5355 5356 /* 5357 * Get a get device CCB for the specified device. 5358 */ 5359 static int 5360 get_cgd(struct cam_device *device, struct ccb_getdev *cgd) 5361 { 5362 union ccb *ccb; 5363 int retval = 0; 5364 5365 ccb = cam_getccb(device); 5366 if (ccb == NULL) { 5367 warnx("get_cgd: couldn't allocate CCB"); 5368 return (1); 5369 } 5370 ccb->ccb_h.func_code = XPT_GDEV_TYPE; 5371 if (cam_send_ccb(device, ccb) < 0) { 5372 warn("get_cgd: error sending Get type information CCB"); 5373 retval = 1; 5374 goto get_cgd_bailout; 5375 } 5376 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 5377 if (arglist & CAM_ARG_VERBOSE) 5378 cam_error_print(device, ccb, CAM_ESF_ALL, 5379 CAM_EPF_ALL, stderr); 5380 retval = 1; 5381 goto get_cgd_bailout; 5382 } 5383 bcopy(&ccb->cgd, cgd, sizeof(struct ccb_getdev)); 5384 5385 get_cgd_bailout: 5386 cam_freeccb(ccb); 5387 return (retval); 5388 } 5389 5390 /* 5391 * Returns 1 if the device has the VPD page, 0 if it does not, and -1 on an 5392 * error. 5393 */ 5394 int 5395 dev_has_vpd_page(struct cam_device *dev, uint8_t page_id, int retry_count, 5396 int timeout, int verbosemode) 5397 { 5398 union ccb *ccb = NULL; 5399 struct scsi_vpd_supported_page_list sup_pages; 5400 int i; 5401 int retval = 0; 5402 5403 ccb = cam_getccb(dev); 5404 if (ccb == NULL) { 5405 warn("Unable to allocate CCB"); 5406 retval = -1; 5407 goto bailout; 5408 } 5409 5410 bzero(&sup_pages, sizeof(sup_pages)); 5411 5412 scsi_inquiry(&ccb->csio, 5413 /*retries*/ retry_count, 5414 /*cbfcnp*/ NULL, 5415 /* tag_action */ MSG_SIMPLE_Q_TAG, 5416 /* inq_buf */ (uint8_t *)&sup_pages, 5417 /* inq_len */ sizeof(sup_pages), 5418 /* evpd */ 1, 5419 /* page_code */ SVPD_SUPPORTED_PAGE_LIST, 5420 /* sense_len */ SSD_FULL_SIZE, 5421 /* timeout */ timeout ? timeout : 5000); 5422 5423 /* Disable freezing the device queue */ 5424 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 5425 5426 if (retry_count != 0) 5427 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 5428 5429 if (cam_send_ccb(dev, ccb) < 0) { 5430 cam_freeccb(ccb); 5431 ccb = NULL; 5432 retval = -1; 5433 goto bailout; 5434 } 5435 5436 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 5437 if (verbosemode != 0) 5438 cam_error_print(dev, ccb, CAM_ESF_ALL, 5439 CAM_EPF_ALL, stderr); 5440 retval = -1; 5441 goto bailout; 5442 } 5443 5444 for (i = 0; i < sup_pages.length; i++) { 5445 if (sup_pages.list[i] == page_id) { 5446 retval = 1; 5447 goto bailout; 5448 } 5449 } 5450 bailout: 5451 if (ccb != NULL) 5452 cam_freeccb(ccb); 5453 5454 return (retval); 5455 } 5456 5457 /* 5458 * devtype is filled in with the type of device. 5459 * Returns 0 for success, non-zero for failure. 5460 */ 5461 int 5462 get_device_type(struct cam_device *dev, int retry_count, int timeout, 5463 int verbosemode, camcontrol_devtype *devtype) 5464 { 5465 struct ccb_getdev cgd; 5466 int retval; 5467 5468 retval = get_cgd(dev, &cgd); 5469 if (retval != 0) 5470 goto bailout; 5471 5472 switch (cgd.protocol) { 5473 case PROTO_SCSI: 5474 break; 5475 case PROTO_ATA: 5476 case PROTO_ATAPI: 5477 case PROTO_SATAPM: 5478 *devtype = CC_DT_ATA; 5479 goto bailout; 5480 break; /*NOTREACHED*/ 5481 case PROTO_NVME: 5482 *devtype = CC_DT_NVME; 5483 goto bailout; 5484 break; /*NOTREACHED*/ 5485 case PROTO_MMCSD: 5486 *devtype = CC_DT_MMCSD; 5487 goto bailout; 5488 break; /*NOTREACHED*/ 5489 default: 5490 *devtype = CC_DT_UNKNOWN; 5491 goto bailout; 5492 break; /*NOTREACHED*/ 5493 } 5494 5495 if (retry_count == -1) { 5496 /* 5497 * For a retry count of -1, used only the cached data to avoid 5498 * I/O to the drive. Sending the identify command to the drive 5499 * can cause issues for SATL attachaed drives since identify is 5500 * not an NCQ command. We check for the strings that windows 5501 * displays since those will not be NULs (they are supposed 5502 * to be space padded). We could check other bits, but anything 5503 * non-zero implies SATL. 5504 */ 5505 if (cgd.ident_data.serial[0] != 0 || 5506 cgd.ident_data.revision[0] != 0 || 5507 cgd.ident_data.model[0] != 0) 5508 *devtype = CC_DT_SATL; 5509 else 5510 *devtype = CC_DT_SCSI; 5511 } else { 5512 /* 5513 * Check for the ATA Information VPD page (0x89). If this is an 5514 * ATA device behind a SCSI to ATA translation layer (SATL), 5515 * this VPD page should be present. 5516 * 5517 * If that VPD page isn't present, or we get an error back from 5518 * the INQUIRY command, we'll just treat it as a normal SCSI 5519 * device. 5520 */ 5521 retval = dev_has_vpd_page(dev, SVPD_ATA_INFORMATION, retry_count, 5522 timeout, verbosemode); 5523 if (retval == 1) 5524 *devtype = CC_DT_SATL; 5525 else 5526 *devtype = CC_DT_SCSI; 5527 } 5528 retval = 0; 5529 5530 bailout: 5531 return (retval); 5532 } 5533 5534 int 5535 build_ata_cmd(union ccb *ccb, uint32_t retry_count, uint32_t flags, 5536 uint8_t tag_action, uint8_t protocol, uint8_t ata_flags, uint16_t features, 5537 uint16_t sector_count, uint64_t lba, uint8_t command, uint32_t auxiliary, 5538 uint8_t *data_ptr, uint32_t dxfer_len, uint8_t *cdb_storage, 5539 size_t cdb_storage_len, uint8_t sense_len, uint32_t timeout, 5540 int is48bit, camcontrol_devtype devtype) 5541 { 5542 int retval = 0; 5543 5544 if (devtype == CC_DT_ATA) { 5545 cam_fill_ataio(&ccb->ataio, 5546 /*retries*/ retry_count, 5547 /*cbfcnp*/ NULL, 5548 /*flags*/ flags, 5549 /*tag_action*/ tag_action, 5550 /*data_ptr*/ data_ptr, 5551 /*dxfer_len*/ dxfer_len, 5552 /*timeout*/ timeout); 5553 if (is48bit || lba > ATA_MAX_28BIT_LBA) 5554 ata_48bit_cmd(&ccb->ataio, command, features, lba, 5555 sector_count); 5556 else 5557 ata_28bit_cmd(&ccb->ataio, command, features, lba, 5558 sector_count); 5559 5560 if (auxiliary != 0) { 5561 ccb->ataio.ata_flags |= ATA_FLAG_AUX; 5562 ccb->ataio.aux = auxiliary; 5563 } 5564 5565 if (ata_flags & AP_FLAG_CHK_COND) 5566 ccb->ataio.cmd.flags |= CAM_ATAIO_NEEDRESULT; 5567 5568 if ((protocol & AP_PROTO_MASK) == AP_PROTO_DMA) 5569 ccb->ataio.cmd.flags |= CAM_ATAIO_DMA; 5570 else if ((protocol & AP_PROTO_MASK) == AP_PROTO_FPDMA) 5571 ccb->ataio.cmd.flags |= CAM_ATAIO_FPDMA; 5572 } else { 5573 if (is48bit || lba > ATA_MAX_28BIT_LBA) 5574 protocol |= AP_EXTEND; 5575 5576 retval = scsi_ata_pass(&ccb->csio, 5577 /*retries*/ retry_count, 5578 /*cbfcnp*/ NULL, 5579 /*flags*/ flags, 5580 /*tag_action*/ tag_action, 5581 /*protocol*/ protocol, 5582 /*ata_flags*/ ata_flags, 5583 /*features*/ features, 5584 /*sector_count*/ sector_count, 5585 /*lba*/ lba, 5586 /*command*/ command, 5587 /*device*/ 0, 5588 /*icc*/ 0, 5589 /*auxiliary*/ auxiliary, 5590 /*control*/ 0, 5591 /*data_ptr*/ data_ptr, 5592 /*dxfer_len*/ dxfer_len, 5593 /*cdb_storage*/ cdb_storage, 5594 /*cdb_storage_len*/ cdb_storage_len, 5595 /*minimum_cmd_size*/ 0, 5596 /*sense_len*/ sense_len, 5597 /*timeout*/ timeout); 5598 } 5599 5600 return (retval); 5601 } 5602 5603 /* 5604 * Returns: 0 -- success, 1 -- error, 2 -- lba truncated, 5605 * 4 -- count truncated, 6 -- lba and count truncated. 5606 */ 5607 int 5608 get_ata_status(struct cam_device *dev, union ccb *ccb, uint8_t *error, 5609 uint16_t *count, uint64_t *lba, uint8_t *device, uint8_t *status) 5610 { 5611 int retval; 5612 5613 switch (ccb->ccb_h.func_code) { 5614 case XPT_SCSI_IO: { 5615 uint8_t opcode; 5616 int error_code = 0, sense_key = 0, asc = 0, ascq = 0; 5617 u_int sense_len; 5618 5619 /* 5620 * In this case, we have SCSI ATA PASS-THROUGH command, 12 5621 * or 16 byte, and need to see what 5622 */ 5623 if (ccb->ccb_h.flags & CAM_CDB_POINTER) 5624 opcode = ccb->csio.cdb_io.cdb_ptr[0]; 5625 else 5626 opcode = ccb->csio.cdb_io.cdb_bytes[0]; 5627 if ((opcode != ATA_PASS_12) 5628 && (opcode != ATA_PASS_16)) { 5629 warnx("%s: unsupported opcode %02x", __func__, opcode); 5630 return (1); 5631 } 5632 5633 retval = scsi_extract_sense_ccb(ccb, &error_code, &sense_key, 5634 &asc, &ascq); 5635 /* Note: the _ccb() variant returns 0 for an error */ 5636 if (retval == 0) 5637 return (1); 5638 5639 sense_len = ccb->csio.sense_len - ccb->csio.sense_resid; 5640 switch (error_code) { 5641 case SSD_DESC_CURRENT_ERROR: 5642 case SSD_DESC_DEFERRED_ERROR: { 5643 struct scsi_sense_data_desc *sense; 5644 struct scsi_sense_ata_ret_desc *desc; 5645 uint8_t *desc_ptr; 5646 5647 sense = (struct scsi_sense_data_desc *) 5648 &ccb->csio.sense_data; 5649 5650 desc_ptr = scsi_find_desc(sense, sense_len, 5651 SSD_DESC_ATA); 5652 if (desc_ptr == NULL) { 5653 cam_error_print(dev, ccb, CAM_ESF_ALL, 5654 CAM_EPF_ALL, stderr); 5655 return (1); 5656 } 5657 desc = (struct scsi_sense_ata_ret_desc *)desc_ptr; 5658 5659 *error = desc->error; 5660 *count = (desc->count_15_8 << 8) | 5661 desc->count_7_0; 5662 *lba = ((uint64_t)desc->lba_47_40 << 40) | 5663 ((uint64_t)desc->lba_39_32 << 32) | 5664 ((uint64_t)desc->lba_31_24 << 24) | 5665 (desc->lba_23_16 << 16) | 5666 (desc->lba_15_8 << 8) | 5667 desc->lba_7_0; 5668 *device = desc->device; 5669 *status = desc->status; 5670 5671 /* 5672 * If the extend bit isn't set, the result is for a 5673 * 12-byte ATA PASS-THROUGH command or a 16 or 32 byte 5674 * command without the extend bit set. This means 5675 * that the device is supposed to return 28-bit 5676 * status. The count field is only 8 bits, and the 5677 * LBA field is only 8 bits. 5678 */ 5679 if ((desc->flags & SSD_DESC_ATA_FLAG_EXTEND) == 0){ 5680 *count &= 0xff; 5681 *lba &= 0x0fffffff; 5682 } 5683 break; 5684 } 5685 case SSD_CURRENT_ERROR: 5686 case SSD_DEFERRED_ERROR: { 5687 uint64_t val; 5688 5689 /* 5690 * In my understanding of SAT-5 specification, saying: 5691 * "without interpreting the contents of the STATUS", 5692 * this should not happen if CK_COND was set, but it 5693 * does at least for some devices, so try to revert. 5694 */ 5695 if ((sense_key == SSD_KEY_ABORTED_COMMAND) && 5696 (asc == 0) && (ascq == 0)) { 5697 *status = ATA_STATUS_ERROR; 5698 *error = ATA_ERROR_ABORT; 5699 *device = 0; 5700 *count = 0; 5701 *lba = 0; 5702 return (0); 5703 } 5704 5705 if ((sense_key != SSD_KEY_RECOVERED_ERROR) || 5706 (asc != 0x00) || (ascq != 0x1d)) 5707 return (1); 5708 5709 val = 0; 5710 scsi_get_sense_info(&ccb->csio.sense_data, sense_len, 5711 SSD_DESC_INFO, &val, NULL); 5712 *error = (val >> 24) & 0xff; 5713 *status = (val >> 16) & 0xff; 5714 *device = (val >> 8) & 0xff; 5715 *count = val & 0xff; 5716 5717 val = 0; 5718 scsi_get_sense_info(&ccb->csio.sense_data, sense_len, 5719 SSD_DESC_COMMAND, &val, NULL); 5720 *lba = ((val >> 16) & 0xff) | (val & 0xff00) | 5721 ((val & 0xff) << 16); 5722 5723 /* Report UPPER NONZERO bits as errors 2, 4 and 6. */ 5724 return ((val >> 28) & 0x06); 5725 } 5726 default: 5727 return (1); 5728 } 5729 5730 break; 5731 } 5732 case XPT_ATA_IO: { 5733 struct ata_res *res; 5734 5735 /* Only some statuses return ATA result register set. */ 5736 if (cam_ccb_status(ccb) != CAM_REQ_CMP && 5737 cam_ccb_status(ccb) != CAM_ATA_STATUS_ERROR) 5738 return (1); 5739 5740 res = &ccb->ataio.res; 5741 *error = res->error; 5742 *status = res->status; 5743 *device = res->device; 5744 *count = res->sector_count; 5745 *lba = (res->lba_high << 16) | 5746 (res->lba_mid << 8) | 5747 (res->lba_low); 5748 if (ccb->ataio.cmd.flags & CAM_ATAIO_48BIT) { 5749 *count |= (res->sector_count_exp << 8); 5750 *lba |= ((uint64_t)res->lba_low_exp << 24) | 5751 ((uint64_t)res->lba_mid_exp << 32) | 5752 ((uint64_t)res->lba_high_exp << 40); 5753 } else { 5754 *lba |= (res->device & 0xf) << 24; 5755 } 5756 break; 5757 } 5758 default: 5759 return (1); 5760 } 5761 return (0); 5762 } 5763 5764 static void 5765 cpi_print(struct ccb_pathinq *cpi) 5766 { 5767 char adapter_str[1024]; 5768 uint64_t i; 5769 5770 snprintf(adapter_str, sizeof(adapter_str), 5771 "%s%d:", cpi->dev_name, cpi->unit_number); 5772 5773 fprintf(stdout, "%s SIM/HBA version: %d\n", adapter_str, 5774 cpi->version_num); 5775 5776 for (i = 1; i < UINT8_MAX; i = i << 1) { 5777 const char *str; 5778 5779 if ((i & cpi->hba_inquiry) == 0) 5780 continue; 5781 5782 fprintf(stdout, "%s supports ", adapter_str); 5783 5784 switch(i) { 5785 case PI_MDP_ABLE: 5786 str = "MDP message"; 5787 break; 5788 case PI_WIDE_32: 5789 str = "32 bit wide SCSI"; 5790 break; 5791 case PI_WIDE_16: 5792 str = "16 bit wide SCSI"; 5793 break; 5794 case PI_SDTR_ABLE: 5795 str = "SDTR message"; 5796 break; 5797 case PI_LINKED_CDB: 5798 str = "linked CDBs"; 5799 break; 5800 case PI_TAG_ABLE: 5801 str = "tag queue messages"; 5802 break; 5803 case PI_SOFT_RST: 5804 str = "soft reset alternative"; 5805 break; 5806 case PI_SATAPM: 5807 str = "SATA Port Multiplier"; 5808 break; 5809 default: 5810 str = "unknown PI bit set"; 5811 break; 5812 } 5813 fprintf(stdout, "%s\n", str); 5814 } 5815 5816 for (i = 1; i < UINT32_MAX; i = i << 1) { 5817 const char *str; 5818 5819 if ((i & cpi->hba_misc) == 0) 5820 continue; 5821 5822 fprintf(stdout, "%s ", adapter_str); 5823 5824 switch(i) { 5825 case PIM_ATA_EXT: 5826 str = "can understand ata_ext requests"; 5827 break; 5828 case PIM_EXTLUNS: 5829 str = "64bit extended LUNs supported"; 5830 break; 5831 case PIM_SCANHILO: 5832 str = "bus scans from high ID to low ID"; 5833 break; 5834 case PIM_NOREMOVE: 5835 str = "removable devices not included in scan"; 5836 break; 5837 case PIM_NOINITIATOR: 5838 str = "initiator role not supported"; 5839 break; 5840 case PIM_NOBUSRESET: 5841 str = "user has disabled initial BUS RESET or" 5842 " controller is in target/mixed mode"; 5843 break; 5844 case PIM_NO_6_BYTE: 5845 str = "do not send 6-byte commands"; 5846 break; 5847 case PIM_SEQSCAN: 5848 str = "scan bus sequentially"; 5849 break; 5850 case PIM_UNMAPPED: 5851 str = "unmapped I/O supported"; 5852 break; 5853 case PIM_NOSCAN: 5854 str = "does its own scanning"; 5855 break; 5856 default: 5857 str = "unknown PIM bit set"; 5858 break; 5859 } 5860 fprintf(stdout, "%s\n", str); 5861 } 5862 5863 for (i = 1; i < UINT16_MAX; i = i << 1) { 5864 const char *str; 5865 5866 if ((i & cpi->target_sprt) == 0) 5867 continue; 5868 5869 fprintf(stdout, "%s supports ", adapter_str); 5870 switch(i) { 5871 case PIT_PROCESSOR: 5872 str = "target mode processor mode"; 5873 break; 5874 case PIT_PHASE: 5875 str = "target mode phase cog. mode"; 5876 break; 5877 case PIT_DISCONNECT: 5878 str = "disconnects in target mode"; 5879 break; 5880 case PIT_TERM_IO: 5881 str = "terminate I/O message in target mode"; 5882 break; 5883 case PIT_GRP_6: 5884 str = "group 6 commands in target mode"; 5885 break; 5886 case PIT_GRP_7: 5887 str = "group 7 commands in target mode"; 5888 break; 5889 default: 5890 str = "unknown PIT bit set"; 5891 break; 5892 } 5893 5894 fprintf(stdout, "%s\n", str); 5895 } 5896 fprintf(stdout, "%s HBA engine count: %d\n", adapter_str, 5897 cpi->hba_eng_cnt); 5898 fprintf(stdout, "%s maximum target: %d\n", adapter_str, 5899 cpi->max_target); 5900 fprintf(stdout, "%s maximum LUN: %d\n", adapter_str, 5901 cpi->max_lun); 5902 fprintf(stdout, "%s highest path ID in subsystem: %d\n", 5903 adapter_str, cpi->hpath_id); 5904 fprintf(stdout, "%s initiator ID: %d\n", adapter_str, 5905 cpi->initiator_id); 5906 fprintf(stdout, "%s SIM vendor: %s\n", adapter_str, cpi->sim_vid); 5907 fprintf(stdout, "%s HBA vendor: %s\n", adapter_str, cpi->hba_vid); 5908 fprintf(stdout, "%s HBA vendor ID: 0x%04x\n", 5909 adapter_str, cpi->hba_vendor); 5910 fprintf(stdout, "%s HBA device ID: 0x%04x\n", 5911 adapter_str, cpi->hba_device); 5912 fprintf(stdout, "%s HBA subvendor ID: 0x%04x\n", 5913 adapter_str, cpi->hba_subvendor); 5914 fprintf(stdout, "%s HBA subdevice ID: 0x%04x\n", 5915 adapter_str, cpi->hba_subdevice); 5916 fprintf(stdout, "%s bus ID: %d\n", adapter_str, cpi->bus_id); 5917 fprintf(stdout, "%s base transfer speed: ", adapter_str); 5918 if (cpi->base_transfer_speed > 1000) 5919 fprintf(stdout, "%d.%03dMB/sec\n", 5920 cpi->base_transfer_speed / 1000, 5921 cpi->base_transfer_speed % 1000); 5922 else 5923 fprintf(stdout, "%dKB/sec\n", 5924 (cpi->base_transfer_speed % 1000) * 1000); 5925 fprintf(stdout, "%s maximum transfer size: %u bytes\n", 5926 adapter_str, cpi->maxio); 5927 } 5928 5929 static int 5930 get_print_cts(struct cam_device *device, int user_settings, int quiet, 5931 struct ccb_trans_settings *cts) 5932 { 5933 int retval; 5934 union ccb *ccb; 5935 5936 retval = 0; 5937 ccb = cam_getccb(device); 5938 5939 if (ccb == NULL) { 5940 warnx("get_print_cts: error allocating ccb"); 5941 return (1); 5942 } 5943 5944 ccb->ccb_h.func_code = XPT_GET_TRAN_SETTINGS; 5945 5946 if (user_settings == 0) 5947 ccb->cts.type = CTS_TYPE_CURRENT_SETTINGS; 5948 else 5949 ccb->cts.type = CTS_TYPE_USER_SETTINGS; 5950 5951 if (cam_send_ccb(device, ccb) < 0) { 5952 warn("error sending XPT_GET_TRAN_SETTINGS CCB"); 5953 retval = 1; 5954 goto get_print_cts_bailout; 5955 } 5956 5957 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 5958 warnx("XPT_GET_TRANS_SETTINGS CCB failed"); 5959 if (arglist & CAM_ARG_VERBOSE) 5960 cam_error_print(device, ccb, CAM_ESF_ALL, 5961 CAM_EPF_ALL, stderr); 5962 retval = 1; 5963 goto get_print_cts_bailout; 5964 } 5965 5966 if (quiet == 0) 5967 cts_print(device, &ccb->cts); 5968 5969 if (cts != NULL) 5970 bcopy(&ccb->cts, cts, sizeof(struct ccb_trans_settings)); 5971 5972 get_print_cts_bailout: 5973 5974 cam_freeccb(ccb); 5975 5976 return (retval); 5977 } 5978 5979 static int 5980 ratecontrol(struct cam_device *device, int task_attr, int retry_count, 5981 int timeout, int argc, char **argv, char *combinedopt) 5982 { 5983 int c; 5984 union ccb *ccb; 5985 int user_settings = 0; 5986 int retval = 0; 5987 int disc_enable = -1, tag_enable = -1; 5988 int mode = -1; 5989 int offset = -1; 5990 double syncrate = -1; 5991 int bus_width = -1; 5992 int quiet = 0; 5993 int change_settings = 0, send_tur = 0; 5994 struct ccb_pathinq cpi; 5995 5996 ccb = cam_getccb(device); 5997 if (ccb == NULL) { 5998 warnx("ratecontrol: error allocating ccb"); 5999 return (1); 6000 } 6001 while ((c = getopt(argc, argv, combinedopt)) != -1) { 6002 switch(c){ 6003 case 'a': 6004 send_tur = 1; 6005 break; 6006 case 'c': 6007 user_settings = 0; 6008 break; 6009 case 'D': 6010 if (strncasecmp(optarg, "enable", 6) == 0) 6011 disc_enable = 1; 6012 else if (strncasecmp(optarg, "disable", 7) == 0) 6013 disc_enable = 0; 6014 else { 6015 warnx("-D argument \"%s\" is unknown", optarg); 6016 retval = 1; 6017 goto ratecontrol_bailout; 6018 } 6019 change_settings = 1; 6020 break; 6021 case 'M': 6022 mode = ata_string2mode(optarg); 6023 if (mode < 0) { 6024 warnx("unknown mode '%s'", optarg); 6025 retval = 1; 6026 goto ratecontrol_bailout; 6027 } 6028 change_settings = 1; 6029 break; 6030 case 'O': 6031 offset = strtol(optarg, NULL, 0); 6032 if (offset < 0) { 6033 warnx("offset value %d is < 0", offset); 6034 retval = 1; 6035 goto ratecontrol_bailout; 6036 } 6037 change_settings = 1; 6038 break; 6039 case 'q': 6040 quiet++; 6041 break; 6042 case 'R': 6043 syncrate = atof(optarg); 6044 if (syncrate < 0) { 6045 warnx("sync rate %f is < 0", syncrate); 6046 retval = 1; 6047 goto ratecontrol_bailout; 6048 } 6049 change_settings = 1; 6050 break; 6051 case 'T': 6052 if (strncasecmp(optarg, "enable", 6) == 0) 6053 tag_enable = 1; 6054 else if (strncasecmp(optarg, "disable", 7) == 0) 6055 tag_enable = 0; 6056 else { 6057 warnx("-T argument \"%s\" is unknown", optarg); 6058 retval = 1; 6059 goto ratecontrol_bailout; 6060 } 6061 change_settings = 1; 6062 break; 6063 case 'U': 6064 user_settings = 1; 6065 break; 6066 case 'W': 6067 bus_width = strtol(optarg, NULL, 0); 6068 if (bus_width < 0) { 6069 warnx("bus width %d is < 0", bus_width); 6070 retval = 1; 6071 goto ratecontrol_bailout; 6072 } 6073 change_settings = 1; 6074 break; 6075 default: 6076 break; 6077 } 6078 } 6079 /* 6080 * Grab path inquiry information, so we can determine whether 6081 * or not the initiator is capable of the things that the user 6082 * requests. 6083 */ 6084 if ((retval = get_cpi(device, &cpi)) != 0) 6085 goto ratecontrol_bailout; 6086 if (quiet == 0) { 6087 fprintf(stdout, "%s parameters:\n", 6088 user_settings ? "User" : "Current"); 6089 } 6090 retval = get_print_cts(device, user_settings, quiet, &ccb->cts); 6091 if (retval != 0) 6092 goto ratecontrol_bailout; 6093 6094 if (arglist & CAM_ARG_VERBOSE) 6095 cpi_print(&cpi); 6096 6097 if (change_settings) { 6098 int didsettings = 0; 6099 struct ccb_trans_settings_spi *spi = NULL; 6100 struct ccb_trans_settings_pata *pata = NULL; 6101 struct ccb_trans_settings_sata *sata = NULL; 6102 struct ccb_trans_settings_ata *ata = NULL; 6103 struct ccb_trans_settings_scsi *scsi = NULL; 6104 6105 if (ccb->cts.transport == XPORT_SPI) 6106 spi = &ccb->cts.xport_specific.spi; 6107 if (ccb->cts.transport == XPORT_ATA) 6108 pata = &ccb->cts.xport_specific.ata; 6109 if (ccb->cts.transport == XPORT_SATA) 6110 sata = &ccb->cts.xport_specific.sata; 6111 if (ccb->cts.protocol == PROTO_ATA) 6112 ata = &ccb->cts.proto_specific.ata; 6113 if (ccb->cts.protocol == PROTO_SCSI) 6114 scsi = &ccb->cts.proto_specific.scsi; 6115 ccb->cts.xport_specific.valid = 0; 6116 ccb->cts.proto_specific.valid = 0; 6117 if (spi && disc_enable != -1) { 6118 spi->valid |= CTS_SPI_VALID_DISC; 6119 if (disc_enable == 0) 6120 spi->flags &= ~CTS_SPI_FLAGS_DISC_ENB; 6121 else 6122 spi->flags |= CTS_SPI_FLAGS_DISC_ENB; 6123 didsettings++; 6124 } 6125 if (tag_enable != -1) { 6126 if ((cpi.hba_inquiry & PI_TAG_ABLE) == 0) { 6127 warnx("HBA does not support tagged queueing, " 6128 "so you cannot modify tag settings"); 6129 retval = 1; 6130 goto ratecontrol_bailout; 6131 } 6132 if (ata) { 6133 ata->valid |= CTS_SCSI_VALID_TQ; 6134 if (tag_enable == 0) 6135 ata->flags &= ~CTS_ATA_FLAGS_TAG_ENB; 6136 else 6137 ata->flags |= CTS_ATA_FLAGS_TAG_ENB; 6138 didsettings++; 6139 } else if (scsi) { 6140 scsi->valid |= CTS_SCSI_VALID_TQ; 6141 if (tag_enable == 0) 6142 scsi->flags &= ~CTS_SCSI_FLAGS_TAG_ENB; 6143 else 6144 scsi->flags |= CTS_SCSI_FLAGS_TAG_ENB; 6145 didsettings++; 6146 } 6147 } 6148 if (spi && offset != -1) { 6149 if ((cpi.hba_inquiry & PI_SDTR_ABLE) == 0) { 6150 warnx("HBA is not capable of changing offset"); 6151 retval = 1; 6152 goto ratecontrol_bailout; 6153 } 6154 spi->valid |= CTS_SPI_VALID_SYNC_OFFSET; 6155 spi->sync_offset = offset; 6156 didsettings++; 6157 } 6158 if (spi && syncrate != -1) { 6159 int prelim_sync_period; 6160 6161 if ((cpi.hba_inquiry & PI_SDTR_ABLE) == 0) { 6162 warnx("HBA is not capable of changing " 6163 "transfer rates"); 6164 retval = 1; 6165 goto ratecontrol_bailout; 6166 } 6167 spi->valid |= CTS_SPI_VALID_SYNC_RATE; 6168 /* 6169 * The sync rate the user gives us is in MHz. 6170 * We need to translate it into KHz for this 6171 * calculation. 6172 */ 6173 syncrate *= 1000; 6174 /* 6175 * Next, we calculate a "preliminary" sync period 6176 * in tenths of a nanosecond. 6177 */ 6178 if (syncrate == 0) 6179 prelim_sync_period = 0; 6180 else 6181 prelim_sync_period = 10000000 / syncrate; 6182 spi->sync_period = 6183 scsi_calc_syncparam(prelim_sync_period); 6184 didsettings++; 6185 } 6186 if (sata && syncrate != -1) { 6187 if ((cpi.hba_inquiry & PI_SDTR_ABLE) == 0) { 6188 warnx("HBA is not capable of changing " 6189 "transfer rates"); 6190 retval = 1; 6191 goto ratecontrol_bailout; 6192 } 6193 if (!user_settings) { 6194 warnx("You can modify only user rate " 6195 "settings for SATA"); 6196 retval = 1; 6197 goto ratecontrol_bailout; 6198 } 6199 sata->revision = ata_speed2revision(syncrate * 100); 6200 if (sata->revision < 0) { 6201 warnx("Invalid rate %f", syncrate); 6202 retval = 1; 6203 goto ratecontrol_bailout; 6204 } 6205 sata->valid |= CTS_SATA_VALID_REVISION; 6206 didsettings++; 6207 } 6208 if ((pata || sata) && mode != -1) { 6209 if ((cpi.hba_inquiry & PI_SDTR_ABLE) == 0) { 6210 warnx("HBA is not capable of changing " 6211 "transfer rates"); 6212 retval = 1; 6213 goto ratecontrol_bailout; 6214 } 6215 if (!user_settings) { 6216 warnx("You can modify only user mode " 6217 "settings for ATA/SATA"); 6218 retval = 1; 6219 goto ratecontrol_bailout; 6220 } 6221 if (pata) { 6222 pata->mode = mode; 6223 pata->valid |= CTS_ATA_VALID_MODE; 6224 } else { 6225 sata->mode = mode; 6226 sata->valid |= CTS_SATA_VALID_MODE; 6227 } 6228 didsettings++; 6229 } 6230 /* 6231 * The bus_width argument goes like this: 6232 * 0 == 8 bit 6233 * 1 == 16 bit 6234 * 2 == 32 bit 6235 * Therefore, if you shift the number of bits given on the 6236 * command line right by 4, you should get the correct 6237 * number. 6238 */ 6239 if (spi && bus_width != -1) { 6240 /* 6241 * We might as well validate things here with a 6242 * decipherable error message, rather than what 6243 * will probably be an indecipherable error message 6244 * by the time it gets back to us. 6245 */ 6246 if ((bus_width == 16) 6247 && ((cpi.hba_inquiry & PI_WIDE_16) == 0)) { 6248 warnx("HBA does not support 16 bit bus width"); 6249 retval = 1; 6250 goto ratecontrol_bailout; 6251 } else if ((bus_width == 32) 6252 && ((cpi.hba_inquiry & PI_WIDE_32) == 0)) { 6253 warnx("HBA does not support 32 bit bus width"); 6254 retval = 1; 6255 goto ratecontrol_bailout; 6256 } else if ((bus_width != 8) 6257 && (bus_width != 16) 6258 && (bus_width != 32)) { 6259 warnx("Invalid bus width %d", bus_width); 6260 retval = 1; 6261 goto ratecontrol_bailout; 6262 } 6263 spi->valid |= CTS_SPI_VALID_BUS_WIDTH; 6264 spi->bus_width = bus_width >> 4; 6265 didsettings++; 6266 } 6267 if (didsettings == 0) { 6268 goto ratecontrol_bailout; 6269 } 6270 ccb->ccb_h.func_code = XPT_SET_TRAN_SETTINGS; 6271 if (cam_send_ccb(device, ccb) < 0) { 6272 warn("error sending XPT_SET_TRAN_SETTINGS CCB"); 6273 retval = 1; 6274 goto ratecontrol_bailout; 6275 } 6276 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 6277 warnx("XPT_SET_TRANS_SETTINGS CCB failed"); 6278 if (arglist & CAM_ARG_VERBOSE) { 6279 cam_error_print(device, ccb, CAM_ESF_ALL, 6280 CAM_EPF_ALL, stderr); 6281 } 6282 retval = 1; 6283 goto ratecontrol_bailout; 6284 } 6285 } 6286 if (send_tur) { 6287 retval = testunitready(device, task_attr, retry_count, timeout, 6288 (arglist & CAM_ARG_VERBOSE) ? 0 : 1); 6289 /* 6290 * If the TUR didn't succeed, just bail. 6291 */ 6292 if (retval != 0) { 6293 if (quiet == 0) 6294 fprintf(stderr, "Test Unit Ready failed\n"); 6295 goto ratecontrol_bailout; 6296 } 6297 } 6298 if ((change_settings || send_tur) && !quiet && 6299 (ccb->cts.transport == XPORT_ATA || 6300 ccb->cts.transport == XPORT_SATA || send_tur)) { 6301 fprintf(stdout, "New parameters:\n"); 6302 retval = get_print_cts(device, user_settings, 0, NULL); 6303 } 6304 6305 ratecontrol_bailout: 6306 cam_freeccb(ccb); 6307 return (retval); 6308 } 6309 6310 static int 6311 scsiformat(struct cam_device *device, int argc, char **argv, 6312 char *combinedopt, int task_attr, int retry_count, int timeout) 6313 { 6314 union ccb *ccb; 6315 int c; 6316 int ycount = 0, quiet = 0; 6317 int error = 0, retval = 0; 6318 int use_timeout = 10800 * 1000; 6319 int immediate = 1; 6320 struct format_defect_list_header fh; 6321 uint8_t *data_ptr = NULL; 6322 uint32_t dxfer_len = 0; 6323 uint8_t byte2 = 0; 6324 int num_warnings = 0; 6325 int reportonly = 0; 6326 6327 ccb = cam_getccb(device); 6328 6329 if (ccb == NULL) { 6330 warnx("scsiformat: error allocating ccb"); 6331 return (1); 6332 } 6333 6334 while ((c = getopt(argc, argv, combinedopt)) != -1) { 6335 switch(c) { 6336 case 'q': 6337 quiet++; 6338 break; 6339 case 'r': 6340 reportonly = 1; 6341 break; 6342 case 'w': 6343 immediate = 0; 6344 break; 6345 case 'y': 6346 ycount++; 6347 break; 6348 } 6349 } 6350 6351 if (reportonly) 6352 goto doreport; 6353 6354 if (quiet == 0 && ycount == 0) { 6355 fprintf(stdout, "You are about to REMOVE ALL DATA from the " 6356 "following device:\n"); 6357 6358 error = scsidoinquiry(device, argc, argv, combinedopt, 6359 task_attr, retry_count, timeout); 6360 6361 if (error != 0) { 6362 warnx("scsiformat: error sending inquiry"); 6363 goto scsiformat_bailout; 6364 } 6365 } 6366 6367 if (ycount == 0) { 6368 if (!get_confirmation()) { 6369 error = 1; 6370 goto scsiformat_bailout; 6371 } 6372 } 6373 6374 if (timeout != 0) 6375 use_timeout = timeout; 6376 6377 if (quiet == 0) { 6378 fprintf(stdout, "Current format timeout is %d seconds\n", 6379 use_timeout / 1000); 6380 } 6381 6382 /* 6383 * If the user hasn't disabled questions and didn't specify a 6384 * timeout on the command line, ask them if they want the current 6385 * timeout. 6386 */ 6387 if ((ycount == 0) 6388 && (timeout == 0)) { 6389 char str[1024]; 6390 int new_timeout = 0; 6391 6392 fprintf(stdout, "Enter new timeout in seconds or press\n" 6393 "return to keep the current timeout [%d] ", 6394 use_timeout / 1000); 6395 6396 if (fgets(str, sizeof(str), stdin) != NULL) { 6397 if (str[0] != '\0') 6398 new_timeout = atoi(str); 6399 } 6400 6401 if (new_timeout != 0) { 6402 use_timeout = new_timeout * 1000; 6403 fprintf(stdout, "Using new timeout value %d\n", 6404 use_timeout / 1000); 6405 } 6406 } 6407 6408 /* 6409 * Keep this outside the if block below to silence any unused 6410 * variable warnings. 6411 */ 6412 bzero(&fh, sizeof(fh)); 6413 6414 /* 6415 * If we're in immediate mode, we've got to include the format 6416 * header 6417 */ 6418 if (immediate != 0) { 6419 fh.byte2 = FU_DLH_IMMED; 6420 data_ptr = (uint8_t *)&fh; 6421 dxfer_len = sizeof(fh); 6422 byte2 = FU_FMT_DATA; 6423 } else if (quiet == 0) { 6424 fprintf(stdout, "Formatting..."); 6425 fflush(stdout); 6426 } 6427 6428 scsi_format_unit(&ccb->csio, 6429 /* retries */ retry_count, 6430 /* cbfcnp */ NULL, 6431 /* tag_action */ task_attr, 6432 /* byte2 */ byte2, 6433 /* ileave */ 0, 6434 /* data_ptr */ data_ptr, 6435 /* dxfer_len */ dxfer_len, 6436 /* sense_len */ SSD_FULL_SIZE, 6437 /* timeout */ use_timeout); 6438 6439 /* Disable freezing the device queue */ 6440 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 6441 6442 if (arglist & CAM_ARG_ERR_RECOVER) 6443 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 6444 6445 if (((retval = cam_send_ccb(device, ccb)) < 0) 6446 || ((immediate == 0) 6447 && ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP))) { 6448 const char errstr[] = "error sending format command"; 6449 6450 if (retval < 0) 6451 warn(errstr); 6452 else 6453 warnx(errstr); 6454 6455 if (arglist & CAM_ARG_VERBOSE) { 6456 cam_error_print(device, ccb, CAM_ESF_ALL, 6457 CAM_EPF_ALL, stderr); 6458 } 6459 error = 1; 6460 goto scsiformat_bailout; 6461 } 6462 6463 /* 6464 * If we ran in non-immediate mode, we already checked for errors 6465 * above and printed out any necessary information. If we're in 6466 * immediate mode, we need to loop through and get status 6467 * information periodically. 6468 */ 6469 if (immediate == 0) { 6470 if (quiet == 0) { 6471 fprintf(stdout, "Format Complete\n"); 6472 } 6473 goto scsiformat_bailout; 6474 } 6475 6476 doreport: 6477 do { 6478 cam_status status; 6479 6480 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->csio); 6481 6482 /* 6483 * There's really no need to do error recovery or 6484 * retries here, since we're just going to sit in a 6485 * loop and wait for the device to finish formatting. 6486 */ 6487 scsi_test_unit_ready(&ccb->csio, 6488 /* retries */ 0, 6489 /* cbfcnp */ NULL, 6490 /* tag_action */ task_attr, 6491 /* sense_len */ SSD_FULL_SIZE, 6492 /* timeout */ 5000); 6493 6494 /* Disable freezing the device queue */ 6495 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 6496 6497 retval = cam_send_ccb(device, ccb); 6498 6499 /* 6500 * If we get an error from the ioctl, bail out. SCSI 6501 * errors are expected. 6502 */ 6503 if (retval < 0) { 6504 warn("error sending TEST UNIT READY command"); 6505 error = 1; 6506 goto scsiformat_bailout; 6507 } 6508 6509 status = ccb->ccb_h.status & CAM_STATUS_MASK; 6510 6511 if ((status != CAM_REQ_CMP) 6512 && (status == CAM_SCSI_STATUS_ERROR) 6513 && ((ccb->ccb_h.status & CAM_AUTOSNS_VALID) != 0)) { 6514 struct scsi_sense_data *sense; 6515 int error_code, sense_key, asc, ascq; 6516 6517 sense = &ccb->csio.sense_data; 6518 scsi_extract_sense_len(sense, ccb->csio.sense_len - 6519 ccb->csio.sense_resid, &error_code, &sense_key, 6520 &asc, &ascq, /*show_errors*/ 1); 6521 6522 /* 6523 * According to the SCSI-2 and SCSI-3 specs, a 6524 * drive that is in the middle of a format should 6525 * return NOT READY with an ASC of "logical unit 6526 * not ready, format in progress". The sense key 6527 * specific bytes will then be a progress indicator. 6528 */ 6529 if ((sense_key == SSD_KEY_NOT_READY) 6530 && (asc == 0x04) && (ascq == 0x04)) { 6531 uint8_t sks[3]; 6532 6533 if ((scsi_get_sks(sense, ccb->csio.sense_len - 6534 ccb->csio.sense_resid, sks) == 0) 6535 && (quiet == 0)) { 6536 uint32_t val; 6537 u_int64_t percentage; 6538 6539 val = scsi_2btoul(&sks[1]); 6540 percentage = 10000ull * val; 6541 6542 fprintf(stdout, 6543 "\rFormatting: %ju.%02u %% " 6544 "(%u/%d) done", 6545 (uintmax_t)(percentage / 6546 (0x10000 * 100)), 6547 (unsigned)((percentage / 6548 0x10000) % 100), 6549 val, 0x10000); 6550 fflush(stdout); 6551 } else if ((quiet == 0) 6552 && (++num_warnings <= 1)) { 6553 warnx("Unexpected SCSI Sense Key " 6554 "Specific value returned " 6555 "during format:"); 6556 scsi_sense_print(device, &ccb->csio, 6557 stderr); 6558 warnx("Unable to print status " 6559 "information, but format will " 6560 "proceed."); 6561 warnx("will exit when format is " 6562 "complete"); 6563 } 6564 sleep(1); 6565 } else { 6566 warnx("Unexpected SCSI error during format"); 6567 cam_error_print(device, ccb, CAM_ESF_ALL, 6568 CAM_EPF_ALL, stderr); 6569 error = 1; 6570 goto scsiformat_bailout; 6571 } 6572 6573 } else if (status != CAM_REQ_CMP) { 6574 warnx("Unexpected CAM status %#x", status); 6575 if (arglist & CAM_ARG_VERBOSE) 6576 cam_error_print(device, ccb, CAM_ESF_ALL, 6577 CAM_EPF_ALL, stderr); 6578 error = 1; 6579 goto scsiformat_bailout; 6580 } 6581 6582 } while((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP); 6583 6584 if (quiet == 0) 6585 fprintf(stdout, "\nFormat Complete\n"); 6586 6587 scsiformat_bailout: 6588 6589 cam_freeccb(ccb); 6590 6591 return (error); 6592 } 6593 6594 static int 6595 sanitize_wait_ata(struct cam_device *device, union ccb *ccb, int quiet, 6596 camcontrol_devtype devtype) 6597 { 6598 int retval; 6599 uint8_t error = 0, ata_device = 0, status = 0; 6600 uint16_t count = 0; 6601 uint64_t lba = 0; 6602 u_int val, perc; 6603 6604 do { 6605 retval = build_ata_cmd(ccb, 6606 /*retries*/ 0, 6607 /*flags*/ CAM_DIR_NONE, 6608 /*tag_action*/ MSG_SIMPLE_Q_TAG, 6609 /*protocol*/ AP_PROTO_NON_DATA, 6610 /*ata_flags*/ AP_FLAG_CHK_COND, 6611 /*features*/ 0x00, /* SANITIZE STATUS EXT */ 6612 /*sector_count*/ 0, 6613 /*lba*/ 0, 6614 /*command*/ ATA_SANITIZE, 6615 /*auxiliary*/ 0, 6616 /*data_ptr*/ NULL, 6617 /*dxfer_len*/ 0, 6618 /*cdb_storage*/ NULL, 6619 /*cdb_storage_len*/ 0, 6620 /*sense_len*/ SSD_FULL_SIZE, 6621 /*timeout*/ 10000, 6622 /*is48bit*/ 1, 6623 /*devtype*/ devtype); 6624 if (retval != 0) { 6625 warnx("%s: build_ata_cmd() failed, likely " 6626 "programmer error", __func__); 6627 return (1); 6628 } 6629 6630 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 6631 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 6632 retval = cam_send_ccb(device, ccb); 6633 if (retval != 0) { 6634 warn("error sending SANITIZE STATUS EXT command"); 6635 return (1); 6636 } 6637 6638 retval = get_ata_status(device, ccb, &error, &count, &lba, 6639 &ata_device, &status); 6640 if (retval != 0) { 6641 warnx("Can't get SANITIZE STATUS EXT status, " 6642 "sanitize may still run."); 6643 return (retval); 6644 } 6645 if (status & ATA_STATUS_ERROR) { 6646 if (error & ATA_ERROR_ABORT) { 6647 switch (lba & 0xff) { 6648 case 0x00: 6649 warnx("Reason not reported or sanitize failed."); 6650 return (1); 6651 case 0x01: 6652 warnx("Sanitize command unsuccessful. "); 6653 return (1); 6654 case 0x02: 6655 warnx("Unsupported sanitize device command. "); 6656 return (1); 6657 case 0x03: 6658 warnx("Device is in sanitize frozen state. "); 6659 return (1); 6660 case 0x04: 6661 warnx("Sanitize antifreeze lock is enabled. "); 6662 return (1); 6663 } 6664 } 6665 warnx("SANITIZE STATUS EXT failed, " 6666 "sanitize may still run."); 6667 return (1); 6668 } 6669 if (count & 0x4000) { 6670 if (quiet == 0) { 6671 val = lba & 0xffff; 6672 perc = 10000 * val; 6673 fprintf(stdout, 6674 "Sanitizing: %u.%02u%% (%d/%d)\r", 6675 (perc / (0x10000 * 100)), 6676 ((perc / 0x10000) % 100), 6677 val, 0x10000); 6678 fflush(stdout); 6679 } 6680 sleep(1); 6681 } else 6682 break; 6683 } while (1); 6684 return (0); 6685 } 6686 6687 static int 6688 sanitize_wait_scsi(struct cam_device *device, union ccb *ccb, int task_attr, int quiet) 6689 { 6690 int warnings = 0, retval; 6691 cam_status status; 6692 u_int val, perc; 6693 6694 do { 6695 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->csio); 6696 6697 /* 6698 * There's really no need to do error recovery or 6699 * retries here, since we're just going to sit in a 6700 * loop and wait for the device to finish sanitizing. 6701 */ 6702 scsi_test_unit_ready(&ccb->csio, 6703 /* retries */ 0, 6704 /* cbfcnp */ NULL, 6705 /* tag_action */ task_attr, 6706 /* sense_len */ SSD_FULL_SIZE, 6707 /* timeout */ 5000); 6708 6709 /* Disable freezing the device queue */ 6710 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 6711 6712 retval = cam_send_ccb(device, ccb); 6713 6714 /* 6715 * If we get an error from the ioctl, bail out. SCSI 6716 * errors are expected. 6717 */ 6718 if (retval < 0) { 6719 warn("error sending TEST UNIT READY command"); 6720 return (1); 6721 } 6722 6723 status = ccb->ccb_h.status & CAM_STATUS_MASK; 6724 if ((status == CAM_SCSI_STATUS_ERROR) && 6725 ((ccb->ccb_h.status & CAM_AUTOSNS_VALID) != 0)) { 6726 struct scsi_sense_data *sense; 6727 int error_code, sense_key, asc, ascq; 6728 6729 sense = &ccb->csio.sense_data; 6730 scsi_extract_sense_len(sense, ccb->csio.sense_len - 6731 ccb->csio.sense_resid, &error_code, &sense_key, 6732 &asc, &ascq, /*show_errors*/ 1); 6733 6734 /* 6735 * According to the SCSI-3 spec, a drive that is in the 6736 * middle of a sanitize should return NOT READY with an 6737 * ASC of "logical unit not ready, sanitize in 6738 * progress". The sense key specific bytes will then 6739 * be a progress indicator. 6740 */ 6741 if ((sense_key == SSD_KEY_NOT_READY) 6742 && (asc == 0x04) && (ascq == 0x1b)) { 6743 uint8_t sks[3]; 6744 6745 if ((scsi_get_sks(sense, ccb->csio.sense_len - 6746 ccb->csio.sense_resid, sks) == 0) 6747 && (quiet == 0)) { 6748 val = scsi_2btoul(&sks[1]); 6749 perc = 10000 * val; 6750 fprintf(stdout, 6751 "Sanitizing: %u.%02u%% (%d/%d)\r", 6752 (perc / (0x10000 * 100)), 6753 ((perc / 0x10000) % 100), 6754 val, 0x10000); 6755 fflush(stdout); 6756 } else if ((quiet == 0) && (++warnings <= 1)) { 6757 warnx("Unexpected SCSI Sense Key " 6758 "Specific value returned " 6759 "during sanitize:"); 6760 scsi_sense_print(device, &ccb->csio, 6761 stderr); 6762 warnx("Unable to print status " 6763 "information, but sanitze will " 6764 "proceed."); 6765 warnx("will exit when sanitize is " 6766 "complete"); 6767 } 6768 sleep(1); 6769 } else { 6770 warnx("Unexpected SCSI error during sanitize"); 6771 cam_error_print(device, ccb, CAM_ESF_ALL, 6772 CAM_EPF_ALL, stderr); 6773 return (1); 6774 } 6775 6776 } else if (status != CAM_REQ_CMP && status != CAM_REQUEUE_REQ) { 6777 warnx("Unexpected CAM status %#x", status); 6778 if (arglist & CAM_ARG_VERBOSE) 6779 cam_error_print(device, ccb, CAM_ESF_ALL, 6780 CAM_EPF_ALL, stderr); 6781 return (1); 6782 } 6783 } while ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP); 6784 return (0); 6785 } 6786 6787 static int 6788 sanitize(struct cam_device *device, int argc, char **argv, 6789 char *combinedopt, int task_attr, int retry_count, int timeout) 6790 { 6791 union ccb *ccb; 6792 uint8_t action = 0; 6793 int c; 6794 int ycount = 0, quiet = 0; 6795 int error = 0; 6796 int use_timeout; 6797 int immediate = 1; 6798 int invert = 0; 6799 int passes = 0; 6800 int ause = 0; 6801 int fd = -1; 6802 const char *pattern = NULL; 6803 uint8_t *data_ptr = NULL; 6804 uint32_t dxfer_len = 0; 6805 uint8_t byte2; 6806 uint16_t feature, count; 6807 uint64_t lba; 6808 int reportonly = 0; 6809 camcontrol_devtype dt; 6810 6811 /* 6812 * Get the device type, request no I/O be done to do this. 6813 */ 6814 error = get_device_type(device, -1, 0, 0, &dt); 6815 if (error != 0 || (unsigned)dt > CC_DT_UNKNOWN) { 6816 warnx("sanitize: can't get device type"); 6817 return (1); 6818 } 6819 6820 ccb = cam_getccb(device); 6821 6822 if (ccb == NULL) { 6823 warnx("sanitize: error allocating ccb"); 6824 return (1); 6825 } 6826 6827 while ((c = getopt(argc, argv, combinedopt)) != -1) { 6828 switch(c) { 6829 case 'a': 6830 if (strcasecmp(optarg, "overwrite") == 0) 6831 action = SSZ_SERVICE_ACTION_OVERWRITE; 6832 else if (strcasecmp(optarg, "block") == 0) 6833 action = SSZ_SERVICE_ACTION_BLOCK_ERASE; 6834 else if (strcasecmp(optarg, "crypto") == 0) 6835 action = SSZ_SERVICE_ACTION_CRYPTO_ERASE; 6836 else if (strcasecmp(optarg, "exitfailure") == 0) 6837 action = SSZ_SERVICE_ACTION_EXIT_MODE_FAILURE; 6838 else { 6839 warnx("invalid service operation \"%s\"", 6840 optarg); 6841 error = 1; 6842 goto sanitize_bailout; 6843 } 6844 break; 6845 case 'c': 6846 passes = strtol(optarg, NULL, 0); 6847 if (passes < 1 || passes > 31) { 6848 warnx("invalid passes value %d", passes); 6849 error = 1; 6850 goto sanitize_bailout; 6851 } 6852 break; 6853 case 'I': 6854 invert = 1; 6855 break; 6856 case 'P': 6857 pattern = optarg; 6858 break; 6859 case 'q': 6860 quiet++; 6861 break; 6862 case 'U': 6863 ause = 1; 6864 break; 6865 case 'r': 6866 reportonly = 1; 6867 break; 6868 case 'w': 6869 /* ATA supports only immediate commands. */ 6870 if (dt == CC_DT_SCSI) 6871 immediate = 0; 6872 break; 6873 case 'y': 6874 ycount++; 6875 break; 6876 } 6877 } 6878 6879 if (reportonly) 6880 goto doreport; 6881 6882 if (action == 0) { 6883 warnx("an action is required"); 6884 error = 1; 6885 goto sanitize_bailout; 6886 } else if (action == SSZ_SERVICE_ACTION_OVERWRITE) { 6887 struct scsi_sanitize_parameter_list *pl; 6888 struct stat sb; 6889 ssize_t sz, amt; 6890 6891 if (pattern == NULL) { 6892 warnx("overwrite action requires -P argument"); 6893 error = 1; 6894 goto sanitize_bailout; 6895 } 6896 fd = open(pattern, O_RDONLY); 6897 if (fd < 0) { 6898 warn("cannot open pattern file %s", pattern); 6899 error = 1; 6900 goto sanitize_bailout; 6901 } 6902 if (fstat(fd, &sb) < 0) { 6903 warn("cannot stat pattern file %s", pattern); 6904 error = 1; 6905 goto sanitize_bailout; 6906 } 6907 sz = sb.st_size; 6908 if (sz > SSZPL_MAX_PATTERN_LENGTH) { 6909 warnx("pattern file size exceeds maximum value %d", 6910 SSZPL_MAX_PATTERN_LENGTH); 6911 error = 1; 6912 goto sanitize_bailout; 6913 } 6914 dxfer_len = sizeof(*pl) + sz; 6915 data_ptr = calloc(1, dxfer_len); 6916 if (data_ptr == NULL) { 6917 warnx("cannot allocate parameter list buffer"); 6918 error = 1; 6919 goto sanitize_bailout; 6920 } 6921 6922 amt = read(fd, data_ptr + sizeof(*pl), sz); 6923 if (amt < 0) { 6924 warn("cannot read pattern file"); 6925 error = 1; 6926 goto sanitize_bailout; 6927 } else if (amt != sz) { 6928 warnx("short pattern file read"); 6929 error = 1; 6930 goto sanitize_bailout; 6931 } 6932 6933 pl = (struct scsi_sanitize_parameter_list *)data_ptr; 6934 if (passes == 0) 6935 pl->byte1 = 1; 6936 else 6937 pl->byte1 = passes; 6938 if (invert != 0) 6939 pl->byte1 |= SSZPL_INVERT; 6940 scsi_ulto2b(sz, pl->length); 6941 } else { 6942 const char *arg; 6943 6944 if (passes != 0) 6945 arg = "-c"; 6946 else if (invert != 0) 6947 arg = "-I"; 6948 else if (pattern != NULL) 6949 arg = "-P"; 6950 else 6951 arg = NULL; 6952 if (arg != NULL) { 6953 warnx("%s argument only valid with overwrite " 6954 "operation", arg); 6955 error = 1; 6956 goto sanitize_bailout; 6957 } 6958 } 6959 6960 if (quiet == 0 && ycount == 0) { 6961 fprintf(stdout, "You are about to REMOVE ALL DATA from the " 6962 "following device:\n"); 6963 6964 if (dt == CC_DT_SCSI) { 6965 error = scsidoinquiry(device, argc, argv, combinedopt, 6966 task_attr, retry_count, timeout); 6967 } else if (dt == CC_DT_ATA || dt == CC_DT_SATL) { 6968 struct ata_params *ident_buf; 6969 error = ata_do_identify(device, retry_count, timeout, 6970 ccb, &ident_buf); 6971 if (error == 0) { 6972 printf("%s%d: ", device->device_name, 6973 device->dev_unit_num); 6974 ata_print_ident(ident_buf); 6975 free(ident_buf); 6976 } 6977 } else 6978 error = 1; 6979 6980 if (error != 0) { 6981 warnx("sanitize: error sending inquiry"); 6982 goto sanitize_bailout; 6983 } 6984 } 6985 6986 if (ycount == 0) { 6987 if (!get_confirmation()) { 6988 error = 1; 6989 goto sanitize_bailout; 6990 } 6991 } 6992 6993 if (timeout != 0) 6994 use_timeout = timeout; 6995 else 6996 use_timeout = (immediate ? 10 : 10800) * 1000; 6997 6998 if (immediate == 0 && quiet == 0) { 6999 fprintf(stdout, "Current sanitize timeout is %d seconds\n", 7000 use_timeout / 1000); 7001 } 7002 7003 /* 7004 * If the user hasn't disabled questions and didn't specify a 7005 * timeout on the command line, ask them if they want the current 7006 * timeout. 7007 */ 7008 if (immediate == 0 && ycount == 0 && timeout == 0) { 7009 char str[1024]; 7010 int new_timeout = 0; 7011 7012 fprintf(stdout, "Enter new timeout in seconds or press\n" 7013 "return to keep the current timeout [%d] ", 7014 use_timeout / 1000); 7015 7016 if (fgets(str, sizeof(str), stdin) != NULL) { 7017 if (str[0] != '\0') 7018 new_timeout = atoi(str); 7019 } 7020 7021 if (new_timeout != 0) { 7022 use_timeout = new_timeout * 1000; 7023 fprintf(stdout, "Using new timeout value %d\n", 7024 use_timeout / 1000); 7025 } 7026 } 7027 7028 if (dt == CC_DT_SCSI) { 7029 byte2 = action; 7030 if (ause != 0) 7031 byte2 |= SSZ_UNRESTRICTED_EXIT; 7032 if (immediate != 0) 7033 byte2 |= SSZ_IMMED; 7034 scsi_sanitize(&ccb->csio, 7035 /* retries */ retry_count, 7036 /* cbfcnp */ NULL, 7037 /* tag_action */ task_attr, 7038 /* byte2 */ byte2, 7039 /* control */ 0, 7040 /* data_ptr */ data_ptr, 7041 /* dxfer_len */ dxfer_len, 7042 /* sense_len */ SSD_FULL_SIZE, 7043 /* timeout */ use_timeout); 7044 7045 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 7046 if (arglist & CAM_ARG_ERR_RECOVER) 7047 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 7048 if (cam_send_ccb(device, ccb) < 0) { 7049 warn("error sending sanitize command"); 7050 error = 1; 7051 goto sanitize_bailout; 7052 } 7053 } else if (dt == CC_DT_ATA || dt == CC_DT_SATL) { 7054 if (action == SSZ_SERVICE_ACTION_OVERWRITE) { 7055 feature = 0x14; /* OVERWRITE EXT */ 7056 lba = 0x4F5700000000 | scsi_4btoul(data_ptr + 4); 7057 count = (passes == 0) ? 1 : (passes >= 16) ? 0 : passes; 7058 if (invert) 7059 count |= 0x80; /* INVERT PATTERN */ 7060 if (ause) 7061 count |= 0x10; /* FAILURE MODE */ 7062 } else if (action == SSZ_SERVICE_ACTION_BLOCK_ERASE) { 7063 feature = 0x12; /* BLOCK ERASE EXT */ 7064 lba = 0x0000426B4572; 7065 count = 0; 7066 if (ause) 7067 count |= 0x10; /* FAILURE MODE */ 7068 } else if (action == SSZ_SERVICE_ACTION_CRYPTO_ERASE) { 7069 feature = 0x11; /* CRYPTO SCRAMBLE EXT */ 7070 lba = 0x000043727970; 7071 count = 0; 7072 if (ause) 7073 count |= 0x10; /* FAILURE MODE */ 7074 } else if (action == SSZ_SERVICE_ACTION_EXIT_MODE_FAILURE) { 7075 feature = 0x00; /* SANITIZE STATUS EXT */ 7076 lba = 0; 7077 count = 1; /* CLEAR SANITIZE OPERATION FAILED */ 7078 } else { 7079 error = 1; 7080 goto sanitize_bailout; 7081 } 7082 7083 error = ata_do_cmd(device, 7084 ccb, 7085 retry_count, 7086 /*flags*/CAM_DIR_NONE, 7087 /*protocol*/AP_PROTO_NON_DATA | AP_EXTEND, 7088 /*ata_flags*/0, 7089 /*tag_action*/MSG_SIMPLE_Q_TAG, 7090 /*command*/ATA_SANITIZE, 7091 /*features*/feature, 7092 /*lba*/lba, 7093 /*sector_count*/count, 7094 /*data_ptr*/NULL, 7095 /*dxfer_len*/0, 7096 /*timeout*/ use_timeout, 7097 /*is48bit*/1); 7098 } 7099 7100 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 7101 struct scsi_sense_data *sense; 7102 int error_code, sense_key, asc, ascq; 7103 7104 if ((ccb->ccb_h.status & CAM_STATUS_MASK) == 7105 CAM_SCSI_STATUS_ERROR) { 7106 sense = &ccb->csio.sense_data; 7107 scsi_extract_sense_len(sense, ccb->csio.sense_len - 7108 ccb->csio.sense_resid, &error_code, &sense_key, 7109 &asc, &ascq, /*show_errors*/ 1); 7110 7111 if (sense_key == SSD_KEY_ILLEGAL_REQUEST && 7112 asc == 0x20 && ascq == 0x00) 7113 warnx("sanitize is not supported by " 7114 "this device"); 7115 else 7116 warnx("error sanitizing this device"); 7117 } else 7118 warnx("error sanitizing this device"); 7119 7120 if (arglist & CAM_ARG_VERBOSE) { 7121 cam_error_print(device, ccb, CAM_ESF_ALL, 7122 CAM_EPF_ALL, stderr); 7123 } 7124 error = 1; 7125 goto sanitize_bailout; 7126 } 7127 7128 /* 7129 * If we ran in non-immediate mode, we already checked for errors 7130 * above and printed out any necessary information. If we're in 7131 * immediate mode, we need to loop through and get status 7132 * information periodically. 7133 */ 7134 if (immediate == 0) { 7135 if (quiet == 0) { 7136 fprintf(stdout, "Sanitize Complete\n"); 7137 } 7138 goto sanitize_bailout; 7139 } 7140 7141 doreport: 7142 if (dt == CC_DT_SCSI) { 7143 error = sanitize_wait_scsi(device, ccb, task_attr, quiet); 7144 } else if (dt == CC_DT_ATA || dt == CC_DT_SATL) { 7145 error = sanitize_wait_ata(device, ccb, quiet, dt); 7146 } else 7147 error = 1; 7148 if (error == 0 && quiet == 0) 7149 fprintf(stdout, "Sanitize Complete \n"); 7150 7151 sanitize_bailout: 7152 if (fd >= 0) 7153 close(fd); 7154 if (data_ptr != NULL) 7155 free(data_ptr); 7156 cam_freeccb(ccb); 7157 7158 return (error); 7159 } 7160 7161 static int 7162 scsireportluns(struct cam_device *device, int argc, char **argv, 7163 char *combinedopt, int task_attr, int retry_count, int timeout) 7164 { 7165 union ccb *ccb; 7166 int c, countonly, lunsonly; 7167 struct scsi_report_luns_data *lundata; 7168 int alloc_len; 7169 uint8_t report_type; 7170 uint32_t list_len, i, j; 7171 int retval; 7172 7173 retval = 0; 7174 lundata = NULL; 7175 report_type = RPL_REPORT_DEFAULT; 7176 ccb = cam_getccb(device); 7177 7178 if (ccb == NULL) { 7179 warnx("%s: error allocating ccb", __func__); 7180 return (1); 7181 } 7182 7183 countonly = 0; 7184 lunsonly = 0; 7185 7186 while ((c = getopt(argc, argv, combinedopt)) != -1) { 7187 switch (c) { 7188 case 'c': 7189 countonly++; 7190 break; 7191 case 'l': 7192 lunsonly++; 7193 break; 7194 case 'r': 7195 if (strcasecmp(optarg, "default") == 0) 7196 report_type = RPL_REPORT_DEFAULT; 7197 else if (strcasecmp(optarg, "wellknown") == 0) 7198 report_type = RPL_REPORT_WELLKNOWN; 7199 else if (strcasecmp(optarg, "all") == 0) 7200 report_type = RPL_REPORT_ALL; 7201 else { 7202 warnx("%s: invalid report type \"%s\"", 7203 __func__, optarg); 7204 retval = 1; 7205 goto bailout; 7206 } 7207 break; 7208 default: 7209 break; 7210 } 7211 } 7212 7213 if ((countonly != 0) 7214 && (lunsonly != 0)) { 7215 warnx("%s: you can only specify one of -c or -l", __func__); 7216 retval = 1; 7217 goto bailout; 7218 } 7219 /* 7220 * According to SPC-4, the allocation length must be at least 16 7221 * bytes -- enough for the header and one LUN. 7222 */ 7223 alloc_len = sizeof(*lundata) + 8; 7224 7225 retry: 7226 7227 lundata = malloc(alloc_len); 7228 7229 if (lundata == NULL) { 7230 warn("%s: error mallocing %d bytes", __func__, alloc_len); 7231 retval = 1; 7232 goto bailout; 7233 } 7234 7235 scsi_report_luns(&ccb->csio, 7236 /*retries*/ retry_count, 7237 /*cbfcnp*/ NULL, 7238 /*tag_action*/ task_attr, 7239 /*select_report*/ report_type, 7240 /*rpl_buf*/ lundata, 7241 /*alloc_len*/ alloc_len, 7242 /*sense_len*/ SSD_FULL_SIZE, 7243 /*timeout*/ timeout ? timeout : 5000); 7244 7245 /* Disable freezing the device queue */ 7246 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 7247 7248 if (arglist & CAM_ARG_ERR_RECOVER) 7249 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 7250 7251 if (cam_send_ccb(device, ccb) < 0) { 7252 warn("error sending REPORT LUNS command"); 7253 retval = 1; 7254 goto bailout; 7255 } 7256 7257 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 7258 cam_error_print(device, ccb, CAM_ESF_ALL, CAM_EPF_ALL, stderr); 7259 retval = 1; 7260 goto bailout; 7261 } 7262 7263 7264 list_len = scsi_4btoul(lundata->length); 7265 7266 /* 7267 * If we need to list the LUNs, and our allocation 7268 * length was too short, reallocate and retry. 7269 */ 7270 if ((countonly == 0) 7271 && (list_len > (alloc_len - sizeof(*lundata)))) { 7272 alloc_len = list_len + sizeof(*lundata); 7273 free(lundata); 7274 goto retry; 7275 } 7276 7277 if (lunsonly == 0) 7278 fprintf(stdout, "%u LUN%s found\n", list_len / 8, 7279 ((list_len / 8) > 1) ? "s" : ""); 7280 7281 if (countonly != 0) 7282 goto bailout; 7283 7284 for (i = 0; i < (list_len / 8); i++) { 7285 int no_more; 7286 7287 no_more = 0; 7288 for (j = 0; j < sizeof(lundata->luns[i].lundata); j += 2) { 7289 if (j != 0) 7290 fprintf(stdout, ","); 7291 switch (lundata->luns[i].lundata[j] & 7292 RPL_LUNDATA_ATYP_MASK) { 7293 case RPL_LUNDATA_ATYP_PERIPH: 7294 if ((lundata->luns[i].lundata[j] & 7295 RPL_LUNDATA_PERIPH_BUS_MASK) != 0) 7296 fprintf(stdout, "%d:", 7297 lundata->luns[i].lundata[j] & 7298 RPL_LUNDATA_PERIPH_BUS_MASK); 7299 else if ((j == 0) 7300 && ((lundata->luns[i].lundata[j+2] & 7301 RPL_LUNDATA_PERIPH_BUS_MASK) == 0)) 7302 no_more = 1; 7303 7304 fprintf(stdout, "%d", 7305 lundata->luns[i].lundata[j+1]); 7306 break; 7307 case RPL_LUNDATA_ATYP_FLAT: { 7308 uint8_t tmplun[2]; 7309 tmplun[0] = lundata->luns[i].lundata[j] & 7310 RPL_LUNDATA_FLAT_LUN_MASK; 7311 tmplun[1] = lundata->luns[i].lundata[j+1]; 7312 7313 fprintf(stdout, "%d", scsi_2btoul(tmplun)); 7314 no_more = 1; 7315 break; 7316 } 7317 case RPL_LUNDATA_ATYP_LUN: 7318 fprintf(stdout, "%d:%d:%d", 7319 (lundata->luns[i].lundata[j+1] & 7320 RPL_LUNDATA_LUN_BUS_MASK) >> 5, 7321 lundata->luns[i].lundata[j] & 7322 RPL_LUNDATA_LUN_TARG_MASK, 7323 lundata->luns[i].lundata[j+1] & 7324 RPL_LUNDATA_LUN_LUN_MASK); 7325 break; 7326 case RPL_LUNDATA_ATYP_EXTLUN: { 7327 int field_len_code, eam_code; 7328 7329 eam_code = lundata->luns[i].lundata[j] & 7330 RPL_LUNDATA_EXT_EAM_MASK; 7331 field_len_code = (lundata->luns[i].lundata[j] & 7332 RPL_LUNDATA_EXT_LEN_MASK) >> 4; 7333 7334 if ((eam_code == RPL_LUNDATA_EXT_EAM_WK) 7335 && (field_len_code == 0x00)) { 7336 fprintf(stdout, "%d", 7337 lundata->luns[i].lundata[j+1]); 7338 } else if ((eam_code == 7339 RPL_LUNDATA_EXT_EAM_NOT_SPEC) 7340 && (field_len_code == 0x03)) { 7341 uint8_t tmp_lun[8]; 7342 7343 /* 7344 * This format takes up all 8 bytes. 7345 * If we aren't starting at offset 0, 7346 * that's a bug. 7347 */ 7348 if (j != 0) { 7349 fprintf(stdout, "Invalid " 7350 "offset %d for " 7351 "Extended LUN not " 7352 "specified format", j); 7353 no_more = 1; 7354 break; 7355 } 7356 bzero(tmp_lun, sizeof(tmp_lun)); 7357 bcopy(&lundata->luns[i].lundata[j+1], 7358 &tmp_lun[1], sizeof(tmp_lun) - 1); 7359 fprintf(stdout, "%#jx", 7360 (intmax_t)scsi_8btou64(tmp_lun)); 7361 no_more = 1; 7362 } else { 7363 fprintf(stderr, "Unknown Extended LUN" 7364 "Address method %#x, length " 7365 "code %#x", eam_code, 7366 field_len_code); 7367 no_more = 1; 7368 } 7369 break; 7370 } 7371 default: 7372 fprintf(stderr, "Unknown LUN address method " 7373 "%#x\n", lundata->luns[i].lundata[0] & 7374 RPL_LUNDATA_ATYP_MASK); 7375 break; 7376 } 7377 /* 7378 * For the flat addressing method, there are no 7379 * other levels after it. 7380 */ 7381 if (no_more != 0) 7382 break; 7383 } 7384 fprintf(stdout, "\n"); 7385 } 7386 7387 bailout: 7388 7389 cam_freeccb(ccb); 7390 7391 free(lundata); 7392 7393 return (retval); 7394 } 7395 7396 static int 7397 scsireadcapacity(struct cam_device *device, int argc, char **argv, 7398 char *combinedopt, int task_attr, int retry_count, int timeout) 7399 { 7400 union ccb *ccb; 7401 int blocksizeonly, humanize, numblocks, quiet, sizeonly, baseten, longonly; 7402 struct scsi_read_capacity_data rcap; 7403 struct scsi_read_capacity_data_long rcaplong; 7404 uint64_t maxsector; 7405 uint32_t block_len; 7406 int retval; 7407 int c; 7408 7409 blocksizeonly = 0; 7410 humanize = 0; 7411 longonly = 0; 7412 numblocks = 0; 7413 quiet = 0; 7414 sizeonly = 0; 7415 baseten = 0; 7416 retval = 0; 7417 7418 ccb = cam_getccb(device); 7419 7420 if (ccb == NULL) { 7421 warnx("%s: error allocating ccb", __func__); 7422 return (1); 7423 } 7424 7425 while ((c = getopt(argc, argv, combinedopt)) != -1) { 7426 switch (c) { 7427 case 'b': 7428 blocksizeonly++; 7429 break; 7430 case 'h': 7431 humanize++; 7432 baseten = 0; 7433 break; 7434 case 'H': 7435 humanize++; 7436 baseten++; 7437 break; 7438 case 'l': 7439 longonly++; 7440 break; 7441 case 'N': 7442 numblocks++; 7443 break; 7444 case 'q': 7445 quiet++; 7446 break; 7447 case 's': 7448 sizeonly++; 7449 break; 7450 default: 7451 break; 7452 } 7453 } 7454 7455 if ((blocksizeonly != 0) 7456 && (numblocks != 0)) { 7457 warnx("%s: you can only specify one of -b or -N", __func__); 7458 retval = 1; 7459 goto bailout; 7460 } 7461 7462 if ((blocksizeonly != 0) 7463 && (sizeonly != 0)) { 7464 warnx("%s: you can only specify one of -b or -s", __func__); 7465 retval = 1; 7466 goto bailout; 7467 } 7468 7469 if ((humanize != 0) 7470 && (quiet != 0)) { 7471 warnx("%s: you can only specify one of -h/-H or -q", __func__); 7472 retval = 1; 7473 goto bailout; 7474 } 7475 7476 if ((humanize != 0) 7477 && (blocksizeonly != 0)) { 7478 warnx("%s: you can only specify one of -h/-H or -b", __func__); 7479 retval = 1; 7480 goto bailout; 7481 } 7482 7483 if (longonly != 0) 7484 goto long_only; 7485 7486 scsi_read_capacity(&ccb->csio, 7487 /*retries*/ retry_count, 7488 /*cbfcnp*/ NULL, 7489 /*tag_action*/ task_attr, 7490 &rcap, 7491 SSD_FULL_SIZE, 7492 /*timeout*/ timeout ? timeout : 5000); 7493 7494 /* Disable freezing the device queue */ 7495 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 7496 7497 if (arglist & CAM_ARG_ERR_RECOVER) 7498 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 7499 7500 if (cam_send_ccb(device, ccb) < 0) { 7501 warn("error sending READ CAPACITY command"); 7502 retval = 1; 7503 goto bailout; 7504 } 7505 7506 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 7507 cam_error_print(device, ccb, CAM_ESF_ALL, CAM_EPF_ALL, stderr); 7508 retval = 1; 7509 goto bailout; 7510 } 7511 7512 maxsector = scsi_4btoul(rcap.addr); 7513 block_len = scsi_4btoul(rcap.length); 7514 7515 /* 7516 * A last block of 2^32-1 means that the true capacity is over 2TB, 7517 * and we need to issue the long READ CAPACITY to get the real 7518 * capacity. Otherwise, we're all set. 7519 */ 7520 if (maxsector != 0xffffffff) 7521 goto do_print; 7522 7523 long_only: 7524 scsi_read_capacity_16(&ccb->csio, 7525 /*retries*/ retry_count, 7526 /*cbfcnp*/ NULL, 7527 /*tag_action*/ task_attr, 7528 /*lba*/ 0, 7529 /*reladdr*/ 0, 7530 /*pmi*/ 0, 7531 /*rcap_buf*/ (uint8_t *)&rcaplong, 7532 /*rcap_buf_len*/ sizeof(rcaplong), 7533 /*sense_len*/ SSD_FULL_SIZE, 7534 /*timeout*/ timeout ? timeout : 5000); 7535 7536 /* Disable freezing the device queue */ 7537 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 7538 7539 if (arglist & CAM_ARG_ERR_RECOVER) 7540 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 7541 7542 if (cam_send_ccb(device, ccb) < 0) { 7543 warn("error sending READ CAPACITY (16) command"); 7544 retval = 1; 7545 goto bailout; 7546 } 7547 7548 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 7549 cam_error_print(device, ccb, CAM_ESF_ALL, CAM_EPF_ALL, stderr); 7550 retval = 1; 7551 goto bailout; 7552 } 7553 7554 maxsector = scsi_8btou64(rcaplong.addr); 7555 block_len = scsi_4btoul(rcaplong.length); 7556 7557 do_print: 7558 if (blocksizeonly == 0) { 7559 /* 7560 * Humanize implies !quiet, and also implies numblocks. 7561 */ 7562 if (humanize != 0) { 7563 char tmpstr[6]; 7564 int64_t tmpbytes; 7565 int ret; 7566 7567 tmpbytes = (maxsector + 1) * block_len; 7568 ret = humanize_number(tmpstr, sizeof(tmpstr), 7569 tmpbytes, "", HN_AUTOSCALE, 7570 HN_B | HN_DECIMAL | 7571 ((baseten != 0) ? 7572 HN_DIVISOR_1000 : 0)); 7573 if (ret == -1) { 7574 warnx("%s: humanize_number failed!", __func__); 7575 retval = 1; 7576 goto bailout; 7577 } 7578 fprintf(stdout, "Device Size: %s%s", tmpstr, 7579 (sizeonly == 0) ? ", " : "\n"); 7580 } else if (numblocks != 0) { 7581 fprintf(stdout, "%s%ju%s", (quiet == 0) ? 7582 "Blocks: " : "", (uintmax_t)maxsector + 1, 7583 (sizeonly == 0) ? ", " : "\n"); 7584 } else { 7585 fprintf(stdout, "%s%ju%s", (quiet == 0) ? 7586 "Last Block: " : "", (uintmax_t)maxsector, 7587 (sizeonly == 0) ? ", " : "\n"); 7588 } 7589 } 7590 if (sizeonly == 0) 7591 fprintf(stdout, "%s%u%s\n", (quiet == 0) ? 7592 "Block Length: " : "", block_len, (quiet == 0) ? 7593 " bytes" : ""); 7594 bailout: 7595 cam_freeccb(ccb); 7596 7597 return (retval); 7598 } 7599 7600 static int 7601 smpcmd(struct cam_device *device, int argc, char **argv, char *combinedopt, 7602 int retry_count, int timeout) 7603 { 7604 int c, error = 0; 7605 union ccb *ccb; 7606 uint8_t *smp_request = NULL, *smp_response = NULL; 7607 int request_size = 0, response_size = 0; 7608 int fd_request = 0, fd_response = 0; 7609 char *datastr = NULL; 7610 struct get_hook hook; 7611 int retval; 7612 int flags = 0; 7613 7614 /* 7615 * Note that at the moment we don't support sending SMP CCBs to 7616 * devices that aren't probed by CAM. 7617 */ 7618 ccb = cam_getccb(device); 7619 if (ccb == NULL) { 7620 warnx("%s: error allocating CCB", __func__); 7621 return (1); 7622 } 7623 7624 while ((c = getopt(argc, argv, combinedopt)) != -1) { 7625 switch (c) { 7626 case 'R': 7627 arglist |= CAM_ARG_CMD_IN; 7628 response_size = strtol(optarg, NULL, 0); 7629 if (response_size <= 0) { 7630 warnx("invalid number of response bytes %d", 7631 response_size); 7632 error = 1; 7633 goto smpcmd_bailout; 7634 } 7635 hook.argc = argc - optind; 7636 hook.argv = argv + optind; 7637 hook.got = 0; 7638 optind++; 7639 datastr = cget(&hook, NULL); 7640 /* 7641 * If the user supplied "-" instead of a format, he 7642 * wants the data to be written to stdout. 7643 */ 7644 if ((datastr != NULL) 7645 && (datastr[0] == '-')) 7646 fd_response = 1; 7647 7648 smp_response = (uint8_t *)malloc(response_size); 7649 if (smp_response == NULL) { 7650 warn("can't malloc memory for SMP response"); 7651 error = 1; 7652 goto smpcmd_bailout; 7653 } 7654 break; 7655 case 'r': 7656 arglist |= CAM_ARG_CMD_OUT; 7657 request_size = strtol(optarg, NULL, 0); 7658 if (request_size <= 0) { 7659 warnx("invalid number of request bytes %d", 7660 request_size); 7661 error = 1; 7662 goto smpcmd_bailout; 7663 } 7664 hook.argc = argc - optind; 7665 hook.argv = argv + optind; 7666 hook.got = 0; 7667 datastr = cget(&hook, NULL); 7668 smp_request = (uint8_t *)malloc(request_size); 7669 if (smp_request == NULL) { 7670 warn("can't malloc memory for SMP request"); 7671 error = 1; 7672 goto smpcmd_bailout; 7673 } 7674 bzero(smp_request, request_size); 7675 /* 7676 * If the user supplied "-" instead of a format, he 7677 * wants the data to be read from stdin. 7678 */ 7679 if ((datastr != NULL) 7680 && (datastr[0] == '-')) 7681 fd_request = 1; 7682 else 7683 buff_encode_visit(smp_request, request_size, 7684 datastr, 7685 iget, &hook); 7686 optind += hook.got; 7687 break; 7688 default: 7689 break; 7690 } 7691 } 7692 7693 /* 7694 * If fd_data is set, and we're writing to the device, we need to 7695 * read the data the user wants written from stdin. 7696 */ 7697 if ((fd_request == 1) && (arglist & CAM_ARG_CMD_OUT)) { 7698 ssize_t amt_read; 7699 int amt_to_read = request_size; 7700 uint8_t *buf_ptr = smp_request; 7701 7702 for (amt_read = 0; amt_to_read > 0; 7703 amt_read = read(STDIN_FILENO, buf_ptr, amt_to_read)) { 7704 if (amt_read == -1) { 7705 warn("error reading data from stdin"); 7706 error = 1; 7707 goto smpcmd_bailout; 7708 } 7709 amt_to_read -= amt_read; 7710 buf_ptr += amt_read; 7711 } 7712 } 7713 7714 if (((arglist & CAM_ARG_CMD_IN) == 0) 7715 || ((arglist & CAM_ARG_CMD_OUT) == 0)) { 7716 warnx("%s: need both the request (-r) and response (-R) " 7717 "arguments", __func__); 7718 error = 1; 7719 goto smpcmd_bailout; 7720 } 7721 7722 flags |= CAM_DEV_QFRZDIS; 7723 7724 cam_fill_smpio(&ccb->smpio, 7725 /*retries*/ retry_count, 7726 /*cbfcnp*/ NULL, 7727 /*flags*/ flags, 7728 /*smp_request*/ smp_request, 7729 /*smp_request_len*/ request_size, 7730 /*smp_response*/ smp_response, 7731 /*smp_response_len*/ response_size, 7732 /*timeout*/ timeout ? timeout : 5000); 7733 7734 ccb->smpio.flags = SMP_FLAG_NONE; 7735 7736 if (((retval = cam_send_ccb(device, ccb)) < 0) 7737 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 7738 const char warnstr[] = "error sending command"; 7739 7740 if (retval < 0) 7741 warn(warnstr); 7742 else 7743 warnx(warnstr); 7744 7745 if (arglist & CAM_ARG_VERBOSE) { 7746 cam_error_print(device, ccb, CAM_ESF_ALL, 7747 CAM_EPF_ALL, stderr); 7748 } 7749 } 7750 7751 if (((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP) 7752 && (response_size > 0)) { 7753 if (fd_response == 0) { 7754 buff_decode_visit(smp_response, response_size, 7755 datastr, arg_put, NULL); 7756 fprintf(stdout, "\n"); 7757 } else { 7758 ssize_t amt_written; 7759 int amt_to_write = response_size; 7760 uint8_t *buf_ptr = smp_response; 7761 7762 for (amt_written = 0; (amt_to_write > 0) && 7763 (amt_written = write(STDOUT_FILENO, buf_ptr, 7764 amt_to_write)) > 0;){ 7765 amt_to_write -= amt_written; 7766 buf_ptr += amt_written; 7767 } 7768 if (amt_written == -1) { 7769 warn("error writing data to stdout"); 7770 error = 1; 7771 goto smpcmd_bailout; 7772 } else if ((amt_written == 0) 7773 && (amt_to_write > 0)) { 7774 warnx("only wrote %u bytes out of %u", 7775 response_size - amt_to_write, 7776 response_size); 7777 } 7778 } 7779 } 7780 smpcmd_bailout: 7781 if (ccb != NULL) 7782 cam_freeccb(ccb); 7783 7784 if (smp_request != NULL) 7785 free(smp_request); 7786 7787 if (smp_response != NULL) 7788 free(smp_response); 7789 7790 return (error); 7791 } 7792 7793 static int 7794 mmcsdcmd(struct cam_device *device, int argc, char **argv, char *combinedopt, 7795 int retry_count, int timeout) 7796 { 7797 int c, error = 0; 7798 union ccb *ccb; 7799 int32_t mmc_opcode = 0, mmc_arg = 0; 7800 int32_t mmc_flags = -1; 7801 int retval; 7802 int is_write = 0; 7803 int is_bw_4 = 0, is_bw_1 = 0; 7804 int is_frequency = 0; 7805 int is_highspeed = 0, is_stdspeed = 0; 7806 int is_info_request = 0; 7807 int flags = 0; 7808 uint8_t mmc_data_byte = 0; 7809 uint32_t mmc_frequency = 0; 7810 7811 /* For IO_RW_EXTENDED command */ 7812 uint8_t *mmc_data = NULL; 7813 struct mmc_data mmc_d; 7814 int mmc_data_len = 0; 7815 7816 /* 7817 * Note that at the moment we don't support sending SMP CCBs to 7818 * devices that aren't probed by CAM. 7819 */ 7820 ccb = cam_getccb(device); 7821 if (ccb == NULL) { 7822 warnx("%s: error allocating CCB", __func__); 7823 return (1); 7824 } 7825 7826 bzero(&(&ccb->ccb_h)[1], 7827 sizeof(union ccb) - sizeof(struct ccb_hdr)); 7828 7829 while ((c = getopt(argc, argv, combinedopt)) != -1) { 7830 switch (c) { 7831 case '4': 7832 is_bw_4 = 1; 7833 break; 7834 case '1': 7835 is_bw_1 = 1; 7836 break; 7837 case 'S': 7838 if (!strcmp(optarg, "high")) 7839 is_highspeed = 1; 7840 else 7841 is_stdspeed = 1; 7842 break; 7843 case 'I': 7844 is_info_request = 1; 7845 break; 7846 case 'F': 7847 is_frequency = 1; 7848 mmc_frequency = strtol(optarg, NULL, 0); 7849 break; 7850 case 'c': 7851 mmc_opcode = strtol(optarg, NULL, 0); 7852 if (mmc_opcode < 0) { 7853 warnx("invalid MMC opcode %d", 7854 mmc_opcode); 7855 error = 1; 7856 goto mmccmd_bailout; 7857 } 7858 break; 7859 case 'a': 7860 mmc_arg = strtol(optarg, NULL, 0); 7861 if (mmc_arg < 0) { 7862 warnx("invalid MMC arg %d", 7863 mmc_arg); 7864 error = 1; 7865 goto mmccmd_bailout; 7866 } 7867 break; 7868 case 'f': 7869 mmc_flags = strtol(optarg, NULL, 0); 7870 if (mmc_flags < 0) { 7871 warnx("invalid MMC flags %d", 7872 mmc_flags); 7873 error = 1; 7874 goto mmccmd_bailout; 7875 } 7876 break; 7877 case 'l': 7878 mmc_data_len = strtol(optarg, NULL, 0); 7879 if (mmc_data_len <= 0) { 7880 warnx("invalid MMC data len %d", 7881 mmc_data_len); 7882 error = 1; 7883 goto mmccmd_bailout; 7884 } 7885 break; 7886 case 'W': 7887 is_write = 1; 7888 break; 7889 case 'b': 7890 mmc_data_byte = strtol(optarg, NULL, 0); 7891 break; 7892 default: 7893 break; 7894 } 7895 } 7896 flags |= CAM_DEV_QFRZDIS; /* masks are broken?! */ 7897 7898 /* If flags are left default, supply the right flags */ 7899 if (mmc_flags < 0) 7900 switch (mmc_opcode) { 7901 case MMC_GO_IDLE_STATE: 7902 mmc_flags = MMC_RSP_NONE | MMC_CMD_BC; 7903 break; 7904 case IO_SEND_OP_COND: 7905 mmc_flags = MMC_RSP_R4; 7906 break; 7907 case SD_SEND_RELATIVE_ADDR: 7908 mmc_flags = MMC_RSP_R6 | MMC_CMD_BCR; 7909 break; 7910 case MMC_SELECT_CARD: 7911 mmc_flags = MMC_RSP_R1B | MMC_CMD_AC; 7912 mmc_arg = mmc_arg << 16; 7913 break; 7914 case SD_IO_RW_DIRECT: 7915 mmc_flags = MMC_RSP_R5 | MMC_CMD_AC; 7916 mmc_arg = SD_IO_RW_ADR(mmc_arg); 7917 if (is_write) 7918 mmc_arg |= SD_IO_RW_WR | SD_IO_RW_RAW | SD_IO_RW_DAT(mmc_data_byte); 7919 break; 7920 case SD_IO_RW_EXTENDED: 7921 mmc_flags = MMC_RSP_R5 | MMC_CMD_ADTC; 7922 mmc_arg = SD_IO_RW_ADR(mmc_arg); 7923 int len_arg = mmc_data_len; 7924 if (mmc_data_len == 512) 7925 len_arg = 0; 7926 7927 // Byte mode 7928 mmc_arg |= SD_IOE_RW_LEN(len_arg) | SD_IO_RW_INCR; 7929 // Block mode 7930 // mmc_arg |= SD_IOE_RW_BLK | SD_IOE_RW_LEN(len_arg) | SD_IO_RW_INCR; 7931 break; 7932 default: 7933 mmc_flags = MMC_RSP_R1; 7934 break; 7935 } 7936 7937 // Switch bus width instead of sending IO command 7938 if (is_bw_4 || is_bw_1) { 7939 struct ccb_trans_settings_mmc *cts; 7940 ccb->ccb_h.func_code = XPT_SET_TRAN_SETTINGS; 7941 ccb->ccb_h.flags = 0; 7942 cts = &ccb->cts.proto_specific.mmc; 7943 cts->ios.bus_width = is_bw_4 == 1 ? bus_width_4 : bus_width_1; 7944 cts->ios_valid = MMC_BW; 7945 if (((retval = cam_send_ccb(device, ccb)) < 0) 7946 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 7947 warn("Error sending command"); 7948 } else { 7949 printf("Parameters set OK\n"); 7950 } 7951 cam_freeccb(ccb); 7952 return (retval); 7953 } 7954 7955 if (is_frequency) { 7956 struct ccb_trans_settings_mmc *cts; 7957 ccb->ccb_h.func_code = XPT_SET_TRAN_SETTINGS; 7958 ccb->ccb_h.flags = 0; 7959 cts = &ccb->cts.proto_specific.mmc; 7960 cts->ios.clock = mmc_frequency; 7961 cts->ios_valid = MMC_CLK; 7962 if (((retval = cam_send_ccb(device, ccb)) < 0) 7963 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 7964 warn("Error sending command"); 7965 } else { 7966 printf("Parameters set OK\n"); 7967 } 7968 cam_freeccb(ccb); 7969 return (retval); 7970 } 7971 7972 // Switch bus speed instead of sending IO command 7973 if (is_stdspeed || is_highspeed) { 7974 struct ccb_trans_settings_mmc *cts; 7975 ccb->ccb_h.func_code = XPT_SET_TRAN_SETTINGS; 7976 ccb->ccb_h.flags = 0; 7977 cts = &ccb->cts.proto_specific.mmc; 7978 cts->ios.timing = is_highspeed == 1 ? bus_timing_hs : bus_timing_normal; 7979 cts->ios_valid = MMC_BT; 7980 if (((retval = cam_send_ccb(device, ccb)) < 0) 7981 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 7982 warn("Error sending command"); 7983 } else { 7984 printf("Speed set OK (HS: %d)\n", is_highspeed); 7985 } 7986 cam_freeccb(ccb); 7987 return (retval); 7988 } 7989 7990 // Get information about controller and its settings 7991 if (is_info_request) { 7992 ccb->ccb_h.func_code = XPT_GET_TRAN_SETTINGS; 7993 ccb->ccb_h.flags = 0; 7994 struct ccb_trans_settings_mmc *cts; 7995 cts = &ccb->cts.proto_specific.mmc; 7996 if (((retval = cam_send_ccb(device, ccb)) < 0) 7997 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 7998 warn("Error sending command"); 7999 return (retval); 8000 } 8001 printf("Host controller information\n"); 8002 printf("Host OCR: 0x%x\n", cts->host_ocr); 8003 printf("Min frequency: %u KHz\n", cts->host_f_min / 1000); 8004 printf("Max frequency: %u MHz\n", cts->host_f_max / 1000000); 8005 printf("Supported bus width:\n"); 8006 if (cts->host_caps & MMC_CAP_4_BIT_DATA) 8007 printf(" 4 bit\n"); 8008 if (cts->host_caps & MMC_CAP_8_BIT_DATA) 8009 printf(" 8 bit\n"); 8010 8011 printf("Supported operating modes:\n"); 8012 if (cts->host_caps & MMC_CAP_HSPEED) 8013 printf(" Can do High Speed transfers\n"); 8014 if (cts->host_caps & MMC_CAP_UHS_SDR12) 8015 printf(" Can do UHS SDR12\n"); 8016 if (cts->host_caps & MMC_CAP_UHS_SDR25) 8017 printf(" Can do UHS SDR25\n"); 8018 if (cts->host_caps & MMC_CAP_UHS_SDR50) 8019 printf(" Can do UHS SDR50\n"); 8020 if (cts->host_caps & MMC_CAP_UHS_SDR104) 8021 printf(" Can do UHS SDR104\n"); 8022 if (cts->host_caps & MMC_CAP_UHS_DDR50) 8023 printf(" Can do UHS DDR50\n"); 8024 if (cts->host_caps & MMC_CAP_MMC_DDR52_120) 8025 printf(" Can do eMMC DDR52 at 1.2V\n"); 8026 if (cts->host_caps & MMC_CAP_MMC_DDR52_180) 8027 printf(" Can do eMMC DDR52 at 1.8V\n"); 8028 if (cts->host_caps & MMC_CAP_MMC_HS200_120) 8029 printf(" Can do eMMC HS200 at 1.2V\n"); 8030 if (cts->host_caps & MMC_CAP_MMC_HS200_180) 8031 printf(" Can do eMMC HS200 at 1.8V\n"); 8032 if (cts->host_caps & MMC_CAP_MMC_HS400_120) 8033 printf(" Can do eMMC HS400 at 1.2V\n"); 8034 if (cts->host_caps & MMC_CAP_MMC_HS400_180) 8035 printf(" Can do eMMC HS400 at 1.8V\n"); 8036 8037 printf("Supported VCCQ voltages:\n"); 8038 if (cts->host_caps & MMC_CAP_SIGNALING_120) 8039 printf(" 1.2V\n"); 8040 if (cts->host_caps & MMC_CAP_SIGNALING_180) 8041 printf(" 1.8V\n"); 8042 if (cts->host_caps & MMC_CAP_SIGNALING_330) 8043 printf(" 3.3V\n"); 8044 8045 printf("Current settings:\n"); 8046 printf(" Bus width: "); 8047 switch (cts->ios.bus_width) { 8048 case bus_width_1: 8049 printf("1 bit\n"); 8050 break; 8051 case bus_width_4: 8052 printf("4 bit\n"); 8053 break; 8054 case bus_width_8: 8055 printf("8 bit\n"); 8056 break; 8057 } 8058 printf(" Freq: %d.%03d MHz%s\n", 8059 cts->ios.clock / 1000000, 8060 (cts->ios.clock / 1000) % 1000, 8061 cts->ios.timing == bus_timing_hs ? " (high-speed timing)" : ""); 8062 8063 printf(" VCCQ: "); 8064 switch (cts->ios.vccq) { 8065 case vccq_330: 8066 printf("3.3V\n"); 8067 break; 8068 case vccq_180: 8069 printf("1.8V\n"); 8070 break; 8071 case vccq_120: 8072 printf("1.2V\n"); 8073 break; 8074 } 8075 return (0); 8076 } 8077 8078 printf("CMD %d arg %d flags %02x\n", mmc_opcode, mmc_arg, mmc_flags); 8079 8080 if (mmc_data_len > 0) { 8081 flags |= CAM_DIR_IN; 8082 mmc_data = malloc(mmc_data_len); 8083 memset(mmc_data, 0, mmc_data_len); 8084 memset(&mmc_d, 0, sizeof(mmc_d)); 8085 mmc_d.len = mmc_data_len; 8086 mmc_d.data = mmc_data; 8087 mmc_d.flags = MMC_DATA_READ; 8088 } else flags |= CAM_DIR_NONE; 8089 8090 cam_fill_mmcio(&ccb->mmcio, 8091 /*retries*/ retry_count, 8092 /*cbfcnp*/ NULL, 8093 /*flags*/ flags, 8094 /*mmc_opcode*/ mmc_opcode, 8095 /*mmc_arg*/ mmc_arg, 8096 /*mmc_flags*/ mmc_flags, 8097 /*mmc_data*/ mmc_data_len > 0 ? &mmc_d : NULL, 8098 /*timeout*/ timeout ? timeout : 5000); 8099 8100 if (((retval = cam_send_ccb(device, ccb)) < 0) 8101 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 8102 const char warnstr[] = "error sending command"; 8103 8104 if (retval < 0) 8105 warn(warnstr); 8106 else 8107 warnx(warnstr); 8108 8109 if (arglist & CAM_ARG_VERBOSE) { 8110 cam_error_print(device, ccb, CAM_ESF_ALL, 8111 CAM_EPF_ALL, stderr); 8112 } 8113 } 8114 8115 if (((ccb->ccb_h.status & CAM_STATUS_MASK) == CAM_REQ_CMP)) { 8116 printf("MMCIO: error %d, %08x %08x %08x %08x\n", 8117 ccb->mmcio.cmd.error, ccb->mmcio.cmd.resp[0], 8118 ccb->mmcio.cmd.resp[1], 8119 ccb->mmcio.cmd.resp[2], 8120 ccb->mmcio.cmd.resp[3]); 8121 8122 switch (mmc_opcode) { 8123 case SD_IO_RW_DIRECT: 8124 printf("IO_RW_DIRECT: resp byte %02x, cur state %d\n", 8125 SD_R5_DATA(ccb->mmcio.cmd.resp), 8126 (ccb->mmcio.cmd.resp[0] >> 12) & 0x3); 8127 break; 8128 case SD_IO_RW_EXTENDED: 8129 printf("IO_RW_EXTENDED: read %d bytes w/o error:\n", mmc_data_len); 8130 hexdump(mmc_data, mmc_data_len, NULL, 0); 8131 break; 8132 case SD_SEND_RELATIVE_ADDR: 8133 printf("SEND_RELATIVE_ADDR: published RCA %02x\n", ccb->mmcio.cmd.resp[0] >> 16); 8134 break; 8135 default: 8136 printf("No command-specific decoder for CMD %d\n", mmc_opcode); 8137 if (mmc_data_len > 0) 8138 hexdump(mmc_data, mmc_data_len, NULL, 0); 8139 } 8140 } 8141 mmccmd_bailout: 8142 if (ccb != NULL) 8143 cam_freeccb(ccb); 8144 8145 if (mmc_data_len > 0 && mmc_data != NULL) 8146 free(mmc_data); 8147 8148 return (error); 8149 } 8150 8151 static int 8152 smpreportgeneral(struct cam_device *device, int argc, char **argv, 8153 char *combinedopt, int retry_count, int timeout) 8154 { 8155 union ccb *ccb; 8156 struct smp_report_general_request *request = NULL; 8157 struct smp_report_general_response *response = NULL; 8158 struct sbuf *sb = NULL; 8159 int error = 0; 8160 int c, long_response = 0; 8161 int retval; 8162 8163 /* 8164 * Note that at the moment we don't support sending SMP CCBs to 8165 * devices that aren't probed by CAM. 8166 */ 8167 ccb = cam_getccb(device); 8168 if (ccb == NULL) { 8169 warnx("%s: error allocating CCB", __func__); 8170 return (1); 8171 } 8172 8173 while ((c = getopt(argc, argv, combinedopt)) != -1) { 8174 switch (c) { 8175 case 'l': 8176 long_response = 1; 8177 break; 8178 default: 8179 break; 8180 } 8181 } 8182 request = malloc(sizeof(*request)); 8183 if (request == NULL) { 8184 warn("%s: unable to allocate %zd bytes", __func__, 8185 sizeof(*request)); 8186 error = 1; 8187 goto bailout; 8188 } 8189 8190 response = malloc(sizeof(*response)); 8191 if (response == NULL) { 8192 warn("%s: unable to allocate %zd bytes", __func__, 8193 sizeof(*response)); 8194 error = 1; 8195 goto bailout; 8196 } 8197 8198 try_long: 8199 smp_report_general(&ccb->smpio, 8200 retry_count, 8201 /*cbfcnp*/ NULL, 8202 request, 8203 /*request_len*/ sizeof(*request), 8204 (uint8_t *)response, 8205 /*response_len*/ sizeof(*response), 8206 /*long_response*/ long_response, 8207 timeout); 8208 8209 if (((retval = cam_send_ccb(device, ccb)) < 0) 8210 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 8211 const char warnstr[] = "error sending command"; 8212 8213 if (retval < 0) 8214 warn(warnstr); 8215 else 8216 warnx(warnstr); 8217 8218 if (arglist & CAM_ARG_VERBOSE) { 8219 cam_error_print(device, ccb, CAM_ESF_ALL, 8220 CAM_EPF_ALL, stderr); 8221 } 8222 error = 1; 8223 goto bailout; 8224 } 8225 8226 /* 8227 * If the device supports the long response bit, try again and see 8228 * if we can get all of the data. 8229 */ 8230 if ((response->long_response & SMP_RG_LONG_RESPONSE) 8231 && (long_response == 0)) { 8232 ccb->ccb_h.status = CAM_REQ_INPROG; 8233 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->smpio); 8234 long_response = 1; 8235 goto try_long; 8236 } 8237 8238 /* 8239 * XXX KDM detect and decode SMP errors here. 8240 */ 8241 sb = sbuf_new_auto(); 8242 if (sb == NULL) { 8243 warnx("%s: error allocating sbuf", __func__); 8244 goto bailout; 8245 } 8246 8247 smp_report_general_sbuf(response, sizeof(*response), sb); 8248 8249 if (sbuf_finish(sb) != 0) { 8250 warnx("%s: sbuf_finish", __func__); 8251 goto bailout; 8252 } 8253 8254 printf("%s", sbuf_data(sb)); 8255 8256 bailout: 8257 if (ccb != NULL) 8258 cam_freeccb(ccb); 8259 8260 if (request != NULL) 8261 free(request); 8262 8263 if (response != NULL) 8264 free(response); 8265 8266 if (sb != NULL) 8267 sbuf_delete(sb); 8268 8269 return (error); 8270 } 8271 8272 static struct camcontrol_opts phy_ops[] = { 8273 {"nop", SMP_PC_PHY_OP_NOP, CAM_ARG_NONE, NULL}, 8274 {"linkreset", SMP_PC_PHY_OP_LINK_RESET, CAM_ARG_NONE, NULL}, 8275 {"hardreset", SMP_PC_PHY_OP_HARD_RESET, CAM_ARG_NONE, NULL}, 8276 {"disable", SMP_PC_PHY_OP_DISABLE, CAM_ARG_NONE, NULL}, 8277 {"clearerrlog", SMP_PC_PHY_OP_CLEAR_ERR_LOG, CAM_ARG_NONE, NULL}, 8278 {"clearaffiliation", SMP_PC_PHY_OP_CLEAR_AFFILIATON, CAM_ARG_NONE,NULL}, 8279 {"sataportsel", SMP_PC_PHY_OP_TRANS_SATA_PSS, CAM_ARG_NONE, NULL}, 8280 {"clearitnl", SMP_PC_PHY_OP_CLEAR_STP_ITN_LS, CAM_ARG_NONE, NULL}, 8281 {"setdevname", SMP_PC_PHY_OP_SET_ATT_DEV_NAME, CAM_ARG_NONE, NULL}, 8282 {NULL, 0, 0, NULL} 8283 }; 8284 8285 static int 8286 smpphycontrol(struct cam_device *device, int argc, char **argv, 8287 char *combinedopt, int retry_count, int timeout) 8288 { 8289 union ccb *ccb; 8290 struct smp_phy_control_request *request = NULL; 8291 struct smp_phy_control_response *response = NULL; 8292 int long_response = 0; 8293 int retval = 0; 8294 int phy = -1; 8295 uint32_t phy_operation = SMP_PC_PHY_OP_NOP; 8296 int phy_op_set = 0; 8297 uint64_t attached_dev_name = 0; 8298 int dev_name_set = 0; 8299 uint32_t min_plr = 0, max_plr = 0; 8300 uint32_t pp_timeout_val = 0; 8301 int slumber_partial = 0; 8302 int set_pp_timeout_val = 0; 8303 int c; 8304 8305 /* 8306 * Note that at the moment we don't support sending SMP CCBs to 8307 * devices that aren't probed by CAM. 8308 */ 8309 ccb = cam_getccb(device); 8310 if (ccb == NULL) { 8311 warnx("%s: error allocating CCB", __func__); 8312 return (1); 8313 } 8314 8315 while ((c = getopt(argc, argv, combinedopt)) != -1) { 8316 switch (c) { 8317 case 'a': 8318 case 'A': 8319 case 's': 8320 case 'S': { 8321 int enable = -1; 8322 8323 if (strcasecmp(optarg, "enable") == 0) 8324 enable = 1; 8325 else if (strcasecmp(optarg, "disable") == 0) 8326 enable = 2; 8327 else { 8328 warnx("%s: Invalid argument %s", __func__, 8329 optarg); 8330 retval = 1; 8331 goto bailout; 8332 } 8333 switch (c) { 8334 case 's': 8335 slumber_partial |= enable << 8336 SMP_PC_SAS_SLUMBER_SHIFT; 8337 break; 8338 case 'S': 8339 slumber_partial |= enable << 8340 SMP_PC_SAS_PARTIAL_SHIFT; 8341 break; 8342 case 'a': 8343 slumber_partial |= enable << 8344 SMP_PC_SATA_SLUMBER_SHIFT; 8345 break; 8346 case 'A': 8347 slumber_partial |= enable << 8348 SMP_PC_SATA_PARTIAL_SHIFT; 8349 break; 8350 default: 8351 warnx("%s: programmer error", __func__); 8352 retval = 1; 8353 goto bailout; 8354 break; /*NOTREACHED*/ 8355 } 8356 break; 8357 } 8358 case 'd': 8359 attached_dev_name = (uintmax_t)strtoumax(optarg, 8360 NULL,0); 8361 dev_name_set = 1; 8362 break; 8363 case 'l': 8364 long_response = 1; 8365 break; 8366 case 'm': 8367 /* 8368 * We don't do extensive checking here, so this 8369 * will continue to work when new speeds come out. 8370 */ 8371 min_plr = strtoul(optarg, NULL, 0); 8372 if ((min_plr == 0) 8373 || (min_plr > 0xf)) { 8374 warnx("%s: invalid link rate %x", 8375 __func__, min_plr); 8376 retval = 1; 8377 goto bailout; 8378 } 8379 break; 8380 case 'M': 8381 /* 8382 * We don't do extensive checking here, so this 8383 * will continue to work when new speeds come out. 8384 */ 8385 max_plr = strtoul(optarg, NULL, 0); 8386 if ((max_plr == 0) 8387 || (max_plr > 0xf)) { 8388 warnx("%s: invalid link rate %x", 8389 __func__, max_plr); 8390 retval = 1; 8391 goto bailout; 8392 } 8393 break; 8394 case 'o': { 8395 camcontrol_optret optreturn; 8396 cam_argmask argnums; 8397 const char *subopt; 8398 8399 if (phy_op_set != 0) { 8400 warnx("%s: only one phy operation argument " 8401 "(-o) allowed", __func__); 8402 retval = 1; 8403 goto bailout; 8404 } 8405 8406 phy_op_set = 1; 8407 8408 /* 8409 * Allow the user to specify the phy operation 8410 * numerically, as well as with a name. This will 8411 * future-proof it a bit, so options that are added 8412 * in future specs can be used. 8413 */ 8414 if (isdigit(optarg[0])) { 8415 phy_operation = strtoul(optarg, NULL, 0); 8416 if ((phy_operation == 0) 8417 || (phy_operation > 0xff)) { 8418 warnx("%s: invalid phy operation %#x", 8419 __func__, phy_operation); 8420 retval = 1; 8421 goto bailout; 8422 } 8423 break; 8424 } 8425 optreturn = getoption(phy_ops, optarg, &phy_operation, 8426 &argnums, &subopt); 8427 8428 if (optreturn == CC_OR_AMBIGUOUS) { 8429 warnx("%s: ambiguous option %s", __func__, 8430 optarg); 8431 usage(0); 8432 retval = 1; 8433 goto bailout; 8434 } else if (optreturn == CC_OR_NOT_FOUND) { 8435 warnx("%s: option %s not found", __func__, 8436 optarg); 8437 usage(0); 8438 retval = 1; 8439 goto bailout; 8440 } 8441 break; 8442 } 8443 case 'p': 8444 phy = atoi(optarg); 8445 break; 8446 case 'T': 8447 pp_timeout_val = strtoul(optarg, NULL, 0); 8448 if (pp_timeout_val > 15) { 8449 warnx("%s: invalid partial pathway timeout " 8450 "value %u, need a value less than 16", 8451 __func__, pp_timeout_val); 8452 retval = 1; 8453 goto bailout; 8454 } 8455 set_pp_timeout_val = 1; 8456 break; 8457 default: 8458 break; 8459 } 8460 } 8461 8462 if (phy == -1) { 8463 warnx("%s: a PHY (-p phy) argument is required",__func__); 8464 retval = 1; 8465 goto bailout; 8466 } 8467 8468 if (((dev_name_set != 0) 8469 && (phy_operation != SMP_PC_PHY_OP_SET_ATT_DEV_NAME)) 8470 || ((phy_operation == SMP_PC_PHY_OP_SET_ATT_DEV_NAME) 8471 && (dev_name_set == 0))) { 8472 warnx("%s: -d name and -o setdevname arguments both " 8473 "required to set device name", __func__); 8474 retval = 1; 8475 goto bailout; 8476 } 8477 8478 request = malloc(sizeof(*request)); 8479 if (request == NULL) { 8480 warn("%s: unable to allocate %zd bytes", __func__, 8481 sizeof(*request)); 8482 retval = 1; 8483 goto bailout; 8484 } 8485 8486 response = malloc(sizeof(*response)); 8487 if (response == NULL) { 8488 warn("%s: unable to allocate %zd bytes", __func__, 8489 sizeof(*response)); 8490 retval = 1; 8491 goto bailout; 8492 } 8493 8494 smp_phy_control(&ccb->smpio, 8495 retry_count, 8496 /*cbfcnp*/ NULL, 8497 request, 8498 sizeof(*request), 8499 (uint8_t *)response, 8500 sizeof(*response), 8501 long_response, 8502 /*expected_exp_change_count*/ 0, 8503 phy, 8504 phy_operation, 8505 (set_pp_timeout_val != 0) ? 1 : 0, 8506 attached_dev_name, 8507 min_plr, 8508 max_plr, 8509 slumber_partial, 8510 pp_timeout_val, 8511 timeout); 8512 8513 if (((retval = cam_send_ccb(device, ccb)) < 0) 8514 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 8515 const char warnstr[] = "error sending command"; 8516 8517 if (retval < 0) 8518 warn(warnstr); 8519 else 8520 warnx(warnstr); 8521 8522 if (arglist & CAM_ARG_VERBOSE) { 8523 /* 8524 * Use CAM_EPF_NORMAL so we only get one line of 8525 * SMP command decoding. 8526 */ 8527 cam_error_print(device, ccb, CAM_ESF_ALL, 8528 CAM_EPF_NORMAL, stderr); 8529 } 8530 retval = 1; 8531 goto bailout; 8532 } 8533 8534 /* XXX KDM print out something here for success? */ 8535 bailout: 8536 if (ccb != NULL) 8537 cam_freeccb(ccb); 8538 8539 if (request != NULL) 8540 free(request); 8541 8542 if (response != NULL) 8543 free(response); 8544 8545 return (retval); 8546 } 8547 8548 static int 8549 smpmaninfo(struct cam_device *device, int argc, char **argv, 8550 char *combinedopt, int retry_count, int timeout) 8551 { 8552 union ccb *ccb; 8553 struct smp_report_manuf_info_request request; 8554 struct smp_report_manuf_info_response response; 8555 struct sbuf *sb = NULL; 8556 int long_response = 0; 8557 int retval = 0; 8558 int c; 8559 8560 /* 8561 * Note that at the moment we don't support sending SMP CCBs to 8562 * devices that aren't probed by CAM. 8563 */ 8564 ccb = cam_getccb(device); 8565 if (ccb == NULL) { 8566 warnx("%s: error allocating CCB", __func__); 8567 return (1); 8568 } 8569 8570 while ((c = getopt(argc, argv, combinedopt)) != -1) { 8571 switch (c) { 8572 case 'l': 8573 long_response = 1; 8574 break; 8575 default: 8576 break; 8577 } 8578 } 8579 bzero(&request, sizeof(request)); 8580 bzero(&response, sizeof(response)); 8581 8582 smp_report_manuf_info(&ccb->smpio, 8583 retry_count, 8584 /*cbfcnp*/ NULL, 8585 &request, 8586 sizeof(request), 8587 (uint8_t *)&response, 8588 sizeof(response), 8589 long_response, 8590 timeout); 8591 8592 if (((retval = cam_send_ccb(device, ccb)) < 0) 8593 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 8594 const char warnstr[] = "error sending command"; 8595 8596 if (retval < 0) 8597 warn(warnstr); 8598 else 8599 warnx(warnstr); 8600 8601 if (arglist & CAM_ARG_VERBOSE) { 8602 cam_error_print(device, ccb, CAM_ESF_ALL, 8603 CAM_EPF_ALL, stderr); 8604 } 8605 retval = 1; 8606 goto bailout; 8607 } 8608 8609 sb = sbuf_new_auto(); 8610 if (sb == NULL) { 8611 warnx("%s: error allocating sbuf", __func__); 8612 goto bailout; 8613 } 8614 8615 smp_report_manuf_info_sbuf(&response, sizeof(response), sb); 8616 8617 if (sbuf_finish(sb) != 0) { 8618 warnx("%s: sbuf_finish", __func__); 8619 goto bailout; 8620 } 8621 8622 printf("%s", sbuf_data(sb)); 8623 8624 bailout: 8625 8626 if (ccb != NULL) 8627 cam_freeccb(ccb); 8628 8629 if (sb != NULL) 8630 sbuf_delete(sb); 8631 8632 return (retval); 8633 } 8634 8635 static int 8636 getdevid(struct cam_devitem *item) 8637 { 8638 int retval = 0; 8639 union ccb *ccb = NULL; 8640 8641 struct cam_device *dev; 8642 8643 dev = cam_open_btl(item->dev_match.path_id, 8644 item->dev_match.target_id, 8645 item->dev_match.target_lun, O_RDWR, NULL); 8646 8647 if (dev == NULL) { 8648 warnx("%s", cam_errbuf); 8649 retval = 1; 8650 goto bailout; 8651 } 8652 8653 item->device_id_len = 0; 8654 8655 ccb = cam_getccb(dev); 8656 if (ccb == NULL) { 8657 warnx("%s: error allocating CCB", __func__); 8658 retval = 1; 8659 goto bailout; 8660 } 8661 8662 /* 8663 * On the first try, we just probe for the size of the data, and 8664 * then allocate that much memory and try again. 8665 */ 8666 retry: 8667 ccb->ccb_h.func_code = XPT_DEV_ADVINFO; 8668 ccb->ccb_h.flags = CAM_DIR_IN; 8669 ccb->cdai.flags = CDAI_FLAG_NONE; 8670 ccb->cdai.buftype = CDAI_TYPE_SCSI_DEVID; 8671 ccb->cdai.bufsiz = item->device_id_len; 8672 if (item->device_id_len != 0) 8673 ccb->cdai.buf = (uint8_t *)item->device_id; 8674 8675 if (cam_send_ccb(dev, ccb) < 0) { 8676 warn("%s: error sending XPT_GDEV_ADVINFO CCB", __func__); 8677 retval = 1; 8678 goto bailout; 8679 } 8680 8681 if (ccb->ccb_h.status != CAM_REQ_CMP) { 8682 warnx("%s: CAM status %#x", __func__, ccb->ccb_h.status); 8683 retval = 1; 8684 goto bailout; 8685 } 8686 8687 if (item->device_id_len == 0) { 8688 /* 8689 * This is our first time through. Allocate the buffer, 8690 * and then go back to get the data. 8691 */ 8692 if (ccb->cdai.provsiz == 0) { 8693 warnx("%s: invalid .provsiz field returned with " 8694 "XPT_GDEV_ADVINFO CCB", __func__); 8695 retval = 1; 8696 goto bailout; 8697 } 8698 item->device_id_len = ccb->cdai.provsiz; 8699 item->device_id = malloc(item->device_id_len); 8700 if (item->device_id == NULL) { 8701 warn("%s: unable to allocate %d bytes", __func__, 8702 item->device_id_len); 8703 retval = 1; 8704 goto bailout; 8705 } 8706 ccb->ccb_h.status = CAM_REQ_INPROG; 8707 goto retry; 8708 } 8709 8710 bailout: 8711 if (dev != NULL) 8712 cam_close_device(dev); 8713 8714 if (ccb != NULL) 8715 cam_freeccb(ccb); 8716 8717 return (retval); 8718 } 8719 8720 /* 8721 * XXX KDM merge this code with getdevtree()? 8722 */ 8723 static int 8724 buildbusdevlist(struct cam_devlist *devlist) 8725 { 8726 union ccb ccb; 8727 int bufsize, fd = -1; 8728 struct dev_match_pattern *patterns; 8729 struct cam_devitem *item = NULL; 8730 int skip_device = 0; 8731 int retval = 0; 8732 8733 if ((fd = open(XPT_DEVICE, O_RDWR)) == -1) { 8734 warn("couldn't open %s", XPT_DEVICE); 8735 return (1); 8736 } 8737 8738 bzero(&ccb, sizeof(union ccb)); 8739 8740 ccb.ccb_h.path_id = CAM_XPT_PATH_ID; 8741 ccb.ccb_h.target_id = CAM_TARGET_WILDCARD; 8742 ccb.ccb_h.target_lun = CAM_LUN_WILDCARD; 8743 8744 ccb.ccb_h.func_code = XPT_DEV_MATCH; 8745 bufsize = sizeof(struct dev_match_result) * 100; 8746 ccb.cdm.match_buf_len = bufsize; 8747 ccb.cdm.matches = (struct dev_match_result *)malloc(bufsize); 8748 if (ccb.cdm.matches == NULL) { 8749 warnx("can't malloc memory for matches"); 8750 close(fd); 8751 return (1); 8752 } 8753 ccb.cdm.num_matches = 0; 8754 ccb.cdm.num_patterns = 2; 8755 ccb.cdm.pattern_buf_len = sizeof(struct dev_match_pattern) * 8756 ccb.cdm.num_patterns; 8757 8758 patterns = (struct dev_match_pattern *)malloc(ccb.cdm.pattern_buf_len); 8759 if (patterns == NULL) { 8760 warnx("can't malloc memory for patterns"); 8761 retval = 1; 8762 goto bailout; 8763 } 8764 8765 ccb.cdm.patterns = patterns; 8766 bzero(patterns, ccb.cdm.pattern_buf_len); 8767 8768 patterns[0].type = DEV_MATCH_DEVICE; 8769 patterns[0].pattern.device_pattern.flags = DEV_MATCH_PATH; 8770 patterns[0].pattern.device_pattern.path_id = devlist->path_id; 8771 patterns[1].type = DEV_MATCH_PERIPH; 8772 patterns[1].pattern.periph_pattern.flags = PERIPH_MATCH_PATH; 8773 patterns[1].pattern.periph_pattern.path_id = devlist->path_id; 8774 8775 /* 8776 * We do the ioctl multiple times if necessary, in case there are 8777 * more than 100 nodes in the EDT. 8778 */ 8779 do { 8780 unsigned int i; 8781 8782 if (ioctl(fd, CAMIOCOMMAND, &ccb) == -1) { 8783 warn("error sending CAMIOCOMMAND ioctl"); 8784 retval = 1; 8785 goto bailout; 8786 } 8787 8788 if ((ccb.ccb_h.status != CAM_REQ_CMP) 8789 || ((ccb.cdm.status != CAM_DEV_MATCH_LAST) 8790 && (ccb.cdm.status != CAM_DEV_MATCH_MORE))) { 8791 warnx("got CAM error %#x, CDM error %d\n", 8792 ccb.ccb_h.status, ccb.cdm.status); 8793 retval = 1; 8794 goto bailout; 8795 } 8796 8797 for (i = 0; i < ccb.cdm.num_matches; i++) { 8798 switch (ccb.cdm.matches[i].type) { 8799 case DEV_MATCH_DEVICE: { 8800 struct device_match_result *dev_result; 8801 8802 dev_result = 8803 &ccb.cdm.matches[i].result.device_result; 8804 8805 if (dev_result->flags & 8806 DEV_RESULT_UNCONFIGURED) { 8807 skip_device = 1; 8808 break; 8809 } else 8810 skip_device = 0; 8811 8812 item = malloc(sizeof(*item)); 8813 if (item == NULL) { 8814 warn("%s: unable to allocate %zd bytes", 8815 __func__, sizeof(*item)); 8816 retval = 1; 8817 goto bailout; 8818 } 8819 bzero(item, sizeof(*item)); 8820 bcopy(dev_result, &item->dev_match, 8821 sizeof(*dev_result)); 8822 STAILQ_INSERT_TAIL(&devlist->dev_queue, item, 8823 links); 8824 8825 if (getdevid(item) != 0) { 8826 retval = 1; 8827 goto bailout; 8828 } 8829 break; 8830 } 8831 case DEV_MATCH_PERIPH: { 8832 struct periph_match_result *periph_result; 8833 8834 periph_result = 8835 &ccb.cdm.matches[i].result.periph_result; 8836 8837 if (skip_device != 0) 8838 break; 8839 item->num_periphs++; 8840 item->periph_matches = realloc( 8841 item->periph_matches, 8842 item->num_periphs * 8843 sizeof(struct periph_match_result)); 8844 if (item->periph_matches == NULL) { 8845 warn("%s: error allocating periph " 8846 "list", __func__); 8847 retval = 1; 8848 goto bailout; 8849 } 8850 bcopy(periph_result, &item->periph_matches[ 8851 item->num_periphs - 1], 8852 sizeof(*periph_result)); 8853 break; 8854 } 8855 default: 8856 fprintf(stderr, "%s: unexpected match " 8857 "type %d\n", __func__, 8858 ccb.cdm.matches[i].type); 8859 retval = 1; 8860 goto bailout; 8861 break; /*NOTREACHED*/ 8862 } 8863 } 8864 } while ((ccb.ccb_h.status == CAM_REQ_CMP) 8865 && (ccb.cdm.status == CAM_DEV_MATCH_MORE)); 8866 bailout: 8867 8868 if (fd != -1) 8869 close(fd); 8870 8871 free(patterns); 8872 8873 free(ccb.cdm.matches); 8874 8875 if (retval != 0) 8876 freebusdevlist(devlist); 8877 8878 return (retval); 8879 } 8880 8881 static void 8882 freebusdevlist(struct cam_devlist *devlist) 8883 { 8884 struct cam_devitem *item, *item2; 8885 8886 STAILQ_FOREACH_SAFE(item, &devlist->dev_queue, links, item2) { 8887 STAILQ_REMOVE(&devlist->dev_queue, item, cam_devitem, 8888 links); 8889 free(item->device_id); 8890 free(item->periph_matches); 8891 free(item); 8892 } 8893 } 8894 8895 static struct cam_devitem * 8896 findsasdevice(struct cam_devlist *devlist, uint64_t sasaddr) 8897 { 8898 struct cam_devitem *item; 8899 8900 STAILQ_FOREACH(item, &devlist->dev_queue, links) { 8901 struct scsi_vpd_id_descriptor *idd; 8902 8903 /* 8904 * XXX KDM look for LUN IDs as well? 8905 */ 8906 idd = scsi_get_devid(item->device_id, 8907 item->device_id_len, 8908 scsi_devid_is_sas_target); 8909 if (idd == NULL) 8910 continue; 8911 8912 if (scsi_8btou64(idd->identifier) == sasaddr) 8913 return (item); 8914 } 8915 8916 return (NULL); 8917 } 8918 8919 static int 8920 smpphylist(struct cam_device *device, int argc, char **argv, 8921 char *combinedopt, int retry_count, int timeout) 8922 { 8923 struct smp_report_general_request *rgrequest = NULL; 8924 struct smp_report_general_response *rgresponse = NULL; 8925 struct smp_discover_request *disrequest = NULL; 8926 struct smp_discover_response *disresponse = NULL; 8927 struct cam_devlist devlist; 8928 union ccb *ccb; 8929 int long_response = 0; 8930 int num_phys = 0; 8931 int quiet = 0; 8932 int retval; 8933 int i, c; 8934 8935 /* 8936 * Note that at the moment we don't support sending SMP CCBs to 8937 * devices that aren't probed by CAM. 8938 */ 8939 ccb = cam_getccb(device); 8940 if (ccb == NULL) { 8941 warnx("%s: error allocating CCB", __func__); 8942 return (1); 8943 } 8944 8945 STAILQ_INIT(&devlist.dev_queue); 8946 8947 rgrequest = malloc(sizeof(*rgrequest)); 8948 if (rgrequest == NULL) { 8949 warn("%s: unable to allocate %zd bytes", __func__, 8950 sizeof(*rgrequest)); 8951 retval = 1; 8952 goto bailout; 8953 } 8954 8955 rgresponse = malloc(sizeof(*rgresponse)); 8956 if (rgresponse == NULL) { 8957 warn("%s: unable to allocate %zd bytes", __func__, 8958 sizeof(*rgresponse)); 8959 retval = 1; 8960 goto bailout; 8961 } 8962 8963 while ((c = getopt(argc, argv, combinedopt)) != -1) { 8964 switch (c) { 8965 case 'l': 8966 long_response = 1; 8967 break; 8968 case 'q': 8969 quiet = 1; 8970 break; 8971 default: 8972 break; 8973 } 8974 } 8975 8976 smp_report_general(&ccb->smpio, 8977 retry_count, 8978 /*cbfcnp*/ NULL, 8979 rgrequest, 8980 /*request_len*/ sizeof(*rgrequest), 8981 (uint8_t *)rgresponse, 8982 /*response_len*/ sizeof(*rgresponse), 8983 /*long_response*/ long_response, 8984 timeout); 8985 8986 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 8987 8988 if (((retval = cam_send_ccb(device, ccb)) < 0) 8989 || ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP)) { 8990 const char warnstr[] = "error sending command"; 8991 8992 if (retval < 0) 8993 warn(warnstr); 8994 else 8995 warnx(warnstr); 8996 8997 if (arglist & CAM_ARG_VERBOSE) { 8998 cam_error_print(device, ccb, CAM_ESF_ALL, 8999 CAM_EPF_ALL, stderr); 9000 } 9001 retval = 1; 9002 goto bailout; 9003 } 9004 9005 num_phys = rgresponse->num_phys; 9006 9007 if (num_phys == 0) { 9008 if (quiet == 0) 9009 fprintf(stdout, "%s: No Phys reported\n", __func__); 9010 retval = 1; 9011 goto bailout; 9012 } 9013 9014 devlist.path_id = device->path_id; 9015 9016 retval = buildbusdevlist(&devlist); 9017 if (retval != 0) 9018 goto bailout; 9019 9020 if (quiet == 0) { 9021 fprintf(stdout, "%d PHYs:\n", num_phys); 9022 fprintf(stdout, "PHY Attached SAS Address\n"); 9023 } 9024 9025 disrequest = malloc(sizeof(*disrequest)); 9026 if (disrequest == NULL) { 9027 warn("%s: unable to allocate %zd bytes", __func__, 9028 sizeof(*disrequest)); 9029 retval = 1; 9030 goto bailout; 9031 } 9032 9033 disresponse = malloc(sizeof(*disresponse)); 9034 if (disresponse == NULL) { 9035 warn("%s: unable to allocate %zd bytes", __func__, 9036 sizeof(*disresponse)); 9037 retval = 1; 9038 goto bailout; 9039 } 9040 9041 for (i = 0; i < num_phys; i++) { 9042 struct cam_devitem *item; 9043 struct device_match_result *dev_match; 9044 char vendor[16], product[48], revision[16]; 9045 char tmpstr[256]; 9046 int j; 9047 9048 CCB_CLEAR_ALL_EXCEPT_HDR(&ccb->smpio); 9049 9050 ccb->ccb_h.status = CAM_REQ_INPROG; 9051 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 9052 9053 smp_discover(&ccb->smpio, 9054 retry_count, 9055 /*cbfcnp*/ NULL, 9056 disrequest, 9057 sizeof(*disrequest), 9058 (uint8_t *)disresponse, 9059 sizeof(*disresponse), 9060 long_response, 9061 /*ignore_zone_group*/ 0, 9062 /*phy*/ i, 9063 timeout); 9064 9065 if (((retval = cam_send_ccb(device, ccb)) < 0) 9066 || (((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) 9067 && (disresponse->function_result != SMP_FR_PHY_VACANT))) { 9068 const char warnstr[] = "error sending command"; 9069 9070 if (retval < 0) 9071 warn(warnstr); 9072 else 9073 warnx(warnstr); 9074 9075 if (arglist & CAM_ARG_VERBOSE) { 9076 cam_error_print(device, ccb, CAM_ESF_ALL, 9077 CAM_EPF_ALL, stderr); 9078 } 9079 retval = 1; 9080 goto bailout; 9081 } 9082 9083 if (disresponse->function_result == SMP_FR_PHY_VACANT) { 9084 if (quiet == 0) 9085 fprintf(stdout, "%3d <vacant>\n", i); 9086 continue; 9087 } 9088 9089 if (disresponse->attached_device == SMP_DIS_AD_TYPE_NONE) { 9090 item = NULL; 9091 } else { 9092 item = findsasdevice(&devlist, 9093 scsi_8btou64(disresponse->attached_sas_address)); 9094 } 9095 9096 if ((quiet == 0) 9097 || (item != NULL)) { 9098 fprintf(stdout, "%3d 0x%016jx", i, 9099 (uintmax_t)scsi_8btou64( 9100 disresponse->attached_sas_address)); 9101 if (item == NULL) { 9102 fprintf(stdout, "\n"); 9103 continue; 9104 } 9105 } else if (quiet != 0) 9106 continue; 9107 9108 dev_match = &item->dev_match; 9109 9110 if (dev_match->protocol == PROTO_SCSI) { 9111 cam_strvis(vendor, dev_match->inq_data.vendor, 9112 sizeof(dev_match->inq_data.vendor), 9113 sizeof(vendor)); 9114 cam_strvis(product, dev_match->inq_data.product, 9115 sizeof(dev_match->inq_data.product), 9116 sizeof(product)); 9117 cam_strvis(revision, dev_match->inq_data.revision, 9118 sizeof(dev_match->inq_data.revision), 9119 sizeof(revision)); 9120 sprintf(tmpstr, "<%s %s %s>", vendor, product, 9121 revision); 9122 } else if ((dev_match->protocol == PROTO_ATA) 9123 || (dev_match->protocol == PROTO_SATAPM)) { 9124 cam_strvis(product, dev_match->ident_data.model, 9125 sizeof(dev_match->ident_data.model), 9126 sizeof(product)); 9127 cam_strvis(revision, dev_match->ident_data.revision, 9128 sizeof(dev_match->ident_data.revision), 9129 sizeof(revision)); 9130 sprintf(tmpstr, "<%s %s>", product, revision); 9131 } else { 9132 sprintf(tmpstr, "<>"); 9133 } 9134 fprintf(stdout, " %-33s ", tmpstr); 9135 9136 /* 9137 * If we have 0 periphs, that's a bug... 9138 */ 9139 if (item->num_periphs == 0) { 9140 fprintf(stdout, "\n"); 9141 continue; 9142 } 9143 9144 fprintf(stdout, "("); 9145 for (j = 0; j < item->num_periphs; j++) { 9146 if (j > 0) 9147 fprintf(stdout, ","); 9148 9149 fprintf(stdout, "%s%d", 9150 item->periph_matches[j].periph_name, 9151 item->periph_matches[j].unit_number); 9152 9153 } 9154 fprintf(stdout, ")\n"); 9155 } 9156 bailout: 9157 if (ccb != NULL) 9158 cam_freeccb(ccb); 9159 9160 free(rgrequest); 9161 9162 free(rgresponse); 9163 9164 free(disrequest); 9165 9166 free(disresponse); 9167 9168 freebusdevlist(&devlist); 9169 9170 return (retval); 9171 } 9172 9173 static int 9174 atapm_proc_resp(struct cam_device *device, union ccb *ccb) 9175 { 9176 uint8_t error = 0, ata_device = 0, status = 0; 9177 uint16_t count = 0; 9178 uint64_t lba = 0; 9179 int retval; 9180 9181 retval = get_ata_status(device, ccb, &error, &count, &lba, &ata_device, 9182 &status); 9183 if (retval == 1) { 9184 if (arglist & CAM_ARG_VERBOSE) { 9185 cam_error_print(device, ccb, CAM_ESF_ALL, 9186 CAM_EPF_ALL, stderr); 9187 } 9188 warnx("Can't get ATA command status"); 9189 return (retval); 9190 } 9191 9192 if (status & ATA_STATUS_ERROR) { 9193 cam_error_print(device, ccb, CAM_ESF_ALL, 9194 CAM_EPF_ALL, stderr); 9195 return (1); 9196 } 9197 9198 printf("%s%d: ", device->device_name, device->dev_unit_num); 9199 switch (count) { 9200 case ATA_PM_STANDBY: 9201 printf("Standby mode\n"); 9202 break; 9203 case ATA_PM_STANDBY_Y: 9204 printf("Standby_y mode\n"); 9205 break; 9206 case 0x40: /* obsolete since ACS-3 */ 9207 printf("NV Cache Power Mode and the spindle is spun down or spinning down\n"); 9208 break; 9209 case 0x41: /* obsolete since ACS-3 */ 9210 printf("NV Cache Power Mode and the spindle is spun up or spinning up\n"); 9211 break; 9212 case ATA_PM_IDLE: 9213 printf("Idle mode\n"); 9214 break; 9215 case ATA_PM_IDLE_A: 9216 printf("Idle_a mode\n"); 9217 break; 9218 case ATA_PM_IDLE_B: 9219 printf("Idle_b mode\n"); 9220 break; 9221 case ATA_PM_IDLE_C: 9222 printf("Idle_c mode\n"); 9223 break; 9224 case ATA_PM_ACTIVE_IDLE: 9225 printf("Active or Idle mode\n"); 9226 break; 9227 default: 9228 printf("Unknown mode 0x%02x\n", count); 9229 break; 9230 } 9231 9232 return (0); 9233 } 9234 9235 static int 9236 atapm(struct cam_device *device, int argc, char **argv, 9237 char *combinedopt, int retry_count, int timeout) 9238 { 9239 union ccb *ccb; 9240 int retval = 0; 9241 int t = -1; 9242 int c; 9243 uint8_t ata_flags = 0; 9244 u_char cmd, sc; 9245 9246 ccb = cam_getccb(device); 9247 9248 if (ccb == NULL) { 9249 warnx("%s: error allocating ccb", __func__); 9250 return (1); 9251 } 9252 9253 while ((c = getopt(argc, argv, combinedopt)) != -1) { 9254 switch (c) { 9255 case 't': 9256 t = atoi(optarg); 9257 break; 9258 default: 9259 break; 9260 } 9261 } 9262 if (strcmp(argv[1], "idle") == 0) { 9263 if (t == -1) 9264 cmd = ATA_IDLE_IMMEDIATE; 9265 else 9266 cmd = ATA_IDLE_CMD; 9267 } else if (strcmp(argv[1], "standby") == 0) { 9268 if (t == -1) 9269 cmd = ATA_STANDBY_IMMEDIATE; 9270 else 9271 cmd = ATA_STANDBY_CMD; 9272 } else if (strcmp(argv[1], "powermode") == 0) { 9273 cmd = ATA_CHECK_POWER_MODE; 9274 ata_flags = AP_FLAG_CHK_COND; 9275 t = -1; 9276 } else { 9277 cmd = ATA_SLEEP; 9278 t = -1; 9279 } 9280 9281 if (t < 0) 9282 sc = 0; 9283 else if (t <= (240 * 5)) 9284 sc = (t + 4) / 5; 9285 else if (t <= (252 * 5)) 9286 /* special encoding for 21 minutes */ 9287 sc = 252; 9288 else if (t <= (11 * 30 * 60)) 9289 sc = (t - 1) / (30 * 60) + 241; 9290 else 9291 sc = 253; 9292 9293 retval = ata_do_cmd(device, 9294 ccb, 9295 /*retries*/retry_count, 9296 /*flags*/CAM_DIR_NONE, 9297 /*protocol*/AP_PROTO_NON_DATA, 9298 /*ata_flags*/ata_flags, 9299 /*tag_action*/MSG_SIMPLE_Q_TAG, 9300 /*command*/cmd, 9301 /*features*/0, 9302 /*lba*/0, 9303 /*sector_count*/sc, 9304 /*data_ptr*/NULL, 9305 /*dxfer_len*/0, 9306 /*timeout*/timeout ? timeout : 30 * 1000, 9307 /*force48bit*/0); 9308 9309 if (retval == 0 && cmd == ATA_CHECK_POWER_MODE) 9310 retval = atapm_proc_resp(device, ccb); 9311 9312 cam_freeccb(ccb); 9313 return (retval); 9314 } 9315 9316 static int 9317 ataaxm(struct cam_device *device, int argc, char **argv, 9318 char *combinedopt, int retry_count, int timeout) 9319 { 9320 union ccb *ccb; 9321 int retval = 0; 9322 int l = -1; 9323 int c; 9324 u_char cmd, sc; 9325 9326 ccb = cam_getccb(device); 9327 9328 if (ccb == NULL) { 9329 warnx("%s: error allocating ccb", __func__); 9330 return (1); 9331 } 9332 9333 while ((c = getopt(argc, argv, combinedopt)) != -1) { 9334 switch (c) { 9335 case 'l': 9336 l = atoi(optarg); 9337 break; 9338 default: 9339 break; 9340 } 9341 } 9342 sc = 0; 9343 if (strcmp(argv[1], "apm") == 0) { 9344 if (l == -1) 9345 cmd = 0x85; 9346 else { 9347 cmd = 0x05; 9348 sc = l; 9349 } 9350 } else /* aam */ { 9351 if (l == -1) 9352 cmd = 0xC2; 9353 else { 9354 cmd = 0x42; 9355 sc = l; 9356 } 9357 } 9358 9359 retval = ata_do_cmd(device, 9360 ccb, 9361 /*retries*/retry_count, 9362 /*flags*/CAM_DIR_NONE, 9363 /*protocol*/AP_PROTO_NON_DATA, 9364 /*ata_flags*/0, 9365 /*tag_action*/MSG_SIMPLE_Q_TAG, 9366 /*command*/ATA_SETFEATURES, 9367 /*features*/cmd, 9368 /*lba*/0, 9369 /*sector_count*/sc, 9370 /*data_ptr*/NULL, 9371 /*dxfer_len*/0, 9372 /*timeout*/timeout ? timeout : 30 * 1000, 9373 /*force48bit*/0); 9374 9375 cam_freeccb(ccb); 9376 return (retval); 9377 } 9378 9379 int 9380 scsigetopcodes(struct cam_device *device, int opcode_set, int opcode, 9381 int show_sa_errors, int sa_set, int service_action, 9382 int timeout_desc, int task_attr, int retry_count, int timeout, 9383 int verbosemode, uint32_t *fill_len, uint8_t **data_ptr) 9384 { 9385 union ccb *ccb = NULL; 9386 uint8_t *buf = NULL; 9387 uint32_t alloc_len = 0, num_opcodes; 9388 uint32_t valid_len = 0; 9389 uint32_t avail_len = 0; 9390 struct scsi_report_supported_opcodes_all *all_hdr; 9391 struct scsi_report_supported_opcodes_one *one; 9392 int options = 0; 9393 int retval = 0; 9394 9395 /* 9396 * Make it clear that we haven't yet allocated or filled anything. 9397 */ 9398 *fill_len = 0; 9399 *data_ptr = NULL; 9400 9401 ccb = cam_getccb(device); 9402 if (ccb == NULL) { 9403 warnx("couldn't allocate CCB"); 9404 retval = 1; 9405 goto bailout; 9406 } 9407 9408 if (opcode_set != 0) { 9409 options |= RSO_OPTIONS_OC; 9410 num_opcodes = 1; 9411 alloc_len = sizeof(*one) + CAM_MAX_CDBLEN; 9412 } else { 9413 num_opcodes = 256; 9414 alloc_len = sizeof(*all_hdr) + (num_opcodes * 9415 sizeof(struct scsi_report_supported_opcodes_descr)); 9416 } 9417 9418 if (timeout_desc != 0) { 9419 options |= RSO_RCTD; 9420 alloc_len += num_opcodes * 9421 sizeof(struct scsi_report_supported_opcodes_timeout); 9422 } 9423 9424 if (sa_set != 0) { 9425 options |= RSO_OPTIONS_OC_SA; 9426 if (show_sa_errors != 0) 9427 options &= ~RSO_OPTIONS_OC; 9428 } 9429 9430 retry_alloc: 9431 if (buf != NULL) { 9432 free(buf); 9433 buf = NULL; 9434 } 9435 9436 buf = malloc(alloc_len); 9437 if (buf == NULL) { 9438 warn("Unable to allocate %u bytes", alloc_len); 9439 retval = 1; 9440 goto bailout; 9441 } 9442 bzero(buf, alloc_len); 9443 9444 scsi_report_supported_opcodes(&ccb->csio, 9445 /*retries*/ retry_count, 9446 /*cbfcnp*/ NULL, 9447 /*tag_action*/ task_attr, 9448 /*options*/ options, 9449 /*req_opcode*/ opcode, 9450 /*req_service_action*/ service_action, 9451 /*data_ptr*/ buf, 9452 /*dxfer_len*/ alloc_len, 9453 /*sense_len*/ SSD_FULL_SIZE, 9454 /*timeout*/ timeout ? timeout : 10000); 9455 9456 ccb->ccb_h.flags |= CAM_DEV_QFRZDIS; 9457 9458 if (retry_count != 0) 9459 ccb->ccb_h.flags |= CAM_PASS_ERR_RECOVER; 9460 9461 if (cam_send_ccb(device, ccb) < 0) { 9462 warn("error sending REPORT SUPPORTED OPERATION CODES command"); 9463 retval = 1; 9464 goto bailout; 9465 } 9466 9467 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 9468 if (verbosemode != 0) 9469 cam_error_print(device, ccb, CAM_ESF_ALL, 9470 CAM_EPF_ALL, stderr); 9471 retval = 1; 9472 goto bailout; 9473 } 9474 9475 valid_len = ccb->csio.dxfer_len - ccb->csio.resid; 9476 9477 if (((options & RSO_OPTIONS_MASK) == RSO_OPTIONS_ALL) 9478 && (valid_len >= sizeof(*all_hdr))) { 9479 all_hdr = (struct scsi_report_supported_opcodes_all *)buf; 9480 avail_len = scsi_4btoul(all_hdr->length) + sizeof(*all_hdr); 9481 } else if (((options & RSO_OPTIONS_MASK) != RSO_OPTIONS_ALL) 9482 && (valid_len >= sizeof(*one))) { 9483 uint32_t cdb_length; 9484 9485 one = (struct scsi_report_supported_opcodes_one *)buf; 9486 cdb_length = scsi_2btoul(one->cdb_length); 9487 avail_len = sizeof(*one) + cdb_length; 9488 if (one->support & RSO_ONE_CTDP) { 9489 struct scsi_report_supported_opcodes_timeout *td; 9490 9491 td = (struct scsi_report_supported_opcodes_timeout *) 9492 &buf[avail_len]; 9493 if (valid_len >= (avail_len + sizeof(td->length))) { 9494 avail_len += scsi_2btoul(td->length) + 9495 sizeof(td->length); 9496 } else { 9497 avail_len += sizeof(*td); 9498 } 9499 } 9500 } 9501 9502 /* 9503 * avail_len could be zero if we didn't get enough data back from 9504 * thet target to determine 9505 */ 9506 if ((avail_len != 0) 9507 && (avail_len > valid_len)) { 9508 alloc_len = avail_len; 9509 goto retry_alloc; 9510 } 9511 9512 *fill_len = valid_len; 9513 *data_ptr = buf; 9514 bailout: 9515 if (retval != 0) 9516 free(buf); 9517 9518 cam_freeccb(ccb); 9519 9520 return (retval); 9521 } 9522 9523 static int 9524 scsiprintoneopcode(struct cam_device *device, int req_opcode, int sa_set, 9525 int req_sa, uint8_t *buf, uint32_t valid_len) 9526 { 9527 struct scsi_report_supported_opcodes_one *one; 9528 struct scsi_report_supported_opcodes_timeout *td; 9529 uint32_t cdb_len = 0, td_len = 0; 9530 const char *op_desc = NULL; 9531 unsigned int i; 9532 int retval = 0; 9533 9534 one = (struct scsi_report_supported_opcodes_one *)buf; 9535 9536 /* 9537 * If we don't have the full single opcode descriptor, no point in 9538 * continuing. 9539 */ 9540 if (valid_len < __offsetof(struct scsi_report_supported_opcodes_one, 9541 cdb_length)) { 9542 warnx("Only %u bytes returned, not enough to verify support", 9543 valid_len); 9544 retval = 1; 9545 goto bailout; 9546 } 9547 9548 op_desc = scsi_op_desc(req_opcode, &device->inq_data); 9549 9550 printf("%s (0x%02x)", op_desc != NULL ? op_desc : "UNKNOWN", 9551 req_opcode); 9552 if (sa_set != 0) 9553 printf(", SA 0x%x", req_sa); 9554 printf(": "); 9555 9556 switch (one->support & RSO_ONE_SUP_MASK) { 9557 case RSO_ONE_SUP_UNAVAIL: 9558 printf("No command support information currently available\n"); 9559 break; 9560 case RSO_ONE_SUP_NOT_SUP: 9561 printf("Command not supported\n"); 9562 retval = 1; 9563 goto bailout; 9564 break; /*NOTREACHED*/ 9565 case RSO_ONE_SUP_AVAIL: 9566 printf("Command is supported, complies with a SCSI standard\n"); 9567 break; 9568 case RSO_ONE_SUP_VENDOR: 9569 printf("Command is supported, vendor-specific " 9570 "implementation\n"); 9571 break; 9572 default: 9573 printf("Unknown command support flags 0x%#x\n", 9574 one->support & RSO_ONE_SUP_MASK); 9575 break; 9576 } 9577 9578 /* 9579 * If we don't have the CDB length, it isn't exactly an error, the 9580 * command probably isn't supported. 9581 */ 9582 if (valid_len < __offsetof(struct scsi_report_supported_opcodes_one, 9583 cdb_usage)) 9584 goto bailout; 9585 9586 cdb_len = scsi_2btoul(one->cdb_length); 9587 9588 /* 9589 * If our valid data doesn't include the full reported length, 9590 * return. The caller should have detected this and adjusted his 9591 * allocation length to get all of the available data. 9592 */ 9593 if (valid_len < sizeof(*one) + cdb_len) { 9594 retval = 1; 9595 goto bailout; 9596 } 9597 9598 /* 9599 * If all we have is the opcode, there is no point in printing out 9600 * the usage bitmap. 9601 */ 9602 if (cdb_len <= 1) { 9603 retval = 1; 9604 goto bailout; 9605 } 9606 9607 printf("CDB usage bitmap:"); 9608 for (i = 0; i < cdb_len; i++) { 9609 printf(" %02x", one->cdb_usage[i]); 9610 } 9611 printf("\n"); 9612 9613 /* 9614 * If we don't have a timeout descriptor, we're done. 9615 */ 9616 if ((one->support & RSO_ONE_CTDP) == 0) 9617 goto bailout; 9618 9619 /* 9620 * If we don't have enough valid length to include the timeout 9621 * descriptor length, we're done. 9622 */ 9623 if (valid_len < (sizeof(*one) + cdb_len + sizeof(td->length))) 9624 goto bailout; 9625 9626 td = (struct scsi_report_supported_opcodes_timeout *) 9627 &buf[sizeof(*one) + cdb_len]; 9628 td_len = scsi_2btoul(td->length); 9629 td_len += sizeof(td->length); 9630 9631 /* 9632 * If we don't have the full timeout descriptor, we're done. 9633 */ 9634 if (td_len < sizeof(*td)) 9635 goto bailout; 9636 9637 /* 9638 * If we don't have enough valid length to contain the full timeout 9639 * descriptor, we're done. 9640 */ 9641 if (valid_len < (sizeof(*one) + cdb_len + td_len)) 9642 goto bailout; 9643 9644 printf("Timeout information:\n"); 9645 printf("Command-specific: 0x%02x\n", td->cmd_specific); 9646 printf("Nominal timeout: %u seconds\n", 9647 scsi_4btoul(td->nominal_time)); 9648 printf("Recommended timeout: %u seconds\n", 9649 scsi_4btoul(td->recommended_time)); 9650 9651 bailout: 9652 return (retval); 9653 } 9654 9655 static int 9656 scsiprintopcodes(struct cam_device *device, int td_req, uint8_t *buf, 9657 uint32_t valid_len) 9658 { 9659 struct scsi_report_supported_opcodes_all *hdr; 9660 struct scsi_report_supported_opcodes_descr *desc; 9661 uint32_t avail_len = 0, used_len = 0; 9662 uint8_t *cur_ptr; 9663 int retval = 0; 9664 9665 if (valid_len < sizeof(*hdr)) { 9666 warnx("%s: not enough returned data (%u bytes) opcode list", 9667 __func__, valid_len); 9668 retval = 1; 9669 goto bailout; 9670 } 9671 hdr = (struct scsi_report_supported_opcodes_all *)buf; 9672 avail_len = scsi_4btoul(hdr->length); 9673 avail_len += sizeof(hdr->length); 9674 /* 9675 * Take the lesser of the amount of data the drive claims is 9676 * available, and the amount of data the HBA says was returned. 9677 */ 9678 avail_len = MIN(avail_len, valid_len); 9679 9680 used_len = sizeof(hdr->length); 9681 9682 printf("%-6s %4s %8s ", 9683 "Opcode", "SA", "CDB len" ); 9684 9685 if (td_req != 0) 9686 printf("%5s %6s %6s ", "CS", "Nom", "Rec"); 9687 printf(" Description\n"); 9688 9689 while ((avail_len - used_len) > sizeof(*desc)) { 9690 struct scsi_report_supported_opcodes_timeout *td; 9691 uint32_t td_len; 9692 const char *op_desc = NULL; 9693 9694 cur_ptr = &buf[used_len]; 9695 desc = (struct scsi_report_supported_opcodes_descr *)cur_ptr; 9696 9697 op_desc = scsi_op_desc(desc->opcode, &device->inq_data); 9698 if (op_desc == NULL) 9699 op_desc = "UNKNOWN"; 9700 9701 printf("0x%02x %#4x %8u ", desc->opcode, 9702 scsi_2btoul(desc->service_action), 9703 scsi_2btoul(desc->cdb_length)); 9704 9705 used_len += sizeof(*desc); 9706 9707 if ((desc->flags & RSO_CTDP) == 0) { 9708 printf(" %s\n", op_desc); 9709 continue; 9710 } 9711 9712 /* 9713 * If we don't have enough space to fit a timeout 9714 * descriptor, then we're done. 9715 */ 9716 if (avail_len - used_len < sizeof(*td)) { 9717 used_len = avail_len; 9718 printf(" %s\n", op_desc); 9719 continue; 9720 } 9721 cur_ptr = &buf[used_len]; 9722 td = (struct scsi_report_supported_opcodes_timeout *)cur_ptr; 9723 td_len = scsi_2btoul(td->length); 9724 td_len += sizeof(td->length); 9725 9726 used_len += td_len; 9727 /* 9728 * If the given timeout descriptor length is less than what 9729 * we understand, skip it. 9730 */ 9731 if (td_len < sizeof(*td)) { 9732 printf(" %s\n", op_desc); 9733 continue; 9734 } 9735 9736 printf(" 0x%02x %6u %6u %s\n", td->cmd_specific, 9737 scsi_4btoul(td->nominal_time), 9738 scsi_4btoul(td->recommended_time), op_desc); 9739 } 9740 bailout: 9741 return (retval); 9742 } 9743 9744 static int 9745 scsiopcodes(struct cam_device *device, int argc, char **argv, 9746 char *combinedopt, int task_attr, int retry_count, int timeout, 9747 int verbosemode) 9748 { 9749 int c; 9750 uint32_t opcode = 0, service_action = 0; 9751 int td_set = 0, opcode_set = 0, sa_set = 0; 9752 int show_sa_errors = 1; 9753 uint32_t valid_len = 0; 9754 uint8_t *buf = NULL; 9755 char *endptr; 9756 int retval = 0; 9757 9758 while ((c = getopt(argc, argv, combinedopt)) != -1) { 9759 switch (c) { 9760 case 'N': 9761 show_sa_errors = 0; 9762 break; 9763 case 'o': 9764 opcode = strtoul(optarg, &endptr, 0); 9765 if (*endptr != '\0') { 9766 warnx("Invalid opcode \"%s\", must be a number", 9767 optarg); 9768 retval = 1; 9769 goto bailout; 9770 } 9771 if (opcode > 0xff) { 9772 warnx("Invalid opcode 0x%#x, must be between" 9773 "0 and 0xff inclusive", opcode); 9774 retval = 1; 9775 goto bailout; 9776 } 9777 opcode_set = 1; 9778 break; 9779 case 's': 9780 service_action = strtoul(optarg, &endptr, 0); 9781 if (*endptr != '\0') { 9782 warnx("Invalid service action \"%s\", must " 9783 "be a number", optarg); 9784 retval = 1; 9785 goto bailout; 9786 } 9787 if (service_action > 0xffff) { 9788 warnx("Invalid service action 0x%#x, must " 9789 "be between 0 and 0xffff inclusive", 9790 service_action); 9791 retval = 1; 9792 } 9793 sa_set = 1; 9794 break; 9795 case 'T': 9796 td_set = 1; 9797 break; 9798 default: 9799 break; 9800 } 9801 } 9802 9803 if ((sa_set != 0) 9804 && (opcode_set == 0)) { 9805 warnx("You must specify an opcode with -o if a service " 9806 "action is given"); 9807 retval = 1; 9808 goto bailout; 9809 } 9810 retval = scsigetopcodes(device, opcode_set, opcode, show_sa_errors, 9811 sa_set, service_action, td_set, task_attr, 9812 retry_count, timeout, verbosemode, &valid_len, 9813 &buf); 9814 if (retval != 0) 9815 goto bailout; 9816 9817 if ((opcode_set != 0) 9818 || (sa_set != 0)) { 9819 retval = scsiprintoneopcode(device, opcode, sa_set, 9820 service_action, buf, valid_len); 9821 } else { 9822 retval = scsiprintopcodes(device, td_set, buf, valid_len); 9823 } 9824 9825 bailout: 9826 free(buf); 9827 9828 return (retval); 9829 } 9830 9831 9832 static int 9833 reprobe(struct cam_device *device) 9834 { 9835 union ccb *ccb; 9836 int retval = 0; 9837 9838 ccb = cam_getccb(device); 9839 9840 if (ccb == NULL) { 9841 warnx("%s: error allocating ccb", __func__); 9842 return (1); 9843 } 9844 9845 ccb->ccb_h.func_code = XPT_REPROBE_LUN; 9846 9847 if (cam_send_ccb(device, ccb) < 0) { 9848 warn("error sending XPT_REPROBE_LUN CCB"); 9849 retval = 1; 9850 goto bailout; 9851 } 9852 9853 if ((ccb->ccb_h.status & CAM_STATUS_MASK) != CAM_REQ_CMP) { 9854 cam_error_print(device, ccb, CAM_ESF_ALL, CAM_EPF_ALL, stderr); 9855 retval = 1; 9856 goto bailout; 9857 } 9858 9859 bailout: 9860 cam_freeccb(ccb); 9861 9862 return (retval); 9863 } 9864 9865 void 9866 usage(int printlong) 9867 { 9868 9869 fprintf(printlong ? stdout : stderr, 9870 "usage: camcontrol <command> [device id][generic args][command args]\n" 9871 " camcontrol devlist [-b] [-v]\n" 9872 " camcontrol periphlist [dev_id][-n dev_name] [-u unit]\n" 9873 " camcontrol tur [dev_id][generic args]\n" 9874 " camcontrol inquiry [dev_id][generic args] [-D] [-S] [-R]\n" 9875 " camcontrol identify [dev_id][generic args] [-v]\n" 9876 " camcontrol reportluns [dev_id][generic args] [-c] [-l] [-r report]\n" 9877 " camcontrol readcap [dev_id][generic args] [-b] [-h] [-H] [-N]\n" 9878 " [-q] [-s] [-l]\n" 9879 " camcontrol start [dev_id][generic args]\n" 9880 " camcontrol stop [dev_id][generic args]\n" 9881 " camcontrol load [dev_id][generic args]\n" 9882 " camcontrol eject [dev_id][generic args]\n" 9883 " camcontrol reprobe [dev_id][generic args]\n" 9884 " camcontrol rescan <all | bus[:target:lun] | dev_id>\n" 9885 " camcontrol reset <all | bus[:target:lun] | dev_id>\n" 9886 " camcontrol defects [dev_id][generic args] <-f format> [-P][-G]\n" 9887 " [-q][-s][-S offset][-X]\n" 9888 " camcontrol modepage [dev_id][generic args] <-m page | -l>\n" 9889 " [-P pagectl][-e | -b][-d]\n" 9890 " camcontrol cmd [dev_id][generic args]\n" 9891 " <-a cmd [args] | -c cmd [args]>\n" 9892 " [-d] [-f] [-i len fmt|-o len fmt [args]] [-r fmt]\n" 9893 " camcontrol smpcmd [dev_id][generic args]\n" 9894 " <-r len fmt [args]> <-R len fmt [args]>\n" 9895 " camcontrol smprg [dev_id][generic args][-l]\n" 9896 " camcontrol smppc [dev_id][generic args] <-p phy> [-l]\n" 9897 " [-o operation][-d name][-m rate][-M rate]\n" 9898 " [-T pp_timeout][-a enable|disable]\n" 9899 " [-A enable|disable][-s enable|disable]\n" 9900 " [-S enable|disable]\n" 9901 " camcontrol smpphylist [dev_id][generic args][-l][-q]\n" 9902 " camcontrol smpmaninfo [dev_id][generic args][-l]\n" 9903 " camcontrol debug [-I][-P][-T][-S][-X][-c]\n" 9904 " <all|dev_id|bus[:target[:lun]]|off>\n" 9905 " camcontrol tags [dev_id][generic args] [-N tags] [-q] [-v]\n" 9906 " camcontrol negotiate [dev_id][generic args] [-a][-c]\n" 9907 " [-D <enable|disable>][-M mode][-O offset]\n" 9908 " [-q][-R syncrate][-v][-T <enable|disable>]\n" 9909 " [-U][-W bus_width]\n" 9910 " camcontrol format [dev_id][generic args][-q][-r][-w][-y]\n" 9911 " camcontrol sanitize [dev_id][generic args]\n" 9912 " [-a overwrite|block|crypto|exitfailure]\n" 9913 " [-c passes][-I][-P pattern][-q][-U][-r][-w]\n" 9914 " [-y]\n" 9915 " camcontrol idle [dev_id][generic args][-t time]\n" 9916 " camcontrol standby [dev_id][generic args][-t time]\n" 9917 " camcontrol sleep [dev_id][generic args]\n" 9918 " camcontrol powermode [dev_id][generic args]\n" 9919 " camcontrol apm [dev_id][generic args][-l level]\n" 9920 " camcontrol aam [dev_id][generic args][-l level]\n" 9921 " camcontrol fwdownload [dev_id][generic args] <-f fw_image> [-q]\n" 9922 " [-s][-y]\n" 9923 " camcontrol security [dev_id][generic args]\n" 9924 " <-d pwd | -e pwd | -f | -h pwd | -k pwd>\n" 9925 " [-l <high|maximum>] [-q] [-s pwd] [-T timeout]\n" 9926 " [-U <user|master>] [-y]\n" 9927 " camcontrol hpa [dev_id][generic args] [-f] [-l] [-P] [-p pwd]\n" 9928 " [-q] [-s max_sectors] [-U pwd] [-y]\n" 9929 " camcontrol ama [dev_id][generic args] [-f] [-q] [-s max_sectors]\n" 9930 " camcontrol persist [dev_id][generic args] <-i action|-o action>\n" 9931 " [-a][-I tid][-k key][-K sa_key][-p][-R rtp]\n" 9932 " [-s scope][-S][-T type][-U]\n" 9933 " camcontrol attrib [dev_id][generic args] <-r action|-w attr>\n" 9934 " [-a attr_num][-c][-e elem][-F form1,form1]\n" 9935 " [-p part][-s start][-T type][-V vol]\n" 9936 " camcontrol opcodes [dev_id][generic args][-o opcode][-s SA]\n" 9937 " [-N][-T]\n" 9938 " camcontrol zone [dev_id][generic args]<-c cmd> [-a] [-l LBA]\n" 9939 " [-o rep_opts] [-P print_opts]\n" 9940 " camcontrol epc [dev_id][generic_args]<-c cmd> [-d] [-D] [-e]\n" 9941 " [-H] [-p power_cond] [-P] [-r rst_src] [-s]\n" 9942 " [-S power_src] [-T timer]\n" 9943 " camcontrol timestamp [dev_id][generic_args] <-r [-f format|-m|-U]>|\n" 9944 " <-s <-f format -T time | -U >>\n" 9945 " camcontrol devtype [dev_id]\n" 9946 " camcontrol depop [dev_id] [-d | -l | -r] [-e element] [-c capacity]\n" 9947 " camcontrol mmcsdcmd [dev_id] [[-c mmc_opcode] [-a mmc_arg]\n" 9948 " [-f mmc_flags] [-l data_len]\n" 9949 " [-W [-b data_byte]]] |\n" 9950 " [-F frequency] |\n" 9951 " [-I]\n" 9952 " [-1 | -4]\n" 9953 " [-S high|normal]\n" 9954 " \n" 9955 " camcontrol help\n"); 9956 if (!printlong) 9957 return; 9958 fprintf(stdout, 9959 "Specify one of the following options:\n" 9960 "devlist list all CAM devices\n" 9961 "periphlist list all CAM peripheral drivers attached to a device\n" 9962 "tur send a test unit ready to the named device\n" 9963 "inquiry send a SCSI inquiry command to the named device\n" 9964 "identify send a ATA identify command to the named device\n" 9965 "reportluns send a SCSI report luns command to the device\n" 9966 "readcap send a SCSI read capacity command to the device\n" 9967 "start send a Start Unit command to the device\n" 9968 "stop send a Stop Unit command to the device\n" 9969 "load send a Start Unit command to the device with the load bit set\n" 9970 "eject send a Stop Unit command to the device with the eject bit set\n" 9971 "reprobe update capacity information of the given device\n" 9972 "rescan rescan all buses, the given bus, bus:target:lun or device\n" 9973 "reset reset all buses, the given bus, bus:target:lun or device\n" 9974 "defects read the defect list of the specified device\n" 9975 "modepage display or edit (-e) the given mode page\n" 9976 "cmd send the given SCSI command, may need -i or -o as well\n" 9977 "smpcmd send the given SMP command, requires -o and -i\n" 9978 "smprg send the SMP Report General command\n" 9979 "smppc send the SMP PHY Control command, requires -p\n" 9980 "smpphylist display phys attached to a SAS expander\n" 9981 "smpmaninfo send the SMP Report Manufacturer Info command\n" 9982 "debug turn debugging on/off for a bus, target, or lun, or all devices\n" 9983 "tags report or set the number of transaction slots for a device\n" 9984 "negotiate report or set device negotiation parameters\n" 9985 "format send the SCSI FORMAT UNIT command to the named device\n" 9986 "sanitize send the SCSI SANITIZE command to the named device\n" 9987 "idle send the ATA IDLE command to the named device\n" 9988 "standby send the ATA STANDBY command to the named device\n" 9989 "sleep send the ATA SLEEP command to the named device\n" 9990 "powermode send the ATA CHECK POWER MODE command to the named device\n" 9991 "fwdownload program firmware of the named device with the given image\n" 9992 "security report or send ATA security commands to the named device\n" 9993 "persist send the SCSI PERSISTENT RESERVE IN or OUT commands\n" 9994 "attrib send the SCSI READ or WRITE ATTRIBUTE commands\n" 9995 "opcodes send the SCSI REPORT SUPPORTED OPCODES command\n" 9996 "zone manage Zoned Block (Shingled) devices\n" 9997 "epc send ATA Extended Power Conditions commands\n" 9998 "timestamp report or set the device's timestamp\n" 9999 "devtype report the type of device\n" 10000 "depop manage drive storage elements\n" 10001 "mmcsdcmd send the given MMC command, needs -c and -a as well\n" 10002 "help this message\n" 10003 "Device Identifiers:\n" 10004 "bus:target specify the bus and target, lun defaults to 0\n" 10005 "bus:target:lun specify the bus, target and lun\n" 10006 "deviceUNIT specify the device name, like \"da4\" or \"cd2\"\n" 10007 "Generic arguments:\n" 10008 "-v be verbose, print out sense information\n" 10009 "-t timeout command timeout in seconds, overrides default timeout\n" 10010 "-n dev_name specify device name, e.g. \"da\", \"cd\"\n" 10011 "-u unit specify unit number, e.g. \"0\", \"5\"\n" 10012 "-E have the kernel attempt to perform SCSI error recovery\n" 10013 "-C count specify the SCSI command retry count (needs -E to work)\n" 10014 "-Q task_attr specify ordered, simple or head tag type for SCSI cmds\n" 10015 "modepage arguments:\n" 10016 "-l list all available mode pages\n" 10017 "-m page specify the mode page to view or edit\n" 10018 "-e edit the specified mode page\n" 10019 "-b force view to binary mode\n" 10020 "-d disable block descriptors for mode sense\n" 10021 "-P pgctl page control field 0-3\n" 10022 "defects arguments:\n" 10023 "-f format specify defect list format (block, bfi or phys)\n" 10024 "-G get the grown defect list\n" 10025 "-P get the permanent defect list\n" 10026 "inquiry arguments:\n" 10027 "-D get the standard inquiry data\n" 10028 "-S get the serial number\n" 10029 "-R get the transfer rate, etc.\n" 10030 "reportluns arguments:\n" 10031 "-c only report a count of available LUNs\n" 10032 "-l only print out luns, and not a count\n" 10033 "-r <reporttype> specify \"default\", \"wellknown\" or \"all\"\n" 10034 "readcap arguments\n" 10035 "-b only report the blocksize\n" 10036 "-h human readable device size, base 2\n" 10037 "-H human readable device size, base 10\n" 10038 "-N print the number of blocks instead of last block\n" 10039 "-q quiet, print numbers only\n" 10040 "-s only report the last block/device size\n" 10041 "cmd arguments:\n" 10042 "-c cdb [args] specify the SCSI CDB\n" 10043 "-i len fmt specify input data and input data format\n" 10044 "-o len fmt [args] specify output data and output data fmt\n" 10045 "smpcmd arguments:\n" 10046 "-r len fmt [args] specify the SMP command to be sent\n" 10047 "-R len fmt [args] specify SMP response format\n" 10048 "smprg arguments:\n" 10049 "-l specify the long response format\n" 10050 "smppc arguments:\n" 10051 "-p phy specify the PHY to operate on\n" 10052 "-l specify the long request/response format\n" 10053 "-o operation specify the phy control operation\n" 10054 "-d name set the attached device name\n" 10055 "-m rate set the minimum physical link rate\n" 10056 "-M rate set the maximum physical link rate\n" 10057 "-T pp_timeout set the partial pathway timeout value\n" 10058 "-a enable|disable enable or disable SATA slumber\n" 10059 "-A enable|disable enable or disable SATA partial phy power\n" 10060 "-s enable|disable enable or disable SAS slumber\n" 10061 "-S enable|disable enable or disable SAS partial phy power\n" 10062 "smpphylist arguments:\n" 10063 "-l specify the long response format\n" 10064 "-q only print phys with attached devices\n" 10065 "smpmaninfo arguments:\n" 10066 "-l specify the long response format\n" 10067 "debug arguments:\n" 10068 "-I CAM_DEBUG_INFO -- scsi commands, errors, data\n" 10069 "-T CAM_DEBUG_TRACE -- routine flow tracking\n" 10070 "-S CAM_DEBUG_SUBTRACE -- internal routine command flow\n" 10071 "-c CAM_DEBUG_CDB -- print out SCSI CDBs only\n" 10072 "tags arguments:\n" 10073 "-N tags specify the number of tags to use for this device\n" 10074 "-q be quiet, don't report the number of tags\n" 10075 "-v report a number of tag-related parameters\n" 10076 "negotiate arguments:\n" 10077 "-a send a test unit ready after negotiation\n" 10078 "-c report/set current negotiation settings\n" 10079 "-D <arg> \"enable\" or \"disable\" disconnection\n" 10080 "-M mode set ATA mode\n" 10081 "-O offset set command delay offset\n" 10082 "-q be quiet, don't report anything\n" 10083 "-R syncrate synchronization rate in MHz\n" 10084 "-T <arg> \"enable\" or \"disable\" tagged queueing\n" 10085 "-U report/set user negotiation settings\n" 10086 "-W bus_width set the bus width in bits (8, 16 or 32)\n" 10087 "-v also print a Path Inquiry CCB for the controller\n" 10088 "format arguments:\n" 10089 "-q be quiet, don't print status messages\n" 10090 "-r run in report only mode\n" 10091 "-w don't send immediate format command\n" 10092 "-y don't ask any questions\n" 10093 "sanitize arguments:\n" 10094 "-a operation operation mode: overwrite, block, crypto or exitfailure\n" 10095 "-c passes overwrite passes to perform (1 to 31)\n" 10096 "-I invert overwrite pattern after each pass\n" 10097 "-P pattern path to overwrite pattern file\n" 10098 "-q be quiet, don't print status messages\n" 10099 "-r run in report only mode\n" 10100 "-U run operation in unrestricted completion exit mode\n" 10101 "-w don't send immediate sanitize command\n" 10102 "-y don't ask any questions\n" 10103 "idle/standby arguments:\n" 10104 "-t <arg> number of seconds before respective state.\n" 10105 "fwdownload arguments:\n" 10106 "-f fw_image path to firmware image file\n" 10107 "-q don't print informational messages, only errors\n" 10108 "-s run in simulation mode\n" 10109 "-v print info for every firmware segment sent to device\n" 10110 "-y don't ask any questions\n" 10111 "security arguments:\n" 10112 "-d pwd disable security using the given password for the selected\n" 10113 " user\n" 10114 "-e pwd erase the device using the given pwd for the selected user\n" 10115 "-f freeze the security configuration of the specified device\n" 10116 "-h pwd enhanced erase the device using the given pwd for the\n" 10117 " selected user\n" 10118 "-k pwd unlock the device using the given pwd for the selected\n" 10119 " user\n" 10120 "-l <high|maximum> specifies which security level to set: high or maximum\n" 10121 "-q be quiet, do not print any status messages\n" 10122 "-s pwd password the device (enable security) using the given\n" 10123 " pwd for the selected user\n" 10124 "-T timeout overrides the timeout (seconds) used for erase operation\n" 10125 "-U <user|master> specifies which user to set: user or master\n" 10126 "-y don't ask any questions\n" 10127 "hpa arguments:\n" 10128 "-f freeze the HPA configuration of the device\n" 10129 "-l lock the HPA configuration of the device\n" 10130 "-P make the HPA max sectors persist\n" 10131 "-p pwd Set the HPA configuration password required for unlock\n" 10132 " calls\n" 10133 "-q be quiet, do not print any status messages\n" 10134 "-s sectors configures the maximum user accessible sectors of the\n" 10135 " device\n" 10136 "-U pwd unlock the HPA configuration of the device\n" 10137 "-y don't ask any questions\n" 10138 "ama arguments:\n" 10139 "-f freeze the AMA configuration of the device\n" 10140 "-q be quiet, do not print any status messages\n" 10141 "-s sectors configures the maximum user accessible sectors of the\n" 10142 " device\n" 10143 "persist arguments:\n" 10144 "-i action specify read_keys, read_reservation, report_cap, or\n" 10145 " read_full_status\n" 10146 "-o action specify register, register_ignore, reserve, release,\n" 10147 " clear, preempt, preempt_abort, register_move, replace_lost\n" 10148 "-a set the All Target Ports (ALL_TG_PT) bit\n" 10149 "-I tid specify a Transport ID, e.g.: sas,0x1234567812345678\n" 10150 "-k key specify the Reservation Key\n" 10151 "-K sa_key specify the Service Action Reservation Key\n" 10152 "-p set the Activate Persist Through Power Loss bit\n" 10153 "-R rtp specify the Relative Target Port\n" 10154 "-s scope specify the scope: lun, extent, element or a number\n" 10155 "-S specify Transport ID for register, requires -I\n" 10156 "-T res_type specify the reservation type: read_shared, wr_ex, rd_ex,\n" 10157 " ex_ac, wr_ex_ro, ex_ac_ro, wr_ex_ar, ex_ac_ar\n" 10158 "-U unregister the current initiator for register_move\n" 10159 "attrib arguments:\n" 10160 "-r action specify attr_values, attr_list, lv_list, part_list, or\n" 10161 " supp_attr\n" 10162 "-w attr specify an attribute to write, one -w argument per attr\n" 10163 "-a attr_num only display this attribute number\n" 10164 "-c get cached attributes\n" 10165 "-e elem_addr request attributes for the given element in a changer\n" 10166 "-F form1,form2 output format, comma separated list: text_esc, text_raw,\n" 10167 " nonascii_esc, nonascii_trim, nonascii_raw, field_all,\n" 10168 " field_none, field_desc, field_num, field_size, field_rw\n" 10169 "-p partition request attributes for the given partition\n" 10170 "-s start_attr request attributes starting at the given number\n" 10171 "-T elem_type specify the element type (used with -e)\n" 10172 "-V logical_vol specify the logical volume ID\n" 10173 "opcodes arguments:\n" 10174 "-o opcode specify the individual opcode to list\n" 10175 "-s service_action specify the service action for the opcode\n" 10176 "-N do not return SCSI error for unsupported SA\n" 10177 "-T request nominal and recommended timeout values\n" 10178 "zone arguments:\n" 10179 "-c cmd required: rz, open, close, finish, or rwp\n" 10180 "-a apply the action to all zones\n" 10181 "-l LBA specify the zone starting LBA\n" 10182 "-o rep_opts report zones options: all, empty, imp_open, exp_open,\n" 10183 " closed, full, ro, offline, reset, nonseq, nonwp\n" 10184 "-P print_opt report zones printing: normal, summary, script\n" 10185 "epc arguments:\n" 10186 "-c cmd required: restore, goto, timer, state, enable, disable,\n" 10187 " source, status, list\n" 10188 "-d disable power mode (timer, state)\n" 10189 "-D delayed entry (goto)\n" 10190 "-e enable power mode (timer, state)\n" 10191 "-H hold power mode (goto)\n" 10192 "-p power_cond Idle_a, Idle_b, Idle_c, Standby_y, Standby_z (timer,\n" 10193 " state, goto)\n" 10194 "-P only display power mode (status)\n" 10195 "-r rst_src restore settings from: default, saved (restore)\n" 10196 "-s save mode (timer, state, restore)\n" 10197 "-S power_src set power source: battery, nonbattery (source)\n" 10198 "-T timer set timer, seconds, .1 sec resolution (timer)\n" 10199 "timestamp arguments:\n" 10200 "-r report the timestamp of the device\n" 10201 "-f format report the timestamp of the device with the given\n" 10202 " strftime(3) format string\n" 10203 "-m report the timestamp of the device as milliseconds since\n" 10204 " January 1st, 1970\n" 10205 "-U report the time with UTC instead of the local time zone\n" 10206 "-s set the timestamp of the device\n" 10207 "-f format the format of the time string passed into strptime(3)\n" 10208 "-T time the time value passed into strptime(3)\n" 10209 "-U set the timestamp of the device to UTC time\n" 10210 "depop arguments:\n" 10211 "-d remove an element from service\n" 10212 "-l list status of all elements of drive\n" 10213 "-r restore all elements to service\n" 10214 "-e elm element to remove\n" 10215 "-c capacity requested new capacity\n" 10216 "mmcsdcmd arguments:\n" 10217 "-c mmc_cmd MMC command to send to the card\n" 10218 "-a mmc_arg Argument for the MMC command\n" 10219 "-f mmc_flag Flags to set for the MMC command\n" 10220 "-l data_len Expect data_len bytes of data in reply and display them\n" 10221 "-W Fill the data buffer before invoking the MMC command\n" 10222 "-b data_byte One byte of data to fill the data buffer with\n" 10223 "-F frequency Operating frequency to set on the controller\n" 10224 "-4 Set bus width to 4 bit\n" 10225 "-1 Set bus width to 8 bit\n" 10226 "-S high | std Set high-speed or standard timing\n" 10227 "-I Display various card and host controller information\n" 10228 ); 10229 } 10230 10231 int 10232 main(int argc, char **argv) 10233 { 10234 int c; 10235 char *device = NULL; 10236 int unit = 0; 10237 struct cam_device *cam_dev = NULL; 10238 int timeout = 0, retry_count = 1; 10239 camcontrol_optret optreturn; 10240 char *tstr; 10241 const char *mainopt = "C:En:Q:t:u:v"; 10242 const char *subopt = NULL; 10243 char combinedopt[256]; 10244 int error = 0, optstart = 2; 10245 int task_attr = MSG_SIMPLE_Q_TAG; 10246 int devopen = 1; 10247 cam_cmd cmdlist; 10248 path_id_t bus; 10249 target_id_t target; 10250 lun_id_t lun; 10251 10252 cmdlist = CAM_CMD_NONE; 10253 arglist = CAM_ARG_NONE; 10254 10255 if (argc < 2) { 10256 usage(0); 10257 exit(1); 10258 } 10259 10260 /* 10261 * Get the base option. 10262 */ 10263 optreturn = getoption(option_table,argv[1], &cmdlist, &arglist,&subopt); 10264 10265 if (optreturn == CC_OR_AMBIGUOUS) { 10266 warnx("ambiguous option %s", argv[1]); 10267 usage(0); 10268 exit(1); 10269 } else if (optreturn == CC_OR_NOT_FOUND) { 10270 warnx("option %s not found", argv[1]); 10271 usage(0); 10272 exit(1); 10273 } 10274 10275 /* 10276 * Ahh, getopt(3) is a pain. 10277 * 10278 * This is a gross hack. There really aren't many other good 10279 * options (excuse the pun) for parsing options in a situation like 10280 * this. getopt is kinda braindead, so you end up having to run 10281 * through the options twice, and give each invocation of getopt 10282 * the option string for the other invocation. 10283 * 10284 * You would think that you could just have two groups of options. 10285 * The first group would get parsed by the first invocation of 10286 * getopt, and the second group would get parsed by the second 10287 * invocation of getopt. It doesn't quite work out that way. When 10288 * the first invocation of getopt finishes, it leaves optind pointing 10289 * to the argument _after_ the first argument in the second group. 10290 * So when the second invocation of getopt comes around, it doesn't 10291 * recognize the first argument it gets and then bails out. 10292 * 10293 * A nice alternative would be to have a flag for getopt that says 10294 * "just keep parsing arguments even when you encounter an unknown 10295 * argument", but there isn't one. So there's no real clean way to 10296 * easily parse two sets of arguments without having one invocation 10297 * of getopt know about the other. 10298 * 10299 * Without this hack, the first invocation of getopt would work as 10300 * long as the generic arguments are first, but the second invocation 10301 * (in the subfunction) would fail in one of two ways. In the case 10302 * where you don't set optreset, it would fail because optind may be 10303 * pointing to the argument after the one it should be pointing at. 10304 * In the case where you do set optreset, and reset optind, it would 10305 * fail because getopt would run into the first set of options, which 10306 * it doesn't understand. 10307 * 10308 * All of this would "sort of" work if you could somehow figure out 10309 * whether optind had been incremented one option too far. The 10310 * mechanics of that, however, are more daunting than just giving 10311 * both invocations all of the expect options for either invocation. 10312 * 10313 * Needless to say, I wouldn't mind if someone invented a better 10314 * (non-GPL!) command line parsing interface than getopt. I 10315 * wouldn't mind if someone added more knobs to getopt to make it 10316 * work better. Who knows, I may talk myself into doing it someday, 10317 * if the standards weenies let me. As it is, it just leads to 10318 * hackery like this and causes people to avoid it in some cases. 10319 * 10320 * KDM, September 8th, 1998 10321 */ 10322 if (subopt != NULL) 10323 sprintf(combinedopt, "%s%s", mainopt, subopt); 10324 else 10325 sprintf(combinedopt, "%s", mainopt); 10326 10327 /* 10328 * For these options we do not parse optional device arguments and 10329 * we do not open a passthrough device. 10330 */ 10331 if ((cmdlist == CAM_CMD_RESCAN) 10332 || (cmdlist == CAM_CMD_RESET) 10333 || (cmdlist == CAM_CMD_DEVTREE) 10334 || (cmdlist == CAM_CMD_USAGE) 10335 || (cmdlist == CAM_CMD_DEBUG)) 10336 devopen = 0; 10337 10338 if ((devopen == 1) 10339 && (argc > 2 && argv[2][0] != '-')) { 10340 char name[30]; 10341 int rv; 10342 10343 if (isdigit(argv[2][0])) { 10344 /* device specified as bus:target[:lun] */ 10345 rv = parse_btl(argv[2], &bus, &target, &lun, &arglist); 10346 if (rv < 2) 10347 errx(1, "numeric device specification must " 10348 "be either bus:target, or " 10349 "bus:target:lun"); 10350 /* default to 0 if lun was not specified */ 10351 if ((arglist & CAM_ARG_LUN) == 0) { 10352 lun = 0; 10353 arglist |= CAM_ARG_LUN; 10354 } 10355 optstart++; 10356 } else { 10357 if (cam_get_device(argv[2], name, sizeof name, &unit) 10358 == -1) 10359 errx(1, "%s", cam_errbuf); 10360 device = strdup(name); 10361 arglist |= CAM_ARG_DEVICE | CAM_ARG_UNIT; 10362 optstart++; 10363 } 10364 } 10365 /* 10366 * Start getopt processing at argv[2/3], since we've already 10367 * accepted argv[1..2] as the command name, and as a possible 10368 * device name. 10369 */ 10370 optind = optstart; 10371 10372 /* 10373 * Now we run through the argument list looking for generic 10374 * options, and ignoring options that possibly belong to 10375 * subfunctions. 10376 */ 10377 while ((c = getopt(argc, argv, combinedopt))!= -1){ 10378 switch(c) { 10379 case 'C': 10380 retry_count = strtol(optarg, NULL, 0); 10381 if (retry_count < 0) 10382 errx(1, "retry count %d is < 0", 10383 retry_count); 10384 arglist |= CAM_ARG_RETRIES; 10385 break; 10386 case 'E': 10387 arglist |= CAM_ARG_ERR_RECOVER; 10388 break; 10389 case 'n': 10390 arglist |= CAM_ARG_DEVICE; 10391 tstr = optarg; 10392 while (isspace(*tstr) && (*tstr != '\0')) 10393 tstr++; 10394 device = (char *)strdup(tstr); 10395 break; 10396 case 'Q': { 10397 char *endptr; 10398 int table_entry = 0; 10399 10400 tstr = optarg; 10401 while (isspace(*tstr) && (*tstr != '\0')) 10402 tstr++; 10403 if (isdigit(*tstr)) { 10404 task_attr = strtol(tstr, &endptr, 0); 10405 if (*endptr != '\0') { 10406 errx(1, "Invalid queue option " 10407 "%s", tstr); 10408 } 10409 } else { 10410 size_t table_size; 10411 scsi_nv_status status; 10412 10413 table_size = sizeof(task_attrs) / 10414 sizeof(task_attrs[0]); 10415 status = scsi_get_nv(task_attrs, 10416 table_size, tstr, &table_entry, 10417 SCSI_NV_FLAG_IG_CASE); 10418 if (status == SCSI_NV_FOUND) 10419 task_attr = task_attrs[ 10420 table_entry].value; 10421 else { 10422 errx(1, "%s option %s", 10423 (status == SCSI_NV_AMBIGUOUS)? 10424 "ambiguous" : "invalid", 10425 tstr); 10426 } 10427 } 10428 break; 10429 } 10430 case 't': 10431 timeout = strtol(optarg, NULL, 0); 10432 if (timeout < 0) 10433 errx(1, "invalid timeout %d", timeout); 10434 /* Convert the timeout from seconds to ms */ 10435 timeout *= 1000; 10436 arglist |= CAM_ARG_TIMEOUT; 10437 break; 10438 case 'u': 10439 arglist |= CAM_ARG_UNIT; 10440 unit = strtol(optarg, NULL, 0); 10441 break; 10442 case 'v': 10443 arglist |= CAM_ARG_VERBOSE; 10444 break; 10445 default: 10446 break; 10447 } 10448 } 10449 10450 /* 10451 * For most commands we'll want to open the passthrough device 10452 * associated with the specified device. In the case of the rescan 10453 * commands, we don't use a passthrough device at all, just the 10454 * transport layer device. 10455 */ 10456 if (devopen == 1) { 10457 if (((arglist & (CAM_ARG_BUS|CAM_ARG_TARGET)) == 0) 10458 && (((arglist & CAM_ARG_DEVICE) == 0) 10459 || ((arglist & CAM_ARG_UNIT) == 0))) { 10460 errx(1, "subcommand \"%s\" requires a valid device " 10461 "identifier", argv[1]); 10462 } 10463 10464 if ((cam_dev = ((arglist & (CAM_ARG_BUS | CAM_ARG_TARGET))? 10465 cam_open_btl(bus, target, lun, O_RDWR, NULL) : 10466 cam_open_spec_device(device,unit,O_RDWR,NULL))) 10467 == NULL) 10468 errx(1,"%s", cam_errbuf); 10469 } 10470 10471 /* 10472 * Reset optind to 2, and reset getopt, so these routines can parse 10473 * the arguments again. 10474 */ 10475 optind = optstart; 10476 optreset = 1; 10477 10478 switch(cmdlist) { 10479 case CAM_CMD_DEVLIST: 10480 error = getdevlist(cam_dev); 10481 break; 10482 case CAM_CMD_HPA: 10483 error = atahpa(cam_dev, retry_count, timeout, 10484 argc, argv, combinedopt); 10485 break; 10486 case CAM_CMD_AMA: 10487 error = ataama(cam_dev, retry_count, timeout, 10488 argc, argv, combinedopt); 10489 break; 10490 case CAM_CMD_DEVTREE: 10491 error = getdevtree(argc, argv, combinedopt); 10492 break; 10493 case CAM_CMD_DEVTYPE: 10494 error = getdevtype(cam_dev); 10495 break; 10496 case CAM_CMD_TUR: 10497 error = testunitready(cam_dev, task_attr, retry_count, 10498 timeout, 0); 10499 break; 10500 case CAM_CMD_INQUIRY: 10501 error = scsidoinquiry(cam_dev, argc, argv, combinedopt, 10502 task_attr, retry_count, timeout); 10503 break; 10504 case CAM_CMD_IDENTIFY: 10505 error = identify(cam_dev, retry_count, timeout); 10506 break; 10507 case CAM_CMD_STARTSTOP: 10508 error = scsistart(cam_dev, arglist & CAM_ARG_START_UNIT, 10509 arglist & CAM_ARG_EJECT, task_attr, 10510 retry_count, timeout); 10511 break; 10512 case CAM_CMD_RESCAN: 10513 error = dorescan_or_reset(argc, argv, 1); 10514 break; 10515 case CAM_CMD_RESET: 10516 error = dorescan_or_reset(argc, argv, 0); 10517 break; 10518 case CAM_CMD_READ_DEFECTS: 10519 error = readdefects(cam_dev, argc, argv, combinedopt, 10520 task_attr, retry_count, timeout); 10521 break; 10522 case CAM_CMD_MODE_PAGE: 10523 modepage(cam_dev, argc, argv, combinedopt, 10524 task_attr, retry_count, timeout); 10525 break; 10526 case CAM_CMD_SCSI_CMD: 10527 error = scsicmd(cam_dev, argc, argv, combinedopt, 10528 task_attr, retry_count, timeout); 10529 break; 10530 case CAM_CMD_MMCSD_CMD: 10531 error = mmcsdcmd(cam_dev, argc, argv, combinedopt, 10532 retry_count, timeout); 10533 break; 10534 case CAM_CMD_SMP_CMD: 10535 error = smpcmd(cam_dev, argc, argv, combinedopt, 10536 retry_count, timeout); 10537 break; 10538 case CAM_CMD_SMP_RG: 10539 error = smpreportgeneral(cam_dev, argc, argv, 10540 combinedopt, retry_count, 10541 timeout); 10542 break; 10543 case CAM_CMD_SMP_PC: 10544 error = smpphycontrol(cam_dev, argc, argv, combinedopt, 10545 retry_count, timeout); 10546 break; 10547 case CAM_CMD_SMP_PHYLIST: 10548 error = smpphylist(cam_dev, argc, argv, combinedopt, 10549 retry_count, timeout); 10550 break; 10551 case CAM_CMD_SMP_MANINFO: 10552 error = smpmaninfo(cam_dev, argc, argv, combinedopt, 10553 retry_count, timeout); 10554 break; 10555 case CAM_CMD_DEBUG: 10556 error = camdebug(argc, argv, combinedopt); 10557 break; 10558 case CAM_CMD_TAG: 10559 error = tagcontrol(cam_dev, argc, argv, combinedopt); 10560 break; 10561 case CAM_CMD_RATE: 10562 error = ratecontrol(cam_dev, task_attr, retry_count, 10563 timeout, argc, argv, combinedopt); 10564 break; 10565 case CAM_CMD_FORMAT: 10566 error = scsiformat(cam_dev, argc, argv, 10567 combinedopt, task_attr, retry_count, 10568 timeout); 10569 break; 10570 case CAM_CMD_REPORTLUNS: 10571 error = scsireportluns(cam_dev, argc, argv, 10572 combinedopt, task_attr, 10573 retry_count, timeout); 10574 break; 10575 case CAM_CMD_READCAP: 10576 error = scsireadcapacity(cam_dev, argc, argv, 10577 combinedopt, task_attr, 10578 retry_count, timeout); 10579 break; 10580 case CAM_CMD_IDLE: 10581 case CAM_CMD_STANDBY: 10582 case CAM_CMD_SLEEP: 10583 case CAM_CMD_POWER_MODE: 10584 error = atapm(cam_dev, argc, argv, 10585 combinedopt, retry_count, timeout); 10586 break; 10587 case CAM_CMD_APM: 10588 case CAM_CMD_AAM: 10589 error = ataaxm(cam_dev, argc, argv, 10590 combinedopt, retry_count, timeout); 10591 break; 10592 case CAM_CMD_SECURITY: 10593 error = atasecurity(cam_dev, retry_count, timeout, 10594 argc, argv, combinedopt); 10595 break; 10596 case CAM_CMD_DOWNLOAD_FW: 10597 error = fwdownload(cam_dev, argc, argv, combinedopt, 10598 arglist & CAM_ARG_VERBOSE, task_attr, retry_count, 10599 timeout); 10600 break; 10601 case CAM_CMD_SANITIZE: 10602 error = sanitize(cam_dev, argc, argv, combinedopt, task_attr, 10603 retry_count, timeout); 10604 break; 10605 case CAM_CMD_PERSIST: 10606 error = scsipersist(cam_dev, argc, argv, combinedopt, 10607 task_attr, retry_count, timeout, 10608 arglist & CAM_ARG_VERBOSE, 10609 arglist & CAM_ARG_ERR_RECOVER); 10610 break; 10611 case CAM_CMD_ATTRIB: 10612 error = scsiattrib(cam_dev, argc, argv, combinedopt, 10613 task_attr, retry_count, timeout, 10614 arglist & CAM_ARG_VERBOSE, 10615 arglist & CAM_ARG_ERR_RECOVER); 10616 break; 10617 case CAM_CMD_OPCODES: 10618 error = scsiopcodes(cam_dev, argc, argv, combinedopt, 10619 task_attr, retry_count, timeout, 10620 arglist & CAM_ARG_VERBOSE); 10621 break; 10622 case CAM_CMD_REPROBE: 10623 error = reprobe(cam_dev); 10624 break; 10625 case CAM_CMD_ZONE: 10626 error = zone(cam_dev, argc, argv, combinedopt, 10627 task_attr, retry_count, timeout, 10628 arglist & CAM_ARG_VERBOSE); 10629 break; 10630 case CAM_CMD_EPC: 10631 error = epc(cam_dev, argc, argv, combinedopt, 10632 retry_count, timeout, arglist & CAM_ARG_VERBOSE); 10633 break; 10634 case CAM_CMD_TIMESTAMP: 10635 error = timestamp(cam_dev, argc, argv, combinedopt, 10636 task_attr, retry_count, timeout, 10637 arglist & CAM_ARG_VERBOSE); 10638 break; 10639 case CAM_CMD_DEPOP: 10640 error = depop(cam_dev, argc, argv, combinedopt, 10641 task_attr, retry_count, timeout, 10642 arglist & CAM_ARG_VERBOSE); 10643 break; 10644 case CAM_CMD_USAGE: 10645 usage(1); 10646 break; 10647 default: 10648 usage(0); 10649 error = 1; 10650 break; 10651 } 10652 10653 if (cam_dev != NULL) 10654 cam_close_device(cam_dev); 10655 10656 exit(error); 10657 } 10658