| #!/bin/sh |
| # SPDX-License-Identifier: GPL-2.0-only |
| |
| # pstore_post_reboot_tests - Check pstore's behavior after crash/reboot |
| # |
| # Copyright (C) Hitachi Ltd., 2015 |
| # Written by Hiraku Toyooka <hiraku.toyooka.gu@hitachi.com> |
| # |
| |
| # Kselftest framework requirement - SKIP code is 4. |
| ksft_skip=4 |
| |
| . ./common_tests |
| |
| if [ -e $REBOOT_FLAG ]; then |
| rm $REBOOT_FLAG |
| else |
| prlog "pstore_crash_test has not been executed yet. we skip further tests." |
| exit $ksft_skip |
| fi |
| |
| prlog -n "Mounting pstore filesystem ... " |
| mount_info=`grep pstore /proc/mounts` |
| if [ $? -eq 0 ]; then |
| mount_point=`echo ${mount_info} | cut -d' ' -f2 | head -n1` |
| prlog "ok" |
| else |
| mount none /sys/fs/pstore -t pstore |
| if [ $? -eq 0 ]; then |
| mount_point=`grep pstore /proc/mounts | cut -d' ' -f2 | head -n1` |
| prlog "ok" |
| else |
| prlog "FAIL" |
| exit 1 |
| fi |
| fi |
| |
| cd ${mount_point} |
| |
| prlog -n "Checking dmesg files exist in pstore filesystem ... " |
| check_files_exist dmesg |
| |
| prlog -n "Checking console files exist in pstore filesystem ... " |
| check_files_exist console |
| |
| prlog -n "Checking pmsg files exist in pstore filesystem ... " |
| check_files_exist pmsg |
| |
| prlog -n "Checking dmesg files contain oops end marker" |
| grep_end_trace() { |
| grep -q "\---\[ end trace" $1 |
| } |
| files=`ls dmesg-${backend}-*` |
| operate_files $? "$files" grep_end_trace |
| |
| prlog -n "Checking console file contains oops end marker ... " |
| grep -q "\---\[ end trace" console-${backend}-0 |
| show_result $? |
| |
| prlog -n "Checking pmsg file properly keeps the content written before crash ... " |
| prev_uuid=`cat $TOP_DIR/prev_uuid` |
| if [ $? -eq 0 ]; then |
| nr_matched=`grep -c "$TEST_STRING_PATTERN" pmsg-${backend}-0` |
| if [ $nr_matched -eq 1 ]; then |
| grep -q "$TEST_STRING_PATTERN"$prev_uuid pmsg-${backend}-0 |
| show_result $? |
| else |
| prlog "FAIL" |
| rc=1 |
| fi |
| else |
| prlog "FAIL" |
| rc=1 |
| fi |
| |
| prlog -n "Removing all files in pstore filesystem " |
| files=`ls *-${backend}-*` |
| operate_files $? "$files" rm |
| |
| exit $rc |