From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-lj1-f181.google.com (mail-lj1-f181.google.com [209.85.208.181]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EF2AF334688 for ; Tue, 17 Mar 2026 21:17:14 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.181 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773782236; cv=none; b=BDt1B0UMDeazqCwkIqJcuIC32D1DPUq4TUmAY7rZjqly8zI8i+aP/3mFBt5doSbZfbfRpsJX0AvE5iLmzferXL+LvyfpAl/K4XoE3yCeEP05lo/hDz+9xAV6zY1s56hvZjUgDMCRuyhxIF6sysDQ72ztiyGzIJbuOeisSvj/Oe0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773782236; c=relaxed/simple; bh=1S9lDlu/x97TsP/WWrDi53PQd5spyLKCkNoNsuVAow4=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=oK9YLeuqmvR+rD25rsrvUsctZr3Wnhe139YBwz8XM0SEsSMr1osaxdvvU6t86DCcfWPofy+rZm2O7IeSEbTcsQUC4ojhb35KoswMBuvWrEcE1tnYGgMjtgFu5wUSLi68xysCfjk5f+HXG2ANJRfGXTiOeGbl3qKZq/i3IImsQO0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=cn7wmgiv; arc=none smtp.client-ip=209.85.208.181 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="cn7wmgiv" Received: by mail-lj1-f181.google.com with SMTP id 38308e7fff4ca-38a2e62b893so50413651fa.1 for ; Tue, 17 Mar 2026 14:17:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1773782233; x=1774387033; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=k0fyMktyhZQ4/nntQbVatF5P/jsJ0+yYs8f8wPeGzK8=; b=cn7wmgivZT5LWPgZ/Py8mgJDQ+Gnn4HWF8iaazs5XC47ZfXbek3DcQe14mc935ZBTx lSnnkPRFpNjOSlKHbh+oOPX2n35qsRyxyTfub/jmStbXQYXd+uHEG8kTZWjUZbKSdPke BxDXUfXmJOUJfkFvuPqKNeVupMCpmkwr6t22QEQPHyfIFgfGe6e0Q4q3qxaHxueWR1Qf qGiJJV8N6w0xCZfZ0vT4dsw4WhwyUAEk0CPEFl+6KW7H/E3YJWZL73cUxPgL3wHZ1qQM TbU9xYnumeWGwJ/MTvtrxwrH5c97VGB9a2Dcdzay4F0tz34e9ig7hC4JntrPvdwtoKCp ky9g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1773782233; x=1774387033; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=k0fyMktyhZQ4/nntQbVatF5P/jsJ0+yYs8f8wPeGzK8=; b=qva4+05VBpIlufXoTdwyCkbRo0xjfas0EGzCvizrrWMAVwfE6V4KBn//WosDERZOXV mZ8TlQ5qqtGP5kD/Rl1qRNI/IPRdb41ue5us6yhxU6e/7Sj25/09NqhjndmmVZZz/OtN g3U+3FOzbmZ0J3Dg4P5ju+G8Z4c2xZHLcCX5Ti2hxi03YhpA03TMkvOmT8Xn2oOOay1B iEwaZeGO58bGyue9WiMc5VIo99nybkNCytZ2+KSaL87Hydn17xUwycNbynE/fk1kR24g EIJ6cOMGMfqsz72qM00cNSqF96702sq0HKy0XOv9yAB7zxSe43p25Hi6k7SmWNQJ7Jd7 x1vg== X-Forwarded-Encrypted: i=1; AJvYcCXgkkJWc3ZtkLFlxDM6vy3SiRDoLHkwYTbmGYYMhn7BhuxcwzWI65i0lZFLVwSRd82KLaUyWkDGAuxsDjE=@vger.kernel.org X-Gm-Message-State: AOJu0YwL3a9+SqOBfZd0N/YXMMpmYMIxvFq4/RiiBRvjZ/XluenOMW+j meKngEF+k62QLcs58XcH5PZbcXxGi6EQcBhTF6+Psk4J1TevAIFfrvmE X-Gm-Gg: ATEYQzxQ/76Z3Pq31IbhzaYcOJLr+pubZd5Uk2gxJUFDBUuNL/y0tAV/8bKplek3OA+ hunMdKO45uYXs6X5s5TiowKbAeXckKJtVeBEqUfMewmAw/uFWK594HUnZEcsdBwa+/GhW5oIG31 ZrH1PAFFLhZ7kxK9ahvhnuSzD7b8w9VwTDZIo1+TsVJkmnr1nLi+Ed8RRCseG0SjBsLLAjN8lE8 p4xTYO3iMMEDNIUfR2HlywJtkPjxcfRObw3l/E3Y4DOut9TP3SmJVkxK4B8Uul4Xzek86MMgubY mQEsHXwlEAm+QIPO1Wn7adri8p5sAle5l7A+WI6YTEO4BLokYBZKWKRykTazgG0+idZNAEeSyYP guwMnLIQuGfg3JnmaaD170Pu5rVQld0WPunlBRYVxMlC7akX7CCjJEHPbxhj5gHcMCbDck7UT6H xRMA8sxByemomfSfesvgwqYnOqbiP7BOMXgdc840WIiLbA/hXqJjLgJt8Rz4xodvj7NnujBc4M/ Q== X-Received: by 2002:a2e:3218:0:b0:38a:4197:862c with SMTP id 38308e7fff4ca-38bd57ed443mr3342951fa.9.1773782232850; Tue, 17 Mar 2026 14:17:12 -0700 (PDT) Received: from T6NXCV08J99224A.lan (81-237-238-191-no600.tbcn.telia.com. [81.237.238.191]) by smtp.gmail.com with ESMTPSA id 38308e7fff4ca-38bd54bc645sm1716991fa.30.2026.03.17.14.17.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 17 Mar 2026 14:17:11 -0700 (PDT) From: Oskar Ray-Frayssinet To: dtwlin@gmail.com Cc: johan@kernel.org, elder@kernel.org, gregkh@linuxfoundation.org, greybus-dev@lists.linaro.org, linux-staging@lists.linux.dev, linux-kernel@vger.kernel.org, Oskar Ray-Frayssinet Subject: [PATCH] staging: greybus: replace DEFINE_IDR with DEFINE_XARRAY_ALLOC in uart.c Date: Tue, 17 Mar 2026 22:16:51 +0100 Message-ID: <20260317211651.8098-1-rayfraytech@gmail.com> X-Mailer: git-send-email 2.43.0 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Replace deprecated DEFINE_IDR and idr_* functions with the modern DEFINE_XARRAY_ALLOC and xa_* equivalents in the greybus uart driver. Signed-off-by: Oskar Ray-Frayssinet --- drivers/staging/greybus/uart.c | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/drivers/staging/greybus/uart.c b/drivers/staging/greybus/uart.c index 7d060b4cd33d..6af0a3b4d2c4 100644 --- a/drivers/staging/greybus/uart.c +++ b/drivers/staging/greybus/uart.c @@ -67,7 +67,7 @@ struct gb_tty { }; static struct tty_driver *gb_tty_driver; -static DEFINE_IDR(tty_minors); +static DEFINE_XARRAY_ALLOC(tty_minors); static DEFINE_MUTEX(table_lock); static int gb_uart_receive_data_handler(struct gb_operation *op) @@ -342,7 +342,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) { @@ -360,12 +360,15 @@ static struct gb_tty *get_gb_by_minor(unsigned int minor) 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); + ret = xa_alloc(&tty_minors, &minor, gb_tty, + XA_LIMIT(0, GB_NUM_MINORS - 1), GFP_KERNEL); mutex_unlock(&table_lock); - if (minor >= 0) - gb_tty->minor = minor; + if (ret) + return ret; + gb_tty->minor = minor; return minor; } @@ -375,7 +378,7 @@ static void release_minor(struct gb_tty *gb_tty) gb_tty->minor = 0; /* Maybe should use an invalid value instead */ mutex_lock(&table_lock); - idr_remove(&tty_minors, minor); + xa_erase(&tty_minors, minor); mutex_unlock(&table_lock); } @@ -984,7 +987,7 @@ static void gb_tty_exit(void) { tty_unregister_driver(gb_tty_driver); tty_driver_kref_put(gb_tty_driver); - idr_destroy(&tty_minors); + xa_destroy(&tty_minors); } static const struct gbphy_device_id gb_uart_id_table[] = { -- 2.43.0