cregit-Linux how code gets into the kernel

Release 4.9 arch/arm/mm/pageattr.c

Directory: arch/arm/mm
/*
 * Copyright (c) 2014, The Linux Foundation. All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 and
 * only 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.
 */
#include <linux/mm.h>
#include <linux/module.h>

#include <asm/pgtable.h>
#include <asm/tlbflush.h>


struct page_change_data {
	
pgprot_t set_mask;
	
pgprot_t clear_mask;
};


static int change_page_range(pte_t *ptep, pgtable_t token, unsigned long addr, void *data) { struct page_change_data *cdata = data; pte_t pte = *ptep; pte = clear_pte_bit(pte, cdata->clear_mask); pte = set_pte_bit(pte, cdata->set_mask); set_pte_ext(ptep, pte, 0); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee68100.00%1100.00%
Total68100.00%1100.00%


static int change_memory_common(unsigned long addr, int numpages, pgprot_t set_mask, pgprot_t clear_mask) { unsigned long start = addr; unsigned long size = PAGE_SIZE*numpages; unsigned long end = start + size; int ret; struct page_change_data data; if (!IS_ALIGNED(addr, PAGE_SIZE)) { start &= PAGE_MASK; end = start + size; WARN_ON_ONCE(1); } if (!numpages) return 0; if (start < MODULES_VADDR || start >= MODULES_END) return -EINVAL; if (end < MODULES_VADDR || start >= MODULES_END) return -EINVAL; data.set_mask = set_mask; data.clear_mask = clear_mask; ret = apply_to_page_range(&init_mm, start, size, change_page_range, &data); flush_tlb_kernel_range(start, end); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee12482.67%133.33%
laura abbottlaura abbott1812.00%133.33%
mika penttilamika penttila85.33%133.33%
Total150100.00%3100.00%


int set_memory_ro(unsigned long addr, int numpages) { return change_memory_common(addr, numpages, __pgprot(L_PTE_RDONLY), __pgprot(0)); }

Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee30100.00%1100.00%
Total30100.00%1100.00%


int set_memory_rw(unsigned long addr, int numpages) { return change_memory_common(addr, numpages, __pgprot(0), __pgprot(L_PTE_RDONLY)); }

Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee30100.00%1100.00%
Total30100.00%1100.00%


int set_memory_nx(unsigned long addr, int numpages) { return change_memory_common(addr, numpages, __pgprot(L_PTE_XN), __pgprot(0)); }

Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee30100.00%1100.00%
Total30100.00%1100.00%


int set_memory_x(unsigned long addr, int numpages) { return change_memory_common(addr, numpages, __pgprot(0), __pgprot(L_PTE_XN)); }

Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee30100.00%1100.00%
Total30100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
jungseung leejungseung lee33692.82%133.33%
laura abbottlaura abbott184.97%133.33%
mika penttilamika penttila82.21%133.33%
Total362100.00%3100.00%
Directory: arch/arm/mm