Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ioctl: Live Migration #911

Closed
wants to merge 1 commit into from
Closed

Conversation

NateThornton
Copy link
Contributor

@NateThornton NateThornton commented Nov 13, 2024

Continues efforts from the newly minted TP4159 PCIe Infrastructure for Live Migration specification by adding additional types and ioctl methods.

Depends on completion of #913

Continues efforts from the newly minted TP4159 PCIe Infrastructure for
Live Migration specification by adding additional types and ioctl
methods.

Signed-off-by: Nate Thornton <[email protected]>
@NateThornton NateThornton force-pushed the lm branch 4 times, most recently from aaa49bc to fb711c9 Compare November 13, 2024 17:42
nvme_lm_migration_send;
nvme_lm_migration_recv;
nvme_lm_set_features_ctrl_data_queue;
nvme_lm_get_features_ctrl_data_queue;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Start a new section LIBNVME_1_12 and move them there.

__u8 qt;
__u16 cntlid;
__u16 cdqid;
};
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Avoid any holes in the struct by rearranging the members in order to try to avoid ABI breakage. The only reliable alignment is to sort the members according their natural size: 64bit, pointers, 32bit, 16bit, 8bit. This is necessary that the version trick is working. Not nice, but it is what it is. We will address this in v2 :)

.cdw10 = cdw10,
.addr = (__u64)(uintptr_t)args->data,
.data_len = args->data_len,
.timeout_ms = args->timeout,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please avoid unrelated whitespace changes.

};

return nvme_get_features(&args);
}
Copy link
Collaborator

@igaw igaw Nov 14, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The rest looks okay. Just move the ioctl.c and ioctl.h changes into a separate patch.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Types moved to #913

@@ -4429,6 +4430,7 @@ enum nvme_fid_supported_effects {
NVME_FID_SUPPORTED_EFFECTS_SCOPE_ENDGRP = 1 << 3,
NVME_FID_SUPPORTED_EFFECTS_SCOPE_DOMAIN = 1 << 4,
NVME_FID_SUPPORTED_EFFECTS_SCOPE_NSS = 1 << 5,
NVME_FID_SUPPORTED_EFFECTS_SCOPE_CDQSCP = 1 << 6,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The bit is just called Controller Data Queue (CDQSCP), no scope.

@@ -9007,4 +9025,324 @@ struct nvme_ns_mgmt_host_sw_specified {
};
#endif /* SWIG */

/**
* enum nvme_lm_select - Select (SEL): This field specifies the type of management operation to
* perform.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this render the documentation correct? Is the perform on the short description? I recenetly learned you can add a new line in the short description, but I think then you need to have a empty line between the header and the first paragraph.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is does in the man page. Is there somewhere else I should look to verify?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Check the output of scripts/kernel-doc src/nvme/types.h

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks OK to me

NVME_LM_RESUME = 1,
NVME_LM_SET_CONTROLLER_STATE = 2,
/* Migration Receive */
NVME_LM_GET_CONTROLLER_STATE = 0,
Copy link
Collaborator

@igaw igaw Nov 14, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I fiend this very surprising that the select field from different commands are mixed into one enum. Do we have this pattern already somewhere else?

Could this a problem when those commands get extended? And from past experience the chances for this are not zero.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All the LM commands share the same cdw10 structure. I thought it better organized in one select block.

Would you rather I have an enum per command, where all fields pertaining to that command are located in one block? Or an enum per command per field?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I broke these into per-command fields

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While I understand the motivation to interpret the spec and make it a bit more usable I am not sure if this is a good thing in the long run. We didn't do this for the rest of the spec. Maybe @keithbusch has some input on this.

NVME_LM_MIGRATION_RECV_CTRL_SUSPENDED = 1,
NVME_LM_MIGRATION_RECV_CTRL_SUSPENDED_SHIFT = 0,
NVME_LM_MIGRATION_RECV_CTRL_SUSPENDED_MASK = 0x1,
};
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same comment as above, this seems to mix the definition from different commands into one enum.

__u16 hp;
__u16 tp;
__u32 attrs;
__u8 rsvd20[4];
Copy link
Collaborator

@igaw igaw Nov 29, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

could you use the field names as in the spec used, e.g. iocqprp1, ...

__u16 attrs;
__u16 hp;
__u16 tp;
__u8 rsvd20[4];
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

could you use the field names as in the spec used, e.g. iosqprp1, ...

NVME_LM_S0PT_MASK = 0x1,
NVME_LM_S0PT_SHIFT = 2,
NVME_LM_IOCQIV_MASK = 0xffff,
NVME_LM_IOCQIV_SHIFT = 16,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the same comment as above, with prefixing it consistently and matching the names with the spec.

@igaw
Copy link
Collaborator

igaw commented Nov 29, 2024

Sorry for the late review, just a bit busy. And also sorry for being so anal here. But my point is that we shouldn't be too creative when typing down the spec. Note, we also plan to auto generate all the headers for the next version. In this case we really follow the spec exactly, which makes it simpler to migrate.

@igaw
Copy link
Collaborator

igaw commented Nov 29, 2024

I assume this got superseded by #913

@igaw igaw closed this Nov 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants