mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 10:45:49 +00:00
s390/purgatory: use SYM* macros instead of ENTRY(), etc.
Consistently use the SYM* family of macros instead of the deprecated ENTRY(), ENDPROC(), etc. family of macros. Signed-off-by: Heiko Carstens <hca@linux.ibm.com> Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
This commit is contained in:
parent
6cea5f0bc9
commit
04b6d02dbe
@ -77,8 +77,8 @@
|
||||
.endm
|
||||
|
||||
.text
|
||||
.align PAGE_SIZE
|
||||
ENTRY(purgatory_start)
|
||||
.balign PAGE_SIZE
|
||||
SYM_CODE_START(purgatory_start)
|
||||
/* The purgatory might be called after a diag308 so better set
|
||||
* architecture and addressing mode.
|
||||
*/
|
||||
@ -245,45 +245,21 @@ ENTRY(purgatory_start)
|
||||
|
||||
/* start crash kernel */
|
||||
START_NEXT_KERNEL .base_dst 1
|
||||
SYM_CODE_END(purgatory_start)
|
||||
|
||||
|
||||
load_psw_mask:
|
||||
.long 0x00080000,0x80000000
|
||||
|
||||
.align 8
|
||||
disabled_wait_psw:
|
||||
.quad 0x0002000180000000
|
||||
.quad 0x0000000000000000 + .do_checksum_verification
|
||||
|
||||
gprregs:
|
||||
.rept 10
|
||||
.quad 0
|
||||
.endr
|
||||
|
||||
/* Macro to define a global variable with name and size (in bytes) to be
|
||||
* shared with C code.
|
||||
*
|
||||
* Add the .size and .type attribute to satisfy checks on the Elf_Sym during
|
||||
* purgatory load.
|
||||
*/
|
||||
.macro GLOBAL_VARIABLE name,size
|
||||
\name:
|
||||
.global \name
|
||||
.size \name,\size
|
||||
.type \name,object
|
||||
.skip \size,0
|
||||
.endm
|
||||
|
||||
GLOBAL_VARIABLE purgatory_sha256_digest,32
|
||||
GLOBAL_VARIABLE purgatory_sha_regions,16*__KEXEC_SHA_REGION_SIZE
|
||||
GLOBAL_VARIABLE kernel_entry,8
|
||||
GLOBAL_VARIABLE kernel_type,8
|
||||
GLOBAL_VARIABLE crash_start,8
|
||||
GLOBAL_VARIABLE crash_size,8
|
||||
|
||||
.align PAGE_SIZE
|
||||
stack:
|
||||
SYM_DATA_LOCAL(load_psw_mask, .long 0x00080000,0x80000000)
|
||||
.balign 8
|
||||
SYM_DATA_LOCAL(disabled_wait_psw, .quad 0x0002000180000000,.do_checksum_verification)
|
||||
SYM_DATA_LOCAL(gprregs, .fill 10,8,0)
|
||||
SYM_DATA(purgatory_sha256_digest, .skip 32)
|
||||
SYM_DATA(purgatory_sha_regions, .skip 16*__KEXEC_SHA_REGION_SIZE)
|
||||
SYM_DATA(kernel_entry, .skip 8)
|
||||
SYM_DATA(kernel_type, .skip 8)
|
||||
SYM_DATA(crash_start, .skip 8)
|
||||
SYM_DATA(crash_size, .skip 8)
|
||||
.balign PAGE_SIZE
|
||||
SYM_DATA_START_LOCAL(stack)
|
||||
/* The buffer to move this code must be as big as the code. */
|
||||
.skip stack-purgatory_start
|
||||
.align PAGE_SIZE
|
||||
purgatory_end:
|
||||
.balign PAGE_SIZE
|
||||
SYM_DATA_END_LABEL(stack, SYM_L_LOCAL, purgatory_end)
|
||||
|
@ -1,14 +1,12 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
#include <linux/linkage.h>
|
||||
|
||||
.section .rodata, "a"
|
||||
|
||||
.align 8
|
||||
kexec_purgatory:
|
||||
.globl kexec_purgatory
|
||||
.balign 8
|
||||
SYM_DATA_START(kexec_purgatory)
|
||||
.incbin "arch/s390/purgatory/purgatory.ro"
|
||||
.Lkexec_purgatroy_end:
|
||||
SYM_DATA_END_LABEL(kexec_purgatory, SYM_L_LOCAL, kexec_purgatory_end)
|
||||
|
||||
.align 8
|
||||
kexec_purgatory_size:
|
||||
.globl kexec_purgatory_size
|
||||
.quad .Lkexec_purgatroy_end - kexec_purgatory
|
||||
.balign 8
|
||||
SYM_DATA(kexec_purgatory_size, .quad kexec_purgatory_end-kexec_purgatory)
|
||||
|
Loading…
Reference in New Issue
Block a user