diff options
-rw-r--r-- | drivers/block/nvme-core.c | 55 | ||||
-rw-r--r-- | include/linux/nvme.h | 60 |
2 files changed, 60 insertions, 55 deletions
diff --git a/drivers/block/nvme-core.c b/drivers/block/nvme-core.c index 26e266072079..1f98040cf677 100644 --- a/drivers/block/nvme-core.c +++ b/drivers/block/nvme-core.c | |||
@@ -46,7 +46,6 @@ | |||
46 | #define SQ_SIZE(depth) (depth * sizeof(struct nvme_command)) | 46 | #define SQ_SIZE(depth) (depth * sizeof(struct nvme_command)) |
47 | #define CQ_SIZE(depth) (depth * sizeof(struct nvme_completion)) | 47 | #define CQ_SIZE(depth) (depth * sizeof(struct nvme_completion)) |
48 | #define NVME_MINORS 64 | 48 | #define NVME_MINORS 64 |
49 | #define NVME_IO_TIMEOUT (5 * HZ) | ||
50 | #define ADMIN_TIMEOUT (60 * HZ) | 49 | #define ADMIN_TIMEOUT (60 * HZ) |
51 | 50 | ||
52 | static int nvme_major; | 51 | static int nvme_major; |
@@ -60,44 +59,6 @@ static LIST_HEAD(dev_list); | |||
60 | static struct task_struct *nvme_thread; | 59 | static struct task_struct *nvme_thread; |
61 | 60 | ||
62 | /* | 61 | /* |
63 | * Represents an NVM Express device. Each nvme_dev is a PCI function. | ||
64 | */ | ||
65 | struct nvme_dev { | ||
66 | struct list_head node; | ||
67 | struct nvme_queue **queues; | ||
68 | u32 __iomem *dbs; | ||
69 | struct pci_dev *pci_dev; | ||
70 | struct dma_pool *prp_page_pool; | ||
71 | struct dma_pool *prp_small_pool; | ||
72 | int instance; | ||
73 | int queue_count; | ||
74 | int db_stride; | ||
75 | u32 ctrl_config; | ||
76 | struct msix_entry *entry; | ||
77 | struct nvme_bar __iomem *bar; | ||
78 | struct list_head namespaces; | ||
79 | char serial[20]; | ||
80 | char model[40]; | ||
81 | char firmware_rev[8]; | ||
82 | u32 max_hw_sectors; | ||
83 | u16 oncs; | ||
84 | }; | ||
85 | |||
86 | /* | ||
87 | * An NVM Express namespace is equivalent to a SCSI LUN | ||
88 | */ | ||
89 | struct nvme_ns { | ||
90 | struct list_head list; | ||
91 | |||
92 | struct nvme_dev *dev; | ||
93 | struct request_queue *queue; | ||
94 | struct gendisk *disk; | ||
95 | |||
96 | int ns_id; | ||
97 | int lba_shift; | ||
98 | }; | ||
99 | |||
100 | /* | ||
101 | * An NVM Express queue. Each device has at least two (one for admin | 62 | * An NVM Express queue. Each device has at least two (one for admin |
102 | * commands and one for I/O commands). | 63 | * commands and one for I/O commands). |
103 | */ | 64 | */ |
@@ -295,22 +256,6 @@ static int nvme_submit_cmd(struct nvme_queue *nvmeq, struct nvme_command *cmd) | |||
295 | return 0; | 256 | return 0; |
296 | } | 257 | } |
297 | 258 | ||
298 | /* | ||
299 | * The nvme_iod describes the data in an I/O, including the list of PRP | ||
300 | * entries. You can't see it in this data structure because C doesn't let | ||
301 | * me express that. Use nvme_alloc_iod to ensure there's enough space | ||
302 | * allocated to store the PRP list. | ||
303 | */ | ||
304 | struct nvme_iod { | ||
305 | void *private; /* For the use of the submitter of the I/O */ | ||
306 | int npages; /* In the PRP list. 0 means small pool in use */ | ||
307 | int offset; /* Of PRP list */ | ||
308 | int nents; /* Used in scatterlist */ | ||
309 | int length; /* Of data, in bytes */ | ||
310 | dma_addr_t first_dma; | ||
311 | struct scatterlist sg[0]; | ||
312 | }; | ||
313 | |||
314 | static __le64 **iod_list(struct nvme_iod *iod) | 259 | static __le64 **iod_list(struct nvme_iod *iod) |
315 | { | 260 | { |
316 | return ((void *)iod) + iod->offset; | 261 | return ((void *)iod) + iod->offset; |
diff --git a/include/linux/nvme.h b/include/linux/nvme.h index bde44c1fd213..6f899add14ab 100644 --- a/include/linux/nvme.h +++ b/include/linux/nvme.h | |||
@@ -493,4 +493,64 @@ struct nvme_admin_cmd { | |||
493 | #define NVME_IOCTL_ADMIN_CMD _IOWR('N', 0x41, struct nvme_admin_cmd) | 493 | #define NVME_IOCTL_ADMIN_CMD _IOWR('N', 0x41, struct nvme_admin_cmd) |
494 | #define NVME_IOCTL_SUBMIT_IO _IOW('N', 0x42, struct nvme_user_io) | 494 | #define NVME_IOCTL_SUBMIT_IO _IOW('N', 0x42, struct nvme_user_io) |
495 | 495 | ||
496 | #ifdef __KERNEL__ | ||
497 | #include <linux/pci.h> | ||
498 | |||
499 | #define NVME_IO_TIMEOUT (5 * HZ) | ||
500 | |||
501 | /* | ||
502 | * Represents an NVM Express device. Each nvme_dev is a PCI function. | ||
503 | */ | ||
504 | struct nvme_dev { | ||
505 | struct list_head node; | ||
506 | struct nvme_queue **queues; | ||
507 | u32 __iomem *dbs; | ||
508 | struct pci_dev *pci_dev; | ||
509 | struct dma_pool *prp_page_pool; | ||
510 | struct dma_pool *prp_small_pool; | ||
511 | int instance; | ||
512 | int queue_count; | ||
513 | int db_stride; | ||
514 | u32 ctrl_config; | ||
515 | struct msix_entry *entry; | ||
516 | struct nvme_bar __iomem *bar; | ||
517 | struct list_head namespaces; | ||
518 | char serial[20]; | ||
519 | char model[40]; | ||
520 | char firmware_rev[8]; | ||
521 | u32 max_hw_sectors; | ||
522 | u16 oncs; | ||
523 | }; | ||
524 | |||
525 | /* | ||
526 | * An NVM Express namespace is equivalent to a SCSI LUN | ||
527 | */ | ||
528 | struct nvme_ns { | ||
529 | struct list_head list; | ||
530 | |||
531 | struct nvme_dev *dev; | ||
532 | struct request_queue *queue; | ||
533 | struct gendisk *disk; | ||
534 | |||
535 | int ns_id; | ||
536 | int lba_shift; | ||
537 | }; | ||
538 | |||
539 | /* | ||
540 | * The nvme_iod describes the data in an I/O, including the list of PRP | ||
541 | * entries. You can't see it in this data structure because C doesn't let | ||
542 | * me express that. Use nvme_alloc_iod to ensure there's enough space | ||
543 | * allocated to store the PRP list. | ||
544 | */ | ||
545 | struct nvme_iod { | ||
546 | void *private; /* For the use of the submitter of the I/O */ | ||
547 | int npages; /* In the PRP list. 0 means small pool in use */ | ||
548 | int offset; /* Of PRP list */ | ||
549 | int nents; /* Used in scatterlist */ | ||
550 | int length; /* Of data, in bytes */ | ||
551 | dma_addr_t first_dma; | ||
552 | struct scatterlist sg[0]; | ||
553 | }; | ||
554 | #endif | ||
555 | |||
496 | #endif /* _LINUX_NVME_H */ | 556 | #endif /* _LINUX_NVME_H */ |