On Sun, Oct 28, 2018 at 04:49:47PM +0100, Christoph Hellwig wrote: > On Sun, Oct 28, 2018 at 08:51:31AM +0800, Ming Lei wrote: > > On Fri, Oct 26, 2018 at 09:44:15AM +0200, Christoph Hellwig wrote: > > > > if (req_sects > UINT_MAX >> 9) > > > > - req_sects = UINT_MAX >> 9; > > > > + req_sects = (UINT_MAX >> 9) & ~bs_mask; > > > > > > Given that we have this same thing duplicated in write zeroes > > > what about a documented helper? > > > > IMO, using UINT_MAX & bs_mask is better because it is self-explanatory > > in the context. > > I don't think it is in any way. I understand it because I know the > code, but there is nothing that documents why we do that. Then how about introducing this helper? /* + * The max sectors one bio can handle is 'UINT_MAX >> 9' becasue + * bvec_iter.bi_size is defined as 'unsigned int', also it has to aligned + * to with logical block size which is minimum accepted unit by hardware. + */ +static inline unsigned int blk_max_allowed_max_secotrs(struct request_queue *q) +{ + return round_down(UINT_MAX, queue_logical_block_size(q)) >> 9; +} + +/* Thanks, Ming