powerpc/powernv: move opal console flushing to udbg

OPAL console writes do not have to synchronously flush firmware /
hardware buffers unless they are going through the udbg path.

Remove the unconditional flushing from opal_put_chars. Flush if
there was no space in the buffer as an optimisation (callers loop
waiting for success in that case). udbg flushing is moved to
udbg_opal_putc.

Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
This commit is contained in:
Nicholas Piggin 2018-05-01 00:55:50 +10:00 committed by Michael Ellerman
parent b74d2807ae
commit ac4ac788fd
2 changed files with 12 additions and 5 deletions

View File

@ -400,12 +400,14 @@ int opal_put_chars(uint32_t vtermno, const char *data, int total_len)
out: out:
spin_unlock_irqrestore(&opal_write_lock, flags); spin_unlock_irqrestore(&opal_write_lock, flags);
/* This is a bit nasty but we need that for the console to /* In the -EAGAIN case, callers loop, so we have to flush the console
* flush when there aren't any interrupts. We will clean * here in case they have interrupts off (and we don't want to wait
* things a bit later to limit that to synchronous path * for async flushing if we can make immediate progress here). If
* such as the kernel console and xmon/udbg * necessary the API could be made entirely non-flushing if the
* callers had a ->flush API to use.
*/ */
opal_flush_console(vtermno); if (written == -EAGAIN)
opal_flush_console(vtermno);
return written; return written;
} }

View File

@ -275,6 +275,11 @@ static void udbg_opal_putc(char c)
count = hvc_opal_hvsi_put_chars(termno, &c, 1); count = hvc_opal_hvsi_put_chars(termno, &c, 1);
break; break;
} }
/* This is needed for the cosole to flush
* when there aren't any interrupts.
*/
opal_flush_console(termno);
} while(count == 0 || count == -EAGAIN); } while(count == 0 || count == -EAGAIN);
} }