Author: mav
Date: Fri May  3 11:53:06 2013
New Revision: 250208
URL: http://svnweb.freebsd.org/changeset/base/250208

Log:
  Tune support for removable media in da driver:
   - remove DA_FLAG_SAW_MEDIA flag, almost opposite to DA_FLAG_PACK_INVALID,
  using the last instead.
   - allow opening device with no media present, reporting zero media size
  and non-zero sector size, as geom/notes suggests.  That allow to read
  device attributes and potentially do other things, not related to media.

Modified:
  head/sys/cam/scsi/scsi_da.c

Modified: head/sys/cam/scsi/scsi_da.c
==============================================================================
--- head/sys/cam/scsi/scsi_da.c Fri May  3 11:10:04 2013        (r250207)
+++ head/sys/cam/scsi/scsi_da.c Fri May  3 11:53:06 2013        (r250208)
@@ -82,7 +82,6 @@ typedef enum {
        DA_FLAG_NEW_PACK        = 0x002,
        DA_FLAG_PACK_LOCKED     = 0x004,
        DA_FLAG_PACK_REMOVABLE  = 0x008,
-       DA_FLAG_SAW_MEDIA       = 0x010,
        DA_FLAG_NEED_OTAG       = 0x020,
        DA_FLAG_WENT_IDLE       = 0x040,
        DA_FLAG_RETRY_UA        = 0x080,
@@ -1026,9 +1025,6 @@ daopen(struct disk *dp)
            ("daopen\n"));
 
        softc = (struct da_softc *)periph->softc;
-       softc->flags |= DA_FLAG_OPEN;
-       softc->flags &= ~DA_FLAG_PACK_INVALID;
-
        dareprobe(periph);
 
        /* Wait for the disk size update.  */
@@ -1037,25 +1033,23 @@ daopen(struct disk *dp)
        if (error != 0)
                xpt_print(periph->path, "unable to retrieve capacity data");
 
-       if (periph->flags & CAM_PERIPH_INVALID ||
-           softc->disk->d_sectorsize == 0 ||
-           softc->disk->d_mediasize == 0)
+       if (periph->flags & CAM_PERIPH_INVALID)
                error = ENXIO;
 
        if (error == 0 && (softc->flags & DA_FLAG_PACK_REMOVABLE) != 0 &&
            (softc->quirks & DA_Q_NO_PREVENT) == 0)
                daprevent(periph, PR_PREVENT);
 
-       if (error == 0)
-               softc->flags |= DA_FLAG_SAW_MEDIA;
+       if (error == 0) {
+               softc->flags &= ~DA_FLAG_PACK_INVALID;
+               softc->flags |= DA_FLAG_OPEN;
+       }
 
        cam_periph_unhold(periph);
        cam_periph_unlock(periph);
 
-       if (error != 0) {
-               softc->flags &= ~DA_FLAG_OPEN;
+       if (error != 0)
                cam_periph_release(periph);
-       }
 
        return (error);
 }
@@ -2818,9 +2812,10 @@ dadone(struct cam_periph *periph, union 
                         * here.
                         */
                        if (block_size == 0 && maxsector == 0) {
-                               snprintf(announce_buf, sizeof(announce_buf),
-                                       "0MB (no media?)");
-                       } else if (block_size >= MAXPHYS || block_size == 0) {
+                               block_size = 512;
+                               maxsector = -1;
+                       }
+                       if (block_size >= MAXPHYS || block_size == 0) {
                                xpt_print(periph->path,
                                    "unsupportable block size %ju\n",
                                    (uintmax_t) block_size);
@@ -2920,6 +2915,7 @@ dadone(struct cam_periph *periph, union 
                                        const char *sense_key_desc;
                                        const char *asc_desc;
 
+                                       dasetgeom(periph, 512, -1, NULL, 0);
                                        scsi_sense_desc(sense_key, asc, ascq,
                                                        &cgd.inq_data,
                                                        &sense_key_desc,
@@ -3297,8 +3293,8 @@ daerror(union ccb *ccb, u_int32_t cam_fl
                    asc == 0x28 && ascq == 0x00)
                        disk_media_changed(softc->disk, M_NOWAIT);
                else if (sense_key == SSD_KEY_NOT_READY &&
-                   asc == 0x3a && (softc->flags & DA_FLAG_SAW_MEDIA)) {
-                       softc->flags &= ~DA_FLAG_SAW_MEDIA;
+                   asc == 0x3a && (softc->flags & DA_FLAG_PACK_INVALID) == 0) {
+                       softc->flags |= DA_FLAG_PACK_INVALID;
                        disk_media_gone(softc->disk, M_NOWAIT);
                }
        }
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to