aboutsummaryrefslogtreecommitdiff
path: root/sys/cam/cam.c
diff options
context:
space:
mode:
authorMatt Jacob <mjacob@FreeBSD.org>2006-04-18 21:53:39 +0000
committerMatt Jacob <mjacob@FreeBSD.org>2006-04-18 21:53:39 +0000
commitbae3cbf07571314ab5122f6dcba83550c55d6abd (patch)
tree964060dcf107ec18c7c874591ddae4e755351e9f /sys/cam/cam.c
parent2901a7b7d43d84e30da27442d7687ed439761a97 (diff)
downloadsrc-bae3cbf07571314ab5122f6dcba83550c55d6abd.tar.gz
src-bae3cbf07571314ab5122f6dcba83550c55d6abd.zip
Do more guarding against zero divide traps for the geom subroutine.
Notes
Notes: svn path=/head/; revision=157854
Diffstat (limited to 'sys/cam/cam.c')
-rw-r--r--sys/cam/cam.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/sys/cam/cam.c b/sys/cam/cam.c
index 9fbdac78907e..cc438bf970f8 100644
--- a/sys/cam/cam.c
+++ b/sys/cam/cam.c
@@ -373,7 +373,16 @@ cam_calc_geometry(struct ccb_calc_geometry *ccg, int extended)
{
uint32_t size_mb, secs_per_cylinder;
- size_mb = ccg->volume_size / ((1024L * 1024L) / ccg->block_size);
+ if (ccg->block_size == 0) {
+ ccg->ccb_h.status = CAM_REQ_CMP_ERR;
+ return;
+ }
+ size_mb = (1024L * 1024L) / ccg->block_size;
+ if (size_mb == 0) {
+ ccg->ccb_h.status = CAM_REQ_CMP_ERR;
+ return;
+ }
+ size_mb = ccg->volume_size / size_mb;
if (size_mb > 1024 && extended) {
ccg->heads = 255;
ccg->secs_per_track = 63;
@@ -382,6 +391,10 @@ cam_calc_geometry(struct ccb_calc_geometry *ccg, int extended)
ccg->secs_per_track = 32;
}
secs_per_cylinder = ccg->heads * ccg->secs_per_track;
+ if (secs_per_cylinder == 0) {
+ ccg->ccb_h.status = CAM_REQ_CMP_ERR;
+ return;
+ }
ccg->cylinders = ccg->volume_size / secs_per_cylinder;
ccg->ccb_h.status = CAM_REQ_CMP;
}