本篇內(nèi)容介紹了“l(fā)inux中blk函數(shù)的用法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)專注于泉山企業(yè)網(wǎng)站建設,響應式網(wǎng)站設計,商城建設。泉山網(wǎng)站建設公司,為泉山等地區(qū)提供建站服務。全流程定制設計,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務
int blk_rq_append_bio(struct request *rq, struct bio *bio) { if (!rq->bio) { //yyf: rq中無bio時 blk_rq_bio_prep(rq->q, rq, bio); } else { if (!ll_back_merge_fn(rq->q, rq, bio)) return -EINVAL; rq->biotail->bi_next = bio; rq->biotail = bio; rq->__data_len += bio->bi_iter.bi_size; } return 0; } EXPORT_SYMBOL(blk_rq_append_bio);
blk_rq_append_bio的功能是掛個bio到rq,如果rq中已經(jīng)存在bio了,則直接更新rq->biotail指向的最后一個bio的bi_next指針,并更新biotail指針和__data_len長度。
當rq中無bio時,執(zhí)行blk_rq_bio_prep函數(shù):
void blk_rq_bio_prep(struct request_queue *q, struct request *rq, struct bio *bio) { if (bio_has_data(bio)) //yyf: 如果有數(shù)據(jù)的話,則賦值rq的nr_phys_segments rq->nr_phys_segments = bio_phys_segments(q, bio); rq->__data_len = bio->bi_iter.bi_size; rq->bio = rq->biotail = bio; //yyf: bio掛入rq鏈表 if (bio->bi_bdev) rq->rq_disk = bio->bi_bdev->bd_disk; }
bio_has_data判斷bio是否攜帶數(shù)據(jù),在
/* * Check whether this bio carries any data or not. A NULL bio is allowed. */ static inline bool bio_has_data(struct bio *bio) { if (bio && bio->bi_iter.bi_size && bio_op(bio) != REQ_OP_DISCARD && bio_op(bio) != REQ_OP_SECURE_ERASE && bio_op(bio) != REQ_OP_WRITE_ZEROES) return true; return false; }
bio_has_data函數(shù)很簡單,就是判斷bio是否存在,是否有bi_size,是否滿足一定的操作命令。
“l(fā)inux中blk函數(shù)的用法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!