2005-01-05 22:34:37 +00:00
|
|
|
/*-
|
1998-09-15 06:36:34 +00:00
|
|
|
* Largely written by Julian Elischer (julian@tfs.com)
|
|
|
|
* for TRW Financial Systems.
|
|
|
|
*
|
|
|
|
* TRW Financial Systems, in accordance with their agreement with Carnegie
|
|
|
|
* Mellon University, makes this software available to CMU to distribute
|
|
|
|
* or use in any manner that they see fit as long as this message is kept with
|
|
|
|
* the software. For this reason TFS also grants any other persons or
|
|
|
|
* organisations permission to use or modify this software.
|
|
|
|
*
|
|
|
|
* TFS supplies this software to be publicly redistributed
|
|
|
|
* on the understanding that TFS is not responsible for the correct
|
|
|
|
* functioning of this software in any circumstances.
|
|
|
|
*
|
|
|
|
* Ported to run under 386BSD by Julian Elischer (julian@tfs.com) Sept 1992
|
|
|
|
*
|
1999-08-28 01:08:13 +00:00
|
|
|
* $FreeBSD$
|
1998-09-15 06:36:34 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* SCSI general interface description
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SCSI_SCSI_ALL_H
|
|
|
|
#define _SCSI_SCSI_ALL_H 1
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
|
1999-12-29 04:46:21 +00:00
|
|
|
#ifdef _KERNEL
|
1999-05-22 22:00:24 +00:00
|
|
|
/*
|
|
|
|
* This is the number of seconds we wait for devices to settle after a SCSI
|
|
|
|
* bus reset.
|
|
|
|
*/
|
2002-09-02 20:10:19 +00:00
|
|
|
extern int scsi_delay;
|
1999-12-29 04:46:21 +00:00
|
|
|
#endif /* _KERNEL */
|
1999-05-22 22:00:24 +00:00
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
/*
|
|
|
|
* SCSI command format
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Define dome bits that are in ALL (or a lot of) scsi commands
|
|
|
|
*/
|
|
|
|
#define SCSI_CTL_LINK 0x01
|
|
|
|
#define SCSI_CTL_FLAG 0x02
|
|
|
|
#define SCSI_CTL_VENDOR 0xC0
|
|
|
|
#define SCSI_CMD_LUN 0xA0 /* these two should not be needed */
|
|
|
|
#define SCSI_CMD_LUN_SHIFT 5 /* LUN in the cmd is no longer SCSI */
|
|
|
|
|
|
|
|
#define SCSI_MAX_CDBLEN 16 /*
|
|
|
|
* 16 byte commands are in the
|
|
|
|
* SCSI-3 spec
|
|
|
|
*/
|
|
|
|
#if defined(CAM_MAX_CDBLEN) && (CAM_MAX_CDBLEN < SCSI_MAX_CDBLEN)
|
|
|
|
#error "CAM_MAX_CDBLEN cannot be less than SCSI_MAX_CDBLEN"
|
|
|
|
#endif
|
|
|
|
|
2000-07-14 19:40:54 +00:00
|
|
|
/* 6byte CDBs special case 0 length to be 256 */
|
|
|
|
#define SCSI_CDB6_LEN(len) ((len) == 0 ? 256 : len)
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
/*
|
|
|
|
* This type defines actions to be taken when a particular sense code is
|
|
|
|
* received. Right now, these flags are only defined to take up 16 bits,
|
|
|
|
* but can be expanded in the future if necessary.
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
SS_NOP = 0x000000, /* Do nothing */
|
|
|
|
SS_RETRY = 0x010000, /* Retry the command */
|
|
|
|
SS_FAIL = 0x020000, /* Bail out */
|
|
|
|
SS_START = 0x030000, /* Send a Start Unit command to the device,
|
|
|
|
* then retry the original command.
|
|
|
|
*/
|
|
|
|
SS_TUR = 0x040000, /* Send a Test Unit Ready command to the
|
|
|
|
* device, then retry the original command.
|
|
|
|
*/
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
SS_REQSENSE = 0x050000, /* Send a RequestSense command to the
|
|
|
|
* device, then retry the original command.
|
1998-09-15 06:36:34 +00:00
|
|
|
*/
|
|
|
|
SS_MASK = 0xff0000
|
|
|
|
} scsi_sense_action;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
SSQ_NONE = 0x0000,
|
|
|
|
SSQ_DECREMENT_COUNT = 0x0100, /* Decrement the retry count */
|
|
|
|
SSQ_MANY = 0x0200, /* send lots of recovery commands */
|
|
|
|
SSQ_RANGE = 0x0400, /*
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
* This table entry represents the
|
|
|
|
* end of a range of ASCQs that
|
|
|
|
* have identical error actions
|
|
|
|
* and text.
|
1998-09-15 06:36:34 +00:00
|
|
|
*/
|
|
|
|
SSQ_PRINT_SENSE = 0x0800,
|
|
|
|
SSQ_MASK = 0xff00
|
|
|
|
} scsi_sense_action_qualifier;
|
|
|
|
|
|
|
|
/* Mask for error status values */
|
|
|
|
#define SS_ERRMASK 0xff
|
|
|
|
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
/* The default, retyable, error action */
|
|
|
|
#define SS_RDEF SS_RETRY|SSQ_DECREMENT_COUNT|SSQ_PRINT_SENSE|EIO
|
1998-09-15 06:36:34 +00:00
|
|
|
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
/* The retyable, error action, with table specified error code */
|
|
|
|
#define SS_RET SS_RETRY|SSQ_DECREMENT_COUNT|SSQ_PRINT_SENSE
|
1998-09-15 06:36:34 +00:00
|
|
|
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
/* Fatal error action, with table specified error code */
|
|
|
|
#define SS_FATAL SS_FAIL|SSQ_PRINT_SENSE
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
struct scsi_generic
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t bytes[11];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_request_sense
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_test_unit_ready
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused[3];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_send_diag
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define SSD_UOL 0x01
|
|
|
|
#define SSD_DOL 0x02
|
|
|
|
#define SSD_SELFTEST 0x04
|
|
|
|
#define SSD_PF 0x10
|
|
|
|
u_int8_t unused[1];
|
|
|
|
u_int8_t paramlen[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_sense
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_inquiry
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define SI_EVPD 0x01
|
|
|
|
u_int8_t page_code;
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_sense_6
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define SMS_DBD 0x08
|
|
|
|
u_int8_t page;
|
|
|
|
#define SMS_PAGE_CODE 0x3F
|
|
|
|
#define SMS_VENDOR_SPECIFIC_PAGE 0x00
|
|
|
|
#define SMS_DISCONNECT_RECONNECT_PAGE 0x02
|
2010-04-01 01:49:43 +00:00
|
|
|
#define SMS_FORMAT_DEVICE_PAGE 0x03
|
|
|
|
#define SMS_GEOMETRY_PAGE 0x04
|
2007-10-12 22:11:22 +00:00
|
|
|
#define SMS_CACHE_PAGE 0x08
|
1998-09-15 06:36:34 +00:00
|
|
|
#define SMS_PERIPHERAL_DEVICE_PAGE 0x09
|
|
|
|
#define SMS_CONTROL_MODE_PAGE 0x0A
|
2007-10-12 22:11:22 +00:00
|
|
|
#define SMS_PROTO_SPECIFIC_PAGE 0x19
|
|
|
|
#define SMS_INFO_EXCEPTIONS_PAGE 0x1C
|
1998-09-15 06:36:34 +00:00
|
|
|
#define SMS_ALL_PAGES_PAGE 0x3F
|
|
|
|
#define SMS_PAGE_CTRL_MASK 0xC0
|
|
|
|
#define SMS_PAGE_CTRL_CURRENT 0x00
|
|
|
|
#define SMS_PAGE_CTRL_CHANGEABLE 0x40
|
|
|
|
#define SMS_PAGE_CTRL_DEFAULT 0x80
|
|
|
|
#define SMS_PAGE_CTRL_SAVED 0xC0
|
|
|
|
u_int8_t unused;
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_sense_10
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2; /* same bits as small version */
|
|
|
|
u_int8_t page; /* same bits as small version */
|
|
|
|
u_int8_t unused[4];
|
|
|
|
u_int8_t length[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_select_6
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define SMS_SP 0x01
|
|
|
|
#define SMS_PF 0x10
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_select_10
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2; /* same bits as small version */
|
|
|
|
u_int8_t unused[5];
|
|
|
|
u_int8_t length[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* When sending a mode select to a tape drive, the medium type must be 0.
|
|
|
|
*/
|
|
|
|
struct scsi_mode_hdr_6
|
|
|
|
{
|
|
|
|
u_int8_t datalen;
|
|
|
|
u_int8_t medium_type;
|
|
|
|
u_int8_t dev_specific;
|
|
|
|
u_int8_t block_descr_len;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_hdr_10
|
|
|
|
{
|
|
|
|
u_int8_t datalen[2];
|
|
|
|
u_int8_t medium_type;
|
|
|
|
u_int8_t dev_specific;
|
|
|
|
u_int8_t reserved[2];
|
|
|
|
u_int8_t block_descr_len[2];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_block_descr
|
|
|
|
{
|
|
|
|
u_int8_t density_code;
|
|
|
|
u_int8_t num_blocks[3];
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t block_len[3];
|
|
|
|
};
|
|
|
|
|
2001-08-27 01:29:30 +00:00
|
|
|
struct scsi_log_sense
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define SLS_SP 0x01
|
|
|
|
#define SLS_PPC 0x02
|
|
|
|
u_int8_t page;
|
|
|
|
#define SLS_PAGE_CODE 0x3F
|
|
|
|
#define SLS_ALL_PAGES_PAGE 0x00
|
|
|
|
#define SLS_OVERRUN_PAGE 0x01
|
|
|
|
#define SLS_ERROR_WRITE_PAGE 0x02
|
|
|
|
#define SLS_ERROR_READ_PAGE 0x03
|
|
|
|
#define SLS_ERROR_READREVERSE_PAGE 0x04
|
|
|
|
#define SLS_ERROR_VERIFY_PAGE 0x05
|
|
|
|
#define SLS_ERROR_NONMEDIUM_PAGE 0x06
|
|
|
|
#define SLS_ERROR_LASTN_PAGE 0x07
|
2007-10-12 22:11:22 +00:00
|
|
|
#define SLS_SELF_TEST_PAGE 0x10
|
|
|
|
#define SLS_IE_PAGE 0x2f
|
2001-08-27 01:29:30 +00:00
|
|
|
#define SLS_PAGE_CTRL_MASK 0xC0
|
|
|
|
#define SLS_PAGE_CTRL_THRESHOLD 0x00
|
|
|
|
#define SLS_PAGE_CTRL_CUMULATIVE 0x40
|
|
|
|
#define SLS_PAGE_CTRL_THRESH_DEFAULT 0x80
|
|
|
|
#define SLS_PAGE_CTRL_CUMUL_DEFAULT 0xC0
|
|
|
|
u_int8_t reserved[2];
|
|
|
|
u_int8_t paramptr[2];
|
|
|
|
u_int8_t length[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_log_select
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
/* SLS_SP 0x01 */
|
|
|
|
#define SLS_PCR 0x02
|
|
|
|
u_int8_t page;
|
|
|
|
/* SLS_PAGE_CTRL_MASK 0xC0 */
|
|
|
|
/* SLS_PAGE_CTRL_THRESHOLD 0x00 */
|
|
|
|
/* SLS_PAGE_CTRL_CUMULATIVE 0x40 */
|
|
|
|
/* SLS_PAGE_CTRL_THRESH_DEFAULT 0x80 */
|
|
|
|
/* SLS_PAGE_CTRL_CUMUL_DEFAULT 0xC0 */
|
|
|
|
u_int8_t reserved[4];
|
|
|
|
u_int8_t length[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_log_header
|
|
|
|
{
|
|
|
|
u_int8_t page;
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t datalen[2];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_log_param_header {
|
|
|
|
u_int8_t param_code[2];
|
|
|
|
u_int8_t param_control;
|
|
|
|
#define SLP_LP 0x01
|
|
|
|
#define SLP_LBIN 0x02
|
|
|
|
#define SLP_TMC_MASK 0x0C
|
|
|
|
#define SLP_TMC_ALWAYS 0x00
|
|
|
|
#define SLP_TMC_EQUAL 0x04
|
|
|
|
#define SLP_TMC_NOTEQUAL 0x08
|
|
|
|
#define SLP_TMC_GREATER 0x0C
|
|
|
|
#define SLP_ETC 0x10
|
|
|
|
#define SLP_TSD 0x20
|
|
|
|
#define SLP_DS 0x40
|
|
|
|
#define SLP_DU 0x80
|
|
|
|
u_int8_t param_len;
|
|
|
|
};
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct scsi_control_page {
|
|
|
|
u_int8_t page_code;
|
|
|
|
u_int8_t page_length;
|
|
|
|
u_int8_t rlec;
|
|
|
|
#define SCB_RLEC 0x01 /*Report Log Exception Cond*/
|
|
|
|
u_int8_t queue_flags;
|
|
|
|
#define SCP_QUEUE_ALG_MASK 0xF0
|
|
|
|
#define SCP_QUEUE_ALG_RESTRICTED 0x00
|
|
|
|
#define SCP_QUEUE_ALG_UNRESTRICTED 0x10
|
|
|
|
#define SCP_QUEUE_ERR 0x02 /*Queued I/O aborted for CACs*/
|
|
|
|
#define SCP_QUEUE_DQUE 0x01 /*Queued I/O disabled*/
|
|
|
|
u_int8_t eca_and_aen;
|
|
|
|
#define SCP_EECA 0x80 /*Enable Extended CA*/
|
|
|
|
#define SCP_RAENP 0x04 /*Ready AEN Permission*/
|
|
|
|
#define SCP_UAAENP 0x02 /*UA AEN Permission*/
|
|
|
|
#define SCP_EAENP 0x01 /*Error AEN Permission*/
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t aen_holdoff_period[2];
|
|
|
|
};
|
|
|
|
|
2007-10-12 22:11:22 +00:00
|
|
|
struct scsi_cache_page {
|
|
|
|
u_int8_t page_code;
|
|
|
|
#define SCHP_PAGE_SAVABLE 0x80 /* Page is savable */
|
|
|
|
u_int8_t page_length;
|
|
|
|
u_int8_t cache_flags;
|
|
|
|
#define SCHP_FLAGS_WCE 0x04 /* Write Cache Enable */
|
|
|
|
#define SCHP_FLAGS_MF 0x02 /* Multiplication factor */
|
|
|
|
#define SCHP_FLAGS_RCD 0x01 /* Read Cache Disable */
|
|
|
|
u_int8_t rw_cache_policy;
|
|
|
|
u_int8_t dis_prefetch[2];
|
|
|
|
u_int8_t min_prefetch[2];
|
|
|
|
u_int8_t max_prefetch[2];
|
|
|
|
u_int8_t max_prefetch_ceil[2];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_info_exceptions_page {
|
|
|
|
u_int8_t page_code;
|
|
|
|
#define SIEP_PAGE_SAVABLE 0x80 /* Page is savable */
|
|
|
|
u_int8_t page_length;
|
|
|
|
u_int8_t info_flags;
|
|
|
|
#define SIEP_FLAGS_PERF 0x80
|
|
|
|
#define SIEP_FLAGS_EBF 0x20
|
|
|
|
#define SIEP_FLAGS_EWASC 0x10
|
|
|
|
#define SIEP_FLAGS_DEXCPT 0x08
|
|
|
|
#define SIEP_FLAGS_TEST 0x04
|
|
|
|
#define SIEP_FLAGS_EBACKERR 0x02
|
|
|
|
#define SIEP_FLAGS_LOGERR 0x01
|
|
|
|
u_int8_t mrie;
|
|
|
|
u_int8_t interval_timer[4];
|
|
|
|
u_int8_t report_count[4];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_proto_specific_page {
|
|
|
|
u_int8_t page_code;
|
|
|
|
#define SPSP_PAGE_SAVABLE 0x80 /* Page is savable */
|
|
|
|
u_int8_t page_length;
|
|
|
|
u_int8_t protocol;
|
|
|
|
#define SPSP_PROTO_FC 0x00
|
|
|
|
#define SPSP_PROTO_SPI 0x01
|
|
|
|
#define SPSP_PROTO_SSA 0x02
|
|
|
|
#define SPSP_PROTO_1394 0x03
|
|
|
|
#define SPSP_PROTO_RDMA 0x04
|
|
|
|
#define SPSP_PROTO_ISCSI 0x05
|
|
|
|
#define SPSP_PROTO_SAS 0x06
|
|
|
|
#define SPSP_PROTO_ADT 0x07
|
|
|
|
#define SPSP_PROTO_ATA 0x08
|
|
|
|
#define SPSP_PROTO_NONE 0x0f
|
|
|
|
};
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct scsi_reserve
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_release
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_prevent
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t how;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
#define PR_PREVENT 0x01
|
|
|
|
#define PR_ALLOW 0x00
|
|
|
|
|
|
|
|
struct scsi_sync_cache
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t begin_lba[4];
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t lb_count[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct scsi_changedef
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t unused1;
|
|
|
|
u_int8_t how;
|
|
|
|
u_int8_t unused[4];
|
|
|
|
u_int8_t datalen;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_read_buffer
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define RWB_MODE 0x07
|
|
|
|
#define RWB_MODE_HDR_DATA 0x00
|
|
|
|
#define RWB_MODE_DATA 0x02
|
|
|
|
#define RWB_MODE_DOWNLOAD 0x04
|
|
|
|
#define RWB_MODE_DOWNLOAD_SAVE 0x05
|
|
|
|
u_int8_t buffer_id;
|
|
|
|
u_int8_t offset[3];
|
|
|
|
u_int8_t length[3];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_write_buffer
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t buffer_id;
|
|
|
|
u_int8_t offset[3];
|
|
|
|
u_int8_t length[3];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
1998-09-18 22:33:59 +00:00
|
|
|
struct scsi_rw_6
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t addr[3];
|
|
|
|
/* only 5 bits are valid in the MSB address byte */
|
|
|
|
#define SRW_TOPADDR 0x1F
|
|
|
|
u_int8_t length;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_rw_10
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
#define SRW10_RELADDR 0x01
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
/* EBP defined for WRITE(10) only */
|
|
|
|
#define SRW10_EBP 0x04
|
|
|
|
#define SRW10_FUA 0x08
|
1998-09-18 22:33:59 +00:00
|
|
|
#define SRW10_DPO 0x10
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t addr[4];
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t length[2];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_rw_12
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
#define SRW12_RELADDR 0x01
|
|
|
|
#define SRW12_FUA 0x08
|
|
|
|
#define SRW12_DPO 0x10
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t addr[4];
|
|
|
|
u_int8_t length[4];
|
2002-10-08 17:12:44 +00:00
|
|
|
u_int8_t reserved;
|
1998-09-18 22:33:59 +00:00
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
struct scsi_rw_16
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
#define SRW16_RELADDR 0x01
|
|
|
|
#define SRW16_FUA 0x08
|
|
|
|
#define SRW16_DPO 0x10
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t addr[8];
|
|
|
|
u_int8_t length[4];
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
1998-09-18 22:33:59 +00:00
|
|
|
struct scsi_start_stop_unit
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
#define SSS_IMMED 0x01
|
|
|
|
u_int8_t reserved[2];
|
|
|
|
u_int8_t how;
|
|
|
|
#define SSS_START 0x01
|
|
|
|
#define SSS_LOEJ 0x02
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
2007-10-12 22:11:22 +00:00
|
|
|
struct ata_pass_12 {
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t protocol;
|
|
|
|
#define AP_MULTI 0xe0
|
|
|
|
u_int8_t flags;
|
|
|
|
#define AP_T_LEN 0x03
|
|
|
|
#define AP_BB 0x04
|
|
|
|
#define AP_T_DIR 0x08
|
|
|
|
#define AP_CK_COND 0x20
|
|
|
|
#define AP_OFFLINE 0x60
|
|
|
|
u_int8_t features;
|
|
|
|
u_int8_t sector_count;
|
|
|
|
u_int8_t lba_low;
|
|
|
|
u_int8_t lba_mid;
|
|
|
|
u_int8_t lba_high;
|
|
|
|
u_int8_t device;
|
|
|
|
u_int8_t command;
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ata_pass_16 {
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t protocol;
|
|
|
|
#define AP_EXTEND 0x01
|
|
|
|
u_int8_t flags;
|
|
|
|
u_int8_t features_ext;
|
|
|
|
u_int8_t features;
|
|
|
|
u_int8_t sector_count_ext;
|
|
|
|
u_int8_t sector_count;
|
|
|
|
u_int8_t lba_low_ext;
|
|
|
|
u_int8_t lba_low;
|
|
|
|
u_int8_t lba_mid_ext;
|
|
|
|
u_int8_t lba_mid;
|
|
|
|
u_int8_t lba_high_ext;
|
|
|
|
u_int8_t lba_high;
|
|
|
|
u_int8_t device;
|
|
|
|
u_int8_t command;
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
#define SC_SCSI_1 0x01
|
|
|
|
#define SC_SCSI_2 0x03
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Opcodes
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define TEST_UNIT_READY 0x00
|
|
|
|
#define REQUEST_SENSE 0x03
|
1998-09-18 22:33:59 +00:00
|
|
|
#define READ_6 0x08
|
|
|
|
#define WRITE_6 0x0a
|
1998-09-15 06:36:34 +00:00
|
|
|
#define INQUIRY 0x12
|
|
|
|
#define MODE_SELECT_6 0x15
|
|
|
|
#define MODE_SENSE_6 0x1a
|
1998-09-18 22:33:59 +00:00
|
|
|
#define START_STOP_UNIT 0x1b
|
1998-09-15 06:36:34 +00:00
|
|
|
#define START_STOP 0x1b
|
|
|
|
#define RESERVE 0x16
|
|
|
|
#define RELEASE 0x17
|
2000-01-15 19:05:29 +00:00
|
|
|
#define RECEIVE_DIAGNOSTIC 0x1c
|
|
|
|
#define SEND_DIAGNOSTIC 0x1d
|
1998-09-15 06:36:34 +00:00
|
|
|
#define PREVENT_ALLOW 0x1e
|
|
|
|
#define READ_CAPACITY 0x25
|
1998-09-18 22:33:59 +00:00
|
|
|
#define READ_10 0x28
|
|
|
|
#define WRITE_10 0x2a
|
1998-09-15 06:36:34 +00:00
|
|
|
#define POSITION_TO_ELEMENT 0x2b
|
|
|
|
#define SYNCHRONIZE_CACHE 0x35
|
2007-10-12 22:11:22 +00:00
|
|
|
#define READ_DEFECT_DATA_10 0x37
|
1998-09-15 06:36:34 +00:00
|
|
|
#define WRITE_BUFFER 0x3b
|
|
|
|
#define READ_BUFFER 0x3c
|
|
|
|
#define CHANGE_DEFINITION 0x40
|
2001-08-27 01:29:30 +00:00
|
|
|
#define LOG_SELECT 0x4c
|
|
|
|
#define LOG_SENSE 0x4d
|
1998-09-15 06:36:34 +00:00
|
|
|
#define MODE_SELECT_10 0x55
|
|
|
|
#define MODE_SENSE_10 0x5A
|
2007-10-12 22:11:22 +00:00
|
|
|
#define ATA_PASS_16 0x85
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
#define READ_16 0x88
|
|
|
|
#define WRITE_16 0x8a
|
|
|
|
#define SERVICE_ACTION_IN 0x9e
|
2002-06-04 17:41:47 +00:00
|
|
|
#define REPORT_LUNS 0xA0
|
2007-10-12 22:11:22 +00:00
|
|
|
#define ATA_PASS_12 0xa1
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
#define MOVE_MEDIUM 0xa5
|
|
|
|
#define READ_12 0xa8
|
|
|
|
#define WRITE_12 0xaa
|
|
|
|
#define READ_ELEMENT_STATUS 0xb8
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Device Types
|
|
|
|
*/
|
2008-08-07 17:25:05 +00:00
|
|
|
#define T_DIRECT 0x00
|
|
|
|
#define T_SEQUENTIAL 0x01
|
|
|
|
#define T_PRINTER 0x02
|
|
|
|
#define T_PROCESSOR 0x03
|
|
|
|
#define T_WORM 0x04
|
|
|
|
#define T_CDROM 0x05
|
|
|
|
#define T_SCANNER 0x06
|
|
|
|
#define T_OPTICAL 0x07
|
|
|
|
#define T_CHANGER 0x08
|
|
|
|
#define T_COMM 0x09
|
|
|
|
#define T_ASC0 0x0a
|
|
|
|
#define T_ASC1 0x0b
|
1998-09-15 06:36:34 +00:00
|
|
|
#define T_STORARRAY 0x0c
|
|
|
|
#define T_ENCLOSURE 0x0d
|
2000-01-17 06:24:35 +00:00
|
|
|
#define T_RBC 0x0e
|
|
|
|
#define T_OCRW 0x0f
|
2008-08-07 17:25:05 +00:00
|
|
|
#define T_OSD 0x11
|
|
|
|
#define T_ADC 0x12
|
|
|
|
#define T_NODEVICE 0x1f
|
|
|
|
#define T_ANY 0xff /* Used in Quirk table matches */
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
#define T_REMOV 1
|
|
|
|
#define T_FIXED 0
|
|
|
|
|
2000-02-20 04:42:44 +00:00
|
|
|
/*
|
|
|
|
* This length is the initial inquiry length used by the probe code, as
|
|
|
|
* well as the legnth necessary for scsi_print_inquiry() to function
|
|
|
|
* correctly. If either use requires a different length in the future,
|
|
|
|
* the two values should be de-coupled.
|
|
|
|
*/
|
2000-01-17 06:24:35 +00:00
|
|
|
#define SHORT_INQUIRY_LENGTH 36
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct scsi_inquiry_data
|
|
|
|
{
|
|
|
|
u_int8_t device;
|
|
|
|
#define SID_TYPE(inq_data) ((inq_data)->device & 0x1f)
|
|
|
|
#define SID_QUAL(inq_data) (((inq_data)->device & 0xE0) >> 5)
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SID_QUAL_LU_CONNECTED 0x00 /*
|
|
|
|
* The specified peripheral device
|
1998-09-15 06:36:34 +00:00
|
|
|
* type is currently connected to
|
|
|
|
* logical unit. If the target cannot
|
|
|
|
* determine whether or not a physical
|
|
|
|
* device is currently connected, it
|
|
|
|
* shall also use this peripheral
|
|
|
|
* qualifier when returning the INQUIRY
|
|
|
|
* data. This peripheral qualifier
|
|
|
|
* does not mean that the device is
|
|
|
|
* ready for access by the initiator.
|
|
|
|
*/
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SID_QUAL_LU_OFFLINE 0x01 /*
|
|
|
|
* The target is capable of supporting
|
1998-09-15 06:36:34 +00:00
|
|
|
* the specified peripheral device type
|
|
|
|
* on this logical unit; however, the
|
|
|
|
* physical device is not currently
|
|
|
|
* connected to this logical unit.
|
|
|
|
*/
|
|
|
|
#define SID_QUAL_RSVD 0x02
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SID_QUAL_BAD_LU 0x03 /*
|
|
|
|
* The target is not capable of
|
1998-09-15 06:36:34 +00:00
|
|
|
* supporting a physical device on
|
|
|
|
* this logical unit. For this
|
|
|
|
* peripheral qualifier the peripheral
|
|
|
|
* device type shall be set to 1Fh to
|
|
|
|
* provide compatibility with previous
|
|
|
|
* versions of SCSI. All other
|
|
|
|
* peripheral device type values are
|
|
|
|
* reserved for this peripheral
|
|
|
|
* qualifier.
|
|
|
|
*/
|
|
|
|
#define SID_QUAL_IS_VENDOR_UNIQUE(inq_data) ((SID_QUAL(inq_data) & 0x08) != 0)
|
|
|
|
u_int8_t dev_qual2;
|
|
|
|
#define SID_QUAL2 0x7F
|
|
|
|
#define SID_IS_REMOVABLE(inq_data) (((inq_data)->dev_qual2 & 0x80) != 0)
|
|
|
|
u_int8_t version;
|
|
|
|
#define SID_ANSI_REV(inq_data) ((inq_data)->version & 0x07)
|
1998-12-05 22:10:14 +00:00
|
|
|
#define SCSI_REV_0 0
|
|
|
|
#define SCSI_REV_CCS 1
|
|
|
|
#define SCSI_REV_2 2
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SCSI_REV_SPC 3
|
2000-01-17 06:24:35 +00:00
|
|
|
#define SCSI_REV_SPC2 4
|
1998-12-05 22:10:14 +00:00
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
#define SID_ECMA 0x38
|
|
|
|
#define SID_ISO 0xC0
|
|
|
|
u_int8_t response_format;
|
|
|
|
#define SID_AENC 0x80
|
|
|
|
#define SID_TrmIOP 0x40
|
|
|
|
u_int8_t additional_length;
|
2006-12-04 23:04:13 +00:00
|
|
|
#define SID_ADDITIONAL_LENGTH(iqd) \
|
|
|
|
((iqd)->additional_length + \
|
|
|
|
offsetof(struct scsi_inquiry_data, additional_length) + 1)
|
2006-05-30 22:44:00 +00:00
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t spc2_flags;
|
|
|
|
#define SPC2_SID_MChngr 0x08
|
|
|
|
#define SPC2_SID_MultiP 0x10
|
|
|
|
#define SPC2_SID_EncServ 0x40
|
|
|
|
#define SPC2_SID_BQueue 0x80
|
|
|
|
|
|
|
|
#define INQ_DATA_TQ_ENABLED(iqd) \
|
|
|
|
((SID_ANSI_REV(iqd) < SCSI_REV_SPC2)? ((iqd)->flags & SID_CmdQue) : \
|
|
|
|
(((iqd)->flags & SID_CmdQue) && !((iqd)->spc2_flags & SPC2_SID_BQueue)) || \
|
|
|
|
(!((iqd)->flags & SID_CmdQue) && ((iqd)->spc2_flags & SPC2_SID_BQueue)))
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
u_int8_t flags;
|
|
|
|
#define SID_SftRe 0x01
|
|
|
|
#define SID_CmdQue 0x02
|
|
|
|
#define SID_Linked 0x08
|
|
|
|
#define SID_Sync 0x10
|
|
|
|
#define SID_WBus16 0x20
|
|
|
|
#define SID_WBus32 0x40
|
|
|
|
#define SID_RelAdr 0x80
|
|
|
|
#define SID_VENDOR_SIZE 8
|
|
|
|
char vendor[SID_VENDOR_SIZE];
|
|
|
|
#define SID_PRODUCT_SIZE 16
|
|
|
|
char product[SID_PRODUCT_SIZE];
|
|
|
|
#define SID_REVISION_SIZE 4
|
|
|
|
char revision[SID_REVISION_SIZE];
|
2000-01-17 06:24:35 +00:00
|
|
|
/*
|
|
|
|
* The following fields were taken from SCSI Primary Commands - 2
|
|
|
|
* (SPC-2) Revision 14, Dated 11 November 1999
|
|
|
|
*/
|
|
|
|
#define SID_VENDOR_SPECIFIC_0_SIZE 20
|
|
|
|
u_int8_t vendor_specific0[SID_VENDOR_SPECIFIC_0_SIZE];
|
|
|
|
/*
|
|
|
|
* An extension of SCSI Parallel Specific Values
|
|
|
|
*/
|
|
|
|
#define SID_SPI_IUS 0x01
|
|
|
|
#define SID_SPI_QAS 0x02
|
|
|
|
#define SID_SPI_CLOCK_ST 0x00
|
|
|
|
#define SID_SPI_CLOCK_DT 0x04
|
|
|
|
#define SID_SPI_CLOCK_DT_ST 0x0C
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SID_SPI_MASK 0x0F
|
2000-01-17 06:24:35 +00:00
|
|
|
u_int8_t spi3data;
|
|
|
|
u_int8_t reserved2;
|
|
|
|
/*
|
|
|
|
* Version Descriptors, stored 2 byte values.
|
|
|
|
*/
|
|
|
|
u_int8_t version1[2];
|
|
|
|
u_int8_t version2[2];
|
|
|
|
u_int8_t version3[2];
|
|
|
|
u_int8_t version4[2];
|
|
|
|
u_int8_t version5[2];
|
|
|
|
u_int8_t version6[2];
|
|
|
|
u_int8_t version7[2];
|
|
|
|
u_int8_t version8[2];
|
|
|
|
|
|
|
|
u_int8_t reserved3[22];
|
|
|
|
|
2000-01-25 17:37:02 +00:00
|
|
|
#define SID_VENDOR_SPECIFIC_1_SIZE 160
|
2000-01-17 06:24:35 +00:00
|
|
|
u_int8_t vendor_specific1[SID_VENDOR_SPECIFIC_1_SIZE];
|
1998-09-15 06:36:34 +00:00
|
|
|
};
|
|
|
|
|
2007-10-12 22:11:22 +00:00
|
|
|
struct scsi_vpd_supported_page_list
|
|
|
|
{
|
|
|
|
u_int8_t device;
|
|
|
|
u_int8_t page_code;
|
|
|
|
#define SVPD_SUPPORTED_PAGE_LIST 0x00
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t length; /* number of VPD entries */
|
|
|
|
#define SVPD_SUPPORTED_PAGES_SIZE 251
|
|
|
|
u_int8_t list[SVPD_SUPPORTED_PAGES_SIZE];
|
|
|
|
};
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct scsi_vpd_unit_serial_number
|
|
|
|
{
|
|
|
|
u_int8_t device;
|
|
|
|
u_int8_t page_code;
|
|
|
|
#define SVPD_UNIT_SERIAL_NUMBER 0x80
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t length; /* serial number length */
|
|
|
|
#define SVPD_SERIAL_NUM_SIZE 251
|
2000-01-17 06:24:35 +00:00
|
|
|
u_int8_t serial_num[SVPD_SERIAL_NUM_SIZE];
|
1998-09-15 06:36:34 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_read_capacity
|
|
|
|
{
|
|
|
|
u_int8_t opcode;
|
|
|
|
u_int8_t byte2;
|
|
|
|
u_int8_t addr[4];
|
|
|
|
u_int8_t unused[3];
|
|
|
|
u_int8_t control;
|
|
|
|
};
|
|
|
|
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
struct scsi_read_capacity_16
|
|
|
|
{
|
|
|
|
uint8_t opcode;
|
|
|
|
#define SRC16_SERVICE_ACTION 0x10
|
|
|
|
uint8_t service_action;
|
|
|
|
uint8_t addr[8];
|
|
|
|
uint8_t alloc_len[4];
|
|
|
|
#define SRC16_PMI 0x01
|
|
|
|
#define SRC16_RELADR 0x02
|
|
|
|
uint8_t reladr;
|
|
|
|
uint8_t control;
|
|
|
|
};
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct scsi_read_capacity_data
|
|
|
|
{
|
|
|
|
u_int8_t addr[4];
|
|
|
|
u_int8_t length[4];
|
|
|
|
};
|
|
|
|
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
struct scsi_read_capacity_data_long
|
|
|
|
{
|
|
|
|
uint8_t addr[8];
|
|
|
|
uint8_t length[4];
|
|
|
|
};
|
|
|
|
|
2002-06-04 17:41:47 +00:00
|
|
|
struct scsi_report_luns
|
|
|
|
{
|
2006-08-21 13:24:50 +00:00
|
|
|
uint8_t opcode;
|
|
|
|
uint8_t reserved1;
|
|
|
|
#define RPL_REPORT_DEFAULT 0x00
|
|
|
|
#define RPL_REPORT_WELLKNOWN 0x01
|
|
|
|
#define RPL_REPORT_ALL 0x02
|
|
|
|
uint8_t select_report;
|
|
|
|
uint8_t reserved2[3];
|
|
|
|
uint8_t length[4];
|
|
|
|
uint8_t reserved3;
|
|
|
|
uint8_t control;
|
2002-06-04 17:41:47 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_report_luns_data {
|
|
|
|
u_int8_t length[4]; /* length of LUN inventory, in bytes */
|
|
|
|
u_int8_t reserved[4]; /* unused */
|
|
|
|
/*
|
|
|
|
* LUN inventory- we only support the type zero form for now.
|
|
|
|
*/
|
|
|
|
struct {
|
|
|
|
u_int8_t lundata[8];
|
2006-08-21 13:24:50 +00:00
|
|
|
} luns[0];
|
2002-06-04 17:41:47 +00:00
|
|
|
};
|
2006-08-21 13:24:50 +00:00
|
|
|
#define RPL_LUNDATA_PERIPH_BUS_MASK 0x3f
|
|
|
|
#define RPL_LUNDATA_FLAT_LUN_MASK 0x3f
|
|
|
|
#define RPL_LUNDATA_LUN_TARG_MASK 0x3f
|
|
|
|
#define RPL_LUNDATA_LUN_BUS_MASK 0xe0
|
|
|
|
#define RPL_LUNDATA_LUN_LUN_MASK 0x1f
|
|
|
|
#define RPL_LUNDATA_EXT_LEN_MASK 0x30
|
|
|
|
#define RPL_LUNDATA_EXT_EAM_MASK 0x0f
|
|
|
|
#define RPL_LUNDATA_EXT_EAM_WK 0x01
|
|
|
|
#define RPL_LUNDATA_EXT_EAM_NOT_SPEC 0x0f
|
2002-06-04 17:41:47 +00:00
|
|
|
#define RPL_LUNDATA_ATYP_MASK 0xc0 /* MBZ for type 0 lun */
|
2006-08-21 13:24:50 +00:00
|
|
|
#define RPL_LUNDATA_ATYP_PERIPH 0x00
|
|
|
|
#define RPL_LUNDATA_ATYP_FLAT 0x40
|
|
|
|
#define RPL_LUNDATA_ATYP_LUN 0x80
|
|
|
|
#define RPL_LUNDATA_ATYP_EXTLUN 0xc0
|
2002-06-04 17:41:47 +00:00
|
|
|
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct scsi_sense_data
|
|
|
|
{
|
|
|
|
u_int8_t error_code;
|
|
|
|
#define SSD_ERRCODE 0x7F
|
|
|
|
#define SSD_CURRENT_ERROR 0x70
|
|
|
|
#define SSD_DEFERRED_ERROR 0x71
|
|
|
|
#define SSD_ERRCODE_VALID 0x80
|
|
|
|
u_int8_t segment;
|
|
|
|
u_int8_t flags;
|
|
|
|
#define SSD_KEY 0x0F
|
|
|
|
#define SSD_KEY_NO_SENSE 0x00
|
|
|
|
#define SSD_KEY_RECOVERED_ERROR 0x01
|
|
|
|
#define SSD_KEY_NOT_READY 0x02
|
|
|
|
#define SSD_KEY_MEDIUM_ERROR 0x03
|
|
|
|
#define SSD_KEY_HARDWARE_ERROR 0x04
|
|
|
|
#define SSD_KEY_ILLEGAL_REQUEST 0x05
|
|
|
|
#define SSD_KEY_UNIT_ATTENTION 0x06
|
|
|
|
#define SSD_KEY_DATA_PROTECT 0x07
|
|
|
|
#define SSD_KEY_BLANK_CHECK 0x08
|
|
|
|
#define SSD_KEY_Vendor_Specific 0x09
|
|
|
|
#define SSD_KEY_COPY_ABORTED 0x0a
|
|
|
|
#define SSD_KEY_ABORTED_COMMAND 0x0b
|
|
|
|
#define SSD_KEY_EQUAL 0x0c
|
|
|
|
#define SSD_KEY_VOLUME_OVERFLOW 0x0d
|
|
|
|
#define SSD_KEY_MISCOMPARE 0x0e
|
|
|
|
#define SSD_KEY_RESERVED 0x0f
|
|
|
|
#define SSD_ILI 0x20
|
|
|
|
#define SSD_EOM 0x40
|
|
|
|
#define SSD_FILEMARK 0x80
|
|
|
|
u_int8_t info[4];
|
|
|
|
u_int8_t extra_len;
|
|
|
|
u_int8_t cmd_spec_info[4];
|
|
|
|
u_int8_t add_sense_code;
|
|
|
|
u_int8_t add_sense_code_qual;
|
|
|
|
u_int8_t fru;
|
|
|
|
u_int8_t sense_key_spec[3];
|
|
|
|
#define SSD_SCS_VALID 0x80
|
|
|
|
#define SSD_FIELDPTR_CMD 0x40
|
|
|
|
#define SSD_BITPTR_VALID 0x08
|
|
|
|
#define SSD_BITPTR_VALUE 0x07
|
|
|
|
#define SSD_MIN_SIZE 18
|
|
|
|
u_int8_t extra_bytes[14];
|
|
|
|
#define SSD_FULL_SIZE sizeof(struct scsi_sense_data)
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_header_6
|
|
|
|
{
|
|
|
|
u_int8_t data_length; /* Sense data length */
|
|
|
|
u_int8_t medium_type;
|
|
|
|
u_int8_t dev_spec;
|
|
|
|
u_int8_t blk_desc_len;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_header_10
|
|
|
|
{
|
|
|
|
u_int8_t data_length[2];/* Sense data length */
|
|
|
|
u_int8_t medium_type;
|
|
|
|
u_int8_t dev_spec;
|
|
|
|
u_int8_t unused[2];
|
|
|
|
u_int8_t blk_desc_len[2];
|
|
|
|
};
|
|
|
|
|
2000-08-08 06:24:17 +00:00
|
|
|
struct scsi_mode_page_header
|
|
|
|
{
|
|
|
|
u_int8_t page_code;
|
|
|
|
u_int8_t page_length;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_mode_blk_desc
|
1998-09-15 06:36:34 +00:00
|
|
|
{
|
|
|
|
u_int8_t density;
|
|
|
|
u_int8_t nblocks[3];
|
|
|
|
u_int8_t reserved;
|
|
|
|
u_int8_t blklen[3];
|
|
|
|
};
|
|
|
|
|
1998-12-05 22:10:14 +00:00
|
|
|
#define SCSI_DEFAULT_DENSITY 0x00 /* use 'default' density */
|
|
|
|
#define SCSI_SAME_DENSITY 0x7f /* use 'same' density- >= SCSI-2 only */
|
2002-06-04 17:41:47 +00:00
|
|
|
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
/*
|
|
|
|
* Status Byte
|
|
|
|
*/
|
|
|
|
#define SCSI_STATUS_OK 0x00
|
|
|
|
#define SCSI_STATUS_CHECK_COND 0x02
|
|
|
|
#define SCSI_STATUS_COND_MET 0x04
|
|
|
|
#define SCSI_STATUS_BUSY 0x08
|
|
|
|
#define SCSI_STATUS_INTERMED 0x10
|
|
|
|
#define SCSI_STATUS_INTERMED_COND_MET 0x14
|
|
|
|
#define SCSI_STATUS_RESERV_CONFLICT 0x18
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SCSI_STATUS_CMD_TERMINATED 0x22 /* Obsolete in SAM-2 */
|
1998-09-15 06:36:34 +00:00
|
|
|
#define SCSI_STATUS_QUEUE_FULL 0x28
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#define SCSI_STATUS_ACA_ACTIVE 0x30
|
|
|
|
#define SCSI_STATUS_TASK_ABORTED 0x40
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
struct scsi_inquiry_pattern {
|
|
|
|
u_int8_t type;
|
|
|
|
u_int8_t media_type;
|
|
|
|
#define SIP_MEDIA_REMOVABLE 0x01
|
|
|
|
#define SIP_MEDIA_FIXED 0x02
|
|
|
|
const char *vendor;
|
|
|
|
const char *product;
|
|
|
|
const char *revision;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_static_inquiry_pattern {
|
|
|
|
u_int8_t type;
|
|
|
|
u_int8_t media_type;
|
|
|
|
char vendor[SID_VENDOR_SIZE+1];
|
|
|
|
char product[SID_PRODUCT_SIZE+1];
|
|
|
|
char revision[SID_REVISION_SIZE+1];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_sense_quirk_entry {
|
|
|
|
struct scsi_inquiry_pattern inq_pat;
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
int num_sense_keys;
|
1998-09-15 06:36:34 +00:00
|
|
|
int num_ascs;
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
struct sense_key_table_entry *sense_key_info;
|
1998-09-15 06:36:34 +00:00
|
|
|
struct asc_table_entry *asc_info;
|
|
|
|
};
|
|
|
|
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
struct sense_key_table_entry {
|
|
|
|
u_int8_t sense_key;
|
|
|
|
u_int32_t action;
|
|
|
|
const char *desc;
|
|
|
|
};
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
struct asc_table_entry {
|
|
|
|
u_int8_t asc;
|
|
|
|
u_int8_t ascq;
|
|
|
|
u_int32_t action;
|
|
|
|
const char *desc;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct op_table_entry {
|
|
|
|
u_int8_t opcode;
|
2008-08-07 17:25:05 +00:00
|
|
|
u_int32_t opmask;
|
1998-09-15 06:36:34 +00:00
|
|
|
const char *desc;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct scsi_op_quirk_entry {
|
|
|
|
struct scsi_inquiry_pattern inq_pat;
|
|
|
|
int num_ops;
|
|
|
|
struct op_table_entry *op_table;
|
|
|
|
};
|
|
|
|
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
typedef enum {
|
|
|
|
SSS_FLAG_NONE = 0x00,
|
|
|
|
SSS_FLAG_PRINT_COMMAND = 0x01
|
|
|
|
} scsi_sense_string_flags;
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
struct ccb_scsiio;
|
|
|
|
struct cam_periph;
|
|
|
|
union ccb;
|
1999-12-29 04:46:21 +00:00
|
|
|
#ifndef _KERNEL
|
1998-09-15 06:36:34 +00:00
|
|
|
struct cam_device;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
extern const char *scsi_sense_key_text[];
|
|
|
|
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
struct sbuf;
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
__BEGIN_DECLS
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
void scsi_sense_desc(int sense_key, int asc, int ascq,
|
|
|
|
struct scsi_inquiry_data *inq_data,
|
|
|
|
const char **sense_key_desc, const char **asc_desc);
|
|
|
|
scsi_sense_action scsi_error_action(struct ccb_scsiio* csio,
|
|
|
|
struct scsi_inquiry_data *inq_data,
|
|
|
|
u_int32_t sense_flags);
|
|
|
|
const char * scsi_status_string(struct ccb_scsiio *csio);
|
1999-12-29 04:46:21 +00:00
|
|
|
#ifdef _KERNEL
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
int scsi_command_string(struct ccb_scsiio *csio, struct sbuf *sb);
|
|
|
|
int scsi_sense_sbuf(struct ccb_scsiio *csio, struct sbuf *sb,
|
|
|
|
scsi_sense_string_flags flags);
|
|
|
|
char * scsi_sense_string(struct ccb_scsiio *csio,
|
|
|
|
char *str, int str_len);
|
1998-09-15 06:36:34 +00:00
|
|
|
void scsi_sense_print(struct ccb_scsiio *csio);
|
|
|
|
int scsi_interpret_sense(union ccb *ccb,
|
|
|
|
u_int32_t sense_flags,
|
|
|
|
u_int32_t *relsim_flags,
|
|
|
|
u_int32_t *reduction,
|
|
|
|
u_int32_t *timeout,
|
|
|
|
scsi_sense_action error_action);
|
Rewrite of the CAM error recovery code.
Some of the major changes include:
- The SCSI error handling portion of cam_periph_error() has
been broken out into a number of subfunctions to better
modularize the code that handles the hierarchy of SCSI errors.
As a result, the code is now much easier to read.
- String handling and error printing has been significantly
revamped. We now use sbufs to do string formatting instead
of using printfs (for the kernel) and snprintf/strncat (for
userland) as before.
There is a new catchall error printing routine,
cam_error_print() and its string-based counterpart,
cam_error_string() that allow the kernel and userland
applications to pass in a CCB and have errors printed out
properly, whether or not they're SCSI errors. Among other
things, this helped eliminate a fair amount of duplicate code
in camcontrol.
We now print out more information than before, including
the CAM status and SCSI status and the error recovery action
taken to remedy the problem.
- sbufs are now available in userland, via libsbuf. This
change was necessary since most of the error printing code
is shared between libcam and the kernel.
- A new transfer settings interface is included in this checkin.
This code is #ifdef'ed out, and is primarily intended to aid
discussion with HBA driver authors on the final form the
interface should take. There is example code in the ahc(4)
driver that implements the HBA driver side of the new
interface. The new transfer settings code won't be enabled
until we're ready to switch all HBA drivers over to the new
interface.
src/Makefile.inc1,
lib/Makefile: Add libsbuf. It must be built before libcam,
since libcam uses sbuf routines.
libcam/Makefile: libcam now depends on libsbuf.
libsbuf/Makefile: Add a makefile for libsbuf. This pulls in the
sbuf sources from sys/kern.
bsd.libnames.mk: Add LIBSBUF.
camcontrol/Makefile: Add -lsbuf. Since camcontrol is statically
linked, we can't depend on the dynamic linker
to pull in libsbuf.
camcontrol.c: Use cam_error_print() instead of checking for
CAM_SCSI_STATUS_ERROR on every failed CCB.
sbuf.9: Change the prototypes for sbuf_cat() and
sbuf_cpy() so that the source string is now a
const char *. This is more in line wth the
standard system string functions, and helps
eliminate warnings when dealing with a const
source buffer.
Fix a typo.
cam.c: Add description strings for the various CAM
error status values, as well as routines to
look up those strings.
Add new cam_error_string() and
cam_error_print() routines for userland and
the kernel.
cam.h: Add a new CAM flag, CAM_RETRY_SELTO.
Add enumerated types for the various options
available with cam_error_print() and
cam_error_string().
cam_ccb.h: Add new transfer negotiation structures/types.
Change inq_len in the ccb_getdev structure to
be "reserved". This field has never been
filled in, and will be removed when we next
bump the CAM version.
cam_debug.h: Fix typo.
cam_periph.c: Modularize cam_periph_error(). The SCSI error
handling part of cam_periph_error() is now
in camperiphscsistatuserror() and
camperiphscsisenseerror().
In cam_periph_lock(), increase the reference
count on the periph while we wait for our lock
attempt to succeed so that the periph won't go
away while we're sleeping.
cam_xpt.c: Add new transfer negotiation code. (ifdefed
out)
Add a new function, xpt_path_string(). This
is a string/sbuf analog to xpt_print_path().
scsi_all.c: Revamp string handing and error printing code.
We now use sbufs for much of the string
formatting code. More of that code is shared
between userland the kernel.
scsi_all.h: Get rid of SS_TURSTART, it wasn't terribly
useful in the first place.
Add a new error action, SS_REQSENSE. (Send a
request sense and then retry the command.)
This is useful when the controller hasn't
performed autosense for some reason.
Change the default actions around a bit.
scsi_cd.c,
scsi_da.c,
scsi_pt.c,
scsi_ses.c: SF_RETRY_SELTO -> CAM_RETRY_SELTO. Selection
timeouts shouldn't be covered by a sense flag.
scsi_pass.[ch]: SF_RETRY_SELTO -> CAM_RETRY_SELTO.
Get rid of the last vestiges of a read/write
interface.
libkern/bsearch.c,
sys/libkern.h,
conf/files: Add bsearch.c, which is needed for some of the
new table lookup routines.
aic7xxx_freebsd.c: Define AHC_NEW_TRAN_SETTINGS if
CAM_NEW_TRAN_CODE is defined.
sbuf.h,
subr_sbuf.c: Add the appropriate #ifdefs so sbufs can
compile and run in userland.
Change sbuf_printf() to use vsnprintf()
instead of kvprintf(), which is only available
in the kernel.
Change the source string for sbuf_cpy() and
sbuf_cat() to be a const char *.
Add __BEGIN_DECLS and __END_DECLS around
function prototypes since they're now exported
to userland.
kdump/mkioctls: Include stdio.h before cam.h since cam.h now
includes a function with a FILE * argument.
Submitted by: gibbs (mostly)
Reviewed by: jdp, marcel (libsbuf makefile changes)
Reviewed by: des (sbuf changes)
Reviewed by: ken
2001-03-27 05:45:52 +00:00
|
|
|
#else /* _KERNEL */
|
|
|
|
int scsi_command_string(struct cam_device *device,
|
|
|
|
struct ccb_scsiio *csio, struct sbuf *sb);
|
|
|
|
int scsi_sense_sbuf(struct cam_device *device,
|
|
|
|
struct ccb_scsiio *csio, struct sbuf *sb,
|
|
|
|
scsi_sense_string_flags flags);
|
1998-09-15 06:36:34 +00:00
|
|
|
char * scsi_sense_string(struct cam_device *device,
|
|
|
|
struct ccb_scsiio *csio,
|
|
|
|
char *str, int str_len);
|
|
|
|
void scsi_sense_print(struct cam_device *device,
|
|
|
|
struct ccb_scsiio *csio, FILE *ofile);
|
|
|
|
int scsi_interpret_sense(struct cam_device *device,
|
|
|
|
union ccb *ccb,
|
|
|
|
u_int32_t sense_flags,
|
|
|
|
u_int32_t *relsim_flags,
|
|
|
|
u_int32_t *reduction,
|
|
|
|
u_int32_t *timeout,
|
|
|
|
scsi_sense_action error_action);
|
1999-12-29 04:46:21 +00:00
|
|
|
#endif /* _KERNEL */
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
#define SF_RETRY_UA 0x01
|
|
|
|
#define SF_NO_PRINT 0x02
|
|
|
|
#define SF_QUIET_IR 0x04 /* Be quiet about Illegal Request reponses */
|
1998-09-29 22:11:30 +00:00
|
|
|
#define SF_PRINT_ALWAYS 0x08
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
const char * scsi_op_desc(u_int16_t opcode,
|
|
|
|
struct scsi_inquiry_data *inq_data);
|
1998-10-15 19:08:58 +00:00
|
|
|
char * scsi_cdb_string(u_int8_t *cdb_ptr, char *cdb_string,
|
|
|
|
size_t len);
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
void scsi_print_inquiry(struct scsi_inquiry_data *inq_data);
|
|
|
|
|
|
|
|
u_int scsi_calc_syncsrate(u_int period_factor);
|
|
|
|
u_int scsi_calc_syncparam(u_int period);
|
|
|
|
|
|
|
|
void scsi_test_unit_ready(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *),
|
|
|
|
u_int8_t tag_action,
|
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
|
|
|
void scsi_request_sense(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *),
|
|
|
|
void *data_ptr, u_int8_t dxfer_len,
|
|
|
|
u_int8_t tag_action, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
|
|
|
|
|
|
|
void scsi_inquiry(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *, union ccb *),
|
|
|
|
u_int8_t tag_action, u_int8_t *inq_buf,
|
|
|
|
u_int32_t inq_len, int evpd, u_int8_t page_code,
|
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
|
|
|
void scsi_mode_sense(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *),
|
|
|
|
u_int8_t tag_action, int dbd,
|
|
|
|
u_int8_t page_code, u_int8_t page,
|
|
|
|
u_int8_t *param_buf, u_int32_t param_len,
|
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
Fix ATAPI/USB/Firewire CDROM drive handling in cd(4) and hopefully fix
a number of related problems along the way.
- Automatically detect CDROM drives that can't handle 6 byte mode
sense and mode select, and adjust our command size accordingly.
We have to handle this in the cd(4) driver (where the buffers are
allocated), since the parameter list length is different for the
6 and 10 byte mode sense commands.
- Remove MODE_SENSE and MODE_SELECT translation removed in ATAPICAM
and in the umass(4) driver, since there's no way for that to work
properly.
- Add a quirk entry for CDROM drives that just hang when they get a 6
byte mode sense or mode select. The reason for the quirk must be
documented in a PR, and all quirks must be approved by
ken@FreeBSD.org. This is to make sure that we fully understand why
each quirk is needed. Once the CAM_NEW_TRAN_CODE is finished, we
should be able to remove any such quirks, since we'll know what
protocol the drive speaks (SCSI, ATAPI, etc.) and therefore whether
we should use 6 or 10 byte mode sense/select commands.
- Change the way the da(4) handles the no_6_byte sysctl. There is
now a per-drive sysctl to set the minimum command size for that
particular disk. (Since you could have multiple disks with
multiple requirements in one system.)
- Loader tunable support for all the sysctls in the da(4) and cd(4)
drivers.
- Add a CDIOCCLOSE ioctl for cd(4) (bde pointed this out a long
time ago).
- Add a media validation routine (cdcheckmedia()) to the cd(4)
driver, to fix some problems bde pointed out a long time ago. We
now allow open() to succeed no matter what, but if we don't detect
valid media, the user can only issue CDIOCCLOSE or CDIOCEJECT
ioctls.
- The media validation routine also reads the table of contents off
the drive. We use the table of contents to implement the
CDIOCPLAYTRACKS ioctl using the PLAY AUDIO MSF command. The
PLAY AUDIO TRACK INDEX command that we previously used was
deprecated after SCSI-2. It works in every SCSI CDROM I've tried,
but doesn't seem to work on ATAPI CDROM drives. We still use the
play audio track index command if we don't have a valid TOC, but
I suppose it'll fail anyway in that case.
- Add _len() versions of scsi_mode_sense() and scsi_mode_select() so
that we can specify the minimum command length.
- Fix a couple of formatting problems in the sense printing code.
MFC after: 4 weeks
2003-02-21 06:19:38 +00:00
|
|
|
void scsi_mode_sense_len(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *),
|
|
|
|
u_int8_t tag_action, int dbd,
|
|
|
|
u_int8_t page_code, u_int8_t page,
|
|
|
|
u_int8_t *param_buf, u_int32_t param_len,
|
|
|
|
int minimum_cmd_size, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
void scsi_mode_select(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *),
|
|
|
|
u_int8_t tag_action, int scsi_page_fmt,
|
|
|
|
int save_pages, u_int8_t *param_buf,
|
|
|
|
u_int32_t param_len, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
|
|
|
|
Fix ATAPI/USB/Firewire CDROM drive handling in cd(4) and hopefully fix
a number of related problems along the way.
- Automatically detect CDROM drives that can't handle 6 byte mode
sense and mode select, and adjust our command size accordingly.
We have to handle this in the cd(4) driver (where the buffers are
allocated), since the parameter list length is different for the
6 and 10 byte mode sense commands.
- Remove MODE_SENSE and MODE_SELECT translation removed in ATAPICAM
and in the umass(4) driver, since there's no way for that to work
properly.
- Add a quirk entry for CDROM drives that just hang when they get a 6
byte mode sense or mode select. The reason for the quirk must be
documented in a PR, and all quirks must be approved by
ken@FreeBSD.org. This is to make sure that we fully understand why
each quirk is needed. Once the CAM_NEW_TRAN_CODE is finished, we
should be able to remove any such quirks, since we'll know what
protocol the drive speaks (SCSI, ATAPI, etc.) and therefore whether
we should use 6 or 10 byte mode sense/select commands.
- Change the way the da(4) handles the no_6_byte sysctl. There is
now a per-drive sysctl to set the minimum command size for that
particular disk. (Since you could have multiple disks with
multiple requirements in one system.)
- Loader tunable support for all the sysctls in the da(4) and cd(4)
drivers.
- Add a CDIOCCLOSE ioctl for cd(4) (bde pointed this out a long
time ago).
- Add a media validation routine (cdcheckmedia()) to the cd(4)
driver, to fix some problems bde pointed out a long time ago. We
now allow open() to succeed no matter what, but if we don't detect
valid media, the user can only issue CDIOCCLOSE or CDIOCEJECT
ioctls.
- The media validation routine also reads the table of contents off
the drive. We use the table of contents to implement the
CDIOCPLAYTRACKS ioctl using the PLAY AUDIO MSF command. The
PLAY AUDIO TRACK INDEX command that we previously used was
deprecated after SCSI-2. It works in every SCSI CDROM I've tried,
but doesn't seem to work on ATAPI CDROM drives. We still use the
play audio track index command if we don't have a valid TOC, but
I suppose it'll fail anyway in that case.
- Add _len() versions of scsi_mode_sense() and scsi_mode_select() so
that we can specify the minimum command length.
- Fix a couple of formatting problems in the sense printing code.
MFC after: 4 weeks
2003-02-21 06:19:38 +00:00
|
|
|
void scsi_mode_select_len(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *),
|
|
|
|
u_int8_t tag_action, int scsi_page_fmt,
|
|
|
|
int save_pages, u_int8_t *param_buf,
|
|
|
|
u_int32_t param_len, int minimum_cmd_size,
|
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
2001-08-27 01:29:30 +00:00
|
|
|
void scsi_log_sense(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *, union ccb *),
|
|
|
|
u_int8_t tag_action, u_int8_t page_code,
|
|
|
|
u_int8_t page, int save_pages, int ppc,
|
|
|
|
u_int32_t paramptr, u_int8_t *param_buf,
|
|
|
|
u_int32_t param_len, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
|
|
|
|
|
|
|
void scsi_log_select(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *), u_int8_t tag_action,
|
|
|
|
u_int8_t page_code, int save_pages,
|
|
|
|
int pc_reset, u_int8_t *param_buf,
|
|
|
|
u_int32_t param_len, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
|
|
|
|
2002-06-04 17:41:47 +00:00
|
|
|
void scsi_prevent(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *, union ccb *),
|
|
|
|
u_int8_t tag_action, u_int8_t action,
|
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
void scsi_read_capacity(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *), u_int8_t tag_action,
|
2002-06-04 17:41:47 +00:00
|
|
|
struct scsi_read_capacity_data *,
|
1998-09-15 06:36:34 +00:00
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
void scsi_read_capacity_16(struct ccb_scsiio *csio, uint32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *), uint8_t tag_action,
|
|
|
|
uint64_t lba, int reladr, int pmi,
|
|
|
|
struct scsi_read_capacity_data_long
|
|
|
|
*rcap_buf, uint8_t sense_len,
|
|
|
|
uint32_t timeout);
|
1998-09-15 06:36:34 +00:00
|
|
|
|
2002-06-04 17:41:47 +00:00
|
|
|
void scsi_report_luns(struct ccb_scsiio *csio, u_int32_t retries,
|
2006-08-21 13:24:50 +00:00
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *), u_int8_t tag_action,
|
|
|
|
u_int8_t select_report,
|
|
|
|
struct scsi_report_luns_data *rpl_buf,
|
|
|
|
u_int32_t alloc_len, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
void scsi_synchronize_cache(struct ccb_scsiio *csio,
|
|
|
|
u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *,
|
|
|
|
union ccb *), u_int8_t tag_action,
|
|
|
|
u_int32_t begin_lba, u_int16_t lb_count,
|
|
|
|
u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
1998-09-18 22:33:59 +00:00
|
|
|
void scsi_read_write(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *, union ccb *),
|
|
|
|
u_int8_t tag_action, int readop, u_int8_t byte2,
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
int minimum_cmd_size, u_int64_t lba,
|
1998-09-18 22:33:59 +00:00
|
|
|
u_int32_t block_count, u_int8_t *data_ptr,
|
|
|
|
u_int32_t dxfer_len, u_int8_t sense_len,
|
|
|
|
u_int32_t timeout);
|
|
|
|
|
|
|
|
void scsi_start_stop(struct ccb_scsiio *csio, u_int32_t retries,
|
|
|
|
void (*cbfcnp)(struct cam_periph *, union ccb *),
|
|
|
|
u_int8_t tag_action, int start, int load_eject,
|
|
|
|
int immediate, u_int8_t sense_len, u_int32_t timeout);
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
int scsi_inquiry_match(caddr_t inqbuffer, caddr_t table_entry);
|
|
|
|
int scsi_static_inquiry_match(caddr_t inqbuffer,
|
|
|
|
caddr_t table_entry);
|
|
|
|
|
|
|
|
static __inline void scsi_extract_sense(struct scsi_sense_data *sense,
|
|
|
|
int *error_code, int *sense_key,
|
|
|
|
int *asc, int *ascq);
|
|
|
|
static __inline void scsi_ulto2b(u_int32_t val, u_int8_t *bytes);
|
|
|
|
static __inline void scsi_ulto3b(u_int32_t val, u_int8_t *bytes);
|
|
|
|
static __inline void scsi_ulto4b(u_int32_t val, u_int8_t *bytes);
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
static __inline void scsi_u64to8b(u_int64_t val, u_int8_t *bytes);
|
1998-09-15 06:36:34 +00:00
|
|
|
static __inline u_int32_t scsi_2btoul(u_int8_t *bytes);
|
|
|
|
static __inline u_int32_t scsi_3btoul(u_int8_t *bytes);
|
|
|
|
static __inline int32_t scsi_3btol(u_int8_t *bytes);
|
|
|
|
static __inline u_int32_t scsi_4btoul(u_int8_t *bytes);
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
static __inline u_int64_t scsi_8btou64(u_int8_t *bytes);
|
1998-10-02 05:25:49 +00:00
|
|
|
static __inline void *find_mode_page_6(struct scsi_mode_header_6 *mode_header);
|
|
|
|
static __inline void *find_mode_page_10(struct scsi_mode_header_10 *mode_header);
|
1998-09-15 06:36:34 +00:00
|
|
|
|
|
|
|
static __inline void scsi_extract_sense(struct scsi_sense_data *sense,
|
|
|
|
int *error_code, int *sense_key,
|
|
|
|
int *asc, int *ascq)
|
|
|
|
{
|
|
|
|
*error_code = sense->error_code & SSD_ERRCODE;
|
|
|
|
*sense_key = sense->flags & SSD_KEY;
|
|
|
|
*asc = (sense->extra_len >= 5) ? sense->add_sense_code : 0;
|
|
|
|
*ascq = (sense->extra_len >= 6) ? sense->add_sense_code_qual : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
scsi_ulto2b(u_int32_t val, u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
|
|
|
|
bytes[0] = (val >> 8) & 0xff;
|
|
|
|
bytes[1] = val & 0xff;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
scsi_ulto3b(u_int32_t val, u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
|
|
|
|
bytes[0] = (val >> 16) & 0xff;
|
|
|
|
bytes[1] = (val >> 8) & 0xff;
|
|
|
|
bytes[2] = val & 0xff;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void
|
|
|
|
scsi_ulto4b(u_int32_t val, u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
|
|
|
|
bytes[0] = (val >> 24) & 0xff;
|
|
|
|
bytes[1] = (val >> 16) & 0xff;
|
|
|
|
bytes[2] = (val >> 8) & 0xff;
|
|
|
|
bytes[3] = val & 0xff;
|
|
|
|
}
|
|
|
|
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
static __inline void
|
|
|
|
scsi_u64to8b(u_int64_t val, u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
|
|
|
|
bytes[0] = (val >> 56) & 0xff;
|
|
|
|
bytes[1] = (val >> 48) & 0xff;
|
|
|
|
bytes[2] = (val >> 40) & 0xff;
|
|
|
|
bytes[3] = (val >> 32) & 0xff;
|
|
|
|
bytes[4] = (val >> 24) & 0xff;
|
|
|
|
bytes[5] = (val >> 16) & 0xff;
|
|
|
|
bytes[6] = (val >> 8) & 0xff;
|
|
|
|
bytes[7] = val & 0xff;
|
|
|
|
}
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
static __inline u_int32_t
|
|
|
|
scsi_2btoul(u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
u_int32_t rv;
|
|
|
|
|
|
|
|
rv = (bytes[0] << 8) |
|
|
|
|
bytes[1];
|
|
|
|
return (rv);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline u_int32_t
|
|
|
|
scsi_3btoul(u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
u_int32_t rv;
|
|
|
|
|
|
|
|
rv = (bytes[0] << 16) |
|
|
|
|
(bytes[1] << 8) |
|
|
|
|
bytes[2];
|
|
|
|
return (rv);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline int32_t
|
|
|
|
scsi_3btol(u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
u_int32_t rc = scsi_3btoul(bytes);
|
|
|
|
|
|
|
|
if (rc & 0x00800000)
|
|
|
|
rc |= 0xff000000;
|
|
|
|
|
|
|
|
return (int32_t) rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline u_int32_t
|
|
|
|
scsi_4btoul(u_int8_t *bytes)
|
|
|
|
{
|
|
|
|
u_int32_t rv;
|
|
|
|
|
|
|
|
rv = (bytes[0] << 24) |
|
|
|
|
(bytes[1] << 16) |
|
|
|
|
(bytes[2] << 8) |
|
|
|
|
bytes[3];
|
|
|
|
return (rv);
|
|
|
|
}
|
1998-10-02 05:25:49 +00:00
|
|
|
|
Add support to CAM for devices with more than 2^32 blocks. (2TB if you're
using 512 byte blocks).
cam_ccb.h: Bump up volume_size and cylinders in ccb_calc_geometry to
64 bits and 32 bits respectively, so we can hold larger
device sizes. cylinders would overflow at about 500GB.
Bump CAM_VERSION for this change. Note that this will
require a recompile of all applications that talk to the
pass(4) driver.
scsi_all.c: Add descriptions for READ/WRITE(16), update READ/WRITE(12)
descriptions, add descriptions for SERVICE ACTION IN/OUT.
Add a new function, scsi_read_capacity_16(), that issues
the read capacity service action. (Necessary for arrays
larger than 2^32 sectors.) Update scsi_read_write() to use
a 64 bit LBA and issue READ(16) or WRITE(16) if necessary.
NOTE the API change. This should be largely transparnet
to most userland applications at compile time, but will
break binary compatibility. The CAM_VERSION bump, above,
also serves the purpose of forcing a recompile for any
applications that talk to CAM.
scsi_all.h: Add 16 byte READ/WRITE structures, structures for 16 byte
READ CAPACITY/SERVICE ACTION IN. Add scsi_u64to8b() and
scsi_8btou64.
scsi_da.c: The da(4) driver probe now has two stages for devices
larger than 2TB. If a standard READ CAPACITY(10) returns
0xffffffff, we issue the 16 byte version of read capacity
to determine the true array capacity. We also do the same
thing in daopen() -- use the 16 byte read capacity if the
device is large enough.
The sysctl/loader code has also been updated to accept
16 bytes as a minimum command size.
2003-04-30 00:35:22 +00:00
|
|
|
static __inline uint64_t
|
|
|
|
scsi_8btou64(uint8_t *bytes)
|
|
|
|
{
|
|
|
|
uint64_t rv;
|
|
|
|
|
|
|
|
rv = (((uint64_t)bytes[0]) << 56) |
|
|
|
|
(((uint64_t)bytes[1]) << 48) |
|
|
|
|
(((uint64_t)bytes[2]) << 40) |
|
|
|
|
(((uint64_t)bytes[3]) << 32) |
|
|
|
|
(((uint64_t)bytes[4]) << 24) |
|
|
|
|
(((uint64_t)bytes[5]) << 16) |
|
|
|
|
(((uint64_t)bytes[6]) << 8) |
|
|
|
|
bytes[7];
|
|
|
|
return (rv);
|
|
|
|
}
|
|
|
|
|
1998-10-02 05:25:49 +00:00
|
|
|
/*
|
|
|
|
* Given the pointer to a returned mode sense buffer, return a pointer to
|
|
|
|
* the start of the first mode page.
|
|
|
|
*/
|
|
|
|
static __inline void *
|
|
|
|
find_mode_page_6(struct scsi_mode_header_6 *mode_header)
|
|
|
|
{
|
|
|
|
void *page_start;
|
|
|
|
|
|
|
|
page_start = (void *)((u_int8_t *)&mode_header[1] +
|
|
|
|
mode_header->blk_desc_len);
|
|
|
|
|
|
|
|
return(page_start);
|
|
|
|
}
|
|
|
|
|
|
|
|
static __inline void *
|
|
|
|
find_mode_page_10(struct scsi_mode_header_10 *mode_header)
|
|
|
|
{
|
|
|
|
void *page_start;
|
|
|
|
|
2007-11-15 16:23:38 +00:00
|
|
|
page_start = (void *)((u_int8_t *)&mode_header[1] +
|
1998-10-02 05:25:49 +00:00
|
|
|
scsi_2btoul(mode_header->blk_desc_len));
|
|
|
|
|
|
|
|
return(page_start);
|
|
|
|
}
|
|
|
|
|
1998-09-15 06:36:34 +00:00
|
|
|
__END_DECLS
|
|
|
|
|
|
|
|
#endif /*_SCSI_SCSI_ALL_H*/
|