1*fdd8201dSApple OSS Distributionsfrom __future__ import absolute_import, print_function 2*fdd8201dSApple OSS Distributions 3*fdd8201dSApple OSS Distributionsimport os 4*fdd8201dSApple OSS Distributionsimport re 5*fdd8201dSApple OSS Distributions 6*fdd8201dSApple OSS Distributionsdef GetSettingsValues(debugger, setting_variable_name): 7*fdd8201dSApple OSS Distributions """ Queries the lldb internal settings 8*fdd8201dSApple OSS Distributions params: 9*fdd8201dSApple OSS Distributions debugger : lldb.SBDebugger instance 10*fdd8201dSApple OSS Distributions setting_variable_name: str - string name of the setting(eg prompt) 11*fdd8201dSApple OSS Distributions returns: 12*fdd8201dSApple OSS Distributions [] : Array of strings. Empty array if setting is not found/set 13*fdd8201dSApple OSS Distributions """ 14*fdd8201dSApple OSS Distributions retval = [] 15*fdd8201dSApple OSS Distributions settings_val_list = debugger.GetInternalVariableValue(setting_variable_name, debugger.GetInstanceName()) 16*fdd8201dSApple OSS Distributions for s in settings_val_list: 17*fdd8201dSApple OSS Distributions retval.append(str(s)) 18*fdd8201dSApple OSS Distributions return retval 19*fdd8201dSApple OSS Distributions 20*fdd8201dSApple OSS Distributionsdef GetSymbolsFilePathFromModule(m): 21*fdd8201dSApple OSS Distributions """ Get a file path from a module. 22*fdd8201dSApple OSS Distributions params: m - lldb.target.module 23*fdd8201dSApple OSS Distributions returns: 24*fdd8201dSApple OSS Distributions str : path to first file based symbol. Note this might be dir path inside sources. 25*fdd8201dSApple OSS Distributions """ 26*fdd8201dSApple OSS Distributions for s in m.symbols: 27*fdd8201dSApple OSS Distributions if s.type == 8: 28*fdd8201dSApple OSS Distributions return os.path.dirname(str(s.name)) 29*fdd8201dSApple OSS Distributions return "" 30*fdd8201dSApple OSS Distributions 31*fdd8201dSApple OSS Distributionsdef GetSourcePathSettings(binary_path, symbols_path): 32*fdd8201dSApple OSS Distributions """ Parse the binary path and symbols_path to find if source-map setting is applicable 33*fdd8201dSApple OSS Distributions params: 34*fdd8201dSApple OSS Distributions binary_path: str path of the kernel module 35*fdd8201dSApple OSS Distributions symbols_path: str path of the symbols stored in binary. Use 36*fdd8201dSApple OSS Distributions returns: 37*fdd8201dSApple OSS Distributions str : string command to set the source-map setting. 38*fdd8201dSApple OSS Distributions """ 39*fdd8201dSApple OSS Distributions retval = "" 40*fdd8201dSApple OSS Distributions train_re = re.compile(r"dsyms/([a-zA-Z]+)/") 41*fdd8201dSApple OSS Distributions _t_arr = train_re.findall(binary_path) 42*fdd8201dSApple OSS Distributions train = '' 43*fdd8201dSApple OSS Distributions if _t_arr: 44*fdd8201dSApple OSS Distributions train = _t_arr[0] 45*fdd8201dSApple OSS Distributions if not train: 46*fdd8201dSApple OSS Distributions return retval 47*fdd8201dSApple OSS Distributions new_path = "~rc/Software/{}/Projects/".format(train) 48*fdd8201dSApple OSS Distributions new_path = os.path.expanduser(new_path) 49*fdd8201dSApple OSS Distributions new_path = os.path.normpath(new_path) 50*fdd8201dSApple OSS Distributions common_path_re = re.compile("(^.*?Sources/)(xnu.*?)/.*$") 51*fdd8201dSApple OSS Distributions _t_arr = common_path_re.findall(symbols_path) 52*fdd8201dSApple OSS Distributions srcpath = "" 53*fdd8201dSApple OSS Distributions projpath = "xnu" 54*fdd8201dSApple OSS Distributions if _t_arr: 55*fdd8201dSApple OSS Distributions srcpath = "".join(_t_arr[0]) 56*fdd8201dSApple OSS Distributions projpath = _t_arr[0][-1] 57*fdd8201dSApple OSS Distributions else: 58*fdd8201dSApple OSS Distributions return retval 59*fdd8201dSApple OSS Distributions 60*fdd8201dSApple OSS Distributions new_path = new_path + os.path.sep + projpath 61*fdd8201dSApple OSS Distributions cmd = "settings append target.source-map {} {}" 62*fdd8201dSApple OSS Distributions retval = cmd.format(srcpath, new_path) 63*fdd8201dSApple OSS Distributions return retval 64*fdd8201dSApple OSS Distributions 65*fdd8201dSApple OSS Distributionsdef CheckMissingLibs(debugger): 66*fdd8201dSApple OSS Distributions """ Check that required modules are installed. """ 67*fdd8201dSApple OSS Distributions 68*fdd8201dSApple OSS Distributions # Collect lldb_host version 69*fdd8201dSApple OSS Distributions ver_str = debugger.GetVersionString() 70*fdd8201dSApple OSS Distributions lldb_ver = re.search("^lldb.*-(.*)$", ver_str, re.MULTILINE).group(1) 71*fdd8201dSApple OSS Distributions ver = tuple(map(int, lldb_ver.split('.'))) 72*fdd8201dSApple OSS Distributions 73*fdd8201dSApple OSS Distributions # Display correct command to install missing packages. 74*fdd8201dSApple OSS Distributions if ver[1] == 2: 75*fdd8201dSApple OSS Distributions cmd_fmt = "Please install {mod:s}: xcrun --sdk <sdk> python3 -m pip install --user --ignore-installed {mod:s}" 76*fdd8201dSApple OSS Distributions else: 77*fdd8201dSApple OSS Distributions cmd_fmt = "Please install {mod:s}: xcrun pip3 install --user --ignore-installed {mod:s}" 78*fdd8201dSApple OSS Distributions 79*fdd8201dSApple OSS Distributions try: 80*fdd8201dSApple OSS Distributions import macholib 81*fdd8201dSApple OSS Distributions except: 82*fdd8201dSApple OSS Distributions print(cmd_fmt.format(mod="macholib")) 83*fdd8201dSApple OSS Distributions return False 84*fdd8201dSApple OSS Distributions 85*fdd8201dSApple OSS Distributions try: 86*fdd8201dSApple OSS Distributions from future import standard_library 87*fdd8201dSApple OSS Distributions except: 88*fdd8201dSApple OSS Distributions print(cmd_fmt.format(mod="future")) 89*fdd8201dSApple OSS Distributions return False 90*fdd8201dSApple OSS Distributions 91*fdd8201dSApple OSS Distributions return True 92*fdd8201dSApple OSS Distributions 93*fdd8201dSApple OSS Distributionsdef __lldb_init_module(debugger, internal_dict): 94*fdd8201dSApple OSS Distributions 95*fdd8201dSApple OSS Distributions if not CheckMissingLibs(debugger): 96*fdd8201dSApple OSS Distributions print("Can't load LLDB macros. Please install dependencies first.") 97*fdd8201dSApple OSS Distributions return 98*fdd8201dSApple OSS Distributions 99*fdd8201dSApple OSS Distributions debug_session_enabled = False 100*fdd8201dSApple OSS Distributions if "DEBUG_XNU_LLDBMACROS" in os.environ and len(os.environ['DEBUG_XNU_LLDBMACROS']) > 0: 101*fdd8201dSApple OSS Distributions debug_session_enabled = True 102*fdd8201dSApple OSS Distributions prev_os_plugin = "".join(GetSettingsValues(debugger, 'target.process.python-os-plugin-path')) 103*fdd8201dSApple OSS Distributions print("Loading kernel debugging from %s" % __file__) 104*fdd8201dSApple OSS Distributions print("LLDB version %s" % debugger.GetVersionString()) 105*fdd8201dSApple OSS Distributions self_path = "{}".format(__file__) 106*fdd8201dSApple OSS Distributions base_dir_name = self_path[:self_path.rfind("/")] 107*fdd8201dSApple OSS Distributions core_os_plugin = base_dir_name + "/lldbmacros/core/operating_system.py" 108*fdd8201dSApple OSS Distributions osplugin_cmd = "settings set target.process.python-os-plugin-path \"%s\"" % core_os_plugin 109*fdd8201dSApple OSS Distributions intel_whitelist = ['hndl_allintrs', 'hndl_alltraps', 'trap_from_kernel', 'hndl_double_fault', 'hndl_machine_check'] 110*fdd8201dSApple OSS Distributions arm_whitelist = ['_fleh_prefabt', '_ExceptionVectorsBase', '_ExceptionVectorsTable', '_fleh_undef', '_fleh_dataabt', '_fleh_irq', '_fleh_decirq', '_fleh_fiq_generic', '_fleh_dec'] 111*fdd8201dSApple OSS Distributions whitelist_trap_cmd = "settings set target.trap-handler-names %s %s" % (' '.join(intel_whitelist), ' '.join(arm_whitelist)) 112*fdd8201dSApple OSS Distributions xnu_debug_path = base_dir_name + "/lldbmacros/xnu.py" 113*fdd8201dSApple OSS Distributions xnu_load_cmd = "command script import \"%s\"" % xnu_debug_path 114*fdd8201dSApple OSS Distributions disable_optimization_warnings_cmd = "settings set target.process.optimization-warnings false" 115*fdd8201dSApple OSS Distributions 116*fdd8201dSApple OSS Distributions # Single stepping support 117*fdd8201dSApple OSS Distributions report_all_threads_cmd = "settings set target.process.experimental.os-plugin-reports-all-threads false" 118*fdd8201dSApple OSS Distributions step_mode_cmd = "settings set target.process.run-all-threads true" 119*fdd8201dSApple OSS Distributions 120*fdd8201dSApple OSS Distributions source_map_cmd = "" 121*fdd8201dSApple OSS Distributions try: 122*fdd8201dSApple OSS Distributions source_map_cmd = GetSourcePathSettings(base_dir_name, GetSymbolsFilePathFromModule(debugger.GetTargetAtIndex(0).modules[0]) ) 123*fdd8201dSApple OSS Distributions except Exception as e: 124*fdd8201dSApple OSS Distributions pass 125*fdd8201dSApple OSS Distributions if debug_session_enabled : 126*fdd8201dSApple OSS Distributions if len(prev_os_plugin) > 0: 127*fdd8201dSApple OSS Distributions print("\nDEBUG_XNU_LLDBMACROS is set. Skipping the setting of OS plugin from dSYM.\nYou can manually set the OS plugin by running\n" + osplugin_cmd) 128*fdd8201dSApple OSS Distributions else: 129*fdd8201dSApple OSS Distributions print(osplugin_cmd) 130*fdd8201dSApple OSS Distributions debugger.HandleCommand(osplugin_cmd) 131*fdd8201dSApple OSS Distributions print("\nDEBUG_XNU_LLDBMACROS is set. Skipping the load of xnu debug framework.\nYou can manually load the framework by running\n" + xnu_load_cmd) 132*fdd8201dSApple OSS Distributions else: 133*fdd8201dSApple OSS Distributions print(osplugin_cmd) 134*fdd8201dSApple OSS Distributions debugger.HandleCommand(osplugin_cmd) 135*fdd8201dSApple OSS Distributions print(whitelist_trap_cmd) 136*fdd8201dSApple OSS Distributions debugger.HandleCommand(whitelist_trap_cmd) 137*fdd8201dSApple OSS Distributions print(xnu_load_cmd) 138*fdd8201dSApple OSS Distributions debugger.HandleCommand(xnu_load_cmd) 139*fdd8201dSApple OSS Distributions print(disable_optimization_warnings_cmd) 140*fdd8201dSApple OSS Distributions debugger.HandleCommand(disable_optimization_warnings_cmd) 141*fdd8201dSApple OSS Distributions print(report_all_threads_cmd) 142*fdd8201dSApple OSS Distributions debugger.HandleCommand(report_all_threads_cmd) 143*fdd8201dSApple OSS Distributions print(step_mode_cmd) 144*fdd8201dSApple OSS Distributions debugger.HandleCommand(step_mode_cmd) 145*fdd8201dSApple OSS Distributions if source_map_cmd: 146*fdd8201dSApple OSS Distributions print(source_map_cmd) 147*fdd8201dSApple OSS Distributions debugger.HandleCommand(source_map_cmd) 148*fdd8201dSApple OSS Distributions 149*fdd8201dSApple OSS Distributions load_kexts = True 150*fdd8201dSApple OSS Distributions if "XNU_LLDBMACROS_NOBUILTINKEXTS" in os.environ and len(os.environ['XNU_LLDBMACROS_NOBUILTINKEXTS']) > 0: 151*fdd8201dSApple OSS Distributions load_kexts = False 152*fdd8201dSApple OSS Distributions builtinkexts_path = os.path.join(os.path.dirname(self_path), "lldbmacros", "builtinkexts") 153*fdd8201dSApple OSS Distributions if os.access(builtinkexts_path, os.F_OK): 154*fdd8201dSApple OSS Distributions kexts = os.listdir(builtinkexts_path) 155*fdd8201dSApple OSS Distributions if len(kexts) > 0: 156*fdd8201dSApple OSS Distributions print("\nBuiltin kexts: %s\n" % kexts) 157*fdd8201dSApple OSS Distributions if load_kexts == False: 158*fdd8201dSApple OSS Distributions print("XNU_LLDBMACROS_NOBUILTINKEXTS is set, not loading:\n") 159*fdd8201dSApple OSS Distributions for kextdir in kexts: 160*fdd8201dSApple OSS Distributions # Python does not handle well modules that contain '-' in their names. 161*fdd8201dSApple OSS Distributions # Remap such scripts to use '_' instead. 162*fdd8201dSApple OSS Distributions script_name = kextdir.split('.')[-1].replace('-', '_') + ".py" 163*fdd8201dSApple OSS Distributions script = os.path.join(builtinkexts_path, kextdir, script_name) 164*fdd8201dSApple OSS Distributions 165*fdd8201dSApple OSS Distributions import_kext_cmd = "command script import \"%s\"" % script 166*fdd8201dSApple OSS Distributions print("%s" % import_kext_cmd) 167*fdd8201dSApple OSS Distributions if load_kexts: 168*fdd8201dSApple OSS Distributions debugger.HandleCommand(import_kext_cmd) 169*fdd8201dSApple OSS Distributions 170*fdd8201dSApple OSS Distributions print("\n") 171*fdd8201dSApple OSS Distributions 172