From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on inbox.vuxu.org X-Spam-Level: X-Spam-Status: No, score=-3.3 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, MAILING_LIST_MULTI,RCVD_IN_DNSWL_MED,RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL autolearn=ham autolearn_force=no version=3.4.4 Received: (qmail 22354 invoked from network); 19 Jan 2021 22:03:15 -0000 Received: from mother.openwall.net (195.42.179.200) by inbox.vuxu.org with ESMTPUTF8; 19 Jan 2021 22:03:15 -0000 Received: (qmail 20040 invoked by uid 550); 19 Jan 2021 22:03:13 -0000 Mailing-List: contact musl-help@lists.openwall.com; run by ezmlm Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-ID: Reply-To: musl@lists.openwall.com Received: (qmail 20022 invoked from network); 19 Jan 2021 22:03:13 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=notion-se.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=4XbBFXWrsCWUVSKSwUxXUwfuXN0WADAZdgdXDKCn+ic=; b=kpSiuQ1gnJRYd0omIfkN90o52vN6H3DDGouPWk1Zviy12OdHUXfmivn9g4gVKU8JJn kjatvW24ziGAWega63q08A7ip53aT5UbbFW4W24logAiMp4w889EB+6fpiagxB26ub0T MCVhydwaPJd3piQxZ7J3arhuX7U7m80Izl6aKf5Rb2HoH7X8l/Tcsf8EXyNC4BMXH46f 6H7i71VARRvtDGEIU6zBS0/JT/OqD5FvZTC1dafrVap3Ra254gcsW4cVEfb+H5BX/mdC PX5igKazBzIDMrjQRq3Y7we7hjpnZHDhR9CfI/C1c4+aK6Th6SGkg6Nx8icJV8GIx97B kyyg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=4XbBFXWrsCWUVSKSwUxXUwfuXN0WADAZdgdXDKCn+ic=; b=lBO7mZNQI2L/bxh3vmTg9S+dVd/CBdcRfLRvj86hhrcn2mHfYv0Q7Ukl71ErxunKXp MJDdBBvObEnFZXNKIlEQu+CTgWsFJ0w1yPR17GEew5n7AJtuJkSXxIztfxEl8ghJTqwu f68785rgNeI9m8lpN/aOtVUFNOo18i7bgYD1OEdU1OGNZ5xrk3GJ5Zvf0fwRIYJgE3Qu O4ou2aR7dgplMKq2ccKdVYZkReQhyDClEuouYmzILBDrT6zV3h2WDPbp3E6/88L96WH7 S/S54oci7J5Q+++vHVv52++nxJ0/ovLeUamMYTBi/9BKRo5HuZH7jHjfgiUr6h4CqlL/ NXfg== X-Gm-Message-State: AOAM531HSMUGFqpa4LdLL7d8lbW1rKneP+3MAr/8KTmMaY3AkknlWD+X dluxf1r0VztrZgsMITH0Oc8j8IwRvsIVAZJBZCyhVw== X-Google-Smtp-Source: ABdhPJwEFbuM1Y1XPKIaSP/UNrO/4JQNiVGD9vNbSgbbw+nmMnz8o8TVttMUWi4LFO53lQi2q/7XYwMG+9TAPT3WXzo= X-Received: by 2002:a17:90b:358d:: with SMTP id mm13mr1971112pjb.146.1611093780970; Tue, 19 Jan 2021 14:03:00 -0800 (PST) MIME-Version: 1.0 References: <20210119193337.GB2006@voyager> <20210119211653.GK23432@brightrain.aerifal.cx> In-Reply-To: From: Rasmus Andersson Date: Tue, 19 Jan 2021 14:02:50 -0800 Message-ID: To: Rich Felker Cc: musl@lists.openwall.com Content-Type: text/plain; charset="UTF-8" Subject: Re: [musl] waitpid (wait4) on Linux 5 returns invalid values The program compiles correctly with https://more.musl.cc/9/x86_64-linux-musl/x86_64-linux-musl-native.tgz (The GCC 9 version) Perhaps an issue with GCC 10? On Tue, Jan 19, 2021 at 2:00 PM Rasmus Andersson wrote: > > That was compiled using > https://more.musl.cc/10/x86_64-linux-musl/x86_64-linux-musl-native.tgz > on Alpine Linux in a docker container (alpine:3.12) > > Full repro: > $ wget https://more.musl.cc/10/x86_64-linux-musl/x86_64-linux-musl-native.tgz > $ tar -xf x86_64-linux-musl-native.tgz > $ cat << EOF > a.c > #include > #include > #include > #include > int main(int argc, char **argv) { > int wstat = 0; > pid_t child = waitpid(-1, &wstat, WNOHANG); > printf("waitpid returned %d, wstat=%d, errno=%d (%s)\n", child, > wstat, errno, strerror(errno)); > return 0; > } > EOF > $ x86_64-linux-musl-native/bin/gcc -static a.c > $ ./a.out > waitpid returned -10, wstat=0, errno=0 (No error information) > > On Tue, Jan 19, 2021 at 1:16 PM Rich Felker wrote: > > > > On Tue, Jan 19, 2021 at 12:35:26PM -0800, Rasmus Andersson wrote: > > > Relevant parts from disassembly: (objdump --disassemble --source > > > --line-numbers a.out) > > > > > > 0000000000401f61 <__syscall_cp_c>: > > > sccp(): > > > 401f61: 48 89 f8 mov %rdi,%rax > > > 401f64: 4d 89 c2 mov %r8,%r10 > > > 401f67: 48 89 f7 mov %rsi,%rdi > > > 401f6a: 4d 89 c8 mov %r9,%r8 > > > 401f6d: 48 89 d6 mov %rdx,%rsi > > > 401f70: 4c 8b 4c 24 08 mov 0x8(%rsp),%r9 > > > 401f75: 48 89 ca mov %rcx,%rdx > > > 401f78: 0f 05 syscall > > > 401f7a: c3 retq > > > > > > 0000000000401f7b <__syscall_cp>: > > > __syscall_cp(): > > > 401f7b: e9 e1 ff ff ff jmpq 401f61 <__syscall_cp_c> > > > > > > 00000000004004fd : > > > waitpid(): > > > ... > > > 40051a: e8 5c 1a 00 00 callq 401f7b <__syscall_cp> > > > 40051f: 48 83 c4 18 add $0x18,%rsp > > > 400523: c3 retq > > > > This disassembly shows a miscompiled (or compiled with wrong patches) > > waitpid. It should be a tail call to __syscall_ret, not a retq. > > > > Rich