[linux-next:master 5938/6538] mm/zswap.c:1183:6: warning: variable 'ret' is used uninitialized whenever 'if' condition is true

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



tree:   https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git master
head:   571d71e886a5edc89b4ea6d0fe6f445282938320
commit: be23cb8e7a96c4ae97a35cd99f993e98d9bd66a5 [5938/6538] zswap: do not shrink if cgroup may not zswap
config: hexagon-randconfig-r045-20230531 (https://download.01.org/0day-ci/archive/20230601/202306011435.2BxsHFUE-lkp@xxxxxxxxx/config)
compiler: clang version 15.0.4 (https://github.com/llvm/llvm-project 5c68a1cb123161b54b72ce90e7975d95a8eaf2a4)
reproduce (this is a W=1 build):
        mkdir -p ~/bin
        wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross
        chmod +x ~/bin/make.cross
        # https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/?id=be23cb8e7a96c4ae97a35cd99f993e98d9bd66a5
        git remote add linux-next https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
        git fetch --no-tags linux-next master
        git checkout be23cb8e7a96c4ae97a35cd99f993e98d9bd66a5
        # save the config file
        mkdir build_dir && cp config build_dir/.config
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=clang ~/bin/make.cross W=1 O=build_dir ARCH=hexagon olddefconfig
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=clang ~/bin/make.cross W=1 O=build_dir ARCH=hexagon SHELL=/bin/bash

If you fix the issue, kindly add following tag where applicable
| Reported-by: kernel test robot <lkp@xxxxxxxxx>
| Closes: https://lore.kernel.org/oe-kbuild-all/202306011435.2BxsHFUE-lkp@xxxxxxxxx/

All warnings (new ones prefixed by >>):

   In file included from mm/zswap.c:18:
   In file included from include/linux/highmem.h:12:
   In file included from include/linux/hardirq.h:11:
   In file included from ./arch/hexagon/include/generated/asm/hardirq.h:1:
   In file included from include/asm-generic/hardirq.h:17:
   In file included from include/linux/irq.h:20:
   In file included from include/linux/io.h:13:
   In file included from arch/hexagon/include/asm/io.h:334:
   include/asm-generic/io.h:547:31: warning: performing pointer arithmetic on a null pointer has undefined behavior [-Wnull-pointer-arithmetic]
           val = __raw_readb(PCI_IOBASE + addr);
                             ~~~~~~~~~~ ^
   include/asm-generic/io.h:560:61: warning: performing pointer arithmetic on a null pointer has undefined behavior [-Wnull-pointer-arithmetic]
           val = __le16_to_cpu((__le16 __force)__raw_readw(PCI_IOBASE + addr));
                                                           ~~~~~~~~~~ ^
   include/uapi/linux/byteorder/little_endian.h:37:51: note: expanded from macro '__le16_to_cpu'
   #define __le16_to_cpu(x) ((__force __u16)(__le16)(x))
                                                     ^
   In file included from mm/zswap.c:18:
   In file included from include/linux/highmem.h:12:
   In file included from include/linux/hardirq.h:11:
   In file included from ./arch/hexagon/include/generated/asm/hardirq.h:1:
   In file included from include/asm-generic/hardirq.h:17:
   In file included from include/linux/irq.h:20:
   In file included from include/linux/io.h:13:
   In file included from arch/hexagon/include/asm/io.h:334:
   include/asm-generic/io.h:573:61: warning: performing pointer arithmetic on a null pointer has undefined behavior [-Wnull-pointer-arithmetic]
           val = __le32_to_cpu((__le32 __force)__raw_readl(PCI_IOBASE + addr));
                                                           ~~~~~~~~~~ ^
   include/uapi/linux/byteorder/little_endian.h:35:51: note: expanded from macro '__le32_to_cpu'
   #define __le32_to_cpu(x) ((__force __u32)(__le32)(x))
                                                     ^
   In file included from mm/zswap.c:18:
   In file included from include/linux/highmem.h:12:
   In file included from include/linux/hardirq.h:11:
   In file included from ./arch/hexagon/include/generated/asm/hardirq.h:1:
   In file included from include/asm-generic/hardirq.h:17:
   In file included from include/linux/irq.h:20:
   In file included from include/linux/io.h:13:
   In file included from arch/hexagon/include/asm/io.h:334:
   include/asm-generic/io.h:584:33: warning: performing pointer arithmetic on a null pointer has undefined behavior [-Wnull-pointer-arithmetic]
           __raw_writeb(value, PCI_IOBASE + addr);
                               ~~~~~~~~~~ ^
   include/asm-generic/io.h:594:59: warning: performing pointer arithmetic on a null pointer has undefined behavior [-Wnull-pointer-arithmetic]
           __raw_writew((u16 __force)cpu_to_le16(value), PCI_IOBASE + addr);
                                                         ~~~~~~~~~~ ^
   include/asm-generic/io.h:604:59: warning: performing pointer arithmetic on a null pointer has undefined behavior [-Wnull-pointer-arithmetic]
           __raw_writel((u32 __force)cpu_to_le32(value), PCI_IOBASE + addr);
                                                         ~~~~~~~~~~ ^
>> mm/zswap.c:1183:6: warning: variable 'ret' is used uninitialized whenever 'if' condition is true [-Wsometimes-uninitialized]
           if (objcg && !obj_cgroup_may_zswap(objcg))
               ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   mm/zswap.c:1327:9: note: uninitialized use occurs here
           return ret;
                  ^~~
   mm/zswap.c:1183:2: note: remove the 'if' if its condition is always false
           if (objcg && !obj_cgroup_may_zswap(objcg))
           ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   mm/zswap.c:1158:9: note: initialize the variable 'ret' to silence this warning
           int ret;
                  ^
                   = 0
   7 warnings generated.


vim +1183 mm/zswap.c

a85f878b443f8d Srividya Desireddy  2018-01-31  1144  
2b2811178e8555 Seth Jennings       2013-07-10  1145  /*********************************
2b2811178e8555 Seth Jennings       2013-07-10  1146  * frontswap hooks
2b2811178e8555 Seth Jennings       2013-07-10  1147  **********************************/
2b2811178e8555 Seth Jennings       2013-07-10  1148  /* attempts to compress and store an single page */
2b2811178e8555 Seth Jennings       2013-07-10  1149  static int zswap_frontswap_store(unsigned type, pgoff_t offset,
2b2811178e8555 Seth Jennings       2013-07-10  1150  				struct page *page)
2b2811178e8555 Seth Jennings       2013-07-10  1151  {
2b2811178e8555 Seth Jennings       2013-07-10  1152  	struct zswap_tree *tree = zswap_trees[type];
2b2811178e8555 Seth Jennings       2013-07-10  1153  	struct zswap_entry *entry, *dupentry;
1ec3b5fe6eec78 Barry Song          2020-12-14  1154  	struct scatterlist input, output;
1ec3b5fe6eec78 Barry Song          2020-12-14  1155  	struct crypto_acomp_ctx *acomp_ctx;
f4840ccfca25db Johannes Weiner     2022-05-19  1156  	struct obj_cgroup *objcg = NULL;
f4840ccfca25db Johannes Weiner     2022-05-19  1157  	struct zswap_pool *pool;
2b2811178e8555 Seth Jennings       2013-07-10  1158  	int ret;
9c3760eb80880f Yu Zhao             2018-01-31  1159  	unsigned int hlen, dlen = PAGE_SIZE;
a85f878b443f8d Srividya Desireddy  2018-01-31  1160  	unsigned long handle, value;
2b2811178e8555 Seth Jennings       2013-07-10  1161  	char *buf;
2b2811178e8555 Seth Jennings       2013-07-10  1162  	u8 *src, *dst;
9c3760eb80880f Yu Zhao             2018-01-31  1163  	struct zswap_header zhdr = { .swpentry = swp_entry(type, offset) };
d2fcd82bb83aab Hui Zhu             2019-09-23  1164  	gfp_t gfp;
2b2811178e8555 Seth Jennings       2013-07-10  1165  
7ba716698cc53f Huang Ying          2018-02-21  1166  	/* THP isn't supported */
7ba716698cc53f Huang Ying          2018-02-21  1167  	if (PageTransHuge(page)) {
7ba716698cc53f Huang Ying          2018-02-21  1168  		ret = -EINVAL;
7ba716698cc53f Huang Ying          2018-02-21  1169  		goto reject;
7ba716698cc53f Huang Ying          2018-02-21  1170  	}
7ba716698cc53f Huang Ying          2018-02-21  1171  
c00ed16a9eb98a Dan Streetman       2015-06-25  1172  	if (!zswap_enabled || !tree) {
2b2811178e8555 Seth Jennings       2013-07-10  1173  		ret = -ENODEV;
2b2811178e8555 Seth Jennings       2013-07-10  1174  		goto reject;
2b2811178e8555 Seth Jennings       2013-07-10  1175  	}
2b2811178e8555 Seth Jennings       2013-07-10  1176  
be23cb8e7a96c4 Nhat Pham           2023-05-30  1177  	/*
be23cb8e7a96c4 Nhat Pham           2023-05-30  1178  	 * XXX: zswap reclaim does not work with cgroups yet. Without a
be23cb8e7a96c4 Nhat Pham           2023-05-30  1179  	 * cgroup-aware entry LRU, we will push out entries system-wide based on
be23cb8e7a96c4 Nhat Pham           2023-05-30  1180  	 * local cgroup limits.
be23cb8e7a96c4 Nhat Pham           2023-05-30  1181  	 */
f4840ccfca25db Johannes Weiner     2022-05-19  1182  	objcg = get_obj_cgroup_from_page(page);
f4840ccfca25db Johannes Weiner     2022-05-19 @1183  	if (objcg && !obj_cgroup_may_zswap(objcg))
be23cb8e7a96c4 Nhat Pham           2023-05-30  1184  		goto reject;
f4840ccfca25db Johannes Weiner     2022-05-19  1185  
2b2811178e8555 Seth Jennings       2013-07-10  1186  	/* reclaim space if needed */
2b2811178e8555 Seth Jennings       2013-07-10  1187  	if (zswap_is_full()) {
2b2811178e8555 Seth Jennings       2013-07-10  1188  		zswap_pool_limit_hit++;
45190f01dd4021 Vitaly Wool         2020-01-30  1189  		zswap_pool_reached_full = true;
f4840ccfca25db Johannes Weiner     2022-05-19  1190  		goto shrink;
2b2811178e8555 Seth Jennings       2013-07-10  1191  	}
16e536ef47f567 Li Wang             2018-07-26  1192  
45190f01dd4021 Vitaly Wool         2020-01-30  1193  	if (zswap_pool_reached_full) {
45190f01dd4021 Vitaly Wool         2020-01-30  1194  	       if (!zswap_can_accept()) {
16e536ef47f567 Li Wang             2018-07-26  1195  			ret = -ENOMEM;
16e536ef47f567 Li Wang             2018-07-26  1196  			goto reject;
45190f01dd4021 Vitaly Wool         2020-01-30  1197  		} else
45190f01dd4021 Vitaly Wool         2020-01-30  1198  			zswap_pool_reached_full = false;
2b2811178e8555 Seth Jennings       2013-07-10  1199  	}
2b2811178e8555 Seth Jennings       2013-07-10  1200  
2b2811178e8555 Seth Jennings       2013-07-10  1201  	/* allocate entry */
2b2811178e8555 Seth Jennings       2013-07-10  1202  	entry = zswap_entry_cache_alloc(GFP_KERNEL);
2b2811178e8555 Seth Jennings       2013-07-10  1203  	if (!entry) {
2b2811178e8555 Seth Jennings       2013-07-10  1204  		zswap_reject_kmemcache_fail++;
2b2811178e8555 Seth Jennings       2013-07-10  1205  		ret = -ENOMEM;
2b2811178e8555 Seth Jennings       2013-07-10  1206  		goto reject;
2b2811178e8555 Seth Jennings       2013-07-10  1207  	}
2b2811178e8555 Seth Jennings       2013-07-10  1208  
a85f878b443f8d Srividya Desireddy  2018-01-31  1209  	if (zswap_same_filled_pages_enabled) {
a85f878b443f8d Srividya Desireddy  2018-01-31  1210  		src = kmap_atomic(page);
a85f878b443f8d Srividya Desireddy  2018-01-31  1211  		if (zswap_is_page_same_filled(src, &value)) {
a85f878b443f8d Srividya Desireddy  2018-01-31  1212  			kunmap_atomic(src);
a85f878b443f8d Srividya Desireddy  2018-01-31  1213  			entry->offset = offset;
a85f878b443f8d Srividya Desireddy  2018-01-31  1214  			entry->length = 0;
a85f878b443f8d Srividya Desireddy  2018-01-31  1215  			entry->value = value;
a85f878b443f8d Srividya Desireddy  2018-01-31  1216  			atomic_inc(&zswap_same_filled_pages);
a85f878b443f8d Srividya Desireddy  2018-01-31  1217  			goto insert_entry;
a85f878b443f8d Srividya Desireddy  2018-01-31  1218  		}
a85f878b443f8d Srividya Desireddy  2018-01-31  1219  		kunmap_atomic(src);
a85f878b443f8d Srividya Desireddy  2018-01-31  1220  	}
a85f878b443f8d Srividya Desireddy  2018-01-31  1221  
cb325ddde56162 Maciej S. Szmigiero 2022-03-22  1222  	if (!zswap_non_same_filled_pages_enabled) {
cb325ddde56162 Maciej S. Szmigiero 2022-03-22  1223  		ret = -EINVAL;
cb325ddde56162 Maciej S. Szmigiero 2022-03-22  1224  		goto freepage;
cb325ddde56162 Maciej S. Szmigiero 2022-03-22  1225  	}
cb325ddde56162 Maciej S. Szmigiero 2022-03-22  1226  
f1c54846ee4504 Dan Streetman       2015-09-09  1227  	/* if entry is successfully added, it keeps the reference */
f1c54846ee4504 Dan Streetman       2015-09-09  1228  	entry->pool = zswap_pool_current_get();
f1c54846ee4504 Dan Streetman       2015-09-09  1229  	if (!entry->pool) {
f1c54846ee4504 Dan Streetman       2015-09-09  1230  		ret = -EINVAL;
f1c54846ee4504 Dan Streetman       2015-09-09  1231  		goto freepage;
f1c54846ee4504 Dan Streetman       2015-09-09  1232  	}
f1c54846ee4504 Dan Streetman       2015-09-09  1233  
2b2811178e8555 Seth Jennings       2013-07-10  1234  	/* compress */
1ec3b5fe6eec78 Barry Song          2020-12-14  1235  	acomp_ctx = raw_cpu_ptr(entry->pool->acomp_ctx);
1ec3b5fe6eec78 Barry Song          2020-12-14  1236  
1ec3b5fe6eec78 Barry Song          2020-12-14  1237  	mutex_lock(acomp_ctx->mutex);
1ec3b5fe6eec78 Barry Song          2020-12-14  1238  
1ec3b5fe6eec78 Barry Song          2020-12-14  1239  	dst = acomp_ctx->dstmem;
1ec3b5fe6eec78 Barry Song          2020-12-14  1240  	sg_init_table(&input, 1);
1ec3b5fe6eec78 Barry Song          2020-12-14  1241  	sg_set_page(&input, page, PAGE_SIZE, 0);
1ec3b5fe6eec78 Barry Song          2020-12-14  1242  
1ec3b5fe6eec78 Barry Song          2020-12-14  1243  	/* zswap_dstmem is of size (PAGE_SIZE * 2). Reflect same in sg_list */
1ec3b5fe6eec78 Barry Song          2020-12-14  1244  	sg_init_one(&output, dst, PAGE_SIZE * 2);
1ec3b5fe6eec78 Barry Song          2020-12-14  1245  	acomp_request_set_params(acomp_ctx->req, &input, &output, PAGE_SIZE, dlen);
1ec3b5fe6eec78 Barry Song          2020-12-14  1246  	/*
1ec3b5fe6eec78 Barry Song          2020-12-14  1247  	 * it maybe looks a little bit silly that we send an asynchronous request,
1ec3b5fe6eec78 Barry Song          2020-12-14  1248  	 * then wait for its completion synchronously. This makes the process look
1ec3b5fe6eec78 Barry Song          2020-12-14  1249  	 * synchronous in fact.
1ec3b5fe6eec78 Barry Song          2020-12-14  1250  	 * Theoretically, acomp supports users send multiple acomp requests in one
1ec3b5fe6eec78 Barry Song          2020-12-14  1251  	 * acomp instance, then get those requests done simultaneously. but in this
1ec3b5fe6eec78 Barry Song          2020-12-14  1252  	 * case, frontswap actually does store and load page by page, there is no
1ec3b5fe6eec78 Barry Song          2020-12-14  1253  	 * existing method to send the second page before the first page is done
1ec3b5fe6eec78 Barry Song          2020-12-14  1254  	 * in one thread doing frontswap.
1ec3b5fe6eec78 Barry Song          2020-12-14  1255  	 * but in different threads running on different cpu, we have different
1ec3b5fe6eec78 Barry Song          2020-12-14  1256  	 * acomp instance, so multiple threads can do (de)compression in parallel.
1ec3b5fe6eec78 Barry Song          2020-12-14  1257  	 */
1ec3b5fe6eec78 Barry Song          2020-12-14  1258  	ret = crypto_wait_req(crypto_acomp_compress(acomp_ctx->req), &acomp_ctx->wait);
1ec3b5fe6eec78 Barry Song          2020-12-14  1259  	dlen = acomp_ctx->req->dlen;
1ec3b5fe6eec78 Barry Song          2020-12-14  1260  
2b2811178e8555 Seth Jennings       2013-07-10  1261  	if (ret) {
2b2811178e8555 Seth Jennings       2013-07-10  1262  		ret = -EINVAL;
f1c54846ee4504 Dan Streetman       2015-09-09  1263  		goto put_dstmem;
2b2811178e8555 Seth Jennings       2013-07-10  1264  	}
2b2811178e8555 Seth Jennings       2013-07-10  1265  
2b2811178e8555 Seth Jennings       2013-07-10  1266  	/* store */
9c3760eb80880f Yu Zhao             2018-01-31  1267  	hlen = zpool_evictable(entry->pool->zpool) ? sizeof(zhdr) : 0;
d2fcd82bb83aab Hui Zhu             2019-09-23  1268  	gfp = __GFP_NORETRY | __GFP_NOWARN | __GFP_KSWAPD_RECLAIM;
d2fcd82bb83aab Hui Zhu             2019-09-23  1269  	if (zpool_malloc_support_movable(entry->pool->zpool))
d2fcd82bb83aab Hui Zhu             2019-09-23  1270  		gfp |= __GFP_HIGHMEM | __GFP_MOVABLE;
d2fcd82bb83aab Hui Zhu             2019-09-23  1271  	ret = zpool_malloc(entry->pool->zpool, hlen + dlen, gfp, &handle);
2b2811178e8555 Seth Jennings       2013-07-10  1272  	if (ret == -ENOSPC) {
2b2811178e8555 Seth Jennings       2013-07-10  1273  		zswap_reject_compress_poor++;
f1c54846ee4504 Dan Streetman       2015-09-09  1274  		goto put_dstmem;
2b2811178e8555 Seth Jennings       2013-07-10  1275  	}
2b2811178e8555 Seth Jennings       2013-07-10  1276  	if (ret) {
2b2811178e8555 Seth Jennings       2013-07-10  1277  		zswap_reject_alloc_fail++;
f1c54846ee4504 Dan Streetman       2015-09-09  1278  		goto put_dstmem;
2b2811178e8555 Seth Jennings       2013-07-10  1279  	}
ae34af1f11d0a6 Miaohe Lin          2021-06-30  1280  	buf = zpool_map_handle(entry->pool->zpool, handle, ZPOOL_MM_WO);
9c3760eb80880f Yu Zhao             2018-01-31  1281  	memcpy(buf, &zhdr, hlen);
9c3760eb80880f Yu Zhao             2018-01-31  1282  	memcpy(buf + hlen, dst, dlen);
f1c54846ee4504 Dan Streetman       2015-09-09  1283  	zpool_unmap_handle(entry->pool->zpool, handle);
1ec3b5fe6eec78 Barry Song          2020-12-14  1284  	mutex_unlock(acomp_ctx->mutex);
2b2811178e8555 Seth Jennings       2013-07-10  1285  
2b2811178e8555 Seth Jennings       2013-07-10  1286  	/* populate entry */
2b2811178e8555 Seth Jennings       2013-07-10  1287  	entry->offset = offset;
2b2811178e8555 Seth Jennings       2013-07-10  1288  	entry->handle = handle;
2b2811178e8555 Seth Jennings       2013-07-10  1289  	entry->length = dlen;
2b2811178e8555 Seth Jennings       2013-07-10  1290  
a85f878b443f8d Srividya Desireddy  2018-01-31  1291  insert_entry:
f4840ccfca25db Johannes Weiner     2022-05-19  1292  	entry->objcg = objcg;
f4840ccfca25db Johannes Weiner     2022-05-19  1293  	if (objcg) {
f4840ccfca25db Johannes Weiner     2022-05-19  1294  		obj_cgroup_charge_zswap(objcg, entry->length);
f4840ccfca25db Johannes Weiner     2022-05-19  1295  		/* Account before objcg ref is moved to tree */
f4840ccfca25db Johannes Weiner     2022-05-19  1296  		count_objcg_event(objcg, ZSWPOUT);
f4840ccfca25db Johannes Weiner     2022-05-19  1297  	}
f4840ccfca25db Johannes Weiner     2022-05-19  1298  
2b2811178e8555 Seth Jennings       2013-07-10  1299  	/* map */
2b2811178e8555 Seth Jennings       2013-07-10  1300  	spin_lock(&tree->lock);
2b2811178e8555 Seth Jennings       2013-07-10  1301  	do {
2b2811178e8555 Seth Jennings       2013-07-10  1302  		ret = zswap_rb_insert(&tree->rbroot, entry, &dupentry);
2b2811178e8555 Seth Jennings       2013-07-10  1303  		if (ret == -EEXIST) {
2b2811178e8555 Seth Jennings       2013-07-10  1304  			zswap_duplicate_entry++;
2b2811178e8555 Seth Jennings       2013-07-10  1305  			/* remove from rbtree */
0ab0abcf511545 Weijie Yang         2013-11-12  1306  			zswap_rb_erase(&tree->rbroot, dupentry);
0ab0abcf511545 Weijie Yang         2013-11-12  1307  			zswap_entry_put(tree, dupentry);
2b2811178e8555 Seth Jennings       2013-07-10  1308  		}
2b2811178e8555 Seth Jennings       2013-07-10  1309  	} while (ret == -EEXIST);
2b2811178e8555 Seth Jennings       2013-07-10  1310  	spin_unlock(&tree->lock);
2b2811178e8555 Seth Jennings       2013-07-10  1311  
2b2811178e8555 Seth Jennings       2013-07-10  1312  	/* update stats */
2b2811178e8555 Seth Jennings       2013-07-10  1313  	atomic_inc(&zswap_stored_pages);
f1c54846ee4504 Dan Streetman       2015-09-09  1314  	zswap_update_total_size();
f6498b776d280b Johannes Weiner     2022-05-19  1315  	count_vm_event(ZSWPOUT);
2b2811178e8555 Seth Jennings       2013-07-10  1316  
2b2811178e8555 Seth Jennings       2013-07-10  1317  	return 0;
2b2811178e8555 Seth Jennings       2013-07-10  1318  
f1c54846ee4504 Dan Streetman       2015-09-09  1319  put_dstmem:
1ec3b5fe6eec78 Barry Song          2020-12-14  1320  	mutex_unlock(acomp_ctx->mutex);
f1c54846ee4504 Dan Streetman       2015-09-09  1321  	zswap_pool_put(entry->pool);
f1c54846ee4504 Dan Streetman       2015-09-09  1322  freepage:
2b2811178e8555 Seth Jennings       2013-07-10  1323  	zswap_entry_cache_free(entry);
2b2811178e8555 Seth Jennings       2013-07-10  1324  reject:
f4840ccfca25db Johannes Weiner     2022-05-19  1325  	if (objcg)
f4840ccfca25db Johannes Weiner     2022-05-19  1326  		obj_cgroup_put(objcg);
2b2811178e8555 Seth Jennings       2013-07-10  1327  	return ret;
f4840ccfca25db Johannes Weiner     2022-05-19  1328  
f4840ccfca25db Johannes Weiner     2022-05-19  1329  shrink:
f4840ccfca25db Johannes Weiner     2022-05-19  1330  	pool = zswap_pool_last_get();
f4840ccfca25db Johannes Weiner     2022-05-19  1331  	if (pool)
f4840ccfca25db Johannes Weiner     2022-05-19  1332  		queue_work(shrink_wq, &pool->shrink_work);
f4840ccfca25db Johannes Weiner     2022-05-19  1333  	ret = -ENOMEM;
f4840ccfca25db Johannes Weiner     2022-05-19  1334  	goto reject;
2b2811178e8555 Seth Jennings       2013-07-10  1335  }
2b2811178e8555 Seth Jennings       2013-07-10  1336  

:::::: The code at line 1183 was first introduced by commit
:::::: f4840ccfca25db225b3371a8f7b5770febee87c5 zswap: memcg accounting

:::::: TO: Johannes Weiner <hannes@xxxxxxxxxxx>
:::::: CC: akpm <akpm@xxxxxxxxxxxxxxxxxxxx>

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




[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Bugtraq]     [Linux OMAP]     [Linux MIPS]     [eCos]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux