Actually, ~0 is fine. This is because of the associativity of events 
happening. Breaking it down into individual ops as the compiler sees it:
1) constant 0 -> int type
2) ~0 -> (int)-1
3) assign to larger type sector_t -> sign extend smaller type to size of 
larger type -> (sector_t)-1
Therefore not specifying anything after the initial constant definition 
_always_ works because of sign extension and the order of evaluation which 
is guaranteed by the C language.
OTOH if you hard code 0U or 0L or 0UL or whatever it breaks because it 
forces the compiler not to sign extend and assume this to be a hardvalue, 
which is zero extended.
Note I just tried all possible combinations with a little test program and 
both assignments and binary operators work as expected (with sign 
extension) when the constant is given without qualifiers and both break 
horribly (no sign extension) when the constant is given with qualifiers.
I did this testing for another reason, and that is PAGE_MASK and 
PAGE_CACHE_MASK which break when used for 64-bit values on 32-bit 
architectures exactly for the above outlined reasons.
If no one beats me to it I will submit a patch to change PAGE_SIZE (and 
thus automatically PAGE_CACHE_SIZE) on all architectures to no longer use 
the "UL" type qualifier which is responsible for the breakage. This 
supersedes my previous ugly patch introducing a PAGE_{CACHE_,}MASK_LL...
Best regards,
         Anton
-- "I've not lost my mind. It's backed up on tape somewhere." - Unknown-- Anton Altaparmakov <aia21 at cantab.net> (replace at with @) Linux NTFS Maintainer / IRC: #ntfs on irc.openprojects.net WWW: http://linux-ntfs.sf.net/ & http://www-stu.christs.cam.ac.uk/~aia21/- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/