cregit-Linux how code gets into the kernel

Release 4.11 arch/arm/include/asm/tlbflush.h

/*
 *  arch/arm/include/asm/tlbflush.h
 *
 *  Copyright (C) 1999-2003 Russell King
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#ifndef _ASMARM_TLBFLUSH_H

#define _ASMARM_TLBFLUSH_H

#ifndef __ASSEMBLY__
# include <linux/mm_types.h>
#endif

#ifdef CONFIG_MMU

#include <asm/glue.h>


#define TLB_V4_U_PAGE	(1 << 1)

#define TLB_V4_D_PAGE	(1 << 2)

#define TLB_V4_I_PAGE	(1 << 3)

#define TLB_V6_U_PAGE	(1 << 4)

#define TLB_V6_D_PAGE	(1 << 5)

#define TLB_V6_I_PAGE	(1 << 6)


#define TLB_V4_U_FULL	(1 << 9)

#define TLB_V4_D_FULL	(1 << 10)

#define TLB_V4_I_FULL	(1 << 11)

#define TLB_V6_U_FULL	(1 << 12)

#define TLB_V6_D_FULL	(1 << 13)

#define TLB_V6_I_FULL	(1 << 14)


#define TLB_V6_U_ASID	(1 << 16)

#define TLB_V6_D_ASID	(1 << 17)

#define TLB_V6_I_ASID	(1 << 18)


#define TLB_V6_BP	(1 << 19)

/* Unified Inner Shareable TLB operations (ARMv7 MP extensions) */

#define TLB_V7_UIS_PAGE	(1 << 20)

#define TLB_V7_UIS_FULL (1 << 21)

#define TLB_V7_UIS_ASID (1 << 22)

#define TLB_V7_UIS_BP	(1 << 23)


#define TLB_BARRIER	(1 << 28)

#define TLB_L2CLEAN_FR	(1 << 29)		
/* Feroceon */

#define TLB_DCLEAN	(1 << 30)

#define TLB_WB		(1 << 31)

/*
 *      MMU TLB Model
 *      =============
 *
 *      We have the following to choose from:
 *        v4    - ARMv4 without write buffer
 *        v4wb  - ARMv4 with write buffer without I TLB flush entry instruction
 *        v4wbi - ARMv4 with write buffer with I TLB flush entry instruction
 *        fr    - Feroceon (v4wbi with non-outer-cacheable page table walks)
 *        fa    - Faraday (v4 with write buffer with UTLB)
 *        v6wbi - ARMv6 with write buffer with I TLB flush entry instruction
 *        v7wbi - identical to v6wbi
 */

#undef _TLB

#undef MULTI_TLB

#ifdef CONFIG_SMP_ON_UP

#define MULTI_TLB 1
#endif


#define v4_tlb_flags	(TLB_V4_U_FULL | TLB_V4_U_PAGE)

#ifdef CONFIG_CPU_TLB_V4WT

# define v4_possible_flags	v4_tlb_flags

# define v4_always_flags	v4_tlb_flags
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB v4
# endif
#else

# define v4_possible_flags	0

# define v4_always_flags	(-1UL)
#endif


#define fa_tlb_flags	(TLB_WB | TLB_DCLEAN | TLB_BARRIER | \
                         TLB_V4_U_FULL | TLB_V4_U_PAGE)

#ifdef CONFIG_CPU_TLB_FA

# define fa_possible_flags	fa_tlb_flags

# define fa_always_flags	fa_tlb_flags
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB fa
# endif
#else

# define fa_possible_flags	0

# define fa_always_flags	(-1UL)
#endif


#define v4wbi_tlb_flags	(TLB_WB | TLB_DCLEAN | \
                         TLB_V4_I_FULL | TLB_V4_D_FULL | \
                         TLB_V4_I_PAGE | TLB_V4_D_PAGE)

#ifdef CONFIG_CPU_TLB_V4WBI

# define v4wbi_possible_flags	v4wbi_tlb_flags

