Skip to content

Commit

Permalink
nvme: Add APST payload overriding
Browse files Browse the repository at this point in the history
The apst_data tunable allows APST configuration to be adjusted
during controller initialization.  It accepts an array of encoded
integers, each defining specific transition parameters.

Signed-off-by: Alexey Sukhoguzov <[email protected]>
  • Loading branch information
eseipi committed Dec 13, 2024
1 parent 3990a6f commit 23523f6
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 8 deletions.
12 changes: 12 additions & 0 deletions share/man/man4/nvme.4
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,18 @@ hw.nvme.apst_enable=1
.Ed
.Pp
The default vendor-provided settings, if any, will be applied.
To override this, set the following tunable:
.Bd -literal -offset indent
hw.nvme.apst_data
.Ed
.Pp
The string must contain up to 32 encoded integers, e.g. "0x6418 0
0 0x3e820".
Each value corresponds to a specific available power state starting
from the lowest, and defines the target state (bits 3..7) to
transition to, as well as the idle time in milliseconds (bits 8..31)
to wait before that transition.
Bits 0..2 must be zero.
.Pp
The
.Xr nvd 4
Expand Down
22 changes: 14 additions & 8 deletions sys/dev/nvme/nvme_ctrlr.c
Original file line number Diff line number Diff line change
Expand Up @@ -882,7 +882,7 @@ nvme_ctrlr_configure_apst(struct nvme_controller *ctrlr)
{
struct nvme_completion_poll_status status;
uint64_t *data;
int data_size;
int data_size, i, read_size;
bool enable, error = true;

if (TUNABLE_BOOL_FETCH("hw.nvme.apst_enable", &enable) == 0 ||
Expand All @@ -892,13 +892,19 @@ nvme_ctrlr_configure_apst(struct nvme_controller *ctrlr)
data_size = 32 * sizeof(*data);
data = malloc(data_size, M_NVME, M_WAITOK | M_ZERO);

status.done = 0;
nvme_ctrlr_cmd_get_feature(ctrlr,
NVME_FEAT_AUTONOMOUS_POWER_STATE_TRANSITION, 0,
data, data_size, nvme_completion_poll_cb, &status);
nvme_completion_poll(&status);
if (nvme_completion_is_error(&status.cpl))
goto out;
if (getenv_array("hw.nvme.apst_data", data, data_size,
&read_size, sizeof(*data), GETENV_UNSIGNED) != 0) {
for (i = 0; i < read_size / sizeof(*data); ++i)
data[i] = htole64(data[i]);
} else {
status.done = 0;
nvme_ctrlr_cmd_get_feature(ctrlr,
NVME_FEAT_AUTONOMOUS_POWER_STATE_TRANSITION, 0,
data, data_size, nvme_completion_poll_cb, &status);
nvme_completion_poll(&status);
if (nvme_completion_is_error(&status.cpl))
goto out;
}

status.done = 0;
nvme_ctrlr_cmd_set_feature(ctrlr,
Expand Down

0 comments on commit 23523f6

Please sign in to comment.