Received: by 2002:a05:7412:7c14:b0:fa:6e18:a558 with SMTP id ii20csp316384rdb; Mon, 22 Jan 2024 05:18:58 -0800 (PST) X-Google-Smtp-Source: AGHT+IFbMTPKwNFg8HRMCplMUM7ZAhnw3B2nDKx6aKpVrMu+/9RAtjA67XpbDWg7nkxkCtjyiRWj X-Received: by 2002:a05:620a:46a5:b0:783:9dc9:9a6f with SMTP id bq37-20020a05620a46a500b007839dc99a6fmr2239540qkb.120.1705929538325; Mon, 22 Jan 2024 05:18:58 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1705929538; cv=pass; d=google.com; s=arc-20160816; b=MKR3p3dD7NlnpShoBqgvENqgpsE3Wk3zQKWXlifPD0b54nl9h1kNBaTPgcQil8n6/u oClwDjZAKVbf3OtCMkKacof1jCWi3Nv4MMX5uiX5B7hxUOnmI8vWI6ae4b2Yu2ujbc6L Zf3GhAZYYCu2w3Nx6HptNdut7K47cLfwdFG49dl/skBsC1sjP5iF4bkVCp+HULmlTw0Z czVYfgSIGeL98iR7lo99qfmIXtS+wY0tG9jxAZhliXAYXb7GCxjWizY4ak++0fnUkFvu AN9YbO+3GV6M6UIsp7+mbxPjX6ao4ICIncKhDNMB76bd+L2BNmkmR14iT04qZUvV2T8z LuOQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=8OWYoZvn4DIL+CctQ8TECYPg6+Gh541QlQ7vvlwVN8E=; fh=5KhvPoiN8e9PZDAgVtZRrZ3F3WJS6nXkX45ZrGlUNDs=; b=xN+CRBkxH0+a0oN7RNM0YI78bBG9UixU1MRirXUtz4BriX5+3haKkPcNctydiBATSW xvm1bT2rywzMoVdu0clAOEOwj5UAL0+Zi4PxF1QLGM7/0URGnGoqGZra0sZI0HlfYG/H bP9S3AjpV/oOcVpSSkFrashaSzOpwySHRYkaHHoxIB25abayk/OOUKiBhwoWBZXq5D1m 05QJe31rIIKTkd7YFoAMphq+WELPNZ2yqmTPlMD0HobqHqxjDqo/4BSTWxOwFkty3z7I R7xx/FcyESq9cdHFYTU1AjQ0nJEl7H7uJQYzyPZCGp++piTCg4B++0cql5G1XbkYy8zF o1lg== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=oMiKdq6O; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-kernel+bounces-33088-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-33088-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id x25-20020a05620a099900b007833c5d6b6csi5351104qkx.713.2024.01.22.05.18.58 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 22 Jan 2024 05:18:58 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-33088-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=oMiKdq6O; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-kernel+bounces-33088-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-33088-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 097001C22734 for ; Mon, 22 Jan 2024 13:18:58 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 1E5F93CF71; Mon, 22 Jan 2024 13:18:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="oMiKdq6O" Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 86EC83CF42; Mon, 22 Jan 2024 13:18:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1705929531; cv=none; b=uDvGtQoYhfYZ1uuobClEuL921z+tKWHi0GaixA9zLwJVH58DUCUkeRSa+DCEaNzOPR27lsrNttZlrC2uKQoiZntySUzSUcNGlBwpjuCSRkfLX65SfI7UUpOibIq/bZCeLk6J5eb3AotziTb2GBeHwsZ+CicZ3A7lVSTwdQNAfcw= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1705929531; c=relaxed/simple; bh=SIzxtC9pLmVG8/cD1VD0yzpq/VmHH5qfbP7jr02pMEg=; h=Message-ID:Date:MIME-Version:Subject:To:CC:References:From: In-Reply-To:Content-Type; b=b4qMiwNz8OD/ChjqmEEnVadsAtFTLplLuIFtPnLujwA7yMi1FI5AwDywDafbdVlrKDrfrxJzwtoNkiUICE8r5lngdw8rFwZ66cN90rT5G6AbqfxQVC1n6mnxmpDNm1LpT7rwsWDiN7SbanxGC6wbNbb8FH7OhRstGHGQ/v5IZsw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com; spf=pass smtp.mailfrom=quicinc.com; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b=oMiKdq6O; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=quicinc.com Received: from pps.filterd (m0279866.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.24/8.17.1.24) with ESMTP id 40MAnFTp001475; Mon, 22 Jan 2024 13:18:27 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h= message-id:date:mime-version:subject:to:cc:references:from :in-reply-to:content-type:content-transfer-encoding; s= qcppdkim1; bh=8OWYoZvn4DIL+CctQ8TECYPg6+Gh541QlQ7vvlwVN8E=; b=oM iKdq6Ogf9cqRZ3z2IaZpPdgmVNa1Sa8eVrQ+3ZOr1+fcHH96nIjGnsjNNf+NDc95 TiQuWU0KCxt6KR3ipR1edtuBA3irxsw/yk/HVWfC/jOEWuo+XYgEh3gXpF3GwciT /AJQGY9ZMvgSpVZL7VOi4HnKLHqb3eo/sn1q5+mwv4AZ20G9Xe9hN9i+qPsoA73Q hDBTEXDGFkqo6QQa+3qI7f9zq7W/pZK85Iiz7pI98xyU0XY41xZwtzIxDuxhqsqI pRJg/E5roUyZ2x8Iug75rqWWDEJpEuUcVLPKq8ZgWblahJqHgmvmXNX+5Icz6bcT BszEsXIKRUnk/yyp6myg== Received: from nalasppmta01.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3vr7fd41jw-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Jan 2024 13:18:27 +0000 (GMT) Received: from nalasex01b.na.qualcomm.com (nalasex01b.na.qualcomm.com [10.47.209.197]) by NALASPPMTA01.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 40MDIQJ2005798 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Jan 2024 13:18:26 GMT Received: from [10.216.19.244] (10.80.80.8) by nalasex01b.na.qualcomm.com (10.47.209.197) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.40; Mon, 22 Jan 2024 05:18:18 -0800 Message-ID: Date: Mon, 22 Jan 2024 18:48:14 +0530 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.1.0 Subject: Re: [PATCH RESEND v2 0/4] PM: hibernate: LZ4 compression support Content-Language: en-US To: "Rafael J. Wysocki" CC: Pavel Machek , Len Brown , "Jonathan Corbet" , Randy Dunlap , Peter Zijlstra , "Steven Rostedt (Google)" , Tejun Heo , "Paul E. McKenney" , "Catalin Marinas" , , , , , , , , , References: <2153c549-2a45-3d1d-a407-e175a34b77bf@quicinc.com> From: Nikhil V In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01b.na.qualcomm.com (10.47.209.197) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: oDAZodEk35KDRIDX-iL_nXDGVeztm7XI X-Proofpoint-ORIG-GUID: oDAZodEk35KDRIDX-iL_nXDGVeztm7XI X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.1011,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2024-01-22_02,2024-01-22_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 priorityscore=1501 lowpriorityscore=0 mlxlogscore=999 mlxscore=0 phishscore=0 adultscore=0 malwarescore=0 clxscore=1015 suspectscore=0 impostorscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2311290000 definitions=main-2401220093 On 1/22/2024 5:46 PM, Rafael J. Wysocki wrote: > On Mon, Jan 22, 2024 at 1:14 PM Nikhil V wrote: >> >> >> >> On 12/12/2023 6:14 PM, Rafael J. Wysocki wrote: >>> Hi, >>> >>> On Wed, Nov 29, 2023 at 11:20 AM Nikhil V wrote: >>>> >>>> >>>> On 11/15/2023 5:52 PM, Nikhil V wrote: >>>>> This patch series covers the following: >>>>> 1. Renaming lzo* to generic names, except for lzo_xxx() APIs. This is >>>>> used in the next patch where we move to crypto based APIs for >>>>> compression. There are no functional changes introduced by this >>>>> approach. >>>>> >>>>> >>>>> 2. Replace LZO library calls with crypto generic APIs >>>>> >>>>> Currently for hibernation, LZO is the only compression algorithm >>>>> available and uses the existing LZO library calls. However, there >>>>> is no flexibility to switch to other algorithms which provides better >>>>> results. The main idea is that different compression algorithms have >>>>> different characteristics and hibernation may benefit when it uses >>>>> alternate algorithms. >>>>> >>>>> By moving to crypto based APIs, it lays a foundation to use other >>>>> compression algorithms for hibernation. >>>>> >>>>> >>>>> 3. LZ4 compression >>>>> >>>>> Extend the support for LZ4 compression to be used with hibernation. >>>>> The main idea is that different compression algorithms have different >>>>> characteristics and hibernation may benefit when it uses any of these >>>>> algorithms: a default algorithm, having higher compression rate but is >>>>> slower(compression/decompression) and a secondary algorithm, that is >>>>> faster(compression/decompression) but has lower compression rate. >>>>> >>>>> LZ4 algorithm has better decompression speeds over LZO. This reduces >>>>> the hibernation image restore time. >>>>> As per test results: >>>>> LZO LZ4 >>>>> Size before Compression(bytes) 682696704 682393600 >>>>> Size after Compression(bytes) 146502402 155993547 >>>>> Decompression Rate 335.02 MB/s 501.05 MB/s >>>>> Restore time 4.4s 3.8s >>>>> >>>>> LZO is the default compression algorithm used for hibernation. Enable >>>>> CONFIG_HIBERNATION_DEF_COMP_LZ4 to set the default compressor as LZ4. >>>>> >>>>> Compression Benchmarks: https://github.com/lz4/lz4 >>>>> >>>>> >>>>> 4. Support to select compression algorithm >>>>> >>>>> Currently the default compression algorithm is selected based on >>>>> Kconfig. Introduce a kernel command line parameter "hib_compression" to >>>>> override this behaviour. >>>>> >>>>> Users can set "hib_compression" command line parameter to specify >>>>> the algorithm. >>>>> Usage: >>>>> LZO: hib_compression=lzo >>>>> LZ4: hib_compression=lz4 >>>>> LZO is the default compression algorithm used with hibernation. >>>>> >>>>> >>>>> Changes in v2: >>>>> - Fixed build issues reported by kernel test robot for ARCH=sh, [1]. >>>>> [1] https://lore.kernel.org/oe-kbuild-all/202310171226.pLUPeuC7-lkp@intel.com/ >>>>> >>>>> Nikhil V (4): >>>>> PM: hibernate: Rename lzo* to make it generic >>>>> PM: hibernate: Move to crypto APIs for LZO compression >>>>> PM: hibernate: Add support for LZ4 compression for hibernation >>>>> PM: hibernate: Support to select compression algorithm >>>>> >>>>> .../admin-guide/kernel-parameters.txt | 6 + >>>>> kernel/power/Kconfig | 26 ++- >>>>> kernel/power/hibernate.c | 85 +++++++- >>>>> kernel/power/power.h | 19 ++ >>>>> kernel/power/swap.c | 189 +++++++++++------- >>>>> 5 files changed, 251 insertions(+), 74 deletions(-) >>>>> >>>>> >>>>> base-commit: b85ea95d086471afb4ad062012a4d73cd328fa86 >>>> >>>> Hi @Rafael/@Pavel/@Len, >>>> >>>> Could you please let me know if you have any concerns on this approach? >>> >>> Not really a concern, but that is a significant change that I would >>> rather make early in the cycle, which means after the 6.8 merge >>> window. >>> >>> No need to resend unless there is something to address in which case >>> I'll let you know. >>> >>> Thanks! >>> >>>> FYI: We have tested this on QEMU and its working fine. >>>> >>>> Logs(suspend): >>>> [ 75.242227] PM: Using 3 thread(s) for lz4 compression >>>> [ 75.243043] PM: Compressing and saving image data (17495 pages)... >>>> [ 75.243917] PM: Image saving progress: 0% >>>> [ 75.261727] PM: Image saving progress: 10% >>>> [ 75.277968] PM: Image saving progress: 20% >>>> [ 75.290927] PM: Image saving progress: 30% >>>> [ 75.305186] PM: Image saving progress: 40% >>>> [ 75.318252] PM: Image saving progress: 50% >>>> [ 75.330310] PM: Image saving progress: 60% >>>> [ 75.345906] PM: Image saving progress: 70% >>>> [ 75.359054] PM: Image saving progress: 80% >>>> [ 75.372176] PM: Image saving progress: 90% >>>> [ 75.388411] PM: Image saving progress: 100% >>>> [ 75.389775] PM: Image saving done >>>> [ 75.390397] PM: hibernation: Wrote 69980 kbytes in 0.14 seconds >>>> (499.85 MB/s) >>>> [ 75.391591] PM: Image size after compression: 28242 kbytes >>>> [ 75.393089] PM: S| >>>> [ 75.399784] sd 0:0:0:0: [sda] Synchronizing SCSI cache >>>> [ 75.439170] sd 0:0:0:0: [sda] Stopping disk >>>> [ 75.501461] ACPI: PM: Preparing to enter system sleep state S5 >>>> [ 75.502766] reboot: Power down >>>> >>>> >>>> >>>> Logs(resume): >>>> [ 1.063248] PM: hibernation: resume from hibernation >>>> [ 1.072868] Freezing user space processes >>>> [ 1.073707] Freezing user space processes completed (elapsed 0.000 >>>> seconds) >>>> [ 1.075192] OOM killer disabled. >>>> [ 1.075837] Freezing remaining freezable tasks >>>> [ 1.078010] Freezing remaining freezable tasks completed (elapsed >>>> 0.001 seconds) >>>> [ 1.087489] PM: Using 3 thread(s) for lz4 decompression >>>> [ 1.088570] PM: Loading and decompressing image data (17495 pages)... >>>> [ 1.125549] PM: Image loading progress: 0% >>>> [ 1.190380] PM: Image loading progress: 10% >>>> [ 1.204963] PM: Image loading progress: 20% >>>> [ 1.218988] PM: Image loading progress: 30% >>>> [ 1.233697] PM: Image loading progress: 40% >>>> [ 1.248658] PM: Image loading progress: 50% >>>> [ 1.262910] PM: Image loading progress: 60% >>>> [ 1.276966] PM: Image loading progress: 70% >>>> [ 1.290517] PM: Image loading progress: 80% >>>> [ 1.305427] PM: Image loading progress: 90% >>>> [ 1.320666] PM: Image loading progress: 100% >>>> [ 1.321866] PM: Image loading done >>>> [ 1.322599] PM: hibernation: Read 69980 kbytes in 0.23 seconds >>>> (304.26 MB/s) >>>> [ 1.324795] printk: Suspending console(s) (use no_console_suspend to >>>> debug) >>>> [ 74.943801] ata1.00: Entering standby power mode >>>> >>>> >>>> Thanks, >>>> Nikhil V >> >> >> Hi @Rafael >> >> We have picked this patch series on 6.8-rc1 and tested the functionality >> on QEMU. Its working fine. However, while applying the patches we could >> see minor conflicts. Could you please let me know if we need to push a >> new version after resolving these conflicts? > > It will help. > > I can resolve the conflicts, but I may make mistakes in the process. > > Thanks! Thanks for the response. Will push a new version after resolving the conflicts. Thanks, Nikhil V