summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormr <mr@FreeBSD.org>2002-11-08 07:57:42 +0000
committermr <mr@FreeBSD.org>2002-11-08 07:57:42 +0000
commit10ff71fdf9be08498de18fdf0adf3f48c688ed06 (patch)
tree00380518b2d29d425baa1334f1003fa4763911dc
parent1f976473deb023b28f8d914b12a5ddfc12446be6 (diff)
downloadFreeBSD-src-10ff71fdf9be08498de18fdf0adf3f48c688ed06.zip
FreeBSD-src-10ff71fdf9be08498de18fdf0adf3f48c688ed06.tar.gz
Reviewed by: n_hibma
MFC after: 2 weeks fix XPT_CALC_GEOMETRY to fill in some reasonable values. Inspired by aic/sbp.
-rw-r--r--sys/dev/usb/umass.c24
1 files changed, 16 insertions, 8 deletions
diff --git a/sys/dev/usb/umass.c b/sys/dev/usb/umass.c
index cfd167c..a491431 100644
--- a/sys/dev/usb/umass.c
+++ b/sys/dev/usb/umass.c
@@ -2450,16 +2450,24 @@ umass_cam_action(struct cam_sim *sim, union ccb *ccb)
}
case XPT_CALC_GEOMETRY:
{
-#ifdef USB_DEBUG
struct ccb_calc_geometry *ccg = &ccb->ccg;
-#endif
- DPRINTF(UDMASS_SCSI, ("%s:%d:%d:%d:XPT_CALC_GEOMETRY: "
- "Volume size = %d (unimplemented)\n",
- USBDEVNAME(sc->sc_dev), cam_sim_path(umass_sim),
- ccb->ccb_h.target_id, ccb->ccb_h.target_lun,
- ccg->volume_size));
+ u_int32_t size_mb;
+ u_int32_t secs_per_cylinder;
+ int extended = 1;
- ccb->ccb_h.status = CAM_REQ_CMP_ERR;
+ size_mb = ccg->volume_size
+ / ((1024L * 1024L) / ccg->block_size);
+
+ if (size_mb >= 1024 && extended) {
+ ccg->heads = 255;
+ ccg->secs_per_track = 63;
+ } else {
+ ccg->heads = 64;
+ ccg->secs_per_track = 32;
+ }
+ secs_per_cylinder = ccg->heads * ccg->secs_per_track;
+ ccg->cylinders = ccg->volume_size / secs_per_cylinder;
+ ccb->ccb_h.status = CAM_REQ_CMP;
xpt_done(ccb);
break;
OpenPOWER on IntegriCloud