aboutsummaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMichael Reifenberger <mr@FreeBSD.org>2002-11-08 07:57:42 +0000
committerMichael Reifenberger <mr@FreeBSD.org>2002-11-08 07:57:42 +0000
commitad59e7ecbda8af44836c31126bfbefddbc2f4bc0 (patch)
tree00380518b2d29d425baa1334f1003fa4763911dc /sys/dev
parent6f3a9df298a3b3cabd0a3a2d767a039f78e0cd5a (diff)
downloadsrc-ad59e7ecbda8af44836c31126bfbefddbc2f4bc0.tar.gz
src-ad59e7ecbda8af44836c31126bfbefddbc2f4bc0.zip
Reviewed by: n_hibma
MFC after: 2 weeks fix XPT_CALC_GEOMETRY to fill in some reasonable values. Inspired by aic/sbp.
Notes
Notes: svn path=/head/; revision=106615
Diffstat (limited to 'sys/dev')
-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 cfd167c98060..a49143156efb 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;