Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4446683rwd; Tue, 30 May 2023 05:41:46 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4XsR/JjV4Cxbe6YA7NVvRjahk/eJytAbBbf3CDjf9FYHd/KkQSXhFntgfrGfDeayxW6Die X-Received: by 2002:a17:903:2352:b0:1a2:a904:c42e with SMTP id c18-20020a170903235200b001a2a904c42emr2651371plh.24.1685450506588; Tue, 30 May 2023 05:41:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1685450506; cv=none; d=google.com; s=arc-20160816; b=iBiqeHHs0nkS5y0DAvo8uLUETOAVz2sWlVMKIaSW6aQcTXy9/8XmGgi39CJKmWCqPf GdllP7RLxxFchhzlEzx0sntGa1GqXibfduWVT5dhV/DfuPRqHPbfb8YLLrnM2eM9YCA6 RYBTUkFlOvObV/BBHIaUSsp9J50MkLlk1P7uRLdM1fveI68E4pqb/lGFw77WTbXGkL5W Hqr6HQ7EHjXjzRt/5wsYWBWZcNCBuqj2nrVM0LzSKwf0p6RlWcq62bSdw50mPDIbmmxi tKn2jm/daaPzuCuTCkZgCjetMsVYkixW/21f/7oXeYMtbedci4Qw3wIl+/uPUO+vyY1Y xSQw== 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 :user-agent:message-id:date:references:in-reply-to:subject:cc:to :from:dkim-signature:dkim-signature; bh=k4r2dKrL0esFEC4r6mNqOb67BdMVIEvOCW/VAhqjUWc=; b=KW+O2FJNWOvAwc+z1ITR8HwFyB8vVEKvaA0lAlHoaeVrvr0DegyHcO8JbFYMr3e1eZ 1ILdFbwVZU6DtxNn+4nfEzQyHmMpCRFuPojgOED0hnTUZ+loZ0vdZE5YHYfX3deyBbuc FNf7xe4gkbwCUmWIM9C3j9+wGVNcPv0nIakE6XZfZFoggAO+EYva5fSiWZta7QMv5J1q ADPQI55c48bCSLcIS1TwaN/lsh3+7UNJQm/HfAETpnrKqffUNec72GgBgo7HltVBPgKw a8mvuN6xpwEyi1nV0ob85JFZJnPVV6DbrJxtX1uXIufSRnufU2XZdrTm9hyMlY2wybR9 PNeA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=h5MmXUfh; dkim=neutral (no key) header.i=@suse.de header.s=susede2_ed25519; 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=suse.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id bb1-20020a170902bc8100b001a0544138b8si1297866plb.395.2023.05.30.05.41.34; Tue, 30 May 2023 05:41:46 -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=@suse.de header.s=susede2_rsa header.b=h5MmXUfh; dkim=neutral (no key) header.i=@suse.de header.s=susede2_ed25519; 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=suse.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232117AbjE3Mda (ORCPT + 99 others); Tue, 30 May 2023 08:33:30 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57982 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232135AbjE3MdO (ORCPT ); Tue, 30 May 2023 08:33:14 -0400 Received: from smtp-out1.suse.de (smtp-out1.suse.de [195.135.220.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 88707E53; Tue, 30 May 2023 05:32:42 -0700 (PDT) Received: from relay2.suse.de (relay2.suse.de [149.44.160.134]) by smtp-out1.suse.de (Postfix) with ESMTP id C5B0121ADF; Tue, 30 May 2023 12:31:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1685449893; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=k4r2dKrL0esFEC4r6mNqOb67BdMVIEvOCW/VAhqjUWc=; b=h5MmXUfhWOwZcrwe7NZWvEHK+/tpbD3lT5ESYjsR/fIPtu0KHvMknKC6cW3VNZ5Ptrf73A RiUbbCXvcUxaLhr/974N3UlCeCE2fWfJkosgaAY6FY4bGoIG0EyQLRKSHjbyFGraUOfq4b hYmHNi5oR+WcaQkUO0odCa4BhJs352E= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1685449893; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=k4r2dKrL0esFEC4r6mNqOb67BdMVIEvOCW/VAhqjUWc=; b=ywPZow5zX5ejCdKMprk/QdgpbZJt1V+/FKo3w6H4WtoQU4el7u8hpvk/rQx1kFoRAHOfjY YB+M+lY49OFM8bAg== Received: from hawking.suse.de (unknown [10.168.4.11]) by relay2.suse.de (Postfix) with ESMTP id 528F92C141; Tue, 30 May 2023 12:31:33 +0000 (UTC) Received: by hawking.suse.de (Postfix, from userid 17005) id 3F3164A037E; Tue, 30 May 2023 14:31:33 +0200 (CEST) From: Andreas Schwab To: Willy Tarreau Cc: Thomas =?utf-8?Q?Wei=C3=9Fschuh?= , Zhangjin Wu , arnd@arndb.de, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-riscv@lists.infradead.org Subject: Re: [PATCH 1/2] selftests/nolibc: add new gettimeofday test cases In-Reply-To: (Willy Tarreau's message of "Tue, 30 May 2023 14:05:00 +0200") References: <96f1134d-ce6e-4d82-ae00-1cd4038809c4@t-8ch.de> X-Yow: I represent a sardine!! Date: Tue, 30 May 2023 14:31:33 +0200 Message-ID: User-Agent: Gnus/5.13 (Gnus v5.13) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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 On Mai 30 2023, Willy Tarreau wrote: > On Tue, May 30, 2023 at 12:59:31PM +0200, Thomas Weißschuh wrote: >> On 2023-05-30 14:37:49+0800, Zhangjin Wu wrote: >> > These 3 test cases are added to cover the normal using scenes of >> > gettimeofday(). >> > >> > They have been used to trigger and fix up such issue: >> > >> > nolibc-test.c:(.text.gettimeofday+0x54): undefined reference to `__aeabi_ldivmod' >> > >> > This issue happens while there is no "unsigned int" conversion in the >> > new clock_gettime / clock_gettime64 syscall path of gettimeofday(): >> > >> > tv->tv_usec = ts.tv_nsec / 1000; >> > >> > Signed-off-by: Zhangjin Wu >> > --- >> > tools/testing/selftests/nolibc/nolibc-test.c | 5 +++++ >> > 1 file changed, 5 insertions(+) >> > >> > diff --git a/tools/testing/selftests/nolibc/nolibc-test.c b/tools/testing/selftests/nolibc/nolibc-test.c >> > index 8ba8c2fc71a0..20d184da9a2b 100644 >> > --- a/tools/testing/selftests/nolibc/nolibc-test.c >> > +++ b/tools/testing/selftests/nolibc/nolibc-test.c >> > @@ -533,6 +533,8 @@ static int test_stat_timestamps(void) >> > */ >> > int run_syscall(int min, int max) >> > { >> > + struct timeval tv; >> > + struct timezone tz; >> > struct stat stat_buf; >> > int euid0; >> > int proc; >> > @@ -588,6 +590,9 @@ int run_syscall(int min, int max) >> > CASE_TEST(getdents64_root); EXPECT_SYSNE(1, test_getdents64("/"), -1); break; >> > CASE_TEST(getdents64_null); EXPECT_SYSER(1, test_getdents64("/dev/null"), -1, ENOTDIR); break; >> > CASE_TEST(gettimeofday_null); EXPECT_SYSZR(1, gettimeofday(NULL, NULL)); break; >> > + CASE_TEST(gettimeofday_tv); EXPECT_SYSZR(1, gettimeofday(&tv, NULL)); break; >> > + CASE_TEST(gettimeofday_tz); EXPECT_SYSZR(1, gettimeofday(NULL, &tz)); break; >> >> Calling gettimeofday(NULL, ...) will actually segfault on glibc. >> It works when calling through the VDSO, but not the logic in glibc >> itself, which is guess is allowed by POSIX. > > Then that's shocking, because the man page says: > > If either tv or tz is NULL, the corresponding structure is not set or > returned. (However, compilation warnings will result if tv is NULL.) > > I'd expect glibc to at least support what'd documented in the man > page :-/ The manual page is not part of glibc. Neither the glibc documentation nor the POSIX spec has ever supported NULL for the first argument. The generic POSIX implementation in glibc originally returned EINVAL for that case, though. -- Andreas Schwab, SUSE Labs, schwab@suse.de GPG Key fingerprint = 0196 BAD8 1CE9 1970 F4BE 1748 E4D4 88E3 0EEA B9D7 "And now for something completely different."