Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp3864013iob; Tue, 17 May 2022 08:43:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzeKwt+L33bYNwTb6HxzUcoMld9aUwSWdXZ6iBjwxvxOB4GjRnGv3h7qxKZqvCxQxX1uU0P X-Received: by 2002:aa7:9d0d:0:b0:50d:4fcc:7cb1 with SMTP id k13-20020aa79d0d000000b0050d4fcc7cb1mr23058572pfp.41.1652802180977; Tue, 17 May 2022 08:43:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652802180; cv=none; d=google.com; s=arc-20160816; b=cCV0aJtZGWWk7XMx/4qskRhgF3Gvs4y+ou0NiyD7+Sjp2vqXAyQH91ZN8oNDJ0FtKr II0rsQJKzRArDnDyDTcFp+KWPnXfydgK7evqn7H1tALwmhSOEV8pCPjs/gbyHdaRKFsl QJ69PBY1VRd6XtAb8zM4SCWZfK/7uxfrgU+4BHkwaI4ZULFPltVbFP6UqIAugPCzh2B5 Vsa2YQ4c8hTGZVGeQstaqj4BPOpZrw8mKt+hhSKxJ0YBmVLPwSpr2CLvZL0MfGqwkoCq cnf6hihX9BGXSE3718OudriDRv4vgnf7R4NizWHBBDXQMCKiYk/vBgRU7ZMb+3QbluPV xa6A== 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=pWk//zuevd4uz/9F/IaBvceXIdmDtNXyljsJKyDwTPs=; b=bHvBqXyFFZYkp2rIeQB6eG5HIP5VyFt3qQT6WRm5NncYBImS8b3smYkWzvGwi9FCva z+X5iS9rSIsbh6wUCTqJL046QElEIQNDfnuOaG7h7ek6E+Xv/rYcsZ0ro6s4su7lBCn7 NTuP4q823QEHv8Y2MJbkyBeO7ilqIvt7p6O7EHwa1Eh2IUlbYJ34fz2aOOkLCMNkBvcj vtvQwqdTN+pS/1HW/2J6Ms5ASWAnOvheVHf9gHl1/neW9om3NrVZIG8poG9Jv+SHADXn lJ9BXTEqmoRqK3DjhGUB8S7EJdon1mA/x437RtC30vGINtioMwYrqHYbYqH+P6jdIzs1 Wqgg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=MVec5s8S; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u200-20020a6279d1000000b0050d3c158c04si54785pfc.178.2022.05.17.08.42.48; Tue, 17 May 2022 08:43:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=MVec5s8S; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244785AbiEQK2w (ORCPT + 99 others); Tue, 17 May 2022 06:28:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35530 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344021AbiEQK2g (ORCPT ); Tue, 17 May 2022 06:28:36 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6A1B11CA; Tue, 17 May 2022 03:28:34 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 668F86156A; Tue, 17 May 2022 10:28:34 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 051A2C385B8; Tue, 17 May 2022 10:28:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1652783313; bh=H2A/jFCSJ+xqg/vLvKvV+fIaM4AAIUyg7v6zsd4rM1w=; h=From:To:Cc:Subject:Date:From; b=MVec5s8SsX0DJYpVL/N/V8VBrlI5FY37E7huj+UgAVGxd0+S32Uua80uV1J/sy0k4 nMmyjfLihqiqdR68b1JgghbEyVamhtq5bGfZDnmfvKKmhciUD6OnZ0VyULnZKNE03o zo/brvn3lTXUTtJ3LQimulPHSHbIAtWP9beMemKEKeJqQ4Qv6U7a1Nq4hdGS2lyJ+H BWW3Pa0l+PZR6a4rFX8h0VC5dB3u+gIOg9eLXGq+qYizGBKJ2+DaPY53BcNdk5hXAq dd01Qshgfe5JU2CH6XQ9ViU+AQjzMkoz9wv/8iYyNXodhoVbFR1XNuHMn32HqPdZP1 KZ+qjzVsmUIbA== From: Miguel Ojeda To: Greg Kroah-Hartman Cc: rust-for-linux@vger.kernel.org, Arnd Bergmann , Masahiro Yamada , Li Li , linux-kernel@vger.kernel.org, Miguel Ojeda , Wedson Almeida Filho Subject: [PATCH v2] binder: convert `BINDER_*` ioctl `#define`s into an `enum` Date: Tue, 17 May 2022 12:28:13 +0200 Message-Id: <20220517102813.10310-1-ojeda@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.2 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org bindgen (a tool which generates the "raw" C bindings for Rust) only works (so far) with "simple" C `#define`s. In order to avoid having to manually maintain these constants in the (potential) Rust side, this patch converts them into an `enum`. There may be support in the future for expanding macros that end up in a "numeric" one: https://github.com/rust-lang/rust-bindgen/issues/753. Link: https://lore.kernel.org/lkml/YoIK2l6xbQMPGZHy@kroah.com/ Co-developed-by: Wedson Almeida Filho Signed-off-by: Wedson Almeida Filho Signed-off-by: Miguel Ojeda --- v2: - Rebased on top of Greg's char-misc-next. - Added Link tag for future reference. v1: https://lore.kernel.org/lkml/20220516100401.7639-1-ojeda@kernel.org/ include/uapi/linux/android/binder.h | 30 +++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/include/uapi/linux/android/binder.h b/include/uapi/linux/android/binder.h index e6ee8cae303b..a4c3e750168a 100644 --- a/include/uapi/linux/android/binder.h +++ b/include/uapi/linux/android/binder.h @@ -251,20 +251,22 @@ struct binder_extended_error { __s32 param; }; -#define BINDER_WRITE_READ _IOWR('b', 1, struct binder_write_read) -#define BINDER_SET_IDLE_TIMEOUT _IOW('b', 3, __s64) -#define BINDER_SET_MAX_THREADS _IOW('b', 5, __u32) -#define BINDER_SET_IDLE_PRIORITY _IOW('b', 6, __s32) -#define BINDER_SET_CONTEXT_MGR _IOW('b', 7, __s32) -#define BINDER_THREAD_EXIT _IOW('b', 8, __s32) -#define BINDER_VERSION _IOWR('b', 9, struct binder_version) -#define BINDER_GET_NODE_DEBUG_INFO _IOWR('b', 11, struct binder_node_debug_info) -#define BINDER_GET_NODE_INFO_FOR_REF _IOWR('b', 12, struct binder_node_info_for_ref) -#define BINDER_SET_CONTEXT_MGR_EXT _IOW('b', 13, struct flat_binder_object) -#define BINDER_FREEZE _IOW('b', 14, struct binder_freeze_info) -#define BINDER_GET_FROZEN_INFO _IOWR('b', 15, struct binder_frozen_status_info) -#define BINDER_ENABLE_ONEWAY_SPAM_DETECTION _IOW('b', 16, __u32) -#define BINDER_GET_EXTENDED_ERROR _IOWR('b', 17, struct binder_extended_error) +enum { + BINDER_WRITE_READ = _IOWR('b', 1, struct binder_write_read), + BINDER_SET_IDLE_TIMEOUT = _IOW('b', 3, __s64), + BINDER_SET_MAX_THREADS = _IOW('b', 5, __u32), + BINDER_SET_IDLE_PRIORITY = _IOW('b', 6, __s32), + BINDER_SET_CONTEXT_MGR = _IOW('b', 7, __s32), + BINDER_THREAD_EXIT = _IOW('b', 8, __s32), + BINDER_VERSION = _IOWR('b', 9, struct binder_version), + BINDER_GET_NODE_DEBUG_INFO = _IOWR('b', 11, struct binder_node_debug_info), + BINDER_GET_NODE_INFO_FOR_REF = _IOWR('b', 12, struct binder_node_info_for_ref), + BINDER_SET_CONTEXT_MGR_EXT = _IOW('b', 13, struct flat_binder_object), + BINDER_FREEZE = _IOW('b', 14, struct binder_freeze_info), + BINDER_GET_FROZEN_INFO = _IOWR('b', 15, struct binder_frozen_status_info), + BINDER_ENABLE_ONEWAY_SPAM_DETECTION = _IOW('b', 16, __u32), + BINDER_GET_EXTENDED_ERROR = _IOWR('b', 17, struct binder_extended_error), +}; /* * NOTE: Two special error codes you should check for when calling base-commit: 33a1c6618677fe33f8e84cb7bedc45abbce89a50 -- 2.36.1