Commit 7b411ac6 authored by Heiko Carstens's avatar Heiko Carstens Committed by Martin Schwidefsky

s390/pci: use basic blocks for pci inline assemblies

Use only simple inline assemblies which consist of a single basic
block if the register asm construct is being used.

Otherwise gcc would generate broken code if the compiler option
--sanitize-coverage=trace-pc would be used.
Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
Acked-by: default avatarSebastian Ott <sebott@linux.vnet.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent eb090ad2
...@@ -99,7 +99,7 @@ void zpci_set_irq_ctrl(u16 ctl, char *unused, u8 isc) ...@@ -99,7 +99,7 @@ void zpci_set_irq_ctrl(u16 ctl, char *unused, u8 isc)
} }
/* PCI Load */ /* PCI Load */
static inline int __pcilg(u64 *data, u64 req, u64 offset, u8 *status) static inline int ____pcilg(u64 *data, u64 req, u64 offset, u8 *status)
{ {
register u64 __req asm("2") = req; register u64 __req asm("2") = req;
register u64 __offset asm("3") = offset; register u64 __offset asm("3") = offset;
...@@ -116,6 +116,16 @@ static inline int __pcilg(u64 *data, u64 req, u64 offset, u8 *status) ...@@ -116,6 +116,16 @@ static inline int __pcilg(u64 *data, u64 req, u64 offset, u8 *status)
: "d" (__offset) : "d" (__offset)
: "cc"); : "cc");
*status = __req >> 24 & 0xff; *status = __req >> 24 & 0xff;
*data = __data;
return cc;
}
static inline int __pcilg(u64 *data, u64 req, u64 offset, u8 *status)
{
u64 __data;
int cc;
cc = ____pcilg(&__data, req, offset, status);
if (!cc) if (!cc)
*data = __data; *data = __data;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment