提交 eea9befa 编写于 作者: N NeilBrown 提交者: Jens Axboe

Fix various abuse of bio fields in umem.c

umem.c:
  advances bi_idx and bi_sector to track where it is up to.
   But it is only ever doing this on one bio, so the updated
   fields can easily be kept elsewhere (current_*).
  updates bi_size, but never uses the updated values, so
   this isn't needed.
  reuses bi_phys_segments to count how many iovecs have been
   completely.  As the completion happens sequentiually, we
   can store this information outside the bio too.
Signed-off-by: NNeil Brown <neilb@suse.de>

diff .prev/drivers/block/umem.c ./drivers/block/umem.c
Signed-off-by: NJens Axboe <jens.axboe@oracle.com>
上级 5705f702
...@@ -113,6 +113,8 @@ struct cardinfo { ...@@ -113,6 +113,8 @@ struct cardinfo {
* have been written * have been written
*/ */
struct bio *bio, *currentbio, **biotail; struct bio *bio, *currentbio, **biotail;
int current_idx;
sector_t current_sector;
struct request_queue *queue; struct request_queue *queue;
...@@ -121,6 +123,7 @@ struct cardinfo { ...@@ -121,6 +123,7 @@ struct cardinfo {
struct mm_dma_desc *desc; struct mm_dma_desc *desc;
int cnt, headcnt; int cnt, headcnt;
struct bio *bio, **biotail; struct bio *bio, **biotail;
int idx;
} mm_pages[2]; } mm_pages[2];
#define DESC_PER_PAGE ((PAGE_SIZE*2)/sizeof(struct mm_dma_desc)) #define DESC_PER_PAGE ((PAGE_SIZE*2)/sizeof(struct mm_dma_desc))
...@@ -380,12 +383,16 @@ static int add_bio(struct cardinfo *card) ...@@ -380,12 +383,16 @@ static int add_bio(struct cardinfo *card)
dma_addr_t dma_handle; dma_addr_t dma_handle;
int offset; int offset;
struct bio *bio; struct bio *bio;
struct bio_vec *vec;
int idx;
int rw; int rw;
int len; int len;
bio = card->currentbio; bio = card->currentbio;
if (!bio && card->bio) { if (!bio && card->bio) {
card->currentbio = card->bio; card->currentbio = card->bio;
card->current_idx = card->bio->bi_idx;
card->current_sector = card->bio->bi_sector;
card->bio = card->bio->bi_next; card->bio = card->bio->bi_next;
if (card->bio == NULL) if (card->bio == NULL)
card->biotail = &card->bio; card->biotail = &card->bio;
...@@ -394,15 +401,17 @@ static int add_bio(struct cardinfo *card) ...@@ -394,15 +401,17 @@ static int add_bio(struct cardinfo *card)
} }
if (!bio) if (!bio)
return 0; return 0;
idx = card->current_idx;
rw = bio_rw(bio); rw = bio_rw(bio);
if (card->mm_pages[card->Ready].cnt >= DESC_PER_PAGE) if (card->mm_pages[card->Ready].cnt >= DESC_PER_PAGE)
return 0; return 0;
len = bio_iovec(bio)->bv_len; vec = bio_iovec_idx(bio, idx);
dma_handle = pci_map_page(card->dev, len = vec->bv_len;
bio_page(bio), dma_handle = pci_map_page(card->dev,
bio_offset(bio), vec->bv_page,
vec->bv_offset,
len, len,
(rw==READ) ? (rw==READ) ?
PCI_DMA_FROMDEVICE : PCI_DMA_TODEVICE); PCI_DMA_FROMDEVICE : PCI_DMA_TODEVICE);
...@@ -410,6 +419,8 @@ static int add_bio(struct cardinfo *card) ...@@ -410,6 +419,8 @@ static int add_bio(struct cardinfo *card)
p = &card->mm_pages[card->Ready]; p = &card->mm_pages[card->Ready];
desc = &p->desc[p->cnt]; desc = &p->desc[p->cnt];
p->cnt++; p->cnt++;
if (p->bio == NULL)
p->idx = idx;
if ((p->biotail) != &bio->bi_next) { if ((p->biotail) != &bio->bi_next) {
*(p->biotail) = bio; *(p->biotail) = bio;
p->biotail = &(bio->bi_next); p->biotail = &(bio->bi_next);
...@@ -419,7 +430,7 @@ static int add_bio(struct cardinfo *card) ...@@ -419,7 +430,7 @@ static int add_bio(struct cardinfo *card)
desc->data_dma_handle = dma_handle; desc->data_dma_handle = dma_handle;
desc->pci_addr = cpu_to_le64((u64)desc->data_dma_handle); desc->pci_addr = cpu_to_le64((u64)desc->data_dma_handle);
desc->local_addr= cpu_to_le64(bio->bi_sector << 9); desc->local_addr = cpu_to_le64(card->current_sector << 9);
desc->transfer_size = cpu_to_le32(len); desc->transfer_size = cpu_to_le32(len);
offset = ( ((char*)&desc->sem_control_bits) - ((char*)p->desc)); offset = ( ((char*)&desc->sem_control_bits) - ((char*)p->desc));
desc->sem_addr = cpu_to_le64((u64)(p->page_dma+offset)); desc->sem_addr = cpu_to_le64((u64)(p->page_dma+offset));
...@@ -435,10 +446,10 @@ static int add_bio(struct cardinfo *card) ...@@ -435,10 +446,10 @@ static int add_bio(struct cardinfo *card)
desc->control_bits |= cpu_to_le32(DMASCR_TRANSFER_READ); desc->control_bits |= cpu_to_le32(DMASCR_TRANSFER_READ);
desc->sem_control_bits = desc->control_bits; desc->sem_control_bits = desc->control_bits;
bio->bi_sector += (len>>9); card->current_sector += (len >> 9);
bio->bi_size -= len; idx++;
bio->bi_idx++; card->current_idx = idx;
if (bio->bi_idx >= bio->bi_vcnt) if (idx >= bio->bi_vcnt)
card->currentbio = NULL; card->currentbio = NULL;
return 1; return 1;
...@@ -474,10 +485,12 @@ static void process_page(unsigned long data) ...@@ -474,10 +485,12 @@ static void process_page(unsigned long data)
last=1; last=1;
} }
page->headcnt++; page->headcnt++;
idx = bio->bi_phys_segments; idx = page->idx;
bio->bi_phys_segments++; page->idx++;
if (bio->bi_phys_segments >= bio->bi_vcnt) if (page->idx >= bio->bi_vcnt) {
page->bio = bio->bi_next; page->bio = bio->bi_next;
page->idx = page->bio->bi_idx;
}
pci_unmap_page(card->dev, desc->data_dma_handle, pci_unmap_page(card->dev, desc->data_dma_handle,
bio_iovec_idx(bio,idx)->bv_len, bio_iovec_idx(bio,idx)->bv_len,
...@@ -547,7 +560,6 @@ static int mm_make_request(struct request_queue *q, struct bio *bio) ...@@ -547,7 +560,6 @@ static int mm_make_request(struct request_queue *q, struct bio *bio)
pr_debug("mm_make_request %llu %u\n", pr_debug("mm_make_request %llu %u\n",
(unsigned long long)bio->bi_sector, bio->bi_size); (unsigned long long)bio->bi_sector, bio->bi_size);
bio->bi_phys_segments = bio->bi_idx; /* count of completed segments*/
spin_lock_irq(&card->lock); spin_lock_irq(&card->lock);
*card->biotail = bio; *card->biotail = bio;
bio->bi_next = NULL; bio->bi_next = NULL;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册