Skip to content

Commit 6f07f86

Browse files
committed
acpi, nfit: Introduce nfit_mem flags
In preparation for adding a flag to indicate whether a DIMM publishes a dirty-shutdown count, convert the existing flags to a bit field. Reviewed-by: Keith Busch <[email protected]> Signed-off-by: Dan Williams <[email protected]>
1 parent 97052c1 commit 6f07f86

File tree

2 files changed

+22
-13
lines changed

2 files changed

+22
-13
lines changed

drivers/acpi/nfit/core.c

Lines changed: 16 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -191,18 +191,20 @@ static int xlat_nvdimm_status(struct nvdimm *nvdimm, void *buf, unsigned int cmd
191191
* In the _LSI, _LSR, _LSW case the locked status is
192192
* communicated via the read/write commands
193193
*/
194-
if (nfit_mem->has_lsr)
194+
if (test_bit(NFIT_MEM_LSR, &nfit_mem->flags))
195195
break;
196196

197197
if (status >> 16 & ND_CONFIG_LOCKED)
198198
return -EACCES;
199199
break;
200200
case ND_CMD_GET_CONFIG_DATA:
201-
if (nfit_mem->has_lsr && status == ACPI_LABELS_LOCKED)
201+
if (test_bit(NFIT_MEM_LSR, &nfit_mem->flags)
202+
&& status == ACPI_LABELS_LOCKED)
202203
return -EACCES;
203204
break;
204205
case ND_CMD_SET_CONFIG_DATA:
205-
if (nfit_mem->has_lsw && status == ACPI_LABELS_LOCKED)
206+
if (test_bit(NFIT_MEM_LSW, &nfit_mem->flags)
207+
&& status == ACPI_LABELS_LOCKED)
206208
return -EACCES;
207209
break;
208210
default:
@@ -480,14 +482,16 @@ int acpi_nfit_ctl(struct nvdimm_bus_descriptor *nd_desc, struct nvdimm *nvdimm,
480482
min_t(u32, 256, in_buf.buffer.length), true);
481483

482484
/* call the BIOS, prefer the named methods over _DSM if available */
483-
if (nvdimm && cmd == ND_CMD_GET_CONFIG_SIZE && nfit_mem->has_lsr)
485+
if (nvdimm && cmd == ND_CMD_GET_CONFIG_SIZE
486+
&& test_bit(NFIT_MEM_LSR, &nfit_mem->flags))
484487
out_obj = acpi_label_info(handle);
485-
else if (nvdimm && cmd == ND_CMD_GET_CONFIG_DATA && nfit_mem->has_lsr) {
488+
else if (nvdimm && cmd == ND_CMD_GET_CONFIG_DATA
489+
&& test_bit(NFIT_MEM_LSR, &nfit_mem->flags)) {
486490
struct nd_cmd_get_config_data_hdr *p = buf;
487491

488492
out_obj = acpi_label_read(handle, p->in_offset, p->in_length);
489493
} else if (nvdimm && cmd == ND_CMD_SET_CONFIG_DATA
490-
&& nfit_mem->has_lsw) {
494+
&& test_bit(NFIT_MEM_LSW, &nfit_mem->flags)) {
491495
struct nd_cmd_set_config_hdr *p = buf;
492496

493497
out_obj = acpi_label_write(handle, p->in_offset, p->in_length,
@@ -1784,12 +1788,13 @@ static int acpi_nfit_add_dimm(struct acpi_nfit_desc *acpi_desc,
17841788
if (acpi_nvdimm_has_method(adev_dimm, "_LSI")
17851789
&& acpi_nvdimm_has_method(adev_dimm, "_LSR")) {
17861790
dev_dbg(dev, "%s: has _LSR\n", dev_name(&adev_dimm->dev));
1787-
nfit_mem->has_lsr = true;
1791+
set_bit(NFIT_MEM_LSR, &nfit_mem->flags);
17881792
}
17891793

1790-
if (nfit_mem->has_lsr && acpi_nvdimm_has_method(adev_dimm, "_LSW")) {
1794+
if (test_bit(NFIT_MEM_LSR, &nfit_mem->flags)
1795+
&& acpi_nvdimm_has_method(adev_dimm, "_LSW")) {
17911796
dev_dbg(dev, "%s: has _LSW\n", dev_name(&adev_dimm->dev));
1792-
nfit_mem->has_lsw = true;
1797+
set_bit(NFIT_MEM_LSW, &nfit_mem->flags);
17931798
}
17941799

17951800
return 0;
@@ -1878,11 +1883,11 @@ static int acpi_nfit_register_dimms(struct acpi_nfit_desc *acpi_desc)
18781883
cmd_mask |= nfit_mem->dsm_mask & NVDIMM_STANDARD_CMDMASK;
18791884
}
18801885

1881-
if (nfit_mem->has_lsr) {
1886+
if (test_bit(NFIT_MEM_LSR, &nfit_mem->flags)) {
18821887
set_bit(ND_CMD_GET_CONFIG_SIZE, &cmd_mask);
18831888
set_bit(ND_CMD_GET_CONFIG_DATA, &cmd_mask);
18841889
}
1885-
if (nfit_mem->has_lsw)
1890+
if (test_bit(NFIT_MEM_LSW, &nfit_mem->flags))
18861891
set_bit(ND_CMD_SET_CONFIG_DATA, &cmd_mask);
18871892

18881893
flush = nfit_mem->nfit_flush ? nfit_mem->nfit_flush->flush

drivers/acpi/nfit/nfit.h

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -159,6 +159,11 @@ struct nfit_memdev {
159159
struct acpi_nfit_memory_map memdev[0];
160160
};
161161

162+
enum nfit_mem_flags {
163+
NFIT_MEM_LSR,
164+
NFIT_MEM_LSW,
165+
};
166+
162167
/* assembled tables for a given dimm/memory-device */
163168
struct nfit_mem {
164169
struct nvdimm *nvdimm;
@@ -178,9 +183,8 @@ struct nfit_mem {
178183
struct acpi_nfit_desc *acpi_desc;
179184
struct resource *flush_wpq;
180185
unsigned long dsm_mask;
186+
unsigned long flags;
181187
int family;
182-
bool has_lsr;
183-
bool has_lsw;
184188
};
185189

186190
struct acpi_nfit_desc {

0 commit comments

Comments
 (0)