13e3f28b4SMichael Tritz#!/bin/sh 23e3f28b4SMichael Tritz 3ab741df3SJayanth Othayoth# TODO openbmc/openbmc#1622 remove -e option related changes. 4ab741df3SJayanth Othayoth 53e3f28b4SMichael Tritzhelp=$'FFDC File Collection Script 63e3f28b4SMichael Tritz 73e3f28b4SMichael TritzCollects various FFDC files and system parameters and places them in a .tar 83e3f28b4SMichael Tritz 93e3f28b4SMichael Tritzusage: ffdc [OPTION] 103e3f28b4SMichael Tritz 113e3f28b4SMichael TritzOptions: 123e3f28b4SMichael Tritz -d, --dir <directory> Specify destination directory. Defaults to /tmp if 133e3f28b4SMichael Tritz invalid or unspecified. 14ab741df3SJayanth Othayoth -e, --enable_dump Enable BMC Dump specific features. 153e3f28b4SMichael Tritz -h, --help Display this help text and exit. 163e3f28b4SMichael Tritz' 173e3f28b4SMichael Tritz 183e3f28b4SMichael Tritzdeclare -a arr=( 193e3f28b4SMichael Tritz# Commands to be outputted into individual files 203e3f28b4SMichael Tritz# Format: "File name" "Command" 213e3f28b4SMichael Tritz "Build_info.txt" "cat /etc/version" 223e3f28b4SMichael Tritz "FW_level.txt" "cat /etc/os-release" 233e3f28b4SMichael Tritz "BMC_OS.txt" "uname -a" 243e3f28b4SMichael Tritz "BMC_uptime.txt" "uptime" 253e3f28b4SMichael Tritz "BMC_disk_usage.txt" "df -hT" 263e3f28b4SMichael Tritz 273e3f28b4SMichael Tritz "systemctl_status.txt" "systemctl status | cat" 283e3f28b4SMichael Tritz "failed_services.txt" "systemctl --failed" 293e3f28b4SMichael Tritz "host_console.txt" "cat /var/log/obmc-console.log" 303e3f28b4SMichael Tritz 313e3f28b4SMichael Tritz "BMC_proc_list.txt" "top -n 1 -b" 323e3f28b4SMichael Tritz "BMC_journalctl.txt" "journalctl --no-pager" 333e3f28b4SMichael Tritz "BMC_dmesg.txt" "dmesg" 343e3f28b4SMichael Tritz "BMC_procinfo.txt" "cat /proc/cpuinfo" 353e3f28b4SMichael Tritz "BMC_meminfo.txt" "cat /proc/meminfo" 363e3f28b4SMichael Tritz 373e3f28b4SMichael Tritz# Copy all content from these directories into directories in the .tar 383e3f28b4SMichael Tritz# Format: "Directory name" "Directory to copy" 393e3f28b4SMichael Tritz "obmc" "/var/lib/obmc/" 40*5cca05a8SJayanth Othayoth "core" "/var/lib/systemd/coredump" 413e3f28b4SMichael Tritz) 423e3f28b4SMichael Tritz 433e3f28b4SMichael Tritzdir=$"ffdc_$(date +"%Y-%m-%d_%H-%M-%S")" 443e3f28b4SMichael Tritzdest="/tmp" 45ab741df3SJayanth Othayothenable_dump=false 463e3f28b4SMichael Tritz 473e3f28b4SMichael Tritzwhile [[ $# -gt 0 ]]; do 483e3f28b4SMichael Tritz key="$1" 493e3f28b4SMichael Tritz case $key in 503e3f28b4SMichael Tritz -d|--dir) 51599c7afeSJayanth Othayoth mkdir -p "$2" 52599c7afeSJayanth Othayoth if [ $? -eq 0 ]; then 533e3f28b4SMichael Tritz dest="$2" 543e3f28b4SMichael Tritz else 55599c7afeSJayanth Othayoth echo "Failed to create the destination directory specified." 563e3f28b4SMichael Tritz break 573e3f28b4SMichael Tritz fi 583e3f28b4SMichael Tritz shift 2 593e3f28b4SMichael Tritz ;; 60ab741df3SJayanth Othayoth -e|--enable_dump) 61ab741df3SJayanth Othayoth enable_dump=true 62ab741df3SJayanth Othayoth shift 63ab741df3SJayanth Othayoth ;; 643e3f28b4SMichael Tritz -h|--help) 653e3f28b4SMichael Tritz echo "$help" 663e3f28b4SMichael Tritz exit 673e3f28b4SMichael Tritz ;; 683e3f28b4SMichael Tritz *) 693e3f28b4SMichael Tritz echo "Unknown option $1. Display available options with -h or --help" 703e3f28b4SMichael Tritz exit 713e3f28b4SMichael Tritz ;; 723e3f28b4SMichael Tritz esac 733e3f28b4SMichael Tritzdone 743e3f28b4SMichael Tritz 753e3f28b4SMichael Tritzecho "Using destination directory $dest" 763e3f28b4SMichael Tritz 77ab741df3SJayanth Othayothif [ $enable_dump = true ]; then 78ab741df3SJayanth Othayoth id=$(basename $dest) 79ab741df3SJayanth Othayoth printf -v f_id "%08d" $id 80ab741df3SJayanth Othayoth dir=$"obmcdump_"$f_id"_$(date +"%s")" 81ab741df3SJayanth Othayothfi 82ab741df3SJayanth Othayoth 83a19440dcSJayanth Othayothmkdir -p "$dest/$dir" 843e3f28b4SMichael Tritz 853e3f28b4SMichael Tritzfor ((i=0;i<${#arr[@]};i+=2)); do 863e3f28b4SMichael Tritz if [ -d "${arr[i+1]}" ]; then 873e3f28b4SMichael Tritz echo "Copying contents of ${arr[i+1]} to directory ./${arr[i]} ..." 883e3f28b4SMichael Tritz mkdir "$dest/$dir/${arr[i]}" 893e3f28b4SMichael Tritz cp -r ${arr[i+1]}/* $dest/$dir/${arr[i]} 903e3f28b4SMichael Tritz else 913e3f28b4SMichael Tritz echo "Collecting ${arr[i]}..." 923e3f28b4SMichael Tritz ${arr[i+1]} >> "$dest/$dir/${arr[i]}" 933e3f28b4SMichael Tritz fi 943e3f28b4SMichael Tritzdone 953e3f28b4SMichael Tritz 96a19440dcSJayanth Othayothtar -cf "$dest/$dir.tar" -C $dest $dir 973e3f28b4SMichael Tritzecho "Contents in $dest/$dir.tar" 983e3f28b4SMichael Tritz 993e3f28b4SMichael Tritzrm -r "$dest/$dir" 100