# define v4wbi_always_flags	v4wbi_tlb_flags
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB v4wbi
# endif
#else

# define v4wbi_possible_flags	0

# define v4wbi_always_flags	(-1UL)
#endif


#define fr_tlb_flags	(TLB_WB | TLB_DCLEAN | TLB_L2CLEAN_FR | \
                         TLB_V4_I_FULL | TLB_V4_D_FULL | \
                         TLB_V4_I_PAGE | TLB_V4_D_PAGE)

#ifdef CONFIG_CPU_TLB_FEROCEON

# define fr_possible_flags	fr_tlb_flags

# define fr_always_flags	fr_tlb_flags
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB v4wbi
# endif
#else

# define fr_possible_flags	0

# define fr_always_flags	(-1UL)
#endif


#define v4wb_tlb_flags	(TLB_WB | TLB_DCLEAN | \
                         TLB_V4_I_FULL | TLB_V4_D_FULL | \
                         TLB_V4_D_PAGE)

#ifdef CONFIG_CPU_TLB_V4WB

# define v4wb_possible_flags	v4wb_tlb_flags

# define v4wb_always_flags	v4wb_tlb_flags
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB v4wb
# endif
#else

# define v4wb_possible_flags	0

# define v4wb_always_flags	(-1UL)
#endif


#define v6wbi_tlb_flags (TLB_WB | TLB_DCLEAN | TLB_BARRIER | \
                         TLB_V6_I_FULL | TLB_V6_D_FULL | \
                         TLB_V6_I_PAGE | TLB_V6_D_PAGE | \
                         TLB_V6_I_ASID | TLB_V6_D_ASID | \
                         TLB_V6_BP)

#ifdef CONFIG_CPU_TLB_V6

# define v6wbi_possible_flags	v6wbi_tlb_flags

# define v6wbi_always_flags	v6wbi_tlb_flags
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB v6wbi
# endif
#else

# define v6wbi_possible_flags	0

# define v6wbi_always_flags	(-1UL)
#endif


#define v7wbi_tlb_flags_smp	(TLB_WB | TLB_BARRIER | \
                                 TLB_V7_UIS_FULL | TLB_V7_UIS_PAGE | \
                                 TLB_V7_UIS_ASID | TLB_V7_UIS_BP)

#define v7wbi_tlb_flags_up	(TLB_WB | TLB_DCLEAN | TLB_BARRIER | \
                                 TLB_V6_U_FULL | TLB_V6_U_PAGE | \
                                 TLB_V6_U_ASID | TLB_V6_BP)

#ifdef CONFIG_CPU_TLB_V7

# ifdef CONFIG_SMP_ON_UP

#  define v7wbi_possible_flags	(v7wbi_tlb_flags_smp | v7wbi_tlb_flags_up)

#  define v7wbi_always_flags	(v7wbi_tlb_flags_smp & v7wbi_tlb_flags_up)
# elif defined(CONFIG_SMP)

#  define v7wbi_possible_flags	v7wbi_tlb_flags_smp

#  define v7wbi_always_flags	v7wbi_tlb_flags_smp
# else

#  define v7wbi_possible_flags	v7wbi_tlb_flags_up

#  define v7wbi_always_flags	v7wbi_tlb_flags_up
# endif
# ifdef _TLB

#  define MULTI_TLB 1
# else

#  define _TLB v7wbi
# endif
#else

# define v7wbi_possible_flags	0

# define v7wbi_always_flags	(-1UL)
#endif

#ifndef _TLB
#error Unknown TLB model
#endif

#ifndef __ASSEMBLY__

#include <linux/sched.h>


struct cpu_tlb_fns {
	
void (*flush_user_range)(unsigned long, unsigned long, struct vm_area_struct *);
	
void (*flush_kern_range)(unsigned long, unsigned long);
	
unsigned long tlb_flags;
};

/*
 * Select the calling method
 */
#ifdef MULTI_TLB


#define __cpu_flush_user_tlb_range	cpu_tlb.flush_user_range

