mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 ad0bf4eb91
			
		
	
	
		ad0bf4eb91
		
	
	
	
	
		
			
			- Update maintainers. Niklas Schnelle takes over zpci and Vineeth Vijayan common io code. - Extend cpuinfo to include topology information. - Add new extended counters for IBM z15 and sampling buffer allocation rework in perf code. - Add control over zeroing out memory during system restart. - CCA protected key block version 2 support and other fixes/improvements in crypto code. - Convert to new fallthrough; annotations. - Replace zero-length arrays with flexible-arrays. - QDIO debugfs and other small improvements. - Drop 2-level paging support optimization for compat tasks. Varios mm cleanups. - Remove broken and unused hibernate / power management support. - Remove fake numa support which does not bring any benefits. - Exclude offline CPUs from CPU topology masks to be more consistent with other architectures. - Prevent last branching instruction address leaking to userspace. - Other small various fixes and improvements all over the code. -----BEGIN PGP SIGNATURE----- iQEzBAABCAAdFiEE3QHqV+H2a8xAv27vjYWKoQLXFBgFAl6Ig2YACgkQjYWKoQLX FBj2gggAibnHOl9d0ngX1mVT4nz51R3V8z5sEQjNMr2uHBmaTqs7pi/00gaFMxoC NngVEXvL443jSogQivthGgXPpRCV9xdKE3sp38j7fF4LgHoeuDtGd1oaX4W9Rqk0 7Yii35EaO2e2WHdOKaAbu+ZvDRunFjERyntc51MYaIUivFosogSo07vC73vFIArF VGStS09fJ4Ny76ott896T7Ulx1Iek/MkF1vponEMLGNUIcLIQbbxZxOwgz0pHuEF SlyyJBnhOIaAJGOYlKREQDt1cew+hsxluPU+a01bwdsmdZv9LH1BGwLayDqTH58i QWvtEpzJFmDvo9jGM1v81ebaGnyCKg== =hiGF -----END PGP SIGNATURE----- Merge tag 's390-5.7-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux Pull s390 updates from Vasily Gorbik: - Update maintainers. Niklas Schnelle takes over zpci and Vineeth Vijayan common io code. - Extend cpuinfo to include topology information. - Add new extended counters for IBM z15 and sampling buffer allocation rework in perf code. - Add control over zeroing out memory during system restart. - CCA protected key block version 2 support and other fixes/improvements in crypto code. - Convert to new fallthrough; annotations. - Replace zero-length arrays with flexible-arrays. - QDIO debugfs and other small improvements. - Drop 2-level paging support optimization for compat tasks. Varios mm cleanups. - Remove broken and unused hibernate / power management support. - Remove fake numa support which does not bring any benefits. - Exclude offline CPUs from CPU topology masks to be more consistent with other architectures. - Prevent last branching instruction address leaking to userspace. - Other small various fixes and improvements all over the code. * tag 's390-5.7-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux: (57 commits) s390/mm: cleanup init_new_context() callback s390/mm: cleanup virtual memory constants usage s390/mm: remove page table downgrade support s390/qdio: set qdio_irq->cdev at allocation time s390/qdio: remove unused function declarations s390/ccwgroup: remove pm support s390/ap: remove power management code from ap bus and drivers s390/zcrypt: use kvmalloc instead of kmalloc for 256k alloc s390/mm: cleanup arch_get_unmapped_area() and friends s390/ism: remove pm support s390/cio: use fallthrough; s390/vfio: use fallthrough; s390/zcrypt: use fallthrough; s390: use fallthrough; s390/cpum_sf: Fix wrong page count in error message s390/diag: fix display of diagnose call statistics s390/ap: Remove ap device suspend and resume callbacks s390/pci: Improve handling of unset UID s390/pci: Fix zpci_alloc_domain() over allocation s390/qdio: pass ISC as parameter to chsc_sadc() ...
		
			
				
	
	
		
			140 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  *  S390 version
 | |
|  *
 | |
|  *  Derived from "include/asm-i386/mmu_context.h"
 | |
|  */
 | |
| 
 | |
| #ifndef __S390_MMU_CONTEXT_H
 | |
| #define __S390_MMU_CONTEXT_H
 | |
| 
 | |
| #include <asm/pgalloc.h>
 | |
| #include <linux/uaccess.h>
 | |
| #include <linux/mm_types.h>
 | |
| #include <asm/tlbflush.h>
 | |
| #include <asm/ctl_reg.h>
 | |
| #include <asm-generic/mm_hooks.h>
 | |
| 
 | |
| static inline int init_new_context(struct task_struct *tsk,
 | |
| 				   struct mm_struct *mm)
 | |
