cregit-Linux how code gets into the kernel

Release 4.14 arch/parisc/include/asm/cacheflush.h

/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _PARISC_CACHEFLUSH_H

#define _PARISC_CACHEFLUSH_H

#include <linux/mm.h>
#include <linux/uaccess.h>
#include <asm/tlbflush.h>

/* The usual comment is "Caches aren't brain-dead on the <architecture>".
 * Unfortunately, that doesn't apply to PA-RISC. */

/* Internal implementation */
void flush_data_cache_local(void *);  /* flushes local data-cache only */
void flush_instruction_cache_local(void *); /* flushes local code-cache only */
#ifdef CONFIG_SMP
void flush_data_cache(void); /* flushes data-cache only (all processors) */
void flush_instruction_cache(void); /* flushes i-cache only (all processors) */
#else

#define flush_data_cache() flush_data_cache_local(NULL)

#define flush_instruction_cache() flush_instruction_cache_local(NULL)
#endif


#define flush_cache_dup_mm(mm) flush_cache_mm(mm)

void flush_user_icache_range_asm(unsigned long, unsigned long);
void flush_kernel_icache_range_asm(unsigned long, unsigned long);
void flush_user_dcache_range_asm(unsigned long, unsigned long);
void flush_kernel_dcache_range_asm(unsigned long, unsigned long);
void flush_kernel_dcache_page_asm(void *);
void flush_kernel_icache_page(void *);

/* Cache flush operations */

void flush_cache_all_local(void);
void flush_cache_all(void);
void flush_cache_mm(struct mm_struct *mm);


#define ARCH_HAS_FLUSH_KERNEL_DCACHE_PAGE
void flush_kernel_dcache_page_addr(void *addr);

static inline void flush_kernel_dcache_page(struct page *page) { flush_kernel_dcache_page_addr(page_address(page)); }

Contributors

PersonTokensPropCommitsCommitProp
James Bottomley20100.00%1100.00%
Total20100.00%1100.00%

#define flush_kernel_dcache_range(start,size) \ flush_kernel_dcache_range_asm((start), (start)+(size)); void flush_kernel_vmap_range(void *vaddr, int size); void invalidate_kernel_vmap_range(void *vaddr, int size); #define flush_cache_vmap(start, end) flush_cache_all() #define flush_cache_vunmap(start, end) flush_cache_all() #define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1 extern void flush_dcache_page(struct page *page); #define flush_dcache_mmap_lock(mapping) \ spin_lock_irq(&(mapping)->tree_lock) #define flush_dcache_mmap_unlock(mapping) \ spin_unlock_irq(&(mapping)->tree_lock) #define flush_icache_page(vma,page) do { \ flush_kernel_dcache_page(page); \ flush_kernel_icache_page(page_address(page)); \ } while (0) #define flush_icache_range(s,e) do { \ flush_kernel_dcache_range_asm(s,e); \ flush_kernel_icache_range_asm(s,e); \ } while (0) #define copy_to_user_page(vma, page, vaddr, dst, src, len) \ do { \ flush_cache_page(vma, vaddr, page_to_pfn(page)); \ memcpy(dst, src, len); \ flush_kernel_dcache_range_asm((unsigned long)dst, (unsigned long)dst + len); \ } while (0) #define copy_from_user_page(vma, page, vaddr, dst, src, len) \ do { \ flush_cache_page(vma, vaddr, page_to_pfn(page)); \ memcpy(dst, src, len); \ } while (0) void flush_cache_page(struct vm_area_struct *vma, unsigned long vmaddr, unsigned long pfn); void flush_cache_range(struct vm_area_struct *vma, unsigned long start, unsigned long end); /* defined in pacache.S exported in cache.c used by flush_anon_page */ void flush_dcache_page_asm(unsigned long phys_addr, unsigned long vaddr); #define ARCH_HAS_FLUSH_ANON_PAGE
static inline void flush_anon_page(struct vm_area_struct *vma, struct page *page, unsigned long vmaddr) { if (PageAnon(page)) { flush_tlb_page(vma, vmaddr); preempt_disable(); flush_dcache_page_asm(page_to_phys(page), vmaddr); preempt_enable(); } }

Contributors

PersonTokensPropCommitsCommitProp
James Bottomley4279.25%360.00%
John David Anglin611.32%120.00%
Russell King59.43%120.00%
Total53100.00%5100.00%

#include <asm/kmap_types.h> #define ARCH_HAS_KMAP
static inline void *kmap(struct page *page) { might_sleep(); return page_address(page); }

Contributors

PersonTokensPropCommitsCommitProp
James Bottomley22100.00%1100.00%
Total22100.00%1100.00%


static inline void kunmap(struct page *page) { flush_kernel_dcache_page_addr(page_address(page)); }

Contributors

PersonTokensPropCommitsCommitProp
John David Anglin1680.00%266.67%
James Bottomley420.00%133.33%
Total20100.00%3100.00%


static inline void *kmap_atomic(struct page *page) { preempt_disable(); pagefault_disable(); return page_address(page); }

Contributors

PersonTokensPropCommitsCommitProp
John David Anglin1872.00%125.00%
David Hildenbrand312.00%125.00%
James Bottomley312.00%125.00%
Américo Wang14.00%125.00%
Total25100.00%4100.00%


static inline void __kunmap_atomic(void *addr) { flush_kernel_dcache_page_addr(addr); pagefault_enable(); preempt_enable(); }

Contributors

PersonTokensPropCommitsCommitProp
John David Anglin1881.82%250.00%
David Hildenbrand313.64%125.00%
James Bottomley14.55%125.00%
Total22100.00%4100.00%

#define kmap_atomic_prot(page, prot) kmap_atomic(page) #define kmap_atomic_pfn(pfn) kmap_atomic(pfn_to_page(pfn)) #endif /* _PARISC_CACHEFLUSH_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
James Bottomley15729.62%722.58%
Randolph Chung12022.64%13.23%
Matthew Wilcox10119.06%516.13%
John David Anglin6612.45%516.13%
Andrew Morton489.06%26.45%
Ralf Bächle71.32%13.23%
Hugh Dickins61.13%13.23%
David Hildenbrand61.13%13.23%
Russell King50.94%13.23%
Ilya Loginov40.75%13.23%
Kyle McMartin30.57%13.23%
David S. Miller20.38%13.23%
Nicholas Piggin20.38%13.23%
Helge Deller10.19%13.23%
Greg Kroah-Hartman10.19%13.23%
Américo Wang10.19%13.23%
Total530100.00%31100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.