1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367 |
- IPA function summary for prvInitialiseNewTimer.constprop/72 inlinable
- global time: 15.415032
- self size: 22
- global size: 22
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op1 changed)
- size:3.000000, time:1.320005, executed if:(op1 != 0) && (not inlined)
- size:2.000000, time:0.660002, executed if:(op1 != 0)
- size:2.000000, time:0.660002, executed if:(op1 != 0), nonconst if:(op2 changed) && (op1 != 0)
- size:1.000000, time:0.165001, executed if:(op2 != 0) && (op1 != 0) && (not inlined)
- size:2.000000, time:0.330001, executed if:(op2 != 0) && (op1 != 0)
- size:5.000000, time:3.349994, executed if:(op1 == 0)
- calls:
- prvCheckForValidListAndQueue/29 function not considered for inlining
- loop depth: 0 freq:0.33 size: 1 time: 10callee size:12 stack: 0 predicate: (op1 != 0)
- vListInitialiseItem/53 function body not available
- loop depth: 0 freq:0.33 size: 2 time: 11 predicate: (op1 != 0)
- IPA function summary for prvInsertTimerInActiveList.part.0/57 inlinable
- global time: 15.000000
- self size: 7
- global size: 7
- min size: 6
- self stack: 0
- global stack: 0
- size:1.000000, time:1.000000
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- vListInsert/44 function body not available
- loop depth: 0 freq:1.00 size: 3 time: 12
- IPA function summary for vTimerSetTimerNumber/36 inlinable
- global time: 3.000000
- self size: 4
- global size: 4
- min size: 0
- self stack: 0
- global stack: 0
- size:0.500000, time:0.500000
- size:3.500000, time:2.500000, executed if:(not inlined)
- calls:
- IPA function summary for uxTimerGetTimerNumber/35 inlinable
- global time: 3.000000
- self size: 4
- global size: 4
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:3.000000, time:2.000000, executed if:(not inlined)
- size:0.500000, time:0.500000, executed if:(not inlined), nonconst if:(op0[ref offset: 288] changed) && (not inlined)
- size:0.500000, time:0.500000, nonconst if:(op0[ref offset: 288] changed)
- calls:
- IPA function summary for xTimerPendFunctionCall/34 inlinable
- global time: 16.555202
- self size: 21
- global size: 21
- min size: 12
- self stack: 16
- global stack: 16
- size:12.000000, time:7.465300
- size:3.000000, time:1.069400, executed if:(not inlined)
- calls:
- xQueueGenericSend/55 function body not available
- loop depth: 0 freq:0.53 size: 6 time: 15
- op1 is compile time invariant
- op3 is compile time invariant
- IPA function summary for xTimerPendFunctionCallFromISR/33 inlinable
- global time: 22.000000
- self size: 14
- global size: 14
- min size: 12
- self stack: 16
- global stack: 16
- size:5.000000, time:5.000000
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- xQueueGenericSendFromISR/56 function body not available
- loop depth: 0 freq:1.00 size: 6 time: 15
- op1 is compile time invariant
- op3 is compile time invariant
- IPA function summary for vTimerSetTimerID/32 inlinable
- global time: 16.624602
- self size: 13
- global size: 13
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:0.500000, time:0.267350, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for pvTimerGetTimerID/31 inlinable
- global time: 16.624602
- self size: 13
- global size: 13
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:0.500000, time:0.267350, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for xTimerIsTimerActive/30 inlinable
- global time: 17.159302
- self size: 14
- global size: 14
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:1.500000, time:0.802050, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for prvCheckForValidListAndQueue/29 inlinable
- global time: 33.264679
- self size: 25
- global size: 25
- min size: 28
- self stack: 0
- global stack: 0
- size:8.000000, time:3.871500
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:1.00 size: 1 time: 10
- vQueueAddToRegistry/50 function body not available
- loop depth: 0 freq:0.09 size: 3 time: 12
- op1 is compile time invariant
- xQueueGenericCreate/49 function body not available
- loop depth: 0 freq:0.17 size: 5 time: 14
- op0 is compile time invariant
- op1 is compile time invariant
- op2 is compile time invariant
- vListInitialise/48 function body not available
- loop depth: 0 freq:0.17 size: 2 time: 11
- op0 is compile time invariant
- vListInitialise/48 function body not available
- loop depth: 0 freq:0.17 size: 2 time: 11
- op0 is compile time invariant
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:1.00 size: 1 time: 10
- IPA function summary for prvSwitchTimerLists/28 inlinable
- global time: 154.636365
- self size: 15
- global size: 15
- min size: 6
- self stack: 0
- global stack: 0
- size:9.000000, time:55.545455
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- prvProcessExpiredTimer/21 function not considered for inlining
- loop depth: 1 freq:8.09 size: 3 time: 12callee size:11 stack: 0
- op1 is compile time invariant
- IPA function summary for prvProcessReceivedCommands/27 inlinable
- global time: 589.511443
- self size: 112
- global size: 112
- min size: 72
- self stack: 20
- global stack: 20
- size:73.000000, time:192.498507
- size:3.000000, time:1.979424, executed if:(not inlined)
- calls:
- xQueueReceive/46 function body not available
- loop depth: 3 freq:17.99 size: 5 time: 14
- op1 is compile time invariant
- op2 is compile time invariant
- vPortFree/45 function body not available
- loop depth: 1 freq:0.06 size: 2 time: 11
- prvInsertTimerInActiveList/26 function not considered for inlining
- loop depth: 1 freq:0.18 size: 5 time: 14callee size:11 stack: 0
- prvReloadTimer/20 function not considered for inlining
- loop depth: 1 freq:0.03 size: 4 time: 13callee size:10 stack: 0
- prvInsertTimerInActiveList/26 function not considered for inlining
- loop depth: 1 freq:0.19 size: 6 time: 15callee size:11 stack: 0
- prvSampleTimeNow/25 function not considered for inlining
- loop depth: 2 freq:0.94 size: 3 time: 12callee size: 6 stack: 0
- op0 is compile time invariant
- uxListRemove/43 function body not available
- loop depth: 2 freq:0.50 size: 2 time: 11
- indirect call loop depth: 1 freq:0.09 size: 4 time: 16
- indirect call loop depth: 3 freq:6.97 size: 5 time: 17
- IPA function summary for prvInsertTimerInActiveList/26 inlinable
- global time: 15.972500
- self size: 22
- global size: 22
- min size: 12
- self stack: 0
- global stack: 0
- size:2.000000, time:1.332500
- size:4.000000, time:3.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op1 changed || op2 changed)
- size:3.000000, time:1.500000, nonconst if:(op2 changed || op3 changed)
- size:2.000000, time:0.670000, nonconst if:(op1 changed || op3 changed)
- size:0.500000, time:0.250000, executed if:(not inlined), nonconst if:(op0[ref offset: 192] changed) && (not inlined)
- size:0.500000, time:0.250000, nonconst if:(op0[ref offset: 192] changed)
- size:2.000000, time:1.000000, nonconst if:(op2 changed || op3 changed || op0[ref offset: 192] changed)
- calls:
- vListInsert/44 function body not available
- loop depth: 0 freq:0.33 size: 3 time: 12
- prvInsertTimerInActiveList.part.0/57 function not considered for inlining
- loop depth: 0 freq:0.16 size: 3 time: 12callee size: 3 stack: 0
- IPA function summary for prvSampleTimeNow/25 inlinable
- global time: 21.300000
- self size: 12
- global size: 12
- min size: 6
- self stack: 0
- global stack: 0
- size:5.000000, time:4.500000
- size:4.000000, time:2.500000, executed if:(not inlined)
- calls:
- prvSwitchTimerLists/28 function not considered for inlining
- loop depth: 0 freq:0.33 size: 1 time: 10callee size: 7 stack: 0
- xTaskGetTickCount/41 function body not available
- loop depth: 0 freq:1.00 size: 2 time: 11
- IPA function summary for prvGetNextExpireTime/24 inlinable
- global time: 10.000000
- self size: 12
- global size: 12
- min size: 0
- self stack: 0
- global stack: 0
- size:8.500000, time:7.500000
- size:3.500000, time:2.500000, executed if:(not inlined)
- calls:
- IPA function summary for prvProcessTimerOrBlockTask/23 inlinable
- global time: 53.483675
- self size: 38
- global size: 38
- min size: 22
- self stack: 4
- global stack: 4
- size:10.000000, time:6.076975
- size:3.000000, time:2.000000, executed if:(not inlined)
- size:4.000000, time:2.458900, nonconst if:(op1 changed)
- size:2.000000, time:0.670000, executed if:(op1 == 0)
- size:4.000000, time:1.118900, executed if:(op1 != 0)
- calls:
- xTaskResumeAll/39 function body not available
- loop depth: 0 freq:0.33 size: 1 time: 10
- xTaskResumeAll/39 function body not available
- loop depth: 0 freq:0.56 size: 2 time: 11
- vQueueWaitForMessageRestricted/40 function body not available
- loop depth: 0 freq:0.56 size: 4 time: 13
- prvProcessExpiredTimer/21 function not considered for inlining
- loop depth: 0 freq:0.11 size: 3 time: 12callee size:11 stack: 0 predicate: (op1 == 0)
- xTaskResumeAll/39 function body not available
- loop depth: 0 freq:0.11 size: 1 time: 10 predicate: (op1 == 0)
- prvSampleTimeNow/25 function not considered for inlining
- loop depth: 0 freq:1.00 size: 3 time: 12callee size: 6 stack: 0
- op0 is compile time invariant
- vTaskSuspendAll/38 function body not available
- loop depth: 0 freq:1.00 size: 1 time: 10
- IPA function summary for prvTimerTask/22 inlinable
- global time: 350000.594727
- self size: 10
- global size: 10
- min size: 14
- self stack: 4
- global stack: 4
- size:1.000000, time:10000.016983
- size:2.000000, time:0.000000, executed if:(not inlined)
- calls:
- prvProcessReceivedCommands/27 function not considered for inlining
- loop depth: 1 freq:10000.02 size: 1 time: 10callee size:56 stack:20
- prvProcessTimerOrBlockTask/23 function not considered for inlining
- loop depth: 1 freq:10000.02 size: 3 time: 12callee size:19 stack: 4
- prvGetNextExpireTime/24 function not considered for inlining
- loop depth: 1 freq:10000.02 size: 3 time: 12callee size: 6 stack: 0
- op0 is compile time invariant
- IPA function summary for prvProcessExpiredTimer/21 inlinable
- global time: 42.630000
- self size: 23
- global size: 23
- min size: 20
- self stack: 0
- global stack: 0
- size:10.000000, time:9.340000
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- prvReloadTimer/20 function not considered for inlining
- loop depth: 0 freq:0.33 size: 4 time: 13callee size:10 stack: 0
- uxListRemove/43 function body not available
- loop depth: 0 freq:1.00 size: 2 time: 11
- indirect call loop depth: 0 freq:1.00 size: 4 time: 16
- IPA function summary for prvReloadTimer/20 inlinable
- global time: 328.454547
- self size: 20
- global size: 20
- min size: 20
- self stack: 0
- global stack: 0
- size:5.500000, time:48.000000
- size:4.500000, time:14.636364, executed if:(not inlined)
- calls:
- prvInsertTimerInActiveList/26 function not considered for inlining
- loop depth: 1 freq:9.09 size: 6 time: 15callee size:11 stack: 0
- op0 change 10.990000% of time
- op2 change 10.990000% of time
- indirect call loop depth: 1 freq:8.09 size: 4 time: 16
- IPA function summary for pcTimerGetName/19 inlinable
- global time: 5.600001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:0.500000, time:0.350000, executed if:(op0 != 0B) && (not inlined), nonconst if:(op0[ref offset: 0] changed) && (op0 != 0B) && (not inlined)
- size:0.500000, time:0.350000, executed if:(op0 != 0B), nonconst if:(op0[ref offset: 0] changed) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- IPA function summary for xTimerGetExpiryTime/18 inlinable
- global time: 5.600001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:0.500000, time:0.350000, executed if:(op0 != 0B) && (not inlined), nonconst if:(op0[ref offset: 32] changed) && (op0 != 0B) && (not inlined)
- size:0.500000, time:0.350000, executed if:(op0 != 0B), nonconst if:(op0[ref offset: 32] changed) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- IPA function summary for uxTimerGetReloadMode/17 inlinable
- global time: 18.228702
- self size: 16
- global size: 16
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:3.500000, time:1.871450, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for vTimerSetReloadMode/16 inlinable
- global time: 18.763389
- self size: 20
- global size: 20
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:2.000000, time:1.069400, executed if:(op0 != 0B), nonconst if:(op1 changed) && (op0 != 0B)
- size:1.000000, time:0.267348, executed if:(op1 == 0) && (op0 != 0B) && (not inlined)
- size:2.000000, time:0.534696, executed if:(op1 == 0) && (op0 != 0B)
- size:1.000000, time:0.267348, executed if:(op1 != 0) && (op0 != 0B) && (not inlined)
- size:2.000000, time:0.534696, executed if:(op1 != 0) && (op0 != 0B)
- size:1.000000, time:1.069400, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for xTimerGetPeriod/15 inlinable
- global time: 5.600001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:0.500000, time:0.350000, executed if:(op0 != 0B) && (not inlined), nonconst if:(op0[ref offset: 192] changed) && (op0 != 0B) && (not inlined)
- size:0.500000, time:0.350000, executed if:(op0 != 0B), nonconst if:(op0[ref offset: 192] changed) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- IPA function summary for xTimerGetTimerDaemonTaskHandle/14 inlinable
- global time: 5.900001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:8.000000, time:4.500001
- size:3.000000, time:1.399999, executed if:(not inlined)
- calls:
- IPA function summary for xTimerGenericCommand/13 inlinable
- global time: 20.230048
- self size: 42
- global size: 42
- min size: 0
- self stack: 16
- global stack: 16
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:6.000000, time:3.570004, executed if:(op0 != 0B)
- size:2.000000, time:0.980004, executed if:(op0 != 0B), nonconst if:(op1 changed) && (op0 != 0B)
- size:4.000000, time:0.735003, executed if:(op1 <= 5) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- xQueueGenericSendFromISR/56 function body not available
- loop depth: 0 freq:0.25 size: 6 time: 15 predicate: (op1 > 5) && (op0 != 0B)
- op1 is compile time invariant
- op3 is compile time invariant
- xQueueGenericSend/55 function body not available
- loop depth: 0 freq:0.16 size: 6 time: 15 predicate: (op1 <= 5) && (op0 != 0B)
- op1 is compile time invariant
- op2 is compile time invariant
- op3 is compile time invariant
- xQueueGenericSend/55 function body not available
- loop depth: 0 freq:0.08 size: 6 time: 15 predicate: (op1 <= 5) && (op0 != 0B)
- op1 is compile time invariant
- op3 is compile time invariant
- xTaskGetSchedulerState/54 function body not available
- loop depth: 0 freq:0.25 size: 2 time: 11 predicate: (op1 <= 5) && (op0 != 0B)
- IPA function summary for xTimerCreate/11 inlinable
- global time: 25.089900
- self size: 16
- global size: 16
- min size: 20
- self stack: 0
- global stack: 0
- size:3.000000, time:2.534700
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- prvInitialiseNewTimer.constprop/72 function not considered for inlining
- loop depth: 0 freq:0.53 size: 7 time: 16callee size:11 stack: 0
- pvPortMalloc/52 function body not available
- loop depth: 0 freq:1.00 size: 3 time: 12
- op0 is compile time invariant
- IPA function summary for xTimerCreateTimerTask/10 inlinable
- global time: 27.357181
- self size: 22
- global size: 22
- min size: 18
- self stack: 0
- global stack: 0
- size:10.000000, time:7.732635
- size:3.000000, time:0.534703, executed if:(not inlined)
- calls:
- xTaskCreate/37 function body not available
- loop depth: 0 freq:0.53 size: 8 time: 17
- op0 is compile time invariant
- op1 is compile time invariant
- op2 is compile time invariant
- op3 is compile time invariant
- op4 is compile time invariant
- op5 is compile time invariant
- prvCheckForValidListAndQueue/29 function not considered for inlining
- loop depth: 0 freq:1.00 size: 1 time: 10callee size:12 stack: 0
- Flattening functions:
- Overall time estimate: 351507.595703 weighted by profile: 0.000000
- Deciding on inlining of small functions. Starting with size 0.
- Enqueueing calls in prvInitialiseNewTimer.constprop/72.
- Enqueueing calls in prvInsertTimerInActiveList.part.0/57.
- Enqueueing calls in vTimerSetTimerNumber/36.
- Enqueueing calls in uxTimerGetTimerNumber/35.
- Enqueueing calls in xTimerPendFunctionCall/34.
- Enqueueing calls in xTimerPendFunctionCallFromISR/33.
- Enqueueing calls in vTimerSetTimerID/32.
- Enqueueing calls in pvTimerGetTimerID/31.
- Enqueueing calls in xTimerIsTimerActive/30.
- Enqueueing calls in prvCheckForValidListAndQueue/29.
- Enqueueing calls in prvSwitchTimerLists/28.
- Enqueueing calls in prvProcessReceivedCommands/27.
- Enqueueing calls in prvInsertTimerInActiveList/26.
- Enqueueing calls in prvSampleTimeNow/25.
- Enqueueing calls in prvGetNextExpireTime/24.
- Enqueueing calls in prvProcessTimerOrBlockTask/23.
- Enqueueing calls in prvTimerTask/22.
- Enqueueing calls in prvProcessExpiredTimer/21.
- Enqueueing calls in prvReloadTimer/20.
- Enqueueing calls in pcTimerGetName/19.
- Enqueueing calls in xTimerGetExpiryTime/18.
- Enqueueing calls in uxTimerGetReloadMode/17.
- Enqueueing calls in vTimerSetReloadMode/16.
- Enqueueing calls in xTimerGetPeriod/15.
- Enqueueing calls in xTimerGetTimerDaemonTaskHandle/14.
- Enqueueing calls in xTimerGenericCommand/13.
- Enqueueing calls in xTimerCreate/11.
- Enqueueing calls in xTimerCreateTimerTask/10.
- Considering prvGetNextExpireTime/24 with 12 size
- to be inlined into prvTimerTask/22 in ../FreeRTOS/Source/timers.c:586
- Estimated badness is -6041.676941, frequency 10000.02.
- Considering prvProcessTimerOrBlockTask/23 with 38 size
- to be inlined into prvTimerTask/22 in ../FreeRTOS/Source/timers.c:590
- Estimated badness is -416.667376, frequency 10000.02.
- Considering prvSampleTimeNow/25 with 12 size
- to be inlined into prvProcessTimerOrBlockTask/23 in ../FreeRTOS/Source/timers.c:611
- Estimated badness is -7733.346512, frequency 10000.02.
- Considering prvProcessReceivedCommands/27 with 112 size
- to be inlined into prvTimerTask/22 in ../FreeRTOS/Source/timers.c:593
- Estimated badness is -37.600263, frequency 10000.02.
- Considering prvSampleTimeNow/25 with 12 size
- to be inlined into prvProcessReceivedCommands/27 in ../FreeRTOS/Source/timers.c:811
- Estimated badness is -7232.827499, frequency 9352.79.
- Considering prvInitialiseNewTimer.constprop/72 with 22 size
- to be inlined into xTimerCreate/11 in ../FreeRTOS/Source/timers.c:304
- Estimated badness is -0.166209, frequency 0.53.
- Considering prvInsertTimerInActiveList.part.0/57 with 7 size
- to be inlined into prvInsertTimerInActiveList/26 in unknown:0
- Estimated badness is -0.001786, frequency 0.16.
- Reclaiming functions:
- Reclaiming variables:
- Clearing address taken flags:
- Deciding on functions to be inlined into all callers and removing useless speculations:
- Overall time estimate: 6607568.406250 weighted by profile: 0.000000
- Why inlining failed?
- function body not available : 38 calls, 230526.954346 freq, 0 count
- call is unlikely and code size would grow : 11 calls, 11457.497711 freq, 0 count
- IPA function summary for vTimerSetTimerNumber/36 inlinable
- global time: 3.000000
- self size: 4
- global size: 4
- min size: 0
- self stack: 0
- global stack: 0
- size:0.500000, time:0.500000
- size:3.500000, time:2.500000, executed if:(not inlined)
- calls:
- IPA function summary for uxTimerGetTimerNumber/35 inlinable
- global time: 3.000000
- self size: 4
- global size: 4
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:3.000000, time:2.000000, executed if:(not inlined)
- size:0.500000, time:0.500000, executed if:(not inlined), nonconst if:(op0[ref offset: 288] changed) && (not inlined)
- size:0.500000, time:0.500000, nonconst if:(op0[ref offset: 288] changed)
- calls:
- IPA function summary for xTimerPendFunctionCall/34 inlinable
- global time: 16.555202
- self size: 21
- global size: 21
- min size: 12
- self stack: 16
- global stack: 16
- size:12.000000, time:7.465300
- size:3.000000, time:1.069400, executed if:(not inlined)
- calls:
- xQueueGenericSend/55 function body not available
- loop depth: 0 freq:0.53 size: 6 time: 15
- op1 is compile time invariant
- op3 is compile time invariant
- IPA function summary for xTimerPendFunctionCallFromISR/33 inlinable
- global time: 22.000000
- self size: 14
- global size: 14
- min size: 12
- self stack: 16
- global stack: 16
- size:5.000000, time:5.000000
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- xQueueGenericSendFromISR/56 function body not available
- loop depth: 0 freq:1.00 size: 6 time: 15
- op1 is compile time invariant
- op3 is compile time invariant
- IPA function summary for vTimerSetTimerID/32 inlinable
- global time: 16.624602
- self size: 13
- global size: 13
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:0.500000, time:0.267350, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for pvTimerGetTimerID/31 inlinable
- global time: 16.624602
- self size: 13
- global size: 13
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:0.500000, time:0.267350, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for xTimerIsTimerActive/30 inlinable
- global time: 17.159302
- self size: 14
- global size: 14
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:1.500000, time:0.802050, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for prvCheckForValidListAndQueue/29 inlinable
- global time: 33.264679
- self size: 25
- global size: 25
- min size: 8
- self stack: 0
- global stack: 0
- estimated growth:17
- size:8.000000, time:3.871500
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:1.00 size: 1 time: 10
- vQueueAddToRegistry/50 function body not available
- loop depth: 0 freq:0.09 size: 3 time: 12
- op1 is compile time invariant
- xQueueGenericCreate/49 function body not available
- loop depth: 0 freq:0.17 size: 5 time: 14
- op0 is compile time invariant
- op1 is compile time invariant
- op2 is compile time invariant
- vListInitialise/48 function body not available
- loop depth: 0 freq:0.17 size: 2 time: 11
- op0 is compile time invariant
- vListInitialise/48 function body not available
- loop depth: 0 freq:0.17 size: 2 time: 11
- op0 is compile time invariant
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:1.00 size: 1 time: 10
- IPA function summary for prvSwitchTimerLists/28 inlinable
- global time: 154.636365
- self size: 15
- global size: 15
- min size: 9
- self stack: 0
- global stack: 0
- estimated growth:-4
- size:9.000000, time:55.545455
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- prvProcessExpiredTimer/21 call is unlikely and code size would grow
- loop depth: 1 freq:8.09 size: 3 time: 12callee size:11 stack: 0
- op1 is compile time invariant
- IPA function summary for prvInsertTimerInActiveList/26 inlinable
- global time: 16.137500
- self size: 22
- global size: 23
- min size: 3
- self stack: 0
- global stack: 0
- estimated growth:15
- size:3.000000, time:1.497500
- size:4.000000, time:3.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op1 changed || op2 changed)
- size:3.000000, time:1.500000, nonconst if:(op2 changed || op3 changed)
- size:2.000000, time:0.670000, nonconst if:(op1 changed || op3 changed)
- size:0.500000, time:0.250000, executed if:(not inlined), nonconst if:(op0[ref offset: 192] changed) && (not inlined)
- size:0.500000, time:0.250000, nonconst if:(op0[ref offset: 192] changed)
- size:2.000000, time:1.000000, nonconst if:(op2 changed || op3 changed || op0[ref offset: 192] changed)
- calls:
- vListInsert/44 function body not available
- loop depth: 0 freq:0.33 size: 3 time: 12
- prvInsertTimerInActiveList.part.0/57 inlined
- loop depth: 0 freq:0.16 size: 3 time: 12callee size: 3 stack: 0
- Stack frame offset 0, callee self size 0, callee size 0
- vListInsert/44 function body not available
- loop depth: 0 freq:0.16 size: 3 time: 12
- IPA function summary for prvTimerTask/22 inlinable
- global time: 6606767.054688
- self size: 10
- global size: 166
- min size: 290
- self stack: 4
- global stack: 24
- size:112.500000, time:2200324.062500
- size:2.000000, time:0.000000, executed if:(not inlined)
- calls:
- prvProcessReceivedCommands/27 inlined
- loop depth: 1 freq:10000.02 size: 1 time: 10callee size:56 stack:20
- Stack frame offset 4, callee self size 20, callee size 20
- xQueueReceive/46 function body not available
- loop depth: 4 freq:179947.93 size: 5 time: 14
- op1 is compile time invariant
- op2 is compile time invariant
- vPortFree/45 function body not available
- loop depth: 2 freq:617.28 size: 2 time: 11
- prvInsertTimerInActiveList/26 call is unlikely and code size would grow
- loop depth: 2 freq:1767.68 size: 5 time: 14callee size:11 stack: 0
- prvReloadTimer/20 call is unlikely and code size would grow
- loop depth: 2 freq:308.64 size: 4 time: 13callee size:10 stack: 0
- prvInsertTimerInActiveList/26 call is unlikely and code size would grow
- loop depth: 2 freq:1870.56 size: 6 time: 15callee size:11 stack: 0
- prvSampleTimeNow/25 inlined
- loop depth: 3 freq:9352.79 size: 3 time: 12callee size: 6 stack: 0
- Stack frame offset 24, callee self size 0, callee size 0
- prvSwitchTimerLists/28 call is unlikely and code size would grow
- loop depth: 3 freq:3086.42 size: 1 time: 10callee size: 7 stack: 0
- xTaskGetTickCount/41 function body not available
- loop depth: 3 freq:9352.79 size: 2 time: 11
- uxListRemove/43 function body not available
- loop depth: 3 freq:5000.94 size: 2 time: 11
- indirect call loop depth: 2 freq:935.28 size: 4 time: 16
- indirect call loop depth: 4 freq:69720.83 size: 5 time: 17
- prvProcessTimerOrBlockTask/23 inlined
- loop depth: 1 freq:10000.02 size: 3 time: 12callee size:19 stack: 4
- Stack frame offset 4, callee self size 4, callee size 4
- xTaskResumeAll/39 function body not available
- loop depth: 1 freq:3300.01 size: 1 time: 10
- xTaskResumeAll/39 function body not available
- loop depth: 1 freq:5594.51 size: 2 time: 11
- vQueueWaitForMessageRestricted/40 function body not available
- loop depth: 1 freq:5594.51 size: 4 time: 13
- prvProcessExpiredTimer/21 call is unlikely and code size would grow
- loop depth: 1 freq:1105.50 size: 3 time: 12callee size:11 stack: 0
- xTaskResumeAll/39 function body not available
- loop depth: 1 freq:1105.50 size: 1 time: 10
- prvSampleTimeNow/73 inlined
- loop depth: 1 freq:10000.02 size: 3 time: 12callee size: 6 stack: 0
- Stack frame offset 8, callee self size 0, callee size 0
- xTaskGetTickCount/41 function body not available
- loop depth: 1 freq:10000.02 size: 2 time: 11
- prvSwitchTimerLists/28 call is unlikely and code size would grow
- loop depth: 1 freq:3300.01 size: 1 time: 10callee size: 7 stack: 0
- vTaskSuspendAll/38 function body not available
- loop depth: 1 freq:10000.02 size: 1 time: 10
- prvGetNextExpireTime/24 inlined
- loop depth: 1 freq:10000.02 size: 3 time: 12callee size: 6 stack: 0
- Stack frame offset 4, callee self size 0, callee size 0
- IPA function summary for prvProcessExpiredTimer/21 inlinable
- global time: 42.630000
- self size: 23
- global size: 23
- min size: 10
- self stack: 0
- global stack: 0
- estimated growth:11
- size:10.000000, time:9.340000
- size:3.000000, time:2.000000, executed if:(not inlined)
- calls:
- prvReloadTimer/20 call is unlikely and code size would grow
- loop depth: 0 freq:0.33 size: 4 time: 13callee size:10 stack: 0
- uxListRemove/43 function body not available
- loop depth: 0 freq:1.00 size: 2 time: 11
- indirect call loop depth: 0 freq:1.00 size: 4 time: 16
- IPA function summary for prvReloadTimer/20 inlinable
- global time: 328.454547
- self size: 20
- global size: 20
- min size: 6
- self stack: 0
- global stack: 0
- estimated growth:4
- size:5.500000, time:48.000000
- size:4.500000, time:14.636364, executed if:(not inlined)
- calls:
- prvInsertTimerInActiveList/26 call is unlikely and code size would grow
- loop depth: 1 freq:9.09 size: 6 time: 15callee size:11 stack: 0
- op0 change 10.990000% of time
- op2 change 10.990000% of time
- indirect call loop depth: 1 freq:8.09 size: 4 time: 16
- IPA function summary for pcTimerGetName/19 inlinable
- global time: 5.600001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:0.500000, time:0.350000, executed if:(op0 != 0B) && (not inlined), nonconst if:(op0[ref offset: 0] changed) && (op0 != 0B) && (not inlined)
- size:0.500000, time:0.350000, executed if:(op0 != 0B), nonconst if:(op0[ref offset: 0] changed) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- IPA function summary for xTimerGetExpiryTime/18 inlinable
- global time: 5.600001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:0.500000, time:0.350000, executed if:(op0 != 0B) && (not inlined), nonconst if:(op0[ref offset: 32] changed) && (op0 != 0B) && (not inlined)
- size:0.500000, time:0.350000, executed if:(op0 != 0B), nonconst if:(op0[ref offset: 32] changed) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- IPA function summary for uxTimerGetReloadMode/17 inlinable
- global time: 18.228702
- self size: 16
- global size: 16
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:1.500000, time:1.336750, executed if:(op0 != 0B) && (not inlined)
- size:3.500000, time:1.871450, executed if:(op0 != 0B)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for vTimerSetReloadMode/16 inlinable
- global time: 18.763389
- self size: 20
- global size: 20
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:2.000000, time:1.069400, executed if:(op0 != 0B), nonconst if:(op1 changed) && (op0 != 0B)
- size:1.000000, time:0.267348, executed if:(op1 == 0) && (op0 != 0B) && (not inlined)
- size:2.000000, time:0.534696, executed if:(op1 == 0) && (op0 != 0B)
- size:1.000000, time:0.267348, executed if:(op1 != 0) && (op0 != 0B) && (not inlined)
- size:2.000000, time:0.534696, executed if:(op1 != 0) && (op0 != 0B)
- size:1.000000, time:1.069400, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:2.326499, executed if:(op0 == 0B)
- calls:
- vPortExitCritical/51 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- vPortEnterCritical/47 function body not available
- loop depth: 0 freq:0.53 size: 1 time: 10 predicate: (op0 != 0B)
- IPA function summary for xTimerGetPeriod/15 inlinable
- global time: 5.600001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:0.500000, time:0.350000, executed if:(op0 != 0B) && (not inlined), nonconst if:(op0[ref offset: 192] changed) && (op0 != 0B) && (not inlined)
- size:0.500000, time:0.350000, executed if:(op0 != 0B), nonconst if:(op0[ref offset: 192] changed) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- IPA function summary for xTimerGetTimerDaemonTaskHandle/14 inlinable
- global time: 5.900001
- self size: 11
- global size: 11
- min size: 0
- self stack: 0
- global stack: 0
- size:8.000000, time:4.500001
- size:3.000000, time:1.399999, executed if:(not inlined)
- calls:
- IPA function summary for xTimerGenericCommand/13 inlinable
- global time: 20.230048
- self size: 42
- global size: 42
- min size: 0
- self stack: 16
- global stack: 16
- size:0.000000, time:0.000000
- size:2.000000, time:0.000000, executed if:(not inlined)
- size:2.000000, time:2.000000, nonconst if:(op0 changed)
- size:6.000000, time:3.570004, executed if:(op0 != 0B)
- size:2.000000, time:0.980004, executed if:(op0 != 0B), nonconst if:(op1 changed) && (op0 != 0B)
- size:4.000000, time:0.735003, executed if:(op1 <= 5) && (op0 != 0B)
- size:1.000000, time:1.399999, executed if:(op0 != 0B) && (not inlined)
- size:5.000000, time:1.500001, executed if:(op0 == 0B)
- calls:
- xQueueGenericSendFromISR/56 function body not available
- loop depth: 0 freq:0.25 size: 6 time: 15 predicate: (op1 > 5) && (op0 != 0B)
- op1 is compile time invariant
- op3 is compile time invariant
- xQueueGenericSend/55 function body not available
- loop depth: 0 freq:0.16 size: 6 time: 15 predicate: (op1 <= 5) && (op0 != 0B)
- op1 is compile time invariant
- op2 is compile time invariant
- op3 is compile time invariant
- xQueueGenericSend/55 function body not available
- loop depth: 0 freq:0.08 size: 6 time: 15 predicate: (op1 <= 5) && (op0 != 0B)
- op1 is compile time invariant
- op3 is compile time invariant
- xTaskGetSchedulerState/54 function body not available
- loop depth: 0 freq:0.25 size: 2 time: 11 predicate: (op1 <= 5) && (op0 != 0B)
- IPA function summary for xTimerCreate/11 inlinable
- global time: 23.983085
- self size: 16
- global size: 25
- min size: 26
- self stack: 0
- global stack: 0
- size:3.000000, time:2.534700
- size:3.000000, time:2.000000, executed if:(not inlined)
- size:2.000000, time:1.069400, nonconst if:(op1 changed)
- size:2.000000, time:0.352903, executed if:(op1 != 0)
- size:2.000000, time:0.352903, executed if:(op1 != 0), nonconst if:(op2 changed) && (op1 != 0)
- size:2.000000, time:0.176452, executed if:(op2 != 0) && (op1 != 0)
- size:5.000000, time:1.791242, executed if:(op1 == 0)
- calls:
- prvInitialiseNewTimer.constprop/72 inlined
- loop depth: 0 freq:0.53 size: 7 time: 16callee size:11 stack: 0
- Stack frame offset 0, callee self size 0, callee size 0
- prvCheckForValidListAndQueue/29 call is unlikely and code size would grow
- loop depth: 0 freq:0.18 size: 1 time: 10callee size:12 stack: 0 predicate: (op1 != 0)
- vListInitialiseItem/53 function body not available
- loop depth: 0 freq:0.18 size: 2 time: 11 predicate: (op1 != 0)
- pvPortMalloc/52 function body not available
- loop depth: 0 freq:1.00 size: 3 time: 12
- op0 is compile time invariant
- IPA function summary for xTimerCreateTimerTask/10 inlinable
- global time: 27.357181
- self size: 22
- global size: 22
- min size: 18
- self stack: 0
- global stack: 0
- size:10.000000, time:7.732635
- size:3.000000, time:0.534703, executed if:(not inlined)
- calls:
- xTaskCreate/37 function body not available
- loop depth: 0 freq:0.53 size: 8 time: 17
- op0 is compile time invariant
- op1 is compile time invariant
- op2 is compile time invariant
- op3 is compile time invariant
- op4 is compile time invariant
- op5 is compile time invariant
- prvCheckForValidListAndQueue/29 call is unlikely and code size would grow
- loop depth: 0 freq:1.00 size: 1 time: 10callee size:12 stack: 0
- Symbol table:
- prvSampleTimeNow/73 (prvSampleTimeNow) @05e5b0e0
- Type: function definition analyzed
- Visibility:
- next sharing asm name: 25
- References: xLastTime.6551/42 (read)xLastTime.6551/42 (write)
- Referring:
- Function prvSampleTimeNow/73 is inline copy in prvTimerTask/22
- Clone of prvSampleTimeNow/25
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvProcessTimerOrBlockTask/23 (inlined) (1073741824 (estimated locally),10000.02 per call)
- Calls: xTaskGetTickCount/41 (1073741824 (estimated locally),10000.02 per call) prvSwitchTimerLists/28 (354334802 (estimated locally),3300.01 per call)
- prvInitialiseNewTimer.constprop.0/72 (prvInitialiseNewTimer.constprop) @05e55d20
- Type: function definition analyzed
- Visibility:
- References:
- Referring:
- Function prvInitialiseNewTimer.constprop/72 is inline copy in xTimerCreate/11
- Clone of prvInitialiseNewTimer/12
- Availability: local
- Function flags: count:574129754 (estimated locally) local optimize_size
- Called by: xTimerCreate/11 (inlined) (574129754 (estimated locally),0.53 per call)
- Calls: prvCheckForValidListAndQueue/29 (189463535 (estimated locally),0.18 per call) vListInitialiseItem/53 (189463535 (estimated locally),0.18 per call)
- prvInsertTimerInActiveList.part.0/57 (prvInsertTimerInActiveList.part.0) @05e55a80
- Type: function definition analyzed
- Visibility: prevailing_def_ironly artificial
- References: pxOverflowTimerList/7 (read)
- Referring:
- Function prvInsertTimerInActiveList.part.0/57 is inline copy in prvInsertTimerInActiveList/26
- Availability: local
- Function flags: count:177167400 (estimated locally) first_run:1 body local split_part optimize_size
- Called by: prvInsertTimerInActiveList/26 (inlined) (177167400 (estimated locally),0.16 per call)
- Calls: vListInsert/44 (177167400 (estimated locally),0.16 per call)
- xQueueGenericSendFromISR/56 (xQueueGenericSendFromISR) @05f5cc40
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: xTimerPendFunctionCallFromISR/33 (1073741824 (estimated locally),1.00 per call) xTimerGenericCommand/13 (87689 (estimated locally),0.25 per call)
- Calls:
- xQueueGenericSend/55 (xQueueGenericSend) @05f5cb60
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: xTimerPendFunctionCall/34 (123389 (estimated locally),0.53 per call) xTimerGenericCommand/13 (57875 (estimated locally),0.16 per call) xTimerGenericCommand/13 (29814 (estimated locally),0.08 per call)
- Calls:
- xTaskGetSchedulerState/54 (xTaskGetSchedulerState) @05f5ca80
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: xTimerGenericCommand/13 (87689 (estimated locally),0.25 per call)
- Calls:
- vListInitialiseItem/53 (vListInitialiseItem) @05f5c8c0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvInitialiseNewTimer.constprop/72 (189463535 (estimated locally),0.18 per call)
- Calls:
- pvPortMalloc/52 (pvPortMalloc) @05f5c700
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: xTimerCreate/11 (1073741824 (estimated locally),1.00 per call)
- Calls:
- vPortExitCritical/51 (vPortExitCritical) @05f5c460
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: vTimerSetTimerID/32 (123389 (estimated locally),0.53 per call) pvTimerGetTimerID/31 (123389 (estimated locally),0.53 per call) xTimerIsTimerActive/30 (123389 (estimated locally),0.53 per call) uxTimerGetReloadMode/17 (123389 (estimated locally),0.53 per call) vTimerSetReloadMode/16 (123389 (estimated locally),0.53 per call) prvCheckForValidListAndQueue/29 (1073741824 (estimated locally),1.00 per call)
- Calls:
- vQueueAddToRegistry/50 (vQueueAddToRegistry) @05f5c380
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvCheckForValidListAndQueue/29 (100070816 (estimated locally),0.09 per call)
- Calls:
- xQueueGenericCreate/49 (xQueueGenericCreate) @05f5c2a0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvCheckForValidListAndQueue/29 (187153200 (estimated locally),0.17 per call)
- Calls:
- vListInitialise/48 (vListInitialise) @05f5c0e0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvCheckForValidListAndQueue/29 (187153200 (estimated locally),0.17 per call) prvCheckForValidListAndQueue/29 (187153200 (estimated locally),0.17 per call)
- Calls:
- vPortEnterCritical/47 (vPortEnterCritical) @05f5c000
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: vTimerSetTimerID/32 (123389 (estimated locally),0.53 per call) pvTimerGetTimerID/31 (123389 (estimated locally),0.53 per call) xTimerIsTimerActive/30 (123389 (estimated locally),0.53 per call) uxTimerGetReloadMode/17 (123389 (estimated locally),0.53 per call) vTimerSetReloadMode/16 (123389 (estimated locally),0.53 per call) prvCheckForValidListAndQueue/29 (1073741824 (estimated locally),1.00 per call)
- Calls:
- xQueueReceive/46 (xQueueReceive) @05f36e00
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvProcessReceivedCommands/27 (19321729474 (estimated locally),179947.93 per call)
- Calls:
- vPortFree/45 (vPortFree) @05f36d20
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvProcessReceivedCommands/27 (66280295 (estimated locally),617.28 per call)
- Calls:
- vListInsert/44 (vListInsert) @05f369a0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvInsertTimerInActiveList/26 (357019157 (estimated locally),0.33 per call) prvInsertTimerInActiveList.part.0/57 (177167400 (estimated locally),0.16 per call)
- Calls:
- uxListRemove/43 (uxListRemove) @05f36700
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvProcessReceivedCommands/27 (536970861 (estimated locally),5000.94 per call) prvProcessExpiredTimer/21 (1073741824 (estimated locally),1.00 per call)
- Calls:
- xLastTime.6551/42 (xLastTime) @05f4c120
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: prvSampleTimeNow/25 (read)prvSampleTimeNow/25 (write)prvSampleTimeNow/73 (read)prvSampleTimeNow/73 (write)
- Availability: available
- Varpool flags: initialized
- xTaskGetTickCount/41 (xTaskGetTickCount) @05f36380
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvSampleTimeNow/73 (1073741824 (estimated locally),10000.02 per call) prvSampleTimeNow/25 (1004246918 (estimated locally),9352.79 per call)
- Calls:
- vQueueWaitForMessageRestricted/40 (vQueueWaitForMessageRestricted) @05f361c0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvProcessTimerOrBlockTask/23 (600704865 (estimated locally),5594.51 per call)
- Calls:
- xTaskResumeAll/39 (xTaskResumeAll) @05f360e0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvProcessTimerOrBlockTask/23 (354334802 (estimated locally),3300.01 per call) prvProcessTimerOrBlockTask/23 (600704865 (estimated locally),5594.51 per call) prvProcessTimerOrBlockTask/23 (118702158 (estimated locally),1105.50 per call)
- Calls:
- vTaskSuspendAll/38 (vTaskSuspendAll) @05f36000
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: prvProcessTimerOrBlockTask/23 (1073741824 (estimated locally),10000.02 per call)
- Calls:
- xTaskCreate/37 (xTaskCreate) @05f2aee0
- Type: function
- Visibility: external public
- References:
- Referring:
- Availability: not_available
- Function flags: optimize_size
- Called by: xTimerCreateTimerTask/10 (78363 (estimated locally),0.53 per call)
- Calls:
- vTimerSetTimerNumber/36 (vTimerSetTimerNumber) @05f2aa80
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:1073741824 (estimated locally) body optimize_size
- Called by:
- Calls:
- uxTimerGetTimerNumber/35 (uxTimerGetTimerNumber) @05f2a7e0
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:1073741824 (estimated locally) body optimize_size
- Called by:
- Calls:
- xTimerPendFunctionCall/34 (xTimerPendFunctionCall) @05f2a540
- Type: function definition analyzed
- Visibility: externally_visible public
- References: xTimerQueue/8 (read)
- Referring:
- Availability: available
- Function flags: count:230763 (estimated locally) body optimize_size
- Called by:
- Calls: xQueueGenericSend/55 (123389 (estimated locally),0.53 per call)
- xTimerPendFunctionCallFromISR/33 (xTimerPendFunctionCallFromISR) @05f2a0e0
- Type: function definition analyzed
- Visibility: externally_visible public
- References: xTimerQueue/8 (read)
- Referring:
- Availability: available
- Function flags: count:1073741824 (estimated locally) body optimize_size
- Called by:
- Calls: xQueueGenericSendFromISR/56 (1073741824 (estimated locally),1.00 per call)
- vTimerSetTimerID/32 (vTimerSetTimerID) @05f268c0
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:230763 (estimated locally) body optimize_size
- Called by:
- Calls: vPortExitCritical/51 (123389 (estimated locally),0.53 per call) vPortEnterCritical/47 (123389 (estimated locally),0.53 per call)
- pvTimerGetTimerID/31 (pvTimerGetTimerID) @05f26ee0
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:230763 (estimated locally) body optimize_size
- Called by:
- Calls: vPortExitCritical/51 (123389 (estimated locally),0.53 per call) vPortEnterCritical/47 (123389 (estimated locally),0.53 per call)
- xTimerIsTimerActive/30 (xTimerIsTimerActive) @05f26b60
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:230763 (estimated locally) body optimize_size
- Called by:
- Calls: vPortExitCritical/51 (123389 (estimated locally),0.53 per call) vPortEnterCritical/47 (123389 (estimated locally),0.53 per call)
- prvCheckForValidListAndQueue/29 (prvCheckForValidListAndQueue) @05f267e0
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: xTimerQueue/8 (read)xActiveTimerList1/4 (addr)xActiveTimerList2/5 (addr)pxCurrentTimerList/6 (write)xActiveTimerList1/4 (addr)pxOverflowTimerList/7 (write)xActiveTimerList2/5 (addr)xTimerQueue/8 (write)
- Referring:
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvInitialiseNewTimer.constprop/72 (189463535 (estimated locally),0.18 per call) xTimerCreateTimerTask/10 (146556 (estimated locally),1.00 per call)
- Calls: vPortExitCritical/51 (1073741824 (estimated locally),1.00 per call) vQueueAddToRegistry/50 (100070816 (estimated locally),0.09 per call) xQueueGenericCreate/49 (187153200 (estimated locally),0.17 per call) vListInitialise/48 (187153200 (estimated locally),0.17 per call) vListInitialise/48 (187153200 (estimated locally),0.17 per call) vPortEnterCritical/47 (1073741824 (estimated locally),1.00 per call)
- prvSwitchTimerLists/28 (prvSwitchTimerLists) @05f26460
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: pxCurrentTimerList/6 (read)pxOverflowTimerList/7 (read)pxCurrentTimerList/6 (write)pxOverflowTimerList/7 (write)
- Referring:
- Availability: local
- Function flags: count:118111600 (estimated locally) body local optimize_size
- Called by: prvSampleTimeNow/73 (354334802 (estimated locally),3300.01 per call) prvSampleTimeNow/25 (331401483 (estimated locally),3086.42 per call)
- Calls: prvProcessExpiredTimer/21 (955630223 (estimated locally),8.09 per call)
- prvProcessReceivedCommands/27 (prvProcessReceivedCommands) @05f260e0
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: xTimerQueue/8 (read)
- Referring:
- Function prvProcessReceivedCommands/27 is inline copy in prvTimerTask/22
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvTimerTask/22 (inlined) (1073741824 (estimated locally),10000.02 per call)
- Calls: xQueueReceive/46 (19321729474 (estimated locally),179947.93 per call) vPortFree/45 (66280295 (estimated locally),617.28 per call) prvInsertTimerInActiveList/26 (189802709 (estimated locally),1767.68 per call) prvReloadTimer/20 (33140147 (estimated locally),308.64 per call) prvInsertTimerInActiveList/26 (200849425 (estimated locally),1870.56 per call) prvSampleTimeNow/25 (inlined) (1004246918 (estimated locally),9352.79 per call) uxListRemove/43 (536970861 (estimated locally),5000.94 per call)
- Indirect call(100424661 (estimated locally),935.28 per call)
- Indirect call(7486204063 (estimated locally),69720.83 per call)
- prvInsertTimerInActiveList/26 (prvInsertTimerInActiveList) @05f1a7e0
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: pxCurrentTimerList/6 (read)
- Referring:
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvProcessReceivedCommands/27 (189802709 (estimated locally),1767.68 per call) prvProcessReceivedCommands/27 (200849425 (estimated locally),1870.56 per call) prvReloadTimer/20 (1073741824 (estimated locally),9.09 per call)
- Calls: vListInsert/44 (357019157 (estimated locally),0.33 per call) prvInsertTimerInActiveList.part.0/57 (inlined) (177167400 (estimated locally),0.16 per call)
- prvSampleTimeNow/25 (prvSampleTimeNow) @05f1ad20
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- previous sharing asm name: 73
- References: xLastTime.6551/42 (read)xLastTime.6551/42 (write)
- Referring:
- Function prvSampleTimeNow/25 is inline copy in prvTimerTask/22
- Availability: local
- Function flags: count:1004246918 (estimated locally) body local optimize_size
- Called by: prvProcessReceivedCommands/27 (inlined) (1004246918 (estimated locally),9352.79 per call)
- Calls: prvSwitchTimerLists/28 (331401483 (estimated locally),3086.42 per call) xTaskGetTickCount/41 (1004246918 (estimated locally),9352.79 per call)
- prvGetNextExpireTime/24 (prvGetNextExpireTime) @05f1aa80
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: pxCurrentTimerList/6 (read)
- Referring:
- Function prvGetNextExpireTime/24 is inline copy in prvTimerTask/22
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvTimerTask/22 (inlined) (1073741824 (estimated locally),10000.02 per call)
- Calls:
- prvProcessTimerOrBlockTask/23 (prvProcessTimerOrBlockTask) @05f1a700
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: pxOverflowTimerList/7 (read)xTimerQueue/8 (read)
- Referring:
- Function prvProcessTimerOrBlockTask/23 is inline copy in prvTimerTask/22
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvTimerTask/22 (inlined) (1073741824 (estimated locally),10000.02 per call)
- Calls: xTaskResumeAll/39 (354334802 (estimated locally),3300.01 per call) xTaskResumeAll/39 (600704865 (estimated locally),5594.51 per call) vQueueWaitForMessageRestricted/40 (600704865 (estimated locally),5594.51 per call) prvProcessExpiredTimer/21 (118702158 (estimated locally),1105.50 per call) xTaskResumeAll/39 (118702158 (estimated locally),1105.50 per call) prvSampleTimeNow/73 (inlined) (1073741824 (estimated locally),10000.02 per call) vTaskSuspendAll/38 (1073741824 (estimated locally),10000.02 per call)
- prvTimerTask/22 (prvTimerTask) @05f1a2a0
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- Address is taken.
- References:
- Referring: xTimerCreateTimerTask/10 (addr)
- Availability: available
- Function flags: count:107374 (estimated locally) body executed_once optimize_size
- Called by:
- Calls: prvProcessReceivedCommands/27 (inlined) (1073741824 (estimated locally),10000.02 per call) prvProcessTimerOrBlockTask/23 (inlined) (1073741824 (estimated locally),10000.02 per call) prvGetNextExpireTime/24 (inlined) (1073741824 (estimated locally),10000.02 per call)
- prvProcessExpiredTimer/21 (prvProcessExpiredTimer) @05f1a000
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References: pxCurrentTimerList/6 (read)
- Referring:
- Availability: local
- Function flags: count:1073741824 (estimated locally) body local optimize_size
- Called by: prvProcessTimerOrBlockTask/23 (118702158 (estimated locally),1105.50 per call) prvSwitchTimerLists/28 (955630223 (estimated locally),8.09 per call)
- Calls: prvReloadTimer/20 (354334802 (estimated locally),0.33 per call) uxListRemove/43 (1073741824 (estimated locally),1.00 per call)
- Indirect call(1073741824 (estimated locally),1.00 per call)
- prvReloadTimer/20 (prvReloadTimer) @05ec0540
- Type: function definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring:
- Availability: local
- Function flags: count:118111600 (estimated locally) body local optimize_size
- Called by: prvProcessReceivedCommands/27 (33140147 (estimated locally),308.64 per call) prvProcessExpiredTimer/21 (354334802 (estimated locally),0.33 per call)
- Calls: prvInsertTimerInActiveList/26 (1073741824 (estimated locally),9.09 per call)
- Indirect call(955630223 (estimated locally),8.09 per call) of param:0 loaded from aggregate passed by reference at offset 256 (vptr maybe changed)
- pcTimerGetName/19 (pcTimerGetName) @05ec0ee0
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:357913 (estimated locally) body optimize_size
- Called by:
- Calls:
- xTimerGetExpiryTime/18 (xTimerGetExpiryTime) @05ec0b60
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:357913 (estimated locally) body optimize_size
- Called by:
- Calls:
- uxTimerGetReloadMode/17 (uxTimerGetReloadMode) @05ec07e0
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:230763 (estimated locally) body optimize_size
- Called by:
- Calls: vPortExitCritical/51 (123389 (estimated locally),0.53 per call) vPortEnterCritical/47 (123389 (estimated locally),0.53 per call)
- vTimerSetReloadMode/16 (vTimerSetReloadMode) @05ec0460
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:230763 (estimated locally) body optimize_size
- Called by:
- Calls: vPortExitCritical/51 (123389 (estimated locally),0.53 per call) vPortEnterCritical/47 (123389 (estimated locally),0.53 per call)
- xTimerGetPeriod/15 (xTimerGetPeriod) @05ec00e0
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:357913 (estimated locally) body optimize_size
- Called by:
- Calls:
- xTimerGetTimerDaemonTaskHandle/14 (xTimerGetTimerDaemonTaskHandle) @05f157e0
- Type: function definition analyzed
- Visibility: externally_visible public
- References: xTimerTaskHandle/9 (read)
- Referring:
- Availability: available
- Function flags: count:357913 (estimated locally) body optimize_size
- Called by:
- Calls:
- xTimerGenericCommand/13 (xTimerGenericCommand) @05f151c0
- Type: function definition analyzed
- Visibility: externally_visible public
- References: xTimerQueue/8 (read)xTimerQueue/8 (read)xTimerQueue/8 (read)
- Referring:
- Availability: available
- Function flags: count:357913 (estimated locally) body optimize_size
- Called by:
- Calls: xQueueGenericSendFromISR/56 (87689 (estimated locally),0.25 per call) xQueueGenericSend/55 (57875 (estimated locally),0.16 per call) xQueueGenericSend/55 (29814 (estimated locally),0.08 per call) xTaskGetSchedulerState/54 (87689 (estimated locally),0.25 per call)
- prvInitialiseNewTimer/12 (prvInitialiseNewTimer) @05f15a80
- Type: function
- Body removed by symtab_remove_unreachable_nodes
- Visibility: prevailing_def_ironly
- References:
- Referring:
- Availability: not_available
- Function flags: count:160260 (estimated locally) body optimize_size
- Called by:
- Calls:
- xTimerCreate/11 (xTimerCreate) @05f15700
- Type: function definition analyzed
- Visibility: externally_visible public
- References:
- Referring:
- Availability: available
- Function flags: count:1073741824 (estimated locally) body optimize_size
- Called by:
- Calls: prvInitialiseNewTimer.constprop/72 (inlined) (574129754 (estimated locally),0.53 per call) pvPortMalloc/52 (1073741824 (estimated locally),1.00 per call)
- xTimerCreateTimerTask/10 (xTimerCreateTimerTask) @05f15460
- Type: function definition analyzed
- Visibility: externally_visible public
- References: xTimerQueue/8 (read)prvTimerTask/22 (addr)xTimerTaskHandle/9 (addr)
- Referring:
- Availability: available
- Function flags: count:146556 (estimated locally) body optimize_size
- Called by:
- Calls: xTaskCreate/37 (78363 (estimated locally),0.53 per call) prvCheckForValidListAndQueue/29 (146556 (estimated locally),1.00 per call)
- xTimerTaskHandle/9 (xTimerTaskHandle) @05f0f678
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: xTimerCreateTimerTask/10 (addr)xTimerGetTimerDaemonTaskHandle/14 (read)
- Availability: available
- Varpool flags: initialized
- xTimerQueue/8 (xTimerQueue) @05f0f5e8
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: prvProcessReceivedCommands/27 (read)xTimerGenericCommand/13 (read)xTimerPendFunctionCallFromISR/33 (read)prvCheckForValidListAndQueue/29 (write)xTimerCreateTimerTask/10 (read)prvCheckForValidListAndQueue/29 (read)prvProcessTimerOrBlockTask/23 (read)xTimerGenericCommand/13 (read)xTimerGenericCommand/13 (read)xTimerPendFunctionCall/34 (read)
- Availability: available
- Varpool flags: initialized
- pxOverflowTimerList/7 (pxOverflowTimerList) @05f0f558
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: prvInsertTimerInActiveList.part.0/57 (read)prvSwitchTimerLists/28 (write)prvProcessTimerOrBlockTask/23 (read)prvSwitchTimerLists/28 (read)prvCheckForValidListAndQueue/29 (write)
- Availability: available
- Varpool flags:
- pxCurrentTimerList/6 (pxCurrentTimerList) @05f0f4c8
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: prvSwitchTimerLists/28 (write)prvProcessExpiredTimer/21 (read)prvInsertTimerInActiveList/26 (read)prvGetNextExpireTime/24 (read)prvSwitchTimerLists/28 (read)prvCheckForValidListAndQueue/29 (write)
- Availability: available
- Varpool flags:
- xActiveTimerList2/5 (xActiveTimerList2) @05f0f438
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: prvCheckForValidListAndQueue/29 (addr)prvCheckForValidListAndQueue/29 (addr)
- Availability: available
- Varpool flags:
- xActiveTimerList1/4 (xActiveTimerList1) @05f0f3a8
- Type: variable definition analyzed
- Visibility: prevailing_def_ironly
- References:
- Referring: prvCheckForValidListAndQueue/29 (addr)prvCheckForValidListAndQueue/29 (addr)
- Availability: available
- Varpool flags:
- ;; Function prvCheckForValidListAndQueue (prvCheckForValidListAndQueue, funcdef_no=23, decl_uid=6421, cgraph_uid=24, symbol_order=29)
- prvCheckForValidListAndQueue ()
- {
- struct QueueDefinition * xTimerQueue.17_1;
- struct QueueDefinition * _2;
- <bb 2> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- vPortEnterCritical ();
- # DEBUG BEGIN_STMT
- xTimerQueue.17_1 = xTimerQueue;
- if (xTimerQueue.17_1 == 0B)
- goto <bb 3>; [17.43%]
- else
- goto <bb 5>; [82.57%]
- <bb 3> [local count: 187153200]:
- # DEBUG BEGIN_STMT
- vListInitialise (&xActiveTimerList1);
- # DEBUG BEGIN_STMT
- vListInitialise (&xActiveTimerList2);
- # DEBUG BEGIN_STMT
- pxCurrentTimerList = &xActiveTimerList1;
- # DEBUG BEGIN_STMT
- pxOverflowTimerList = &xActiveTimerList2;
- # DEBUG BEGIN_STMT
- _2 = xQueueGenericCreate (10, 16, 0);
- xTimerQueue = _2;
- # DEBUG BEGIN_STMT
- if (_2 != 0B)
- goto <bb 4>; [53.47%]
- else
- goto <bb 5>; [46.53%]
- <bb 4> [local count: 100070816]:
- # DEBUG BEGIN_STMT
- vQueueAddToRegistry (_2, "TmrQ");
- <bb 5> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vPortExitCritical ();
- return;
- }
- ;; Function prvInsertTimerInActiveList (prvInsertTimerInActiveList, funcdef_no=20, decl_uid=6430, cgraph_uid=21, symbol_order=26)
- Symbols to be put in SSA form
- { D.6795 D.6894 }
- Incremental SSA update started at block: 0
- Number of blocks in CFG: 13
- Number of blocks to update: 12 ( 92%)
- Removing basic block 4
- Removing basic block 10
- Merging blocks 11 and 12
- Merging blocks 11 and 9
- ;; 1 loops found
- ;;
- ;; Loop 0
- ;; header 0, latch 1
- ;; depth 0, outer -1
- ;; nodes: 0 1 2 3 4 5 6 7 8
- ;; 2 succs { 3 5 }
- ;; 3 succs { 8 4 }
- ;; 4 succs { 8 }
- ;; 5 succs { 6 7 }
- ;; 6 succs { 8 7 }
- ;; 7 succs { 8 }
- ;; 8 succs { 1 }
- prvInsertTimerInActiveList (struct Timer_t * const pxTimer, const TickType_t xNextExpiryTime, const TickType_t xTimeNow, const TickType_t xCommandTime)
- {
- BaseType_t D.6894;
- BaseType_t xProcessTimerNow;
- long unsigned int _1;
- long unsigned int _2;
- struct List_t * pxCurrentTimerList.15_3;
- struct ListItem_t * _4;
- struct List_t * pxOverflowTimerList.14_17;
- struct ListItem_t * _18;
- <bb 2> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- # DEBUG xProcessTimerNow => 0
- # DEBUG BEGIN_STMT
- pxTimer_8(D)->xTimerListItem.xItemValue = xNextExpiryTime_9(D);
- # DEBUG BEGIN_STMT
- pxTimer_8(D)->xTimerListItem.pvOwner = pxTimer_8(D);
- # DEBUG BEGIN_STMT
- if (xNextExpiryTime_9(D) <= xTimeNow_12(D))
- goto <bb 3>; [50.00%]
- else
- goto <bb 5>; [50.00%]
- <bb 3> [local count: 536870913]:
- # DEBUG BEGIN_STMT
- _1 = xTimeNow_12(D) - xCommandTime_13(D);
- _2 = pxTimer_8(D)->xTimerPeriodInTicks;
- if (_1 >= _2)
- goto <bb 8>; [67.00%]
- else
- goto <bb 4>; [33.00%]
- <bb 4> [local count: 177167401]:
- # DEBUG D#1 => xNextExpiryTime_9(D)
- # DEBUG D#2 => xTimeNow_12(D)
- # DEBUG D#3 => xCommandTime_13(D)
- # DEBUG pxTimer => pxTimer_8(D)
- # DEBUG INLINE_ENTRY prvInsertTimerInActiveList
- # DEBUG D#6 => D#1
- # DEBUG xNextExpiryTime => D#6
- # DEBUG D#5 => D#2
- # DEBUG xTimeNow => D#5
- # DEBUG D#4 => D#3
- # DEBUG xCommandTime => D#4
- # DEBUG BEGIN_STMT
- pxOverflowTimerList.14_17 = pxOverflowTimerList;
- _18 = &pxTimer_8(D)->xTimerListItem;
- vListInsert (pxOverflowTimerList.14_17, _18);
- # DEBUG xProcessTimerNow => 0
- # DEBUG BEGIN_STMT
- _21 = 0;
- # DEBUG pxTimer => NULL
- # DEBUG xProcessTimerNow => NULL
- # DEBUG xNextExpiryTime => NULL
- # DEBUG xTimeNow => NULL
- # DEBUG xCommandTime => NULL
- xProcessTimerNow_16 = _21;
- goto <bb 8>; [100.00%]
- <bb 5> [local count: 536870913]:
- # DEBUG BEGIN_STMT
- if (xTimeNow_12(D) < xCommandTime_13(D))
- goto <bb 6>; [67.00%]
- else
- goto <bb 7>; [33.00%]
- <bb 6> [local count: 359703511]:
- if (xNextExpiryTime_9(D) >= xCommandTime_13(D))
- goto <bb 8>; [50.00%]
- else
- goto <bb 7>; [50.00%]
- <bb 7> [local count: 357019157]:
- # DEBUG BEGIN_STMT
- pxCurrentTimerList.15_3 = pxCurrentTimerList;
- _4 = &pxTimer_8(D)->xTimerListItem;
- vListInsert (pxCurrentTimerList.15_3, _4);
- <bb 8> [local count: 1073741824]:
- # xProcessTimerNow_5 = PHI <xProcessTimerNow_16(4), 1(6), 0(7), 1(3)>
- # DEBUG xProcessTimerNow => xProcessTimerNow_5
- # DEBUG BEGIN_STMT
- return xProcessTimerNow_5;
- }
- ;; Function prvReloadTimer (prvReloadTimer, funcdef_no=14, decl_uid=6434, cgraph_uid=15, symbol_order=20)
- prvReloadTimer (struct Timer_t * const pxTimer, TickType_t xExpiredTime, const TickType_t xTimeNow)
- {
- long unsigned int _1;
- void (*<T689>) (struct tmrTimerControl *) _2;
- long unsigned int _3;
- long unsigned int _4;
- long int _5;
- <bb 2> [local count: 118111600]:
- # DEBUG BEGIN_STMT
- goto <bb 4>; [100.00%]
- <bb 3> [local count: 955630223]:
- # DEBUG BEGIN_STMT
- _1 = pxTimer_10(D)->xTimerPeriodInTicks;
- xExpiredTime_13 = _1 + xExpiredTime_6;
- # DEBUG xExpiredTime => xExpiredTime_13
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _2 = pxTimer_10(D)->pxCallbackFunction;
- _2 (pxTimer_10(D));
- <bb 4> [local count: 1073741824]:
- # xExpiredTime_6 = PHI <xExpiredTime_8(D)(2), xExpiredTime_13(3)>
- # DEBUG xExpiredTime => xExpiredTime_6
- # DEBUG BEGIN_STMT
- _3 = pxTimer_10(D)->xTimerPeriodInTicks;
- _4 = _3 + xExpiredTime_6;
- _5 = prvInsertTimerInActiveList (pxTimer_10(D), _4, xTimeNow_11(D), xExpiredTime_6);
- if (_5 != 0)
- goto <bb 3>; [89.00%]
- else
- goto <bb 5>; [11.00%]
- <bb 5> [local count: 118111601]:
- return;
- }
- ;; Function prvProcessExpiredTimer (prvProcessExpiredTimer, funcdef_no=15, decl_uid=6437, cgraph_uid=16, symbol_order=21)
- prvProcessExpiredTimer (const TickType_t xNextExpireTime, const TickType_t xTimeNow)
- {
- struct Timer_t * const pxTimer;
- struct List_t * pxCurrentTimerList.13_1;
- struct xLIST_ITEM * _2;
- struct ListItem_t * _3;
- unsigned char _4;
- unsigned char _5;
- void (*<T689>) (struct tmrTimerControl *) _6;
- unsigned char _16;
- <bb 2> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- pxCurrentTimerList.13_1 = pxCurrentTimerList;
- _2 = pxCurrentTimerList.13_1->xListEnd.pxNext;
- pxTimer_9 = _2->pvOwner;
- # DEBUG pxTimer => pxTimer_9
- # DEBUG BEGIN_STMT
- _3 = &pxTimer_9->xTimerListItem;
- uxListRemove (_3);
- # DEBUG BEGIN_STMT
- _4 = pxTimer_9->ucStatus;
- _16 = _4 & 4;
- if (_16 != 0)
- goto <bb 3>; [33.00%]
- else
- goto <bb 4>; [67.00%]
- <bb 3> [local count: 354334802]:
- # DEBUG BEGIN_STMT
- prvReloadTimer (pxTimer_9, xNextExpireTime_12(D), xTimeNow_13(D));
- goto <bb 5>; [100.00%]
- <bb 4> [local count: 719407023]:
- # DEBUG BEGIN_STMT
- _5 = _4 & 254;
- pxTimer_9->ucStatus = _5;
- <bb 5> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _6 = pxTimer_9->pxCallbackFunction;
- _6 (pxTimer_9);
- return;
- }
- ;; Function prvSwitchTimerLists (prvSwitchTimerLists, funcdef_no=22, decl_uid=6439, cgraph_uid=23, symbol_order=28)
- prvSwitchTimerLists ()
- {
- TickType_t xNextExpireTime;
- struct xLIST_ITEM * _1;
- struct List_t * pxCurrentTimerList.11_2;
- long unsigned int _3;
- struct List_t * pxOverflowTimerList.12_4;
- struct List_t * pxCurrentTimerList.11_7;
- <bb 2> [local count: 118111600]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- goto <bb 4>; [100.00%]
- <bb 3> [local count: 955630223]:
- # DEBUG BEGIN_STMT
- _1 = pxCurrentTimerList.11_2->xListEnd.pxNext;
- xNextExpireTime_10 = _1->xItemValue;
- # DEBUG xNextExpireTime => xNextExpireTime_10
- # DEBUG BEGIN_STMT
- prvProcessExpiredTimer (xNextExpireTime_10, 4294967295);
- <bb 4> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- pxCurrentTimerList.11_2 = pxCurrentTimerList;
- _3 ={v} pxCurrentTimerList.11_2->uxNumberOfItems;
- if (_3 != 0)
- goto <bb 3>; [89.00%]
- else
- goto <bb 5>; [11.00%]
- <bb 5> [local count: 118111601]:
- # pxCurrentTimerList.11_7 = PHI <pxCurrentTimerList.11_2(4)>
- # DEBUG BEGIN_STMT
- # DEBUG pxTemp => pxCurrentTimerList.11_7
- # DEBUG BEGIN_STMT
- pxOverflowTimerList.12_4 = pxOverflowTimerList;
- pxCurrentTimerList = pxOverflowTimerList.12_4;
- # DEBUG BEGIN_STMT
- pxOverflowTimerList = pxCurrentTimerList.11_7;
- return;
- }
- ;; Function prvTimerTask (prvTimerTask, funcdef_no=16, decl_uid=6423, cgraph_uid=17, symbol_order=22) (executed once)
- Symbols to be put in SSA form
- { D.6802 D.6922 D.6925 D.6928 }
- Incremental SSA update started at block: 0
- Number of blocks in CFG: 62
- Number of blocks to update: 61 ( 98%)
- Merging blocks 3 and 47
- Removing basic block 4
- Removing basic block 5
- Removing basic block 6
- Removing basic block 10
- Merging blocks 13 and 58
- Removing basic block 14
- Merging blocks 23 and 24
- Removing basic block 34
- Merging blocks 51 and 46
- Merging blocks 56 and 52
- Merging blocks 61 and 57
- Merging blocks 51 and 35
- Merging blocks 51 and 53
- No longer having address taken: xListWasEmpty
- No longer having address taken: xTimerListsWereSwitched
- No longer having address taken: xTimerListsWereSwitched
- Symbols to be put in SSA form
- { D.6535 D.6906 D.6919 }
- Incremental SSA update started at block: 0
- Number of blocks in CFG: 48
- Number of blocks to update: 47 ( 98%)
- ;; 6 loops found
- ;;
- ;; Loop 0
- ;; header 0, latch 1
- ;; depth 0, outer -1
- ;; nodes: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
- ;;
- ;; Loop 2
- ;; header 38, latch 38
- ;; depth 1, outer 0
- ;; nodes: 38
- ;;
- ;; Loop 1
- ;; header 3, latch 47
- ;; depth 1, outer 0
- ;; nodes: 3 47 46 23 45 29 44 20 43 30 34 35 39 41 42 40 36 32 33 31 13 17 18 19 10 8 9 7 5 6 4 14 15 16 11 12 27 28 26 24 25 21 22
- ;;
- ;; Loop 3
- ;; header 44, latch 43
- ;; depth 2, outer 1
- ;; nodes: 44 43 30 34 35 39 41 42 40 29 27 28 26 24 25 23 21 22 46 45 36 32 33 31
- ;;
- ;; Loop 4
- ;; header 45, latch 29
- ;; depth 3, outer 3
- ;; nodes: 45 29 27 28 26 24 25 23 21 22 46
- ;;
- ;; Loop 5
- ;; header 46, latch 23
- ;; depth 4, outer 4
- ;; nodes: 46 23 21 22
- ;; 2 succs { 3 }
- ;; 3 succs { 5 4 }
- ;; 4 succs { 5 }
- ;; 5 succs { 6 7 }
- ;; 6 succs { 7 }
- ;; 7 succs { 8 9 }
- ;; 8 succs { 10 }
- ;; 9 succs { 10 }
- ;; 10 succs { 11 19 }
- ;; 11 succs { 12 14 }
- ;; 12 succs { 13 14 }
- ;; 13 succs { 20 }
- ;; 14 succs { 15 17 }
- ;; 15 succs { 17 16 }
- ;; 16 succs { 17 }
- ;; 17 succs { 18 20 }
- ;; 18 succs { 20 }
- ;; 19 succs { 20 }
- ;; 20 succs { 44 }
- ;; 21 succs { 22 23 }
- ;; 22 succs { 23 }
- ;; 23 succs { 24 46 }
- ;; 24 succs { 25 26 }
- ;; 25 succs { 26 }
- ;; 26 succs { 27 28 }
- ;; 27 succs { 29 }
- ;; 28 succs { 29 }
- ;; 29 succs { 45 30 35 36 40 }
- ;; 30 succs { 31 43 }
- ;; 31 succs { 32 33 }
- ;; 32 succs { 34 }
- ;; 33 succs { 34 }
- ;; 34 succs { 43 }
- ;; 35 succs { 43 }
- ;; 36 succs { 37 39 }
- ;; 37 succs { 38 }
- ;; 38 succs { 38 }
- ;; 39 succs { 43 }
- ;; 40 succs { 41 42 }
- ;; 41 succs { 43 }
- ;; 42 succs { 43 }
- ;; 43 succs { 44 }
- ;; 44 succs { 45 }
- ;; 45 succs { 46 }
- ;; 46 succs { 21 47 }
- ;; 47 succs { 3 }
- prvTimerTask (void * pvParameters)
- {
- TickType_t xTimeNow;
- TickType_t D.6928;
- static TickType_t xLastTime = 0;
- TickType_t xTimeNow;
- TickType_t D.6925;
- static TickType_t xLastTime = 0;
- TickType_t xNextExpireTime;
- TickType_t D.6922;
- TickType_t xTimeNow;
- BaseType_t xTimerListsWereSwitched;
- BaseType_t xListWasEmpty;
- struct DaemonTaskMessage_t xMessage;
- struct Timer_t * pxTimer;
- BaseType_t xTimerListsWereSwitched;
- TickType_t xTimeNow;
- uint32_t ulNewBASEPRI;
- BaseType_t xListWasEmpty;
- TickType_t xNextExpireTime;
- long int xListWasEmpty.1_1;
- long int _8;
- void (*<T68e>) (void *, uint32_t) _9;
- void * _10;
- long unsigned int _11;
- long int _12;
- struct xLIST * _14;
- struct ListItem_t * _15;
- long int _17;
- unsigned char _19;
- unsigned char _20;
- long unsigned int _21;
- long unsigned int _22;
- long unsigned int _23;
- long int _25;
- unsigned char _26;
- unsigned char _27;
- long unsigned int _28;
- long unsigned int _29;
- long unsigned int _30;
- unsigned char _31;
- void (*<T689>) (struct tmrTimerControl *) _32;
- unsigned char _34;
- unsigned char _35;
- unsigned char _37;
- unsigned char _38;
- long unsigned int _39;
- long unsigned int _42;
- unsigned char _44;
- unsigned char _45;
- unsigned char _46;
- struct QueueDefinition * xTimerQueue.16_47;
- long int _48;
- long int xTimerListsWereSwitched.5_50;
- struct List_t * pxOverflowTimerList.7_51;
- long unsigned int _52;
- struct QueueDefinition * xTimerQueue.8_53;
- long unsigned int _54;
- long int _56;
- struct List_t * pxCurrentTimerList.3_57;
- long unsigned int _58;
- long int iftmp.2_59;
- struct xLIST_ITEM * _60;
- long unsigned int xLastTime.9_64;
- long unsigned int xLastTime.9_66;
- <bb 2> [local count: 107374]:
- <bb 3> [local count: 10436763]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG xTimeNow => NULL
- # DEBUG xTimerListsWereSwitched => NULL
- # DEBUG pxTimer => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG pxListWasEmpty => &xListWasEmpty
- # DEBUG INLINE_ENTRY prvGetNextExpireTime
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- pxCurrentTimerList.3_57 = pxCurrentTimerList;
- _58 ={v} pxCurrentTimerList.3_57->uxNumberOfItems;
- if (_58 == 0)
- goto <bb 5>; [50.00%]
- else
- goto <bb 4>; [50.00%]
- <bb 4> [local count: 5218382]:
- <bb 5> [local count: 10436763]:
- # iftmp.2_59 = PHI <1(3), 0(4)>
- xListWasEmpty_119 = iftmp.2_59;
- # DEBUG xListWasEmpty => xListWasEmpty_119
- # DEBUG BEGIN_STMT
- if (iftmp.2_59 == 0)
- goto <bb 6>; [50.00%]
- else
- goto <bb 7>; [50.00%]
- <bb 6> [local count: 5218382]:
- # DEBUG BEGIN_STMT
- _60 = pxCurrentTimerList.3_57->xListEnd.pxNext;
- xNextExpireTime_61 = _60->xItemValue;
- # DEBUG xNextExpireTime => xNextExpireTime_61
- <bb 7> [local count: 10436763]:
- # xNextExpireTime_62 = PHI <0(5), xNextExpireTime_61(6)>
- # DEBUG xNextExpireTime => xNextExpireTime_62
- # DEBUG BEGIN_STMT
- _78 = xNextExpireTime_62;
- # DEBUG pxListWasEmpty => NULL
- # DEBUG xNextExpireTime => NULL
- xNextExpireTime_5 = _78;
- # DEBUG xNextExpireTime => xNextExpireTime_5
- # DEBUG BEGIN_STMT
- xListWasEmpty.1_1 = xListWasEmpty_119;
- # DEBUG xNextExpireTime => xNextExpireTime_5
- # DEBUG xListWasEmpty => xListWasEmpty.1_1
- # DEBUG INLINE_ENTRY prvProcessTimerOrBlockTask
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vTaskSuspendAll ();
- # DEBUG BEGIN_STMT
- # DEBUG pxTimerListsWereSwitched => &xTimerListsWereSwitched
- # DEBUG INLINE_ENTRY prvSampleTimeNow
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xTimeNow_63 = xTaskGetTickCount ();
- # DEBUG xTimeNow => xTimeNow_63
- # DEBUG BEGIN_STMT
- xLastTime.9_64 = xLastTime;
- if (xTimeNow_63 < xLastTime.9_64)
- goto <bb 8>; [33.00%]
- else
- goto <bb 9>; [67.00%]
- <bb 8> [local count: 3444132]:
- # DEBUG BEGIN_STMT
- prvSwitchTimerLists ();
- # DEBUG BEGIN_STMT
- xTimerListsWereSwitched_121 = 1;
- # DEBUG xTimerListsWereSwitched => xTimerListsWereSwitched_121
- goto <bb 10>; [100.00%]
- <bb 9> [local count: 6992631]:
- # DEBUG BEGIN_STMT
- xTimerListsWereSwitched_120 = 0;
- # DEBUG xTimerListsWereSwitched => xTimerListsWereSwitched_120
- <bb 10> [local count: 10436763]:
- # xTimerListsWereSwitched_118 = PHI <xTimerListsWereSwitched_121(8), xTimerListsWereSwitched_120(9)>
- # DEBUG xTimerListsWereSwitched => xTimerListsWereSwitched_118
- # DEBUG BEGIN_STMT
- xLastTime = xTimeNow_63;
- # DEBUG BEGIN_STMT
- _85 = xTimeNow_63;
- # DEBUG pxTimerListsWereSwitched => NULL
- # DEBUG xTimeNow => NULL
- xTimeNow_49 = _85;
- # DEBUG xTimeNow => xTimeNow_49
- # DEBUG BEGIN_STMT
- xTimerListsWereSwitched.5_50 = xTimerListsWereSwitched_118;
- if (xTimerListsWereSwitched.5_50 == 0)
- goto <bb 11>; [67.00%]
- else
- goto <bb 19>; [33.00%]
- <bb 11> [local count: 6992631]:
- # DEBUG BEGIN_STMT
- if (xListWasEmpty.1_1 == 0)
- goto <bb 12>; [50.00%]
- else
- goto <bb 14>; [50.00%]
- <bb 12> [local count: 3496316]:
- if (xNextExpireTime_5 <= xTimeNow_49)
- goto <bb 13>; [33.00%]
- else
- goto <bb 14>; [67.00%]
- <bb 13> [local count: 1153784]:
- # DEBUG BEGIN_STMT
- xTaskResumeAll ();
- # DEBUG BEGIN_STMT
- prvProcessExpiredTimer (xNextExpireTime_5, xTimeNow_49);
- goto <bb 20>; [100.00%]
- <bb 14> [local count: 5838847]:
- # DEBUG BEGIN_STMT
- if (xListWasEmpty.1_1 != 0)
- goto <bb 15>; [50.00%]
- else
- goto <bb 17>; [50.00%]
- <bb 15> [local count: 2919424]:
- # DEBUG BEGIN_STMT
- pxOverflowTimerList.7_51 = pxOverflowTimerList;
- _52 ={v} pxOverflowTimerList.7_51->uxNumberOfItems;
- if (_52 == 0)
- goto <bb 17>; [50.00%]
- else
- goto <bb 16>; [50.00%]
- <bb 16> [local count: 1459712]:
- <bb 17> [local count: 5838847]:
- # xListWasEmpty_55 = PHI <xListWasEmpty.1_1(14), 1(15), 0(16)>
- # DEBUG xListWasEmpty => xListWasEmpty_55
- # DEBUG BEGIN_STMT
- xTimerQueue.8_53 = xTimerQueue;
- _54 = xNextExpireTime_5 - xTimeNow_49;
- vQueueWaitForMessageRestricted (xTimerQueue.8_53, _54, xListWasEmpty_55);
- # DEBUG BEGIN_STMT
- _56 = xTaskResumeAll ();
- if (_56 == 0)
- goto <bb 18>; [50.00%]
- else
- goto <bb 20>; [50.00%]
- <bb 18> [local count: 2919424]:
- # DEBUG BEGIN_STMT
- MEM[(volatile uint32_t *)3758157060B] ={v} 268435456;
- # DEBUG BEGIN_STMT
- __asm__ __volatile__("dsb" : : : "memory");
- # DEBUG BEGIN_STMT
- __asm__ __volatile__("isb");
- # DEBUG BEGIN_STMT
- goto <bb 20>; [100.00%]
- <bb 19> [local count: 3444132]:
- # DEBUG BEGIN_STMT
- xTaskResumeAll ();
- <bb 20> [local count: 10436763]:
- # DEBUG D#10 => {CLOBBER}
- # DEBUG xTimerListsWereSwitched => D#10
- goto <bb 44>; [100.00%]
- <bb 21> [local count: 177477686]:
- # DEBUG BEGIN_STMT
- _8 = xMessage.xMessageID;
- if (_8 < 0)
- goto <bb 22>; [41.00%]
- else
- goto <bb 23>; [59.00%]
- <bb 22> [local count: 72765851]:
- # DEBUG BEGIN_STMT
- # DEBUG pxCallback => &xMessage.u.xCallbackParameters
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _9 = MEM[(const struct CallbackParameters_t *)&xMessage + 4B].pxCallbackFunction;
- _10 = MEM[(const struct CallbackParameters_t *)&xMessage + 4B].pvParameter1;
- _11 = MEM[(const struct CallbackParameters_t *)&xMessage + 4B].ulParameter2;
- _9 (_10, _11);
- <bb 23> [local count: 177477686]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _12 = xMessage.xMessageID;
- if (_12 >= 0)
- goto <bb 24>; [5.50%]
- else
- goto <bb 46>; [94.50%]
- <bb 24> [local count: 9761273]:
- # DEBUG BEGIN_STMT
- pxTimer_13 = xMessage.u.xTimerParameters.pxTimer;
- # DEBUG pxTimer => pxTimer_13
- # DEBUG BEGIN_STMT
- _14 = pxTimer_13->xTimerListItem.pvContainer;
- if (_14 != 0B)
- goto <bb 25>; [53.47%]
- else
- goto <bb 26>; [46.53%]
- <bb 25> [local count: 5219353]:
- # DEBUG BEGIN_STMT
- _15 = &pxTimer_13->xTimerListItem;
- uxListRemove (_15);
- <bb 26> [local count: 9761273]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG pxTimerListsWereSwitched => &xTimerListsWereSwitched
- # DEBUG INLINE_ENTRY prvSampleTimeNow
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xTimeNow_65 = xTaskGetTickCount ();
- # DEBUG xTimeNow => xTimeNow_65
- # DEBUG BEGIN_STMT
- xLastTime.9_66 = xLastTime;
- if (xTimeNow_65 < xLastTime.9_66)
- goto <bb 27>; [33.00%]
- else
- goto <bb 28>; [67.00%]
- <bb 27> [local count: 3221220]:
- # DEBUG BEGIN_STMT
- prvSwitchTimerLists ();
- # DEBUG BEGIN_STMT
- xTimerListsWereSwitched_125 = 1;
- # DEBUG xTimerListsWereSwitched => xTimerListsWereSwitched_125
- goto <bb 29>; [100.00%]
- <bb 28> [local count: 6540053]:
- # DEBUG BEGIN_STMT
- xTimerListsWereSwitched_124 = 0;
- # DEBUG xTimerListsWereSwitched => xTimerListsWereSwitched_124
- <bb 29> [local count: 9761273]:
- # DEBUG BEGIN_STMT
- xLastTime = xTimeNow_65;
- # DEBUG BEGIN_STMT
- _105 = xTimeNow_65;
- # DEBUG pxTimerListsWereSwitched => NULL
- # DEBUG xTimeNow => NULL
- xTimeNow_16 = _105;
- # DEBUG xTimeNow => xTimeNow_16
- # DEBUG BEGIN_STMT
- _17 = xMessage.xMessageID;
- switch (_17) <default: <L6> [20.00%], case 1 ... 2: <L2> [20.00%], case 3: <L3> [20.00%], case 4: <L4> [20.00%], case 5: <L5> [20.00%], case 6 ... 7: <L2> [20.00%], case 8: <L3> [20.00%], case 9: <L4> [20.00%]>
- <bb 30> [local count: 1952255]:
- # pxTimer_18 = PHI <pxTimer_13(29)>
- # xTimeNow_24 = PHI <xTimeNow_16(29)>
- <L2>:
- # DEBUG BEGIN_STMT
- _19 = pxTimer_18->ucStatus;
- _20 = _19 | 1;
- pxTimer_18->ucStatus = _20;
- # DEBUG BEGIN_STMT
- _21 = xMessage.u.xTimerParameters.xMessageValue;
- _22 = pxTimer_18->xTimerPeriodInTicks;
- _23 = _21 + _22;
- _25 = prvInsertTimerInActiveList (pxTimer_18, _23, xTimeNow_24, _21);
- if (_25 != 0)
- goto <bb 31>; [50.00%]
- else
- goto <bb 43>; [50.00%]
- <bb 31> [local count: 976127]:
- # DEBUG BEGIN_STMT
- _26 = pxTimer_18->ucStatus;
- _27 = _26 & 4;
- if (_27 != 0)
- goto <bb 32>; [33.00%]
- else
- goto <bb 33>; [67.00%]
- <bb 32> [local count: 322122]:
- # DEBUG BEGIN_STMT
- _28 = xMessage.u.xTimerParameters.xMessageValue;
- _29 = pxTimer_18->xTimerPeriodInTicks;
- _30 = _28 + _29;
- prvReloadTimer (pxTimer_18, _30, xTimeNow_24);
- goto <bb 34>; [100.00%]
- <bb 33> [local count: 654005]:
- # DEBUG BEGIN_STMT
- _31 = _26 & 254;
- pxTimer_18->ucStatus = _31;
- <bb 34> [local count: 976127]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _32 = pxTimer_18->pxCallbackFunction;
- _32 (pxTimer_18);
- goto <bb 43>; [100.00%]
- <bb 35> [local count: 1952255]:
- # pxTimer_33 = PHI <pxTimer_13(29)>
- <L3>:
- # DEBUG BEGIN_STMT
- _34 = pxTimer_33->ucStatus;
- _35 = _34 & 254;
- pxTimer_33->ucStatus = _35;
- # DEBUG BEGIN_STMT
- goto <bb 43>; [100.00%]
- <bb 36> [local count: 1952255]:
- # pxTimer_36 = PHI <pxTimer_13(29)>
- # xTimeNow_41 = PHI <xTimeNow_16(29)>
- <L4>:
- # DEBUG BEGIN_STMT
- _37 = pxTimer_36->ucStatus;
- _38 = _37 | 1;
- pxTimer_36->ucStatus = _38;
- # DEBUG BEGIN_STMT
- _39 = xMessage.u.xTimerParameters.xMessageValue;
- pxTimer_36->xTimerPeriodInTicks = _39;
- # DEBUG BEGIN_STMT
- if (_39 == 0)
- goto <bb 37>; [5.50%]
- else
- goto <bb 39>; [94.50%]
- <bb 37> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_40 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_40
- <bb 38> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- goto <bb 38>; [100.00%]
- <bb 39> [local count: 1844881]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _42 = _39 + xTimeNow_41;
- prvInsertTimerInActiveList (pxTimer_36, _42, xTimeNow_41, xTimeNow_41);
- # DEBUG BEGIN_STMT
- goto <bb 43>; [100.00%]
- <bb 40> [local count: 1952255]:
- # pxTimer_43 = PHI <pxTimer_13(29)>
- <L5>:
- # DEBUG BEGIN_STMT
- _44 = pxTimer_43->ucStatus;
- _45 = _44 & 2;
- if (_45 == 0)
- goto <bb 41>; [33.00%]
- else
- goto <bb 42>; [67.00%]
- <bb 41> [local count: 644244]:
- # DEBUG BEGIN_STMT
- vPortFree (pxTimer_43);
- goto <bb 43>; [100.00%]
- <bb 42> [local count: 1308011]:
- # DEBUG BEGIN_STMT
- _46 = _44 & 254;
- pxTimer_43->ucStatus = _46;
- <bb 43> [local count: 7701644]:
- <bb 44> [local count: 18138407]:
- # DEBUG xNextExpireTime => NULL
- # DEBUG xListWasEmpty => NULL
- # DEBUG xTimerListsWereSwitched => NULL
- # DEBUG xTimeNow => NULL
- <bb 45> [local count: 20090662]:
- <L6>:
- <bb 46> [local count: 187807075]:
- # DEBUG BEGIN_STMT
- xTimerQueue.16_47 = xTimerQueue;
- _48 = xQueueReceive (xTimerQueue.16_47, &xMessage, 0);
- if (_48 != 0)
- goto <bb 21>; [94.50%]
- else
- goto <bb 47>; [5.50%]
- <bb 47> [local count: 10329389]:
- xMessage ={v} {CLOBBER};
- # DEBUG D#11 => {CLOBBER}
- # DEBUG xTimerListsWereSwitched => D#11
- goto <bb 3>; [100.00%]
- }
- ;; Function xTimerCreateTimerTask (xTimerCreateTimerTask, funcdef_no=4, decl_uid=6377, cgraph_uid=5, symbol_order=10)
- xTimerCreateTimerTask ()
- {
- uint32_t ulNewBASEPRI;
- BaseType_t xReturn;
- struct QueueDefinition * xTimerQueue.0_1;
- <bb 2> [local count: 146556]:
- # DEBUG BEGIN_STMT
- # DEBUG xReturn => 0
- # DEBUG BEGIN_STMT
- prvCheckForValidListAndQueue ();
- # DEBUG BEGIN_STMT
- xTimerQueue.0_1 = xTimerQueue;
- if (xTimerQueue.0_1 != 0B)
- goto <bb 4>; [53.47%]
- else
- goto <bb 5>; [46.53%]
- <bb 4> [local count: 78363]:
- # DEBUG BEGIN_STMT
- xReturn_5 = xTaskCreate (prvTimerTask, "Tmr Svc", 180, 0B, 2, &xTimerTaskHandle);
- # DEBUG xReturn => xReturn_5
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- if (xReturn_5 == 0)
- goto <bb 5>; [50.00%]
- else
- goto <bb 7>; [50.00%]
- <bb 5> [local count: 107374]:
- # DEBUG xReturn => NULL
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_7 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_7
- <bb 6> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 8> [local count: 1073741824]:
- goto <bb 6>; [100.00%]
- <bb 7> [local count: 39182]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- return xReturn_5;
- }
- ;; Function xTimerCreate (xTimerCreate, funcdef_no=5, decl_uid=6345, cgraph_uid=6, symbol_order=11)
- Symbols to be put in SSA form
- { D.6806 }
- Incremental SSA update started at block: 0
- Number of blocks in CFG: 14
- Number of blocks to update: 13 ( 93%)
- Merging blocks 3 and 6
- Removing basic block 5
- Merging blocks 9 and 10
- Merging blocks 3 and 7
- ;; 2 loops found
- ;;
- ;; Loop 0
- ;; header 0, latch 1
- ;; depth 0, outer -1
- ;; nodes: 0 1 2 3 4 5 6 7 8 9
- ;;
- ;; Loop 1
- ;; header 5, latch 5
- ;; depth 1, outer 0
- ;; nodes: 5
- ;; 2 succs { 3 9 }
- ;; 3 succs { 4 6 }
- ;; 4 succs { 5 }
- ;; 5 succs { 5 }
- ;; 6 succs { 7 8 }
- ;; 7 succs { 8 }
- ;; 8 succs { 9 }
- ;; 9 succs { 1 }
- xTimerCreate (const char * const pcTimerName, const TickType_t xTimerPeriodInTicks, const UBaseType_t uxAutoReload, void * const pvTimerID, void (*TimerCallbackFunction_t) (struct tmrTimerControl *) pxCallbackFunction)
- {
- uint32_t ulNewBASEPRI;
- struct Timer_t * pxNewTimer;
- struct ListItem_t * _13;
- unsigned char _14;
- unsigned char _15;
- <bb 2> [local count: 299719]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- pxNewTimer_4 = pvPortMalloc (44);
- # DEBUG pxNewTimer => pxNewTimer_4
- # DEBUG BEGIN_STMT
- if (pxNewTimer_4 != 0B)
- goto <bb 3>; [53.47%]
- else
- goto <bb 9>; [46.53%]
- <bb 3> [local count: 160260]:
- # DEBUG BEGIN_STMT
- pxNewTimer_4->ucStatus = 0;
- # DEBUG BEGIN_STMT
- # DEBUG pcTimerName => pcTimerName_6(D)
- # DEBUG xTimerPeriodInTicks => xTimerPeriodInTicks_7(D)
- # DEBUG uxAutoReload => uxAutoReload_8(D)
- # DEBUG pvTimerID => pvTimerID_9(D)
- # DEBUG pxCallbackFunction => pxCallbackFunction_10(D)
- # DEBUG pxNewTimer => pxNewTimer_4
- # DEBUG INLINE_ENTRY prvInitialiseNewTimer
- # DEBUG BEGIN_STMT
- if (xTimerPeriodInTicks_7(D) == 0)
- goto <bb 4>; [67.00%]
- else
- goto <bb 6>; [33.00%]
- <bb 4> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_12 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_12
- <bb 5> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- goto <bb 5>; [100.00%]
- <bb 6> [local count: 52886]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- prvCheckForValidListAndQueue ();
- # DEBUG BEGIN_STMT
- pxNewTimer_4->pcTimerName = pcTimerName_6(D);
- # DEBUG BEGIN_STMT
- pxNewTimer_4->xTimerPeriodInTicks = xTimerPeriodInTicks_7(D);
- # DEBUG BEGIN_STMT
- pxNewTimer_4->pvTimerID = pvTimerID_9(D);
- # DEBUG BEGIN_STMT
- pxNewTimer_4->pxCallbackFunction = pxCallbackFunction_10(D);
- # DEBUG BEGIN_STMT
- _13 = &pxNewTimer_4->xTimerListItem;
- vListInitialiseItem (_13);
- # DEBUG BEGIN_STMT
- if (uxAutoReload_8(D) != 0)
- goto <bb 7>; [50.00%]
- else
- goto <bb 8>; [50.00%]
- <bb 7> [local count: 26443]:
- # DEBUG BEGIN_STMT
- _14 = pxNewTimer_4->ucStatus;
- _15 = _14 | 4;
- pxNewTimer_4->ucStatus = _15;
- <bb 8> [local count: 52886]:
- # DEBUG BEGIN_STMT
- <bb 9> [local count: 192345]:
- # DEBUG pcTimerName => NULL
- # DEBUG xTimerPeriodInTicks => NULL
- # DEBUG uxAutoReload => NULL
- # DEBUG pvTimerID => NULL
- # DEBUG pxCallbackFunction => NULL
- # DEBUG pxNewTimer => NULL
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- return pxNewTimer_4;
- }
- ;; Function xTimerGenericCommand (xTimerGenericCommand, funcdef_no=7, decl_uid=6383, cgraph_uid=8, symbol_order=13)
- xTimerGenericCommand (struct tmrTimerControl * xTimer, const BaseType_t xCommandID, const TickType_t xOptionalValue, BaseType_t * const pxHigherPriorityTaskWoken, const TickType_t xTicksToWait)
- {
- uint32_t ulNewBASEPRI;
- struct DaemonTaskMessage_t xMessage;
- BaseType_t xReturn;
- struct QueueDefinition * xTimerQueue.20_1;
- long int _2;
- struct QueueDefinition * xTimerQueue.21_3;
- struct QueueDefinition * xTimerQueue.22_4;
- <bb 2> [local count: 357913]:
- # DEBUG BEGIN_STMT
- # DEBUG xReturn => 0
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- if (xTimer_7(D) == 0B)
- goto <bb 3>; [30.00%]
- else
- goto <bb 5>; [70.00%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_24 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_24
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 12> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 250539]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xTimerQueue.20_1 = xTimerQueue;
- if (xTimerQueue.20_1 != 0B)
- goto <bb 6>; [70.00%]
- else
- goto <bb 11>; [30.00%]
- <bb 6> [local count: 175378]:
- # DEBUG BEGIN_STMT
- xMessage.xMessageID = xCommandID_9(D);
- # DEBUG BEGIN_STMT
- xMessage.u.xTimerParameters.xMessageValue = xOptionalValue_11(D);
- # DEBUG BEGIN_STMT
- xMessage.u.xTimerParameters.pxTimer = xTimer_7(D);
- # DEBUG BEGIN_STMT
- if (xCommandID_9(D) <= 5)
- goto <bb 7>; [50.00%]
- else
- goto <bb 10>; [50.00%]
- <bb 7> [local count: 87689]:
- # DEBUG BEGIN_STMT
- _2 = xTaskGetSchedulerState ();
- if (_2 == 2)
- goto <bb 8>; [34.00%]
- else
- goto <bb 9>; [66.00%]
- <bb 8> [local count: 29814]:
- # DEBUG BEGIN_STMT
- xTimerQueue.21_3 = xTimerQueue;
- xReturn_22 = xQueueGenericSend (xTimerQueue.21_3, &xMessage, xTicksToWait_20(D), 0);
- # DEBUG xReturn => xReturn_22
- goto <bb 11>; [100.00%]
- <bb 9> [local count: 57875]:
- # DEBUG BEGIN_STMT
- xTimerQueue.22_4 = xTimerQueue;
- xReturn_19 = xQueueGenericSend (xTimerQueue.22_4, &xMessage, 0, 0);
- # DEBUG xReturn => xReturn_19
- goto <bb 11>; [100.00%]
- <bb 10> [local count: 87689]:
- # DEBUG BEGIN_STMT
- xReturn_16 = xQueueGenericSendFromISR (xTimerQueue.20_1, &xMessage, pxHigherPriorityTaskWoken_14(D), 0);
- # DEBUG xReturn => xReturn_16
- <bb 11> [local count: 250539]:
- # xReturn_5 = PHI <0(5), xReturn_16(10), xReturn_19(9), xReturn_22(8)>
- # DEBUG xReturn => xReturn_5
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xMessage ={v} {CLOBBER};
- return xReturn_5;
- }
- ;; Function xTimerGetTimerDaemonTaskHandle (xTimerGetTimerDaemonTaskHandle, funcdef_no=8, decl_uid=6354, cgraph_uid=9, symbol_order=14)
- xTimerGetTimerDaemonTaskHandle ()
- {
- uint32_t ulNewBASEPRI;
- struct tskTaskControlBlock * xTimerTaskHandle.24_1;
- <bb 2> [local count: 357913]:
- # DEBUG BEGIN_STMT
- xTimerTaskHandle.24_1 = xTimerTaskHandle;
- if (xTimerTaskHandle.24_1 == 0B)
- goto <bb 3>; [30.00%]
- else
- goto <bb 5>; [70.00%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_3 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_3
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 250539]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- return xTimerTaskHandle.24_1;
- }
- ;; Function xTimerGetPeriod (xTimerGetPeriod, funcdef_no=9, decl_uid=6373, cgraph_uid=10, symbol_order=15)
- xTimerGetPeriod (struct tmrTimerControl * xTimer)
- {
- uint32_t ulNewBASEPRI;
- TickType_t _3;
- <bb 2> [local count: 357913]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_1(D)
- # DEBUG BEGIN_STMT
- if (xTimer_1(D) == 0B)
- goto <bb 3>; [30.00%]
- else
- goto <bb 5>; [70.00%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_4 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_4
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 250539]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _3 = MEM[(struct Timer_t *)xTimer_1(D)].xTimerPeriodInTicks;
- return _3;
- }
- ;; Function vTimerSetReloadMode (vTimerSetReloadMode, funcdef_no=10, decl_uid=6369, cgraph_uid=11, symbol_order=16)
- vTimerSetReloadMode (struct tmrTimerControl * xTimer, const UBaseType_t uxAutoReload)
- {
- uint32_t ulNewBASEPRI;
- unsigned char _1;
- unsigned char _2;
- unsigned char _3;
- unsigned char _4;
- <bb 2> [local count: 230763]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_6(D)
- # DEBUG BEGIN_STMT
- if (xTimer_6(D) == 0B)
- goto <bb 3>; [46.53%]
- else
- goto <bb 5>; [53.47%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_13 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_13
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 9> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 123389]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vPortEnterCritical ();
- # DEBUG BEGIN_STMT
- if (uxAutoReload_9(D) != 0)
- goto <bb 6>; [50.00%]
- else
- goto <bb 7>; [50.00%]
- <bb 6> [local count: 61694]:
- # DEBUG BEGIN_STMT
- _1 = MEM[(struct Timer_t *)xTimer_6(D)].ucStatus;
- _2 = _1 | 4;
- MEM[(struct Timer_t *)xTimer_6(D)].ucStatus = _2;
- goto <bb 8>; [100.00%]
- <bb 7> [local count: 61694]:
- # DEBUG BEGIN_STMT
- _3 = MEM[(struct Timer_t *)xTimer_6(D)].ucStatus;
- _4 = _3 & 251;
- MEM[(struct Timer_t *)xTimer_6(D)].ucStatus = _4;
- <bb 8> [local count: 123389]:
- # DEBUG BEGIN_STMT
- vPortExitCritical ();
- return;
- }
- ;; Function uxTimerGetReloadMode (uxTimerGetReloadMode, funcdef_no=11, decl_uid=6371, cgraph_uid=12, symbol_order=17)
- uxTimerGetReloadMode (struct tmrTimerControl * xTimer)
- {
- uint32_t ulNewBASEPRI;
- UBaseType_t uxReturn;
- unsigned char _1;
- unsigned char _4;
- <bb 2> [local count: 230763]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_3(D)
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- if (xTimer_3(D) == 0B)
- goto <bb 3>; [46.53%]
- else
- goto <bb 5>; [53.47%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_8 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_8
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 8> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 123389]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vPortEnterCritical ();
- # DEBUG BEGIN_STMT
- _1 = MEM[(struct Timer_t *)xTimer_3(D)].ucStatus;
- _4 = _1 & 4;
- if (_4 == 0)
- goto <bb 7>; [50.00%]
- else
- goto <bb 6>; [50.00%]
- <bb 6> [local count: 61694]:
- # DEBUG BEGIN_STMT
- # DEBUG uxReturn => 1
- <bb 7> [local count: 123389]:
- # uxReturn_2 = PHI <0(5), 1(6)>
- # DEBUG uxReturn => uxReturn_2
- # DEBUG BEGIN_STMT
- vPortExitCritical ();
- # DEBUG BEGIN_STMT
- return uxReturn_2;
- }
- ;; Function xTimerGetExpiryTime (xTimerGetExpiryTime, funcdef_no=12, decl_uid=6375, cgraph_uid=13, symbol_order=18)
- xTimerGetExpiryTime (struct tmrTimerControl * xTimer)
- {
- uint32_t ulNewBASEPRI;
- TickType_t xReturn;
- <bb 2> [local count: 357913]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_1(D)
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- if (xTimer_1(D) == 0B)
- goto <bb 3>; [30.00%]
- else
- goto <bb 5>; [70.00%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_4 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_4
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 250539]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xReturn_3 = MEM[(struct Timer_t *)xTimer_1(D)].xTimerListItem.xItemValue;
- # DEBUG xReturn => xReturn_3
- # DEBUG BEGIN_STMT
- return xReturn_3;
- }
- ;; Function pcTimerGetName (pcTimerGetName, funcdef_no=13, decl_uid=6366, cgraph_uid=14, symbol_order=19)
- pcTimerGetName (struct tmrTimerControl * xTimer)
- {
- uint32_t ulNewBASEPRI;
- const char * _3;
- <bb 2> [local count: 357913]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_1(D)
- # DEBUG BEGIN_STMT
- if (xTimer_1(D) == 0B)
- goto <bb 3>; [30.00%]
- else
- goto <bb 5>; [70.00%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_4 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_4
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 250539]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- _3 = MEM[(struct Timer_t *)xTimer_1(D)].pcTimerName;
- return _3;
- }
- ;; Function xTimerIsTimerActive (xTimerIsTimerActive, funcdef_no=24, decl_uid=6352, cgraph_uid=25, symbol_order=30)
- xTimerIsTimerActive (struct tmrTimerControl * xTimer)
- {
- uint32_t ulNewBASEPRI;
- unsigned char _1;
- long int _2;
- unsigned char _4;
- <bb 2> [local count: 230763]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_3(D)
- # DEBUG BEGIN_STMT
- if (xTimer_3(D) == 0B)
- goto <bb 3>; [46.53%]
- else
- goto <bb 5>; [53.47%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_8 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_8
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 123389]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vPortEnterCritical ();
- # DEBUG BEGIN_STMT
- _1 = MEM[(struct Timer_t *)xTimer_3(D)].ucStatus;
- _4 = _1 & 1;
- _2 = (long int) _4;
- # DEBUG xReturn => _2
- # DEBUG BEGIN_STMT
- vPortExitCritical ();
- # DEBUG BEGIN_STMT
- return _2;
- }
- ;; Function pvTimerGetTimerID (pvTimerGetTimerID, funcdef_no=25, decl_uid=6347, cgraph_uid=26, symbol_order=31)
- pvTimerGetTimerID (struct tmrTimerControl * const xTimer)
- {
- uint32_t ulNewBASEPRI;
- void * pvReturn;
- <bb 2> [local count: 230763]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_1(D)
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- if (xTimer_1(D) == 0B)
- goto <bb 3>; [46.53%]
- else
- goto <bb 5>; [53.47%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_6 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_6
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 123389]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vPortEnterCritical ();
- # DEBUG BEGIN_STMT
- pvReturn_4 = MEM[(struct Timer_t *)xTimer_1(D)].pvTimerID;
- # DEBUG pvReturn => pvReturn_4
- # DEBUG BEGIN_STMT
- vPortExitCritical ();
- # DEBUG BEGIN_STMT
- return pvReturn_4;
- }
- ;; Function vTimerSetTimerID (vTimerSetTimerID, funcdef_no=26, decl_uid=6350, cgraph_uid=27, symbol_order=32)
- vTimerSetTimerID (struct tmrTimerControl * xTimer, void * pvNewID)
- {
- uint32_t ulNewBASEPRI;
- <bb 2> [local count: 230763]:
- # DEBUG BEGIN_STMT
- # DEBUG pxTimer => xTimer_1(D)
- # DEBUG BEGIN_STMT
- if (xTimer_1(D) == 0B)
- goto <bb 3>; [46.53%]
- else
- goto <bb 5>; [53.47%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_7 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_7
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 123389]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- vPortEnterCritical ();
- # DEBUG BEGIN_STMT
- MEM[(struct Timer_t *)xTimer_1(D)].pvTimerID = pvNewID_4(D);
- # DEBUG BEGIN_STMT
- vPortExitCritical ();
- return;
- }
- ;; Function xTimerPendFunctionCallFromISR (xTimerPendFunctionCallFromISR, funcdef_no=27, decl_uid=6359, cgraph_uid=28, symbol_order=33)
- xTimerPendFunctionCallFromISR (void (*PendedFunction_t) (void *, uint32_t) xFunctionToPend, void * pvParameter1, uint32_t ulParameter2, BaseType_t * pxHigherPriorityTaskWoken)
- {
- BaseType_t xReturn;
- struct DaemonTaskMessage_t xMessage;
- struct QueueDefinition * xTimerQueue.25_1;
- <bb 2> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xMessage.xMessageID = -2;
- # DEBUG BEGIN_STMT
- xMessage.u.xCallbackParameters.pxCallbackFunction = xFunctionToPend_4(D);
- # DEBUG BEGIN_STMT
- xMessage.u.xCallbackParameters.pvParameter1 = pvParameter1_6(D);
- # DEBUG BEGIN_STMT
- xMessage.u.xCallbackParameters.ulParameter2 = ulParameter2_8(D);
- # DEBUG BEGIN_STMT
- xTimerQueue.25_1 = xTimerQueue;
- xReturn_12 = xQueueGenericSendFromISR (xTimerQueue.25_1, &xMessage, pxHigherPriorityTaskWoken_10(D), 0);
- # DEBUG xReturn => xReturn_12
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xMessage ={v} {CLOBBER};
- return xReturn_12;
- }
- ;; Function xTimerPendFunctionCall (xTimerPendFunctionCall, funcdef_no=28, decl_uid=6364, cgraph_uid=29, symbol_order=34)
- xTimerPendFunctionCall (void (*PendedFunction_t) (void *, uint32_t) xFunctionToPend, void * pvParameter1, uint32_t ulParameter2, TickType_t xTicksToWait)
- {
- uint32_t ulNewBASEPRI;
- BaseType_t xReturn;
- struct DaemonTaskMessage_t xMessage;
- struct QueueDefinition * xTimerQueue.26_1;
- <bb 2> [local count: 230763]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xTimerQueue.26_1 = xTimerQueue;
- if (xTimerQueue.26_1 == 0B)
- goto <bb 3>; [46.53%]
- else
- goto <bb 5>; [53.47%]
- <bb 3> [local count: 107374]:
- # DEBUG BEGIN_STMT
- # DEBUG INLINE_ENTRY vPortRaiseBASEPRI
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- __asm__ __volatile__(" mov %0, %1
- msr basepri, %0
- isb
- dsb
- " : "=r" ulNewBASEPRI_14 : "i" 16 : "memory");
- # DEBUG ulNewBASEPRI => ulNewBASEPRI_14
- <bb 4> [local count: 1073741824]:
- # DEBUG ulNewBASEPRI => NULL
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- <bb 6> [local count: 1073741824]:
- goto <bb 4>; [100.00%]
- <bb 5> [local count: 123389]:
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xMessage.xMessageID = -1;
- # DEBUG BEGIN_STMT
- xMessage.u.xCallbackParameters.pxCallbackFunction = xFunctionToPend_4(D);
- # DEBUG BEGIN_STMT
- xMessage.u.xCallbackParameters.pvParameter1 = pvParameter1_6(D);
- # DEBUG BEGIN_STMT
- xMessage.u.xCallbackParameters.ulParameter2 = ulParameter2_8(D);
- # DEBUG BEGIN_STMT
- xReturn_12 = xQueueGenericSend (xTimerQueue.26_1, &xMessage, xTicksToWait_10(D), 0);
- # DEBUG xReturn => xReturn_12
- # DEBUG BEGIN_STMT
- # DEBUG BEGIN_STMT
- xMessage ={v} {CLOBBER};
- return xReturn_12;
- }
- ;; Function uxTimerGetTimerNumber (uxTimerGetTimerNumber, funcdef_no=29, decl_uid=6388, cgraph_uid=30, symbol_order=35)
- uxTimerGetTimerNumber (struct tmrTimerControl * xTimer)
- {
- UBaseType_t _3;
- <bb 2> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- _3 = MEM[(struct Timer_t *)xTimer_2(D)].uxTimerNumber;
- return _3;
- }
- ;; Function vTimerSetTimerNumber (vTimerSetTimerNumber, funcdef_no=30, decl_uid=6386, cgraph_uid=31, symbol_order=36)
- vTimerSetTimerNumber (struct tmrTimerControl * xTimer, UBaseType_t uxTimerNumber)
- {
- <bb 2> [local count: 1073741824]:
- # DEBUG BEGIN_STMT
- MEM[(struct Timer_t *)xTimer_2(D)].uxTimerNumber = uxTimerNumber_3(D);
- return;
- }
|