linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [linux-next:master 6386/7397] mm/swap_state.c:256:46: error: 'SWAP_ADDRESS_SPACE_MASK' undeclared
@ 2024-06-21  9:53 kernel test robot
  2024-06-21 12:44 ` Philip Li
  0 siblings, 1 reply; 2+ messages in thread
From: kernel test robot @ 2024-06-21  9:53 UTC (permalink / raw)
  To: Kairui Song
  Cc: oe-kbuild-all, Linux Memory Management List, Andrew Morton, Huang, Ying

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git master
head:   b992b79ca8bc336fa8e2c80990b5af80ed8f36fd
commit: 23c593d8220af52504cff1d99fbd39ab56a02c82 [6386/7397] mm/swap: reduce swap cache search space
config: x86_64-randconfig-014-20240202 (https://download.01.org/0day-ci/archive/20240621/202406211750.Ks4k82Gi-lkp@intel.com/config)
compiler: gcc-13 (Ubuntu 13.2.0-4ubuntu3) 13.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20240621/202406211750.Ks4k82Gi-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/202406211750.Ks4k82Gi-lkp@intel.com/

All errors (new ones prefixed by >>):

   mm/swap_state.c:65:6: error: redefinition of 'show_swap_cache_info'
      65 | void show_swap_cache_info(void)
         |      ^~~~~~~~~~~~~~~~~~~~
   In file included from mm/swap_state.c:27:
   mm/swap.h:104:20: note: previous definition of 'show_swap_cache_info' with type 'void(void)'
     104 | static inline void show_swap_cache_info(void)
         |                    ^~~~~~~~~~~~~~~~~~~~
   mm/swap_state.c:72:7: error: redefinition of 'get_shadow_from_swap_cache'
      72 | void *get_shadow_from_swap_cache(swp_entry_t entry)
         |       ^~~~~~~~~~~~~~~~~~~~~~~~~~
   mm/swap.h:147:21: note: previous definition of 'get_shadow_from_swap_cache' with type 'void *(swp_entry_t)'
     147 | static inline void *get_shadow_from_swap_cache(swp_entry_t entry)
         |                     ^~~~~~~~~~~~~~~~~~~~~~~~~~
   mm/swap_state.c:88:5: error: redefinition of 'add_to_swap_cache'
      88 | int add_to_swap_cache(struct folio *folio, swp_entry_t entry,
         |     ^~~~~~~~~~~~~~~~~
   mm/swap.h:152:19: note: previous definition of 'add_to_swap_cache' with type 'int(struct folio *, swp_entry_t,  gfp_t,  void **)' {aka 'int(struct folio *, swp_entry_t,  unsigned int,  void **)'}
     152 | static inline int add_to_swap_cache(struct folio *folio, swp_entry_t entry,
         |                   ^~~~~~~~~~~~~~~~~
   mm/swap_state.c: In function 'add_to_swap_cache':
   mm/swap_state.c:124:48: error: 'NR_SWAPCACHE' undeclared (first use in this function)
     124 |                 __lruvec_stat_mod_folio(folio, NR_SWAPCACHE, nr);
         |                                                ^~~~~~~~~~~~
   mm/swap_state.c:124:48: note: each undeclared identifier is reported only once for each function it appears in
   mm/swap_state.c: At top level:
   mm/swap_state.c:141:6: error: redefinition of '__delete_from_swap_cache'
     141 | void __delete_from_swap_cache(struct folio *folio,
         |      ^~~~~~~~~~~~~~~~~~~~~~~~
   mm/swap.h:158:20: note: previous definition of '__delete_from_swap_cache' with type 'void(struct folio *, swp_entry_t,  void *)'
     158 | static inline void __delete_from_swap_cache(struct folio *folio,
         |                    ^~~~~~~~~~~~~~~~~~~~~~~~
   mm/swap_state.c: In function '__delete_from_swap_cache':
   mm/swap_state.c:165:40: error: 'NR_SWAPCACHE' undeclared (first use in this function)
     165 |         __lruvec_stat_mod_folio(folio, NR_SWAPCACHE, -nr);
         |                                        ^~~~~~~~~~~~
   mm/swap_state.c: At top level:
   mm/swap_state.c:178:6: error: redefinition of 'add_to_swap'
     178 | bool add_to_swap(struct folio *folio)
         |      ^~~~~~~~~~~
   mm/swap.h:142:20: note: previous definition of 'add_to_swap' with type 'bool(struct folio *)' {aka '_Bool(struct folio *)'}
     142 | static inline bool add_to_swap(struct folio *folio)
         |                    ^~~~~~~~~~~
   mm/swap_state.c:235:6: error: redefinition of 'delete_from_swap_cache'
     235 | void delete_from_swap_cache(struct folio *folio)
         |      ^~~~~~~~~~~~~~~~~~~~~~
   mm/swap.h:163:20: note: previous definition of 'delete_from_swap_cache' with type 'void(struct folio *)'
     163 | static inline void delete_from_swap_cache(struct folio *folio)
         |                    ^~~~~~~~~~~~~~~~~~~~~~
   mm/swap_state.c:248:6: error: redefinition of 'clear_shadow_from_swap_cache'
     248 | void clear_shadow_from_swap_cache(int type, unsigned long begin,
         |      ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
   mm/swap.h:167:20: note: previous definition of 'clear_shadow_from_swap_cache' with type 'void(int,  long unsigned int,  long unsigned int)'
     167 | static inline void clear_shadow_from_swap_cache(int type, unsigned long begin,
         |                    ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
   mm/swap_state.c: In function 'clear_shadow_from_swap_cache':
>> mm/swap_state.c:256:46: error: 'SWAP_ADDRESS_SPACE_MASK' undeclared (first use in this function)
     256 |                 unsigned long index = curr & SWAP_ADDRESS_SPACE_MASK;
         |                                              ^~~~~~~~~~~~~~~~~~~~~~~
   In file included from include/linux/list_lru.h:14,
                    from include/linux/fs.h:13,
                    from include/linux/huge_mm.h:8,
                    from include/linux/mm.h:1120,
                    from mm/swap_state.c:10:
   mm/swap_state.c:263:67: error: 'SWAP_ADDRESS_SPACE_PAGES' undeclared (first use in this function)
     263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
         |                                                                   ^~~~~~~~~~~~~~~~~~~~~~~~
   include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
    1799 |         for (entry = xas_find(xas, max); entry; \
         |                                    ^~~
   include/linux/minmax.h:56:31: note: in expansion of macro '__is_constexpr'
      56 |         __builtin_choose_expr(__is_constexpr((x) - (y)),        \
         |                               ^~~~~~~~~~~~~~
   include/linux/minmax.h:85:25: note: in expansion of macro '__careful_cmp'
      85 | #define min(x, y)       __careful_cmp(min, x, y)
         |                         ^~~~~~~~~~~~~
   mm/swap_state.c:263:41: note: in expansion of macro 'min'
     263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
         |                                         ^~~
   include/linux/minmax.h:31:9: error: first argument to '__builtin_choose_expr' not a constant
      31 |         __builtin_choose_expr(__is_constexpr(is_signed_type(typeof(x))),        \
         |         ^~~~~~~~~~~~~~~~~~~~~
   include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
    1799 |         for (entry = xas_find(xas, max); entry; \
         |                                    ^~~
   include/linux/build_bug.h:77:34: note: in expansion of macro '__static_assert'
      77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
         |                                  ^~~~~~~~~~~~~~~
   include/linux/minmax.h:51:9: note: in expansion of macro 'static_assert'
      51 |         static_assert(__types_ok(x, y),                 \
         |         ^~~~~~~~~~~~~
   include/linux/minmax.h:39:28: note: in expansion of macro '__is_signed'
      39 |         (__is_signed(x) == __is_signed(y) ||                    \
         |                            ^~~~~~~~~~~
   include/linux/minmax.h:51:23: note: in expansion of macro '__types_ok'
      51 |         static_assert(__types_ok(x, y),                 \
         |                       ^~~~~~~~~~
   include/linux/minmax.h:58:17: note: in expansion of macro '__cmp_once'
      58 |                 __cmp_once(op, x, y, __UNIQUE_ID(__x), __UNIQUE_ID(__y)))
         |                 ^~~~~~~~~~
   include/linux/minmax.h:85:25: note: in expansion of macro '__careful_cmp'
      85 | #define min(x, y)       __careful_cmp(min, x, y)
         |                         ^~~~~~~~~~~~~
   mm/swap_state.c:263:41: note: in expansion of macro 'min'
     263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
         |                                         ^~~
   include/linux/minmax.h:31:9: error: first argument to '__builtin_choose_expr' not a constant
      31 |         __builtin_choose_expr(__is_constexpr(is_signed_type(typeof(x))),        \
         |         ^~~~~~~~~~~~~~~~~~~~~
   include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
    1799 |         for (entry = xas_find(xas, max); entry; \
         |                                    ^~~
   include/linux/build_bug.h:77:34: note: in expansion of macro '__static_assert'
      77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
         |                                  ^~~~~~~~~~~~~~~
   include/linux/minmax.h:51:9: note: in expansion of macro 'static_assert'
      51 |         static_assert(__types_ok(x, y),                 \
         |         ^~~~~~~~~~~~~
   include/linux/minmax.h:40:41: note: in expansion of macro '__is_signed'
      40 |                 __is_signed((x) + 0) == __is_signed((y) + 0) || \
         |                                         ^~~~~~~~~~~
   include/linux/minmax.h:51:23: note: in expansion of macro '__types_ok'
      51 |         static_assert(__types_ok(x, y),                 \
         |                       ^~~~~~~~~~
   include/linux/minmax.h:58:17: note: in expansion of macro '__cmp_once'
      58 |                 __cmp_once(op, x, y, __UNIQUE_ID(__x), __UNIQUE_ID(__y)))
         |                 ^~~~~~~~~~
   include/linux/minmax.h:85:25: note: in expansion of macro '__careful_cmp'
      85 | #define min(x, y)       __careful_cmp(min, x, y)
         |                         ^~~~~~~~~~~~~
   mm/swap_state.c:263:41: note: in expansion of macro 'min'
     263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
         |                                         ^~~
   include/linux/minmax.h:31:9: error: first argument to '__builtin_choose_expr' not a constant
      31 |         __builtin_choose_expr(__is_constexpr(is_signed_type(typeof(x))),        \
         |         ^~~~~~~~~~~~~~~~~~~~~
   include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
    1799 |         for (entry = xas_find(xas, max); entry; \
         |                                    ^~~
   include/linux/build_bug.h:77:34: note: in expansion of macro '__static_assert'
      77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
         |                                  ^~~~~~~~~~~~~~~
   include/linux/minmax.h:51:9: note: in expansion of macro 'static_assert'
      51 |         static_assert(__types_ok(x, y),                 \
         |         ^~~~~~~~~~~~~
   include/linux/minmax.h:36:53: note: in expansion of macro '__is_signed'
      36 |         (__builtin_choose_expr(__is_constexpr(x) && __is_signed(x), x, -1) >= 0)
         |                                                     ^~~~~~~~~~~
   include/linux/minmax.h:41:38: note: in expansion of macro '__is_noneg_int'
      41 |                 __is_noneg_int(x) || __is_noneg_int(y))
         |                                      ^~~~~~~~~~~~~~
   include/linux/minmax.h:51:23: note: in expansion of macro '__types_ok'
      51 |         static_assert(__types_ok(x, y),                 \
         |                       ^~~~~~~~~~
   include/linux/minmax.h:58:17: note: in expansion of macro '__cmp_once'
      58 |                 __cmp_once(op, x, y, __UNIQUE_ID(__x), __UNIQUE_ID(__y)))
         |                 ^~~~~~~~~~


vim +/SWAP_ADDRESS_SPACE_MASK +256 mm/swap_state.c

   247	
   248	void clear_shadow_from_swap_cache(int type, unsigned long begin,
   249					unsigned long end)
   250	{
   251		unsigned long curr = begin;
   252		void *old;
   253	
   254		for (;;) {
   255			swp_entry_t entry = swp_entry(type, curr);
 > 256			unsigned long index = curr & SWAP_ADDRESS_SPACE_MASK;
   257			struct address_space *address_space = swap_address_space(entry);
   258			XA_STATE(xas, &address_space->i_pages, index);
   259	
   260			xas_set_update(&xas, workingset_update_node);
   261	
   262			xa_lock_irq(&address_space->i_pages);
   263			xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
   264				if (!xa_is_value(old))
   265					continue;
   266				xas_store(&xas, NULL);
   267			}
   268			xa_unlock_irq(&address_space->i_pages);
   269	
   270			/* search the next swapcache until we meet end */
   271			curr >>= SWAP_ADDRESS_SPACE_SHIFT;
   272			curr++;
   273			curr <<= SWAP_ADDRESS_SPACE_SHIFT;
   274			if (curr > end)
   275				break;
   276		}
   277	}
   278	

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


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [linux-next:master 6386/7397] mm/swap_state.c:256:46: error: 'SWAP_ADDRESS_SPACE_MASK' undeclared
  2024-06-21  9:53 [linux-next:master 6386/7397] mm/swap_state.c:256:46: error: 'SWAP_ADDRESS_SPACE_MASK' undeclared kernel test robot
@ 2024-06-21 12:44 ` Philip Li
  0 siblings, 0 replies; 2+ messages in thread
