mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-11-04 10:21:25 +01:00 
			
		
		
		
	Add PStore command to sandbox and sandbox64 defconfigs. Add test checking: - 'pstore display' of all records - 'pstore display' only the 2nd dump record - 'pstore save' of all records Signed-off-by: Frédéric Danis <frederic.danis@collabora.com> [trini: Adjust to always load files from source directory] Signed-off-by: Tom Rini <trini@konsulko.com> Cc: Heinrich Schuchardt <xypron.glpk@gmx.de> Cc: Wolfgang Denk <wd@denx.de> Cc: Heiko Schocher <hs@denx.de>
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: GPL-2.0+
 | 
						|
# Copyright (c) 2020, Collabora
 | 
						|
# Author: Frédéric Danis <frederic.danis@collabora.com>
 | 
						|
 | 
						|
import pytest
 | 
						|
import u_boot_utils
 | 
						|
import os
 | 
						|
import tempfile
 | 
						|
import shutil
 | 
						|
 | 
						|
PSTORE_ADDR=0x3000000
 | 
						|
PSTORE_LENGTH=0x100000
 | 
						|
PSTORE_PANIC1='test/py/tests/test_pstore_data_panic1.hex'
 | 
						|
PSTORE_PANIC2='test/py/tests/test_pstore_data_panic2.hex'
 | 
						|
PSTORE_CONSOLE='test/py/tests/test_pstore_data_console.hex'
 | 
						|
ADDR=0x01000008
 | 
						|
 | 
						|
def load_pstore(u_boot_console):
 | 
						|
    """Load PStore records from sample files"""
 | 
						|
 | 
						|
    output = u_boot_console.run_command_list([
 | 
						|
        'host load hostfs - 0x%x %s' % (PSTORE_ADDR,
 | 
						|
            os.path.join(u_boot_console.config.source_dir, PSTORE_PANIC1)),
 | 
						|
        'host load hostfs - 0x%x %s' % (PSTORE_ADDR + 4096,
 | 
						|
            os.path.join(u_boot_console.config.source_dir, PSTORE_PANIC2)),
 | 
						|
        'host load hostfs - 0x%x %s' % (PSTORE_ADDR + 253 * 4096,
 | 
						|
            os.path.join(u_boot_console.config.source_dir, PSTORE_CONSOLE)),
 | 
						|
        'pstore set 0x%x 0x%x' % (PSTORE_ADDR, PSTORE_LENGTH)])
 | 
						|
 | 
						|
def checkfile(u_boot_console, path, filesize, checksum):
 | 
						|
    """Check file against MD5 checksum"""
 | 
						|
 | 
						|
    output = u_boot_console.run_command_list([
 | 
						|
        'load hostfs - %x %s' % (ADDR, path),
 | 
						|
        'printenv filesize'])
 | 
						|
    assert('filesize=%x' % (filesize) in ''.join(output))
 | 
						|
 | 
						|
    output = u_boot_console.run_command_list([
 | 
						|
        'md5sum %x $filesize' % ADDR,
 | 
						|
        'setenv filesize'])
 | 
						|
    assert(checksum in ''.join(output))
 | 
						|
 | 
						|
@pytest.mark.buildconfigspec('cmd_pstore')
 | 
						|
def test_pstore_display_all_records(u_boot_console):
 | 
						|
    """Test that pstore displays all records."""
 | 
						|
 | 
						|
    u_boot_console.run_command('')
 | 
						|
    load_pstore(u_boot_console)
 | 
						|
    response = u_boot_console.run_command('pstore display')
 | 
						|
    assert('**** Dump' in response)
 | 
						|
    assert('**** Console' in response)
 | 
						|
 | 
						|
@pytest.mark.buildconfigspec('cmd_pstore')
 | 
						|
def test_pstore_display_one_record(u_boot_console):
 | 
						|
    """Test that pstore displays only one record."""
 | 
						|
 | 
						|
    u_boot_console.run_command('')
 | 
						|
    load_pstore(u_boot_console)
 | 
						|
    response = u_boot_console.run_command('pstore display dump 1')
 | 
						|
    assert('Panic#2 Part1' in response)
 | 
						|
    assert('**** Console' not in response)
 | 
						|
 | 
						|
@pytest.mark.buildconfigspec('cmd_pstore')
 | 
						|
def test_pstore_save_records(u_boot_console):
 | 
						|
    """Test that pstore saves all records."""
 | 
						|
 | 
						|
    outdir = tempfile.mkdtemp()
 | 
						|
 | 
						|
    u_boot_console.run_command('')
 | 
						|
    load_pstore(u_boot_console)
 | 
						|
    u_boot_console.run_command('pstore save hostfs - %s' % (outdir))
 | 
						|
 | 
						|
    checkfile(u_boot_console, '%s/dmesg-ramoops-0' % (outdir), 3798, '8059335ab4cfa62c77324c491659c503')
 | 
						|
    checkfile(u_boot_console, '%s/dmesg-ramoops-1' % (outdir), 4035, '3ff30df3429d81939c75d0070b5187b9')
 | 
						|
    checkfile(u_boot_console, '%s/console-ramoops-0' % (outdir), 4084, 'bb44de4a9b8ebd9b17ae98003287325b')
 | 
						|
 | 
						|
    shutil.rmtree(outdir)
 |