Page MenuHomeFreeBSD

nvme_xpt: Tidy nvme_announce_periph for fabrics support.
ClosedPublic

Authored by jhb on Jun 20 2023, 5:58 AM.
Tags
None
Referenced Files
F108434552: D40618.id123802.diff
Fri, Jan 24, 5:58 PM
Unknown Object (File)
Fri, Jan 10, 8:50 PM
Unknown Object (File)
Mon, Dec 30, 4:44 AM
Unknown Object (File)
Dec 21 2024, 12:28 PM
Unknown Object (File)
Dec 9 2024, 5:37 AM
Unknown Object (File)
Oct 10 2024, 3:36 AM
Unknown Object (File)
Oct 2 2024, 4:33 PM
Unknown Object (File)
Oct 2 2024, 4:24 PM
Subscribers

Details

Summary
  • Read the version from cts.protocol_version.
  • Only check xport_specific.nvme for PCI-e info for XPORT_NVME.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 52154
Build 49045: arc lint + arc unit

Event Timeline

jhb requested review of this revision.Jun 20 2023, 5:58 AM

Ah, this explains an earlier comment.

Will fabrics have a different protocol specific field for the cts? If not, why bother being careful here? I've not seen that code so I don't know, but it would seem a bit odd if it did, though most of nvme_xpt doesn't care... the only other place is in nvme_device_transport which sets the .valid fields to 0 before calling XPT_SET_TRAN_SETTINGS

Also, side note: I think we should be setting max_xfer where I tagged before and printing it here, but that's beyond this scope of this change...

This revision is now accepted and ready to land.Jun 20 2023, 8:23 AM

If the transport variable mirrors the Fabric types (i.e., PCIe, RDMA, TCP, FC), this makes sense to me as there are differences (like shown here with the PCIe lane count / speeds) between the -oF transports.

FYI, the hash will change so this link will go dead as I keep rebasing the branch, but here's the current XPORT for Fabrics: https://github.com/freebsd/freebsd-src/commit/8f0f6268974edd44695fec83ea527cbf3af5e8a5

I don't think it makes sense to merge until the actual Fabrics host is closer to landing though.

In D40618#924842, @imp wrote:

Ah, this explains an earlier comment.

Will fabrics have a different protocol specific field for the cts? If not, why bother being careful here? I've not seen that code so I don't know, but it would seem a bit odd if it did, though most of nvme_xpt doesn't care... the only other place is in nvme_device_transport which sets the .valid fields to 0 before calling XPT_SET_TRAN_SETTINGS

It has a different transport settings field. However, this also moves towards pulling the version from protocol_version instead of storing it separately in the structure. See my comment on the earlier review about what I think makes sense longer term, that is splitting ccb_trans_settings_nvme into separate structures: one for the protocol and one for the xport (right now we reuse the same structure for both which is a bit confusing)

Also, side note: I think we should be setting max_xfer where I tagged before and printing it here, but that's beyond this scope of this change...

In D40618#925264, @jhb wrote:
In D40618#924842, @imp wrote:

Ah, this explains an earlier comment.

Will fabrics have a different protocol specific field for the cts? If not, why bother being careful here? I've not seen that code so I don't know, but it would seem a bit odd if it did, though most of nvme_xpt doesn't care... the only other place is in nvme_device_transport which sets the .valid fields to 0 before calling XPT_SET_TRAN_SETTINGS

It has a different transport settings field. However, this also moves towards pulling the version from protocol_version instead of storing it separately in the structure. See my comment on the earlier review about what I think makes sense longer term, that is splitting ccb_trans_settings_nvme into separate structures: one for the protocol and one for the xport (right now we reuse the same structure for both which is a bit confusing)

Yea, that likely makes sense.