Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp893786ybx; Fri, 1 Nov 2019 13:02:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqxLAqljQ3xkoYlZ2UbAAPKnzW6iPGIduQSeeqwV9u92s4fyNRBYiOTS1QZFn7WCGrRkWnGN X-Received: by 2002:aa7:c6c9:: with SMTP id b9mr4897684eds.1.1572638579704; Fri, 01 Nov 2019 13:02:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572638579; cv=none; d=google.com; s=arc-20160816; b=maqJnGNdhOpfD86MzcbV3y9j3kcYotpEEZtsUyQ9HfpGzzCbLVbL1i19HIoZ37WjbP WEqhXgLeOQpdyD7tSZg3bP1MSxSs1RceaYQPzk4dHW8WSFzVjTP00F6HxY2cX/rGJ0qM ViTQsv5FVY/6WvmizpgI8InkoqNCIA2W6MEZKhiquAQJIjPFIMwCNp1+JpciBfK2Ie0m gR0sJPzlSp/fBCYQWSlWQrX1s8XZ1UKVwAzb3ZgI7J9HYZyIEkk9N42n83zsFZw0IkHt viYOrehQkuFiM7nxRRpfOpWRzCVCbxkF2DKxBwvHbsW8BTN5f2135wwBlhRhkUTlW1dH jKYw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=eODAYpwUSq8sknNL3bx5u/e2HlXwEy9HVcN6iqX93N8=; b=ROtyiSaGFMamPApbk03k428p7wWyeKyOsnN8sDVLOgRYU/z/9cPlpw6m4Rg+5qtNqU ERD4P1vPFtfXNyEfAsogqbjSx8qYkPmTrAXnu7ZJo5Uv+EtDLH0QLqS5L4KiHtfFDJ1+ UrMDqUuasfjfwKsdT/KW8UTby4UXiZbId3VSr+/2fap9g27fpaYQd0AAKO2xOf9hvto9 iIc6354c6f4lbz2NSKfVP+s4ACId2cSlhgEFH6ovcP6eooGNnEjRl3Xe0kuT+s8LLquc /pK8Q718MvgJ39eW8QZKdzZL5tosGd6kaAQchu0XP4KpJJHn71Ju0yxf/q8B2wz9fnA8 rtXw== ARC-Authentication-Results: i=1; mx.google.com; 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 u11si1341908edi.385.2019.11.01.13.02.33; Fri, 01 Nov 2019 13:02:59 -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; 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 S1727412AbfKAUBh (ORCPT + 99 others); Fri, 1 Nov 2019 16:01:37 -0400 Received: from mx2.suse.de ([195.135.220.15]:43118 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726709AbfKAUBh (ORCPT ); Fri, 1 Nov 2019 16:01:37 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 9D6D5B2CB; Fri, 1 Nov 2019 20:01:35 +0000 (UTC) From: Davidlohr Bueso To: kys@microsoft.com, haiyangz@microsoft.com, sthemmin@microsoft.com, sashal@kernel.org Cc: linux-kernel@vger.kernel.org, linux-hyperv@vger.kernel.org, dave@stgolabs.net, Davidlohr Bueso Subject: [PATCH] drivers/hv: Replace binary semaphore with mutex Date: Fri, 1 Nov 2019 13:00:04 -0700 Message-Id: <20191101200004.20318-1-dave@stgolabs.net> X-Mailer: git-send-email 2.16.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org At a slight footprint cost (24 vs 32 bytes), mutexes are more optimal than semaphores; it's also a nicer interface for mutual exclusion, which is why they are encouraged over binary semaphores, when possible. Replace the hyperv_mmio_lock, its semantics implies traditional lock ownership; that is, the lock owner is the same for both lock/unlock operations. Therefore it is safe to convert. Signed-off-by: Davidlohr Bueso --- This is part of reducing the amount of semaphore users in the kernel. Compile-tested only. drivers/hv/vmbus_drv.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c index 391f0b225c9a..5c606dc4a3f7 100644 --- a/drivers/hv/vmbus_drv.c +++ b/drivers/hv/vmbus_drv.c @@ -79,7 +79,7 @@ static struct notifier_block hyperv_panic_block = { static const char *fb_mmio_name = "fb_range"; static struct resource *fb_mmio; static struct resource *hyperv_mmio; -static DEFINE_SEMAPHORE(hyperv_mmio_lock); +static DEFINE_MUTEX(hyperv_mmio_lock); static int vmbus_exists(void) { @@ -2011,7 +2011,7 @@ int vmbus_allocate_mmio(struct resource **new, struct hv_device *device_obj, int retval; retval = -ENXIO; - down(&hyperv_mmio_lock); + mutex_lock(&hyperv_mmio_lock); /* * If overlaps with frame buffers are allowed, then first attempt to @@ -2058,7 +2058,7 @@ int vmbus_allocate_mmio(struct resource **new, struct hv_device *device_obj, } exit: - up(&hyperv_mmio_lock); + mutex_unlock(&hyperv_mmio_lock); return retval; } EXPORT_SYMBOL_GPL(vmbus_allocate_mmio); @@ -2075,7 +2075,7 @@ void vmbus_free_mmio(resource_size_t start, resource_size_t size) { struct resource *iter; - down(&hyperv_mmio_lock); + mutex_lock(&hyperv_mmio_lock); for (iter = hyperv_mmio; iter; iter = iter->sibling) { if ((iter->start >= start + size) || (iter->end <= start)) continue; @@ -2083,7 +2083,7 @@ void vmbus_free_mmio(resource_size_t start, resource_size_t size) __release_region(iter, start, size); } release_mem_region(start, size); - up(&hyperv_mmio_lock); + mutex_unlock(&hyperv_mmio_lock); } EXPORT_SYMBOL_GPL(vmbus_free_mmio); -- 2.16.4