* Make the s390-ccw bios compilable with Clang
* Fix ECKD booting with null block numbers in the chain -----BEGIN PGP SIGNATURE----- iQJFBAABCAAvFiEEJ7iIR+7gJQEY8+q5LtnXdP5wLbUFAmCY4GYRHHRodXRoQHJl ZGhhdC5jb20ACgkQLtnXdP5wLbXx3xAArN3SQlce8UIPDyUTI2wyYiAe0KDBR6L6 G/EWMQ6DYvJ5MZL7vBbBDN+7JtydQs8MFMsmC22TlPcaDpkaIf9fbLrC6yXG4vJv 0DIxLI/kv/Ogu6mPkU8xB5jgwebuFD+Er+GyQpAb1vRU4G9WFkBrfIDW2aQ4XCVw KlE5tmq9sQ4KokvXlpdq8LM0tib8fUgr3SuL+DWZEvHUjNazeplzCbw0TFMDI/TY MacO3Fb1Ad/g9eMGEYBpIkgJmSQ5CIVwMB6TbJfh44Fl44DJueIN2m++GLMQi96G xZSCqFXvjZX/icpCkctPP5LNTpHL8EyMeL5Z2pEUFK1jtZFCa26QBM0+72v1sQtK j/2yLuqVBE7YT96FxDzIWqDrX5JOrpesi6cyTkqIzPWpY23VJi60fMG1dGe1lEn9 BYMh6HvrHPm57Kvz6CLipyk66lFlgrw7TVbUMHXynZ2kAuiUt93fQoAVaHozqXFb UICaE8hVQxYH8JGveyovqWyXqRmtkud5lp0WIAwTQBwA6MbmO2Owtb4K2aT1pz1P ARvctMqy58ae9olFw97zI5JqsSXCaadBPCBNV6AzSzMufVz1ygRRFN5rlyMNQ1H3 NDhuP+aoflor5szdAqrV097L7iqfXLSGsvfUrbwTIZrh4kj7ASkdoi1gv3PLSNOE 3aX72N2l1as= =Gg+4 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/thuth-gitlab/tags/s390-ccw-bios-2021-05-10' into staging * Make the s390-ccw bios compilable with Clang * Fix ECKD booting with null block numbers in the chain # gpg: Signature made Mon 10 May 2021 08:27:34 BST # gpg: using RSA key 27B88847EEE0250118F3EAB92ED9D774FE702DB5 # gpg: issuer "thuth@redhat.com" # gpg: Good signature from "Thomas Huth <th.huth@gmx.de>" [full] # gpg: aka "Thomas Huth <thuth@redhat.com>" [full] # gpg: aka "Thomas Huth <huth@tuxfamily.org>" [full] # gpg: aka "Thomas Huth <th.huth@posteo.de>" [unknown] # Primary key fingerprint: 27B8 8847 EEE0 2501 18F3 EAB9 2ED9 D774 FE70 2DB5 * remotes/thuth-gitlab/tags/s390-ccw-bios-2021-05-10: pc-bios/s390: Update the s390-ccw bios binaries with the Clang and other fixes pc-bios/s390-ccw: Allow building with Clang, too pc-bios/s390-ccw: Silence GCC 11 stringop-overflow warning pc-bios/s390-ccw: Fix the cc-option macro in the Makefile pc-bios/s390-ccw: Silence warning from Clang by marking panic() as noreturn pc-bios/s390-ccw/netboot: Use "-Wl," prefix to pass parameter to the linker pc-bios/s390-ccw: Use reset_psw pointer instead of hard-coded null pointer pc-bios/s390-ccw/bootmap: Silence compiler warning from Clang pc-bios/s390-ccw: don't try to read the next block if end of chunk is reached Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
7c7cb752d7
9
configure
vendored
9
configure
vendored
@ -5440,9 +5440,16 @@ if { test "$cpu" = "i386" || test "$cpu" = "x86_64"; } && \
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Only build s390-ccw bios if we're on s390x and the compiler has -march=z900
|
# Only build s390-ccw bios if we're on s390x and the compiler has -march=z900
|
||||||
|
# or -march=z10 (which is the lowest architecture level that Clang supports)
|
||||||
if test "$cpu" = "s390x" ; then
|
if test "$cpu" = "s390x" ; then
|
||||||
write_c_skeleton
|
write_c_skeleton
|
||||||
if compile_prog "-march=z900" ""; then
|
compile_prog "-march=z900" ""
|
||||||
|
has_z900=$?
|
||||||
|
if [ $has_z900 = 0 ] || compile_prog "-march=z10" ""; then
|
||||||
|
if [ $has_z900 != 0 ]; then
|
||||||
|
echo "WARNING: Your compiler does not support the z900!"
|
||||||
|
echo " The s390-ccw bios will only work with guest CPUs >= z10."
|
||||||
|
fi
|
||||||
roms="$roms s390-ccw"
|
roms="$roms s390-ccw"
|
||||||
# SLOF is required for building the s390-ccw firmware on s390x,
|
# SLOF is required for building the s390-ccw firmware on s390x,
|
||||||
# since it is using the libnet code from SLOF for network booting.
|
# since it is using the libnet code from SLOF for network booting.
|
||||||
|
Binary file not shown.
@ -6,8 +6,8 @@ include ../../config-host.mak
|
|||||||
CFLAGS = -O2 -g
|
CFLAGS = -O2 -g
|
||||||
|
|
||||||
quiet-command = $(if $(V),$1,$(if $(2),@printf " %-7s %s\n" $2 $3 && $1, @$1))
|
quiet-command = $(if $(V),$1,$(if $(2),@printf " %-7s %s\n" $2 $3 && $1, @$1))
|
||||||
cc-option = $(if $(shell $(CC) $1 -S -o /dev/null -xc /dev/null > /dev/null \
|
cc-option = $(if $(shell $(CC) $1 $2 -S -o /dev/null -xc /dev/null \
|
||||||
2>&1 && echo OK), $1, $2)
|
>/dev/null 2>&1 && echo OK),$2,$3)
|
||||||
|
|
||||||
VPATH_SUFFIXES = %.c %.h %.S %.m %.mak %.sh %.rc Kconfig% %.json.in
|
VPATH_SUFFIXES = %.c %.h %.S %.m %.mak %.sh %.rc Kconfig% %.json.in
|
||||||
set-vpath = $(if $1,$(foreach PATTERN,$(VPATH_SUFFIXES),$(eval vpath $(PATTERN) $1)))
|
set-vpath = $(if $1,$(foreach PATTERN,$(VPATH_SUFFIXES),$(eval vpath $(PATTERN) $1)))
|
||||||
@ -30,10 +30,12 @@ OBJECTS = start.o main.o bootmap.o jump2ipl.o sclp.o menu.o \
|
|||||||
virtio.o virtio-scsi.o virtio-blkdev.o libc.o cio.o dasd-ipl.o
|
virtio.o virtio-scsi.o virtio-blkdev.o libc.o cio.o dasd-ipl.o
|
||||||
|
|
||||||
QEMU_CFLAGS := -Wall $(filter -W%, $(QEMU_CFLAGS))
|
QEMU_CFLAGS := -Wall $(filter -W%, $(QEMU_CFLAGS))
|
||||||
|
QEMU_CFLAGS += $(call cc-option,-Werror $(QEMU_CFLAGS),-Wno-stringop-overflow)
|
||||||
QEMU_CFLAGS += -ffreestanding -fno-delete-null-pointer-checks -fno-common -fPIE
|
QEMU_CFLAGS += -ffreestanding -fno-delete-null-pointer-checks -fno-common -fPIE
|
||||||
QEMU_CFLAGS += -fwrapv -fno-strict-aliasing -fno-asynchronous-unwind-tables
|
QEMU_CFLAGS += -fwrapv -fno-strict-aliasing -fno-asynchronous-unwind-tables
|
||||||
QEMU_CFLAGS += $(call cc-option, $(QEMU_CFLAGS), -fno-stack-protector)
|
QEMU_CFLAGS += $(call cc-option, $(QEMU_CFLAGS), -fno-stack-protector)
|
||||||
QEMU_CFLAGS += -msoft-float -march=z900
|
QEMU_CFLAGS += -msoft-float
|
||||||
|
QEMU_CFLAGS += $(call cc-option, $(QEMU_CFLAGS),-march=z900,-march=z10)
|
||||||
QEMU_CFLAGS += -std=gnu99
|
QEMU_CFLAGS += -std=gnu99
|
||||||
LDFLAGS += -Wl,-pie -nostdlib
|
LDFLAGS += -Wl,-pie -nostdlib
|
||||||
|
|
||||||
|
@ -213,7 +213,7 @@ static int eckd_get_boot_menu_index(block_number_t s1b_block_nr)
|
|||||||
next_block_nr = eckd_block_num(&s1b->seek[i + 1].chs);
|
next_block_nr = eckd_block_num(&s1b->seek[i + 1].chs);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (next_block_nr) {
|
if (next_block_nr && !is_null_block_number(next_block_nr)) {
|
||||||
read_block(next_block_nr, s2_next_blk,
|
read_block(next_block_nr, s2_next_blk,
|
||||||
"Cannot read stage2 boot loader");
|
"Cannot read stage2 boot loader");
|
||||||
}
|
}
|
||||||
@ -299,7 +299,7 @@ static void ipl_eckd_cdl(void)
|
|||||||
sclp_print("Bad block size in zIPL section of IPL2 record.\n");
|
sclp_print("Bad block size in zIPL section of IPL2 record.\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!mbr->dev_type == DEV_TYPE_ECKD) {
|
if (mbr->dev_type != DEV_TYPE_ECKD) {
|
||||||
sclp_print("Non-ECKD device type in zIPL section of IPL2 record.\n");
|
sclp_print("Non-ECKD device type in zIPL section of IPL2 record.\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -82,8 +82,8 @@ void jump_to_low_kernel(void)
|
|||||||
jump_to_IPL_code(KERN_IMAGE_START);
|
jump_to_IPL_code(KERN_IMAGE_START);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Trying to get PSW at zero address */
|
/* Trying to get PSW at zero address (pointed to by reset_psw) */
|
||||||
if (*((uint64_t *)0) & RESET_PSW_MASK) {
|
if (*reset_psw & RESET_PSW_MASK) {
|
||||||
/*
|
/*
|
||||||
* Surely nobody will try running directly from lowcore, so
|
* Surely nobody will try running directly from lowcore, so
|
||||||
* let's use 0 as an indication that we want to load the reset
|
* let's use 0 as an indication that we want to load the reset
|
||||||
|
@ -6,7 +6,7 @@ NETOBJS := start.o sclp.o cio.o virtio.o virtio-net.o jump2ipl.o netmain.o
|
|||||||
LIBC_INC := -nostdinc -I$(SLOF_DIR)/lib/libc/include
|
LIBC_INC := -nostdinc -I$(SLOF_DIR)/lib/libc/include
|
||||||
LIBNET_INC := -I$(SLOF_DIR)/lib/libnet
|
LIBNET_INC := -I$(SLOF_DIR)/lib/libnet
|
||||||
|
|
||||||
NETLDFLAGS := $(LDFLAGS) -Ttext=0x7800000
|
NETLDFLAGS := $(LDFLAGS) -Wl,-Ttext=0x7800000
|
||||||
|
|
||||||
$(NETOBJS): QEMU_CFLAGS += $(LIBC_INC) $(LIBNET_INC)
|
$(NETOBJS): QEMU_CFLAGS += $(LIBC_INC) $(LIBNET_INC)
|
||||||
|
|
||||||
|
@ -89,6 +89,7 @@ bool menu_is_enabled_enum(void);
|
|||||||
|
|
||||||
#define MAX_BOOT_ENTRIES 31
|
#define MAX_BOOT_ENTRIES 31
|
||||||
|
|
||||||
|
__attribute__ ((__noreturn__))
|
||||||
static inline void panic(const char *string)
|
static inline void panic(const char *string)
|
||||||
{
|
{
|
||||||
sclp_print(string);
|
sclp_print(string);
|
||||||
|
Binary file not shown.
Loading…
Reference in New Issue
Block a user