Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756338AbcJ1NTX (ORCPT ); Fri, 28 Oct 2016 09:19:23 -0400 Received: from mail-vk0-f66.google.com ([209.85.213.66]:33507 "EHLO mail-vk0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751795AbcJ1NTW (ORCPT ); Fri, 28 Oct 2016 09:19:22 -0400 MIME-Version: 1.0 X-Originating-IP: [2a02:fe0:c130:1430:7e7a:91ff:fe0e:3e2c] In-Reply-To: References: <20161026191810.12275-1-dh.herrmann@gmail.com> <20161026191810.12275-9-dh.herrmann@gmail.com> From: Tom Gundersen Date: Fri, 28 Oct 2016 15:18:59 +0200 Message-ID: Subject: Re: [RFC v1 08/14] bus1: implement peer management context To: Richard Weinberger Cc: David Herrmann , LKML , Andy Lutomirski , Jiri Kosina , Greg KH , Hannes Reinecke , Steven Rostedt , Arnd Bergmann , Josh Triplett , Linus Torvalds , Andrew Morton Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1226 Lines: 38 On Fri, Oct 28, 2016 at 2:06 PM, Richard Weinberger wrote: > David, Tom, > > On Wed, Oct 26, 2016 at 9:18 PM, David Herrmann wrote: >> +struct bus1_peer *bus1_peer_new(void) >> +{ >> + static atomic64_t peer_ids = ATOMIC64_INIT(0); >> + const struct cred *cred = current_cred(); >> + struct bus1_peer *peer; >> + struct bus1_user *user; >> + >> + user = bus1_user_ref_by_uid(cred->uid); >> + if (IS_ERR(user)) >> + return ERR_CAST(user); >> + >> + peer = kmalloc(sizeof(*peer), GFP_KERNEL); >> + if (!peer) { >> + bus1_user_unref(user); >> + return ERR_PTR(-ENOMEM); >> + } >> + >> + /* initialize constant fields */ >> + peer->id = atomic64_inc_return(&peer_ids); > > What is the purpose of this id? Do other components depend on it > and are they aware of possible overflows? The id is used purely to give a name to the peer in debugfs. > Since it is an 64bit integer overflowing it is hard but not impossible. Hm, what scenario do you have in mind? I cannot see how this could happen (short of creating peers in a loop for hundreds of years). Cheers, Tom