Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp189574iog; Tue, 28 Jun 2022 20:09:05 -0700 (PDT) X-Google-Smtp-Source: AGRyM1t/vB1yfCe/v4LWEfU2h7y0b/OWAr5+3TUKSxg1NNC9owlPoITvvGDesmOzLnqHUBK3Dvyh X-Received: by 2002:a17:903:22cc:b0:16a:612e:7962 with SMTP id y12-20020a17090322cc00b0016a612e7962mr7010378plg.134.1656472144850; Tue, 28 Jun 2022 20:09:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1656472144; cv=none; d=google.com; s=arc-20160816; b=QS0cVCPJOr+al2XgaHlZpFq+tBH8jYvwcNLRCscWfM6Ojx5j/qbae0RuGIeWSB4GW1 SxMRLPklLcrzBYPgvCo/ckzfuvh1QLK2qDCXfk4wCWgm4e8eP0UpmFeR4UjtsWDXwIHv H3lO8DrFF2c14v55bxLWcJrd4AOvQJCvvFlmyb9FmZYwOy3SQxnA6H9L2N2WT1C4JlL6 p/UTjIpcf0Zg9jzMRiUrMzh3yLncuW/JvvW5mlK/7RQcLSNDNQxX1v5kSQJTlEowqWfY GfHrvELxr0Cz2BR4Jss9UZnY/uD/j4eBE/AZVfsH5xw6/poQYuMNDE4s8EPwBKsxQkK6 4/AA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=9GERcdaVd7KnJ50tj6wcHwK5gzZyC8SKn3EK1wPimSU=; b=c7/QsytBjb3s4HiE532ZCuQlLLL1fRX4OnoKicKTtqIEbsS7/ckSRyW80tsfO5Sdeu MUPskyzdGCp5smMJEPPLR4xctX1C+5h2xd7wYXHBEcxiMID1n450ysO5Ta2Awv4BMmv+ DV5oEHV7zQ+0EDZ4hZq5fVknWB93pzQ0TupNqmhJ2KcXmGsKa/7oC2YIeyZN5H6lfUsn JYqx9Z40jBKhAVgLQm28h9L6m74sVgMQFccIXcDdYzVl/SmO7nQZeOf2kjHkKuqt2q1Y +tZ9dcuOC59xMSI6egjeCjA/RZnt/XbOVUhGfOg9UkoKImDOpBtAlhiSvbIsflt8irA5 3yDA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id oo11-20020a17090b1c8b00b001e8927db60bsi2538487pjb.73.2022.06.28.20.08.51; Tue, 28 Jun 2022 20:09:04 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230128AbiF2CmR (ORCPT + 99 others); Tue, 28 Jun 2022 22:42:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49560 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229568AbiF2CmQ (ORCPT ); Tue, 28 Jun 2022 22:42:16 -0400 Received: from mail.nfschina.com (unknown [IPv6:2400:dd01:100f:2:72e2:84ff:fe10:5f45]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 0B3C71FCD9; Tue, 28 Jun 2022 19:42:14 -0700 (PDT) Received: from localhost (unknown [127.0.0.1]) by mail.nfschina.com (Postfix) with ESMTP id 7E9661E80D11; Wed, 29 Jun 2022 10:41:05 +0800 (CST) X-Virus-Scanned: amavisd-new at test.com Received: from mail.nfschina.com ([127.0.0.1]) by localhost (mail.nfschina.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id KkPVWUOZtBJR; Wed, 29 Jun 2022 10:41:02 +0800 (CST) Received: from localhost.localdomain (unknown [219.141.250.2]) (Authenticated sender: kunyu@nfschina.com) by mail.nfschina.com (Postfix) with ESMTPA id A51DF1E80CDC; Wed, 29 Jun 2022 10:41:02 +0800 (CST) From: Li kunyu To: skhan@linuxfoundation.org Cc: kunyu@nfschina.com, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, shuah@kernel.org Subject: Re: [PATCH] tools: Strong conversion of void type pointer could be removed Date: Wed, 29 Jun 2022 10:42:06 +0800 Message-Id: <20220629024207.6523-1-kunyu@nfschina.com> X-Mailer: git-send-email 2.18.2 In-Reply-To: <9b587975-db5b-c7bf-eb8f-bd6e5c3d9f54@linuxfoundation.org> References: <9b587975-db5b-c7bf-eb8f-bd6e5c3d9f54@linuxfoundation.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.1 required=5.0 tests=BAYES_00,RDNS_NONE, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 Hi Shuah, now I can't paste the test code, so I could write a demo and paste it: -------------source--------------- #include #include struct ucontext { struct ucontext *uc_link; unsigned long uc_flags; sigset_t uc_sigmask; struct ucontext *uc_mcontext; }; typedef struct ucontext ucontext_t; void sigsegv(void *ctx_void) { ucontext_t *ctx = (ucontext_t*)ctx_void; ucontext_t *ctx2 = (int *)ctx_void; ucontext_t *ctx3 = ctx_void; printf("ctx:%p, ctx2:%p, ctx3:%p.\n", ctx, ctx2, ctx3); } int main() { ucontext_t *test = malloc(sizeof(ucontext_t)); sigsegv(test); return 0; } -------------------------------------- The result is CTX: 0x563D96CE5010, CTX2:0x563D96CE5010, CTx3:0x563D96CE5010. Now force ucontext_t and int pointers are the same as the addresses obtained without forced conversion. Now I'll paste the assembly code for them: |0x700 push %rbp │ │0x701 mov %rsp,%rbp │ │0x704 sub $0x30,%rsp │ │0x708 mov %rdi,-0x28(%rbp) │ │0x70c mov -0x28(%rbp),%rax │ │0x710 mov %rax,-0x8(%rbp) │ │0x714 mov -0x28(%rbp),%rax │ │0x718 mov %rax,-0x10(%rbp) │ │0x71c mov -0x28(%rbp),%rax │ │0x720 mov %rax,-0x18(%rbp) │ │0x724 mov -0x18(%rbp),%rcx │ │0x728 mov -0x10(%rbp),%rdx │ │0x72c mov -0x8(%rbp),%rax │ │0x730 mov %rax,%rsi │ │0x733 lea 0xba(%rip),%rdi # 0x7f4 │ │0x73a mov $0x0,%eax │ │0x73f callq 0x5a0 │ │0x744 nop │ │0x745 leaveq │ │0x746 retq