cregit-Linux how code gets into the kernel

Release 4.7 arch/s390/mm/hugetlbpage.c

Directory: arch/s390/mm
/*
 *  IBM System z Huge TLB Page Support for Kernel.
 *
 *    Copyright IBM Corp. 2007
 *    Author(s): Gerald Schaefer <gerald.schaefer@de.ibm.com>
 */

#include <linux/mm.h>
#include <linux/hugetlb.h>


static inline pmd_t __pte_to_pmd(pte_t pte) { pmd_t pmd; /* * Convert encoding pte bits pmd bits * lIR.uswrdy.p dy..R...I...wr * empty 010.000000.0 -> 00..0...1...00 * prot-none, clean, old 111.000000.1 -> 00..1...1...00 * prot-none, clean, young 111.000001.1 -> 01..1...1...00 * prot-none, dirty, old 111.000010.1 -> 10..1...1...00 * prot-none, dirty, young 111.000011.1 -> 11..1...1...00 * read-only, clean, old 111.000100.1 -> 00..1...1...01 * read-only, clean, young 101.000101.1 -> 01..1...0...01 * read-only, dirty, old 111.000110.1 -> 10..1...1...01 * read-only, dirty, young 101.000111.1 -> 11..1...0...01 * read-write, clean, old 111.001100.1 -> 00..1...1...11 * read-write, clean, young 101.001101.1 -> 01..1...0...11 * read-write, dirty, old 110.001110.1 -> 10..0...1...11 * read-write, dirty, young 100.001111.1 -> 11..0...0...11 * HW-bits: R read-only, I invalid * SW-bits: p present, y young, d dirty, r read, w write, s special, * u unused, l large */ if (pte_present(pte)) { pmd_val(pmd) = pte_val(pte) & PAGE_MASK; pmd_val(pmd) |= (pte_val(pte) & _PAGE_READ) >> 4; pmd_val(pmd) |= (pte_val(pte) & _PAGE_WRITE) >> 4; pmd_val(pmd) |= (pte_val(pte) & _PAGE_INVALID) >> 5; pmd_val(pmd) |= (pte_val(pte) & _PAGE_PROTECT); pmd_val(pmd) |= (pte_val(pte) & _PAGE_DIRTY) << 10; pmd_val(pmd) |= (pte_val(pte) & _PAGE_YOUNG) << 10; pmd_val(pmd) |= (pte_val(pte) & _PAGE_SOFT_DIRTY) << 13; } else pmd_val(pmd) = _SEGMENT_ENTRY_INVALID; return pmd; }

Contributors

PersonTokensPropCommitsCommitProp
martin schwidefskymartin schwidefsky156100.00%5100.00%
Total156100.00%5100.00%


static inline pte_t __pmd_to_pte(pmd_t pmd) { pte_t pte; /* * Convert encoding pmd bits pte bits * dy..R...I...wr lIR.uswrdy.p * empty 00..0...1...00 -> 010.000000.0 * prot-none, clean, old 00..1...1...00 -> 111.000000.1 * prot-none, clean, young 01..1...1...00 -> 111.000001.1 * prot-none, dirty, old 10..1...1...00 -> 111.000010.1 * prot-none, dirty, young 11..1...1...00 -> 111.000011.1 * read-only, clean, old 00..1...1...01 -> 111.000100.1 * read-only, clean, young 01..1...0...01 -> 101.000101.1 * read-only, dirty, old 10..1...1...01 -> 111.000110.1 * read-only, dirty, young 11..1...0...01 -> 101.000111.1 * read-write, clean, old 00..1...1...11 -> 111.001100.1 * read-write, clean, young 01..1...0...11 -> 101.001101.1 * read-write, dirty, old 10..0...1...11 -> 110.001110.1 * read-write, dirty, young 11..0...0...11 -> 100.001111.1 * HW-bits: R read-only, I invalid * SW-bits: p present, y young, d dirty, r read, w write, s special, * u unused, l large */ if (pmd_present(pmd)) { pte_val(pte) = pmd_val(pmd) & _SEGMENT_ENTRY_ORIGIN_LARGE; pte_val(pte) |= _PAGE_LARGE | _PAGE_PRESENT; pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_READ) << 4; pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_WRITE) << 4; pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_INVALID) << 5; pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_PROTECT); pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_DIRTY) >> 10; pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_YOUNG) >> 10; pte_val(pte) |= (pmd_val(pmd) & _SEGMENT_ENTRY_SOFT_DIRTY) >> 13; } else pte_val(pte) = _PAGE_INVALID; return pte; }

Contributors

PersonTokensPropCommitsCommitProp
martin schwidefskymartin schwidefsky165100.00%6100.00%
Total165100.00%6100.00%


void set_huge_pte_at(struct mm_struct *mm, unsigned long addr, pte_t *ptep, pte_t pte) { pmd_t pmd = __pte_to_pmd(pte); pmd_val(pmd) |= _SEGMENT_ENTRY_LARGE; *(pmd_t *) ptep = pmd; }

Contributors

PersonTokensPropCommitsCommitProp
gerald schaefergerald schaefer2351.11%133.33%
martin schwidefskymartin schwidefsky2044.44%133.33%
dominik dingeldominik dingel24.44%133.33%
Total45100.00%3100.00%


pte_t huge_ptep_get(pte_t *ptep) { pmd_t pmd = *(pmd_t *) ptep; return __pmd_to_pte(pmd); }

Contributors

PersonTokensPropCommitsCommitProp
martin schwidefskymartin schwidefsky2288.00%133.33%
dominik dingeldominik dingel28.00%133.33%
gerald schaefergerald schaefer14.00%133.33%
Total25100.00%3100.00%


pte_t huge_ptep_get_and_clear(struct mm_struct *mm, unsigned long addr, pte_t *ptep) { pmd_t *pmdp = (pmd_t *) ptep; pmd_t old; old = pmdp_xchg_direct(mm, addr, pmdp, __pmd(_SEGMENT_ENTRY_EMPTY)); return __pmd_to_pte(old); }

Contributors

PersonTokensPropCommitsCommitProp
martin schwidefskymartin schwidefsky5094.34%375.00%
gerald schaefergerald schaefer35.66%125.00%
Total53100.00%4100.00%


pte_t *huge_pte_alloc(struct mm_struct *mm, unsigned long addr, unsigned long sz) { pgd_t *pgdp; pud_t *pudp; pmd_t *pmdp = NULL; pgdp = pgd_offset(mm, addr); pudp = pud_alloc(mm, pgdp, addr); if (pudp) pmdp = pmd_alloc(mm, pudp, addr); return (pte_t *) pmdp; }

Contributors

PersonTokensPropCommitsCommitProp
gerald schaefergerald schaefer7194.67%150.00%
andi kleenandi kleen45.33%150.00%
Total75100.00%2100.00%


pte_t *huge_pte_offset(struct mm_struct *mm, unsigned long addr) { pgd_t *pgdp; pud_t *pudp; pmd_t *pmdp = NULL; pgdp = pgd_offset(mm, addr); if (pgd_present(*pgdp)) { pudp = pud_offset(pgdp, addr); if (pud_present(*pudp)) pmdp = pmd_offset(pudp, addr); } return (pte_t *) pmdp; }

Contributors

PersonTokensPropCommitsCommitProp
gerald schaefergerald schaefer81100.00%1100.00%
Total81100.00%1100.00%


int pmd_huge(pmd_t pmd) { return pmd_large(pmd); }

Contributors

PersonTokensPropCommitsCommitProp
gerald schaefergerald schaefer1392.86%150.00%
dominik dingeldominik dingel17.14%150.00%
Total14100.00%2100.00%


int pud_huge(pud_t pud) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
andi kleenandi kleen11100.00%1100.00%
Total11100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
martin schwidefskymartin schwidefsky41365.35%857.14%
gerald schaefergerald schaefer19831.33%17.14%
andi kleenandi kleen152.37%214.29%
dominik dingeldominik dingel50.79%214.29%
heiko carstensheiko carstens10.16%17.14%
Total632100.00%14100.00%
Directory: arch/s390/mm
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}