Lines Matching full:plug
876 * first place, directly accessing the plug instead of using in bio_poll()
880 blk_flush_plug(current->plug, false); in bio_poll()
1050 void blk_start_plug_nr_ios(struct blk_plug *plug, unsigned short nr_ios) in blk_start_plug_nr_ios() argument
1055 * If this is a nested plug, don't actually assign it. in blk_start_plug_nr_ios()
1057 if (tsk->plug) in blk_start_plug_nr_ios()
1060 plug->mq_list = NULL; in blk_start_plug_nr_ios()
1061 plug->cached_rq = NULL; in blk_start_plug_nr_ios()
1062 plug->nr_ios = min_t(unsigned short, nr_ios, BLK_MAX_REQUEST_COUNT); in blk_start_plug_nr_ios()
1063 plug->rq_count = 0; in blk_start_plug_nr_ios()
1064 plug->multiple_queues = false; in blk_start_plug_nr_ios()
1065 plug->has_elevator = false; in blk_start_plug_nr_ios()
1066 INIT_LIST_HEAD(&plug->cb_list); in blk_start_plug_nr_ios()
1072 tsk->plug = plug; in blk_start_plug_nr_ios()
1077 * @plug: The &struct blk_plug that needs to be initialized
1095 * plug. By flushing the pending I/O when the process goes to sleep, we avoid
1098 void blk_start_plug(struct blk_plug *plug) in blk_start_plug() argument
1100 blk_start_plug_nr_ios(plug, 1); in blk_start_plug()
1104 static void flush_plug_callbacks(struct blk_plug *plug, bool from_schedule) in flush_plug_callbacks() argument
1108 while (!list_empty(&plug->cb_list)) { in flush_plug_callbacks()
1109 list_splice_init(&plug->cb_list, &callbacks); in flush_plug_callbacks()
1124 struct blk_plug *plug = current->plug; in blk_check_plugged() local
1127 if (!plug) in blk_check_plugged()
1130 list_for_each_entry(cb, &plug->cb_list, list) in blk_check_plugged()
1140 list_add(&cb->list, &plug->cb_list); in blk_check_plugged()
1146 void __blk_flush_plug(struct blk_plug *plug, bool from_schedule) in __blk_flush_plug() argument
1148 if (!list_empty(&plug->cb_list)) in __blk_flush_plug()
1149 flush_plug_callbacks(plug, from_schedule); in __blk_flush_plug()
1150 blk_mq_flush_plug_list(plug, from_schedule); in __blk_flush_plug()
1157 if (unlikely(!rq_list_empty(plug->cached_rq))) in __blk_flush_plug()
1158 blk_mq_free_plug_rqs(plug); in __blk_flush_plug()
1163 * @plug: The &struct blk_plug passed to blk_start_plug()
1171 void blk_finish_plug(struct blk_plug *plug) in blk_finish_plug() argument
1173 if (plug == current->plug) { in blk_finish_plug()
1174 __blk_flush_plug(plug, false); in blk_finish_plug()
1175 current->plug = NULL; in blk_finish_plug()