Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp2750527pxb; Sun, 29 Aug 2021 02:24:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwUaVznHXv8iPS9/EjFFcXvDTS5IYknA/sJCSxIi2aX9TKVR61aur0RH2oaXOMXbSJDKYJu X-Received: by 2002:a6b:8d15:: with SMTP id p21mr14078474iod.194.1630229088109; Sun, 29 Aug 2021 02:24:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630229088; cv=none; d=google.com; s=arc-20160816; b=VSs9QjUwds5L3I6i9luIM+zcQJ/7uRngRTAWYQeOGNX491NJafQCJW9pqTyqPQfOJh lI6FyPXjC6sSya77CW1x1J40sLEr8y/bFOUP/ZcHBhZoJpXO2T+Xj+w+yNPOgXt3MpDs xMoi5JXtgZTAzhbCazk4KLsr7DTV6BATgFPozThHLloHDG09CfhRHq3KOeea4ifJ0i+o aJbNQ1jLe2ga4bkbRdOrBdHZI7V3J3HPr9RBIhOZZwt4VgJ02HhxOin/LsNIuAvyVLns JSRHCnZeCj//sRSiSwEdYmqCYDO4BvmTNGKYHCTCcwX4g3WbIcldQdl5vWXEaj41wFWD kpJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=e+dqt6XS4ZNHrivjUXrH9fxmNodvBLxJ0+D0nFk09Hs=; b=Ac+yTMM9kLquFlwwQXRThUvtffoCxCihEQ0M4DXt8okBUk1o462moaFm5vo1Jx2UuE 83mOgK40E4yiFdZBOGhJ1eByWzkey0D+gbJseGHnKuoQmvOZx825VCcYgOPc2NEEFw82 nKqDXA6eYXnWeKSa8ptt3sZduLWApEDri4YbFbPGGJBFdZgpCNO/SjR1oXpH7d3jSr0c u+X83VQV7AsdpDEgflUQIC9RTl/iPNWE7m7vs20CGkfInYuRVs8LHp0voRCPulcPBkMB f+GdOV72h+3QBXGvKQxGfF7wQeP0etgAt80gc4AR25EQcZq+A4Vw2+L7nygiR3KMeN7q TFOQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=JU8XOd2b; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t11si12444465jal.119.2021.08.29.02.24.36; Sun, 29 Aug 2021 02:24:48 -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=@gmail.com header.s=20161025 header.b=JU8XOd2b; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234889AbhH2JXw (ORCPT + 99 others); Sun, 29 Aug 2021 05:23:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52388 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234835AbhH2JXw (ORCPT ); Sun, 29 Aug 2021 05:23:52 -0400 Received: from mail-ej1-x629.google.com (mail-ej1-x629.google.com [IPv6:2a00:1450:4864:20::629]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 215CAC061575 for ; Sun, 29 Aug 2021 02:23:00 -0700 (PDT) Received: by mail-ej1-x629.google.com with SMTP id mf2so24033393ejb.9 for ; Sun, 29 Aug 2021 02:23:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=e+dqt6XS4ZNHrivjUXrH9fxmNodvBLxJ0+D0nFk09Hs=; b=JU8XOd2b7Xq5IKjUsiaaBVKqQ3ZtsFJwsPoNIih8o+KUk46lR4ecr611my62NK94Z5 cLZlHegUnhQo6eN7sxiYLPLd8CIrtDYVLdwdtExbixGnYWFDEtkzsa11hQ/XG2rPr6mj RFadpuwGKvGyQGDZtydcVxY6RyAFMU1Tw44uD4EZhKQhbEUw4IVrdf0EK0tkinCyvFCO +lotJf7sryrklWXPjz0BHrU88LxcL6cgcP6lFcUZCXcQFP2d9RNBKMCdmK/CvckqjQwJ 98Zcc5y4MDfDcgf5akQMDpnikq15HZn3lw+PvDjhQNydQomY60Im6u5BjleJdZ2rEZmX bUdg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=e+dqt6XS4ZNHrivjUXrH9fxmNodvBLxJ0+D0nFk09Hs=; b=mwBhpSBFXsFNYqwPjfvhNzvlxunRkR33lAtN0czLXLtwjsZJFDhX6P5zk/ycW5Vhqj xFkpTvRVwWQd6t5+kC+hDqxAtuqRC5mB0UWp31PmsGPpOfwjJUSEWiasc2q58kaJUhiP 1Grp4a2UJMlW3BIPt28kJ/JFxW0SuF9VmuUPN+nUZFX+hysU2nApgWyUyZxGRmItG1mZ 9FU+GWh6tc6q110VhoojAUfzO/pEIAiNFRUSrd8trHxGCQDzbqMUmgDQZBN+xu/pw24a WkkmHRKWh1jWOwiYB584macwwia9NcJroSZhqcemG8rxxJp4X9hZjoGED3diphzW7pnC dxJg== X-Gm-Message-State: AOAM533LyWBPQGhydyNsIw8CiZVRhdDxmXAQymZFLiMPFPXOFFuZn5qc O8YfsUtTo9cBlde+cCB77k0= X-Received: by 2002:a17:907:628d:: with SMTP id nd13mr19549239ejc.7.1630228978627; Sun, 29 Aug 2021 02:22:58 -0700 (PDT) Received: from localhost.localdomain (host-79-22-100-164.retail.telecomitalia.it. [79.22.100.164]) by smtp.gmail.com with ESMTPSA id u4sm610916ejc.19.2021.08.29.02.22.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 29 Aug 2021 02:22:57 -0700 (PDT) From: "Fabio M. De Francesco" To: Johan Hovold , Alex Elder , Greg Kroah-Hartman , greybus-dev@lists.linaro.org, linux-staging@lists.linux.dev, linux-kernel@vger.kernel.org Cc: "Fabio M. De Francesco" Subject: [PATCH v4] staging: greybus: Convert uart.c from IDR to XArray Date: Sun, 29 Aug 2021 11:22:50 +0200 Message-Id: <20210829092250.25379-1-fmdefrancesco@gmail.com> X-Mailer: git-send-email 2.32.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Convert greybus/uart.c from IDR to XArray. The abstract data type XArray is more memory-efficient, parallelisable, and cache friendly. It takes advantage of RCU to perform lookups without locking. Furthermore, IDR is deprecated because XArray has a better (cleaner and more consistent) API. Signed-off-by: Fabio M. De Francesco --- v3->v4: Remove mutex_lock/unlock around xa_load(). These locks seem to be unnecessary because there is a 1:1 correspondence between a specific minor and its gb_tty and there is no reference counting. I think that the RCU locks used inside xa_load() are sufficient to protect this API from returning an invalid gb_tty in case of concurrent access. Some more considerations on this topic are in the following message to linux-kernel list: https://lore.kernel.org/lkml/3554184.2JXonMZcNW@localhost.localdomain/ v2->v3: Fix some issues according to a review by Alex Elder v1->v2: Fix an issue found by the kernel test robot. It is due to passing to xa_*lock() the same old mutex that IDR used with the previous version of the code. drivers/staging/greybus/uart.c | 32 ++++++++++++++------------------ 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/drivers/staging/greybus/uart.c b/drivers/staging/greybus/uart.c index 73f01ed1e5b7..f66983adb51b 100644 --- a/drivers/staging/greybus/uart.c +++ b/drivers/staging/greybus/uart.c @@ -22,7 +22,7 @@ #include #include #include -#include +#include #include #include #include @@ -32,8 +32,9 @@ #include "gbphy.h" -#define GB_NUM_MINORS 16 /* 16 is more than enough */ -#define GB_NAME "ttyGB" +#define GB_NUM_MINORS 16 /* 16 is more than enough */ +#define GB_RANGE_MINORS XA_LIMIT(0, GB_NUM_MINORS) +#define GB_NAME "ttyGB" #define GB_UART_WRITE_FIFO_SIZE PAGE_SIZE #define GB_UART_WRITE_ROOM_MARGIN 1 /* leave some space in fifo */ @@ -67,8 +68,7 @@ struct gb_tty { }; static struct tty_driver *gb_tty_driver; -static DEFINE_IDR(tty_minors); -static DEFINE_MUTEX(table_lock); +static DEFINE_XARRAY(tty_minors); static int gb_uart_receive_data_handler(struct gb_operation *op) { @@ -341,8 +341,7 @@ static struct gb_tty *get_gb_by_minor(unsigned int minor) { struct gb_tty *gb_tty; - mutex_lock(&table_lock); - gb_tty = idr_find(&tty_minors, minor); + gb_tty = xa_load(&tty_minors, minor); if (gb_tty) { mutex_lock(&gb_tty->mutex); if (gb_tty->disconnected) { @@ -353,19 +352,18 @@ static struct gb_tty *get_gb_by_minor(unsigned int minor) mutex_unlock(&gb_tty->mutex); } } - mutex_unlock(&table_lock); return gb_tty; } static int alloc_minor(struct gb_tty *gb_tty) { int minor; + int ret; - mutex_lock(&table_lock); - minor = idr_alloc(&tty_minors, gb_tty, 0, GB_NUM_MINORS, GFP_KERNEL); - mutex_unlock(&table_lock); - if (minor >= 0) - gb_tty->minor = minor; + ret = xa_alloc(&tty_minors, &minor, gb_tty, GB_RANGE_MINORS, GFP_KERNEL); + if (ret) + return ret; + gb_tty->minor = minor; return minor; } @@ -374,9 +372,7 @@ static void release_minor(struct gb_tty *gb_tty) int minor = gb_tty->minor; gb_tty->minor = 0; /* Maybe should use an invalid value instead */ - mutex_lock(&table_lock); - idr_remove(&tty_minors, minor); - mutex_unlock(&table_lock); + xa_erase(&tty_minors, minor); } static int gb_tty_install(struct tty_driver *driver, struct tty_struct *tty) @@ -837,7 +833,7 @@ static int gb_uart_probe(struct gbphy_device *gbphy_dev, minor = alloc_minor(gb_tty); if (minor < 0) { - if (minor == -ENOSPC) { + if (minor == -EBUSY) { dev_err(&gbphy_dev->dev, "no more free minor numbers\n"); retval = -ENODEV; @@ -982,7 +978,7 @@ static void gb_tty_exit(void) { tty_unregister_driver(gb_tty_driver); put_tty_driver(gb_tty_driver); - idr_destroy(&tty_minors); + xa_destroy(&tty_minors); } static const struct gbphy_device_id gb_uart_id_table[] = { -- 2.32.0