Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932626AbcJQUag (ORCPT ); Mon, 17 Oct 2016 16:30:36 -0400 Received: from mout.kundenserver.de ([212.227.17.10]:49289 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758012AbcJQUa1 (ORCPT ); Mon, 17 Oct 2016 16:30:27 -0400 From: Arnd Bergmann To: Binoy Jayan Cc: Doug Ledford , Sean Hefty , Hal Rosenstock , linux-rdma@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 6/8] IB/hns: Replace counting semaphore event_sem with wait condition Date: Mon, 17 Oct 2016 22:29:57 +0200 Message-ID: <5900385.6T4BAIyXjD@wuerfel> User-Agent: KMail/5.1.3 (Linux/4.4.0-34-generic; KDE/5.18.0; x86_64; ; ) In-Reply-To: <1476721862-7070-7-git-send-email-binoy.jayan@linaro.org> References: <1476721862-7070-1-git-send-email-binoy.jayan@linaro.org> <1476721862-7070-7-git-send-email-binoy.jayan@linaro.org> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-Provags-ID: V03:K0:zKepDcLHDeW92+ar1XtnMLRF1INybuFnFJG43EbbkhoJSWvoVe4 vDUy8rvpdYvs7OzvrXZq0+eha0QAMAeQbaCYJPKizk17aFeyWt1Afh0vYBJr37RKtmMkC0D dXH+gWwsF/yQ0jwdPoW8h2A03efOXm9zj1cg03nQztzamgskGrCjWlk70WGmdmzdOWiQpkF sjuNpLYml3AGtyLNb2feg== X-UI-Out-Filterresults: notjunk:1;V01:K0:vjOwFmLXiFA=:7uN6+qX9h5QYfwN3duRZR8 CO1aVYSxoTP/XNbtwZHJubAJ+MjD9un8lhj0p/LMAtKlyQei3aERFFpt8lCVYqIcm4OXSEKPl ZlLSEU+rkczZ1df5L1+oBkv/M3JieoG52h9SWlERpSyPxBJg3wWbQtRZJom2x6AH+qH/fHemr ajZAE69TDftTb5zoEBYjteJjCiuQu5jMOy+rIL4/soxBHSB89oOWUNfoZjbBq1OtXmCK5NCeM iZ2fKUGZH/EqGGgGnhfTS+ij7TRecgKcI/BBBBJrqaeDhQfe1nKGLbiCq5J6PPWJ8HjZVLjt/ jR7nwVmEwgURgfdI6ozutB7OXhgJbOH2W5uHKoadeySK5MgMFd5BGKOmgdsGZSGIGq7d3hLCB qCOAkkpSBYvPZwteIPml1ZuC3YuV8z6NoUDAyAJcdQjsFqQtEmV1IdS4xRq12nDlFT6/hBXrR 3jq6nyFRIJRUd2OAwkX7Bcm/3EtweQSl0v/91qRnMnDDUx4cihw3C25uc5x5d1aPTjMBeOGiQ Yrl3ARXA2N1H4ZwcZg1XWt4pvzdlJgB8CV8NTHuPWyoBH3sjE6xfF5S4yLDIEhvwL7d2xlJrG j7OmbW69K8NAVfhRwF/dSelHPkFh5OGOi1x8PFQoeLgyr9sA19vfbT0RwmS0k+Wxh6+fIwR70 Z0+p6dMAdabgDlTceB6XTqa3CqcJqVIJAh9NwcaC7EhEkock2ShVm5L0BvpYy99oMW800RKrp sDQW2AfH2Sdh9iUH Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1337 Lines: 33 On Monday, October 17, 2016 10:01:00 PM CEST Binoy Jayan wrote: > --- a/drivers/infiniband/hw/hns/hns_roce_cmd.c > +++ b/drivers/infiniband/hw/hns/hns_roce_cmd.c > @@ -248,10 +248,14 @@ static int hns_roce_cmd_mbox_wait(struct hns_roce_dev *hr_dev, u64 in_param, > { > int ret = 0; > > - down(&hr_dev->cmd.event_sem); > + wait_event(hr_dev->cmd.event_sem.wq, > + atomic_add_unless(&hr_dev->cmd.event_sem.count, -1, 0)); > + > ret = __hns_roce_cmd_mbox_wait(hr_dev, in_param, out_param, > in_modifier, op_modifier, op, timeout); > - up(&hr_dev->cmd.event_sem); > + > + if (atomic_inc_return(&hr_dev->cmd.event_sem.count) == 1) > + wake_up(&hr_dev->cmd.event_sem.wq); > > return ret; > } This is the only interesting use of the event_sem that cares about the counting and it protects the __hns_roce_cmd_mbox_wait() from being entered too often. The count here is the number of size of the hr_dev->cmd.context[] array. However, that function already use a spinlock to protect that array and pick the correct context. I think changing the inner function to handle the case of 'no context available' by using a waitqueue without counting anything would be a reasonable transformation away from the semaphore. Arnd