cregit-Linux how code gets into the kernel

Release 4.14 arch/arm64/mm/flush.c

Directory: arch/arm64/mm
/*
 * Based on arch/arm/mm/flush.c
 *
 * Copyright (C) 1995-2002 Russell King
 * Copyright (C) 2012 ARM Ltd.
 *
 * 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.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#include <linux/export.h>
#include <linux/mm.h>
#include <linux/pagemap.h>

#include <asm/cacheflush.h>
#include <asm/cache.h>
#include <asm/tlbflush.h>


void sync_icache_aliases(void *kaddr, unsigned long len) { unsigned long addr = (unsigned long)kaddr; if (icache_is_aliasing()) { __clean_dcache_area_pou(kaddr, len); __flush_icache_all(); } else { flush_icache_range(addr, addr + len); } }

Contributors

PersonTokensPropCommitsCommitProp
Catalin Marinas5096.15%150.00%
Ashok Kumar23.85%150.00%
Total52100.00%2100.00%


static void flush_ptrace_access(struct vm_area_struct *vma, struct page *page, unsigned long uaddr, void *kaddr, unsigned long len) { if (vma->vm_flags & VM_EXEC) sync_icache_aliases(kaddr, len); }

Contributors

PersonTokensPropCommitsCommitProp
Ashok Kumar4297.67%150.00%
Catalin Marinas12.33%150.00%
Total43100.00%2100.00%

/* * Copy user data from/to a page which is mapped into a different processes * address space. Really, we want to allow our "user space" model to handle * this. */
void copy_to_user_page(struct vm_area_struct *vma, struct page *page, unsigned long uaddr, void *dst, const void *src, unsigned long len) { memcpy(dst, src, len); flush_ptrace_access(vma, page, uaddr, dst, len); }

Contributors

PersonTokensPropCommitsCommitProp
Catalin Marinas54100.00%1100.00%
Total54100.00%1100.00%


void __sync_icache_dcache(pte_t pte, unsigned long addr) { struct page *page = pte_page(pte); if (!test_and_set_bit(PG_dcache_clean, &page->flags)) sync_icache_aliases(page_address(page), PAGE_SIZE << compound_order(page)); }

Contributors

PersonTokensPropCommitsCommitProp
Catalin Marinas4488.00%360.00%
Steve Capper510.00%120.00%
Ashok Kumar12.00%120.00%
Total50100.00%5100.00%

/* * This function is called when a page has been modified by the kernel. Mark * it as dirty for later flushing when mapped in user space (if executable, * see __sync_icache_dcache). */
void flush_dcache_page(struct page *page) { if (test_bit(PG_dcache_clean, &page->flags)) clear_bit(PG_dcache_clean, &page->flags); }

Contributors

PersonTokensPropCommitsCommitProp
Catalin Marinas32100.00%2100.00%
Total32100.00%2100.00%

EXPORT_SYMBOL(flush_dcache_page); /* * Additional functions defined in assembly. */ EXPORT_SYMBOL(flush_icache_range); #ifdef CONFIG_ARCH_HAS_PMEM_API
void arch_wb_cache_pmem(void *addr, size_t size) { /* Ensure order against any prior non-cacheable writes */ dmb(osh); __clean_dcache_area_pop(addr, size); }

Contributors

PersonTokensPropCommitsCommitProp
Robin Murphy25100.00%1100.00%
Total25100.00%1100.00%

EXPORT_SYMBOL_GPL(arch_wb_cache_pmem);
void arch_invalidate_pmem(void *addr, size_t size) { __inval_dcache_area(addr, size); }

Contributors

PersonTokensPropCommitsCommitProp
Robin Murphy19100.00%1100.00%
Total19100.00%1100.00%

EXPORT_SYMBOL_GPL(arch_invalidate_pmem); #endif

Overall Contributors

PersonTokensPropCommitsCommitProp
Catalin Marinas21165.53%444.44%
Robin Murphy5918.32%111.11%
Ashok Kumar4513.98%111.11%
Steve Capper51.55%111.11%
Mark Rutland10.31%111.11%
Will Deacon10.31%111.11%
Total322100.00%9100.00%
Directory: arch/arm64/mm
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.