| {
 | |
| 	unsigned long asce_type, init_entry;
 | |
| 
 | |
| 	spin_lock_init(&mm->context.lock);
 | |
| 	INIT_LIST_HEAD(&mm->context.pgtable_list);
 | |
| 	INIT_LIST_HEAD(&mm->context.gmap_list);
 | |
| 	cpumask_clear(&mm->context.cpu_attach_mask);
 | |
| 	atomic_set(&mm->context.flush_count, 0);
 | |
| 	atomic_set(&mm->context.is_protected, 0);
 | |
| 	mm->context.gmap_asce = 0;
 | |
| 	mm->context.flush_mm = 0;
 | |
| #ifdef CONFIG_PGSTE
 | |
| 	mm->context.alloc_pgste = page_table_allocate_pgste ||
 | |
| 		test_thread_flag(TIF_PGSTE) ||
 | |
| 		(current->mm && current->mm->context.alloc_pgste);
 | |
| 	mm->context.has_pgste = 0;
 | |
| 	mm->context.uses_skeys = 0;
 | |
| 	mm->context.uses_cmm = 0;
 | |
| 	mm->context.allow_gmap_hpage_1m = 0;
 | |
| #endif
 | |
| 	switch (mm->context.asce_limit) {
 | |
| 	default:
 | |
| 		/*
 | |
| 		 * context created by exec, the value of asce_limit can
 | |
| 		 * only be zero in this case
 | |
| 		 */
 | |
| 		VM_BUG_ON(mm->context.asce_limit);
 | |
| 		/* continue as 3-level task */
 | |
| 		mm->context.asce_limit = _REGION2_SIZE;
 | |
| 		fallthrough;
 | |
| 	case _REGION2_SIZE:
 | |
| 		/* forked 3-level task */
 | |
| 		init_entry = _REGION3_ENTRY_EMPTY;
 | |
| 		asce_type = _ASCE_TYPE_REGION3;
 | |
| 		break;
 | |
| 	case TASK_SIZE_MAX:
 | |
| 		/* forked 5-level task */
 | |
| 		init_entry = _REGION1_ENTRY_EMPTY;
 | |
| 		asce_type = _ASCE_TYPE_REGION1;
 | |
| 		break;
 | |
| 	case _REGION1_SIZE:
 | |
| 		/* forked 4-level task */
 | |
| 		init_entry = _REGION2_ENTRY_EMPTY;
 | |
| 		asce_type = _ASCE_TYPE_REGION2;
 | |
| 		break;
 | |
| 	}
 | |
| 	mm->context.asce = __pa(mm->pgd) | _ASCE_TABLE_LENGTH |
 | |
| 			   _ASCE_USER_BITS | asce_type;
 | |
| 	crst_table_init((unsigned long *) mm->pgd, init_entry);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| #define destroy_context(mm)             do { } while (0)
 | |
| 
 | |
| static inline void set_user_asce(struct mm_struct *mm)
 | |
| {
 | |
| 	S390_lowcore.user_asce = mm->context.asce;
 | |
| 	__ctl_load(S390_lowcore.user_asce, 1, 1);
 | |
| 	clear_cpu_flag(CIF_ASCE_PRIMARY);
 | |
| }
 | |
| 
 | |
| static inline void clear_user_asce(void)
 | |
| {
 | |
| 	S390_lowcore.user_asce = S390_lowcore.kernel_asce;
 | |
| 	__ctl_load(S390_lowcore.kernel_asce, 1, 1);
 | |
| 	set_cpu_flag(CIF_ASCE_PRIMARY);
 | |
| }
 | |
| 
 | |
| mm_segment_t enable_sacf_uaccess(void);
 | |
| void disable_sacf_uaccess(mm_segment_t old_fs);
 | |
| 
 | |
| static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next,
 | |
| 			     struct task_struct *tsk)
 | |
| {
 | |
| 	int cpu = smp_processor_id();
 | |
| 
 | |
| 	S390_lowcore.user_asce = next->context.asce;
 | |
| 	cpumask_set_cpu(cpu, &next->context.cpu_attach_mask);
 | |
| 	/* Clear previous user-ASCE from CR1 and CR7 */
 | |
| 	if (!test_cpu_flag(CIF_ASCE_PRIMARY)) {
 | |
| 		__ctl_load(S390_lowcore.kernel_asce, 1, 1);
 | |
| 		set_cpu_flag(CIF_ASCE_PRIMARY);
 | |
| 	}
 | |
| 	if (test_cpu_flag(CIF_ASCE_SECONDARY)) {
 | |
| 		__ctl_load(S390_lowcore.vdso_asce, 7, 7);
 | |
| 		clear_cpu_flag(CIF_ASCE_SECONDARY);
 | |
| 	}
 | |
| 	if (prev != next)
 | |
| 		cpumask_clear_cpu(cpu, &prev->context.cpu_attach_mask);
 | |
| }
 | |
| 
 | |
| #define finish_arch_post_lock_switch finish_arch_post_lock_switch
 | |
| static inline void finish_arch_post_lock_switch(void)
 | |
| {
 | |
| 	struct task_struct *tsk = current;
 | |
| 	struct mm_struct *mm = tsk->mm;
 | |
| 
 | |
| 	if (mm) {
 | |
| 		preempt_disable();
 | |
| 		while (atomic_read(&mm->context.flush_count))
 | |
| 			cpu_relax();
 | |
| 		cpumask_set_cpu(smp_processor_id(), mm_cpumask(mm));
 | |
| 		__tlb_flush_mm_lazy(mm);
 | |
| 		preempt_enable();
 | |
| 	}
 | |
| 	set_fs(current->thread.mm_segment);
 | |
| }
 | |
| 
 | |
| #define enter_lazy_tlb(mm,tsk)	do { } while (0)
 | |
| #define deactivate_mm(tsk,mm)	do { } while (0)
 | |
| 
 | |
| static inline void activate_mm(struct mm_struct *prev,
 | |
|                                struct mm_struct *next)
 | |
| {
 | |
| 	switch_mm(prev, next, current);
 | |
| 	cpumask_set_cpu(smp_processor_id(), mm_cpumask(next));
 | |
| 	set_user_asce(next);
 | |
| }
 | |
| 
 | |
| #endif /* __S390_MMU_CONTEXT_H */
 |