diff options
author | Paul Burton <paul.burton@mips.com> | 2019-02-02 04:43:24 +0300 |
---|---|---|
committer | Paul Burton <paul.burton@mips.com> | 2019-02-04 21:56:28 +0300 |
commit | 4ebea49ce233ce76421250f113a75d6d33c90e22 (patch) | |
tree | c2545c6b0cd71a225cd40a0e213716fee23d9c2b /arch/mips/mm/context.c | |
parent | 7e8556d06acd552ba4d01c0e0d7307f7b79f9945 (diff) | |
download | linux-4ebea49ce233ce76421250f113a75d6d33c90e22.tar.xz |
MIPS: mm: Un-inline get_new_mmu_context
In preparation for adding MMID support to get_new_mmu_context() which
will increase the size of the function somewhat, move it from
asm/mmu_context.h into a C file.
Signed-off-by: Paul Burton <paul.burton@mips.com>
Cc: linux-mips@vger.kernel.org
Diffstat (limited to 'arch/mips/mm/context.c')
-rw-r--r-- | arch/mips/mm/context.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/arch/mips/mm/context.c b/arch/mips/mm/context.c new file mode 100644 index 000000000000..b5af471006f0 --- /dev/null +++ b/arch/mips/mm/context.c @@ -0,0 +1,19 @@ +// SPDX-License-Identifier: GPL-2.0 +#include <linux/mmu_context.h> + +void get_new_mmu_context(struct mm_struct *mm) +{ + unsigned int cpu; + u64 asid; + + cpu = smp_processor_id(); + asid = asid_cache(cpu); + + if (!((asid += cpu_asid_inc()) & cpu_asid_mask(&cpu_data[cpu]))) { + if (cpu_has_vtag_icache) + flush_icache_all(); + local_flush_tlb_all(); /* start new asid cycle */ + } + + cpu_context(cpu, mm) = asid_cache(cpu) = asid; +} |