cregit-Linux how code gets into the kernel

Release 4.14 arch/s390/include/asm/page.h

/* SPDX-License-Identifier: GPL-2.0 */
/*
 *  S390 version
 *    Copyright IBM Corp. 1999, 2000
 *    Author(s): Hartmut Penner (hp@de.ibm.com)
 */

#ifndef _S390_PAGE_H

#define _S390_PAGE_H

#include <linux/const.h>
#include <asm/types.h>


#define _PAGE_SHIFT	12

#define _PAGE_SIZE	(_AC(1, UL) << _PAGE_SHIFT)

#define _PAGE_MASK	(~(_PAGE_SIZE - 1))

/* PAGE_SHIFT determines the page size */

#define PAGE_SHIFT	_PAGE_SHIFT

#define PAGE_SIZE	_PAGE_SIZE

#define PAGE_MASK	_PAGE_MASK

#define PAGE_DEFAULT_ACC	0

#define PAGE_DEFAULT_KEY	(PAGE_DEFAULT_ACC << 4)


#define HPAGE_SHIFT	20

#define HPAGE_SIZE	(1UL << HPAGE_SHIFT)

#define HPAGE_MASK	(~(HPAGE_SIZE - 1))

#define HUGETLB_PAGE_ORDER	(HPAGE_SHIFT - PAGE_SHIFT)

#define HUGE_MAX_HSTATE		2


#define ARCH_HAS_SETCLEAR_HUGE_PTE

#define ARCH_HAS_HUGE_PTE_TYPE

#define ARCH_HAS_PREPARE_HUGEPAGE

#define ARCH_HAS_HUGEPAGE_CLEAR_FLUSH

#include <asm/setup.h>
#ifndef __ASSEMBLY__

void __storage_key_init_range(unsigned long start, unsigned long end);


static inline void storage_key_init_range(unsigned long start, unsigned long end) { if (PAGE_DEFAULT_KEY) __storage_key_init_range(start, end); }

Contributors

PersonTokensPropCommitsCommitProp
Heiko Carstens1453.85%266.67%
Martin Schwidefsky1246.15%133.33%
Total26100.00%3100.00%

#define clear_page(page) memset((page), 0, PAGE_SIZE) /* * copy_page uses the mvcl instruction with 0xb0 padding byte in order to * bypass caches when copying a page. Especially when copying huge pages * this keeps L1 and L2 data caches alive. */
static inline void copy_page(void *to, void *from) { register void *reg2 asm ("2") = to; register unsigned long reg3 asm ("3") = 0x1000; register void *reg4 asm ("4") = from; register unsigned long reg5 asm ("5") = 0xb0001000; asm volatile( " mvcl 2,4" : "+d" (reg2), "+d" (reg3), "+d" (reg4), "+d" (reg5) : : "memory", "cc"); }

Contributors

PersonTokensPropCommitsCommitProp
Heiko Carstens3759.68%120.00%
Linus Torvalds1422.58%240.00%
Martin Schwidefsky1117.74%240.00%
Total62100.00%5100.00%

#define clear_user_page(page, vaddr, pg) clear_page(page) #define copy_user_page(to, from, vaddr, pg) copy_page(to, from) #define __alloc_zeroed_user_highpage(movableflags, vma, vaddr) \ alloc_page_vma(GFP_HIGHUSER | __GFP_ZERO | movableflags, vma, vaddr) #define __HAVE_ARCH_ALLOC_ZEROED_USER_HIGHPAGE /* * These are used to make use of C type-checking.. */ typedef struct { unsigned long pgprot; } pgprot_t; typedef struct { unsigned long pgste; } pgste_t; typedef struct { unsigned long pte; } pte_t; typedef struct { unsigned long pmd; } pmd_t; typedef struct { unsigned long pud; } pud_t; typedef struct { unsigned long p4d; } p4d_t; typedef struct { unsigned long pgd; } pgd_t; typedef pte_t *pgtable_t; #define pgprot_val(x) ((x).pgprot) #define pgste_val(x) ((x).pgste) #define pte_val(x) ((x).pte) #define pmd_val(x) ((x).pmd) #define pud_val(x) ((x).pud) #define p4d_val(x) ((x).p4d) #define pgd_val(x) ((x).pgd) #define __pgste(x) ((pgste_t) { (x) } ) #define __pte(x) ((pte_t) { (x) } ) #define __pmd(x) ((pmd_t) { (x) } ) #define __pud(x) ((pud_t) { (x) } ) #define __p4d(x) ((p4d_t) { (x) } ) #define __pgd(x) ((pgd_t) { (x) } ) #define __pgprot(x) ((pgprot_t) { (x) } )
static inline void page_set_storage_key(unsigned long addr, unsigned char skey, int mapped) { if (!mapped) asm volatile(".insn rrf,0xb22b0000,%0,%1,8,0" : : "d" (skey), "a" (addr)); else asm volatile("sske %0,%1" : : "d" (skey), "a" (addr)); }

Contributors

PersonTokensPropCommitsCommitProp
Martin Schwidefsky30100.00%4100.00%
Total30100.00%4100.00%


static inline unsigned char page_get_storage_key(unsigned long addr) { unsigned char skey; asm volatile("iske %0,%1" : "=d" (skey) : "a" (addr)); return skey; }

Contributors

PersonTokensPropCommitsCommitProp
Martin Schwidefsky22100.00%2100.00%
Total22100.00%2100.00%


static inline int page_reset_referenced(unsigned long addr) { int cc; asm volatile( " rrbe 0,%1\n" " ipm %0\n" " srl %0,28\n" : "=d" (cc) : "a" (addr) : "cc"); return cc; }

Contributors

PersonTokensPropCommitsCommitProp
Martin Schwidefsky1785.00%150.00%
David Hildenbrand315.00%150.00%
Total20100.00%2100.00%

/* Bits int the storage key */ #define _PAGE_CHANGED 0x02 /* HW changed bit */ #define _PAGE_REFERENCED 0x04 /* HW referenced bit */ #define _PAGE_FP_BIT 0x08 /* HW fetch protection bit */ #define _PAGE_ACC_BITS 0xf0 /* HW access control bits */ struct page; void arch_free_page(struct page *page, int order); void arch_alloc_page(struct page *page, int order); void arch_set_page_dat(struct page *page, int order); void arch_set_page_nodat(struct page *page, int order); int arch_test_page_nodat(struct page *page); void arch_set_page_states(int make_stable);
static inline int devmem_is_allowed(unsigned long pfn) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Hendrik Brueckner14100.00%1100.00%
Total14100.00%1100.00%

#define HAVE_ARCH_FREE_PAGE #define HAVE_ARCH_ALLOC_PAGE #endif /* !__ASSEMBLY__ */ #define __PAGE_OFFSET 0x0UL #define PAGE_OFFSET 0x0UL #define __pa(x) ((unsigned long)(x)) #define __va(x) ((void *)(unsigned long)(x)) #define virt_to_pfn(kaddr) (__pa(kaddr) >> PAGE_SHIFT) #define pfn_to_virt(pfn) __va((pfn) << PAGE_SHIFT) #define virt_to_page(kaddr) pfn_to_page(virt_to_pfn(kaddr)) #define page_to_virt(page) pfn_to_virt(page_to_pfn(page)) #define phys_to_pfn(kaddr) ((kaddr) >> PAGE_SHIFT) #define pfn_to_phys(pfn) ((pfn) << PAGE_SHIFT) #define phys_to_page(kaddr) pfn_to_page(phys_to_pfn(kaddr)) #define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT) #define virt_addr_valid(kaddr) pfn_valid(__pa(kaddr) >> PAGE_SHIFT) #define VM_DATA_DEFAULT_FLAGS (VM_READ | VM_WRITE | \ VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC) #include <asm-generic/memory_model.h> #include <asm-generic/getorder.h> #endif /* _S390_PAGE_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
Martin Schwidefsky30243.96%1434.15%
Heiko Carstens12418.05%717.07%
Linus Torvalds (pre-git)11216.30%24.88%
Linus Torvalds456.55%24.88%
Gerald Schaefer294.22%24.88%
Hendrik Brueckner142.04%12.44%
David Hildenbrand131.89%24.88%
Christoph Lameter101.46%12.44%
Dominik Dingel91.31%12.44%
Peter Oberparleiter81.16%12.44%
Mel Gorman50.73%12.44%
Christian Bornträger30.44%12.44%
Kamezawa Hiroyuki30.44%12.44%
Sam Ravnborg30.44%12.44%
David Mosberger-Tang30.44%12.44%
Stephen Rothwell20.29%12.44%
Greg Kroah-Hartman10.15%12.44%
Arnd Bergmann10.15%12.44%
Total687100.00%41100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.