#define __cpu_flush_kern_tlb_range	cpu_tlb.flush_kern_range

#else


#define __cpu_flush_user_tlb_range	__glue(_TLB,_flush_user_tlb_range)

#define __cpu_flush_kern_tlb_range	__glue(_TLB,_flush_kern_tlb_range)

extern void __cpu_flush_user_tlb_range(unsigned long, unsigned long, struct vm_area_struct *);
extern void __cpu_flush_kern_tlb_range(unsigned long, unsigned long);

#endif

extern struct cpu_tlb_fns cpu_tlb;


#define __cpu_tlb_flags			cpu_tlb.tlb_flags

/*
 *      TLB Management
 *      ==============
 *
 *      The arch/arm/mm/tlb-*.S files implement these methods.
 *
 *      The TLB specific code is expected to perform whatever tests it
 *      needs to determine if it should invalidate the TLB for each
 *      call.  Start addresses are inclusive and end addresses are
 *      exclusive; it is safe to round these addresses down.
 *
 *      flush_tlb_all()
 *
 *              Invalidate the entire TLB.
 *
 *      flush_tlb_mm(mm)
 *
 *              Invalidate all TLB entries in a particular address
 *              space.
 *              - mm    - mm_struct describing address space
 *
 *      flush_tlb_range(mm,start,end)
 *
 *              Invalidate a range of TLB entries in the specified
 *              address space.
 *              - mm    - mm_struct describing address space
 *              - start - start address (may not be aligned)
 *              - end   - end address (exclusive, may not be aligned)
 *
 *      flush_tlb_page(vaddr,vma)
 *
 *              Invalidate the specified page in the specified address range.
 *              - vaddr - virtual address (may not be aligned)
 *              - vma   - vma_struct describing address range
 *
 *      flush_kern_tlb_page(kaddr)
 *
 *              Invalidate the TLB entry for the specified page.  The address
 *              will be in the kernels virtual memory space.  Current uses
 *              only require the D-TLB to be invalidated.
 *              - kaddr - Kernel virtual memory address
 */

/*
 * We optimise the code below by:
 *  - building a set of TLB flags that might be set in __cpu_tlb_flags
 *  - building a set of TLB flags that will always be set in __cpu_tlb_flags
 *  - if we're going to need __cpu_tlb_flags, access it once and only once
 *
 * This allows us to build optimal assembly for the single-CPU type case,
 * and as close to optimal given the compiler constrants for multi-CPU
 * case.  We could do better for the multi-CPU case if the compiler
 * implemented the "%?" method, but this has been discontinued due to too
 * many people getting it wrong.
 */

#define possible_tlb_flags	(v4_possible_flags | \
                                 v4wbi_possible_flags | \
                                 fr_possible_flags | \
                                 v4wb_possible_flags | \
                                 fa_possible_flags | \
                                 v6wbi_possible_flags | \
                                 v7wbi_possible_flags)


#define always_tlb_flags	(v4_always_flags & \
                                 v4wbi_always_flags & \
                                 fr_always_flags & \
                                 v4wb_always_flags & \
                                 fa_always_flags & \
                                 v6wbi_always_flags & \
                                 v7wbi_always_flags)


#define tlb_flag(f)	((always_tlb_flags & (f)) || (__tlb_flag & possible_tlb_flags & (f)))


#define __tlb_op(f, insnarg, arg)					\
	do {                                                            \
                if (always_tlb_flags & (f))                             \
                        asm("mcr " insnarg                              \
                            : : "r" (arg) : "cc");                      \
                else if (possible_tlb_flags & (f))                      \
                        asm("tst %1, %2\n\t"                            \
                            "mcrne " insnarg                            \
                            : : "r" (arg), "r" (__tlb_flag), "Ir" (f)   \
                            : "cc");                                    \
        } while (0)


#define tlb_op(f, regs, arg)	__tlb_op(f, "p15, 0, %0, " regs, arg)

#define tlb_l2_op(f, regs, arg)	__tlb_op(f, "p15, 1, %0, " regs, arg)


