hc
2024-05-11 645e752c5a84baeb21015cdc85fc05b7d16312c8
kernel/fs/pstore/ram_core.c
....@@ -439,7 +439,11 @@
439439 phys_addr_t addr = page_start + i * PAGE_SIZE;
440440 pages[i] = pfn_to_page(addr >> PAGE_SHIFT);
441441 }
442
- vaddr = vmap(pages, page_count, VM_MAP, prot);
442
+ /*
443
+ * VM_IOREMAP used here to bypass this region during vread()
444
+ * and kmap_atomic() (i.e. kcore) to avoid __va() failures.
445
+ */
446
+ vaddr = vmap(pages, page_count, VM_MAP | VM_IOREMAP, prot);
443447 kfree(pages);
444448
445449 /*
....@@ -514,7 +518,7 @@
514518 sig ^= PERSISTENT_RAM_SIG;
515519
516520 if (prz->buffer->sig == sig) {
517
- if (buffer_size(prz) == 0) {
521
+ if (buffer_size(prz) == 0 && buffer_start(prz) == 0) {
518522 pr_debug("found existing empty buffer\n");
519523 return 0;
520524 }
....@@ -587,6 +591,8 @@
587591 raw_spin_lock_init(&prz->buffer_lock);
588592 prz->flags = flags;
589593 prz->label = kstrdup(label, GFP_KERNEL);
594
+ if (!prz->label)
595
+ goto err;
590596
591597 ret = persistent_ram_buffer_map(start, size, prz, memtype);
592598 if (ret)