linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
From: kernel test robot <lkp@intel.com>
To: alexs@kernel.org, Vitaly Wool <vitaly.wool@konsulko.com>,
	Miaohe Lin <linmiaohe@huawei.com>,
	Andrew Morton <akpm@linux-foundation.org>,
	linux-kernel@vger.kernel.org, minchan@kernel.org,
	willy@infradead.org, senozhatsky@chromium.org, david@redhat.com,
	42.hyeyoo@gmail.com, Yosry Ahmed <yosryahmed@google.com>,
	nphamcs@gmail.com
Cc: llvm@lists.linux.dev, oe-kbuild-all@lists.linux.dev,
	Linux Memory Management List <linux-mm@kvack.org>,
	Alex Shi <alexs@kernel.org>
Subject: Re: [PATCH v2 01/20] mm/zsmalloc: add zpdesc memory descriptor for zswap.zpool
Date: Fri, 5 Jul 2024 21:41:36 +0800	[thread overview]
Message-ID: <202407052121.e5LTYhXc-lkp@intel.com> (raw)
In-Reply-To: <20240703040613.681396-2-alexs@kernel.org>

Hi,

kernel test robot noticed the following build errors:

[auto build test ERROR on akpm-mm/mm-everything]

url:    https://github.com/intel-lab-lkp/linux/commits/alexs-kernel-org/mm-zsmalloc-add-zpdesc-memory-descriptor-for-zswap-zpool/20240703-182314
base:   https://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm.git mm-everything
patch link:    https://lore.kernel.org/r/20240703040613.681396-2-alexs%40kernel.org
patch subject: [PATCH v2 01/20] mm/zsmalloc: add zpdesc memory descriptor for zswap.zpool
config: i386-buildonly-randconfig-004-20240705 (https://download.01.org/0day-ci/archive/20240705/202407052121.e5LTYhXc-lkp@intel.com/config)
compiler: clang version 18.1.5 (https://github.com/llvm/llvm-project 617a15a9eac96088ae5e9134248d8236e34b91b1)
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20240705/202407052121.e5LTYhXc-lkp@intel.com/reproduce)

If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@intel.com>
| Closes: https://lore.kernel.org/oe-kbuild-all/202407052121.e5LTYhXc-lkp@intel.com/

All errors (new ones prefixed by >>):

   In file included from mm/zsmalloc.c:65:
>> mm/zpdesc.h:48:1: error: no member named 'memcg_data' in 'page'
      48 | ZPDESC_MATCH(memcg_data, memcg_data);
         | ^            ~~~~~~~~~~
   mm/zpdesc.h:40:16: note: expanded from macro 'ZPDESC_MATCH'
      40 |         static_assert(offsetof(struct page, pg) == offsetof(struct zpdesc, zp))
         |                       ^                     ~~
   include/linux/stddef.h:16:32: note: expanded from macro 'offsetof'
      16 | #define offsetof(TYPE, MEMBER)  __builtin_offsetof(TYPE, MEMBER)
         |                                 ^                        ~~~~~~
   include/linux/build_bug.h:77:50: note: expanded from macro 'static_assert'
      77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
         |                                                  ^~~~
   include/linux/build_bug.h:78:56: note: expanded from macro '__static_assert'
      78 | #define __static_assert(expr, msg, ...) _Static_assert(expr, msg)
         |                                                        ^~~~
   In file included from mm/zsmalloc.c:65:
>> mm/zpdesc.h:48:1: error: no member named 'memcg_data' in 'zpdesc'
      48 | ZPDESC_MATCH(memcg_data, memcg_data);
         | ^                        ~~~~~~~~~~
   mm/zpdesc.h:40:45: note: expanded from macro 'ZPDESC_MATCH'
      40 |         static_assert(offsetof(struct page, pg) == offsetof(struct zpdesc, zp))
         |                                                    ^                       ~~
   include/linux/stddef.h:16:32: note: expanded from macro 'offsetof'
      16 | #define offsetof(TYPE, MEMBER)  __builtin_offsetof(TYPE, MEMBER)
         |                                 ^                        ~~~~~~
   include/linux/build_bug.h:77:50: note: expanded from macro 'static_assert'
      77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
         |                                                  ^~~~
   include/linux/build_bug.h:78:56: note: expanded from macro '__static_assert'
      78 | #define __static_assert(expr, msg, ...) _Static_assert(expr, msg)
         |                                                        ^~~~
   2 errors generated.


vim +48 mm/zpdesc.h

     9	
    10	/*
    11	 * struct zpdesc -	Memory descriptor for zpool memory, now is for zsmalloc
    12	 * @flags:		Page flags, PG_private: identifies the first component page
    13	 * @lru:		Indirectly used by page migration
    14	 * @mops:		Used by page migration
    15	 * @next:		Next zpdesc in a zspage in zsmalloc zpool
    16	 * @handle:		For huge zspage in zsmalloc zpool
    17	 * @zspage:		Pointer to zspage in zsmalloc
    18	 * @memcg_data:		Memory Control Group data.
    19	 *
    20	 * This struct overlays struct page for now. Do not modify without a good
    21	 * understanding of the issues.
    22	 */
    23	struct zpdesc {
    24		unsigned long flags;
    25		struct list_head lru;
    26		struct movable_operations *mops;
    27		union {
    28			/* Next zpdescs in a zspage in zsmalloc zpool */
    29			struct zpdesc *next;
    30			/* For huge zspage in zsmalloc zpool */
    31			unsigned long handle;
    32		};
    33		struct zspage *zspage;
    34		unsigned long _zp_pad_1;
    35	#ifdef CONFIG_SLAB_OBJ_EXT
    36		unsigned long memcg_data;
    37	#endif
    38	};
    39	#define ZPDESC_MATCH(pg, zp) \
    40		static_assert(offsetof(struct page, pg) == offsetof(struct zpdesc, zp))
    41	
    42	ZPDESC_MATCH(flags, flags);
    43	ZPDESC_MATCH(lru, lru);
    44	ZPDESC_MATCH(mapping, mops);
    45	ZPDESC_MATCH(index, next);
    46	ZPDESC_MATCH(index, handle);
    47	ZPDESC_MATCH(private, zspage);
  > 48	ZPDESC_MATCH(memcg_data, memcg_data);
    49	#undef ZPDESC_MATCH
    50	static_assert(sizeof(struct zpdesc) <= sizeof(struct page));
    51	

-- 
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki


  reply	other threads:[~2024-07-05 13:41 UTC|newest]

Thread overview: 25+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-07-03  4:05 [PATCH v2 00/20] " alexs
2024-07-03  4:05 ` [PATCH v2 01/20] " alexs
2024-07-05 13:41   ` kernel test robot [this message]
2024-07-05 14:02   ` kernel test robot
2024-07-03  4:05 ` [PATCH v2 02/20] mm/zsmalloc: use zpdesc in trylock_zspage/lock_zspage alexs
2024-07-03  4:05 ` [PATCH v2 03/20] mm/zsmalloc: convert __zs_map_object/__zs_unmap_object to use zpdesc alexs
2024-07-03  4:05 ` [PATCH v2 04/20] mm/zsmalloc: add and use pfn/zpdesc seeking funcs alexs
2024-07-03  4:05 ` [PATCH v2 05/20] mm/zsmalloc: convert obj_malloc() to use zpdesc alexs
2024-07-03  4:05 ` [PATCH v2 06/20] mm/zsmalloc: convert create_page_chain() and its users " alexs
2024-07-03  4:05 ` [PATCH v2 07/20] mm/zsmalloc: convert obj_allocated() and related helpers " alexs
2024-07-03  4:05 ` [PATCH v2 08/20] mm/zsmalloc: convert init_zspage() " alexs
2024-07-03  4:05 ` [PATCH v2 09/20] mm/zsmalloc: convert obj_to_page() and zs_free() " alexs
2024-07-03  4:06 ` [PATCH v2 10/20] mm/zsmalloc: add zpdesc_is_isolated/zpdesc_zone helper for zs_page_migrate alexs
2024-07-03  4:06 ` [PATCH v2 11/20] mm/zsmalloc: rename reset_page to reset_zpdesc and use zpdesc in it alexs
2024-07-03  4:06 ` [PATCH v2 12/20] mm/zsmalloc: convert __free_zspage() to use zdsesc alexs
2024-07-03  4:06 ` [PATCH v2 13/20] mm/zsmalloc: convert location_to_obj() to take zpdesc alexs
2024-07-03  4:06 ` [PATCH v2 14/20] mm/zsmalloc: convert migrate_zspage() to use zpdesc alexs
2024-07-03  4:06 ` [PATCH v2 15/20] mm/zsmalloc: convert get_zspage() to take zpdesc alexs
2024-07-03  4:06 ` [PATCH v2 16/20] mm/zsmalloc: convert SetZsPageMovable and remove unused funcs alexs
2024-07-03  4:06 ` [PATCH v2 17/20] mm/zsmalloc: convert get/set_first_obj_offset() to take zpdesc alexs
2024-07-05 14:43   ` kernel test robot
2024-07-05 17:15     ` Nathan Chancellor
2024-07-03  4:06 ` [PATCH v2 18/20] mm/zsmalloc: introduce __zpdesc_clear_movable alexs
2024-07-03  4:06 ` [PATCH v2 19/20] mm/zsmalloc: introduce __zpdesc_clear_zsmalloc alexs
2024-07-03  4:06 ` [PATCH v2 20/20] mm/zsmalloc: introduce __zpdesc_set_zsmalloc() alexs

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=202407052121.e5LTYhXc-lkp@intel.com \
    --to=lkp@intel.com \
    --cc=42.hyeyoo@gmail.com \
    --cc=akpm@linux-foundation.org \
    --cc=alexs@kernel.org \
    --cc=david@redhat.com \
    --cc=linmiaohe@huawei.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mm@kvack.org \
    --cc=llvm@lists.linux.dev \
    --cc=minchan@kernel.org \
    --cc=nphamcs@gmail.com \
    --cc=oe-kbuild-all@lists.linux.dev \
    --cc=senozhatsky@chromium.org \
    --cc=vitaly.wool@konsulko.com \
    --cc=willy@infradead.org \
    --cc=yosryahmed@google.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox