#ifndef __MMU_H #define __MMU_H #include <linux/cpumask.h> #include <linux/errno.h> typedef struct { cpumask_t cpu_attach_mask; atomic_t flush_count; unsigned int flush_mm; spinlock_t pgtable_lock; struct list_head pgtable_list; spinlock_t gmap_lock; struct list_head gmap_list; unsigned long gmap_asce; unsigned long asce; unsigned long asce_limit; unsigned long vdso_base; /* The mmu context allocates 4K page tables. */ unsigned int alloc_pgste:1; /* The mmu context uses extended page tables. */ unsigned int has_pgste:1; /* The mmu context uses storage keys. */ unsigned int use_skey:1; /* The mmu context uses CMMA. */ unsigned int use_cmma:1; } mm_context_t; #define INIT_MM_CONTEXT(name) \ .context.pgtable_lock = \ __SPIN_LOCK_UNLOCKED(name.context.pgtable_lock), \ .context.pgtable_list = LIST_HEAD_INIT(name.context.pgtable_list), \ .context.gmap_lock = __SPIN_LOCK_UNLOCKED(name.context.gmap_lock), \ .context.gmap_list = LIST_HEAD_INIT(name.context.gmap_list),
static inline int tprot(unsigned long addr) { int rc = -EFAULT; asm volatile( " tprot 0(%1),0\n" "0: ipm %0\n" " srl %0,28\n" "1:\n" EX_TABLE(0b,1b) : "+d" (rc) : "a" (addr) : "cc"); return rc; }Contributors
Person | Tokens | Prop | Commits | CommitProp |
David Howells | 23 | 100.00% | 1 | 100.00% |
Total | 23 | 100.00% | 1 | 100.00% |
Person | Tokens | Prop | Commits | CommitProp |
Martin Schwidefsky | 57 | 47.90% | 12 | 60.00% |
David Howells | 23 | 19.33% | 1 | 5.00% |
Linus Torvalds (pre-git) | 13 | 10.92% | 1 | 5.00% |
Heiko Carstens | 10 | 8.40% | 2 | 10.00% |
Claudio Imbrenda | 7 | 5.88% | 1 | 5.00% |
Dominik Dingel | 7 | 5.88% | 1 | 5.00% |
Gerald Schaefer | 1 | 0.84% | 1 | 5.00% |
Christian Bornträger | 1 | 0.84% | 1 | 5.00% |
Total | 119 | 100.00% | 20 | 100.00% |