Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp810676ybx; Fri, 1 Nov 2019 11:35:29 -0700 (PDT) X-Google-Smtp-Source: APXvYqz1viSF2w5ThzpyEz96XvIQKordsHuQhIOHSmd3x2hjdgbpOPd3I+fCl8M85tZV4WXiOLtG X-Received: by 2002:a17:906:5ac5:: with SMTP id x5mr11381120ejs.257.1572633329511; Fri, 01 Nov 2019 11:35:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572633329; cv=none; d=google.com; s=arc-20160816; b=yvgyeTeYmyBCdT/tWeApYUXPOD9AXpaPtqla08ZsMam1o7TYR7Jcy4uY10i78Rp8jr T443vYYIBuooU/G2Rqz1ZXyMY6lS49jnnJx4AOezDZA/3JR6FHpsdQ5jhgJ3KUvB7ZVU kFtEqHCgU8rC3i2hzSQbmcSfvMJndc/qIwCCle047hnDJqVAqMseXPp3lSjtJZj7wUYI Z4a/CcM9pX/J3NoL/vKsjcqyET+qzq/75SQ550uAttxpt9ESp5pQa2UAZtukCmrlz35O jfV19wyI6UxQ3geJF3MoSxQczReWzVrfvIFDxbmzBmm4uq/rXBFFMd2OLyZTt+nsuvba HiLg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=3r+YUUclAtovCSw7GUSPsIf+BDg59WwwL7czXG9pPzw=; b=H+tBwMXahShmaC4DdmtYiHKkhOYJvjUtYt58Q3g9a+RqjIUO4iN4fCEy4vQpLGgvQt 3VjdoC1DzqzcQwsgqPKyG9czruwfJ/yjhnUAnVh8JesOhkLK6bL9x6x+kBwepnBQDr36 VCjlBXeghRGdROtsLSrmGmj5jJ6WNnxXJ4Z5vgi/SishnM0w62qkiiqVuQKyVcEaCeBh yJnh7zZDJpY06bn0hr/zscw//ragdoRqRehgl0v+SD4YNfw5sal6yj2uIQxjFJCnITpe QflLQEKRG0kcxk4mgRGuDVgQlfHwE6Nh7phfZ0gSGCnrUrioKeZFvP9PgqqIuMIU2nMH V8jA== 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 a55si983192edc.13.2019.11.01.11.35.05; Fri, 01 Nov 2019 11:35:29 -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 S1727473AbfKASbj (ORCPT + 99 others); Fri, 1 Nov 2019 14:31:39 -0400 Received: from mx2.suse.de ([195.135.220.15]:43322 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727222AbfKASbj (ORCPT ); Fri, 1 Nov 2019 14:31:39 -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 41AABB309; Fri, 1 Nov 2019 18:31:37 +0000 (UTC) From: Davidlohr Bueso To: eric@anholt.net, wahrenst@gmx.net Cc: gregkh@linuxfoundation.org, dave@stgolabs.net, linux-kernel@vger.kernel.org, devel@driverdev.osuosl.org Subject: [PATCH resend] staging: vc04_services: replace g_free_fragments_mutex with spinlock Date: Fri, 1 Nov 2019 11:29:49 -0700 Message-Id: <20191101182949.21225-1-dave@stgolabs.net> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20191028165909.GA469472@kroah.com> References: <20191028165909.GA469472@kroah.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There is 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. This is a resend, which just seems simpler given the confusions. .../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