Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp6473692rwl; Mon, 9 Jan 2023 08:46:34 -0800 (PST) X-Google-Smtp-Source: AMrXdXs9/hi3wp3rSLBeEsOFoWhX89xDfd6jIEtB6VxFoHQrQVc9dQogTK+zEFKTRM6tHKHD+0Cd X-Received: by 2002:a17:903:2447:b0:191:1a7c:ef9f with SMTP id l7-20020a170903244700b001911a7cef9fmr95786151pls.1.1673282794172; Mon, 09 Jan 2023 08:46:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673282794; cv=none; d=google.com; s=arc-20160816; b=oTEzF6AA+vnMdWWW8B5N6s+ougkjEQLTPHckDW5ZDJw7TlYRiP6LvuSqUEFdUabWbu fXviOAtYkxhNonKYf53u0BVhTNslwyB57FqNEexTwPYo9tmF+VGLQQGK/0eC2b1AIjAw 8lRh/RHtUdJT1QFWN1HEFWS/C5Dd/KeI9c8Ejph1NVZXRWFAQBPz/6Vb4Qv8+sn8Ncv6 Qlcb/gNBbMxDtAntVAcB4pBmA6OuPg6bd+npEFoyuIo7AQPFpWrL+KR+u0Z5WjJCMWFP lqe7gKOmEWUfBZhssDyKQVn85p640PghQlTY8gHLu1ht1lOG4+/cBkCHpQkld9KtOxAH EYkg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :organization:from:references:cc:to:content-language:subject :user-agent:mime-version:date:message-id:dkim-signature; bh=W9uCN3VQ3btzl2FPuIbtk5ZKyJr6zz6N2a76k393fHs=; b=r/5lsmFeMUx5ny+44zx3uD9AQpDGLM8CT31kQwdtMOADR0sGK2VQD5Rez2qn1PdgcB +zkxlcLUyBj/NhSrHrnnRgvS7HKOuthbcRtxIMYByPvSIqytYLZ+aJUjWoOo2SsfmEtU SCMUjAm1At9Y7Wc7WB1aNcnw+t6+EPG+GZg9Drk4U5g5a2z7bkFGmjibvtew6PE/WXqJ srRuIMl2iJAypqq3TDfKRdaRldgCPGJ4furJ+LpWtkPQB7YLj4GyrRDLnFrcgRoZacrY QDu4TP3/x2IUj6yCjoB1tmjvHvNrc/iCXizXTL+uW/qnaxXMpu02v6tH0h7hA4Ll7Syk SzWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=GkJNql7u; 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=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y68-20020a633247000000b00478ea44f124si9922189pgy.96.2023.01.09.08.46.27; Mon, 09 Jan 2023 08:46:34 -0800 (PST) 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=@redhat.com header.s=mimecast20190719 header.b=GkJNql7u; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234178AbjAIQnS (ORCPT + 53 others); Mon, 9 Jan 2023 11:43:18 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38702 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229648AbjAIQnP (ORCPT ); Mon, 9 Jan 2023 11:43:15 -0500 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F14AFE0DC for ; Mon, 9 Jan 2023 08:42:31 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1673282551; h=from:from:reply-to:subject:subject: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=W9uCN3VQ3btzl2FPuIbtk5ZKyJr6zz6N2a76k393fHs=; b=GkJNql7uZofLDWZLQFlXKGDzy7WneGTRdfzFdMRbO0MtJwizJ8h1bsOad2zG3Tz8PQ5pzS bruNT0rinbgT3Dx6uwzXCPg6SRJaSrBXTlPTlmDZ73axsrVMS3jtqGGbJAOYaSkfJYmwny vxO9jOY+OiyDrPsM6pQ95AXU4IqHb3g= Received: from mail-wr1-f71.google.com (mail-wr1-f71.google.com [209.85.221.71]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_128_GCM_SHA256) id us-mta-645-l8RW4Z23McWdIu0DZy3BCg-1; Mon, 09 Jan 2023 11:42:27 -0500 X-MC-Unique: l8RW4Z23McWdIu0DZy3BCg-1 Received: by mail-wr1-f71.google.com with SMTP id r10-20020adfa14a000000b0025ba73dff40so1418530wrr.12 for ; Mon, 09 Jan 2023 08:42:27 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:organization:from:references :cc:to:content-language:subject:user-agent:mime-version:date :message-id:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=W9uCN3VQ3btzl2FPuIbtk5ZKyJr6zz6N2a76k393fHs=; b=1jcKt5bIJQg9Lq9eoKxX/Lemn+LZJHcYr9u67Hire8/rr3nDspm8EjuKcACM88cOHT F1bbFe9elQPG/WuCpiHVjxrY7710yjYgmctHf+LBKQNNn6IzaZMzn4NvEzD7Uw1KqMAZ mgHR26WwZI/6vZJ/mFEN7SpaswRXL+jOVAzXQYCfmRbwC2axGQH7D2eULXEsgpXTYtjn t0FO3e2rT1NTQAUZbRsqFT1FNnGyjHlh5bdm30Owu4O8FlEm8EgCJCJM2SzjBl6oFrJx UXcGEBc64qrLIMjahhK2FeIOH42WYfzRM3J5Uu0OWLqiU8rGPNGq+mykXg8HShdbl9jf EtEQ== X-Gm-Message-State: AFqh2krujTeHgYXCwgnUDhyNKeNuP9uUH2oPSgdhPn0EZByqJnYh/qZO ocWLDr+WczRk+hBOg9y6kS5xsHBP/fsEZ2D6uRwbLSH9E+nPfnphlS86Sq5xKVeMalUgOQ9gBnA cINQ+yHSXACRuosObaztXAFNO X-Received: by 2002:adf:f402:0:b0:270:c07e:56 with SMTP id g2-20020adff402000000b00270c07e0056mr35801395wro.53.1673282546793; Mon, 09 Jan 2023 08:42:26 -0800 (PST) X-Received: by 2002:adf:f402:0:b0:270:c07e:56 with SMTP id g2-20020adff402000000b00270c07e0056mr35801381wro.53.1673282546464; Mon, 09 Jan 2023 08:42:26 -0800 (PST) Received: from ?IPV6:2003:cb:c703:8f00:ba3:7d27:204f:8e29? (p200300cbc7038f000ba37d27204f8e29.dip0.t-ipconnect.de. [2003:cb:c703:8f00:ba3:7d27:204f:8e29]) by smtp.gmail.com with ESMTPSA id z2-20020a5d6402000000b00297dcfdc90fsm8954756wru.24.2023.01.09.08.42.25 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 09 Jan 2023 08:42:26 -0800 (PST) Message-ID: <0ee389dc-5e47-5b7e-4db5-637eb2b3fbc9@redhat.com> Date: Mon, 9 Jan 2023 17:42:25 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.6.0 Subject: =?UTF-8?Q?Re=3a_PROBLEM=3a_selftest/vm/cow=2ec_failed_to_compile_?= =?UTF-8?B?KOKAmE1BRFZfUEFHRU9VVOKAmSB1bmRlY2xhcmVkKQ==?= Content-Language: en-US To: Mirsad Goran Todorovac , linux-mm@kvack.org Cc: Andrew Morton , Shuah Khan , linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org References: <0f117203-3227-cd16-61c2-2dd3de75ecc7@alu.unizg.hr> From: David Hildenbrand Organization: Red Hat In-Reply-To: <0f117203-3227-cd16-61c2-2dd3de75ecc7@alu.unizg.hr> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=unavailable 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 08.01.23 11:58, Mirsad Goran Todorovac wrote: > Hi all, > > During "make kselftest" there is an error in selftest/vm/cow.c compilation on > platform: > > - Lenovo desktop 10TX000VCR (LENOVO_MT_10TX_BU_Lenovo_FM_V530S-07ICB) > - AlmaLinux 8.7 (CentOS fork) > - gcc 8.5.0 20210514 (Red Hat 8.5.0-15) > - vanilla kernel 6.2-rc2 from the torvalds mainline tree. > > Compilation fails to find "#define MADV_PAGEOUT": > > [root@pc-mtodorov vm]# make > gcc -Wall -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../.. -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -isystem /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -no-pie cow.c vm_util.c -lrt -lpthread -o /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm/cow > cow.c: In function ‘do_run_with_base_page’: > cow.c:755:26: error: ‘MADV_PAGEOUT’ undeclared (first use in this function); did you mean ‘MADV_RANDOM’? > madvise(mem, pagesize, MADV_PAGEOUT); > ^~~~~~~~~~~~ > MADV_RANDOM > cow.c:755:26: note: each undeclared identifier is reported only once for each function it appears in > cow.c: In function ‘do_run_with_thp’: > cow.c:914:22: error: ‘MADV_PAGEOUT’ undeclared (first use in this function); did you mean ‘MADV_RANDOM’? > madvise(mem, size, MADV_PAGEOUT); > ^~~~~~~~~~~~ > MADV_RANDOM > make: *** [../lib.mk:145: /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm/cow] Error 1 > [root@pc-mtodorov vm]# > > MADV_PAGEOUT is defined in #include : > > [root@pc-mtodorov vm]# grep MADV_PAGEOUT -r /usr/include > /usr/include/asm-generic/mman-common.h:#define MADV_PAGEOUT 21 /* reclaim these pages */ > [root@pc-mtodorov vm]# grep MADV_PAGEOUT -r ../../../../usr/include > ../../../../usr/include/asm-generic/mman-common.h:#define MADV_PAGEOUT 21 /* reclaim these pages */ > [root@pc-mtodorov vm]# > > However, gcc -E shows that asm-generic/mman-common.h is somehow never included: > > --------------------------------------------------------------------------------------------- > [root@pc-mtodorov vm]# gcc -Wall -E -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../.. -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -isystem /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -no-pie cow.c | cat -s | less > # 1 "/usr/include/sys/mman.h" 1 3 4 > # 25 "/usr/include/sys/mman.h" 3 4 > # 1 "/usr/lib/gcc/x86_64-redhat-linux/8/include/stddef.h" 1 3 4 > # 26 "/usr/include/sys/mman.h" 2 3 4 > # 41 "/usr/include/sys/mman.h" 3 4 > # 1 "/usr/include/bits/mman.h" 1 3 4 > # 49 "/usr/include/bits/mman.h" 3 4 > # 1 "/usr/include/bits/mman-linux.h" 1 3 4 > # 117 "/usr/include/bits/mman-linux.h" 3 4 > # 1 "/usr/include/bits/mman-shared.h" 1 3 4 > # 42 "/usr/include/bits/mman-shared.h" 3 4 > > int memfd_create (const char *__name, unsigned int __flags) __attribute__ ((__nothrow__ , __leaf__)); > int mlock2 (const void *__addr, size_t __length, unsigned int __flags) __attribute__ ((__nothrow__ , __leaf__)); > int pkey_alloc (unsigned int __flags, unsigned int __access_rights) __attribute__ ((__nothrow__ , __leaf__)); > int pkey_set (int __key, unsigned int __access_rights) __attribute__ ((__nothrow__ , __leaf__)); > int pkey_get (int __key) __attribute__ ((__nothrow__ , __leaf__)); > int pkey_free (int __key) __attribute__ ((__nothrow__ , __leaf__)); > int pkey_mprotect (void *__addr, size_t __len, int __prot, int __pkey) __attribute__ ((__nothrow__ , __leaf__)); > > # 117 "/usr/include/bits/mman-linux.h" 2 3 4 > # 49 "/usr/include/bits/mman.h" 2 3 4 > # 42 "/usr/include/sys/mman.h" 2 3 4 > > # 57 "/usr/include/sys/mman.h" 3 4 > extern void *mmap (void *__addr, size_t __len, int __prot, > int __flags, int __fd, __off_t __offset) __attribute__ ((__nothrow__ , __leaf__)); > # 70 "/usr/include/sys/mman.h" 3 4 > extern void *mmap64 (void *__addr, size_t __len, int __prot, > int __flags, int __fd, __off64_t __offset) __attribute__ ((__nothrow__ , __leaf__)); > > extern int munmap (void *__addr, size_t __len) __attribute__ ((__nothrow__ , __leaf__)); > extern int mprotect (void *__addr, size_t __len, int __prot) __attribute__ ((__nothrow__ , __leaf__)); > extern int msync (void *__addr, size_t __len, int __flags); > extern int madvise (void *__addr, size_t __len, int __advice) __attribute__ ((__nothrow__ , __leaf__)); > extern int posix_madvise (void *__addr, size_t __len, int __advice) __attribute__ ((__nothrow__ , __leaf__)); > extern int mlock (const void *__addr, size_t __len) __attribute__ ((__nothrow__ , __leaf__)); > extern int munlock (const void *__addr, size_t __len) __attribute__ ((__nothrow__ , __leaf__)); > extern int mlockall (int __flags) __attribute__ ((__nothrow__ , __leaf__)); > extern int munlockall (void) __attribute__ ((__nothrow__ , __leaf__)); > extern int mincore (void *__start, size_t __len, unsigned char *__vec) > __attribute__ ((__nothrow__ , __leaf__)); > > # 133 "/usr/include/sys/mman.h" 3 4 > > extern void *mremap (void *__addr, size_t __old_len, size_t __new_len, > int __flags, ...) __attribute__ ((__nothrow__ , __leaf__)); > extern int remap_file_pages (void *__start, size_t __size, int __prot, > size_t __pgoff, int __flags) __attribute__ ((__nothrow__ , __leaf__)); > extern int shm_open (const char *__name, int __oflag, mode_t __mode); > extern int shm_unlink (const char *__name); > ------------------------------------------------------------------------------------------------------- > > FYI: > > On the platform: > > - Ubuntu 22.10 kinetic kudu > - gcc 12.2.0 > - same 6.2-rc2 > > , MADV_PAGEOUT is also defined in bits/mmap-linux.h, so the compile passes. > > root@marvin-IdeaPad-3-15ITL6:/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm# grep MADV_PAGEOUT -r /usr/include > /usr/include/asm-generic/mman-common.h:#define MADV_PAGEOUT 21 /* reclaim these pages */ > /usr/include/x86_64-linux-gnu/bits/mman-linux.h:# define MADV_PAGEOUT 21 /* Reclaim these pages. */ > root@marvin-IdeaPad-3-15ITL6:/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm# grep MADV_PAGEOUT -r ../../../../usr/include > ../../../../usr/include/asm-generic/mman-common.h:#define MADV_PAGEOUT 21 /* reclaim these pages */ > root@marvin-IdeaPad-3-15ITL6:/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm# > > However, mman-common.h from ../../../../usr/include/asm-generic/mman-common.h is also not included, > as of "gcc -E", but only bits/mman-linux.h: > > root@marvin-IdeaPad-3-15ITL6:/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm# gcc -Wall -E -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../.. -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -isystem /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -no-pie cow.c | grep mman-common.h > root@marvin-IdeaPad-3-15ITL6:/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm# gcc -Wall -E -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../.. -I /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -isystem /home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/../../../usr/include -no-pie cow.c | grep mman-linux.h > # 1 "/usr/include/x86_64-linux-gnu/bits/mman-linux.h" 1 3 4 > # 119 "/usr/include/x86_64-linux-gnu/bits/mman-linux.h" 3 4 > # 120 "/usr/include/x86_64-linux-gnu/bits/mman-linux.h" 2 3 4 > root@marvin-IdeaPad-3-15ITL6:/home/marvin/linux/kernel/linux_torvalds/tools/testing/selftests/vm# > > I hope this is enough information for you to debug the issue. > > I am standing by for any additional diagnostics needed. Won't userfaultfd.c fail in a similar way? Anyhow, khugepaged.c jas #ifndef MADV_PAGEOUT #define MADV_PAGEOUT 21 #endif So most probably we should do the same. -- Thanks, David / dhildenb