2Yc@sddlZddljZddlZddlZddlZddlmZddl Z ddl m Z m Z ej jZdefdYZdS(iN(tcommands(tPopentPIPEtPlugincBsEeZdZdZdZedZedZedZ dZ dZ dZ d Z d Zd Zd Zd ZdZdZdZdZdZdZdZdZdZedZdZdZdZedZ dZ!dZ"edZ#dZ$d Z%d!Z&d"Z'd#Z(d$Z)d:d%Z+d:d&Z,d:d'Z-d:d(Z.d)Z/d*Z0d+Z1d,Z2d-Z3d:ed.Z4d:d:d/Z5d0Z6d1Z7d2Z8d:d3Z9d4Z:d5Z;d6Z<d7Z=d8Z>d9Z?RS(;s Base class for all plugins. Plugins change various system settings in order to get desired performance or power saving. Plugins use Monitor objects to get information from the running system. Intentionally a lot of logic is included in the plugin to increase plugin flexibility. c Cs|j|jj|_||_||_||_||_||_t j |_ |j |j ||_||_t|_|j|_t|_dS(sPlugin constructor.N(tcreatet __class__t__name__t_storaget_monitors_repositoryt_hardware_inventoryt_device_matchert_device_matcher_udevt_instance_factoryt collectionst OrderedDictt _instancest_init_commandst _init_devicest _global_cfgt _variablestFalset_has_dynamic_optionst#_get_config_options_used_by_dynamict_options_used_by_dynamicRt_cmd( tselftmonitors_repositorytstorage_factorythardware_inventorytdevice_matchertdevice_matcher_udevtinstance_factoryt global_cfgt variables((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt__init__s          cCs|jdS(N(tdestroy_instances(R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytcleanup,scCs'|jjjddjdddS(Nt.it_i(Rt __module__tsplit(R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytname/scCsiS(s-Default configuration options for the plugin.((R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_get_config_options7scCsgS(snList of config options used by dynamic tuning. Their previous values will be automatically saved and restored.((R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR<scCsj|jj}xQ|D]I}||ks4|jrE||||t|tkr|St|j}|dkp=|dkS(Nttruet1(ttypetbooltstrtlower(Rtvalue((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt _option_boolLsc Csf||jkr"td|n|j|}|jj|||||||}||j|<|S(s8Create new instance of the plugin and seize the devices.s.Plugin instance with name '%s' already exists.(Rt ExceptionR1R R( RR)tdevices_expressiontdevices_udev_regext script_pret script_postR.teffective_optionstinstance((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytcreate_instanceVs cCs{|j|kr(td||fn|j|jkrMtd|n|j|j}|j||j|j=dS(sDestroy existing instance.s9Plugin instance '%s' does not belong to this plugin '%s'.s+Plugin instance '%s' was already destroyed.N(t_pluginR:R)Rt_destroy_instance(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytdestroy_instancebs cCs.tjd|j|jf|j|dS(sInitialize an instance.sinitializing instance %s (%s)N(R,tdebugR)t_instance_init(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytinitialize_instancemscCsUxA|jjD]0}tjd|j|jf|j|qW|jjdS(sDestroy all instances.sdestroying instance %s (%s)N(RtvaluesR,RER)RCtclear(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR#rscCs|j||j|dS(N(trelease_devicest_instance_cleanup(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRCys cCs tdS(N(tNotImplementedError(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRF}scCs tdS(N(RL(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRKscCs%t|_t|_t|_dS(N(Rt_devices_supportedtsett_assigned_devicest _free_devices(R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRs  cCsdS(sOverride this in a subclass to transform a list of device names (e.g. ['sda']) to a list of pyudev.Device objects, if your plugin supports itN(tNone(Rtdevices((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_get_device_objectsscCs|jdkr+t|jj|j|S|j|}|dkr`tjd|j tS|j j|j|}tt d|SdS(Ns<Plugin '%s' does not support the 'devices_udev_regex' optioncSs|jS(N(tsys_name(tx((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyts( R<RQRNR t match_listR;RSR,terrorR)R tmap(RR@RRt udev_devices((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_get_matching_devicess cCs|js dStjd|j|j||j}t|dk|_|jsktjd|jn}|j}|j|jkr|d|j7}ntj d|dj |f|j j ||j |O_ |j|8_dS(Ns assigning devices to instance %sis*instance %s: no matching devices availables (%s)s!instance %s: assigning devices %ss, (RMR,RER)R[RPtlentactiveR-tinfotjoinRRtupdateRO(RR@t to_assignR)((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytassign_free_devicess    cCsU|js dS|j|j@}t|_|jj|j|8_|j|O_dS(N(RMRRRORR]RIRP(RR@t to_release((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRJs   cCs@|jr|j}n dg}x|D]}|||q%WdS(N(RMRRRQ(RR@tcallbackRRtdevice((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_run_for_each_devices     cCsdS(N((RR@tenabling((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_instance_pre_staticscCsdS(N((RR@Rg((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_instance_post_staticsc Cs|dkrdSt|dkr@tjd|j|fdS|jdsdtjddtStj j |}t }xF|D]>}tj } | j |jj|g} |r| jdn| j|tjd|t| ftjdt| jyzt|g| d td td t d | d |} | j\} } | jrtjd|| j| d ft}nWqttfk r}tjd||ft}qXqW|S(Nis1Instance '%s': no device to call script '%s' for.t/s<Relative paths cannot be used in script_pre or script_post. sUse ${i:PROFILE_DIR}.t full_rollbacks'calling script '%s' with arguments '%s'susing environment '%s'tstdouttstderrt close_fdstenvtcwdsscript '%s' error: %d, '%s'isscript '%s' error: %s(RQR\R,R-R)t startswithRXRtostpathtdirnametTruetenvironR`Rtget_envtappendR^R6REtitemsRRt communicatet returncodetOSErrortIOError(RR@tscripttopRRRktdir_nametrettdevRvt argumentstproctoutterrte((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_call_device_scripts>      (  ! cCs|js dS|jr~|j||jd|j|j|t|j||j|t|j||j d|jn|j r|j j t jt jr|j||jndS(sG Apply static and dynamic tuning if the plugin instance is active. Ntapply(R]thas_static_tuningRR=RRRhRut_instance_apply_staticRiR>thas_dynamic_tuningRtgettconststCFG_DYNAMIC_TUNINGtCFG_DEF_DYNAMIC_TUNINGRft_instance_apply_dynamic(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytinstance_apply_tunings   $cCs|js dS|jr|j||jd|jtkr>tS|j||tkrZtS|j||jd|jtkrtSt SdSdS(s< Verify static tuning if the plugin instance is active. tverifyN( R]RQRRR=RRRt_instance_verify_staticR>Ru(RR@tignore_missing((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytinstance_verify_tunings  $$cCsK|js dS|jrG|jjtjtjrG|j||jndS(s< Apply dynamic tuning if the plugin instance is active. N( R]RRRRRRRft_instance_update_dynamic(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytinstance_update_tunings $cCs|jr:|jjtjtjr:|j||jn|jr|j ||j d|j d||j |t |j|||j|t |j ||jd|j d|ndS(s8 Remove all tunings applied by the plugin instance. tunapplyRkN(RRRRRRRft_instance_unapply_dynamicRRR>RRRhRt_instance_unapply_staticRiR=(RR@Rk((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pytinstance_unapply_tunings$ "cCs$|j||j||jdS(N(t _execute_all_non_device_commandst_execute_all_device_commandsRR(RR@((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR%s cCsRt}|j||tkr't}n|j||j|tkrNt}n|S(N(Rut_verify_all_non_device_commandsRt_verify_all_device_commandsRR(RR@RR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR)s   cCs$|j||j|j|dS(N(t_cleanup_all_device_commandsRRt _cleanup_all_non_device_commands(RR@Rk((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR1scsZxCtfdjD] }jj|q"WjdS(Ncs jj|dkS(N(t _storage_gett _commandsRQ(topt(ReR@R(s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRV6s(tfilterRt_check_and_save_valueRR(RR@Retoption((ReR@Rs6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR5s(cCs tdS(N(RL(RR@Re((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR;scCs tdS(N(RL(RR@Re((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR>scCs'tj|_|j|jdS(s Initialize commands. N(R RRt_autoregister_commandst_check_commands(R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyREs cCsVx%|jjD]}|jdr(q nt||}t|dsLq n|jd}|jj|i|d6}d|jkrd |d<||d<|jd|d<|jd|dd|jkr||d<|jd|d<|jd|dshcannot compare new value '%s' with current value '%s' by operator '%s', using '%s' directly as new value(RR(RQR6R\tintt ValueErrorR,R-(RRt current_valuetnwsRtval((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_process_assignment_modifierss(         $cCs/|dk r |d|d|S|dSdS(NRR(RQ(RRReR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt_get_current_values cCsY|j||}|j||}|dk rU|dk rU|j||||n|S(N(RRRQR(RR@RReRR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRs cCso|ddk r-|dt||ttn>|j||||}|dk rk|d||dtndS(NRRNtsim(RQRuRR(RR@RReR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRs  cCsi|ddk r*|dt|ttn;|j||d|}|dk re|d|dtndS(NRRNR(RQRuRR(RR@RR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRs  cCsA|jjt|}tjd|r=tjdd|S|S(Ns\s*(0+,)+[\da-fA-F]*\s*$s ^\s*(0+,)+t(RtunquoteR6tretmatchtsub(RR8tv((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt _norm_valuescCs|dkrdSt}|dkri|ri|dkrKtjtj|ntjtj||ftS|dk r|j|}|j|}yt |t |k}Wqt k ry"t |dt |dk}Wqt k r t |t |k}qXqXn|r||dkrOtjtj |t |j fn)tjtj||t |j ftS|dkrtjtj|t |j t |j fn8tjtj||t |j t |j ftSdS(Ni(RQRR,R^Rt STR_VERIFY_PROFILE_VALUE_MISSINGt'STR_VERIFY_PROFILE_DEVICE_VALUE_MISSINGRuRRRR6tSTR_VERIFY_PROFILE_VALUE_OKtstript"STR_VERIFY_PROFILE_DEVICE_VALUE_OKRXtSTR_VERIFY_PROFILE_VALUE_FAILt$STR_VERIFY_PROFILE_DEVICE_VALUE_FAIL(RR)RRRReR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyt _verify_values6    " # )) 88cCs|ddk r*|dt||t|S|j||d|}|j||}|dkrddS|d||t}|j|d||||S(NRRRNR)(RQRuRRR(RR@RReRRR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRs cCs|ddk r'|dt|t|S|j|}|j||}|dkrXdS|d|t}|j|d|||S(NRRNR)(RQRuRRR(RR@RRRR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRs cCsuxnttd|jjD]K}|jj|dddk sZ|d|jkr"|j||q"q"WdS(NcSs |d S(NR((R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRV&sR)( treversedRRRHR.RRQRt_cleanup_non_device_command(RR@R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR%s(2cCsxttd|jjD]_}|jj|dddk sZ|d|jkr"x$|D]}|j|||qaWq"q"WdS(NcSs|dS(NR((R((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyRV+sR)( RRRRHR.RRQRt_cleanup_device_command(RR@RRRRe((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR*s(2 cCs|ddk r-|dtd|ttnN|j|||}|dk rh|d||dtn|j|||dS(NRRNR(RQRRR(RR@RRet old_value((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR0s  cCss|ddk r*|dtdttnE|j||}|dk r_|d|dtn|j||dS(NRRNR(RQRRR(RR@RR((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR9s  N(@RR't__doc__R"R$tpropertyR)t classmethodR*RR1R9RARDRGR#RCRFRKRRSR[RbRJRfRhRiRRRRRRRRRRRRRRRRQRRRRRRRRRRRRRRRRRRRRR(((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyR st              !                      "   (Rt tuned.constsRttuned.profiles.variablesttunedt tuned.logsR ttuned.utils.commandsRRrt subprocessRRtlogsRR,tobjectR(((s6/usr/lib/python2.7/site-packages/tuned/plugins/base.pyts