diff options
Diffstat (limited to 'include/linux/blkdev.h')
| -rw-r--r-- | include/linux/blkdev.h | 30 | 
1 files changed, 22 insertions, 8 deletions
| diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index 4571ef1a12a9..7e5d7e018bea 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h @@ -499,7 +499,8 @@ struct request_queue {  #define QUEUE_FLAG_MQ_DEFAULT	((1 << QUEUE_FLAG_IO_STAT) |		\  				 (1 << QUEUE_FLAG_STACKABLE)	|	\ -				 (1 << QUEUE_FLAG_SAME_COMP)) +				 (1 << QUEUE_FLAG_SAME_COMP)	|	\ +				 (1 << QUEUE_FLAG_POLL))  static inline void queue_lockdep_assert_held(struct request_queue *q)  { @@ -895,7 +896,7 @@ static inline unsigned int blk_rq_get_max_sectors(struct request *rq)  {  	struct request_queue *q = rq->q; -	if (unlikely(rq->cmd_type == REQ_TYPE_BLOCK_PC)) +	if (unlikely(rq->cmd_type != REQ_TYPE_FS))  		return q->limits.max_hw_sectors;  	if (!q->limits.chunk_sectors || (rq->cmd_flags & REQ_DISCARD)) @@ -1029,6 +1030,7 @@ extern int blk_pre_runtime_suspend(struct request_queue *q);  extern void blk_post_runtime_suspend(struct request_queue *q, int err);  extern void blk_pre_runtime_resume(struct request_queue *q);  extern void blk_post_runtime_resume(struct request_queue *q, int err); +extern void blk_set_runtime_active(struct request_queue *q);  #else  static inline void blk_pm_runtime_init(struct request_queue *q,  	struct device *dev) {} @@ -1039,6 +1041,7 @@ static inline int blk_pre_runtime_suspend(struct request_queue *q)  static inline void blk_post_runtime_suspend(struct request_queue *q, int err) {}  static inline void blk_pre_runtime_resume(struct request_queue *q) {}  static inline void blk_post_runtime_resume(struct request_queue *q, int err) {} +extern inline void blk_set_runtime_active(struct request_queue *q) {}  #endif  /* @@ -1372,6 +1375,13 @@ static inline void put_dev_sector(Sector p)  	page_cache_release(p.v);  } +static inline bool __bvec_gap_to_prev(struct request_queue *q, +				struct bio_vec *bprv, unsigned int offset) +{ +	return offset || +		((bprv->bv_offset + bprv->bv_len) & queue_virt_boundary(q)); +} +  /*   * Check if adding a bio_vec after bprv with offset would create a gap in   * the SG list. Most drivers don't care about this, but some do. @@ -1381,18 +1391,22 @@ static inline bool bvec_gap_to_prev(struct request_queue *q,  {  	if (!queue_virt_boundary(q))  		return false; -	return offset || -		((bprv->bv_offset + bprv->bv_len) & queue_virt_boundary(q)); +	return __bvec_gap_to_prev(q, bprv, offset);  }  static inline bool bio_will_gap(struct request_queue *q, struct bio *prev,  			 struct bio *next)  { -	if (!bio_has_data(prev)) -		return false; +	if (bio_has_data(prev) && queue_virt_boundary(q)) { +		struct bio_vec pb, nb; + +		bio_get_last_bvec(prev, &pb); +		bio_get_first_bvec(next, &nb); -	return bvec_gap_to_prev(q, &prev->bi_io_vec[prev->bi_vcnt - 1], -				next->bi_io_vec[0].bv_offset); +		return __bvec_gap_to_prev(q, &pb, nb.bv_offset); +	} + +	return false;  }  static inline bool req_gap_back_merge(struct request *req, struct bio *bio) |