forked from pool/s390-tools
30232e2023
- Added the following patches for bsc#1166850 zipl: fix secure boot config handling: * s390-tools-sles15sp2-01-zipl-Add-missing-options-to-help-output.patch * s390-tools-sles15sp2-02-zipl-allow-stand-alone-secure-option-on-command-l.patch * s390-tools-sles15sp2-03-zipl-correct-secure-boot-config-handling.patch * s390-tools-sles15sp2-04-zipl-fix-zipl.conf-man-page-example-for-secure-boot.patch - Modified the spec file so that the kernel used for the SCSI dump tool is named zfcpdump-image instead of zfcpdump_part.image. This is to match the new version of zipl that expects this new file name. (bsc#1166851) - Added the following patches to implement jsc#SLE-7471, Enhanced tooling for kvm guest images (bsc#1165549): * s390-tools-sles15sp2-01-zipl-fix-Wdiscarded-qualifiers.patch * s390-tools-sles15sp2-02-zipl-fix-Waddress-of-packed-member.patch * s390-tools-sles15sp2-03-zipl-remove-some-useless-__packed___-attributes.patch * s390-tools-sles15sp2-04-zipl-Fix-entry-point-for-stand-alone-kdump.patch * s390-tools-sles15sp2-05-zipl-Fix-dependency-generation-in-zipl-boot.patch * s390-tools-sles15sp2-06-zipl-Make-use-of-__packed-macro.patch * s390-tools-sles15sp2-07-zipl-define-__section-macro-and-make-use-of-it.patch * s390-tools-sles15sp2-08-zipl-Make-use-of-__noreturn-macro.patch * s390-tools-sles15sp2-09-zipl-Define-__noinline-macro-and-make-use-of-it.patch * s390-tools-sles15sp2-10-zipl-stage3-Mark-start_kernel-__noreturn.patch * s390-tools-sles15sp2-11-zipl-sclp-Remove-duplicate-macros.patch * s390-tools-sles15sp2-12-zipl-Make-address-size-mask-macros-UL.patch * s390-tools-sles15sp2-13-zipl-libc-Use-stdint.h-instead-of-self-defined-macro.patch * s390-tools-sles15sp2-14-zipl-Consolidate-IMAGE-macros.patch * s390-tools-sles15sp2-15-zipl-Consolidate-STAGE-2-3-macros.patch * s390-tools-sles15sp2-16-zipl-stfle-use-uint64_t-instead-of-u64.patch * s390-tools-sles15sp2-17-zipl-boot-fix-comment-in-stage3.lds.patch * s390-tools-sles15sp2-18-lib-zt_common-add-STATIC_ASSERT-macro.patch * s390-tools-sles15sp2-19-zipl-use-STATIC_ASSERT-macro-for-no-padding-verifica.patch * s390-tools-sles15sp2-20-Support-lib-zt_common.h-to-be-used-in-assembler-and-.patch * s390-tools-sles15sp2-21-zipl-move-IPL-related-definitions-into-separate-head.patch * s390-tools-sles15sp2-22-zipl-move-SIGP-related-functions-and-definitions-int.patch * s390-tools-sles15sp2-23-zipl-add-SIGP_SET_ARCHITECTURE-to-sigp.h-and-use-it.patch * s390-tools-sles15sp2-24-zipl-stage3-make-IPL_DEVICE-definition-consistent-wi.patch * s390-tools-sles15sp2-25-zipl-move-Linux-layout-definitions-into-separate-hea.patch * s390-tools-sles15sp2-26-zipl-tape0-use-constants-defined-in-linux_layout.h.patch * s390-tools-sles15sp2-27-zipl-use-STAGE3_ENTRY-for-STAGE3_LOAD_ADDRESS.patch * s390-tools-sles15sp2-28-zipl-move-loaders-layout-definitions-into-separate-h.patch * s390-tools-sles15sp2-29-zipl-s390.h-rename-inline-macro-into-__always_inline.patch * s390-tools-sles15sp2-30-zipl-move-__always_inline-barrier-__pa32-pa-to-zt_co.patch * s390-tools-sles15sp2-31-zipl-make-BLK_PWRT-unsigned-int.patch * s390-tools-sles15sp2-32-Consolidate-MIN-and-MAX-macros.patch * s390-tools-sles15sp2-33-zipl-remove-libc.h-include-in-s390.h.patch * s390-tools-sles15sp2-34-zipl-move-s390.h-to-include-boot-s390.h.patch * s390-tools-sles15sp2-35-zipl-libc-include-s390.h.patch * s390-tools-sles15sp2-36-include-boot-s390.h-move-panic-and-panic_notify-to-l.patch * s390-tools-sles15sp2-37-include-boot-s390.h-fixes-for-Werror-sign-conversion.patch * s390-tools-sles15sp2-38-zipl-refactor-all-EBCDIC-code-into-separate-files.patch * s390-tools-sles15sp2-39-zipl-sclp-add-macros-for-the-control-program-masks.patch * s390-tools-sles15sp2-40-zipl-sclp-add-sclp_print_ascii.patch * s390-tools-sles15sp2-41-zipl-libc-printf-print-on-linemode-and-ASCII-console.patch * s390-tools-sles15sp2-42-Consolidate-ALIGN-__ALIGN_MASK-ARRAY_SIZE-macros.patch * s390-tools-sles15sp2-43-genprotimg-boot-initial-bootloader-support.patch * s390-tools-sles15sp2-44-genprotimg-boot-use-C-pre-processor-for-linker-scrip.patch * s390-tools-sles15sp2-45-genprotimg-add-relocator-for-stage3b.patch * s390-tools-sles15sp2-46-README.md-remove-useless-empty-line.patch * s390-tools-sles15sp2-47-include-boot-s390.h-add-guard-for-struct-__vector128.patch * s390-tools-sles15sp2-48-genprotimg-introduce-new-tool-for-the-creation-of-PV.patch - Added a BuildRequires for glib2-devel to support the new feature. - Added a %dir entry for /usr/share/s390-tools/genprotimg OBS-URL: https://build.opensuse.org/request/show/786614 OBS-URL: https://build.opensuse.org/package/show/Base:System/s390-tools?expand=0&rev=92
193 lines
6.4 KiB
Diff
193 lines
6.4 KiB
Diff
Subject: [PATCH] [FEAT VS1804] zipl/s390.h: rename `inline` macro into `__always_inline`
|
|
From: Marc Hartmayer <mhartmay@linux.ibm.com>
|
|
|
|
Summary: genprotimg: Introduce new tool for the creation of PV images
|
|
Description: genprotimg takes a kernel, host-key documents, optionally an
|
|
initrd, optionally a file with the kernel command line, and it
|
|
generates a single, loadable image file. The image consists of a
|
|
concatenation of a plain text boot loader, the encrypted
|
|
components for kernel, initrd, and cmdline, and the
|
|
integrity-protected PV header, containing metadata necessary for
|
|
running the guest in PV mode. It's possible to use this image file
|
|
as a kernel for zIPL or for a direct kernel boot using QEMU.
|
|
Upstream-ID: 67e76b8ebd8acb4aef1d22309287776892b7267e
|
|
Problem-ID: VS1804
|
|
|
|
Upstream-Description:
|
|
|
|
zipl/s390.h: rename `inline` macro into `__always_inline`
|
|
|
|
Rename `inline` macro into `__always_inline` so one can differentiate
|
|
between the macro and the C keyword. While at it, undefine the
|
|
previous `__always_inline` macro so s390.h can be used in combination
|
|
with glibc.
|
|
|
|
Reviewed-by: Philipp Rudo <prudo@linux.ibm.com>
|
|
Reviewed-by: Stefan Haberland <sth@linux.ibm.com>
|
|
Signed-off-by: Marc Hartmayer <mhartmay@linux.ibm.com>
|
|
Signed-off-by: Jan Höppner <hoeppner@linux.ibm.com>
|
|
|
|
|
|
Signed-off-by: Marc Hartmayer <mhartmay@linux.ibm.com>
|
|
---
|
|
zipl/boot/s390.h | 39 ++++++++++++++++++++++-----------------
|
|
1 file changed, 22 insertions(+), 17 deletions(-)
|
|
|
|
--- a/zipl/boot/s390.h
|
|
+++ b/zipl/boot/s390.h
|
|
@@ -19,7 +19,12 @@
|
|
#define __pa(x) ((unsigned long)(x))
|
|
#define MIN(x, y) ((x) < (y) ? (x) : (y))
|
|
#define barrier() __asm__ __volatile__("": : :"memory")
|
|
-#define inline inline __attribute__((always_inline))
|
|
+/* The Linux kernel (in stddef.h) and glibc (sys/cdefs.h) define
|
|
+ * __always_inline. Therefore undefine it first to allow the headers
|
|
+ * to be included first.
|
|
+ */
|
|
+#undef __always_inline
|
|
+#define __always_inline inline __attribute__((always_inline))
|
|
|
|
/*
|
|
* Helper macro for exception table entries
|
|
@@ -214,7 +219,7 @@ do { \
|
|
libc_stop(reason); \
|
|
} while (0)
|
|
|
|
-static inline int page_is_valid(unsigned long addr)
|
|
+static __always_inline int page_is_valid(unsigned long addr)
|
|
{
|
|
unsigned long tmp;
|
|
int rc;
|
|
@@ -234,7 +239,7 @@ static inline int page_is_valid(unsigned
|
|
return rc;
|
|
}
|
|
|
|
-static inline uint32_t csum_partial(const void *buf, int len, uint32_t sum)
|
|
+static __always_inline uint32_t csum_partial(const void *buf, int len, uint32_t sum)
|
|
{
|
|
register unsigned long reg2 asm("2") = (unsigned long) buf;
|
|
register unsigned long reg3 asm("3") = (unsigned long) len;
|
|
@@ -262,7 +267,7 @@ static inline uint32_t csum_partial(cons
|
|
"i" (low), "i" (high)); \
|
|
})
|
|
|
|
-static inline void __ctl_set_bit(unsigned int cr, unsigned int bit)
|
|
+static __always_inline void __ctl_set_bit(unsigned int cr, unsigned int bit)
|
|
{
|
|
unsigned long reg;
|
|
|
|
@@ -282,7 +287,7 @@ enum diag308_subcode {
|
|
DIAG308_STORE = 6,
|
|
};
|
|
|
|
-static inline int diag308(unsigned long subcode, void *addr)
|
|
+static __always_inline int diag308(unsigned long subcode, void *addr)
|
|
{
|
|
register unsigned long _addr asm("0") = (unsigned long) addr;
|
|
register unsigned long _rc asm("1") = 0;
|
|
@@ -298,7 +303,7 @@ static inline int diag308(unsigned long
|
|
/*
|
|
* Store CPU address
|
|
*/
|
|
-static inline unsigned short stap(void)
|
|
+static __always_inline unsigned short stap(void)
|
|
{
|
|
unsigned short cpu_address;
|
|
|
|
@@ -309,7 +314,7 @@ static inline unsigned short stap(void)
|
|
/*
|
|
* Program the clock comparator
|
|
*/
|
|
-static inline void set_clock_comparator(uint64_t time)
|
|
+static __always_inline void set_clock_comparator(uint64_t time)
|
|
{
|
|
asm volatile("sckc %0" : : "Q" (time));
|
|
}
|
|
@@ -317,7 +322,7 @@ static inline void set_clock_comparator(
|
|
/*
|
|
* Program the CPU timer
|
|
*/
|
|
-static inline void set_cpu_timer(uint64_t timer)
|
|
+static __always_inline void set_cpu_timer(uint64_t timer)
|
|
{
|
|
asm volatile("spt %0" : : "Q" (timer));
|
|
}
|
|
@@ -325,7 +330,7 @@ static inline void set_cpu_timer(uint64_
|
|
/*
|
|
* Get current time (store clock)
|
|
*/
|
|
-static inline unsigned long long get_tod_clock(void)
|
|
+static __always_inline unsigned long long get_tod_clock(void)
|
|
{
|
|
unsigned long long clk;
|
|
|
|
@@ -343,7 +348,7 @@ struct cpuid {
|
|
unsigned int unused:16;
|
|
} __packed __aligned(8);
|
|
|
|
-static inline void get_cpu_id(struct cpuid *ptr)
|
|
+static __always_inline void get_cpu_id(struct cpuid *ptr)
|
|
{
|
|
asm volatile("stidp %0" : "=Q" (*ptr));
|
|
}
|
|
@@ -351,7 +356,7 @@ static inline void get_cpu_id(struct cpu
|
|
/*
|
|
* Check if we run under z/VM
|
|
*/
|
|
-static inline int is_zvm(void)
|
|
+static __always_inline int is_zvm(void)
|
|
{
|
|
struct cpuid cpuid;
|
|
|
|
@@ -369,7 +374,7 @@ typedef struct {
|
|
/*
|
|
* Save vector registers
|
|
*/
|
|
-static inline void save_vx_regs(__vector128 *vxrs)
|
|
+static __always_inline void save_vx_regs(__vector128 *vxrs)
|
|
{
|
|
typedef struct { __vector128 _[32]; } addrtype;
|
|
|
|
@@ -383,7 +388,7 @@ static inline void save_vx_regs(__vector
|
|
/*
|
|
* Save vector registers safe
|
|
*/
|
|
-static inline void save_vx_regs_safe(__vector128 *vxrs)
|
|
+static __always_inline void save_vx_regs_safe(__vector128 *vxrs)
|
|
{
|
|
unsigned long cr0;
|
|
|
|
@@ -396,7 +401,7 @@ static inline void save_vx_regs_safe(__v
|
|
|
|
#define MAX_FACILITY_BIT (256*8) /* stfle_fac_list has 256 bytes */
|
|
|
|
-static inline int __test_facility(unsigned long nr, void *facilities)
|
|
+static __always_inline int __test_facility(unsigned long nr, void *facilities)
|
|
{
|
|
unsigned char *ptr;
|
|
|
|
@@ -411,12 +416,12 @@ static inline int __test_facility(unsign
|
|
* That makes it easier to query facility bits with the bit number as
|
|
* documented in the Principles of Operation.
|
|
*/
|
|
-static inline int test_facility(unsigned long nr)
|
|
+static __always_inline int test_facility(unsigned long nr)
|
|
{
|
|
return __test_facility(nr, &S390_lowcore.stfle_fac_list);
|
|
}
|
|
|
|
-static inline unsigned long __stfle_asm(uint64_t *stfle_fac_list, int size)
|
|
+static __always_inline unsigned long __stfle_asm(uint64_t *stfle_fac_list, int size)
|
|
{
|
|
register unsigned long reg0 asm("0") = size - 1;
|
|
|
|
@@ -433,7 +438,7 @@ static inline unsigned long __stfle_asm(
|
|
* @stfle_fac_list: array where facility list can be stored
|
|
* @size: size of passed in array in double words
|
|
*/
|
|
-static inline void stfle(uint64_t *stfle_fac_list, int size)
|
|
+static __always_inline void stfle(uint64_t *stfle_fac_list, int size)
|
|
{
|
|
unsigned long nr;
|
|
|