diff options
| author | Doug Rabson <dfr@FreeBSD.org> | 2002-04-06 12:55:48 +0000 |
|---|---|---|
| committer | Doug Rabson <dfr@FreeBSD.org> | 2002-04-06 12:55:48 +0000 |
| commit | ce5c49f1aa4e893be7c21f4fe5e5748bcad08066 (patch) | |
| tree | 583c32705a40683d683d10eb5b66c10ee0f7860b /sys | |
| parent | 9ad42ab5944b9ea39e826615a327a2fbf0c4e115 (diff) | |
Notes
Diffstat (limited to 'sys')
| -rw-r--r-- | sys/ia64/include/param.h | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/sys/ia64/include/param.h b/sys/ia64/include/param.h index db8761973987..a516325839aa 100644 --- a/sys/ia64/include/param.h +++ b/sys/ia64/include/param.h @@ -185,9 +185,16 @@ #define ctob(x) ((x) << PAGE_SHIFT) #define btoc(x) (((x) + PAGE_MASK) >> PAGE_SHIFT) -/* bytes to disk blocks */ -#define btodb(x) ((x) >> DEV_BSHIFT) -#define dbtob(x) ((x) << DEV_BSHIFT) +/* + * btodb() is messy and perhaps slow because `bytes' may be an off_t. We + * want to shift an unsigned type to avoid sign extension and we don't + * want to widen `bytes' unnecessarily. Assume that the result fits in + * a daddr_t. + */ +#define btodb(bytes) /* calculates (bytes / DEV_BSIZE) */ \ + (daddr_t)((unsigned long)(bytes) >> DEV_BSHIFT) +#define dbtob(db) /* calculates (db * DEV_BSIZE) */ \ + ((off_t)(db) << DEV_BSHIFT) /* * Mach derived conversion macros |
