Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2530101pxu; Mon, 7 Dec 2020 08:51:07 -0800 (PST) X-Google-Smtp-Source: ABdhPJyVNuk7FQPAW7+zXc1qSBiRAM9FHPhCJKdjXrq+aFt5YuadF6h6KkuSff3CYwpV/S/0JXsM X-Received: by 2002:a05:6402:b4d:: with SMTP id bx13mr20810525edb.93.1607359866843; Mon, 07 Dec 2020 08:51:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607359866; cv=none; d=google.com; s=arc-20160816; b=R3U8FQhmk6DEU3ppTX9VSAaSaVcLM6TXz8VxsHA7LtBwJllBCSPSAwztpQSoOqSYXV q3Xkt0tCL4qL1LHXexxsDRt95KHyx+KF/o8YODTNFcXu/hA1GA50JIRXiO5y4HkkLgB9 BzvssMvbDrD/ahMK4Yfv5LmG3ouW7lJgtC5X61oHTNL0bdz1z3kT2gUiPMRDrAZ5pC+G lhNK6/YhiVoaCgakCGrl23sQDidrevdlKc7ZO/9j3XhNv5hZrVc49AP9lJyn2ni/u/zz XYOXxSd3ZD9LHj9qCMUrqlFOzEDbO+HzruTE9Zw9a4vL/w8jnxM5deD5wW9zvez3mnFS NF/g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :mime-version:accept-language:in-reply-to:references:message-id:date :thread-index:thread-topic:subject:cc:to:from; bh=M92AkB2f1rNbk7Zl/tTfV+01zJyznEnwediwz05adVU=; b=UYj0Eh1iCUymQJj+4duss1S6xZA0eRVrp1KB+80XRj9PM18jL/67yQ+yQoHb1irU1k +JcstpgYtSs2lwxTnV+M4sgys+JkieVZcKVhuOGYxzIjT150DCWXEG/OYlD8blLGMyJi lO71tk0Ew02aVzTzk5NS0nkhHCvq5h6DOYq8HFqAiH+zHSeNKnaVL15N3jUV1NR2ZBiP V8dSrHVfcP7Ore3LaA6ICKeG7YEyl0ulzPyPxpXs0YPCdAnhuQo8Forv3m655SUEvjrS 8AoYoNhYyVwaB3F2HwLGQ/izFkSzEO03if0xPd3APE3lQraiFQUBST5OG+w1qWaxu2Sk nf8g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e18si6981768ejq.261.2020.12.07.08.50.44; Mon, 07 Dec 2020 08:51:06 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727589AbgLGQsU convert rfc822-to-8bit (ORCPT + 99 others); Mon, 7 Dec 2020 11:48:20 -0500 Received: from eu-smtp-delivery-151.mimecast.com ([207.82.80.151]:33219 "EHLO eu-smtp-delivery-151.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727303AbgLGQsU (ORCPT ); Mon, 7 Dec 2020 11:48:20 -0500 Received: from AcuMS.aculab.com (156.67.243.126 [156.67.243.126]) (Using TLS) by relay.mimecast.com with ESMTP id uk-mta-242-QI3yR-scPsyRFFaCGeCl_A-1; Mon, 07 Dec 2020 16:46:41 +0000 X-MC-Unique: QI3yR-scPsyRFFaCGeCl_A-1 Received: from AcuMS.Aculab.com (fd9f:af1c:a25b:0:43c:695e:880f:8750) by AcuMS.aculab.com (fd9f:af1c:a25b:0:43c:695e:880f:8750) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Mon, 7 Dec 2020 16:46:40 +0000 Received: from AcuMS.Aculab.com ([fe80::43c:695e:880f:8750]) by AcuMS.aculab.com ([fe80::43c:695e:880f:8750%12]) with mapi id 15.00.1347.000; Mon, 7 Dec 2020 16:46:40 +0000 From: David Laight To: 'John Ogness' , Peter Zijlstra CC: Petr Mladek , Sergey Senozhatsky , Sergey Senozhatsky , Steven Rostedt , "Linus Torvalds" , Greg Kroah-Hartman , Thomas Gleixner , "linux-kernel@vger.kernel.org" Subject: RE: [PATCH next v2 2/3] printk: change @clear_seq to atomic64_t Thread-Topic: [PATCH next v2 2/3] printk: change @clear_seq to atomic64_t Thread-Index: AQHWzICKswdVD7bXr0KkK6JFsMrIzKnr1zJA Date: Mon, 7 Dec 2020 16:46:40 +0000 Message-ID: References: <20201201205341.3871-1-john.ogness@linutronix.de> <20201201205341.3871-3-john.ogness@linutronix.de> <875z5eof8g.fsf@jogness.linutronix.de> <20201207093419.GH3040@hirez.programming.kicks-ass.net> <87mtyq9blw.fsf@jogness.linutronix.de> In-Reply-To: <87mtyq9blw.fsf@jogness.linutronix.de> Accept-Language: en-GB, en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.202.205.107] MIME-Version: 1.0 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=C51A453 smtp.mailfrom=david.laight@aculab.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: aculab.com Content-Language: en-US Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: John Ogness > Sent: 07 December 2020 10:04 > > On 2020-12-07, Peter Zijlstra wrote: > >> Yes, and it is read-only access. Perhaps atomic64_t is the wrong thing > >> to use here. We could use a seqcount_latch and a shadow variable so that > >> if a writer has been preempted, we can use the previous value. (Only > >> kmsg_dump would need to use the lockless variant to read the value.) > >> > >> void clear_seq_set(u64 val) > >> { > >> spin_lock_irq(&clear_lock); > >> raw_write_seqcount_latch(&clear_latch); > >> clear_seq[0] = val; > >> raw_write_seqcount_latch(&clear_latch); > >> clear_seq[1] = val; > >> spin_unlock_irq(&clear_lock); > >> } > >> > >> u64 clear_seq_get_nolock(void) > >> { > >> unsigned int seq, idx; > >> u64 val; > >> > >> do { > >> seq = raw_read_seqcount_latch(&clear_latch); > >> idx = seq & 0x1; > >> val = clear_seq[idx]; > >> } while (read_seqcount_latch_retry(&clear_latch, seq)); > >> > >> return val; > >> } > > > > That's overly complicated. > > > > If you're going to double the storage you can simply do: > > > > > > seq = val > > smp_wmb(); > > seq_copy = val; > > > > vs > > > > do { > > tmp = seq_copy; > > smp_rmb(); > > val = seq; > > } while (val != tmp); > > That will not work. We are talking about a situation where the writer is > preempted. So seq will never equal seq_copy in that situation. I expect > that the seqcount_latch is necessary. Is the value just being incremented?? If so you can do: seq_hi_0 = val >> 32; smp_wmb(); seq_lo = val; smp_wmb(); seq_hi_1 = val >> 32; Then the reader can assume that seq_lo is zero if seq_h1_0 and seq_hi_1 differ. David - Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK Registration No: 1397386 (Wales)