1 // SPDX-License-Identifier: GPL-2.0 2 // 3 // regmap KUnit tests 4 // 5 // Copyright 2023 Arm Ltd 6 7 #include <kunit/test.h> 8 #include "internal.h" 9 10 #define BLOCK_TEST_SIZE 12 11 12 static void get_changed_bytes(void *orig, void *new, size_t size) 13 { 14 char *o = orig; 15 char *n = new; 16 int i; 17 18 get_random_bytes(new, size); 19 20 /* 21 * This could be nicer and more efficient but we shouldn't 22 * super care. 23 */ 24 for (i = 0; i < size; i++) 25 while (n[i] == o[i]) 26 get_random_bytes(&n[i], 1); 27 } 28 29 static const struct regmap_config test_regmap_config = { 30 .max_register = BLOCK_TEST_SIZE, 31 .reg_stride = 1, 32 .val_bits = sizeof(unsigned int) * 8, 33 }; 34 35 struct regcache_types { 36 enum regcache_type type; 37 const char *name; 38 }; 39 40 static void case_to_desc(const struct regcache_types *t, char *desc) 41 { 42 strcpy(desc, t->name); 43 } 44 45 static const struct regcache_types regcache_types_list[] = { 46 { REGCACHE_NONE, "none" }, 47 { REGCACHE_FLAT, "flat" }, 48 { REGCACHE_RBTREE, "rbtree" }, 49 { REGCACHE_MAPLE, "maple" }, 50 }; 51 52 KUNIT_ARRAY_PARAM(regcache_types, regcache_types_list, case_to_desc); 53 54 static const struct regcache_types real_cache_types_list[] = { 55 { REGCACHE_FLAT, "flat" }, 56 { REGCACHE_RBTREE, "rbtree" }, 57 { REGCACHE_MAPLE, "maple" }, 58 }; 59 60 KUNIT_ARRAY_PARAM(real_cache_types, real_cache_types_list, case_to_desc); 61 62 static const struct regcache_types sparse_cache_types_list[] = { 63 { REGCACHE_RBTREE, "rbtree" }, 64 { REGCACHE_MAPLE, "maple" }, 65 }; 66 67 KUNIT_ARRAY_PARAM(sparse_cache_types, sparse_cache_types_list, case_to_desc); 68 69 static struct regmap *gen_regmap(struct regmap_config *config, 70 struct regmap_ram_data **data) 71 { 72 unsigned int *buf; 73 struct regmap *ret; 74 size_t size = (config->max_register + 1) * sizeof(unsigned int); 75 int i; 76 struct reg_default *defaults; 77 78 config->disable_locking = config->cache_type == REGCACHE_RBTREE || 79 config->cache_type == REGCACHE_MAPLE; 80 81 buf = kmalloc(size, GFP_KERNEL); 82 if (!buf) 83 return ERR_PTR(-ENOMEM); 84 85 get_random_bytes(buf, size); 86 87 *data = kzalloc(sizeof(**data), GFP_KERNEL); 88 if (!(*data)) 89 return ERR_PTR(-ENOMEM); 90 (*data)->vals = buf; 91 92 if (config->num_reg_defaults) { 93 defaults = kcalloc(config->num_reg_defaults, 94 sizeof(struct reg_default), 95 GFP_KERNEL); 96 if (!defaults) 97 return ERR_PTR(-ENOMEM); 98 config->reg_defaults = defaults; 99 100 for (i = 0; i < config->num_reg_defaults; i++) { 101 defaults[i].reg = i * config->reg_stride; 102 defaults[i].def = buf[i * config->reg_stride]; 103 } 104 } 105 106 ret = regmap_init_ram(config, *data); 107 if (IS_ERR(ret)) { 108 kfree(buf); 109 kfree(*data); 110 } 111 112 return ret; 113 } 114 115 static bool reg_5_false(struct device *context, unsigned int reg) 116 { 117 return reg != 5; 118 } 119 120 static void basic_read_write(struct kunit *test) 121 { 122 struct regcache_types *t = (struct regcache_types *)test->param_value; 123 struct regmap *map; 124 struct regmap_config config; 125 struct regmap_ram_data *data; 126 unsigned int val, rval; 127 128 config = test_regmap_config; 129 config.cache_type = t->type; 130 131 map = gen_regmap(&config, &data); 132 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 133 if (IS_ERR(map)) 134 return; 135 136 get_random_bytes(&val, sizeof(val)); 137 138 /* If we write a value to a register we can read it back */ 139 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 0, val)); 140 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 0, &rval)); 141 KUNIT_EXPECT_EQ(test, val, rval); 142 143 /* If using a cache the cache satisfied the read */ 144 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, data->read[0]); 145 146 regmap_exit(map); 147 } 148 149 static void bulk_write(struct kunit *test) 150 { 151 struct regcache_types *t = (struct regcache_types *)test->param_value; 152 struct regmap *map; 153 struct regmap_config config; 154 struct regmap_ram_data *data; 155 unsigned int val[BLOCK_TEST_SIZE], rval[BLOCK_TEST_SIZE]; 156 int i; 157 158 config = test_regmap_config; 159 config.cache_type = t->type; 160 161 map = gen_regmap(&config, &data); 162 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 163 if (IS_ERR(map)) 164 return; 165 166 get_random_bytes(&val, sizeof(val)); 167 168 /* 169 * Data written via the bulk API can be read back with single 170 * reads. 171 */ 172 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_write(map, 0, val, 173 BLOCK_TEST_SIZE)); 174 for (i = 0; i < BLOCK_TEST_SIZE; i++) 175 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &rval[i])); 176 177 KUNIT_EXPECT_MEMEQ(test, val, rval, sizeof(val)); 178 179 /* If using a cache the cache satisfied the read */ 180 for (i = 0; i < BLOCK_TEST_SIZE; i++) 181 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, data->read[i]); 182 183 regmap_exit(map); 184 } 185 186 static void bulk_read(struct kunit *test) 187 { 188 struct regcache_types *t = (struct regcache_types *)test->param_value; 189 struct regmap *map; 190 struct regmap_config config; 191 struct regmap_ram_data *data; 192 unsigned int val[BLOCK_TEST_SIZE], rval[BLOCK_TEST_SIZE]; 193 int i; 194 195 config = test_regmap_config; 196 config.cache_type = t->type; 197 198 map = gen_regmap(&config, &data); 199 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 200 if (IS_ERR(map)) 201 return; 202 203 get_random_bytes(&val, sizeof(val)); 204 205 /* Data written as single writes can be read via the bulk API */ 206 for (i = 0; i < BLOCK_TEST_SIZE; i++) 207 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, val[i])); 208 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 209 BLOCK_TEST_SIZE)); 210 KUNIT_EXPECT_MEMEQ(test, val, rval, sizeof(val)); 211 212 /* If using a cache the cache satisfied the read */ 213 for (i = 0; i < BLOCK_TEST_SIZE; i++) 214 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, data->read[i]); 215 216 regmap_exit(map); 217 } 218 219 static void write_readonly(struct kunit *test) 220 { 221 struct regcache_types *t = (struct regcache_types *)test->param_value; 222 struct regmap *map; 223 struct regmap_config config; 224 struct regmap_ram_data *data; 225 unsigned int val; 226 int i; 227 228 config = test_regmap_config; 229 config.cache_type = t->type; 230 config.num_reg_defaults = BLOCK_TEST_SIZE; 231 config.writeable_reg = reg_5_false; 232 233 map = gen_regmap(&config, &data); 234 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 235 if (IS_ERR(map)) 236 return; 237 238 get_random_bytes(&val, sizeof(val)); 239 240 for (i = 0; i < BLOCK_TEST_SIZE; i++) 241 data->written[i] = false; 242 243 /* Change the value of all registers, readonly should fail */ 244 for (i = 0; i < BLOCK_TEST_SIZE; i++) 245 KUNIT_EXPECT_EQ(test, i != 5, regmap_write(map, i, val) == 0); 246 247 /* Did that match what we see on the device? */ 248 for (i = 0; i < BLOCK_TEST_SIZE; i++) 249 KUNIT_EXPECT_EQ(test, i != 5, data->written[i]); 250 251 regmap_exit(map); 252 } 253 254 static void read_writeonly(struct kunit *test) 255 { 256 struct regcache_types *t = (struct regcache_types *)test->param_value; 257 struct regmap *map; 258 struct regmap_config config; 259 struct regmap_ram_data *data; 260 unsigned int val; 261 int i; 262 263 config = test_regmap_config; 264 config.cache_type = t->type; 265 config.readable_reg = reg_5_false; 266 267 map = gen_regmap(&config, &data); 268 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 269 if (IS_ERR(map)) 270 return; 271 272 for (i = 0; i < BLOCK_TEST_SIZE; i++) 273 data->read[i] = false; 274 275 /* 276 * Try to read all the registers, the writeonly one should 277 * fail if we aren't using the flat cache. 278 */ 279 for (i = 0; i < BLOCK_TEST_SIZE; i++) { 280 if (t->type != REGCACHE_FLAT) { 281 KUNIT_EXPECT_EQ(test, i != 5, 282 regmap_read(map, i, &val) == 0); 283 } else { 284 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &val)); 285 } 286 } 287 288 /* Did we trigger a hardware access? */ 289 KUNIT_EXPECT_FALSE(test, data->read[5]); 290 291 regmap_exit(map); 292 } 293 294 static void reg_defaults(struct kunit *test) 295 { 296 struct regcache_types *t = (struct regcache_types *)test->param_value; 297 struct regmap *map; 298 struct regmap_config config; 299 struct regmap_ram_data *data; 300 unsigned int rval[BLOCK_TEST_SIZE]; 301 int i; 302 303 config = test_regmap_config; 304 config.cache_type = t->type; 305 config.num_reg_defaults = BLOCK_TEST_SIZE; 306 307 map = gen_regmap(&config, &data); 308 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 309 if (IS_ERR(map)) 310 return; 311 312 /* Read back the expected default data */ 313 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 314 BLOCK_TEST_SIZE)); 315 KUNIT_EXPECT_MEMEQ(test, data->vals, rval, sizeof(rval)); 316 317 /* The data should have been read from cache if there was one */ 318 for (i = 0; i < BLOCK_TEST_SIZE; i++) 319 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, data->read[i]); 320 } 321 322 static void reg_defaults_read_dev(struct kunit *test) 323 { 324 struct regcache_types *t = (struct regcache_types *)test->param_value; 325 struct regmap *map; 326 struct regmap_config config; 327 struct regmap_ram_data *data; 328 unsigned int rval[BLOCK_TEST_SIZE]; 329 int i; 330 331 config = test_regmap_config; 332 config.cache_type = t->type; 333 config.num_reg_defaults_raw = BLOCK_TEST_SIZE; 334 335 map = gen_regmap(&config, &data); 336 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 337 if (IS_ERR(map)) 338 return; 339 340 /* We should have read the cache defaults back from the map */ 341 for (i = 0; i < BLOCK_TEST_SIZE; i++) { 342 KUNIT_EXPECT_EQ(test, t->type != REGCACHE_NONE, data->read[i]); 343 data->read[i] = false; 344 } 345 346 /* Read back the expected default data */ 347 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 348 BLOCK_TEST_SIZE)); 349 KUNIT_EXPECT_MEMEQ(test, data->vals, rval, sizeof(rval)); 350 351 /* The data should have been read from cache if there was one */ 352 for (i = 0; i < BLOCK_TEST_SIZE; i++) 353 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, data->read[i]); 354 } 355 356 static void register_patch(struct kunit *test) 357 { 358 struct regcache_types *t = (struct regcache_types *)test->param_value; 359 struct regmap *map; 360 struct regmap_config config; 361 struct regmap_ram_data *data; 362 struct reg_sequence patch[2]; 363 unsigned int rval[BLOCK_TEST_SIZE]; 364 int i; 365 366 /* We need defaults so readback works */ 367 config = test_regmap_config; 368 config.cache_type = t->type; 369 config.num_reg_defaults = BLOCK_TEST_SIZE; 370 371 map = gen_regmap(&config, &data); 372 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 373 if (IS_ERR(map)) 374 return; 375 376 /* Stash the original values */ 377 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 378 BLOCK_TEST_SIZE)); 379 380 /* Patch a couple of values */ 381 patch[0].reg = 2; 382 patch[0].def = rval[2] + 1; 383 patch[0].delay_us = 0; 384 patch[1].reg = 5; 385 patch[1].def = rval[5] + 1; 386 patch[1].delay_us = 0; 387 KUNIT_EXPECT_EQ(test, 0, regmap_register_patch(map, patch, 388 ARRAY_SIZE(patch))); 389 390 /* Only the patched registers are written */ 391 for (i = 0; i < BLOCK_TEST_SIZE; i++) { 392 switch (i) { 393 case 2: 394 case 5: 395 KUNIT_EXPECT_TRUE(test, data->written[i]); 396 KUNIT_EXPECT_EQ(test, data->vals[i], rval[i] + 1); 397 break; 398 default: 399 KUNIT_EXPECT_FALSE(test, data->written[i]); 400 KUNIT_EXPECT_EQ(test, data->vals[i], rval[i]); 401 break; 402 } 403 } 404 405 regmap_exit(map); 406 } 407 408 static void stride(struct kunit *test) 409 { 410 struct regcache_types *t = (struct regcache_types *)test->param_value; 411 struct regmap *map; 412 struct regmap_config config; 413 struct regmap_ram_data *data; 414 unsigned int rval; 415 int i; 416 417 config = test_regmap_config; 418 config.cache_type = t->type; 419 config.reg_stride = 2; 420 config.num_reg_defaults = BLOCK_TEST_SIZE / 2; 421 422 map = gen_regmap(&config, &data); 423 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 424 if (IS_ERR(map)) 425 return; 426 427 /* Only even registers can be accessed, try both read and write */ 428 for (i = 0; i < BLOCK_TEST_SIZE; i++) { 429 data->read[i] = false; 430 data->written[i] = false; 431 432 if (i % 2) { 433 KUNIT_EXPECT_NE(test, 0, regmap_read(map, i, &rval)); 434 KUNIT_EXPECT_NE(test, 0, regmap_write(map, i, rval)); 435 KUNIT_EXPECT_FALSE(test, data->read[i]); 436 KUNIT_EXPECT_FALSE(test, data->written[i]); 437 } else { 438 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &rval)); 439 KUNIT_EXPECT_EQ(test, data->vals[i], rval); 440 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, 441 data->read[i]); 442 443 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, rval)); 444 KUNIT_EXPECT_TRUE(test, data->written[i]); 445 } 446 } 447 448 regmap_exit(map); 449 } 450 451 static struct regmap_range_cfg test_range = { 452 .selector_reg = 1, 453 .selector_mask = 0xff, 454 455 .window_start = 4, 456 .window_len = 10, 457 458 .range_min = 20, 459 .range_max = 40, 460 }; 461 462 static bool test_range_window_volatile(struct device *dev, unsigned int reg) 463 { 464 if (reg >= test_range.window_start && 465 reg <= test_range.window_start + test_range.window_len) 466 return true; 467 468 return false; 469 } 470 471 static bool test_range_all_volatile(struct device *dev, unsigned int reg) 472 { 473 if (test_range_window_volatile(dev, reg)) 474 return true; 475 476 if (reg >= test_range.range_min && reg <= test_range.range_max) 477 return true; 478 479 return false; 480 } 481 482 static void basic_ranges(struct kunit *test) 483 { 484 struct regcache_types *t = (struct regcache_types *)test->param_value; 485 struct regmap *map; 486 struct regmap_config config; 487 struct regmap_ram_data *data; 488 unsigned int val; 489 int i; 490 491 config = test_regmap_config; 492 config.cache_type = t->type; 493 config.volatile_reg = test_range_all_volatile; 494 config.ranges = &test_range; 495 config.num_ranges = 1; 496 config.max_register = test_range.range_max; 497 498 map = gen_regmap(&config, &data); 499 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 500 if (IS_ERR(map)) 501 return; 502 503 for (i = test_range.range_min; i < test_range.range_max; i++) { 504 data->read[i] = false; 505 data->written[i] = false; 506 } 507 508 /* Reset the page to a non-zero value to trigger a change */ 509 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, test_range.selector_reg, 510 test_range.range_max)); 511 512 /* Check we set the page and use the window for writes */ 513 data->written[test_range.selector_reg] = false; 514 data->written[test_range.window_start] = false; 515 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, test_range.range_min, 0)); 516 KUNIT_EXPECT_TRUE(test, data->written[test_range.selector_reg]); 517 KUNIT_EXPECT_TRUE(test, data->written[test_range.window_start]); 518 519 data->written[test_range.selector_reg] = false; 520 data->written[test_range.window_start] = false; 521 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 522 test_range.range_min + 523 test_range.window_len, 524 0)); 525 KUNIT_EXPECT_TRUE(test, data->written[test_range.selector_reg]); 526 KUNIT_EXPECT_TRUE(test, data->written[test_range.window_start]); 527 528 /* Same for reads */ 529 data->written[test_range.selector_reg] = false; 530 data->read[test_range.window_start] = false; 531 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, test_range.range_min, &val)); 532 KUNIT_EXPECT_TRUE(test, data->written[test_range.selector_reg]); 533 KUNIT_EXPECT_TRUE(test, data->read[test_range.window_start]); 534 535 data->written[test_range.selector_reg] = false; 536 data->read[test_range.window_start] = false; 537 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 538 test_range.range_min + 539 test_range.window_len, 540 &val)); 541 KUNIT_EXPECT_TRUE(test, data->written[test_range.selector_reg]); 542 KUNIT_EXPECT_TRUE(test, data->read[test_range.window_start]); 543 544 /* No physical access triggered in the virtual range */ 545 for (i = test_range.range_min; i < test_range.range_max; i++) { 546 KUNIT_EXPECT_FALSE(test, data->read[i]); 547 KUNIT_EXPECT_FALSE(test, data->written[i]); 548 } 549 550 regmap_exit(map); 551 } 552 553 /* Try to stress dynamic creation of cache data structures */ 554 static void stress_insert(struct kunit *test) 555 { 556 struct regcache_types *t = (struct regcache_types *)test->param_value; 557 struct regmap *map; 558 struct regmap_config config; 559 struct regmap_ram_data *data; 560 unsigned int rval, *vals; 561 size_t buf_sz; 562 int i; 563 564 config = test_regmap_config; 565 config.cache_type = t->type; 566 config.max_register = 300; 567 568 map = gen_regmap(&config, &data); 569 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 570 if (IS_ERR(map)) 571 return; 572 573 vals = kunit_kcalloc(test, sizeof(unsigned long), config.max_register, 574 GFP_KERNEL); 575 KUNIT_ASSERT_FALSE(test, vals == NULL); 576 buf_sz = sizeof(unsigned long) * config.max_register; 577 578 get_random_bytes(vals, buf_sz); 579 580 /* Write data into the map/cache in ever decreasing strides */ 581 for (i = 0; i < config.max_register; i += 100) 582 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 583 for (i = 0; i < config.max_register; i += 50) 584 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 585 for (i = 0; i < config.max_register; i += 25) 586 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 587 for (i = 0; i < config.max_register; i += 10) 588 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 589 for (i = 0; i < config.max_register; i += 5) 590 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 591 for (i = 0; i < config.max_register; i += 3) 592 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 593 for (i = 0; i < config.max_register; i += 2) 594 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 595 for (i = 0; i < config.max_register; i++) 596 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, i, vals[i])); 597 598 /* Do reads from the cache (if there is one) match? */ 599 for (i = 0; i < config.max_register; i ++) { 600 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &rval)); 601 KUNIT_EXPECT_EQ(test, rval, vals[i]); 602 KUNIT_EXPECT_EQ(test, t->type == REGCACHE_NONE, data->read[i]); 603 } 604 605 regmap_exit(map); 606 } 607 608 static void cache_bypass(struct kunit *test) 609 { 610 struct regcache_types *t = (struct regcache_types *)test->param_value; 611 struct regmap *map; 612 struct regmap_config config; 613 struct regmap_ram_data *data; 614 unsigned int val, rval; 615 616 config = test_regmap_config; 617 config.cache_type = t->type; 618 619 map = gen_regmap(&config, &data); 620 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 621 if (IS_ERR(map)) 622 return; 623 624 get_random_bytes(&val, sizeof(val)); 625 626 /* Ensure the cache has a value in it */ 627 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 0, val)); 628 629 /* Bypass then write a different value */ 630 regcache_cache_bypass(map, true); 631 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 0, val + 1)); 632 633 /* Read the bypassed value */ 634 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 0, &rval)); 635 KUNIT_EXPECT_EQ(test, val + 1, rval); 636 KUNIT_EXPECT_EQ(test, data->vals[0], rval); 637 638 /* Disable bypass, the cache should still return the original value */ 639 regcache_cache_bypass(map, false); 640 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 0, &rval)); 641 KUNIT_EXPECT_EQ(test, val, rval); 642 643 regmap_exit(map); 644 } 645 646 static void cache_sync(struct kunit *test) 647 { 648 struct regcache_types *t = (struct regcache_types *)test->param_value; 649 struct regmap *map; 650 struct regmap_config config; 651 struct regmap_ram_data *data; 652 unsigned int val[BLOCK_TEST_SIZE]; 653 int i; 654 655 config = test_regmap_config; 656 config.cache_type = t->type; 657 658 map = gen_regmap(&config, &data); 659 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 660 if (IS_ERR(map)) 661 return; 662 663 get_random_bytes(&val, sizeof(val)); 664 665 /* Put some data into the cache */ 666 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_write(map, 0, val, 667 BLOCK_TEST_SIZE)); 668 for (i = 0; i < BLOCK_TEST_SIZE; i++) 669 data->written[i] = false; 670 671 /* Trash the data on the device itself then resync */ 672 regcache_mark_dirty(map); 673 memset(data->vals, 0, sizeof(val)); 674 KUNIT_EXPECT_EQ(test, 0, regcache_sync(map)); 675 676 /* Did we just write the correct data out? */ 677 KUNIT_EXPECT_MEMEQ(test, data->vals, val, sizeof(val)); 678 for (i = 0; i < BLOCK_TEST_SIZE; i++) 679 KUNIT_EXPECT_EQ(test, true, data->written[i]); 680 681 regmap_exit(map); 682 } 683 684 static void cache_sync_defaults(struct kunit *test) 685 { 686 struct regcache_types *t = (struct regcache_types *)test->param_value; 687 struct regmap *map; 688 struct regmap_config config; 689 struct regmap_ram_data *data; 690 unsigned int val; 691 int i; 692 693 config = test_regmap_config; 694 config.cache_type = t->type; 695 config.num_reg_defaults = BLOCK_TEST_SIZE; 696 697 map = gen_regmap(&config, &data); 698 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 699 if (IS_ERR(map)) 700 return; 701 702 get_random_bytes(&val, sizeof(val)); 703 704 /* Change the value of one register */ 705 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 2, val)); 706 707 /* Resync */ 708 regcache_mark_dirty(map); 709 for (i = 0; i < BLOCK_TEST_SIZE; i++) 710 data->written[i] = false; 711 KUNIT_EXPECT_EQ(test, 0, regcache_sync(map)); 712 713 /* Did we just sync the one register we touched? */ 714 for (i = 0; i < BLOCK_TEST_SIZE; i++) 715 KUNIT_EXPECT_EQ(test, i == 2, data->written[i]); 716 717 regmap_exit(map); 718 } 719 720 static void cache_sync_readonly(struct kunit *test) 721 { 722 struct regcache_types *t = (struct regcache_types *)test->param_value; 723 struct regmap *map; 724 struct regmap_config config; 725 struct regmap_ram_data *data; 726 unsigned int val; 727 int i; 728 729 config = test_regmap_config; 730 config.cache_type = t->type; 731 config.writeable_reg = reg_5_false; 732 733 map = gen_regmap(&config, &data); 734 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 735 if (IS_ERR(map)) 736 return; 737 738 /* Read all registers to fill the cache */ 739 for (i = 0; i < BLOCK_TEST_SIZE; i++) 740 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &val)); 741 742 /* Change the value of all registers, readonly should fail */ 743 get_random_bytes(&val, sizeof(val)); 744 regcache_cache_only(map, true); 745 for (i = 0; i < BLOCK_TEST_SIZE; i++) 746 KUNIT_EXPECT_EQ(test, i != 5, regmap_write(map, i, val) == 0); 747 regcache_cache_only(map, false); 748 749 /* Resync */ 750 for (i = 0; i < BLOCK_TEST_SIZE; i++) 751 data->written[i] = false; 752 KUNIT_EXPECT_EQ(test, 0, regcache_sync(map)); 753 754 /* Did that match what we see on the device? */ 755 for (i = 0; i < BLOCK_TEST_SIZE; i++) 756 KUNIT_EXPECT_EQ(test, i != 5, data->written[i]); 757 758 regmap_exit(map); 759 } 760 761 static void cache_sync_patch(struct kunit *test) 762 { 763 struct regcache_types *t = (struct regcache_types *)test->param_value; 764 struct regmap *map; 765 struct regmap_config config; 766 struct regmap_ram_data *data; 767 struct reg_sequence patch[2]; 768 unsigned int rval[BLOCK_TEST_SIZE], val; 769 int i; 770 771 /* We need defaults so readback works */ 772 config = test_regmap_config; 773 config.cache_type = t->type; 774 config.num_reg_defaults = BLOCK_TEST_SIZE; 775 776 map = gen_regmap(&config, &data); 777 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 778 if (IS_ERR(map)) 779 return; 780 781 /* Stash the original values */ 782 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 783 BLOCK_TEST_SIZE)); 784 785 /* Patch a couple of values */ 786 patch[0].reg = 2; 787 patch[0].def = rval[2] + 1; 788 patch[0].delay_us = 0; 789 patch[1].reg = 5; 790 patch[1].def = rval[5] + 1; 791 patch[1].delay_us = 0; 792 KUNIT_EXPECT_EQ(test, 0, regmap_register_patch(map, patch, 793 ARRAY_SIZE(patch))); 794 795 /* Sync the cache */ 796 regcache_mark_dirty(map); 797 for (i = 0; i < BLOCK_TEST_SIZE; i++) 798 data->written[i] = false; 799 KUNIT_EXPECT_EQ(test, 0, regcache_sync(map)); 800 801 /* The patch should be on the device but not in the cache */ 802 for (i = 0; i < BLOCK_TEST_SIZE; i++) { 803 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &val)); 804 KUNIT_EXPECT_EQ(test, val, rval[i]); 805 806 switch (i) { 807 case 2: 808 case 5: 809 KUNIT_EXPECT_EQ(test, true, data->written[i]); 810 KUNIT_EXPECT_EQ(test, data->vals[i], rval[i] + 1); 811 break; 812 default: 813 KUNIT_EXPECT_EQ(test, false, data->written[i]); 814 KUNIT_EXPECT_EQ(test, data->vals[i], rval[i]); 815 break; 816 } 817 } 818 819 regmap_exit(map); 820 } 821 822 static void cache_drop(struct kunit *test) 823 { 824 struct regcache_types *t = (struct regcache_types *)test->param_value; 825 struct regmap *map; 826 struct regmap_config config; 827 struct regmap_ram_data *data; 828 unsigned int rval[BLOCK_TEST_SIZE]; 829 int i; 830 831 config = test_regmap_config; 832 config.cache_type = t->type; 833 config.num_reg_defaults = BLOCK_TEST_SIZE; 834 835 map = gen_regmap(&config, &data); 836 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 837 if (IS_ERR(map)) 838 return; 839 840 /* Ensure the data is read from the cache */ 841 for (i = 0; i < BLOCK_TEST_SIZE; i++) 842 data->read[i] = false; 843 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 844 BLOCK_TEST_SIZE)); 845 for (i = 0; i < BLOCK_TEST_SIZE; i++) { 846 KUNIT_EXPECT_FALSE(test, data->read[i]); 847 data->read[i] = false; 848 } 849 KUNIT_EXPECT_MEMEQ(test, data->vals, rval, sizeof(rval)); 850 851 /* Drop some registers */ 852 KUNIT_EXPECT_EQ(test, 0, regcache_drop_region(map, 3, 5)); 853 854 /* Reread and check only the dropped registers hit the device. */ 855 KUNIT_EXPECT_EQ(test, 0, regmap_bulk_read(map, 0, rval, 856 BLOCK_TEST_SIZE)); 857 for (i = 0; i < BLOCK_TEST_SIZE; i++) 858 KUNIT_EXPECT_EQ(test, data->read[i], i >= 3 && i <= 5); 859 KUNIT_EXPECT_MEMEQ(test, data->vals, rval, sizeof(rval)); 860 861 regmap_exit(map); 862 } 863 864 static void cache_present(struct kunit *test) 865 { 866 struct regcache_types *t = (struct regcache_types *)test->param_value; 867 struct regmap *map; 868 struct regmap_config config; 869 struct regmap_ram_data *data; 870 unsigned int val; 871 int i; 872 873 config = test_regmap_config; 874 config.cache_type = t->type; 875 876 map = gen_regmap(&config, &data); 877 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 878 if (IS_ERR(map)) 879 return; 880 881 for (i = 0; i < BLOCK_TEST_SIZE; i++) 882 data->read[i] = false; 883 884 /* No defaults so no registers cached. */ 885 for (i = 0; i < BLOCK_TEST_SIZE; i++) 886 KUNIT_ASSERT_FALSE(test, regcache_reg_cached(map, i)); 887 888 /* We didn't trigger any reads */ 889 for (i = 0; i < BLOCK_TEST_SIZE; i++) 890 KUNIT_ASSERT_FALSE(test, data->read[i]); 891 892 /* Fill the cache */ 893 for (i = 0; i < BLOCK_TEST_SIZE; i++) 894 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &val)); 895 896 /* Now everything should be cached */ 897 for (i = 0; i < BLOCK_TEST_SIZE; i++) 898 KUNIT_ASSERT_TRUE(test, regcache_reg_cached(map, i)); 899 900 regmap_exit(map); 901 } 902 903 /* Check that caching the window register works with sync */ 904 static void cache_range_window_reg(struct kunit *test) 905 { 906 struct regcache_types *t = (struct regcache_types *)test->param_value; 907 struct regmap *map; 908 struct regmap_config config; 909 struct regmap_ram_data *data; 910 unsigned int val; 911 int i; 912 913 config = test_regmap_config; 914 config.cache_type = t->type; 915 config.volatile_reg = test_range_window_volatile; 916 config.ranges = &test_range; 917 config.num_ranges = 1; 918 config.max_register = test_range.range_max; 919 920 map = gen_regmap(&config, &data); 921 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 922 if (IS_ERR(map)) 923 return; 924 925 /* Write new values to the entire range */ 926 for (i = test_range.range_min; i <= test_range.range_max; i++) 927 KUNIT_ASSERT_EQ(test, 0, regmap_write(map, i, 0)); 928 929 val = data->vals[test_range.selector_reg] & test_range.selector_mask; 930 KUNIT_ASSERT_EQ(test, val, 2); 931 932 /* Write to the first register in the range to reset the page */ 933 KUNIT_ASSERT_EQ(test, 0, regmap_write(map, test_range.range_min, 0)); 934 val = data->vals[test_range.selector_reg] & test_range.selector_mask; 935 KUNIT_ASSERT_EQ(test, val, 0); 936 937 /* Trigger a cache sync */ 938 regcache_mark_dirty(map); 939 KUNIT_ASSERT_EQ(test, 0, regcache_sync(map)); 940 941 /* Write to the first register again, the page should be reset */ 942 KUNIT_ASSERT_EQ(test, 0, regmap_write(map, test_range.range_min, 0)); 943 val = data->vals[test_range.selector_reg] & test_range.selector_mask; 944 KUNIT_ASSERT_EQ(test, val, 0); 945 946 /* Trigger another cache sync */ 947 regcache_mark_dirty(map); 948 KUNIT_ASSERT_EQ(test, 0, regcache_sync(map)); 949 950 /* Write to the last register again, the page should be reset */ 951 KUNIT_ASSERT_EQ(test, 0, regmap_write(map, test_range.range_max, 0)); 952 val = data->vals[test_range.selector_reg] & test_range.selector_mask; 953 KUNIT_ASSERT_EQ(test, val, 2); 954 } 955 956 struct raw_test_types { 957 const char *name; 958 959 enum regcache_type cache_type; 960 enum regmap_endian val_endian; 961 }; 962 963 static void raw_to_desc(const struct raw_test_types *t, char *desc) 964 { 965 strcpy(desc, t->name); 966 } 967 968 static const struct raw_test_types raw_types_list[] = { 969 { "none-little", REGCACHE_NONE, REGMAP_ENDIAN_LITTLE }, 970 { "none-big", REGCACHE_NONE, REGMAP_ENDIAN_BIG }, 971 { "flat-little", REGCACHE_FLAT, REGMAP_ENDIAN_LITTLE }, 972 { "flat-big", REGCACHE_FLAT, REGMAP_ENDIAN_BIG }, 973 { "rbtree-little", REGCACHE_RBTREE, REGMAP_ENDIAN_LITTLE }, 974 { "rbtree-big", REGCACHE_RBTREE, REGMAP_ENDIAN_BIG }, 975 { "maple-little", REGCACHE_MAPLE, REGMAP_ENDIAN_LITTLE }, 976 { "maple-big", REGCACHE_MAPLE, REGMAP_ENDIAN_BIG }, 977 }; 978 979 KUNIT_ARRAY_PARAM(raw_test_types, raw_types_list, raw_to_desc); 980 981 static const struct raw_test_types raw_cache_types_list[] = { 982 { "flat-little", REGCACHE_FLAT, REGMAP_ENDIAN_LITTLE }, 983 { "flat-big", REGCACHE_FLAT, REGMAP_ENDIAN_BIG }, 984 { "rbtree-little", REGCACHE_RBTREE, REGMAP_ENDIAN_LITTLE }, 985 { "rbtree-big", REGCACHE_RBTREE, REGMAP_ENDIAN_BIG }, 986 { "maple-little", REGCACHE_MAPLE, REGMAP_ENDIAN_LITTLE }, 987 { "maple-big", REGCACHE_MAPLE, REGMAP_ENDIAN_BIG }, 988 }; 989 990 KUNIT_ARRAY_PARAM(raw_test_cache_types, raw_cache_types_list, raw_to_desc); 991 992 static const struct regmap_config raw_regmap_config = { 993 .max_register = BLOCK_TEST_SIZE, 994 995 .reg_format_endian = REGMAP_ENDIAN_LITTLE, 996 .reg_bits = 16, 997 .val_bits = 16, 998 }; 999 1000 static struct regmap *gen_raw_regmap(struct regmap_config *config, 1001 struct raw_test_types *test_type, 1002 struct regmap_ram_data **data) 1003 { 1004 u16 *buf; 1005 struct regmap *ret; 1006 size_t size = (config->max_register + 1) * config->reg_bits / 8; 1007 int i; 1008 struct reg_default *defaults; 1009 1010 config->cache_type = test_type->cache_type; 1011 config->val_format_endian = test_type->val_endian; 1012 config->disable_locking = config->cache_type == REGCACHE_RBTREE || 1013 config->cache_type == REGCACHE_MAPLE; 1014 1015 buf = kmalloc(size, GFP_KERNEL); 1016 if (!buf) 1017 return ERR_PTR(-ENOMEM); 1018 1019 get_random_bytes(buf, size); 1020 1021 *data = kzalloc(sizeof(**data), GFP_KERNEL); 1022 if (!(*data)) 1023 return ERR_PTR(-ENOMEM); 1024 (*data)->vals = (void *)buf; 1025 1026 config->num_reg_defaults = config->max_register + 1; 1027 defaults = kcalloc(config->num_reg_defaults, 1028 sizeof(struct reg_default), 1029 GFP_KERNEL); 1030 if (!defaults) 1031 return ERR_PTR(-ENOMEM); 1032 config->reg_defaults = defaults; 1033 1034 for (i = 0; i < config->num_reg_defaults; i++) { 1035 defaults[i].reg = i; 1036 switch (test_type->val_endian) { 1037 case REGMAP_ENDIAN_LITTLE: 1038 defaults[i].def = le16_to_cpu(buf[i]); 1039 break; 1040 case REGMAP_ENDIAN_BIG: 1041 defaults[i].def = be16_to_cpu(buf[i]); 1042 break; 1043 default: 1044 return ERR_PTR(-EINVAL); 1045 } 1046 } 1047 1048 /* 1049 * We use the defaults in the tests but they don't make sense 1050 * to the core if there's no cache. 1051 */ 1052 if (config->cache_type == REGCACHE_NONE) 1053 config->num_reg_defaults = 0; 1054 1055 ret = regmap_init_raw_ram(config, *data); 1056 if (IS_ERR(ret)) { 1057 kfree(buf); 1058 kfree(*data); 1059 } 1060 1061 return ret; 1062 } 1063 1064 static void raw_read_defaults_single(struct kunit *test) 1065 { 1066 struct raw_test_types *t = (struct raw_test_types *)test->param_value; 1067 struct regmap *map; 1068 struct regmap_config config; 1069 struct regmap_ram_data *data; 1070 unsigned int rval; 1071 int i; 1072 1073 config = raw_regmap_config; 1074 1075 map = gen_raw_regmap(&config, t, &data); 1076 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 1077 if (IS_ERR(map)) 1078 return; 1079 1080 /* Check that we can read the defaults via the API */ 1081 for (i = 0; i < config.max_register + 1; i++) { 1082 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &rval)); 1083 KUNIT_EXPECT_EQ(test, config.reg_defaults[i].def, rval); 1084 } 1085 1086 regmap_exit(map); 1087 } 1088 1089 static void raw_read_defaults(struct kunit *test) 1090 { 1091 struct raw_test_types *t = (struct raw_test_types *)test->param_value; 1092 struct regmap *map; 1093 struct regmap_config config; 1094 struct regmap_ram_data *data; 1095 u16 *rval; 1096 u16 def; 1097 size_t val_len; 1098 int i; 1099 1100 config = raw_regmap_config; 1101 1102 map = gen_raw_regmap(&config, t, &data); 1103 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 1104 if (IS_ERR(map)) 1105 return; 1106 1107 val_len = sizeof(*rval) * (config.max_register + 1); 1108 rval = kmalloc(val_len, GFP_KERNEL); 1109 KUNIT_ASSERT_TRUE(test, rval != NULL); 1110 if (!rval) 1111 return; 1112 1113 /* Check that we can read the defaults via the API */ 1114 KUNIT_EXPECT_EQ(test, 0, regmap_raw_read(map, 0, rval, val_len)); 1115 for (i = 0; i < config.max_register + 1; i++) { 1116 def = config.reg_defaults[i].def; 1117 if (config.val_format_endian == REGMAP_ENDIAN_BIG) { 1118 KUNIT_EXPECT_EQ(test, def, be16_to_cpu(rval[i])); 1119 } else { 1120 KUNIT_EXPECT_EQ(test, def, le16_to_cpu(rval[i])); 1121 } 1122 } 1123 1124 kfree(rval); 1125 regmap_exit(map); 1126 } 1127 1128 static void raw_write_read_single(struct kunit *test) 1129 { 1130 struct raw_test_types *t = (struct raw_test_types *)test->param_value; 1131 struct regmap *map; 1132 struct regmap_config config; 1133 struct regmap_ram_data *data; 1134 u16 val; 1135 unsigned int rval; 1136 1137 config = raw_regmap_config; 1138 1139 map = gen_raw_regmap(&config, t, &data); 1140 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 1141 if (IS_ERR(map)) 1142 return; 1143 1144 get_random_bytes(&val, sizeof(val)); 1145 1146 /* If we write a value to a register we can read it back */ 1147 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 0, val)); 1148 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 0, &rval)); 1149 KUNIT_EXPECT_EQ(test, val, rval); 1150 1151 regmap_exit(map); 1152 } 1153 1154 static void raw_write(struct kunit *test) 1155 { 1156 struct raw_test_types *t = (struct raw_test_types *)test->param_value; 1157 struct regmap *map; 1158 struct regmap_config config; 1159 struct regmap_ram_data *data; 1160 u16 *hw_buf; 1161 u16 val[2]; 1162 unsigned int rval; 1163 int i; 1164 1165 config = raw_regmap_config; 1166 1167 map = gen_raw_regmap(&config, t, &data); 1168 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 1169 if (IS_ERR(map)) 1170 return; 1171 1172 hw_buf = (u16 *)data->vals; 1173 1174 get_random_bytes(&val, sizeof(val)); 1175 1176 /* Do a raw write */ 1177 KUNIT_EXPECT_EQ(test, 0, regmap_raw_write(map, 2, val, sizeof(val))); 1178 1179 /* We should read back the new values, and defaults for the rest */ 1180 for (i = 0; i < config.max_register + 1; i++) { 1181 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &rval)); 1182 1183 switch (i) { 1184 case 2: 1185 case 3: 1186 if (config.val_format_endian == REGMAP_ENDIAN_BIG) { 1187 KUNIT_EXPECT_EQ(test, rval, 1188 be16_to_cpu(val[i % 2])); 1189 } else { 1190 KUNIT_EXPECT_EQ(test, rval, 1191 le16_to_cpu(val[i % 2])); 1192 } 1193 break; 1194 default: 1195 KUNIT_EXPECT_EQ(test, config.reg_defaults[i].def, rval); 1196 break; 1197 } 1198 } 1199 1200 /* The values should appear in the "hardware" */ 1201 KUNIT_EXPECT_MEMEQ(test, &hw_buf[2], val, sizeof(val)); 1202 1203 regmap_exit(map); 1204 } 1205 1206 static bool reg_zero(struct device *dev, unsigned int reg) 1207 { 1208 return reg == 0; 1209 } 1210 1211 static bool ram_reg_zero(struct regmap_ram_data *data, unsigned int reg) 1212 { 1213 return reg == 0; 1214 } 1215 1216 static void raw_noinc_write(struct kunit *test) 1217 { 1218 struct raw_test_types *t = (struct raw_test_types *)test->param_value; 1219 struct regmap *map; 1220 struct regmap_config config; 1221 struct regmap_ram_data *data; 1222 unsigned int val; 1223 u16 val_test, val_last; 1224 u16 val_array[BLOCK_TEST_SIZE]; 1225 1226 config = raw_regmap_config; 1227 config.volatile_reg = reg_zero; 1228 config.writeable_noinc_reg = reg_zero; 1229 config.readable_noinc_reg = reg_zero; 1230 1231 map = gen_raw_regmap(&config, t, &data); 1232 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 1233 if (IS_ERR(map)) 1234 return; 1235 1236 data->noinc_reg = ram_reg_zero; 1237 1238 get_random_bytes(&val_array, sizeof(val_array)); 1239 1240 if (config.val_format_endian == REGMAP_ENDIAN_BIG) { 1241 val_test = be16_to_cpu(val_array[1]) + 100; 1242 val_last = be16_to_cpu(val_array[BLOCK_TEST_SIZE - 1]); 1243 } else { 1244 val_test = le16_to_cpu(val_array[1]) + 100; 1245 val_last = le16_to_cpu(val_array[BLOCK_TEST_SIZE - 1]); 1246 } 1247 1248 /* Put some data into the register following the noinc register */ 1249 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 1, val_test)); 1250 1251 /* Write some data to the noinc register */ 1252 KUNIT_EXPECT_EQ(test, 0, regmap_noinc_write(map, 0, val_array, 1253 sizeof(val_array))); 1254 1255 /* We should read back the last value written */ 1256 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 0, &val)); 1257 KUNIT_ASSERT_EQ(test, val_last, val); 1258 1259 /* Make sure we didn't touch the register after the noinc register */ 1260 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, 1, &val)); 1261 KUNIT_ASSERT_EQ(test, val_test, val); 1262 1263 regmap_exit(map); 1264 } 1265 1266 static void raw_sync(struct kunit *test) 1267 { 1268 struct raw_test_types *t = (struct raw_test_types *)test->param_value; 1269 struct regmap *map; 1270 struct regmap_config config; 1271 struct regmap_ram_data *data; 1272 u16 val[3]; 1273 u16 *hw_buf; 1274 unsigned int rval; 1275 int i; 1276 1277 config = raw_regmap_config; 1278 1279 map = gen_raw_regmap(&config, t, &data); 1280 KUNIT_ASSERT_FALSE(test, IS_ERR(map)); 1281 if (IS_ERR(map)) 1282 return; 1283 1284 hw_buf = (u16 *)data->vals; 1285 1286 get_changed_bytes(&hw_buf[2], &val[0], sizeof(val)); 1287 1288 /* Do a regular write and a raw write in cache only mode */ 1289 regcache_cache_only(map, true); 1290 KUNIT_EXPECT_EQ(test, 0, regmap_raw_write(map, 2, val, 1291 sizeof(u16) * 2)); 1292 KUNIT_EXPECT_EQ(test, 0, regmap_write(map, 4, val[2])); 1293 1294 /* We should read back the new values, and defaults for the rest */ 1295 for (i = 0; i < config.max_register + 1; i++) { 1296 KUNIT_EXPECT_EQ(test, 0, regmap_read(map, i, &rval)); 1297 1298 switch (i) { 1299 case 2: 1300 case 3: 1301 if (config.val_format_endian == REGMAP_ENDIAN_BIG) { 1302 KUNIT_EXPECT_EQ(test, rval, 1303 be16_to_cpu(val[i - 2])); 1304 } else { 1305 KUNIT_EXPECT_EQ(test, rval, 1306 le16_to_cpu(val[i - 2])); 1307 } 1308 break; 1309 case 4: 1310 KUNIT_EXPECT_EQ(test, rval, val[i - 2]); 1311 break; 1312 default: 1313 KUNIT_EXPECT_EQ(test, config.reg_defaults[i].def, rval); 1314 break; 1315 } 1316 } 1317 1318 /* 1319 * The value written via _write() was translated by the core, 1320 * translate the original copy for comparison purposes. 1321 */ 1322 if (config.val_format_endian == REGMAP_ENDIAN_BIG) 1323 val[2] = cpu_to_be16(val[2]); 1324 else 1325 val[2] = cpu_to_le16(val[2]); 1326 1327 /* The values should not appear in the "hardware" */ 1328 KUNIT_EXPECT_MEMNEQ(test, &hw_buf[2], &val[0], sizeof(val)); 1329 1330 for (i = 0; i < config.max_register + 1; i++) 1331 data->written[i] = false; 1332 1333 /* Do the sync */ 1334 regcache_cache_only(map, false); 1335 regcache_mark_dirty(map); 1336 KUNIT_EXPECT_EQ(test, 0, regcache_sync(map)); 1337 1338 /* The values should now appear in the "hardware" */ 1339 KUNIT_EXPECT_MEMEQ(test, &hw_buf[2], &val[0], sizeof(val)); 1340 1341 regmap_exit(map); 1342 } 1343 1344 static struct kunit_case regmap_test_cases[] = { 1345 KUNIT_CASE_PARAM(basic_read_write, regcache_types_gen_params), 1346 KUNIT_CASE_PARAM(bulk_write, regcache_types_gen_params), 1347 KUNIT_CASE_PARAM(bulk_read, regcache_types_gen_params), 1348 KUNIT_CASE_PARAM(write_readonly, regcache_types_gen_params), 1349 KUNIT_CASE_PARAM(read_writeonly, regcache_types_gen_params), 1350 KUNIT_CASE_PARAM(reg_defaults, regcache_types_gen_params), 1351 KUNIT_CASE_PARAM(reg_defaults_read_dev, regcache_types_gen_params), 1352 KUNIT_CASE_PARAM(register_patch, regcache_types_gen_params), 1353 KUNIT_CASE_PARAM(stride, regcache_types_gen_params), 1354 KUNIT_CASE_PARAM(basic_ranges, regcache_types_gen_params), 1355 KUNIT_CASE_PARAM(stress_insert, regcache_types_gen_params), 1356 KUNIT_CASE_PARAM(cache_bypass, real_cache_types_gen_params), 1357 KUNIT_CASE_PARAM(cache_sync, real_cache_types_gen_params), 1358 KUNIT_CASE_PARAM(cache_sync_defaults, real_cache_types_gen_params), 1359 KUNIT_CASE_PARAM(cache_sync_readonly, real_cache_types_gen_params), 1360 KUNIT_CASE_PARAM(cache_sync_patch, real_cache_types_gen_params), 1361 KUNIT_CASE_PARAM(cache_drop, sparse_cache_types_gen_params), 1362 KUNIT_CASE_PARAM(cache_present, sparse_cache_types_gen_params), 1363 KUNIT_CASE_PARAM(cache_range_window_reg, real_cache_types_gen_params), 1364 1365 KUNIT_CASE_PARAM(raw_read_defaults_single, raw_test_types_gen_params), 1366 KUNIT_CASE_PARAM(raw_read_defaults, raw_test_types_gen_params), 1367 KUNIT_CASE_PARAM(raw_write_read_single, raw_test_types_gen_params), 1368 KUNIT_CASE_PARAM(raw_write, raw_test_types_gen_params), 1369 KUNIT_CASE_PARAM(raw_noinc_write, raw_test_types_gen_params), 1370 KUNIT_CASE_PARAM(raw_sync, raw_test_cache_types_gen_params), 1371 {} 1372 }; 1373 1374 static struct kunit_suite regmap_test_suite = { 1375 .name = "regmap", 1376 .test_cases = regmap_test_cases, 1377 }; 1378 kunit_test_suite(regmap_test_suite); 1379 1380 MODULE_LICENSE("GPL v2"); 1381