Received: by 10.192.165.148 with SMTP id m20csp3881930imm; Mon, 30 Apr 2018 07:59:44 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqJrvfnneXIFrEmHg4ljGCVI/xxTofUtKKoYatcs2LijeskeEZAXuAfurw3gLrZ2wjBbgr2 X-Received: by 2002:a17:902:bc88:: with SMTP id bb8-v6mr1287529plb.175.1525100384084; Mon, 30 Apr 2018 07:59:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525100384; cv=none; d=google.com; s=arc-20160816; b=aExF/1tIfadJzPth0zB3BnaQDDSDxnpbdVF1seBjguNPDOaoH7lMcVfxYw/+BQydDM Hs2lGxFaJ3pyuqWZ28N7dJ8YwhdOGOMeM7/lP1PK/4NcE1Cx7T4E7WsDOvjcdixBDff6 T8iFMXnoOfIHZ98QXVkTskfWg+Wtfup8jxHdWk0CUIcV4KZweiAB8hsndpzVtxpTx+MY ZAgpC9dp4Ty7vU/rIbmYGchEPuNc/0e2c/pe+fumlSZmUPyiX8ERwgYZ3wdiPG5mkvcd 1RHVvqQ3dALF2Jvjzm7F48LKYQfz50zn6pRxULg6qbU0bb1j9ZwU3umyUD1egc2JiWIt XMLA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=gLL0iD7Se+4qGM6YbXK3aymkd8q1kqbXfwTSaXfqol8=; b=ZN7R7YXKcyzT7vgWbP1GIvoKeeZsWsgwIkslo2D4KNhhAtxKT+yM0V6jfqRWgC+gkF 7thiApjBCJj3mmNGrySDZIHnLjJXMKsi2jGKYOoY3Fz1YtqY/XZl3YBJOLdSBswl/0Vf QGgz5sDWqv5kXTKHC0YJ14YuLahXOrESKPGGC1ZJd/0WXZUvwbYdcIHInkzQqMQkJrHZ R3kXsM22Qmk/2xJMIwxZitBLCyaIfvbMybeLZtXh/kF81NAueiim3Uz4yB4FSnPQkv8H FK8eFp3hVZb+aNVup9kSFvoTobUZ5IuUzfO1JPAKrWHootQrcxFq/MY6w1Vr+83aWhyB JxiA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=AXLbkXRZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b9-v6si7741096pli.427.2018.04.30.07.59.30; Mon, 30 Apr 2018 07:59:44 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=AXLbkXRZ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754665AbeD3O4j (ORCPT + 99 others); Mon, 30 Apr 2018 10:56:39 -0400 Received: from mail-pf0-f193.google.com ([209.85.192.193]:33161 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754625AbeD3O4g (ORCPT ); Mon, 30 Apr 2018 10:56:36 -0400 Received: by mail-pf0-f193.google.com with SMTP id f15so6937814pfn.0 for ; Mon, 30 Apr 2018 07:56:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=gLL0iD7Se+4qGM6YbXK3aymkd8q1kqbXfwTSaXfqol8=; b=AXLbkXRZciejQarx79TrL+7a7bLPHdQKw0PJI4vVZbrvPbVxezcSdiP9pNPiCam9Le xGkR1WKqMsm1hZBaB22nJWBrAUd4QJc3/hdkTrN/gF7e8iLojaZLSO93fwiJsrgNLJVP TUBXAFBMNacVh5W2wBbetb4qjRWswZFR4uWdDdNbjd5/vjFMZala8faONFamFNrN6CSI uHj5xkycZMRJPuI/JqlPPQVrdwfVlBquug0fSOdsNLY9rImjInFY/Jd5goLysvUyHwQG 38YOS2W3SWdWa6KGhac7/9uwW2gZYHRb3DHycwC3snKN3iiHf7z4tWkUzFv9PSDvJhUO h/Bg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=gLL0iD7Se+4qGM6YbXK3aymkd8q1kqbXfwTSaXfqol8=; b=pbkllez8/TTMgKF0yolkqm2sukVnCIoIuiv9P6D0PVp6cVmSXPm5qDjDoRo0bBhThr 5km0B+3BcHtQbou6clbG1dMY5NMvhpu7Ftreik+SRc+oleOC0u7CzGC/OzFF2++JhnGo dRo6DSmyz8RLxNEunIFXu15hVJPZLoBca81pzvv1gsgh33DOd14HLbNfC10AUUoaUBuT NWVz4tE352hxE6anwn/NucY4wKk6lKHdHBYPQUEm9arLfie/MgMrZbKqHi/O2NMJ1B2f lY2u/EboFmiMQPnSAdVfmOH5TR3RuFrxlWNZblLCyIFv3puLZNmzEOv2eb6cJmVo/xyr 8iAw== X-Gm-Message-State: ALQs6tBR+sHFWjF+EoIKbXn8EoehrgkxmNUyDACeDVUpfnrtXbkHe72i VJR7sXZbwIeAnmliGh3tMwU= X-Received: by 2002:a65:5308:: with SMTP id m8-v6mr10236676pgq.28.1525100195585; Mon, 30 Apr 2018 07:56:35 -0700 (PDT) Received: from roar.au.ibm.com (59-102-70-78.tpgi.com.au. [59.102.70.78]) by smtp.gmail.com with ESMTPSA id a12sm19132534pfe.78.2018.04.30.07.56.32 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 30 Apr 2018 07:56:34 -0700 (PDT) From: Nicholas Piggin To: linuxppc-dev@lists.ozlabs.org Cc: Nicholas Piggin , Benjamin Herrenschmidt , Greg Kroah-Hartman , Jiri Slaby , linux-kernel@vger.kernel.org Subject: [PATCH 07/15] powerpc/powernv: move opal console flushing to udbg Date: Tue, 1 May 2018 00:55:50 +1000 Message-Id: <20180430145558.4308-8-npiggin@gmail.com> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180430145558.4308-1-npiggin@gmail.com> References: <20180430145558.4308-1-npiggin@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 --- arch/powerpc/platforms/powernv/opal.c | 12 +++++++----- drivers/tty/hvc/hvc_opal.c | 5 +++++ 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/arch/powerpc/platforms/powernv/opal.c b/arch/powerpc/platforms/powernv/opal.c index 0ddb63226695..55d4b1983110 100644 --- a/arch/powerpc/platforms/powernv/opal.c +++ b/arch/powerpc/platforms/powernv/opal.c @@ -400,12 +400,14 @@ int opal_put_chars(uint32_t vtermno, const char *data, int total_len) out: spin_unlock_irqrestore(&opal_write_lock, flags); - /* This is a bit nasty but we need that for the console to - * flush when there aren't any interrupts. We will clean - * things a bit later to limit that to synchronous path - * such as the kernel console and xmon/udbg + /* In the -EAGAIN case, callers loop, so we have to flush the console + * here in case they have interrupts off (and we don't want to wait + * for async flushing if we can make immediate progress here). If + * 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; } diff --git a/drivers/tty/hvc/hvc_opal.c b/drivers/tty/hvc/hvc_opal.c index 2ed07ca6389e..af122ad7f06d 100644 --- a/drivers/tty/hvc/hvc_opal.c +++ b/drivers/tty/hvc/hvc_opal.c @@ -275,6 +275,11 @@ static void udbg_opal_putc(char c) count = hvc_opal_hvsi_put_chars(termno, &c, 1); break; } + + /* This is needed for the cosole to flush + * when there aren't any interrupts. + */ + opal_flush_console(termno); } while(count == 0 || count == -EAGAIN); } -- 2.17.0