blob: 632841cad5a50a19aa80a08e6d22d0f2444ec79a [file] [log] [blame]
George Keishinge7e91712021-09-03 11:28:44 -05001#!/usr/bin/env python3
Michael Walshffe21d72018-08-20 15:01:58 -05002
3r"""
4See help text for details.
5"""
6
George Keishinge635ddc2022-12-08 07:38:02 -06007import sys
8
Sridevi Ramesh47375aa2022-12-08 05:05:31 -06009save_path_0 = sys.path[0]
10del sys.path[0]
11
Patrick Williams20f38712022-12-08 06:18:26 -060012from gen_arg import * # NOQA
13from gen_print import * # NOQA
14from gen_valid import * # NOQA
15from openbmc_ffdc_list import * # NOQA
George Keishing37c58c82022-12-08 07:42:54 -060016
Michael Walshffe21d72018-08-20 15:01:58 -050017# Restore sys.path[0].
18sys.path.insert(0, save_path_0)
19
20# Set exit_on_error for gen_valid functions.
21set_exit_on_error(True)
22
23parser = argparse.ArgumentParser(
Patrick Williamsa57fef42022-12-03 07:00:14 -060024 usage="%(prog)s [OPTIONS]",
Patrick Williams20f38712022-12-08 06:18:26 -060025 description=(
26 "%(prog)s will print a colon-delimited list of all valid OBMC FFDC"
27 " functions.\n\nExample:"
28 )
29 + "\n\n\nDump Log:FFDC Generic Report:Get Request FFDC:SEL Log:BMC"
30 " Specific Files:Sys Inventory Files"
Patrick Williamsa57fef42022-12-03 07:00:14 -060031 + ":Core Files:OS FFDC:Dump Files",
Michael Walshffe21d72018-08-20 15:01:58 -050032 formatter_class=argparse.RawDescriptionHelpFormatter,
Patrick Williamsa57fef42022-12-03 07:00:14 -060033 prefix_chars="-+",
34)
Michael Walshffe21d72018-08-20 15:01:58 -050035
36# Populate stock_list with options we want.
37stock_list = [("test_mode", 0), ("quiet", 1), ("debug", 0)]
38
39
Patrick Williamsa57fef42022-12-03 07:00:14 -060040def exit_function(signal_number=0, frame=None):
Michael Walshffe21d72018-08-20 15:01:58 -050041 r"""
42 Execute whenever the program ends normally or with the signals that we catch (i.e. TERM, INT).
43 """
44
45 dprint_executing()
46 dprint_var(signal_number)
47
48 qprint_pgm_footer()
49
50
Patrick Williamsa57fef42022-12-03 07:00:14 -060051def signal_handler(signal_number, frame):
Michael Walshffe21d72018-08-20 15:01:58 -050052 r"""
53 Handle signals. Without a function to catch a SIGTERM or SIGINT, our program would terminate immediately
54 with return code 143 and without calling our exit_function.
55 """
56
57 # Our convention is to set up exit_function with atexit.register() so there is no need to explicitly
58 # call exit_function from here.
59
60 dprint_executing()
61
62 # Calling exit prevents us from returning to the code that was running when we received the signal.
63 exit(0)
64
65
66def validate_parms():
67 r"""
68 Validate program parameters, etc.
69 """
70
71 gen_post_validation(exit_function, signal_handler)
72
73
74def main():
Michael Walshffe21d72018-08-20 15:01:58 -050075 gen_get_options(parser, stock_list)
76
77 validate_parms()
78
79 qprint_pgm_header()
80
81 my_openbmc_ffdc_list = openbmc_ffdc_list()
Patrick Williamsa57fef42022-12-03 07:00:14 -060082 ffdc_function_list = my_openbmc_ffdc_list.get_ffdc_method_desc("BMC LOGS")
Michael Walshffe21d72018-08-20 15:01:58 -050083 # Convert from list to colon-delimited string.
Patrick Williamsa57fef42022-12-03 07:00:14 -060084 ffdc_function_list = ":".join(ffdc_function_list)
Michael Walshffe21d72018-08-20 15:01:58 -050085 print(ffdc_function_list)
86
87
88main()