mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 06:44:00 -04:00
Merge branch 'for-7.0/blk-pvec' into for-7.0/block
* for-7.0/blk-pvec: types: move phys_vec definition to common header nvme-pci: Use size_t for length fields to handle larger sizes
This commit is contained in:
@@ -6,11 +6,6 @@
|
||||
#include <linux/blk-mq-dma.h>
|
||||
#include "blk.h"
|
||||
|
||||
struct phys_vec {
|
||||
phys_addr_t paddr;
|
||||
u32 len;
|
||||
};
|
||||
|
||||
static bool __blk_map_iter_next(struct blk_map_iter *iter)
|
||||
{
|
||||
if (iter->iter.bi_size)
|
||||
@@ -112,8 +107,8 @@ static bool blk_rq_dma_map_iova(struct request *req, struct device *dma_dev,
|
||||
struct phys_vec *vec)
|
||||
{
|
||||
enum dma_data_direction dir = rq_dma_dir(req);
|
||||
unsigned int mapped = 0;
|
||||
unsigned int attrs = 0;
|
||||
size_t mapped = 0;
|
||||
int error;
|
||||
|
||||
iter->addr = state->addr;
|
||||
@@ -296,6 +291,8 @@ int __blk_rq_map_sg(struct request *rq, struct scatterlist *sglist,
|
||||
blk_rq_map_iter_init(rq, &iter);
|
||||
while (blk_map_iter_next(rq, &iter, &vec)) {
|
||||
*last_sg = blk_next_sg(last_sg, sglist);
|
||||
|
||||
WARN_ON_ONCE(overflows_type(vec.len, unsigned int));
|
||||
sg_set_page(*last_sg, phys_to_page(vec.paddr), vec.len,
|
||||
offset_in_page(vec.paddr));
|
||||
nsegs++;
|
||||
@@ -416,6 +413,8 @@ int blk_rq_map_integrity_sg(struct request *rq, struct scatterlist *sglist)
|
||||
|
||||
while (blk_map_iter_next(rq, &iter, &vec)) {
|
||||
sg = blk_next_sg(&sg, sglist);
|
||||
|
||||
WARN_ON_ONCE(overflows_type(vec.len, unsigned int));
|
||||
sg_set_page(sg, phys_to_page(vec.paddr), vec.len,
|
||||
offset_in_page(vec.paddr));
|
||||
segments++;
|
||||
|
||||
@@ -290,14 +290,14 @@ struct nvme_iod {
|
||||
u8 flags;
|
||||
u8 nr_descriptors;
|
||||
|
||||
unsigned int total_len;
|
||||
size_t total_len;
|
||||
struct dma_iova_state dma_state;
|
||||
void *descriptors[NVME_MAX_NR_DESCRIPTORS];
|
||||
struct nvme_dma_vec *dma_vecs;
|
||||
unsigned int nr_dma_vecs;
|
||||
|
||||
dma_addr_t meta_dma;
|
||||
unsigned int meta_total_len;
|
||||
size_t meta_total_len;
|
||||
struct dma_iova_state meta_dma_state;
|
||||
struct nvme_sgl_desc *meta_descriptor;
|
||||
};
|
||||
|
||||
@@ -171,6 +171,11 @@ typedef u64 phys_addr_t;
|
||||
typedef u32 phys_addr_t;
|
||||
#endif
|
||||
|
||||
struct phys_vec {
|
||||
phys_addr_t paddr;
|
||||
size_t len;
|
||||
};
|
||||
|
||||
typedef phys_addr_t resource_size_t;
|
||||
|
||||
/*
|
||||
|
||||
Reference in New Issue
Block a user