diff options
Diffstat (limited to 'arch/s390/kernel')
32 files changed, 54 insertions, 86 deletions
| diff --git a/arch/s390/kernel/alternative.c b/arch/s390/kernel/alternative.c index 315986a06cf5..574e77622c04 100644 --- a/arch/s390/kernel/alternative.c +++ b/arch/s390/kernel/alternative.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  #include <linux/module.h>  #include <asm/alternative.h>  #include <asm/facility.h> diff --git a/arch/s390/kernel/compat_linux.c b/arch/s390/kernel/compat_linux.c index f04db3779b34..59eea9c65d3e 100644 --- a/arch/s390/kernel/compat_linux.c +++ b/arch/s390/kernel/compat_linux.c @@ -263,6 +263,7 @@ COMPAT_SYSCALL_DEFINE2(s390_setgroups16, int, gidsetsize, u16 __user *, grouplis  		return retval;  	} +	groups_sort(group_info);  	retval = set_current_groups(group_info);  	put_group_info(group_info); diff --git a/arch/s390/kernel/debug.c b/arch/s390/kernel/debug.c index 58b9e127b615..80e974adb9e8 100644 --- a/arch/s390/kernel/debug.c +++ b/arch/s390/kernel/debug.c @@ -1392,7 +1392,7 @@ int debug_dflt_header_fn(debug_info_t *id, struct debug_view *view,  	else  		except_str = "-";  	caller = (unsigned long) entry->caller; -	rc += sprintf(out_buf, "%02i %011ld:%06lu %1u %1s %02i %p  ", +	rc += sprintf(out_buf, "%02i %011ld:%06lu %1u %1s %02i %pK  ",  		      area, sec, usec, level, except_str,  		      entry->id.fields.cpuid, (void *)caller);  	return rc; diff --git a/arch/s390/kernel/dis.c b/arch/s390/kernel/dis.c index 3be829721cf9..b2c68fbf2634 100644 --- a/arch/s390/kernel/dis.c +++ b/arch/s390/kernel/dis.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Disassemble s390 instructions.   * @@ -396,9 +397,14 @@ struct s390_insn *find_insn(unsigned char *code)  	unsigned char opfrag;  	int i; +	/* Search the opcode offset table to find an entry which +	 * matches the beginning of the opcode. If there is no match +	 * the last entry will be used, which is the default entry for +	 * unknown instructions as well as 1-byte opcode instructions. +	 */  	for (i = 0; i < ARRAY_SIZE(opcode_offset); i++) {  		entry = &opcode_offset[i]; -		if (entry->opcode == code[0] || entry->opcode == 0) +		if (entry->opcode == code[0])  			break;  	} @@ -543,7 +549,7 @@ void show_code(struct pt_regs *regs)  		start += opsize;  		pr_cont("%s", buffer);  		ptr = buffer; -		ptr += sprintf(ptr, "\n\t  "); +		ptr += sprintf(ptr, "\n          ");  		hops++;  	}  	pr_cont("\n"); diff --git a/arch/s390/kernel/dumpstack.c b/arch/s390/kernel/dumpstack.c index 2aa545dca4d5..5b23c4f6e50c 100644 --- a/arch/s390/kernel/dumpstack.c +++ b/arch/s390/kernel/dumpstack.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Stack dumping functions   * diff --git a/arch/s390/kernel/entry.S b/arch/s390/kernel/entry.S index a316cd6999ad..9e5f6cd8e4c2 100644 --- a/arch/s390/kernel/entry.S +++ b/arch/s390/kernel/entry.S @@ -180,18 +180,17 @@ _PIF_WORK	= (_PIF_PER_TRAP | _PIF_SYSCALL_RESTART)   */  ENTRY(__switch_to)  	stmg	%r6,%r15,__SF_GPRS(%r15)	# store gprs of prev task -	lgr	%r1,%r2 -	aghi	%r1,__TASK_thread		# thread_struct of prev task -	lg	%r5,__TASK_stack(%r3)		# start of kernel stack of next -	stg	%r15,__THREAD_ksp(%r1)		# store kernel stack of prev -	lgr	%r1,%r3 -	aghi	%r1,__TASK_thread		# thread_struct of next task +	lghi	%r4,__TASK_stack +	lghi	%r1,__TASK_thread +	lg	%r5,0(%r4,%r3)			# start of kernel stack of next +	stg	%r15,__THREAD_ksp(%r1,%r2)	# store kernel stack of prev  	lgr	%r15,%r5  	aghi	%r15,STACK_INIT			# end of kernel stack of next  	stg	%r3,__LC_CURRENT		# store task struct of next  	stg	%r15,__LC_KERNEL_STACK		# store end of kernel stack -	lg	%r15,__THREAD_ksp(%r1)		# load kernel stack of next -	mvc	__LC_CURRENT_PID(4,%r0),__TASK_pid(%r3) # store pid of next +	lg	%r15,__THREAD_ksp(%r1,%r3)	# load kernel stack of next +	aghi	%r3,__TASK_pid +	mvc	__LC_CURRENT_PID(4,%r0),0(%r3)	# store pid of next  	lmg	%r6,%r15,__SF_GPRS(%r15)	# load gprs of next task  	TSTMSK	__LC_MACHINE_FLAGS,MACHINE_FLAG_LPP  	bzr	%r14 diff --git a/arch/s390/kernel/ipl.c b/arch/s390/kernel/ipl.c index 310e59e6eb4b..8ecb8726ac47 100644 --- a/arch/s390/kernel/ipl.c +++ b/arch/s390/kernel/ipl.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   *    ipl/reipl/dump support for Linux on s390.   * diff --git a/arch/s390/kernel/kprobes.c b/arch/s390/kernel/kprobes.c index 1a6521af1751..af3722c28fd9 100644 --- a/arch/s390/kernel/kprobes.c +++ b/arch/s390/kernel/kprobes.c @@ -1,20 +1,7 @@ +// SPDX-License-Identifier: GPL-2.0+  /*   *  Kernel Probes (KProbes)   * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * 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. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - *   * Copyright IBM Corp. 2002, 2006   *   * s390 port, used ppc64 as template. Mike Grundy <[email protected]> diff --git a/arch/s390/kernel/lgr.c b/arch/s390/kernel/lgr.c index bf9622f0e6b1..452502f9a0d9 100644 --- a/arch/s390/kernel/lgr.c +++ b/arch/s390/kernel/lgr.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Linux Guest Relocation (LGR) detection   * diff --git a/arch/s390/kernel/module.c b/arch/s390/kernel/module.c index 7b87991416fd..b7abfad4fd7d 100644 --- a/arch/s390/kernel/module.c +++ b/arch/s390/kernel/module.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0+  /*   *  Kernel module help for s390.   * @@ -8,20 +9,6 @@   *   *  based on i386 version   *    Copyright (C) 2001 Rusty Russell. - * - *  This program is free software; you can redistribute it and/or modify - *  it under the terms of the GNU General Public License as published by - *  the Free Software Foundation; either version 2 of the License, or - *  (at your option) any later version. - * - *  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. - * - *  You should have received a copy of the GNU General Public License - *  along with this program; if not, write to the Free Software - *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA   */  #include <linux/module.h>  #include <linux/elf.h> diff --git a/arch/s390/kernel/nmi.c b/arch/s390/kernel/nmi.c index 6ff169253cae..c7a627620e5e 100644 --- a/arch/s390/kernel/nmi.c +++ b/arch/s390/kernel/nmi.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   *   Machine check handler   * diff --git a/arch/s390/kernel/perf_cpum_cf.c b/arch/s390/kernel/perf_cpum_cf.c index 746d03423333..cc085e2d2ce9 100644 --- a/arch/s390/kernel/perf_cpum_cf.c +++ b/arch/s390/kernel/perf_cpum_cf.c @@ -1,12 +1,9 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Performance event support for s390x - CPU-measurement Counter Facility   *   *  Copyright IBM Corp. 2012, 2017   *  Author(s): Hendrik Brueckner <[email protected]> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #define KMSG_COMPONENT	"cpum_cf"  #define pr_fmt(fmt)	KMSG_COMPONENT ": " fmt diff --git a/arch/s390/kernel/perf_cpum_sf.c b/arch/s390/kernel/perf_cpum_sf.c index 227b38bd82c9..1c9ddd7aa5ec 100644 --- a/arch/s390/kernel/perf_cpum_sf.c +++ b/arch/s390/kernel/perf_cpum_sf.c @@ -1,12 +1,9 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Performance event support for the System z CPU-measurement Sampling Facility   *   * Copyright IBM Corp. 2013   * Author(s): Hendrik Brueckner <[email protected]> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #define KMSG_COMPONENT	"cpum_sf"  #define pr_fmt(fmt)	KMSG_COMPONENT ": " fmt diff --git a/arch/s390/kernel/perf_event.c b/arch/s390/kernel/perf_event.c index 93a386f4a3b5..0d770e513abf 100644 --- a/arch/s390/kernel/perf_event.c +++ b/arch/s390/kernel/perf_event.c @@ -1,12 +1,9 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Performance event support for s390x   *   *  Copyright IBM Corp. 2012, 2013   *  Author(s): Hendrik Brueckner <[email protected]> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #define KMSG_COMPONENT	"perf"  #define pr_fmt(fmt)	KMSG_COMPONENT ": " fmt diff --git a/arch/s390/kernel/perf_regs.c b/arch/s390/kernel/perf_regs.c index f8603ebed669..54e2d634b849 100644 --- a/arch/s390/kernel/perf_regs.c +++ b/arch/s390/kernel/perf_regs.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  #include <linux/perf_event.h>  #include <linux/perf_regs.h>  #include <linux/kernel.h> diff --git a/arch/s390/kernel/ptrace.c b/arch/s390/kernel/ptrace.c index 26c0523c1488..cd3df5514552 100644 --- a/arch/s390/kernel/ptrace.c +++ b/arch/s390/kernel/ptrace.c @@ -1651,6 +1651,14 @@ static const struct user_regset s390_compat_regsets[] = {  		.set = s390_gs_cb_set,  	},  	{ +		.core_note_type = NT_S390_GS_BC, +		.n = sizeof(struct gs_cb) / sizeof(__u64), +		.size = sizeof(__u64), +		.align = sizeof(__u64), +		.get = s390_gs_bc_get, +		.set = s390_gs_bc_set, +	}, +	{  		.core_note_type = NT_S390_RI_CB,  		.n = sizeof(struct runtime_instr_cb) / sizeof(__u64),  		.size = sizeof(__u64), diff --git a/arch/s390/kernel/setup.c b/arch/s390/kernel/setup.c index 090053cf279b..793da97f9a6e 100644 --- a/arch/s390/kernel/setup.c +++ b/arch/s390/kernel/setup.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   *  S390 version   *    Copyright IBM Corp. 1999, 2012 diff --git a/arch/s390/kernel/smp.c b/arch/s390/kernel/smp.c index cd4334e80b64..b8c1a85bcf2d 100644 --- a/arch/s390/kernel/smp.c +++ b/arch/s390/kernel/smp.c @@ -55,6 +55,7 @@  #include <asm/sigp.h>  #include <asm/idle.h>  #include <asm/nmi.h> +#include <asm/topology.h>  #include "entry.h"  enum { diff --git a/arch/s390/kernel/stacktrace.c b/arch/s390/kernel/stacktrace.c index e66687dc6144..460dcfba7d4e 100644 --- a/arch/s390/kernel/stacktrace.c +++ b/arch/s390/kernel/stacktrace.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * Stack trace management functions   * diff --git a/arch/s390/kernel/sthyi.c b/arch/s390/kernel/sthyi.c index 12981e197f01..80b862e9c53c 100644 --- a/arch/s390/kernel/sthyi.c +++ b/arch/s390/kernel/sthyi.c @@ -1,10 +1,7 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * store hypervisor information instruction emulation functions.   * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation. - *   * Copyright IBM Corp. 2016   * Author(s): Janosch Frank <[email protected]>   */ diff --git a/arch/s390/kernel/syscalls.S b/arch/s390/kernel/syscalls.S index 308a7b63348b..f7fc63385553 100644 --- a/arch/s390/kernel/syscalls.S +++ b/arch/s390/kernel/syscalls.S @@ -370,10 +370,10 @@ SYSCALL(sys_recvmmsg,compat_sys_recvmmsg)  SYSCALL(sys_sendmmsg,compat_sys_sendmmsg)  SYSCALL(sys_socket,sys_socket)  SYSCALL(sys_socketpair,compat_sys_socketpair)		/* 360 */ -SYSCALL(sys_bind,sys_bind) -SYSCALL(sys_connect,sys_connect) +SYSCALL(sys_bind,compat_sys_bind) +SYSCALL(sys_connect,compat_sys_connect)  SYSCALL(sys_listen,sys_listen) -SYSCALL(sys_accept4,sys_accept4) +SYSCALL(sys_accept4,compat_sys_accept4)  SYSCALL(sys_getsockopt,compat_sys_getsockopt)		/* 365 */  SYSCALL(sys_setsockopt,compat_sys_setsockopt)  SYSCALL(sys_getsockname,compat_sys_getsockname) diff --git a/arch/s390/kernel/time.c b/arch/s390/kernel/time.c index be6198193ec2..cf561160ea88 100644 --- a/arch/s390/kernel/time.c +++ b/arch/s390/kernel/time.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   *    Time of day based timer functions.   * diff --git a/arch/s390/kernel/topology.c b/arch/s390/kernel/topology.c index f9b393d4a078..4d5b65e527b5 100644 --- a/arch/s390/kernel/topology.c +++ b/arch/s390/kernel/topology.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   *    Copyright IBM Corp. 2007, 2011   *    Author(s): Heiko Carstens <[email protected]> diff --git a/arch/s390/kernel/vdso.c b/arch/s390/kernel/vdso.c index 39a218703c50..f3a1c7c6824e 100644 --- a/arch/s390/kernel/vdso.c +++ b/arch/s390/kernel/vdso.c @@ -1,12 +1,9 @@ +// SPDX-License-Identifier: GPL-2.0  /*   * vdso setup for s390   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <linux/init.h> diff --git a/arch/s390/kernel/vdso32/clock_getres.S b/arch/s390/kernel/vdso32/clock_getres.S index eca3f001f081..f61df5253c23 100644 --- a/arch/s390/kernel/vdso32/clock_getres.S +++ b/arch/s390/kernel/vdso32/clock_getres.S @@ -1,13 +1,10 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * Userland implementation of clock_getres() for 32 bits processes in a   * s390 kernel for use in the vDSO   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <asm/vdso.h>  #include <asm/asm-offsets.h> diff --git a/arch/s390/kernel/vdso32/clock_gettime.S b/arch/s390/kernel/vdso32/clock_gettime.S index a5769b83d90e..2d6ec3abe095 100644 --- a/arch/s390/kernel/vdso32/clock_gettime.S +++ b/arch/s390/kernel/vdso32/clock_gettime.S @@ -1,13 +1,10 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * Userland implementation of clock_gettime() for 32 bits processes in a   * s390 kernel for use in the vDSO   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <asm/vdso.h>  #include <asm/asm-offsets.h> diff --git a/arch/s390/kernel/vdso32/gettimeofday.S b/arch/s390/kernel/vdso32/gettimeofday.S index 63b86dceb0bf..aa8bf13a2edb 100644 --- a/arch/s390/kernel/vdso32/gettimeofday.S +++ b/arch/s390/kernel/vdso32/gettimeofday.S @@ -1,13 +1,10 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * Userland implementation of gettimeofday() for 32 bits processes in a   * s390 kernel for use in the vDSO   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <asm/vdso.h>  #include <asm/asm-offsets.h> diff --git a/arch/s390/kernel/vdso64/clock_getres.S b/arch/s390/kernel/vdso64/clock_getres.S index c8513deb8c66..faf5213b15df 100644 --- a/arch/s390/kernel/vdso64/clock_getres.S +++ b/arch/s390/kernel/vdso64/clock_getres.S @@ -1,13 +1,10 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * Userland implementation of clock_getres() for 64 bits processes in a   * s390 kernel for use in the vDSO   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <asm/vdso.h>  #include <asm/asm-offsets.h> diff --git a/arch/s390/kernel/vdso64/clock_gettime.S b/arch/s390/kernel/vdso64/clock_gettime.S index 5d7b56b49458..6046b3bfca46 100644 --- a/arch/s390/kernel/vdso64/clock_gettime.S +++ b/arch/s390/kernel/vdso64/clock_gettime.S @@ -1,13 +1,10 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * Userland implementation of clock_gettime() for 64 bits processes in a   * s390 kernel for use in the vDSO   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <asm/vdso.h>  #include <asm/asm-offsets.h> diff --git a/arch/s390/kernel/vdso64/gettimeofday.S b/arch/s390/kernel/vdso64/gettimeofday.S index b02e62f3bc12..cc9dbc27da6f 100644 --- a/arch/s390/kernel/vdso64/gettimeofday.S +++ b/arch/s390/kernel/vdso64/gettimeofday.S @@ -1,13 +1,10 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * Userland implementation of gettimeofday() for 64 bits processes in a   * s390 kernel for use in the vDSO   *   *  Copyright IBM Corp. 2008   *  Author(s): Martin Schwidefsky ([email protected]) - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License (version 2 only) - * as published by the Free Software Foundation.   */  #include <asm/vdso.h>  #include <asm/asm-offsets.h> diff --git a/arch/s390/kernel/vdso64/note.S b/arch/s390/kernel/vdso64/note.S index 79a071e4357e..db19d0680a0a 100644 --- a/arch/s390/kernel/vdso64/note.S +++ b/arch/s390/kernel/vdso64/note.S @@ -1,3 +1,4 @@ +/* SPDX-License-Identifier: GPL-2.0 */  /*   * This supplies .note.* sections to go into the PT_NOTE inside the vDSO text.   * Here we can supply some information useful to userland. diff --git a/arch/s390/kernel/vtime.c b/arch/s390/kernel/vtime.c index dd7178fbb4f3..f24395a01918 100644 --- a/arch/s390/kernel/vtime.c +++ b/arch/s390/kernel/vtime.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0  /*   *    Virtual cpu timer based timer functions.   * |