summaryrefslogtreecommitdiffstats
path: root/sys/dev/arcmsr/arcmsr.c
diff options
context:
space:
mode:
authormarius <marius@FreeBSD.org>2011-11-23 21:43:51 +0000
committermarius <marius@FreeBSD.org>2011-11-23 21:43:51 +0000
commitc5cf0f6b20206d14255b5200ec08705a768ac451 (patch)
tree07604949d086d79c0b4929545a210d0cc779bb03 /sys/dev/arcmsr/arcmsr.c
parent0f30a4cf8906e3cbfa5895b21f8f9232f17e39bb (diff)
downloadFreeBSD-src-c5cf0f6b20206d14255b5200ec08705a768ac451.zip
FreeBSD-src-c5cf0f6b20206d14255b5200ec08705a768ac451.tar.gz
- Just use cam_calc_geometry(9) on newer version of FreeBSD rather than
duplicating it. - In hptmv(4) and hptrr(4) use __FBSDID and DEVMETHOD_END.
Diffstat (limited to 'sys/dev/arcmsr/arcmsr.c')
-rw-r--r--sys/dev/arcmsr/arcmsr.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/sys/dev/arcmsr/arcmsr.c b/sys/dev/arcmsr/arcmsr.c
index b672176..9fde306 100644
--- a/sys/dev/arcmsr/arcmsr.c
+++ b/sys/dev/arcmsr/arcmsr.c
@@ -2714,16 +2714,20 @@ static void arcmsr_action(struct cam_sim * psim, union ccb * pccb)
xpt_done(pccb);
break;
}
- case XPT_CALC_GEOMETRY: {
- struct ccb_calc_geometry *ccg;
- u_int32_t size_mb;
- u_int32_t secs_per_cylinder;
-
+ case XPT_CALC_GEOMETRY:
if(pccb->ccb_h.target_id == 16) {
pccb->ccb_h.status |= CAM_FUNC_NOTAVAIL;
xpt_done(pccb);
break;
}
+#if __FreeBSD_version >= 500000
+ cam_calc_geometry(&pccb->ccg, 1);
+#else
+ {
+ struct ccb_calc_geometry *ccg;
+ u_int32_t size_mb;
+ u_int32_t secs_per_cylinder;
+
ccg= &pccb->ccg;
if (ccg->block_size == 0) {
pccb->ccb_h.status = CAM_REQ_INVALID;
@@ -2746,9 +2750,10 @@ static void arcmsr_action(struct cam_sim * psim, union ccb * pccb)
secs_per_cylinder=ccg->heads * ccg->secs_per_track;
ccg->cylinders=ccg->volume_size / secs_per_cylinder;
pccb->ccb_h.status |= CAM_REQ_CMP;
+ }
+#endif
xpt_done(pccb);
break;
- }
default:
pccb->ccb_h.status |= CAM_REQ_INVALID;
xpt_done(pccb);
OpenPOWER on IntegriCloud