Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp2447252imd; Fri, 2 Nov 2018 11:32:46 -0700 (PDT) X-Google-Smtp-Source: AJdET5fdVXDeZQsozISc6soHkFUfq/hmjtV9ds/gAaPSC0u37vn83tpIeRfMzue9et1Wws+pff2h X-Received: by 2002:a62:f715:: with SMTP id h21-v6mr12430441pfi.169.1541183566188; Fri, 02 Nov 2018 11:32:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1541183566; cv=none; d=google.com; s=arc-20160816; b=V6TiRZ3blG7pPLwt8Bcf1ssNd91XeC+5dwq6yaRbVD4rD8EUSZsyhtouRM59vGaUbj JsAd4LBwjPbTRNuAx1S85RwiS/HMuJdWVhgbmVG0OvKtvqEyffpQ6IQUqr7q63qNdm99 fLh1T7HlHSH2HBwPNDgGa9TjhOkNXnvU85uF65TyBfEIYN3dxybgKGI/Bq1+O+nBoNoa iPIVcLdmCQFlA4WlXp8iOAO5f8KBrzJH4C9aCkIveugTZS3+ZJXkOy+Idjd/Un46X8HV 4chh0Lq2soY1hyA0ID/IrNOnvEWimpTvPOg8/L2rZR5kNp0A7ozf6YLLlKOnvJJv1NFD /mxA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=lGr1/GPhODRNl1DjrK/xhjMVkRLtOcHFU4zI5hPAmoY=; b=lMs/34RjZTxqgkdlI9Z2UgRKJAK/A0/cbVQSPQLKcLstQG/dee+5/XWOkIw3v+rcuU Aw6ym0ePHHzKvONSgVVecP602SV8bR4RIlk+6F02O69ILNC09lbS2ZxE6KGco4APdgj7 d5xJb2OciyVN/WJEVeWlKpvuu5DX+v6P0dcCuYHG9RcY+TZjXfArcwLwYHWWHrE3+kLX CVPUQNQNtr/aslRr4TOInwv0AKMNJaL3uiKKHY+umcdfdXYAvoPuBOVmDWg1p+6OB29M hFo6O3bmZ8BtaTOJr0veC/ZStK5x5hO2qw7qatujKvZwo9REClNhYu4oIhPu2KnmjLdX XU1w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=jEy7l80g; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t25-v6si26659666pfm.152.2018.11.02.11.32.31; Fri, 02 Nov 2018 11:32:46 -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=@joelfernandes.org header.s=google header.b=jEy7l80g; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728151AbeKCDkR (ORCPT + 99 others); Fri, 2 Nov 2018 23:40:17 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:36676 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727747AbeKCDkR (ORCPT ); Fri, 2 Nov 2018 23:40:17 -0400 Received: by mail-pf1-f196.google.com with SMTP id j22-v6so1408165pfh.3 for ; Fri, 02 Nov 2018 11:32:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=lGr1/GPhODRNl1DjrK/xhjMVkRLtOcHFU4zI5hPAmoY=; b=jEy7l80gAkC6w6FsjraAuOg0wmNPMoUroVQPMjlpHIAJi/2OL8NlIQhyqPJIDh1RJM gzjzyWAyPhK3JYy4IxuCpoDr5esPDff+ptGtgtDPtmfeWF9mnDdBH1EOe2jWHO6IZ5Rq 7Xl0m5zX/zNUAHzpiXyAXH0Xv18wf2PBprL04= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=lGr1/GPhODRNl1DjrK/xhjMVkRLtOcHFU4zI5hPAmoY=; b=L7iqzWWVig40M1QVE+1nlaf6zkP/KWBfRNr6UHVUVrmYw6WxQHEaWiMlsbJfSwADlf bx/rj71UfyXAGFI4ZnMPTncheSIXofWJd78s8As+yTDRPFfgDRgEIHau1NGY9t+j0lqT wHcyhEBL1SRNiTN2iDafuWtFO//nK8JQ/esjYut5dafB23ZmJ7M0Dn7STwUcGWJ/M93Z WUVUiOxrK4VQZVCZCGdHEGxLAwzlKKeAA7hhEWesYWD7fcG9EO7tu9pWWMuW4nW307N/ WBwn4u+4enXKnw3zc6g9n1XKHI4eNU4ZCHEussN4FjJv5X2NUoOD6xJsB6JCWj1Cv++2 MGXA== X-Gm-Message-State: AGRZ1gLsHvDT1ltBVfoQZmW0KVhg8yKhW9gyyF+oqUO3Vu7fDSVQEaCA UrLIDWX2XC/Icy7zyrIo5GXi1Hz83Qs= X-Received: by 2002:a65:4244:: with SMTP id d4-v6mr11868515pgq.289.1541183527247; Fri, 02 Nov 2018 11:32:07 -0700 (PDT) Received: from localhost ([2620:0:1000:1601:3aef:314f:b9ea:889f]) by smtp.gmail.com with ESMTPSA id t4-v6sm39487571pfb.44.2018.11.02.11.32.05 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 02 Nov 2018 11:32:05 -0700 (PDT) Date: Fri, 2 Nov 2018 11:32:04 -0700 From: Joel Fernandes To: Kees Cook Cc: linux-kernel@vger.kernel.org, Anton Vorontsov , Colin Cross , Tony Luck Subject: Re: [PATCH 7/8] pstore: Remove needless lock during console writes Message-ID: <20181102183204.GC14942@google.com> References: <20181101235200.28584-1-keescook@chromium.org> <20181101235200.28584-8-keescook@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181101235200.28584-8-keescook@chromium.org> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Nov 01, 2018 at 04:51:59PM -0700, Kees Cook wrote: > Since commit 70ad35db3321 ("pstore: Convert console write to use > ->write_buf"), the console writer does not use the preallocated crash > dump buffer any more, so there is no reason to perform locking around it. Out of curiosity, what was the reason for having this preallocated crash buffer in the first place? I thought the 'console' type only did regular kernel console logging, not crash dumps. I looked at all the patches and had some minor nits, with the nits addressed (if you agree with them), feel free to add my Reviewed-by on future respins: Reviewed-by: Joel Fernandes (Google) Also I wonder if Namhyung is still poking around that virtio pstore driver he mentioned in the commit mentioned above. :) thanks, - Joel > Signed-off-by: Kees Cook > --- > fs/pstore/platform.c | 29 ++++++----------------------- > 1 file changed, 6 insertions(+), 23 deletions(-) > > diff --git a/fs/pstore/platform.c b/fs/pstore/platform.c > index a956c7bc3f67..32340e7dd6a5 100644 > --- a/fs/pstore/platform.c > +++ b/fs/pstore/platform.c > @@ -461,31 +461,14 @@ static void pstore_unregister_kmsg(void) > #ifdef CONFIG_PSTORE_CONSOLE > static void pstore_console_write(struct console *con, const char *s, unsigned c) > { > - const char *e = s + c; > + struct pstore_record record; > > - while (s < e) { > - struct pstore_record record; > - unsigned long flags; > - > - pstore_record_init(&record, psinfo); > - record.type = PSTORE_TYPE_CONSOLE; > - > - if (c > psinfo->bufsize) > - c = psinfo->bufsize; > + pstore_record_init(&record, psinfo); > + record.type = PSTORE_TYPE_CONSOLE; > > - if (oops_in_progress) { > - if (!spin_trylock_irqsave(&psinfo->buf_lock, flags)) > - break; > - } else { > - spin_lock_irqsave(&psinfo->buf_lock, flags); > - } > - record.buf = (char *)s; > - record.size = c; > - psinfo->write(&record); > - spin_unlock_irqrestore(&psinfo->buf_lock, flags); > - s += c; > - c = e - s; > - } > + record.buf = (char *)s; > + record.size = c; > + psinfo->write(&record); > } > > static struct console pstore_console = { > -- > 2.17.1 >