Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1689438pxk; Fri, 2 Oct 2020 16:52:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy3L0EMt2bVWpBfvZxBf1Pw70Se+M20uGkAUfx83/mN2BX6MVu4v97JdUa2OOij+J3iquOq X-Received: by 2002:a17:906:e08f:: with SMTP id gh15mr4462357ejb.443.1601682773456; Fri, 02 Oct 2020 16:52:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601682773; cv=none; d=google.com; s=arc-20160816; b=TVZaF+5kO8lAEfRGvNwxfcECSwhWyrL5L9ldR0eCqQqhjTeO/UakIC24muSod8JTCR 7EiXWO8z5maFhJbkj8fh71NGZ5TS5uyPU4HuwhNuqVFc901adq8z4M8Cz8E7/n3G5LwK e621H8iewYl4NdVOc+x6K+mQiBIIQApfzZ0tYwb4Sphmj3Dvd6Op70otT0sznOyVZp2o R1YqZyh6bbiIbEJDDIx441ePC3rSjQiZ600zxa/fY6PzFms49MHl+68cYt3O9aST7a4E m7TwKD55sI2l/IywX9ANJmgvq0u0NlNWKyGRlpyktpBz+4sNH1/B18Hxa90F6IHlN7Zd m9+Q== 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 :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=y34GUHs7y+dhv/PBEvBFpzMJQXZxzed838y/lOyLkeg=; b=FUg26nYr8VhqDoioEGZzfyGmiH5Q1jkKorPcMDMYM6XqpZjFqs/p2cS+XM+xTsMe7x DGOsbqf1gYTed2cZX2cZLyNNZVKNBgNqb/58oA2DrH0RI85EKBjjZo8i9GtfvjAKwWXe 9hl+MqecGzCu2hSoWBQ5NVKUUaI100I+cw+QV1UQzialMy4+LwqMRDnpE8B0RW3mj4+6 1izT2KMhvE7IawI74eWOB4R06At2u32cUgPyAcV/VQG3LVmQoMYowP7/LZtehEvFhXNX U5TU5fKUlcbOogGY19u71MVDVFWdCOPXgD7zOEoA8TAwGvdc50M3PIQDjfxd8FqteBkr +spA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=OwYWHVGo; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id pg18si828371ejb.467.2020.10.02.16.52.31; Fri, 02 Oct 2020 16:52:53 -0700 (PDT) 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; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=OwYWHVGo; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725791AbgJBXuL (ORCPT + 99 others); Fri, 2 Oct 2020 19:50:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57010 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725283AbgJBXuL (ORCPT ); Fri, 2 Oct 2020 19:50:11 -0400 Received: from mail-io1-xd29.google.com (mail-io1-xd29.google.com [IPv6:2607:f8b0:4864:20::d29]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 291A1C0613D0 for ; Fri, 2 Oct 2020 16:50:11 -0700 (PDT) Received: by mail-io1-xd29.google.com with SMTP id k6so3365935ior.2 for ; Fri, 02 Oct 2020 16:50:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linuxfoundation.org; s=google; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=y34GUHs7y+dhv/PBEvBFpzMJQXZxzed838y/lOyLkeg=; b=OwYWHVGo0duTZnucRDmSw4KE0SR/5oK6MjUHXkaXaZfKd4ZipqfpuD49mVhiJKjZlv foof3M7EwOlISDCGFPniEcCoGb9R3GMBYpjtj1kdCbWhzCtglUC2Y3AhMXI56dvI4IB3 12EP7mBPUzV7Y/Dkj7rbuTUXufEgWwpYYDz5w= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=y34GUHs7y+dhv/PBEvBFpzMJQXZxzed838y/lOyLkeg=; b=Xjmu1h9zvk8F0lxt5ycH60g2zlIpa7ggS1y61Ajf53F8Jq6jZsGweZXETTzmKlS9C4 P3Z3RJQfdS9wCSWDSAHvpNGal4/mLtXLvIPdEoh3TDCs8VXpQ1BgVHplEtEz3uvxT4lZ II7ANIgGDNIJMMIqZbojJAHPVXJ6bBxa26Pw9C8mhFPqLaUqfEUVkgRZYgy1H6Z6YmfW mKSzC7qWhwhwFvHGA4/EKX2mXpcgy9YQ++wpPgOg+XtdzFHU37SjsbWqUWg/G18IEPaJ ZTwlR4wRfgIPumFr/fJchLQj98V63pr7TqZkKusrr6GKRcApiQYpPOUcVwFXOjcCsTYh nGsQ== X-Gm-Message-State: AOAM533EkX5i/5zz7Rc+PJjSESq7vQG5O1zXvIRLZ5ca3rbJjGK2tOdi A/tFag3dEHff4rAh2i8VRVRrBA== X-Received: by 2002:a6b:7909:: with SMTP id i9mr3399241iop.98.1601682610398; Fri, 02 Oct 2020 16:50:10 -0700 (PDT) Received: from [192.168.1.112] (c-24-9-64-241.hsd1.co.comcast.net. [24.9.64.241]) by smtp.gmail.com with ESMTPSA id z13sm1571063ilm.53.2020.10.02.16.50.09 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 02 Oct 2020 16:50:09 -0700 (PDT) Subject: Re: drivers/block/rbd.c: atomic_inc_return_safe() & atomic_dec_return_safe() To: Jens Axboe , idryomov@gmail.com, dongsheng.yang@easystack.cn Cc: ceph-devel@vger.kernel.org, Linux Kernel Mailing List , Greg Kroah-Hartman , Kees Cook , Shuah Khan References: From: Shuah Khan Message-ID: Date: Fri, 2 Oct 2020 17:50:09 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/2/20 5:44 PM, Jens Axboe wrote: > On 10/2/20 4:34 PM, Shuah Khan wrote: >> All, >> >> I came across these atomic_inc_return_safe() & atomic_dec_return_safe() >> functions that hold the counters at safe values. >> >> atomic_inc_return_safe() >> >> If the counter is already 0 it will not be incremented. >> If the counter is already at its maximum value returns >> -EINVAL without updating it. >> >> atomic_dec_return_safe() >> >> Decrement the counter. Return the resulting value, or -EINVAL >> >> These two routines are static and only used in rbd.c. >> >> Can these become part of atomic_t ops? > > I think you just want to use refcount_t for this use case. They > have safe guards for under/overflow. > Makes sense. Guess these came before refcount_t. I will track this for refcount_t conversion. thanks, -- Shuah