Received: by 2002:a05:6358:7058:b0:131:369:b2a3 with SMTP id 24csp748513rwp; Wed, 12 Jul 2023 23:43:08 -0700 (PDT) X-Google-Smtp-Source: APBJJlEVMUgFsTaGDV86VvZ7F5A2QcfoW+CR+Rsrbsk3fHWiXudwUGQvTRmjVdlmfNSuRvLt/O3s X-Received: by 2002:a17:906:dfd8:b0:994:1eb4:689b with SMTP id jt24-20020a170906dfd800b009941eb4689bmr480774ejc.74.1689230587803; Wed, 12 Jul 2023 23:43:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689230587; cv=none; d=google.com; s=arc-20160816; b=Teks2Kr8X/tjI55YFiGc8SxXZkMmgOBD6/SPBwD0e1aRPCNIndKy0ja3yE7Ws8iZAE A3vojR5uNWSBm5NNZ9MrlXePwWVGimGfMNc30HNFbkMJ8MS0dT+pz45YzMddMQRlhlRi 7CtfRKgyZ5dkx7ier2ULRB4eUU8q49PZYms3/stAoA21rcS0ttMVZBGmI3I+BTRp5wx1 subJwRtjgW71dF83NQhayF7oz2s5DtPZPlYzqzUVirk5RyAJertwQGspyEek9EKf7LFq EmKAnsFmFrHgGbbp5g4ozY+VqorIZoA4Isn0skzVQ3cBWoUE4b415BfRxe13X1qpwlYC /0bA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:feedback-id:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from; bh=sPlkPeRAT7aQrpfWC9NqTAqyQoJiyhICxGAlCoQQy9g=; fh=GpsioFpGwOjkkM/FJljwBhJ/LeC8BdYBcE06RO6Wd9s=; b=XAK0FMgXaLomYYbeasmCqkSVDpB0sTc4Dzm6CRfwUacWvu4ROX9qyAft30IvGngf0d poXX1FBtp+c4mgPsFv3KY2CguMTXt1Cqw8L6g5Gczw4p5CY/Umvsp7aINVzSOMX4MwLC uXfuwrmvjS5c1twRT6nd55kcwdCduc7qv04Eg/6ozCrslHZBUbM1lVve7cOejj9d6hHP V9ox5fYGxQf/ZO3JUXrgFEU1F5S84InFou5htepaJsv9BhnTBr4L34Bt4v3vsGF8nojD BlzmaQJtutQmDQ81KluZhjwGHLod4G2c3jZia5dLI8sdTtJNLc+0O14OjNrVy9CIqmp+ VJHg== 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 gz19-20020a170906f2d300b009891f47b282si6143785ejb.1012.2023.07.12.23.42.43; Wed, 12 Jul 2023 23:43:07 -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 S234028AbjGMGXm (ORCPT + 99 others); Thu, 13 Jul 2023 02:23:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46308 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233395AbjGMGXl (ORCPT ); Thu, 13 Jul 2023 02:23:41 -0400 Received: from bg4.exmail.qq.com (bg4.exmail.qq.com [43.155.65.254]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 25D3EA2; Wed, 12 Jul 2023 23:23:38 -0700 (PDT) X-QQ-mid: bizesmtp90t1689229407tyeq7sbn Received: from linux-lab-host.localdomain ( [116.30.126.249]) by bizesmtp.qq.com (ESMTP) with id ; Thu, 13 Jul 2023 14:23:26 +0800 (CST) X-QQ-SSF: 01200000000000D0W000000A0000000 X-QQ-FEAT: rZJGTgY0+YP0Yb2Mhugqzx/9pFfcXDgUR6jtxy/b41GO/9ar8aFi5CVYyh3tk HQY3Y41lJYWacFnZ3VrwlFMoTn7Y+CZrfoQyw9vtgD6Tl8bu1tFFficldkKEcseGxnnE+WV qZmdFQqA+HgCLXKCbvdmiAmW2mDGqSSQ4QiuERx+8rIZKbQ/2fpdgshw4up4xZfzQOffD0i VnswCJMlT4lVTGPJzSXfjkpAQoBcFQBMcHyUVFDbeeSh7rvAS7BIaijf+/L7jl31dDz0gaS e0VDhoZGd9Po7wDbu60DJuhnSGwsa2AYE5DtlT0aLlTrlH5BRAsH8t0FQvspq1LtM2NRUyS 7XO9t7tRS5/IMjQxMbxrhvG85h8EAyCCxWnYNpcEqv7xaKCoqo= X-QQ-GoodBg: 0 X-BIZMAIL-ID: 4386575556554638218 From: Zhangjin Wu To: falcon@tinylab.org Cc: arnd@arndb.de, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, thomas@t-8ch.de, w@1wt.eu Subject: Re: [PATCH v3 02/11] tools/nolibc: add new crt.h with _start_c Date: Thu, 13 Jul 2023 14:23:26 +0800 Message-Id: <20230713062326.52045-1-falcon@tinylab.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20230713061227.43222-1-falcon@tinylab.org> References: <20230713061227.43222-1-falcon@tinylab.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-QQ-SENDSIZE: 520 Feedback-ID: bizesmtp:tinylab.org:qybglogicsvrgz:qybglogicsvrgz5a-1 X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_NONE, 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 Hi, Thomas > > On 2023-07-12 17:17:39+0800, Zhangjin Wu wrote: > [...] > > > +static void exit(int); > > > + > > > +void _start_c(long *sp) > > > +{ > > > + int argc, i; > > > + char **argv; > > > + char **envp; > > > + /* silence potential warning: conflicting types for 'main' */ > > > + _nolibc_main_fn _nolibc_main __asm__ ("main"); > > > > What about the stackprotector initialization? > > It would really fit great into this series. > > > > Ok, which gcc version supports stackprotector? seems the test even skip > on gcc 10, I will find one to verify the code change. > Thomas, please ignore this question, I forgot some options in my own script. Best regards, Zhangjin > > > + > > > + /* > > > + * sp : argc <-- argument count, required by main() > > > + * argv: argv[0] <-- argument vector, required by main() > > > + * argv[1] > > > + * ... > > > + * argv[argc-1] > > > + * null > > > + * envp: envp[0] <-- environment variables, required by main() and getenv() > > > + * envp[1] > > > + * ... > > > + * null > > > + * _auxv: auxv[0] <-- auxiliary vector, required by getauxval() > > > + * auxv[1] > > > + * ... > > > + * null > > > + */ > > > + > > > + /* assign argc and argv */ > > > + argc = sp[0]; > > > + argv = (void *)(sp + 1); > > > > Bit of a weird mismatch between array syntax and pointer arithmetic. > >