From: Philip Li @ 2024-06-21 12:44 UTC (permalink / raw)
  To: kernel test robot
  Cc: Kairui Song, oe-kbuild-all, Linux Memory Management List,
	Andrew Morton, Huang, Ying

On Fri, Jun 21, 2024 at 05:53:00PM +0800, kernel test robot wrote:
> tree:   https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git master
> head:   b992b79ca8bc336fa8e2c80990b5af80ed8f36fd
> commit: 23c593d8220af52504cff1d99fbd39ab56a02c82 [6386/7397] mm/swap: reduce swap cache search space
> config: x86_64-randconfig-014-20240202 (https://download.01.org/0day-ci/archive/20240621/202406211750.Ks4k82Gi-lkp@intel.com/config)
> compiler: gcc-13 (Ubuntu 13.2.0-4ubuntu3) 13.2.0
> reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20240621/202406211750.Ks4k82Gi-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/202406211750.Ks4k82Gi-lkp@intel.com/
> 
> All errors (new ones prefixed by >>):

Kindly ignore this report, which is a wrong report. We will fix the bot
asap to resolve the issue.

> 
>    mm/swap_state.c:65:6: error: redefinition of 'show_swap_cache_info'
>       65 | void show_swap_cache_info(void)
>          |      ^~~~~~~~~~~~~~~~~~~~
>    In file included from mm/swap_state.c:27:
>    mm/swap.h:104:20: note: previous definition of 'show_swap_cache_info' with type 'void(void)'
>      104 | static inline void show_swap_cache_info(void)
>          |                    ^~~~~~~~~~~~~~~~~~~~
>    mm/swap_state.c:72:7: error: redefinition of 'get_shadow_from_swap_cache'
>       72 | void *get_shadow_from_swap_cache(swp_entry_t entry)
>          |       ^~~~~~~~~~~~~~~~~~~~~~~~~~
>    mm/swap.h:147:21: note: previous definition of 'get_shadow_from_swap_cache' with type 'void *(swp_entry_t)'
>      147 | static inline void *get_shadow_from_swap_cache(swp_entry_t entry)
>          |                     ^~~~~~~~~~~~~~~~~~~~~~~~~~
>    mm/swap_state.c:88:5: error: redefinition of 'add_to_swap_cache'
>       88 | int add_to_swap_cache(struct folio *folio, swp_entry_t entry,
>          |     ^~~~~~~~~~~~~~~~~
>    mm/swap.h:152:19: note: previous definition of 'add_to_swap_cache' with type 'int(struct folio *, swp_entry_t,  gfp_t,  void **)' {aka 'int(struct folio *, swp_entry_t,  unsigned int,  void **)'}
>      152 | static inline int add_to_swap_cache(struct folio *folio, swp_entry_t entry,
>          |                   ^~~~~~~~~~~~~~~~~
>    mm/swap_state.c: In function 'add_to_swap_cache':
>    mm/swap_state.c:124:48: error: 'NR_SWAPCACHE' undeclared (first use in this function)
>      124 |                 __lruvec_stat_mod_folio(folio, NR_SWAPCACHE, nr);
>          |                                                ^~~~~~~~~~~~
>    mm/swap_state.c:124:48: note: each undeclared identifier is reported only once for each function it appears in
>    mm/swap_state.c: At top level:
>    mm/swap_state.c:141:6: error: redefinition of '__delete_from_swap_cache'
>      141 | void __delete_from_swap_cache(struct folio *folio,
>          |      ^~~~~~~~~~~~~~~~~~~~~~~~
>    mm/swap.h:158:20: note: previous definition of '__delete_from_swap_cache' with type 'void(struct folio *, swp_entry_t,  void *)'
>      158 | static inline void __delete_from_swap_cache(struct folio *folio,
>          |                    ^~~~~~~~~~~~~~~~~~~~~~~~
>    mm/swap_state.c: In function '__delete_from_swap_cache':
>    mm/swap_state.c:165:40: error: 'NR_SWAPCACHE' undeclared (first use in this function)
>      165 |         __lruvec_stat_mod_folio(folio, NR_SWAPCACHE, -nr);
>          |                                        ^~~~~~~~~~~~
>    mm/swap_state.c: At top level:
>    mm/swap_state.c:178:6: error: redefinition of 'add_to_swap'
>      178 | bool add_to_swap(struct folio *folio)
>          |      ^~~~~~~~~~~
>    mm/swap.h:142:20: note: previous definition of 'add_to_swap' with type 'bool(struct folio *)' {aka '_Bool(struct folio *)'}
>      142 | static inline bool add_to_swap(struct folio *folio)
>          |                    ^~~~~~~~~~~
>    mm/swap_state.c:235:6: error: redefinition of 'delete_from_swap_cache'
>      235 | void delete_from_swap_cache(struct folio *folio)
>          |      ^~~~~~~~~~~~~~~~~~~~~~
>    mm/swap.h:163:20: note: previous definition of 'delete_from_swap_cache' with type 'void(struct folio *)'
>      163 | static inline void delete_from_swap_cache(struct folio *folio)
>          |                    ^~~~~~~~~~~~~~~~~~~~~~
>    mm/swap_state.c:248:6: error: redefinition of 'clear_shadow_from_swap_cache'
>      248 | void clear_shadow_from_swap_cache(int type, unsigned long begin,
>          |      ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
>    mm/swap.h:167:20: note: previous definition of 'clear_shadow_from_swap_cache' with type 'void(int,  long unsigned int,  long unsigned int)'
>      167 | static inline void clear_shadow_from_swap_cache(int type, unsigned long begin,
>          |                    ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
>    mm/swap_state.c: In function 'clear_shadow_from_swap_cache':
> >> mm/swap_state.c:256:46: error: 'SWAP_ADDRESS_SPACE_MASK' undeclared (first use in this function)
>      256 |                 unsigned long index = curr & SWAP_ADDRESS_SPACE_MASK;
>          |                                              ^~~~~~~~~~~~~~~~~~~~~~~
>    In file included from include/linux/list_lru.h:14,
>                     from include/linux/fs.h:13,
>                     from include/linux/huge_mm.h:8,
>                     from include/linux/mm.h:1120,
>                     from mm/swap_state.c:10:
>    mm/swap_state.c:263:67: error: 'SWAP_ADDRESS_SPACE_PAGES' undeclared (first use in this function)
>      263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
>          |                                                                   ^~~~~~~~~~~~~~~~~~~~~~~~
>    include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
>     1799 |         for (entry = xas_find(xas, max); entry; \
>          |                                    ^~~
>    include/linux/minmax.h:56:31: note: in expansion of macro '__is_constexpr'
>       56 |         __builtin_choose_expr(__is_constexpr((x) - (y)),        \
>          |                               ^~~~~~~~~~~~~~
>    include/linux/minmax.h:85:25: note: in expansion of macro '__careful_cmp'
>       85 | #define min(x, y)       __careful_cmp(min, x, y)
>          |                         ^~~~~~~~~~~~~
>    mm/swap_state.c:263:41: note: in expansion of macro 'min'
>      263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
>          |                                         ^~~
>    include/linux/minmax.h:31:9: error: first argument to '__builtin_choose_expr' not a constant
>       31 |         __builtin_choose_expr(__is_constexpr(is_signed_type(typeof(x))),        \
>          |         ^~~~~~~~~~~~~~~~~~~~~
>    include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
>     1799 |         for (entry = xas_find(xas, max); entry; \
>          |                                    ^~~
>    include/linux/build_bug.h:77:34: note: in expansion of macro '__static_assert'
>       77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
>          |                                  ^~~~~~~~~~~~~~~
>    include/linux/minmax.h:51:9: note: in expansion of macro 'static_assert'
>       51 |         static_assert(__types_ok(x, y),                 \
>          |         ^~~~~~~~~~~~~
>    include/linux/minmax.h:39:28: note: in expansion of macro '__is_signed'
>       39 |         (__is_signed(x) == __is_signed(y) ||                    \
>          |                            ^~~~~~~~~~~
>    include/linux/minmax.h:51:23: note: in expansion of macro '__types_ok'
>       51 |         static_assert(__types_ok(x, y),                 \
>          |                       ^~~~~~~~~~
>    include/linux/minmax.h:58:17: note: in expansion of macro '__cmp_once'
>       58 |                 __cmp_once(op, x, y, __UNIQUE_ID(__x), __UNIQUE_ID(__y)))
>          |                 ^~~~~~~~~~
>    include/linux/minmax.h:85:25: note: in expansion of macro '__careful_cmp'
>       85 | #define min(x, y)       __careful_cmp(min, x, y)
>          |                         ^~~~~~~~~~~~~
>    mm/swap_state.c:263:41: note: in expansion of macro 'min'
>      263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
>          |                                         ^~~
>    include/linux/minmax.h:31:9: error: first argument to '__builtin_choose_expr' not a constant
>       31 |         __builtin_choose_expr(__is_constexpr(is_signed_type(typeof(x))),        \
>          |         ^~~~~~~~~~~~~~~~~~~~~
>    include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
>     1799 |         for (entry = xas_find(xas, max); entry; \
>          |                                    ^~~
>    include/linux/build_bug.h:77:34: note: in expansion of macro '__static_assert'
>       77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
>          |                                  ^~~~~~~~~~~~~~~
>    include/linux/minmax.h:51:9: note: in expansion of macro 'static_assert'
>       51 |         static_assert(__types_ok(x, y),                 \
>          |         ^~~~~~~~~~~~~
>    include/linux/minmax.h:40:41: note: in expansion of macro '__is_signed'
>       40 |                 __is_signed((x) + 0) == __is_signed((y) + 0) || \
>          |                                         ^~~~~~~~~~~
>    include/linux/minmax.h:51:23: note: in expansion of macro '__types_ok'
>       51 |         static_assert(__types_ok(x, y),                 \
>          |                       ^~~~~~~~~~
>    include/linux/minmax.h:58:17: note: in expansion of macro '__cmp_once'
>       58 |                 __cmp_once(op, x, y, __UNIQUE_ID(__x), __UNIQUE_ID(__y)))
>          |                 ^~~~~~~~~~
>    include/linux/minmax.h:85:25: note: in expansion of macro '__careful_cmp'
>       85 | #define min(x, y)       __careful_cmp(min, x, y)
>          |                         ^~~~~~~~~~~~~
>    mm/swap_state.c:263:41: note: in expansion of macro 'min'
>      263 |                 xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
>          |                                         ^~~
>    include/linux/minmax.h:31:9: error: first argument to '__builtin_choose_expr' not a constant
>       31 |         __builtin_choose_expr(__is_constexpr(is_signed_type(typeof(x))),        \
>          |         ^~~~~~~~~~~~~~~~~~~~~
>    include/linux/xarray.h:1799:36: note: in definition of macro 'xas_for_each'
>     1799 |         for (entry = xas_find(xas, max); entry; \
>          |                                    ^~~
>    include/linux/build_bug.h:77:34: note: in expansion of macro '__static_assert'
>       77 | #define static_assert(expr, ...) __static_assert(expr, ##__VA_ARGS__, #expr)
>          |                                  ^~~~~~~~~~~~~~~
>    include/linux/minmax.h:51:9: note: in expansion of macro 'static_assert'
>       51 |         static_assert(__types_ok(x, y),                 \
>          |         ^~~~~~~~~~~~~
>    include/linux/minmax.h:36:53: note: in expansion of macro '__is_signed'
>       36 |         (__builtin_choose_expr(__is_constexpr(x) && __is_signed(x), x, -1) >= 0)
>          |                                                     ^~~~~~~~~~~
>    include/linux/minmax.h:41:38: note: in expansion of macro '__is_noneg_int'
>       41 |                 __is_noneg_int(x) || __is_noneg_int(y))
>          |                                      ^~~~~~~~~~~~~~
>    include/linux/minmax.h:51:23: note: in expansion of macro '__types_ok'
>       51 |         static_assert(__types_ok(x, y),                 \
>          |                       ^~~~~~~~~~
>    include/linux/minmax.h:58:17: note: in expansion of macro '__cmp_once'
>       58 |                 __cmp_once(op, x, y, __UNIQUE_ID(__x), __UNIQUE_ID(__y)))
>          |                 ^~~~~~~~~~
> 
> 
> vim +/SWAP_ADDRESS_SPACE_MASK +256 mm/swap_state.c
> 
>    247	
>    248	void clear_shadow_from_swap_cache(int type, unsigned long begin,
>    249					unsigned long end)
>    250	{
>    251		unsigned long curr = begin;
>    252		void *old;
>    253	
>    254		for (;;) {
>    255			swp_entry_t entry = swp_entry(type, curr);
>  > 256			unsigned long index = curr & SWAP_ADDRESS_SPACE_MASK;
>    257			struct address_space *address_space = swap_address_space(entry);
>    258			XA_STATE(xas, &address_space->i_pages, index);
>    259	
>    260			xas_set_update(&xas, workingset_update_node);
>    261	
>    262			xa_lock_irq(&address_space->i_pages);
>    263			xas_for_each(&xas, old, min(index + (end - curr), SWAP_ADDRESS_SPACE_PAGES)) {
>    264				if (!xa_is_value(old))
>    265					continue;
>    266				xas_store(&xas, NULL);
>    267			}
>    268			xa_unlock_irq(&address_space->i_pages);
>    269	
>    270			/* search the next swapcache until we meet end */
>    271			curr >>= SWAP_ADDRESS_SPACE_SHIFT;
>    272			curr++;
>    273			curr <<= SWAP_ADDRESS_SPACE_SHIFT;
>    274			if (curr > end)
>    275				break;
>    276		}
>    277	}
>    278	
> 
> -- 
> 0-DAY CI Kernel Test Service
> https://github.com/intel/lkp-tests/wiki
> 


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2024-06-21 12:44 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-06-21  9:53 [linux-next:master 6386/7397] mm/swap_state.c:256:46: error: 'SWAP_ADDRESS_SPACE_MASK' undeclared kernel test robot
2024-06-21 12:44 ` Philip Li

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox