Skip to content

Commit 1227daa

Browse files
committed
pstore/ram: Clarify resource reservation labels
When ramoops reserved a memory region in the kernel, it had an unhelpful label of "persistent_memory". When reading /proc/iomem, it would be repeated many times, did not hint that it was ramoops in particular, and didn't clarify very much about what each was used for: 400000000-407ffffff : Persistent Memory (legacy) 400000000-400000fff : persistent_memory 400001000-400001fff : persistent_memory ... 4000ff000-4000fffff : persistent_memory Instead, this adds meaningful labels for how the various regions are being used: 400000000-407ffffff : Persistent Memory (legacy) 400000000-400000fff : ramoops:dump(0/252) 400001000-400001fff : ramoops:dump(1/252) ... 4000fc000-4000fcfff : ramoops:dump(252/252) 4000fd000-4000fdfff : ramoops:console 4000fe000-4000fe3ff : ramoops:ftrace(0/3) 4000fe400-4000fe7ff : ramoops:ftrace(1/3) 4000fe800-4000febff : ramoops:ftrace(2/3) 4000fec00-4000fefff : ramoops:ftrace(3/3) 4000ff000-4000fffff : ramoops:pmsg Signed-off-by: Kees Cook <keescook@chromium.org> Reviewed-by: Joel Fernandes (Google) <joel@joelfernandes.org> Tested-by: Sai Prakash Ranjan <saiprakash.ranjan@codeaurora.org> Tested-by: Guenter Roeck <groeck@chromium.org>
1 parent 95047b0 commit 1227daa

File tree

3 files changed

+22
-8
lines changed

3 files changed

+22
-8
lines changed

fs/pstore/ram.c

Lines changed: 13 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -587,9 +587,16 @@ static int ramoops_init_przs(const char *name,
587587
goto fail;
588588

589589
for (i = 0; i < *cnt; i++) {
590+
char *label;
591+
592+
if (*cnt == 1)
593+
label = kasprintf(GFP_KERNEL, "ramoops:%s", name);
594+
else
595+
label = kasprintf(GFP_KERNEL, "ramoops:%s(%d/%d)",
596+
name, i, *cnt - 1);
590597
prz_ar[i] = persistent_ram_new(*paddr, zone_sz, sig,
591-
&cxt->ecc_info,
592-
cxt->memtype, flags);
598+
&cxt->ecc_info,
599+
cxt->memtype, flags, label);
593600
if (IS_ERR(prz_ar[i])) {
594601
err = PTR_ERR(prz_ar[i]);
595602
dev_err(dev, "failed to request %s mem region (0x%zx@0x%llx): %d\n",
@@ -619,6 +626,8 @@ static int ramoops_init_prz(const char *name,
619626
struct persistent_ram_zone **prz,
620627
phys_addr_t *paddr, size_t sz, u32 sig)
621628
{
629+
char *label;
630+
622631
if (!sz)
623632
return 0;
624633

@@ -629,8 +638,9 @@ static int ramoops_init_prz(const char *name,
629638
return -ENOMEM;
630639
}
631640

641+
label = kasprintf(GFP_KERNEL, "ramoops:%s", name);
632642
*prz = persistent_ram_new(*paddr, sz, sig, &cxt->ecc_info,
633-
cxt->memtype, 0);
643+
cxt->memtype, 0, label);
634644
if (IS_ERR(*prz)) {
635645
int err = PTR_ERR(*prz);
636646

fs/pstore/ram_core.c

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -433,11 +433,11 @@ static void *persistent_ram_vmap(phys_addr_t start, size_t size,
433433
}
434434

435435
static void *persistent_ram_iomap(phys_addr_t start, size_t size,
436-
unsigned int memtype)
436+
unsigned int memtype, char *label)
437437
{
438438
void *va;
439439

440-
if (!request_mem_region(start, size, "persistent_ram")) {
440+
if (!request_mem_region(start, size, label ?: "ramoops")) {
441441
pr_err("request mem region (0x%llx@0x%llx) failed\n",
442442
(unsigned long long)size, (unsigned long long)start);
443443
return NULL;
@@ -460,7 +460,8 @@ static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size,
460460
if (pfn_valid(start >> PAGE_SHIFT))
461461
prz->vaddr = persistent_ram_vmap(start, size, memtype);
462462
else
463-
prz->vaddr = persistent_ram_iomap(start, size, memtype);
463+
prz->vaddr = persistent_ram_iomap(start, size, memtype,
464+
prz->label);
464465

465466
if (!prz->vaddr) {
466467
pr_err("%s: Failed to map 0x%llx pages at 0x%llx\n", __func__,
@@ -530,12 +531,13 @@ void persistent_ram_free(struct persistent_ram_zone *prz)
530531
prz->ecc_info.par = NULL;
531532

532533
persistent_ram_free_old(prz);
534+
kfree(prz->label);
533535
kfree(prz);
534536
}
535537

536538
struct persistent_ram_zone *persistent_ram_new(phys_addr_t start, size_t size,
537539
u32 sig, struct persistent_ram_ecc_info *ecc_info,
538-
unsigned int memtype, u32 flags)
540+
unsigned int memtype, u32 flags, char *label)
539541
{
540542
struct persistent_ram_zone *prz;
541543
int ret = -ENOMEM;
@@ -549,6 +551,7 @@ struct persistent_ram_zone *persistent_ram_new(phys_addr_t start, size_t size,
549551
/* Initialize general buffer state. */
550552
raw_spin_lock_init(&prz->buffer_lock);
551553
prz->flags = flags;
554+
prz->label = label;
552555

553556
ret = persistent_ram_buffer_map(start, size, prz, memtype);
554557
if (ret)

include/linux/pstore_ram.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -46,6 +46,7 @@ struct persistent_ram_zone {
4646
phys_addr_t paddr;
4747
size_t size;
4848
void *vaddr;
49+
char *label;
4950
struct persistent_ram_buffer *buffer;
5051
size_t buffer_size;
5152
u32 flags;
@@ -65,7 +66,7 @@ struct persistent_ram_zone {
6566

6667
struct persistent_ram_zone *persistent_ram_new(phys_addr_t start, size_t size,
6768
u32 sig, struct persistent_ram_ecc_info *ecc_info,
68-
unsigned int memtype, u32 flags);
69+
unsigned int memtype, u32 flags, char *label);
6970
void persistent_ram_free(struct persistent_ram_zone *prz);
7071
void persistent_ram_zap(struct persistent_ram_zone *prz);
7172

0 commit comments

Comments
 (0)