static inline void __local_flush_tlb_all(void) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; tlb_op(TLB_V4_U_FULL | TLB_V6_U_FULL, "c8, c7, 0", zero); tlb_op(TLB_V4_D_FULL | TLB_V6_D_FULL, "c8, c6, 0", zero); tlb_op(TLB_V4_I_FULL | TLB_V6_I_FULL, "c8, c5, 0", zero); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King5396.36%266.67%
Will Deacon23.64%133.33%
Total55100.00%3100.00%


static inline void local_flush_tlb_all(void) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; if (tlb_flag(TLB_WB)) dsb(nshst); __local_flush_tlb_all(); tlb_op(TLB_V7_UIS_FULL, "c8, c7, 0", zero); if (tlb_flag(TLB_BARRIER)) { dsb(nsh); isb(); } }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon63100.00%2100.00%
Total63100.00%2100.00%


static inline void __flush_tlb_all(void) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; if (tlb_flag(TLB_WB)) dsb(ishst); __local_flush_tlb_all(); tlb_op(TLB_V7_UIS_FULL, "c8, c3, 0", zero); if (tlb_flag(TLB_BARRIER)) { dsb(ish); isb(); } }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon3961.90%225.00%
Catalin Marinas1625.40%337.50%
Russell King812.70%337.50%
Total63100.00%8100.00%


