ACK: [PATCH 3/3] acpi: s4: do kernel log comparisons without destroying klog (LP: #1262208)

IvanHu ivan.hu at canonical.com
Mon Dec 23 08:09:33 UTC 2013


On 12/18/2013 10:19 PM, Colin King wrote:
> From: Colin Ian King <colin.king at canonical.com>
>
> Use the new kernel log comapring helper to compare old vs new
> kernel logs and remove the need to clear the kernel log before
> each S4 iteration.
>
> Signed-off-by: Colin Ian King <colin.king at canonical.com>
> ---
>   src/acpi/s4/s4.c | 49 +++++++++++++++++++++++++------------------------
>   1 file changed, 25 insertions(+), 24 deletions(-)
>
> diff --git a/src/acpi/s4/s4.c b/src/acpi/s4/s4.c
> index d9ddd6b..fbbc9ac 100644
> --- a/src/acpi/s4/s4.c
> +++ b/src/acpi/s4/s4.c
> @@ -27,6 +27,9 @@
>   #include <unistd.h>
>
>   #define PM_HIBERNATE	"pm-hibernate"
> +#define FWTS_HIBERNATE	"FWTS_HIBERNATE"
> +#define FWTS_RESUME	"FWTS_RESUME"
> +
>
>   #define FWTS_TRACING_BUFFER_SIZE	"/sys/kernel/debug/tracing/buffer_size_kb"
>
> @@ -44,11 +47,6 @@ static int s4_init(fwts_framework *fw)
>   {
>   	fwts_list* swap_devs;
>
> -	if (fwts_klog_clear()) {
> -		fwts_log_error(fw, "Cannot clear kernel log.");
> -		return FWTS_ERROR;
> -	}
> -
>   	swap_devs = fwts_file_open_and_read("/proc/swaps");
>   	if (fwts_text_list_strstr(swap_devs, "/dev/") == NULL) {
>   		fwts_list_free(swap_devs, free);
> @@ -100,7 +98,7 @@ static int s4_hibernate(fwts_framework *fw,
>   	int percent)
>   {
>   	fwts_list *output;
> -	fwts_list *klog;
> +	fwts_list *klog_pre, *klog_post, *klog_diff;
>   	fwts_hwinfo hwinfo1, hwinfo2;
>   	int status;
>   	int differences;
> @@ -108,11 +106,6 @@ static int s4_hibernate(fwts_framework *fw,
>   	char *quirks;
>   	char buffer[80];
>
> -	if (fwts_klog_clear()) {
> -		fwts_log_error(fw, "S4 hibernate: Cannot clear kernel log.");
> -		return FWTS_ERROR;
> -	}
> -
>   	if (s4_device_check)
>   		fwts_hwinfo_get(fw, &hwinfo1);
>
> @@ -137,12 +130,22 @@ static int s4_hibernate(fwts_framework *fw,
>   	fwts_wakealarm_trigger(fw, s4_sleep_delay);
>
>   	/* Do s4 here */
> +	if ((klog_pre = fwts_klog_read()) == NULL)
> +		fwts_log_error(fw, "S4: hibernate: Cannot read kernel log.");
> +
>   	fwts_progress_message(fw, percent, "(Hibernating)");
> +	(void)fwts_klog_write(fw, "Starting fwts hibernate\n");
> +	(void)fwts_klog_write(fw, FWTS_HIBERNATE "\n");
>   	(void)fwts_pipe_exec(command, &output, &status);
> +	(void)fwts_klog_write(fw, FWTS_RESUME "\n");
> +	(void)fwts_klog_write(fw, "Finished fwts resume\n");
>   	fwts_progress_message(fw, percent, "(Resumed)");
>   	fwts_text_list_free(output);
>   	free(command);
>
> +	if ((klog_post = fwts_klog_read()) == NULL)
> +		fwts_log_error(fw, "S4: hibernate: Cannot re-read kernel log.");
> +
>   	if (s4_device_check) {
>   		int i;
>
> @@ -166,12 +169,8 @@ static int s4_hibernate(fwts_framework *fw,
>
>   	fwts_progress_message(fw, percent, "(Checking for errors)");
>
> -	if ((klog = fwts_klog_read()) == NULL) {
> -		fwts_log_error(fw, "S4: hibernate: Cannot read kernel log.");
> -		return FWTS_ERROR;
> -	}
> -
> -	s4_check_log(fw, klog, klog_errors, klog_oopses, klog_warn_ons);
> +	klog_diff = fwts_klog_find_changes(klog_pre, klog_post);
> +	s4_check_log(fw, klog_diff, klog_errors, klog_oopses, klog_warn_ons);
>
>   	fwts_progress_message(fw, percent, "(Checking for PM errors)");
>
> @@ -193,39 +192,41 @@ static int s4_hibernate(fwts_framework *fw,
>   		(*pm_errors)++;
>   	}
>
> -	if (fwts_klog_regex_find(fw, klog, "Freezing user space processes.*done") < 1) {
> +	if (fwts_klog_regex_find(fw, klog_diff, "Freezing user space processes.*done") < 1) {
>   		fwts_failed(fw, LOG_LEVEL_HIGH, "UserSpaceTaskFreeze",
>   			"Failed to freeze user space processes.");
>   		(*pm_errors)++;
>   	}
>
> -	if (fwts_klog_regex_find(fw, klog, "Freezing remaining freezable tasks.*done") < 1) {
> +	if (fwts_klog_regex_find(fw, klog_diff, "Freezing remaining freezable tasks.*done") < 1) {
>   		fwts_failed(fw, LOG_LEVEL_HIGH, "KernelTaskFreeze",
>   			"Failed to freeze remaining non-user space processes.");
>   		(*pm_errors)++;
>   	}
>
> -	if ((fwts_klog_regex_find(fw, klog, "PM: freeze of devices complete") < 1) &&
> -	    (fwts_klog_regex_find(fw, klog, "PM: late freeze of devices complete") < 1)) {
> +	if ((fwts_klog_regex_find(fw, klog_diff, "PM: freeze of devices complete") < 1) &&
> +	    (fwts_klog_regex_find(fw, klog_diff, "PM: late freeze of devices complete") < 1)) {
>   		fwts_failed(fw, LOG_LEVEL_HIGH, "DeviceFreeze",
>   			"Failed to freeze devices.");
>   		(*pm_errors)++;
>   	}
>
> -	if (fwts_klog_regex_find(fw, klog, "PM: Allocated.*kbytes") < 1) {
> +	if (fwts_klog_regex_find(fw, klog_diff, "PM: Allocated.*kbytes") < 1) {
>   		fwts_failed(fw, LOG_LEVEL_HIGH, "HibernateImageAlloc",
>   			"Failed to allocate memory for hibernate image.");
>   		*failed_alloc_image = 1;
>   		(*pm_errors)++;
>   	}
>
> -	if (fwts_klog_regex_find(fw, klog, "PM: Image restored successfully") < 1) {
> +	if (fwts_klog_regex_find(fw, klog_diff, "PM: Image restored successfully") < 1) {
>   		fwts_failed(fw, LOG_LEVEL_HIGH, "HibernateImageRestore",
>   			"Failed to restore hibernate image.");
>   		(*pm_errors)++;
>   	}
>
> -	fwts_klog_free(klog);
> +	fwts_klog_free(klog_pre);
> +	fwts_klog_free(klog_post);
> +	fwts_list_free(klog_diff, NULL);
>
>   	return FWTS_OK;
>   }
>

Acked-by: Ivan Hu <ivan.hu at canonical.com>



More information about the fwts-devel mailing list