This patch adds CAM pass(4) support for NVMe IO's. Applications indicate the IO type (Admin or NVM) using bit 4 of the xflags variable in struct ccb_nvmeio.ccb_h XPT op-codes XPT_NVME_ADMIN or XPT_NVME_IO.
Details
Tested pass-through of both NVM and Admin commands via cam_send_ccb and NVM Read/Write commands via camdd(8)
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
Lint Skipped - Unit
Tests Skipped
Event Timeline
sys/cam/scsi/scsi_pass.c | ||
---|---|---|
2185 | Being the first person to need xflags copied to the new ccb raised the question in my mind as to whether this was the correct approach | |
sys/dev/nvme/nvme_sim.c | ||
113 | Bit 4 (i.e. 0x10) appeared to be the first unused bit in xflags and is used to differentiate between Admin commands (bit 4 set) and NVM commands (bit 4 clear). As I wasn't sure about the approach, I didn't create a #define for it at this time. |
sys/cam/scsi/scsi_pass.c | ||
---|---|---|
2185 | We should get other people's notions as well (Scott Long maybe). How would this be used in the kernel to allow access to the admin queue from CAM devices. Most of the stuff we have today won't need an in-kernel consumer, but it's instructive to think of it that way. | |
sys/dev/nvme/nvme_sim.c | ||
113 | Yea, that was the point of my rather cryptic, mysterious comment :) |
This is v2 of the patch based on feedback / discussions on freebsd-scsi to use different XPT op-codes for NVMe Admin and NVM commands instead of the original xflags approach.
This needs a case added to passmemsetup() and the CAMIOQUEUE case in passdoioctl() in the pass(4) driver so that asynchronous I/O will work for NVMe devices.
If you want a test case, you could add NVMe support to camdd(8), but that may be more work than you're signing up for. :)
v3 of the patch adds the missing changes to passmemsetup() and passdoioctl() as noted in the previous review.