static inline void __local_flush_tlb_mm(struct mm_struct *mm) { const int zero = 0; const int asid = ASID(mm); const unsigned int __tlb_flag = __cpu_tlb_flags; if (possible_tlb_flags & (TLB_V4_U_FULL|TLB_V4_D_FULL|TLB_V4_I_FULL)) { if (cpumask_test_cpu(smp_processor_id(), mm_cpumask(mm))) { tlb_op(TLB_V4_U_FULL, "c8, c7, 0", zero); tlb_op(TLB_V4_D_FULL, "c8, c6, 0", zero); tlb_op(TLB_V4_I_FULL, "c8, c5, 0", zero); } } tlb_op(TLB_V6_U_ASID, "c8, c7, 2", asid); tlb_op(TLB_V6_D_ASID, "c8, c6, 2", asid); tlb_op(TLB_V6_I_ASID, "c8, c5, 2", asid); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King11094.02%360.00%
Rusty Russell43.42%120.00%
Will Deacon32.56%120.00%
Total117100.00%5100.00%


static inline void local_flush_tlb_mm(struct mm_struct *mm) { const int asid = ASID(mm); const unsigned int __tlb_flag = __cpu_tlb_flags; if (tlb_flag(TLB_WB)) dsb(nshst); __local_flush_tlb_mm(mm); tlb_op(TLB_V7_UIS_ASID, "c8, c7, 2", asid); if (tlb_flag(TLB_BARRIER)) dsb(nsh); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon66100.00%2100.00%
Total66100.00%2100.00%


static inline void __flush_tlb_mm(struct mm_struct *mm) { const unsigned int __tlb_flag = __cpu_tlb_flags; if (tlb_flag(TLB_WB)) dsb(ishst); __local_flush_tlb_mm(mm); #ifdef CONFIG_ARM_ERRATA_720789 tlb_op(TLB_V7_UIS_ASID, "c8, c3, 0", 0); #else tlb_op(TLB_V7_UIS_ASID, "c8, c3, 2", ASID(mm)); #endif if (tlb_flag(TLB_BARRIER)) dsb(ish); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon5065.79%333.33%
Russell King1823.68%333.33%
Catalin Marinas810.53%333.33%
Total76100.00%9100.00%


static inline void __local_flush_tlb_page(struct vm_area_struct *vma, unsigned long uaddr) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; uaddr = (uaddr & PAGE_MASK) | ASID(vma->vm_mm); if (possible_tlb_flags & (TLB_V4_U_PAGE|TLB_V4_D_PAGE|TLB_V4_I_PAGE|TLB_V4_I_FULL) && cpumask_test_cpu(smp_processor_id(), mm_cpumask(vma->vm_mm))) { tlb_op(TLB_V4_U_PAGE, "c8, c7, 1", uaddr); tlb_op(TLB_V4_D_PAGE, "c8, c6, 1", uaddr); tlb_op(TLB_V4_I_PAGE, "c8, c5, 1", uaddr); if (!tlb_flag(TLB_V4_I_PAGE) && tlb_flag(TLB_V4_I_FULL)) asm("mcr p15, 0, %0, c8, c5, 0" : : "r" (zero) : "cc"); } tlb_op(TLB_V6_U_PAGE, "c8, c7, 1", uaddr); tlb_op(TLB_V6_D_PAGE, "c8, c6, 1", uaddr); tlb_op(TLB_V6_I_PAGE, "c8, c5, 1", uaddr); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King13495.04%350.00%
Rusty Russell42.84%116.67%
Will Deacon21.42%116.67%
Daniel Jacobowitz10.71%116.67%
Total141100.00%6100.00%


static inline void local_flush_tlb_page(struct vm_area_struct *vma, unsigned long uaddr) { const unsigned int __tlb_flag = __cpu_tlb_flags; uaddr = (uaddr & PAGE_MASK) | ASID(vma->vm_mm); if (tlb_flag(TLB_WB)) dsb(nshst); __local_flush_tlb_page(vma, uaddr); tlb_op(TLB_V7_UIS_PAGE, "c8, c7, 1", uaddr); if (tlb_flag(TLB_BARRIER)) dsb(nsh); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon78100.00%2100.00%
Total78100.00%2100.00%


static inline void __flush_tlb_page(struct vm_area_struct *vma, unsigned long uaddr) { const unsigned int __tlb_flag = __cpu_tlb_flags; uaddr = (uaddr & PAGE_MASK) | ASID(vma->vm_mm); if (tlb_flag(TLB_WB)) dsb(ishst); __local_flush_tlb_page(vma, uaddr); #ifdef CONFIG_ARM_ERRATA_720789 tlb_op(TLB_V7_UIS_PAGE, "c8, c3, 3", uaddr & PAGE_MASK); #else tlb_op(TLB_V7_UIS_PAGE, "c8, c3, 1", uaddr); #endif if (tlb_flag(TLB_BARRIER)) dsb(ish); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon6668.75%342.86%
Russell King2121.88%228.57%
Catalin Marinas99.38%228.57%
Total96100.00%7100.00%


static inline void __local_flush_tlb_kernel_page(unsigned long kaddr) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; tlb_op(TLB_V4_U_PAGE, "c8, c7, 1", kaddr); tlb_op(TLB_V4_D_PAGE, "c8, c6, 1", kaddr); tlb_op(TLB_V4_I_PAGE, "c8, c5, 1", kaddr); if (!tlb_flag(TLB_V4_I_PAGE) && tlb_flag(TLB_V4_I_FULL)) asm("mcr p15, 0, %0, c8, c5, 0" : : "r" (zero) : "cc"); tlb_op(TLB_V6_U_PAGE, "c8, c7, 1", kaddr); tlb_op(TLB_V6_D_PAGE, "c8, c6, 1", kaddr); tlb_op(TLB_V6_I_PAGE, "c8, c5, 1", kaddr); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King8996.74%250.00%
Will Deacon22.17%125.00%
Daniel Jacobowitz11.09%125.00%
Total92100.00%4100.00%


static inline void local_flush_tlb_kernel_page(unsigned long kaddr) { const unsigned int __tlb_flag = __cpu_tlb_flags; kaddr &= PAGE_MASK; if (tlb_flag(TLB_WB)) dsb(nshst); __local_flush_tlb_kernel_page(kaddr); tlb_op(TLB_V7_UIS_PAGE, "c8, c7, 1", kaddr); if (tlb_flag(TLB_BARRIER)) { dsb(nsh); isb(); } }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon65100.00%2100.00%
Total65100.00%2100.00%


static inline void __flush_tlb_kernel_page(unsigned long kaddr) { const unsigned int __tlb_flag = __cpu_tlb_flags; kaddr &= PAGE_MASK; if (tlb_flag(TLB_WB)) dsb(ishst); __local_flush_tlb_kernel_page(kaddr); tlb_op(TLB_V7_UIS_PAGE, "c8, c3, 1", kaddr); if (tlb_flag(TLB_BARRIER)) { dsb(ish); isb(); } }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon4163.08%225.00%
Catalin Marinas1624.62%337.50%
Russell King812.31%337.50%
Total65100.00%8100.00%

/* * Branch predictor maintenance is paired with full TLB invalidation, so * there is no need for any barriers here. */
static inline void __local_flush_bp_all(void) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; if (tlb_flag(TLB_V6_BP)) asm("mcr p15, 0, %0, c7, c5, 6" : : "r" (zero)); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon30100.00%1100.00%
Total30100.00%1100.00%


static inline void local_flush_bp_all(void) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; __local_flush_bp_all(); if (tlb_flag(TLB_V7_UIS_BP)) asm("mcr p15, 0, %0, c7, c5, 6" : : "r" (zero)); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon33100.00%2100.00%
Total33100.00%2100.00%


static inline void __flush_bp_all(void) { const int zero = 0; const unsigned int __tlb_flag = __cpu_tlb_flags; __local_flush_bp_all(); if (tlb_flag(TLB_V7_UIS_BP)) asm("mcr p15, 0, %0, c7, c1, 6" : : "r" (zero)); }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon33100.00%2100.00%
Total33100.00%2100.00%

/* * flush_pmd_entry * * Flush a PMD entry (word aligned, or double-word aligned) to * RAM if the TLB for the CPU we are running on requires this. * This is typically used when we are creating PMD entries. * * clean_pmd_entry * * Clean (but don't drain the write buffer) if the CPU requires * these operations. This is typically used when we are removing * PMD entries. */
static inline void flush_pmd_entry(void *pmd) { const unsigned int __tlb_flag = __cpu_tlb_flags; tlb_op(TLB_DCLEAN, "c7, c10, 1 @ flush_pmd", pmd); tlb_l2_op(TLB_L2CLEAN_FR, "c15, c9, 1 @ L2 flush_pmd", pmd); if (tlb_flag(TLB_WB)) dsb(ishst); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King3675.00%233.33%
Lennert Buytenhek612.50%116.67%
Catalin Marinas36.25%233.33%
Will Deacon36.25%116.67%
Total48100.00%6100.00%


static inline void clean_pmd_entry(void *pmd) { const unsigned int __tlb_flag = __cpu_tlb_flags; tlb_op(TLB_DCLEAN, "c7, c10, 1 @ flush_pmd", pmd); tlb_l2_op(TLB_L2CLEAN_FR, "c15, c9, 1 @ L2 flush_pmd", pmd); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King3288.89%250.00%
Lennert Buytenhek38.33%125.00%
Catalin Marinas12.78%125.00%
Total36100.00%4100.00%

#undef tlb_op #undef tlb_flag #undef always_tlb_flags #undef possible_tlb_flags /* * Convert calls to our calling convention. */ #define local_flush_tlb_range(vma,start,end) __cpu_flush_user_tlb_range(start,end,vma) #define local_flush_tlb_kernel_range(s,e) __cpu_flush_kern_tlb_range(s,e) #ifndef CONFIG_SMP #define flush_tlb_all local_flush_tlb_all #define flush_tlb_mm local_flush_tlb_mm #define flush_tlb_page local_flush_tlb_page #define flush_tlb_kernel_page local_flush_tlb_kernel_page #define flush_tlb_range local_flush_tlb_range #define flush_tlb_kernel_range local_flush_tlb_kernel_range #define flush_bp_all local_flush_bp_all #else extern void flush_tlb_all(void); extern void flush_tlb_mm(struct mm_struct *mm); extern void flush_tlb_page(struct vm_area_struct *vma, unsigned long uaddr); extern void flush_tlb_kernel_page(unsigned long kaddr); extern void flush_tlb_range(struct vm_area_struct *vma, unsigned long start, unsigned long end); extern void flush_tlb_kernel_range(unsigned long start, unsigned long end); extern void flush_bp_all(void); #endif /* * If PG_dcache_clean is not set for the page, we need to ensure that any * cache entries for the kernels virtual memory range are written * back to the page. On ARMv6 and later, the cache coherency is handled via * the set_pte_at() function. */ #if __LINUX_ARM_ARCH__ < 6 extern void update_mmu_cache(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep); #else
static inline void update_mmu_cache(struct vm_area_struct *vma, unsigned long addr, pte_t *ptep) { }

Contributors

PersonTokensPropCommitsCommitProp
Catalin Marinas19100.00%1100.00%
Total19100.00%1100.00%

#endif #define update_mmu_cache_pmd(vma, address, pmd) do { } while (0) #endif #elif defined(CONFIG_SMP) /* !CONFIG_MMU */ #ifndef __ASSEMBLY__
static inline void local_flush_tlb_all(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon8100.00%1100.00%
Total8100.00%1100.00%


static inline void local_flush_tlb_mm(struct mm_struct *mm) { }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon11100.00%1100.00%
Total11100.00%1100.00%


static inline void local_flush_tlb_page(struct vm_area_struct *vma, unsigned long uaddr) { }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon15100.00%1100.00%
Total15100.00%1100.00%


static inline void local_flush_tlb_kernel_page(unsigned long kaddr) { }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon10100.00%1100.00%
Total10100.00%1100.00%


static inline void local_flush_tlb_range(struct vm_area_struct *vma, unsigned long start, unsigned long end) { }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon19100.00%1100.00%
Total19100.00%1100.00%


static inline void local_flush_tlb_kernel_range(unsigned long start, unsigned long end) { }

Contributors

PersonTokensPropCommitsCommitProp
Will Deacon14100.00%1100.00%
Total14100.00%1100.00%


static inline void local_flush_bp_all(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Jonathan Austin8100.00%1100.00%
Total8100.00%1100.00%

extern void flush_tlb_all(void); extern void flush_tlb_mm(struct mm_struct *mm); extern void flush_tlb_page(struct vm_area_struct *vma, unsigned long uaddr); extern void flush_tlb_kernel_page(unsigned long kaddr); extern void flush_tlb_range(struct vm_area_struct *vma, unsigned long start, unsigned long end); extern void flush_tlb_kernel_range(unsigned long start, unsigned long end); extern void flush_bp_all(void); #endif /* __ASSEMBLY__ */ #endif #ifndef __ASSEMBLY__ #ifdef CONFIG_ARM_ERRATA_798181 extern void erratum_a15_798181_init(void); #else
static inline void erratum_a15_798181_init(void) {}

Contributors

PersonTokensPropCommitsCommitProp
Rob Herring8100.00%1100.00%
Total8100.00%1100.00%

#endif extern bool (*erratum_a15_798181_handler)(void);
static inline bool erratum_a15_798181(void) { if (unlikely(IS_ENABLED(CONFIG_ARM_ERRATA_798181) && erratum_a15_798181_handler)) return erratum_a15_798181_handler(); return false; }

Contributors

PersonTokensPropCommitsCommitProp
Rob Herring28100.00%1100.00%
Total28100.00%1100.00%

#endif #endif

Overall Contributors

PersonTokensPropCommitsCommitProp
Russell King111950.07%1231.58%
Will Deacon76434.18%923.68%
Catalin Marinas1516.76%821.05%
Rob Herring652.91%12.63%
Lennert Buytenhek562.51%12.63%
Paulius Zaleckas411.83%12.63%
Jonathan Austin150.67%12.63%
Rusty Russell80.36%12.63%
Ingo Molnar80.36%12.63%
Hyok S. Choi30.13%12.63%
Alexey Dobriyan30.13%12.63%
Daniel Jacobowitz20.09%12.63%
Total2235100.00%38100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.