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;
|
||
|
|