Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp2952310ybg; Mon, 28 Oct 2019 05:11:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqz+1/odtbvXyTmCEELVC7jK14xVXWWyzAwurF0Kv01WrSpo0PEEClC0AFyKdwFzTbZCaZTl X-Received: by 2002:a17:906:1611:: with SMTP id m17mr13681417ejd.281.1572264678782; Mon, 28 Oct 2019 05:11:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572264678; cv=none; d=google.com; s=arc-20160816; b=PifdAXpi2ngaqfJHPc/S3aQTu0SORn5gbyxzJXAKXh7VCA6OkK+9yDC8mPjG071o4Z m1LlWapwQeGy2QEg+UTqz5pDL3GTXN6lSDN9Fnz1zetmm3B8hnX/7P0Ryn0SyDnwPw3H wAR4v8Hwm0rraqIJY+PAc54aiJL8Q0As/Mo5yS4I9YtdPRxqSqOZva/A3D2t3nVyHjve RlY1dNIDg7RKqgnUCZWuHhDvBngu0A62Relo5AkNKgtNlBCi5ZCdUzqZmFx+hn9onKU5 hPTOCAKS0UVe0TrmIyxWxjzwA754a8LeAXqgO4wsGP97d9N7eut9NQudZkUfKz1x/pNz 3BWg== 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=uD8vXcwvCS7LEjkwkeRor8uz93n3+EpFmi5oLWBi72Y=; b=ny+R7WJ+EjWisNujF+HeVOOl9Xc3n4WsGYnx3mV74jriCDJjMVH7ViNUezJ6CY+yR4 WWmKrcBr+rOQBs+3SUM2lQViNGdXKoWX+zYagT9luegXeyGgSZGc0S+47IbCrO6uPKwV 1TyNVCmJOJAUmdgUI/MPlExyMcTac7h+qA06N/fm98ys/bXxirnzpGJJtcXJIRquTDP1 A3kQjCarjJPxZaF7VhbHKNIW3h8ArhB4A/v6jnOhU4TMXJ7vjVkC9ktqb+PFpR75LTOJ SiCOXL8xHgcnYOxKuXF9MCAMhRu071S80ea7PAZL1+L2O2a2Qbe0nov3MzcNenIHUgau UUDw== 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 d36si6416313ede.44.2019.10.28.05.10.53; Mon, 28 Oct 2019 05:11:18 -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 S1727247AbfJ0WRH (ORCPT + 99 others); Sun, 27 Oct 2019 18:17:07 -0400 Received: from mx2.suse.de ([195.135.220.15]:50308 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726717AbfJ0WRH (ORCPT ); Sun, 27 Oct 2019 18:17:07 -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 C1DFFAD88; Sun, 27 Oct 2019 22:17:05 +0000 (UTC) From: Davidlohr Bueso To: eric@anholt.net, wahrenst@gmx.net Cc: gregkh@linuxfoundation.org, dave@stgolabs.net, linux-kernel@vger.kernel.org Subject: [PATCH] staging: vc04_services: replace g_free_fragments_mutex with spinlock Date: Sun, 27 Oct 2019 15:15:30 -0700 Message-Id: <20191027221530.12080-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 There seems no need to be using a semaphore, or a sleeping lock in the first place: critical region is extremely short, does not call into any blocking calls and furthermore lock and unlocking operations occur in the same context. Get rid of another semaphore user by replacing it with a spinlock. Signed-off-by: Davidlohr Bueso --- This is in an effort to further reduce semaphore users in the kernel. .../staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c index 8dc730cfe7a6..710d21654128 100644 --- a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c +++ b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_2835_arm.c @@ -63,7 +63,7 @@ static char *g_free_fragments; static struct semaphore g_free_fragments_sema; static struct device *g_dev; -static DEFINE_SEMAPHORE(g_free_fragments_mutex); +static DEFINE_SPINLOCK(g_free_fragments_lock); static irqreturn_t vchiq_doorbell_irq(int irq, void *dev_id); @@ -528,11 +528,11 @@ create_pagelist(char __user *buf, size_t count, unsigned short type) WARN_ON(g_free_fragments == NULL); - down(&g_free_fragments_mutex); + spin_lock(&g_free_fragments_lock); fragments = g_free_fragments; WARN_ON(fragments == NULL); g_free_fragments = *(char **) g_free_fragments; - up(&g_free_fragments_mutex); + spin_unlock(&g_free_fragments_lock); pagelist->type = PAGELIST_READ_WITH_FRAGMENTS + (fragments - g_fragments_base) / g_fragments_size; } @@ -591,10 +591,10 @@ free_pagelist(struct vchiq_pagelist_info *pagelistinfo, kunmap(pages[num_pages - 1]); } - down(&g_free_fragments_mutex); + spin_lock(&g_free_fragments_lock); *(char **)fragments = g_free_fragments; g_free_fragments = fragments; - up(&g_free_fragments_mutex); + spin_unlock(&g_free_fragments_lock); up(&g_free_fragments_sema); } -- 2.16.4