Use atomic_load_acq_int() here too to poll done, ala r328521

This commit is contained in:
imp 2018-11-13 22:41:20 +00:00
parent 80199cdcb4
commit ed132066cd

View File

@ -535,11 +535,11 @@ nvme_ns_construct(struct nvme_namespace *ns, uint32_t id,
if (!mtx_initialized(&ns->lock)) if (!mtx_initialized(&ns->lock))
mtx_init(&ns->lock, "nvme ns lock", NULL, MTX_DEF); mtx_init(&ns->lock, "nvme ns lock", NULL, MTX_DEF);
status.done = FALSE; status.done = 0;
nvme_ctrlr_cmd_identify_namespace(ctrlr, id, &ns->data, nvme_ctrlr_cmd_identify_namespace(ctrlr, id, &ns->data,
nvme_completion_poll_cb, &status); nvme_completion_poll_cb, &status);
while (status.done == FALSE) while (!atomic_load_acq_int(&status.done))
DELAY(5); pause("nvme", 1);
if (nvme_completion_is_error(&status.cpl)) { if (nvme_completion_is_error(&status.cpl)) {
nvme_printf(ctrlr, "nvme_identify_namespace failed\n"); nvme_printf(ctrlr, "nvme_identify_namespace failed\n");
return (ENXIO); return (ENXIO);