h8300: gcc-8.1 fix
authorYoshinori Sato <ysato@users.sourceforge.jp>
Fri, 13 Jul 2018 07:36:21 +0000 (16:36 +0900)
committerYoshinori Sato <ysato@users.sourceforge.jp>
Wed, 22 Aug 2018 10:14:18 +0000 (19:14 +0900)
Since gcc 8.1 does not generate an assignment statement to er 0,
we had to explicitly write it.

Signed-off-by: Yoshinori Sato <ysato@users.sourceforge.jp>
arch/h8300/kernel/sim-console.c

index 46138f55a9ea7eedb86eeb60e074655d863bcc69..03aa35b1a08c2701765da7a61bf5017f97099ce3 100644 (file)
 
 static void sim_write(struct console *con, const char *s, unsigned n)
 {
-       register const int fd __asm__("er0") = 1; /* stdout */
        register const char *_ptr __asm__("er1") = s;
        register const unsigned _len __asm__("er2") = n;
 
-       __asm__(".byte 0x5e,0x00,0x00,0xc7\n\t" /* jsr @0xc7 (sys_write) */
-               : : "g"(fd), "g"(_ptr), "g"(_len));
+       __asm__("sub.l er0,er0\n\t"             /* er0 = 1 (stdout) */
+               "inc.l #1,er0\n\t"
+               ".byte 0x5e,0x00,0x00,0xc7\n\t" /* jsr @0xc7 (sys_write) */
+               : : "g"(_ptr), "g"(_len):"er0");
 }
 
 static int __init sim_setup(struct earlycon_device *device, const char *opt)