============================ struct request documentation ============================ Jens Axboe <jens.axboe@oracle.com> 27/05/02 .. FIXME: No idea about what does mean - seems just some noise, so comment it 1.0 Index 2.0 Struct request members classification 2.1 struct request members explanation 3.0 2.0 Short explanation of request members ==================================== Classification flags: = ==================== D driver member B block layer member I I/O scheduler member = ==================== Unless an entry contains a D classification, a device driver must not access this member. Some members may contain D classifications, but should only be access through certain macros or functions (eg ->flags). <linux/blkdev.h> =============================== ======= ======================================= Member Flag Comment =============================== ======= ======================================= struct list_head queuelist BI Organization on various internal queues ``void *elevator_private`` I I/O scheduler private data unsigned char cmd[16] D Driver can use this for setting up a cdb before execution, see blk_queue_prep_rq unsigned long flags DBI Contains info about data direction, request type, etc. int rq_status D Request status bits kdev_t rq_dev DBI Target device int errors DB Error counts sector_t sector DBI Target location unsigned long hard_nr_sectors B Used to keep sector sane unsigned long nr_sectors DBI Total number of sectors in request unsigned long hard_nr_sectors B Used to keep nr_sectors sane unsigned short nr_phys_segments DB Number of physical scatter gather segments in a request unsigned short nr_hw_segments DB Number of hardware scatter gather segments in a request unsigned int current_nr_sectors DB Number of sectors in first segment of request unsigned int hard_cur_sectors B Used to keep current_nr_sectors sane int tag DB TCQ tag, if assigned ``void *special`` D Free to be used by driver ``char *buffer`` D Map of first segment, also see section on bouncing SECTION ``struct completion *waiting`` D Can be used by driver to get signalled on request completion ``struct bio *bio`` DBI First bio in request ``struct bio *biotail`` DBI Last bio in request ``struct request_queue *q`` DB Request queue this request belongs to ``struct request_list *rl`` B Request list this request came from =============================== ======= =======================================