cregit-Linux how code gets into the kernel

Release 4.8 arch/mips/mm/sc-mips.c

Directory: arch/mips/mm
/*
 * Copyright (C) 2006 Chris Dearman (chris@mips.com),
 */
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/sched.h>
#include <linux/mm.h>

#include <asm/cpu-type.h>
#include <asm/mipsregs.h>
#include <asm/bcache.h>
#include <asm/cacheops.h>
#include <asm/page.h>
#include <asm/pgtable.h>
#include <asm/mmu_context.h>
#include <asm/r4kcache.h>
#include <asm/mips-cm.h>

/*
 * MIPS32/MIPS64 L2 cache handling
 */

/*
 * Writeback and invalidate the secondary cache before DMA.
 */

static void mips_sc_wback_inv(unsigned long addr, unsigned long size) { blast_scache_range(addr, addr + size); }

Contributors

PersonTokensPropCommitsCommitProp
chris dearmanchris dearman2295.65%150.00%
atsushi nemotoatsushi nemoto14.35%150.00%
Total23100.00%2100.00%

/* * Invalidate the secondary cache before DMA. */
static void mips_sc_inv(unsigned long addr, unsigned long size) { unsigned long lsize = cpu_scache_line_size(); unsigned long almask = ~(lsize - 1); cache_op(Hit_Writeback_Inv_SD, addr & almask); cache_op(Hit_Writeback_Inv_SD, (addr + size - 1) & almask); blast_inv_scache_range(addr, addr + size); }

Contributors

PersonTokensPropCommitsCommitProp
kevin cernekeekevin cernekee4264.62%133.33%
chris dearmanchris dearman2233.85%133.33%
atsushi nemotoatsushi nemoto11.54%133.33%
Total65100.00%3100.00%


static void mips_sc_enable(void) { /* L2 cache is permanently enabled */ }

Contributors

PersonTokensPropCommitsCommitProp
chris dearmanchris dearman9100.00%1100.00%
Total9100.00%1100.00%


static void mips_sc_disable(void) { /* L2 cache is permanently enabled */ }

Contributors

PersonTokensPropCommitsCommitProp
chris dearmanchris dearman9100.00%1100.00%
Total9100.00%1100.00%


static void mips_sc_prefetch_enable(void) { unsigned long pftctl; if (mips_cm_revision() < CM_REV_CM2_5) return; /* * If there is one or more L2 prefetch unit present then enable * prefetching for both code & data, for all ports. */ pftctl = read_gcr_l2_pft_control(); if (pftctl & CM_GCR_L2_PFT_CONTROL_NPFT_MSK) { pftctl &= ~CM_GCR_L2_PFT_CONTROL_PAGEMASK_MSK; pftctl |= PAGE_MASK & CM_GCR_L2_PFT_CONTROL_PAGEMASK_MSK; pftctl |= CM_GCR_L2_PFT_CONTROL_PFTEN_MSK; write_gcr_l2_pft_control(pftctl); pftctl = read_gcr_l2_pft_control_b(); pftctl |= CM_GCR_L2_PFT_CONTROL_B_PORTID_MSK; pftctl |= CM_GCR_L2_PFT_CONTROL_B_CEN_MSK; write_gcr_l2_pft_control_b(pftctl); } }

Contributors

PersonTokensPropCommitsCommitProp
paul burtonpaul burton72100.00%1100.00%
Total72100.00%1100.00%


static void mips_sc_prefetch_disable(void) { unsigned long pftctl; if (mips_cm_revision() < CM_REV_CM2_5) return; pftctl = read_gcr_l2_pft_control(); pftctl &= ~CM_GCR_L2_PFT_CONTROL_PFTEN_MSK; write_gcr_l2_pft_control(pftctl); pftctl = read_gcr_l2_pft_control_b(); pftctl &= ~CM_GCR_L2_PFT_CONTROL_B_PORTID_MSK; pftctl &= ~CM_GCR_L2_PFT_CONTROL_B_CEN_MSK; write_gcr_l2_pft_control_b(pftctl); }

Contributors

PersonTokensPropCommitsCommitProp
paul burtonpaul burton55100.00%1100.00%
Total55100.00%1100.00%


static bool mips_sc_prefetch_is_enabled(void) { unsigned long pftctl; if (mips_cm_revision() < CM_REV_CM2_5) return false; pftctl = read_gcr_l2_pft_control(); if (!(pftctl & CM_GCR_L2_PFT_CONTROL_NPFT_MSK)) return false; return !!(pftctl & CM_GCR_L2_PFT_CONTROL_PFTEN_MSK); }

Contributors

PersonTokensPropCommitsCommitProp
paul burtonpaul burton48100.00%1100.00%
Total48100.00%1100.00%

static struct bcache_ops mips_sc_ops = { .bc_enable = mips_sc_enable, .bc_disable = mips_sc_disable, .bc_wback_inv = mips_sc_wback_inv, .bc_inv = mips_sc_inv, .bc_prefetch_enable = mips_sc_prefetch_enable, .bc_prefetch_disable = mips_sc_prefetch_disable, .bc_prefetch_is_enabled = mips_sc_prefetch_is_enabled, }; /* * Check if the L2 cache controller is activated on a particular platform. * MTI's L2 controller and the L2 cache controller of Broadcom's BMIPS * cores both use c0_config2's bit 12 as "L2 Bypass" bit, that is the * cache being disabled. However there is no guarantee for this to be * true on all platforms. In an act of stupidity the spec defined bits * 12..15 as implementation defined so below function will eventually have * to be replaced by a platform specific probe. */
static inline int mips_sc_is_activated(struct cpuinfo_mips *c) { unsigned int config2 = read_c0_config2(); unsigned int tmp; /* Check the bypass bit (L2B) */ switch (current_cpu_type()) { case CPU_34K: case CPU_74K: case CPU_1004K: case CPU_1074K: case CPU_INTERAPTIV: case CPU_PROAPTIV: case CPU_P5600: case CPU_BMIPS5000: case CPU_QEMU_GENERIC: case CPU_P6600: if (config2 & (1 << 12)) return 0; } tmp = (config2 >> 4) & 0x0f; if (0 < tmp && tmp <= 7) c->scache.linesz = 2 << tmp; else return 0; return 1; }

Contributors

PersonTokensPropCommitsCommitProp
kevin cernekeekevin cernekee9181.98%222.22%
leonid yegoshinleonid yegoshin98.11%333.33%
paul burtonpaul burton32.70%111.11%
steven j. hillsteven j. hill32.70%111.11%
james hoganjames hogan32.70%111.11%
ralf baechleralf baechle21.80%111.11%
Total111100.00%9100.00%


static int __init mips_sc_probe_cm3(void) { struct cpuinfo_mips *c = &current_cpu_data; unsigned long cfg = read_gcr_l2_config(); unsigned long sets, line_sz, assoc; if (cfg & CM_GCR_L2_CONFIG_BYPASS_MSK) return 0; sets = cfg & CM_GCR_L2_CONFIG_SET_SIZE_MSK; sets >>= CM_GCR_L2_CONFIG_SET_SIZE_SHF; if (sets) c->scache.sets = 64 << sets; line_sz = cfg & CM_GCR_L2_CONFIG_LINE_SIZE_MSK; line_sz >>= CM_GCR_L2_CONFIG_LINE_SIZE_SHF; if (line_sz) c->scache.linesz = 2 << line_sz; assoc = cfg & CM_GCR_L2_CONFIG_ASSOC_MSK; assoc >>= CM_GCR_L2_CONFIG_ASSOC_SHF; c->scache.ways = assoc + 1; c->scache.waysize = c->scache.sets * c->scache.linesz; c->scache.waybit = __ffs(c->scache.waysize); if (c->scache.linesz) { c->scache.flags &= ~MIPS_CACHE_NOT_PRESENT; return 1; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
paul burtonpaul burton14687.43%150.00%
govindraj rajagovindraj raja2112.57%150.00%
Total167100.00%2100.00%


static inline int __init mips_sc_probe(void) { struct cpuinfo_mips *c = &current_cpu_data; unsigned int config1, config2; unsigned int tmp; /* Mark as not present until probe completed */ c->scache.flags |= MIPS_CACHE_NOT_PRESENT; if (mips_cm_revision() >= CM_REV_CM3) return mips_sc_probe_cm3(); /* Ignore anything but MIPSxx processors */ if (!(c->isa_level & (MIPS_CPU_ISA_M32R1 | MIPS_CPU_ISA_M32R2 | MIPS_CPU_ISA_M32R6 | MIPS_CPU_ISA_M64R1 | MIPS_CPU_ISA_M64R2 | MIPS_CPU_ISA_M64R6))) return 0; /* Does this MIPS32/MIPS64 CPU have a config2 register? */ config1 = read_c0_config1(); if (!(config1 & MIPS_CONF_M)) return 0; config2 = read_c0_config2(); if (!mips_sc_is_activated(c)) return 0; tmp = (config2 >> 8) & 0x0f; if (tmp <= 7) c->scache.sets = 64 << tmp; else return 0; tmp = (config2 >> 0) & 0x0f; if (tmp <= 7) c->scache.ways = tmp + 1; else return 0; c->scache.waysize = c->scache.sets * c->scache.linesz; c->scache.waybit = __ffs(c->scache.waysize); c->scache.flags &= ~MIPS_CACHE_NOT_PRESENT; return 1; }

Contributors

PersonTokensPropCommitsCommitProp
chris dearmanchris dearman17079.44%116.67%
atsushi nemotoatsushi nemoto157.01%116.67%
paul burtonpaul burton115.14%116.67%
deng-cheng zhudeng-cheng zhu94.21%116.67%
kevin cernekeekevin cernekee52.34%116.67%
markos chandrasmarkos chandras41.87%116.67%
Total214100.00%6100.00%


int mips_sc_init(void) { int found = mips_sc_probe(); if (found) { mips_sc_enable(); mips_sc_prefetch_enable(); bcops = &mips_sc_ops; } return found; }

Contributors

PersonTokensPropCommitsCommitProp
chris dearmanchris dearman3090.91%150.00%
paul burtonpaul burton39.09%150.00%
Total33100.00%2100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
paul burtonpaul burton35740.02%317.65%
chris dearmanchris dearman32536.43%15.88%
kevin cernekeekevin cernekee13915.58%317.65%
govindraj rajagovindraj raja212.35%15.88%
atsushi nemotoatsushi nemoto171.91%15.88%
deng-cheng zhudeng-cheng zhu91.01%15.88%
leonid yegoshinleonid yegoshin91.01%317.65%
ralf baechleralf baechle50.56%15.88%
markos chandrasmarkos chandras40.45%15.88%
steven j. hillsteven j. hill30.34%15.88%
james hoganjames hogan30.34%15.88%
Total892100.00%17100.00%
Directory: arch/mips/mm
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.