Commit e5a2e7fd authored by Kyle McMartin's avatar Kyle McMartin Committed by Kyle McMartin

[PARISC] Match show_cache_info with reality

show_cache_info and struct pdc_cache_cf were out of sync with
published documentation. Fix the reporting of cache associativity
and update the pdc_cache_cf bitfields to match documentation.
Signed-off-by: default avatarKyle McMartin <kyle@parisc-linux.org>
parent 667baef5
...@@ -97,15 +97,17 @@ update_mmu_cache(struct vm_area_struct *vma, unsigned long address, pte_t pte) ...@@ -97,15 +97,17 @@ update_mmu_cache(struct vm_area_struct *vma, unsigned long address, pte_t pte)
void void
show_cache_info(struct seq_file *m) show_cache_info(struct seq_file *m)
{ {
char buf[32];
seq_printf(m, "I-cache\t\t: %ld KB\n", seq_printf(m, "I-cache\t\t: %ld KB\n",
cache_info.ic_size/1024 ); cache_info.ic_size/1024 );
seq_printf(m, "D-cache\t\t: %ld KB (%s%s, %d-way associative)\n", if (cache_info.dc_loop == 1)
snprintf(buf, 32, "%lu-way associative", cache_info.dc_loop);
seq_printf(m, "D-cache\t\t: %ld KB (%s%s, %s)\n",
cache_info.dc_size/1024, cache_info.dc_size/1024,
(cache_info.dc_conf.cc_wt ? "WT":"WB"), (cache_info.dc_conf.cc_wt ? "WT":"WB"),
(cache_info.dc_conf.cc_sh ? ", shared I/D":""), (cache_info.dc_conf.cc_sh ? ", shared I/D":""),
(cache_info.dc_conf.cc_assoc) ((cache_info.dc_loop == 1) ? "direct mapped" : buf));
);
seq_printf(m, "ITLB entries\t: %ld\n" "DTLB entries\t: %ld%s\n", seq_printf(m, "ITLB entries\t: %ld\n" "DTLB entries\t: %ld%s\n",
cache_info.it_size, cache_info.it_size,
cache_info.dt_size, cache_info.dt_size,
...@@ -158,11 +160,11 @@ parisc_cache_init(void) ...@@ -158,11 +160,11 @@ parisc_cache_init(void)
cache_info.dc_conf.cc_block, cache_info.dc_conf.cc_block,
cache_info.dc_conf.cc_line, cache_info.dc_conf.cc_line,
cache_info.dc_conf.cc_shift); cache_info.dc_conf.cc_shift);
printk(" wt %d sh %d cst %d assoc %d\n", printk(" wt %d sh %d cst %d hv %d\n",
cache_info.dc_conf.cc_wt, cache_info.dc_conf.cc_wt,
cache_info.dc_conf.cc_sh, cache_info.dc_conf.cc_sh,
cache_info.dc_conf.cc_cst, cache_info.dc_conf.cc_cst,
cache_info.dc_conf.cc_assoc); cache_info.dc_conf.cc_hv);
printk("IC base 0x%lx stride 0x%lx count 0x%lx loop 0x%lx\n", printk("IC base 0x%lx stride 0x%lx count 0x%lx loop 0x%lx\n",
cache_info.ic_base, cache_info.ic_base,
...@@ -176,11 +178,11 @@ parisc_cache_init(void) ...@@ -176,11 +178,11 @@ parisc_cache_init(void)
cache_info.ic_conf.cc_block, cache_info.ic_conf.cc_block,
cache_info.ic_conf.cc_line, cache_info.ic_conf.cc_line,
cache_info.ic_conf.cc_shift); cache_info.ic_conf.cc_shift);
printk(" wt %d sh %d cst %d assoc %d\n", printk(" wt %d sh %d cst %d hv %d\n",
cache_info.ic_conf.cc_wt, cache_info.ic_conf.cc_wt,
cache_info.ic_conf.cc_sh, cache_info.ic_conf.cc_sh,
cache_info.ic_conf.cc_cst, cache_info.ic_conf.cc_cst,
cache_info.ic_conf.cc_assoc); cache_info.ic_conf.cc_hv);
printk("D-TLB conf: sh %d page %d cst %d aid %d pad1 %d \n", printk("D-TLB conf: sh %d page %d cst %d aid %d pad1 %d \n",
cache_info.dt_conf.tc_sh, cache_info.dt_conf.tc_sh,
......
...@@ -352,8 +352,8 @@ struct pdc_cache_cf { /* for PDC_CACHE (I/D-caches) */ ...@@ -352,8 +352,8 @@ struct pdc_cache_cf { /* for PDC_CACHE (I/D-caches) */
cc_wt : 1, /* 0 = WT-Dcache, 1 = WB-Dcache */ cc_wt : 1, /* 0 = WT-Dcache, 1 = WB-Dcache */
cc_sh : 2, /* 0 = separate I/D-cache, else shared I/D-cache */ cc_sh : 2, /* 0 = separate I/D-cache, else shared I/D-cache */
cc_cst : 3, /* 0 = incoherent D-cache, 1=coherent D-cache */ cc_cst : 3, /* 0 = incoherent D-cache, 1=coherent D-cache */
cc_pad1 : 5, /* reserved */ cc_pad1 : 10, /* reserved */
cc_assoc: 8; /* associativity of I/D-cache */ cc_hv : 3; /* hversion dependent */
}; };
struct pdc_tlb_cf { /* for PDC_CACHE (I/D-TLB's) */ struct pdc_tlb_cf { /* for PDC_CACHE (I/D-TLB's) */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment