a ”ˆ«hVzã@sˆddlmZddlTddlZddlmZddlmZddl Z ddl Z ddl Z ddl Z ddl Z ddl Z ej ¡ZdZGdd„dejƒZdS) é)Úhotplug)Ú*éN)Úcommandsz$/sys/devices/system/cpu/cpu0/cpuidlecs^eZdZdZ‡fdd„Zdd„Zdd„Zedd „ƒZd d „Z d d „Z dd„Z dd„Z dd„Z dd„Zdd„Zdd„Zdd„Zdd„Z‡fdd„Zd d!„Zd"d#„Zd$d%„Z‡fd&d'„Zejf‡fd(d)„ Zd*d+„Zd,d-„Zd.d/„Zd0d1„Zd2d3„Zdvd5d6„Z dwd7d8„Z!dxd9d:„Z"d;d<„Z#d=d>„Z$e%d?d@dAdBdC„ƒZ&e'd?ƒdydDdE„ƒZ(dzdGdH„Z)e%dId@dJdKdLdM„ƒZ*e'dIƒd{dNdO„ƒZ+dPdQ„Z,dRdS„Z-d|dTdU„Z.dVdW„Z/e%dXd@dAdYdZ„ƒZ0d[d\„Z1d]d^„Z2d_d`„Z3e'dXƒd}dadb„ƒZ4dcdd„Z5dedf„Z6e%dgd@dAdhdi„ƒZ7e'dgƒd~djdk„ƒZ8e%dld@dAdmdn„ƒZ9e'dlƒddodp„ƒZ:e%dqd@dAdrds„ƒZ;e'dqƒd€dtdu„ƒZ<‡Z=S)ÚCPULatencyPluginaŒ Sets the CPU governor to the value specified by the [option]`governor` option and dynamically changes the Power Management Quality of Service (PM QoS) CPU Direct Memory Access (DMA) latency according to the CPU load. `governor`::: The [option]`governor` option of the 'cpu' plug-in supports specifying CPU governors. Multiple governors are separated using '|'. The '|' character is meant to represent a logical 'or' operator. Note that the same syntax is used for the [option]`energy_perf_bias` option. *TuneD* will set the first governor that is available on the system. + .Specifying a CPU governor ==== ---- [cpu] governor=ondemand|powersave ---- *TuneD* will set the 'ondemand' governor, if it is available. If it is not available, but the 'powersave' governor is available, 'powersave' will be set. If neither of them are available, the governor will not be changed. ==== `sampling_down_factor`::: The sampling rate determines how frequently the governor checks to tune the CPU. The [option]`sampling_down_factor` is a tunable that multiplies the sampling rate when the CPU is at its highest clock frequency thereby delaying load evaluation and improving performance. Allowed values for sampling_down_factor are 1 to 100000. + .The recommended setting for jitter reduction ==== ---- [cpu] sampling_down_factor = 100 ---- ==== `energy_perf_bias`::: [option]`energy_perf_bias` supports managing energy vs. performance policy via x86 Model Specific Registers using the `x86_energy_perf_policy` tool. Multiple alternative Energy Performance Bias (EPB) values are supported. The alternative values are separated using the '|' character. The following EPB values are supported starting with kernel 4.13: "performance", "balance-performance", "normal", "balance-power" and "power". On newer processors is value writen straight to file (see rhbz#2095829) + .Specifying alternative Energy Performance Bias values ==== ---- [cpu] energy_perf_bias=powersave|power ---- *TuneD* will try to set EPB to 'powersave'. If that fails, it will try to set it to 'power'. ==== `energy_performance_preference`::: [option]`energy_performance_preference` supports managing energy vs. performance hints on newer Intel and AMD processors with active P-State CPU scaling drivers (intel_pstate or amd-pstate). Multiple alternative Energy Performance Preferences (EPP) values are supported. The alternative values are separated using the '|' character. Available values can be found in `energy_performance_available_preferences` file in `CPUFreq` policy directory in `sysfs`. in + .Specifying alternative Energy Performance Hints values ==== ---- [cpu] energy_performance_preference=balance_power|power ---- *TuneD* will try to set EPP to 'balance_power'. If that fails, it will try to set it to 'power'. ==== `latency_low, latency_high, load_threshold`::: + If the CPU load is lower than the value specified by the [option]`load_threshold` option, the latency is set to the value specified either by the [option]`latency_high` option or by the [option]`latency_low` option. `force_latency`::: You can also force the latency to a specific value and prevent it from dynamically changing further. To do so, set the [option]`force_latency` option to the required latency value. + The maximum latency value can be specified in several ways: + -- * by a numerical value in microseconds (for example, `force_latency=10`) * as the kernel CPU idle level ID of the maximum C-state allowed (for example, force_latency = cstate.id:1) * as a case sensitive name of the maximum C-state allowed (for example, force_latency = cstate.name:C1) * by using 'None' as a fallback value to prevent errors when alternative C-state IDs/names do not exist. When 'None' is used in the alternatives pipeline, all the alternatives that follow 'None' are ignored. -- + It is also possible to specify multiple fallback values separated by '|' as the C-state names and/or IDs may not be available on some systems. + .Specifying fallback C-state values ==== ---- [cpu] force_latency=cstate.name:C6|cstate.id:4|10 ---- This configuration tries to obtain and set the latency of C-state named C6. If the C-state C6 does not exist, kernel CPU idle level ID 4 (state4) latency is searched for in sysfs. Finally, if the state4 directory in sysfs is not found, the last latency fallback value is `10` us. The value is encoded and written into the kernel's PM QoS file `/dev/cpu_dma_latency`. ==== + .Specifying fallback C-state values using 'None'. ==== ---- [cpu] force_latency=cstate.name:XYZ|None ---- In this case, if C-state with the name `XYZ` does not exist, no latency value will be written into the kernel's PM QoS file, and no errors will be reported due to the presence of 'None'. ==== `min_perf_pct, max_perf_pct, no_turbo`::: These options set the internals of the Intel P-State driver exposed via the kernel's `sysfs` interface. + .Adjusting the configuration of the Intel P-State driver ==== ---- [cpu] min_perf_pct=100 ---- Limit the minimum P-State that will be requested by the driver. It states it as a percentage of the max (non-turbo) performance level. ==== `pm_qos_resume_latency_us`::: This option allow to set specific latency for all cpus or specific ones. + .Configuring resume latency ==== ---- [cpu] pm_qos_resume_latency_us=n/a ---- Special value that disables C-states completely. ---- [cpu] pm_qos_resume_latency_us=0 ---- Allows all C-states. ---- [cpu] pm_qos_resume_latency_us=100 ---- Allows any C-state with a resume latency less than 100. ==== `boost`::: The [option]`boost` option allows the CPU to boost above nominal frequencies for shorts periods of time. On Intel systems with the intel_pstate driver, setting boost=0 will automatically set no_turbo=1 to ensure boost is properly disabled. + .Allowing CPU boost ==== ---- [cpu] boost=1 ---- ==== cs|tt|ƒj|i|¤Žd|_d|_d|_d|_d|_d|_d|_ d|_ d|_ d|_ d|_ d|_d|_i|_tƒ|_d|_dS)NTÚx86_64F)ÚsuperrÚ__init__Ú _has_pm_qosÚ_archZ_is_x86Ú _is_intelÚ_is_amdÚ _has_hwp_eppÚ _has_energy_perf_policy_and_biasÚ_has_intel_pstateÚ_has_amd_pstateÚ_has_pm_qos_resume_latency_usÚ_min_perf_pct_saveÚ_max_perf_pct_saveÚ_no_turbo_saveÚ_governors_maprÚ_cmdÚ_flags)ÚselfÚargsÚkwargs©Ú __class__©úîóz8CPULatencyPlugin._get_device_objects..r)rZdevicesrr)rÚ_get_device_objectsísz$CPULatencyPlugin._get_device_objectscCs ddddddddddddddœ S)Ngš™™™™™É?édiè) Úload_thresholdÚ latency_lowÚ latency_highÚ force_latencyÚgovernorÚsampling_down_factorÚenergy_perf_biasÚ min_perf_pctÚ max_perf_pctÚno_turboÚpm_qos_resume_latency_usÚenergy_performance_preferenceÚboostrr)rrrÚ_get_config_optionsðsóz$CPULatencyPlugin._get_config_optionscCs¼gd¢}t ¡|_|j|vrnt ¡}|j d¡}|dkr@d|_n|dksP|dkrXd|_nd|_t   d|¡nt   d|j¡t j |  ¡v|_|jrª|js¢| ¡| ¡|jr¸| ¡dS) N)rZi686Zi585Zi486Zi386Z vendor_idZ GenuineIntelTZ AuthenticAMDZ HygonGenuinez$We are running on an x86 %s platformzWe are running on %s (non x86))ÚplatformÚmachiner ÚprocfsÚcpuinfoÚtagsÚgetr r ÚlogÚinfoÚconstsZCFG_CPU_EPP_FLAGÚ_get_cpuinfo_flagsrÚ"_check_energy_perf_policy_and_biasÚ_check_intel_pstateÚ_check_amd_pstate)rZ intel_archsr ZvendorrrrÚ _check_archs&   zCPULatencyPlugin._check_archcCs\d}|jjddgtj|gd\}}|dkr:|dkr:d|_n|dkrNt d¡n t d ¡d S) z_Check for EPB via x86_energy_perf_policy, warn if the tool is not available or EPB unsupported.rÚx86_energy_perf_policyú-r)Z no_errorsrÚTzgunable to run x86_energy_perf_policy tool, ignoring CPU energy performance bias, is the tool installed?zXyour CPU doesn't support MSR_IA32_ENERGY_PERF_BIAS, ignoring CPU energy performance biasN)rÚexecuteÚerrnoÚENOENTrrBÚwarning)rZretcode_unsupportedÚretcodeÚoutrrrrF%s z3CPULatencyPlugin._check_energy_perf_policy_and_biascCs"tj d¡|_|jrt d¡dS)Nz$/sys/devices/system/cpu/intel_pstatezintel_pstate detected)ÚosÚpathÚexistsrrBrCr)rrrrG3sz$CPULatencyPlugin._check_intel_pstatecCs"tj d¡|_|jrt d¡dS)Nz"/sys/devices/system/cpu/amd_pstatezamd-pstate detected)rSrTrUrrBrCr)rrrrH8sz"CPULatencyPlugin._check_amd_pstatecCs$|jdurt ¡j dg¡|_|jS)NÚflags)rr>r?r@rAr)rrrrE=s z#CPULatencyPlugin._get_cpuinfo_flagscCs t|ƒ}|j t|ƒ dd¡¡S)Nr rL)ÚstrrZ is_cpu_onlineÚreplace)rr%ÚsdrrrÚ_is_cpu_onlineBszCPULatencyPlugin._is_cpu_onlinecCstj d|¡S)Nú3/sys/devices/system/cpu/%s/cpufreq/scaling_governor)rSrTrUr$rrrÚ_cpu_has_scaling_governorFsz*CPULatencyPlugin._cpu_has_scaling_governorcCs<| |¡st d|¡dS| |¡s8t d|¡dSdS)Nz'%s' is not online, skippingFz.there is no scaling governor fo '%s', skippingT)rZrBÚdebugr\r$rrrÚ_check_cpu_can_change_governorIs  z/CPULatencyPlugin._check_cpu_can_change_governorcCsèd|_d|_d|_t|j ¡ƒd|kr d|_zt t j tj ¡|_ Wn(t ylt dt j ¡d|_Yn0d|_|jddur–|jddur–d|_| ¡nd|_t d|j¡zt|jƒd|_Wntyâd|_Yn0dS)NTFrz-Unable to open '%s', disabling PM_QoS controlr1r8zILatency settings from non-first CPU plugin instance '%s' will be ignored.)Z_has_static_tuningZ_has_dynamic_tuningÚ _load_monitorÚlistZ _instancesÚvaluesÚ_first_instancerSÚopenrDZPATH_CPU_DMA_LATENCYÚO_WRONLYÚ_cpu_latency_fdÚOSErrorrBrCr Ú_latencyÚoptionsrIÚnameZassigned_devicesÚ _first_deviceÚ IndexError©rÚinstancerrrÚ_instance_initRs(    zCPULatencyPlugin._instance_initcCs4|jr0|jrt |j¡|jdur0|j |j¡dS©N)rbr rSÚcloserer_Ú_monitors_repositoryÚdeleterlrrrÚ_instance_cleanupns   z"CPULatencyPlugin._instance_cleanupcs*tt|ƒ |¡|jr&|j dd¡|_dS)NÚload)rrÚ_instance_init_dynamicrbrqZcreater_rlrrrruusz'CPULatencyPlugin._instance_init_dynamiccCs|j d|d¡ ¡S)Nú'/sys/devices/system/cpu/intel_pstate/%s)rÚ read_fileÚstrip)rÚattrrrrÚ_get_intel_pstate_attrzsz'CPULatencyPlugin._get_intel_pstate_attrcCs"|dur|jjd||dddS)NrvT)Ú ignore_same)rÚ write_to_file)rryÚvalrrrÚ_set_intel_pstate_attr}sz'CPULatencyPlugin._set_intel_pstate_attrcCs&|dur dS| |¡}| ||¡|Sro)rzr~)rryÚvalueÚvrrrÚ_getset_intel_pstate_attrs   z*CPULatencyPlugin._getset_intel_pstate_attrcs°tt|ƒ |¡|jsdS|j |jd¡}|dur>| |¡|jr¬|j |jd¡}|  d|¡|_ |j |jd¡}|  d|¡|_ |j   |j |jd¡¡}|  d|¡|_dS)Nr1r5r6r7)rrÚ_instance_apply_staticrbZ _variablesÚexpandrhÚ _set_latencyrrrrrZget_boolr)rrmZforce_latency_valueZ new_valuerrrr‚ˆs6ÿ ÿÿÿÿ ÿÿz'CPULatencyPlugin._instance_apply_staticcsLtt|ƒ ||¡|jrH|jrH| d|j¡| d|j¡| d|j¡dS)Nr5r6r7) rrÚ_instance_unapply_staticrbrr~rrr)rrmZrollbackrrrr… s  z)CPULatencyPlugin._instance_unapply_staticcCs| ||¡dSro)Ú_instance_update_dynamic©rrmr%rrrÚ_instance_apply_dynamic¨sz(CPULatencyPlugin._instance_apply_dynamiccCsZ|js J‚||jkrdS|j ¡d}||jdkrF| |jd¡n| |jd¡dS)NÚsystemr.r0r/)rbrjr_Zget_loadrhr„)rrmr%rtrrrr†«s  z)CPULatencyPlugin._instance_update_dynamiccCsdSrorr‡rrrÚ_instance_unapply_dynamic¶sz*CPULatencyPlugin._instance_unapply_dynamicc Cs(z t|ƒWSttfy"YdS0dSro)ÚintÚ ValueErrorÚ TypeError©rÚsrrrÚ_str2int¹s zCPULatencyPlugin._str2intcCs‚i|_t t¡D]l}td|}|jj|dddd}|jj|dddd}|dur|dur| |¡}|dur||j| ¡<qdS)Nz/%s/riT©Zerr_retÚno_errorÚlatency)Úcstates_latencyrSÚlistdirÚcpuidle_states_pathrrwrrx)rÚdZ cstate_pathrir“rrrÚ_read_cstates_latency¿s  z&CPULatencyPlugin._read_cstates_latencyFcCsht d|¡|jdur*t d¡| ¡|j |d¡}|rR|dkrRt d¡dSt dt|ƒ¡|S)Nz)getting latency for cstate with name '%s'zreading cstates latency tablerú"skipping latency 0 as set by paramz!cstate name mapped to latency: %s)rBr]r”r˜rArW)rriÚno_zeror“rrrÚ_get_latency_by_cstate_nameÊs    z,CPULatencyPlugin._get_latency_by_cstate_namecCsŠt dt|ƒ¡| |¡}|dur2t d¡dStdd|}| |jj|ddd¡}|rt|dkrtt d¡dSt d t|ƒ¡|S) Nz'getting latency for cstate with ID '%s'zcstate ID is invalidz /%s/latencyzstate%dTr‘rr™zcstate ID mapped to latency: %s)rBr]rWrr–rrw)rZlidršZ latency_pathr“rrrÚ_get_latency_by_cstate_idÖs    z*CPULatencyPlugin._get_latency_by_cstate_idc Cs^d|_t|ƒ d¡}t d||f¡|D](}zt|ƒ}t d|¡WnútyD|dd…dkr‚|j|dd…dd}n¾|dd …d kr¦| |d d…¡}nš|dd …d krÎ|j|d d…dd}nr|dd …dkrò| |d d…¡}nN|dvrt d¡YdS|r*|dkr*t d¡nt dt|ƒ¡d}Yn0|dur*qVq*|dfS)Nú|z#parsing latency '%s', allow_na '%s'z+parsed directly specified latency value: %drézcstate.id_no_zero:T)ršé z cstate.id:ézcstate.name_no_zero:é z cstate.name:)ZnoneÚNonezlatency 'none' specified)NTún/azlatency 'n/a' specifiedzinvalid latency specified: '%s'F) r”rWÚsplitrBr]r‹rŒrœr›)rr“Úallow_naZ latenciesrrrÚ_parse_latencyås6     zCPULatencyPlugin._parse_latencycCsn| |¡\}}|sj|jrj|dur2t d¡d|_n8|j|krjt d|¡t d|¡}t  |j |¡||_dS)Nztunable to evaluate latency value (probably wrong settings in the 'cpu' section of current profile), disabling PM QoSFzsetting new cpu latency %dÚi) r¦r rBÚerrorrgrCÚstructÚpackrSÚwritere)rr“ÚskipZ latency_binrrrr„s    zCPULatencyPlugin._set_latencycCs|j d|¡ ¡ ¡S)Nz>/sys/devices/system/cpu/%s/cpufreq/scaling_available_governors)rrwrxr¤r$rrrÚ_get_available_governorssz)CPULatencyPlugin._get_available_governorsr2T)Ú per_devicecCsâ| |¡sdSt|ƒ}| d¡}dd„|Dƒ}|D] }t|ƒdkr2t d¡dSq2| |¡}|D]b}||vr®|s¨t d||f¡|jj d|||ržt j gndd d qÞqb|sbt  d ||f¡qbt  d d  |¡¡d}|S)NrcSsg|] }| ¡‘qSr)rx)r'r2rrrr*r+z2CPULatencyPlugin._set_governor..rz.The 'governor' option contains an empty value.z!setting governor '%s' on cpu '%s'r[FT©r’r{z7Ignoring governor '%s' on cpu '%s', it is not supportedz.None of the scaling governors is supported: %sz, )r^rWr¤ÚlenrBr¨r­rCrr|rNrOr]rPÚjoin)rZ governorsr%rmÚsimÚremover2Zavailable_governorsrrrÚ _set_governors>     ÿÿÿÿÿzCPULatencyPlugin._set_governorcCsTd}| |¡sdS|jjd||d ¡}t|ƒdkr:|}|durPt d|¡|S)Nr[©r’rz*could not get current governor on cpu '%s')r^rrwrxr°rBr¨)rr%rmÚignore_missingr2ÚdatarrrÚ _get_governor/s  zCPULatencyPlugin._get_governorÚondemandcCsd|S)Nz7/sys/devices/system/cpu/cpufreq/%s/sampling_down_factorr)rr2rrrÚ_sampling_down_factor_path=sz+CPULatencyPlugin._sampling_down_factor_pathr3rŸ)r®Úpriorityc CsÐd}||jvr|j ¡d|j|<| ||¡}|durHt d|¡dS|t|j ¡ƒvrÌ||j|<| |¡}tj   |¡st d||f¡dSt |ƒ}|sÌt  d||f¡|j j|||rÄtjgndd|S)NzIignoring sampling_down_factor setting for CPU '%s', cannot match governorzTignoring sampling_down_factor setting for CPU '%s', governor '%s' doesn't support itz6setting sampling_down_factor to '%s' for governor '%s'Frµ)rÚclearr¸rBr]r`rarºrSrTrUrWrCrr|rNrO) rr3r%rmr²r³r}r2rTrrrÚ_set_sampling_down_factor@s&       z*CPULatencyPlugin._set_sampling_down_factorcCsF|j|||d}|durdS| |¡}tj |¡s6dS|j |¡ ¡S)N)r¶)r¸rºrSrTrUrrwrx)rr%rmr¶r2rTrrrÚ_get_sampling_down_factor[s  z*CPULatencyPlugin._get_sampling_down_factorcCs*|jjdd|t|ƒgdd\}}}||fS)NrJú-cT)Z return_err)rrMrW)rÚcpu_idrrQrRÚerr_msgrrrÚ_try_set_energy_perf_biasesþû z*CPULatencyPlugin._try_set_energy_perf_biascCsd|S)Nz./sys/devices/system/cpu/cpufreq/policy%s/boostr©rrÀrrrÚ_pstate_boost_pathnsz#CPULatencyPlugin._pstate_boost_pathcCsd||r dndfS)Nz>/sys/devices/system/cpu/cpufreq/policy%s/energy_performance_%sZavailable_preferencesZ preferencer)rrÀZ availablerrrÚ_pstate_preference_pathqsz(CPULatencyPlugin._pstate_preference_pathcCsd|S)Nz4/sys/devices/system/cpu/cpu%s/power/energy_perf_biasrrÃrrrÚ_energy_perf_bias_pathtsz'CPULatencyPlugin._energy_perf_bias_pathr4c Csx| |¡st d|¡dS| d¡}| d¡}|jrÂ| |¡}tj  |¡r®|s¦|D]B} |   ¡} |j j || |rvt jgndddrTt d| |f¡q¦qTt d|¡t|ƒSt d |¡dSn²|jrp|sh|D]„} |   ¡} t d | |f¡| || ¡\} } | d kr&t d| |f¡qhqÔ| d krFt d | ¡qhqÔt d | |f¡qÔt d|¡t|ƒSdSdS)Nú%s is not online, skippingr rFTr¯z5energy_perf_bias successfully set to '%s' on cpu '%s'zPFailed to set energy_perf_bias on cpu '%s'. Is the value in the profile correct?zXFailed to set energy_perf_bias on cpu '%s' because energy_perf_bias file does not exist.z2Trying to set energy_perf_bias to '%s' on cpu '%s'rz"Failed to set energy_perf_bias: %szHCould not set energy_perf_bias to '%s' on cpu '%s', trying another value)rZrBr]Úlstripr¤rrÆrSrTrUrxrr|rNrOrCr¨rWrrÂ) rr4r%rmr²r³rÀÚvalsÚenergy_perf_bias_pathr}rQrÁrrrÚ_set_energy_perf_biaswsl      ÿÿÿÿÿÿ ÿ ÿÿÿz&CPULatencyPlugin._set_energy_perf_biasc Csnz t|ƒ}Wn\tyh}zDzt|dƒ}Wn(tyR}z|}WYd}~n d}~00WYd}~n d}~00|S)Né)r‹rŒ)rrr€ÚerrrÚ_try_parse_num¯s 0zCPULatencyPlugin._try_parse_numcCsddddœ | |¡|¡S)NÚ performanceÚnormalZ powersave)réé©rArÎrŽrrrÚ_energy_perf_policy_to_humanºsz-CPULatencyPlugin._energy_perf_policy_to_humancCsddddddœ | |¡|¡S)NrÏzbalance-performancerÐz balance-powerZpower)rérÑérÒrÓrŽrrrÚ_energy_perf_policy_to_human_v2¾sü ûz0CPULatencyPlugin._energy_perf_policy_to_human_v2c CsØd}| |¡s t d|¡dS| d¡}|jrZ| |¡}tj |¡rÔ|  |j   |¡¡}nz|j rÔ|j   dd|dg¡\}}|dkrÔ| ¡D]J} |  ¡} t| ƒdkr´| | d¡}qÔqˆt| ƒd krˆ|  | d¡}qÔqˆ|S) NrÇr rJr¿rKréré)rZrBr]rÈrrÆrSrTrUr×rrwrrMÚ splitlinesr¤r°rÔ) rr%rmr¶r4rÀrÊrQÚlinesÚlineÚlrrrÚ_get_energy_perf_biasÆs*       z&CPULatencyPlugin._get_energy_perf_biascCsd|S)Nz9/sys/devices/system/cpu/%s/power/pm_qos_resume_latency_usrr$rrrÚ_pm_qos_resume_latency_us_pathßsz/CPULatencyPlugin._pm_qos_resume_latency_us_pathcCs4|jdur.tj | |¡¡|_|js.t d¡|jS)NzGOption 'pm_qos_resume_latency_us' is not supported on current hardware.)rrSrTrUrßrBrCr$rrrÚ_check_pm_qos_resume_latency_usâs   z0CPULatencyPlugin._check_pm_qos_resume_latency_usr8cCsš| |¡st d|¡dS|j|dd\}}|s<| |¡s@dS|dusX|dkrn|dkrnt d||f¡dS|s–|jj| |¡||rŽt j gndd|S) NrÇT)r¥r£rzÚ__name__Ú __module__Ú __qualname__Ú__doc__r r&r,Ú classmethodr;rIrFrGrHrErZr\r^rnrsrurzr~rr‚rDZ ROLLBACK_SOFTr…rˆr†rŠrr˜r›rœr¦r„r­Z command_setr´Z command_getr¸rºr½r¾rÂrÄrÅrÆrËrÎrÔr×rÞrßràrárârçrérìríÚ __classcell__rrrrrs†<   #                 7       '  r)rLrZ decoratorsZ tuned.logsZtunedZtuned.utils.commandsrZ tuned.constsrDrSrNr©r<r>ZlogsrArBr–ZPluginrrrrrÚs