xref: /openbmc/linux/tools/testing/nvdimm/test/nfit.c (revision 4da722ca)
1 /*
2  * Copyright(c) 2013-2015 Intel Corporation. All rights reserved.
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of version 2 of the GNU General Public License as
6  * published by the Free Software Foundation.
7  *
8  * This program is distributed in the hope that it will be useful, but
9  * WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11  * General Public License for more details.
12  */
13 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
14 #include <linux/platform_device.h>
15 #include <linux/dma-mapping.h>
16 #include <linux/workqueue.h>
17 #include <linux/libnvdimm.h>
18 #include <linux/vmalloc.h>
19 #include <linux/device.h>
20 #include <linux/module.h>
21 #include <linux/mutex.h>
22 #include <linux/ndctl.h>
23 #include <linux/sizes.h>
24 #include <linux/list.h>
25 #include <linux/slab.h>
26 #include <nd-core.h>
27 #include <nfit.h>
28 #include <nd.h>
29 #include "nfit_test.h"
30 
31 /*
32  * Generate an NFIT table to describe the following topology:
33  *
34  * BUS0: Interleaved PMEM regions, and aliasing with BLK regions
35  *
36  *                     (a)                       (b)            DIMM   BLK-REGION
37  *           +----------+--------------+----------+---------+
38  * +------+  |  blk2.0  |     pm0.0    |  blk2.1  |  pm1.0  |    0      region2
39  * | imc0 +--+- - - - - region0 - - - -+----------+         +
40  * +--+---+  |  blk3.0  |     pm0.0    |  blk3.1  |  pm1.0  |    1      region3
41  *    |      +----------+--------------v----------v         v
42  * +--+---+                            |                    |
43  * | cpu0 |                                    region1
44  * +--+---+                            |                    |
45  *    |      +-------------------------^----------^         ^
46  * +--+---+  |                 blk4.0             |  pm1.0  |    2      region4
47  * | imc1 +--+-------------------------+----------+         +
48  * +------+  |                 blk5.0             |  pm1.0  |    3      region5
49  *           +-------------------------+----------+-+-------+
50  *
51  * +--+---+
52  * | cpu1 |
53  * +--+---+                   (Hotplug DIMM)
54  *    |      +----------------------------------------------+
55  * +--+---+  |                 blk6.0/pm7.0                 |    4      region6/7
56  * | imc0 +--+----------------------------------------------+
57  * +------+
58  *
59  *
60  * *) In this layout we have four dimms and two memory controllers in one
61  *    socket.  Each unique interface (BLK or PMEM) to DPA space
62  *    is identified by a region device with a dynamically assigned id.
63  *
64  * *) The first portion of dimm0 and dimm1 are interleaved as REGION0.
65  *    A single PMEM namespace "pm0.0" is created using half of the
66  *    REGION0 SPA-range.  REGION0 spans dimm0 and dimm1.  PMEM namespace
67  *    allocate from from the bottom of a region.  The unallocated
68  *    portion of REGION0 aliases with REGION2 and REGION3.  That
69  *    unallacted capacity is reclaimed as BLK namespaces ("blk2.0" and
70  *    "blk3.0") starting at the base of each DIMM to offset (a) in those
71  *    DIMMs.  "pm0.0", "blk2.0" and "blk3.0" are free-form readable
72  *    names that can be assigned to a namespace.
73  *
74  * *) In the last portion of dimm0 and dimm1 we have an interleaved
75  *    SPA range, REGION1, that spans those two dimms as well as dimm2
76  *    and dimm3.  Some of REGION1 allocated to a PMEM namespace named
77  *    "pm1.0" the rest is reclaimed in 4 BLK namespaces (for each
78  *    dimm in the interleave set), "blk2.1", "blk3.1", "blk4.0", and
79  *    "blk5.0".
80  *
81  * *) The portion of dimm2 and dimm3 that do not participate in the
82  *    REGION1 interleaved SPA range (i.e. the DPA address below offset
83  *    (b) are also included in the "blk4.0" and "blk5.0" namespaces.
84  *    Note, that BLK namespaces need not be contiguous in DPA-space, and
85  *    can consume aliased capacity from multiple interleave sets.
86  *
87  * BUS1: Legacy NVDIMM (single contiguous range)
88  *
89  *  region2
90  * +---------------------+
91  * |---------------------|
92  * ||       pm2.0       ||
93  * |---------------------|
94  * +---------------------+
95  *
96  * *) A NFIT-table may describe a simple system-physical-address range
97  *    with no BLK aliasing.  This type of region may optionally
98  *    reference an NVDIMM.
99  */
100 enum {
101 	NUM_PM  = 3,
102 	NUM_DCR = 5,
103 	NUM_HINTS = 8,
104 	NUM_BDW = NUM_DCR,
105 	NUM_SPA = NUM_PM + NUM_DCR + NUM_BDW,
106 	NUM_MEM = NUM_DCR + NUM_BDW + 2 /* spa0 iset */ + 4 /* spa1 iset */,
107 	DIMM_SIZE = SZ_32M,
108 	LABEL_SIZE = SZ_128K,
109 	SPA_VCD_SIZE = SZ_4M,
110 	SPA0_SIZE = DIMM_SIZE,
111 	SPA1_SIZE = DIMM_SIZE*2,
112 	SPA2_SIZE = DIMM_SIZE,
113 	BDW_SIZE = 64 << 8,
114 	DCR_SIZE = 12,
115 	NUM_NFITS = 2, /* permit testing multiple NFITs per system */
116 };
117 
118 struct nfit_test_dcr {
119 	__le64 bdw_addr;
120 	__le32 bdw_status;
121 	__u8 aperature[BDW_SIZE];
122 };
123 
124 #define NFIT_DIMM_HANDLE(node, socket, imc, chan, dimm) \
125 	(((node & 0xfff) << 16) | ((socket & 0xf) << 12) \
126 	 | ((imc & 0xf) << 8) | ((chan & 0xf) << 4) | (dimm & 0xf))
127 
128 static u32 handle[] = {
129 	[0] = NFIT_DIMM_HANDLE(0, 0, 0, 0, 0),
130 	[1] = NFIT_DIMM_HANDLE(0, 0, 0, 0, 1),
131 	[2] = NFIT_DIMM_HANDLE(0, 0, 1, 0, 0),
132 	[3] = NFIT_DIMM_HANDLE(0, 0, 1, 0, 1),
133 	[4] = NFIT_DIMM_HANDLE(0, 1, 0, 0, 0),
134 	[5] = NFIT_DIMM_HANDLE(1, 0, 0, 0, 0),
135 	[6] = NFIT_DIMM_HANDLE(1, 0, 0, 0, 1),
136 };
137 
138 static unsigned long dimm_fail_cmd_flags[NUM_DCR];
139 
140 struct nfit_test {
141 	struct acpi_nfit_desc acpi_desc;
142 	struct platform_device pdev;
143 	struct list_head resources;
144 	void *nfit_buf;
145 	dma_addr_t nfit_dma;
146 	size_t nfit_size;
147 	int dcr_idx;
148 	int num_dcr;
149 	int num_pm;
150 	void **dimm;
151 	dma_addr_t *dimm_dma;
152 	void **flush;
153 	dma_addr_t *flush_dma;
154 	void **label;
155 	dma_addr_t *label_dma;
156 	void **spa_set;
157 	dma_addr_t *spa_set_dma;
158 	struct nfit_test_dcr **dcr;
159 	dma_addr_t *dcr_dma;
160 	int (*alloc)(struct nfit_test *t);
161 	void (*setup)(struct nfit_test *t);
162 	int setup_hotplug;
163 	union acpi_object **_fit;
164 	dma_addr_t _fit_dma;
165 	struct ars_state {
166 		struct nd_cmd_ars_status *ars_status;
167 		unsigned long deadline;
168 		spinlock_t lock;
169 	} ars_state;
170 	struct device *dimm_dev[NUM_DCR];
171 };
172 
173 static struct nfit_test *to_nfit_test(struct device *dev)
174 {
175 	struct platform_device *pdev = to_platform_device(dev);
176 
177 	return container_of(pdev, struct nfit_test, pdev);
178 }
179 
180 static int nfit_test_cmd_get_config_size(struct nd_cmd_get_config_size *nd_cmd,
181 		unsigned int buf_len)
182 {
183 	if (buf_len < sizeof(*nd_cmd))
184 		return -EINVAL;
185 
186 	nd_cmd->status = 0;
187 	nd_cmd->config_size = LABEL_SIZE;
188 	nd_cmd->max_xfer = SZ_4K;
189 
190 	return 0;
191 }
192 
193 static int nfit_test_cmd_get_config_data(struct nd_cmd_get_config_data_hdr
194 		*nd_cmd, unsigned int buf_len, void *label)
195 {
196 	unsigned int len, offset = nd_cmd->in_offset;
197 	int rc;
198 
199 	if (buf_len < sizeof(*nd_cmd))
200 		return -EINVAL;
201 	if (offset >= LABEL_SIZE)
202 		return -EINVAL;
203 	if (nd_cmd->in_length + sizeof(*nd_cmd) > buf_len)
204 		return -EINVAL;
205 
206 	nd_cmd->status = 0;
207 	len = min(nd_cmd->in_length, LABEL_SIZE - offset);
208 	memcpy(nd_cmd->out_buf, label + offset, len);
209 	rc = buf_len - sizeof(*nd_cmd) - len;
210 
211 	return rc;
212 }
213 
214 static int nfit_test_cmd_set_config_data(struct nd_cmd_set_config_hdr *nd_cmd,
215 		unsigned int buf_len, void *label)
216 {
217 	unsigned int len, offset = nd_cmd->in_offset;
218 	u32 *status;
219 	int rc;
220 
221 	if (buf_len < sizeof(*nd_cmd))
222 		return -EINVAL;
223 	if (offset >= LABEL_SIZE)
224 		return -EINVAL;
225 	if (nd_cmd->in_length + sizeof(*nd_cmd) + 4 > buf_len)
226 		return -EINVAL;
227 
228 	status = (void *)nd_cmd + nd_cmd->in_length + sizeof(*nd_cmd);
229 	*status = 0;
230 	len = min(nd_cmd->in_length, LABEL_SIZE - offset);
231 	memcpy(label + offset, nd_cmd->in_buf, len);
232 	rc = buf_len - sizeof(*nd_cmd) - (len + 4);
233 
234 	return rc;
235 }
236 
237 #define NFIT_TEST_ARS_RECORDS 4
238 #define NFIT_TEST_CLEAR_ERR_UNIT 256
239 
240 static int nfit_test_cmd_ars_cap(struct nd_cmd_ars_cap *nd_cmd,
241 		unsigned int buf_len)
242 {
243 	if (buf_len < sizeof(*nd_cmd))
244 		return -EINVAL;
245 
246 	nd_cmd->max_ars_out = sizeof(struct nd_cmd_ars_status)
247 		+ NFIT_TEST_ARS_RECORDS * sizeof(struct nd_ars_record);
248 	nd_cmd->status = (ND_ARS_PERSISTENT | ND_ARS_VOLATILE) << 16;
249 	nd_cmd->clear_err_unit = NFIT_TEST_CLEAR_ERR_UNIT;
250 
251 	return 0;
252 }
253 
254 /*
255  * Initialize the ars_state to return an ars_result 1 second in the future with
256  * a 4K error range in the middle of the requested address range.
257  */
258 static void post_ars_status(struct ars_state *ars_state, u64 addr, u64 len)
259 {
260 	struct nd_cmd_ars_status *ars_status;
261 	struct nd_ars_record *ars_record;
262 
263 	ars_state->deadline = jiffies + 1*HZ;
264 	ars_status = ars_state->ars_status;
265 	ars_status->status = 0;
266 	ars_status->out_length = sizeof(struct nd_cmd_ars_status)
267 		+ sizeof(struct nd_ars_record);
268 	ars_status->address = addr;
269 	ars_status->length = len;
270 	ars_status->type = ND_ARS_PERSISTENT;
271 	ars_status->num_records = 1;
272 	ars_record = &ars_status->records[0];
273 	ars_record->handle = 0;
274 	ars_record->err_address = addr + len / 2;
275 	ars_record->length = SZ_4K;
276 }
277 
278 static int nfit_test_cmd_ars_start(struct ars_state *ars_state,
279 		struct nd_cmd_ars_start *ars_start, unsigned int buf_len,
280 		int *cmd_rc)
281 {
282 	if (buf_len < sizeof(*ars_start))
283 		return -EINVAL;
284 
285 	spin_lock(&ars_state->lock);
286 	if (time_before(jiffies, ars_state->deadline)) {
287 		ars_start->status = NFIT_ARS_START_BUSY;
288 		*cmd_rc = -EBUSY;
289 	} else {
290 		ars_start->status = 0;
291 		ars_start->scrub_time = 1;
292 		post_ars_status(ars_state, ars_start->address,
293 				ars_start->length);
294 		*cmd_rc = 0;
295 	}
296 	spin_unlock(&ars_state->lock);
297 
298 	return 0;
299 }
300 
301 static int nfit_test_cmd_ars_status(struct ars_state *ars_state,
302 		struct nd_cmd_ars_status *ars_status, unsigned int buf_len,
303 		int *cmd_rc)
304 {
305 	if (buf_len < ars_state->ars_status->out_length)
306 		return -EINVAL;
307 
308 	spin_lock(&ars_state->lock);
309 	if (time_before(jiffies, ars_state->deadline)) {
310 		memset(ars_status, 0, buf_len);
311 		ars_status->status = NFIT_ARS_STATUS_BUSY;
312 		ars_status->out_length = sizeof(*ars_status);
313 		*cmd_rc = -EBUSY;
314 	} else {
315 		memcpy(ars_status, ars_state->ars_status,
316 				ars_state->ars_status->out_length);
317 		*cmd_rc = 0;
318 	}
319 	spin_unlock(&ars_state->lock);
320 	return 0;
321 }
322 
323 static int nfit_test_cmd_clear_error(struct nd_cmd_clear_error *clear_err,
324 		unsigned int buf_len, int *cmd_rc)
325 {
326 	const u64 mask = NFIT_TEST_CLEAR_ERR_UNIT - 1;
327 	if (buf_len < sizeof(*clear_err))
328 		return -EINVAL;
329 
330 	if ((clear_err->address & mask) || (clear_err->length & mask))
331 		return -EINVAL;
332 
333 	/*
334 	 * Report 'all clear' success for all commands even though a new
335 	 * scrub will find errors again.  This is enough to have the
336 	 * error removed from the 'badblocks' tracking in the pmem
337 	 * driver.
338 	 */
339 	clear_err->status = 0;
340 	clear_err->cleared = clear_err->length;
341 	*cmd_rc = 0;
342 	return 0;
343 }
344 
345 static int nfit_test_cmd_smart(struct nd_cmd_smart *smart, unsigned int buf_len)
346 {
347 	static const struct nd_smart_payload smart_data = {
348 		.flags = ND_SMART_HEALTH_VALID | ND_SMART_TEMP_VALID
349 			| ND_SMART_SPARES_VALID | ND_SMART_ALARM_VALID
350 			| ND_SMART_USED_VALID | ND_SMART_SHUTDOWN_VALID,
351 		.health = ND_SMART_NON_CRITICAL_HEALTH,
352 		.temperature = 23 * 16,
353 		.spares = 75,
354 		.alarm_flags = ND_SMART_SPARE_TRIP | ND_SMART_TEMP_TRIP,
355 		.life_used = 5,
356 		.shutdown_state = 0,
357 		.vendor_size = 0,
358 	};
359 
360 	if (buf_len < sizeof(*smart))
361 		return -EINVAL;
362 	memcpy(smart->data, &smart_data, sizeof(smart_data));
363 	return 0;
364 }
365 
366 static int nfit_test_cmd_smart_threshold(struct nd_cmd_smart_threshold *smart_t,
367 		unsigned int buf_len)
368 {
369 	static const struct nd_smart_threshold_payload smart_t_data = {
370 		.alarm_control = ND_SMART_SPARE_TRIP | ND_SMART_TEMP_TRIP,
371 		.temperature = 40 * 16,
372 		.spares = 5,
373 	};
374 
375 	if (buf_len < sizeof(*smart_t))
376 		return -EINVAL;
377 	memcpy(smart_t->data, &smart_t_data, sizeof(smart_t_data));
378 	return 0;
379 }
380 
381 static int nfit_test_ctl(struct nvdimm_bus_descriptor *nd_desc,
382 		struct nvdimm *nvdimm, unsigned int cmd, void *buf,
383 		unsigned int buf_len, int *cmd_rc)
384 {
385 	struct acpi_nfit_desc *acpi_desc = to_acpi_desc(nd_desc);
386 	struct nfit_test *t = container_of(acpi_desc, typeof(*t), acpi_desc);
387 	unsigned int func = cmd;
388 	int i, rc = 0, __cmd_rc;
389 
390 	if (!cmd_rc)
391 		cmd_rc = &__cmd_rc;
392 	*cmd_rc = 0;
393 
394 	if (nvdimm) {
395 		struct nfit_mem *nfit_mem = nvdimm_provider_data(nvdimm);
396 		unsigned long cmd_mask = nvdimm_cmd_mask(nvdimm);
397 
398 		if (!nfit_mem)
399 			return -ENOTTY;
400 
401 		if (cmd == ND_CMD_CALL) {
402 			struct nd_cmd_pkg *call_pkg = buf;
403 
404 			buf_len = call_pkg->nd_size_in + call_pkg->nd_size_out;
405 			buf = (void *) call_pkg->nd_payload;
406 			func = call_pkg->nd_command;
407 			if (call_pkg->nd_family != nfit_mem->family)
408 				return -ENOTTY;
409 		}
410 
411 		if (!test_bit(cmd, &cmd_mask)
412 				|| !test_bit(func, &nfit_mem->dsm_mask))
413 			return -ENOTTY;
414 
415 		/* lookup label space for the given dimm */
416 		for (i = 0; i < ARRAY_SIZE(handle); i++)
417 			if (__to_nfit_memdev(nfit_mem)->device_handle ==
418 					handle[i])
419 				break;
420 		if (i >= ARRAY_SIZE(handle))
421 			return -ENXIO;
422 
423 		if ((1 << func) & dimm_fail_cmd_flags[i])
424 			return -EIO;
425 
426 		switch (func) {
427 		case ND_CMD_GET_CONFIG_SIZE:
428 			rc = nfit_test_cmd_get_config_size(buf, buf_len);
429 			break;
430 		case ND_CMD_GET_CONFIG_DATA:
431 			rc = nfit_test_cmd_get_config_data(buf, buf_len,
432 				t->label[i - t->dcr_idx]);
433 			break;
434 		case ND_CMD_SET_CONFIG_DATA:
435 			rc = nfit_test_cmd_set_config_data(buf, buf_len,
436 				t->label[i - t->dcr_idx]);
437 			break;
438 		case ND_CMD_SMART:
439 			rc = nfit_test_cmd_smart(buf, buf_len);
440 			break;
441 		case ND_CMD_SMART_THRESHOLD:
442 			rc = nfit_test_cmd_smart_threshold(buf, buf_len);
443 			device_lock(&t->pdev.dev);
444 			__acpi_nvdimm_notify(t->dimm_dev[i], 0x81);
445 			device_unlock(&t->pdev.dev);
446 			break;
447 		default:
448 			return -ENOTTY;
449 		}
450 	} else {
451 		struct ars_state *ars_state = &t->ars_state;
452 
453 		if (!nd_desc || !test_bit(cmd, &nd_desc->cmd_mask))
454 			return -ENOTTY;
455 
456 		switch (func) {
457 		case ND_CMD_ARS_CAP:
458 			rc = nfit_test_cmd_ars_cap(buf, buf_len);
459 			break;
460 		case ND_CMD_ARS_START:
461 			rc = nfit_test_cmd_ars_start(ars_state, buf, buf_len,
462 					cmd_rc);
463 			break;
464 		case ND_CMD_ARS_STATUS:
465 			rc = nfit_test_cmd_ars_status(ars_state, buf, buf_len,
466 					cmd_rc);
467 			break;
468 		case ND_CMD_CLEAR_ERROR:
469 			rc = nfit_test_cmd_clear_error(buf, buf_len, cmd_rc);
470 			break;
471 		default:
472 			return -ENOTTY;
473 		}
474 	}
475 
476 	return rc;
477 }
478 
479 static DEFINE_SPINLOCK(nfit_test_lock);
480 static struct nfit_test *instances[NUM_NFITS];
481 
482 static void release_nfit_res(void *data)
483 {
484 	struct nfit_test_resource *nfit_res = data;
485 
486 	spin_lock(&nfit_test_lock);
487 	list_del(&nfit_res->list);
488 	spin_unlock(&nfit_test_lock);
489 
490 	vfree(nfit_res->buf);
491 	kfree(nfit_res);
492 }
493 
494 static void *__test_alloc(struct nfit_test *t, size_t size, dma_addr_t *dma,
495 		void *buf)
496 {
497 	struct device *dev = &t->pdev.dev;
498 	struct nfit_test_resource *nfit_res = kzalloc(sizeof(*nfit_res),
499 			GFP_KERNEL);
500 	int rc;
501 
502 	if (!buf || !nfit_res)
503 		goto err;
504 	rc = devm_add_action(dev, release_nfit_res, nfit_res);
505 	if (rc)
506 		goto err;
507 	INIT_LIST_HEAD(&nfit_res->list);
508 	memset(buf, 0, size);
509 	nfit_res->dev = dev;
510 	nfit_res->buf = buf;
511 	nfit_res->res.start = *dma;
512 	nfit_res->res.end = *dma + size - 1;
513 	nfit_res->res.name = "NFIT";
514 	spin_lock_init(&nfit_res->lock);
515 	INIT_LIST_HEAD(&nfit_res->requests);
516 	spin_lock(&nfit_test_lock);
517 	list_add(&nfit_res->list, &t->resources);
518 	spin_unlock(&nfit_test_lock);
519 
520 	return nfit_res->buf;
521  err:
522 	if (buf)
523 		vfree(buf);
524 	kfree(nfit_res);
525 	return NULL;
526 }
527 
528 static void *test_alloc(struct nfit_test *t, size_t size, dma_addr_t *dma)
529 {
530 	void *buf = vmalloc(size);
531 
532 	*dma = (unsigned long) buf;
533 	return __test_alloc(t, size, dma, buf);
534 }
535 
536 static struct nfit_test_resource *nfit_test_lookup(resource_size_t addr)
537 {
538 	int i;
539 
540 	for (i = 0; i < ARRAY_SIZE(instances); i++) {
541 		struct nfit_test_resource *n, *nfit_res = NULL;
542 		struct nfit_test *t = instances[i];
543 
544 		if (!t)
545 			continue;
546 		spin_lock(&nfit_test_lock);
547 		list_for_each_entry(n, &t->resources, list) {
548 			if (addr >= n->res.start && (addr < n->res.start
549 						+ resource_size(&n->res))) {
550 				nfit_res = n;
551 				break;
552 			} else if (addr >= (unsigned long) n->buf
553 					&& (addr < (unsigned long) n->buf
554 						+ resource_size(&n->res))) {
555 				nfit_res = n;
556 				break;
557 			}
558 		}
559 		spin_unlock(&nfit_test_lock);
560 		if (nfit_res)
561 			return nfit_res;
562 	}
563 
564 	return NULL;
565 }
566 
567 static int ars_state_init(struct device *dev, struct ars_state *ars_state)
568 {
569 	ars_state->ars_status = devm_kzalloc(dev,
570 			sizeof(struct nd_cmd_ars_status)
571 			+ sizeof(struct nd_ars_record) * NFIT_TEST_ARS_RECORDS,
572 			GFP_KERNEL);
573 	if (!ars_state->ars_status)
574 		return -ENOMEM;
575 	spin_lock_init(&ars_state->lock);
576 	return 0;
577 }
578 
579 static void put_dimms(void *data)
580 {
581 	struct device **dimm_dev = data;
582 	int i;
583 
584 	for (i = 0; i < NUM_DCR; i++)
585 		if (dimm_dev[i])
586 			device_unregister(dimm_dev[i]);
587 }
588 
589 static struct class *nfit_test_dimm;
590 
591 static int dimm_name_to_id(struct device *dev)
592 {
593 	int dimm;
594 
595 	if (sscanf(dev_name(dev), "test_dimm%d", &dimm) != 1
596 			|| dimm >= NUM_DCR || dimm < 0)
597 		return -ENXIO;
598 	return dimm;
599 }
600 
601 
602 static ssize_t handle_show(struct device *dev, struct device_attribute *attr,
603 		char *buf)
604 {
605 	int dimm = dimm_name_to_id(dev);
606 
607 	if (dimm < 0)
608 		return dimm;
609 
610 	return sprintf(buf, "%#x", handle[dimm]);
611 }
612 DEVICE_ATTR_RO(handle);
613 
614 static ssize_t fail_cmd_show(struct device *dev, struct device_attribute *attr,
615 		char *buf)
616 {
617 	int dimm = dimm_name_to_id(dev);
618 
619 	if (dimm < 0)
620 		return dimm;
621 
622 	return sprintf(buf, "%#lx\n", dimm_fail_cmd_flags[dimm]);
623 }
624 
625 static ssize_t fail_cmd_store(struct device *dev, struct device_attribute *attr,
626 		const char *buf, size_t size)
627 {
628 	int dimm = dimm_name_to_id(dev);
629 	unsigned long val;
630 	ssize_t rc;
631 
632 	if (dimm < 0)
633 		return dimm;
634 
635 	rc = kstrtol(buf, 0, &val);
636 	if (rc)
637 		return rc;
638 
639 	dimm_fail_cmd_flags[dimm] = val;
640 	return size;
641 }
642 static DEVICE_ATTR_RW(fail_cmd);
643 
644 static struct attribute *nfit_test_dimm_attributes[] = {
645 	&dev_attr_fail_cmd.attr,
646 	&dev_attr_handle.attr,
647 	NULL,
648 };
649 
650 static struct attribute_group nfit_test_dimm_attribute_group = {
651 	.attrs = nfit_test_dimm_attributes,
652 };
653 
654 static const struct attribute_group *nfit_test_dimm_attribute_groups[] = {
655 	&nfit_test_dimm_attribute_group,
656 	NULL,
657 };
658 
659 static int nfit_test0_alloc(struct nfit_test *t)
660 {
661 	size_t nfit_size = sizeof(struct acpi_nfit_system_address) * NUM_SPA
662 			+ sizeof(struct acpi_nfit_memory_map) * NUM_MEM
663 			+ sizeof(struct acpi_nfit_control_region) * NUM_DCR
664 			+ offsetof(struct acpi_nfit_control_region,
665 					window_size) * NUM_DCR
666 			+ sizeof(struct acpi_nfit_data_region) * NUM_BDW
667 			+ (sizeof(struct acpi_nfit_flush_address)
668 					+ sizeof(u64) * NUM_HINTS) * NUM_DCR;
669 	int i;
670 
671 	t->nfit_buf = test_alloc(t, nfit_size, &t->nfit_dma);
672 	if (!t->nfit_buf)
673 		return -ENOMEM;
674 	t->nfit_size = nfit_size;
675 
676 	t->spa_set[0] = test_alloc(t, SPA0_SIZE, &t->spa_set_dma[0]);
677 	if (!t->spa_set[0])
678 		return -ENOMEM;
679 
680 	t->spa_set[1] = test_alloc(t, SPA1_SIZE, &t->spa_set_dma[1]);
681 	if (!t->spa_set[1])
682 		return -ENOMEM;
683 
684 	t->spa_set[2] = test_alloc(t, SPA0_SIZE, &t->spa_set_dma[2]);
685 	if (!t->spa_set[2])
686 		return -ENOMEM;
687 
688 	for (i = 0; i < t->num_dcr; i++) {
689 		t->dimm[i] = test_alloc(t, DIMM_SIZE, &t->dimm_dma[i]);
690 		if (!t->dimm[i])
691 			return -ENOMEM;
692 
693 		t->label[i] = test_alloc(t, LABEL_SIZE, &t->label_dma[i]);
694 		if (!t->label[i])
695 			return -ENOMEM;
696 		sprintf(t->label[i], "label%d", i);
697 
698 		t->flush[i] = test_alloc(t, max(PAGE_SIZE,
699 					sizeof(u64) * NUM_HINTS),
700 				&t->flush_dma[i]);
701 		if (!t->flush[i])
702 			return -ENOMEM;
703 	}
704 
705 	for (i = 0; i < t->num_dcr; i++) {
706 		t->dcr[i] = test_alloc(t, LABEL_SIZE, &t->dcr_dma[i]);
707 		if (!t->dcr[i])
708 			return -ENOMEM;
709 	}
710 
711 	t->_fit = test_alloc(t, sizeof(union acpi_object **), &t->_fit_dma);
712 	if (!t->_fit)
713 		return -ENOMEM;
714 
715 	if (devm_add_action_or_reset(&t->pdev.dev, put_dimms, t->dimm_dev))
716 		return -ENOMEM;
717 	for (i = 0; i < NUM_DCR; i++) {
718 		t->dimm_dev[i] = device_create_with_groups(nfit_test_dimm,
719 				&t->pdev.dev, 0, NULL,
720 				nfit_test_dimm_attribute_groups,
721 				"test_dimm%d", i);
722 		if (!t->dimm_dev[i])
723 			return -ENOMEM;
724 	}
725 
726 	return ars_state_init(&t->pdev.dev, &t->ars_state);
727 }
728 
729 static int nfit_test1_alloc(struct nfit_test *t)
730 {
731 	size_t nfit_size = sizeof(struct acpi_nfit_system_address) * 2
732 		+ sizeof(struct acpi_nfit_memory_map) * 2
733 		+ offsetof(struct acpi_nfit_control_region, window_size) * 2;
734 	int i;
735 
736 	t->nfit_buf = test_alloc(t, nfit_size, &t->nfit_dma);
737 	if (!t->nfit_buf)
738 		return -ENOMEM;
739 	t->nfit_size = nfit_size;
740 
741 	t->spa_set[0] = test_alloc(t, SPA2_SIZE, &t->spa_set_dma[0]);
742 	if (!t->spa_set[0])
743 		return -ENOMEM;
744 
745 	for (i = 0; i < t->num_dcr; i++) {
746 		t->label[i] = test_alloc(t, LABEL_SIZE, &t->label_dma[i]);
747 		if (!t->label[i])
748 			return -ENOMEM;
749 		sprintf(t->label[i], "label%d", i);
750 	}
751 
752 	t->spa_set[1] = test_alloc(t, SPA_VCD_SIZE, &t->spa_set_dma[1]);
753 	if (!t->spa_set[1])
754 		return -ENOMEM;
755 
756 	return ars_state_init(&t->pdev.dev, &t->ars_state);
757 }
758 
759 static void dcr_common_init(struct acpi_nfit_control_region *dcr)
760 {
761 	dcr->vendor_id = 0xabcd;
762 	dcr->device_id = 0;
763 	dcr->revision_id = 1;
764 	dcr->valid_fields = 1;
765 	dcr->manufacturing_location = 0xa;
766 	dcr->manufacturing_date = cpu_to_be16(2016);
767 }
768 
769 static void nfit_test0_setup(struct nfit_test *t)
770 {
771 	const int flush_hint_size = sizeof(struct acpi_nfit_flush_address)
772 		+ (sizeof(u64) * NUM_HINTS);
773 	struct acpi_nfit_desc *acpi_desc;
774 	struct acpi_nfit_memory_map *memdev;
775 	void *nfit_buf = t->nfit_buf;
776 	struct acpi_nfit_system_address *spa;
777 	struct acpi_nfit_control_region *dcr;
778 	struct acpi_nfit_data_region *bdw;
779 	struct acpi_nfit_flush_address *flush;
780 	unsigned int offset, i;
781 
782 	/*
783 	 * spa0 (interleave first half of dimm0 and dimm1, note storage
784 	 * does not actually alias the related block-data-window
785 	 * regions)
786 	 */
787 	spa = nfit_buf;
788 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
789 	spa->header.length = sizeof(*spa);
790 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_PM), 16);
791 	spa->range_index = 0+1;
792 	spa->address = t->spa_set_dma[0];
793 	spa->length = SPA0_SIZE;
794 
795 	/*
796 	 * spa1 (interleave last half of the 4 DIMMS, note storage
797 	 * does not actually alias the related block-data-window
798 	 * regions)
799 	 */
800 	spa = nfit_buf + sizeof(*spa);
801 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
802 	spa->header.length = sizeof(*spa);
803 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_PM), 16);
804 	spa->range_index = 1+1;
805 	spa->address = t->spa_set_dma[1];
806 	spa->length = SPA1_SIZE;
807 
808 	/* spa2 (dcr0) dimm0 */
809 	spa = nfit_buf + sizeof(*spa) * 2;
810 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
811 	spa->header.length = sizeof(*spa);
812 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_DCR), 16);
813 	spa->range_index = 2+1;
814 	spa->address = t->dcr_dma[0];
815 	spa->length = DCR_SIZE;
816 
817 	/* spa3 (dcr1) dimm1 */
818 	spa = nfit_buf + sizeof(*spa) * 3;
819 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
820 	spa->header.length = sizeof(*spa);
821 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_DCR), 16);
822 	spa->range_index = 3+1;
823 	spa->address = t->dcr_dma[1];
824 	spa->length = DCR_SIZE;
825 
826 	/* spa4 (dcr2) dimm2 */
827 	spa = nfit_buf + sizeof(*spa) * 4;
828 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
829 	spa->header.length = sizeof(*spa);
830 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_DCR), 16);
831 	spa->range_index = 4+1;
832 	spa->address = t->dcr_dma[2];
833 	spa->length = DCR_SIZE;
834 
835 	/* spa5 (dcr3) dimm3 */
836 	spa = nfit_buf + sizeof(*spa) * 5;
837 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
838 	spa->header.length = sizeof(*spa);
839 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_DCR), 16);
840 	spa->range_index = 5+1;
841 	spa->address = t->dcr_dma[3];
842 	spa->length = DCR_SIZE;
843 
844 	/* spa6 (bdw for dcr0) dimm0 */
845 	spa = nfit_buf + sizeof(*spa) * 6;
846 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
847 	spa->header.length = sizeof(*spa);
848 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_BDW), 16);
849 	spa->range_index = 6+1;
850 	spa->address = t->dimm_dma[0];
851 	spa->length = DIMM_SIZE;
852 
853 	/* spa7 (bdw for dcr1) dimm1 */
854 	spa = nfit_buf + sizeof(*spa) * 7;
855 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
856 	spa->header.length = sizeof(*spa);
857 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_BDW), 16);
858 	spa->range_index = 7+1;
859 	spa->address = t->dimm_dma[1];
860 	spa->length = DIMM_SIZE;
861 
862 	/* spa8 (bdw for dcr2) dimm2 */
863 	spa = nfit_buf + sizeof(*spa) * 8;
864 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
865 	spa->header.length = sizeof(*spa);
866 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_BDW), 16);
867 	spa->range_index = 8+1;
868 	spa->address = t->dimm_dma[2];
869 	spa->length = DIMM_SIZE;
870 
871 	/* spa9 (bdw for dcr3) dimm3 */
872 	spa = nfit_buf + sizeof(*spa) * 9;
873 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
874 	spa->header.length = sizeof(*spa);
875 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_BDW), 16);
876 	spa->range_index = 9+1;
877 	spa->address = t->dimm_dma[3];
878 	spa->length = DIMM_SIZE;
879 
880 	offset = sizeof(*spa) * 10;
881 	/* mem-region0 (spa0, dimm0) */
882 	memdev = nfit_buf + offset;
883 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
884 	memdev->header.length = sizeof(*memdev);
885 	memdev->device_handle = handle[0];
886 	memdev->physical_id = 0;
887 	memdev->region_id = 0;
888 	memdev->range_index = 0+1;
889 	memdev->region_index = 4+1;
890 	memdev->region_size = SPA0_SIZE/2;
891 	memdev->region_offset = 1;
892 	memdev->address = 0;
893 	memdev->interleave_index = 0;
894 	memdev->interleave_ways = 2;
895 
896 	/* mem-region1 (spa0, dimm1) */
897 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map);
898 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
899 	memdev->header.length = sizeof(*memdev);
900 	memdev->device_handle = handle[1];
901 	memdev->physical_id = 1;
902 	memdev->region_id = 0;
903 	memdev->range_index = 0+1;
904 	memdev->region_index = 5+1;
905 	memdev->region_size = SPA0_SIZE/2;
906 	memdev->region_offset = (1 << 8);
907 	memdev->address = 0;
908 	memdev->interleave_index = 0;
909 	memdev->interleave_ways = 2;
910 	memdev->flags = ACPI_NFIT_MEM_HEALTH_ENABLED;
911 
912 	/* mem-region2 (spa1, dimm0) */
913 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 2;
914 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
915 	memdev->header.length = sizeof(*memdev);
916 	memdev->device_handle = handle[0];
917 	memdev->physical_id = 0;
918 	memdev->region_id = 1;
919 	memdev->range_index = 1+1;
920 	memdev->region_index = 4+1;
921 	memdev->region_size = SPA1_SIZE/4;
922 	memdev->region_offset = (1 << 16);
923 	memdev->address = SPA0_SIZE/2;
924 	memdev->interleave_index = 0;
925 	memdev->interleave_ways = 4;
926 	memdev->flags = ACPI_NFIT_MEM_HEALTH_ENABLED;
927 
928 	/* mem-region3 (spa1, dimm1) */
929 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 3;
930 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
931 	memdev->header.length = sizeof(*memdev);
932 	memdev->device_handle = handle[1];
933 	memdev->physical_id = 1;
934 	memdev->region_id = 1;
935 	memdev->range_index = 1+1;
936 	memdev->region_index = 5+1;
937 	memdev->region_size = SPA1_SIZE/4;
938 	memdev->region_offset = (1 << 24);
939 	memdev->address = SPA0_SIZE/2;
940 	memdev->interleave_index = 0;
941 	memdev->interleave_ways = 4;
942 
943 	/* mem-region4 (spa1, dimm2) */
944 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 4;
945 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
946 	memdev->header.length = sizeof(*memdev);
947 	memdev->device_handle = handle[2];
948 	memdev->physical_id = 2;
949 	memdev->region_id = 0;
950 	memdev->range_index = 1+1;
951 	memdev->region_index = 6+1;
952 	memdev->region_size = SPA1_SIZE/4;
953 	memdev->region_offset = (1ULL << 32);
954 	memdev->address = SPA0_SIZE/2;
955 	memdev->interleave_index = 0;
956 	memdev->interleave_ways = 4;
957 	memdev->flags = ACPI_NFIT_MEM_HEALTH_ENABLED;
958 
959 	/* mem-region5 (spa1, dimm3) */
960 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 5;
961 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
962 	memdev->header.length = sizeof(*memdev);
963 	memdev->device_handle = handle[3];
964 	memdev->physical_id = 3;
965 	memdev->region_id = 0;
966 	memdev->range_index = 1+1;
967 	memdev->region_index = 7+1;
968 	memdev->region_size = SPA1_SIZE/4;
969 	memdev->region_offset = (1ULL << 40);
970 	memdev->address = SPA0_SIZE/2;
971 	memdev->interleave_index = 0;
972 	memdev->interleave_ways = 4;
973 
974 	/* mem-region6 (spa/dcr0, dimm0) */
975 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 6;
976 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
977 	memdev->header.length = sizeof(*memdev);
978 	memdev->device_handle = handle[0];
979 	memdev->physical_id = 0;
980 	memdev->region_id = 0;
981 	memdev->range_index = 2+1;
982 	memdev->region_index = 0+1;
983 	memdev->region_size = 0;
984 	memdev->region_offset = 0;
985 	memdev->address = 0;
986 	memdev->interleave_index = 0;
987 	memdev->interleave_ways = 1;
988 
989 	/* mem-region7 (spa/dcr1, dimm1) */
990 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 7;
991 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
992 	memdev->header.length = sizeof(*memdev);
993 	memdev->device_handle = handle[1];
994 	memdev->physical_id = 1;
995 	memdev->region_id = 0;
996 	memdev->range_index = 3+1;
997 	memdev->region_index = 1+1;
998 	memdev->region_size = 0;
999 	memdev->region_offset = 0;
1000 	memdev->address = 0;
1001 	memdev->interleave_index = 0;
1002 	memdev->interleave_ways = 1;
1003 
1004 	/* mem-region8 (spa/dcr2, dimm2) */
1005 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 8;
1006 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1007 	memdev->header.length = sizeof(*memdev);
1008 	memdev->device_handle = handle[2];
1009 	memdev->physical_id = 2;
1010 	memdev->region_id = 0;
1011 	memdev->range_index = 4+1;
1012 	memdev->region_index = 2+1;
1013 	memdev->region_size = 0;
1014 	memdev->region_offset = 0;
1015 	memdev->address = 0;
1016 	memdev->interleave_index = 0;
1017 	memdev->interleave_ways = 1;
1018 
1019 	/* mem-region9 (spa/dcr3, dimm3) */
1020 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 9;
1021 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1022 	memdev->header.length = sizeof(*memdev);
1023 	memdev->device_handle = handle[3];
1024 	memdev->physical_id = 3;
1025 	memdev->region_id = 0;
1026 	memdev->range_index = 5+1;
1027 	memdev->region_index = 3+1;
1028 	memdev->region_size = 0;
1029 	memdev->region_offset = 0;
1030 	memdev->address = 0;
1031 	memdev->interleave_index = 0;
1032 	memdev->interleave_ways = 1;
1033 
1034 	/* mem-region10 (spa/bdw0, dimm0) */
1035 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 10;
1036 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1037 	memdev->header.length = sizeof(*memdev);
1038 	memdev->device_handle = handle[0];
1039 	memdev->physical_id = 0;
1040 	memdev->region_id = 0;
1041 	memdev->range_index = 6+1;
1042 	memdev->region_index = 0+1;
1043 	memdev->region_size = 0;
1044 	memdev->region_offset = 0;
1045 	memdev->address = 0;
1046 	memdev->interleave_index = 0;
1047 	memdev->interleave_ways = 1;
1048 
1049 	/* mem-region11 (spa/bdw1, dimm1) */
1050 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 11;
1051 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1052 	memdev->header.length = sizeof(*memdev);
1053 	memdev->device_handle = handle[1];
1054 	memdev->physical_id = 1;
1055 	memdev->region_id = 0;
1056 	memdev->range_index = 7+1;
1057 	memdev->region_index = 1+1;
1058 	memdev->region_size = 0;
1059 	memdev->region_offset = 0;
1060 	memdev->address = 0;
1061 	memdev->interleave_index = 0;
1062 	memdev->interleave_ways = 1;
1063 
1064 	/* mem-region12 (spa/bdw2, dimm2) */
1065 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 12;
1066 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1067 	memdev->header.length = sizeof(*memdev);
1068 	memdev->device_handle = handle[2];
1069 	memdev->physical_id = 2;
1070 	memdev->region_id = 0;
1071 	memdev->range_index = 8+1;
1072 	memdev->region_index = 2+1;
1073 	memdev->region_size = 0;
1074 	memdev->region_offset = 0;
1075 	memdev->address = 0;
1076 	memdev->interleave_index = 0;
1077 	memdev->interleave_ways = 1;
1078 
1079 	/* mem-region13 (spa/dcr3, dimm3) */
1080 	memdev = nfit_buf + offset + sizeof(struct acpi_nfit_memory_map) * 13;
1081 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1082 	memdev->header.length = sizeof(*memdev);
1083 	memdev->device_handle = handle[3];
1084 	memdev->physical_id = 3;
1085 	memdev->region_id = 0;
1086 	memdev->range_index = 9+1;
1087 	memdev->region_index = 3+1;
1088 	memdev->region_size = 0;
1089 	memdev->region_offset = 0;
1090 	memdev->address = 0;
1091 	memdev->interleave_index = 0;
1092 	memdev->interleave_ways = 1;
1093 	memdev->flags = ACPI_NFIT_MEM_HEALTH_ENABLED;
1094 
1095 	offset = offset + sizeof(struct acpi_nfit_memory_map) * 14;
1096 	/* dcr-descriptor0: blk */
1097 	dcr = nfit_buf + offset;
1098 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1099 	dcr->header.length = sizeof(struct acpi_nfit_control_region);
1100 	dcr->region_index = 0+1;
1101 	dcr_common_init(dcr);
1102 	dcr->serial_number = ~handle[0];
1103 	dcr->code = NFIT_FIC_BLK;
1104 	dcr->windows = 1;
1105 	dcr->window_size = DCR_SIZE;
1106 	dcr->command_offset = 0;
1107 	dcr->command_size = 8;
1108 	dcr->status_offset = 8;
1109 	dcr->status_size = 4;
1110 
1111 	/* dcr-descriptor1: blk */
1112 	dcr = nfit_buf + offset + sizeof(struct acpi_nfit_control_region);
1113 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1114 	dcr->header.length = sizeof(struct acpi_nfit_control_region);
1115 	dcr->region_index = 1+1;
1116 	dcr_common_init(dcr);
1117 	dcr->serial_number = ~handle[1];
1118 	dcr->code = NFIT_FIC_BLK;
1119 	dcr->windows = 1;
1120 	dcr->window_size = DCR_SIZE;
1121 	dcr->command_offset = 0;
1122 	dcr->command_size = 8;
1123 	dcr->status_offset = 8;
1124 	dcr->status_size = 4;
1125 
1126 	/* dcr-descriptor2: blk */
1127 	dcr = nfit_buf + offset + sizeof(struct acpi_nfit_control_region) * 2;
1128 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1129 	dcr->header.length = sizeof(struct acpi_nfit_control_region);
1130 	dcr->region_index = 2+1;
1131 	dcr_common_init(dcr);
1132 	dcr->serial_number = ~handle[2];
1133 	dcr->code = NFIT_FIC_BLK;
1134 	dcr->windows = 1;
1135 	dcr->window_size = DCR_SIZE;
1136 	dcr->command_offset = 0;
1137 	dcr->command_size = 8;
1138 	dcr->status_offset = 8;
1139 	dcr->status_size = 4;
1140 
1141 	/* dcr-descriptor3: blk */
1142 	dcr = nfit_buf + offset + sizeof(struct acpi_nfit_control_region) * 3;
1143 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1144 	dcr->header.length = sizeof(struct acpi_nfit_control_region);
1145 	dcr->region_index = 3+1;
1146 	dcr_common_init(dcr);
1147 	dcr->serial_number = ~handle[3];
1148 	dcr->code = NFIT_FIC_BLK;
1149 	dcr->windows = 1;
1150 	dcr->window_size = DCR_SIZE;
1151 	dcr->command_offset = 0;
1152 	dcr->command_size = 8;
1153 	dcr->status_offset = 8;
1154 	dcr->status_size = 4;
1155 
1156 	offset = offset + sizeof(struct acpi_nfit_control_region) * 4;
1157 	/* dcr-descriptor0: pmem */
1158 	dcr = nfit_buf + offset;
1159 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1160 	dcr->header.length = offsetof(struct acpi_nfit_control_region,
1161 			window_size);
1162 	dcr->region_index = 4+1;
1163 	dcr_common_init(dcr);
1164 	dcr->serial_number = ~handle[0];
1165 	dcr->code = NFIT_FIC_BYTEN;
1166 	dcr->windows = 0;
1167 
1168 	/* dcr-descriptor1: pmem */
1169 	dcr = nfit_buf + offset + offsetof(struct acpi_nfit_control_region,
1170 			window_size);
1171 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1172 	dcr->header.length = offsetof(struct acpi_nfit_control_region,
1173 			window_size);
1174 	dcr->region_index = 5+1;
1175 	dcr_common_init(dcr);
1176 	dcr->serial_number = ~handle[1];
1177 	dcr->code = NFIT_FIC_BYTEN;
1178 	dcr->windows = 0;
1179 
1180 	/* dcr-descriptor2: pmem */
1181 	dcr = nfit_buf + offset + offsetof(struct acpi_nfit_control_region,
1182 			window_size) * 2;
1183 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1184 	dcr->header.length = offsetof(struct acpi_nfit_control_region,
1185 			window_size);
1186 	dcr->region_index = 6+1;
1187 	dcr_common_init(dcr);
1188 	dcr->serial_number = ~handle[2];
1189 	dcr->code = NFIT_FIC_BYTEN;
1190 	dcr->windows = 0;
1191 
1192 	/* dcr-descriptor3: pmem */
1193 	dcr = nfit_buf + offset + offsetof(struct acpi_nfit_control_region,
1194 			window_size) * 3;
1195 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1196 	dcr->header.length = offsetof(struct acpi_nfit_control_region,
1197 			window_size);
1198 	dcr->region_index = 7+1;
1199 	dcr_common_init(dcr);
1200 	dcr->serial_number = ~handle[3];
1201 	dcr->code = NFIT_FIC_BYTEN;
1202 	dcr->windows = 0;
1203 
1204 	offset = offset + offsetof(struct acpi_nfit_control_region,
1205 			window_size) * 4;
1206 	/* bdw0 (spa/dcr0, dimm0) */
1207 	bdw = nfit_buf + offset;
1208 	bdw->header.type = ACPI_NFIT_TYPE_DATA_REGION;
1209 	bdw->header.length = sizeof(struct acpi_nfit_data_region);
1210 	bdw->region_index = 0+1;
1211 	bdw->windows = 1;
1212 	bdw->offset = 0;
1213 	bdw->size = BDW_SIZE;
1214 	bdw->capacity = DIMM_SIZE;
1215 	bdw->start_address = 0;
1216 
1217 	/* bdw1 (spa/dcr1, dimm1) */
1218 	bdw = nfit_buf + offset + sizeof(struct acpi_nfit_data_region);
1219 	bdw->header.type = ACPI_NFIT_TYPE_DATA_REGION;
1220 	bdw->header.length = sizeof(struct acpi_nfit_data_region);
1221 	bdw->region_index = 1+1;
1222 	bdw->windows = 1;
1223 	bdw->offset = 0;
1224 	bdw->size = BDW_SIZE;
1225 	bdw->capacity = DIMM_SIZE;
1226 	bdw->start_address = 0;
1227 
1228 	/* bdw2 (spa/dcr2, dimm2) */
1229 	bdw = nfit_buf + offset + sizeof(struct acpi_nfit_data_region) * 2;
1230 	bdw->header.type = ACPI_NFIT_TYPE_DATA_REGION;
1231 	bdw->header.length = sizeof(struct acpi_nfit_data_region);
1232 	bdw->region_index = 2+1;
1233 	bdw->windows = 1;
1234 	bdw->offset = 0;
1235 	bdw->size = BDW_SIZE;
1236 	bdw->capacity = DIMM_SIZE;
1237 	bdw->start_address = 0;
1238 
1239 	/* bdw3 (spa/dcr3, dimm3) */
1240 	bdw = nfit_buf + offset + sizeof(struct acpi_nfit_data_region) * 3;
1241 	bdw->header.type = ACPI_NFIT_TYPE_DATA_REGION;
1242 	bdw->header.length = sizeof(struct acpi_nfit_data_region);
1243 	bdw->region_index = 3+1;
1244 	bdw->windows = 1;
1245 	bdw->offset = 0;
1246 	bdw->size = BDW_SIZE;
1247 	bdw->capacity = DIMM_SIZE;
1248 	bdw->start_address = 0;
1249 
1250 	offset = offset + sizeof(struct acpi_nfit_data_region) * 4;
1251 	/* flush0 (dimm0) */
1252 	flush = nfit_buf + offset;
1253 	flush->header.type = ACPI_NFIT_TYPE_FLUSH_ADDRESS;
1254 	flush->header.length = flush_hint_size;
1255 	flush->device_handle = handle[0];
1256 	flush->hint_count = NUM_HINTS;
1257 	for (i = 0; i < NUM_HINTS; i++)
1258 		flush->hint_address[i] = t->flush_dma[0] + i * sizeof(u64);
1259 
1260 	/* flush1 (dimm1) */
1261 	flush = nfit_buf + offset + flush_hint_size * 1;
1262 	flush->header.type = ACPI_NFIT_TYPE_FLUSH_ADDRESS;
1263 	flush->header.length = flush_hint_size;
1264 	flush->device_handle = handle[1];
1265 	flush->hint_count = NUM_HINTS;
1266 	for (i = 0; i < NUM_HINTS; i++)
1267 		flush->hint_address[i] = t->flush_dma[1] + i * sizeof(u64);
1268 
1269 	/* flush2 (dimm2) */
1270 	flush = nfit_buf + offset + flush_hint_size  * 2;
1271 	flush->header.type = ACPI_NFIT_TYPE_FLUSH_ADDRESS;
1272 	flush->header.length = flush_hint_size;
1273 	flush->device_handle = handle[2];
1274 	flush->hint_count = NUM_HINTS;
1275 	for (i = 0; i < NUM_HINTS; i++)
1276 		flush->hint_address[i] = t->flush_dma[2] + i * sizeof(u64);
1277 
1278 	/* flush3 (dimm3) */
1279 	flush = nfit_buf + offset + flush_hint_size * 3;
1280 	flush->header.type = ACPI_NFIT_TYPE_FLUSH_ADDRESS;
1281 	flush->header.length = flush_hint_size;
1282 	flush->device_handle = handle[3];
1283 	flush->hint_count = NUM_HINTS;
1284 	for (i = 0; i < NUM_HINTS; i++)
1285 		flush->hint_address[i] = t->flush_dma[3] + i * sizeof(u64);
1286 
1287 	if (t->setup_hotplug) {
1288 		offset = offset + flush_hint_size * 4;
1289 		/* dcr-descriptor4: blk */
1290 		dcr = nfit_buf + offset;
1291 		dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1292 		dcr->header.length = sizeof(struct acpi_nfit_control_region);
1293 		dcr->region_index = 8+1;
1294 		dcr_common_init(dcr);
1295 		dcr->serial_number = ~handle[4];
1296 		dcr->code = NFIT_FIC_BLK;
1297 		dcr->windows = 1;
1298 		dcr->window_size = DCR_SIZE;
1299 		dcr->command_offset = 0;
1300 		dcr->command_size = 8;
1301 		dcr->status_offset = 8;
1302 		dcr->status_size = 4;
1303 
1304 		offset = offset + sizeof(struct acpi_nfit_control_region);
1305 		/* dcr-descriptor4: pmem */
1306 		dcr = nfit_buf + offset;
1307 		dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1308 		dcr->header.length = offsetof(struct acpi_nfit_control_region,
1309 				window_size);
1310 		dcr->region_index = 9+1;
1311 		dcr_common_init(dcr);
1312 		dcr->serial_number = ~handle[4];
1313 		dcr->code = NFIT_FIC_BYTEN;
1314 		dcr->windows = 0;
1315 
1316 		offset = offset + offsetof(struct acpi_nfit_control_region,
1317 				window_size);
1318 		/* bdw4 (spa/dcr4, dimm4) */
1319 		bdw = nfit_buf + offset;
1320 		bdw->header.type = ACPI_NFIT_TYPE_DATA_REGION;
1321 		bdw->header.length = sizeof(struct acpi_nfit_data_region);
1322 		bdw->region_index = 8+1;
1323 		bdw->windows = 1;
1324 		bdw->offset = 0;
1325 		bdw->size = BDW_SIZE;
1326 		bdw->capacity = DIMM_SIZE;
1327 		bdw->start_address = 0;
1328 
1329 		offset = offset + sizeof(struct acpi_nfit_data_region);
1330 		/* spa10 (dcr4) dimm4 */
1331 		spa = nfit_buf + offset;
1332 		spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
1333 		spa->header.length = sizeof(*spa);
1334 		memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_DCR), 16);
1335 		spa->range_index = 10+1;
1336 		spa->address = t->dcr_dma[4];
1337 		spa->length = DCR_SIZE;
1338 
1339 		/*
1340 		 * spa11 (single-dimm interleave for hotplug, note storage
1341 		 * does not actually alias the related block-data-window
1342 		 * regions)
1343 		 */
1344 		spa = nfit_buf + offset + sizeof(*spa);
1345 		spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
1346 		spa->header.length = sizeof(*spa);
1347 		memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_PM), 16);
1348 		spa->range_index = 11+1;
1349 		spa->address = t->spa_set_dma[2];
1350 		spa->length = SPA0_SIZE;
1351 
1352 		/* spa12 (bdw for dcr4) dimm4 */
1353 		spa = nfit_buf + offset + sizeof(*spa) * 2;
1354 		spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
1355 		spa->header.length = sizeof(*spa);
1356 		memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_BDW), 16);
1357 		spa->range_index = 12+1;
1358 		spa->address = t->dimm_dma[4];
1359 		spa->length = DIMM_SIZE;
1360 
1361 		offset = offset + sizeof(*spa) * 3;
1362 		/* mem-region14 (spa/dcr4, dimm4) */
1363 		memdev = nfit_buf + offset;
1364 		memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1365 		memdev->header.length = sizeof(*memdev);
1366 		memdev->device_handle = handle[4];
1367 		memdev->physical_id = 4;
1368 		memdev->region_id = 0;
1369 		memdev->range_index = 10+1;
1370 		memdev->region_index = 8+1;
1371 		memdev->region_size = 0;
1372 		memdev->region_offset = 0;
1373 		memdev->address = 0;
1374 		memdev->interleave_index = 0;
1375 		memdev->interleave_ways = 1;
1376 
1377 		/* mem-region15 (spa0, dimm4) */
1378 		memdev = nfit_buf + offset +
1379 				sizeof(struct acpi_nfit_memory_map);
1380 		memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1381 		memdev->header.length = sizeof(*memdev);
1382 		memdev->device_handle = handle[4];
1383 		memdev->physical_id = 4;
1384 		memdev->region_id = 0;
1385 		memdev->range_index = 11+1;
1386 		memdev->region_index = 9+1;
1387 		memdev->region_size = SPA0_SIZE;
1388 		memdev->region_offset = (1ULL << 48);
1389 		memdev->address = 0;
1390 		memdev->interleave_index = 0;
1391 		memdev->interleave_ways = 1;
1392 		memdev->flags = ACPI_NFIT_MEM_HEALTH_ENABLED;
1393 
1394 		/* mem-region16 (spa/bdw4, dimm4) */
1395 		memdev = nfit_buf + offset +
1396 				sizeof(struct acpi_nfit_memory_map) * 2;
1397 		memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1398 		memdev->header.length = sizeof(*memdev);
1399 		memdev->device_handle = handle[4];
1400 		memdev->physical_id = 4;
1401 		memdev->region_id = 0;
1402 		memdev->range_index = 12+1;
1403 		memdev->region_index = 8+1;
1404 		memdev->region_size = 0;
1405 		memdev->region_offset = 0;
1406 		memdev->address = 0;
1407 		memdev->interleave_index = 0;
1408 		memdev->interleave_ways = 1;
1409 
1410 		offset = offset + sizeof(struct acpi_nfit_memory_map) * 3;
1411 		/* flush3 (dimm4) */
1412 		flush = nfit_buf + offset;
1413 		flush->header.type = ACPI_NFIT_TYPE_FLUSH_ADDRESS;
1414 		flush->header.length = flush_hint_size;
1415 		flush->device_handle = handle[4];
1416 		flush->hint_count = NUM_HINTS;
1417 		for (i = 0; i < NUM_HINTS; i++)
1418 			flush->hint_address[i] = t->flush_dma[4]
1419 				+ i * sizeof(u64);
1420 	}
1421 
1422 	post_ars_status(&t->ars_state, t->spa_set_dma[0], SPA0_SIZE);
1423 
1424 	acpi_desc = &t->acpi_desc;
1425 	set_bit(ND_CMD_GET_CONFIG_SIZE, &acpi_desc->dimm_cmd_force_en);
1426 	set_bit(ND_CMD_GET_CONFIG_DATA, &acpi_desc->dimm_cmd_force_en);
1427 	set_bit(ND_CMD_SET_CONFIG_DATA, &acpi_desc->dimm_cmd_force_en);
1428 	set_bit(ND_CMD_SMART, &acpi_desc->dimm_cmd_force_en);
1429 	set_bit(ND_CMD_ARS_CAP, &acpi_desc->bus_cmd_force_en);
1430 	set_bit(ND_CMD_ARS_START, &acpi_desc->bus_cmd_force_en);
1431 	set_bit(ND_CMD_ARS_STATUS, &acpi_desc->bus_cmd_force_en);
1432 	set_bit(ND_CMD_CLEAR_ERROR, &acpi_desc->bus_cmd_force_en);
1433 	set_bit(ND_CMD_SMART_THRESHOLD, &acpi_desc->dimm_cmd_force_en);
1434 }
1435 
1436 static void nfit_test1_setup(struct nfit_test *t)
1437 {
1438 	size_t offset;
1439 	void *nfit_buf = t->nfit_buf;
1440 	struct acpi_nfit_memory_map *memdev;
1441 	struct acpi_nfit_control_region *dcr;
1442 	struct acpi_nfit_system_address *spa;
1443 	struct acpi_nfit_desc *acpi_desc;
1444 
1445 	offset = 0;
1446 	/* spa0 (flat range with no bdw aliasing) */
1447 	spa = nfit_buf + offset;
1448 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
1449 	spa->header.length = sizeof(*spa);
1450 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_PM), 16);
1451 	spa->range_index = 0+1;
1452 	spa->address = t->spa_set_dma[0];
1453 	spa->length = SPA2_SIZE;
1454 
1455 	/* virtual cd region */
1456 	spa = nfit_buf + sizeof(*spa);
1457 	spa->header.type = ACPI_NFIT_TYPE_SYSTEM_ADDRESS;
1458 	spa->header.length = sizeof(*spa);
1459 	memcpy(spa->range_guid, to_nfit_uuid(NFIT_SPA_VCD), 16);
1460 	spa->range_index = 0;
1461 	spa->address = t->spa_set_dma[1];
1462 	spa->length = SPA_VCD_SIZE;
1463 
1464 	offset += sizeof(*spa) * 2;
1465 	/* mem-region0 (spa0, dimm0) */
1466 	memdev = nfit_buf + offset;
1467 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1468 	memdev->header.length = sizeof(*memdev);
1469 	memdev->device_handle = handle[5];
1470 	memdev->physical_id = 0;
1471 	memdev->region_id = 0;
1472 	memdev->range_index = 0+1;
1473 	memdev->region_index = 0+1;
1474 	memdev->region_size = SPA2_SIZE;
1475 	memdev->region_offset = 0;
1476 	memdev->address = 0;
1477 	memdev->interleave_index = 0;
1478 	memdev->interleave_ways = 1;
1479 	memdev->flags = ACPI_NFIT_MEM_SAVE_FAILED | ACPI_NFIT_MEM_RESTORE_FAILED
1480 		| ACPI_NFIT_MEM_FLUSH_FAILED | ACPI_NFIT_MEM_HEALTH_OBSERVED
1481 		| ACPI_NFIT_MEM_NOT_ARMED;
1482 
1483 	offset += sizeof(*memdev);
1484 	/* dcr-descriptor0 */
1485 	dcr = nfit_buf + offset;
1486 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1487 	dcr->header.length = offsetof(struct acpi_nfit_control_region,
1488 			window_size);
1489 	dcr->region_index = 0+1;
1490 	dcr_common_init(dcr);
1491 	dcr->serial_number = ~handle[5];
1492 	dcr->code = NFIT_FIC_BYTE;
1493 	dcr->windows = 0;
1494 
1495 	offset += dcr->header.length;
1496 	memdev = nfit_buf + offset;
1497 	memdev->header.type = ACPI_NFIT_TYPE_MEMORY_MAP;
1498 	memdev->header.length = sizeof(*memdev);
1499 	memdev->device_handle = handle[6];
1500 	memdev->physical_id = 0;
1501 	memdev->region_id = 0;
1502 	memdev->range_index = 0;
1503 	memdev->region_index = 0+2;
1504 	memdev->region_size = SPA2_SIZE;
1505 	memdev->region_offset = 0;
1506 	memdev->address = 0;
1507 	memdev->interleave_index = 0;
1508 	memdev->interleave_ways = 1;
1509 	memdev->flags = ACPI_NFIT_MEM_MAP_FAILED;
1510 
1511 	/* dcr-descriptor1 */
1512 	offset += sizeof(*memdev);
1513 	dcr = nfit_buf + offset;
1514 	dcr->header.type = ACPI_NFIT_TYPE_CONTROL_REGION;
1515 	dcr->header.length = offsetof(struct acpi_nfit_control_region,
1516 			window_size);
1517 	dcr->region_index = 0+2;
1518 	dcr_common_init(dcr);
1519 	dcr->serial_number = ~handle[6];
1520 	dcr->code = NFIT_FIC_BYTE;
1521 	dcr->windows = 0;
1522 
1523 	post_ars_status(&t->ars_state, t->spa_set_dma[0], SPA2_SIZE);
1524 
1525 	acpi_desc = &t->acpi_desc;
1526 	set_bit(ND_CMD_ARS_CAP, &acpi_desc->bus_cmd_force_en);
1527 	set_bit(ND_CMD_ARS_START, &acpi_desc->bus_cmd_force_en);
1528 	set_bit(ND_CMD_ARS_STATUS, &acpi_desc->bus_cmd_force_en);
1529 	set_bit(ND_CMD_CLEAR_ERROR, &acpi_desc->bus_cmd_force_en);
1530 	set_bit(ND_CMD_GET_CONFIG_SIZE, &acpi_desc->dimm_cmd_force_en);
1531 	set_bit(ND_CMD_GET_CONFIG_DATA, &acpi_desc->dimm_cmd_force_en);
1532 	set_bit(ND_CMD_SET_CONFIG_DATA, &acpi_desc->dimm_cmd_force_en);
1533 }
1534 
1535 static int nfit_test_blk_do_io(struct nd_blk_region *ndbr, resource_size_t dpa,
1536 		void *iobuf, u64 len, int rw)
1537 {
1538 	struct nfit_blk *nfit_blk = ndbr->blk_provider_data;
1539 	struct nfit_blk_mmio *mmio = &nfit_blk->mmio[BDW];
1540 	struct nd_region *nd_region = &ndbr->nd_region;
1541 	unsigned int lane;
1542 
1543 	lane = nd_region_acquire_lane(nd_region);
1544 	if (rw)
1545 		memcpy(mmio->addr.base + dpa, iobuf, len);
1546 	else {
1547 		memcpy(iobuf, mmio->addr.base + dpa, len);
1548 
1549 		/* give us some some coverage of the mmio_flush_range() API */
1550 		mmio_flush_range(mmio->addr.base + dpa, len);
1551 	}
1552 	nd_region_release_lane(nd_region, lane);
1553 
1554 	return 0;
1555 }
1556 
1557 static unsigned long nfit_ctl_handle;
1558 
1559 union acpi_object *result;
1560 
1561 static union acpi_object *nfit_test_evaluate_dsm(acpi_handle handle,
1562 		const guid_t *guid, u64 rev, u64 func, union acpi_object *argv4)
1563 {
1564 	if (handle != &nfit_ctl_handle)
1565 		return ERR_PTR(-ENXIO);
1566 
1567 	return result;
1568 }
1569 
1570 static int setup_result(void *buf, size_t size)
1571 {
1572 	result = kmalloc(sizeof(union acpi_object) + size, GFP_KERNEL);
1573 	if (!result)
1574 		return -ENOMEM;
1575 	result->package.type = ACPI_TYPE_BUFFER,
1576 	result->buffer.pointer = (void *) (result + 1);
1577 	result->buffer.length = size;
1578 	memcpy(result->buffer.pointer, buf, size);
1579 	memset(buf, 0, size);
1580 	return 0;
1581 }
1582 
1583 static int nfit_ctl_test(struct device *dev)
1584 {
1585 	int rc, cmd_rc;
1586 	struct nvdimm *nvdimm;
1587 	struct acpi_device *adev;
1588 	struct nfit_mem *nfit_mem;
1589 	struct nd_ars_record *record;
1590 	struct acpi_nfit_desc *acpi_desc;
1591 	const u64 test_val = 0x0123456789abcdefULL;
1592 	unsigned long mask, cmd_size, offset;
1593 	union {
1594 		struct nd_cmd_get_config_size cfg_size;
1595 		struct nd_cmd_ars_status ars_stat;
1596 		struct nd_cmd_ars_cap ars_cap;
1597 		char buf[sizeof(struct nd_cmd_ars_status)
1598 			+ sizeof(struct nd_ars_record)];
1599 	} cmds;
1600 
1601 	adev = devm_kzalloc(dev, sizeof(*adev), GFP_KERNEL);
1602 	if (!adev)
1603 		return -ENOMEM;
1604 	*adev = (struct acpi_device) {
1605 		.handle = &nfit_ctl_handle,
1606 		.dev = {
1607 			.init_name = "test-adev",
1608 		},
1609 	};
1610 
1611 	acpi_desc = devm_kzalloc(dev, sizeof(*acpi_desc), GFP_KERNEL);
1612 	if (!acpi_desc)
1613 		return -ENOMEM;
1614 	*acpi_desc = (struct acpi_nfit_desc) {
1615 		.nd_desc = {
1616 			.cmd_mask = 1UL << ND_CMD_ARS_CAP
1617 				| 1UL << ND_CMD_ARS_START
1618 				| 1UL << ND_CMD_ARS_STATUS
1619 				| 1UL << ND_CMD_CLEAR_ERROR,
1620 			.module = THIS_MODULE,
1621 			.provider_name = "ACPI.NFIT",
1622 			.ndctl = acpi_nfit_ctl,
1623 		},
1624 		.dev = &adev->dev,
1625 	};
1626 
1627 	nfit_mem = devm_kzalloc(dev, sizeof(*nfit_mem), GFP_KERNEL);
1628 	if (!nfit_mem)
1629 		return -ENOMEM;
1630 
1631 	mask = 1UL << ND_CMD_SMART | 1UL << ND_CMD_SMART_THRESHOLD
1632 		| 1UL << ND_CMD_DIMM_FLAGS | 1UL << ND_CMD_GET_CONFIG_SIZE
1633 		| 1UL << ND_CMD_GET_CONFIG_DATA | 1UL << ND_CMD_SET_CONFIG_DATA
1634 		| 1UL << ND_CMD_VENDOR;
1635 	*nfit_mem = (struct nfit_mem) {
1636 		.adev = adev,
1637 		.family = NVDIMM_FAMILY_INTEL,
1638 		.dsm_mask = mask,
1639 	};
1640 
1641 	nvdimm = devm_kzalloc(dev, sizeof(*nvdimm), GFP_KERNEL);
1642 	if (!nvdimm)
1643 		return -ENOMEM;
1644 	*nvdimm = (struct nvdimm) {
1645 		.provider_data = nfit_mem,
1646 		.cmd_mask = mask,
1647 		.dev = {
1648 			.init_name = "test-dimm",
1649 		},
1650 	};
1651 
1652 
1653 	/* basic checkout of a typical 'get config size' command */
1654 	cmd_size = sizeof(cmds.cfg_size);
1655 	cmds.cfg_size = (struct nd_cmd_get_config_size) {
1656 		.status = 0,
1657 		.config_size = SZ_128K,
1658 		.max_xfer = SZ_4K,
1659 	};
1660 	rc = setup_result(cmds.buf, cmd_size);
1661 	if (rc)
1662 		return rc;
1663 	rc = acpi_nfit_ctl(&acpi_desc->nd_desc, nvdimm, ND_CMD_GET_CONFIG_SIZE,
1664 			cmds.buf, cmd_size, &cmd_rc);
1665 
1666 	if (rc < 0 || cmd_rc || cmds.cfg_size.status != 0
1667 			|| cmds.cfg_size.config_size != SZ_128K
1668 			|| cmds.cfg_size.max_xfer != SZ_4K) {
1669 		dev_dbg(dev, "%s: failed at: %d rc: %d cmd_rc: %d\n",
1670 				__func__, __LINE__, rc, cmd_rc);
1671 		return -EIO;
1672 	}
1673 
1674 
1675 	/* test ars_status with zero output */
1676 	cmd_size = offsetof(struct nd_cmd_ars_status, address);
1677 	cmds.ars_stat = (struct nd_cmd_ars_status) {
1678 		.out_length = 0,
1679 	};
1680 	rc = setup_result(cmds.buf, cmd_size);
1681 	if (rc)
1682 		return rc;
1683 	rc = acpi_nfit_ctl(&acpi_desc->nd_desc, NULL, ND_CMD_ARS_STATUS,
1684 			cmds.buf, cmd_size, &cmd_rc);
1685 
1686 	if (rc < 0 || cmd_rc) {
1687 		dev_dbg(dev, "%s: failed at: %d rc: %d cmd_rc: %d\n",
1688 				__func__, __LINE__, rc, cmd_rc);
1689 		return -EIO;
1690 	}
1691 
1692 
1693 	/* test ars_cap with benign extended status */
1694 	cmd_size = sizeof(cmds.ars_cap);
1695 	cmds.ars_cap = (struct nd_cmd_ars_cap) {
1696 		.status = ND_ARS_PERSISTENT << 16,
1697 	};
1698 	offset = offsetof(struct nd_cmd_ars_cap, status);
1699 	rc = setup_result(cmds.buf + offset, cmd_size - offset);
1700 	if (rc)
1701 		return rc;
1702 	rc = acpi_nfit_ctl(&acpi_desc->nd_desc, NULL, ND_CMD_ARS_CAP,
1703 			cmds.buf, cmd_size, &cmd_rc);
1704 
1705 	if (rc < 0 || cmd_rc) {
1706 		dev_dbg(dev, "%s: failed at: %d rc: %d cmd_rc: %d\n",
1707 				__func__, __LINE__, rc, cmd_rc);
1708 		return -EIO;
1709 	}
1710 
1711 
1712 	/* test ars_status with 'status' trimmed from 'out_length' */
1713 	cmd_size = sizeof(cmds.ars_stat) + sizeof(struct nd_ars_record);
1714 	cmds.ars_stat = (struct nd_cmd_ars_status) {
1715 		.out_length = cmd_size - 4,
1716 	};
1717 	record = &cmds.ars_stat.records[0];
1718 	*record = (struct nd_ars_record) {
1719 		.length = test_val,
1720 	};
1721 	rc = setup_result(cmds.buf, cmd_size);
1722 	if (rc)
1723 		return rc;
1724 	rc = acpi_nfit_ctl(&acpi_desc->nd_desc, NULL, ND_CMD_ARS_STATUS,
1725 			cmds.buf, cmd_size, &cmd_rc);
1726 
1727 	if (rc < 0 || cmd_rc || record->length != test_val) {
1728 		dev_dbg(dev, "%s: failed at: %d rc: %d cmd_rc: %d\n",
1729 				__func__, __LINE__, rc, cmd_rc);
1730 		return -EIO;
1731 	}
1732 
1733 
1734 	/* test ars_status with 'Output (Size)' including 'status' */
1735 	cmd_size = sizeof(cmds.ars_stat) + sizeof(struct nd_ars_record);
1736 	cmds.ars_stat = (struct nd_cmd_ars_status) {
1737 		.out_length = cmd_size,
1738 	};
1739 	record = &cmds.ars_stat.records[0];
1740 	*record = (struct nd_ars_record) {
1741 		.length = test_val,
1742 	};
1743 	rc = setup_result(cmds.buf, cmd_size);
1744 	if (rc)
1745 		return rc;
1746 	rc = acpi_nfit_ctl(&acpi_desc->nd_desc, NULL, ND_CMD_ARS_STATUS,
1747 			cmds.buf, cmd_size, &cmd_rc);
1748 
1749 	if (rc < 0 || cmd_rc || record->length != test_val) {
1750 		dev_dbg(dev, "%s: failed at: %d rc: %d cmd_rc: %d\n",
1751 				__func__, __LINE__, rc, cmd_rc);
1752 		return -EIO;
1753 	}
1754 
1755 
1756 	/* test extended status for get_config_size results in failure */
1757 	cmd_size = sizeof(cmds.cfg_size);
1758 	cmds.cfg_size = (struct nd_cmd_get_config_size) {
1759 		.status = 1 << 16,
1760 	};
1761 	rc = setup_result(cmds.buf, cmd_size);
1762 	if (rc)
1763 		return rc;
1764 	rc = acpi_nfit_ctl(&acpi_desc->nd_desc, nvdimm, ND_CMD_GET_CONFIG_SIZE,
1765 			cmds.buf, cmd_size, &cmd_rc);
1766 
1767 	if (rc < 0 || cmd_rc >= 0) {
1768 		dev_dbg(dev, "%s: failed at: %d rc: %d cmd_rc: %d\n",
1769 				__func__, __LINE__, rc, cmd_rc);
1770 		return -EIO;
1771 	}
1772 
1773 	return 0;
1774 }
1775 
1776 static int nfit_test_probe(struct platform_device *pdev)
1777 {
1778 	struct nvdimm_bus_descriptor *nd_desc;
1779 	struct acpi_nfit_desc *acpi_desc;
1780 	struct device *dev = &pdev->dev;
1781 	struct nfit_test *nfit_test;
1782 	struct nfit_mem *nfit_mem;
1783 	union acpi_object *obj;
1784 	int rc;
1785 
1786 	if (strcmp(dev_name(&pdev->dev), "nfit_test.0") == 0) {
1787 		rc = nfit_ctl_test(&pdev->dev);
1788 		if (rc)
1789 			return rc;
1790 	}
1791 
1792 	nfit_test = to_nfit_test(&pdev->dev);
1793 
1794 	/* common alloc */
1795 	if (nfit_test->num_dcr) {
1796 		int num = nfit_test->num_dcr;
1797 
1798 		nfit_test->dimm = devm_kcalloc(dev, num, sizeof(void *),
1799 				GFP_KERNEL);
1800 		nfit_test->dimm_dma = devm_kcalloc(dev, num, sizeof(dma_addr_t),
1801 				GFP_KERNEL);
1802 		nfit_test->flush = devm_kcalloc(dev, num, sizeof(void *),
1803 				GFP_KERNEL);
1804 		nfit_test->flush_dma = devm_kcalloc(dev, num, sizeof(dma_addr_t),
1805 				GFP_KERNEL);
1806 		nfit_test->label = devm_kcalloc(dev, num, sizeof(void *),
1807 				GFP_KERNEL);
1808 		nfit_test->label_dma = devm_kcalloc(dev, num,
1809 				sizeof(dma_addr_t), GFP_KERNEL);
1810 		nfit_test->dcr = devm_kcalloc(dev, num,
1811 				sizeof(struct nfit_test_dcr *), GFP_KERNEL);
1812 		nfit_test->dcr_dma = devm_kcalloc(dev, num,
1813 				sizeof(dma_addr_t), GFP_KERNEL);
1814 		if (nfit_test->dimm && nfit_test->dimm_dma && nfit_test->label
1815 				&& nfit_test->label_dma && nfit_test->dcr
1816 				&& nfit_test->dcr_dma && nfit_test->flush
1817 				&& nfit_test->flush_dma)
1818 			/* pass */;
1819 		else
1820 			return -ENOMEM;
1821 	}
1822 
1823 	if (nfit_test->num_pm) {
1824 		int num = nfit_test->num_pm;
1825 
1826 		nfit_test->spa_set = devm_kcalloc(dev, num, sizeof(void *),
1827 				GFP_KERNEL);
1828 		nfit_test->spa_set_dma = devm_kcalloc(dev, num,
1829 				sizeof(dma_addr_t), GFP_KERNEL);
1830 		if (nfit_test->spa_set && nfit_test->spa_set_dma)
1831 			/* pass */;
1832 		else
1833 			return -ENOMEM;
1834 	}
1835 
1836 	/* per-nfit specific alloc */
1837 	if (nfit_test->alloc(nfit_test))
1838 		return -ENOMEM;
1839 
1840 	nfit_test->setup(nfit_test);
1841 	acpi_desc = &nfit_test->acpi_desc;
1842 	acpi_nfit_desc_init(acpi_desc, &pdev->dev);
1843 	acpi_desc->blk_do_io = nfit_test_blk_do_io;
1844 	nd_desc = &acpi_desc->nd_desc;
1845 	nd_desc->provider_name = NULL;
1846 	nd_desc->module = THIS_MODULE;
1847 	nd_desc->ndctl = nfit_test_ctl;
1848 
1849 	rc = acpi_nfit_init(acpi_desc, nfit_test->nfit_buf,
1850 			nfit_test->nfit_size);
1851 	if (rc)
1852 		return rc;
1853 
1854 	rc = devm_add_action_or_reset(&pdev->dev, acpi_nfit_shutdown, acpi_desc);
1855 	if (rc)
1856 		return rc;
1857 
1858 	if (nfit_test->setup != nfit_test0_setup)
1859 		return 0;
1860 
1861 	nfit_test->setup_hotplug = 1;
1862 	nfit_test->setup(nfit_test);
1863 
1864 	obj = kzalloc(sizeof(*obj), GFP_KERNEL);
1865 	if (!obj)
1866 		return -ENOMEM;
1867 	obj->type = ACPI_TYPE_BUFFER;
1868 	obj->buffer.length = nfit_test->nfit_size;
1869 	obj->buffer.pointer = nfit_test->nfit_buf;
1870 	*(nfit_test->_fit) = obj;
1871 	__acpi_nfit_notify(&pdev->dev, nfit_test, 0x80);
1872 
1873 	/* associate dimm devices with nfit_mem data for notification testing */
1874 	mutex_lock(&acpi_desc->init_mutex);
1875 	list_for_each_entry(nfit_mem, &acpi_desc->dimms, list) {
1876 		u32 nfit_handle = __to_nfit_memdev(nfit_mem)->device_handle;
1877 		int i;
1878 
1879 		for (i = 0; i < NUM_DCR; i++)
1880 			if (nfit_handle == handle[i])
1881 				dev_set_drvdata(nfit_test->dimm_dev[i],
1882 						nfit_mem);
1883 	}
1884 	mutex_unlock(&acpi_desc->init_mutex);
1885 
1886 	return 0;
1887 }
1888 
1889 static int nfit_test_remove(struct platform_device *pdev)
1890 {
1891 	return 0;
1892 }
1893 
1894 static void nfit_test_release(struct device *dev)
1895 {
1896 	struct nfit_test *nfit_test = to_nfit_test(dev);
1897 
1898 	kfree(nfit_test);
1899 }
1900 
1901 static const struct platform_device_id nfit_test_id[] = {
1902 	{ KBUILD_MODNAME },
1903 	{ },
1904 };
1905 
1906 static struct platform_driver nfit_test_driver = {
1907 	.probe = nfit_test_probe,
1908 	.remove = nfit_test_remove,
1909 	.driver = {
1910 		.name = KBUILD_MODNAME,
1911 	},
1912 	.id_table = nfit_test_id,
1913 };
1914 
1915 static __init int nfit_test_init(void)
1916 {
1917 	int rc, i;
1918 
1919 	nfit_test_setup(nfit_test_lookup, nfit_test_evaluate_dsm);
1920 
1921 	nfit_test_dimm = class_create(THIS_MODULE, "nfit_test_dimm");
1922 	if (IS_ERR(nfit_test_dimm)) {
1923 		rc = PTR_ERR(nfit_test_dimm);
1924 		goto err_register;
1925 	}
1926 
1927 	for (i = 0; i < NUM_NFITS; i++) {
1928 		struct nfit_test *nfit_test;
1929 		struct platform_device *pdev;
1930 
1931 		nfit_test = kzalloc(sizeof(*nfit_test), GFP_KERNEL);
1932 		if (!nfit_test) {
1933 			rc = -ENOMEM;
1934 			goto err_register;
1935 		}
1936 		INIT_LIST_HEAD(&nfit_test->resources);
1937 		switch (i) {
1938 		case 0:
1939 			nfit_test->num_pm = NUM_PM;
1940 			nfit_test->dcr_idx = 0;
1941 			nfit_test->num_dcr = NUM_DCR;
1942 			nfit_test->alloc = nfit_test0_alloc;
1943 			nfit_test->setup = nfit_test0_setup;
1944 			break;
1945 		case 1:
1946 			nfit_test->num_pm = 2;
1947 			nfit_test->dcr_idx = NUM_DCR;
1948 			nfit_test->num_dcr = 2;
1949 			nfit_test->alloc = nfit_test1_alloc;
1950 			nfit_test->setup = nfit_test1_setup;
1951 			break;
1952 		default:
1953 			rc = -EINVAL;
1954 			goto err_register;
1955 		}
1956 		pdev = &nfit_test->pdev;
1957 		pdev->name = KBUILD_MODNAME;
1958 		pdev->id = i;
1959 		pdev->dev.release = nfit_test_release;
1960 		rc = platform_device_register(pdev);
1961 		if (rc) {
1962 			put_device(&pdev->dev);
1963 			goto err_register;
1964 		}
1965 		get_device(&pdev->dev);
1966 
1967 		rc = dma_coerce_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
1968 		if (rc)
1969 			goto err_register;
1970 
1971 		instances[i] = nfit_test;
1972 	}
1973 
1974 	rc = platform_driver_register(&nfit_test_driver);
1975 	if (rc)
1976 		goto err_register;
1977 	return 0;
1978 
1979  err_register:
1980 	for (i = 0; i < NUM_NFITS; i++)
1981 		if (instances[i])
1982 			platform_device_unregister(&instances[i]->pdev);
1983 	nfit_test_teardown();
1984 	for (i = 0; i < NUM_NFITS; i++)
1985 		if (instances[i])
1986 			put_device(&instances[i]->pdev.dev);
1987 
1988 	return rc;
1989 }
1990 
1991 static __exit void nfit_test_exit(void)
1992 {
1993 	int i;
1994 
1995 	for (i = 0; i < NUM_NFITS; i++)
1996 		platform_device_unregister(&instances[i]->pdev);
1997 	platform_driver_unregister(&nfit_test_driver);
1998 	nfit_test_teardown();
1999 
2000 	for (i = 0; i < NUM_NFITS; i++)
2001 		put_device(&instances[i]->pdev.dev);
2002 	class_destroy(nfit_test_dimm);
2003 }
2004 
2005 module_init(nfit_test_init);
2006 module_exit(nfit_test_exit);
2007 MODULE_LICENSE("GPL v2");
2008 MODULE_AUTHOR("Intel Corporation");
2009