PM: hibernate: Fix crash when freeing invalid crypto compressor

When crypto_alloc_acomp() fails, it returns an ERR_PTR value, not NULL.

The cleanup code in save_compressed_image() and load_compressed_image()
unconditionally calls crypto_free_acomp() without checking for ERR_PTR,
which causes crypto_acomp_tfm() to dereference an invalid pointer and
crash the kernel.

This can be triggered when the compression algorithm is unavailable
(e.g., CONFIG_CRYPTO_LZO not enabled).

Fix by adding IS_ERR_OR_NULL() checks before calling crypto_free_acomp()
and acomp_request_free(), similar to the existing kthread_stop() check.

Fixes: b03d542c3c95 ("PM: hibernate: Use crypto_acomp interface")
Signed-off-by: Malaya Kumar Rout <mrout@redhat.com>
Cc: 6.15+ <stable@vger.kernel.org> # 6.15+
[ rjw: Added 2 empty code lines ]
Link: https://patch.msgid.link/20251230115613.64080-1-mrout@redhat.com
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>

authored by Malaya Kumar Rout and committed by Rafael J. Wysocki 7966cf0e 9ace4753

Changed files
+10 -4
kernel
power
+10 -4
kernel/power/swap.c
··· 902 902 for (thr = 0; thr < nr_threads; thr++) { 903 903 if (data[thr].thr) 904 904 kthread_stop(data[thr].thr); 905 - acomp_request_free(data[thr].cr); 906 - crypto_free_acomp(data[thr].cc); 905 + if (data[thr].cr) 906 + acomp_request_free(data[thr].cr); 907 + 908 + if (!IS_ERR_OR_NULL(data[thr].cc)) 909 + crypto_free_acomp(data[thr].cc); 907 910 } 908 911 vfree(data); 909 912 } ··· 1502 1499 for (thr = 0; thr < nr_threads; thr++) { 1503 1500 if (data[thr].thr) 1504 1501 kthread_stop(data[thr].thr); 1505 - acomp_request_free(data[thr].cr); 1506 - crypto_free_acomp(data[thr].cc); 1502 + if (data[thr].cr) 1503 + acomp_request_free(data[thr].cr); 1504 + 1505 + if (!IS_ERR_OR_NULL(data[thr].cc)) 1506 + crypto_free_acomp(data[thr].cc); 1507 1507 } 1508 1508 vfree(data); 1509 1509 }