cregit-Linux how code gets into the kernel

Release 4.11 arch/mips/kernel/mips-cpc.c

Directory: arch/mips/kernel
/*
 * Copyright (C) 2013 Imagination Technologies
 * Author: Paul Burton <paul.burton@imgtec.com>
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License as published by the
 * Free Software Foundation;  either version 2 of the  License, or (at your
 * option) any later version.
 */

#include <linux/errno.h>
#include <linux/percpu.h>
#include <linux/spinlock.h>

#include <asm/mips-cm.h>
#include <asm/mips-cpc.h>


void __iomem *mips_cpc_base;

static DEFINE_PER_CPU_ALIGNED(spinlock_t, cpc_core_lock);

static DEFINE_PER_CPU_ALIGNED(unsigned long, cpc_core_lock_flags);


phys_addr_t __weak mips_cpc_default_phys_base(void) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Burton11100.00%1100.00%
Total11100.00%1100.00%

/** * mips_cpc_phys_base - retrieve the physical base address of the CPC * * This function returns the physical base address of the Cluster Power * Controller memory mapped registers, or 0 if no Cluster Power Controller * is present. */
static phys_addr_t mips_cpc_phys_base(void) { unsigned long cpc_base; if (!mips_cm_present()) return 0; if (!(read_gcr_cpc_status() & CM_GCR_CPC_STATUS_EX_MSK)) return 0; /* If the CPC is already enabled, leave it so */ cpc_base = read_gcr_cpc_base(); if (cpc_base & CM_GCR_CPC_BASE_CPCEN_MSK) return cpc_base & CM_GCR_CPC_BASE_CPCBASE_MSK; /* Otherwise, use the default address */ cpc_base = mips_cpc_default_phys_base(); if (!cpc_base) return cpc_base; /* Enable the CPC, mapped at the default address */ write_gcr_cpc_base(cpc_base | CM_GCR_CPC_BASE_CPCEN_MSK); return cpc_base; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Burton7294.74%240.00%
Markos Chandras22.63%120.00%
Björn Helgaas11.32%120.00%
Ralf Bächle11.32%120.00%
Total76100.00%5100.00%


int mips_cpc_probe(void) { phys_addr_t addr; unsigned int cpu; for_each_possible_cpu(cpu) spin_lock_init(&per_cpu(cpc_core_lock, cpu)); addr = mips_cpc_phys_base(); if (!addr) return -ENODEV; mips_cpc_base = ioremap_nocache(addr, 0x8000); if (!mips_cpc_base) return -ENXIO; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Burton6296.88%250.00%
Matt Redfearn11.56%125.00%
Ralf Bächle11.56%125.00%
Total64100.00%4100.00%


void mips_cpc_lock_other(unsigned int core) { unsigned int curr_core; if (mips_cm_revision() >= CM_REV_CM3) /* Systems with CM >= 3 lock the CPC via mips_cm_lock_other */ return; preempt_disable(); curr_core = current_cpu_data.core; spin_lock_irqsave(&per_cpu(cpc_core_lock, curr_core), per_cpu(cpc_core_lock_flags, curr_core)); write_cpc_cl_other(core << CPC_Cx_OTHER_CORENUM_SHF); /* * Ensure the core-other region reflects the appropriate core & * VP before any accesses to it occur. */ mb(); }

Contributors

PersonTokensPropCommitsCommitProp
Paul Burton5083.33%250.00%
Matt Redfearn1016.67%250.00%
Total60100.00%4100.00%


void mips_cpc_unlock_other(void) { unsigned int curr_core; if (mips_cm_revision() >= CM_REV_CM3) /* Systems with CM >= 3 lock the CPC via mips_cm_lock_other */ return; curr_core = current_cpu_data.core; spin_unlock_irqrestore(&per_cpu(cpc_core_lock, curr_core), per_cpu(cpc_core_lock_flags, curr_core)); preempt_enable(); }

Contributors

PersonTokensPropCommitsCommitProp
Paul Burton3370.21%133.33%
Matt Redfearn1429.79%266.67%
Total47100.00%3100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Paul Burton26589.53%550.00%
Matt Redfearn258.45%220.00%
Ralf Bächle20.68%110.00%
Björn Helgaas20.68%110.00%
Markos Chandras20.68%110.00%
Total296100.00%10100.00%
Directory: arch/mips/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.