Teensy 4.1 core updated for C++20
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
6 年前
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404
  1. #pragma once
  2. #include <stdint.h>
  3. // Definitions based these documents:
  4. // i.MX RT1050 Reference Manual, Rev. 1, 03/2018
  5. // ARM v7-M Architecture Reference Manual (DDI 0403E.b)
  6. enum IRQ_NUMBER_t {
  7. IRQ_DMA_CH0 = 0,
  8. IRQ_DMA_CH1 = 1,
  9. IRQ_DMA_CH2 = 2,
  10. IRQ_DMA_CH3 = 3,
  11. IRQ_DMA_CH4 = 4,
  12. IRQ_DMA_CH5 = 5,
  13. IRQ_DMA_CH6 = 6,
  14. IRQ_DMA_CH7 = 7,
  15. IRQ_DMA_CH8 = 8,
  16. IRQ_DMA_CH9 = 9,
  17. IRQ_DMA_CH10 = 10,
  18. IRQ_DMA_CH11 = 11,
  19. IRQ_DMA_CH12 = 12,
  20. IRQ_DMA_CH13 = 13,
  21. IRQ_DMA_CH14 = 14,
  22. IRQ_DMA_CH15 = 15,
  23. IRQ_DMA_ERROR = 16,
  24. IRQ_CTI0 = 17,
  25. IRQ_CTI1 = 18,
  26. IRQ_CORE_ERROR = 19, // TODO - name?
  27. IRQ_LPUART1 = 20,
  28. IRQ_LPUART2 = 21,
  29. IRQ_LPUART3 = 22,
  30. IRQ_LPUART4 = 23,
  31. IRQ_LPUART5 = 24,
  32. IRQ_LPUART6 = 25,
  33. IRQ_LPUART7 = 26,
  34. IRQ_LPUART8 = 27,
  35. IRQ_LPI2C1 = 28,
  36. IRQ_LPI2C2 = 29,
  37. IRQ_LPI2C3 = 30,
  38. IRQ_LPI2C4 = 31,
  39. IRQ_LPSPI1 = 32,
  40. IRQ_LPSPI2 = 33,
  41. IRQ_LPSPI3 = 34,
  42. IRQ_LPSPI4 = 35,
  43. IRQ_CAN1 = 36,
  44. IRQ_CAN2 = 37,
  45. IRQ_ADDR_ERR = 38, // TODO: name?
  46. IRQ_KPP = 39,
  47. IRQ_TSC_DIG = 40,
  48. IRQ_GPR_IRQ = 41,
  49. IRQ_LCDIF = 42,
  50. IRQ_CSI = 43,
  51. IRQ_PXP = 44,
  52. IRQ_WDOG2 = 45,
  53. IRQ_SNVS_IRQ = 46,
  54. IRQ_SNVS_SECURITY = 47,
  55. IRQ_SNVS_ONOFF = 48,
  56. IRQ_CSU = 49,
  57. IRQ_DCP0 = 50, // TODO: ???
  58. IRQ_DCP1 = 51, // TODO: ???
  59. IRQ_DCP2 = 52, // TODO: ???
  60. IRQ_TRNG = 53,
  61. IRQ_SJC_IRQ = 54,
  62. IRQ_BEE = 55,
  63. IRQ_SAI1 = 56,
  64. IRQ_SAI2 = 57,
  65. IRQ_SAI3_RX = 58,
  66. IRQ_SAI3_TX = 59,
  67. IRQ_SPDIF = 60,
  68. IRQ_BROWNOUT0 = 61,
  69. IRQ_Reserved1 = 62,
  70. IRQ_TEMPERATURE = 63,
  71. IRQ_TEMPERATURE_PANIC = 64,
  72. IRQ_USBPHY0 = 65,
  73. IRQ_USBPHY1 = 66,
  74. IRQ_ADC1 = 67,
  75. IRQ_ADC2 = 68,
  76. IRQ_DCDC = 69,
  77. IRQ_SOFTWARE = 70,
  78. IRQ_Reserved2 = 71,
  79. IRQ_GPIO1_INT0 = 72,
  80. IRQ_GPIO1_INT1 = 73,
  81. IRQ_GPIO1_INT2 = 74,
  82. IRQ_GPIO1_INT3 = 75,
  83. IRQ_GPIO1_INT4 = 76,
  84. IRQ_GPIO1_INT5 = 77,
  85. IRQ_GPIO1_INT6 = 78,
  86. IRQ_GPIO1_INT7 = 79,
  87. IRQ_GPIO1_0_15 = 80,
  88. IRQ_GPIO1_16_31 = 81,
  89. IRQ_GPIO2_0_15 = 82,
  90. IRQ_GPIO2_16_31 = 83,
  91. IRQ_GPIO3_0_15 = 84,
  92. IRQ_GPIO3_16_31 = 85,
  93. IRQ_GPIO4_0_15 = 86,
  94. IRQ_GPIO4_16_31 = 87,
  95. IRQ_GPIO5_0_15 = 88,
  96. IRQ_GPIO5_16_31 = 89,
  97. IRQ_FLEXIO1 = 90,
  98. IRQ_FLEXIO2 = 91,
  99. IRQ_WDOG1 = 92,
  100. IRQ_RTWDOG = 93,
  101. IRQ_EWM = 94,
  102. IRQ_CCM1 = 95,
  103. IRQ_CCM2 = 96,
  104. IRQ_GPC = 97,
  105. IRQ_SRC = 98,
  106. IRQ_Reserved3 = 99,
  107. IRQ_GPT1 = 100,
  108. IRQ_GPT2 = 101,
  109. IRQ_FLEXPWM1_0 = 102,
  110. IRQ_FLEXPWM1_1 = 103,
  111. IRQ_FLEXPWM1_2 = 104,
  112. IRQ_FLEXPWM1_3 = 105,
  113. IRQ_FLEXPWM1_FAULT = 106,
  114. IRQ_FLEXSPI2 = 107, // RT1060 only
  115. IRQ_FLEXSPI = 108,
  116. IRQ_SEMC = 109,
  117. IRQ_SDHC1 = 110,
  118. IRQ_SDHC2 = 111,
  119. IRQ_USB2 = 112,
  120. IRQ_USB1 = 113,
  121. IRQ_ENET = 114,
  122. IRQ_ENET_TIMER = 115,
  123. IRQ_XBAR1_01 = 116,
  124. IRQ_XBAR1_23 = 117,
  125. IRQ_ADC_ETC0 = 118,
  126. IRQ_ADC_ETC1 = 119,
  127. IRQ_ADC_ETC2 = 120,
  128. IRQ_ADC_ETC_ERR = 121,
  129. IRQ_PIT = 122,
  130. IRQ_ACMP0 = 123,
  131. IRQ_ACMP1 = 124,
  132. IRQ_ACMP2 = 125,
  133. IRQ_ACMP3 = 126,
  134. IRQ_Reserved4 = 127,
  135. IRQ_Reserved5 = 128,
  136. IRQ_ENC1 = 129,
  137. IRQ_ENC2 = 130,
  138. IRQ_ENC3 = 131,
  139. IRQ_ENC4 = 132,
  140. IRQ_QTIMER1 = 133,
  141. IRQ_QTIMER2 = 134,
  142. IRQ_QTIMER3 = 135,
  143. IRQ_QTIMER4 = 136,
  144. IRQ_FLEXPWM2_0 = 137,
  145. IRQ_FLEXPWM2_1 = 138,
  146. IRQ_FLEXPWM2_2 = 139,
  147. IRQ_FLEXPWM2_3 = 140,
  148. IRQ_FLEXPWM2_FAULT = 141,
  149. IRQ_FLEXPWM3_0 = 142,
  150. IRQ_FLEXPWM3_1 = 143,
  151. IRQ_FLEXPWM3_2 = 144,
  152. IRQ_FLEXPWM3_3 = 145,
  153. IRQ_FLEXPWM3_FAULT = 146,
  154. IRQ_FLEXPWM4_0 = 147,
  155. IRQ_FLEXPWM4_1 = 148,
  156. IRQ_FLEXPWM4_2 = 149,
  157. IRQ_FLEXPWM4_3 = 150,
  158. IRQ_FLEXPWM4_FAULT = 151,
  159. IRQ_ENET2 = 152, // RT1060 only
  160. IRQ_ENET2_TIMER = 153, // RT1060 only
  161. IRQ_CAN3 = 154, // RT1060 only
  162. IRQ_Reserved6 = 155,
  163. IRQ_FLEXIO3 = 156, // RT1060 only
  164. IRQ_GPIO6789 = 157, // RT1060 only
  165. IRQ_SJC_DEBUG = 158,
  166. IRQ_NMI_WAKEUP = 159
  167. };
  168. #define NVIC_NUM_INTERRUPTS 160
  169. #define DMA_NUM_CHANNELS 32
  170. #ifdef __cplusplus
  171. extern "C" void (* _VectorsRam[NVIC_NUM_INTERRUPTS+16])(void);
  172. static inline void attachInterruptVector(IRQ_NUMBER_t irq, void (*function)(void)) __attribute__((always_inline, unused));
  173. static inline void attachInterruptVector(IRQ_NUMBER_t irq, void (*function)(void)) { _VectorsRam[irq + 16] = function; asm volatile("": : :"memory"); }
  174. #else
  175. extern void (* _VectorsRam[NVIC_NUM_INTERRUPTS+16])(void);
  176. static inline void attachInterruptVector(enum IRQ_NUMBER_t irq, void (*function)(void)) __attribute__((always_inline, unused));
  177. static inline void attachInterruptVector(enum IRQ_NUMBER_t irq, void (*function)(void)) { _VectorsRam[irq + 16] = function; asm volatile("": : :"memory"); }
  178. #endif
  179. #define DMAMUX_SOURCE_FLEXIO1_REQUEST0 0
  180. #define DMAMUX_SOURCE_FLEXIO1_REQUEST1 0
  181. #define DMAMUX_SOURCE_FLEXIO2_REQUEST0 1
  182. #define DMAMUX_SOURCE_FLEXIO2_REQUEST1 1
  183. #define DMAMUX_SOURCE_LPUART1_RX 2
  184. #define DMAMUX_SOURCE_LPUART1_TX 3
  185. #define DMAMUX_SOURCE_LPUART3_RX 4
  186. #define DMAMUX_SOURCE_LPUART3_TX 5
  187. #define DMAMUX_SOURCE_LPUART5_RX 6
  188. #define DMAMUX_SOURCE_LPUART5_TX 7
  189. #define DMAMUX_SOURCE_LPUART7_RX 8
  190. #define DMAMUX_SOURCE_LPUART7_TX 9
  191. #define DMAMUX_SOURCE_FLEXCAN3 11
  192. #define DMAMUX_SOURCE_CSI 12
  193. #define DMAMUX_SOURCE_LPSPI1_RX 13
  194. #define DMAMUX_SOURCE_LPSPI1_TX 14
  195. #define DMAMUX_SOURCE_LPSPI3_RX 15
  196. #define DMAMUX_SOURCE_LPSPI3_TX 16
  197. #define DMAMUX_SOURCE_LPI2C1 17
  198. #define DMAMUX_SOURCE_LPI2C3 18
  199. #define DMAMUX_SOURCE_SAI1_RX 19
  200. #define DMAMUX_SOURCE_SAI1_TX 20
  201. #define DMAMUX_SOURCE_SAI2_RX 21
  202. #define DMAMUX_SOURCE_SAI2_TX 22
  203. #define DMAMUX_SOURCE_ADC_ETC 23
  204. #define DMAMUX_SOURCE_ADC1 24
  205. #define DMAMUX_SOURCE_ACMP1 25
  206. #define DMAMUX_SOURCE_ACMP3 26
  207. #define DMAMUX_SOURCE_FLEXSPI_RX 28
  208. #define DMAMUX_SOURCE_FLEXSPI_TX 29
  209. #define DMAMUX_SOURCE_XBAR1_0 30
  210. #define DMAMUX_SOURCE_XBAR1_1 31
  211. #define DMAMUX_SOURCE_FLEXPWM1_READ0 32
  212. #define DMAMUX_SOURCE_FLEXPWM1_READ1 33
  213. #define DMAMUX_SOURCE_FLEXPWM1_READ2 34
  214. #define DMAMUX_SOURCE_FLEXPWM1_READ3 35
  215. #define DMAMUX_SOURCE_FLEXPWM1_WRITE0 36
  216. #define DMAMUX_SOURCE_FLEXPWM1_WRITE1 37
  217. #define DMAMUX_SOURCE_FLEXPWM1_WRITE2 38
  218. #define DMAMUX_SOURCE_FLEXPWM1_WRITE3 39
  219. #define DMAMUX_SOURCE_FLEXPWM3_READ0 40
  220. #define DMAMUX_SOURCE_FLEXPWM3_READ1 41
  221. #define DMAMUX_SOURCE_FLEXPWM3_READ2 42
  222. #define DMAMUX_SOURCE_FLEXPWM3_READ3 43
  223. #define DMAMUX_SOURCE_FLEXPWM3_WRITE0 44
  224. #define DMAMUX_SOURCE_FLEXPWM3_WRITE1 45
  225. #define DMAMUX_SOURCE_FLEXPWM3_WRITE2 46
  226. #define DMAMUX_SOURCE_FLEXPWM3_WRITE3 47
  227. #define DMAMUX_SOURCE_QTIMER1_READ0 48
  228. #define DMAMUX_SOURCE_QTIMER1_READ1 49
  229. #define DMAMUX_SOURCE_QTIMER1_READ2 50
  230. #define DMAMUX_SOURCE_QTIMER1_READ3 51
  231. #define DMAMUX_SOURCE_QTIMER1_WRITE0_CMPLD1 52
  232. #define DMAMUX_SOURCE_QTIMER1_WRITE1_CMPLD1 53
  233. #define DMAMUX_SOURCE_QTIMER1_WRITE2_CMPLD1 54
  234. #define DMAMUX_SOURCE_QTIMER1_WRITE3_CMPLD1 55
  235. #define DMAMUX_SOURCE_QTIMER1_WRITE1_CMPLD2 52
  236. #define DMAMUX_SOURCE_QTIMER1_WRITE0_CMPLD2 53
  237. #define DMAMUX_SOURCE_QTIMER1_WRITE3_CMPLD2 54
  238. #define DMAMUX_SOURCE_QTIMER1_WRITE2_CMPLD2 55
  239. #define DMAMUX_SOURCE_QTIMER3_READ0 56
  240. #define DMAMUX_SOURCE_QTIMER3_READ1 57
  241. #define DMAMUX_SOURCE_QTIMER3_READ2 58
  242. #define DMAMUX_SOURCE_QTIMER3_READ3 59
  243. #define DMAMUX_SOURCE_QTIMER3_WRITE0_CMPLD1 56
  244. #define DMAMUX_SOURCE_QTIMER3_WRITE1_CMPLD1 57
  245. #define DMAMUX_SOURCE_QTIMER3_WRITE2_CMPLD1 58
  246. #define DMAMUX_SOURCE_QTIMER3_WRITE3_CMPLD1 59
  247. #define DMAMUX_SOURCE_QTIMER3_WRITE1_CMPLD2 56
  248. #define DMAMUX_SOURCE_QTIMER3_WRITE0_CMPLD2 57
  249. #define DMAMUX_SOURCE_QTIMER3_WRITE3_CMPLD2 58
  250. #define DMAMUX_SOURCE_QTIMER3_WRITE2_CMPLD2 59
  251. #define DMAMUX_SOURCE_FLEXSPI2_RX 60
  252. #define DMAMUX_SOURCE_FLEXSPI2_TX 61
  253. #define DMAMUX_SOURCE_FLEXIO1_REQUEST2 64
  254. #define DMAMUX_SOURCE_FLEXIO1_REQUEST3 64
  255. #define DMAMUX_SOURCE_FLEXIO2_REQUEST2 65
  256. #define DMAMUX_SOURCE_FLEXIO2_REQUEST3 65
  257. #define DMAMUX_SOURCE_LPUART2_RX 66
  258. #define DMAMUX_SOURCE_LPUART2_TX 67
  259. #define DMAMUX_SOURCE_LPUART4_RX 68
  260. #define DMAMUX_SOURCE_LPUART4_TX 69
  261. #define DMAMUX_SOURCE_LPUART6_RX 70
  262. #define DMAMUX_SOURCE_LPUART6_TX 71
  263. #define DMAMUX_SOURCE_LPUART8_RX 72
  264. #define DMAMUX_SOURCE_LPUART8_TX 73
  265. #define DMAMUX_SOURCE_PXP 75
  266. #define DMAMUX_SOURCE_LCDIF 76
  267. #define DMAMUX_SOURCE_LPSPI2_RX 77
  268. #define DMAMUX_SOURCE_LPSPI2_TX 78
  269. #define DMAMUX_SOURCE_LPSPI4_RX 79
  270. #define DMAMUX_SOURCE_LPSPI4_TX 80
  271. #define DMAMUX_SOURCE_LPI2C2 81
  272. #define DMAMUX_SOURCE_LPI2C4 82
  273. #define DMAMUX_SOURCE_SAI3_RX 83
  274. #define DMAMUX_SOURCE_SAI3_TX 84
  275. #define DMAMUX_SOURCE_SPDIF_RX 85
  276. #define DMAMUX_SOURCE_SPDIF_TX 86
  277. #define DMAMUX_SOURCE_ADC2 88
  278. #define DMAMUX_SOURCE_ACMP2 89
  279. #define DMAMUX_SOURCE_ACMP4 90
  280. #define DMAMUX_SOURCE_ENET1_TIMER0 92
  281. #define DMAMUX_SOURCE_ENET1_TIMER1 93
  282. #define DMAMUX_SOURCE_XBAR1_2 94
  283. #define DMAMUX_SOURCE_XBAR1_3 95
  284. #define DMAMUX_SOURCE_FLEXPWM2_READ0 96
  285. #define DMAMUX_SOURCE_FLEXPWM2_READ1 97
  286. #define DMAMUX_SOURCE_FLEXPWM2_READ2 98
  287. #define DMAMUX_SOURCE_FLEXPWM2_READ3 99
  288. #define DMAMUX_SOURCE_FLEXPWM2_WRITE0 100
  289. #define DMAMUX_SOURCE_FLEXPWM2_WRITE1 101
  290. #define DMAMUX_SOURCE_FLEXPWM2_WRITE2 102
  291. #define DMAMUX_SOURCE_FLEXPWM2_WRITE3 103
  292. #define DMAMUX_SOURCE_FLEXPWM4_READ0 104
  293. #define DMAMUX_SOURCE_FLEXPWM4_READ1 105
  294. #define DMAMUX_SOURCE_FLEXPWM4_READ2 106
  295. #define DMAMUX_SOURCE_FLEXPWM4_READ3 107
  296. #define DMAMUX_SOURCE_FLEXPWM4_WRITE0 108
  297. #define DMAMUX_SOURCE_FLEXPWM4_WRITE1 109
  298. #define DMAMUX_SOURCE_FLEXPWM4_WRITE2 110
  299. #define DMAMUX_SOURCE_FLEXPWM4_WRITE3 111
  300. #define DMAMUX_SOURCE_QTIMER2_READ0 112
  301. #define DMAMUX_SOURCE_QTIMER2_READ1 113
  302. #define DMAMUX_SOURCE_QTIMER2_READ2 114
  303. #define DMAMUX_SOURCE_QTIMER2_READ3 115
  304. #define DMAMUX_SOURCE_QTIMER2_WRITE0_CMPLD1 116
  305. #define DMAMUX_SOURCE_QTIMER2_WRITE1_CMPLD1 117
  306. #define DMAMUX_SOURCE_QTIMER2_WRITE2_CMPLD1 118
  307. #define DMAMUX_SOURCE_QTIMER2_WRITE3_CMPLD1 119
  308. #define DMAMUX_SOURCE_QTIMER2_WRITE1_CMPLD2 116
  309. #define DMAMUX_SOURCE_QTIMER2_WRITE0_CMPLD2 117
  310. #define DMAMUX_SOURCE_QTIMER2_WRITE3_CMPLD2 118
  311. #define DMAMUX_SOURCE_QTIMER2_WRITE2_CMPLD2 119
  312. #define DMAMUX_SOURCE_QTIMER4_READ0 120
  313. #define DMAMUX_SOURCE_QTIMER4_READ1 121
  314. #define DMAMUX_SOURCE_QTIMER4_READ2 122
  315. #define DMAMUX_SOURCE_QTIMER4_READ3 123
  316. #define DMAMUX_SOURCE_QTIMER4_WRITE0_CMPLD1 120
  317. #define DMAMUX_SOURCE_QTIMER4_WRITE1_CMPLD1 121
  318. #define DMAMUX_SOURCE_QTIMER4_WRITE2_CMPLD1 122
  319. #define DMAMUX_SOURCE_QTIMER4_WRITE3_CMPLD1 123
  320. #define DMAMUX_SOURCE_QTIMER4_WRITE1_CMPLD2 120
  321. #define DMAMUX_SOURCE_QTIMER4_WRITE0_CMPLD2 121
  322. #define DMAMUX_SOURCE_QTIMER4_WRITE3_CMPLD2 122
  323. #define DMAMUX_SOURCE_QTIMER4_WRITE2_CMPLD2 123
  324. #define DMAMUX_SOURCE_ENET2_TIMER0 124
  325. #define DMAMUX_SOURCE_ENET2_TIMER1 125
  326. typedef struct {
  327. volatile uint32_t offset000;
  328. volatile uint32_t offset004;
  329. volatile uint32_t offset008;
  330. volatile uint32_t offset00C;
  331. volatile uint32_t offset010;
  332. volatile uint32_t offset014;
  333. volatile uint32_t offset018;
  334. volatile uint32_t offset01C;
  335. volatile uint32_t offset020;
  336. volatile uint32_t offset024;
  337. volatile uint32_t offset028;
  338. volatile uint32_t offset02C;
  339. volatile uint32_t offset030;
  340. volatile uint32_t offset034;
  341. volatile uint32_t offset038;
  342. volatile uint32_t offset03C;
  343. volatile uint32_t offset040;
  344. volatile uint32_t offset044;
  345. volatile uint32_t offset048;
  346. volatile uint32_t offset04C;
  347. volatile uint32_t offset050;
  348. volatile uint32_t offset054;
  349. volatile uint32_t offset058;
  350. volatile uint32_t offset05C;
  351. volatile uint32_t offset060;
  352. volatile uint32_t offset064;
  353. volatile uint32_t offset068;
  354. volatile uint32_t offset06C;
  355. volatile uint32_t offset070;
  356. volatile uint32_t offset074;
  357. volatile uint32_t offset078;
  358. volatile uint32_t offset07C;
  359. volatile uint32_t offset080;
  360. volatile uint32_t offset084;
  361. volatile uint32_t offset088;
  362. volatile uint32_t offset08C;
  363. volatile uint32_t offset090;
  364. volatile uint32_t offset094;
  365. volatile uint32_t offset098;
  366. volatile uint32_t offset09C;
  367. volatile uint32_t offset0A0;
  368. volatile uint32_t offset0A4;
  369. volatile uint32_t offset0A8;
  370. volatile uint32_t offset0AC;
  371. volatile uint32_t offset0B0;
  372. volatile uint32_t offset0B4;
  373. volatile uint32_t offset0B8;
  374. volatile uint32_t offset0BC;
  375. volatile uint32_t offset0C0;
  376. volatile uint32_t offset0C4;
  377. volatile uint32_t offset0C8;
  378. volatile uint32_t offset0CC;
  379. volatile uint32_t offset0D0;
  380. volatile uint32_t offset0D4;
  381. volatile uint32_t offset0D8;
  382. volatile uint32_t offset0DC;
  383. volatile uint32_t offset0E0;
  384. volatile uint32_t offset0E4;
  385. volatile uint32_t offset0E8;
  386. volatile uint32_t offset0EC;
  387. volatile uint32_t offset0F0;
  388. volatile uint32_t offset0F4;
  389. volatile uint32_t offset0F8;
  390. volatile uint32_t offset0FC;
  391. volatile uint32_t offset100;
  392. volatile uint32_t offset104;
  393. volatile uint32_t offset108;
  394. volatile uint32_t offset10C;
  395. volatile uint32_t offset110;
  396. volatile uint32_t offset114;
  397. volatile uint32_t offset118;
  398. volatile uint32_t offset11C;
  399. volatile uint32_t offset120;
  400. volatile uint32_t offset124;
  401. volatile uint32_t offset128;
  402. volatile uint32_t offset12C;
  403. volatile uint32_t offset130;
  404. volatile uint32_t offset134;
  405. volatile uint32_t offset138;
  406. volatile uint32_t offset13C;
  407. volatile uint32_t offset140;
  408. volatile uint32_t offset144;
  409. volatile uint32_t offset148;
  410. volatile uint32_t offset14C;
  411. volatile uint32_t offset150;
  412. volatile uint32_t offset154;
  413. volatile uint32_t offset158;
  414. volatile uint32_t offset15C;
  415. volatile uint32_t offset160;
  416. volatile uint32_t offset164;
  417. volatile uint32_t offset168;
  418. volatile uint32_t offset16C;
  419. volatile uint32_t offset170;
  420. volatile uint32_t offset174;
  421. volatile uint32_t offset178;
  422. volatile uint32_t offset17C;
  423. volatile uint32_t offset180;
  424. volatile uint32_t offset184;
  425. volatile uint32_t offset188;
  426. volatile uint32_t offset18C;
  427. volatile uint32_t offset190;
  428. volatile uint32_t offset194;
  429. volatile uint32_t offset198;
  430. volatile uint32_t offset19C;
  431. volatile uint32_t offset1A0;
  432. volatile uint32_t offset1A4;
  433. volatile uint32_t offset1A8;
  434. volatile uint32_t offset1AC;
  435. volatile uint32_t offset1B0;
  436. volatile uint32_t offset1B4;
  437. volatile uint32_t offset1B8;
  438. volatile uint32_t offset1BC;
  439. volatile uint32_t offset1C0;
  440. volatile uint32_t offset1C4;
  441. volatile uint32_t offset1C8;
  442. volatile uint32_t offset1CC;
  443. volatile uint32_t offset1D0;
  444. volatile uint32_t offset1D4;
  445. volatile uint32_t offset1D8;
  446. volatile uint32_t offset1DC;
  447. volatile uint32_t offset1E0;
  448. volatile uint32_t offset1E4;
  449. volatile uint32_t offset1E8;
  450. volatile uint32_t offset1EC;
  451. volatile uint32_t offset1F0;
  452. volatile uint32_t offset1F4;
  453. volatile uint32_t offset1F8;
  454. volatile uint32_t offset1FC;
  455. volatile uint32_t offset200;
  456. volatile uint32_t offset204;
  457. volatile uint32_t offset208;
  458. volatile uint32_t offset20C;
  459. volatile uint32_t offset210;
  460. volatile uint32_t offset214;
  461. volatile uint32_t offset218;
  462. volatile uint32_t offset21C;
  463. volatile uint32_t offset220;
  464. volatile uint32_t offset224;
  465. volatile uint32_t offset228;
  466. volatile uint32_t offset22C;
  467. volatile uint32_t offset230;
  468. volatile uint32_t offset234;
  469. volatile uint32_t offset238;
  470. volatile uint32_t offset23C;
  471. volatile uint32_t offset240;
  472. volatile uint32_t offset244;
  473. volatile uint32_t offset248;
  474. volatile uint32_t offset24C;
  475. volatile uint32_t offset250;
  476. volatile uint32_t offset254;
  477. volatile uint32_t offset258;
  478. volatile uint32_t offset25C;
  479. volatile uint32_t offset260;
  480. volatile uint32_t offset264;
  481. volatile uint32_t offset268;
  482. volatile uint32_t offset26C;
  483. volatile uint32_t offset270;
  484. volatile uint32_t offset274;
  485. volatile uint32_t offset278;
  486. volatile uint32_t offset27C;
  487. volatile uint32_t offset280;
  488. volatile uint32_t offset284;
  489. volatile uint32_t offset288;
  490. volatile uint32_t offset28C;
  491. volatile uint32_t offset290;
  492. volatile uint32_t offset294;
  493. volatile uint32_t offset298;
  494. volatile uint32_t offset29C;
  495. volatile uint32_t offset2A0;
  496. volatile uint32_t offset2A4;
  497. volatile uint32_t offset2A8;
  498. volatile uint32_t offset2AC;
  499. volatile uint32_t offset2B0;
  500. volatile uint32_t offset2B4;
  501. volatile uint32_t offset2B8;
  502. volatile uint32_t offset2BC;
  503. volatile uint32_t offset2C0;
  504. volatile uint32_t offset2C4;
  505. volatile uint32_t offset2C8;
  506. volatile uint32_t offset2CC;
  507. volatile uint32_t offset2D0;
  508. volatile uint32_t offset2D4;
  509. volatile uint32_t offset2D8;
  510. volatile uint32_t offset2DC;
  511. volatile uint32_t offset2E0;
  512. volatile uint32_t offset2E4;
  513. volatile uint32_t offset2E8;
  514. volatile uint32_t offset2EC;
  515. volatile uint32_t offset2F0;
  516. volatile uint32_t offset2F4;
  517. volatile uint32_t offset2F8;
  518. volatile uint32_t offset2FC;
  519. volatile uint32_t offset300;
  520. volatile uint32_t offset304;
  521. volatile uint32_t offset308;
  522. volatile uint32_t offset30C;
  523. volatile uint32_t offset310;
  524. volatile uint32_t offset314;
  525. volatile uint32_t offset318;
  526. volatile uint32_t offset31C;
  527. volatile uint32_t offset320;
  528. volatile uint32_t offset324;
  529. volatile uint32_t offset328;
  530. volatile uint32_t offset32C;
  531. volatile uint32_t offset330;
  532. volatile uint32_t offset334;
  533. volatile uint32_t offset338;
  534. volatile uint32_t offset33C;
  535. volatile uint32_t offset340;
  536. volatile uint32_t offset344;
  537. volatile uint32_t offset348;
  538. volatile uint32_t offset34C;
  539. volatile uint32_t offset350;
  540. volatile uint32_t offset354;
  541. volatile uint32_t offset358;
  542. volatile uint32_t offset35C;
  543. volatile uint32_t offset360;
  544. volatile uint32_t offset364;
  545. volatile uint32_t offset368;
  546. volatile uint32_t offset36C;
  547. volatile uint32_t offset370;
  548. volatile uint32_t offset374;
  549. volatile uint32_t offset378;
  550. volatile uint32_t offset37C;
  551. volatile uint32_t offset380;
  552. volatile uint32_t offset384;
  553. volatile uint32_t offset388;
  554. volatile uint32_t offset38C;
  555. volatile uint32_t offset390;
  556. volatile uint32_t offset394;
  557. volatile uint32_t offset398;
  558. volatile uint32_t offset39C;
  559. volatile uint32_t offset3A0;
  560. volatile uint32_t offset3A4;
  561. volatile uint32_t offset3A8;
  562. volatile uint32_t offset3AC;
  563. volatile uint32_t offset3B0;
  564. volatile uint32_t offset3B4;
  565. volatile uint32_t offset3B8;
  566. volatile uint32_t offset3BC;
  567. volatile uint32_t offset3C0;
  568. volatile uint32_t offset3C4;
  569. volatile uint32_t offset3C8;
  570. volatile uint32_t offset3CC;
  571. volatile uint32_t offset3D0;
  572. volatile uint32_t offset3D4;
  573. volatile uint32_t offset3D8;
  574. volatile uint32_t offset3DC;
  575. volatile uint32_t offset3E0;
  576. volatile uint32_t offset3E4;
  577. volatile uint32_t offset3E8;
  578. volatile uint32_t offset3EC;
  579. volatile uint32_t offset3F0;
  580. volatile uint32_t offset3F4;
  581. volatile uint32_t offset3F8;
  582. volatile uint32_t offset3FC;
  583. } IMXRT_REGISTER32_t;
  584. typedef struct {
  585. volatile uint16_t offset000;
  586. volatile uint16_t offset002;
  587. volatile uint16_t offset004;
  588. volatile uint16_t offset006;
  589. volatile uint16_t offset008;
  590. volatile uint16_t offset00A;
  591. volatile uint16_t offset00C;
  592. volatile uint16_t offset00E;
  593. volatile uint16_t offset010;
  594. volatile uint16_t offset012;
  595. volatile uint16_t offset014;
  596. volatile uint16_t offset016;
  597. volatile uint16_t offset018;
  598. volatile uint16_t offset01A;
  599. volatile uint16_t offset01C;
  600. volatile uint16_t offset01E;
  601. volatile uint16_t offset020;
  602. volatile uint16_t offset022;
  603. volatile uint16_t offset024;
  604. volatile uint16_t offset026;
  605. volatile uint16_t offset028;
  606. volatile uint16_t offset02A;
  607. volatile uint16_t offset02C;
  608. volatile uint16_t offset02E;
  609. volatile uint16_t offset030;
  610. volatile uint16_t offset032;
  611. volatile uint16_t offset034;
  612. volatile uint16_t offset036;
  613. volatile uint16_t offset038;
  614. volatile uint16_t offset03A;
  615. volatile uint16_t offset03C;
  616. volatile uint16_t offset03E;
  617. volatile uint16_t offset040;
  618. volatile uint16_t offset042;
  619. volatile uint16_t offset044;
  620. volatile uint16_t offset046;
  621. volatile uint16_t offset048;
  622. volatile uint16_t offset04A;
  623. volatile uint16_t offset04C;
  624. volatile uint16_t offset04E;
  625. volatile uint16_t offset050;
  626. volatile uint16_t offset052;
  627. volatile uint16_t offset054;
  628. volatile uint16_t offset056;
  629. volatile uint16_t offset058;
  630. volatile uint16_t offset05A;
  631. volatile uint16_t offset05C;
  632. volatile uint16_t offset05E;
  633. volatile uint16_t offset060;
  634. volatile uint16_t offset062;
  635. volatile uint16_t offset064;
  636. volatile uint16_t offset066;
  637. volatile uint16_t offset068;
  638. volatile uint16_t offset06A;
  639. volatile uint16_t offset06C;
  640. volatile uint16_t offset06E;
  641. volatile uint16_t offset070;
  642. volatile uint16_t offset072;
  643. volatile uint16_t offset074;
  644. volatile uint16_t offset076;
  645. volatile uint16_t offset078;
  646. volatile uint16_t offset07A;
  647. volatile uint16_t offset07C;
  648. volatile uint16_t offset07E;
  649. volatile uint16_t offset080;
  650. volatile uint16_t offset082;
  651. volatile uint16_t offset084;
  652. volatile uint16_t offset086;
  653. volatile uint16_t offset088;
  654. volatile uint16_t offset08A;
  655. volatile uint16_t offset08C;
  656. volatile uint16_t offset08E;
  657. volatile uint16_t offset090;
  658. volatile uint16_t offset092;
  659. volatile uint16_t offset094;
  660. volatile uint16_t offset096;
  661. volatile uint16_t offset098;
  662. volatile uint16_t offset09A;
  663. volatile uint16_t offset09C;
  664. volatile uint16_t offset09E;
  665. volatile uint16_t offset0A0;
  666. volatile uint16_t offset0A2;
  667. volatile uint16_t offset0A4;
  668. volatile uint16_t offset0A6;
  669. volatile uint16_t offset0A8;
  670. volatile uint16_t offset0AA;
  671. volatile uint16_t offset0AC;
  672. volatile uint16_t offset0AE;
  673. volatile uint16_t offset0B0;
  674. volatile uint16_t offset0B2;
  675. volatile uint16_t offset0B4;
  676. volatile uint16_t offset0B6;
  677. volatile uint16_t offset0B8;
  678. volatile uint16_t offset0BA;
  679. volatile uint16_t offset0BC;
  680. volatile uint16_t offset0BE;
  681. volatile uint16_t offset0C0;
  682. volatile uint16_t offset0C2;
  683. volatile uint16_t offset0C4;
  684. volatile uint16_t offset0C6;
  685. volatile uint16_t offset0C8;
  686. volatile uint16_t offset0CA;
  687. volatile uint16_t offset0CC;
  688. volatile uint16_t offset0CE;
  689. volatile uint16_t offset0D0;
  690. volatile uint16_t offset0D2;
  691. volatile uint16_t offset0D4;
  692. volatile uint16_t offset0D6;
  693. volatile uint16_t offset0D8;
  694. volatile uint16_t offset0DA;
  695. volatile uint16_t offset0DC;
  696. volatile uint16_t offset0DE;
  697. volatile uint16_t offset0E0;
  698. volatile uint16_t offset0E2;
  699. volatile uint16_t offset0E4;
  700. volatile uint16_t offset0E6;
  701. volatile uint16_t offset0E8;
  702. volatile uint16_t offset0EA;
  703. volatile uint16_t offset0EC;
  704. volatile uint16_t offset0EE;
  705. volatile uint16_t offset0F0;
  706. volatile uint16_t offset0F2;
  707. volatile uint16_t offset0F4;
  708. volatile uint16_t offset0F6;
  709. volatile uint16_t offset0F8;
  710. volatile uint16_t offset0FA;
  711. volatile uint16_t offset0FC;
  712. volatile uint16_t offset0FE;
  713. volatile uint16_t offset100;
  714. volatile uint16_t offset102;
  715. volatile uint16_t offset104;
  716. volatile uint16_t offset106;
  717. volatile uint16_t offset108;
  718. volatile uint16_t offset10A;
  719. volatile uint16_t offset10C;
  720. volatile uint16_t offset10E;
  721. volatile uint16_t offset110;
  722. volatile uint16_t offset112;
  723. volatile uint16_t offset114;
  724. volatile uint16_t offset116;
  725. volatile uint16_t offset118;
  726. volatile uint16_t offset11A;
  727. volatile uint16_t offset11C;
  728. volatile uint16_t offset11E;
  729. volatile uint16_t offset120;
  730. volatile uint16_t offset122;
  731. volatile uint16_t offset124;
  732. volatile uint16_t offset126;
  733. volatile uint16_t offset128;
  734. volatile uint16_t offset12A;
  735. volatile uint16_t offset12C;
  736. volatile uint16_t offset12E;
  737. volatile uint16_t offset130;
  738. volatile uint16_t offset132;
  739. volatile uint16_t offset134;
  740. volatile uint16_t offset136;
  741. volatile uint16_t offset138;
  742. volatile uint16_t offset13A;
  743. volatile uint16_t offset13C;
  744. volatile uint16_t offset13E;
  745. volatile uint16_t offset140;
  746. volatile uint16_t offset142;
  747. volatile uint16_t offset144;
  748. volatile uint16_t offset146;
  749. volatile uint16_t offset148;
  750. volatile uint16_t offset14A;
  751. volatile uint16_t offset14C;
  752. volatile uint16_t offset14E;
  753. volatile uint16_t offset150;
  754. volatile uint16_t offset152;
  755. volatile uint16_t offset154;
  756. volatile uint16_t offset156;
  757. volatile uint16_t offset158;
  758. volatile uint16_t offset15A;
  759. volatile uint16_t offset15C;
  760. volatile uint16_t offset15E;
  761. volatile uint16_t offset160;
  762. volatile uint16_t offset162;
  763. volatile uint16_t offset164;
  764. volatile uint16_t offset166;
  765. volatile uint16_t offset168;
  766. volatile uint16_t offset16A;
  767. volatile uint16_t offset16C;
  768. volatile uint16_t offset16E;
  769. volatile uint16_t offset170;
  770. volatile uint16_t offset172;
  771. volatile uint16_t offset174;
  772. volatile uint16_t offset176;
  773. volatile uint16_t offset178;
  774. volatile uint16_t offset17A;
  775. volatile uint16_t offset17C;
  776. volatile uint16_t offset17E;
  777. volatile uint16_t offset180;
  778. volatile uint16_t offset182;
  779. volatile uint16_t offset184;
  780. volatile uint16_t offset186;
  781. volatile uint16_t offset188;
  782. volatile uint16_t offset18A;
  783. volatile uint16_t offset18C;
  784. volatile uint16_t offset18E;
  785. volatile uint16_t offset190;
  786. volatile uint16_t offset192;
  787. volatile uint16_t offset194;
  788. volatile uint16_t offset196;
  789. volatile uint16_t offset198;
  790. volatile uint16_t offset19A;
  791. volatile uint16_t offset19C;
  792. volatile uint16_t offset19E;
  793. volatile uint16_t offset1A0;
  794. volatile uint16_t offset1A2;
  795. volatile uint16_t offset1A4;
  796. volatile uint16_t offset1A6;
  797. volatile uint16_t offset1A8;
  798. volatile uint16_t offset1AA;
  799. volatile uint16_t offset1AC;
  800. volatile uint16_t offset1AE;
  801. volatile uint16_t offset1B0;
  802. volatile uint16_t offset1B2;
  803. volatile uint16_t offset1B4;
  804. volatile uint16_t offset1B6;
  805. volatile uint16_t offset1B8;
  806. volatile uint16_t offset1BA;
  807. volatile uint16_t offset1BC;
  808. volatile uint16_t offset1BE;
  809. volatile uint16_t offset1C0;
  810. volatile uint16_t offset1C2;
  811. volatile uint16_t offset1C4;
  812. volatile uint16_t offset1C6;
  813. volatile uint16_t offset1C8;
  814. volatile uint16_t offset1CA;
  815. volatile uint16_t offset1CC;
  816. volatile uint16_t offset1CE;
  817. volatile uint16_t offset1D0;
  818. volatile uint16_t offset1D2;
  819. volatile uint16_t offset1D4;
  820. volatile uint16_t offset1D6;
  821. volatile uint16_t offset1D8;
  822. volatile uint16_t offset1DA;
  823. volatile uint16_t offset1DC;
  824. volatile uint16_t offset1DE;
  825. volatile uint16_t offset1E0;
  826. volatile uint16_t offset1E2;
  827. volatile uint16_t offset1E4;
  828. volatile uint16_t offset1E6;
  829. volatile uint16_t offset1E8;
  830. volatile uint16_t offset1EA;
  831. volatile uint16_t offset1EC;
  832. volatile uint16_t offset1EE;
  833. volatile uint16_t offset1F0;
  834. volatile uint16_t offset1F2;
  835. volatile uint16_t offset1F4;
  836. volatile uint16_t offset1F6;
  837. volatile uint16_t offset1F8;
  838. volatile uint16_t offset1FA;
  839. volatile uint16_t offset1FC;
  840. volatile uint16_t offset1FE;
  841. } IMXRT_REGISTER16_t;
  842. typedef struct {
  843. volatile uint8_t offset00;
  844. volatile uint8_t offset01;
  845. volatile uint8_t offset02;
  846. volatile uint8_t offset03;
  847. volatile uint8_t offset04;
  848. volatile uint8_t offset05;
  849. volatile uint8_t offset06;
  850. volatile uint8_t offset07;
  851. volatile uint8_t offset08;
  852. volatile uint8_t offset09;
  853. volatile uint8_t offset0A;
  854. volatile uint8_t offset0B;
  855. volatile uint8_t offset0C;
  856. volatile uint8_t offset0D;
  857. volatile uint8_t offset0E;
  858. volatile uint8_t offset0F;
  859. } IMXRT_REGISTER8_t;
  860. // 13.3: page 456
  861. #define IMXRT_CMP1 (*(IMXRT_REGISTER8_t *)0x40094000)
  862. #define CMP1_CR0 (IMXRT_CMP1.offset00)
  863. #define CMP1_CR1 (IMXRT_CMP1.offset01)
  864. #define CMP1_FPR (IMXRT_CMP1.offset02)
  865. #define CMP1_SCR (IMXRT_CMP1.offset03)
  866. #define CMP1_DACCR (IMXRT_CMP1.offset04)
  867. #define CMP1_MUXCR (IMXRT_CMP1.offset05)
  868. #define IMXRT_CMP2 (*(IMXRT_REGISTER8_t *)0x40094008)
  869. #define CMP2_CR0 (IMXRT_CMP2.offset00)
  870. #define CMP2_CR1 (IMXRT_CMP2.offset01)
  871. #define CMP2_FPR (IMXRT_CMP2.offset02)
  872. #define CMP2_SCR (IMXRT_CMP2.offset03)
  873. #define CMP2_DACCR (IMXRT_CMP2.offset04)
  874. #define CMP2_MUXCR (IMXRT_CMP2.offset05)
  875. #define IMXRT_CMP3 (*(IMXRT_REGISTER8_t *)0x40094010)
  876. #define CMP3_CR0 (IMXRT_CMP3.offset00)
  877. #define CMP3_CR1 (IMXRT_CMP3.offset01)
  878. #define CMP3_FPR (IMXRT_CMP3.offset02)
  879. #define CMP3_SCR (IMXRT_CMP3.offset03)
  880. #define CMP3_DACCR (IMXRT_CMP3.offset04)
  881. #define CMP3_MUXCR (IMXRT_CMP3.offset05)
  882. #define IMXRT_CMP4 (*(IMXRT_REGISTER8_t *)0x40094018)
  883. #define CMP4_CR0 (IMXRT_CMP4.offset00)
  884. #define CMP4_CR1 (IMXRT_CMP4.offset01)
  885. #define CMP4_FPR (IMXRT_CMP4.offset02)
  886. #define CMP4_SCR (IMXRT_CMP4.offset03)
  887. #define CMP4_DACCR (IMXRT_CMP4.offset04)
  888. #define CMP4_MUXCR (IMXRT_CMP4.offset05)
  889. // 14.6: page 505
  890. #define IMXRT_ADC1 (*(IMXRT_REGISTER32_t *)0x400C4000)
  891. #define ADC1_HC0 (IMXRT_ADC1.offset000)
  892. #define ADC1_HC1 (IMXRT_ADC1.offset004)
  893. #define ADC1_HC2 (IMXRT_ADC1.offset008)
  894. #define ADC1_HC3 (IMXRT_ADC1.offset00C)
  895. #define ADC1_HC4 (IMXRT_ADC1.offset010)
  896. #define ADC1_HC5 (IMXRT_ADC1.offset014)
  897. #define ADC1_HC6 (IMXRT_ADC1.offset018)
  898. #define ADC1_HC7 (IMXRT_ADC1.offset01C)
  899. #define ADC1_HS (IMXRT_ADC1.offset020)
  900. #define ADC1_R0 (IMXRT_ADC1.offset024)
  901. #define ADC1_R1 (IMXRT_ADC1.offset028)
  902. #define ADC1_R2 (IMXRT_ADC1.offset02C)
  903. #define ADC1_R3 (IMXRT_ADC1.offset030)
  904. #define ADC1_R4 (IMXRT_ADC1.offset034)
  905. #define ADC1_R5 (IMXRT_ADC1.offset038)
  906. #define ADC1_R6 (IMXRT_ADC1.offset03C)
  907. #define ADC1_R7 (IMXRT_ADC1.offset040)
  908. #define ADC1_CFG (IMXRT_ADC1.offset044)
  909. #define ADC1_GC (IMXRT_ADC1.offset048)
  910. #define ADC1_GS (IMXRT_ADC1.offset04C)
  911. #define ADC1_CV (IMXRT_ADC1.offset050)
  912. #define ADC1_OFS (IMXRT_ADC1.offset054)
  913. #define ADC1_CAL (IMXRT_ADC1.offset058)
  914. #define IMXRT_ADC2 (*(IMXRT_REGISTER32_t *)0x400C8000)
  915. #define ADC2_HC0 (IMXRT_ADC2.offset000)
  916. #define ADC2_HC1 (IMXRT_ADC2.offset004)
  917. #define ADC2_HC2 (IMXRT_ADC2.offset008)
  918. #define ADC2_HC3 (IMXRT_ADC2.offset00C)
  919. #define ADC2_HC4 (IMXRT_ADC2.offset010)
  920. #define ADC2_HC5 (IMXRT_ADC2.offset014)
  921. #define ADC2_HC6 (IMXRT_ADC2.offset018)
  922. #define ADC2_HC7 (IMXRT_ADC2.offset01C)
  923. #define ADC2_HS (IMXRT_ADC2.offset020)
  924. #define ADC2_R0 (IMXRT_ADC2.offset024)
  925. #define ADC2_R1 (IMXRT_ADC2.offset028)
  926. #define ADC2_R2 (IMXRT_ADC2.offset02C)
  927. #define ADC2_R3 (IMXRT_ADC2.offset030)
  928. #define ADC2_R4 (IMXRT_ADC2.offset034)
  929. #define ADC2_R5 (IMXRT_ADC2.offset038)
  930. #define ADC2_R6 (IMXRT_ADC2.offset03C)
  931. #define ADC2_R7 (IMXRT_ADC2.offset040)
  932. #define ADC2_CFG (IMXRT_ADC2.offset044)
  933. #define ADC2_GC (IMXRT_ADC2.offset048)
  934. #define ADC2_GS (IMXRT_ADC2.offset04C)
  935. #define ADC2_CV (IMXRT_ADC2.offset050)
  936. #define ADC2_OFS (IMXRT_ADC2.offset054)
  937. #define ADC2_CAL (IMXRT_ADC2.offset058)
  938. #define ADC_HC_AIEN ((uint32_t)(1<<7))
  939. #define ADC_HC_ADCH(n) ((uint32_t)(((n) & 0x1F) << 0))
  940. #define ADC_HS_COCO0 ((uint32_t)(1<<0))
  941. #define ADC_CFG_OVWREN ((uint32_t)(1<<16))
  942. #define ADC_CFG_AVGS(n) ((uint32_t)(((n) & 0x03) << 14))
  943. #define ADC_CFG_ADTRG ((uint32_t)(1<<13))
  944. #define ADC_CFG_REFSEL(n) ((uint32_t)(((n) & 0x03) << 11))
  945. #define ADC_CFG_ADHSC ((uint32_t)(1<<10))
  946. #define ADC_CFG_ADSTS(n) ((uint32_t)(((n) & 0x03) << 8))
  947. #define ADC_CFG_ADLPC ((uint32_t)(1<<7))
  948. #define ADC_CFG_ADIV(n) ((uint32_t)(((n) & 0x03) << 5))
  949. #define ADC_CFG_ADLSMP ((uint32_t)(1<<4))
  950. #define ADC_CFG_MODE(n) ((uint32_t)(((n) & 0x03) << 2))
  951. #define ADC_CFG_ADICLK(n) ((uint32_t)(((n) & 0x03) << 0))
  952. #define ADC_GC_CAL ((uint32_t)(1<<7))
  953. #define ADC_GC_ADCO ((uint32_t)(1<<6))
  954. #define ADC_GC_AVGE ((uint32_t)(1<<5))
  955. #define ADC_GC_ACFE ((uint32_t)(1<<4))
  956. #define ADC_GC_ACFGT ((uint32_t)(1<<3))
  957. #define ADC_GC_ACREN ((uint32_t)(1<<2))
  958. #define ADC_GC_DMAEN ((uint32_t)(1<<1))
  959. #define ADC_GC_ADACKEN ((uint32_t)(1<<0))
  960. #define ADC_GS_AWKST ((uint32_t)(1<<2))
  961. #define ADC_GS_CALF ((uint32_t)(1<<1))
  962. #define ADC_GS_ADACT ((uint32_t)(1<<0))
  963. #define ADC_CV_CV2(n) ((uint32_t)(((n) & 0xFFF) << 16))
  964. #define ADC_CV_CV1(n) ((uint32_t)(((n) & 0xFFF) << 0))
  965. #define ADC_OFS_SIGN ((uint32_t)(1<<12))
  966. #define ADC_OFS_OFS(n) ((uint32_t)(((n) & 0xFFF) << 0))
  967. #define ADC_CAL_CAL_CODE(n) ((uint32_t)(((n) & 0x0F) << 0))
  968. // 15.4.1.1: page 527
  969. #define IMXRT_ADC_ETC (*(IMXRT_REGISTER32_t *)0x403B0000)
  970. #define ADC_ETC_CTRL (IMXRT_ADC_ETC.offset000)
  971. #define ADC_ETC_DONE0_1_IRQ (IMXRT_ADC_ETC.offset004)
  972. #define ADC_ETC_DONE2_ERR_IRQ (IMXRT_ADC_ETC.offset008)
  973. #define ADC_ETC_DMA_CTRL (IMXRT_ADC_ETC.offset00C)
  974. #define ADC_ETC_TRIG0_CTRL (IMXRT_ADC_ETC.offset010)
  975. #define ADC_ETC_TRIG0_COUNTER (IMXRT_ADC_ETC.offset014)
  976. #define ADC_ETC_TRIG0_CHAIN_1_0 (IMXRT_ADC_ETC.offset018)
  977. #define ADC_ETC_TRIG0_CHAIN_3_2 (IMXRT_ADC_ETC.offset01C)
  978. #define ADC_ETC_TRIG0_CHAIN_5_4 (IMXRT_ADC_ETC.offset020)
  979. #define ADC_ETC_TRIG0_CHAIN_7_6 (IMXRT_ADC_ETC.offset024)
  980. #define ADC_ETC_TRIG0_RESULT_1_0 (IMXRT_ADC_ETC.offset028)
  981. #define ADC_ETC_TRIG0_RESULT_3_2 (IMXRT_ADC_ETC.offset02C)
  982. #define ADC_ETC_TRIG0_RESULT_5_4 (IMXRT_ADC_ETC.offset030)
  983. #define ADC_ETC_TRIG0_RESULT_7_6 (IMXRT_ADC_ETC.offset034)
  984. #define ADC_ETC_TRIG1_CTRL (IMXRT_ADC_ETC.offset038)
  985. #define ADC_ETC_TRIG1_COUNTER (IMXRT_ADC_ETC.offset03C)
  986. #define ADC_ETC_TRIG1_CHAIN_1_0 (IMXRT_ADC_ETC.offset040)
  987. #define ADC_ETC_TRIG1_CHAIN_3_2 (IMXRT_ADC_ETC.offset044)
  988. #define ADC_ETC_TRIG1_CHAIN_5_4 (IMXRT_ADC_ETC.offset048)
  989. #define ADC_ETC_TRIG1_CHAIN_7_6 (IMXRT_ADC_ETC.offset04C)
  990. #define ADC_ETC_TRIG1_RESULT_1_0 (IMXRT_ADC_ETC.offset050)
  991. #define ADC_ETC_TRIG1_RESULT_3_2 (IMXRT_ADC_ETC.offset054)
  992. #define ADC_ETC_TRIG1_RESULT_5_4 (IMXRT_ADC_ETC.offset058)
  993. #define ADC_ETC_TRIG1_RESULT_7_6 (IMXRT_ADC_ETC.offset05C)
  994. #define ADC_ETC_TRIG2_CTRL (IMXRT_ADC_ETC.offset060)
  995. #define ADC_ETC_TRIG2_COUNTER (IMXRT_ADC_ETC.offset064)
  996. #define ADC_ETC_TRIG2_CHAIN_1_0 (IMXRT_ADC_ETC.offset068)
  997. #define ADC_ETC_TRIG2_CHAIN_3_2 (IMXRT_ADC_ETC.offset06C)
  998. #define ADC_ETC_TRIG2_CHAIN_5_4 (IMXRT_ADC_ETC.offset070)
  999. #define ADC_ETC_TRIG2_CHAIN_7_6 (IMXRT_ADC_ETC.offset074)
  1000. #define ADC_ETC_TRIG2_RESULT_1_0 (IMXRT_ADC_ETC.offset078)
  1001. #define ADC_ETC_TRIG2_RESULT_3_2 (IMXRT_ADC_ETC.offset07C)
  1002. #define ADC_ETC_TRIG2_RESULT_5_4 (IMXRT_ADC_ETC.offset080)
  1003. #define ADC_ETC_TRIG2_RESULT_7_6 (IMXRT_ADC_ETC.offset084)
  1004. #define ADC_ETC_TRIG3_CTRL (IMXRT_ADC_ETC.offset088)
  1005. #define ADC_ETC_TRIG3_COUNTER (IMXRT_ADC_ETC.offset08C)
  1006. #define ADC_ETC_TRIG3_CHAIN_1_0 (IMXRT_ADC_ETC.offset090)
  1007. #define ADC_ETC_TRIG3_CHAIN_3_2 (IMXRT_ADC_ETC.offset094)
  1008. #define ADC_ETC_TRIG3_CHAIN_5_4 (IMXRT_ADC_ETC.offset098)
  1009. #define ADC_ETC_TRIG3_CHAIN_7_6 (IMXRT_ADC_ETC.offset09C)
  1010. #define ADC_ETC_TRIG3_RESULT_1_0 (IMXRT_ADC_ETC.offset0A0)
  1011. #define ADC_ETC_TRIG3_RESULT_3_2 (IMXRT_ADC_ETC.offset0A4)
  1012. #define ADC_ETC_TRIG3_RESULT_5_4 (IMXRT_ADC_ETC.offset0A8)
  1013. #define ADC_ETC_TRIG3_RESULT_7_6 (IMXRT_ADC_ETC.offset0AC)
  1014. #define ADC_ETC_TRIG4_CTRL (IMXRT_ADC_ETC.offset0B0)
  1015. #define ADC_ETC_TRIG4_COUNTER (IMXRT_ADC_ETC.offset0B4)
  1016. #define ADC_ETC_TRIG4_CHAIN_1_0 (IMXRT_ADC_ETC.offset0B8)
  1017. #define ADC_ETC_TRIG4_CHAIN_3_2 (IMXRT_ADC_ETC.offset0BC)
  1018. #define ADC_ETC_TRIG4_CHAIN_5_4 (IMXRT_ADC_ETC.offset0C0)
  1019. #define ADC_ETC_TRIG4_CHAIN_7_6 (IMXRT_ADC_ETC.offset0C4)
  1020. #define ADC_ETC_TRIG4_RESULT_1_0 (IMXRT_ADC_ETC.offset0C8)
  1021. #define ADC_ETC_TRIG4_RESULT_3_2 (IMXRT_ADC_ETC.offset0CC)
  1022. #define ADC_ETC_TRIG4_RESULT_5_4 (IMXRT_ADC_ETC.offset0D0)
  1023. #define ADC_ETC_TRIG4_RESULT_7_6 (IMXRT_ADC_ETC.offset0D4)
  1024. #define ADC_ETC_TRIG5_CTRL (IMXRT_ADC_ETC.offset0D8)
  1025. #define ADC_ETC_TRIG5_COUNTER (IMXRT_ADC_ETC.offset0DC)
  1026. #define ADC_ETC_TRIG5_CHAIN_1_0 (IMXRT_ADC_ETC.offset0E0)
  1027. #define ADC_ETC_TRIG5_CHAIN_3_2 (IMXRT_ADC_ETC.offset0E4)
  1028. #define ADC_ETC_TRIG5_CHAIN_5_4 (IMXRT_ADC_ETC.offset0E8)
  1029. #define ADC_ETC_TRIG5_CHAIN_7_6 (IMXRT_ADC_ETC.offset0EC)
  1030. #define ADC_ETC_TRIG5_RESULT_1_0 (IMXRT_ADC_ETC.offset0F0)
  1031. #define ADC_ETC_TRIG5_RESULT_3_2 (IMXRT_ADC_ETC.offset0F4)
  1032. #define ADC_ETC_TRIG5_RESULT_5_4 (IMXRT_ADC_ETC.offset0F8)
  1033. #define ADC_ETC_TRIG5_RESULT_7_6 (IMXRT_ADC_ETC.offset0FC)
  1034. #define ADC_ETC_TRIG6_CTRL (IMXRT_ADC_ETC.offset100)
  1035. #define ADC_ETC_TRIG6_COUNTER (IMXRT_ADC_ETC.offset104)
  1036. #define ADC_ETC_TRIG6_CHAIN_1_0 (IMXRT_ADC_ETC.offset108)
  1037. #define ADC_ETC_TRIG6_CHAIN_3_2 (IMXRT_ADC_ETC.offset10C)
  1038. #define ADC_ETC_TRIG6_CHAIN_5_4 (IMXRT_ADC_ETC.offset110)
  1039. #define ADC_ETC_TRIG6_CHAIN_7_6 (IMXRT_ADC_ETC.offset114)
  1040. #define ADC_ETC_TRIG6_RESULT_1_0 (IMXRT_ADC_ETC.offset118)
  1041. #define ADC_ETC_TRIG6_RESULT_3_2 (IMXRT_ADC_ETC.offset11C)
  1042. #define ADC_ETC_TRIG6_RESULT_5_4 (IMXRT_ADC_ETC.offset120)
  1043. #define ADC_ETC_TRIG6_RESULT_7_6 (IMXRT_ADC_ETC.offset124)
  1044. #define ADC_ETC_TRIG7_CTRL (IMXRT_ADC_ETC.offset128)
  1045. #define ADC_ETC_TRIG7_COUNTER (IMXRT_ADC_ETC.offset12C)
  1046. #define ADC_ETC_TRIG7_CHAIN_1_0 (IMXRT_ADC_ETC.offset130)
  1047. #define ADC_ETC_TRIG7_CHAIN_3_2 (IMXRT_ADC_ETC.offset134)
  1048. #define ADC_ETC_TRIG7_CHAIN_5_4 (IMXRT_ADC_ETC.offset138)
  1049. #define ADC_ETC_TRIG7_CHAIN_7_6 (IMXRT_ADC_ETC.offset13C)
  1050. #define ADC_ETC_TRIG7_RESULT_1_0 (IMXRT_ADC_ETC.offset140)
  1051. #define ADC_ETC_TRIG7_RESULT_3_2 (IMXRT_ADC_ETC.offset144)
  1052. #define ADC_ETC_TRIG7_RESULT_5_4 (IMXRT_ADC_ETC.offset148)
  1053. #define ADC_ETC_TRIG7_RESULT_7_6 (IMXRT_ADC_ETC.offset14C)
  1054. // 16.7: page 640
  1055. #define IMXRT_AIPSTZ1 (*(IMXRT_REGISTER32_t *)0x4007C000)
  1056. #define AIPSTZ1_MPR (IMXRT_AIPSTZ1.offset000)
  1057. #define AIPSTZ1_OPACR (IMXRT_AIPSTZ1.offset040)
  1058. #define AIPSTZ1_OPACR1 (IMXRT_AIPSTZ1.offset044)
  1059. #define AIPSTZ1_OPACR2 (IMXRT_AIPSTZ1.offset048)
  1060. #define AIPSTZ1_OPACR3 (IMXRT_AIPSTZ1.offset04C)
  1061. #define AIPSTZ1_OPACR4 (IMXRT_AIPSTZ1.offset050)
  1062. #define IMXRT_AIPSTZ2 (*(IMXRT_REGISTER32_t *)0x4017C000)
  1063. #define AIPSTZ2_MPR (IMXRT_AIPSTZ2.offset000)
  1064. #define AIPSTZ2_OPACR (IMXRT_AIPSTZ2.offset040)
  1065. #define AIPSTZ2_OPACR1 (IMXRT_AIPSTZ2.offset044)
  1066. #define AIPSTZ2_OPACR2 (IMXRT_AIPSTZ2.offset048)
  1067. #define AIPSTZ2_OPACR3 (IMXRT_AIPSTZ2.offset04C)
  1068. #define AIPSTZ2_OPACR4 (IMXRT_AIPSTZ2.offset050)
  1069. #define IMXRT_AIPSTZ3 (*(IMXRT_REGISTER32_t *)0x4027C000)
  1070. #define AIPSTZ3_MPR (IMXRT_AIPSTZ3.offset000)
  1071. #define AIPSTZ3_OPACR (IMXRT_AIPSTZ3.offset040)
  1072. #define AIPSTZ3_OPACR1 (IMXRT_AIPSTZ3.offset044)
  1073. #define AIPSTZ3_OPACR2 (IMXRT_AIPSTZ3.offset048)
  1074. #define AIPSTZ3_OPACR3 (IMXRT_AIPSTZ3.offset04C)
  1075. #define AIPSTZ3_OPACR4 (IMXRT_AIPSTZ3.offset050)
  1076. #define IMXRT_AIPSTZ4 (*(IMXRT_REGISTER32_t *)0x4037C000)
  1077. #define AIPSTZ4_MPR (IMXRT_AIPSTZ4.offset000)
  1078. #define AIPSTZ4_OPACR (IMXRT_AIPSTZ4.offset040)
  1079. #define AIPSTZ4_OPACR1 (IMXRT_AIPSTZ4.offset044)
  1080. #define AIPSTZ4_OPACR2 (IMXRT_AIPSTZ4.offset048)
  1081. #define AIPSTZ4_OPACR3 (IMXRT_AIPSTZ4.offset04C)
  1082. #define AIPSTZ4_OPACR4 (IMXRT_AIPSTZ4.offset050)
  1083. // 17.3: page 662
  1084. #define IMXRT_AOI1 (*(IMXRT_REGISTER16_t *)0x403B4000)
  1085. #define AOI1_BFCRT010 (IMXRT_AOI1.offset000)
  1086. #define AOI1_BFCRT230 (IMXRT_AOI1.offset002)
  1087. #define AOI1_BFCRT011 (IMXRT_AOI1.offset004)
  1088. #define AOI1_BFCRT231 (IMXRT_AOI1.offset006)
  1089. #define AOI1_BFCRT012 (IMXRT_AOI1.offset008)
  1090. #define AOI1_BFCRT232 (IMXRT_AOI1.offset00A)
  1091. #define AOI1_BFCRT013 (IMXRT_AOI1.offset00C)
  1092. #define AOI1_BFCRT233 (IMXRT_AOI1.offset00E)
  1093. #define IMXRT_AOI2 (*(IMXRT_REGISTER16_t *)0x403B8000)
  1094. #define AOI2_BFCRT010 (IMXRT_AOI2.offset000)
  1095. #define AOI2_BFCRT230 (IMXRT_AOI2.offset002)
  1096. #define AOI2_BFCRT011 (IMXRT_AOI2.offset004)
  1097. #define AOI2_BFCRT231 (IMXRT_AOI2.offset006)
  1098. #define AOI2_BFCRT012 (IMXRT_AOI2.offset008)
  1099. #define AOI2_BFCRT232 (IMXRT_AOI2.offset00A)
  1100. #define AOI2_BFCRT013 (IMXRT_AOI2.offset00C)
  1101. #define AOI2_BFCRT233 (IMXRT_AOI2.offset00E)
  1102. // 18.7: page 703
  1103. #define IMXRT_CCM (*(IMXRT_REGISTER32_t *)0x400FC000)
  1104. #define CCM_CCR (IMXRT_CCM.offset000)
  1105. #define CCM_CSR (IMXRT_CCM.offset008)
  1106. #define CCM_CCSR (IMXRT_CCM.offset00C)
  1107. #define CCM_CACRR (IMXRT_CCM.offset010)
  1108. #define CCM_CBCDR (IMXRT_CCM.offset014)
  1109. #define CCM_CBCMR (IMXRT_CCM.offset018)
  1110. #define CCM_CSCMR1 (IMXRT_CCM.offset01C)
  1111. #define CCM_CSCMR2 (IMXRT_CCM.offset020)
  1112. #define CCM_CSCDR1 (IMXRT_CCM.offset024)
  1113. #define CCM_CS1CDR (IMXRT_CCM.offset028)
  1114. #define CCM_CS2CDR (IMXRT_CCM.offset02C)
  1115. #define CCM_CDCDR (IMXRT_CCM.offset030)
  1116. #define CCM_CSCDR2 (IMXRT_CCM.offset038)
  1117. #define CCM_CSCDR3 (IMXRT_CCM.offset03C)
  1118. #define CCM_CDHIPR (IMXRT_CCM.offset048)
  1119. #define CCM_CLPCR (IMXRT_CCM.offset054)
  1120. #define CCM_CISR (IMXRT_CCM.offset058)
  1121. #define CCM_CIMR (IMXRT_CCM.offset05C)
  1122. #define CCM_CCOSR (IMXRT_CCM.offset060)
  1123. #define CCM_CGPR (IMXRT_CCM.offset064)
  1124. #define CCM_CCGR0 (IMXRT_CCM.offset068)
  1125. #define CCM_CCGR1 (IMXRT_CCM.offset06C)
  1126. #define CCM_CCGR2 (IMXRT_CCM.offset070)
  1127. #define CCM_CCGR3 (IMXRT_CCM.offset074)
  1128. #define CCM_CCGR4 (IMXRT_CCM.offset078)
  1129. #define CCM_CCGR5 (IMXRT_CCM.offset07C)
  1130. #define CCM_CCGR6 (IMXRT_CCM.offset080)
  1131. #define CCM_CCGR7 (IMXRT_CCM.offset084)
  1132. #define CCM_CMEOR (IMXRT_CCM.offset088)
  1133. #define CCM_CCR_RBC_EN ((uint32_t)(1<<27))
  1134. #define CCM_CCR_REG_BYPASS_COUNT(n) ((uint32_t)(((n) & 0x3F) << 21))
  1135. #define CCM_CCR_COSC_EN ((uint32_t)(1<<12))
  1136. #define CCM_CCR_OSCNT(n) ((uint32_t)(((n) & 0xFF) << 0))
  1137. #define CCM_CSR_COSC_READY ((uint32_t)(1<<5))
  1138. #define CCM_CSR_CAMP2_READY ((uint32_t)(1<<3))
  1139. #define CCM_CSR_REF_EN_B ((uint32_t)(1<<0))
  1140. #define CCM_CCSR_PLL3_SW_CLK_SEL ((uint32_t)(1<<0))
  1141. #define CCM_CACRR_ARM_PODF(n) ((uint32_t)(((n) & 0x07) << 0))
  1142. #define CCM_CACRR_ARM_PODF_MASK ((uint32_t)(0x07 << 0))
  1143. #define CCM_CBCDR_PERIPH_CLK2_PODF(n) ((uint32_t)(((n) & 0x07) << 27))
  1144. #define CCM_CBCDR_PERIPH_CLK2_PODF_MASK ((uint32_t)(0x07 << 27))
  1145. #define CCM_CBCDR_PERIPH_CLK_SEL ((uint32_t)(1<<25))
  1146. #define CCM_CBCDR_SEMC_PODF(n) ((uint32_t)(((n) & 0x07) << 16))
  1147. #define CCM_CBCDR_AHB_PODF(n) ((uint32_t)(((n) & 0x07) << 10))
  1148. #define CCM_CBCDR_AHB_PODF_MASK ((uint32_t)(0x07 << 10))
  1149. #define CCM_CBCDR_IPG_PODF(n) ((uint32_t)(((n) & 0x03) << 8))
  1150. #define CCM_CBCDR_IPG_PODF_MASK ((uint32_t)(0x03 << 8))
  1151. #define CCM_CBCDR_SEMC_ALT_CLK_SEL ((uint32_t)(1<<7))
  1152. #define CCM_CBCDR_SEMC_CLK_SEL ((uint32_t)(1<<6))
  1153. #define CCM_CBCMR_LPSPI_PODF(n) ((uint32_t)(((n) & 0x07) << 26))
  1154. #define CCM_CBCMR_LCDIF_PODF(n) ((uint32_t)(((n) & 0x07) << 23))
  1155. #define CCM_CBCMR_PRE_PERIPH_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 18))
  1156. #define CCM_CBCMR_TRACE_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 14))
  1157. #define CCM_CBCMR_PERIPH_CLK2_SEL(n) ((uint32_t)(((n) & 0x03) << 12))
  1158. #define CCM_CBCMR_PERIPH_CLK2_SEL_MASK ((uint32_t)(0x03 << 12))
  1159. #define CCM_CBCMR_LPSPI_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 4))
  1160. #define CCM_CBCMR_LPSPI_PODF_MASK ((uint32_t)(0x07 << 26))
  1161. #define CCM_CBCMR_LCDIF_PODF_MASK ((uint32_t)(0x07 << 23))
  1162. #define CCM_CBCMR_PRE_PERIPH_CLK_SEL_MASK ((uint32_t)(0x03 << 18))
  1163. #define CCM_CBCMR_TRACE_CLK_SEL_MASK ((uint32_t)(0x03 << 14))
  1164. #define CCM_CBCMR_LPSPI_CLK_SEL_MASK ((uint32_t)(0x03 << 4))
  1165. #define CCM_CSCMR1_FLEXSPI_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 29))
  1166. #define CCM_CSCMR1_FLEXSPI_PODF(n) ((uint32_t)(((n) & 0x07) << 23))
  1167. #define CCM_CSCMR1_USDHC2_CLK_SEL ((uint32_t)(1<<17))
  1168. #define CCM_CSCMR1_USDHC1_CLK_SEL ((uint32_t)(1<<16))
  1169. #define CCM_CSCMR1_SAI3_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 14))
  1170. #define CCM_CSCMR1_SAI2_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 12))
  1171. #define CCM_CSCMR1_SAI1_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 10))
  1172. #define CCM_CSCMR1_PERCLK_CLK_SEL ((uint32_t)(1<<6))
  1173. #define CCM_CSCMR1_PERCLK_PODF(n) ((uint32_t)(((n) & 0x3F) << 0))
  1174. #define CCM_CSCMR2_FLEXIO2_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 19))
  1175. #define CCM_CSCMR2_CAN_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 8))
  1176. #define CCM_CSCMR2_CAN_CLK_PODF(n) ((uint32_t)(((n) & 0x3F) << 2))
  1177. #define CCM_CSCDR1_TRACE_PODF(n) ((uint32_t)(((n) & 0x07) << 25))
  1178. #define CCM_CSCDR1_USDHC2_PODF(n) ((uint32_t)(((n) & 0x07) << 16))
  1179. #define CCM_CSCDR1_USDHC1_PODF(n) ((uint32_t)(((n) & 0x07) << 11))
  1180. #define CCM_CSCDR1_UART_CLK_SEL ((uint32_t)(1<<6))
  1181. #define CCM_CSCDR1_UART_CLK_PODF(n) ((uint32_t)(((n) & 0x3F) << 0))
  1182. #define CCM_CS1CDR_FLEXIO2_CLK_PODF(n) ((uint32_t)(((n) & 0x07) << 25))
  1183. #define CCM_CS1CDR_SAI3_CLK_PRED(n) ((uint32_t)(((n) & 0x07) << 22))
  1184. #define CCM_CS1CDR_SAI3_CLK_PODF(n) ((uint32_t)(((n) & 0x3F) << 16))
  1185. #define CCM_CS1CDR_FLEXIO2_CLK_PRED(n) ((uint32_t)(((n) & 0x07) << 9))
  1186. #define CCM_CS1CDR_SAI1_CLK_PRED(n) ((uint32_t)(((n) & 0x07) << 6))
  1187. #define CCM_CS1CDR_SAI1_CLK_PODF(n) ((uint32_t)(((n) & 0x3F) << 0))
  1188. #define CCM_CS2CDR_SAI2_CLK_PRED(n) ((uint32_t)(((n) & 0x07) << 6))
  1189. #define CCM_CS2CDR_SAI2_CLK_PODF(n) ((uint32_t)(((n) & 0x3F) << 0))
  1190. #define CCM_CDCDR_SPDIF0_CLK_PRED(n) ((uint32_t)(((n) & 0x07) << 25))
  1191. #define CCM_CDCDR_SPDIF0_CLK_PODF(n) ((uint32_t)(((n) & 0x07) << 22))
  1192. #define CCM_CDCDR_SPDIF0_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 20))
  1193. #define CCM_CDCDR_FLEXIO1_CLK_PRED(n) ((uint32_t)(((n) & 0x07) << 12))
  1194. #define CCM_CDCDR_FLEXIO1_CLK_PODF(n) ((uint32_t)(((n) & 0x07) << 9))
  1195. #define CCM_CDCDR_FLEXIO1_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 7))
  1196. #define CCM_CSCDR2_LPI2C_CLK_PODF(n) ((uint32_t)(((n) & 0x1F) << 19))
  1197. #define CCM_CSCDR2_LPI2C_CLK_SEL ((uint32_t)(1<<18))
  1198. #define CCM_CSCDR2_LCDIF_PRE_CLK_SEL(n) ((uint32_t)(((n) & 0x07) << 15))
  1199. #define CCM_CSCDR2_LCDIF_PRED(n) ((uint32_t)(((n) & 0x07) << 12))
  1200. #define CCM_CSCDR2_LCDIF_CLK_SEL(n) ((uint32_t)(((n) & 0x07) << 9))
  1201. #define CCM_CSCDR3_CSI_PODF(n) ((uint32_t)(((n) & 0x07) << 11))
  1202. #define CCM_CSCDR3_CSI_CLK_SEL(n) ((uint32_t)(((n) & 0x03) << 9))
  1203. #define CCM_CDHIPR_ARM_PODF_BUSY ((uint32_t)(1<<16))
  1204. #define CCM_CDHIPR_PERIPH_CLK_SEL_BUSY ((uint32_t)(1<<5))
  1205. #define CCM_CDHIPR_PERIPH2_CLK_SEL_BUSY ((uint32_t)(1<<3))
  1206. #define CCM_CDHIPR_AHB_PODF_BUSY ((uint32_t)(1<<1))
  1207. #define CCM_CDHIPR_SEMC_PODF_BUSY ((uint32_t)(1<<0))
  1208. #define CCM_CLPCR_MASK_L2CC_IDLE ((uint32_t)(1<<27))
  1209. #define CCM_CLPCR_MASK_SCU_IDLE ((uint32_t)(1<<26))
  1210. #define CCM_CLPCR_MASK_CORE0_WFI ((uint32_t)(1<<22))
  1211. #define CCM_CLPCR_BYPASS_LPM_HS0 ((uint32_t)(1<<21))
  1212. #define CCM_CLPCR_BYPASS_LPM_HS1 ((uint32_t)(1<<19))
  1213. #define CCM_CLPCR_COSC_PWRDOWN ((uint32_t)(1<<11))
  1214. #define CCM_CLPCR_STBY_COUNT(n) ((uint32_t)(((n) & 0x03) << 9))
  1215. #define CCM_CLPCR_VSTBY ((uint32_t)(1<<8))
  1216. #define CCM_CLPCR_DIS_REF_OSC ((uint32_t)(1<<7))
  1217. #define CCM_CLPCR_SBYOS ((uint32_t)(1<<6))
  1218. #define CCM_CLPCR_ARM_CLK_DIS_ON_LPM ((uint32_t)(1<<5))
  1219. #define CCM_CLPCR_LPM(n) ((uint32_t)(((n) & 0x03) << 0))
  1220. #define CCM_CISR_ARM_PODF_LOADED ((uint32_t)(1<<26))
  1221. #define CCM_CISR_PERIPH_CLK_SEL_LOADED ((uint32_t)(1<<22))
  1222. #define CCM_CISR_AHB_PODF_LOADED ((uint32_t)(1<<20))
  1223. #define CCM_CISR_PERIPH2_CLK_SEL_LOADED ((uint32_t)(1<<19))
  1224. #define CCM_CISR_SEMC_PODF_LOADED ((uint32_t)(1<<17))
  1225. #define CCM_CISR_COSC_READY ((uint32_t)(1<<6))
  1226. #define CCM_CISR_LRF_PLL ((uint32_t)(1<<0))
  1227. #define CCM_CIMR_ARM_PODF_LOADED ((uint32_t)(1<<26))
  1228. #define CCM_CIMR_MASK_PERIPH_CLK_SEL_LOADED ((uint32_t)(1<<22))
  1229. #define CCM_CIMR_MASK_AHB_PODF_LOADED ((uint32_t)(1<<20))
  1230. #define CCM_CIMR_MASK_PERIPH2_CLK_SEL_LOADED ((uint32_t)(1<<19))
  1231. #define CCM_CIMR_MASK_SEMC_PODF_LOADED ((uint32_t)(1<<17))
  1232. #define CCM_CIMR_MASK_COSC_READY ((uint32_t)(1<<6))
  1233. #define CCM_CIMR_MASK_LRF_PLL ((uint32_t)(1<<0))
  1234. #define CCM_CCOSR_CLKO2_EN ((uint32_t)(1<<24))
  1235. #define CCM_CCOSR_CLKO2_DIV(n) ((uint32_t)(((n) & 0x07) << 21))
  1236. #define CCM_CCOSR_CLKO2_SEL(n) ((uint32_t)(((n) & 0x1F) << 16))
  1237. #define CCM_CCOSR_CLK_OUT_SEL ((uint32_t)(1<<8))
  1238. #define CCM_CCOSR_CLKO1_EN ((uint32_t)(1<<7))
  1239. #define CCM_CCOSR_CLKO1_DIV(n) ((uint32_t)(((n) & 0x07) << 4))
  1240. #define CCM_CCOSR_CLKO1_SEL(n) ((uint32_t)(((n) & 0x0F) << 0))
  1241. #define CCM_CGPR_INT_MEM_CLK_LPM ((uint32_t)(1<<17))
  1242. #define CCM_CGPR_FPL ((uint32_t)(1<<16))
  1243. #define CCM_CGPR_SYS_MEM_DS_CTRL(n) ((uint32_t)(((n) & 0x03) << 14))
  1244. #define CCM_CGPR_EFUSE_PROG_SUPPLY_GATE ((uint32_t)(1<<4))
  1245. #define CCM_CGPR_PMIC_DELAY_SCALER ((uint32_t)(1<<0))
  1246. #define CCM_CCGR_OFF 0
  1247. #define CCM_CCGR_ON_RUNONLY 1
  1248. #define CCM_CCGR_ON 3
  1249. #define CCM_CCGR0_GPIO2(n) ((uint32_t)(((n) & 0x03) << 30))
  1250. #define CCM_CCGR0_LPUART2(n) ((uint32_t)(((n) & 0x03) << 28))
  1251. #define CCM_CCGR0_GPT2_SERIAL(n) ((uint32_t)(((n) & 0x03) << 26))
  1252. #define CCM_CCGR0_GPT2_BUS(n) ((uint32_t)(((n) & 0x03) << 24))
  1253. #define CCM_CCGR0_TRACE(n) ((uint32_t)(((n) & 0x03) << 22))
  1254. #define CCM_CCGR0_CAN2_SERIAL(n) ((uint32_t)(((n) & 0x03) << 20))
  1255. #define CCM_CCGR0_CAN2(n) ((uint32_t)(((n) & 0x03) << 18))
  1256. #define CCM_CCGR0_CAN1_SERIAL(n) ((uint32_t)(((n) & 0x03) << 16))
  1257. #define CCM_CCGR0_CAN1(n) ((uint32_t)(((n) & 0x03) << 14))
  1258. #define CCM_CCGR0_LPUART3(n) ((uint32_t)(((n) & 0x03) << 12))
  1259. #define CCM_CCGR0_DCP(n) ((uint32_t)(((n) & 0x03) << 10))
  1260. #define CCM_CCGR0_MQS_HMCLK(n) ((uint32_t)(((n) & 0x03) << 4))
  1261. #define CCM_CCGR0_AIPS_TZ2(n) ((uint32_t)(((n) & 0x03) << 2))
  1262. #define CCM_CCGR0_AIPS_TZ1(n) ((uint32_t)(((n) & 0x03) << 0))
  1263. #define CCM_CCGR1_CSU(n) ((uint32_t)(((n) & 0x03) << 28))
  1264. #define CCM_CCGR1_GPIO1(n) ((uint32_t)(((n) & 0x03) << 26))
  1265. #define CCM_CCGR1_LPUART4(n) ((uint32_t)(((n) & 0x03) << 24))
  1266. #define CCM_CCGR1_GPT_SERIAL(n) ((uint32_t)(((n) & 0x03) << 22))
  1267. #define CCM_CCGR1_GPT(n) ((uint32_t)(((n) & 0x03) << 20))
  1268. #define CCM_CCGR1_ADC1(n) ((uint32_t)(((n) & 0x03) << 16))
  1269. #define CCM_CCGR1_AOI2(n) ((uint32_t)(((n) & 0x03) << 14))
  1270. #define CCM_CCGR1_PIT(n) ((uint32_t)(((n) & 0x03) << 12))
  1271. #define CCM_CCGR1_ENET(n) ((uint32_t)(((n) & 0x03) << 10))
  1272. #define CCM_CCGR1_ADC2(n) ((uint32_t)(((n) & 0x03) << 8))
  1273. #define CCM_CCGR1_LPSPI4(n) ((uint32_t)(((n) & 0x03) << 6))
  1274. #define CCM_CCGR1_LPSPI3(n) ((uint32_t)(((n) & 0x03) << 4))
  1275. #define CCM_CCGR1_LPSPI2(n) ((uint32_t)(((n) & 0x03) << 2))
  1276. #define CCM_CCGR1_LPSPI1(n) ((uint32_t)(((n) & 0x03) << 0))
  1277. #define CCM_CCGR2_PXP(n) ((uint32_t)(((n) & 0x03) << 30))
  1278. #define CCM_CCGR2_LCD(n) ((uint32_t)(((n) & 0x03) << 28))
  1279. #define CCM_CCGR2_GPIO3(n) ((uint32_t)(((n) & 0x03) << 26))
  1280. #define CCM_CCGR2_XBAR2(n) ((uint32_t)(((n) & 0x03) << 24))
  1281. #define CCM_CCGR2_XBAR1(n) ((uint32_t)(((n) & 0x03) << 22))
  1282. #define CCM_CCGR2_IPMUX3(n) ((uint32_t)(((n) & 0x03) << 20))
  1283. #define CCM_CCGR2_IPMUX2(n) ((uint32_t)(((n) & 0x03) << 18))
  1284. #define CCM_CCGR2_IPMUX1(n) ((uint32_t)(((n) & 0x03) << 16))
  1285. #define CCM_CCGR2_XBAR3(n) ((uint32_t)(((n) & 0x03) << 14))
  1286. #define CCM_CCGR2_IIM(n) ((uint32_t)(((n) & 0x03) << 12))
  1287. #define CCM_CCGR2_LPI2C3(n) ((uint32_t)(((n) & 0x03) << 10))
  1288. #define CCM_CCGR2_LPI2C2(n) ((uint32_t)(((n) & 0x03) << 8))
  1289. #define CCM_CCGR2_LPI2C1(n) ((uint32_t)(((n) & 0x03) << 6))
  1290. #define CCM_CCGR2_IOMUXC_SNVS(n) ((uint32_t)(((n) & 0x03) << 4))
  1291. #define CCM_CCGR2_CSI(n) ((uint32_t)(((n) & 0x03) << 2))
  1292. #define CCM_CCGR3_IOMUXC_SNVS_GPR(n) ((uint32_t)(((n) & 0x03) << 30))
  1293. #define CCM_CCGR3_OCRAM(n) ((uint32_t)(((n) & 0x03) << 28))
  1294. #define CCM_CCGR3_ACMP4(n) ((uint32_t)(((n) & 0x03) << 26))
  1295. #define CCM_CCGR3_ACMP3(n) ((uint32_t)(((n) & 0x03) << 24))
  1296. #define CCM_CCGR3_ACMP2(n) ((uint32_t)(((n) & 0x03) << 22))
  1297. #define CCM_CCGR3_ACMP1(n) ((uint32_t)(((n) & 0x03) << 20))
  1298. #define CCM_CCGR3_FLEXRAM(n) ((uint32_t)(((n) & 0x03) << 18))
  1299. #define CCM_CCGR3_WDOG1(n) ((uint32_t)(((n) & 0x03) << 16))
  1300. #define CCM_CCGR3_EWM(n) ((uint32_t)(((n) & 0x03) << 14))
  1301. #define CCM_CCGR3_GPIO4(n) ((uint32_t)(((n) & 0x03) << 12))
  1302. #define CCM_CCGR3_LCDIF_PIX(n) ((uint32_t)(((n) & 0x03) << 10))
  1303. #define CCM_CCGR3_AOI1(n) ((uint32_t)(((n) & 0x03) << 8))
  1304. #define CCM_CCGR3_LPUART6(n) ((uint32_t)(((n) & 0x03) << 6))
  1305. #define CCM_CCGR3_SEMC(n) ((uint32_t)(((n) & 0x03) << 4))
  1306. #define CCM_CCGR3_LPUART5(n) ((uint32_t)(((n) & 0x03) << 2))
  1307. #define CCM_CCGR3_FLEXIO2(n) ((uint32_t)(((n) & 0x03) << 0))
  1308. #define CCM_CCGR4_ENC4(n) ((uint32_t)(((n) & 0x03) << 30))
  1309. #define CCM_CCGR4_ENC3(n) ((uint32_t)(((n) & 0x03) << 28))
  1310. #define CCM_CCGR4_ENC2(n) ((uint32_t)(((n) & 0x03) << 26))
  1311. #define CCM_CCGR4_ENC1(n) ((uint32_t)(((n) & 0x03) << 24))
  1312. #define CCM_CCGR4_PWM4(n) ((uint32_t)(((n) & 0x03) << 22))
  1313. #define CCM_CCGR4_PWM3(n) ((uint32_t)(((n) & 0x03) << 20))
  1314. #define CCM_CCGR4_PWM2(n) ((uint32_t)(((n) & 0x03) << 18))
  1315. #define CCM_CCGR4_PWM1(n) ((uint32_t)(((n) & 0x03) << 16))
  1316. #define CCM_CCGR4_SIM_EMS(n) ((uint32_t)(((n) & 0x03) << 14))
  1317. #define CCM_CCGR4_SIM_M(n) ((uint32_t)(((n) & 0x03) << 12))
  1318. #define CCM_CCGR4_TSC(n) ((uint32_t)(((n) & 0x03) << 10))
  1319. #define CCM_CCGR4_SIM_M7(n) ((uint32_t)(((n) & 0x03) << 8))
  1320. #define CCM_CCGR4_BEE(n) ((uint32_t)(((n) & 0x03) << 6))
  1321. #define CCM_CCGR4_IOMUXC_GPR(n) ((uint32_t)(((n) & 0x03) << 4))
  1322. #define CCM_CCGR4_IOMUXC(n) ((uint32_t)(((n) & 0x03) << 2))
  1323. #define CCM_CCGR5_SNVS_LP(n) ((uint32_t)(((n) & 0x03) << 30))
  1324. #define CCM_CCGR5_SNVS_HP(n) ((uint32_t)(((n) & 0x03) << 28))
  1325. #define CCM_CCGR5_LPUART7(n) ((uint32_t)(((n) & 0x03) << 26))
  1326. #define CCM_CCGR5_LPUART1(n) ((uint32_t)(((n) & 0x03) << 24))
  1327. #define CCM_CCGR5_SAI3(n) ((uint32_t)(((n) & 0x03) << 22))
  1328. #define CCM_CCGR5_SAI2(n) ((uint32_t)(((n) & 0x03) << 20))
  1329. #define CCM_CCGR5_SAI1(n) ((uint32_t)(((n) & 0x03) << 18))
  1330. #define CCM_CCGR5_SIM_MAIN(n) ((uint32_t)(((n) & 0x03) << 16))
  1331. #define CCM_CCGR5_SPDIF(n) ((uint32_t)(((n) & 0x03) << 14))
  1332. #define CCM_CCGR5_AIPS_TZ4(n) ((uint32_t)(((n) & 0x03) << 12))
  1333. #define CCM_CCGR5_WDOG2(n) ((uint32_t)(((n) & 0x03) << 10))
  1334. #define CCM_CCGR5_KPP(n) ((uint32_t)(((n) & 0x03) << 8))
  1335. #define CCM_CCGR5_DMA(n) ((uint32_t)(((n) & 0x03) << 6))
  1336. #define CCM_CCGR5_WDOG3(n) ((uint32_t)(((n) & 0x03) << 4))
  1337. #define CCM_CCGR5_FLEXIO1(n) ((uint32_t)(((n) & 0x03) << 2))
  1338. #define CCM_CCGR5_ROM(n) ((uint32_t)(((n) & 0x03) << 0))
  1339. #define CCM_CCGR6_QTIMER3(n) ((uint32_t)(((n) & 0x03) << 30))
  1340. #define CCM_CCGR6_QTIMER2(n) ((uint32_t)(((n) & 0x03) << 28))
  1341. #define CCM_CCGR6_QTIMER1(n) ((uint32_t)(((n) & 0x03) << 26))
  1342. #define CCM_CCGR6_LPI2C4_SERIAL(n) ((uint32_t)(((n) & 0x03) << 24))
  1343. #define CCM_CCGR6_ANADIG(n) ((uint32_t)(((n) & 0x03) << 22))
  1344. #define CCM_CCGR6_SIM_PER(n) ((uint32_t)(((n) & 0x03) << 20)) /* IMXRT1052 */
  1345. #define CCM_CCGR6_AXBS_P(n) ((uint32_t)(((n) & 0x03) << 20)) /* IMXRT1062 */
  1346. #define CCM_CCGR6_AIPS_TZ3(n) ((uint32_t)(((n) & 0x03) << 18))
  1347. #define CCM_CCGR6_QTIMER4(n) ((uint32_t)(((n) & 0x03) << 16))
  1348. #define CCM_CCGR6_LPUART8(n) ((uint32_t)(((n) & 0x03) << 14))
  1349. #define CCM_CCGR6_TRNG(n) ((uint32_t)(((n) & 0x03) << 12))
  1350. #define CCM_CCGR6_FLEXSPI(n) ((uint32_t)(((n) & 0x03) << 10))
  1351. #define CCM_CCGR6_IPMUX4(n) ((uint32_t)(((n) & 0x03) << 8))
  1352. #define CCM_CCGR6_DCDC(n) ((uint32_t)(((n) & 0x03) << 6))
  1353. #define CCM_CCGR6_USDHC2(n) ((uint32_t)(((n) & 0x03) << 4))
  1354. #define CCM_CCGR6_USDHC1(n) ((uint32_t)(((n) & 0x03) << 2))
  1355. #define CCM_CCGR6_USBOH3(n) ((uint32_t)(((n) & 0x03) << 0))
  1356. #define CCM_CCGR7_FLEXIO3(n) ((uint32_t)(((n) & 0x03) << 12))
  1357. #define CCM_CCGR7_APIS_LITE(n) ((uint32_t)(((n) & 0x03) << 10))
  1358. #define CCM_CCGR7_CAN3_SERIAL(n) ((uint32_t)(((n) & 0x03) << 8))
  1359. #define CCM_CCGR7_CAN3(n) ((uint32_t)(((n) & 0x03) << 6))
  1360. #define CCM_CCGR7_AXBS_L(n) ((uint32_t)(((n) & 0x03) << 4))
  1361. #define CCM_CCGR7_FLEXSPI2(n) ((uint32_t)(((n) & 0x03) << 2))
  1362. #define CCM_CCGR7_ENET2(n) ((uint32_t)(((n) & 0x03) << 0))
  1363. #define CCM_CMEOR_MOD_EN_OV_CAN1_CPI ((uint32_t)(1<<30))
  1364. #define CCM_CMEOR_MOD_EN_OV_CAN2_CPI ((uint32_t)(1<<28))
  1365. #define CCM_CMEOR_MOD_EN_OV_TRNG ((uint32_t)(1<<9))
  1366. #define CCM_CMEOR_MOD_EN_USDHC ((uint32_t)(1<<7))
  1367. #define CCM_CMEOR_MOD_EN_OV_PIT ((uint32_t)(1<<6))
  1368. #define CCM_CMEOR_MOD_EN_OV_GPT ((uint32_t)(1<<5))
  1369. #define CCM_CSCMR1_SAI1_CLK_SEL_MASK (CCM_CSCMR1_SAI1_CLK_SEL(0x03))
  1370. #define CCM_CS1CDR_SAI1_CLK_PRED_MASK (CCM_CS1CDR_SAI1_CLK_PRED(0x07))
  1371. #define CCM_CS1CDR_SAI1_CLK_PODF_MASK (CCM_CS1CDR_SAI1_CLK_PODF(0x3f))
  1372. #define CCM_CSCMR1_SAI2_CLK_SEL_MASK (CCM_CSCMR1_SAI2_CLK_SEL(0x03))
  1373. #define CCM_CS2CDR_SAI2_CLK_PRED_MASK (CCM_CS2CDR_SAI2_CLK_PRED(0x07))
  1374. #define CCM_CS2CDR_SAI2_CLK_PODF_MASK (CCM_CS2CDR_SAI2_CLK_PODF(0x3f))
  1375. #define CCM_CSCMR1_SAI3_CLK_SEL_MASK (CCM_CSCMR1_SAI3_CLK_SEL(0x03))
  1376. #define CCM_CS1CDR_SAI3_CLK_PRED_MASK (CCM_CS1CDR_SAI3_CLK_PRED(0x07))
  1377. #define CCM_CS1CDR_SAI3_CLK_PODF_MASK (CCM_CS1CDR_SAI3_CLK_PODF(0x3f))
  1378. #define CCM_CDCDR_SPDIF0_CLK_SEL_MASK (CCM_CDCDR_SPDIF0_CLK_SEL(0x03))
  1379. #define CCM_CDCDR_SPDIF0_CLK_PRED_MASK (CCM_CDCDR_SPDIF0_CLK_PRED(0x07))
  1380. #define CCM_CDCDR_SPDIF0_CLK_PODF_MASK (CCM_CDCDR_SPDIF0_CLK_PODF(0x07))
  1381. // 18.8: page 752
  1382. #define IMXRT_CCM_ANALOG (*(IMXRT_REGISTER32_t *)0x400D8000)
  1383. #define CCM_ANALOG_PLL_ARM (IMXRT_CCM_ANALOG.offset000)
  1384. #define CCM_ANALOG_PLL_ARM_SET (IMXRT_CCM_ANALOG.offset004)
  1385. #define CCM_ANALOG_PLL_ARM_CLR (IMXRT_CCM_ANALOG.offset008)
  1386. #define CCM_ANALOG_PLL_ARM_TOG (IMXRT_CCM_ANALOG.offset00C)
  1387. #define CCM_ANALOG_PLL_USB1 (IMXRT_CCM_ANALOG.offset010)
  1388. #define CCM_ANALOG_PLL_USB1_SET (IMXRT_CCM_ANALOG.offset014)
  1389. #define CCM_ANALOG_PLL_USB1_CLR (IMXRT_CCM_ANALOG.offset018)
  1390. #define CCM_ANALOG_PLL_USB1_TOG (IMXRT_CCM_ANALOG.offset01C)
  1391. #define CCM_ANALOG_PLL_USB2 (IMXRT_CCM_ANALOG.offset020)
  1392. #define CCM_ANALOG_PLL_USB2_SET (IMXRT_CCM_ANALOG.offset024)
  1393. #define CCM_ANALOG_PLL_USB2_CLR (IMXRT_CCM_ANALOG.offset028)
  1394. #define CCM_ANALOG_PLL_USB2_TOG (IMXRT_CCM_ANALOG.offset02C)
  1395. #define CCM_ANALOG_PLL_SYS (IMXRT_CCM_ANALOG.offset030)
  1396. #define CCM_ANALOG_PLL_SYS_SET (IMXRT_CCM_ANALOG.offset034)
  1397. #define CCM_ANALOG_PLL_SYS_CLR (IMXRT_CCM_ANALOG.offset038)
  1398. #define CCM_ANALOG_PLL_SYS_TOG (IMXRT_CCM_ANALOG.offset03C)
  1399. #define CCM_ANALOG_PLL_SYS_SS (IMXRT_CCM_ANALOG.offset040)
  1400. #define CCM_ANALOG_PLL_SYS_NUM (IMXRT_CCM_ANALOG.offset050)
  1401. #define CCM_ANALOG_PLL_SYS_DENOM (IMXRT_CCM_ANALOG.offset060)
  1402. #define CCM_ANALOG_PLL_AUDIO (IMXRT_CCM_ANALOG.offset070)
  1403. #define CCM_ANALOG_PLL_AUDIO_SET (IMXRT_CCM_ANALOG.offset074)
  1404. #define CCM_ANALOG_PLL_AUDIO_CLR (IMXRT_CCM_ANALOG.offset078)
  1405. #define CCM_ANALOG_PLL_AUDIO_TOG (IMXRT_CCM_ANALOG.offset07C)
  1406. #define CCM_ANALOG_PLL_AUDIO_NUM (IMXRT_CCM_ANALOG.offset080)
  1407. #define CCM_ANALOG_PLL_AUDIO_DENOM (IMXRT_CCM_ANALOG.offset090)
  1408. #define CCM_ANALOG_PLL_VIDEO (IMXRT_CCM_ANALOG.offset0A0)
  1409. #define CCM_ANALOG_PLL_VIDEO_SET (IMXRT_CCM_ANALOG.offset0A4)
  1410. #define CCM_ANALOG_PLL_VIDEO_CLR (IMXRT_CCM_ANALOG.offset0A8)
  1411. #define CCM_ANALOG_PLL_VIDEO_TOG (IMXRT_CCM_ANALOG.offset0AC)
  1412. #define CCM_ANALOG_PLL_VIDEO_NUM (IMXRT_CCM_ANALOG.offset0B0)
  1413. #define CCM_ANALOG_PLL_VIDEO_DENOM (IMXRT_CCM_ANALOG.offset0C0)
  1414. #define CCM_ANALOG_PLL_ENET (IMXRT_CCM_ANALOG.offset0EC)
  1415. #define CCM_ANALOG_PLL_ENET_SET (IMXRT_CCM_ANALOG.offset0E4)
  1416. #define CCM_ANALOG_PLL_ENET_CLR (IMXRT_CCM_ANALOG.offset0E8)
  1417. #define CCM_ANALOG_PLL_ENET_TOG (IMXRT_CCM_ANALOG.offset0EC)
  1418. #define CCM_ANALOG_PFD_480 (IMXRT_CCM_ANALOG.offset0F0)
  1419. #define CCM_ANALOG_PFD_480_SET (IMXRT_CCM_ANALOG.offset0F4)
  1420. #define CCM_ANALOG_PFD_480_CLR (IMXRT_CCM_ANALOG.offset0F8)
  1421. #define CCM_ANALOG_PFD_480_TOG (IMXRT_CCM_ANALOG.offset0FC)
  1422. #define CCM_ANALOG_PFD_528 (IMXRT_CCM_ANALOG.offset100)
  1423. #define CCM_ANALOG_PFD_528_SET (IMXRT_CCM_ANALOG.offset104)
  1424. #define CCM_ANALOG_PFD_528_CLR (IMXRT_CCM_ANALOG.offset108)
  1425. #define CCM_ANALOG_PFD_528_TOG (IMXRT_CCM_ANALOG.offset10C)
  1426. #define CCM_ANALOG_MISC0 (IMXRT_CCM_ANALOG.offset150)
  1427. #define CCM_ANALOG_MISC0_SET (IMXRT_CCM_ANALOG.offset154)
  1428. #define CCM_ANALOG_MISC0_CLR (IMXRT_CCM_ANALOG.offset158)
  1429. #define CCM_ANALOG_MISC0_TOG (IMXRT_CCM_ANALOG.offset15C)
  1430. #define CCM_ANALOG_MISC1 (IMXRT_CCM_ANALOG.offset160)
  1431. #define CCM_ANALOG_MISC1_SET (IMXRT_CCM_ANALOG.offset164)
  1432. #define CCM_ANALOG_MISC1_CLR (IMXRT_CCM_ANALOG.offset168)
  1433. #define CCM_ANALOG_MISC1_TOG (IMXRT_CCM_ANALOG.offset16C)
  1434. #define CCM_ANALOG_MISC2 (IMXRT_CCM_ANALOG.offset170)
  1435. #define CCM_ANALOG_MISC2_SET (IMXRT_CCM_ANALOG.offset174)
  1436. #define CCM_ANALOG_MISC2_CLR (IMXRT_CCM_ANALOG.offset178)
  1437. #define CCM_ANALOG_MISC2_TOG (IMXRT_CCM_ANALOG.offset17C)
  1438. #define CCM_ANALOG_PLL_ARM_LOCK ((uint32_t)(1<<31))
  1439. #define CCM_ANALOG_PLL_ARM_BYPASS ((uint32_t)(1<<16))
  1440. #define CCM_ANALOG_PLL_ARM_ENABLE ((uint32_t)(1<<13))
  1441. #define CCM_ANALOG_PLL_ARM_POWERDOWN ((uint32_t)(1<<12))
  1442. #define CCM_ANALOG_PLL_ARM_DIV_SELECT(n) ((uint32_t)(((n) & 0x7F) << 0))
  1443. #define CCM_ANALOG_PLL_ARM_DIV_SELECT_MASK ((uint32_t)(0x7F << 0))
  1444. #define CCM_ANALOG_PLL_USB1_LOCK ((uint32_t)(1<<31))
  1445. #define CCM_ANALOG_PLL_USB1_BYPASS ((uint32_t)(1<<16))
  1446. #define CCM_ANALOG_PLL_USB1_ENABLE ((uint32_t)(1<<13))
  1447. #define CCM_ANALOG_PLL_USB1_POWER ((uint32_t)(1<<12))
  1448. #define CCM_ANALOG_PLL_USB1_EN_USB_CLKS ((uint32_t)(1<<6))
  1449. #define CCM_ANALOG_PLL_USB1_DIV_SELECT ((uint32_t)(1<<1))
  1450. #define CCM_ANALOG_PLL_USB2_LOCK ((uint32_t)(1<<31))
  1451. #define CCM_ANALOG_PLL_USB2_BYPASS ((uint32_t)(1<<16))
  1452. #define CCM_ANALOG_PLL_USB2_ENABLE ((uint32_t)(1<<13))
  1453. #define CCM_ANALOG_PLL_USB2_POWER ((uint32_t)(1<<12))
  1454. #define CCM_ANALOG_PLL_USB2_EN_USB_CLKS ((uint32_t)(1<<6))
  1455. #define CCM_ANALOG_PLL_USB2_DIV_SELECT ((uint32_t)(1<<1))
  1456. #define CCM_ANALOG_PLL_SYS_LOCK ((uint32_t)(1<<31))
  1457. #define CCM_ANALOG_PLL_SYS_BYPASS ((uint32_t)(1<<16))
  1458. #define CCM_ANALOG_PLL_SYS_ENABLE ((uint32_t)(1<<13))
  1459. #define CCM_ANALOG_PLL_SYS_POWERDOWN ((uint32_t)(1<<12))
  1460. #define CCM_ANALOG_PLL_SYS_DIV_SELECT ((uint32_t)(1<<1))
  1461. #define CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(n) ((uint32_t)(((n) & 0x03) <<19))
  1462. #define CCM_ANALOG_PLL_AUDIO_BYPASS ((uint32_t)(1<<16))
  1463. #define CCM_ANALOG_PLL_AUDIO_BYPASS_CLK_SRC(n) ((uint32_t)(((n) & 0x03) <<14))
  1464. #define CCM_ANALOG_PLL_AUDIO_ENABLE ((uint32_t)(1<<13))
  1465. #define CCM_ANALOG_PLL_AUDIO_POWERDOWN ((uint32_t)(1<<12))
  1466. #define CCM_ANALOG_PLL_AUDIO_DIV_SELECT(n) ((uint32_t)((n) & ((1<<6)-1)))
  1467. #define CCM_ANALOG_MISC2_DIV_MSB ((uint32_t)(1<<23))
  1468. #define CCM_ANALOG_MISC2_DIV_LSB ((uint32_t)(1<<15))
  1469. #define CCM_ANALOG_PLL_AUDIO_NUM_MASK (((1<<29)-1))
  1470. #define CCM_ANALOG_PLL_AUDIO_DENOM_MASK (((1<<29)-1))
  1471. #define CCM_ANALOG_PLL_AUDIO_LOCK ((uint32_t)(1<<31))
  1472. // 19.7: page 810
  1473. #define IMXRT_CSI (*(IMXRT_REGISTER32_t *)0x402BC000)
  1474. #define CSI_CSICR1 (IMXRT_CSI.offset000)
  1475. #define CSI_CSICR2 (IMXRT_CSI.offset004)
  1476. #define CSI_CSICR3 (IMXRT_CSI.offset008)
  1477. #define CSI_CSISTATFIFO (IMXRT_CSI.offset00C)
  1478. #define CSI_CSIRFIFO (IMXRT_CSI.offset010)
  1479. #define CSI_CSIRXCNT (IMXRT_CSI.offset014)
  1480. #define CSI_CSISR (IMXRT_CSI.offset018)
  1481. #define CSI_CSIDMASA_STATFIFO (IMXRT_CSI.offset020)
  1482. #define CSI_CSIDMATS_STATFIFO (IMXRT_CSI.offset024)
  1483. #define CSI_CSIDMASA_FB1 (IMXRT_CSI.offset028)
  1484. #define CSI_CSIDMASA_FB2 (IMXRT_CSI.offset02C)
  1485. #define CSI_CSIFBUF_PARA (IMXRT_CSI.offset030)
  1486. #define CSI_CSIIMAG_PARA (IMXRT_CSI.offset034)
  1487. #define CSI_CSICR18 (IMXRT_CSI.offset048)
  1488. #define CSI_CSICR19 (IMXRT_CSI.offset04C)
  1489. // 20.6.1.1: page 837
  1490. #define IMXRT_DCDC (*(IMXRT_REGISTER32_t *)0x40080000)
  1491. #define DCDC_REG0 (IMXRT_DCDC.offset000)
  1492. #define DCDC_REG1 (IMXRT_DCDC.offset004)
  1493. #define DCDC_REG2 (IMXRT_DCDC.offset008)
  1494. #define DCDC_REG3 (IMXRT_DCDC.offset00C)
  1495. #define DCDC_REG0_STS_DC_OK ((uint32_t)(1<<31))
  1496. #define DCDC_REG0_XTAL_24M_OK ((uint32_t)(1<<29))
  1497. #define DCDC_REG0_CURRENT_ALERT_RESET ((uint32_t)(1<<28))
  1498. #define DCDC_REG0_XTALOK_DISABLE ((uint32_t)(1<<27))
  1499. #define DCDC_REG0_PWD_CMP_OFFSET ((uint32_t)(1<<26))
  1500. #define DCDC_REG0_LP_HIGH_HYS ((uint32_t)(1<<21))
  1501. #define DCDC_REG0_LP_OVERLOAD_FREQ_SEL ((uint32_t)(1<<20))
  1502. #define DCDC_REG0_LP_OVERLOAD_THRSH(n) ((uint32_t)(((n) & 0x03) << 18))
  1503. #define DCDC_REG0_PWD_HIGH_VOLT_DET ((uint32_t)(1<<17))
  1504. #define DCDC_REG0_EN_LP_OVERLOAD_SNS ((uint32_t)(1<<16))
  1505. #define DCDC_REG0_ADJ_POSLIMIT_BUCK(n) ((uint32_t)(((n) & 0x0F) << 12))
  1506. #define DCDC_REG0_PWD_CMP_BATT_DET ((uint32_t)(1<<11))
  1507. #define DCDC_REG0_OVERCUR_TRIG_ADJ(n) ((uint32_t)(((n) & 0x03) << 9))
  1508. #define DCDC_REG0_PWD_OVERCUR_DET ((uint32_t)(1<<8))
  1509. #define DCDC_REG0_CUR_SNS_THRSH(n) ((uint32_t)(((n) & 0x07) << 5))
  1510. #define DCDC_REG0_PWD_CUR_SNS_CMP ((uint32_t)(1<<4))
  1511. #define DCDC_REG0_PWD_OSC_INT ((uint32_t)(1<<3))
  1512. #define DCDC_REG0_SEL_CLK ((uint32_t)(1<<2))
  1513. #define DCDC_REG0_DISABLE_AUTO_CLK_SWITCH ((uint32_t)(1<<1))
  1514. #define DCDC_REG0_PWD_ZCD ((uint32_t)(1<<0))
  1515. #define DCDC_REG1_VBG_TRIM(n) ((uint32_t)(((n) & 0x1F) << 24))
  1516. #define DCDC_REG1_LOOPCTRL_EN_HYST ((uint32_t)(1<<23))
  1517. #define DCDC_REG1_LOOPCTRL_HST_THRESH ((uint32_t)(1<<21))
  1518. #define DCDC_REG1_LP_CMP_ISRC_SEL(n) ((uint32_t)(((n) & 0x03) << 12))
  1519. #define DCDC_REG1_REG_RLOAD_SW ((uint32_t)(1<<9))
  1520. #define DCDC_REG1_REG_FBK_SEL(n) ((uint32_t)(((n) & 0x03) << 7))
  1521. #define DCDC_REG2_DCM_SET_CTRL ((uint32_t)(1<<28))
  1522. #define DCDC_REG2_DISABLE_PULSE_SKIP ((uint32_t)(1<<27))
  1523. #define DCDC_REG2_LOOPCTRL_HYST_SIGN ((uint32_t)(1<<13))
  1524. #define DCDC_REG2_LOOPCTRL_RCSCALE_THRSH ((uint32_t)(1<<12))
  1525. #define DCDC_REG2_LOOPCTRL_EN_RCSCALE ((uint32_t)(((n) & 0x07) << 9))
  1526. #define DCDC_REG2_LOOPCTRL_DC_FF ((uint32_t)(((n) & 0x07) << 6))
  1527. #define DCDC_REG2_LOOPCTRL_DC_R ((uint32_t)(((n) & 0x0F) << 2))
  1528. #define DCDC_REG2_LOOPCTRL_DC_C ((uint32_t)(((n) & 0x03) << 0))
  1529. #define DCDC_REG3_DISABLE_STEP ((uint32_t)(1<<30))
  1530. #define DCDC_REG3_MISC_DISABLEFET_LOGIC ((uint32_t)(1<<28))
  1531. #define DCDC_REG3_MISC_DELAY_TIMING ((uint32_t)(1<<27))
  1532. #define DCDC_REG3_MINPWR_DC_HALFCLK ((uint32_t)(1<<24))
  1533. #define DCDC_REG3_TARGET_LP(n) ((uint32_t)(((n) & 0x07) << 8))
  1534. #define DCDC_REG3_TRG(n) ((uint32_t)(((n) & 0x1F) << 0))
  1535. #define DCDC_REG3_TRG_MASK ((uint32_t)(0x1F << 0))
  1536. // 21.4.1.1: page 849
  1537. #define IMXRT_DMAMUX (*(IMXRT_REGISTER32_t *)0x400EC000)
  1538. #define DMAMUX_CHCFG0 (IMXRT_DMAMUX.offset000)
  1539. #define DMAMUX_CHCFG1 (IMXRT_DMAMUX.offset004)
  1540. #define DMAMUX_CHCFG2 (IMXRT_DMAMUX.offset008)
  1541. #define DMAMUX_CHCFG3 (IMXRT_DMAMUX.offset00C)
  1542. #define DMAMUX_CHCFG4 (IMXRT_DMAMUX.offset010)
  1543. #define DMAMUX_CHCFG5 (IMXRT_DMAMUX.offset014)
  1544. #define DMAMUX_CHCFG6 (IMXRT_DMAMUX.offset018)
  1545. #define DMAMUX_CHCFG7 (IMXRT_DMAMUX.offset01C)
  1546. #define DMAMUX_CHCFG8 (IMXRT_DMAMUX.offset020)
  1547. #define DMAMUX_CHCFG9 (IMXRT_DMAMUX.offset024)
  1548. #define DMAMUX_CHCFG10 (IMXRT_DMAMUX.offset028)
  1549. #define DMAMUX_CHCFG11 (IMXRT_DMAMUX.offset02C)
  1550. #define DMAMUX_CHCFG12 (IMXRT_DMAMUX.offset030)
  1551. #define DMAMUX_CHCFG13 (IMXRT_DMAMUX.offset034)
  1552. #define DMAMUX_CHCFG14 (IMXRT_DMAMUX.offset038)
  1553. #define DMAMUX_CHCFG15 (IMXRT_DMAMUX.offset03C)
  1554. #define DMAMUX_CHCFG16 (IMXRT_DMAMUX.offset040)
  1555. #define DMAMUX_CHCFG17 (IMXRT_DMAMUX.offset044)
  1556. #define DMAMUX_CHCFG18 (IMXRT_DMAMUX.offset048)
  1557. #define DMAMUX_CHCFG19 (IMXRT_DMAMUX.offset04C)
  1558. #define DMAMUX_CHCFG20 (IMXRT_DMAMUX.offset050)
  1559. #define DMAMUX_CHCFG21 (IMXRT_DMAMUX.offset054)
  1560. #define DMAMUX_CHCFG22 (IMXRT_DMAMUX.offset058)
  1561. #define DMAMUX_CHCFG23 (IMXRT_DMAMUX.offset05C)
  1562. #define DMAMUX_CHCFG24 (IMXRT_DMAMUX.offset060)
  1563. #define DMAMUX_CHCFG25 (IMXRT_DMAMUX.offset064)
  1564. #define DMAMUX_CHCFG26 (IMXRT_DMAMUX.offset068)
  1565. #define DMAMUX_CHCFG27 (IMXRT_DMAMUX.offset06C)
  1566. #define DMAMUX_CHCFG28 (IMXRT_DMAMUX.offset070)
  1567. #define DMAMUX_CHCFG29 (IMXRT_DMAMUX.offset074)
  1568. #define DMAMUX_CHCFG30 (IMXRT_DMAMUX.offset078)
  1569. #define DMAMUX_CHCFG31 (IMXRT_DMAMUX.offset07C)
  1570. #define DMAMUX_CHCFG_ENBL ((uint32_t)(1<<31))
  1571. #define DMAMUX_CHCFG_TRIG ((uint32_t)(1<<30))
  1572. #define DMAMUX_CHCFG_A_ON ((uint32_t)(1<<29))
  1573. // 22.3.5.1: page 864
  1574. typedef struct {
  1575. volatile uint32_t CR; // 0
  1576. volatile uint32_t ES; // 4
  1577. uint32_t unused1; // 8
  1578. volatile uint32_t ERQ; // C
  1579. uint32_t unused2; // 10
  1580. volatile uint32_t EEI; // 14
  1581. volatile uint8_t CEEI; // 18
  1582. volatile uint8_t SEEI; // 19
  1583. volatile uint8_t CERQ; // 1A
  1584. volatile uint8_t SERQ; // 1B
  1585. volatile uint8_t CDNE; // 1C
  1586. volatile uint8_t SSRT; // 1D
  1587. volatile uint8_t CERR; // 1E
  1588. volatile uint8_t CINT; // 1F
  1589. uint32_t unused3; // 20
  1590. volatile uint32_t INT; // 24
  1591. uint32_t unused4; // 28
  1592. volatile uint32_t ERR; // 2C
  1593. uint32_t unused5; // 30
  1594. volatile uint32_t HRS; // 34
  1595. uint32_t unused6; // 38
  1596. uint32_t unused7; // 3C
  1597. uint32_t unused8; // 40
  1598. volatile uint32_t EARS; // 44
  1599. uint32_t unused[46];
  1600. volatile uint8_t DCHPRI3;
  1601. volatile uint8_t DCHPRI2;
  1602. volatile uint8_t DCHPRI1;
  1603. volatile uint8_t DCHPRI0;
  1604. volatile uint8_t DCHPRI7;
  1605. volatile uint8_t DCHPRI6;
  1606. volatile uint8_t DCHPRI5;
  1607. volatile uint8_t DCHPRI4;
  1608. volatile uint8_t DCHPRI11;
  1609. volatile uint8_t DCHPRI10;
  1610. volatile uint8_t DCHPRI9;
  1611. volatile uint8_t DCHPRI8;
  1612. volatile uint8_t DCHPRI15;
  1613. volatile uint8_t DCHPRI14;
  1614. volatile uint8_t DCHPRI13;
  1615. volatile uint8_t DCHPRI12;
  1616. volatile uint8_t DCHPRI19;
  1617. volatile uint8_t DCHPRI18;
  1618. volatile uint8_t DCHPRI17;
  1619. volatile uint8_t DCHPRI16;
  1620. volatile uint8_t DCHPRI23;
  1621. volatile uint8_t DCHPRI22;
  1622. volatile uint8_t DCHPRI21;
  1623. volatile uint8_t DCHPRI20;
  1624. volatile uint8_t DCHPRI27;
  1625. volatile uint8_t DCHPRI26;
  1626. volatile uint8_t DCHPRI25;
  1627. volatile uint8_t DCHPRI24;
  1628. volatile uint8_t DCHPRI31;
  1629. volatile uint8_t DCHPRI30;
  1630. volatile uint8_t DCHPRI29;
  1631. volatile uint8_t DCHPRI28;
  1632. } IMXRT_DMA_t;
  1633. typedef struct {
  1634. volatile const void * volatile SADDR;
  1635. int16_t SOFF;
  1636. union {
  1637. uint16_t ATTR;
  1638. struct {
  1639. uint8_t ATTR_DST;
  1640. uint8_t ATTR_SRC;
  1641. };
  1642. };
  1643. union {
  1644. uint32_t NBYTES;
  1645. uint32_t NBYTES_MLNO;
  1646. uint32_t NBYTES_MLOFFNO;
  1647. uint32_t NBYTES_MLOFFYES;
  1648. };
  1649. int32_t SLAST;
  1650. volatile void * volatile DADDR;
  1651. int16_t DOFF;
  1652. union {
  1653. volatile uint16_t CITER;
  1654. volatile uint16_t CITER_ELINKYES;
  1655. volatile uint16_t CITER_ELINKNO;
  1656. };
  1657. int32_t DLASTSGA;
  1658. volatile uint16_t CSR;
  1659. union {
  1660. volatile uint16_t BITER;
  1661. volatile uint16_t BITER_ELINKYES;
  1662. volatile uint16_t BITER_ELINKNO;
  1663. };
  1664. } IMXRT_DMA_TCD_t;
  1665. #define IMXRT_DMA (*(IMXRT_DMA_t *)0x400E8000)
  1666. #define DMA_CR (IMXRT_DMA.CR)
  1667. #define DMA_ES (IMXRT_DMA.ES)
  1668. #define DMA_ERQ (IMXRT_DMA.ERQ)
  1669. #define DMA_EEI (IMXRT_DMA.EEI)
  1670. #define DMA_CEEI (IMXRT_DMA.CEEI)
  1671. #define DMA_SEEI (IMXRT_DMA.SEEI)
  1672. #define DMA_CERQ (IMXRT_DMA.CERQ)
  1673. #define DMA_SERQ (IMXRT_DMA.SERQ)
  1674. #define DMA_CDNE (IMXRT_DMA.CDNE)
  1675. #define DMA_SSRT (IMXRT_DMA.SSRT)
  1676. #define DMA_CERR (IMXRT_DMA.CERR)
  1677. #define DMA_CINT (IMXRT_DMA.CINT)
  1678. #define DMA_INT (IMXRT_DMA.INT)
  1679. #define DMA_ERR (IMXRT_DMA.ERR)
  1680. #define DMA_HRS (IMXRT_DMA.HRS)
  1681. #define DMA_EARS (IMXRT_DMA.EARS)
  1682. #define DMA_DCHPRI3 (IMXRT_DMA.DCHPRI3)
  1683. #define DMA_DCHPRI2 (IMXRT_DMA.DCHPRI2)
  1684. #define DMA_DCHPRI1 (IMXRT_DMA.DCHPRI1)
  1685. #define DMA_DCHPRI0 (IMXRT_DMA.DCHPRI0)
  1686. #define DMA_DCHPRI7 (IMXRT_DMA.DCHPRI7)
  1687. #define DMA_DCHPRI6 (IMXRT_DMA.DCHPRI6)
  1688. #define DMA_DCHPRI5 (IMXRT_DMA.DCHPRI5)
  1689. #define DMA_DCHPRI4 (IMXRT_DMA.DCHPRI4)
  1690. #define DMA_DCHPRI11 (IMXRT_DMA.DCHPRI11)
  1691. #define DMA_DCHPRI10 (IMXRT_DMA.DCHPRI10)
  1692. #define DMA_DCHPRI9 (IMXRT_DMA.DCHPRI9)
  1693. #define DMA_DCHPRI8 (IMXRT_DMA.DCHPRI8)
  1694. #define DMA_DCHPRI15 (IMXRT_DMA.DCHPRI15)
  1695. #define DMA_DCHPRI14 (IMXRT_DMA.DCHPRI14)
  1696. #define DMA_DCHPRI13 (IMXRT_DMA.DCHPRI13)
  1697. #define DMA_DCHPRI12 (IMXRT_DMA.DCHPRI12)
  1698. #define DMA_DCHPRI19 (IMXRT_DMA.DCHPRI19)
  1699. #define DMA_DCHPRI18 (IMXRT_DMA.DCHPRI18)
  1700. #define DMA_DCHPRI17 (IMXRT_DMA.DCHPRI17)
  1701. #define DMA_DCHPRI16 (IMXRT_DMA.DCHPRI16)
  1702. #define DMA_DCHPRI23 (IMXRT_DMA.DCHPRI23)
  1703. #define DMA_DCHPRI22 (IMXRT_DMA.DCHPRI22)
  1704. #define DMA_DCHPRI21 (IMXRT_DMA.DCHPRI21)
  1705. #define DMA_DCHPRI20 (IMXRT_DMA.DCHPRI20)
  1706. #define DMA_DCHPRI27 (IMXRT_DMA.DCHPRI27)
  1707. #define DMA_DCHPRI26 (IMXRT_DMA.DCHPRI26)
  1708. #define DMA_DCHPRI25 (IMXRT_DMA.DCHPRI25)
  1709. #define DMA_DCHPRI24 (IMXRT_DMA.DCHPRI24)
  1710. #define DMA_DCHPRI31 (IMXRT_DMA.DCHPRI31)
  1711. #define DMA_DCHPRI30 (IMXRT_DMA.DCHPRI30)
  1712. #define DMA_DCHPRI29 (IMXRT_DMA.DCHPRI29)
  1713. #define DMA_DCHPRI28 (IMXRT_DMA.DCHPRI28)
  1714. #define DMA_CR_ACTIVE ((uint32_t)(1<<31)) // 1=DMA is executing
  1715. #define DMA_CR_CX ((uint32_t)(1<<17)) // Cancel Transfer
  1716. #define DMA_CR_ECX ((uint32_t)(1<<16)) // Error Cancel Transfer
  1717. #define DMA_CR_GRP1PRI ((uint32_t)(1<<10))
  1718. #define DMA_CR_GRP0PRI ((uint32_t)(1<<8))
  1719. #define DMA_CR_EMLM ((uint32_t)(1<<7)) // Enable Minor Loop Mapping
  1720. #define DMA_CR_CLM ((uint32_t)(1<<6)) // Continuous Link Mode
  1721. #define DMA_CR_HALT ((uint32_t)(1<<5)) // Halt DMA Operations
  1722. #define DMA_CR_HOE ((uint32_t)(1<<4)) // Halt On Error
  1723. #define DMA_CR_ERGA ((uint32_t)(1<<3)) // Enable Round Robin Group Arb
  1724. #define DMA_CR_ERCA ((uint32_t)(1<<2)) // Enable Round Robin Channel Arb
  1725. #define DMA_CR_EDBG ((uint32_t)(1<<1)) // Enable Debug
  1726. #define DMA_CEEI_CEEI(n) ((uint8_t)(n & 0x1F)) // Clear Enable Error Interrupt
  1727. #define DMA_CEEI_CAEE ((uint8_t)1<<6) // Clear All Enable Error Interrupts
  1728. #define DMA_CEEI_NOP ((uint8_t)1<<7) // NOP
  1729. #define DMA_SEEI_SEEI(n) ((uint8_t)(n & 0x1F)) // Set Enable Error Interrupt
  1730. #define DMA_SEEI_SAEE ((uint8_t)1<<6) // Set All Enable Error Interrupts
  1731. #define DMA_SEEI_NOP ((uint8_t)1<<7) // NOP
  1732. #define DMA_CERQ_CERQ(n) ((uint8_t)(n & 0x1F)) // Clear Enable Request
  1733. #define DMA_CERQ_CAER ((uint8_t)1<<6) // Clear All Enable Requests
  1734. #define DMA_CERQ_NOP ((uint8_t)1<<7) // NOP
  1735. #define DMA_SERQ_SERQ(n) ((uint8_t)(n & 0x1F)) // Set Enable Request
  1736. #define DMA_SERQ_SAER ((uint8_t)1<<6) // Set All Enable Requests
  1737. #define DMA_SERQ_NOP ((uint8_t)1<<7) // NOP
  1738. #define DMA_CDNE_CDNE(n) ((uint8_t)(n & 0x1F)) // Clear Done Bit
  1739. #define DMA_CDNE_CADN ((uint8_t)1<<6) // Clear All Done Bits
  1740. #define DMA_CDNE_NOP ((uint8_t)1<<7) // NOP
  1741. #define DMA_SSRT_SSRT(n) ((uint8_t)(n & 0x1F)) // Set Start Bit
  1742. #define DMA_SSRT_SAST ((uint8_t)1<<6) // Set All Start Bits
  1743. #define DMA_SSRT_NOP ((uint8_t)1<<7) // NOP
  1744. #define DMA_CERR_CERR(n) ((uint8_t)(n & 0x1F)) // Clear Error Indicator
  1745. #define DMA_CERR_CAEI ((uint8_t)1<<6) // Clear All Error Indicators
  1746. #define DMA_CERR_NOP ((uint8_t)1<<7) // NOP
  1747. #define DMA_CINT_CINT(n) ((uint8_t)(n & 0x1F)) // Clear Interrupt Request
  1748. #define DMA_CINT_CAIR ((uint8_t)1<<6) // Clear All Interrupt Requests
  1749. #define DMA_CINT_NOP ((uint8_t)1<<7) // NOP
  1750. #define IMXRT_DMA_TCD ((IMXRT_DMA_TCD_t *)0x400E9000)
  1751. #define DMA_TCD0_SADDR (IMXRT_DMA_TCD[0].SADDR)
  1752. #define DMA_TCD0_SOFF (IMXRT_DMA_TCD[0].SOFF)
  1753. #define DMA_TCD0_ATTR (IMXRT_DMA_TCD[0].ATTR)
  1754. #define DMA_TCD0_NBYTES (IMXRT_DMA_TCD[0].NBYTES)
  1755. #define DMA_TCD0_NBYTES_MLNO (IMXRT_DMA_TCD[0].NBYTES_MLNO)
  1756. #define DMA_TCD0_NBYTES_MLOFFNO (IMXRT_DMA_TCD[0].NBYTES_MLOFFNO)
  1757. #define DMA_TCD0_NBYTES_MLOFFYES (IMXRT_DMA_TCD[0].NBYTES_MLOFFYES)
  1758. #define DMA_TCD0_SLAST (IMXRT_DMA_TCD[0].SLAST)
  1759. #define DMA_TCD0_DADDR (IMXRT_DMA_TCD[0].DADDR)
  1760. #define DMA_TCD0_DOFF (IMXRT_DMA_TCD[0].DOFF)
  1761. #define DMA_TCD0_CITER (IMXRT_DMA_TCD[0].CITER)
  1762. #define DMA_TCD0_CITER_ELINKYES (IMXRT_DMA_TCD[0].CITER_ELINKYES)
  1763. #define DMA_TCD0_CITER_ELINKNO (IMXRT_DMA_TCD[0].CITER_ELINKNO)
  1764. #define DMA_TCD0_DLASTSGA (IMXRT_DMA_TCD[0].DLASTSGA)
  1765. #define DMA_TCD0_CSR (IMXRT_DMA_TCD[0].CSR)
  1766. #define DMA_TCD0_BITER (IMXRT_DMA_TCD[0].BITER)
  1767. #define DMA_TCD0_BITER_ELINKYES (IMXRT_DMA_TCD[0].BITER_ELINKYES)
  1768. #define DMA_TCD0_BITER_ELINKNO (IMXRT_DMA_TCD[0].BITER_ELINKNO)
  1769. #define DMA_TCD1_SADDR (IMXRT_DMA_TCD[1].SADDR)
  1770. #define DMA_TCD1_SOFF (IMXRT_DMA_TCD[1].SOFF)
  1771. #define DMA_TCD1_ATTR (IMXRT_DMA_TCD[1].ATTR)
  1772. #define DMA_TCD1_NBYTES (IMXRT_DMA_TCD[1].NBYTES)
  1773. #define DMA_TCD1_NBYTES_MLNO (IMXRT_DMA_TCD[1].NBYTES_MLNO)
  1774. #define DMA_TCD1_NBYTES_MLOFFNO (IMXRT_DMA_TCD[1].NBYTES_MLOFFNO)
  1775. #define DMA_TCD1_NBYTES_MLOFFYES (IMXRT_DMA_TCD[1].NBYTES_MLOFFYES)
  1776. #define DMA_TCD1_SLAST (IMXRT_DMA_TCD[1].SLAST)
  1777. #define DMA_TCD1_DADDR (IMXRT_DMA_TCD[1].DADDR)
  1778. #define DMA_TCD1_DOFF (IMXRT_DMA_TCD[1].DOFF)
  1779. #define DMA_TCD1_CITER (IMXRT_DMA_TCD[1].CITER)
  1780. #define DMA_TCD1_CITER_ELINKYES (IMXRT_DMA_TCD[1].CITER_ELINKYES)
  1781. #define DMA_TCD1_CITER_ELINKNO (IMXRT_DMA_TCD[1].CITER_ELINKNO)
  1782. #define DMA_TCD1_DLASTSGA (IMXRT_DMA_TCD[1].DLASTSGA)
  1783. #define DMA_TCD1_CSR (IMXRT_DMA_TCD[1].CSR)
  1784. #define DMA_TCD1_BITER (IMXRT_DMA_TCD[1].BITER)
  1785. #define DMA_TCD1_BITER_ELINKYES (IMXRT_DMA_TCD[1].BITER_ELINKYES)
  1786. #define DMA_TCD1_BITER_ELINKNO (IMXRT_DMA_TCD[1].BITER_ELINKNO)
  1787. #define DMA_TCD2_SADDR (IMXRT_DMA_TCD[2].SADDR)
  1788. #define DMA_TCD2_SOFF (IMXRT_DMA_TCD[2].SOFF)
  1789. #define DMA_TCD2_ATTR (IMXRT_DMA_TCD[2].ATTR)
  1790. #define DMA_TCD2_NBYTES (IMXRT_DMA_TCD[2].NBYTES)
  1791. #define DMA_TCD2_NBYTES_MLNO (IMXRT_DMA_TCD[2].NBYTES_MLNO)
  1792. #define DMA_TCD2_NBYTES_MLOFFNO (IMXRT_DMA_TCD[2].NBYTES_MLOFFNO)
  1793. #define DMA_TCD2_NBYTES_MLOFFYES (IMXRT_DMA_TCD[2].NBYTES_MLOFFYES)
  1794. #define DMA_TCD2_SLAST (IMXRT_DMA_TCD[2].SLAST)
  1795. #define DMA_TCD2_DADDR (IMXRT_DMA_TCD[2].DADDR)
  1796. #define DMA_TCD2_DOFF (IMXRT_DMA_TCD[2].DOFF)
  1797. #define DMA_TCD2_CITER (IMXRT_DMA_TCD[2].CITER)
  1798. #define DMA_TCD2_CITER_ELINKYES (IMXRT_DMA_TCD[2].CITER_ELINKYES)
  1799. #define DMA_TCD2_CITER_ELINKNO (IMXRT_DMA_TCD[2].CITER_ELINKNO)
  1800. #define DMA_TCD2_DLASTSGA (IMXRT_DMA_TCD[2].DLASTSGA)
  1801. #define DMA_TCD2_CSR (IMXRT_DMA_TCD[2].CSR)
  1802. #define DMA_TCD2_BITER (IMXRT_DMA_TCD[2].BITER)
  1803. #define DMA_TCD2_BITER_ELINKYES (IMXRT_DMA_TCD[2].BITER_ELINKYES)
  1804. #define DMA_TCD2_BITER_ELINKNO (IMXRT_DMA_TCD[2].BITER_ELINKNO)
  1805. #define DMA_TCD3_SADDR (IMXRT_DMA_TCD[3].SADDR)
  1806. #define DMA_TCD3_SOFF (IMXRT_DMA_TCD[3].SOFF)
  1807. #define DMA_TCD3_ATTR (IMXRT_DMA_TCD[3].ATTR)
  1808. #define DMA_TCD3_NBYTES (IMXRT_DMA_TCD[3].NBYTES)
  1809. #define DMA_TCD3_NBYTES_MLNO (IMXRT_DMA_TCD[3].NBYTES_MLNO)
  1810. #define DMA_TCD3_NBYTES_MLOFFNO (IMXRT_DMA_TCD[3].NBYTES_MLOFFNO)
  1811. #define DMA_TCD3_NBYTES_MLOFFYES (IMXRT_DMA_TCD[3].NBYTES_MLOFFYES)
  1812. #define DMA_TCD3_SLAST (IMXRT_DMA_TCD[3].SLAST)
  1813. #define DMA_TCD3_DADDR (IMXRT_DMA_TCD[3].DADDR)
  1814. #define DMA_TCD3_DOFF (IMXRT_DMA_TCD[3].DOFF)
  1815. #define DMA_TCD3_CITER (IMXRT_DMA_TCD[3].CITER)
  1816. #define DMA_TCD3_CITER_ELINKYES (IMXRT_DMA_TCD[3].CITER_ELINKYES)
  1817. #define DMA_TCD3_CITER_ELINKNO (IMXRT_DMA_TCD[3].CITER_ELINKNO)
  1818. #define DMA_TCD3_DLASTSGA (IMXRT_DMA_TCD[3].DLASTSGA)
  1819. #define DMA_TCD3_CSR (IMXRT_DMA_TCD[3].CSR)
  1820. #define DMA_TCD3_BITER (IMXRT_DMA_TCD[3].BITER)
  1821. #define DMA_TCD3_BITER_ELINKYES (IMXRT_DMA_TCD[3].BITER_ELINKYES)
  1822. #define DMA_TCD3_BITER_ELINKNO (IMXRT_DMA_TCD[3].BITER_ELINKNO)
  1823. #define DMA_TCD4_SADDR (IMXRT_DMA_TCD[4].SADDR)
  1824. #define DMA_TCD4_SOFF (IMXRT_DMA_TCD[4].SOFF)
  1825. #define DMA_TCD4_ATTR (IMXRT_DMA_TCD[4].ATTR)
  1826. #define DMA_TCD4_NBYTES (IMXRT_DMA_TCD[4].NBYTES)
  1827. #define DMA_TCD4_NBYTES_MLNO (IMXRT_DMA_TCD[4].NBYTES_MLNO)
  1828. #define DMA_TCD4_NBYTES_MLOFFNO (IMXRT_DMA_TCD[4].NBYTES_MLOFFNO)
  1829. #define DMA_TCD4_NBYTES_MLOFFYES (IMXRT_DMA_TCD[4].NBYTES_MLOFFYES)
  1830. #define DMA_TCD4_SLAST (IMXRT_DMA_TCD[4].SLAST)
  1831. #define DMA_TCD4_DADDR (IMXRT_DMA_TCD[4].DADDR)
  1832. #define DMA_TCD4_DOFF (IMXRT_DMA_TCD[4].DOFF)
  1833. #define DMA_TCD4_CITER (IMXRT_DMA_TCD[4].CITER)
  1834. #define DMA_TCD4_CITER_ELINKYES (IMXRT_DMA_TCD[4].CITER_ELINKYES)
  1835. #define DMA_TCD4_CITER_ELINKNO (IMXRT_DMA_TCD[4].CITER_ELINKNO)
  1836. #define DMA_TCD4_DLASTSGA (IMXRT_DMA_TCD[4].DLASTSGA)
  1837. #define DMA_TCD4_CSR (IMXRT_DMA_TCD[4].CSR)
  1838. #define DMA_TCD4_BITER (IMXRT_DMA_TCD[4].BITER)
  1839. #define DMA_TCD4_BITER_ELINKYES (IMXRT_DMA_TCD[4].BITER_ELINKYES)
  1840. #define DMA_TCD4_BITER_ELINKNO (IMXRT_DMA_TCD[4].BITER_ELINKNO)
  1841. #define DMA_TCD5_SADDR (IMXRT_DMA_TCD[5].SADDR)
  1842. #define DMA_TCD5_SOFF (IMXRT_DMA_TCD[5].SOFF)
  1843. #define DMA_TCD5_ATTR (IMXRT_DMA_TCD[5].ATTR)
  1844. #define DMA_TCD5_NBYTES (IMXRT_DMA_TCD[5].NBYTES)
  1845. #define DMA_TCD5_NBYTES_MLNO (IMXRT_DMA_TCD[5].NBYTES_MLNO)
  1846. #define DMA_TCD5_NBYTES_MLOFFNO (IMXRT_DMA_TCD[5].NBYTES_MLOFFNO)
  1847. #define DMA_TCD5_NBYTES_MLOFFYES (IMXRT_DMA_TCD[5].NBYTES_MLOFFYES)
  1848. #define DMA_TCD5_SLAST (IMXRT_DMA_TCD[5].SLAST)
  1849. #define DMA_TCD5_DADDR (IMXRT_DMA_TCD[5].DADDR)
  1850. #define DMA_TCD5_DOFF (IMXRT_DMA_TCD[5].DOFF)
  1851. #define DMA_TCD5_CITER (IMXRT_DMA_TCD[5].CITER)
  1852. #define DMA_TCD5_CITER_ELINKYES (IMXRT_DMA_TCD[5].CITER_ELINKYES)
  1853. #define DMA_TCD5_CITER_ELINKNO (IMXRT_DMA_TCD[5].CITER_ELINKNO)
  1854. #define DMA_TCD5_DLASTSGA (IMXRT_DMA_TCD[5].DLASTSGA)
  1855. #define DMA_TCD5_CSR (IMXRT_DMA_TCD[5].CSR)
  1856. #define DMA_TCD5_BITER (IMXRT_DMA_TCD[5].BITER)
  1857. #define DMA_TCD5_BITER_ELINKYES (IMXRT_DMA_TCD[5].BITER_ELINKYES)
  1858. #define DMA_TCD5_BITER_ELINKNO (IMXRT_DMA_TCD[5].BITER_ELINKNO)
  1859. #define DMA_TCD6_SADDR (IMXRT_DMA_TCD[6].SADDR)
  1860. #define DMA_TCD6_SOFF (IMXRT_DMA_TCD[6].SOFF)
  1861. #define DMA_TCD6_ATTR (IMXRT_DMA_TCD[6].ATTR)
  1862. #define DMA_TCD6_NBYTES (IMXRT_DMA_TCD[6].NBYTES)
  1863. #define DMA_TCD6_NBYTES_MLNO (IMXRT_DMA_TCD[6].NBYTES_MLNO)
  1864. #define DMA_TCD6_NBYTES_MLOFFNO (IMXRT_DMA_TCD[6].NBYTES_MLOFFNO)
  1865. #define DMA_TCD6_NBYTES_MLOFFYES (IMXRT_DMA_TCD[6].NBYTES_MLOFFYES)
  1866. #define DMA_TCD6_SLAST (IMXRT_DMA_TCD[6].SLAST)
  1867. #define DMA_TCD6_DADDR (IMXRT_DMA_TCD[6].DADDR)
  1868. #define DMA_TCD6_DOFF (IMXRT_DMA_TCD[6].DOFF)
  1869. #define DMA_TCD6_CITER (IMXRT_DMA_TCD[6].CITER)
  1870. #define DMA_TCD6_CITER_ELINKYES (IMXRT_DMA_TCD[6].CITER_ELINKYES)
  1871. #define DMA_TCD6_CITER_ELINKNO (IMXRT_DMA_TCD[6].CITER_ELINKNO)
  1872. #define DMA_TCD6_DLASTSGA (IMXRT_DMA_TCD[6].DLASTSGA)
  1873. #define DMA_TCD6_CSR (IMXRT_DMA_TCD[6].CSR)
  1874. #define DMA_TCD6_BITER (IMXRT_DMA_TCD[6].BITER)
  1875. #define DMA_TCD6_BITER_ELINKYES (IMXRT_DMA_TCD[6].BITER_ELINKYES)
  1876. #define DMA_TCD6_BITER_ELINKNO (IMXRT_DMA_TCD[6].BITER_ELINKNO)
  1877. #define DMA_TCD7_SADDR (IMXRT_DMA_TCD[7].SADDR)
  1878. #define DMA_TCD7_SOFF (IMXRT_DMA_TCD[7].SOFF)
  1879. #define DMA_TCD7_ATTR (IMXRT_DMA_TCD[7].ATTR)
  1880. #define DMA_TCD7_NBYTES (IMXRT_DMA_TCD[7].NBYTES)
  1881. #define DMA_TCD7_NBYTES_MLNO (IMXRT_DMA_TCD[7].NBYTES_MLNO)
  1882. #define DMA_TCD7_NBYTES_MLOFFNO (IMXRT_DMA_TCD[7].NBYTES_MLOFFNO)
  1883. #define DMA_TCD7_NBYTES_MLOFFYES (IMXRT_DMA_TCD[7].NBYTES_MLOFFYES)
  1884. #define DMA_TCD7_SLAST (IMXRT_DMA_TCD[7].SLAST)
  1885. #define DMA_TCD7_DADDR (IMXRT_DMA_TCD[7].DADDR)
  1886. #define DMA_TCD7_DOFF (IMXRT_DMA_TCD[7].DOFF)
  1887. #define DMA_TCD7_CITER (IMXRT_DMA_TCD[7].CITER)
  1888. #define DMA_TCD7_CITER_ELINKYES (IMXRT_DMA_TCD[7].CITER_ELINKYES)
  1889. #define DMA_TCD7_CITER_ELINKNO (IMXRT_DMA_TCD[7].CITER_ELINKNO)
  1890. #define DMA_TCD7_DLASTSGA (IMXRT_DMA_TCD[7].DLASTSGA)
  1891. #define DMA_TCD7_CSR (IMXRT_DMA_TCD[7].CSR)
  1892. #define DMA_TCD7_BITER (IMXRT_DMA_TCD[7].BITER)
  1893. #define DMA_TCD7_BITER_ELINKYES (IMXRT_DMA_TCD[7].BITER_ELINKYES)
  1894. #define DMA_TCD7_BITER_ELINKNO (IMXRT_DMA_TCD[7].BITER_ELINKNO)
  1895. #define DMA_TCD8_SADDR (IMXRT_DMA_TCD[8].SADDR)
  1896. #define DMA_TCD8_SOFF (IMXRT_DMA_TCD[8].SOFF)
  1897. #define DMA_TCD8_ATTR (IMXRT_DMA_TCD[8].ATTR)
  1898. #define DMA_TCD8_NBYTES (IMXRT_DMA_TCD[8].NBYTES)
  1899. #define DMA_TCD8_NBYTES_MLNO (IMXRT_DMA_TCD[8].NBYTES_MLNO)
  1900. #define DMA_TCD8_NBYTES_MLOFFNO (IMXRT_DMA_TCD[8].NBYTES_MLOFFNO)
  1901. #define DMA_TCD8_NBYTES_MLOFFYES (IMXRT_DMA_TCD[8].NBYTES_MLOFFYES)
  1902. #define DMA_TCD8_SLAST (IMXRT_DMA_TCD[8].SLAST)
  1903. #define DMA_TCD8_DADDR (IMXRT_DMA_TCD[8].DADDR)
  1904. #define DMA_TCD8_DOFF (IMXRT_DMA_TCD[8].DOFF)
  1905. #define DMA_TCD8_CITER (IMXRT_DMA_TCD[8].CITER)
  1906. #define DMA_TCD8_CITER_ELINKYES (IMXRT_DMA_TCD[8].CITER_ELINKYES)
  1907. #define DMA_TCD8_CITER_ELINKNO (IMXRT_DMA_TCD[8].CITER_ELINKNO)
  1908. #define DMA_TCD8_DLASTSGA (IMXRT_DMA_TCD[8].DLASTSGA)
  1909. #define DMA_TCD8_CSR (IMXRT_DMA_TCD[8].CSR)
  1910. #define DMA_TCD8_BITER (IMXRT_DMA_TCD[8].BITER)
  1911. #define DMA_TCD8_BITER_ELINKYES (IMXRT_DMA_TCD[8].BITER_ELINKYES)
  1912. #define DMA_TCD8_BITER_ELINKNO (IMXRT_DMA_TCD[8].BITER_ELINKNO)
  1913. #define DMA_TCD9_SADDR (IMXRT_DMA_TCD[9].SADDR)
  1914. #define DMA_TCD9_SOFF (IMXRT_DMA_TCD[9].SOFF)
  1915. #define DMA_TCD9_ATTR (IMXRT_DMA_TCD[9].ATTR)
  1916. #define DMA_TCD9_NBYTES (IMXRT_DMA_TCD[9].NBYTES)
  1917. #define DMA_TCD9_NBYTES_MLNO (IMXRT_DMA_TCD[9].NBYTES_MLNO)
  1918. #define DMA_TCD9_NBYTES_MLOFFNO (IMXRT_DMA_TCD[9].NBYTES_MLOFFNO)
  1919. #define DMA_TCD9_NBYTES_MLOFFYES (IMXRT_DMA_TCD[9].NBYTES_MLOFFYES)
  1920. #define DMA_TCD9_SLAST (IMXRT_DMA_TCD[9].SLAST)
  1921. #define DMA_TCD9_DADDR (IMXRT_DMA_TCD[9].DADDR)
  1922. #define DMA_TCD9_DOFF (IMXRT_DMA_TCD[9].DOFF)
  1923. #define DMA_TCD9_CITER (IMXRT_DMA_TCD[9].CITER)
  1924. #define DMA_TCD9_CITER_ELINKYES (IMXRT_DMA_TCD[9].CITER_ELINKYES)
  1925. #define DMA_TCD9_CITER_ELINKNO (IMXRT_DMA_TCD[9].CITER_ELINKNO)
  1926. #define DMA_TCD9_DLASTSGA (IMXRT_DMA_TCD[9].DLASTSGA)
  1927. #define DMA_TCD9_CSR (IMXRT_DMA_TCD[9].CSR)
  1928. #define DMA_TCD9_BITER (IMXRT_DMA_TCD[9].BITER)
  1929. #define DMA_TCD9_BITER_ELINKYES (IMXRT_DMA_TCD[9].BITER_ELINKYES)
  1930. #define DMA_TCD9_BITER_ELINKNO (IMXRT_DMA_TCD[9].BITER_ELINKNO)
  1931. #define DMA_TCD10_SADDR (IMXRT_DMA_TCD[10].SADDR)
  1932. #define DMA_TCD10_SOFF (IMXRT_DMA_TCD[10].SOFF)
  1933. #define DMA_TCD10_ATTR (IMXRT_DMA_TCD[10].ATTR)
  1934. #define DMA_TCD10_NBYTES (IMXRT_DMA_TCD[10].NBYTES)
  1935. #define DMA_TCD10_NBYTES_MLNO (IMXRT_DMA_TCD[10].NBYTES_MLNO)
  1936. #define DMA_TCD10_NBYTES_MLOFFNO (IMXRT_DMA_TCD[10].NBYTES_MLOFFNO)
  1937. #define DMA_TCD10_NBYTES_MLOFFYES (IMXRT_DMA_TCD[10].NBYTES_MLOFFYES)
  1938. #define DMA_TCD10_SLAST (IMXRT_DMA_TCD[10].SLAST)
  1939. #define DMA_TCD10_DADDR (IMXRT_DMA_TCD[10].DADDR)
  1940. #define DMA_TCD10_DOFF (IMXRT_DMA_TCD[10].DOFF)
  1941. #define DMA_TCD10_CITER (IMXRT_DMA_TCD[10].CITER)
  1942. #define DMA_TCD10_CITER_ELINKYES (IMXRT_DMA_TCD[10].CITER_ELINKYES)
  1943. #define DMA_TCD10_CITER_ELINKNO (IMXRT_DMA_TCD[10].CITER_ELINKNO)
  1944. #define DMA_TCD10_DLASTSGA (IMXRT_DMA_TCD[10].DLASTSGA)
  1945. #define DMA_TCD10_CSR (IMXRT_DMA_TCD[10].CSR)
  1946. #define DMA_TCD10_BITER (IMXRT_DMA_TCD[10].BITER)
  1947. #define DMA_TCD10_BITER_ELINKYES (IMXRT_DMA_TCD[10].BITER_ELINKYES)
  1948. #define DMA_TCD10_BITER_ELINKNO (IMXRT_DMA_TCD[10].BITER_ELINKNO)
  1949. #define DMA_TCD11_SADDR (IMXRT_DMA_TCD[11].SADDR)
  1950. #define DMA_TCD11_SOFF (IMXRT_DMA_TCD[11].SOFF)
  1951. #define DMA_TCD11_ATTR (IMXRT_DMA_TCD[11].ATTR)
  1952. #define DMA_TCD11_NBYTES (IMXRT_DMA_TCD[11].NBYTES)
  1953. #define DMA_TCD11_NBYTES_MLNO (IMXRT_DMA_TCD[11].NBYTES_MLNO)
  1954. #define DMA_TCD11_NBYTES_MLOFFNO (IMXRT_DMA_TCD[11].NBYTES_MLOFFNO)
  1955. #define DMA_TCD11_NBYTES_MLOFFYES (IMXRT_DMA_TCD[11].NBYTES_MLOFFYES)
  1956. #define DMA_TCD11_SLAST (IMXRT_DMA_TCD[11].SLAST)
  1957. #define DMA_TCD11_DADDR (IMXRT_DMA_TCD[11].DADDR)
  1958. #define DMA_TCD11_DOFF (IMXRT_DMA_TCD[11].DOFF)
  1959. #define DMA_TCD11_CITER (IMXRT_DMA_TCD[11].CITER)
  1960. #define DMA_TCD11_CITER_ELINKYES (IMXRT_DMA_TCD[11].CITER_ELINKYES)
  1961. #define DMA_TCD11_CITER_ELINKNO (IMXRT_DMA_TCD[11].CITER_ELINKNO)
  1962. #define DMA_TCD11_DLASTSGA (IMXRT_DMA_TCD[11].DLASTSGA)
  1963. #define DMA_TCD11_CSR (IMXRT_DMA_TCD[11].CSR)
  1964. #define DMA_TCD11_BITER (IMXRT_DMA_TCD[11].BITER)
  1965. #define DMA_TCD11_BITER_ELINKYES (IMXRT_DMA_TCD[11].BITER_ELINKYES)
  1966. #define DMA_TCD11_BITER_ELINKNO (IMXRT_DMA_TCD[11].BITER_ELINKNO)
  1967. #define DMA_TCD12_SADDR (IMXRT_DMA_TCD[12].SADDR)
  1968. #define DMA_TCD12_SOFF (IMXRT_DMA_TCD[12].SOFF)
  1969. #define DMA_TCD12_ATTR (IMXRT_DMA_TCD[12].ATTR)
  1970. #define DMA_TCD12_NBYTES (IMXRT_DMA_TCD[12].NBYTES)
  1971. #define DMA_TCD12_NBYTES_MLNO (IMXRT_DMA_TCD[12].NBYTES_MLNO)
  1972. #define DMA_TCD12_NBYTES_MLOFFNO (IMXRT_DMA_TCD[12].NBYTES_MLOFFNO)
  1973. #define DMA_TCD12_NBYTES_MLOFFYES (IMXRT_DMA_TCD[12].NBYTES_MLOFFYES)
  1974. #define DMA_TCD12_SLAST (IMXRT_DMA_TCD[12].SLAST)
  1975. #define DMA_TCD12_DADDR (IMXRT_DMA_TCD[12].DADDR)
  1976. #define DMA_TCD12_DOFF (IMXRT_DMA_TCD[12].DOFF)
  1977. #define DMA_TCD12_CITER (IMXRT_DMA_TCD[12].CITER)
  1978. #define DMA_TCD12_CITER_ELINKYES (IMXRT_DMA_TCD[12].CITER_ELINKYES)
  1979. #define DMA_TCD12_CITER_ELINKNO (IMXRT_DMA_TCD[12].CITER_ELINKNO)
  1980. #define DMA_TCD12_DLASTSGA (IMXRT_DMA_TCD[12].DLASTSGA)
  1981. #define DMA_TCD12_CSR (IMXRT_DMA_TCD[12].CSR)
  1982. #define DMA_TCD12_BITER (IMXRT_DMA_TCD[12].BITER)
  1983. #define DMA_TCD12_BITER_ELINKYES (IMXRT_DMA_TCD[12].BITER_ELINKYES)
  1984. #define DMA_TCD12_BITER_ELINKNO (IMXRT_DMA_TCD[12].BITER_ELINKNO)
  1985. #define DMA_TCD13_SADDR (IMXRT_DMA_TCD[13].SADDR)
  1986. #define DMA_TCD13_SOFF (IMXRT_DMA_TCD[13].SOFF)
  1987. #define DMA_TCD13_ATTR (IMXRT_DMA_TCD[13].ATTR)
  1988. #define DMA_TCD13_NBYTES (IMXRT_DMA_TCD[13].NBYTES)
  1989. #define DMA_TCD13_NBYTES_MLNO (IMXRT_DMA_TCD[13].NBYTES_MLNO)
  1990. #define DMA_TCD13_NBYTES_MLOFFNO (IMXRT_DMA_TCD[13].NBYTES_MLOFFNO)
  1991. #define DMA_TCD13_NBYTES_MLOFFYES (IMXRT_DMA_TCD[13].NBYTES_MLOFFYES)
  1992. #define DMA_TCD13_SLAST (IMXRT_DMA_TCD[13].SLAST)
  1993. #define DMA_TCD13_DADDR (IMXRT_DMA_TCD[13].DADDR)
  1994. #define DMA_TCD13_DOFF (IMXRT_DMA_TCD[13].DOFF)
  1995. #define DMA_TCD13_CITER (IMXRT_DMA_TCD[13].CITER)
  1996. #define DMA_TCD13_CITER_ELINKYES (IMXRT_DMA_TCD[13].CITER_ELINKYES)
  1997. #define DMA_TCD13_CITER_ELINKNO (IMXRT_DMA_TCD[13].CITER_ELINKNO)
  1998. #define DMA_TCD13_DLASTSGA (IMXRT_DMA_TCD[13].DLASTSGA)
  1999. #define DMA_TCD13_CSR (IMXRT_DMA_TCD[13].CSR)
  2000. #define DMA_TCD13_BITER (IMXRT_DMA_TCD[13].BITER)
  2001. #define DMA_TCD13_BITER_ELINKYES (IMXRT_DMA_TCD[13].BITER_ELINKYES)
  2002. #define DMA_TCD13_BITER_ELINKNO (IMXRT_DMA_TCD[13].BITER_ELINKNO)
  2003. #define DMA_TCD14_SADDR (IMXRT_DMA_TCD[14].SADDR)
  2004. #define DMA_TCD14_SOFF (IMXRT_DMA_TCD[14].SOFF)
  2005. #define DMA_TCD14_ATTR (IMXRT_DMA_TCD[14].ATTR)
  2006. #define DMA_TCD14_NBYTES (IMXRT_DMA_TCD[14].NBYTES)
  2007. #define DMA_TCD14_NBYTES_MLNO (IMXRT_DMA_TCD[14].NBYTES_MLNO)
  2008. #define DMA_TCD14_NBYTES_MLOFFNO (IMXRT_DMA_TCD[14].NBYTES_MLOFFNO)
  2009. #define DMA_TCD14_NBYTES_MLOFFYES (IMXRT_DMA_TCD[14].NBYTES_MLOFFYES)
  2010. #define DMA_TCD14_SLAST (IMXRT_DMA_TCD[14].SLAST)
  2011. #define DMA_TCD14_DADDR (IMXRT_DMA_TCD[14].DADDR)
  2012. #define DMA_TCD14_DOFF (IMXRT_DMA_TCD[14].DOFF)
  2013. #define DMA_TCD14_CITER (IMXRT_DMA_TCD[14].CITER)
  2014. #define DMA_TCD14_CITER_ELINKYES (IMXRT_DMA_TCD[14].CITER_ELINKYES)
  2015. #define DMA_TCD14_CITER_ELINKNO (IMXRT_DMA_TCD[14].CITER_ELINKNO)
  2016. #define DMA_TCD14_DLASTSGA (IMXRT_DMA_TCD[14].DLASTSGA)
  2017. #define DMA_TCD14_CSR (IMXRT_DMA_TCD[14].CSR)
  2018. #define DMA_TCD14_BITER (IMXRT_DMA_TCD[14].BITER)
  2019. #define DMA_TCD14_BITER_ELINKYES (IMXRT_DMA_TCD[14].BITER_ELINKYES)
  2020. #define DMA_TCD14_BITER_ELINKNO (IMXRT_DMA_TCD[14].BITER_ELINKNO)
  2021. #define DMA_TCD15_SADDR (IMXRT_DMA_TCD[15].SADDR)
  2022. #define DMA_TCD15_SOFF (IMXRT_DMA_TCD[15].SOFF)
  2023. #define DMA_TCD15_ATTR (IMXRT_DMA_TCD[15].ATTR)
  2024. #define DMA_TCD15_NBYTES (IMXRT_DMA_TCD[15].NBYTES)
  2025. #define DMA_TCD15_NBYTES_MLNO (IMXRT_DMA_TCD[15].NBYTES_MLNO)
  2026. #define DMA_TCD15_NBYTES_MLOFFNO (IMXRT_DMA_TCD[15].NBYTES_MLOFFNO)
  2027. #define DMA_TCD15_NBYTES_MLOFFYES (IMXRT_DMA_TCD[15].NBYTES_MLOFFYES)
  2028. #define DMA_TCD15_SLAST (IMXRT_DMA_TCD[15].SLAST)
  2029. #define DMA_TCD15_DADDR (IMXRT_DMA_TCD[15].DADDR)
  2030. #define DMA_TCD15_DOFF (IMXRT_DMA_TCD[15].DOFF)
  2031. #define DMA_TCD15_CITER (IMXRT_DMA_TCD[15].CITER)
  2032. #define DMA_TCD15_CITER_ELINKYES (IMXRT_DMA_TCD[15].CITER_ELINKYES)
  2033. #define DMA_TCD15_CITER_ELINKNO (IMXRT_DMA_TCD[15].CITER_ELINKNO)
  2034. #define DMA_TCD15_DLASTSGA (IMXRT_DMA_TCD[15].DLASTSGA)
  2035. #define DMA_TCD15_CSR (IMXRT_DMA_TCD[15].CSR)
  2036. #define DMA_TCD15_BITER (IMXRT_DMA_TCD[15].BITER)
  2037. #define DMA_TCD15_BITER_ELINKYES (IMXRT_DMA_TCD[15].BITER_ELINKYES)
  2038. #define DMA_TCD15_BITER_ELINKNO (IMXRT_DMA_TCD[15].BITER_ELINKNO)
  2039. #define DMA_TCD16_SADDR (IMXRT_DMA_TCD[16].SADDR)
  2040. #define DMA_TCD16_SOFF (IMXRT_DMA_TCD[16].SOFF)
  2041. #define DMA_TCD16_ATTR (IMXRT_DMA_TCD[16].ATTR)
  2042. #define DMA_TCD16_NBYTES (IMXRT_DMA_TCD[16].NBYTES)
  2043. #define DMA_TCD16_NBYTES_MLNO (IMXRT_DMA_TCD[16].NBYTES_MLNO)
  2044. #define DMA_TCD16_NBYTES_MLOFFNO (IMXRT_DMA_TCD[16].NBYTES_MLOFFNO)
  2045. #define DMA_TCD16_NBYTES_MLOFFYES (IMXRT_DMA_TCD[16].NBYTES_MLOFFYES)
  2046. #define DMA_TCD16_SLAST (IMXRT_DMA_TCD[16].SLAST)
  2047. #define DMA_TCD16_DADDR (IMXRT_DMA_TCD[16].DADDR)
  2048. #define DMA_TCD16_DOFF (IMXRT_DMA_TCD[16].DOFF)
  2049. #define DMA_TCD16_CITER (IMXRT_DMA_TCD[16].CITER)
  2050. #define DMA_TCD16_CITER_ELINKYES (IMXRT_DMA_TCD[16].CITER_ELINKYES)
  2051. #define DMA_TCD16_CITER_ELINKNO (IMXRT_DMA_TCD[16].CITER_ELINKNO)
  2052. #define DMA_TCD16_DLASTSGA (IMXRT_DMA_TCD[16].DLASTSGA)
  2053. #define DMA_TCD16_CSR (IMXRT_DMA_TCD[16].CSR)
  2054. #define DMA_TCD16_BITER (IMXRT_DMA_TCD[16].BITER)
  2055. #define DMA_TCD16_BITER_ELINKYES (IMXRT_DMA_TCD[16].BITER_ELINKYES)
  2056. #define DMA_TCD16_BITER_ELINKNO (IMXRT_DMA_TCD[16].BITER_ELINKNO)
  2057. #define DMA_TCD17_SADDR (IMXRT_DMA_TCD[17].SADDR)
  2058. #define DMA_TCD17_SOFF (IMXRT_DMA_TCD[17].SOFF)
  2059. #define DMA_TCD17_ATTR (IMXRT_DMA_TCD[17].ATTR)
  2060. #define DMA_TCD17_NBYTES (IMXRT_DMA_TCD[17].NBYTES)
  2061. #define DMA_TCD17_NBYTES_MLNO (IMXRT_DMA_TCD[17].NBYTES_MLNO)
  2062. #define DMA_TCD17_NBYTES_MLOFFNO (IMXRT_DMA_TCD[17].NBYTES_MLOFFNO)
  2063. #define DMA_TCD17_NBYTES_MLOFFYES (IMXRT_DMA_TCD[17].NBYTES_MLOFFYES)
  2064. #define DMA_TCD17_SLAST (IMXRT_DMA_TCD[17].SLAST)
  2065. #define DMA_TCD17_DADDR (IMXRT_DMA_TCD[17].DADDR)
  2066. #define DMA_TCD17_DOFF (IMXRT_DMA_TCD[17].DOFF)
  2067. #define DMA_TCD17_CITER (IMXRT_DMA_TCD[17].CITER)
  2068. #define DMA_TCD17_CITER_ELINKYES (IMXRT_DMA_TCD[17].CITER_ELINKYES)
  2069. #define DMA_TCD17_CITER_ELINKNO (IMXRT_DMA_TCD[17].CITER_ELINKNO)
  2070. #define DMA_TCD17_DLASTSGA (IMXRT_DMA_TCD[17].DLASTSGA)
  2071. #define DMA_TCD17_CSR (IMXRT_DMA_TCD[17].CSR)
  2072. #define DMA_TCD17_BITER (IMXRT_DMA_TCD[17].BITER)
  2073. #define DMA_TCD17_BITER_ELINKYES (IMXRT_DMA_TCD[17].BITER_ELINKYES)
  2074. #define DMA_TCD17_BITER_ELINKNO (IMXRT_DMA_TCD[17].BITER_ELINKNO)
  2075. #define DMA_TCD18_SADDR (IMXRT_DMA_TCD[18].SADDR)
  2076. #define DMA_TCD18_SOFF (IMXRT_DMA_TCD[18].SOFF)
  2077. #define DMA_TCD18_ATTR (IMXRT_DMA_TCD[18].ATTR)
  2078. #define DMA_TCD18_NBYTES (IMXRT_DMA_TCD[18].NBYTES)
  2079. #define DMA_TCD18_NBYTES_MLNO (IMXRT_DMA_TCD[18].NBYTES_MLNO)
  2080. #define DMA_TCD18_NBYTES_MLOFFNO (IMXRT_DMA_TCD[18].NBYTES_MLOFFNO)
  2081. #define DMA_TCD18_NBYTES_MLOFFYES (IMXRT_DMA_TCD[18].NBYTES_MLOFFYES)
  2082. #define DMA_TCD18_SLAST (IMXRT_DMA_TCD[18].SLAST)
  2083. #define DMA_TCD18_DADDR (IMXRT_DMA_TCD[18].DADDR)
  2084. #define DMA_TCD18_DOFF (IMXRT_DMA_TCD[18].DOFF)
  2085. #define DMA_TCD18_CITER (IMXRT_DMA_TCD[18].CITER)
  2086. #define DMA_TCD18_CITER_ELINKYES (IMXRT_DMA_TCD[18].CITER_ELINKYES)
  2087. #define DMA_TCD18_CITER_ELINKNO (IMXRT_DMA_TCD[18].CITER_ELINKNO)
  2088. #define DMA_TCD18_DLASTSGA (IMXRT_DMA_TCD[18].DLASTSGA)
  2089. #define DMA_TCD18_CSR (IMXRT_DMA_TCD[18].CSR)
  2090. #define DMA_TCD18_BITER (IMXRT_DMA_TCD[18].BITER)
  2091. #define DMA_TCD18_BITER_ELINKYES (IMXRT_DMA_TCD[18].BITER_ELINKYES)
  2092. #define DMA_TCD18_BITER_ELINKNO (IMXRT_DMA_TCD[18].BITER_ELINKNO)
  2093. #define DMA_TCD19_SADDR (IMXRT_DMA_TCD[19].SADDR)
  2094. #define DMA_TCD19_SOFF (IMXRT_DMA_TCD[19].SOFF)
  2095. #define DMA_TCD19_ATTR (IMXRT_DMA_TCD[19].ATTR)
  2096. #define DMA_TCD19_NBYTES (IMXRT_DMA_TCD[19].NBYTES)
  2097. #define DMA_TCD19_NBYTES_MLNO (IMXRT_DMA_TCD[19].NBYTES_MLNO)
  2098. #define DMA_TCD19_NBYTES_MLOFFNO (IMXRT_DMA_TCD[19].NBYTES_MLOFFNO)
  2099. #define DMA_TCD19_NBYTES_MLOFFYES (IMXRT_DMA_TCD[19].NBYTES_MLOFFYES)
  2100. #define DMA_TCD19_SLAST (IMXRT_DMA_TCD[19].SLAST)
  2101. #define DMA_TCD19_DADDR (IMXRT_DMA_TCD[19].DADDR)
  2102. #define DMA_TCD19_DOFF (IMXRT_DMA_TCD[19].DOFF)
  2103. #define DMA_TCD19_CITER (IMXRT_DMA_TCD[19].CITER)
  2104. #define DMA_TCD19_CITER_ELINKYES (IMXRT_DMA_TCD[19].CITER_ELINKYES)
  2105. #define DMA_TCD19_CITER_ELINKNO (IMXRT_DMA_TCD[19].CITER_ELINKNO)
  2106. #define DMA_TCD19_DLASTSGA (IMXRT_DMA_TCD[19].DLASTSGA)
  2107. #define DMA_TCD19_CSR (IMXRT_DMA_TCD[19].CSR)
  2108. #define DMA_TCD19_BITER (IMXRT_DMA_TCD[19].BITER)
  2109. #define DMA_TCD19_BITER_ELINKYES (IMXRT_DMA_TCD[19].BITER_ELINKYES)
  2110. #define DMA_TCD19_BITER_ELINKNO (IMXRT_DMA_TCD[19].BITER_ELINKNO)
  2111. #define DMA_TCD20_SADDR (IMXRT_DMA_TCD[20].SADDR)
  2112. #define DMA_TCD20_SOFF (IMXRT_DMA_TCD[20].SOFF)
  2113. #define DMA_TCD20_ATTR (IMXRT_DMA_TCD[20].ATTR)
  2114. #define DMA_TCD20_NBYTES (IMXRT_DMA_TCD[20].NBYTES)
  2115. #define DMA_TCD20_NBYTES_MLNO (IMXRT_DMA_TCD[20].NBYTES_MLNO)
  2116. #define DMA_TCD20_NBYTES_MLOFFNO (IMXRT_DMA_TCD[20].NBYTES_MLOFFNO)
  2117. #define DMA_TCD20_NBYTES_MLOFFYES (IMXRT_DMA_TCD[20].NBYTES_MLOFFYES)
  2118. #define DMA_TCD20_SLAST (IMXRT_DMA_TCD[20].SLAST)
  2119. #define DMA_TCD20_DADDR (IMXRT_DMA_TCD[20].DADDR)
  2120. #define DMA_TCD20_DOFF (IMXRT_DMA_TCD[20].DOFF)
  2121. #define DMA_TCD20_CITER (IMXRT_DMA_TCD[20].CITER)
  2122. #define DMA_TCD20_CITER_ELINKYES (IMXRT_DMA_TCD[20].CITER_ELINKYES)
  2123. #define DMA_TCD20_CITER_ELINKNO (IMXRT_DMA_TCD[20].CITER_ELINKNO)
  2124. #define DMA_TCD20_DLASTSGA (IMXRT_DMA_TCD[20].DLASTSGA)
  2125. #define DMA_TCD20_CSR (IMXRT_DMA_TCD[20].CSR)
  2126. #define DMA_TCD20_BITER (IMXRT_DMA_TCD[20].BITER)
  2127. #define DMA_TCD20_BITER_ELINKYES (IMXRT_DMA_TCD[20].BITER_ELINKYES)
  2128. #define DMA_TCD20_BITER_ELINKNO (IMXRT_DMA_TCD[20].BITER_ELINKNO)
  2129. #define DMA_TCD21_SADDR (IMXRT_DMA_TCD[21].SADDR)
  2130. #define DMA_TCD21_SOFF (IMXRT_DMA_TCD[21].SOFF)
  2131. #define DMA_TCD21_ATTR (IMXRT_DMA_TCD[21].ATTR)
  2132. #define DMA_TCD21_NBYTES (IMXRT_DMA_TCD[21].NBYTES)
  2133. #define DMA_TCD21_NBYTES_MLNO (IMXRT_DMA_TCD[21].NBYTES_MLNO)
  2134. #define DMA_TCD21_NBYTES_MLOFFNO (IMXRT_DMA_TCD[21].NBYTES_MLOFFNO)
  2135. #define DMA_TCD21_NBYTES_MLOFFYES (IMXRT_DMA_TCD[21].NBYTES_MLOFFYES)
  2136. #define DMA_TCD21_SLAST (IMXRT_DMA_TCD[21].SLAST)
  2137. #define DMA_TCD21_DADDR (IMXRT_DMA_TCD[21].DADDR)
  2138. #define DMA_TCD21_DOFF (IMXRT_DMA_TCD[21].DOFF)
  2139. #define DMA_TCD21_CITER (IMXRT_DMA_TCD[21].CITER)
  2140. #define DMA_TCD21_CITER_ELINKYES (IMXRT_DMA_TCD[21].CITER_ELINKYES)
  2141. #define DMA_TCD21_CITER_ELINKNO (IMXRT_DMA_TCD[21].CITER_ELINKNO)
  2142. #define DMA_TCD21_DLASTSGA (IMXRT_DMA_TCD[21].DLASTSGA)
  2143. #define DMA_TCD21_CSR (IMXRT_DMA_TCD[21].CSR)
  2144. #define DMA_TCD21_BITER (IMXRT_DMA_TCD[21].BITER)
  2145. #define DMA_TCD21_BITER_ELINKYES (IMXRT_DMA_TCD[21].BITER_ELINKYES)
  2146. #define DMA_TCD21_BITER_ELINKNO (IMXRT_DMA_TCD[21].BITER_ELINKNO)
  2147. #define DMA_TCD22_SADDR (IMXRT_DMA_TCD[22].SADDR)
  2148. #define DMA_TCD22_SOFF (IMXRT_DMA_TCD[22].SOFF)
  2149. #define DMA_TCD22_ATTR (IMXRT_DMA_TCD[22].ATTR)
  2150. #define DMA_TCD22_NBYTES (IMXRT_DMA_TCD[22].NBYTES)
  2151. #define DMA_TCD22_NBYTES_MLNO (IMXRT_DMA_TCD[22].NBYTES_MLNO)
  2152. #define DMA_TCD22_NBYTES_MLOFFNO (IMXRT_DMA_TCD[22].NBYTES_MLOFFNO)
  2153. #define DMA_TCD22_NBYTES_MLOFFYES (IMXRT_DMA_TCD[22].NBYTES_MLOFFYES)
  2154. #define DMA_TCD22_SLAST (IMXRT_DMA_TCD[22].SLAST)
  2155. #define DMA_TCD22_DADDR (IMXRT_DMA_TCD[22].DADDR)
  2156. #define DMA_TCD22_DOFF (IMXRT_DMA_TCD[22].DOFF)
  2157. #define DMA_TCD22_CITER (IMXRT_DMA_TCD[22].CITER)
  2158. #define DMA_TCD22_CITER_ELINKYES (IMXRT_DMA_TCD[22].CITER_ELINKYES)
  2159. #define DMA_TCD22_CITER_ELINKNO (IMXRT_DMA_TCD[22].CITER_ELINKNO)
  2160. #define DMA_TCD22_DLASTSGA (IMXRT_DMA_TCD[22].DLASTSGA)
  2161. #define DMA_TCD22_CSR (IMXRT_DMA_TCD[22].CSR)
  2162. #define DMA_TCD22_BITER (IMXRT_DMA_TCD[22].BITER)
  2163. #define DMA_TCD22_BITER_ELINKYES (IMXRT_DMA_TCD[22].BITER_ELINKYES)
  2164. #define DMA_TCD22_BITER_ELINKNO (IMXRT_DMA_TCD[22].BITER_ELINKNO)
  2165. #define DMA_TCD23_SADDR (IMXRT_DMA_TCD[23].SADDR)
  2166. #define DMA_TCD23_SOFF (IMXRT_DMA_TCD[23].SOFF)
  2167. #define DMA_TCD23_ATTR (IMXRT_DMA_TCD[23].ATTR)
  2168. #define DMA_TCD23_NBYTES (IMXRT_DMA_TCD[23].NBYTES)
  2169. #define DMA_TCD23_NBYTES_MLNO (IMXRT_DMA_TCD[23].NBYTES_MLNO)
  2170. #define DMA_TCD23_NBYTES_MLOFFNO (IMXRT_DMA_TCD[23].NBYTES_MLOFFNO)
  2171. #define DMA_TCD23_NBYTES_MLOFFYES (IMXRT_DMA_TCD[23].NBYTES_MLOFFYES)
  2172. #define DMA_TCD23_SLAST (IMXRT_DMA_TCD[23].SLAST)
  2173. #define DMA_TCD23_DADDR (IMXRT_DMA_TCD[23].DADDR)
  2174. #define DMA_TCD23_DOFF (IMXRT_DMA_TCD[23].DOFF)
  2175. #define DMA_TCD23_CITER (IMXRT_DMA_TCD[23].CITER)
  2176. #define DMA_TCD23_CITER_ELINKYES (IMXRT_DMA_TCD[23].CITER_ELINKYES)
  2177. #define DMA_TCD23_CITER_ELINKNO (IMXRT_DMA_TCD[23].CITER_ELINKNO)
  2178. #define DMA_TCD23_DLASTSGA (IMXRT_DMA_TCD[23].DLASTSGA)
  2179. #define DMA_TCD23_CSR (IMXRT_DMA_TCD[23].CSR)
  2180. #define DMA_TCD23_BITER (IMXRT_DMA_TCD[23].BITER)
  2181. #define DMA_TCD23_BITER_ELINKYES (IMXRT_DMA_TCD[23].BITER_ELINKYES)
  2182. #define DMA_TCD23_BITER_ELINKNO (IMXRT_DMA_TCD[23].BITER_ELINKNO)
  2183. #define DMA_TCD24_SADDR (IMXRT_DMA_TCD[24].SADDR)
  2184. #define DMA_TCD24_SOFF (IMXRT_DMA_TCD[24].SOFF)
  2185. #define DMA_TCD24_ATTR (IMXRT_DMA_TCD[24].ATTR)
  2186. #define DMA_TCD24_NBYTES (IMXRT_DMA_TCD[24].NBYTES)
  2187. #define DMA_TCD24_NBYTES_MLNO (IMXRT_DMA_TCD[24].NBYTES_MLNO)
  2188. #define DMA_TCD24_NBYTES_MLOFFNO (IMXRT_DMA_TCD[24].NBYTES_MLOFFNO)
  2189. #define DMA_TCD24_NBYTES_MLOFFYES (IMXRT_DMA_TCD[24].NBYTES_MLOFFYES)
  2190. #define DMA_TCD24_SLAST (IMXRT_DMA_TCD[24].SLAST)
  2191. #define DMA_TCD24_DADDR (IMXRT_DMA_TCD[24].DADDR)
  2192. #define DMA_TCD24_DOFF (IMXRT_DMA_TCD[24].DOFF)
  2193. #define DMA_TCD24_CITER (IMXRT_DMA_TCD[24].CITER)
  2194. #define DMA_TCD24_CITER_ELINKYES (IMXRT_DMA_TCD[24].CITER_ELINKYES)
  2195. #define DMA_TCD24_CITER_ELINKNO (IMXRT_DMA_TCD[24].CITER_ELINKNO)
  2196. #define DMA_TCD24_DLASTSGA (IMXRT_DMA_TCD[24].DLASTSGA)
  2197. #define DMA_TCD24_CSR (IMXRT_DMA_TCD[24].CSR)
  2198. #define DMA_TCD24_BITER (IMXRT_DMA_TCD[24].BITER)
  2199. #define DMA_TCD24_BITER_ELINKYES (IMXRT_DMA_TCD[24].BITER_ELINKYES)
  2200. #define DMA_TCD24_BITER_ELINKNO (IMXRT_DMA_TCD[24].BITER_ELINKNO)
  2201. #define DMA_TCD25_SADDR (IMXRT_DMA_TCD[25].SADDR)
  2202. #define DMA_TCD25_SOFF (IMXRT_DMA_TCD[25].SOFF)
  2203. #define DMA_TCD25_ATTR (IMXRT_DMA_TCD[25].ATTR)
  2204. #define DMA_TCD25_NBYTES (IMXRT_DMA_TCD[25].NBYTES)
  2205. #define DMA_TCD25_NBYTES_MLNO (IMXRT_DMA_TCD[25].NBYTES_MLNO)
  2206. #define DMA_TCD25_NBYTES_MLOFFNO (IMXRT_DMA_TCD[25].NBYTES_MLOFFNO)
  2207. #define DMA_TCD25_NBYTES_MLOFFYES (IMXRT_DMA_TCD[25].NBYTES_MLOFFYES)
  2208. #define DMA_TCD25_SLAST (IMXRT_DMA_TCD[25].SLAST)
  2209. #define DMA_TCD25_DADDR (IMXRT_DMA_TCD[25].DADDR)
  2210. #define DMA_TCD25_DOFF (IMXRT_DMA_TCD[25].DOFF)
  2211. #define DMA_TCD25_CITER (IMXRT_DMA_TCD[25].CITER)
  2212. #define DMA_TCD25_CITER_ELINKYES (IMXRT_DMA_TCD[25].CITER_ELINKYES)
  2213. #define DMA_TCD25_CITER_ELINKNO (IMXRT_DMA_TCD[25].CITER_ELINKNO)
  2214. #define DMA_TCD25_DLASTSGA (IMXRT_DMA_TCD[25].DLASTSGA)
  2215. #define DMA_TCD25_CSR (IMXRT_DMA_TCD[25].CSR)
  2216. #define DMA_TCD25_BITER (IMXRT_DMA_TCD[25].BITER)
  2217. #define DMA_TCD25_BITER_ELINKYES (IMXRT_DMA_TCD[25].BITER_ELINKYES)
  2218. #define DMA_TCD25_BITER_ELINKNO (IMXRT_DMA_TCD[25].BITER_ELINKNO)
  2219. #define DMA_TCD26_SADDR (IMXRT_DMA_TCD[26].SADDR)
  2220. #define DMA_TCD26_SOFF (IMXRT_DMA_TCD[26].SOFF)
  2221. #define DMA_TCD26_ATTR (IMXRT_DMA_TCD[26].ATTR)
  2222. #define DMA_TCD26_NBYTES (IMXRT_DMA_TCD[26].NBYTES)
  2223. #define DMA_TCD26_NBYTES_MLNO (IMXRT_DMA_TCD[26].NBYTES_MLNO)
  2224. #define DMA_TCD26_NBYTES_MLOFFNO (IMXRT_DMA_TCD[26].NBYTES_MLOFFNO)
  2225. #define DMA_TCD26_NBYTES_MLOFFYES (IMXRT_DMA_TCD[26].NBYTES_MLOFFYES)
  2226. #define DMA_TCD26_SLAST (IMXRT_DMA_TCD[26].SLAST)
  2227. #define DMA_TCD26_DADDR (IMXRT_DMA_TCD[26].DADDR)
  2228. #define DMA_TCD26_DOFF (IMXRT_DMA_TCD[26].DOFF)
  2229. #define DMA_TCD26_CITER (IMXRT_DMA_TCD[26].CITER)
  2230. #define DMA_TCD26_CITER_ELINKYES (IMXRT_DMA_TCD[26].CITER_ELINKYES)
  2231. #define DMA_TCD26_CITER_ELINKNO (IMXRT_DMA_TCD[26].CITER_ELINKNO)
  2232. #define DMA_TCD26_DLASTSGA (IMXRT_DMA_TCD[26].DLASTSGA)
  2233. #define DMA_TCD26_CSR (IMXRT_DMA_TCD[26].CSR)
  2234. #define DMA_TCD26_BITER (IMXRT_DMA_TCD[26].BITER)
  2235. #define DMA_TCD26_BITER_ELINKYES (IMXRT_DMA_TCD[26].BITER_ELINKYES)
  2236. #define DMA_TCD26_BITER_ELINKNO (IMXRT_DMA_TCD[26].BITER_ELINKNO)
  2237. #define DMA_TCD27_SADDR (IMXRT_DMA_TCD[27].SADDR)
  2238. #define DMA_TCD27_SOFF (IMXRT_DMA_TCD[27].SOFF)
  2239. #define DMA_TCD27_ATTR (IMXRT_DMA_TCD[27].ATTR)
  2240. #define DMA_TCD27_NBYTES (IMXRT_DMA_TCD[27].NBYTES)
  2241. #define DMA_TCD27_NBYTES_MLNO (IMXRT_DMA_TCD[27].NBYTES_MLNO)
  2242. #define DMA_TCD27_NBYTES_MLOFFNO (IMXRT_DMA_TCD[27].NBYTES_MLOFFNO)
  2243. #define DMA_TCD27_NBYTES_MLOFFYES (IMXRT_DMA_TCD[27].NBYTES_MLOFFYES)
  2244. #define DMA_TCD27_SLAST (IMXRT_DMA_TCD[27].SLAST)
  2245. #define DMA_TCD27_DADDR (IMXRT_DMA_TCD[27].DADDR)
  2246. #define DMA_TCD27_DOFF (IMXRT_DMA_TCD[27].DOFF)
  2247. #define DMA_TCD27_CITER (IMXRT_DMA_TCD[27].CITER)
  2248. #define DMA_TCD27_CITER_ELINKYES (IMXRT_DMA_TCD[27].CITER_ELINKYES)
  2249. #define DMA_TCD27_CITER_ELINKNO (IMXRT_DMA_TCD[27].CITER_ELINKNO)
  2250. #define DMA_TCD27_DLASTSGA (IMXRT_DMA_TCD[27].DLASTSGA)
  2251. #define DMA_TCD27_CSR (IMXRT_DMA_TCD[27].CSR)
  2252. #define DMA_TCD27_BITER (IMXRT_DMA_TCD[27].BITER)
  2253. #define DMA_TCD27_BITER_ELINKYES (IMXRT_DMA_TCD[27].BITER_ELINKYES)
  2254. #define DMA_TCD27_BITER_ELINKNO (IMXRT_DMA_TCD[27].BITER_ELINKNO)
  2255. #define DMA_TCD28_SADDR (IMXRT_DMA_TCD[28].SADDR)
  2256. #define DMA_TCD28_SOFF (IMXRT_DMA_TCD[28].SOFF)
  2257. #define DMA_TCD28_ATTR (IMXRT_DMA_TCD[28].ATTR)
  2258. #define DMA_TCD28_NBYTES (IMXRT_DMA_TCD[28].NBYTES)
  2259. #define DMA_TCD28_NBYTES_MLNO (IMXRT_DMA_TCD[28].NBYTES_MLNO)
  2260. #define DMA_TCD28_NBYTES_MLOFFNO (IMXRT_DMA_TCD[28].NBYTES_MLOFFNO)
  2261. #define DMA_TCD28_NBYTES_MLOFFYES (IMXRT_DMA_TCD[28].NBYTES_MLOFFYES)
  2262. #define DMA_TCD28_SLAST (IMXRT_DMA_TCD[28].SLAST)
  2263. #define DMA_TCD28_DADDR (IMXRT_DMA_TCD[28].DADDR)
  2264. #define DMA_TCD28_DOFF (IMXRT_DMA_TCD[28].DOFF)
  2265. #define DMA_TCD28_CITER (IMXRT_DMA_TCD[28].CITER)
  2266. #define DMA_TCD28_CITER_ELINKYES (IMXRT_DMA_TCD[28].CITER_ELINKYES)
  2267. #define DMA_TCD28_CITER_ELINKNO (IMXRT_DMA_TCD[28].CITER_ELINKNO)
  2268. #define DMA_TCD28_DLASTSGA (IMXRT_DMA_TCD[28].DLASTSGA)
  2269. #define DMA_TCD28_CSR (IMXRT_DMA_TCD[28].CSR)
  2270. #define DMA_TCD28_BITER (IMXRT_DMA_TCD[28].BITER)
  2271. #define DMA_TCD28_BITER_ELINKYES (IMXRT_DMA_TCD[28].BITER_ELINKYES)
  2272. #define DMA_TCD28_BITER_ELINKNO (IMXRT_DMA_TCD[28].BITER_ELINKNO)
  2273. #define DMA_TCD29_SADDR (IMXRT_DMA_TCD[29].SADDR)
  2274. #define DMA_TCD29_SOFF (IMXRT_DMA_TCD[29].SOFF)
  2275. #define DMA_TCD29_ATTR (IMXRT_DMA_TCD[29].ATTR)
  2276. #define DMA_TCD29_NBYTES (IMXRT_DMA_TCD[29].NBYTES)
  2277. #define DMA_TCD29_NBYTES_MLNO (IMXRT_DMA_TCD[29].NBYTES_MLNO)
  2278. #define DMA_TCD29_NBYTES_MLOFFNO (IMXRT_DMA_TCD[29].NBYTES_MLOFFNO)
  2279. #define DMA_TCD29_NBYTES_MLOFFYES (IMXRT_DMA_TCD[29].NBYTES_MLOFFYES)
  2280. #define DMA_TCD29_SLAST (IMXRT_DMA_TCD[29].SLAST)
  2281. #define DMA_TCD29_DADDR (IMXRT_DMA_TCD[29].DADDR)
  2282. #define DMA_TCD29_DOFF (IMXRT_DMA_TCD[29].DOFF)
  2283. #define DMA_TCD29_CITER (IMXRT_DMA_TCD[29].CITER)
  2284. #define DMA_TCD29_CITER_ELINKYES (IMXRT_DMA_TCD[29].CITER_ELINKYES)
  2285. #define DMA_TCD29_CITER_ELINKNO (IMXRT_DMA_TCD[29].CITER_ELINKNO)
  2286. #define DMA_TCD29_DLASTSGA (IMXRT_DMA_TCD[29].DLASTSGA)
  2287. #define DMA_TCD29_CSR (IMXRT_DMA_TCD[29].CSR)
  2288. #define DMA_TCD29_BITER (IMXRT_DMA_TCD[29].BITER)
  2289. #define DMA_TCD29_BITER_ELINKYES (IMXRT_DMA_TCD[29].BITER_ELINKYES)
  2290. #define DMA_TCD29_BITER_ELINKNO (IMXRT_DMA_TCD[29].BITER_ELINKNO)
  2291. #define DMA_TCD30_SADDR (IMXRT_DMA_TCD[30].SADDR)
  2292. #define DMA_TCD30_SOFF (IMXRT_DMA_TCD[30].SOFF)
  2293. #define DMA_TCD30_ATTR (IMXRT_DMA_TCD[30].ATTR)
  2294. #define DMA_TCD30_NBYTES (IMXRT_DMA_TCD[30].NBYTES)
  2295. #define DMA_TCD30_NBYTES_MLNO (IMXRT_DMA_TCD[30].NBYTES_MLNO)
  2296. #define DMA_TCD30_NBYTES_MLOFFNO (IMXRT_DMA_TCD[30].NBYTES_MLOFFNO)
  2297. #define DMA_TCD30_NBYTES_MLOFFYES (IMXRT_DMA_TCD[30].NBYTES_MLOFFYES)
  2298. #define DMA_TCD30_SLAST (IMXRT_DMA_TCD[30].SLAST)
  2299. #define DMA_TCD30_DADDR (IMXRT_DMA_TCD[30].DADDR)
  2300. #define DMA_TCD30_DOFF (IMXRT_DMA_TCD[30].DOFF)
  2301. #define DMA_TCD30_CITER (IMXRT_DMA_TCD[30].CITER)
  2302. #define DMA_TCD30_CITER_ELINKYES (IMXRT_DMA_TCD[30].CITER_ELINKYES)
  2303. #define DMA_TCD30_CITER_ELINKNO (IMXRT_DMA_TCD[30].CITER_ELINKNO)
  2304. #define DMA_TCD30_DLASTSGA (IMXRT_DMA_TCD[30].DLASTSGA)
  2305. #define DMA_TCD30_CSR (IMXRT_DMA_TCD[30].CSR)
  2306. #define DMA_TCD30_BITER (IMXRT_DMA_TCD[30].BITER)
  2307. #define DMA_TCD30_BITER_ELINKYES (IMXRT_DMA_TCD[30].BITER_ELINKYES)
  2308. #define DMA_TCD30_BITER_ELINKNO (IMXRT_DMA_TCD[30].BITER_ELINKNO)
  2309. #define DMA_TCD31_SADDR (IMXRT_DMA_TCD[31].SADDR)
  2310. #define DMA_TCD31_SOFF (IMXRT_DMA_TCD[31].SOFF)
  2311. #define DMA_TCD31_ATTR (IMXRT_DMA_TCD[31].ATTR)
  2312. #define DMA_TCD31_NBYTES (IMXRT_DMA_TCD[31].NBYTES)
  2313. #define DMA_TCD31_NBYTES_MLNO (IMXRT_DMA_TCD[31].NBYTES_MLNO)
  2314. #define DMA_TCD31_NBYTES_MLOFFNO (IMXRT_DMA_TCD[31].NBYTES_MLOFFNO)
  2315. #define DMA_TCD31_NBYTES_MLOFFYES (IMXRT_DMA_TCD[31].NBYTES_MLOFFYES)
  2316. #define DMA_TCD31_SLAST (IMXRT_DMA_TCD[31].SLAST)
  2317. #define DMA_TCD31_DADDR (IMXRT_DMA_TCD[31].DADDR)
  2318. #define DMA_TCD31_DOFF (IMXRT_DMA_TCD[31].DOFF)
  2319. #define DMA_TCD31_CITER (IMXRT_DMA_TCD[31].CITER)
  2320. #define DMA_TCD31_CITER_ELINKYES (IMXRT_DMA_TCD[31].CITER_ELINKYES)
  2321. #define DMA_TCD31_CITER_ELINKNO (IMXRT_DMA_TCD[31].CITER_ELINKNO)
  2322. #define DMA_TCD31_DLASTSGA (IMXRT_DMA_TCD[31].DLASTSGA)
  2323. #define DMA_TCD31_CSR (IMXRT_DMA_TCD[31].CSR)
  2324. #define DMA_TCD31_BITER (IMXRT_DMA_TCD[31].BITER)
  2325. #define DMA_TCD31_BITER_ELINKYES (IMXRT_DMA_TCD[31].BITER_ELINKYES)
  2326. #define DMA_TCD31_BITER_ELINKNO (IMXRT_DMA_TCD[31].BITER_ELINKNO)
  2327. // TODO: double check these defines from Teensy 3.x are still correct for IMXRT
  2328. #define DMA_TCD_ATTR_SMOD(n) (((n) & 0x1F) << 11)
  2329. #define DMA_TCD_ATTR_SSIZE(n) (((n) & 0x7) << 8)
  2330. #define DMA_TCD_ATTR_DMOD(n) (((n) & 0x1F) << 3)
  2331. #define DMA_TCD_ATTR_DSIZE(n) (((n) & 0x7) << 0)
  2332. #define DMA_TCD_ATTR_SIZE_8BIT 0
  2333. #define DMA_TCD_ATTR_SIZE_16BIT 1
  2334. #define DMA_TCD_ATTR_SIZE_32BIT 2
  2335. #define DMA_TCD_ATTR_SIZE_16BYTE 4
  2336. #define DMA_TCD_ATTR_SIZE_32BYTE 5 // caution: this might not be supported in newer chips?
  2337. #define DMA_TCD_CSR_BWC(n) (((n) & 0x3) << 14)
  2338. #define DMA_TCD_CSR_BWC_MASK 0xC000
  2339. #define DMA_TCD_CSR_MAJORLINKCH(n) (((n) & 0xF) << 8)
  2340. #define DMA_TCD_CSR_MAJORLINKCH_MASK 0x0F00
  2341. #define DMA_TCD_CSR_DONE 0x0080
  2342. #define DMA_TCD_CSR_ACTIVE 0x0040
  2343. #define DMA_TCD_CSR_MAJORELINK 0x0020
  2344. #define DMA_TCD_CSR_ESG 0x0010
  2345. #define DMA_TCD_CSR_DREQ 0x0008
  2346. #define DMA_TCD_CSR_INTHALF 0x0004
  2347. #define DMA_TCD_CSR_INTMAJOR 0x0002
  2348. #define DMA_TCD_CSR_START 0x0001
  2349. #define DMA_TCD_CITER_MASK ((uint16_t)0x7FFF) // Loop count mask
  2350. #define DMA_TCD_CITER_ELINK ((uint16_t)1<<15) // Enable channel linking on minor-loop complete
  2351. #define DMA_TCD_BITER_MASK ((uint16_t)0x7FFF) // Loop count mask
  2352. #define DMA_TCD_BITER_ELINK ((uint16_t)1<<15) // Enable channel linking on minor-loop complete
  2353. #define DMA_TCD_BITER_ELINKYES_ELINK 0x8000
  2354. #define DMA_TCD_BITER_ELINKYES_LINKCH(n) (((n) & 0xF) << 9)
  2355. #define DMA_TCD_BITER_ELINKYES_LINKCH_MASK 0x1E00
  2356. #define DMA_TCD_BITER_ELINKYES_BITER(n) (((n) & 0x1FF) << 0)
  2357. #define DMA_TCD_BITER_ELINKYES_BITER_MASK 0x01FF
  2358. #define DMA_TCD_CITER_ELINKYES_ELINK 0x8000
  2359. #define DMA_TCD_CITER_ELINKYES_LINKCH(n) (((n) & 0xF) << 9)
  2360. #define DMA_TCD_CITER_ELINKYES_LINKCH_MASK 0x1E00
  2361. #define DMA_TCD_CITER_ELINKYES_CITER(n) (((n) & 0x1FF) << 0)
  2362. #define DMA_TCD_CITER_ELINKYES_CITER_MASK 0x01FF
  2363. #define DMA_TCD_NBYTES_SMLOE ((uint32_t)1<<31) // Source Minor Loop Offset Enable
  2364. #define DMA_TCD_NBYTES_DMLOE ((uint32_t)1<<30) // Destination Minor Loop Offset Enable
  2365. #define DMA_TCD_NBYTES_MLOFFNO_NBYTES(n) ((uint32_t)((n) & 0x3FFFFFFF)) // NBytes transfer count when minor loop disabled
  2366. #define DMA_TCD_NBYTES_MLOFFYES_NBYTES(n) ((uint32_t)((n) & 0x3FF)) // NBytes transfer count when minor loop enabled
  2367. #define DMA_TCD_NBYTES_MLOFFYES_MLOFF(n) ((uint32_t)((n) & 0xFFFFF)<<10) // Minor loop offset
  2368. // 23.7.1: page 1023
  2369. #define IMXRT_ENC1 (*(IMXRT_REGISTER16_t *)0x403C8000)
  2370. #define ENC1_CTRL (IMXRT_ENC1.offset000)
  2371. #define ENC1_FILT (IMXRT_ENC1.offset002)
  2372. #define ENC1_WTR (IMXRT_ENC1.offset004)
  2373. #define ENC1_POSD (IMXRT_ENC1.offset006)
  2374. #define ENC1_POSDH (IMXRT_ENC1.offset008)
  2375. #define ENC1_REV (IMXRT_ENC1.offset00A)
  2376. #define ENC1_REVH (IMXRT_ENC1.offset00C)
  2377. #define ENC1_UPOS (IMXRT_ENC1.offset00E)
  2378. #define ENC1_LPOS (IMXRT_ENC1.offset010)
  2379. #define ENC1_UPOSH (IMXRT_ENC1.offset012)
  2380. #define ENC1_LPOSH (IMXRT_ENC1.offset014)
  2381. #define ENC1_UINIT (IMXRT_ENC1.offset016)
  2382. #define ENC1_LINIT (IMXRT_ENC1.offset018)
  2383. #define ENC1_IMR (IMXRT_ENC1.offset01A)
  2384. #define ENC1_TST (IMXRT_ENC1.offset01C)
  2385. #define ENC1_CTRL2 (IMXRT_ENC1.offset01E)
  2386. #define ENC1_UMOD (IMXRT_ENC1.offset020)
  2387. #define ENC1_LMOD (IMXRT_ENC1.offset022)
  2388. #define ENC1_UCOMP (IMXRT_ENC1.offset024)
  2389. #define ENC1_LCOMP (IMXRT_ENC1.offset026)
  2390. #define IMXRT_ENC2 (*(IMXRT_REGISTER16_t *)0x403CC000)
  2391. #define ENC2_CTRL (IMXRT_ENC2.offset000)
  2392. #define ENC2_FILT (IMXRT_ENC2.offset002)
  2393. #define ENC2_WTR (IMXRT_ENC2.offset004)
  2394. #define ENC2_POSD (IMXRT_ENC2.offset006)
  2395. #define ENC2_POSDH (IMXRT_ENC2.offset008)
  2396. #define ENC2_REV (IMXRT_ENC2.offset00A)
  2397. #define ENC2_REVH (IMXRT_ENC2.offset00C)
  2398. #define ENC2_UPOS (IMXRT_ENC2.offset00E)
  2399. #define ENC2_LPOS (IMXRT_ENC2.offset010)
  2400. #define ENC2_UPOSH (IMXRT_ENC2.offset012)
  2401. #define ENC2_LPOSH (IMXRT_ENC2.offset014)
  2402. #define ENC2_UINIT (IMXRT_ENC2.offset016)
  2403. #define ENC2_LINIT (IMXRT_ENC2.offset018)
  2404. #define ENC2_IMR (IMXRT_ENC2.offset01A)
  2405. #define ENC2_TST (IMXRT_ENC2.offset01C)
  2406. #define ENC2_CTRL2 (IMXRT_ENC2.offset01E)
  2407. #define ENC2_UMOD (IMXRT_ENC2.offset020)
  2408. #define ENC2_LMOD (IMXRT_ENC2.offset022)
  2409. #define ENC2_UCOMP (IMXRT_ENC2.offset024)
  2410. #define ENC2_LCOMP (IMXRT_ENC2.offset026)
  2411. #define IMXRT_ENC3 (*(IMXRT_REGISTER16_t *)0x403D0000)
  2412. #define ENC3_CTRL (IMXRT_ENC3.offset000)
  2413. #define ENC3_FILT (IMXRT_ENC3.offset002)
  2414. #define ENC3_WTR (IMXRT_ENC3.offset004)
  2415. #define ENC3_POSD (IMXRT_ENC3.offset006)
  2416. #define ENC3_POSDH (IMXRT_ENC3.offset008)
  2417. #define ENC3_REV (IMXRT_ENC3.offset00A)
  2418. #define ENC3_REVH (IMXRT_ENC3.offset00C)
  2419. #define ENC3_UPOS (IMXRT_ENC3.offset00E)
  2420. #define ENC3_LPOS (IMXRT_ENC3.offset010)
  2421. #define ENC3_UPOSH (IMXRT_ENC3.offset012)
  2422. #define ENC3_LPOSH (IMXRT_ENC3.offset014)
  2423. #define ENC3_UINIT (IMXRT_ENC3.offset016)
  2424. #define ENC3_LINIT (IMXRT_ENC3.offset018)
  2425. #define ENC3_IMR (IMXRT_ENC3.offset01A)
  2426. #define ENC3_TST (IMXRT_ENC3.offset01C)
  2427. #define ENC3_CTRL2 (IMXRT_ENC3.offset01E)
  2428. #define ENC3_UMOD (IMXRT_ENC3.offset020)
  2429. #define ENC3_LMOD (IMXRT_ENC3.offset022)
  2430. #define ENC3_UCOMP (IMXRT_ENC3.offset024)
  2431. #define ENC3_LCOMP (IMXRT_ENC3.offset026)
  2432. #define IMXRT_ENC4 (*(IMXRT_REGISTER16_t *)0x403D4000)
  2433. #define ENC4_CTRL (IMXRT_ENC4.offset000)
  2434. #define ENC4_FILT (IMXRT_ENC4.offset002)
  2435. #define ENC4_WTR (IMXRT_ENC4.offset004)
  2436. #define ENC4_POSD (IMXRT_ENC4.offset006)
  2437. #define ENC4_POSDH (IMXRT_ENC4.offset008)
  2438. #define ENC4_REV (IMXRT_ENC4.offset00A)
  2439. #define ENC4_REVH (IMXRT_ENC4.offset00C)
  2440. #define ENC4_UPOS (IMXRT_ENC4.offset00E)
  2441. #define ENC4_LPOS (IMXRT_ENC4.offset010)
  2442. #define ENC4_UPOSH (IMXRT_ENC4.offset012)
  2443. #define ENC4_LPOSH (IMXRT_ENC4.offset014)
  2444. #define ENC4_UINIT (IMXRT_ENC4.offset016)
  2445. #define ENC4_LINIT (IMXRT_ENC4.offset018)
  2446. #define ENC4_IMR (IMXRT_ENC4.offset01A)
  2447. #define ENC4_TST (IMXRT_ENC4.offset01C)
  2448. #define ENC4_CTRL2 (IMXRT_ENC4.offset01E)
  2449. #define ENC4_UMOD (IMXRT_ENC4.offset020)
  2450. #define ENC4_LMOD (IMXRT_ENC4.offset022)
  2451. #define ENC4_UCOMP (IMXRT_ENC4.offset024)
  2452. #define ENC4_LCOMP (IMXRT_ENC4.offset026)
  2453. // 24.5: page 1060
  2454. #define IMXRT_ENET (*(IMXRT_REGISTER32_t *)0x402D8000)
  2455. #define IMXRT_ENET_TIMER (*(IMXRT_REGISTER32_t *)0x402D8400)
  2456. #define ENET_EIR (IMXRT_ENET.offset004)
  2457. #define ENET_EIMR (IMXRT_ENET.offset008)
  2458. #define ENET_RDAR (IMXRT_ENET.offset010)
  2459. #define ENET_TDAR (IMXRT_ENET.offset014)
  2460. #define ENET_ECR (IMXRT_ENET.offset024)
  2461. #define ENET_MMFR (IMXRT_ENET.offset040)
  2462. #define ENET_MSCR (IMXRT_ENET.offset044)
  2463. #define ENET_MIBC (IMXRT_ENET.offset064)
  2464. #define ENET_RCR (IMXRT_ENET.offset084)
  2465. #define ENET_TCR (IMXRT_ENET.offset0C4)
  2466. #define ENET_PALR (IMXRT_ENET.offset0E4)
  2467. #define ENET_PAUR (IMXRT_ENET.offset0E8)
  2468. #define ENET_OPD (IMXRT_ENET.offset0EC)
  2469. #define ENET_TXIC (IMXRT_ENET.offset0F0)
  2470. #define ENET_RXIC (IMXRT_ENET.offset100)
  2471. #define ENET_IAUR (IMXRT_ENET.offset118)
  2472. #define ENET_IALR (IMXRT_ENET.offset11C)
  2473. #define ENET_GAUR (IMXRT_ENET.offset120)
  2474. #define ENET_GALR (IMXRT_ENET.offset124)
  2475. #define ENET_TFWR (IMXRT_ENET.offset144)
  2476. #define ENET_RDSR (IMXRT_ENET.offset180)
  2477. #define ENET_TDSR (IMXRT_ENET.offset184)
  2478. #define ENET_MRBR (IMXRT_ENET.offset188)
  2479. #define ENET_RSFL (IMXRT_ENET.offset190)
  2480. #define ENET_RSEM (IMXRT_ENET.offset194)
  2481. #define ENET_RAEM (IMXRT_ENET.offset198)
  2482. #define ENET_RAFL (IMXRT_ENET.offset19C)
  2483. #define ENET_TSEM (IMXRT_ENET.offset1A0)
  2484. #define ENET_TAEM (IMXRT_ENET.offset1A4)
  2485. #define ENET_TAFL (IMXRT_ENET.offset1A8)
  2486. #define ENET_TIPG (IMXRT_ENET.offset1AC)
  2487. #define ENET_FTRL (IMXRT_ENET.offset1B0)
  2488. #define ENET_TACC (IMXRT_ENET.offset1C0)
  2489. #define ENET_RACC (IMXRT_ENET.offset1C4)
  2490. #define ENET_RMON_T_DROP (IMXRT_ENET.offset200)
  2491. #define ENET_RMON_T_PACKETS (IMXRT_ENET.offset204)
  2492. #define ENET_RMON_T_BC_PKT (IMXRT_ENET.offset208)
  2493. #define ENET_RMON_T_MC_PKT (IMXRT_ENET.offset20C)
  2494. #define ENET_RMON_T_CRC_ALIGN (IMXRT_ENET.offset210)
  2495. #define ENET_RMON_T_UNDERSIZE (IMXRT_ENET.offset214)
  2496. #define ENET_RMON_T_OVERSIZE (IMXRT_ENET.offset218)
  2497. #define ENET_RMON_T_FRAG (IMXRT_ENET.offset21C)
  2498. #define ENET_RMON_T_JAB (IMXRT_ENET.offset220)
  2499. #define ENET_RMON_T_COL (IMXRT_ENET.offset224)
  2500. #define ENET_RMON_T_P64 (IMXRT_ENET.offset228)
  2501. #define ENET_RMON_T_P65TO127 (IMXRT_ENET.offset22C)
  2502. #define ENET_RMON_T_P128TO255 (IMXRT_ENET.offset230)
  2503. #define ENET_RMON_T_P256TO511 (IMXRT_ENET.offset234)
  2504. #define ENET_RMON_T_P512TO1023 (IMXRT_ENET.offset238)
  2505. #define ENET_RMON_T_P1024TO2047 (IMXRT_ENET.offset23C)
  2506. #define ENET_RMON_T_P_GTE2048 (IMXRT_ENET.offset240)
  2507. #define ENET_RMON_T_OCTETS (IMXRT_ENET.offset244)
  2508. #define ENET_IEEE_T_DROP (IMXRT_ENET.offset248)
  2509. #define ENET_IEEE_T_FRAME_OK (IMXRT_ENET.offset24C)
  2510. #define ENET_IEEE_T_1COL (IMXRT_ENET.offset250)
  2511. #define ENET_IEEE_T_MCOL (IMXRT_ENET.offset254)
  2512. #define ENET_IEEE_T_DEF (IMXRT_ENET.offset258)
  2513. #define ENET_IEEE_T_LCOL (IMXRT_ENET.offset25C)
  2514. #define ENET_IEEE_T_EXCOL (IMXRT_ENET.offset260)
  2515. #define ENET_IEEE_T_MACERR (IMXRT_ENET.offset264)
  2516. #define ENET_IEEE_T_CSERR (IMXRT_ENET.offset268)
  2517. #define ENET_IEEE_T_SQE (IMXRT_ENET.offset26C)
  2518. #define ENET_IEEE_T_FDXFC (IMXRT_ENET.offset270)
  2519. #define ENET_IEEE_T_OCTETS_OK (IMXRT_ENET.offset274)
  2520. #define ENET_RMON_R_PACKETS (IMXRT_ENET.offset284)
  2521. #define ENET_RMON_R_BC_PKT (IMXRT_ENET.offset288)
  2522. #define ENET_RMON_R_MC_PKT (IMXRT_ENET.offset28C)
  2523. #define ENET_RMON_R_CRC_ALIGN (IMXRT_ENET.offset290)
  2524. #define ENET_RMON_R_UNDERSIZE (IMXRT_ENET.offset294)
  2525. #define ENET_RMON_R_OVERSIZE (IMXRT_ENET.offset298)
  2526. #define ENET_RMON_R_FRAG (IMXRT_ENET.offset29C)
  2527. #define ENET_RMON_R_JAB (IMXRT_ENET.offset2A0)
  2528. #define ENET_RMON_R_RESVD_0 (IMXRT_ENET.offset2A4)
  2529. #define ENET_RMON_R_P64 (IMXRT_ENET.offset2A8)
  2530. #define ENET_RMON_R_P65TO127 (IMXRT_ENET.offset2AC)
  2531. #define ENET_RMON_R_P128TO255 (IMXRT_ENET.offset2B0)
  2532. #define ENET_RMON_R_P256TO511 (IMXRT_ENET.offset2B4)
  2533. #define ENET_RMON_R_P512TO1023 (IMXRT_ENET.offset2B8)
  2534. #define ENET_RMON_R_P1024TO2047 (IMXRT_ENET.offset2BC)
  2535. #define ENET_RMON_R_P_GTE2048 (IMXRT_ENET.offset2C0)
  2536. #define ENET_RMON_R_OCTETS (IMXRT_ENET.offset2C4)
  2537. #define ENET_IEEE_R_DROP (IMXRT_ENET.offset2C8)
  2538. #define ENET_IEEE_R_FRAME_OK (IMXRT_ENET.offset2CC)
  2539. #define ENET_IEEE_R_CRC (IMXRT_ENET.offset2D0)
  2540. #define ENET_IEEE_R_ALIGN (IMXRT_ENET.offset2D4)
  2541. #define ENET_IEEE_R_MACERR (IMXRT_ENET.offset2D8)
  2542. #define ENET_IEEE_R_FDXFC (IMXRT_ENET.offset2DC)
  2543. #define ENET_IEEE_R_OCTETS_OK (IMXRT_ENET.offset2E0)
  2544. #define ENET_ATCR (IMXRT_ENET_TIMER.offset000)
  2545. #define ENET_ATVR (IMXRT_ENET_TIMER.offset004)
  2546. #define ENET_ATOFF (IMXRT_ENET_TIMER.offset008)
  2547. #define ENET_ATPER (IMXRT_ENET_TIMER.offset00C)
  2548. #define ENET_ATCOR (IMXRT_ENET_TIMER.offset010)
  2549. #define ENET_ATINC (IMXRT_ENET_TIMER.offset014)
  2550. #define ENET_ATSTMP (IMXRT_ENET_TIMER.offset018)
  2551. #define ENET_TGSR (IMXRT_ENET_TIMER.offset204)
  2552. #define ENET_TCSR0 (IMXRT_ENET_TIMER.offset208)
  2553. #define ENET_TCCR0 (IMXRT_ENET_TIMER.offset20C)
  2554. #define ENET_TCSR1 (IMXRT_ENET_TIMER.offset210)
  2555. #define ENET_TCCR1 (IMXRT_ENET_TIMER.offset214)
  2556. #define ENET_TCSR2 (IMXRT_ENET_TIMER.offset218)
  2557. #define ENET_TCCR2 (IMXRT_ENET_TIMER.offset21C)
  2558. #define ENET_TCSR3 (IMXRT_ENET_TIMER.offset220)
  2559. #define ENET_TCCR3 (IMXRT_ENET_TIMER.offset224)
  2560. #define IMXRT_ENET2 (*(IMXRT_REGISTER32_t *)0x402D4000)
  2561. #define IMXRT_ENET2_TIMER (*(IMXRT_REGISTER32_t *)0x402D4400)
  2562. #define ENET2_EIR (IMXRT_ENET2.offset004)
  2563. #define ENET2_EIMR (IMXRT_ENET2.offset008)
  2564. #define ENET2_RDAR (IMXRT_ENET2.offset010)
  2565. #define ENET2_TDAR (IMXRT_ENET2.offset014)
  2566. #define ENET2_ECR (IMXRT_ENET2.offset024)
  2567. #define ENET2_MMFR (IMXRT_ENET2.offset040)
  2568. #define ENET2_MSCR (IMXRT_ENET2.offset044)
  2569. #define ENET2_MIBC (IMXRT_ENET2.offset064)
  2570. #define ENET2_RCR (IMXRT_ENET2.offset084)
  2571. #define ENET2_TCR (IMXRT_ENET2.offset0C4)
  2572. #define ENET2_PALR (IMXRT_ENET2.offset0E4)
  2573. #define ENET2_PAUR (IMXRT_ENET2.offset0E8)
  2574. #define ENET2_OPD (IMXRT_ENET2.offset0EC)
  2575. #define ENET2_TXIC (IMXRT_ENET2.offset0F0)
  2576. #define ENET2_RXIC (IMXRT_ENET2.offset100)
  2577. #define ENET2_IAUR (IMXRT_ENET2.offset118)
  2578. #define ENET2_IALR (IMXRT_ENET2.offset11C)
  2579. #define ENET2_GAUR (IMXRT_ENET2.offset120)
  2580. #define ENET2_GALR (IMXRT_ENET2.offset124)
  2581. #define ENET2_TFWR (IMXRT_ENET2.offset144)
  2582. #define ENET2_RDSR (IMXRT_ENET2.offset180)
  2583. #define ENET2_TDSR (IMXRT_ENET2.offset184)
  2584. #define ENET2_MRBR (IMXRT_ENET2.offset188)
  2585. #define ENET2_RSFL (IMXRT_ENET2.offset190)
  2586. #define ENET2_RSEM (IMXRT_ENET2.offset194)
  2587. #define ENET2_RAEM (IMXRT_ENET2.offset198)
  2588. #define ENET2_RAFL (IMXRT_ENET2.offset19C)
  2589. #define ENET2_TSEM (IMXRT_ENET2.offset1A0)
  2590. #define ENET2_TAEM (IMXRT_ENET2.offset1A4)
  2591. #define ENET2_TAFL (IMXRT_ENET2.offset1A8)
  2592. #define ENET2_TIPG (IMXRT_ENET2.offset1AC)
  2593. #define ENET2_FTRL (IMXRT_ENET2.offset1B0)
  2594. #define ENET2_TACC (IMXRT_ENET2.offset1C0)
  2595. #define ENET2_RACC (IMXRT_ENET2.offset1C4)
  2596. #define ENET2_RMON_T_DROP (IMXRT_ENET2.offset200)
  2597. #define ENET2_RMON_T_PACKETS (IMXRT_ENET2.offset204)
  2598. #define ENET2_RMON_T_BC_PKT (IMXRT_ENET2.offset208)
  2599. #define ENET2_RMON_T_MC_PKT (IMXRT_ENET2.offset20C)
  2600. #define ENET2_RMON_T_CRC_ALIGN (IMXRT_ENET2.offset210)
  2601. #define ENET2_RMON_T_UNDERSIZE (IMXRT_ENET2.offset214)
  2602. #define ENET2_RMON_T_OVERSIZE (IMXRT_ENET2.offset218)
  2603. #define ENET2_RMON_T_FRAG (IMXRT_ENET2.offset21C)
  2604. #define ENET2_RMON_T_JAB (IMXRT_ENET2.offset220)
  2605. #define ENET2_RMON_T_COL (IMXRT_ENET2.offset224)
  2606. #define ENET2_RMON_T_P64 (IMXRT_ENET2.offset228)
  2607. #define ENET2_RMON_T_P65TO127 (IMXRT_ENET2.offset22C)
  2608. #define ENET2_RMON_T_P128TO255 (IMXRT_ENET2.offset230)
  2609. #define ENET2_RMON_T_P256TO511 (IMXRT_ENET2.offset234)
  2610. #define ENET2_RMON_T_P512TO1023 (IMXRT_ENET2.offset238)
  2611. #define ENET2_RMON_T_P1024TO2047 (IMXRT_ENET2.offset23C)
  2612. #define ENET2_RMON_T_P_GTE2048 (IMXRT_ENET2.offset240)
  2613. #define ENET2_RMON_T_OCTETS (IMXRT_ENET2.offset244)
  2614. #define ENET2_IEEE_T_DROP (IMXRT_ENET2.offset248)
  2615. #define ENET2_IEEE_T_FRAME_OK (IMXRT_ENET2.offset24C)
  2616. #define ENET2_IEEE_T_1COL (IMXRT_ENET2.offset250)
  2617. #define ENET2_IEEE_T_MCOL (IMXRT_ENET2.offset254)
  2618. #define ENET2_IEEE_T_DEF (IMXRT_ENET2.offset258)
  2619. #define ENET2_IEEE_T_LCOL (IMXRT_ENET2.offset25C)
  2620. #define ENET2_IEEE_T_EXCOL (IMXRT_ENET2.offset260)
  2621. #define ENET2_IEEE_T_MACERR (IMXRT_ENET2.offset264)
  2622. #define ENET2_IEEE_T_CSERR (IMXRT_ENET2.offset268)
  2623. #define ENET2_IEEE_T_SQE (IMXRT_ENET2.offset26C)
  2624. #define ENET2_IEEE_T_FDXFC (IMXRT_ENET2.offset270)
  2625. #define ENET2_IEEE_T_OCTETS_OK (IMXRT_ENET2.offset274)
  2626. #define ENET2_RMON_R_PACKETS (IMXRT_ENET2.offset284)
  2627. #define ENET2_RMON_R_BC_PKT (IMXRT_ENET2.offset288)
  2628. #define ENET2_RMON_R_MC_PKT (IMXRT_ENET2.offset28C)
  2629. #define ENET2_RMON_R_CRC_ALIGN (IMXRT_ENET2.offset290)
  2630. #define ENET2_RMON_R_UNDERSIZE (IMXRT_ENET2.offset294)
  2631. #define ENET2_RMON_R_OVERSIZE (IMXRT_ENET2.offset298)
  2632. #define ENET2_RMON_R_FRAG (IMXRT_ENET2.offset29C)
  2633. #define ENET2_RMON_R_JAB (IMXRT_ENET2.offset2A0)
  2634. #define ENET2_RMON_R_RESVD_0 (IMXRT_ENET2.offset2A4)
  2635. #define ENET2_RMON_R_P64 (IMXRT_ENET2.offset2A8)
  2636. #define ENET2_RMON_R_P65TO127 (IMXRT_ENET2.offset2AC)
  2637. #define ENET2_RMON_R_P128TO255 (IMXRT_ENET2.offset2B0)
  2638. #define ENET2_RMON_R_P256TO511 (IMXRT_ENET2.offset2B4)
  2639. #define ENET2_RMON_R_P512TO1023 (IMXRT_ENET2.offset2B8)
  2640. #define ENET2_RMON_R_P1024TO2047 (IMXRT_ENET2.offset2BC)
  2641. #define ENET2_RMON_R_P_GTE2048 (IMXRT_ENET2.offset2C0)
  2642. #define ENET2_RMON_R_OCTETS (IMXRT_ENET2.offset2C4)
  2643. #define ENET2_IEEE_R_DROP (IMXRT_ENET2.offset2C8)
  2644. #define ENET2_IEEE_R_FRAME_OK (IMXRT_ENET2.offset2CC)
  2645. #define ENET2_IEEE_R_CRC (IMXRT_ENET2.offset2D0)
  2646. #define ENET2_IEEE_R_ALIGN (IMXRT_ENET2.offset2D4)
  2647. #define ENET2_IEEE_R_MACERR (IMXRT_ENET2.offset2D8)
  2648. #define ENET2_IEEE_R_FDXFC (IMXRT_ENET2.offset2DC)
  2649. #define ENET2_IEEE_R_OCTETS_OK (IMXRT_ENET2.offset2E0)
  2650. #define ENET2_ATCR (IMXRT_ENET2_TIMER.offset000)
  2651. #define ENET2_ATVR (IMXRT_ENET2_TIMER.offset004)
  2652. #define ENET2_ATOFF (IMXRT_ENET2_TIMER.offset008)
  2653. #define ENET2_ATPER (IMXRT_ENET2_TIMER.offset00C)
  2654. #define ENET2_ATCOR (IMXRT_ENET2_TIMER.offset010)
  2655. #define ENET2_ATINC (IMXRT_ENET2_TIMER.offset014)
  2656. #define ENET2_ATSTMP (IMXRT_ENET2_TIMER.offset018)
  2657. #define ENET2_TGSR (IMXRT_ENET2_TIMER.offset204)
  2658. #define ENET2_TCSR0 (IMXRT_ENET2_TIMER.offset208)
  2659. #define ENET2_TCCR0 (IMXRT_ENET2_TIMER.offset20C)
  2660. #define ENET2_TCSR1 (IMXRT_ENET2_TIMER.offset210)
  2661. #define ENET2_TCCR1 (IMXRT_ENET2_TIMER.offset214)
  2662. #define ENET2_TCSR2 (IMXRT_ENET2_TIMER.offset218)
  2663. #define ENET2_TCCR2 (IMXRT_ENET2_TIMER.offset21C)
  2664. #define ENET2_TCSR3 (IMXRT_ENET2_TIMER.offset220)
  2665. #define ENET2_TCCR3 (IMXRT_ENET2_TIMER.offset224)
  2666. // 25.3.1.1: page 1199
  2667. #define IMXRT_EWM (*(IMXRT_REGISTER8_t *)0x402D8000)
  2668. #define EWM_CTRL (IMXRT_EWM.offset00)
  2669. #define EWM_SERV (IMXRT_EWM.offset01)
  2670. #define EWM_CMPL (IMXRT_EWM.offset02)
  2671. #define EWM_CMPH (IMXRT_EWM.offset03)
  2672. #define EWM_CLKCTRL (IMXRT_EWM.offset04)
  2673. #define EWM_CLKPRESCALER (IMXRT_EWM.offset05)
  2674. // 26.8: page 1249
  2675. #define IMXRT_FLEXCAN1 (*(IMXRT_REGISTER32_t *)0x401D0000)
  2676. #define IMXRT_FLEXCAN1_MASK (*(IMXRT_REGISTER32_t *)0x401D0800)
  2677. #define FLEXCAN1_MCR (IMXRT_FLEXCAN1.offset000)
  2678. #define FLEXCAN1_CTRL1 (IMXRT_FLEXCAN1.offset004)
  2679. #define FLEXCAN1_TIMER (IMXRT_FLEXCAN1.offset008)
  2680. #define FLEXCAN1_RXMGMASK (IMXRT_FLEXCAN1.offset010)
  2681. #define FLEXCAN1_RX14MASK (IMXRT_FLEXCAN1.offset014)
  2682. #define FLEXCAN1_RX15MASK (IMXRT_FLEXCAN1.offset018)
  2683. #define FLEXCAN1_ECR (IMXRT_FLEXCAN1.offset01C)
  2684. #define FLEXCAN1_ESR1 (IMXRT_FLEXCAN1.offset020)
  2685. #define FLEXCAN1_IMASK2 (IMXRT_FLEXCAN1.offset024)
  2686. #define FLEXCAN1_IMASK1 (IMXRT_FLEXCAN1.offset028)
  2687. #define FLEXCAN1_IFLAG2 (IMXRT_FLEXCAN1.offset02C)
  2688. #define FLEXCAN1_IFLAG1 (IMXRT_FLEXCAN1.offset030)
  2689. #define FLEXCAN1_CTRL2 (IMXRT_FLEXCAN1.offset034)
  2690. #define FLEXCAN1_ESR2 (IMXRT_FLEXCAN1.offset038)
  2691. #define FLEXCAN1_CRCR (IMXRT_FLEXCAN1.offset044)
  2692. #define FLEXCAN1_RXFGMASK (IMXRT_FLEXCAN1.offset048)
  2693. #define FLEXCAN1_RXFIR (IMXRT_FLEXCAN1.offset04C)
  2694. #define FLEXCAN1_RXIMR0 (IMXRT_FLEXCAN1_MASK.offset080)
  2695. #define FLEXCAN1_RXIMR1 (IMXRT_FLEXCAN1_MASK.offset084)
  2696. #define FLEXCAN1_RXIMR2 (IMXRT_FLEXCAN1_MASK.offset088)
  2697. #define FLEXCAN1_RXIMR3 (IMXRT_FLEXCAN1_MASK.offset08C)
  2698. #define FLEXCAN1_RXIMR4 (IMXRT_FLEXCAN1_MASK.offset090)
  2699. #define FLEXCAN1_RXIMR5 (IMXRT_FLEXCAN1_MASK.offset094)
  2700. #define FLEXCAN1_RXIMR6 (IMXRT_FLEXCAN1_MASK.offset098)
  2701. #define FLEXCAN1_RXIMR7 (IMXRT_FLEXCAN1_MASK.offset09C)
  2702. #define FLEXCAN1_RXIMR8 (IMXRT_FLEXCAN1_MASK.offset0A0)
  2703. #define FLEXCAN1_RXIMR9 (IMXRT_FLEXCAN1_MASK.offset0A4)
  2704. #define FLEXCAN1_RXIMR10 (IMXRT_FLEXCAN1_MASK.offset0A8)
  2705. #define FLEXCAN1_RXIMR11 (IMXRT_FLEXCAN1_MASK.offset0AC)
  2706. #define FLEXCAN1_RXIMR12 (IMXRT_FLEXCAN1_MASK.offset0B0)
  2707. #define FLEXCAN1_RXIMR13 (IMXRT_FLEXCAN1_MASK.offset0B4)
  2708. #define FLEXCAN1_RXIMR14 (IMXRT_FLEXCAN1_MASK.offset0B8)
  2709. #define FLEXCAN1_RXIMR15 (IMXRT_FLEXCAN1_MASK.offset0BC)
  2710. #define FLEXCAN1_RXIMR16 (IMXRT_FLEXCAN1_MASK.offset0C0)
  2711. #define FLEXCAN1_RXIMR17 (IMXRT_FLEXCAN1_MASK.offset0C4)
  2712. #define FLEXCAN1_RXIMR18 (IMXRT_FLEXCAN1_MASK.offset0C8)
  2713. #define FLEXCAN1_RXIMR19 (IMXRT_FLEXCAN1_MASK.offset0CC)
  2714. #define FLEXCAN1_RXIMR20 (IMXRT_FLEXCAN1_MASK.offset0D0)
  2715. #define FLEXCAN1_RXIMR21 (IMXRT_FLEXCAN1_MASK.offset0D4)
  2716. #define FLEXCAN1_RXIMR22 (IMXRT_FLEXCAN1_MASK.offset0D8)
  2717. #define FLEXCAN1_RXIMR23 (IMXRT_FLEXCAN1_MASK.offset0DC)
  2718. #define FLEXCAN1_RXIMR24 (IMXRT_FLEXCAN1_MASK.offset0E0)
  2719. #define FLEXCAN1_RXIMR25 (IMXRT_FLEXCAN1_MASK.offset0E4)
  2720. #define FLEXCAN1_RXIMR26 (IMXRT_FLEXCAN1_MASK.offset0E8)
  2721. #define FLEXCAN1_RXIMR27 (IMXRT_FLEXCAN1_MASK.offset0EC)
  2722. #define FLEXCAN1_RXIMR28 (IMXRT_FLEXCAN1_MASK.offset0F0)
  2723. #define FLEXCAN1_RXIMR29 (IMXRT_FLEXCAN1_MASK.offset0F4)
  2724. #define FLEXCAN1_RXIMR30 (IMXRT_FLEXCAN1_MASK.offset0F8)
  2725. #define FLEXCAN1_RXIMR31 (IMXRT_FLEXCAN1_MASK.offset0FC)
  2726. #define FLEXCAN1_RXIMR32 (IMXRT_FLEXCAN1_MASK.offset100)
  2727. #define FLEXCAN1_RXIMR33 (IMXRT_FLEXCAN1_MASK.offset104)
  2728. #define FLEXCAN1_RXIMR34 (IMXRT_FLEXCAN1_MASK.offset108)
  2729. #define FLEXCAN1_RXIMR35 (IMXRT_FLEXCAN1_MASK.offset10C)
  2730. #define FLEXCAN1_RXIMR36 (IMXRT_FLEXCAN1_MASK.offset110)
  2731. #define FLEXCAN1_RXIMR37 (IMXRT_FLEXCAN1_MASK.offset114)
  2732. #define FLEXCAN1_RXIMR38 (IMXRT_FLEXCAN1_MASK.offset118)
  2733. #define FLEXCAN1_RXIMR39 (IMXRT_FLEXCAN1_MASK.offset11C)
  2734. #define FLEXCAN1_RXIMR40 (IMXRT_FLEXCAN1_MASK.offset120)
  2735. #define FLEXCAN1_RXIMR41 (IMXRT_FLEXCAN1_MASK.offset124)
  2736. #define FLEXCAN1_RXIMR42 (IMXRT_FLEXCAN1_MASK.offset128)
  2737. #define FLEXCAN1_RXIMR43 (IMXRT_FLEXCAN1_MASK.offset12C)
  2738. #define FLEXCAN1_RXIMR44 (IMXRT_FLEXCAN1_MASK.offset130)
  2739. #define FLEXCAN1_RXIMR45 (IMXRT_FLEXCAN1_MASK.offset134)
  2740. #define FLEXCAN1_RXIMR46 (IMXRT_FLEXCAN1_MASK.offset138)
  2741. #define FLEXCAN1_RXIMR47 (IMXRT_FLEXCAN1_MASK.offset13C)
  2742. #define FLEXCAN1_RXIMR48 (IMXRT_FLEXCAN1_MASK.offset140)
  2743. #define FLEXCAN1_RXIMR49 (IMXRT_FLEXCAN1_MASK.offset144)
  2744. #define FLEXCAN1_RXIMR50 (IMXRT_FLEXCAN1_MASK.offset148)
  2745. #define FLEXCAN1_RXIMR51 (IMXRT_FLEXCAN1_MASK.offset14C)
  2746. #define FLEXCAN1_RXIMR52 (IMXRT_FLEXCAN1_MASK.offset150)
  2747. #define FLEXCAN1_RXIMR53 (IMXRT_FLEXCAN1_MASK.offset154)
  2748. #define FLEXCAN1_RXIMR54 (IMXRT_FLEXCAN1_MASK.offset158)
  2749. #define FLEXCAN1_RXIMR55 (IMXRT_FLEXCAN1_MASK.offset15C)
  2750. #define FLEXCAN1_RXIMR56 (IMXRT_FLEXCAN1_MASK.offset160)
  2751. #define FLEXCAN1_RXIMR57 (IMXRT_FLEXCAN1_MASK.offset164)
  2752. #define FLEXCAN1_RXIMR58 (IMXRT_FLEXCAN1_MASK.offset168)
  2753. #define FLEXCAN1_RXIMR59 (IMXRT_FLEXCAN1_MASK.offset16C)
  2754. #define FLEXCAN1_RXIMR60 (IMXRT_FLEXCAN1_MASK.offset170)
  2755. #define FLEXCAN1_RXIMR61 (IMXRT_FLEXCAN1_MASK.offset174)
  2756. #define FLEXCAN1_RXIMR62 (IMXRT_FLEXCAN1_MASK.offset178)
  2757. #define FLEXCAN1_RXIMR63 (IMXRT_FLEXCAN1_MASK.offset17C)
  2758. #define FLEXCAN1_GFWR (IMXRT_FLEXCAN1_MASK.offset1E0)
  2759. #define IMXRT_FLEXCAN2 (*(IMXRT_REGISTER32_t *)0x401D4000)
  2760. #define IMXRT_FLEXCAN2_MASK (*(IMXRT_REGISTER32_t *)0x401D4800)
  2761. #define FLEXCAN2_MCR (IMXRT_FLEXCAN2.offset000)
  2762. #define FLEXCAN2_CTRL1 (IMXRT_FLEXCAN2.offset004)
  2763. #define FLEXCAN2_TIMER (IMXRT_FLEXCAN2.offset008)
  2764. #define FLEXCAN2_RXMGMASK (IMXRT_FLEXCAN2.offset010)
  2765. #define FLEXCAN2_RX14MASK (IMXRT_FLEXCAN2.offset014)
  2766. #define FLEXCAN2_RX15MASK (IMXRT_FLEXCAN2.offset018)
  2767. #define FLEXCAN2_ECR (IMXRT_FLEXCAN2.offset01C)
  2768. #define FLEXCAN2_ESR1 (IMXRT_FLEXCAN2.offset020)
  2769. #define FLEXCAN2_IMASK2 (IMXRT_FLEXCAN2.offset024)
  2770. #define FLEXCAN2_IMASK1 (IMXRT_FLEXCAN2.offset028)
  2771. #define FLEXCAN2_IFLAG2 (IMXRT_FLEXCAN2.offset02C)
  2772. #define FLEXCAN2_IFLAG1 (IMXRT_FLEXCAN2.offset030)
  2773. #define FLEXCAN2_CTRL2 (IMXRT_FLEXCAN2.offset034)
  2774. #define FLEXCAN2_ESR2 (IMXRT_FLEXCAN2.offset038)
  2775. #define FLEXCAN2_CRCR (IMXRT_FLEXCAN2.offset044)
  2776. #define FLEXCAN2_RXFGMASK (IMXRT_FLEXCAN2.offset048)
  2777. #define FLEXCAN2_RXFIR (IMXRT_FLEXCAN2.offset04C)
  2778. #define FLEXCAN2_RXIMR0 (IMXRT_FLEXCAN2_MASK.offset080)
  2779. #define FLEXCAN2_RXIMR1 (IMXRT_FLEXCAN2_MASK.offset084)
  2780. #define FLEXCAN2_RXIMR2 (IMXRT_FLEXCAN2_MASK.offset088)
  2781. #define FLEXCAN2_RXIMR3 (IMXRT_FLEXCAN2_MASK.offset08C)
  2782. #define FLEXCAN2_RXIMR4 (IMXRT_FLEXCAN2_MASK.offset090)
  2783. #define FLEXCAN2_RXIMR5 (IMXRT_FLEXCAN2_MASK.offset094)
  2784. #define FLEXCAN2_RXIMR6 (IMXRT_FLEXCAN2_MASK.offset098)
  2785. #define FLEXCAN2_RXIMR7 (IMXRT_FLEXCAN2_MASK.offset09C)
  2786. #define FLEXCAN2_RXIMR8 (IMXRT_FLEXCAN2_MASK.offset0A0)
  2787. #define FLEXCAN2_RXIMR9 (IMXRT_FLEXCAN2_MASK.offset0A4)
  2788. #define FLEXCAN2_RXIMR10 (IMXRT_FLEXCAN2_MASK.offset0A8)
  2789. #define FLEXCAN2_RXIMR11 (IMXRT_FLEXCAN2_MASK.offset0AC)
  2790. #define FLEXCAN2_RXIMR12 (IMXRT_FLEXCAN2_MASK.offset0B0)
  2791. #define FLEXCAN2_RXIMR13 (IMXRT_FLEXCAN2_MASK.offset0B4)
  2792. #define FLEXCAN2_RXIMR14 (IMXRT_FLEXCAN2_MASK.offset0B8)
  2793. #define FLEXCAN2_RXIMR15 (IMXRT_FLEXCAN2_MASK.offset0BC)
  2794. #define FLEXCAN2_RXIMR16 (IMXRT_FLEXCAN2_MASK.offset0C0)
  2795. #define FLEXCAN2_RXIMR17 (IMXRT_FLEXCAN2_MASK.offset0C4)
  2796. #define FLEXCAN2_RXIMR18 (IMXRT_FLEXCAN2_MASK.offset0C8)
  2797. #define FLEXCAN2_RXIMR19 (IMXRT_FLEXCAN2_MASK.offset0CC)
  2798. #define FLEXCAN2_RXIMR20 (IMXRT_FLEXCAN2_MASK.offset0D0)
  2799. #define FLEXCAN2_RXIMR21 (IMXRT_FLEXCAN2_MASK.offset0D4)
  2800. #define FLEXCAN2_RXIMR22 (IMXRT_FLEXCAN2_MASK.offset0D8)
  2801. #define FLEXCAN2_RXIMR23 (IMXRT_FLEXCAN2_MASK.offset0DC)
  2802. #define FLEXCAN2_RXIMR24 (IMXRT_FLEXCAN2_MASK.offset0E0)
  2803. #define FLEXCAN2_RXIMR25 (IMXRT_FLEXCAN2_MASK.offset0E4)
  2804. #define FLEXCAN2_RXIMR26 (IMXRT_FLEXCAN2_MASK.offset0E8)
  2805. #define FLEXCAN2_RXIMR27 (IMXRT_FLEXCAN2_MASK.offset0EC)
  2806. #define FLEXCAN2_RXIMR28 (IMXRT_FLEXCAN2_MASK.offset0F0)
  2807. #define FLEXCAN2_RXIMR29 (IMXRT_FLEXCAN2_MASK.offset0F4)
  2808. #define FLEXCAN2_RXIMR30 (IMXRT_FLEXCAN2_MASK.offset0F8)
  2809. #define FLEXCAN2_RXIMR31 (IMXRT_FLEXCAN2_MASK.offset0FC)
  2810. #define FLEXCAN2_RXIMR32 (IMXRT_FLEXCAN2_MASK.offset100)
  2811. #define FLEXCAN2_RXIMR33 (IMXRT_FLEXCAN2_MASK.offset104)
  2812. #define FLEXCAN2_RXIMR34 (IMXRT_FLEXCAN2_MASK.offset108)
  2813. #define FLEXCAN2_RXIMR35 (IMXRT_FLEXCAN2_MASK.offset10C)
  2814. #define FLEXCAN2_RXIMR36 (IMXRT_FLEXCAN2_MASK.offset110)
  2815. #define FLEXCAN2_RXIMR37 (IMXRT_FLEXCAN2_MASK.offset114)
  2816. #define FLEXCAN2_RXIMR38 (IMXRT_FLEXCAN2_MASK.offset118)
  2817. #define FLEXCAN2_RXIMR39 (IMXRT_FLEXCAN2_MASK.offset11C)
  2818. #define FLEXCAN2_RXIMR40 (IMXRT_FLEXCAN2_MASK.offset120)
  2819. #define FLEXCAN2_RXIMR41 (IMXRT_FLEXCAN2_MASK.offset124)
  2820. #define FLEXCAN2_RXIMR42 (IMXRT_FLEXCAN2_MASK.offset128)
  2821. #define FLEXCAN2_RXIMR43 (IMXRT_FLEXCAN2_MASK.offset12C)
  2822. #define FLEXCAN2_RXIMR44 (IMXRT_FLEXCAN2_MASK.offset130)
  2823. #define FLEXCAN2_RXIMR45 (IMXRT_FLEXCAN2_MASK.offset134)
  2824. #define FLEXCAN2_RXIMR46 (IMXRT_FLEXCAN2_MASK.offset138)
  2825. #define FLEXCAN2_RXIMR47 (IMXRT_FLEXCAN2_MASK.offset13C)
  2826. #define FLEXCAN2_RXIMR48 (IMXRT_FLEXCAN2_MASK.offset140)
  2827. #define FLEXCAN2_RXIMR49 (IMXRT_FLEXCAN2_MASK.offset144)
  2828. #define FLEXCAN2_RXIMR50 (IMXRT_FLEXCAN2_MASK.offset148)
  2829. #define FLEXCAN2_RXIMR51 (IMXRT_FLEXCAN2_MASK.offset14C)
  2830. #define FLEXCAN2_RXIMR52 (IMXRT_FLEXCAN2_MASK.offset150)
  2831. #define FLEXCAN2_RXIMR53 (IMXRT_FLEXCAN2_MASK.offset154)
  2832. #define FLEXCAN2_RXIMR54 (IMXRT_FLEXCAN2_MASK.offset158)
  2833. #define FLEXCAN2_RXIMR55 (IMXRT_FLEXCAN2_MASK.offset15C)
  2834. #define FLEXCAN2_RXIMR56 (IMXRT_FLEXCAN2_MASK.offset160)
  2835. #define FLEXCAN2_RXIMR57 (IMXRT_FLEXCAN2_MASK.offset164)
  2836. #define FLEXCAN2_RXIMR58 (IMXRT_FLEXCAN2_MASK.offset168)
  2837. #define FLEXCAN2_RXIMR59 (IMXRT_FLEXCAN2_MASK.offset16C)
  2838. #define FLEXCAN2_RXIMR60 (IMXRT_FLEXCAN2_MASK.offset170)
  2839. #define FLEXCAN2_RXIMR61 (IMXRT_FLEXCAN2_MASK.offset174)
  2840. #define FLEXCAN2_RXIMR62 (IMXRT_FLEXCAN2_MASK.offset178)
  2841. #define FLEXCAN2_RXIMR63 (IMXRT_FLEXCAN2_MASK.offset17C)
  2842. #define FLEXCAN2_GFWR (IMXRT_FLEXCAN2_MASK.offset1E0)
  2843. #define IMXRT_FLEXCAN3 (*(IMXRT_REGISTER32_t *)0x401D8000)
  2844. #define IMXRT_FLEXCAN3_MASK (*(IMXRT_REGISTER32_t *)0x401D8800)
  2845. #define IMXRT_FLEXCAN3_EXT (*(IMXRT_REGISTER32_t *)0x401D8B00)
  2846. #define IMXRT_FLEXCAN3_ERXFIFO (*(IMXRT_REGISTER32_t *)0x401DB000)
  2847. #define FLEXCAN3_MCR (IMXRT_FLEXCAN3.offset000)
  2848. #define FLEXCAN3_CTRL1 (IMXRT_FLEXCAN3.offset004)
  2849. #define FLEXCAN3_TIMER (IMXRT_FLEXCAN3.offset008)
  2850. #define FLEXCAN3_RXMGMASK (IMXRT_FLEXCAN3.offset010)
  2851. #define FLEXCAN3_RX14MASK (IMXRT_FLEXCAN3.offset014)
  2852. #define FLEXCAN3_RX15MASK (IMXRT_FLEXCAN3.offset018)
  2853. #define FLEXCAN3_ECR (IMXRT_FLEXCAN3.offset01C)
  2854. #define FLEXCAN3_ESR1 (IMXRT_FLEXCAN3.offset020)
  2855. #define FLEXCAN3_IMASK2 (IMXRT_FLEXCAN3.offset024)
  2856. #define FLEXCAN3_IMASK1 (IMXRT_FLEXCAN3.offset028)
  2857. #define FLEXCAN3_IFLAG2 (IMXRT_FLEXCAN3.offset02C)
  2858. #define FLEXCAN3_IFLAG1 (IMXRT_FLEXCAN3.offset030)
  2859. #define FLEXCAN3_CTRL2 (IMXRT_FLEXCAN3.offset034)
  2860. #define FLEXCAN3_ESR2 (IMXRT_FLEXCAN3.offset038)
  2861. #define FLEXCAN3_CRCR (IMXRT_FLEXCAN3.offset044)
  2862. #define FLEXCAN3_RXFGMASK (IMXRT_FLEXCAN3.offset048)
  2863. #define FLEXCAN3_RXFIR (IMXRT_FLEXCAN3.offset04C)
  2864. #define FLEXCAN3_RXIMR0 (IMXRT_FLEXCAN3_MASK.offset080)
  2865. #define FLEXCAN3_RXIMR1 (IMXRT_FLEXCAN3_MASK.offset084)
  2866. #define FLEXCAN3_RXIMR2 (IMXRT_FLEXCAN3_MASK.offset088)
  2867. #define FLEXCAN3_RXIMR3 (IMXRT_FLEXCAN3_MASK.offset08C)
  2868. #define FLEXCAN3_RXIMR4 (IMXRT_FLEXCAN3_MASK.offset090)
  2869. #define FLEXCAN3_RXIMR5 (IMXRT_FLEXCAN3_MASK.offset094)
  2870. #define FLEXCAN3_RXIMR6 (IMXRT_FLEXCAN3_MASK.offset098)
  2871. #define FLEXCAN3_RXIMR7 (IMXRT_FLEXCAN3_MASK.offset09C)
  2872. #define FLEXCAN3_RXIMR8 (IMXRT_FLEXCAN3_MASK.offset0A0)
  2873. #define FLEXCAN3_RXIMR9 (IMXRT_FLEXCAN3_MASK.offset0A4)
  2874. #define FLEXCAN3_RXIMR10 (IMXRT_FLEXCAN3_MASK.offset0A8)
  2875. #define FLEXCAN3_RXIMR11 (IMXRT_FLEXCAN3_MASK.offset0AC)
  2876. #define FLEXCAN3_RXIMR12 (IMXRT_FLEXCAN3_MASK.offset0B0)
  2877. #define FLEXCAN3_RXIMR13 (IMXRT_FLEXCAN3_MASK.offset0B4)
  2878. #define FLEXCAN3_RXIMR14 (IMXRT_FLEXCAN3_MASK.offset0B8)
  2879. #define FLEXCAN3_RXIMR15 (IMXRT_FLEXCAN3_MASK.offset0BC)
  2880. #define FLEXCAN3_RXIMR16 (IMXRT_FLEXCAN3_MASK.offset0C0)
  2881. #define FLEXCAN3_RXIMR17 (IMXRT_FLEXCAN3_MASK.offset0C4)
  2882. #define FLEXCAN3_RXIMR18 (IMXRT_FLEXCAN3_MASK.offset0C8)
  2883. #define FLEXCAN3_RXIMR19 (IMXRT_FLEXCAN3_MASK.offset0CC)
  2884. #define FLEXCAN3_RXIMR20 (IMXRT_FLEXCAN3_MASK.offset0D0)
  2885. #define FLEXCAN3_RXIMR21 (IMXRT_FLEXCAN3_MASK.offset0D4)
  2886. #define FLEXCAN3_RXIMR22 (IMXRT_FLEXCAN3_MASK.offset0D8)
  2887. #define FLEXCAN3_RXIMR23 (IMXRT_FLEXCAN3_MASK.offset0DC)
  2888. #define FLEXCAN3_RXIMR24 (IMXRT_FLEXCAN3_MASK.offset0E0)
  2889. #define FLEXCAN3_RXIMR25 (IMXRT_FLEXCAN3_MASK.offset0E4)
  2890. #define FLEXCAN3_RXIMR26 (IMXRT_FLEXCAN3_MASK.offset0E8)
  2891. #define FLEXCAN3_RXIMR27 (IMXRT_FLEXCAN3_MASK.offset0EC)
  2892. #define FLEXCAN3_RXIMR28 (IMXRT_FLEXCAN3_MASK.offset0F0)
  2893. #define FLEXCAN3_RXIMR29 (IMXRT_FLEXCAN3_MASK.offset0F4)
  2894. #define FLEXCAN3_RXIMR30 (IMXRT_FLEXCAN3_MASK.offset0F8)
  2895. #define FLEXCAN3_RXIMR31 (IMXRT_FLEXCAN3_MASK.offset0FC)
  2896. #define FLEXCAN3_RXIMR32 (IMXRT_FLEXCAN3_MASK.offset100)
  2897. #define FLEXCAN3_RXIMR33 (IMXRT_FLEXCAN3_MASK.offset104)
  2898. #define FLEXCAN3_RXIMR34 (IMXRT_FLEXCAN3_MASK.offset108)
  2899. #define FLEXCAN3_RXIMR35 (IMXRT_FLEXCAN3_MASK.offset10C)
  2900. #define FLEXCAN3_RXIMR36 (IMXRT_FLEXCAN3_MASK.offset110)
  2901. #define FLEXCAN3_RXIMR37 (IMXRT_FLEXCAN3_MASK.offset114)
  2902. #define FLEXCAN3_RXIMR38 (IMXRT_FLEXCAN3_MASK.offset118)
  2903. #define FLEXCAN3_RXIMR39 (IMXRT_FLEXCAN3_MASK.offset11C)
  2904. #define FLEXCAN3_RXIMR40 (IMXRT_FLEXCAN3_MASK.offset120)
  2905. #define FLEXCAN3_RXIMR41 (IMXRT_FLEXCAN3_MASK.offset124)
  2906. #define FLEXCAN3_RXIMR42 (IMXRT_FLEXCAN3_MASK.offset128)
  2907. #define FLEXCAN3_RXIMR43 (IMXRT_FLEXCAN3_MASK.offset12C)
  2908. #define FLEXCAN3_RXIMR44 (IMXRT_FLEXCAN3_MASK.offset130)
  2909. #define FLEXCAN3_RXIMR45 (IMXRT_FLEXCAN3_MASK.offset134)
  2910. #define FLEXCAN3_RXIMR46 (IMXRT_FLEXCAN3_MASK.offset138)
  2911. #define FLEXCAN3_RXIMR47 (IMXRT_FLEXCAN3_MASK.offset13C)
  2912. #define FLEXCAN3_RXIMR48 (IMXRT_FLEXCAN3_MASK.offset140)
  2913. #define FLEXCAN3_RXIMR49 (IMXRT_FLEXCAN3_MASK.offset144)
  2914. #define FLEXCAN3_RXIMR50 (IMXRT_FLEXCAN3_MASK.offset148)
  2915. #define FLEXCAN3_RXIMR51 (IMXRT_FLEXCAN3_MASK.offset14C)
  2916. #define FLEXCAN3_RXIMR52 (IMXRT_FLEXCAN3_MASK.offset150)
  2917. #define FLEXCAN3_RXIMR53 (IMXRT_FLEXCAN3_MASK.offset154)
  2918. #define FLEXCAN3_RXIMR54 (IMXRT_FLEXCAN3_MASK.offset158)
  2919. #define FLEXCAN3_RXIMR55 (IMXRT_FLEXCAN3_MASK.offset15C)
  2920. #define FLEXCAN3_RXIMR56 (IMXRT_FLEXCAN3_MASK.offset160)
  2921. #define FLEXCAN3_RXIMR57 (IMXRT_FLEXCAN3_MASK.offset164)
  2922. #define FLEXCAN3_RXIMR58 (IMXRT_FLEXCAN3_MASK.offset168)
  2923. #define FLEXCAN3_RXIMR59 (IMXRT_FLEXCAN3_MASK.offset16C)
  2924. #define FLEXCAN3_RXIMR60 (IMXRT_FLEXCAN3_MASK.offset170)
  2925. #define FLEXCAN3_RXIMR61 (IMXRT_FLEXCAN3_MASK.offset174)
  2926. #define FLEXCAN3_RXIMR62 (IMXRT_FLEXCAN3_MASK.offset178)
  2927. #define FLEXCAN3_RXIMR63 (IMXRT_FLEXCAN3_MASK.offset17C)
  2928. #define FLEXCAN3_EPRS (IMXRT_FLEXCAN3_EXT.offset0F0)
  2929. #define FLEXCAN3_ENCBT (IMXRT_FLEXCAN3_EXT.offset0F4)
  2930. #define FLEXCAN3_EDCBT (IMXRT_FLEXCAN3_EXT.offset0F8)
  2931. #define FLEXCAN3_ETDC (IMXRT_FLEXCAN3_EXT.offset0FC)
  2932. #define FLEXCAN3_FDCTRL (IMXRT_FLEXCAN3_EXT.offset100)
  2933. #define FLEXCAN3_FDCBT (IMXRT_FLEXCAN3_EXT.offset104)
  2934. #define FLEXCAN3_FDCRC (IMXRT_FLEXCAN3_EXT.offset108)
  2935. #define FLEXCAN3_ERFCR (IMXRT_FLEXCAN3_EXT.offset10C)
  2936. #define FLEXCAN3_ERFIER (IMXRT_FLEXCAN3_EXT.offset110)
  2937. #define FLEXCAN3_ERFSR (IMXRT_FLEXCAN3_EXT.offset114)
  2938. #define FLEXCAN3_HR_TIME_STAMP0 (IMXRT_FLEXCAN3_EXT.offset130)
  2939. #define FLEXCAN3_HR_TIME_STAMP1 (IMXRT_FLEXCAN3_EXT.offset134)
  2940. #define FLEXCAN3_HR_TIME_STAMP2 (IMXRT_FLEXCAN3_EXT.offset138)
  2941. #define FLEXCAN3_HR_TIME_STAMP3 (IMXRT_FLEXCAN3_EXT.offset13C)
  2942. #define FLEXCAN3_HR_TIME_STAMP4 (IMXRT_FLEXCAN3_EXT.offset140)
  2943. #define FLEXCAN3_HR_TIME_STAMP5 (IMXRT_FLEXCAN3_EXT.offset144)
  2944. #define FLEXCAN3_HR_TIME_STAMP6 (IMXRT_FLEXCAN3_EXT.offset148)
  2945. #define FLEXCAN3_HR_TIME_STAMP7 (IMXRT_FLEXCAN3_EXT.offset14C)
  2946. #define FLEXCAN3_HR_TIME_STAMP8 (IMXRT_FLEXCAN3_EXT.offset150)
  2947. #define FLEXCAN3_HR_TIME_STAMP9 (IMXRT_FLEXCAN3_EXT.offset154)
  2948. #define FLEXCAN3_HR_TIME_STAMP10 (IMXRT_FLEXCAN3_EXT.offset158)
  2949. #define FLEXCAN3_HR_TIME_STAMP11 (IMXRT_FLEXCAN3_EXT.offset15C)
  2950. #define FLEXCAN3_HR_TIME_STAMP12 (IMXRT_FLEXCAN3_EXT.offset160)
  2951. #define FLEXCAN3_HR_TIME_STAMP13 (IMXRT_FLEXCAN3_EXT.offset164)
  2952. #define FLEXCAN3_HR_TIME_STAMP14 (IMXRT_FLEXCAN3_EXT.offset168)
  2953. #define FLEXCAN3_HR_TIME_STAMP15 (IMXRT_FLEXCAN3_EXT.offset16C)
  2954. #define FLEXCAN3_HR_TIME_STAMP16 (IMXRT_FLEXCAN3_EXT.offset170)
  2955. #define FLEXCAN3_HR_TIME_STAMP17 (IMXRT_FLEXCAN3_EXT.offset174)
  2956. #define FLEXCAN3_HR_TIME_STAMP18 (IMXRT_FLEXCAN3_EXT.offset178)
  2957. #define FLEXCAN3_HR_TIME_STAMP19 (IMXRT_FLEXCAN3_EXT.offset17C)
  2958. #define FLEXCAN3_HR_TIME_STAMP20 (IMXRT_FLEXCAN3_EXT.offset180)
  2959. #define FLEXCAN3_HR_TIME_STAMP21 (IMXRT_FLEXCAN3_EXT.offset184)
  2960. #define FLEXCAN3_HR_TIME_STAMP22 (IMXRT_FLEXCAN3_EXT.offset188)
  2961. #define FLEXCAN3_HR_TIME_STAMP23 (IMXRT_FLEXCAN3_EXT.offset18C)
  2962. #define FLEXCAN3_HR_TIME_STAMP24 (IMXRT_FLEXCAN3_EXT.offset190)
  2963. #define FLEXCAN3_HR_TIME_STAMP25 (IMXRT_FLEXCAN3_EXT.offset194)
  2964. #define FLEXCAN3_HR_TIME_STAMP26 (IMXRT_FLEXCAN3_EXT.offset198)
  2965. #define FLEXCAN3_HR_TIME_STAMP27 (IMXRT_FLEXCAN3_EXT.offset19C)
  2966. #define FLEXCAN3_HR_TIME_STAMP28 (IMXRT_FLEXCAN3_EXT.offset1A0)
  2967. #define FLEXCAN3_HR_TIME_STAMP29 (IMXRT_FLEXCAN3_EXT.offset1A4)
  2968. #define FLEXCAN3_HR_TIME_STAMP30 (IMXRT_FLEXCAN3_EXT.offset1A8)
  2969. #define FLEXCAN3_HR_TIME_STAMP31 (IMXRT_FLEXCAN3_EXT.offset1AC)
  2970. #define FLEXCAN3_HR_TIME_STAMP32 (IMXRT_FLEXCAN3_EXT.offset1B0)
  2971. #define FLEXCAN3_HR_TIME_STAMP33 (IMXRT_FLEXCAN3_EXT.offset1B4)
  2972. #define FLEXCAN3_HR_TIME_STAMP34 (IMXRT_FLEXCAN3_EXT.offset1B8)
  2973. #define FLEXCAN3_HR_TIME_STAMP35 (IMXRT_FLEXCAN3_EXT.offset1BC)
  2974. #define FLEXCAN3_HR_TIME_STAMP36 (IMXRT_FLEXCAN3_EXT.offset1C0)
  2975. #define FLEXCAN3_HR_TIME_STAMP37 (IMXRT_FLEXCAN3_EXT.offset1C4)
  2976. #define FLEXCAN3_HR_TIME_STAMP38 (IMXRT_FLEXCAN3_EXT.offset1C8)
  2977. #define FLEXCAN3_HR_TIME_STAMP39 (IMXRT_FLEXCAN3_EXT.offset1CC)
  2978. #define FLEXCAN3_HR_TIME_STAMP40 (IMXRT_FLEXCAN3_EXT.offset1D0)
  2979. #define FLEXCAN3_HR_TIME_STAMP41 (IMXRT_FLEXCAN3_EXT.offset1D4)
  2980. #define FLEXCAN3_HR_TIME_STAMP42 (IMXRT_FLEXCAN3_EXT.offset1D8)
  2981. #define FLEXCAN3_HR_TIME_STAMP43 (IMXRT_FLEXCAN3_EXT.offset1DC)
  2982. #define FLEXCAN3_HR_TIME_STAMP44 (IMXRT_FLEXCAN3_EXT.offset1E0)
  2983. #define FLEXCAN3_HR_TIME_STAMP45 (IMXRT_FLEXCAN3_EXT.offset1E4)
  2984. #define FLEXCAN3_HR_TIME_STAMP46 (IMXRT_FLEXCAN3_EXT.offset1E8)
  2985. #define FLEXCAN3_HR_TIME_STAMP47 (IMXRT_FLEXCAN3_EXT.offset1EC)
  2986. #define FLEXCAN3_HR_TIME_STAMP48 (IMXRT_FLEXCAN3_EXT.offset1F0)
  2987. #define FLEXCAN3_HR_TIME_STAMP49 (IMXRT_FLEXCAN3_EXT.offset1F4)
  2988. #define FLEXCAN3_HR_TIME_STAMP50 (IMXRT_FLEXCAN3_EXT.offset1F8)
  2989. #define FLEXCAN3_HR_TIME_STAMP51 (IMXRT_FLEXCAN3_EXT.offset1FC)
  2990. #define FLEXCAN3_HR_TIME_STAMP52 (IMXRT_FLEXCAN3_EXT.offset200)
  2991. #define FLEXCAN3_HR_TIME_STAMP53 (IMXRT_FLEXCAN3_EXT.offset204)
  2992. #define FLEXCAN3_HR_TIME_STAMP54 (IMXRT_FLEXCAN3_EXT.offset208)
  2993. #define FLEXCAN3_HR_TIME_STAMP55 (IMXRT_FLEXCAN3_EXT.offset20C)
  2994. #define FLEXCAN3_HR_TIME_STAMP56 (IMXRT_FLEXCAN3_EXT.offset210)
  2995. #define FLEXCAN3_HR_TIME_STAMP57 (IMXRT_FLEXCAN3_EXT.offset234)
  2996. #define FLEXCAN3_HR_TIME_STAMP58 (IMXRT_FLEXCAN3_EXT.offset218)
  2997. #define FLEXCAN3_HR_TIME_STAMP59 (IMXRT_FLEXCAN3_EXT.offset21C)
  2998. #define FLEXCAN3_HR_TIME_STAMP60 (IMXRT_FLEXCAN3_EXT.offset220)
  2999. #define FLEXCAN3_HR_TIME_STAMP61 (IMXRT_FLEXCAN3_EXT.offset224)
  3000. #define FLEXCAN3_HR_TIME_STAMP62 (IMXRT_FLEXCAN3_EXT.offset228)
  3001. #define FLEXCAN3_HR_TIME_STAMP63 (IMXRT_FLEXCAN3_EXT.offset22C)
  3002. #define FLEXCAN3_ERFFEL0 (IMXRT_FLEXCAN3_ERXFIFO.offset000)
  3003. #define FLEXCAN3_ERFFEL1 (IMXRT_FLEXCAN3_ERXFIFO.offset004)
  3004. #define FLEXCAN3_ERFFEL2 (IMXRT_FLEXCAN3_ERXFIFO.offset008)
  3005. #define FLEXCAN3_ERFFEL3 (IMXRT_FLEXCAN3_ERXFIFO.offset00C)
  3006. #define FLEXCAN3_ERFFEL4 (IMXRT_FLEXCAN3_ERXFIFO.offset010)
  3007. #define FLEXCAN3_ERFFEL5 (IMXRT_FLEXCAN3_ERXFIFO.offset014)
  3008. #define FLEXCAN3_ERFFEL6 (IMXRT_FLEXCAN3_ERXFIFO.offset018)
  3009. #define FLEXCAN3_ERFFEL7 (IMXRT_FLEXCAN3_ERXFIFO.offset01C)
  3010. #define FLEXCAN3_ERFFEL8 (IMXRT_FLEXCAN3_ERXFIFO.offset020)
  3011. #define FLEXCAN3_ERFFEL9 (IMXRT_FLEXCAN3_ERXFIFO.offset024)
  3012. #define FLEXCAN3_ERFFEL10 (IMXRT_FLEXCAN3_ERXFIFO.offset028)
  3013. #define FLEXCAN3_ERFFEL11 (IMXRT_FLEXCAN3_ERXFIFO.offset02C)
  3014. #define FLEXCAN3_ERFFEL12 (IMXRT_FLEXCAN3_ERXFIFO.offset030)
  3015. #define FLEXCAN3_ERFFEL13 (IMXRT_FLEXCAN3_ERXFIFO.offset034)
  3016. #define FLEXCAN3_ERFFEL14 (IMXRT_FLEXCAN3_ERXFIFO.offset038)
  3017. #define FLEXCAN3_ERFFEL15 (IMXRT_FLEXCAN3_ERXFIFO.offset03C)
  3018. #define FLEXCAN3_ERFFEL16 (IMXRT_FLEXCAN3_ERXFIFO.offset040)
  3019. #define FLEXCAN3_ERFFEL17 (IMXRT_FLEXCAN3_ERXFIFO.offset044)
  3020. #define FLEXCAN3_ERFFEL18 (IMXRT_FLEXCAN3_ERXFIFO.offset048)
  3021. #define FLEXCAN3_ERFFEL19 (IMXRT_FLEXCAN3_ERXFIFO.offset04C)
  3022. #define FLEXCAN3_ERFFEL20 (IMXRT_FLEXCAN3_ERXFIFO.offset050)
  3023. #define FLEXCAN3_ERFFEL21 (IMXRT_FLEXCAN3_ERXFIFO.offset054)
  3024. #define FLEXCAN3_ERFFEL22 (IMXRT_FLEXCAN3_ERXFIFO.offset058)
  3025. #define FLEXCAN3_ERFFEL23 (IMXRT_FLEXCAN3_ERXFIFO.offset05C)
  3026. #define FLEXCAN3_ERFFEL24 (IMXRT_FLEXCAN3_ERXFIFO.offset060)
  3027. #define FLEXCAN3_ERFFEL25 (IMXRT_FLEXCAN3_ERXFIFO.offset064)
  3028. #define FLEXCAN3_ERFFEL26 (IMXRT_FLEXCAN3_ERXFIFO.offset068)
  3029. #define FLEXCAN3_ERFFEL27 (IMXRT_FLEXCAN3_ERXFIFO.offset06C)
  3030. #define FLEXCAN3_ERFFEL28 (IMXRT_FLEXCAN3_ERXFIFO.offset070)
  3031. #define FLEXCAN3_ERFFEL29 (IMXRT_FLEXCAN3_ERXFIFO.offset074)
  3032. #define FLEXCAN3_ERFFEL30 (IMXRT_FLEXCAN3_ERXFIFO.offset078)
  3033. #define FLEXCAN3_ERFFEL31 (IMXRT_FLEXCAN3_ERXFIFO.offset07C)
  3034. #define FLEXCAN3_ERFFEL32 (IMXRT_FLEXCAN3_ERXFIFO.offset080)
  3035. #define FLEXCAN3_ERFFEL33 (IMXRT_FLEXCAN3_ERXFIFO.offset084)
  3036. #define FLEXCAN3_ERFFEL34 (IMXRT_FLEXCAN3_ERXFIFO.offset088)
  3037. #define FLEXCAN3_ERFFEL35 (IMXRT_FLEXCAN3_ERXFIFO.offset08C)
  3038. #define FLEXCAN3_ERFFEL36 (IMXRT_FLEXCAN3_ERXFIFO.offset090)
  3039. #define FLEXCAN3_ERFFEL37 (IMXRT_FLEXCAN3_ERXFIFO.offset094)
  3040. #define FLEXCAN3_ERFFEL38 (IMXRT_FLEXCAN3_ERXFIFO.offset098)
  3041. #define FLEXCAN3_ERFFEL39 (IMXRT_FLEXCAN3_ERXFIFO.offset09C)
  3042. #define FLEXCAN3_ERFFEL40 (IMXRT_FLEXCAN3_ERXFIFO.offset0A0)
  3043. #define FLEXCAN3_ERFFEL41 (IMXRT_FLEXCAN3_ERXFIFO.offset0A4)
  3044. #define FLEXCAN3_ERFFEL42 (IMXRT_FLEXCAN3_ERXFIFO.offset0A8)
  3045. #define FLEXCAN3_ERFFEL43 (IMXRT_FLEXCAN3_ERXFIFO.offset0AC)
  3046. #define FLEXCAN3_ERFFEL44 (IMXRT_FLEXCAN3_ERXFIFO.offset0B0)
  3047. #define FLEXCAN3_ERFFEL45 (IMXRT_FLEXCAN3_ERXFIFO.offset0B4)
  3048. #define FLEXCAN3_ERFFEL46 (IMXRT_FLEXCAN3_ERXFIFO.offset0B8)
  3049. #define FLEXCAN3_ERFFEL47 (IMXRT_FLEXCAN3_ERXFIFO.offset0BC)
  3050. #define FLEXCAN3_ERFFEL48 (IMXRT_FLEXCAN3_ERXFIFO.offset0C0)
  3051. #define FLEXCAN3_ERFFEL49 (IMXRT_FLEXCAN3_ERXFIFO.offset0C4)
  3052. #define FLEXCAN3_ERFFEL50 (IMXRT_FLEXCAN3_ERXFIFO.offset0C8)
  3053. #define FLEXCAN3_ERFFEL51 (IMXRT_FLEXCAN3_ERXFIFO.offset0CC)
  3054. #define FLEXCAN3_ERFFEL52 (IMXRT_FLEXCAN3_ERXFIFO.offset0D0)
  3055. #define FLEXCAN3_ERFFEL53 (IMXRT_FLEXCAN3_ERXFIFO.offset0D4)
  3056. #define FLEXCAN3_ERFFEL54 (IMXRT_FLEXCAN3_ERXFIFO.offset0D8)
  3057. #define FLEXCAN3_ERFFEL55 (IMXRT_FLEXCAN3_ERXFIFO.offset0DC)
  3058. #define FLEXCAN3_ERFFEL56 (IMXRT_FLEXCAN3_ERXFIFO.offset0E0)
  3059. #define FLEXCAN3_ERFFEL57 (IMXRT_FLEXCAN3_ERXFIFO.offset0E4)
  3060. #define FLEXCAN3_ERFFEL58 (IMXRT_FLEXCAN3_ERXFIFO.offset0E8)
  3061. #define FLEXCAN3_ERFFEL59 (IMXRT_FLEXCAN3_ERXFIFO.offset0EC)
  3062. #define FLEXCAN3_ERFFEL60 (IMXRT_FLEXCAN3_ERXFIFO.offset0F0)
  3063. #define FLEXCAN3_ERFFEL61 (IMXRT_FLEXCAN3_ERXFIFO.offset0F4)
  3064. #define FLEXCAN3_ERFFEL62 (IMXRT_FLEXCAN3_ERXFIFO.offset0F8)
  3065. #define FLEXCAN3_ERFFEL63 (IMXRT_FLEXCAN3_ERXFIFO.offset0FC)
  3066. #define FLEXCAN3_ERFFEL64 (IMXRT_FLEXCAN3_ERXFIFO.offset100)
  3067. #define FLEXCAN3_ERFFEL65 (IMXRT_FLEXCAN3_ERXFIFO.offset104)
  3068. #define FLEXCAN3_ERFFEL66 (IMXRT_FLEXCAN3_ERXFIFO.offset108)
  3069. #define FLEXCAN3_ERFFEL67 (IMXRT_FLEXCAN3_ERXFIFO.offset10C)
  3070. #define FLEXCAN3_ERFFEL68 (IMXRT_FLEXCAN3_ERXFIFO.offset110)
  3071. #define FLEXCAN3_ERFFEL69 (IMXRT_FLEXCAN3_ERXFIFO.offset114)
  3072. #define FLEXCAN3_ERFFEL70 (IMXRT_FLEXCAN3_ERXFIFO.offset118)
  3073. #define FLEXCAN3_ERFFEL71 (IMXRT_FLEXCAN3_ERXFIFO.offset11C)
  3074. #define FLEXCAN3_ERFFEL72 (IMXRT_FLEXCAN3_ERXFIFO.offset120)
  3075. #define FLEXCAN3_ERFFEL73 (IMXRT_FLEXCAN3_ERXFIFO.offset124)
  3076. #define FLEXCAN3_ERFFEL74 (IMXRT_FLEXCAN3_ERXFIFO.offset128)
  3077. #define FLEXCAN3_ERFFEL75 (IMXRT_FLEXCAN3_ERXFIFO.offset12C)
  3078. #define FLEXCAN3_ERFFEL76 (IMXRT_FLEXCAN3_ERXFIFO.offset130)
  3079. #define FLEXCAN3_ERFFEL77 (IMXRT_FLEXCAN3_ERXFIFO.offset134)
  3080. #define FLEXCAN3_ERFFEL78 (IMXRT_FLEXCAN3_ERXFIFO.offset138)
  3081. #define FLEXCAN3_ERFFEL79 (IMXRT_FLEXCAN3_ERXFIFO.offset13C)
  3082. #define FLEXCAN3_ERFFEL80 (IMXRT_FLEXCAN3_ERXFIFO.offset140)
  3083. #define FLEXCAN3_ERFFEL81 (IMXRT_FLEXCAN3_ERXFIFO.offset144)
  3084. #define FLEXCAN3_ERFFEL82 (IMXRT_FLEXCAN3_ERXFIFO.offset148)
  3085. #define FLEXCAN3_ERFFEL83 (IMXRT_FLEXCAN3_ERXFIFO.offset14C)
  3086. #define FLEXCAN3_ERFFEL84 (IMXRT_FLEXCAN3_ERXFIFO.offset150)
  3087. #define FLEXCAN3_ERFFEL85 (IMXRT_FLEXCAN3_ERXFIFO.offset154)
  3088. #define FLEXCAN3_ERFFEL86 (IMXRT_FLEXCAN3_ERXFIFO.offset158)
  3089. #define FLEXCAN3_ERFFEL87 (IMXRT_FLEXCAN3_ERXFIFO.offset15C)
  3090. #define FLEXCAN3_ERFFEL88 (IMXRT_FLEXCAN3_ERXFIFO.offset160)
  3091. #define FLEXCAN3_ERFFEL89 (IMXRT_FLEXCAN3_ERXFIFO.offset164)
  3092. #define FLEXCAN3_ERFFEL90 (IMXRT_FLEXCAN3_ERXFIFO.offset168)
  3093. #define FLEXCAN3_ERFFEL91 (IMXRT_FLEXCAN3_ERXFIFO.offset16C)
  3094. #define FLEXCAN3_ERFFEL92 (IMXRT_FLEXCAN3_ERXFIFO.offset170)
  3095. #define FLEXCAN3_ERFFEL93 (IMXRT_FLEXCAN3_ERXFIFO.offset174)
  3096. #define FLEXCAN3_ERFFEL94 (IMXRT_FLEXCAN3_ERXFIFO.offset178)
  3097. #define FLEXCAN3_ERFFEL95 (IMXRT_FLEXCAN3_ERXFIFO.offset17C)
  3098. #define FLEXCAN3_ERFFEL96 (IMXRT_FLEXCAN3_ERXFIFO.offset180)
  3099. #define FLEXCAN3_ERFFEL97 (IMXRT_FLEXCAN3_ERXFIFO.offset184)
  3100. #define FLEXCAN3_ERFFEL98 (IMXRT_FLEXCAN3_ERXFIFO.offset188)
  3101. #define FLEXCAN3_ERFFEL99 (IMXRT_FLEXCAN3_ERXFIFO.offset18C)
  3102. #define FLEXCAN3_ERFFEL100 (IMXRT_FLEXCAN3_ERXFIFO.offset190)
  3103. #define FLEXCAN3_ERFFEL101 (IMXRT_FLEXCAN3_ERXFIFO.offset194)
  3104. #define FLEXCAN3_ERFFEL102 (IMXRT_FLEXCAN3_ERXFIFO.offset198)
  3105. #define FLEXCAN3_ERFFEL103 (IMXRT_FLEXCAN3_ERXFIFO.offset19C)
  3106. #define FLEXCAN3_ERFFEL104 (IMXRT_FLEXCAN3_ERXFIFO.offset1A0)
  3107. #define FLEXCAN3_ERFFEL105 (IMXRT_FLEXCAN3_ERXFIFO.offset1A4)
  3108. #define FLEXCAN3_ERFFEL106 (IMXRT_FLEXCAN3_ERXFIFO.offset1A8)
  3109. #define FLEXCAN3_ERFFEL107 (IMXRT_FLEXCAN3_ERXFIFO.offset1AC)
  3110. #define FLEXCAN3_ERFFEL108 (IMXRT_FLEXCAN3_ERXFIFO.offset1B0)
  3111. #define FLEXCAN3_ERFFEL109 (IMXRT_FLEXCAN3_ERXFIFO.offset1B4)
  3112. #define FLEXCAN3_ERFFEL110 (IMXRT_FLEXCAN3_ERXFIFO.offset1B8)
  3113. #define FLEXCAN3_ERFFEL111 (IMXRT_FLEXCAN3_ERXFIFO.offset1BC)
  3114. #define FLEXCAN3_ERFFEL112 (IMXRT_FLEXCAN3_ERXFIFO.offset1C0)
  3115. #define FLEXCAN3_ERFFEL113 (IMXRT_FLEXCAN3_ERXFIFO.offset1C4)
  3116. #define FLEXCAN3_ERFFEL114 (IMXRT_FLEXCAN3_ERXFIFO.offset1C8)
  3117. #define FLEXCAN3_ERFFEL115 (IMXRT_FLEXCAN3_ERXFIFO.offset1CC)
  3118. #define FLEXCAN3_ERFFEL116 (IMXRT_FLEXCAN3_ERXFIFO.offset1D0)
  3119. #define FLEXCAN3_ERFFEL117 (IMXRT_FLEXCAN3_ERXFIFO.offset1D4)
  3120. #define FLEXCAN3_ERFFEL118 (IMXRT_FLEXCAN3_ERXFIFO.offset1D8)
  3121. #define FLEXCAN3_ERFFEL119 (IMXRT_FLEXCAN3_ERXFIFO.offset1DC)
  3122. #define FLEXCAN3_ERFFEL120 (IMXRT_FLEXCAN3_ERXFIFO.offset1E0)
  3123. #define FLEXCAN3_ERFFEL121 (IMXRT_FLEXCAN3_ERXFIFO.offset1E4)
  3124. #define FLEXCAN3_ERFFEL122 (IMXRT_FLEXCAN3_ERXFIFO.offset1E8)
  3125. #define FLEXCAN3_ERFFEL123 (IMXRT_FLEXCAN3_ERXFIFO.offset1EC)
  3126. #define FLEXCAN3_ERFFEL124 (IMXRT_FLEXCAN3_ERXFIFO.offset1F0)
  3127. #define FLEXCAN3_ERFFEL125 (IMXRT_FLEXCAN3_ERXFIFO.offset1F4)
  3128. #define FLEXCAN3_ERFFEL126 (IMXRT_FLEXCAN3_ERXFIFO.offset1F8)
  3129. #define FLEXCAN3_ERFFEL127 (IMXRT_FLEXCAN3_ERXFIFO.offset1FC)
  3130. // 27.3.1.1: page 1292
  3131. typedef struct {
  3132. const uint32_t VERID; // 0x00 (IMXRT_FLEXIO1.offset000)
  3133. volatile uint32_t PARAM; // 0x04 // (IMXRT_FLEXIO1.offset004)
  3134. volatile uint32_t CTRL; // 0x08(IMXRT_FLEXIO1.offset008)
  3135. volatile uint32_t PIN; // 0x0c (IMXRT_FLEXIO1.offset00C)
  3136. volatile uint32_t SHIFTSTAT; // 0x10 (IMXRT_FLEXIO1.offset010)
  3137. volatile uint32_t SHIFTERR; // 0x14(IMXRT_FLEXIO1.offset014)
  3138. volatile uint32_t TIMSTAT; // 0x18 (IMXRT_FLEXIO1.offset018)
  3139. const uint32_t UNUSED0; // 0x1c
  3140. volatile uint32_t SHIFTSIEN; // 0x20 (IMXRT_FLEXIO1.offset020)
  3141. volatile uint32_t SHIFTEIEN; // 0x24 (IMXRT_FLEXIO1.offset024)
  3142. volatile uint32_t TIMIEN; // 0x28 (IMXRT_FLEXIO1.offset028)
  3143. const uint32_t UNUSED1; // 0x2c
  3144. volatile uint32_t SHIFTSDEN; // 0x30 (IMXRT_FLEXIO1.offset030)
  3145. const uint32_t UNUSED2[3]; // 0x34 38 3C
  3146. volatile uint32_t SHIFTSTATE; // 0x40 (IMXRT_FLEXIO1.offset040)
  3147. const uint32_t UNUSED3[15]; // 0x44.. 50... 60... 70...
  3148. volatile uint32_t SHIFTCTL[4]; // 0x80 84 88 8C
  3149. const uint32_t UNUSED4[28]; // 0x90 - 0xfc
  3150. volatile uint32_t SHIFTCFG[4]; // 0x100 104 108 10C (IMXRT_FLEXIO1.offset100)
  3151. const uint32_t UNUSED5[60]; // 0x110 - 0x1FC
  3152. volatile uint32_t SHIFTBUF[4]; // 0x200 204 208 20c (IMXRT_FLEXIO1.offset200)
  3153. const uint32_t UNUSED6[28]; //
  3154. volatile uint32_t SHIFTBUFBIS[4]; // 0x280 // (IMXRT_FLEXIO1.offset280)
  3155. const uint32_t UNUSED7[28]; //
  3156. volatile uint32_t SHIFTBUFBYS[4]; // 0x300 (IMXRT_FLEXIO1.offset300)
  3157. const uint32_t UNUSED8[28]; //
  3158. volatile uint32_t SHIFTBUFBBS[4]; // 0x380 (IMXRT_FLEXIO1.offset380)
  3159. const uint32_t UNUSED9[28]; //
  3160. volatile uint32_t TIMCTL[4]; // 0x400
  3161. const uint32_t UNUSED10[28]; //
  3162. volatile uint32_t TIMCFG[4]; // 0x480
  3163. const uint32_t UNUSED11[28]; //
  3164. volatile uint32_t TIMCMP[4]; // 0x500
  3165. const uint32_t UNUSED12[28+64]; //
  3166. volatile uint32_t SHIFTBUFNBS[4]; // 0x680
  3167. const uint32_t UNUSED13[28]; //
  3168. volatile uint32_t SHIFTBUFHWS[4]; // 0x700
  3169. const uint32_t UNUSED14[28]; //
  3170. volatile uint32_t SHIFTBUFNIS[4]; // 0x780
  3171. } IMXRT_FLEXIO_t;
  3172. #define IMXRT_FLEXIO1_S (*(IMXRT_FLEXIO_t *)0x401AC000)
  3173. #define IMXRT_FLEXIO2_S (*(IMXRT_FLEXIO_t *)0x401B0000)
  3174. #define IMXRT_FLEXIO3_S (*(IMXRT_FLEXIO_t *)0x42020000)
  3175. #define IMXRT_FLEXIO1 (*(IMXRT_REGISTER32_t *)0x401AC000)
  3176. #define IMXRT_FLEXIO1_b (*(IMXRT_REGISTER32_t *)0x401AC400)
  3177. #define FLEXIO1_VERID (IMXRT_FLEXIO1.offset000)
  3178. #define FLEXIO1_PARAM (IMXRT_FLEXIO1.offset004)
  3179. #define FLEXIO1_CTRL (IMXRT_FLEXIO1.offset008)
  3180. #define FLEXIO1_PIN (IMXRT_FLEXIO1.offset00C)
  3181. #define FLEXIO1_SHIFTSTAT (IMXRT_FLEXIO1.offset010)
  3182. #define FLEXIO1_SHIFTERR (IMXRT_FLEXIO1.offset014)
  3183. #define FLEXIO1_TIMSTAT (IMXRT_FLEXIO1.offset018)
  3184. #define FLEXIO1_SHIFTSIEN (IMXRT_FLEXIO1.offset020)
  3185. #define FLEXIO1_SHIFTEIEN (IMXRT_FLEXIO1.offset024)
  3186. #define FLEXIO1_TIMIEN (IMXRT_FLEXIO1.offset028)
  3187. #define FLEXIO1_SHIFTSDEN (IMXRT_FLEXIO1.offset030)
  3188. #define FLEXIO1_SHIFTSTATE (IMXRT_FLEXIO1.offset040)
  3189. #define FLEXIO1_SHIFTCTL0 (IMXRT_FLEXIO1.offset080)
  3190. #define FLEXIO1_SHIFTCTL1 (IMXRT_FLEXIO1.offset084)
  3191. #define FLEXIO1_SHIFTCTL2 (IMXRT_FLEXIO1.offset088)
  3192. #define FLEXIO1_SHIFTCTL3 (IMXRT_FLEXIO1.offset08C)
  3193. #define FLEXIO1_SHIFTCFG0 (IMXRT_FLEXIO1.offset100)
  3194. #define FLEXIO1_SHIFTCFG1 (IMXRT_FLEXIO1.offset104)
  3195. #define FLEXIO1_SHIFTCFG2 (IMXRT_FLEXIO1.offset108)
  3196. #define FLEXIO1_SHIFTCFG3 (IMXRT_FLEXIO1.offset10C)
  3197. #define FLEXIO1_SHIFTBUF0 (IMXRT_FLEXIO1.offset200)
  3198. #define FLEXIO1_SHIFTBUF1 (IMXRT_FLEXIO1.offset204)
  3199. #define FLEXIO1_SHIFTBUF2 (IMXRT_FLEXIO1.offset208)
  3200. #define FLEXIO1_SHIFTBUF3 (IMXRT_FLEXIO1.offset20C)
  3201. #define FLEXIO1_SHIFTBUFBIS0 (IMXRT_FLEXIO1.offset280)
  3202. #define FLEXIO1_SHIFTBUFBIS1 (IMXRT_FLEXIO1.offset284)
  3203. #define FLEXIO1_SHIFTBUFBIS2 (IMXRT_FLEXIO1.offset288)
  3204. #define FLEXIO1_SHIFTBUFBIS3 (IMXRT_FLEXIO1.offset28C)
  3205. #define FLEXIO1_SHIFTBUFBYS0 (IMXRT_FLEXIO1.offset300)
  3206. #define FLEXIO1_SHIFTBUFBYS1 (IMXRT_FLEXIO1.offset304)
  3207. #define FLEXIO1_SHIFTBUFBYS2 (IMXRT_FLEXIO1.offset308)
  3208. #define FLEXIO1_SHIFTBUFBYS3 (IMXRT_FLEXIO1.offset30C)
  3209. #define FLEXIO1_SHIFTBUFBBS0 (IMXRT_FLEXIO1.offset380)
  3210. #define FLEXIO1_SHIFTBUFBBS1 (IMXRT_FLEXIO1.offset384)
  3211. #define FLEXIO1_SHIFTBUFBBS2 (IMXRT_FLEXIO1.offset388)
  3212. #define FLEXIO1_SHIFTBUFBBS3 (IMXRT_FLEXIO1.offset38C)
  3213. #define FLEXIO1_TIMCTL0 (IMXRT_FLEXIO1_b.offset000)
  3214. #define FLEXIO1_TIMCTL1 (IMXRT_FLEXIO1_b.offset004)
  3215. #define FLEXIO1_TIMCTL2 (IMXRT_FLEXIO1_b.offset008)
  3216. #define FLEXIO1_TIMCTL3 (IMXRT_FLEXIO1_b.offset00C)
  3217. #define FLEXIO1_TIMCFG0 (IMXRT_FLEXIO1_b.offset080)
  3218. #define FLEXIO1_TIMCFG1 (IMXRT_FLEXIO1_b.offset084)
  3219. #define FLEXIO1_TIMCFG2 (IMXRT_FLEXIO1_b.offset088)
  3220. #define FLEXIO1_TIMCFG3 (IMXRT_FLEXIO1_b.offset08C)
  3221. #define FLEXIO1_TIMCMP0 (IMXRT_FLEXIO1_b.offset100)
  3222. #define FLEXIO1_TIMCMP1 (IMXRT_FLEXIO1_b.offset104)
  3223. #define FLEXIO1_TIMCMP2 (IMXRT_FLEXIO1_b.offset108)
  3224. #define FLEXIO1_TIMCMP3 (IMXRT_FLEXIO1_b.offset10C)
  3225. #define FLEXIO1_SHIFTBUFNBS0 (IMXRT_FLEXIO1_b.offset280)
  3226. #define FLEXIO1_SHIFTBUFNBS1 (IMXRT_FLEXIO1_b.offset284)
  3227. #define FLEXIO1_SHIFTBUFNBS2 (IMXRT_FLEXIO1_b.offset288)
  3228. #define FLEXIO1_SHIFTBUFNBS3 (IMXRT_FLEXIO1_b.offset28C)
  3229. #define FLEXIO1_SHIFTBUFHWS0 (IMXRT_FLEXIO1_b.offset300)
  3230. #define FLEXIO1_SHIFTBUFHWS1 (IMXRT_FLEXIO1_b.offset304)
  3231. #define FLEXIO1_SHIFTBUFHWS2 (IMXRT_FLEXIO1_b.offset308)
  3232. #define FLEXIO1_SHIFTBUFHWS3 (IMXRT_FLEXIO1_b.offset30C)
  3233. #define FLEXIO1_SHIFTBUFNIS0 (IMXRT_FLEXIO1_b.offset380)
  3234. #define FLEXIO1_SHIFTBUFNIS1 (IMXRT_FLEXIO1_b.offset384)
  3235. #define FLEXIO1_SHIFTBUFNIS2 (IMXRT_FLEXIO1_b.offset388)
  3236. #define FLEXIO1_SHIFTBUFNIS3 (IMXRT_FLEXIO1_b.offset38C)
  3237. #define IMXRT_FLEXIO2 (*(IMXRT_REGISTER32_t *)0x401B0000)
  3238. #define IMXRT_FLEXIO2_b (*(IMXRT_REGISTER32_t *)0x401B0400)
  3239. #define FLEXIO2_VERID (IMXRT_FLEXIO2.offset000)
  3240. #define FLEXIO2_PARAM (IMXRT_FLEXIO2.offset004)
  3241. #define FLEXIO2_CTRL (IMXRT_FLEXIO2.offset008)
  3242. #define FLEXIO2_PIN (IMXRT_FLEXIO2.offset00C)
  3243. #define FLEXIO2_SHIFTSTAT (IMXRT_FLEXIO2.offset010)
  3244. #define FLEXIO2_SHIFTERR (IMXRT_FLEXIO2.offset014)
  3245. #define FLEXIO2_TIMSTAT (IMXRT_FLEXIO2.offset018)
  3246. #define FLEXIO2_SHIFTSIEN (IMXRT_FLEXIO2.offset020)
  3247. #define FLEXIO2_SHIFTEIEN (IMXRT_FLEXIO2.offset024)
  3248. #define FLEXIO2_TIMIEN (IMXRT_FLEXIO2.offset028)
  3249. #define FLEXIO2_SHIFTSDEN (IMXRT_FLEXIO2.offset030)
  3250. #define FLEXIO2_SHIFTSTATE (IMXRT_FLEXIO2.offset040)
  3251. #define FLEXIO2_SHIFTCTL0 (IMXRT_FLEXIO2.offset080)
  3252. #define FLEXIO2_SHIFTCTL1 (IMXRT_FLEXIO2.offset084)
  3253. #define FLEXIO2_SHIFTCTL2 (IMXRT_FLEXIO2.offset088)
  3254. #define FLEXIO2_SHIFTCTL3 (IMXRT_FLEXIO2.offset08C)
  3255. #define FLEXIO2_SHIFTCFG0 (IMXRT_FLEXIO2.offset100)
  3256. #define FLEXIO2_SHIFTCFG1 (IMXRT_FLEXIO2.offset104)
  3257. #define FLEXIO2_SHIFTCFG2 (IMXRT_FLEXIO2.offset108)
  3258. #define FLEXIO2_SHIFTCFG3 (IMXRT_FLEXIO2.offset10C)
  3259. #define FLEXIO2_SHIFTBUF0 (IMXRT_FLEXIO2.offset200)
  3260. #define FLEXIO2_SHIFTBUF1 (IMXRT_FLEXIO2.offset204)
  3261. #define FLEXIO2_SHIFTBUF2 (IMXRT_FLEXIO2.offset208)
  3262. #define FLEXIO2_SHIFTBUF3 (IMXRT_FLEXIO2.offset20C)
  3263. #define FLEXIO2_SHIFTBUFBIS0 (IMXRT_FLEXIO2.offset280)
  3264. #define FLEXIO2_SHIFTBUFBIS1 (IMXRT_FLEXIO2.offset284)
  3265. #define FLEXIO2_SHIFTBUFBIS2 (IMXRT_FLEXIO2.offset288)
  3266. #define FLEXIO2_SHIFTBUFBIS3 (IMXRT_FLEXIO2.offset28C)
  3267. #define FLEXIO2_SHIFTBUFBYS0 (IMXRT_FLEXIO2.offset300)
  3268. #define FLEXIO2_SHIFTBUFBYS1 (IMXRT_FLEXIO2.offset304)
  3269. #define FLEXIO2_SHIFTBUFBYS2 (IMXRT_FLEXIO2.offset308)
  3270. #define FLEXIO2_SHIFTBUFBYS3 (IMXRT_FLEXIO2.offset30C)
  3271. #define FLEXIO2_SHIFTBUFBBS0 (IMXRT_FLEXIO2.offset380)
  3272. #define FLEXIO2_SHIFTBUFBBS1 (IMXRT_FLEXIO2.offset384)
  3273. #define FLEXIO2_SHIFTBUFBBS2 (IMXRT_FLEXIO2.offset388)
  3274. #define FLEXIO2_SHIFTBUFBBS3 (IMXRT_FLEXIO2.offset38C)
  3275. #define FLEXIO2_TIMCTL0 (IMXRT_FLEXIO2_b.offset000)
  3276. #define FLEXIO2_TIMCTL1 (IMXRT_FLEXIO2_b.offset004)
  3277. #define FLEXIO2_TIMCTL2 (IMXRT_FLEXIO2_b.offset008)
  3278. #define FLEXIO2_TIMCTL3 (IMXRT_FLEXIO2_b.offset00C)
  3279. #define FLEXIO2_TIMCFG0 (IMXRT_FLEXIO2_b.offset080)
  3280. #define FLEXIO2_TIMCFG1 (IMXRT_FLEXIO2_b.offset084)
  3281. #define FLEXIO2_TIMCFG2 (IMXRT_FLEXIO2_b.offset088)
  3282. #define FLEXIO2_TIMCFG3 (IMXRT_FLEXIO2_b.offset08C)
  3283. #define FLEXIO2_TIMCMP0 (IMXRT_FLEXIO2_b.offset100)
  3284. #define FLEXIO2_TIMCMP1 (IMXRT_FLEXIO2_b.offset104)
  3285. #define FLEXIO2_TIMCMP2 (IMXRT_FLEXIO2_b.offset108)
  3286. #define FLEXIO2_TIMCMP3 (IMXRT_FLEXIO2_b.offset10C)
  3287. #define FLEXIO2_SHIFTBUFNBS0 (IMXRT_FLEXIO2_b.offset280)
  3288. #define FLEXIO2_SHIFTBUFNBS1 (IMXRT_FLEXIO2_b.offset284)
  3289. #define FLEXIO2_SHIFTBUFNBS2 (IMXRT_FLEXIO2_b.offset288)
  3290. #define FLEXIO2_SHIFTBUFNBS3 (IMXRT_FLEXIO2_b.offset28C)
  3291. #define FLEXIO2_SHIFTBUFHWS0 (IMXRT_FLEXIO2_b.offset300)
  3292. #define FLEXIO2_SHIFTBUFHWS1 (IMXRT_FLEXIO2_b.offset304)
  3293. #define FLEXIO2_SHIFTBUFHWS2 (IMXRT_FLEXIO2_b.offset308)
  3294. #define FLEXIO2_SHIFTBUFHWS3 (IMXRT_FLEXIO2_b.offset30C)
  3295. #define FLEXIO2_SHIFTBUFNIS0 (IMXRT_FLEXIO2_b.offset380)
  3296. #define FLEXIO2_SHIFTBUFNIS1 (IMXRT_FLEXIO2_b.offset384)
  3297. #define FLEXIO2_SHIFTBUFNIS2 (IMXRT_FLEXIO2_b.offset388)
  3298. #define FLEXIO2_SHIFTBUFNIS3 (IMXRT_FLEXIO2_b.offset38C)
  3299. // FLEXIO3 only present in RT1062
  3300. #define IMXRT_FLEXIO3 (*(IMXRT_REGISTER32_t *)0x42020000)
  3301. #define IMXRT_FLEXIO3_b (*(IMXRT_REGISTER32_t *)0x42020400)
  3302. #define FLEXIO3_VERID (IMXRT_FLEXIO3.offset000)
  3303. #define FLEXIO3_PARAM (IMXRT_FLEXIO3.offset004)
  3304. #define FLEXIO3_CTRL (IMXRT_FLEXIO3.offset008)
  3305. #define FLEXIO3_PIN (IMXRT_FLEXIO3.offset00C)
  3306. #define FLEXIO3_SHIFTSTAT (IMXRT_FLEXIO3.offset010)
  3307. #define FLEXIO3_SHIFTERR (IMXRT_FLEXIO3.offset014)
  3308. #define FLEXIO3_TIMSTAT (IMXRT_FLEXIO3.offset018)
  3309. #define FLEXIO3_SHIFTSIEN (IMXRT_FLEXIO3.offset020)
  3310. #define FLEXIO3_SHIFTEIEN (IMXRT_FLEXIO3.offset024)
  3311. #define FLEXIO3_TIMIEN (IMXRT_FLEXIO3.offset028)
  3312. #define FLEXIO3_SHIFTSDEN (IMXRT_FLEXIO3.offset030)
  3313. #define FLEXIO3_SHIFTSTATE (IMXRT_FLEXIO3.offset040)
  3314. #define FLEXIO3_SHIFTCTL0 (IMXRT_FLEXIO3.offset080)
  3315. #define FLEXIO3_SHIFTCTL1 (IMXRT_FLEXIO3.offset084)
  3316. #define FLEXIO3_SHIFTCTL2 (IMXRT_FLEXIO3.offset088)
  3317. #define FLEXIO3_SHIFTCTL3 (IMXRT_FLEXIO3.offset08C)
  3318. #define FLEXIO3_SHIFTCFG0 (IMXRT_FLEXIO3.offset100)
  3319. #define FLEXIO3_SHIFTCFG1 (IMXRT_FLEXIO3.offset104)
  3320. #define FLEXIO3_SHIFTCFG2 (IMXRT_FLEXIO3.offset108)
  3321. #define FLEXIO3_SHIFTCFG3 (IMXRT_FLEXIO3.offset10C)
  3322. #define FLEXIO3_SHIFTBUF0 (IMXRT_FLEXIO3.offset200)
  3323. #define FLEXIO3_SHIFTBUF1 (IMXRT_FLEXIO3.offset204)
  3324. #define FLEXIO3_SHIFTBUF2 (IMXRT_FLEXIO3.offset208)
  3325. #define FLEXIO3_SHIFTBUF3 (IMXRT_FLEXIO3.offset20C)
  3326. #define FLEXIO3_SHIFTBUFBIS0 (IMXRT_FLEXIO3.offset280)
  3327. #define FLEXIO3_SHIFTBUFBIS1 (IMXRT_FLEXIO3.offset284)
  3328. #define FLEXIO3_SHIFTBUFBIS2 (IMXRT_FLEXIO3.offset288)
  3329. #define FLEXIO3_SHIFTBUFBIS3 (IMXRT_FLEXIO3.offset28C)
  3330. #define FLEXIO3_SHIFTBUFBYS0 (IMXRT_FLEXIO3.offset300)
  3331. #define FLEXIO3_SHIFTBUFBYS1 (IMXRT_FLEXIO3.offset304)
  3332. #define FLEXIO3_SHIFTBUFBYS2 (IMXRT_FLEXIO3.offset308)
  3333. #define FLEXIO3_SHIFTBUFBYS3 (IMXRT_FLEXIO3.offset30C)
  3334. #define FLEXIO3_SHIFTBUFBBS0 (IMXRT_FLEXIO3.offset380)
  3335. #define FLEXIO3_SHIFTBUFBBS1 (IMXRT_FLEXIO3.offset384)
  3336. #define FLEXIO3_SHIFTBUFBBS2 (IMXRT_FLEXIO3.offset388)
  3337. #define FLEXIO3_SHIFTBUFBBS3 (IMXRT_FLEXIO3.offset38C)
  3338. #define FLEXIO3_TIMCTL0 (IMXRT_FLEXIO3_b.offset000)
  3339. #define FLEXIO3_TIMCTL1 (IMXRT_FLEXIO3_b.offset004)
  3340. #define FLEXIO3_TIMCTL2 (IMXRT_FLEXIO3_b.offset008)
  3341. #define FLEXIO3_TIMCTL3 (IMXRT_FLEXIO3_b.offset00C)
  3342. #define FLEXIO3_TIMCFG0 (IMXRT_FLEXIO3_b.offset080)
  3343. #define FLEXIO3_TIMCFG1 (IMXRT_FLEXIO3_b.offset084)
  3344. #define FLEXIO3_TIMCFG2 (IMXRT_FLEXIO3_b.offset088)
  3345. #define FLEXIO3_TIMCFG3 (IMXRT_FLEXIO3_b.offset08C)
  3346. #define FLEXIO3_TIMCMP0 (IMXRT_FLEXIO3_b.offset100)
  3347. #define FLEXIO3_TIMCMP1 (IMXRT_FLEXIO3_b.offset104)
  3348. #define FLEXIO3_TIMCMP2 (IMXRT_FLEXIO3_b.offset108)
  3349. #define FLEXIO3_TIMCMP3 (IMXRT_FLEXIO3_b.offset10C)
  3350. #define FLEXIO3_SHIFTBUFNBS0 (IMXRT_FLEXIO3_b.offset280)
  3351. #define FLEXIO3_SHIFTBUFNBS1 (IMXRT_FLEXIO3_b.offset284)
  3352. #define FLEXIO3_SHIFTBUFNBS2 (IMXRT_FLEXIO3_b.offset288)
  3353. #define FLEXIO3_SHIFTBUFNBS3 (IMXRT_FLEXIO3_b.offset28C)
  3354. #define FLEXIO3_SHIFTBUFHWS0 (IMXRT_FLEXIO3_b.offset300)
  3355. #define FLEXIO3_SHIFTBUFHWS1 (IMXRT_FLEXIO3_b.offset304)
  3356. #define FLEXIO3_SHIFTBUFHWS2 (IMXRT_FLEXIO3_b.offset308)
  3357. #define FLEXIO3_SHIFTBUFHWS3 (IMXRT_FLEXIO3_b.offset30C)
  3358. #define FLEXIO3_SHIFTBUFNIS0 (IMXRT_FLEXIO3_b.offset380)
  3359. #define FLEXIO3_SHIFTBUFNIS1 (IMXRT_FLEXIO3_b.offset384)
  3360. #define FLEXIO3_SHIFTBUFNIS2 (IMXRT_FLEXIO3_b.offset388)
  3361. #define FLEXIO3_SHIFTBUFNIS3 (IMXRT_FLEXIO3_b.offset38C)
  3362. #define FLEXIO_CTRL_DOZEN ((uint32_t)(1<<31))
  3363. #define FLEXIO_CTRL_DBGE ((uint32_t)(1<<30))
  3364. #define FLEXIO_CTRL_FASTACC ((uint32_t)(1<<2))
  3365. #define FLEXIO_CTRL_SWRST ((uint32_t)(1<<1))
  3366. #define FLEXIO_CTRL_FLEXEN ((uint32_t)(1<<0))
  3367. #define FLEXIO_SHIFTCTL_TIMSEL(n) ((uint32_t)(((n) & 0x03) << 24))
  3368. #define FLEXIO_SHIFTCTL_TIMPOL ((uint32_t)(1<<23))
  3369. #define FLEXIO_SHIFTCTL_PINCFG(n) ((uint32_t)(((n) & 0x03) << 16))
  3370. #define FLEXIO_SHIFTCTL_PINSEL(n) ((uint32_t)(((n) & 0x1F) << 8))
  3371. #define FLEXIO_SHIFTCTL_PINPOL ((uint32_t)(1<<7))
  3372. #define FLEXIO_SHIFTCTL_SMOD(n) ((uint32_t)(((n) & 0x07) << 0))
  3373. #define FLEXIO_SHIFTCFG_PWIDTH(n) ((uint32_t)(((n) & 0x1F) << 16))
  3374. #define FLEXIO_SHIFTCFG_INSRC ((uint32_t)(1<<8))
  3375. #define FLEXIO_SHIFTCFG_SSTOP(n) ((uint32_t)(((n) & 0x03) << 4))
  3376. #define FLEXIO_SHIFTCFG_SSTART(n) ((uint32_t)(((n) & 0x03) << 0))
  3377. #define FLEXIO_TIMCTL_TRGSEL(n) ((uint32_t)(((n) & 0x3F) << 24))
  3378. #define FLEXIO_TIMCTL_TRGPOL ((uint32_t)(1<<23))
  3379. #define FLEXIO_TIMCTL_TRGSRC ((uint32_t)(1<<22))
  3380. #define FLEXIO_TIMCTL_PINCFG(n) ((uint32_t)(((n) & 0x03) << 16))
  3381. #define FLEXIO_TIMCTL_PINSEL(n) ((uint32_t)(((n) & 0x1F) << 8))
  3382. #define FLEXIO_TIMCTL_PINPOL ((uint32_t)(1<<7))
  3383. #define FLEXIO_TIMCTL_TIMOD(n) ((uint32_t)(((n) & 0x03) << 0))
  3384. #define FLEXIO_TIMCFG_TIMOUT(n) ((uint32_t)(((n) & 0x03) << 24))
  3385. #define FLEXIO_TIMCFG_TIMDEC(n) ((uint32_t)(((n) & 0x03) << 20))
  3386. #define FLEXIO_TIMCFG_TIMRST(n) ((uint32_t)(((n) & 0x07) << 16))
  3387. #define FLEXIO_TIMCFG_TIMDIS(n) ((uint32_t)(((n) & 0x07) << 12))
  3388. #define FLEXIO_TIMCFG_TIMENA(n) ((uint32_t)(((n) & 0x07) << 8))
  3389. #define FLEXIO_TIMCFG_TSTOP(n) ((uint32_t)(((n) & 0x03) << 4))
  3390. #define FLEXIO_TIMCFG_TSTART ((uint32_t)(1<<1))
  3391. // 28.4.1: page 1354
  3392. typedef struct {
  3393. struct {
  3394. volatile uint16_t CNT;
  3395. volatile uint16_t INIT;
  3396. volatile uint16_t CTRL2;
  3397. volatile uint16_t CTRL;
  3398. volatile uint16_t unused1;
  3399. volatile uint16_t VAL0;
  3400. volatile uint16_t FRACVAL1;
  3401. volatile uint16_t VAL1;
  3402. volatile uint16_t FRACVAL2;
  3403. volatile uint16_t VAL2;
  3404. volatile uint16_t FRACVAL3;
  3405. volatile uint16_t VAL3;
  3406. volatile uint16_t FRACVAL4;
  3407. volatile uint16_t VAL4;
  3408. volatile uint16_t FRACVAL5;
  3409. volatile uint16_t VAL5;
  3410. volatile uint16_t FRCTRL;
  3411. volatile uint16_t OCTRL;
  3412. volatile uint16_t STS;
  3413. volatile uint16_t INTEN;
  3414. volatile uint16_t DMAEN;
  3415. volatile uint16_t TCTRL;
  3416. volatile uint16_t DISMAP0;
  3417. volatile uint16_t DISMAP1;
  3418. volatile uint16_t DTCNT0;
  3419. volatile uint16_t DTCNT1;
  3420. volatile uint16_t CAPTCTRLA;
  3421. volatile uint16_t CAPTCOMPA;
  3422. volatile uint16_t CAPTCTRLB;
  3423. volatile uint16_t CAPTCOMPB;
  3424. volatile uint16_t CAPTCTRLX;
  3425. volatile uint16_t CAPTCOMPX;
  3426. volatile uint16_t CVAL0;
  3427. volatile uint16_t CVAL0CYC;
  3428. volatile uint16_t CVAL1;
  3429. volatile uint16_t CVAL1CYC;
  3430. volatile uint16_t CVAL2;
  3431. volatile uint16_t CVAL2CYC;
  3432. volatile uint16_t CVAL3;
  3433. volatile uint16_t CVAL3CYC;
  3434. volatile uint16_t CVAL4;
  3435. volatile uint16_t CVAL4CYC;
  3436. volatile uint16_t CVAL5;
  3437. volatile uint16_t CVAL5CYC;
  3438. volatile uint16_t unused2;
  3439. volatile uint16_t unused3;
  3440. volatile uint16_t unused4;
  3441. volatile uint16_t unused5;
  3442. } SM[4];
  3443. volatile uint16_t OUTEN;
  3444. volatile uint16_t MASK;
  3445. volatile uint16_t SWCOUT;
  3446. volatile uint16_t DTSRCSEL;
  3447. volatile uint16_t MCTRL;
  3448. volatile uint16_t MCTRL2;
  3449. volatile uint16_t FCTRL0;
  3450. volatile uint16_t FSTS0;
  3451. volatile uint16_t FFILT0;
  3452. volatile uint16_t FTST0;
  3453. volatile uint16_t FCTRL20;
  3454. } IMXRT_FLEXPWM_t;
  3455. #define IMXRT_FLEXPWM1 (*(IMXRT_FLEXPWM_t *)0x403DC000)
  3456. #define IMXRT_FLEXPWM2 (*(IMXRT_FLEXPWM_t *)0x403E0000)
  3457. #define IMXRT_FLEXPWM3 (*(IMXRT_FLEXPWM_t *)0x403E4000)
  3458. #define IMXRT_FLEXPWM4 (*(IMXRT_FLEXPWM_t *)0x403E8000)
  3459. #define FLEXPWM1_SM0CNT (IMXRT_FLEXPWM1.SM[0].CNT)
  3460. #define FLEXPWM1_SM0INIT (IMXRT_FLEXPWM1.SM[0].INIT)
  3461. #define FLEXPWM1_SM0CTRL2 (IMXRT_FLEXPWM1.SM[0].CTRL2)
  3462. #define FLEXPWM1_SM0CTRL (IMXRT_FLEXPWM1.SM[0].CTRL)
  3463. #define FLEXPWM1_SM0VAL0 (IMXRT_FLEXPWM1.SM[0].VAL0)
  3464. #define FLEXPWM1_SM0FRACVAL1 (IMXRT_FLEXPWM1.SM[0].FRACVAL1)
  3465. #define FLEXPWM1_SM0VAL1 (IMXRT_FLEXPWM1.SM[0].VAL1)
  3466. #define FLEXPWM1_SM0FRACVAL2 (IMXRT_FLEXPWM1.SM[0].FRACVAL2)
  3467. #define FLEXPWM1_SM0VAL2 (IMXRT_FLEXPWM1.SM[0].VAL2)
  3468. #define FLEXPWM1_SM0FRACVAL3 (IMXRT_FLEXPWM1.SM[0].FRACVAL3)
  3469. #define FLEXPWM1_SM0VAL3 (IMXRT_FLEXPWM1.SM[0].VAL3)
  3470. #define FLEXPWM1_SM0FRACVAL4 (IMXRT_FLEXPWM1.SM[0].FRACVAL4)
  3471. #define FLEXPWM1_SM0VAL4 (IMXRT_FLEXPWM1.SM[0].VAL4)
  3472. #define FLEXPWM1_SM0FRACVAL5 (IMXRT_FLEXPWM1.SM[0].FRACVAL5)
  3473. #define FLEXPWM1_SM0VAL5 (IMXRT_FLEXPWM1.SM[0].VAL5)
  3474. #define FLEXPWM1_SM0FRCTRL (IMXRT_FLEXPWM1.SM[0].FRCTRL)
  3475. #define FLEXPWM1_SM0OCTRL (IMXRT_FLEXPWM1.SM[0].OCTRL)
  3476. #define FLEXPWM1_SM0STS (IMXRT_FLEXPWM1.SM[0].STS)
  3477. #define FLEXPWM1_SM0INTEN (IMXRT_FLEXPWM1.SM[0].INTEN)
  3478. #define FLEXPWM1_SM0DMAEN (IMXRT_FLEXPWM1.SM[0].DMAEN)
  3479. #define FLEXPWM1_SM0TCTRL (IMXRT_FLEXPWM1.SM[0].TCTRL)
  3480. #define FLEXPWM1_SM0DISMAP0 (IMXRT_FLEXPWM1.SM[0].DISMAP0)
  3481. #define FLEXPWM1_SM0DISMAP1 (IMXRT_FLEXPWM1.SM[0].DISMAP1)
  3482. #define FLEXPWM1_SM0DTCNT0 (IMXRT_FLEXPWM1.SM[0].DTCNT0)
  3483. #define FLEXPWM1_SM0DTCNT1 (IMXRT_FLEXPWM1.SM[0].DTCNT1)
  3484. #define FLEXPWM1_SM0CAPTCTRLA (IMXRT_FLEXPWM1.SM[0].CAPTCTRLA)
  3485. #define FLEXPWM1_SM0CAPTCOMPA (IMXRT_FLEXPWM1.SM[0].CAPTCOMPA)
  3486. #define FLEXPWM1_SM0CAPTCTRLB (IMXRT_FLEXPWM1.SM[0].CAPTCTRLB)
  3487. #define FLEXPWM1_SM0CAPTCOMPB (IMXRT_FLEXPWM1.SM[0].CAPTCOMPB)
  3488. #define FLEXPWM1_SM0CAPTCTRLX (IMXRT_FLEXPWM1.SM[0].CAPTCTRLX)
  3489. #define FLEXPWM1_SM0CAPTCOMPX (IMXRT_FLEXPWM1.SM[0].CAPTCOMPX)
  3490. #define FLEXPWM1_SM0CVAL0 (IMXRT_FLEXPWM1.SM[0].CVAL0)
  3491. #define FLEXPWM1_SM0CVAL0CYC (IMXRT_FLEXPWM1.SM[0].CVAL0CYC)
  3492. #define FLEXPWM1_SM0CVAL1 (IMXRT_FLEXPWM1.SM[0].CVAL1)
  3493. #define FLEXPWM1_SM0CVAL1CYC (IMXRT_FLEXPWM1.SM[0].CVAL1CYC)
  3494. #define FLEXPWM1_SM0CVAL2 (IMXRT_FLEXPWM1.SM[0].CVAL2)
  3495. #define FLEXPWM1_SM0CVAL2CYC (IMXRT_FLEXPWM1.SM[0].CVAL2CYC)
  3496. #define FLEXPWM1_SM0CVAL3 (IMXRT_FLEXPWM1.SM[0].CVAL3)
  3497. #define FLEXPWM1_SM0CVAL3CYC (IMXRT_FLEXPWM1.SM[0].CVAL3CYC)
  3498. #define FLEXPWM1_SM0CVAL4 (IMXRT_FLEXPWM1.SM[0].CVAL4)
  3499. #define FLEXPWM1_SM0CVAL4CYC (IMXRT_FLEXPWM1.SM[0].CVAL4CYC)
  3500. #define FLEXPWM1_SM0CVAL5 (IMXRT_FLEXPWM1.SM[0].CVAL5)
  3501. #define FLEXPWM1_SM0CVAL5CYC (IMXRT_FLEXPWM1.SM[0].CVAL5CYC)
  3502. #define FLEXPWM1_SM1CNT (IMXRT_FLEXPWM1.SM[1].CNT)
  3503. #define FLEXPWM1_SM1INIT (IMXRT_FLEXPWM1.SM[1].INIT)
  3504. #define FLEXPWM1_SM1CTRL2 (IMXRT_FLEXPWM1.SM[1].CTRL2)
  3505. #define FLEXPWM1_SM1CTRL (IMXRT_FLEXPWM1.SM[1].CTRL)
  3506. #define FLEXPWM1_SM1VAL0 (IMXRT_FLEXPWM1.SM[1].VAL0)
  3507. #define FLEXPWM1_SM1FRACVAL1 (IMXRT_FLEXPWM1.SM[1].FRACVAL1)
  3508. #define FLEXPWM1_SM1VAL1 (IMXRT_FLEXPWM1.SM[1].VAL1)
  3509. #define FLEXPWM1_SM1FRACVAL2 (IMXRT_FLEXPWM1.SM[1].FRACVAL2)
  3510. #define FLEXPWM1_SM1VAL2 (IMXRT_FLEXPWM1.SM[1].VAL2)
  3511. #define FLEXPWM1_SM1FRACVAL3 (IMXRT_FLEXPWM1.SM[1].FRACVAL3)
  3512. #define FLEXPWM1_SM1VAL3 (IMXRT_FLEXPWM1.SM[1].VAL3)
  3513. #define FLEXPWM1_SM1FRACVAL4 (IMXRT_FLEXPWM1.SM[1].FRACVAL4)
  3514. #define FLEXPWM1_SM1VAL4 (IMXRT_FLEXPWM1.SM[1].VAL4)
  3515. #define FLEXPWM1_SM1FRACVAL5 (IMXRT_FLEXPWM1.SM[1].FRACVAL5)
  3516. #define FLEXPWM1_SM1VAL5 (IMXRT_FLEXPWM1.SM[1].VAL5)
  3517. #define FLEXPWM1_SM1FRCTRL (IMXRT_FLEXPWM1.SM[1].FRCTRL)
  3518. #define FLEXPWM1_SM1OCTRL (IMXRT_FLEXPWM1.SM[1].OCTRL)
  3519. #define FLEXPWM1_SM1STS (IMXRT_FLEXPWM1.SM[1].STS)
  3520. #define FLEXPWM1_SM1INTEN (IMXRT_FLEXPWM1.SM[1].INTEN)
  3521. #define FLEXPWM1_SM1DMAEN (IMXRT_FLEXPWM1.SM[1].DMAEN)
  3522. #define FLEXPWM1_SM1TCTRL (IMXRT_FLEXPWM1.SM[1].TCTRL)
  3523. #define FLEXPWM1_SM1DISMAP0 (IMXRT_FLEXPWM1.SM[1].DISMAP0)
  3524. #define FLEXPWM1_SM1DISMAP1 (IMXRT_FLEXPWM1.SM[1].DISMAP1)
  3525. #define FLEXPWM1_SM1DTCNT0 (IMXRT_FLEXPWM1.SM[1].DTCNT0)
  3526. #define FLEXPWM1_SM1DTCNT1 (IMXRT_FLEXPWM1.SM[1].DTCNT1)
  3527. #define FLEXPWM1_SM1CAPTCTRLA (IMXRT_FLEXPWM1.SM[1].CAPTCTRLA)
  3528. #define FLEXPWM1_SM1CAPTCOMPA (IMXRT_FLEXPWM1.SM[1].CAPTCOMPA)
  3529. #define FLEXPWM1_SM1CAPTCTRLB (IMXRT_FLEXPWM1.SM[1].CAPTCTRLB)
  3530. #define FLEXPWM1_SM1CAPTCOMPB (IMXRT_FLEXPWM1.SM[1].CAPTCOMPB)
  3531. #define FLEXPWM1_SM1CAPTCTRLX (IMXRT_FLEXPWM1.SM[1].CAPTCTRLX)
  3532. #define FLEXPWM1_SM1CAPTCOMPX (IMXRT_FLEXPWM1.SM[1].CAPTCOMPX)
  3533. #define FLEXPWM1_SM1CVAL0 (IMXRT_FLEXPWM1.SM[1].CVAL0)
  3534. #define FLEXPWM1_SM1CVAL0CYC (IMXRT_FLEXPWM1.SM[1].CVAL0CYC)
  3535. #define FLEXPWM1_SM1CVAL1 (IMXRT_FLEXPWM1.SM[1].CVAL1)
  3536. #define FLEXPWM1_SM1CVAL1CYC (IMXRT_FLEXPWM1.SM[1].CVAL1CYC)
  3537. #define FLEXPWM1_SM1CVAL2 (IMXRT_FLEXPWM1.SM[1].CVAL2)
  3538. #define FLEXPWM1_SM1CVAL2CYC (IMXRT_FLEXPWM1.SM[1].CVAL2CYC)
  3539. #define FLEXPWM1_SM1CVAL3 (IMXRT_FLEXPWM1.SM[1].CVAL3)
  3540. #define FLEXPWM1_SM1CVAL3CYC (IMXRT_FLEXPWM1.SM[1].CVAL3CYC)
  3541. #define FLEXPWM1_SM1CVAL4 (IMXRT_FLEXPWM1.SM[1].CVAL4)
  3542. #define FLEXPWM1_SM1CVAL4CYC (IMXRT_FLEXPWM1.SM[1].CVAL4CYC)
  3543. #define FLEXPWM1_SM1CVAL5 (IMXRT_FLEXPWM1.SM[1].CVAL5)
  3544. #define FLEXPWM1_SM1CVAL5CYC (IMXRT_FLEXPWM1.SM[1].CVAL5CYC)
  3545. #define FLEXPWM1_SM2CNT (IMXRT_FLEXPWM1.SM[2].CNT)
  3546. #define FLEXPWM1_SM2INIT (IMXRT_FLEXPWM1.SM[2].INIT)
  3547. #define FLEXPWM1_SM2CTRL2 (IMXRT_FLEXPWM1.SM[2].CTRL2)
  3548. #define FLEXPWM1_SM2CTRL (IMXRT_FLEXPWM1.SM[2].CTRL)
  3549. #define FLEXPWM1_SM2VAL0 (IMXRT_FLEXPWM1.SM[2].VAL0)
  3550. #define FLEXPWM1_SM2FRACVAL1 (IMXRT_FLEXPWM1.SM[2].FRACVAL1)
  3551. #define FLEXPWM1_SM2VAL1 (IMXRT_FLEXPWM1.SM[2].VAL1)
  3552. #define FLEXPWM1_SM2FRACVAL2 (IMXRT_FLEXPWM1.SM[2].FRACVAL2)
  3553. #define FLEXPWM1_SM2VAL2 (IMXRT_FLEXPWM1.SM[2].VAL2)
  3554. #define FLEXPWM1_SM2FRACVAL3 (IMXRT_FLEXPWM1.SM[2].FRACVAL3)
  3555. #define FLEXPWM1_SM2VAL3 (IMXRT_FLEXPWM1.SM[2].VAL3)
  3556. #define FLEXPWM1_SM2FRACVAL4 (IMXRT_FLEXPWM1.SM[2].FRACVAL4)
  3557. #define FLEXPWM1_SM2VAL4 (IMXRT_FLEXPWM1.SM[2].VAL4)
  3558. #define FLEXPWM1_SM2FRACVAL5 (IMXRT_FLEXPWM1.SM[2].FRACVAL5)
  3559. #define FLEXPWM1_SM2VAL5 (IMXRT_FLEXPWM1.SM[2].VAL5)
  3560. #define FLEXPWM1_SM2FRCTRL (IMXRT_FLEXPWM1.SM[2].FRCTRL)
  3561. #define FLEXPWM1_SM2OCTRL (IMXRT_FLEXPWM1.SM[2].OCTRL)
  3562. #define FLEXPWM1_SM2STS (IMXRT_FLEXPWM1.SM[2].STS)
  3563. #define FLEXPWM1_SM2INTEN (IMXRT_FLEXPWM1.SM[2].INTEN)
  3564. #define FLEXPWM1_SM2DMAEN (IMXRT_FLEXPWM1.SM[2].DMAEN)
  3565. #define FLEXPWM1_SM2TCTRL (IMXRT_FLEXPWM1.SM[2].TCTRL)
  3566. #define FLEXPWM1_SM2DISMAP0 (IMXRT_FLEXPWM1.SM[2].DISMAP0)
  3567. #define FLEXPWM1_SM2DISMAP1 (IMXRT_FLEXPWM1.SM[2].DISMAP1)
  3568. #define FLEXPWM1_SM2DTCNT0 (IMXRT_FLEXPWM1.SM[2].DTCNT0)
  3569. #define FLEXPWM1_SM2DTCNT1 (IMXRT_FLEXPWM1.SM[2].DTCNT1)
  3570. #define FLEXPWM1_SM2CAPTCTRLA (IMXRT_FLEXPWM1.SM[2].CAPTCTRLA)
  3571. #define FLEXPWM1_SM2CAPTCOMPA (IMXRT_FLEXPWM1.SM[2].CAPTCOMPA)
  3572. #define FLEXPWM1_SM2CAPTCTRLB (IMXRT_FLEXPWM1.SM[2].CAPTCTRLB)
  3573. #define FLEXPWM1_SM2CAPTCOMPB (IMXRT_FLEXPWM1.SM[2].CAPTCOMPB)
  3574. #define FLEXPWM1_SM2CAPTCTRLX (IMXRT_FLEXPWM1.SM[2].CAPTCTRLX)
  3575. #define FLEXPWM1_SM2CAPTCOMPX (IMXRT_FLEXPWM1.SM[2].CAPTCOMPX)
  3576. #define FLEXPWM1_SM2CVAL0 (IMXRT_FLEXPWM1.SM[2].CVAL0)
  3577. #define FLEXPWM1_SM2CVAL0CYC (IMXRT_FLEXPWM1.SM[2].CVAL0CYC)
  3578. #define FLEXPWM1_SM2CVAL1 (IMXRT_FLEXPWM1.SM[2].CVAL1)
  3579. #define FLEXPWM1_SM2CVAL1CYC (IMXRT_FLEXPWM1.SM[2].CVAL1CYC)
  3580. #define FLEXPWM1_SM2CVAL2 (IMXRT_FLEXPWM1.SM[2].CVAL2)
  3581. #define FLEXPWM1_SM2CVAL2CYC (IMXRT_FLEXPWM1.SM[2].CVAL2CYC)
  3582. #define FLEXPWM1_SM2CVAL3 (IMXRT_FLEXPWM1.SM[2].CVAL3)
  3583. #define FLEXPWM1_SM2CVAL3CYC (IMXRT_FLEXPWM1.SM[2].CVAL3CYC)
  3584. #define FLEXPWM1_SM2CVAL4 (IMXRT_FLEXPWM1.SM[2].CVAL4)
  3585. #define FLEXPWM1_SM2CVAL4CYC (IMXRT_FLEXPWM1.SM[2].CVAL4CYC)
  3586. #define FLEXPWM1_SM2CVAL5 (IMXRT_FLEXPWM1.SM[2].CVAL5)
  3587. #define FLEXPWM1_SM2CVAL5CYC (IMXRT_FLEXPWM1.SM[2].CVAL5CYC)
  3588. #define FLEXPWM1_SM3CNT (IMXRT_FLEXPWM1.SM[3].CNT)
  3589. #define FLEXPWM1_SM3INIT (IMXRT_FLEXPWM1.SM[3].INIT)
  3590. #define FLEXPWM1_SM3CTRL2 (IMXRT_FLEXPWM1.SM[3].CTRL2)
  3591. #define FLEXPWM1_SM3CTRL (IMXRT_FLEXPWM1.SM[3].CTRL)
  3592. #define FLEXPWM1_SM3VAL0 (IMXRT_FLEXPWM1.SM[3].VAL0)
  3593. #define FLEXPWM1_SM3FRACVAL1 (IMXRT_FLEXPWM1.SM[3].FRACVAL1)
  3594. #define FLEXPWM1_SM3VAL1 (IMXRT_FLEXPWM1.SM[3].VAL1)
  3595. #define FLEXPWM1_SM3FRACVAL2 (IMXRT_FLEXPWM1.SM[3].FRACVAL2)
  3596. #define FLEXPWM1_SM3VAL2 (IMXRT_FLEXPWM1.SM[3].VAL2)
  3597. #define FLEXPWM1_SM3FRACVAL3 (IMXRT_FLEXPWM1.SM[3].FRACVAL3)
  3598. #define FLEXPWM1_SM3VAL3 (IMXRT_FLEXPWM1.SM[3].VAL3)
  3599. #define FLEXPWM1_SM3FRACVAL4 (IMXRT_FLEXPWM1.SM[3].FRACVAL4)
  3600. #define FLEXPWM1_SM3VAL4 (IMXRT_FLEXPWM1.SM[3].VAL4)
  3601. #define FLEXPWM1_SM3FRACVAL5 (IMXRT_FLEXPWM1.SM[3].FRACVAL5)
  3602. #define FLEXPWM1_SM3VAL5 (IMXRT_FLEXPWM1.SM[3].VAL5)
  3603. #define FLEXPWM1_SM3FRCTRL (IMXRT_FLEXPWM1.SM[3].FRCTRL)
  3604. #define FLEXPWM1_SM3OCTRL (IMXRT_FLEXPWM1.SM[3].OCTRL)
  3605. #define FLEXPWM1_SM3STS (IMXRT_FLEXPWM1.SM[3].STS)
  3606. #define FLEXPWM1_SM3INTEN (IMXRT_FLEXPWM1.SM[3].INTEN)
  3607. #define FLEXPWM1_SM3DMAEN (IMXRT_FLEXPWM1.SM[3].DMAEN)
  3608. #define FLEXPWM1_SM3TCTRL (IMXRT_FLEXPWM1.SM[3].TCTRL)
  3609. #define FLEXPWM1_SM3DISMAP0 (IMXRT_FLEXPWM1.SM[3].DISMAP0)
  3610. #define FLEXPWM1_SM3DISMAP1 (IMXRT_FLEXPWM1.SM[3].DISMAP1)
  3611. #define FLEXPWM1_SM3DTCNT0 (IMXRT_FLEXPWM1.SM[3].DTCNT0)
  3612. #define FLEXPWM1_SM3DTCNT1 (IMXRT_FLEXPWM1.SM[3].DTCNT1)
  3613. #define FLEXPWM1_SM3CAPTCTRLA (IMXRT_FLEXPWM1.SM[3].CAPTCTRLA)
  3614. #define FLEXPWM1_SM3CAPTCOMPA (IMXRT_FLEXPWM1.SM[3].CAPTCOMPA)
  3615. #define FLEXPWM1_SM3CAPTCTRLB (IMXRT_FLEXPWM1.SM[3].CAPTCTRLB)
  3616. #define FLEXPWM1_SM3CAPTCOMPB (IMXRT_FLEXPWM1.SM[3].CAPTCOMPB)
  3617. #define FLEXPWM1_SM3CAPTCTRLX (IMXRT_FLEXPWM1.SM[3].CAPTCTRLX)
  3618. #define FLEXPWM1_SM3CAPTCOMPX (IMXRT_FLEXPWM1.SM[3].CAPTCOMPX)
  3619. #define FLEXPWM1_SM3CVAL0 (IMXRT_FLEXPWM1.SM[3].CVAL0)
  3620. #define FLEXPWM1_SM3CVAL0CYC (IMXRT_FLEXPWM1.SM[3].CVAL0CYC)
  3621. #define FLEXPWM1_SM3CVAL1 (IMXRT_FLEXPWM1.SM[3].CVAL1)
  3622. #define FLEXPWM1_SM3CVAL1CYC (IMXRT_FLEXPWM1.SM[3].CVAL1CYC)
  3623. #define FLEXPWM1_SM3CVAL2 (IMXRT_FLEXPWM1.SM[3].CVAL2)
  3624. #define FLEXPWM1_SM3CVAL2CYC (IMXRT_FLEXPWM1.SM[3].CVAL2CYC)
  3625. #define FLEXPWM1_SM3CVAL3 (IMXRT_FLEXPWM1.SM[3].CVAL3)
  3626. #define FLEXPWM1_SM3CVAL3CYC (IMXRT_FLEXPWM1.SM[3].CVAL3CYC)
  3627. #define FLEXPWM1_SM3CVAL4 (IMXRT_FLEXPWM1.SM[3].CVAL4)
  3628. #define FLEXPWM1_SM3CVAL4CYC (IMXRT_FLEXPWM1.SM[3].CVAL4CYC)
  3629. #define FLEXPWM1_SM3CVAL5 (IMXRT_FLEXPWM1.SM[3].CVAL5)
  3630. #define FLEXPWM1_SM3CVAL5CYC (IMXRT_FLEXPWM1.SM[3].CVAL5CYC)
  3631. #define FLEXPWM1_OUTEN (IMXRT_FLEXPWM1.OUTEN)
  3632. #define FLEXPWM1_MASK (IMXRT_FLEXPWM1.MASK)
  3633. #define FLEXPWM1_SWCOUT (IMXRT_FLEXPWM1.SWCOUT)
  3634. #define FLEXPWM1_DTSRCSEL (IMXRT_FLEXPWM1.DTSRCSEL)
  3635. #define FLEXPWM1_MCTRL (IMXRT_FLEXPWM1.MCTRL)
  3636. #define FLEXPWM1_MCTRL2 (IMXRT_FLEXPWM1.MCTRL2)
  3637. #define FLEXPWM1_FCTRL0 (IMXRT_FLEXPWM1.FCTRL0)
  3638. #define FLEXPWM1_FSTS0 (IMXRT_FLEXPWM1.FSTS0)
  3639. #define FLEXPWM1_FFILT0 (IMXRT_FLEXPWM1.FFILT0)
  3640. #define FLEXPWM1_FTST0 (IMXRT_FLEXPWM1.FTST0)
  3641. #define FLEXPWM1_FCTRL20 (IMXRT_FLEXPWM1.FCTRL20)
  3642. #define FLEXPWM2_SM0CNT (IMXRT_FLEXPWM2.SM[0].CNT)
  3643. #define FLEXPWM2_SM0INIT (IMXRT_FLEXPWM2.SM[0].INIT)
  3644. #define FLEXPWM2_SM0CTRL2 (IMXRT_FLEXPWM2.SM[0].CTRL2)
  3645. #define FLEXPWM2_SM0CTRL (IMXRT_FLEXPWM2.SM[0].CTRL)
  3646. #define FLEXPWM2_SM0VAL0 (IMXRT_FLEXPWM2.SM[0].VAL0)
  3647. #define FLEXPWM2_SM0FRACVAL1 (IMXRT_FLEXPWM2.SM[0].FRACVAL1)
  3648. #define FLEXPWM2_SM0VAL1 (IMXRT_FLEXPWM2.SM[0].VAL1)
  3649. #define FLEXPWM2_SM0FRACVAL2 (IMXRT_FLEXPWM2.SM[0].FRACVAL2)
  3650. #define FLEXPWM2_SM0VAL2 (IMXRT_FLEXPWM2.SM[0].VAL2)
  3651. #define FLEXPWM2_SM0FRACVAL3 (IMXRT_FLEXPWM2.SM[0].FRACVAL3)
  3652. #define FLEXPWM2_SM0VAL3 (IMXRT_FLEXPWM2.SM[0].VAL3)
  3653. #define FLEXPWM2_SM0FRACVAL4 (IMXRT_FLEXPWM2.SM[0].FRACVAL4)
  3654. #define FLEXPWM2_SM0VAL4 (IMXRT_FLEXPWM2.SM[0].VAL4)
  3655. #define FLEXPWM2_SM0FRACVAL5 (IMXRT_FLEXPWM2.SM[0].FRACVAL5)
  3656. #define FLEXPWM2_SM0VAL5 (IMXRT_FLEXPWM2.SM[0].VAL5)
  3657. #define FLEXPWM2_SM0FRCTRL (IMXRT_FLEXPWM2.SM[0].FRCTRL)
  3658. #define FLEXPWM2_SM0OCTRL (IMXRT_FLEXPWM2.SM[0].OCTRL)
  3659. #define FLEXPWM2_SM0STS (IMXRT_FLEXPWM2.SM[0].STS)
  3660. #define FLEXPWM2_SM0INTEN (IMXRT_FLEXPWM2.SM[0].INTEN)
  3661. #define FLEXPWM2_SM0DMAEN (IMXRT_FLEXPWM2.SM[0].DMAEN)
  3662. #define FLEXPWM2_SM0TCTRL (IMXRT_FLEXPWM2.SM[0].TCTRL)
  3663. #define FLEXPWM2_SM0DISMAP0 (IMXRT_FLEXPWM2.SM[0].DISMAP0)
  3664. #define FLEXPWM2_SM0DISMAP1 (IMXRT_FLEXPWM2.SM[0].DISMAP1)
  3665. #define FLEXPWM2_SM0DTCNT0 (IMXRT_FLEXPWM2.SM[0].DTCNT0)
  3666. #define FLEXPWM2_SM0DTCNT1 (IMXRT_FLEXPWM2.SM[0].DTCNT1)
  3667. #define FLEXPWM2_SM0CAPTCTRLA (IMXRT_FLEXPWM2.SM[0].CAPTCTRLA)
  3668. #define FLEXPWM2_SM0CAPTCOMPA (IMXRT_FLEXPWM2.SM[0].CAPTCOMPA)
  3669. #define FLEXPWM2_SM0CAPTCTRLB (IMXRT_FLEXPWM2.SM[0].CAPTCTRLB)
  3670. #define FLEXPWM2_SM0CAPTCOMPB (IMXRT_FLEXPWM2.SM[0].CAPTCOMPB)
  3671. #define FLEXPWM2_SM0CAPTCTRLX (IMXRT_FLEXPWM2.SM[0].CAPTCTRLX)
  3672. #define FLEXPWM2_SM0CAPTCOMPX (IMXRT_FLEXPWM2.SM[0].CAPTCOMPX)
  3673. #define FLEXPWM2_SM0CVAL0 (IMXRT_FLEXPWM2.SM[0].CVAL0)
  3674. #define FLEXPWM2_SM0CVAL0CYC (IMXRT_FLEXPWM2.SM[0].CVAL0CYC)
  3675. #define FLEXPWM2_SM0CVAL1 (IMXRT_FLEXPWM2.SM[0].CVAL1)
  3676. #define FLEXPWM2_SM0CVAL1CYC (IMXRT_FLEXPWM2.SM[0].CVAL1CYC)
  3677. #define FLEXPWM2_SM0CVAL2 (IMXRT_FLEXPWM2.SM[0].CVAL2)
  3678. #define FLEXPWM2_SM0CVAL2CYC (IMXRT_FLEXPWM2.SM[0].CVAL2CYC)
  3679. #define FLEXPWM2_SM0CVAL3 (IMXRT_FLEXPWM2.SM[0].CVAL3)
  3680. #define FLEXPWM2_SM0CVAL3CYC (IMXRT_FLEXPWM2.SM[0].CVAL3CYC)
  3681. #define FLEXPWM2_SM0CVAL4 (IMXRT_FLEXPWM2.SM[0].CVAL4)
  3682. #define FLEXPWM2_SM0CVAL4CYC (IMXRT_FLEXPWM2.SM[0].CVAL4CYC)
  3683. #define FLEXPWM2_SM0CVAL5 (IMXRT_FLEXPWM2.SM[0].CVAL5)
  3684. #define FLEXPWM2_SM0CVAL5CYC (IMXRT_FLEXPWM2.SM[0].CVAL5CYC)
  3685. #define FLEXPWM2_SM1CNT (IMXRT_FLEXPWM2.SM[1].CNT)
  3686. #define FLEXPWM2_SM1INIT (IMXRT_FLEXPWM2.SM[1].INIT)
  3687. #define FLEXPWM2_SM1CTRL2 (IMXRT_FLEXPWM2.SM[1].CTRL2)
  3688. #define FLEXPWM2_SM1CTRL (IMXRT_FLEXPWM2.SM[1].CTRL)
  3689. #define FLEXPWM2_SM1VAL0 (IMXRT_FLEXPWM2.SM[1].VAL0)
  3690. #define FLEXPWM2_SM1FRACVAL1 (IMXRT_FLEXPWM2.SM[1].FRACVAL1)
  3691. #define FLEXPWM2_SM1VAL1 (IMXRT_FLEXPWM2.SM[1].VAL1)
  3692. #define FLEXPWM2_SM1FRACVAL2 (IMXRT_FLEXPWM2.SM[1].FRACVAL2)
  3693. #define FLEXPWM2_SM1VAL2 (IMXRT_FLEXPWM2.SM[1].VAL2)
  3694. #define FLEXPWM2_SM1FRACVAL3 (IMXRT_FLEXPWM2.SM[1].FRACVAL3)
  3695. #define FLEXPWM2_SM1VAL3 (IMXRT_FLEXPWM2.SM[1].VAL3)
  3696. #define FLEXPWM2_SM1FRACVAL4 (IMXRT_FLEXPWM2.SM[1].FRACVAL4)
  3697. #define FLEXPWM2_SM1VAL4 (IMXRT_FLEXPWM2.SM[1].VAL4)
  3698. #define FLEXPWM2_SM1FRACVAL5 (IMXRT_FLEXPWM2.SM[1].FRACVAL5)
  3699. #define FLEXPWM2_SM1VAL5 (IMXRT_FLEXPWM2.SM[1].VAL5)
  3700. #define FLEXPWM2_SM1FRCTRL (IMXRT_FLEXPWM2.SM[1].FRCTRL)
  3701. #define FLEXPWM2_SM1OCTRL (IMXRT_FLEXPWM2.SM[1].OCTRL)
  3702. #define FLEXPWM2_SM1STS (IMXRT_FLEXPWM2.SM[1].STS)
  3703. #define FLEXPWM2_SM1INTEN (IMXRT_FLEXPWM2.SM[1].INTEN)
  3704. #define FLEXPWM2_SM1DMAEN (IMXRT_FLEXPWM2.SM[1].DMAEN)
  3705. #define FLEXPWM2_SM1TCTRL (IMXRT_FLEXPWM2.SM[1].TCTRL)
  3706. #define FLEXPWM2_SM1DISMAP0 (IMXRT_FLEXPWM2.SM[1].DISMAP0)
  3707. #define FLEXPWM2_SM1DISMAP1 (IMXRT_FLEXPWM2.SM[1].DISMAP1)
  3708. #define FLEXPWM2_SM1DTCNT0 (IMXRT_FLEXPWM2.SM[1].DTCNT0)
  3709. #define FLEXPWM2_SM1DTCNT1 (IMXRT_FLEXPWM2.SM[1].DTCNT1)
  3710. #define FLEXPWM2_SM1CAPTCTRLA (IMXRT_FLEXPWM2.SM[1].CAPTCTRLA)
  3711. #define FLEXPWM2_SM1CAPTCOMPA (IMXRT_FLEXPWM2.SM[1].CAPTCOMPA)
  3712. #define FLEXPWM2_SM1CAPTCTRLB (IMXRT_FLEXPWM2.SM[1].CAPTCTRLB)
  3713. #define FLEXPWM2_SM1CAPTCOMPB (IMXRT_FLEXPWM2.SM[1].CAPTCOMPB)
  3714. #define FLEXPWM2_SM1CAPTCTRLX (IMXRT_FLEXPWM2.SM[1].CAPTCTRLX)
  3715. #define FLEXPWM2_SM1CAPTCOMPX (IMXRT_FLEXPWM2.SM[1].CAPTCOMPX)
  3716. #define FLEXPWM2_SM1CVAL0 (IMXRT_FLEXPWM2.SM[1].CVAL0)
  3717. #define FLEXPWM2_SM1CVAL0CYC (IMXRT_FLEXPWM2.SM[1].CVAL0CYC)
  3718. #define FLEXPWM2_SM1CVAL1 (IMXRT_FLEXPWM2.SM[1].CVAL1)
  3719. #define FLEXPWM2_SM1CVAL1CYC (IMXRT_FLEXPWM2.SM[1].CVAL1CYC)
  3720. #define FLEXPWM2_SM1CVAL2 (IMXRT_FLEXPWM2.SM[1].CVAL2)
  3721. #define FLEXPWM2_SM1CVAL2CYC (IMXRT_FLEXPWM2.SM[1].CVAL2CYC)
  3722. #define FLEXPWM2_SM1CVAL3 (IMXRT_FLEXPWM2.SM[1].CVAL3)
  3723. #define FLEXPWM2_SM1CVAL3CYC (IMXRT_FLEXPWM2.SM[1].CVAL3CYC)
  3724. #define FLEXPWM2_SM1CVAL4 (IMXRT_FLEXPWM2.SM[1].CVAL4)
  3725. #define FLEXPWM2_SM1CVAL4CYC (IMXRT_FLEXPWM2.SM[1].CVAL4CYC)
  3726. #define FLEXPWM2_SM1CVAL5 (IMXRT_FLEXPWM2.SM[1].CVAL5)
  3727. #define FLEXPWM2_SM1CVAL5CYC (IMXRT_FLEXPWM2.SM[1].CVAL5CYC)
  3728. #define FLEXPWM2_SM2CNT (IMXRT_FLEXPWM2.SM[2].CNT)
  3729. #define FLEXPWM2_SM2INIT (IMXRT_FLEXPWM2.SM[2].INIT)
  3730. #define FLEXPWM2_SM2CTRL2 (IMXRT_FLEXPWM2.SM[2].CTRL2)
  3731. #define FLEXPWM2_SM2CTRL (IMXRT_FLEXPWM2.SM[2].CTRL)
  3732. #define FLEXPWM2_SM2VAL0 (IMXRT_FLEXPWM2.SM[2].VAL0)
  3733. #define FLEXPWM2_SM2FRACVAL1 (IMXRT_FLEXPWM2.SM[2].FRACVAL1)
  3734. #define FLEXPWM2_SM2VAL1 (IMXRT_FLEXPWM2.SM[2].VAL1)
  3735. #define FLEXPWM2_SM2FRACVAL2 (IMXRT_FLEXPWM2.SM[2].FRACVAL2)
  3736. #define FLEXPWM2_SM2VAL2 (IMXRT_FLEXPWM2.SM[2].VAL2)
  3737. #define FLEXPWM2_SM2FRACVAL3 (IMXRT_FLEXPWM2.SM[2].FRACVAL3)
  3738. #define FLEXPWM2_SM2VAL3 (IMXRT_FLEXPWM2.SM[2].VAL3)
  3739. #define FLEXPWM2_SM2FRACVAL4 (IMXRT_FLEXPWM2.SM[2].FRACVAL4)
  3740. #define FLEXPWM2_SM2VAL4 (IMXRT_FLEXPWM2.SM[2].VAL4)
  3741. #define FLEXPWM2_SM2FRACVAL5 (IMXRT_FLEXPWM2.SM[2].FRACVAL5)
  3742. #define FLEXPWM2_SM2VAL5 (IMXRT_FLEXPWM2.SM[2].VAL5)
  3743. #define FLEXPWM2_SM2FRCTRL (IMXRT_FLEXPWM2.SM[2].FRCTRL)
  3744. #define FLEXPWM2_SM2OCTRL (IMXRT_FLEXPWM2.SM[2].OCTRL)
  3745. #define FLEXPWM2_SM2STS (IMXRT_FLEXPWM2.SM[2].STS)
  3746. #define FLEXPWM2_SM2INTEN (IMXRT_FLEXPWM2.SM[2].INTEN)
  3747. #define FLEXPWM2_SM2DMAEN (IMXRT_FLEXPWM2.SM[2].DMAEN)
  3748. #define FLEXPWM2_SM2TCTRL (IMXRT_FLEXPWM2.SM[2].TCTRL)
  3749. #define FLEXPWM2_SM2DISMAP0 (IMXRT_FLEXPWM2.SM[2].DISMAP0)
  3750. #define FLEXPWM2_SM2DISMAP1 (IMXRT_FLEXPWM2.SM[2].DISMAP1)
  3751. #define FLEXPWM2_SM2DTCNT0 (IMXRT_FLEXPWM2.SM[2].DTCNT0)
  3752. #define FLEXPWM2_SM2DTCNT1 (IMXRT_FLEXPWM2.SM[2].DTCNT1)
  3753. #define FLEXPWM2_SM2CAPTCTRLA (IMXRT_FLEXPWM2.SM[2].CAPTCTRLA)
  3754. #define FLEXPWM2_SM2CAPTCOMPA (IMXRT_FLEXPWM2.SM[2].CAPTCOMPA)
  3755. #define FLEXPWM2_SM2CAPTCTRLB (IMXRT_FLEXPWM2.SM[2].CAPTCTRLB)
  3756. #define FLEXPWM2_SM2CAPTCOMPB (IMXRT_FLEXPWM2.SM[2].CAPTCOMPB)
  3757. #define FLEXPWM2_SM2CAPTCTRLX (IMXRT_FLEXPWM2.SM[2].CAPTCTRLX)
  3758. #define FLEXPWM2_SM2CAPTCOMPX (IMXRT_FLEXPWM2.SM[2].CAPTCOMPX)
  3759. #define FLEXPWM2_SM2CVAL0 (IMXRT_FLEXPWM2.SM[2].CVAL0)
  3760. #define FLEXPWM2_SM2CVAL0CYC (IMXRT_FLEXPWM2.SM[2].CVAL0CYC)
  3761. #define FLEXPWM2_SM2CVAL1 (IMXRT_FLEXPWM2.SM[2].CVAL1)
  3762. #define FLEXPWM2_SM2CVAL1CYC (IMXRT_FLEXPWM2.SM[2].CVAL1CYC)
  3763. #define FLEXPWM2_SM2CVAL2 (IMXRT_FLEXPWM2.SM[2].CVAL2)
  3764. #define FLEXPWM2_SM2CVAL2CYC (IMXRT_FLEXPWM2.SM[2].CVAL2CYC)
  3765. #define FLEXPWM2_SM2CVAL3 (IMXRT_FLEXPWM2.SM[2].CVAL3)
  3766. #define FLEXPWM2_SM2CVAL3CYC (IMXRT_FLEXPWM2.SM[2].CVAL3CYC)
  3767. #define FLEXPWM2_SM2CVAL4 (IMXRT_FLEXPWM2.SM[2].CVAL4)
  3768. #define FLEXPWM2_SM2CVAL4CYC (IMXRT_FLEXPWM2.SM[2].CVAL4CYC)
  3769. #define FLEXPWM2_SM2CVAL5 (IMXRT_FLEXPWM2.SM[2].CVAL5)
  3770. #define FLEXPWM2_SM2CVAL5CYC (IMXRT_FLEXPWM2.SM[2].CVAL5CYC)
  3771. #define FLEXPWM2_SM3CNT (IMXRT_FLEXPWM2.SM[3].CNT)
  3772. #define FLEXPWM2_SM3INIT (IMXRT_FLEXPWM2.SM[3].INIT)
  3773. #define FLEXPWM2_SM3CTRL2 (IMXRT_FLEXPWM2.SM[3].CTRL2)
  3774. #define FLEXPWM2_SM3CTRL (IMXRT_FLEXPWM2.SM[3].CTRL)
  3775. #define FLEXPWM2_SM3VAL0 (IMXRT_FLEXPWM2.SM[3].VAL0)
  3776. #define FLEXPWM2_SM3FRACVAL1 (IMXRT_FLEXPWM2.SM[3].FRACVAL1)
  3777. #define FLEXPWM2_SM3VAL1 (IMXRT_FLEXPWM2.SM[3].VAL1)
  3778. #define FLEXPWM2_SM3FRACVAL2 (IMXRT_FLEXPWM2.SM[3].FRACVAL2)
  3779. #define FLEXPWM2_SM3VAL2 (IMXRT_FLEXPWM2.SM[3].VAL2)
  3780. #define FLEXPWM2_SM3FRACVAL3 (IMXRT_FLEXPWM2.SM[3].FRACVAL3)
  3781. #define FLEXPWM2_SM3VAL3 (IMXRT_FLEXPWM2.SM[3].VAL3)
  3782. #define FLEXPWM2_SM3FRACVAL4 (IMXRT_FLEXPWM2.SM[3].FRACVAL4)
  3783. #define FLEXPWM2_SM3VAL4 (IMXRT_FLEXPWM2.SM[3].VAL4)
  3784. #define FLEXPWM2_SM3FRACVAL5 (IMXRT_FLEXPWM2.SM[3].FRACVAL5)
  3785. #define FLEXPWM2_SM3VAL5 (IMXRT_FLEXPWM2.SM[3].VAL5)
  3786. #define FLEXPWM2_SM3FRCTRL (IMXRT_FLEXPWM2.SM[3].FRCTRL)
  3787. #define FLEXPWM2_SM3OCTRL (IMXRT_FLEXPWM2.SM[3].OCTRL)
  3788. #define FLEXPWM2_SM3STS (IMXRT_FLEXPWM2.SM[3].STS)
  3789. #define FLEXPWM2_SM3INTEN (IMXRT_FLEXPWM2.SM[3].INTEN)
  3790. #define FLEXPWM2_SM3DMAEN (IMXRT_FLEXPWM2.SM[3].DMAEN)
  3791. #define FLEXPWM2_SM3TCTRL (IMXRT_FLEXPWM2.SM[3].TCTRL)
  3792. #define FLEXPWM2_SM3DISMAP0 (IMXRT_FLEXPWM2.SM[3].DISMAP0)
  3793. #define FLEXPWM2_SM3DISMAP1 (IMXRT_FLEXPWM2.SM[3].DISMAP1)
  3794. #define FLEXPWM2_SM3DTCNT0 (IMXRT_FLEXPWM2.SM[3].DTCNT0)
  3795. #define FLEXPWM2_SM3DTCNT1 (IMXRT_FLEXPWM2.SM[3].DTCNT1)
  3796. #define FLEXPWM2_SM3CAPTCTRLA (IMXRT_FLEXPWM2.SM[3].CAPTCTRLA)
  3797. #define FLEXPWM2_SM3CAPTCOMPA (IMXRT_FLEXPWM2.SM[3].CAPTCOMPA)
  3798. #define FLEXPWM2_SM3CAPTCTRLB (IMXRT_FLEXPWM2.SM[3].CAPTCTRLB)
  3799. #define FLEXPWM2_SM3CAPTCOMPB (IMXRT_FLEXPWM2.SM[3].CAPTCOMPB)
  3800. #define FLEXPWM2_SM3CAPTCTRLX (IMXRT_FLEXPWM2.SM[3].CAPTCTRLX)
  3801. #define FLEXPWM2_SM3CAPTCOMPX (IMXRT_FLEXPWM2.SM[3].CAPTCOMPX)
  3802. #define FLEXPWM2_SM3CVAL0 (IMXRT_FLEXPWM2.SM[3].CVAL0)
  3803. #define FLEXPWM2_SM3CVAL0CYC (IMXRT_FLEXPWM2.SM[3].CVAL0CYC)
  3804. #define FLEXPWM2_SM3CVAL1 (IMXRT_FLEXPWM2.SM[3].CVAL1)
  3805. #define FLEXPWM2_SM3CVAL1CYC (IMXRT_FLEXPWM2.SM[3].CVAL1CYC)
  3806. #define FLEXPWM2_SM3CVAL2 (IMXRT_FLEXPWM2.SM[3].CVAL2)
  3807. #define FLEXPWM2_SM3CVAL2CYC (IMXRT_FLEXPWM2.SM[3].CVAL2CYC)
  3808. #define FLEXPWM2_SM3CVAL3 (IMXRT_FLEXPWM2.SM[3].CVAL3)
  3809. #define FLEXPWM2_SM3CVAL3CYC (IMXRT_FLEXPWM2.SM[3].CVAL3CYC)
  3810. #define FLEXPWM2_SM3CVAL4 (IMXRT_FLEXPWM2.SM[3].CVAL4)
  3811. #define FLEXPWM2_SM3CVAL4CYC (IMXRT_FLEXPWM2.SM[3].CVAL4CYC)
  3812. #define FLEXPWM2_SM3CVAL5 (IMXRT_FLEXPWM2.SM[3].CVAL5)
  3813. #define FLEXPWM2_SM3CVAL5CYC (IMXRT_FLEXPWM2.SM[3].CVAL5CYC)
  3814. #define FLEXPWM2_OUTEN (IMXRT_FLEXPWM2.OUTEN)
  3815. #define FLEXPWM2_MASK (IMXRT_FLEXPWM2.MASK)
  3816. #define FLEXPWM2_SWCOUT (IMXRT_FLEXPWM2.SWCOUT)
  3817. #define FLEXPWM2_DTSRCSEL (IMXRT_FLEXPWM2.DTSRCSEL)
  3818. #define FLEXPWM2_MCTRL (IMXRT_FLEXPWM2.MCTRL)
  3819. #define FLEXPWM2_MCTRL2 (IMXRT_FLEXPWM2.MCTRL2)
  3820. #define FLEXPWM2_FCTRL0 (IMXRT_FLEXPWM2.FCTRL0)
  3821. #define FLEXPWM2_FSTS0 (IMXRT_FLEXPWM2.FSTS0)
  3822. #define FLEXPWM2_FFILT0 (IMXRT_FLEXPWM2.FFILT0)
  3823. #define FLEXPWM2_FTST0 (IMXRT_FLEXPWM2.FTST0)
  3824. #define FLEXPWM2_FCTRL20 (IMXRT_FLEXPWM2.FCTRL20)
  3825. #define FLEXPWM3_SM0CNT (IMXRT_FLEXPWM3.SM[0].CNT)
  3826. #define FLEXPWM3_SM0INIT (IMXRT_FLEXPWM3.SM[0].INIT)
  3827. #define FLEXPWM3_SM0CTRL2 (IMXRT_FLEXPWM3.SM[0].CTRL2)
  3828. #define FLEXPWM3_SM0CTRL (IMXRT_FLEXPWM3.SM[0].CTRL)
  3829. #define FLEXPWM3_SM0VAL0 (IMXRT_FLEXPWM3.SM[0].VAL0)
  3830. #define FLEXPWM3_SM0FRACVAL1 (IMXRT_FLEXPWM3.SM[0].FRACVAL1)
  3831. #define FLEXPWM3_SM0VAL1 (IMXRT_FLEXPWM3.SM[0].VAL1)
  3832. #define FLEXPWM3_SM0FRACVAL2 (IMXRT_FLEXPWM3.SM[0].FRACVAL2)
  3833. #define FLEXPWM3_SM0VAL2 (IMXRT_FLEXPWM3.SM[0].VAL2)
  3834. #define FLEXPWM3_SM0FRACVAL3 (IMXRT_FLEXPWM3.SM[0].FRACVAL3)
  3835. #define FLEXPWM3_SM0VAL3 (IMXRT_FLEXPWM3.SM[0].VAL3)
  3836. #define FLEXPWM3_SM0FRACVAL4 (IMXRT_FLEXPWM3.SM[0].FRACVAL4)
  3837. #define FLEXPWM3_SM0VAL4 (IMXRT_FLEXPWM3.SM[0].VAL4)
  3838. #define FLEXPWM3_SM0FRACVAL5 (IMXRT_FLEXPWM3.SM[0].FRACVAL5)
  3839. #define FLEXPWM3_SM0VAL5 (IMXRT_FLEXPWM3.SM[0].VAL5)
  3840. #define FLEXPWM3_SM0FRCTRL (IMXRT_FLEXPWM3.SM[0].FRCTRL)
  3841. #define FLEXPWM3_SM0OCTRL (IMXRT_FLEXPWM3.SM[0].OCTRL)
  3842. #define FLEXPWM3_SM0STS (IMXRT_FLEXPWM3.SM[0].STS)
  3843. #define FLEXPWM3_SM0INTEN (IMXRT_FLEXPWM3.SM[0].INTEN)
  3844. #define FLEXPWM3_SM0DMAEN (IMXRT_FLEXPWM3.SM[0].DMAEN)
  3845. #define FLEXPWM3_SM0TCTRL (IMXRT_FLEXPWM3.SM[0].TCTRL)
  3846. #define FLEXPWM3_SM0DISMAP0 (IMXRT_FLEXPWM3.SM[0].DISMAP0)
  3847. #define FLEXPWM3_SM0DISMAP1 (IMXRT_FLEXPWM3.SM[0].DISMAP1)
  3848. #define FLEXPWM3_SM0DTCNT0 (IMXRT_FLEXPWM3.SM[0].DTCNT0)
  3849. #define FLEXPWM3_SM0DTCNT1 (IMXRT_FLEXPWM3.SM[0].DTCNT1)
  3850. #define FLEXPWM3_SM0CAPTCTRLA (IMXRT_FLEXPWM3.SM[0].CAPTCTRLA)
  3851. #define FLEXPWM3_SM0CAPTCOMPA (IMXRT_FLEXPWM3.SM[0].CAPTCOMPA)
  3852. #define FLEXPWM3_SM0CAPTCTRLB (IMXRT_FLEXPWM3.SM[0].CAPTCTRLB)
  3853. #define FLEXPWM3_SM0CAPTCOMPB (IMXRT_FLEXPWM3.SM[0].CAPTCOMPB)
  3854. #define FLEXPWM3_SM0CAPTCTRLX (IMXRT_FLEXPWM3.SM[0].CAPTCTRLX)
  3855. #define FLEXPWM3_SM0CAPTCOMPX (IMXRT_FLEXPWM3.SM[0].CAPTCOMPX)
  3856. #define FLEXPWM3_SM0CVAL0 (IMXRT_FLEXPWM3.SM[0].CVAL0)
  3857. #define FLEXPWM3_SM0CVAL0CYC (IMXRT_FLEXPWM3.SM[0].CVAL0CYC)
  3858. #define FLEXPWM3_SM0CVAL1 (IMXRT_FLEXPWM3.SM[0].CVAL1)
  3859. #define FLEXPWM3_SM0CVAL1CYC (IMXRT_FLEXPWM3.SM[0].CVAL1CYC)
  3860. #define FLEXPWM3_SM0CVAL2 (IMXRT_FLEXPWM3.SM[0].CVAL2)
  3861. #define FLEXPWM3_SM0CVAL2CYC (IMXRT_FLEXPWM3.SM[0].CVAL2CYC)
  3862. #define FLEXPWM3_SM0CVAL3 (IMXRT_FLEXPWM3.SM[0].CVAL3)
  3863. #define FLEXPWM3_SM0CVAL3CYC (IMXRT_FLEXPWM3.SM[0].CVAL3CYC)
  3864. #define FLEXPWM3_SM0CVAL4 (IMXRT_FLEXPWM3.SM[0].CVAL4)
  3865. #define FLEXPWM3_SM0CVAL4CYC (IMXRT_FLEXPWM3.SM[0].CVAL4CYC)
  3866. #define FLEXPWM3_SM0CVAL5 (IMXRT_FLEXPWM3.SM[0].CVAL5)
  3867. #define FLEXPWM3_SM0CVAL5CYC (IMXRT_FLEXPWM3.SM[0].CVAL5CYC)
  3868. #define FLEXPWM3_SM1CNT (IMXRT_FLEXPWM3.SM[1].CNT)
  3869. #define FLEXPWM3_SM1INIT (IMXRT_FLEXPWM3.SM[1].INIT)
  3870. #define FLEXPWM3_SM1CTRL2 (IMXRT_FLEXPWM3.SM[1].CTRL2)
  3871. #define FLEXPWM3_SM1CTRL (IMXRT_FLEXPWM3.SM[1].CTRL)
  3872. #define FLEXPWM3_SM1VAL0 (IMXRT_FLEXPWM3.SM[1].VAL0)
  3873. #define FLEXPWM3_SM1FRACVAL1 (IMXRT_FLEXPWM3.SM[1].FRACVAL1)
  3874. #define FLEXPWM3_SM1VAL1 (IMXRT_FLEXPWM3.SM[1].VAL1)
  3875. #define FLEXPWM3_SM1FRACVAL2 (IMXRT_FLEXPWM3.SM[1].FRACVAL2)
  3876. #define FLEXPWM3_SM1VAL2 (IMXRT_FLEXPWM3.SM[1].VAL2)
  3877. #define FLEXPWM3_SM1FRACVAL3 (IMXRT_FLEXPWM3.SM[1].FRACVAL3)
  3878. #define FLEXPWM3_SM1VAL3 (IMXRT_FLEXPWM3.SM[1].VAL3)
  3879. #define FLEXPWM3_SM1FRACVAL4 (IMXRT_FLEXPWM3.SM[1].FRACVAL4)
  3880. #define FLEXPWM3_SM1VAL4 (IMXRT_FLEXPWM3.SM[1].VAL4)
  3881. #define FLEXPWM3_SM1FRACVAL5 (IMXRT_FLEXPWM3.SM[1].FRACVAL5)
  3882. #define FLEXPWM3_SM1VAL5 (IMXRT_FLEXPWM3.SM[1].VAL5)
  3883. #define FLEXPWM3_SM1FRCTRL (IMXRT_FLEXPWM3.SM[1].FRCTRL)
  3884. #define FLEXPWM3_SM1OCTRL (IMXRT_FLEXPWM3.SM[1].OCTRL)
  3885. #define FLEXPWM3_SM1STS (IMXRT_FLEXPWM3.SM[1].STS)
  3886. #define FLEXPWM3_SM1INTEN (IMXRT_FLEXPWM3.SM[1].INTEN)
  3887. #define FLEXPWM3_SM1DMAEN (IMXRT_FLEXPWM3.SM[1].DMAEN)
  3888. #define FLEXPWM3_SM1TCTRL (IMXRT_FLEXPWM3.SM[1].TCTRL)
  3889. #define FLEXPWM3_SM1DISMAP0 (IMXRT_FLEXPWM3.SM[1].DISMAP0)
  3890. #define FLEXPWM3_SM1DISMAP1 (IMXRT_FLEXPWM3.SM[1].DISMAP1)
  3891. #define FLEXPWM3_SM1DTCNT0 (IMXRT_FLEXPWM3.SM[1].DTCNT0)
  3892. #define FLEXPWM3_SM1DTCNT1 (IMXRT_FLEXPWM3.SM[1].DTCNT1)
  3893. #define FLEXPWM3_SM1CAPTCTRLA (IMXRT_FLEXPWM3.SM[1].CAPTCTRLA)
  3894. #define FLEXPWM3_SM1CAPTCOMPA (IMXRT_FLEXPWM3.SM[1].CAPTCOMPA)
  3895. #define FLEXPWM3_SM1CAPTCTRLB (IMXRT_FLEXPWM3.SM[1].CAPTCTRLB)
  3896. #define FLEXPWM3_SM1CAPTCOMPB (IMXRT_FLEXPWM3.SM[1].CAPTCOMPB)
  3897. #define FLEXPWM3_SM1CAPTCTRLX (IMXRT_FLEXPWM3.SM[1].CAPTCTRLX)
  3898. #define FLEXPWM3_SM1CAPTCOMPX (IMXRT_FLEXPWM3.SM[1].CAPTCOMPX)
  3899. #define FLEXPWM3_SM1CVAL0 (IMXRT_FLEXPWM3.SM[1].CVAL0)
  3900. #define FLEXPWM3_SM1CVAL0CYC (IMXRT_FLEXPWM3.SM[1].CVAL0CYC)
  3901. #define FLEXPWM3_SM1CVAL1 (IMXRT_FLEXPWM3.SM[1].CVAL1)
  3902. #define FLEXPWM3_SM1CVAL1CYC (IMXRT_FLEXPWM3.SM[1].CVAL1CYC)
  3903. #define FLEXPWM3_SM1CVAL2 (IMXRT_FLEXPWM3.SM[1].CVAL2)
  3904. #define FLEXPWM3_SM1CVAL2CYC (IMXRT_FLEXPWM3.SM[1].CVAL2CYC)
  3905. #define FLEXPWM3_SM1CVAL3 (IMXRT_FLEXPWM3.SM[1].CVAL3)
  3906. #define FLEXPWM3_SM1CVAL3CYC (IMXRT_FLEXPWM3.SM[1].CVAL3CYC)
  3907. #define FLEXPWM3_SM1CVAL4 (IMXRT_FLEXPWM3.SM[1].CVAL4)
  3908. #define FLEXPWM3_SM1CVAL4CYC (IMXRT_FLEXPWM3.SM[1].CVAL4CYC)
  3909. #define FLEXPWM3_SM1CVAL5 (IMXRT_FLEXPWM3.SM[1].CVAL5)
  3910. #define FLEXPWM3_SM1CVAL5CYC (IMXRT_FLEXPWM3.SM[1].CVAL5CYC)
  3911. #define FLEXPWM3_SM2CNT (IMXRT_FLEXPWM3.SM[2].CNT)
  3912. #define FLEXPWM3_SM2INIT (IMXRT_FLEXPWM3.SM[2].INIT)
  3913. #define FLEXPWM3_SM2CTRL2 (IMXRT_FLEXPWM3.SM[2].CTRL2)
  3914. #define FLEXPWM3_SM2CTRL (IMXRT_FLEXPWM3.SM[2].CTRL)
  3915. #define FLEXPWM3_SM2VAL0 (IMXRT_FLEXPWM3.SM[2].VAL0)
  3916. #define FLEXPWM3_SM2FRACVAL1 (IMXRT_FLEXPWM3.SM[2].FRACVAL1)
  3917. #define FLEXPWM3_SM2VAL1 (IMXRT_FLEXPWM3.SM[2].VAL1)
  3918. #define FLEXPWM3_SM2FRACVAL2 (IMXRT_FLEXPWM3.SM[2].FRACVAL2)
  3919. #define FLEXPWM3_SM2VAL2 (IMXRT_FLEXPWM3.SM[2].VAL2)
  3920. #define FLEXPWM3_SM2FRACVAL3 (IMXRT_FLEXPWM3.SM[2].FRACVAL3)
  3921. #define FLEXPWM3_SM2VAL3 (IMXRT_FLEXPWM3.SM[2].VAL3)
  3922. #define FLEXPWM3_SM2FRACVAL4 (IMXRT_FLEXPWM3.SM[2].FRACVAL4)
  3923. #define FLEXPWM3_SM2VAL4 (IMXRT_FLEXPWM3.SM[2].VAL4)
  3924. #define FLEXPWM3_SM2FRACVAL5 (IMXRT_FLEXPWM3.SM[2].FRACVAL5)
  3925. #define FLEXPWM3_SM2VAL5 (IMXRT_FLEXPWM3.SM[2].VAL5)
  3926. #define FLEXPWM3_SM2FRCTRL (IMXRT_FLEXPWM3.SM[2].FRCTRL)
  3927. #define FLEXPWM3_SM2OCTRL (IMXRT_FLEXPWM3.SM[2].OCTRL)
  3928. #define FLEXPWM3_SM2STS (IMXRT_FLEXPWM3.SM[2].STS)
  3929. #define FLEXPWM3_SM2INTEN (IMXRT_FLEXPWM3.SM[2].INTEN)
  3930. #define FLEXPWM3_SM2DMAEN (IMXRT_FLEXPWM3.SM[2].DMAEN)
  3931. #define FLEXPWM3_SM2TCTRL (IMXRT_FLEXPWM3.SM[2].TCTRL)
  3932. #define FLEXPWM3_SM2DISMAP0 (IMXRT_FLEXPWM3.SM[2].DISMAP0)
  3933. #define FLEXPWM3_SM2DISMAP1 (IMXRT_FLEXPWM3.SM[2].DISMAP1)
  3934. #define FLEXPWM3_SM2DTCNT0 (IMXRT_FLEXPWM3.SM[2].DTCNT0)
  3935. #define FLEXPWM3_SM2DTCNT1 (IMXRT_FLEXPWM3.SM[2].DTCNT1)
  3936. #define FLEXPWM3_SM2CAPTCTRLA (IMXRT_FLEXPWM3.SM[2].CAPTCTRLA)
  3937. #define FLEXPWM3_SM2CAPTCOMPA (IMXRT_FLEXPWM3.SM[2].CAPTCOMPA)
  3938. #define FLEXPWM3_SM2CAPTCTRLB (IMXRT_FLEXPWM3.SM[2].CAPTCTRLB)
  3939. #define FLEXPWM3_SM2CAPTCOMPB (IMXRT_FLEXPWM3.SM[2].CAPTCOMPB)
  3940. #define FLEXPWM3_SM2CAPTCTRLX (IMXRT_FLEXPWM3.SM[2].CAPTCTRLX)
  3941. #define FLEXPWM3_SM2CAPTCOMPX (IMXRT_FLEXPWM3.SM[2].CAPTCOMPX)
  3942. #define FLEXPWM3_SM2CVAL0 (IMXRT_FLEXPWM3.SM[2].CVAL0)
  3943. #define FLEXPWM3_SM2CVAL0CYC (IMXRT_FLEXPWM3.SM[2].CVAL0CYC)
  3944. #define FLEXPWM3_SM2CVAL1 (IMXRT_FLEXPWM3.SM[2].CVAL1)
  3945. #define FLEXPWM3_SM2CVAL1CYC (IMXRT_FLEXPWM3.SM[2].CVAL1CYC)
  3946. #define FLEXPWM3_SM2CVAL2 (IMXRT_FLEXPWM3.SM[2].CVAL2)
  3947. #define FLEXPWM3_SM2CVAL2CYC (IMXRT_FLEXPWM3.SM[2].CVAL2CYC)
  3948. #define FLEXPWM3_SM2CVAL3 (IMXRT_FLEXPWM3.SM[2].CVAL3)
  3949. #define FLEXPWM3_SM2CVAL3CYC (IMXRT_FLEXPWM3.SM[2].CVAL3CYC)
  3950. #define FLEXPWM3_SM2CVAL4 (IMXRT_FLEXPWM3.SM[2].CVAL4)
  3951. #define FLEXPWM3_SM2CVAL4CYC (IMXRT_FLEXPWM3.SM[2].CVAL4CYC)
  3952. #define FLEXPWM3_SM2CVAL5 (IMXRT_FLEXPWM3.SM[2].CVAL5)
  3953. #define FLEXPWM3_SM2CVAL5CYC (IMXRT_FLEXPWM3.SM[2].CVAL5CYC)
  3954. #define FLEXPWM3_SM3CNT (IMXRT_FLEXPWM3.SM[3].CNT)
  3955. #define FLEXPWM3_SM3INIT (IMXRT_FLEXPWM3.SM[3].INIT)
  3956. #define FLEXPWM3_SM3CTRL2 (IMXRT_FLEXPWM3.SM[3].CTRL2)
  3957. #define FLEXPWM3_SM3CTRL (IMXRT_FLEXPWM3.SM[3].CTRL)
  3958. #define FLEXPWM3_SM3VAL0 (IMXRT_FLEXPWM3.SM[3].VAL0)
  3959. #define FLEXPWM3_SM3FRACVAL1 (IMXRT_FLEXPWM3.SM[3].FRACVAL1)
  3960. #define FLEXPWM3_SM3VAL1 (IMXRT_FLEXPWM3.SM[3].VAL1)
  3961. #define FLEXPWM3_SM3FRACVAL2 (IMXRT_FLEXPWM3.SM[3].FRACVAL2)
  3962. #define FLEXPWM3_SM3VAL2 (IMXRT_FLEXPWM3.SM[3].VAL2)
  3963. #define FLEXPWM3_SM3FRACVAL3 (IMXRT_FLEXPWM3.SM[3].FRACVAL3)
  3964. #define FLEXPWM3_SM3VAL3 (IMXRT_FLEXPWM3.SM[3].VAL3)
  3965. #define FLEXPWM3_SM3FRACVAL4 (IMXRT_FLEXPWM3.SM[3].FRACVAL4)
  3966. #define FLEXPWM3_SM3VAL4 (IMXRT_FLEXPWM3.SM[3].VAL4)
  3967. #define FLEXPWM3_SM3FRACVAL5 (IMXRT_FLEXPWM3.SM[3].FRACVAL5)
  3968. #define FLEXPWM3_SM3VAL5 (IMXRT_FLEXPWM3.SM[3].VAL5)
  3969. #define FLEXPWM3_SM3FRCTRL (IMXRT_FLEXPWM3.SM[3].FRCTRL)
  3970. #define FLEXPWM3_SM3OCTRL (IMXRT_FLEXPWM3.SM[3].OCTRL)
  3971. #define FLEXPWM3_SM3STS (IMXRT_FLEXPWM3.SM[3].STS)
  3972. #define FLEXPWM3_SM3INTEN (IMXRT_FLEXPWM3.SM[3].INTEN)
  3973. #define FLEXPWM3_SM3DMAEN (IMXRT_FLEXPWM3.SM[3].DMAEN)
  3974. #define FLEXPWM3_SM3TCTRL (IMXRT_FLEXPWM3.SM[3].TCTRL)
  3975. #define FLEXPWM3_SM3DISMAP0 (IMXRT_FLEXPWM3.SM[3].DISMAP0)
  3976. #define FLEXPWM3_SM3DISMAP1 (IMXRT_FLEXPWM3.SM[3].DISMAP1)
  3977. #define FLEXPWM3_SM3DTCNT0 (IMXRT_FLEXPWM3.SM[3].DTCNT0)
  3978. #define FLEXPWM3_SM3DTCNT1 (IMXRT_FLEXPWM3.SM[3].DTCNT1)
  3979. #define FLEXPWM3_SM3CAPTCTRLA (IMXRT_FLEXPWM3.SM[3].CAPTCTRLA)
  3980. #define FLEXPWM3_SM3CAPTCOMPA (IMXRT_FLEXPWM3.SM[3].CAPTCOMPA)
  3981. #define FLEXPWM3_SM3CAPTCTRLB (IMXRT_FLEXPWM3.SM[3].CAPTCTRLB)
  3982. #define FLEXPWM3_SM3CAPTCOMPB (IMXRT_FLEXPWM3.SM[3].CAPTCOMPB)
  3983. #define FLEXPWM3_SM3CAPTCTRLX (IMXRT_FLEXPWM3.SM[3].CAPTCTRLX)
  3984. #define FLEXPWM3_SM3CAPTCOMPX (IMXRT_FLEXPWM3.SM[3].CAPTCOMPX)
  3985. #define FLEXPWM3_SM3CVAL0 (IMXRT_FLEXPWM3.SM[3].CVAL0)
  3986. #define FLEXPWM3_SM3CVAL0CYC (IMXRT_FLEXPWM3.SM[3].CVAL0CYC)
  3987. #define FLEXPWM3_SM3CVAL1 (IMXRT_FLEXPWM3.SM[3].CVAL1)
  3988. #define FLEXPWM3_SM3CVAL1CYC (IMXRT_FLEXPWM3.SM[3].CVAL1CYC)
  3989. #define FLEXPWM3_SM3CVAL2 (IMXRT_FLEXPWM3.SM[3].CVAL2)
  3990. #define FLEXPWM3_SM3CVAL2CYC (IMXRT_FLEXPWM3.SM[3].CVAL2CYC)
  3991. #define FLEXPWM3_SM3CVAL3 (IMXRT_FLEXPWM3.SM[3].CVAL3)
  3992. #define FLEXPWM3_SM3CVAL3CYC (IMXRT_FLEXPWM3.SM[3].CVAL3CYC)
  3993. #define FLEXPWM3_SM3CVAL4 (IMXRT_FLEXPWM3.SM[3].CVAL4)
  3994. #define FLEXPWM3_SM3CVAL4CYC (IMXRT_FLEXPWM3.SM[3].CVAL4CYC)
  3995. #define FLEXPWM3_SM3CVAL5 (IMXRT_FLEXPWM3.SM[3].CVAL5)
  3996. #define FLEXPWM3_SM3CVAL5CYC (IMXRT_FLEXPWM3.SM[3].CVAL5CYC)
  3997. #define FLEXPWM3_OUTEN (IMXRT_FLEXPWM3.OUTEN)
  3998. #define FLEXPWM3_MASK (IMXRT_FLEXPWM3.MASK)
  3999. #define FLEXPWM3_SWCOUT (IMXRT_FLEXPWM3.SWCOUT)
  4000. #define FLEXPWM3_DTSRCSEL (IMXRT_FLEXPWM3.DTSRCSEL)
  4001. #define FLEXPWM3_MCTRL (IMXRT_FLEXPWM3.MCTRL)
  4002. #define FLEXPWM3_MCTRL2 (IMXRT_FLEXPWM3.MCTRL2)
  4003. #define FLEXPWM3_FCTRL0 (IMXRT_FLEXPWM3.FCTRL0)
  4004. #define FLEXPWM3_FSTS0 (IMXRT_FLEXPWM3.FSTS0)
  4005. #define FLEXPWM3_FFILT0 (IMXRT_FLEXPWM3.FFILT0)
  4006. #define FLEXPWM3_FTST0 (IMXRT_FLEXPWM3.FTST0)
  4007. #define FLEXPWM3_FCTRL20 (IMXRT_FLEXPWM3.FCTRL20)
  4008. #define FLEXPWM4_SM0CNT (IMXRT_FLEXPWM4.SM[0].CNT)
  4009. #define FLEXPWM4_SM0INIT (IMXRT_FLEXPWM4.SM[0].INIT)
  4010. #define FLEXPWM4_SM0CTRL2 (IMXRT_FLEXPWM4.SM[0].CTRL2)
  4011. #define FLEXPWM4_SM0CTRL (IMXRT_FLEXPWM4.SM[0].CTRL)
  4012. #define FLEXPWM4_SM0VAL0 (IMXRT_FLEXPWM4.SM[0].VAL0)
  4013. #define FLEXPWM4_SM0FRACVAL1 (IMXRT_FLEXPWM4.SM[0].FRACVAL1)
  4014. #define FLEXPWM4_SM0VAL1 (IMXRT_FLEXPWM4.SM[0].VAL1)
  4015. #define FLEXPWM4_SM0FRACVAL2 (IMXRT_FLEXPWM4.SM[0].FRACVAL2)
  4016. #define FLEXPWM4_SM0VAL2 (IMXRT_FLEXPWM4.SM[0].VAL2)
  4017. #define FLEXPWM4_SM0FRACVAL3 (IMXRT_FLEXPWM4.SM[0].FRACVAL3)
  4018. #define FLEXPWM4_SM0VAL3 (IMXRT_FLEXPWM4.SM[0].VAL3)
  4019. #define FLEXPWM4_SM0FRACVAL4 (IMXRT_FLEXPWM4.SM[0].FRACVAL4)
  4020. #define FLEXPWM4_SM0VAL4 (IMXRT_FLEXPWM4.SM[0].VAL4)
  4021. #define FLEXPWM4_SM0FRACVAL5 (IMXRT_FLEXPWM4.SM[0].FRACVAL5)
  4022. #define FLEXPWM4_SM0VAL5 (IMXRT_FLEXPWM4.SM[0].VAL5)
  4023. #define FLEXPWM4_SM0FRCTRL (IMXRT_FLEXPWM4.SM[0].FRCTRL)
  4024. #define FLEXPWM4_SM0OCTRL (IMXRT_FLEXPWM4.SM[0].OCTRL)
  4025. #define FLEXPWM4_SM0STS (IMXRT_FLEXPWM4.SM[0].STS)
  4026. #define FLEXPWM4_SM0INTEN (IMXRT_FLEXPWM4.SM[0].INTEN)
  4027. #define FLEXPWM4_SM0DMAEN (IMXRT_FLEXPWM4.SM[0].DMAEN)
  4028. #define FLEXPWM4_SM0TCTRL (IMXRT_FLEXPWM4.SM[0].TCTRL)
  4029. #define FLEXPWM4_SM0DISMAP0 (IMXRT_FLEXPWM4.SM[0].DISMAP0)
  4030. #define FLEXPWM4_SM0DISMAP1 (IMXRT_FLEXPWM4.SM[0].DISMAP1)
  4031. #define FLEXPWM4_SM0DTCNT0 (IMXRT_FLEXPWM4.SM[0].DTCNT0)
  4032. #define FLEXPWM4_SM0DTCNT1 (IMXRT_FLEXPWM4.SM[0].DTCNT1)
  4033. #define FLEXPWM4_SM0CAPTCTRLA (IMXRT_FLEXPWM4.SM[0].CAPTCTRLA)
  4034. #define FLEXPWM4_SM0CAPTCOMPA (IMXRT_FLEXPWM4.SM[0].CAPTCOMPA)
  4035. #define FLEXPWM4_SM0CAPTCTRLB (IMXRT_FLEXPWM4.SM[0].CAPTCTRLB)
  4036. #define FLEXPWM4_SM0CAPTCOMPB (IMXRT_FLEXPWM4.SM[0].CAPTCOMPB)
  4037. #define FLEXPWM4_SM0CAPTCTRLX (IMXRT_FLEXPWM4.SM[0].CAPTCTRLX)
  4038. #define FLEXPWM4_SM0CAPTCOMPX (IMXRT_FLEXPWM4.SM[0].CAPTCOMPX)
  4039. #define FLEXPWM4_SM0CVAL0 (IMXRT_FLEXPWM4.SM[0].CVAL0)
  4040. #define FLEXPWM4_SM0CVAL0CYC (IMXRT_FLEXPWM4.SM[0].CVAL0CYC)
  4041. #define FLEXPWM4_SM0CVAL1 (IMXRT_FLEXPWM4.SM[0].CVAL1)
  4042. #define FLEXPWM4_SM0CVAL1CYC (IMXRT_FLEXPWM4.SM[0].CVAL1CYC)
  4043. #define FLEXPWM4_SM0CVAL2 (IMXRT_FLEXPWM4.SM[0].CVAL2)
  4044. #define FLEXPWM4_SM0CVAL2CYC (IMXRT_FLEXPWM4.SM[0].CVAL2CYC)
  4045. #define FLEXPWM4_SM0CVAL3 (IMXRT_FLEXPWM4.SM[0].CVAL3)
  4046. #define FLEXPWM4_SM0CVAL3CYC (IMXRT_FLEXPWM4.SM[0].CVAL3CYC)
  4047. #define FLEXPWM4_SM0CVAL4 (IMXRT_FLEXPWM4.SM[0].CVAL4)
  4048. #define FLEXPWM4_SM0CVAL4CYC (IMXRT_FLEXPWM4.SM[0].CVAL4CYC)
  4049. #define FLEXPWM4_SM0CVAL5 (IMXRT_FLEXPWM4.SM[0].CVAL5)
  4050. #define FLEXPWM4_SM0CVAL5CYC (IMXRT_FLEXPWM4.SM[0].CVAL5CYC)
  4051. #define FLEXPWM4_SM1CNT (IMXRT_FLEXPWM4.SM[1].CNT)
  4052. #define FLEXPWM4_SM1INIT (IMXRT_FLEXPWM4.SM[1].INIT)
  4053. #define FLEXPWM4_SM1CTRL2 (IMXRT_FLEXPWM4.SM[1].CTRL2)
  4054. #define FLEXPWM4_SM1CTRL (IMXRT_FLEXPWM4.SM[1].CTRL)
  4055. #define FLEXPWM4_SM1VAL0 (IMXRT_FLEXPWM4.SM[1].VAL0)
  4056. #define FLEXPWM4_SM1FRACVAL1 (IMXRT_FLEXPWM4.SM[1].FRACVAL1)
  4057. #define FLEXPWM4_SM1VAL1 (IMXRT_FLEXPWM4.SM[1].VAL1)
  4058. #define FLEXPWM4_SM1FRACVAL2 (IMXRT_FLEXPWM4.SM[1].FRACVAL2)
  4059. #define FLEXPWM4_SM1VAL2 (IMXRT_FLEXPWM4.SM[1].VAL2)
  4060. #define FLEXPWM4_SM1FRACVAL3 (IMXRT_FLEXPWM4.SM[1].FRACVAL3)
  4061. #define FLEXPWM4_SM1VAL3 (IMXRT_FLEXPWM4.SM[1].VAL3)
  4062. #define FLEXPWM4_SM1FRACVAL4 (IMXRT_FLEXPWM4.SM[1].FRACVAL4)
  4063. #define FLEXPWM4_SM1VAL4 (IMXRT_FLEXPWM4.SM[1].VAL4)
  4064. #define FLEXPWM4_SM1FRACVAL5 (IMXRT_FLEXPWM4.SM[1].FRACVAL5)
  4065. #define FLEXPWM4_SM1VAL5 (IMXRT_FLEXPWM4.SM[1].VAL5)
  4066. #define FLEXPWM4_SM1FRCTRL (IMXRT_FLEXPWM4.SM[1].FRCTRL)
  4067. #define FLEXPWM4_SM1OCTRL (IMXRT_FLEXPWM4.SM[1].OCTRL)
  4068. #define FLEXPWM4_SM1STS (IMXRT_FLEXPWM4.SM[1].STS)
  4069. #define FLEXPWM4_SM1INTEN (IMXRT_FLEXPWM4.SM[1].INTEN)
  4070. #define FLEXPWM4_SM1DMAEN (IMXRT_FLEXPWM4.SM[1].DMAEN)
  4071. #define FLEXPWM4_SM1TCTRL (IMXRT_FLEXPWM4.SM[1].TCTRL)
  4072. #define FLEXPWM4_SM1DISMAP0 (IMXRT_FLEXPWM4.SM[1].DISMAP0)
  4073. #define FLEXPWM4_SM1DISMAP1 (IMXRT_FLEXPWM4.SM[1].DISMAP1)
  4074. #define FLEXPWM4_SM1DTCNT0 (IMXRT_FLEXPWM4.SM[1].DTCNT0)
  4075. #define FLEXPWM4_SM1DTCNT1 (IMXRT_FLEXPWM4.SM[1].DTCNT1)
  4076. #define FLEXPWM4_SM1CAPTCTRLA (IMXRT_FLEXPWM4.SM[1].CAPTCTRLA)
  4077. #define FLEXPWM4_SM1CAPTCOMPA (IMXRT_FLEXPWM4.SM[1].CAPTCOMPA)
  4078. #define FLEXPWM4_SM1CAPTCTRLB (IMXRT_FLEXPWM4.SM[1].CAPTCTRLB)
  4079. #define FLEXPWM4_SM1CAPTCOMPB (IMXRT_FLEXPWM4.SM[1].CAPTCOMPB)
  4080. #define FLEXPWM4_SM1CAPTCTRLX (IMXRT_FLEXPWM4.SM[1].CAPTCTRLX)
  4081. #define FLEXPWM4_SM1CAPTCOMPX (IMXRT_FLEXPWM4.SM[1].CAPTCOMPX)
  4082. #define FLEXPWM4_SM1CVAL0 (IMXRT_FLEXPWM4.SM[1].CVAL0)
  4083. #define FLEXPWM4_SM1CVAL0CYC (IMXRT_FLEXPWM4.SM[1].CVAL0CYC)
  4084. #define FLEXPWM4_SM1CVAL1 (IMXRT_FLEXPWM4.SM[1].CVAL1)
  4085. #define FLEXPWM4_SM1CVAL1CYC (IMXRT_FLEXPWM4.SM[1].CVAL1CYC)
  4086. #define FLEXPWM4_SM1CVAL2 (IMXRT_FLEXPWM4.SM[1].CVAL2)
  4087. #define FLEXPWM4_SM1CVAL2CYC (IMXRT_FLEXPWM4.SM[1].CVAL2CYC)
  4088. #define FLEXPWM4_SM1CVAL3 (IMXRT_FLEXPWM4.SM[1].CVAL3)
  4089. #define FLEXPWM4_SM1CVAL3CYC (IMXRT_FLEXPWM4.SM[1].CVAL3CYC)
  4090. #define FLEXPWM4_SM1CVAL4 (IMXRT_FLEXPWM4.SM[1].CVAL4)
  4091. #define FLEXPWM4_SM1CVAL4CYC (IMXRT_FLEXPWM4.SM[1].CVAL4CYC)
  4092. #define FLEXPWM4_SM1CVAL5 (IMXRT_FLEXPWM4.SM[1].CVAL5)
  4093. #define FLEXPWM4_SM1CVAL5CYC (IMXRT_FLEXPWM4.SM[1].CVAL5CYC)
  4094. #define FLEXPWM4_SM2CNT (IMXRT_FLEXPWM4.SM[2].CNT)
  4095. #define FLEXPWM4_SM2INIT (IMXRT_FLEXPWM4.SM[2].INIT)
  4096. #define FLEXPWM4_SM2CTRL2 (IMXRT_FLEXPWM4.SM[2].CTRL2)
  4097. #define FLEXPWM4_SM2CTRL (IMXRT_FLEXPWM4.SM[2].CTRL)
  4098. #define FLEXPWM4_SM2VAL0 (IMXRT_FLEXPWM4.SM[2].VAL0)
  4099. #define FLEXPWM4_SM2FRACVAL1 (IMXRT_FLEXPWM4.SM[2].FRACVAL1)
  4100. #define FLEXPWM4_SM2VAL1 (IMXRT_FLEXPWM4.SM[2].VAL1)
  4101. #define FLEXPWM4_SM2FRACVAL2 (IMXRT_FLEXPWM4.SM[2].FRACVAL2)
  4102. #define FLEXPWM4_SM2VAL2 (IMXRT_FLEXPWM4.SM[2].VAL2)
  4103. #define FLEXPWM4_SM2FRACVAL3 (IMXRT_FLEXPWM4.SM[2].FRACVAL3)
  4104. #define FLEXPWM4_SM2VAL3 (IMXRT_FLEXPWM4.SM[2].VAL3)
  4105. #define FLEXPWM4_SM2FRACVAL4 (IMXRT_FLEXPWM4.SM[2].FRACVAL4)
  4106. #define FLEXPWM4_SM2VAL4 (IMXRT_FLEXPWM4.SM[2].VAL4)
  4107. #define FLEXPWM4_SM2FRACVAL5 (IMXRT_FLEXPWM4.SM[2].FRACVAL5)
  4108. #define FLEXPWM4_SM2VAL5 (IMXRT_FLEXPWM4.SM[2].VAL5)
  4109. #define FLEXPWM4_SM2FRCTRL (IMXRT_FLEXPWM4.SM[2].FRCTRL)
  4110. #define FLEXPWM4_SM2OCTRL (IMXRT_FLEXPWM4.SM[2].OCTRL)
  4111. #define FLEXPWM4_SM2STS (IMXRT_FLEXPWM4.SM[2].STS)
  4112. #define FLEXPWM4_SM2INTEN (IMXRT_FLEXPWM4.SM[2].INTEN)
  4113. #define FLEXPWM4_SM2DMAEN (IMXRT_FLEXPWM4.SM[2].DMAEN)
  4114. #define FLEXPWM4_SM2TCTRL (IMXRT_FLEXPWM4.SM[2].TCTRL)
  4115. #define FLEXPWM4_SM2DISMAP0 (IMXRT_FLEXPWM4.SM[2].DISMAP0)
  4116. #define FLEXPWM4_SM2DISMAP1 (IMXRT_FLEXPWM4.SM[2].DISMAP1)
  4117. #define FLEXPWM4_SM2DTCNT0 (IMXRT_FLEXPWM4.SM[2].DTCNT0)
  4118. #define FLEXPWM4_SM2DTCNT1 (IMXRT_FLEXPWM4.SM[2].DTCNT1)
  4119. #define FLEXPWM4_SM2CAPTCTRLA (IMXRT_FLEXPWM4.SM[2].CAPTCTRLA)
  4120. #define FLEXPWM4_SM2CAPTCOMPA (IMXRT_FLEXPWM4.SM[2].CAPTCOMPA)
  4121. #define FLEXPWM4_SM2CAPTCTRLB (IMXRT_FLEXPWM4.SM[2].CAPTCTRLB)
  4122. #define FLEXPWM4_SM2CAPTCOMPB (IMXRT_FLEXPWM4.SM[2].CAPTCOMPB)
  4123. #define FLEXPWM4_SM2CAPTCTRLX (IMXRT_FLEXPWM4.SM[2].CAPTCTRLX)
  4124. #define FLEXPWM4_SM2CAPTCOMPX (IMXRT_FLEXPWM4.SM[2].CAPTCOMPX)
  4125. #define FLEXPWM4_SM2CVAL0 (IMXRT_FLEXPWM4.SM[2].CVAL0)
  4126. #define FLEXPWM4_SM2CVAL0CYC (IMXRT_FLEXPWM4.SM[2].CVAL0CYC)
  4127. #define FLEXPWM4_SM2CVAL1 (IMXRT_FLEXPWM4.SM[2].CVAL1)
  4128. #define FLEXPWM4_SM2CVAL1CYC (IMXRT_FLEXPWM4.SM[2].CVAL1CYC)
  4129. #define FLEXPWM4_SM2CVAL2 (IMXRT_FLEXPWM4.SM[2].CVAL2)
  4130. #define FLEXPWM4_SM2CVAL2CYC (IMXRT_FLEXPWM4.SM[2].CVAL2CYC)
  4131. #define FLEXPWM4_SM2CVAL3 (IMXRT_FLEXPWM4.SM[2].CVAL3)
  4132. #define FLEXPWM4_SM2CVAL3CYC (IMXRT_FLEXPWM4.SM[2].CVAL3CYC)
  4133. #define FLEXPWM4_SM2CVAL4 (IMXRT_FLEXPWM4.SM[2].CVAL4)
  4134. #define FLEXPWM4_SM2CVAL4CYC (IMXRT_FLEXPWM4.SM[2].CVAL4CYC)
  4135. #define FLEXPWM4_SM2CVAL5 (IMXRT_FLEXPWM4.SM[2].CVAL5)
  4136. #define FLEXPWM4_SM2CVAL5CYC (IMXRT_FLEXPWM4.SM[2].CVAL5CYC)
  4137. #define FLEXPWM4_SM3CNT (IMXRT_FLEXPWM4.SM[3].CNT)
  4138. #define FLEXPWM4_SM3INIT (IMXRT_FLEXPWM4.SM[3].INIT)
  4139. #define FLEXPWM4_SM3CTRL2 (IMXRT_FLEXPWM4.SM[3].CTRL2)
  4140. #define FLEXPWM4_SM3CTRL (IMXRT_FLEXPWM4.SM[3].CTRL)
  4141. #define FLEXPWM4_SM3VAL0 (IMXRT_FLEXPWM4.SM[3].VAL0)
  4142. #define FLEXPWM4_SM3FRACVAL1 (IMXRT_FLEXPWM4.SM[3].FRACVAL1)
  4143. #define FLEXPWM4_SM3VAL1 (IMXRT_FLEXPWM4.SM[3].VAL1)
  4144. #define FLEXPWM4_SM3FRACVAL2 (IMXRT_FLEXPWM4.SM[3].FRACVAL2)
  4145. #define FLEXPWM4_SM3VAL2 (IMXRT_FLEXPWM4.SM[3].VAL2)
  4146. #define FLEXPWM4_SM3FRACVAL3 (IMXRT_FLEXPWM4.SM[3].FRACVAL3)
  4147. #define FLEXPWM4_SM3VAL3 (IMXRT_FLEXPWM4.SM[3].VAL3)
  4148. #define FLEXPWM4_SM3FRACVAL4 (IMXRT_FLEXPWM4.SM[3].FRACVAL4)
  4149. #define FLEXPWM4_SM3VAL4 (IMXRT_FLEXPWM4.SM[3].VAL4)
  4150. #define FLEXPWM4_SM3FRACVAL5 (IMXRT_FLEXPWM4.SM[3].FRACVAL5)
  4151. #define FLEXPWM4_SM3VAL5 (IMXRT_FLEXPWM4.SM[3].VAL5)
  4152. #define FLEXPWM4_SM3FRCTRL (IMXRT_FLEXPWM4.SM[3].FRCTRL)
  4153. #define FLEXPWM4_SM3OCTRL (IMXRT_FLEXPWM4.SM[3].OCTRL)
  4154. #define FLEXPWM4_SM3STS (IMXRT_FLEXPWM4.SM[3].STS)
  4155. #define FLEXPWM4_SM3INTEN (IMXRT_FLEXPWM4.SM[3].INTEN)
  4156. #define FLEXPWM4_SM3DMAEN (IMXRT_FLEXPWM4.SM[3].DMAEN)
  4157. #define FLEXPWM4_SM3TCTRL (IMXRT_FLEXPWM4.SM[3].TCTRL)
  4158. #define FLEXPWM4_SM3DISMAP0 (IMXRT_FLEXPWM4.SM[3].DISMAP0)
  4159. #define FLEXPWM4_SM3DISMAP1 (IMXRT_FLEXPWM4.SM[3].DISMAP1)
  4160. #define FLEXPWM4_SM3DTCNT0 (IMXRT_FLEXPWM4.SM[3].DTCNT0)
  4161. #define FLEXPWM4_SM3DTCNT1 (IMXRT_FLEXPWM4.SM[3].DTCNT1)
  4162. #define FLEXPWM4_SM3CAPTCTRLA (IMXRT_FLEXPWM4.SM[3].CAPTCTRLA)
  4163. #define FLEXPWM4_SM3CAPTCOMPA (IMXRT_FLEXPWM4.SM[3].CAPTCOMPA)
  4164. #define FLEXPWM4_SM3CAPTCTRLB (IMXRT_FLEXPWM4.SM[3].CAPTCTRLB)
  4165. #define FLEXPWM4_SM3CAPTCOMPB (IMXRT_FLEXPWM4.SM[3].CAPTCOMPB)
  4166. #define FLEXPWM4_SM3CAPTCTRLX (IMXRT_FLEXPWM4.SM[3].CAPTCTRLX)
  4167. #define FLEXPWM4_SM3CAPTCOMPX (IMXRT_FLEXPWM4.SM[3].CAPTCOMPX)
  4168. #define FLEXPWM4_SM3CVAL0 (IMXRT_FLEXPWM4.SM[3].CVAL0)
  4169. #define FLEXPWM4_SM3CVAL0CYC (IMXRT_FLEXPWM4.SM[3].CVAL0CYC)
  4170. #define FLEXPWM4_SM3CVAL1 (IMXRT_FLEXPWM4.SM[3].CVAL1)
  4171. #define FLEXPWM4_SM3CVAL1CYC (IMXRT_FLEXPWM4.SM[3].CVAL1CYC)
  4172. #define FLEXPWM4_SM3CVAL2 (IMXRT_FLEXPWM4.SM[3].CVAL2)
  4173. #define FLEXPWM4_SM3CVAL2CYC (IMXRT_FLEXPWM4.SM[3].CVAL2CYC)
  4174. #define FLEXPWM4_SM3CVAL3 (IMXRT_FLEXPWM4.SM[3].CVAL3)
  4175. #define FLEXPWM4_SM3CVAL3CYC (IMXRT_FLEXPWM4.SM[3].CVAL3CYC)
  4176. #define FLEXPWM4_SM3CVAL4 (IMXRT_FLEXPWM4.SM[3].CVAL4)
  4177. #define FLEXPWM4_SM3CVAL4CYC (IMXRT_FLEXPWM4.SM[3].CVAL4CYC)
  4178. #define FLEXPWM4_SM3CVAL5 (IMXRT_FLEXPWM4.SM[3].CVAL5)
  4179. #define FLEXPWM4_SM3CVAL5CYC (IMXRT_FLEXPWM4.SM[3].CVAL5CYC)
  4180. #define FLEXPWM4_OUTEN (IMXRT_FLEXPWM4.OUTEN)
  4181. #define FLEXPWM4_MASK (IMXRT_FLEXPWM4.MASK)
  4182. #define FLEXPWM4_SWCOUT (IMXRT_FLEXPWM4.SWCOUT)
  4183. #define FLEXPWM4_DTSRCSEL (IMXRT_FLEXPWM4.DTSRCSEL)
  4184. #define FLEXPWM4_MCTRL (IMXRT_FLEXPWM4.MCTRL)
  4185. #define FLEXPWM4_MCTRL2 (IMXRT_FLEXPWM4.MCTRL2)
  4186. #define FLEXPWM4_FCTRL0 (IMXRT_FLEXPWM4.FCTRL0)
  4187. #define FLEXPWM4_FSTS0 (IMXRT_FLEXPWM4.FSTS0)
  4188. #define FLEXPWM4_FFILT0 (IMXRT_FLEXPWM4.FFILT0)
  4189. #define FLEXPWM4_FTST0 (IMXRT_FLEXPWM4.FTST0)
  4190. #define FLEXPWM4_FCTRL20 (IMXRT_FLEXPWM4.FCTRL20)
  4191. // page 1361
  4192. #define FLEXPWM_SMCTRL2_DBGEN ((uint16_t)(1<<15))
  4193. #define FLEXPWM_SMCTRL2_WAITEN ((uint16_t)(1<<14))
  4194. #define FLEXPWM_SMCTRL2_INDEP ((uint16_t)(1<<13))
  4195. #define FLEXPWM_SMCTRL2_PWM23_INIT ((uint16_t)(1<<12))
  4196. #define FLEXPWM_SMCTRL2_PWM45_INIT ((uint16_t)(1<<11))
  4197. #define FLEXPWM_SMCTRL2_PWMX_INIT ((uint16_t)(1<<10))
  4198. #define FLEXPWM_SMCTRL2_INIT_SEL(n) ((uint16_t)(((n) & 0x03) << 8))
  4199. #define FLEXPWM_SMCTRL2_FRCEN ((uint16_t)(1<<7))
  4200. #define FLEXPWM_SMCTRL2_FORCE ((uint16_t)(1<<6))
  4201. #define FLEXPWM_SMCTRL2_FORCE_SEL(n) ((uint16_t)(((n) & 0x07) << 3))
  4202. #define FLEXPWM_SMCTRL2_RELOAD_SEL ((uint16_t)(1<<2))
  4203. #define FLEXPWM_SMCTRL2_CLK_SEL(n) ((uint16_t)(((n) & 0x03) << 0))
  4204. #define FLEXPWM_SMCTRL_LDFQ(n) ((uint16_t)(((n) & 0x0F) << 12))
  4205. #define FLEXPWM_SMCTRL_HALF ((uint16_t)(1<<11))
  4206. #define FLEXPWM_SMCTRL_FULL ((uint16_t)(1<<10))
  4207. #define FLEXPWM_SMCTRL_DT(n) ((uint16_t)(((n) & 0x03) << 8))
  4208. #define FLEXPWM_SMCTRL_COMPMODE ((uint16_t)(1<<7))
  4209. #define FLEXPWM_SMCTRL_PRSC(n) ((uint16_t)(((n) & 0x0F) << 4))
  4210. #define FLEXPWM_SMCTRL_SPLIT ((uint16_t)(1<<3))
  4211. #define FLEXPWM_SMCTRL_LDMOD ((uint16_t)(1<<2))
  4212. #define FLEXPWM_SMCTRL_DBLX ((uint16_t)(1<<1))
  4213. #define FLEXPWM_SMCTRL_DBLEN ((uint16_t)(1<<0))
  4214. #define FLEXPWM_SMFRCTRL_TEST ((uint16_t)(1<<15))
  4215. #define FLEXPWM_SMFRCTRL_FRAC_PU ((uint16_t)(1<<8))
  4216. #define FLEXPWM_SMFRCTRL_FRAC45_EN ((uint16_t)(1<<4))
  4217. #define FLEXPWM_SMFRCTRL_FRAC23_EN ((uint16_t)(1<<2))
  4218. #define FLEXPWM_SMFRCTRL_FRAC1_EN ((uint16_t)(1<<1))
  4219. #define FLEXPWM_SMOCTRL_PWMA_IN ((uint16_t)(1<<15))
  4220. #define FLEXPWM_SMOCTRL_PWMB_IN ((uint16_t)(1<<14))
  4221. #define FLEXPWM_SMOCTRL_PWMX_IN ((uint16_t)(1<<13))
  4222. #define FLEXPWM_SMOCTRL_POLA ((uint16_t)(1<<10))
  4223. #define FLEXPWM_SMOCTRL_POLB ((uint16_t)(1<<9))
  4224. #define FLEXPWM_SMOCTRL_POLX ((uint16_t)(1<<8))
  4225. #define FLEXPWM_SMOCTRL_PWMAFS(n) ((uint16_t)(((n) & 0x03) << 4))
  4226. #define FLEXPWM_SMOCTRL_PWMBFS(n) ((uint16_t)(((n) & 0x03) << 2))
  4227. #define FLEXPWM_SMOCTRL_PWMXFS(n) ((uint16_t)(((n) & 0x03) << 0))
  4228. #define FLEXPWM_SMSTS_RUF ((uint16_t)(1<<14))
  4229. #define FLEXPWM_SMSTS_REF ((uint16_t)(1<<13))
  4230. #define FLEXPWM_SMSTS_RF ((uint16_t)(1<<12))
  4231. #define FLEXPWM_SMSTS_CFA1 ((uint16_t)(1<<11))
  4232. #define FLEXPWM_SMSTS_CFA0 ((uint16_t)(1<<10))
  4233. #define FLEXPWM_SMSTS_CFB1 ((uint16_t)(1<<9))
  4234. #define FLEXPWM_SMSTS_CFB0 ((uint16_t)(1<<8))
  4235. #define FLEXPWM_SMSTS_CFX1 ((uint16_t)(1<<7))
  4236. #define FLEXPWM_SMSTS_CFX0 ((uint16_t)(1<<6))
  4237. #define FLEXPWM_SMSTS_CMPF(n) ((uint16_t)(((n) & 0x3F) << 0))
  4238. #define FLEXPWM_SMINTEN_REIE ((uint16_t)(1<<13))
  4239. #define FLEXPWM_SMINTEN_RIE ((uint16_t)(1<<12))
  4240. #define FLEXPWM_SMINTEN_CA1IE ((uint16_t)(1<<11))
  4241. #define FLEXPWM_SMINTEN_CA0IE ((uint16_t)(1<<10))
  4242. #define FLEXPWM_SMINTEN_CB1IE ((uint16_t)(1<<9))
  4243. #define FLEXPWM_SMINTEN_CB0IE ((uint16_t)(1<<8))
  4244. #define FLEXPWM_SMINTEN_CX1IE ((uint16_t)(1<<7))
  4245. #define FLEXPWM_SMINTEN_CX0IE ((uint16_t)(1<<6))
  4246. #define FLEXPWM_SMINTEN_CMPIE(n) ((uint16_t)(((n) & 0x3F) << 0))
  4247. #define FLEXPWM_SMDMAEN_VALDE ((uint16_t)(1<<9))
  4248. #define FLEXPWM_SMDMAEN_FAND ((uint16_t)(1<<8))
  4249. #define FLEXPWM_SMDMAEN_CAPTDE(n) ((uint16_t)(((n) & 0x03) << 6))
  4250. #define FLEXPWM_SMDMAEN_CA1DE ((uint16_t)(1<<5))
  4251. #define FLEXPWM_SMDMAEN_CA0DE ((uint16_t)(1<<4))
  4252. #define FLEXPWM_SMDMAEN_CB1DE ((uint16_t)(1<<3))
  4253. #define FLEXPWM_SMDMAEN_CB0DE ((uint16_t)(1<<2))
  4254. #define FLEXPWM_SMDMAEN_CX1DE ((uint16_t)(1<<1))
  4255. #define FLEXPWM_SMDMAEN_CX0DE ((uint16_t)(1<<0))
  4256. #define FLEXPWM_SMTCTRL_PWAOT0 ((uint16_t)(1<<15))
  4257. #define FLEXPWM_SMTCTRL_PWBOT1 ((uint16_t)(1<<14))
  4258. #define FLEXPWM_SMTCTRL_TRGFRQ ((uint16_t)(1<<12))
  4259. #define FLEXPWM_SMTCTRL_OUT_TRIG_EN(n) ((uint16_t)(((n) & 0x1F) << 0))
  4260. #define FLEXPWM_SMDISMAP0_DIS0X(n) ((uint16_t)(((n) & 0x0F) << 8))
  4261. #define FLEXPWM_SMDISMAP0_DIS0B(n) ((uint16_t)(((n) & 0x0F) << 4))
  4262. #define FLEXPWM_SMDISMAP0_DIS0A(n) ((uint16_t)(((n) & 0x0F) << 0))
  4263. #define FLEXPWM_SMDISMAP1_DIS1X(n) ((uint16_t)(((n) & 0x0F) << 8))
  4264. #define FLEXPWM_SMDISMAP1_DIS1B(n) ((uint16_t)(((n) & 0x0F) << 4))
  4265. #define FLEXPWM_SMDISMAP1_DIS1A(n) ((uint16_t)(((n) & 0x0F) << 0))
  4266. #define FLEXPWM_SMCAPTCTRLA_CA1CNT(n) ((uint16_t)(((n) & 0x07) << 13))
  4267. #define FLEXPWM_SMCAPTCTRLA_CA0CNT(n) ((uint16_t)(((n) & 0x07) << 10))
  4268. #define FLEXPWM_SMCAPTCTRLA_CFAWM(n) ((uint16_t)(((n) & 0x03) << 8))
  4269. #define FLEXPWM_SMCAPTCTRLA_EDGCNTA_EN ((uint16_t)(1<<7))
  4270. #define FLEXPWM_SMCAPTCTRLA_INP_SELA ((uint16_t)(1<<6))
  4271. #define FLEXPWM_SMCAPTCTRLA_EDGA1(n) ((uint16_t)(((n) & 0x03) << 4))
  4272. #define FLEXPWM_SMCAPTCTRLA_EDGA0(n) ((uint16_t)(((n) & 0x03) << 2))
  4273. #define FLEXPWM_SMCAPTCTRLA_ONESHOTA ((uint16_t)(1<<1))
  4274. #define FLEXPWM_SMCAPTCTRLA_ARMA ((uint16_t)(1<<0))
  4275. #define FLEXPWM_SMCAPTCOMPA_EDGCNTA(n) ((uint16_t)(((n) & 0xFF) << 8))
  4276. #define FLEXPWM_SMCAPTCOMPA_EDGCMPA(n) ((uint16_t)(((n) & 0xFF) << 0))
  4277. #define FLEXPWM_SMCAPTCTRLB_CB1CNT(n) ((uint16_t)(((n) & 0x07) << 13))
  4278. #define FLEXPWM_SMCAPTCTRLB_CB0CNT(n) ((uint16_t)(((n) & 0x07) << 10))
  4279. #define FLEXPWM_SMCAPTCTRLB_CFBWM(n) ((uint16_t)(((n) & 0x03) << 8))
  4280. #define FLEXPWM_SMCAPTCTRLB_EDGCNTB_EN ((uint16_t)(1<<7))
  4281. #define FLEXPWM_SMCAPTCTRLB_INP_SELB ((uint16_t)(1<<6))
  4282. #define FLEXPWM_SMCAPTCTRLB_EDGB1(n) ((uint16_t)(((n) & 0x03) << 4))
  4283. #define FLEXPWM_SMCAPTCTRLB_EDGB0(n) ((uint16_t)(((n) & 0x03) << 2))
  4284. #define FLEXPWM_SMCAPTCTRLB_ONESHOTB ((uint16_t)(1<<1))
  4285. #define FLEXPWM_SMCAPTCTRLB_ARMB ((uint16_t)(1<<0))
  4286. #define FLEXPWM_SMCAPTCOMPB_EDGCNTB(n) ((uint16_t)(((n) & 0xFF) << 8))
  4287. #define FLEXPWM_SMCAPTCOMPB_EDGCMPB(n) ((uint16_t)(((n) & 0xFF) << 0))
  4288. #define FLEXPWM_SMCAPTCTRLX_CX1CNT(n) ((uint16_t)(((n) & 0x07) << 13))
  4289. #define FLEXPWM_SMCAPTCTRLX_CX0CNT(n) ((uint16_t)(((n) & 0x07) << 10))
  4290. #define FLEXPWM_SMCAPTCTRLX_CFXWM(n) ((uint16_t)(((n) & 0x03) << 8))
  4291. #define FLEXPWM_SMCAPTCTRLX_EDGCNTX_EN ((uint16_t)(1<<7))
  4292. #define FLEXPWM_SMCAPTCTRLX_INP_SELX ((uint16_t)(1<<6))
  4293. #define FLEXPWM_SMCAPTCTRLX_EDGX1(n) ((uint16_t)(((n) & 0x03) << 4))
  4294. #define FLEXPWM_SMCAPTCTRLX_EDGX0(n) ((uint16_t)(((n) & 0x03) << 2))
  4295. #define FLEXPWM_SMCAPTCTRLX_ONESHOTX ((uint16_t)(1<<1))
  4296. #define FLEXPWM_SMCAPTCTRLX_ARMX ((uint16_t)(1<<0))
  4297. #define FLEXPWM_SMCAPTCOMPX_EDGCNTX(n) ((uint16_t)(((n) & 0xFF) << 8))
  4298. #define FLEXPWM_SMCAPTCOMPX_EDGCMPX(n) ((uint16_t)(((n) & 0xFF) << 0))
  4299. #define FLEXPWM_OUTEN_PWMA_EN(n) ((uint16_t)(((n) & 0x0F) << 8))
  4300. #define FLEXPWM_OUTEN_PWMB_EN(n) ((uint16_t)(((n) & 0x0F) << 4))
  4301. #define FLEXPWM_OUTEN_PWMX_EN(n) ((uint16_t)(((n) & 0x0F) << 0))
  4302. #define FLEXPWM_MASK_UPDATE_MASK(n) ((uint16_t)(((n) & 0x0F) << 12))
  4303. #define FLEXPWM_MASK_MASKA(n) ((uint16_t)(((n) & 0x0F) << 8))
  4304. #define FLEXPWM_MASK_MASKB(n) ((uint16_t)(((n) & 0x0F) << 4))
  4305. #define FLEXPWM_MASK_MASKX(n) ((uint16_t)(((n) & 0x0F) << 0))
  4306. #define FLEXPWM_SWCOUT_SM3OUT23 ((uint16_t)(1<<7))
  4307. #define FLEXPWM_SWCOUT_SM3OUT45 ((uint16_t)(1<<6))
  4308. #define FLEXPWM_SWCOUT_SM2OUT23 ((uint16_t)(1<<5))
  4309. #define FLEXPWM_SWCOUT_SM2OUT45 ((uint16_t)(1<<4))
  4310. #define FLEXPWM_SWCOUT_SM1OUT23 ((uint16_t)(1<<3))
  4311. #define FLEXPWM_SWCOUT_SM1OUT45 ((uint16_t)(1<<2))
  4312. #define FLEXPWM_SWCOUT_SM0OUT23 ((uint16_t)(1<<1))
  4313. #define FLEXPWM_SWCOUT_SM0OUT45 ((uint16_t)(1<<0))
  4314. #define FLEXPWM_DTSRCSEL_SM3SEL23(n) ((uint16_t)(((n) & 0x03) << 14))
  4315. #define FLEXPWM_DTSRCSEL_SM3SEL45(n) ((uint16_t)(((n) & 0x03) << 12))
  4316. #define FLEXPWM_DTSRCSEL_SM2SEL23(n) ((uint16_t)(((n) & 0x03) << 10))
  4317. #define FLEXPWM_DTSRCSEL_SM2SEL45(n) ((uint16_t)(((n) & 0x03) << 8))
  4318. #define FLEXPWM_DTSRCSEL_SM1SEL23(n) ((uint16_t)(((n) & 0x03) << 6))
  4319. #define FLEXPWM_DTSRCSEL_SM1SEL45(n) ((uint16_t)(((n) & 0x03) << 4))
  4320. #define FLEXPWM_DTSRCSEL_SM0SEL23(n) ((uint16_t)(((n) & 0x03) << 2))
  4321. #define FLEXPWM_DTSRCSEL_SM0SEL45(n) ((uint16_t)(((n) & 0x03) << 0))
  4322. #define FLEXPWM_MCTRL_IPOL(n) ((uint16_t)(((n) & 0x0F) << 12))
  4323. #define FLEXPWM_MCTRL_RUN(n) ((uint16_t)(((n) & 0x0F) << 8))
  4324. #define FLEXPWM_MCTRL_CLDOK(n) ((uint16_t)(((n) & 0x0F) << 4))
  4325. #define FLEXPWM_MCTRL_LDOK(n) ((uint16_t)(((n) & 0x0F) << 0))
  4326. #define FLEXPWM_MCTRL2_MONPLL(n) ((uint16_t)(((n) & 0x03) << 0))
  4327. #define FLEXPWM_FCTRL0_FLVL(n) ((uint16_t)(((n) & 0x0F) << 12))
  4328. #define FLEXPWM_FCTRL0_FAUTO(n) ((uint16_t)(((n) & 0x0F) << 8))
  4329. #define FLEXPWM_FCTRL0_FSAFE(n) ((uint16_t)(((n) & 0x0F) << 4))
  4330. #define FLEXPWM_FCTRL0_FIE(n) ((uint16_t)(((n) & 0x0F) << 0))
  4331. #define FLEXPWM_FSTS0_FHALF(n) ((uint16_t)(((n) & 0x0F) << 12))
  4332. #define FLEXPWM_FSTS0_FFPIN(n) ((uint16_t)(((n) & 0x0F) << 8))
  4333. #define FLEXPWM_FSTS0_FFULL(n) ((uint16_t)(((n) & 0x0F) << 4))
  4334. #define FLEXPWM_FSTS0_FFLAG(n) ((uint16_t)(((n) & 0x0F) << 0))
  4335. #define FLEXPWM_FFILT0_GSTR ((uint16_t)(1<<15))
  4336. #define FLEXPWM_FFILT0_FILT_CNT(n) ((uint16_t)(((n) & 0x07) << 8))
  4337. #define FLEXPWM_FFILT0_FILT_PER(n) ((uint16_t)(((n) & 0xFF) << 0))
  4338. #define FLEXPWM_FTST0_FTEST ((uint16_t)(1<<0))
  4339. #define FLEXPWM_FCTRL20_NOCOMB(n) ((uint16_t)(((n) & 0x0F) << 0))
  4340. // 29.3.1.1: page 1468
  4341. #define IMXRT_FLEXRAM (*(IMXRT_REGISTER32_t *)0x400B0000)
  4342. #define FLEXRAM_TCM_CTRL (IMXRT_FLEXRAM.offset000)
  4343. #define FLEXRAM_INT_STATUS (IMXRT_FLEXRAM.offset010)
  4344. #define FLEXRAM_INT_STAT_EN (IMXRT_FLEXRAM.offset014)
  4345. #define FLEXRAM_INT_SIG_EN (IMXRT_FLEXRAM.offset018)
  4346. #define FLEXRAM_TCM_CTRL_FORCE_CLK_ON ((uint32_t)(1<<2))
  4347. #define FLEXRAM_TCM_CTRL_TCM_RWAIT_EN ((uint32_t)(1<<1))
  4348. #define FLEXRAM_TCM_CTRL_TCM_WWAIT_EN ((uint32_t)(1<<0))
  4349. #define FLEXRAM_INT_STATUS_OCRAM_ERR_STATUS ((uint32_t)(1<<5))
  4350. #define FLEXRAM_INT_STATUS_DTCM_ERR_STATUS ((uint32_t)(1<<4))
  4351. #define FLEXRAM_INT_STATUS_ITCM_ERR_STATUS ((uint32_t)(1<<3))
  4352. #define FLEXRAM_INT_STAT_EN_OCRAM_ERR_STAT_EN ((uint32_t)(1<<5))
  4353. #define FLEXRAM_INT_STAT_EN_DTCM_ERR_STAT_EN ((uint32_t)(1<<4))
  4354. #define FLEXRAM_INT_STAT_EN_ITCM_ERR_STAT_EN ((uint32_t)(1<<3))
  4355. #define FLEXRAM_INT_SIG_EN_OCRAM_ERR_SIG_EN ((uint32_t)(1<<5))
  4356. #define FLEXRAM_INT_SIG_EN_DTCM_ERR_SIG_EN ((uint32_t)(1<<4))
  4357. #define FLEXRAM_INT_SIG_EN_ITCM_ERR_SIG_EN ((uint32_t)(1<<3))
  4358. // 30.5.2.1: page 1481
  4359. #define IMXRT_FLEXSPI (*(IMXRT_REGISTER32_t *)0x402A8000)
  4360. #define FLEXSPI_MCR0 (IMXRT_FLEXSPI.offset000)
  4361. #define FLEXSPI_MCR0_AHBGRANTWAIT(n) ((uint32_t)(((n) & 0xFF) << 24))
  4362. #define FLEXSPI_MCR0_AHBGRANTWAIT_MASK ((uint32_t)(0xFF << 24))
  4363. #define FLEXSPI_MCR0_IPGRANTWAIT(n) ((uint32_t)(((n) & 0xFF) << 16))
  4364. #define FLEXSPI_MCR0_IPGRANTWAIT_MASK ((uint32_t)(0xFF << 16))
  4365. #define FLEXSPI_MCR0_SCKFREERUNEN ((uint32_t)(1<<14))
  4366. #define FLEXSPI_MCR0_COMBINATIONEN ((uint32_t)(1<<13))
  4367. #define FLEXSPI_MCR0_DOZEEN ((uint32_t)(1<<12))
  4368. #define FLEXSPI_MCR0_HSEN ((uint32_t)(1<<11))
  4369. #define FLEXSPI_MCR0_ATDFEN ((uint32_t)(1<<7))
  4370. #define FLEXSPI_MCR0_ARDFEN ((uint32_t)(1<<6))
  4371. #define FLEXSPI_MCR0_RXCLKSRC(n) ((uint32_t)(((n) & 0x03) << 4))
  4372. #define FLEXSPI_MCR0_RXCLKSRC_MASK ((uint32_t)(0x03 << 4))
  4373. #define FLEXSPI_MCR0_MDIS ((uint32_t)(1<<1))
  4374. #define FLEXSPI_MCR0_SWRESET ((uint32_t)(1<<0))
  4375. #define FLEXSPI_MCR1 (IMXRT_FLEXSPI.offset004)
  4376. #define FLEXSPI_MCR1_SEQWAIT(n) ((uint32_t)(((n) & 0xFFFF) << 16))
  4377. #define FLEXSPI_MCR1_AHBBUSWAIT(n) ((uint32_t)(((n) & 0xFFFF) << 0))
  4378. #define FLEXSPI_MCR2 (IMXRT_FLEXSPI.offset008)
  4379. #define FLEXSPI_MCR2_RESUMEWAIT(n) ((uint32_t)(((n) & 0xFF) << 24))
  4380. #define FLEXSPI_MCR2_RESUMEWAIT_MASK ((uint32_t)(0xFF << 24))
  4381. #define FLEXSPI_MCR2_SCKBDIFFOPT ((uint32_t)(1<<19))
  4382. #define FLEXSPI_MCR2_SAMEDEVICEEN ((uint32_t)(1<<15))
  4383. #define FLEXSPI_MCR2_CLRLEARNPHASE ((uint32_t)(1<<14))
  4384. #define FLEXSPI_MCR2_CLRAHBBUFOPT ((uint32_t)(1<<11))
  4385. #define FLEXSPI_AHBCR (IMXRT_FLEXSPI.offset00C)
  4386. #define FLEXSPI_AHBCR_READADDROPT ((uint32_t)(1<<6))
  4387. #define FLEXSPI_AHBCR_PREFETCHEN ((uint32_t)(1<<5))
  4388. #define FLEXSPI_AHBCR_BUFFERABLEEN ((uint32_t)(1<<4))
  4389. #define FLEXSPI_AHBCR_CACHABLEEN ((uint32_t)(1<<3))
  4390. #define FLEXSPI_AHBCR_APAREN ((uint32_t)(1<<0))
  4391. #define FLEXSPI_INTEN (IMXRT_FLEXSPI.offset010)
  4392. #define FLEXSPI_INTEN_SEQTIMEOUTEN ((uint32_t)(1<<11))
  4393. #define FLEXSPI_INTEN_AHBBUSTIMEOUTEN ((uint32_t)(1<<10))
  4394. #define FLEXSPI_INTEN_SCKSTOPBYWREN ((uint32_t)(1<<9))
  4395. #define FLEXSPI_INTEN_SCKSTOPBYRDEN ((uint32_t)(1<<8))
  4396. #define FLEXSPI_INTEN_IPTXWEEN ((uint32_t)(1<<6))
  4397. #define FLEXSPI_INTEN_IPRXWAEN ((uint32_t)(1<<5))
  4398. #define FLEXSPI_INTEN_AHBCMDERREN ((uint32_t)(1<<4))
  4399. #define FLEXSPI_INTEN_IPCMDERREN ((uint32_t)(1<<3))
  4400. #define FLEXSPI_INTEN_AHBCMDGEEN ((uint32_t)(1<<2))
  4401. #define FLEXSPI_INTEN_IPCMDGEEN ((uint32_t)(1<<1))
  4402. #define FLEXSPI_INTEN_IPCMDDONEEN ((uint32_t)(1<<0))
  4403. #define FLEXSPI_INTR (IMXRT_FLEXSPI.offset014)
  4404. #define FLEXSPI_INTR_SEQTIMEOUT ((uint32_t)(1<<11))
  4405. #define FLEXSPI_INTR_AHBBUSTIMEOUT ((uint32_t)(1<<10))
  4406. #define FLEXSPI_INTR_SCKSTOPBYWR ((uint32_t)(1<<9))
  4407. #define FLEXSPI_INTR_SCKSTOPBYRD ((uint32_t)(1<<8))
  4408. #define FLEXSPI_INTR_IPTXWE ((uint32_t)(1<<6))
  4409. #define FLEXSPI_INTR_IPRXWA ((uint32_t)(1<<5))
  4410. #define FLEXSPI_INTR_AHBCMDERR ((uint32_t)(1<<4))
  4411. #define FLEXSPI_INTR_IPCMDERR ((uint32_t)(1<<3))
  4412. #define FLEXSPI_INTR_AHBCMDGE ((uint32_t)(1<<2))
  4413. #define FLEXSPI_INTR_IPCMDGE ((uint32_t)(1<<1))
  4414. #define FLEXSPI_INTR_IPCMDDONE ((uint32_t)(1<<0))
  4415. #define FLEXSPI_LUTKEY (IMXRT_FLEXSPI.offset018)
  4416. #define FLEXSPI_LUTKEY_VALUE ((uint32_t)0x5AF05AF0)
  4417. #define FLEXSPI_LUTCR (IMXRT_FLEXSPI.offset01C)
  4418. #define FLEXSPI_LUTCR_UNLOCK ((uint32_t)(1<<1))
  4419. #define FLEXSPI_LUTCR_LOCK ((uint32_t)(1<<0))
  4420. #define FLEXSPI_AHBRXBUF0CR0 (IMXRT_FLEXSPI.offset020)
  4421. #define FLEXSPI_AHBRXBUF1CR0 (IMXRT_FLEXSPI.offset024)
  4422. #define FLEXSPI_AHBRXBUF2CR0 (IMXRT_FLEXSPI.offset028)
  4423. #define FLEXSPI_AHBRXBUF3CR0 (IMXRT_FLEXSPI.offset02C)
  4424. #define FLEXSPI_AHBRXBUFCR0_PREFETCHEN ((uint32_t)(1<<31))
  4425. #define FLEXSPI_AHBRXBUFCR0_PRIORITY(n) ((uint32_t)(((n) & 0x03) << 24))
  4426. #define FLEXSPI_AHBRXBUFCR0_PRIORITY_MASK ((uint32_t)((0x03) << 24))
  4427. #define FLEXSPI_AHBRXBUFCR0_MSTRID(n) ((uint32_t)(((n) & 0x0F) << 16))
  4428. #define FLEXSPI_AHBRXBUFCR0_MSTRID_MASK ((uint32_t)((0x0F) << 16))
  4429. #define FLEXSPI_AHBRXBUFCR0_BUFSZ(n) ((uint32_t)(((n) & 0xFF) << 0))
  4430. #define FLEXSPI_AHBRXBUFCR0_BUFSZ_MASK ((uint32_t)((0xFF) << 0))
  4431. #define FLEXSPI_FLSHA1CR0 (IMXRT_FLEXSPI.offset060)
  4432. #define FLEXSPI_FLSHA2CR0 (IMXRT_FLEXSPI.offset064)
  4433. #define FLEXSPI_FLSHB1CR0 (IMXRT_FLEXSPI.offset068)
  4434. #define FLEXSPI_FLSHB2CR0 (IMXRT_FLEXSPI.offset06C)
  4435. #define FLEXSPI_FLSHCR0_FLSHSZ(n) ((uint32_t)(((n) & 0x7FFFFF) << 0))
  4436. #define FLEXSPI_FLSHCR0_FLSHSZ_MASK ((uint32_t)((0x7FFFFF) << 0))
  4437. #define FLEXSPI_FLSHA1CR1 (IMXRT_FLEXSPI.offset070)
  4438. #define FLEXSPI_FLSHA2CR1 (IMXRT_FLEXSPI.offset074)
  4439. #define FLEXSPI_FLSHB1CR1 (IMXRT_FLEXSPI.offset078)
  4440. #define FLEXSPI_FLSHB2CR1 (IMXRT_FLEXSPI.offset07C)
  4441. #define FLEXSPI_FLSHCR1_CSINTERVAL(n) ((uint32_t)(((n) & 0xFFFF) << 16))
  4442. #define FLEXSPI_FLSHCR1_CSINTERVAL_MASK ((uint32_t)((0xFFFF) << 16))
  4443. #define FLEXSPI_FLSHCR1_CSINTERVALUNIT ((uint32_t)(1<<15))
  4444. #define FLEXSPI_FLSHCR1_CAS(n) ((uint32_t)(((n) & 0x0F) << 11))
  4445. #define FLEXSPI_FLSHCR1_WA ((uint32_t)(1<<10))
  4446. #define FLEXSPI_FLSHCR1_TCSH(n) ((uint32_t)(((n) & 0x1F) << 5))
  4447. #define FLEXSPI_FLSHCR1_TCSH_MASK ((uint32_t)((0x1F) << 5))
  4448. #define FLEXSPI_FLSHCR1_TCSS(n) ((uint32_t)(((n) & 0x1F) << 0))
  4449. #define FLEXSPI_FLSHCR1_TCSS_MASK ((uint32_t)((0x1F) << 0))
  4450. #define FLEXSPI_FLSHA1CR2 (IMXRT_FLEXSPI.offset080)
  4451. #define FLEXSPI_FLSHA2CR2 (IMXRT_FLEXSPI.offset084)
  4452. #define FLEXSPI_FLSHB1CR2 (IMXRT_FLEXSPI.offset088)
  4453. #define FLEXSPI_FLSHB2CR2 (IMXRT_FLEXSPI.offset08C)
  4454. #define FLEXSPI_FLSHCR2_CLRINSTRPTR ((uint32_t)(1<<31))
  4455. #define FLEXSPI_FLSHCR2_AWRWAITUNIT(n) ((uint32_t)(((n) & 0x07) << 28))
  4456. #define FLEXSPI_FLSHCR2_AWRWAIT(n) ((uint32_t)(((n) & 0xFFF) << 16))
  4457. #define FLEXSPI_FLSHCR2_AWRSEQNUM(n) ((uint32_t)(((n) & 0x07) << 13))
  4458. #define FLEXSPI_FLSHCR2_AWRSEQID(n) ((uint32_t)(((n) & 0x0F) << 8))
  4459. #define FLEXSPI_FLSHCR2_ARDSEQNUM(n) ((uint32_t)(((n) & 0x07) << 5))
  4460. #define FLEXSPI_FLSHCR2_ARDSEQID(n) ((uint32_t)(((n) & 0x0F) << 0))
  4461. #define FLEXSPI_FLSHCR4 (IMXRT_FLEXSPI.offset094)
  4462. #define FLEXSPI_FLSHCR4_WMENB ((uint32_t)(1<<3))
  4463. #define FLEXSPI_FLSHCR4_WMENA ((uint32_t)(1<<2))
  4464. #define FLEXSPI_FLSHCR4_WMOPT1 ((uint32_t)(1<<0))
  4465. #define FLEXSPI_IPCR0 (IMXRT_FLEXSPI.offset0A0)
  4466. #define FLEXSPI_IPCR0_SFAR(n) ((uint32_t)(n))
  4467. #define FLEXSPI_IPCR1 (IMXRT_FLEXSPI.offset0A4)
  4468. #define FLEXSPI_IPCR1_IPAREN ((uint32_t)(1<<31))
  4469. #define FLEXSPI_IPCR1_ISEQNUM(n) ((uint32_t)(((n) & 0x07) << 24))
  4470. #define FLEXSPI_IPCR1_ISEQID(n) ((uint32_t)(((n) & 0x0F) << 16))
  4471. #define FLEXSPI_IPCR1_IDATSZ(n) ((uint32_t)(((n) & 0xFFFF) << 0))
  4472. #define FLEXSPI_IPCMD (IMXRT_FLEXSPI.offset0B0)
  4473. #define FLEXSPI_IPCMD_TRG ((uint32_t)(1<<0))
  4474. #define FLEXSPI_IPRXFCR (IMXRT_FLEXSPI.offset0B8)
  4475. #define FLEXSPI_IPRXFCR_RXWMRK(n) ((uint32_t)(((n) & 0x0F) << 2))
  4476. #define FLEXSPI_IPRXFCR_RXDMAEN ((uint32_t)(1<<1))
  4477. #define FLEXSPI_IPRXFCR_CLRIPRXF ((uint32_t)(1<<0))
  4478. #define FLEXSPI_IPTXFCR (IMXRT_FLEXSPI.offset0BC)
  4479. #define FLEXSPI_IPTXFCR_TXWMRK(n) ((uint32_t)(((n) & 0x0F) << 2))
  4480. #define FLEXSPI_IPTXFCR_TXDMAEN ((uint32_t)(1<<1))
  4481. #define FLEXSPI_IPTXFCR_CLRIPTXF ((uint32_t)(1<<0))
  4482. #define FLEXSPI_DLLACR (IMXRT_FLEXSPI.offset0C0)
  4483. #define FLEXSPI_DLLBCR (IMXRT_FLEXSPI.offset0C4)
  4484. #define FLEXSPI_DLLCR_OVRDVAL(n) ((uint32_t)(((n) & 0x3F) << 9))
  4485. #define FLEXSPI_DLLCR_OVRDEN ((uint32_t)(1<<8))
  4486. #define FLEXSPI_DLLCR_SLVDLYTARGET(n) ((uint32_t)(((n) & 0x0F) << 3))
  4487. #define FLEXSPI_DLLCR_DLLRESET ((uint32_t)(1<<1))
  4488. #define FLEXSPI_DLLCR_DLLEN ((uint32_t)(1<<0))
  4489. #define FLEXSPI_STS0 (IMXRT_FLEXSPI.offset0E0)
  4490. #define FLEXSPI_STS0_ARBCMDSRC(n) ((uint32_t)(((n) & 0x03) << 2))
  4491. #define FLEXSPI_STS0_ARBIDLE ((uint32_t)(1<<1))
  4492. #define FLEXSPI_STS0_SEQIDLE ((uint32_t)(1<<0))
  4493. #define FLEXSPI_STS1 (IMXRT_FLEXSPI.offset0E4)
  4494. #define FLEXSPI_STS1_IPCMDERRCODE(n) ((uint32_t)(((n) & 0x0F) << 24))
  4495. #define FLEXSPI_STS1_IPCMDERRID(n) ((uint32_t)(((n) & 0x0F) << 16))
  4496. #define FLEXSPI_STS1_AHBCMDERRCODE(n) ((uint32_t)(((n) & 0x0F) << 8))
  4497. #define FLEXSPI_STS1_AHBCMDERRID(n) ((uint32_t)(((n) & 0x0F) << 0))
  4498. #define FLEXSPI_STS2 (IMXRT_FLEXSPI.offset0E8)
  4499. #define FLEXSPI_STS2_BREFSEL(n) ((uint32_t)(((n) & 0x3F) << 24))
  4500. #define FLEXSPI_STS2_BSLVSEL(n) ((uint32_t)(((n) & 0x3F) << 18))
  4501. #define FLEXSPI_STS2_BREFLOCK ((uint32_t)(1<<17))
  4502. #define FLEXSPI_STS2_BSLVLOCK ((uint32_t)(1<<16))
  4503. #define FLEXSPI_STS2_AREFSEL(n) ((uint32_t)(((n) & 0x3F) << 8))
  4504. #define FLEXSPI_STS2_ASLVSEL(n) ((uint32_t)(((n) & 0x3F) << 2))
  4505. #define FLEXSPI_STS2_AREFLOCK ((uint32_t)(1<<1))
  4506. #define FLEXSPI_STS2_ASLVLOCK ((uint32_t)(1<<0))
  4507. #define FLEXSPI_AHBSPNDSTS (IMXRT_FLEXSPI.offset0EC)
  4508. #define FLEXSPI_AHBSPNDSTS_DATLFT(n) ((uint32_t)(((n) & 0xFFFF) << 16))
  4509. #define FLEXSPI_AHBSPNDSTS_BUFID(n) ((uint32_t)(((n) & 0x7) << 1))
  4510. #define FLEXSPI_AHBSPNDSTS_ACTIVE ((uint32_t)(1<<0))
  4511. #define FLEXSPI_IPRXFSTS (IMXRT_FLEXSPI.offset0F0)
  4512. #define FLEXSPI_IPRXFSTS_RDCNTR(n) ((uint32_t)(((n) & 0xFFFF) << 16))
  4513. #define FLEXSPI_IPRXFSTS_FILL(n) ((uint32_t)(((n) & 0xFF) << 0))
  4514. #define FLEXSPI_IPTXFSTS (IMXRT_FLEXSPI.offset0F4)
  4515. #define FLEXSPI_IPTXFSTS_WRCNTR(n) ((uint32_t)(((n) & 0xFFFF) << 16))
  4516. #define FLEXSPI_IPTXFSTS_FILL(n) ((uint32_t)(((n) & 0xFF) << 0))
  4517. #define FLEXSPI_RFDR0 (IMXRT_FLEXSPI.offset100)
  4518. #define FLEXSPI_RFDR1 (IMXRT_FLEXSPI.offset104)
  4519. #define FLEXSPI_RFDR2 (IMXRT_FLEXSPI.offset108)
  4520. #define FLEXSPI_RFDR3 (IMXRT_FLEXSPI.offset10C)
  4521. #define FLEXSPI_RFDR4 (IMXRT_FLEXSPI.offset110)
  4522. #define FLEXSPI_RFDR5 (IMXRT_FLEXSPI.offset114)
  4523. #define FLEXSPI_RFDR6 (IMXRT_FLEXSPI.offset118)
  4524. #define FLEXSPI_RFDR7 (IMXRT_FLEXSPI.offset11C)
  4525. #define FLEXSPI_RFDR8 (IMXRT_FLEXSPI.offset120)
  4526. #define FLEXSPI_RFDR9 (IMXRT_FLEXSPI.offset124)
  4527. #define FLEXSPI_RFDR10 (IMXRT_FLEXSPI.offset128)
  4528. #define FLEXSPI_RFDR11 (IMXRT_FLEXSPI.offset12C)
  4529. #define FLEXSPI_RFDR12 (IMXRT_FLEXSPI.offset130)
  4530. #define FLEXSPI_RFDR13 (IMXRT_FLEXSPI.offset134)
  4531. #define FLEXSPI_RFDR14 (IMXRT_FLEXSPI.offset138)
  4532. #define FLEXSPI_RFDR15 (IMXRT_FLEXSPI.offset13C)
  4533. #define FLEXSPI_RFDR16 (IMXRT_FLEXSPI.offset140)
  4534. #define FLEXSPI_RFDR17 (IMXRT_FLEXSPI.offset144)
  4535. #define FLEXSPI_RFDR18 (IMXRT_FLEXSPI.offset148)
  4536. #define FLEXSPI_RFDR19 (IMXRT_FLEXSPI.offset14C)
  4537. #define FLEXSPI_RFDR20 (IMXRT_FLEXSPI.offset150)
  4538. #define FLEXSPI_RFDR21 (IMXRT_FLEXSPI.offset154)
  4539. #define FLEXSPI_RFDR22 (IMXRT_FLEXSPI.offset158)
  4540. #define FLEXSPI_RFDR23 (IMXRT_FLEXSPI.offset15C)
  4541. #define FLEXSPI_RFDR24 (IMXRT_FLEXSPI.offset160)
  4542. #define FLEXSPI_RFDR25 (IMXRT_FLEXSPI.offset164)
  4543. #define FLEXSPI_RFDR26 (IMXRT_FLEXSPI.offset168)
  4544. #define FLEXSPI_RFDR27 (IMXRT_FLEXSPI.offset16C)
  4545. #define FLEXSPI_RFDR28 (IMXRT_FLEXSPI.offset170)
  4546. #define FLEXSPI_RFDR29 (IMXRT_FLEXSPI.offset174)
  4547. #define FLEXSPI_RFDR30 (IMXRT_FLEXSPI.offset178)
  4548. #define FLEXSPI_RFDR31 (IMXRT_FLEXSPI.offset17C)
  4549. #define FLEXSPI_TFDR0 (IMXRT_FLEXSPI.offset180)
  4550. #define FLEXSPI_TFDR1 (IMXRT_FLEXSPI.offset184)
  4551. #define FLEXSPI_TFDR2 (IMXRT_FLEXSPI.offset188)
  4552. #define FLEXSPI_TFDR3 (IMXRT_FLEXSPI.offset18C)
  4553. #define FLEXSPI_TFDR4 (IMXRT_FLEXSPI.offset190)
  4554. #define FLEXSPI_TFDR5 (IMXRT_FLEXSPI.offset194)
  4555. #define FLEXSPI_TFDR6 (IMXRT_FLEXSPI.offset198)
  4556. #define FLEXSPI_TFDR7 (IMXRT_FLEXSPI.offset19C)
  4557. #define FLEXSPI_TFDR8 (IMXRT_FLEXSPI.offset1A0)
  4558. #define FLEXSPI_TFDR9 (IMXRT_FLEXSPI.offset1A4)
  4559. #define FLEXSPI_TFDR10 (IMXRT_FLEXSPI.offset1A8)
  4560. #define FLEXSPI_TFDR11 (IMXRT_FLEXSPI.offset1AC)
  4561. #define FLEXSPI_TFDR12 (IMXRT_FLEXSPI.offset1B0)
  4562. #define FLEXSPI_TFDR13 (IMXRT_FLEXSPI.offset1B4)
  4563. #define FLEXSPI_TFDR14 (IMXRT_FLEXSPI.offset1B8)
  4564. #define FLEXSPI_TFDR15 (IMXRT_FLEXSPI.offset1BC)
  4565. #define FLEXSPI_TFDR16 (IMXRT_FLEXSPI.offset1C0)
  4566. #define FLEXSPI_TFDR17 (IMXRT_FLEXSPI.offset1C4)
  4567. #define FLEXSPI_TFDR18 (IMXRT_FLEXSPI.offset1C8)
  4568. #define FLEXSPI_TFDR19 (IMXRT_FLEXSPI.offset1CC)
  4569. #define FLEXSPI_TFDR20 (IMXRT_FLEXSPI.offset1D0)
  4570. #define FLEXSPI_TFDR21 (IMXRT_FLEXSPI.offset1D4)
  4571. #define FLEXSPI_TFDR22 (IMXRT_FLEXSPI.offset1D8)
  4572. #define FLEXSPI_TFDR23 (IMXRT_FLEXSPI.offset1DC)
  4573. #define FLEXSPI_TFDR24 (IMXRT_FLEXSPI.offset1E0)
  4574. #define FLEXSPI_TFDR25 (IMXRT_FLEXSPI.offset1E4)
  4575. #define FLEXSPI_TFDR26 (IMXRT_FLEXSPI.offset1E8)
  4576. #define FLEXSPI_TFDR27 (IMXRT_FLEXSPI.offset1EC)
  4577. #define FLEXSPI_TFDR28 (IMXRT_FLEXSPI.offset1F0)
  4578. #define FLEXSPI_TFDR29 (IMXRT_FLEXSPI.offset1F4)
  4579. #define FLEXSPI_TFDR30 (IMXRT_FLEXSPI.offset1F8)
  4580. #define FLEXSPI_TFDR31 (IMXRT_FLEXSPI.offset1FC)
  4581. #define FLEXSPI_LUT0 (IMXRT_FLEXSPI.offset200)
  4582. #define FLEXSPI_LUT1 (IMXRT_FLEXSPI.offset204)
  4583. #define FLEXSPI_LUT2 (IMXRT_FLEXSPI.offset208)
  4584. #define FLEXSPI_LUT3 (IMXRT_FLEXSPI.offset20C)
  4585. #define FLEXSPI_LUT4 (IMXRT_FLEXSPI.offset210)
  4586. #define FLEXSPI_LUT5 (IMXRT_FLEXSPI.offset214)
  4587. #define FLEXSPI_LUT6 (IMXRT_FLEXSPI.offset218)
  4588. #define FLEXSPI_LUT7 (IMXRT_FLEXSPI.offset21C)
  4589. #define FLEXSPI_LUT8 (IMXRT_FLEXSPI.offset220)
  4590. #define FLEXSPI_LUT9 (IMXRT_FLEXSPI.offset224)
  4591. #define FLEXSPI_LUT10 (IMXRT_FLEXSPI.offset228)
  4592. #define FLEXSPI_LUT11 (IMXRT_FLEXSPI.offset22C)
  4593. #define FLEXSPI_LUT12 (IMXRT_FLEXSPI.offset230)
  4594. #define FLEXSPI_LUT13 (IMXRT_FLEXSPI.offset234)
  4595. #define FLEXSPI_LUT14 (IMXRT_FLEXSPI.offset238)
  4596. #define FLEXSPI_LUT15 (IMXRT_FLEXSPI.offset23C)
  4597. #define FLEXSPI_LUT16 (IMXRT_FLEXSPI.offset240)
  4598. #define FLEXSPI_LUT17 (IMXRT_FLEXSPI.offset244)
  4599. #define FLEXSPI_LUT18 (IMXRT_FLEXSPI.offset248)
  4600. #define FLEXSPI_LUT19 (IMXRT_FLEXSPI.offset24C)
  4601. #define FLEXSPI_LUT20 (IMXRT_FLEXSPI.offset250)
  4602. #define FLEXSPI_LUT21 (IMXRT_FLEXSPI.offset254)
  4603. #define FLEXSPI_LUT22 (IMXRT_FLEXSPI.offset258)
  4604. #define FLEXSPI_LUT23 (IMXRT_FLEXSPI.offset25C)
  4605. #define FLEXSPI_LUT24 (IMXRT_FLEXSPI.offset260)
  4606. #define FLEXSPI_LUT25 (IMXRT_FLEXSPI.offset264)
  4607. #define FLEXSPI_LUT26 (IMXRT_FLEXSPI.offset268)
  4608. #define FLEXSPI_LUT27 (IMXRT_FLEXSPI.offset26C)
  4609. #define FLEXSPI_LUT28 (IMXRT_FLEXSPI.offset270)
  4610. #define FLEXSPI_LUT29 (IMXRT_FLEXSPI.offset274)
  4611. #define FLEXSPI_LUT30 (IMXRT_FLEXSPI.offset278)
  4612. #define FLEXSPI_LUT31 (IMXRT_FLEXSPI.offset27C)
  4613. #define FLEXSPI_LUT32 (IMXRT_FLEXSPI.offset280)
  4614. #define FLEXSPI_LUT33 (IMXRT_FLEXSPI.offset284)
  4615. #define FLEXSPI_LUT34 (IMXRT_FLEXSPI.offset288)
  4616. #define FLEXSPI_LUT35 (IMXRT_FLEXSPI.offset28C)
  4617. #define FLEXSPI_LUT36 (IMXRT_FLEXSPI.offset290)
  4618. #define FLEXSPI_LUT37 (IMXRT_FLEXSPI.offset294)
  4619. #define FLEXSPI_LUT38 (IMXRT_FLEXSPI.offset298)
  4620. #define FLEXSPI_LUT39 (IMXRT_FLEXSPI.offset29C)
  4621. #define FLEXSPI_LUT40 (IMXRT_FLEXSPI.offset2A0)
  4622. #define FLEXSPI_LUT41 (IMXRT_FLEXSPI.offset2A4)
  4623. #define FLEXSPI_LUT42 (IMXRT_FLEXSPI.offset2A8)
  4624. #define FLEXSPI_LUT43 (IMXRT_FLEXSPI.offset2AC)
  4625. #define FLEXSPI_LUT44 (IMXRT_FLEXSPI.offset2B0)
  4626. #define FLEXSPI_LUT45 (IMXRT_FLEXSPI.offset2B4)
  4627. #define FLEXSPI_LUT46 (IMXRT_FLEXSPI.offset2B8)
  4628. #define FLEXSPI_LUT47 (IMXRT_FLEXSPI.offset2BC)
  4629. #define FLEXSPI_LUT48 (IMXRT_FLEXSPI.offset2C0)
  4630. #define FLEXSPI_LUT49 (IMXRT_FLEXSPI.offset2C4)
  4631. #define FLEXSPI_LUT50 (IMXRT_FLEXSPI.offset2C8)
  4632. #define FLEXSPI_LUT51 (IMXRT_FLEXSPI.offset2CC)
  4633. #define FLEXSPI_LUT52 (IMXRT_FLEXSPI.offset2D0)
  4634. #define FLEXSPI_LUT53 (IMXRT_FLEXSPI.offset2D4)
  4635. #define FLEXSPI_LUT54 (IMXRT_FLEXSPI.offset2D8)
  4636. #define FLEXSPI_LUT55 (IMXRT_FLEXSPI.offset2DC)
  4637. #define FLEXSPI_LUT56 (IMXRT_FLEXSPI.offset2E0)
  4638. #define FLEXSPI_LUT57 (IMXRT_FLEXSPI.offset2E4)
  4639. #define FLEXSPI_LUT58 (IMXRT_FLEXSPI.offset2E8)
  4640. #define FLEXSPI_LUT59 (IMXRT_FLEXSPI.offset2EC)
  4641. #define FLEXSPI_LUT60 (IMXRT_FLEXSPI.offset2F0)
  4642. #define FLEXSPI_LUT61 (IMXRT_FLEXSPI.offset2F4)
  4643. #define FLEXSPI_LUT62 (IMXRT_FLEXSPI.offset2F8)
  4644. #define FLEXSPI_LUT63 (IMXRT_FLEXSPI.offset2FC)
  4645. #define FLEXSPI_LUT_OPCODE1(n) ((uint32_t)(((n) & 0x3F) << 26))
  4646. #define FLEXSPI_LUT_NUM_PADS1(n) ((uint32_t)(((n) & 0x03) << 24))
  4647. #define FLEXSPI_LUT_OPERAND1(n) ((uint32_t)(((n) & 0xFF) << 16))
  4648. #define FLEXSPI_LUT_OPCODE0(n) ((uint32_t)(((n) & 0x3F) << 10))
  4649. #define FLEXSPI_LUT_NUM_PADS0(n) ((uint32_t)(((n) & 0x03) << 8))
  4650. #define FLEXSPI_LUT_OPERAND0(n) ((uint32_t)(((n) & 0xFF) << 0))
  4651. #define FLEXSPI_LUT_INSTRUCTION(opcode, pads, operand) ((uint32_t)(\
  4652. (((opcode) & 0x3F) << 10) | (((pads) & 0x03) << 8) | ((operand) & 0xFF)))
  4653. // 30.7.8: page 1532
  4654. #define FLEXSPI_LUT_OPCODE_CMD_SDR 0x01
  4655. #define FLEXSPI_LUT_OPCODE_CMD_DDR 0x21
  4656. #define FLEXSPI_LUT_OPCODE_RADDR_SDR 0x02
  4657. #define FLEXSPI_LUT_OPCODE_RADDR_DDR 0x22
  4658. #define FLEXSPI_LUT_OPCODE_CADDR_SDR 0x03
  4659. #define FLEXSPI_LUT_OPCODE_CADDR_DDR 0x23
  4660. #define FLEXSPI_LUT_OPCODE_MODE1_SDR 0x04
  4661. #define FLEXSPI_LUT_OPCODE_MODE1_DDR 0x24
  4662. #define FLEXSPI_LUT_OPCODE_MODE2_SDR 0x05
  4663. #define FLEXSPI_LUT_OPCODE_MODE2_DDR 0x25
  4664. #define FLEXSPI_LUT_OPCODE_MODE4_SDR 0x06
  4665. #define FLEXSPI_LUT_OPCODE_MODE4_DDR 0x26
  4666. #define FLEXSPI_LUT_OPCODE_MODE8_SDR 0x07
  4667. #define FLEXSPI_LUT_OPCODE_MODE8_DDR 0x27
  4668. #define FLEXSPI_LUT_OPCODE_WRITE_SDR 0x08
  4669. #define FLEXSPI_LUT_OPCODE_WRITE_DDR 0x28
  4670. #define FLEXSPI_LUT_OPCODE_READ_SDR 0x09
  4671. #define FLEXSPI_LUT_OPCODE_READ_DDR 0x29
  4672. #define FLEXSPI_LUT_OPCODE_LEARN_SDR 0x0A
  4673. #define FLEXSPI_LUT_OPCODE_LEARN_DDR 0x2A
  4674. #define FLEXSPI_LUT_OPCODE_DATSZ_SDR 0x0B
  4675. #define FLEXSPI_LUT_OPCODE_DATSZ_DDR 0x2B
  4676. #define FLEXSPI_LUT_OPCODE_DUMMY_SDR 0x0C
  4677. #define FLEXSPI_LUT_OPCODE_DUMMY_DDR 0x2C
  4678. #define FLEXSPI_LUT_OPCODE_DUMMY_RWDS_SDR 0x0D
  4679. #define FLEXSPI_LUT_OPCODE_DUMMY_RWDS_DDR 0x2D
  4680. #define FLEXSPI_LUT_OPCODE_JMP_ON_CS 0x1F
  4681. #define FLEXSPI_LUT_OPCODE_STOP 0x00
  4682. #define FLEXSPI_LUT_NUM_PADS_1 0x00
  4683. #define FLEXSPI_LUT_NUM_PADS_2 0x01
  4684. #define FLEXSPI_LUT_NUM_PADS_4 0x02
  4685. #define FLEXSPI_LUT_NUM_PADS_8 0x03
  4686. #define IMXRT_FLEXSPI2 (*(IMXRT_REGISTER32_t *)0x402A4000)
  4687. #define FLEXSPI2_MCR0 (IMXRT_FLEXSPI2.offset000)
  4688. #define FLEXSPI2_MCR1 (IMXRT_FLEXSPI2.offset004)
  4689. #define FLEXSPI2_MCR2 (IMXRT_FLEXSPI2.offset008)
  4690. #define FLEXSPI2_AHBCR (IMXRT_FLEXSPI2.offset00C)
  4691. #define FLEXSPI2_INTEN (IMXRT_FLEXSPI2.offset010)
  4692. #define FLEXSPI2_INTR (IMXRT_FLEXSPI2.offset014)
  4693. #define FLEXSPI2_LUTKEY (IMXRT_FLEXSPI2.offset018)
  4694. #define FLEXSPI2_LUTCR (IMXRT_FLEXSPI2.offset01C)
  4695. #define FLEXSPI2_AHBRXBUF0CR0 (IMXRT_FLEXSPI2.offset020)
  4696. #define FLEXSPI2_AHBRXBUF1CR0 (IMXRT_FLEXSPI2.offset024)
  4697. #define FLEXSPI2_AHBRXBUF2CR0 (IMXRT_FLEXSPI2.offset028)
  4698. #define FLEXSPI2_AHBRXBUF3CR0 (IMXRT_FLEXSPI2.offset02C)
  4699. #define FLEXSPI2_FLSHA1CR0 (IMXRT_FLEXSPI2.offset060)
  4700. #define FLEXSPI2_FLSHA2CR0 (IMXRT_FLEXSPI2.offset064)
  4701. #define FLEXSPI2_FLSHB1CR0 (IMXRT_FLEXSPI2.offset068)
  4702. #define FLEXSPI2_FLSHB2CR0 (IMXRT_FLEXSPI2.offset06C)
  4703. #define FLEXSPI2_FLSHA1CR1 (IMXRT_FLEXSPI2.offset070)
  4704. #define FLEXSPI2_FLSHA2CR1 (IMXRT_FLEXSPI2.offset074)
  4705. #define FLEXSPI2_FLSHB1CR1 (IMXRT_FLEXSPI2.offset078)
  4706. #define FLEXSPI2_FLSHB2CR1 (IMXRT_FLEXSPI2.offset07C)
  4707. #define FLEXSPI2_FLSHA1CR2 (IMXRT_FLEXSPI2.offset080)
  4708. #define FLEXSPI2_FLSHA2CR2 (IMXRT_FLEXSPI2.offset084)
  4709. #define FLEXSPI2_FLSHB1CR2 (IMXRT_FLEXSPI2.offset088)
  4710. #define FLEXSPI2_FLSHB2CR2 (IMXRT_FLEXSPI2.offset08C)
  4711. #define FLEXSPI2_FLSHCR4 (IMXRT_FLEXSPI2.offset094)
  4712. #define FLEXSPI2_IPCR0 (IMXRT_FLEXSPI2.offset0A0)
  4713. #define FLEXSPI2_IPCR1 (IMXRT_FLEXSPI2.offset0A4)
  4714. #define FLEXSPI2_IPCMD (IMXRT_FLEXSPI2.offset0B0)
  4715. #define FLEXSPI2_IPRXFCR (IMXRT_FLEXSPI2.offset0B8)
  4716. #define FLEXSPI2_IPTXFCR (IMXRT_FLEXSPI2.offset0BC)
  4717. #define FLEXSPI2_DLLACR (IMXRT_FLEXSPI2.offset0C0)
  4718. #define FLEXSPI2_DLLBCR (IMXRT_FLEXSPI2.offset0C4)
  4719. #define FLEXSPI2_STS0 (IMXRT_FLEXSPI2.offset0E0)
  4720. #define FLEXSPI2_STS1 (IMXRT_FLEXSPI2.offset0E4)
  4721. #define FLEXSPI2_STS2 (IMXRT_FLEXSPI2.offset0E8)
  4722. #define FLEXSPI2_AHBSPNDSTS (IMXRT_FLEXSPI2.offset0EC)
  4723. #define FLEXSPI2_IPRXFSTS (IMXRT_FLEXSPI2.offset0F0)
  4724. #define FLEXSPI2_IPTXFSTS (IMXRT_FLEXSPI2.offset0F4)
  4725. #define FLEXSPI2_RFDR0 (IMXRT_FLEXSPI2.offset100)
  4726. #define FLEXSPI2_RFDR1 (IMXRT_FLEXSPI2.offset104)
  4727. #define FLEXSPI2_RFDR2 (IMXRT_FLEXSPI2.offset108)
  4728. #define FLEXSPI2_RFDR3 (IMXRT_FLEXSPI2.offset10C)
  4729. #define FLEXSPI2_RFDR4 (IMXRT_FLEXSPI2.offset110)
  4730. #define FLEXSPI2_RFDR5 (IMXRT_FLEXSPI2.offset114)
  4731. #define FLEXSPI2_RFDR6 (IMXRT_FLEXSPI2.offset118)
  4732. #define FLEXSPI2_RFDR7 (IMXRT_FLEXSPI2.offset11C)
  4733. #define FLEXSPI2_RFDR8 (IMXRT_FLEXSPI2.offset120)
  4734. #define FLEXSPI2_RFDR9 (IMXRT_FLEXSPI2.offset124)
  4735. #define FLEXSPI2_RFDR10 (IMXRT_FLEXSPI2.offset128)
  4736. #define FLEXSPI2_RFDR11 (IMXRT_FLEXSPI2.offset12C)
  4737. #define FLEXSPI2_RFDR12 (IMXRT_FLEXSPI2.offset130)
  4738. #define FLEXSPI2_RFDR13 (IMXRT_FLEXSPI2.offset134)
  4739. #define FLEXSPI2_RFDR14 (IMXRT_FLEXSPI2.offset138)
  4740. #define FLEXSPI2_RFDR15 (IMXRT_FLEXSPI2.offset13C)
  4741. #define FLEXSPI2_RFDR16 (IMXRT_FLEXSPI2.offset140)
  4742. #define FLEXSPI2_RFDR17 (IMXRT_FLEXSPI2.offset144)
  4743. #define FLEXSPI2_RFDR18 (IMXRT_FLEXSPI2.offset148)
  4744. #define FLEXSPI2_RFDR19 (IMXRT_FLEXSPI2.offset14C)
  4745. #define FLEXSPI2_RFDR20 (IMXRT_FLEXSPI2.offset150)
  4746. #define FLEXSPI2_RFDR21 (IMXRT_FLEXSPI2.offset154)
  4747. #define FLEXSPI2_RFDR22 (IMXRT_FLEXSPI2.offset158)
  4748. #define FLEXSPI2_RFDR23 (IMXRT_FLEXSPI2.offset15C)
  4749. #define FLEXSPI2_RFDR24 (IMXRT_FLEXSPI2.offset160)
  4750. #define FLEXSPI2_RFDR25 (IMXRT_FLEXSPI2.offset164)
  4751. #define FLEXSPI2_RFDR26 (IMXRT_FLEXSPI2.offset168)
  4752. #define FLEXSPI2_RFDR27 (IMXRT_FLEXSPI2.offset16C)
  4753. #define FLEXSPI2_RFDR28 (IMXRT_FLEXSPI2.offset170)
  4754. #define FLEXSPI2_RFDR29 (IMXRT_FLEXSPI2.offset174)
  4755. #define FLEXSPI2_RFDR30 (IMXRT_FLEXSPI2.offset178)
  4756. #define FLEXSPI2_RFDR31 (IMXRT_FLEXSPI2.offset17C)
  4757. #define FLEXSPI2_TFDR0 (IMXRT_FLEXSPI2.offset180)
  4758. #define FLEXSPI2_TFDR1 (IMXRT_FLEXSPI2.offset184)
  4759. #define FLEXSPI2_TFDR2 (IMXRT_FLEXSPI2.offset188)
  4760. #define FLEXSPI2_TFDR3 (IMXRT_FLEXSPI2.offset18C)
  4761. #define FLEXSPI2_TFDR4 (IMXRT_FLEXSPI2.offset190)
  4762. #define FLEXSPI2_TFDR5 (IMXRT_FLEXSPI2.offset194)
  4763. #define FLEXSPI2_TFDR6 (IMXRT_FLEXSPI2.offset198)
  4764. #define FLEXSPI2_TFDR7 (IMXRT_FLEXSPI2.offset19C)
  4765. #define FLEXSPI2_TFDR8 (IMXRT_FLEXSPI2.offset1A0)
  4766. #define FLEXSPI2_TFDR9 (IMXRT_FLEXSPI2.offset1A4)
  4767. #define FLEXSPI2_TFDR10 (IMXRT_FLEXSPI2.offset1A8)
  4768. #define FLEXSPI2_TFDR11 (IMXRT_FLEXSPI2.offset1AC)
  4769. #define FLEXSPI2_TFDR12 (IMXRT_FLEXSPI2.offset1B0)
  4770. #define FLEXSPI2_TFDR13 (IMXRT_FLEXSPI2.offset1B4)
  4771. #define FLEXSPI2_TFDR14 (IMXRT_FLEXSPI2.offset1B8)
  4772. #define FLEXSPI2_TFDR15 (IMXRT_FLEXSPI2.offset1BC)
  4773. #define FLEXSPI2_TFDR16 (IMXRT_FLEXSPI2.offset1C0)
  4774. #define FLEXSPI2_TFDR17 (IMXRT_FLEXSPI2.offset1C4)
  4775. #define FLEXSPI2_TFDR18 (IMXRT_FLEXSPI2.offset1C8)
  4776. #define FLEXSPI2_TFDR19 (IMXRT_FLEXSPI2.offset1CC)
  4777. #define FLEXSPI2_TFDR20 (IMXRT_FLEXSPI2.offset1D0)
  4778. #define FLEXSPI2_TFDR21 (IMXRT_FLEXSPI2.offset1D4)
  4779. #define FLEXSPI2_TFDR22 (IMXRT_FLEXSPI2.offset1D8)
  4780. #define FLEXSPI2_TFDR23 (IMXRT_FLEXSPI2.offset1DC)
  4781. #define FLEXSPI2_TFDR24 (IMXRT_FLEXSPI2.offset1E0)
  4782. #define FLEXSPI2_TFDR25 (IMXRT_FLEXSPI2.offset1E4)
  4783. #define FLEXSPI2_TFDR26 (IMXRT_FLEXSPI2.offset1E8)
  4784. #define FLEXSPI2_TFDR27 (IMXRT_FLEXSPI2.offset1EC)
  4785. #define FLEXSPI2_TFDR28 (IMXRT_FLEXSPI2.offset1F0)
  4786. #define FLEXSPI2_TFDR29 (IMXRT_FLEXSPI2.offset1F4)
  4787. #define FLEXSPI2_TFDR30 (IMXRT_FLEXSPI2.offset1F8)
  4788. #define FLEXSPI2_TFDR31 (IMXRT_FLEXSPI2.offset1FC)
  4789. #define FLEXSPI2_LUT0 (IMXRT_FLEXSPI2.offset200)
  4790. #define FLEXSPI2_LUT1 (IMXRT_FLEXSPI2.offset204)
  4791. #define FLEXSPI2_LUT2 (IMXRT_FLEXSPI2.offset208)
  4792. #define FLEXSPI2_LUT3 (IMXRT_FLEXSPI2.offset20C)
  4793. #define FLEXSPI2_LUT4 (IMXRT_FLEXSPI2.offset210)
  4794. #define FLEXSPI2_LUT5 (IMXRT_FLEXSPI2.offset214)
  4795. #define FLEXSPI2_LUT6 (IMXRT_FLEXSPI2.offset218)
  4796. #define FLEXSPI2_LUT7 (IMXRT_FLEXSPI2.offset21C)
  4797. #define FLEXSPI2_LUT8 (IMXRT_FLEXSPI2.offset220)
  4798. #define FLEXSPI2_LUT9 (IMXRT_FLEXSPI2.offset224)
  4799. #define FLEXSPI2_LUT10 (IMXRT_FLEXSPI2.offset228)
  4800. #define FLEXSPI2_LUT11 (IMXRT_FLEXSPI2.offset22C)
  4801. #define FLEXSPI2_LUT12 (IMXRT_FLEXSPI2.offset230)
  4802. #define FLEXSPI2_LUT13 (IMXRT_FLEXSPI2.offset234)
  4803. #define FLEXSPI2_LUT14 (IMXRT_FLEXSPI2.offset238)
  4804. #define FLEXSPI2_LUT15 (IMXRT_FLEXSPI2.offset23C)
  4805. #define FLEXSPI2_LUT16 (IMXRT_FLEXSPI2.offset240)
  4806. #define FLEXSPI2_LUT17 (IMXRT_FLEXSPI2.offset244)
  4807. #define FLEXSPI2_LUT18 (IMXRT_FLEXSPI2.offset248)
  4808. #define FLEXSPI2_LUT19 (IMXRT_FLEXSPI2.offset24C)
  4809. #define FLEXSPI2_LUT20 (IMXRT_FLEXSPI2.offset250)
  4810. #define FLEXSPI2_LUT21 (IMXRT_FLEXSPI2.offset254)
  4811. #define FLEXSPI2_LUT22 (IMXRT_FLEXSPI2.offset258)
  4812. #define FLEXSPI2_LUT23 (IMXRT_FLEXSPI2.offset25C)
  4813. #define FLEXSPI2_LUT24 (IMXRT_FLEXSPI2.offset260)
  4814. #define FLEXSPI2_LUT25 (IMXRT_FLEXSPI2.offset264)
  4815. #define FLEXSPI2_LUT26 (IMXRT_FLEXSPI2.offset268)
  4816. #define FLEXSPI2_LUT27 (IMXRT_FLEXSPI2.offset26C)
  4817. #define FLEXSPI2_LUT28 (IMXRT_FLEXSPI2.offset270)
  4818. #define FLEXSPI2_LUT29 (IMXRT_FLEXSPI2.offset274)
  4819. #define FLEXSPI2_LUT30 (IMXRT_FLEXSPI2.offset278)
  4820. #define FLEXSPI2_LUT31 (IMXRT_FLEXSPI2.offset27C)
  4821. #define FLEXSPI2_LUT32 (IMXRT_FLEXSPI2.offset280)
  4822. #define FLEXSPI2_LUT33 (IMXRT_FLEXSPI2.offset284)
  4823. #define FLEXSPI2_LUT34 (IMXRT_FLEXSPI2.offset288)
  4824. #define FLEXSPI2_LUT35 (IMXRT_FLEXSPI2.offset28C)
  4825. #define FLEXSPI2_LUT36 (IMXRT_FLEXSPI2.offset290)
  4826. #define FLEXSPI2_LUT37 (IMXRT_FLEXSPI2.offset294)
  4827. #define FLEXSPI2_LUT38 (IMXRT_FLEXSPI2.offset298)
  4828. #define FLEXSPI2_LUT39 (IMXRT_FLEXSPI2.offset29C)
  4829. #define FLEXSPI2_LUT40 (IMXRT_FLEXSPI2.offset2A0)
  4830. #define FLEXSPI2_LUT41 (IMXRT_FLEXSPI2.offset2A4)
  4831. #define FLEXSPI2_LUT42 (IMXRT_FLEXSPI2.offset2A8)
  4832. #define FLEXSPI2_LUT43 (IMXRT_FLEXSPI2.offset2AC)
  4833. #define FLEXSPI2_LUT44 (IMXRT_FLEXSPI2.offset2B0)
  4834. #define FLEXSPI2_LUT45 (IMXRT_FLEXSPI2.offset2B4)
  4835. #define FLEXSPI2_LUT46 (IMXRT_FLEXSPI2.offset2B8)
  4836. #define FLEXSPI2_LUT47 (IMXRT_FLEXSPI2.offset2BC)
  4837. #define FLEXSPI2_LUT48 (IMXRT_FLEXSPI2.offset2C0)
  4838. #define FLEXSPI2_LUT49 (IMXRT_FLEXSPI2.offset2C4)
  4839. #define FLEXSPI2_LUT50 (IMXRT_FLEXSPI2.offset2C8)
  4840. #define FLEXSPI2_LUT51 (IMXRT_FLEXSPI2.offset2CC)
  4841. #define FLEXSPI2_LUT52 (IMXRT_FLEXSPI2.offset2D0)
  4842. #define FLEXSPI2_LUT53 (IMXRT_FLEXSPI2.offset2D4)
  4843. #define FLEXSPI2_LUT54 (IMXRT_FLEXSPI2.offset2D8)
  4844. #define FLEXSPI2_LUT55 (IMXRT_FLEXSPI2.offset2DC)
  4845. #define FLEXSPI2_LUT56 (IMXRT_FLEXSPI2.offset2E0)
  4846. #define FLEXSPI2_LUT57 (IMXRT_FLEXSPI2.offset2E4)
  4847. #define FLEXSPI2_LUT58 (IMXRT_FLEXSPI2.offset2E8)
  4848. #define FLEXSPI2_LUT59 (IMXRT_FLEXSPI2.offset2EC)
  4849. #define FLEXSPI2_LUT60 (IMXRT_FLEXSPI2.offset2F0)
  4850. #define FLEXSPI2_LUT61 (IMXRT_FLEXSPI2.offset2F4)
  4851. #define FLEXSPI2_LUT62 (IMXRT_FLEXSPI2.offset2F8)
  4852. #define FLEXSPI2_LUT63 (IMXRT_FLEXSPI2.offset2FC)
  4853. // 31.5: page 1595
  4854. #define IMXRT_GPC (*(IMXRT_REGISTER32_t *)0x400F4000)
  4855. #define GPC_CNTR (IMXRT_GPC.offset000)
  4856. #define GPC_IMR1 (IMXRT_GPC.offset008)
  4857. #define GPC_IMR2 (IMXRT_GPC.offset00C)
  4858. #define GPC_IMR3 (IMXRT_GPC.offset010)
  4859. #define GPC_IMR4 (IMXRT_GPC.offset014)
  4860. #define GPC_ISR1 (IMXRT_GPC.offset018)
  4861. #define GPC_ISR2 (IMXRT_GPC.offset01C)
  4862. #define GPC_ISR3 (IMXRT_GPC.offset020)
  4863. #define GPC_ISR4 (IMXRT_GPC.offset024)
  4864. #define GPC_IMR5 (IMXRT_GPC.offset034)
  4865. #define GPC_ISR5 (IMXRT_GPC.offset038)
  4866. #define GPC_CNTR_PDRAM0_PGE ((uint32_t)(1<<22))
  4867. #define GPC_CNTR_MEGA_PUP_REQ ((uint32_t)(1<<3))
  4868. #define GPC_CNTR_MEGA_PDN_REQ ((uint32_t)(1<<2))
  4869. // page 1602
  4870. #define PGC_MEGA_CTRL (IMXRT_GPC.offset220)
  4871. #define PGC_MEGA_PUPSCR (IMXRT_GPC.offset224)
  4872. #define PGC_MEGA_PDNSCR (IMXRT_GPC.offset228)
  4873. #define PGC_MEGA_SR (IMXRT_GPC.offset22C)
  4874. #define PGC_CPU_CTRL (IMXRT_GPC.offset2A0)
  4875. #define PGC_CPU_PUPSCR (IMXRT_GPC.offset2A4)
  4876. #define PGC_CPU_PDNSCR (IMXRT_GPC.offset2A8)
  4877. #define PGC_CPU_SR (IMXRT_GPC.offset2AC)
  4878. #define PGC_MEGA_CTRL_PCR ((uint32_t)(1<<0))
  4879. #define PGC_MEGA_PUPSCR_SW2ISO(n) ((uint32_t)(((n) & 0x3F) << 8))
  4880. #define PGC_MEGA_PUPSCR_SW(n) ((uint32_t)(((n) & 0x3F) << 0))
  4881. #define PGC_MEGA_PDNSCR_ISO2SW(n) ((uint32_t)(((n) & 0x3F) << 8))
  4882. #define PGC_MEGA_PDNSCR_ISO(n) ((uint32_t)(((n) & 0x3F) << 0))
  4883. #define PGC_MEGA_SR_PSR ((uint32_t)(1<<0))
  4884. #define PGC_CPU_CTRL_PCR ((uint32_t)(1<<0))
  4885. #define PGC_CPU_PUPSCR_SW2ISO(n) ((uint32_t)(((n) & 0x3F) << 8))
  4886. #define PGC_CPU_PUPSCR_SW(n) ((uint32_t)(((n) & 0x3F) << 0))
  4887. #define PGC_CPU_PDNSCR_ISO2SW(n) ((uint32_t)(((n) & 0x3F) << 8))
  4888. #define PGC_CPU_PDNSCR_ISO(n) ((uint32_t)(((n) & 0x3F) << 0))
  4889. #define PGC_CPU_SR_PSR ((uint32_t)(1<<0))
  4890. // 32.4.1: page 1620
  4891. #define IMXRT_GPIO1 (*(IMXRT_REGISTER32_t *)0x401B8000)
  4892. #define GPIO1_DR (IMXRT_GPIO1.offset000)
  4893. #define GPIO1_GDIR (IMXRT_GPIO1.offset004)
  4894. #define GPIO1_PSR (IMXRT_GPIO1.offset008)
  4895. #define GPIO1_ICR1 (IMXRT_GPIO1.offset00C)
  4896. #define GPIO1_ICR2 (IMXRT_GPIO1.offset010)
  4897. #define GPIO1_IMR (IMXRT_GPIO1.offset014)
  4898. #define GPIO1_ISR (IMXRT_GPIO1.offset018)
  4899. #define GPIO1_EDGE_SEL (IMXRT_GPIO1.offset01C)
  4900. #define GPIO1_DR_SET (IMXRT_GPIO1.offset084)
  4901. #define GPIO1_DR_CLEAR (IMXRT_GPIO1.offset088)
  4902. #define GPIO1_DR_TOGGLE (IMXRT_GPIO1.offset08C)
  4903. #define IMXRT_GPIO2 (*(IMXRT_REGISTER32_t *)0x401BC000)
  4904. #define GPIO2_DR (IMXRT_GPIO2.offset000)
  4905. #define GPIO2_GDIR (IMXRT_GPIO2.offset004)
  4906. #define GPIO2_PSR (IMXRT_GPIO2.offset008)
  4907. #define GPIO2_ICR1 (IMXRT_GPIO2.offset00C)
  4908. #define GPIO2_ICR2 (IMXRT_GPIO2.offset010)
  4909. #define GPIO2_IMR (IMXRT_GPIO2.offset014)
  4910. #define GPIO2_ISR (IMXRT_GPIO2.offset018)
  4911. #define GPIO2_EDGE_SEL (IMXRT_GPIO2.offset01C)
  4912. #define GPIO2_DR_SET (IMXRT_GPIO2.offset084)
  4913. #define GPIO2_DR_CLEAR (IMXRT_GPIO2.offset088)
  4914. #define GPIO2_DR_TOGGLE (IMXRT_GPIO2.offset08C)
  4915. #define IMXRT_GPIO3 (*(IMXRT_REGISTER32_t *)0x401C0000)
  4916. #define GPIO3_DR (IMXRT_GPIO3.offset000)
  4917. #define GPIO3_GDIR (IMXRT_GPIO3.offset004)
  4918. #define GPIO3_PSR (IMXRT_GPIO3.offset008)
  4919. #define GPIO3_ICR1 (IMXRT_GPIO3.offset00C)
  4920. #define GPIO3_ICR2 (IMXRT_GPIO3.offset010)
  4921. #define GPIO3_IMR (IMXRT_GPIO3.offset014)
  4922. #define GPIO3_ISR (IMXRT_GPIO3.offset018)
  4923. #define GPIO3_EDGE_SEL (IMXRT_GPIO3.offset01C)
  4924. #define GPIO3_DR_SET (IMXRT_GPIO3.offset084)
  4925. #define GPIO3_DR_CLEAR (IMXRT_GPIO3.offset088)
  4926. #define GPIO3_DR_TOGGLE (IMXRT_GPIO3.offset08C)
  4927. #define IMXRT_GPIO4 (*(IMXRT_REGISTER32_t *)0x401C4000)
  4928. #define GPIO4_DR (IMXRT_GPIO4.offset000)
  4929. #define GPIO4_GDIR (IMXRT_GPIO4.offset004)
  4930. #define GPIO4_PSR (IMXRT_GPIO4.offset008)
  4931. #define GPIO4_ICR1 (IMXRT_GPIO4.offset00C)
  4932. #define GPIO4_ICR2 (IMXRT_GPIO4.offset010)
  4933. #define GPIO4_IMR (IMXRT_GPIO4.offset014)
  4934. #define GPIO4_ISR (IMXRT_GPIO4.offset018)
  4935. #define GPIO4_EDGE_SEL (IMXRT_GPIO4.offset01C)
  4936. #define GPIO4_DR_SET (IMXRT_GPIO4.offset084)
  4937. #define GPIO4_DR_CLEAR (IMXRT_GPIO4.offset088)
  4938. #define GPIO4_DR_TOGGLE (IMXRT_GPIO4.offset08C)
  4939. #define IMXRT_GPIO5 (*(IMXRT_REGISTER32_t *)0x400C0000)
  4940. #define GPIO5_DR (IMXRT_GPIO5.offset000)
  4941. #define GPIO5_GDIR (IMXRT_GPIO5.offset004)
  4942. #define GPIO5_PSR (IMXRT_GPIO5.offset008)
  4943. #define GPIO5_ICR1 (IMXRT_GPIO5.offset00C)
  4944. #define GPIO5_ICR2 (IMXRT_GPIO5.offset010)
  4945. #define GPIO5_IMR (IMXRT_GPIO5.offset014)
  4946. #define GPIO5_ISR (IMXRT_GPIO5.offset018)
  4947. #define GPIO5_EDGE_SEL (IMXRT_GPIO5.offset01C)
  4948. #define GPIO5_DR_SET (IMXRT_GPIO5.offset084)
  4949. #define GPIO5_DR_CLEAR (IMXRT_GPIO5.offset088)
  4950. #define GPIO5_DR_TOGGLE (IMXRT_GPIO5.offset08C)
  4951. #define IMXRT_GPIO6 (*(IMXRT_REGISTER32_t *)0x42000000)
  4952. #define GPIO6_DR (IMXRT_GPIO6.offset000)
  4953. #define GPIO6_GDIR (IMXRT_GPIO6.offset004)
  4954. #define GPIO6_PSR (IMXRT_GPIO6.offset008)
  4955. #define GPIO6_ICR1 (IMXRT_GPIO6.offset00C)
  4956. #define GPIO6_ICR2 (IMXRT_GPIO6.offset010)
  4957. #define GPIO6_IMR (IMXRT_GPIO6.offset014)
  4958. #define GPIO6_ISR (IMXRT_GPIO6.offset018)
  4959. #define GPIO6_EDGE_SEL (IMXRT_GPIO6.offset01C)
  4960. #define GPIO6_DR_SET (IMXRT_GPIO6.offset084)
  4961. #define GPIO6_DR_CLEAR (IMXRT_GPIO6.offset088)
  4962. #define GPIO6_DR_TOGGLE (IMXRT_GPIO6.offset08C)
  4963. #define IMXRT_GPIO7 (*(IMXRT_REGISTER32_t *)0x42004000)
  4964. #define GPIO7_DR (IMXRT_GPIO7.offset000)
  4965. #define GPIO7_GDIR (IMXRT_GPIO7.offset004)
  4966. #define GPIO7_PSR (IMXRT_GPIO7.offset008)
  4967. #define GPIO7_ICR1 (IMXRT_GPIO7.offset00C)
  4968. #define GPIO7_ICR2 (IMXRT_GPIO7.offset010)
  4969. #define GPIO7_IMR (IMXRT_GPIO7.offset014)
  4970. #define GPIO7_ISR (IMXRT_GPIO7.offset018)
  4971. #define GPIO7_EDGE_SEL (IMXRT_GPIO7.offset01C)
  4972. #define GPIO7_DR_SET (IMXRT_GPIO7.offset084)
  4973. #define GPIO7_DR_CLEAR (IMXRT_GPIO7.offset088)
  4974. #define GPIO7_DR_TOGGLE (IMXRT_GPIO7.offset08C)
  4975. #define IMXRT_GPIO8 (*(IMXRT_REGISTER32_t *)0x42008000)
  4976. #define GPIO8_DR (IMXRT_GPIO8.offset000)
  4977. #define GPIO8_GDIR (IMXRT_GPIO8.offset004)
  4978. #define GPIO8_PSR (IMXRT_GPIO8.offset008)
  4979. #define GPIO8_ICR1 (IMXRT_GPIO8.offset00C)
  4980. #define GPIO8_ICR2 (IMXRT_GPIO8.offset010)
  4981. #define GPIO8_IMR (IMXRT_GPIO8.offset014)
  4982. #define GPIO8_ISR (IMXRT_GPIO8.offset018)
  4983. #define GPIO8_EDGE_SEL (IMXRT_GPIO8.offset01C)
  4984. #define GPIO8_DR_SET (IMXRT_GPIO8.offset084)
  4985. #define GPIO8_DR_CLEAR (IMXRT_GPIO8.offset088)
  4986. #define GPIO8_DR_TOGGLE (IMXRT_GPIO8.offset08C)
  4987. #define IMXRT_GPIO9 (*(IMXRT_REGISTER32_t *)0x4200C000)
  4988. #define GPIO9_DR (IMXRT_GPIO9.offset000)
  4989. #define GPIO9_GDIR (IMXRT_GPIO9.offset004)
  4990. #define GPIO9_PSR (IMXRT_GPIO9.offset008)
  4991. #define GPIO9_ICR1 (IMXRT_GPIO9.offset00C)
  4992. #define GPIO9_ICR2 (IMXRT_GPIO9.offset010)
  4993. #define GPIO9_IMR (IMXRT_GPIO9.offset014)
  4994. #define GPIO9_ISR (IMXRT_GPIO9.offset018)
  4995. #define GPIO9_EDGE_SEL (IMXRT_GPIO9.offset01C)
  4996. #define GPIO9_DR_SET (IMXRT_GPIO9.offset084)
  4997. #define GPIO9_DR_CLEAR (IMXRT_GPIO9.offset088)
  4998. #define GPIO9_DR_TOGGLE (IMXRT_GPIO9.offset08C)
  4999. // 33.6: page 1651
  5000. #define IMXRT_GPT1 (*(IMXRT_REGISTER32_t *)0x401EC000)
  5001. #define GPT1_CR (IMXRT_GPT1.offset000)
  5002. #define GPT1_PR (IMXRT_GPT1.offset004)
  5003. #define GPT1_SR (IMXRT_GPT1.offset008)
  5004. #define GPT1_IR (IMXRT_GPT1.offset00C)
  5005. #define GPT1_OCR1 (IMXRT_GPT1.offset010)
  5006. #define GPT1_OCR2 (IMXRT_GPT1.offset014)
  5007. #define GPT1_OCR3 (IMXRT_GPT1.offset018)
  5008. #define GPT1_ICR1 (IMXRT_GPT1.offset01C)
  5009. #define GPT1_ICR2 (IMXRT_GPT1.offset020)
  5010. #define GPT1_CNT (IMXRT_GPT1.offset024)
  5011. #define IMXRT_GPT2 (*(IMXRT_REGISTER32_t *)0x401F0000)
  5012. #define GPT2_CR (IMXRT_GPT2.offset000)
  5013. #define GPT2_PR (IMXRT_GPT2.offset004)
  5014. #define GPT2_SR (IMXRT_GPT2.offset008)
  5015. #define GPT2_IR (IMXRT_GPT2.offset00C)
  5016. #define GPT2_OCR1 (IMXRT_GPT2.offset010)
  5017. #define GPT2_OCR2 (IMXRT_GPT2.offset014)
  5018. #define GPT2_OCR3 (IMXRT_GPT2.offset018)
  5019. #define GPT2_ICR1 (IMXRT_GPT2.offset01C)
  5020. #define GPT2_ICR2 (IMXRT_GPT2.offset020)
  5021. #define GPT2_CNT (IMXRT_GPT2.offset024)
  5022. #define GPT_CR_FO3 ((uint32_t)(1<<31))
  5023. #define GPT_CR_FO2 ((uint32_t)(1<<30))
  5024. #define GPT_CR_FO1 ((uint32_t)(1<<29))
  5025. #define GPT_CR_OM3(n) ((uint32_t)(((n) & 0x07) << 26))
  5026. #define GPT_CR_OM2(n) ((uint32_t)(((n) & 0x07) << 23))
  5027. #define GPT_CR_OM1(n) ((uint32_t)(((n) & 0x07) << 20))
  5028. #define GPT_CR_IM2(n) ((uint32_t)(((n) & 0x03) << 18))
  5029. #define GPT_CR_IM1(n) ((uint32_t)(((n) & 0x03) << 16))
  5030. #define GPT_CR_SWR ((uint32_t)(1<<15))
  5031. #define GPT_CR_EN_24M ((uint32_t)(1<<10))
  5032. #define GPT_CR_FRR ((uint32_t)(1<<9))
  5033. #define GPT_CR_CLKSRC(n) ((uint32_t)(((n) & 0x07) << 6))
  5034. #define GPT_CR_STOPEN ((uint32_t)(1<<5))
  5035. #define GPT_CR_DOZEEN ((uint32_t)(1<<4))
  5036. #define GPT_CR_WAITEN ((uint32_t)(1<<3))
  5037. #define GPT_CR_DBGEN ((uint32_t)(1<<2))
  5038. #define GPT_CR_ENMOD ((uint32_t)(1<<1))
  5039. #define GPT_CR_EN ((uint32_t)(1<<0))
  5040. #define GPT_PR_PRESCALER24M(n) ((uint32_t)(((n) & 0x0F) << 12))
  5041. #define GPT_PR_PRESCALER(n) ((uint32_t)(((n) & 0xFFF) << 0))
  5042. #define GPT_SR_ROV ((uint32_t)(1<<5))
  5043. #define GPT_SR_IF2 ((uint32_t)(1<<4))
  5044. #define GPT_SR_IF1 ((uint32_t)(1<<3))
  5045. #define GPT_SR_OF3 ((uint32_t)(1<<2))
  5046. #define GPT_SR_OF2 ((uint32_t)(1<<1))
  5047. #define GPT_SR_OF1 ((uint32_t)(1<<0))
  5048. #define GPT_IR_ROVIE ((uint32_t)(1<<5))
  5049. #define GPT_IR_IF2IE ((uint32_t)(1<<4))
  5050. #define GPT_IR_IF1IE ((uint32_t)(1<<3))
  5051. #define GPT_IR_OF3IE ((uint32_t)(1<<2))
  5052. #define GPT_IR_OF2IE ((uint32_t)(1<<1))
  5053. #define GPT_IR_OF1IE ((uint32_t)(1<<0))
  5054. // 34.4: page 1671
  5055. #define IMXRT_IOMUXC_GPR (*(IMXRT_REGISTER32_t *)0x400AC000)
  5056. #define IOMUXC_GPR_GPR0 (IMXRT_IOMUXC_GPR.offset000)
  5057. #define IOMUXC_GPR_GPR1 (IMXRT_IOMUXC_GPR.offset004)
  5058. #define IOMUXC_GPR_GPR2 (IMXRT_IOMUXC_GPR.offset008)
  5059. #define IOMUXC_GPR_GPR3 (IMXRT_IOMUXC_GPR.offset00C)
  5060. #define IOMUXC_GPR_GPR4 (IMXRT_IOMUXC_GPR.offset010)
  5061. #define IOMUXC_GPR_GPR5 (IMXRT_IOMUXC_GPR.offset014)
  5062. #define IOMUXC_GPR_GPR6 (IMXRT_IOMUXC_GPR.offset018)
  5063. #define IOMUXC_GPR_GPR7 (IMXRT_IOMUXC_GPR.offset01C)
  5064. #define IOMUXC_GPR_GPR8 (IMXRT_IOMUXC_GPR.offset020)
  5065. #define IOMUXC_GPR_GPR9 (IMXRT_IOMUXC_GPR.offset024)
  5066. #define IOMUXC_GPR_GPR10 (IMXRT_IOMUXC_GPR.offset028)
  5067. #define IOMUXC_GPR_GPR11 (IMXRT_IOMUXC_GPR.offset02C)
  5068. #define IOMUXC_GPR_GPR12 (IMXRT_IOMUXC_GPR.offset030)
  5069. #define IOMUXC_GPR_GPR13 (IMXRT_IOMUXC_GPR.offset034)
  5070. #define IOMUXC_GPR_GPR14 (IMXRT_IOMUXC_GPR.offset038)
  5071. #define IOMUXC_GPR_GPR15 (IMXRT_IOMUXC_GPR.offset03C)
  5072. #define IOMUXC_GPR_GPR16 (IMXRT_IOMUXC_GPR.offset040)
  5073. #define IOMUXC_GPR_GPR17 (IMXRT_IOMUXC_GPR.offset044)
  5074. #define IOMUXC_GPR_GPR18 (IMXRT_IOMUXC_GPR.offset048)
  5075. #define IOMUXC_GPR_GPR19 (IMXRT_IOMUXC_GPR.offset04C)
  5076. #define IOMUXC_GPR_GPR20 (IMXRT_IOMUXC_GPR.offset050)
  5077. #define IOMUXC_GPR_GPR21 (IMXRT_IOMUXC_GPR.offset054)
  5078. #define IOMUXC_GPR_GPR22 (IMXRT_IOMUXC_GPR.offset058)
  5079. #define IOMUXC_GPR_GPR23 (IMXRT_IOMUXC_GPR.offset05C)
  5080. #define IOMUXC_GPR_GPR24 (IMXRT_IOMUXC_GPR.offset060)
  5081. #define IOMUXC_GPR_GPR25 (IMXRT_IOMUXC_GPR.offset064)
  5082. #define IOMUXC_GPR_GPR26 (IMXRT_IOMUXC_GPR.offset068)
  5083. #define IOMUXC_GPR_GPR27 (IMXRT_IOMUXC_GPR.offset06C)
  5084. #define IOMUXC_GPR_GPR28 (IMXRT_IOMUXC_GPR.offset070)
  5085. #define IOMUXC_GPR_GPR29 (IMXRT_IOMUXC_GPR.offset074)
  5086. #define IOMUXC_GPR_GPR30 (IMXRT_IOMUXC_GPR.offset078)
  5087. #define IOMUXC_GPR_GPR31 (IMXRT_IOMUXC_GPR.offset07C)
  5088. #define IOMUXC_GPR_GPR32 (IMXRT_IOMUXC_GPR.offset080)
  5089. #define IOMUXC_GPR_GPR33 (IMXRT_IOMUXC_GPR.offset084)
  5090. #define IOMUXC_GPR_GPR34 (IMXRT_IOMUXC_GPR.offset088)
  5091. #define IOMUXC_GPR_GPR1_CM7_FORCE_HCLK_EN ((uint32_t)(1<<31))
  5092. #define IOMUXC_GPR_GPR1_ENET_IPG_CLK_S_EN ((uint32_t)(1<<23))
  5093. #define IOMUXC_GPR_GPR1_EXC_MON ((uint32_t)(1<<22))
  5094. #define IOMUXC_GPR_GPR1_SAI3_MCLK_DIR ((uint32_t)(1<<21))
  5095. #define IOMUXC_GPR_GPR1_SAI2_MCLK_DIR ((uint32_t)(1<<20))
  5096. #define IOMUXC_GPR_GPR1_SAI1_MCLK_DIR ((uint32_t)(1<<19))
  5097. #define IOMUXC_GPR_GPR1_ENET2_TX_CLK_DIR ((uint32_t)(1<<18))
  5098. #define IOMUXC_GPR_GPR1_ENET1_TX_CLK_DIR ((uint32_t)(1<<17))
  5099. #define IOMUXC_GPR_GPR1_USB_EXP_MODE ((uint32_t)(1<<15))
  5100. #define IOMUXC_GPR_GPR1_ENET2_CLK_SEL ((uint32_t)(1<<14))
  5101. #define IOMUXC_GPR_GPR1_ENET1_CLK_SEL ((uint32_t)(1<<13))
  5102. #define IOMUXC_GPR_GPR1_GINT ((uint32_t)(1<<12))
  5103. #define IOMUXC_GPR_GPR1_SAI3_MCLK3_SEL(n) ((uint32_t)(((n) & 0x03) << 10))
  5104. #define IOMUXC_GPR_GPR1_SAI2_MCLK3_SEL(n) ((uint32_t)(((n) & 0x03) << 8))
  5105. #define IOMUXC_GPR_GPR1_SAI1_MCLK3_SEL(n) ((uint32_t)(((n) & 0x03) << 6))
  5106. #define IOMUXC_GPR_GPR1_SAI1_MCLK2_SEL(n) ((uint32_t)(((n) & 0x07) << 3))
  5107. #define IOMUXC_GPR_GPR1_SAI1_MCLK1_SEL(n) ((uint32_t)(((n) & 0x07) << 0))
  5108. #define IOMUXC_GPR_GPR1_SAI3_MCLK3_SEL_MASK IOMUXC_GPR_GPR1_SAI3_MCLK3_SEL(3)
  5109. #define IOMUXC_GPR_GPR1_SAI2_MCLK3_SEL_MASK IOMUXC_GPR_GPR1_SAI2_MCLK3_SEL(3)
  5110. #define IOMUXC_GPR_GPR1_SAI1_MCLK3_SEL_MASK IOMUXC_GPR_GPR1_SAI1_MCLK3_SEL(3)
  5111. #define IOMUXC_GPR_GPR1_SAI1_MCLK2_SEL_MASK IOMUXC_GPR_GPR1_SAI1_MCLK2_SEL(7)
  5112. #define IOMUXC_GPR_GPR1_SAI1_MCLK1_SEL_MASK IOMUXC_GPR_GPR1_SAI1_MCLK1_SEL(7)
  5113. #define IOMUXC_GPR_GPR2_QTIMER4_TMR_CNTS_FREEZE ((uint32_t)(1<<31))
  5114. #define IOMUXC_GPR_GPR2_QTIMER3_TMR_CNTS_FREEZE ((uint32_t)(1<<30))
  5115. #define IOMUXC_GPR_GPR2_QTIMER2_TMR_CNTS_FREEZE ((uint32_t)(1<<29))
  5116. #define IOMUXC_GPR_GPR2_QTIMER1_TMR_CNTS_FREEZE ((uint32_t)(1<<28))
  5117. #define IOMUXC_GPR_GPR2_MQS_OVERSAMPLE ((uint32_t)(1<<26))
  5118. #define IOMUXC_GPR_GPR2_MQS_EN ((uint32_t)(1<<25))
  5119. #define IOMUXC_GPR_GPR2_MQS_SW_RST ((uint32_t)(1<<24))
  5120. #define IOMUXC_GPR_GPR2_MQS_CLK_DIV(n) ((uint32_t)(((n) & 0xFF) << 16))
  5121. #define IOMUXC_GPR_GPR2_L2_MEM_DEEPSLEEP ((uint32_t)(1<<14))
  5122. #define IOMUXC_GPR_GPR2_RAM_AUTO_CLK_GATING_EN ((uint32_t)(1<<13))
  5123. #define IOMUXC_GPR_GPR2_L2_MEM_EN_POWERSAVING ((uint32_t)(1<<12))
  5124. #define IOMUXC_GPR_GPR2_CANFD_FILTER_BYPASS ((uint32_t)(1<<6))
  5125. #define IOMUXC_GPR_GPR2_AXBS_P_FORCE_ROUND_ROBIN ((uint32_t)(1<<5))
  5126. #define IOMUXC_GPR_GPR2_AXBS_P_M1_HIGH_PRIORITY ((uint32_t)(1<<4))
  5127. #define IOMUXC_GPR_GPR2_AXBS_P_M0_HIGH_PRIORITY ((uint32_t)(1<<3))
  5128. #define IOMUXC_GPR_GPR2_AXBS_L_FORCE_ROUND_ROBIN ((uint32_t)(1<<2))
  5129. #define IOMUXC_GPR_GPR2_AXBS_L_DMA_HIGH_PRIORITY ((uint32_t)(1<<1))
  5130. #define IOMUXC_GPR_GPR2_AXBS_L_AHBXL_HIGH_PRIORITY ((uint32_t)(1<<0))
  5131. #define IOMUXC_GPR_GPR2_MQS_CLK_DIV_MASK IOMUXC_GPR_GPR2_MQS_CLK_DIV(255)
  5132. #define IOMUXC_GPR_GPR3_AXBS_L_HALTED ((uint32_t)(1<<31))
  5133. #define IOMUXC_GPR_GPR3_OCRAM2_STATUS(n) ((uint32_t)(((n) & 0x0F) << 24))
  5134. #define IOMUXC_GPR_GPR3_OCRAM_STATUS(n) ((uint32_t)(((n) & 0x0F) << 16))
  5135. #define IOMUXC_GPR_GPR3_AXBS_L_HALT_REQ ((uint32_t)(1<<15))
  5136. #define IOMUXC_GPR_GPR3_OCRAM2_CTL(n) ((uint32_t)(((n) & 0x0F) << 8))
  5137. #define IOMUXC_GPR_GPR3_DCP_KEY_SEL ((uint32_t)(1<<4))
  5138. #define IOMUXC_GPR_GPR3_OCRAM_CTL(n) ((uint32_t)(((n) & 0x0F) << 0))
  5139. #define IOMUXC_GPR_GPR4_FLEXSPI2_STOP_ACK ((uint32_t)(1<<31))
  5140. #define IOMUXC_GPR_GPR4_FLEXIO3_STOP_ACK ((uint32_t)(1<<30))
  5141. #define IOMUXC_GPR_GPR4_FLEXIO2_STOP_ACK ((uint32_t)(1<<29))
  5142. #define IOMUXC_GPR_GPR4_FLEXIO1_STOP_ACK ((uint32_t)(1<<28))
  5143. #define IOMUXC_GPR_GPR4_FLEXSPI_STOP_ACK ((uint32_t)(1<<27))
  5144. #define IOMUXC_GPR_GPR4_PIT_STOP_ACK ((uint32_t)(1<<26))
  5145. #define IOMUXC_GPR_GPR4_SEMC_STOP_ACK ((uint32_t)(1<<25))
  5146. #define IOMUXC_GPR_GPR4_SAI3_STOP_ACK ((uint32_t)(1<<23))
  5147. #define IOMUXC_GPR_GPR4_SAI2_STOP_ACK ((uint32_t)(1<<22))
  5148. #define IOMUXC_GPR_GPR4_SAI1_STOP_ACK ((uint32_t)(1<<21))
  5149. #define IOMUXC_GPR_GPR4_ENET_STOP_ACK ((uint32_t)(1<<20))
  5150. #define IOMUXC_GPR_GPR4_TRNG_STOP_ACK ((uint32_t)(1<<19))
  5151. #define IOMUXC_GPR_GPR4_CAN2_STOP_ACK ((uint32_t)(1<<18))
  5152. #define IOMUXC_GPR_GPR4_CAN1_STOP_ACK ((uint32_t)(1<<17))
  5153. #define IOMUXC_GPR_GPR4_EDMA_STOP_ACK ((uint32_t)(1<<16))
  5154. #define IOMUXC_GPR_GPR4_FLEXSPI2_STOP_REQ ((uint32_t)(1<<15))
  5155. #define IOMUXC_GPR_GPR4_FLEXIO3_STOP_REQ ((uint32_t)(1<<14))
  5156. #define IOMUXC_GPR_GPR4_FLEXIO2_STOP_REQ ((uint32_t)(1<<13))
  5157. #define IOMUXC_GPR_GPR4_FLEXIO1_STOP_REQ ((uint32_t)(1<<12))
  5158. #define IOMUXC_GPR_GPR4_FLEXSPI_STOP_REQ ((uint32_t)(1<<11))
  5159. #define IOMUXC_GPR_GPR4_PIT_STOP_REQ ((uint32_t)(1<<10))
  5160. #define IOMUXC_GPR_GPR4_SEMC_STOP_REQ ((uint32_t)(1<<9))
  5161. #define IOMUXC_GPR_GPR4_SAI3_STOP_REQ ((uint32_t)(1<<7))
  5162. #define IOMUXC_GPR_GPR4_SAI2_STOP_REQ ((uint32_t)(1<<6))
  5163. #define IOMUXC_GPR_GPR4_SAI1_STOP_REQ ((uint32_t)(1<<5))
  5164. #define IOMUXC_GPR_GPR4_ENET_STOP_REQ ((uint32_t)(1<<4))
  5165. #define IOMUXC_GPR_GPR4_TRNG_STOP_REQ ((uint32_t)(1<<3))
  5166. #define IOMUXC_GPR_GPR4_CAN2_STOP_REQ ((uint32_t)(1<<2))
  5167. #define IOMUXC_GPR_GPR4_CAN1_STOP_REQ ((uint32_t)(1<<1))
  5168. #define IOMUXC_GPR_GPR4_EDMA_STOP_REQ ((uint32_t)(1<<0))
  5169. #define IOMUXC_GPR_GPR5_VREF_1M_CLK_GPT2 ((uint32_t)(1<<29))
  5170. #define IOMUXC_GPR_GPR5_VREF_1M_CLK_GPT1 ((uint32_t)(1<<28))
  5171. #define IOMUXC_GPR_GPR5_ENET2_EVENT3IN_SEL ((uint32_t)(1<<26))
  5172. #define IOMUXC_GPR_GPR5_ENET_EVENT3IN_SEL ((uint32_t)(1<<25))
  5173. #define IOMUXC_GPR_GPR5_GPT2_CAPIN2_SEL ((uint32_t)(1<<24))
  5174. #define IOMUXC_GPR_GPR5_GPT2_CAPIN1_SEL ((uint32_t)(1<<23))
  5175. #define IOMUXC_GPR_GPR5_WDOG2_MASK ((uint32_t)(1<<7))
  5176. #define IOMUXC_GPR_GPR5_WDOG1_MASK ((uint32_t)(1<<6))
  5177. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_19 ((uint32_t)(1<<31))
  5178. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_18 ((uint32_t)(1<<30))
  5179. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_17 ((uint32_t)(1<<29))
  5180. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_16 ((uint32_t)(1<<28))
  5181. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_15 ((uint32_t)(1<<27))
  5182. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_14 ((uint32_t)(1<<26))
  5183. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_13 ((uint32_t)(1<<25))
  5184. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_12 ((uint32_t)(1<<24))
  5185. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_11 ((uint32_t)(1<<23))
  5186. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_10 ((uint32_t)(1<<22))
  5187. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_9 ((uint32_t)(1<<21))
  5188. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_8 ((uint32_t)(1<<20))
  5189. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_7 ((uint32_t)(1<<19))
  5190. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_6 ((uint32_t)(1<<18))
  5191. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_5 ((uint32_t)(1<<17))
  5192. #define IOMUXC_GPR_GPR6_IOMUXC_XBAR_DIR_SEL_4 ((uint32_t)(1<<16))
  5193. #define IOMUXC_GPR_GPR6_QTIMER4_TRM3_INPUT_SEL ((uint32_t)(1<<15))
  5194. #define IOMUXC_GPR_GPR6_QTIMER4_TRM2_INPUT_SEL ((uint32_t)(1<<14))
  5195. #define IOMUXC_GPR_GPR6_QTIMER4_TRM1_INPUT_SEL ((uint32_t)(1<<13))
  5196. #define IOMUXC_GPR_GPR6_QTIMER4_TRM0_INPUT_SEL ((uint32_t)(1<<12))
  5197. #define IOMUXC_GPR_GPR6_QTIMER3_TRM3_INPUT_SEL ((uint32_t)(1<<11))
  5198. #define IOMUXC_GPR_GPR6_QTIMER3_TRM2_INPUT_SEL ((uint32_t)(1<<10))
  5199. #define IOMUXC_GPR_GPR6_QTIMER3_TRM1_INPUT_SEL ((uint32_t)(1<<9))
  5200. #define IOMUXC_GPR_GPR6_QTIMER3_TRM0_INPUT_SEL ((uint32_t)(1<<8))
  5201. #define IOMUXC_GPR_GPR6_QTIMER2_TRM3_INPUT_SEL ((uint32_t)(1<<7))
  5202. #define IOMUXC_GPR_GPR6_QTIMER2_TRM2_INPUT_SEL ((uint32_t)(1<<6))
  5203. #define IOMUXC_GPR_GPR6_QTIMER2_TRM1_INPUT_SEL ((uint32_t)(1<<5))
  5204. #define IOMUXC_GPR_GPR6_QTIMER2_TRM0_INPUT_SEL ((uint32_t)(1<<4))
  5205. #define IOMUXC_GPR_GPR6_QTIMER1_TRM3_INPUT_SEL ((uint32_t)(1<<3))
  5206. #define IOMUXC_GPR_GPR6_QTIMER1_TRM2_INPUT_SEL ((uint32_t)(1<<2))
  5207. #define IOMUXC_GPR_GPR6_QTIMER1_TRM1_INPUT_SEL ((uint32_t)(1<<1))
  5208. #define IOMUXC_GPR_GPR6_QTIMER1_TRM0_INPUT_SEL ((uint32_t)(1<<0))
  5209. #define IOMUXC_GPR_GPR7_LPUART8_STOP_ACK ((uint32_t)(1<<31))
  5210. #define IOMUXC_GPR_GPR7_LPUART7_STOP_ACK ((uint32_t)(1<<30))
  5211. #define IOMUXC_GPR_GPR7_LPUART6_STOP_ACK ((uint32_t)(1<<29))
  5212. #define IOMUXC_GPR_GPR7_LPUART5_STOP_ACK ((uint32_t)(1<<28))
  5213. #define IOMUXC_GPR_GPR7_LPUART4_STOP_ACK ((uint32_t)(1<<27))
  5214. #define IOMUXC_GPR_GPR7_LPUART3_STOP_ACK ((uint32_t)(1<<26))
  5215. #define IOMUXC_GPR_GPR7_LPUART2_STOP_ACK ((uint32_t)(1<<25))
  5216. #define IOMUXC_GPR_GPR7_LPUART1_STOP_ACK ((uint32_t)(1<<24))
  5217. #define IOMUXC_GPR_GPR7_LPSPI4_STOP_ACK ((uint32_t)(1<<23))
  5218. #define IOMUXC_GPR_GPR7_LPSPI3_STOP_ACK ((uint32_t)(1<<22))
  5219. #define IOMUXC_GPR_GPR7_LPSPI2_STOP_ACK ((uint32_t)(1<<21))
  5220. #define IOMUXC_GPR_GPR7_LPSPI1_STOP_ACK ((uint32_t)(1<<20))
  5221. #define IOMUXC_GPR_GPR7_LPI2C4_STOP_ACK ((uint32_t)(1<<19))
  5222. #define IOMUXC_GPR_GPR7_LPI2C3_STOP_ACK ((uint32_t)(1<<18))
  5223. #define IOMUXC_GPR_GPR7_LPI2C2_STOP_ACK ((uint32_t)(1<<17))
  5224. #define IOMUXC_GPR_GPR7_LPI2C1_STOP_ACK ((uint32_t)(1<<16))
  5225. #define IOMUXC_GPR_GPR7_LPUART8_STOP_REQ ((uint32_t)(1<<15))
  5226. #define IOMUXC_GPR_GPR7_LPUART7_STOP_REQ ((uint32_t)(1<<14))
  5227. #define IOMUXC_GPR_GPR7_LPUART6_STOP_REQ ((uint32_t)(1<<13))
  5228. #define IOMUXC_GPR_GPR7_LPUART5_STOP_REQ ((uint32_t)(1<<12))
  5229. #define IOMUXC_GPR_GPR7_LPUART4_STOP_REQ ((uint32_t)(1<<11))
  5230. #define IOMUXC_GPR_GPR7_LPUART3_STOP_REQ ((uint32_t)(1<<10))
  5231. #define IOMUXC_GPR_GPR7_LPUART2_STOP_REQ ((uint32_t)(1<<9))
  5232. #define IOMUXC_GPR_GPR7_LPUART1_STOP_REQ ((uint32_t)(1<<8))
  5233. #define IOMUXC_GPR_GPR7_LPSPI4_STOP_REQ ((uint32_t)(1<<7))
  5234. #define IOMUXC_GPR_GPR7_LPSPI3_STOP_REQ ((uint32_t)(1<<6))
  5235. #define IOMUXC_GPR_GPR7_LPSPI2_STOP_REQ ((uint32_t)(1<<5))
  5236. #define IOMUXC_GPR_GPR7_LPSPI1_STOP_REQ ((uint32_t)(1<<4))
  5237. #define IOMUXC_GPR_GPR7_LPI2C4_STOP_REQ ((uint32_t)(1<<3))
  5238. #define IOMUXC_GPR_GPR7_LPI2C3_STOP_REQ ((uint32_t)(1<<2))
  5239. #define IOMUXC_GPR_GPR7_LPI2C2_STOP_REQ ((uint32_t)(1<<1))
  5240. #define IOMUXC_GPR_GPR7_LPI2C1_STOP_REQ ((uint32_t)(1<<0))
  5241. #define IOMUXC_GPR_GPR8_LPUART8_IPG_DOZE ((uint32_t)(1<<31))
  5242. #define IOMUXC_GPR_GPR8_LPUART8_IPG_STOP_MODE ((uint32_t)(1<<30))
  5243. #define IOMUXC_GPR_GPR8_LPUART7_IPG_DOZE ((uint32_t)(1<<29))
  5244. #define IOMUXC_GPR_GPR8_LPUART7_IPG_STOP_MODE ((uint32_t)(1<<28))
  5245. #define IOMUXC_GPR_GPR8_LPUART6_IPG_DOZE ((uint32_t)(1<<27))
  5246. #define IOMUXC_GPR_GPR8_LPUART6_IPG_STOP_MODE ((uint32_t)(1<<26))
  5247. #define IOMUXC_GPR_GPR8_LPUART5_IPG_DOZE ((uint32_t)(1<<25))
  5248. #define IOMUXC_GPR_GPR8_LPUART5_IPG_STOP_MODE ((uint32_t)(1<<24))
  5249. #define IOMUXC_GPR_GPR8_LPUART4_IPG_DOZE ((uint32_t)(1<<23))
  5250. #define IOMUXC_GPR_GPR8_LPUART4_IPG_STOP_MODE ((uint32_t)(1<<22))
  5251. #define IOMUXC_GPR_GPR8_LPUART3_IPG_DOZE ((uint32_t)(1<<21))
  5252. #define IOMUXC_GPR_GPR8_LPUART3_IPG_STOP_MODE ((uint32_t)(1<<20))
  5253. #define IOMUXC_GPR_GPR8_LPUART2_IPG_DOZE ((uint32_t)(1<<19))
  5254. #define IOMUXC_GPR_GPR8_LPUART2_IPG_STOP_MODE ((uint32_t)(1<<18))
  5255. #define IOMUXC_GPR_GPR8_LPUART1_IPG_DOZE ((uint32_t)(1<<17))
  5256. #define IOMUXC_GPR_GPR8_LPUART1_IPG_STOP_MODE ((uint32_t)(1<<16))
  5257. #define IOMUXC_GPR_GPR8_LPSPI4_IPG_DOZE ((uint32_t)(1<<15))
  5258. #define IOMUXC_GPR_GPR8_LPSPI4_IPG_STOP_MODE ((uint32_t)(1<<14))
  5259. #define IOMUXC_GPR_GPR8_LPSPI3_IPG_DOZE ((uint32_t)(1<<13))
  5260. #define IOMUXC_GPR_GPR8_LPSPI3_IPG_STOP_MODE ((uint32_t)(1<<12))
  5261. #define IOMUXC_GPR_GPR8_LPSPI2_IPG_DOZE ((uint32_t)(1<<11))
  5262. #define IOMUXC_GPR_GPR8_LPSPI2_IPG_STOP_MODE ((uint32_t)(1<<10))
  5263. #define IOMUXC_GPR_GPR8_LPSPI1_IPG_DOZE ((uint32_t)(1<<9))
  5264. #define IOMUXC_GPR_GPR8_LPSPI1_IPG_STOP_MODE ((uint32_t)(1<<8))
  5265. #define IOMUXC_GPR_GPR8_LPI2C4_IPG_DOZE ((uint32_t)(1<<7))
  5266. #define IOMUXC_GPR_GPR8_LPI2C4_IPG_STOP_MODE ((uint32_t)(1<<6))
  5267. #define IOMUXC_GPR_GPR8_LPI2C3_IPG_DOZE ((uint32_t)(1<<5))
  5268. #define IOMUXC_GPR_GPR8_LPI2C3_IPG_STOP_MODE ((uint32_t)(1<<4))
  5269. #define IOMUXC_GPR_GPR8_LPI2C2_IPG_DOZE ((uint32_t)(1<<3))
  5270. #define IOMUXC_GPR_GPR8_LPI2C2_IPG_STOP_MODE ((uint32_t)(1<<2))
  5271. #define IOMUXC_GPR_GPR8_LPI2C1_IPG_DOZE ((uint32_t)(1<<1))
  5272. #define IOMUXC_GPR_GPR8_LPI2C1_IPG_STOP_MODE ((uint32_t)(1<<0))
  5273. #define IOMUXC_GPR_GPR10_LOCK_OCRAM_TZ_ADDR(n) ((uint32_t)(((n) & 0x7F) << 25))
  5274. #define IOMUXC_GPR_GPR10_LOCK_OCRAM_TZ_EN ((uint32_t)(1<<24))
  5275. #define IOMUXC_GPR_GPR10_LOCK_DCPKEY_OCOTP_OR_KEYMUX ((uint32_t)(1<<20))
  5276. #define IOMUXC_GPR_GPR10_LOCK_SEC_ERR_RESP ((uint32_t)(1<<18))
  5277. #define IOMUXC_GPR_GPR10_LOCK_DBG_EN ((uint32_t)(1<<17))
  5278. #define IOMUXC_GPR_GPR10_LOCK_NIDEN ((uint32_t)(1<<16))
  5279. #define IOMUXC_GPR_GPR10_OCRAM_TZ_ADDR(n) ((uint32_t)(((n) & 0x7F) << 9))
  5280. #define IOMUXC_GPR_GPR10_OCRAM_TZ_EN ((uint32_t)(1<<8))
  5281. #define IOMUXC_GPR_GPR10_DCPKEY_OCOTP_OR_KEYMUX ((uint32_t)(1<<4))
  5282. #define IOMUXC_GPR_GPR10_SEC_ERR_RESP ((uint32_t)(1<<2))
  5283. #define IOMUXC_GPR_GPR10_DBG_EN ((uint32_t)(1<<1))
  5284. #define IOMUXC_GPR_GPR10_NIDEN ((uint32_t)(1<<0))
  5285. #define IOMUXC_GPR_GPR11_LOCK_BEE_DE_RX_EN(n) ((uint32_t)(((n) & 0x0F) << 24))
  5286. #define IOMUXC_GPR_GPR11_LOCK_M7_APC_AC_R3_CTRL(n) ((uint32_t)(((n) & 0x03) << 22))
  5287. #define IOMUXC_GPR_GPR11_LOCK_M7_APC_AC_R2_CTRL(n) ((uint32_t)(((n) & 0x03) << 20))
  5288. #define IOMUXC_GPR_GPR11_LOCK_M7_APC_AC_R1_CTRL(n) ((uint32_t)(((n) & 0x03) << 18))
  5289. #define IOMUXC_GPR_GPR11_LOCK_M7_APC_AC_R0_CTRL(n) ((uint32_t)(((n) & 0x03) << 16))
  5290. #define IOMUXC_GPR_GPR11_BEE_DE_RX_EN(n) ((uint32_t)(((n) & 0x0F) << 8))
  5291. #define IOMUXC_GPR_GPR11_M7_APC_AC_R3_CTRL(n) ((uint32_t)(((n) & 0x03) << 6))
  5292. #define IOMUXC_GPR_GPR11_M7_APC_AC_R2_CTRL(n) ((uint32_t)(((n) & 0x03) << 4))
  5293. #define IOMUXC_GPR_GPR11_M7_APC_AC_R1_CTRL(n) ((uint32_t)(((n) & 0x03) << 2))
  5294. #define IOMUXC_GPR_GPR11_M7_APC_AC_R0_CTRL(n) ((uint32_t)(((n) & 0x03) << 0))
  5295. #define IOMUXC_GPR_GPR12_FLEXIO3_IPG_DOZE ((uint32_t)(1<<6))
  5296. #define IOMUXC_GPR_GPR12_FLEXIO3_IPG_STOP_MODE ((uint32_t)(1<<5))
  5297. #define IOMUXC_GPR_GPR12_ACMP_IPG_STOP_MODE ((uint32_t)(1<<4))
  5298. #define IOMUXC_GPR_GPR12_FLEXIO2_IPG_DOZE ((uint32_t)(1<<3))
  5299. #define IOMUXC_GPR_GPR12_FLEXIO2_IPG_STOP_MODE ((uint32_t)(1<<2))
  5300. #define IOMUXC_GPR_GPR12_FLEXIO1_IPG_DOZE ((uint32_t)(1<<1))
  5301. #define IOMUXC_GPR_GPR12_FLEXIO1_IPG_STOP_MODE ((uint32_t)(1<<0))
  5302. #define IOMUXC_GPR_GPR13_CANFD_STOP_ACK ((uint32_t)(1<<20))
  5303. #define IOMUXC_GPR_GPR13_CACHE_USB ((uint32_t)(1<<13))
  5304. #define IOMUXC_GPR_GPR13_CACHE_ENET ((uint32_t)(1<<7))
  5305. #define IOMUXC_GPR_GPR13_CANFD_STOP_REQ ((uint32_t)(1<<4))
  5306. #define IOMUXC_GPR_GPR13_AWCACHE_USDHC ((uint32_t)(1<<1))
  5307. #define IOMUXC_GPR_GPR13_ARCACHE_USDHC ((uint32_t)(1<<0))
  5308. #define IOMUXC_GPR_GPR14_CM7_MX6RT_CFGDTCMSZ(n) ((uint32_t)(((n) & 0x0F) << 20))
  5309. #define IOMUXC_GPR_GPR14_CM7_MX6RT_CFGITCMSZ(n) ((uint32_t)(((n) & 0x0F) << 16))
  5310. #define IOMUXC_GPR_GPR14_ACMP4_SAMPLE_SYNC_EN ((uint32_t)(1<<11))
  5311. #define IOMUXC_GPR_GPR14_ACMP3_SAMPLE_SYNC_EN ((uint32_t)(1<<10))
  5312. #define IOMUXC_GPR_GPR14_ACMP2_SAMPLE_SYNC_EN ((uint32_t)(1<<9))
  5313. #define IOMUXC_GPR_GPR14_ACMP1_SAMPLE_SYNC_EN ((uint32_t)(1<<8))
  5314. #define IOMUXC_GPR_GPR14_ACMP4_CMP_IGEN_TRIM_UP ((uint32_t)(1<<7))
  5315. #define IOMUXC_GPR_GPR14_ACMP3_CMP_IGEN_TRIM_UP ((uint32_t)(1<<6))
  5316. #define IOMUXC_GPR_GPR14_ACMP2_CMP_IGEN_TRIM_UP ((uint32_t)(1<<5))
  5317. #define IOMUXC_GPR_GPR14_ACMP1_CMP_IGEN_TRIM_UP ((uint32_t)(1<<4))
  5318. #define IOMUXC_GPR_GPR14_ACMP4_CMP_IGEN_TRIM_DN ((uint32_t)(1<<3))
  5319. #define IOMUXC_GPR_GPR14_ACMP3_CMP_IGEN_TRIM_DN ((uint32_t)(1<<2))
  5320. #define IOMUXC_GPR_GPR14_ACMP2_CMP_IGEN_TRIM_DN ((uint32_t)(1<<1))
  5321. #define IOMUXC_GPR_GPR14_ACMP1_CMP_IGEN_TRIM_DN ((uint32_t)(1<<0))
  5322. #define IOMUXC_GPR_GPR16_CM7_INIT_VTOR(n) ((uint32_t)(((n) & 0x1FFFFFF) << 7))
  5323. #define IOMUXC_GPR_GPR16_FLEXRAM_BANK_CFG_SEL ((uint32_t)(1<<2))
  5324. #define IOMUXC_GPR_GPR16_INIT_DTCM_EN ((uint32_t)(1<<1))
  5325. #define IOMUXC_GPR_GPR16_INIT_ITCM_EN ((uint32_t)(1<<0))
  5326. #define IOMUXC_GPR_GPR18_M7_APC_AC_R0_BOT(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5327. #define IOMUXC_GPR_GPR18_LOCK_M7_APC_AC_R0_BOT ((uint32_t)(1<<0))
  5328. #define IOMUXC_GPR_GPR19_M7_APC_AC_R0_TOP(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5329. #define IOMUXC_GPR_GPR19_LOCK_M7_APC_AC_R0_TOP ((uint32_t)(1<<0))
  5330. #define IOMUXC_GPR_GPR20_M7_APC_AC_R1_BOT(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5331. #define IOMUXC_GPR_GPR20_LOCK_M7_APC_AC_R1_BOT ((uint32_t)(1<<0))
  5332. #define IOMUXC_GPR_GPR21_M7_APC_AC_R1_TOP(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5333. #define IOMUXC_GPR_GPR21_LOCK_M7_APC_AC_R1_TOP ((uint32_t)(1<<0))
  5334. #define IOMUXC_GPR_GPR22_M7_APC_AC_R2_BOT(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5335. #define IOMUXC_GPR_GPR22_LOCK_M7_APC_AC_R2_BOT ((uint32_t)(1<<0))
  5336. #define IOMUXC_GPR_GPR23_M7_APC_AC_R2_TOP(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5337. #define IOMUXC_GPR_GPR23_LOCK_M7_APC_AC_R2_TOP ((uint32_t)(1<<0))
  5338. #define IOMUXC_GPR_GPR24_M7_APC_AC_R3_BOT(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5339. #define IOMUXC_GPR_GPR24_LOCK_M7_APC_AC_R3_BOT ((uint32_t)(1<<0))
  5340. #define IOMUXC_GPR_GPR25_M7_APC_AC_R3_TOP(n) ((uint32_t)(((n) & 0x1FFFFFFF) << 3))
  5341. #define IOMUXC_GPR_GPR25_LOCK_M7_APC_AC_R3_TOP ((uint32_t)(1<<0))
  5342. #define IOMUXC_GPR_GPR33_LOCK_OCRAM2_TZ_ADDR(n) ((uint32_t)(((n) & 0x7F) << 17))
  5343. #define IOMUXC_GPR_GPR33_LOCK_OCRAM2_TZ_EN ((uint32_t)(1<<16))
  5344. #define IOMUXC_GPR_GPR33_OCRAM2_TZ_ADDR(n) ((uint32_t)(((n) & 0x7F) << 1))
  5345. #define IOMUXC_GPR_GPR33_OCRAM2_TZ_EN ((uint32_t)(1<<0))
  5346. #define IOMUXC_GPR_GPR34_SIP_TEST_MUX_QSPI_SIP_EN ((uint32_t)(1<<8))
  5347. #define IOMUXC_GPR_GPR34_SIP_TEST_MUX_BOOT_PIN_SEL(n) ((uint32_t)(((n) & 0xFF) << 0))
  5348. // 34.5: page 1717
  5349. #define IMXRT_IOMUXC_SNVS (*(IMXRT_REGISTER32_t *)0x400A8000)
  5350. #define IOMUXC_SNVS_SW_MUX_CTL_PAD_WAKEUP (IMXRT_IOMUXC_SNVS.offset000)
  5351. #define IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_ON_REQ (IMXRT_IOMUXC_SNVS.offset004)
  5352. #define IOMUXC_SNVS_SW_MUX_CTL_PAD_PMIC_STBY_REQ (IMXRT_IOMUXC_SNVS.offset008)
  5353. #define IOMUXC_SNVS_SW_PAD_CTL_PAD_TEST_MODE (IMXRT_IOMUXC_SNVS.offset00C)
  5354. #define IOMUXC_SNVS_SW_PAD_CTL_PAD_POR_B (IMXRT_IOMUXC_SNVS.offset010)
  5355. #define IOMUXC_SNVS_SW_PAD_CTL_PAD_ONOFF (IMXRT_IOMUXC_SNVS.offset014)
  5356. #define IOMUXC_SNVS_SW_PAD_CTL_PAD_WAKEUP (IMXRT_IOMUXC_SNVS.offset018)
  5357. #define IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_ON_REQ (IMXRT_IOMUXC_SNVS.offset01C)
  5358. #define IOMUXC_SNVS_SW_PAD_CTL_PAD_PMIC_STBY_REQ (IMXRT_IOMUXC_SNVS.offset020)
  5359. // 34.6: page 1732
  5360. #define IMXRT_IOMUXC_SNVS_GPR (*(IMXRT_REGISTER32_t *)0x400A4000)
  5361. #define IOMUXC_SNVS_GPR_GPR0 (IMXRT_IOMUXC_SNVS_GPR.offset000)
  5362. #define IOMUXC_SNVS_GPR_GPR1 (IMXRT_IOMUXC_SNVS_GPR.offset004)
  5363. #define IOMUXC_SNVS_GPR_GPR2 (IMXRT_IOMUXC_SNVS_GPR.offset008)
  5364. #define IOMUXC_SNVS_GPR_GPR3 (IMXRT_IOMUXC_SNVS_GPR.offset00C)
  5365. // 34.7: page 1736
  5366. #define IMXRT_IOMUXC (*(IMXRT_REGISTER32_t *)0x401F8000)
  5367. #define IMXRT_IOMUXC_b (*(IMXRT_REGISTER32_t *)0x401F8400)
  5368. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_00 (IMXRT_IOMUXC.offset014)
  5369. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_01 (IMXRT_IOMUXC.offset018)
  5370. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_02 (IMXRT_IOMUXC.offset01C)
  5371. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_03 (IMXRT_IOMUXC.offset020)
  5372. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_04 (IMXRT_IOMUXC.offset024)
  5373. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_05 (IMXRT_IOMUXC.offset028)
  5374. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_06 (IMXRT_IOMUXC.offset02C)
  5375. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_07 (IMXRT_IOMUXC.offset030)
  5376. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_08 (IMXRT_IOMUXC.offset034)
  5377. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_09 (IMXRT_IOMUXC.offset038)
  5378. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_10 (IMXRT_IOMUXC.offset03C)
  5379. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_11 (IMXRT_IOMUXC.offset040)
  5380. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_12 (IMXRT_IOMUXC.offset044)
  5381. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_13 (IMXRT_IOMUXC.offset048)
  5382. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_14 (IMXRT_IOMUXC.offset04C)
  5383. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_15 (IMXRT_IOMUXC.offset050)
  5384. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_16 (IMXRT_IOMUXC.offset054)
  5385. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_17 (IMXRT_IOMUXC.offset058)
  5386. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_18 (IMXRT_IOMUXC.offset05C)
  5387. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_19 (IMXRT_IOMUXC.offset060)
  5388. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_20 (IMXRT_IOMUXC.offset064)
  5389. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_21 (IMXRT_IOMUXC.offset068)
  5390. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_22 (IMXRT_IOMUXC.offset06C)
  5391. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_23 (IMXRT_IOMUXC.offset070)
  5392. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_24 (IMXRT_IOMUXC.offset074)
  5393. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_25 (IMXRT_IOMUXC.offset078)
  5394. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_26 (IMXRT_IOMUXC.offset07C)
  5395. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_27 (IMXRT_IOMUXC.offset080)
  5396. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_28 (IMXRT_IOMUXC.offset084)
  5397. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_29 (IMXRT_IOMUXC.offset088)
  5398. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_30 (IMXRT_IOMUXC.offset08C)
  5399. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_31 (IMXRT_IOMUXC.offset090)
  5400. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_32 (IMXRT_IOMUXC.offset094)
  5401. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_33 (IMXRT_IOMUXC.offset098)
  5402. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_34 (IMXRT_IOMUXC.offset09C)
  5403. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_35 (IMXRT_IOMUXC.offset0A0)
  5404. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_36 (IMXRT_IOMUXC.offset0A4)
  5405. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_37 (IMXRT_IOMUXC.offset0A8)
  5406. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_38 (IMXRT_IOMUXC.offset0AC)
  5407. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_39 (IMXRT_IOMUXC.offset0B0)
  5408. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_40 (IMXRT_IOMUXC.offset0B4)
  5409. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_EMC_41 (IMXRT_IOMUXC.offset0B8)
  5410. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_00 (IMXRT_IOMUXC.offset0BC)
  5411. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_01 (IMXRT_IOMUXC.offset0C0)
  5412. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_02 (IMXRT_IOMUXC.offset0C4)
  5413. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_03 (IMXRT_IOMUXC.offset0C8)
  5414. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_04 (IMXRT_IOMUXC.offset0CC)
  5415. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_05 (IMXRT_IOMUXC.offset0D0)
  5416. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_06 (IMXRT_IOMUXC.offset0D4)
  5417. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_07 (IMXRT_IOMUXC.offset0D8)
  5418. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_08 (IMXRT_IOMUXC.offset0DC)
  5419. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_09 (IMXRT_IOMUXC.offset0E0)
  5420. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_10 (IMXRT_IOMUXC.offset0E4)
  5421. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_11 (IMXRT_IOMUXC.offset0E8)
  5422. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_12 (IMXRT_IOMUXC.offset0EC)
  5423. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_13 (IMXRT_IOMUXC.offset0F0)
  5424. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_14 (IMXRT_IOMUXC.offset0F4)
  5425. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B0_15 (IMXRT_IOMUXC.offset0F8)
  5426. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_00 (IMXRT_IOMUXC.offset0FC)
  5427. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_01 (IMXRT_IOMUXC.offset100)
  5428. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_02 (IMXRT_IOMUXC.offset104)
  5429. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_03 (IMXRT_IOMUXC.offset108)
  5430. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_04 (IMXRT_IOMUXC.offset10C)
  5431. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_05 (IMXRT_IOMUXC.offset110)
  5432. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_06 (IMXRT_IOMUXC.offset114)
  5433. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_07 (IMXRT_IOMUXC.offset118)
  5434. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_08 (IMXRT_IOMUXC.offset11C)
  5435. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_09 (IMXRT_IOMUXC.offset120)
  5436. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_10 (IMXRT_IOMUXC.offset124)
  5437. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_11 (IMXRT_IOMUXC.offset128)
  5438. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_12 (IMXRT_IOMUXC.offset12C)
  5439. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_13 (IMXRT_IOMUXC.offset130)
  5440. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_14 (IMXRT_IOMUXC.offset134)
  5441. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_15 (IMXRT_IOMUXC.offset138)
  5442. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_00 (IMXRT_IOMUXC.offset13C)
  5443. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_01 (IMXRT_IOMUXC.offset140)
  5444. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_02 (IMXRT_IOMUXC.offset144)
  5445. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_03 (IMXRT_IOMUXC.offset148)
  5446. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_04 (IMXRT_IOMUXC.offset14C)
  5447. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_05 (IMXRT_IOMUXC.offset150)
  5448. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_06 (IMXRT_IOMUXC.offset154)
  5449. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_07 (IMXRT_IOMUXC.offset158)
  5450. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_08 (IMXRT_IOMUXC.offset15C)
  5451. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_09 (IMXRT_IOMUXC.offset160)
  5452. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_10 (IMXRT_IOMUXC.offset164)
  5453. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_11 (IMXRT_IOMUXC.offset168)
  5454. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_12 (IMXRT_IOMUXC.offset16C)
  5455. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_13 (IMXRT_IOMUXC.offset170)
  5456. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_14 (IMXRT_IOMUXC.offset174)
  5457. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B0_15 (IMXRT_IOMUXC.offset178)
  5458. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_00 (IMXRT_IOMUXC.offset17C)
  5459. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_01 (IMXRT_IOMUXC.offset180)
  5460. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_02 (IMXRT_IOMUXC.offset184)
  5461. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_03 (IMXRT_IOMUXC.offset188)
  5462. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_04 (IMXRT_IOMUXC.offset18C)
  5463. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_05 (IMXRT_IOMUXC.offset190)
  5464. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_06 (IMXRT_IOMUXC.offset194)
  5465. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_07 (IMXRT_IOMUXC.offset198)
  5466. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_08 (IMXRT_IOMUXC.offset19C)
  5467. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_09 (IMXRT_IOMUXC.offset1A0)
  5468. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_10 (IMXRT_IOMUXC.offset1A4)
  5469. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_11 (IMXRT_IOMUXC.offset1A8)
  5470. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_12 (IMXRT_IOMUXC.offset1AC)
  5471. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_13 (IMXRT_IOMUXC.offset1B0)
  5472. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_14 (IMXRT_IOMUXC.offset1B4)
  5473. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_B1_15 (IMXRT_IOMUXC.offset1B8)
  5474. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_00 (IMXRT_IOMUXC.offset1BC)
  5475. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_01 (IMXRT_IOMUXC.offset1C0)
  5476. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_02 (IMXRT_IOMUXC.offset1C4)
  5477. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_03 (IMXRT_IOMUXC.offset1C8)
  5478. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_04 (IMXRT_IOMUXC.offset1CC)
  5479. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B0_05 (IMXRT_IOMUXC.offset1D0)
  5480. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_00 (IMXRT_IOMUXC.offset1D4)
  5481. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_01 (IMXRT_IOMUXC.offset1D8)
  5482. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_02 (IMXRT_IOMUXC.offset1DC)
  5483. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_03 (IMXRT_IOMUXC.offset1E0)
  5484. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_04 (IMXRT_IOMUXC.offset1E4)
  5485. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_05 (IMXRT_IOMUXC.offset1E8)
  5486. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_06 (IMXRT_IOMUXC.offset1EC)
  5487. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_07 (IMXRT_IOMUXC.offset1F0)
  5488. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_08 (IMXRT_IOMUXC.offset1F4)
  5489. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_09 (IMXRT_IOMUXC.offset1F8)
  5490. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_10 (IMXRT_IOMUXC.offset1FC)
  5491. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SD_B1_11 (IMXRT_IOMUXC.offset200)
  5492. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_00 (IMXRT_IOMUXC.offset204)
  5493. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_01 (IMXRT_IOMUXC.offset208)
  5494. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_02 (IMXRT_IOMUXC.offset20C)
  5495. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_03 (IMXRT_IOMUXC.offset210)
  5496. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_04 (IMXRT_IOMUXC.offset214)
  5497. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_05 (IMXRT_IOMUXC.offset218)
  5498. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_06 (IMXRT_IOMUXC.offset21C)
  5499. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_07 (IMXRT_IOMUXC.offset220)
  5500. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_08 (IMXRT_IOMUXC.offset224)
  5501. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_09 (IMXRT_IOMUXC.offset228)
  5502. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_10 (IMXRT_IOMUXC.offset22C)
  5503. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_11 (IMXRT_IOMUXC.offset230)
  5504. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_12 (IMXRT_IOMUXC.offset234)
  5505. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_13 (IMXRT_IOMUXC.offset238)
  5506. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_14 (IMXRT_IOMUXC.offset23C)
  5507. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_15 (IMXRT_IOMUXC.offset240)
  5508. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_16 (IMXRT_IOMUXC.offset244)
  5509. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_17 (IMXRT_IOMUXC.offset248)
  5510. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_18 (IMXRT_IOMUXC.offset24C)
  5511. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_19 (IMXRT_IOMUXC.offset250)
  5512. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_20 (IMXRT_IOMUXC.offset254)
  5513. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_21 (IMXRT_IOMUXC.offset258)
  5514. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_22 (IMXRT_IOMUXC.offset25C)
  5515. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_23 (IMXRT_IOMUXC.offset260)
  5516. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_24 (IMXRT_IOMUXC.offset264)
  5517. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_25 (IMXRT_IOMUXC.offset268)
  5518. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_26 (IMXRT_IOMUXC.offset26C)
  5519. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_27 (IMXRT_IOMUXC.offset270)
  5520. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_28 (IMXRT_IOMUXC.offset274)
  5521. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_29 (IMXRT_IOMUXC.offset278)
  5522. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_30 (IMXRT_IOMUXC.offset27C)
  5523. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_31 (IMXRT_IOMUXC.offset280)
  5524. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_32 (IMXRT_IOMUXC.offset284)
  5525. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_33 (IMXRT_IOMUXC.offset288)
  5526. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_34 (IMXRT_IOMUXC.offset28C)
  5527. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_35 (IMXRT_IOMUXC.offset290)
  5528. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_36 (IMXRT_IOMUXC.offset294)
  5529. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_37 (IMXRT_IOMUXC.offset298)
  5530. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_38 (IMXRT_IOMUXC.offset29C)
  5531. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_39 (IMXRT_IOMUXC.offset2A0)
  5532. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_40 (IMXRT_IOMUXC.offset2A4)
  5533. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_EMC_41 (IMXRT_IOMUXC.offset2A8)
  5534. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_00 (IMXRT_IOMUXC.offset2AC)
  5535. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_01 (IMXRT_IOMUXC.offset2B0)
  5536. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_02 (IMXRT_IOMUXC.offset2B4)
  5537. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_03 (IMXRT_IOMUXC.offset2B8)
  5538. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_04 (IMXRT_IOMUXC.offset2BC)
  5539. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_05 (IMXRT_IOMUXC.offset2C0)
  5540. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_06 (IMXRT_IOMUXC.offset2C4)
  5541. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_07 (IMXRT_IOMUXC.offset2C8)
  5542. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_08 (IMXRT_IOMUXC.offset2CC)
  5543. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_09 (IMXRT_IOMUXC.offset2D0)
  5544. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_10 (IMXRT_IOMUXC.offset2D4)
  5545. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_11 (IMXRT_IOMUXC.offset2D8)
  5546. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_12 (IMXRT_IOMUXC.offset2DC)
  5547. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_13 (IMXRT_IOMUXC.offset2E0)
  5548. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_14 (IMXRT_IOMUXC.offset2E4)
  5549. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B0_15 (IMXRT_IOMUXC.offset2E8)
  5550. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_00 (IMXRT_IOMUXC.offset2EC)
  5551. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_01 (IMXRT_IOMUXC.offset2F0)
  5552. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_02 (IMXRT_IOMUXC.offset2F4)
  5553. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_03 (IMXRT_IOMUXC.offset2F8)
  5554. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_04 (IMXRT_IOMUXC.offset2FC)
  5555. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_05 (IMXRT_IOMUXC.offset300)
  5556. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_06 (IMXRT_IOMUXC.offset304)
  5557. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_07 (IMXRT_IOMUXC.offset308)
  5558. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_08 (IMXRT_IOMUXC.offset30C)
  5559. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_09 (IMXRT_IOMUXC.offset310)
  5560. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_10 (IMXRT_IOMUXC.offset314)
  5561. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_11 (IMXRT_IOMUXC.offset318)
  5562. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_12 (IMXRT_IOMUXC.offset31C)
  5563. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_13 (IMXRT_IOMUXC.offset320)
  5564. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_14 (IMXRT_IOMUXC.offset324)
  5565. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_AD_B1_15 (IMXRT_IOMUXC.offset328)
  5566. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_00 (IMXRT_IOMUXC.offset32C)
  5567. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_01 (IMXRT_IOMUXC.offset330)
  5568. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_02 (IMXRT_IOMUXC.offset334)
  5569. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_03 (IMXRT_IOMUXC.offset338)
  5570. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_04 (IMXRT_IOMUXC.offset33C)
  5571. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_05 (IMXRT_IOMUXC.offset340)
  5572. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_06 (IMXRT_IOMUXC.offset344)
  5573. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_07 (IMXRT_IOMUXC.offset348)
  5574. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_08 (IMXRT_IOMUXC.offset34C)
  5575. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_09 (IMXRT_IOMUXC.offset350)
  5576. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_10 (IMXRT_IOMUXC.offset354)
  5577. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_11 (IMXRT_IOMUXC.offset358)
  5578. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_12 (IMXRT_IOMUXC.offset35C)
  5579. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_13 (IMXRT_IOMUXC.offset360)
  5580. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_14 (IMXRT_IOMUXC.offset364)
  5581. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B0_15 (IMXRT_IOMUXC.offset368)
  5582. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_00 (IMXRT_IOMUXC.offset36C)
  5583. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_01 (IMXRT_IOMUXC.offset370)
  5584. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_02 (IMXRT_IOMUXC.offset374)
  5585. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_03 (IMXRT_IOMUXC.offset378)
  5586. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_04 (IMXRT_IOMUXC.offset37C)
  5587. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_05 (IMXRT_IOMUXC.offset380)
  5588. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_06 (IMXRT_IOMUXC.offset384)
  5589. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_07 (IMXRT_IOMUXC.offset388)
  5590. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_08 (IMXRT_IOMUXC.offset38C)
  5591. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_09 (IMXRT_IOMUXC.offset390)
  5592. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_10 (IMXRT_IOMUXC.offset394)
  5593. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_11 (IMXRT_IOMUXC.offset398)
  5594. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_12 (IMXRT_IOMUXC.offset39C)
  5595. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_13 (IMXRT_IOMUXC.offset3A0)
  5596. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_14 (IMXRT_IOMUXC.offset3A4)
  5597. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_B1_15 (IMXRT_IOMUXC.offset3A8)
  5598. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_00 (IMXRT_IOMUXC.offset3AC)
  5599. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_01 (IMXRT_IOMUXC.offset3B0)
  5600. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_02 (IMXRT_IOMUXC.offset3B4)
  5601. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_03 (IMXRT_IOMUXC.offset3B8)
  5602. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_04 (IMXRT_IOMUXC.offset3BC)
  5603. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B0_05 (IMXRT_IOMUXC.offset3C0)
  5604. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_00 (IMXRT_IOMUXC.offset3C4)
  5605. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_01 (IMXRT_IOMUXC.offset3C8)
  5606. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_02 (IMXRT_IOMUXC.offset3CC)
  5607. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_03 (IMXRT_IOMUXC.offset3D0)
  5608. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_04 (IMXRT_IOMUXC.offset3D4)
  5609. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_05 (IMXRT_IOMUXC.offset3D8)
  5610. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_06 (IMXRT_IOMUXC.offset3DC)
  5611. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_07 (IMXRT_IOMUXC.offset3E0)
  5612. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_08 (IMXRT_IOMUXC.offset3E4)
  5613. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_09 (IMXRT_IOMUXC.offset3E8)
  5614. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_10 (IMXRT_IOMUXC.offset3EC)
  5615. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SD_B1_11 (IMXRT_IOMUXC.offset3F0)
  5616. #define IOMUXC_ANATOP_USB_OTG_ID_SELECT_INPUT (IMXRT_IOMUXC.offset3F4)
  5617. #define IOMUXC_ANATOP_USB_UH1_ID_SELECT_INPUT (IMXRT_IOMUXC.offset3F8)
  5618. #define IOMUXC_CCM_PMIC_READY_SELECT_INPUT (IMXRT_IOMUXC.offset3FC)
  5619. #define IOMUXC_CSI_DATA02_SELECT_INPUT (IMXRT_IOMUXC_b.offset000)
  5620. #define IOMUXC_CSI_DATA03_SELECT_INPUT (IMXRT_IOMUXC_b.offset004)
  5621. #define IOMUXC_CSI_DATA04_SELECT_INPUT (IMXRT_IOMUXC_b.offset008)
  5622. #define IOMUXC_CSI_DATA05_SELECT_INPUT (IMXRT_IOMUXC_b.offset00C)
  5623. #define IOMUXC_CSI_DATA06_SELECT_INPUT (IMXRT_IOMUXC_b.offset010)
  5624. #define IOMUXC_CSI_DATA07_SELECT_INPUT (IMXRT_IOMUXC_b.offset014)
  5625. #define IOMUXC_CSI_DATA08_SELECT_INPUT (IMXRT_IOMUXC_b.offset018)
  5626. #define IOMUXC_CSI_DATA09_SELECT_INPUT (IMXRT_IOMUXC_b.offset01C)
  5627. #define IOMUXC_CSI_HSYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset020)
  5628. #define IOMUXC_CSI_PIXCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset024)
  5629. #define IOMUXC_CSI_VSYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset028)
  5630. #define IOMUXC_ENET_IPG_CLK_RMII_SELECT_INPUT (IMXRT_IOMUXC_b.offset02C)
  5631. #define IOMUXC_ENET_MDIO_SELECT_INPUT (IMXRT_IOMUXC_b.offset030)
  5632. #define IOMUXC_ENET0_RXDATA_SELECT_INPUT (IMXRT_IOMUXC_b.offset034)
  5633. #define IOMUXC_ENET1_RXDATA_SELECT_INPUT (IMXRT_IOMUXC_b.offset038)
  5634. #define IOMUXC_ENET_RXEN_SELECT_INPUT (IMXRT_IOMUXC_b.offset03C)
  5635. #define IOMUXC_ENET_RXERR_SELECT_INPUT (IMXRT_IOMUXC_b.offset040)
  5636. #define IOMUXC_ENET0_TIMER_SELECT_INPUT (IMXRT_IOMUXC_b.offset044)
  5637. #define IOMUXC_ENET_TXCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset048)
  5638. #define IOMUXC_FLEXCAN1_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset04C)
  5639. #define IOMUXC_FLEXCAN2_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset050)
  5640. #define IOMUXC_FLEXPWM1_PWMA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset054)
  5641. #define IOMUXC_FLEXPWM1_PWMA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset058)
  5642. #define IOMUXC_FLEXPWM1_PWMA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset05C)
  5643. #define IOMUXC_FLEXPWM1_PWMA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset060)
  5644. #define IOMUXC_FLEXPWM1_PWMB3_SELECT_INPUT (IMXRT_IOMUXC_b.offset064)
  5645. #define IOMUXC_FLEXPWM1_PWMB0_SELECT_INPUT (IMXRT_IOMUXC_b.offset068)
  5646. #define IOMUXC_FLEXPWM1_PWMB1_SELECT_INPUT (IMXRT_IOMUXC_b.offset06C)
  5647. #define IOMUXC_FLEXPWM1_PWMB2_SELECT_INPUT (IMXRT_IOMUXC_b.offset070)
  5648. #define IOMUXC_FLEXPWM2_PWMA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset074)
  5649. #define IOMUXC_FLEXPWM2_PWMA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset078)
  5650. #define IOMUXC_FLEXPWM2_PWMA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset07C)
  5651. #define IOMUXC_FLEXPWM2_PWMA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset080)
  5652. #define IOMUXC_FLEXPWM2_PWMB3_SELECT_INPUT (IMXRT_IOMUXC_b.offset084)
  5653. #define IOMUXC_FLEXPWM2_PWMB0_SELECT_INPUT (IMXRT_IOMUXC_b.offset088)
  5654. #define IOMUXC_FLEXPWM2_PWMB1_SELECT_INPUT (IMXRT_IOMUXC_b.offset09C)
  5655. #define IOMUXC_FLEXPWM2_PWMB2_SELECT_INPUT (IMXRT_IOMUXC_b.offset090)
  5656. #define IOMUXC_FLEXPWM4_PWMA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset094)
  5657. #define IOMUXC_FLEXPWM4_PWMA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset098)
  5658. #define IOMUXC_FLEXPWM4_PWMA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset09C)
  5659. #define IOMUXC_FLEXPWM4_PWMA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset0A0)
  5660. #define IOMUXC_FLEXSPIA_DQS_SELECT_INPUT (IMXRT_IOMUXC_b.offset0A4)
  5661. #define IOMUXC_FLEXSPIA_DATA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset0A8)
  5662. #define IOMUXC_FLEXSPIA_DATA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset0AC)
  5663. #define IOMUXC_FLEXSPIA_DATA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset0B0)
  5664. #define IOMUXC_FLEXSPIA_DATA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset0B4)
  5665. #define IOMUXC_FLEXSPIB_DATA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset0B8)
  5666. #define IOMUXC_FLEXSPIB_DATA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset0BC)
  5667. #define IOMUXC_FLEXSPIB_DATA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset0C0)
  5668. #define IOMUXC_FLEXSPIB_DATA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset0C4)
  5669. #define IOMUXC_FLEXSPIA_SCK_SELECT_INPUT (IMXRT_IOMUXC_b.offset0C8)
  5670. #define IOMUXC_LPI2C1_SCL_SELECT_INPUT (IMXRT_IOMUXC_b.offset0CC)
  5671. #define IOMUXC_LPI2C1_SDA_SELECT_INPUT (IMXRT_IOMUXC_b.offset0D0)
  5672. #define IOMUXC_LPI2C2_SCL_SELECT_INPUT (IMXRT_IOMUXC_b.offset0D4)
  5673. #define IOMUXC_LPI2C2_SDA_SELECT_INPUT (IMXRT_IOMUXC_b.offset0D8)
  5674. #define IOMUXC_LPI2C3_SCL_SELECT_INPUT (IMXRT_IOMUXC_b.offset0DC)
  5675. #define IOMUXC_LPI2C3_SDA_SELECT_INPUT (IMXRT_IOMUXC_b.offset0E0)
  5676. #define IOMUXC_LPI2C4_SCL_SELECT_INPUT (IMXRT_IOMUXC_b.offset0E4)
  5677. #define IOMUXC_LPI2C4_SDA_SELECT_INPUT (IMXRT_IOMUXC_b.offset0E8)
  5678. #define IOMUXC_LPSPI1_PCS0_SELECT_INPUT (IMXRT_IOMUXC_b.offset0EC)
  5679. #define IOMUXC_LPSPI1_SCK_SELECT_INPUT (IMXRT_IOMUXC_b.offset0F0)
  5680. #define IOMUXC_LPSPI1_SDI_SELECT_INPUT (IMXRT_IOMUXC_b.offset0F4)
  5681. #define IOMUXC_LPSPI1_SDO_SELECT_INPUT (IMXRT_IOMUXC_b.offset0F8)
  5682. #define IOMUXC_LPSPI2_PCS0_SELECT_INPUT (IMXRT_IOMUXC_b.offset0FC)
  5683. #define IOMUXC_LPSPI2_SCK_SELECT_INPUT (IMXRT_IOMUXC_b.offset100)
  5684. #define IOMUXC_LPSPI2_SDI_SELECT_INPUT (IMXRT_IOMUXC_b.offset104)
  5685. #define IOMUXC_LPSPI2_SDO_SELECT_INPUT (IMXRT_IOMUXC_b.offset108)
  5686. #define IOMUXC_LPSPI3_PCS0_SELECT_INPUT (IMXRT_IOMUXC_b.offset10C)
  5687. #define IOMUXC_LPSPI3_SCK_SELECT_INPUT (IMXRT_IOMUXC_b.offset110)
  5688. #define IOMUXC_LPSPI3_SDI_SELECT_INPUT (IMXRT_IOMUXC_b.offset114)
  5689. #define IOMUXC_LPSPI3_SDO_SELECT_INPUT (IMXRT_IOMUXC_b.offset118)
  5690. #define IOMUXC_LPSPI4_PCS0_SELECT_INPUT (IMXRT_IOMUXC_b.offset11C)
  5691. #define IOMUXC_LPSPI4_SCK_SELECT_INPUT (IMXRT_IOMUXC_b.offset120)
  5692. #define IOMUXC_LPSPI4_SDI_SELECT_INPUT (IMXRT_IOMUXC_b.offset124)
  5693. #define IOMUXC_LPSPI4_SDO_SELECT_INPUT (IMXRT_IOMUXC_b.offset128)
  5694. #define IOMUXC_LPUART2_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset12C)
  5695. #define IOMUXC_LPUART2_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset130)
  5696. #define IOMUXC_LPUART3_CTS_B_SELECT_INPUT (IMXRT_IOMUXC_b.offset134)
  5697. #define IOMUXC_LPUART3_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset138)
  5698. #define IOMUXC_LPUART3_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset13C)
  5699. #define IOMUXC_LPUART4_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset140)
  5700. #define IOMUXC_LPUART4_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset144)
  5701. #define IOMUXC_LPUART5_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset148)
  5702. #define IOMUXC_LPUART5_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset14C)
  5703. #define IOMUXC_LPUART6_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset150)
  5704. #define IOMUXC_LPUART6_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset154)
  5705. #define IOMUXC_LPUART7_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset158)
  5706. #define IOMUXC_LPUART7_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset15C)
  5707. #define IOMUXC_LPUART8_RX_SELECT_INPUT (IMXRT_IOMUXC_b.offset160)
  5708. #define IOMUXC_LPUART8_TX_SELECT_INPUT (IMXRT_IOMUXC_b.offset164)
  5709. #define IOMUXC_NMI_GLUE_NMI_SELECT_INPUT (IMXRT_IOMUXC_b.offset168)
  5710. #define IOMUXC_QTIMER2_TIMER0_SELECT_INPUT (IMXRT_IOMUXC_b.offset16C)
  5711. #define IOMUXC_QTIMER2_TIMER1_SELECT_INPUT (IMXRT_IOMUXC_b.offset170)
  5712. #define IOMUXC_QTIMER2_TIMER2_SELECT_INPUT (IMXRT_IOMUXC_b.offset174)
  5713. #define IOMUXC_QTIMER2_TIMER3_SELECT_INPUT (IMXRT_IOMUXC_b.offset178)
  5714. #define IOMUXC_QTIMER3_TIMER0_SELECT_INPUT (IMXRT_IOMUXC_b.offset17C)
  5715. #define IOMUXC_QTIMER3_TIMER1_SELECT_INPUT (IMXRT_IOMUXC_b.offset180)
  5716. #define IOMUXC_QTIMER3_TIMER2_SELECT_INPUT (IMXRT_IOMUXC_b.offset184)
  5717. #define IOMUXC_QTIMER3_TIMER3_SELECT_INPUT (IMXRT_IOMUXC_b.offset188)
  5718. #define IOMUXC_SAI1_MCLK2_SELECT_INPUT (IMXRT_IOMUXC_b.offset18C)
  5719. #define IOMUXC_SAI1_RX_BCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset190)
  5720. #define IOMUXC_SAI1_RX_DATA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset194)
  5721. #define IOMUXC_SAI1_RX_DATA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset198)
  5722. #define IOMUXC_SAI1_RX_DATA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset19C)
  5723. #define IOMUXC_SAI1_RX_DATA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset1A0)
  5724. #define IOMUXC_SAI1_RX_SYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset1A4)
  5725. #define IOMUXC_SAI1_TX_BCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset1A8)
  5726. #define IOMUXC_SAI1_TX_SYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset1AC)
  5727. #define IOMUXC_SAI2_MCLK2_SELECT_INPUT (IMXRT_IOMUXC_b.offset1B0)
  5728. #define IOMUXC_SAI2_RX_BCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset1B4)
  5729. #define IOMUXC_SAI2_RX_DATA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset1B8)
  5730. #define IOMUXC_SAI2_RX_SYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset1BC)
  5731. #define IOMUXC_SAI2_TX_BCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset1C0)
  5732. #define IOMUXC_SAI2_TX_SYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset1C4)
  5733. #define IOMUXC_SPDIF_IN_SELECT_INPUT (IMXRT_IOMUXC_b.offset1C8)
  5734. #define IOMUXC_USB_OTG2_OC_SELECT_INPUT (IMXRT_IOMUXC_b.offset1CC)
  5735. #define IOMUXC_USB_OTG1_OC_SELECT_INPUT (IMXRT_IOMUXC_b.offset1D0)
  5736. #define IOMUXC_USDHC1_CD_B_SELECT_INPUT (IMXRT_IOMUXC_b.offset1D4)
  5737. #define IOMUXC_USDHC1_WP_SELECT_INPUT (IMXRT_IOMUXC_b.offset1D8)
  5738. #define IOMUXC_USDHC2_CLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset1DC)
  5739. #define IOMUXC_USDHC2_CD_B_SELECT_INPUT (IMXRT_IOMUXC_b.offset1E0)
  5740. #define IOMUXC_USDHC2_CMD_SELECT_INPUT (IMXRT_IOMUXC_b.offset1E4)
  5741. #define IOMUXC_USDHC2_DATA0_SELECT_INPUT (IMXRT_IOMUXC_b.offset1E8)
  5742. #define IOMUXC_USDHC2_DATA1_SELECT_INPUT (IMXRT_IOMUXC_b.offset1EC)
  5743. #define IOMUXC_USDHC2_DATA2_SELECT_INPUT (IMXRT_IOMUXC_b.offset1F0)
  5744. #define IOMUXC_USDHC2_DATA3_SELECT_INPUT (IMXRT_IOMUXC_b.offset1F4)
  5745. #define IOMUXC_USDHC2_DATA4_SELECT_INPUT (IMXRT_IOMUXC_b.offset1F8)
  5746. #define IOMUXC_USDHC2_DATA5_SELECT_INPUT (IMXRT_IOMUXC_b.offset1FC)
  5747. #define IOMUXC_USDHC2_DATA6_SELECT_INPUT (IMXRT_IOMUXC_b.offset200)
  5748. #define IOMUXC_USDHC2_DATA7_SELECT_INPUT (IMXRT_IOMUXC_b.offset204)
  5749. #define IOMUXC_USDHC2_WP_SELECT_INPUT (IMXRT_IOMUXC_b.offset208)
  5750. #define IOMUXC_XBAR1_IN02_SELECT_INPUT (IMXRT_IOMUXC_b.offset20C)
  5751. #define IOMUXC_XBAR1_IN03_SELECT_INPUT (IMXRT_IOMUXC_b.offset210)
  5752. #define IOMUXC_XBAR1_IN04_SELECT_INPUT (IMXRT_IOMUXC_b.offset214)
  5753. #define IOMUXC_XBAR1_IN05_SELECT_INPUT (IMXRT_IOMUXC_b.offset218)
  5754. #define IOMUXC_XBAR1_IN06_SELECT_INPUT (IMXRT_IOMUXC_b.offset21C)
  5755. #define IOMUXC_XBAR1_IN07_SELECT_INPUT (IMXRT_IOMUXC_b.offset220)
  5756. #define IOMUXC_XBAR1_IN08_SELECT_INPUT (IMXRT_IOMUXC_b.offset224)
  5757. #define IOMUXC_XBAR1_IN09_SELECT_INPUT (IMXRT_IOMUXC_b.offset228)
  5758. #define IOMUXC_XBAR1_IN17_SELECT_INPUT (IMXRT_IOMUXC_b.offset22C)
  5759. #define IOMUXC_XBAR1_IN18_SELECT_INPUT (IMXRT_IOMUXC_b.offset230)
  5760. #define IOMUXC_XBAR1_IN20_SELECT_INPUT (IMXRT_IOMUXC_b.offset234)
  5761. #define IOMUXC_XBAR1_IN22_SELECT_INPUT (IMXRT_IOMUXC_b.offset238)
  5762. #define IOMUXC_XBAR1_IN23_SELECT_INPUT (IMXRT_IOMUXC_b.offset23C)
  5763. #define IOMUXC_XBAR1_IN24_SELECT_INPUT (IMXRT_IOMUXC_b.offset240)
  5764. #define IOMUXC_XBAR1_IN14_SELECT_INPUT (IMXRT_IOMUXC_b.offset244)
  5765. #define IOMUXC_XBAR1_IN15_SELECT_INPUT (IMXRT_IOMUXC_b.offset248)
  5766. #define IOMUXC_XBAR1_IN16_SELECT_INPUT (IMXRT_IOMUXC_b.offset24C)
  5767. #define IOMUXC_XBAR1_IN25_SELECT_INPUT (IMXRT_IOMUXC_b.offset250)
  5768. #define IOMUXC_XBAR1_IN19_SELECT_INPUT (IMXRT_IOMUXC_b.offset254)
  5769. #define IOMUXC_XBAR1_IN21_SELECT_INPUT (IMXRT_IOMUXC_b.offset258)
  5770. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_00 (IMXRT_IOMUXC_b.offset25C)
  5771. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_01 (IMXRT_IOMUXC_b.offset260)
  5772. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_02 (IMXRT_IOMUXC_b.offset264)
  5773. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_03 (IMXRT_IOMUXC_b.offset268)
  5774. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_04 (IMXRT_IOMUXC_b.offset26C)
  5775. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_05 (IMXRT_IOMUXC_b.offset270)
  5776. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_06 (IMXRT_IOMUXC_b.offset274)
  5777. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_07 (IMXRT_IOMUXC_b.offset278)
  5778. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_08 (IMXRT_IOMUXC_b.offset27C)
  5779. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_09 (IMXRT_IOMUXC_b.offset280)
  5780. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_10 (IMXRT_IOMUXC_b.offset284)
  5781. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_11 (IMXRT_IOMUXC_b.offset288)
  5782. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_12 (IMXRT_IOMUXC_b.offset28C)
  5783. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B0_13 (IMXRT_IOMUXC_b.offset290)
  5784. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_00 (IMXRT_IOMUXC_b.offset294)
  5785. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_01 (IMXRT_IOMUXC_b.offset298)
  5786. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_02 (IMXRT_IOMUXC_b.offset29C)
  5787. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_03 (IMXRT_IOMUXC_b.offset2A0)
  5788. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_04 (IMXRT_IOMUXC_b.offset2A4)
  5789. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_05 (IMXRT_IOMUXC_b.offset2A8)
  5790. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_06 (IMXRT_IOMUXC_b.offset2AC)
  5791. #define IOMUXC_SW_MUX_CTL_PAD_GPIO_SPI_B1_07 (IMXRT_IOMUXC_b.offset2B0)
  5792. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_00 (IMXRT_IOMUXC_b.offset2B4)
  5793. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_01 (IMXRT_IOMUXC_b.offset2B8)
  5794. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_02 (IMXRT_IOMUXC_b.offset2BC)
  5795. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_03 (IMXRT_IOMUXC_b.offset2C0)
  5796. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_04 (IMXRT_IOMUXC_b.offset2C4)
  5797. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_05 (IMXRT_IOMUXC_b.offset2C8)
  5798. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_06 (IMXRT_IOMUXC_b.offset2CC)
  5799. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_07 (IMXRT_IOMUXC_b.offset2D0)
  5800. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_08 (IMXRT_IOMUXC_b.offset2D4)
  5801. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_09 (IMXRT_IOMUXC_b.offset2D8)
  5802. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_10 (IMXRT_IOMUXC_b.offset2DC)
  5803. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_11 (IMXRT_IOMUXC_b.offset2E0)
  5804. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_12 (IMXRT_IOMUXC_b.offset2E4)
  5805. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B0_13 (IMXRT_IOMUXC_b.offset2E8)
  5806. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_00 (IMXRT_IOMUXC_b.offset2EC)
  5807. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_01 (IMXRT_IOMUXC_b.offset2F0)
  5808. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_02 (IMXRT_IOMUXC_b.offset2F4)
  5809. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_03 (IMXRT_IOMUXC_b.offset2F8)
  5810. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_04 (IMXRT_IOMUXC_b.offset2FC)
  5811. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_05 (IMXRT_IOMUXC_b.offset300)
  5812. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_06 (IMXRT_IOMUXC_b.offset304)
  5813. #define IOMUXC_SW_PAD_CTL_PAD_GPIO_SPI_B1_07 (IMXRT_IOMUXC_b.offset308)
  5814. #define IOMUXC_ENET2_IPG_CLK_RMII_SELECT_INPUT (IMXRT_IOMUXC_b.offset30C)
  5815. #define IOMUXC_ENET2_IPP_IND_MAC0_MDIO_SELECT_INPUT (IMXRT_IOMUXC_b.offset310)
  5816. #define IOMUXC_ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_0 (IMXRT_IOMUXC_b.offset314)
  5817. #define IOMUXC_ENET2_IPP_IND_MAC0_RXDATA_SELECT_INPUT_1 (IMXRT_IOMUXC_b.offset318)
  5818. #define IOMUXC_ENET2_IPP_IND_MAC0_RXEN_SELECT_INPUT (IMXRT_IOMUXC_b.offset31C)
  5819. #define IOMUXC_ENET2_IPP_IND_MAC0_RXERR_SELECT_INPUT (IMXRT_IOMUXC_b.offset320)
  5820. #define IOMUXC_ENET2_IPP_IND_MAC0_TIMER_SELECT_INPUT_0 (IMXRT_IOMUXC_b.offset324)
  5821. #define IOMUXC_ENET2_IPP_IND_MAC0_TXCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset328)
  5822. #define IOMUXC_FLEXSPI2_IPP_IND_DQS_FA_SELECT_INPUT (IMXRT_IOMUXC_b.offset32C)
  5823. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT0_SELECT_INPUT (IMXRT_IOMUXC_b.offset330)
  5824. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT1_SELECT_INPUT (IMXRT_IOMUXC_b.offset334)
  5825. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT2_SELECT_INPUT (IMXRT_IOMUXC_b.offset338)
  5826. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FA_BIT3_SELECT_INPUT (IMXRT_IOMUXC_b.offset33C)
  5827. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT0_SELECT_INPUT (IMXRT_IOMUXC_b.offset340)
  5828. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT1_SELECT_INPUT (IMXRT_IOMUXC_b.offset344)
  5829. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT2_SELECT_INPUT (IMXRT_IOMUXC_b.offset348)
  5830. #define IOMUXC_FLEXSPI2_IPP_IND_IO_FB_BIT3_SELECT_INPUT (IMXRT_IOMUXC_b.offset34C)
  5831. #define IOMUXC_FLEXSPI2_IPP_IND_SCK_FA_SELECT_INPUT (IMXRT_IOMUXC_b.offset350)
  5832. #define IOMUXC_FLEXSPI2_IPP_IND_SCK_FB_SELECT_INPUT (IMXRT_IOMUXC_b.offset354)
  5833. #define IOMUXC_GPT1_IPP_IND_CAPIN1_SELECT_INPUT (IMXRT_IOMUXC_b.offset358)
  5834. #define IOMUXC_GPT1_IPP_IND_CAPIN2_SELECT_INPUT (IMXRT_IOMUXC_b.offset35C)
  5835. #define IOMUXC_GPT1_IPP_IND_CLKIN_SELECT_INPUT (IMXRT_IOMUXC_b.offset360)
  5836. #define IOMUXC_GPT2_IPP_IND_CAPIN1_SELECT_INPUT (IMXRT_IOMUXC_b.offset364)
  5837. #define IOMUXC_GPT2_IPP_IND_CAPIN2_SELECT_INPUT (IMXRT_IOMUXC_b.offset368)
  5838. #define IOMUXC_GPT2_IPP_IND_CLKIN_SELECT_INPUT (IMXRT_IOMUXC_b.offset36C)
  5839. #define IOMUXC_SAI3_IPG_CLK_SAI_MCLK_SELECT_INPUT_2 (IMXRT_IOMUXC_b.offset370)
  5840. #define IOMUXC_SAI3_IPP_IND_SAI_RXBCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset374)
  5841. #define IOMUXC_SAI3_IPP_IND_SAI_RXDATA_SELECT_INPUT_0 (IMXRT_IOMUXC_b.offset378)
  5842. #define IOMUXC_SAI3_IPP_IND_SAI_RXSYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset37C)
  5843. #define IOMUXC_SAI3_IPP_IND_SAI_TXBCLK_SELECT_INPUT (IMXRT_IOMUXC_b.offset380)
  5844. #define IOMUXC_SAI3_IPP_IND_SAI_TXSYNC_SELECT_INPUT (IMXRT_IOMUXC_b.offset384)
  5845. #define IOMUXC_SEMC_I_IPP_IND_DQS4_SELECT_INPUT (IMXRT_IOMUXC_b.offset388)
  5846. #define IOMUXC_CANFD_IPP_IND_CANRX_SELECT_INPUT (IMXRT_IOMUXC_b.offset38C)
  5847. #define IOMUXC_PAD_SRE ((uint32_t)(1<<0))
  5848. #define IOMUXC_PAD_DSE(n) ((uint32_t)(((n) & 0x07) << 3))
  5849. #define IOMUXC_PAD_SPEED(n) ((uint32_t)(((n) & 0x03) << 6))
  5850. #define IOMUXC_PAD_ODE ((uint32_t)(1<<11))
  5851. #define IOMUXC_PAD_PKE ((uint32_t)(1<<12))
  5852. #define IOMUXC_PAD_PUE ((uint32_t)(1<<13))
  5853. #define IOMUXC_PAD_PUS(n) ((uint32_t)(((n) & 0x03) << 14))
  5854. #define IOMUXC_PAD_HYS ((uint32_t)(1<<16))
  5855. // 35.6: page 2301
  5856. #define IMXRT_KPP (*(IMXRT_REGISTER16_t *)0x401FC000)
  5857. #define KPP_KPCR (IMXRT_KPP.offset000)
  5858. #define KPP_KPSR (IMXRT_KPP.offset002)
  5859. #define KPP_KDDR (IMXRT_KPP.offset004)
  5860. #define KPP_KPDR (IMXRT_KPP.offset006)
  5861. // 36.4: page 2325
  5862. #define IMXRT_LCDIF (*(IMXRT_REGISTER32_t *)0x402B8000)
  5863. #define LCDIF_CTRL (IMXRT_LCDIF.offset000)
  5864. #define LCDIF_CTRL_SET (IMXRT_LCDIF.offset004)
  5865. #define LCDIF_CTRL_CLR (IMXRT_LCDIF.offset008)
  5866. #define LCDIF_CTRL_TOG (IMXRT_LCDIF.offset00C)
  5867. #define LCDIF_CTRL1 (IMXRT_LCDIF.offset010)
  5868. #define LCDIF_CTRL1_SET (IMXRT_LCDIF.offset014)
  5869. #define LCDIF_CTRL1_CLR (IMXRT_LCDIF.offset018)
  5870. #define LCDIF_CTRL1_TOG (IMXRT_LCDIF.offset01C)
  5871. #define LCDIF_CTRL2 (IMXRT_LCDIF.offset020)
  5872. #define LCDIF_CTRL2_SET (IMXRT_LCDIF.offset024)
  5873. #define LCDIF_CTRL2_CLR (IMXRT_LCDIF.offset028)
  5874. #define LCDIF_CTRL2_TOG (IMXRT_LCDIF.offset02C)
  5875. #define LCDIF_TRANSFER_COUNT (IMXRT_LCDIF.offset030)
  5876. #define LCDIF_CUR_BUF (IMXRT_LCDIF.offset040)
  5877. #define LCDIF_NEXT_BUF (IMXRT_LCDIF.offset050)
  5878. #define LCDIF_VDCTRL0 (IMXRT_LCDIF.offset070)
  5879. #define LCDIF_VDCTRL0_SET (IMXRT_LCDIF.offset074)
  5880. #define LCDIF_VDCTRL0_CLR (IMXRT_LCDIF.offset078)
  5881. #define LCDIF_VDCTRL0_TOG (IMXRT_LCDIF.offset07C)
  5882. #define LCDIF_VDCTRL1 (IMXRT_LCDIF.offset080)
  5883. #define LCDIF_VDCTRL2 (IMXRT_LCDIF.offset090)
  5884. #define LCDIF_VDCTRL3 (IMXRT_LCDIF.offset0A0)
  5885. #define LCDIF_VDCTRL4 (IMXRT_LCDIF.offset0B0)
  5886. #define LCDIF_BM_ERROR_STAT (IMXRT_LCDIF.offset190)
  5887. #define LCDIF_CRC_STAT (IMXRT_LCDIF.offset1A0)
  5888. #define LCDIF_STAT (IMXRT_LCDIF.offset1B0)
  5889. #define LCDIF_THRES (IMXRT_LCDIF.offset200)
  5890. #define LCDIF_AS_CTRL (IMXRT_LCDIF.offset210)
  5891. #define LCDIF_AS_BUF (IMXRT_LCDIF.offset220)
  5892. #define LCDIF_AS_NEXT_BUF (IMXRT_LCDIF.offset230)
  5893. #define LCDIF_AS_CLRKEYLOW (IMXRT_LCDIF.offset240)
  5894. #define LCDIF_AS_CLRKEYHIGH (IMXRT_LCDIF.offset250)
  5895. #define LCDIF_PIGEONCTRL0 (IMXRT_LCDIF.offset380)
  5896. #define LCDIF_PIGEONCTRL0_SET (IMXRT_LCDIF.offset384)
  5897. #define LCDIF_PIGEONCTRL0_CLR (IMXRT_LCDIF.offset388)
  5898. #define LCDIF_PIGEONCTRL0_TOG (IMXRT_LCDIF.offset38C)
  5899. #define LCDIF_PIGEONCTRL1 (IMXRT_LCDIF.offset390)
  5900. #define LCDIF_PIGEONCTRL1_SET (IMXRT_LCDIF.offset394)
  5901. #define LCDIF_PIGEONCTRL1_CLR (IMXRT_LCDIF.offset398)
  5902. #define LCDIF_PIGEONCTRL1_TOG (IMXRT_LCDIF.offset39C)
  5903. #define LCDIF_PIGEONCTRL2 (IMXRT_LCDIF.offset3A0)
  5904. #define LCDIF_PIGEONCTRL2_SET (IMXRT_LCDIF.offset3A4)
  5905. #define LCDIF_PIGEONCTRL2_CLR (IMXRT_LCDIF.offset3A8)
  5906. #define LCDIF_PIGEONCTRL2_TOG (IMXRT_LCDIF.offset3AC)
  5907. #define IMXRT_LCDIF_b (*(IMXRT_REGISTER32_t *)0x402B8800)
  5908. #define LCDIF_PIGEON_0_0 (IMXRT_LCDIF_b.offset000)
  5909. #define LCDIF_PIGEON_0_1 (IMXRT_LCDIF_b.offset010)
  5910. #define LCDIF_PIGEON_0_2 (IMXRT_LCDIF_b.offset020)
  5911. #define LCDIF_PIGEON_1_0 (IMXRT_LCDIF_b.offset040)
  5912. #define LCDIF_PIGEON_1_1 (IMXRT_LCDIF_b.offset050)
  5913. #define LCDIF_PIGEON_1_2 (IMXRT_LCDIF_b.offset060)
  5914. #define LCDIF_PIGEON_2_0 (IMXRT_LCDIF_b.offset080)
  5915. #define LCDIF_PIGEON_2_1 (IMXRT_LCDIF_b.offset090)
  5916. #define LCDIF_PIGEON_2_2 (IMXRT_LCDIF_b.offset0A0)
  5917. #define LCDIF_PIGEON_3_0 (IMXRT_LCDIF_b.offset0C0)
  5918. #define LCDIF_PIGEON_3_1 (IMXRT_LCDIF_b.offset0D0)
  5919. #define LCDIF_PIGEON_3_2 (IMXRT_LCDIF_b.offset0E0)
  5920. #define LCDIF_PIGEON_4_0 (IMXRT_LCDIF_b.offset100)
  5921. #define LCDIF_PIGEON_4_1 (IMXRT_LCDIF_b.offset110)
  5922. #define LCDIF_PIGEON_4_2 (IMXRT_LCDIF_b.offset120)
  5923. #define LCDIF_PIGEON_5_0 (IMXRT_LCDIF_b.offset140)
  5924. #define LCDIF_PIGEON_5_1 (IMXRT_LCDIF_b.offset150)
  5925. #define LCDIF_PIGEON_5_2 (IMXRT_LCDIF_b.offset160)
  5926. #define LCDIF_PIGEON_6_0 (IMXRT_LCDIF_b.offset180)
  5927. #define LCDIF_PIGEON_6_1 (IMXRT_LCDIF_b.offset190)
  5928. #define LCDIF_PIGEON_6_2 (IMXRT_LCDIF_b.offset1A0)
  5929. #define LCDIF_PIGEON_7_0 (IMXRT_LCDIF_b.offset1C0)
  5930. #define LCDIF_PIGEON_7_1 (IMXRT_LCDIF_b.offset1D0)
  5931. #define LCDIF_PIGEON_7_2 (IMXRT_LCDIF_b.offset1E0)
  5932. #define LCDIF_PIGEON_8_0 (IMXRT_LCDIF_b.offset200)
  5933. #define LCDIF_PIGEON_8_1 (IMXRT_LCDIF_b.offset210)
  5934. #define LCDIF_PIGEON_8_2 (IMXRT_LCDIF_b.offset220)
  5935. #define LCDIF_PIGEON_9_0 (IMXRT_LCDIF_b.offset240)
  5936. #define LCDIF_PIGEON_9_1 (IMXRT_LCDIF_b.offset250)
  5937. #define LCDIF_PIGEON_9_2 (IMXRT_LCDIF_b.offset260)
  5938. #define LCDIF_PIGEON_10_0 (IMXRT_LCDIF_b.offset280)
  5939. #define LCDIF_PIGEON_10_1 (IMXRT_LCDIF_b.offset290)
  5940. #define LCDIF_PIGEON_10_2 (IMXRT_LCDIF_b.offset2A0)
  5941. #define LCDIF_PIGEON_11_0 (IMXRT_LCDIF_b.offset2C0)
  5942. #define LCDIF_PIGEON_11_1 (IMXRT_LCDIF_b.offset2D0)
  5943. #define LCDIF_PIGEON_11_2 (IMXRT_LCDIF_b.offset2E0)
  5944. // 37.4: page 2371
  5945. typedef struct {
  5946. const uint32_t VERID;
  5947. const uint32_t PARAM;
  5948. const uint32_t unused1;
  5949. const uint32_t unused2;
  5950. volatile uint32_t MCR; // 010
  5951. volatile uint32_t MSR; // 014
  5952. volatile uint32_t MIER; // 018
  5953. volatile uint32_t MDER; // 01C
  5954. volatile uint32_t MCFGR0; // 020
  5955. volatile uint32_t MCFGR1; // 024
  5956. volatile uint32_t MCFGR2; // 028
  5957. volatile uint32_t MCFGR3; // 02C
  5958. volatile uint32_t unused3[4];
  5959. volatile uint32_t MDMR; // 040
  5960. volatile uint32_t unused4;
  5961. volatile uint32_t MCCR0; // 048
  5962. volatile uint32_t unused5;
  5963. volatile uint32_t MCCR1; // 050
  5964. volatile uint32_t unused6;
  5965. volatile uint32_t MFCR; // 058
  5966. volatile uint32_t MFSR; // 05C
  5967. volatile uint32_t MTDR; // 060
  5968. volatile uint32_t unused7[3];
  5969. volatile uint32_t MRDR; // 070
  5970. volatile uint32_t unused8[39];
  5971. volatile uint32_t SCR; // 110
  5972. volatile uint32_t SSR; // 114
  5973. volatile uint32_t SIER; // 118
  5974. volatile uint32_t SDER; // 11C
  5975. volatile uint32_t unused9;
  5976. volatile uint32_t SCFGR1; // 124
  5977. volatile uint32_t SCFGR2; // 128
  5978. volatile uint32_t unused10[5];
  5979. volatile uint32_t SAMR; // 140
  5980. volatile uint32_t unused11[3];
  5981. volatile uint32_t SASR; // 150
  5982. volatile uint32_t unused12[3];
  5983. volatile uint32_t STAR; // 154
  5984. volatile uint32_t unused13[3];
  5985. volatile uint32_t STDR; // 160
  5986. volatile uint32_t unused14[3];
  5987. volatile uint32_t SRDR; // 170
  5988. } IMXRT_LPI2C_t;
  5989. #define IMXRT_LPI2C1 (*(IMXRT_LPI2C_t *)0x403F0000)
  5990. #define LPI2C1_VERID (IMXRT_LPI2C1.VERID)
  5991. #define LPI2C1_PARAM (IMXRT_LPI2C1.PARAM)
  5992. #define LPI2C1_MCR (IMXRT_LPI2C1.MCR)
  5993. #define LPI2C1_MSR (IMXRT_LPI2C1.MSR)
  5994. #define LPI2C1_MIER (IMXRT_LPI2C1.MIER)
  5995. #define LPI2C1_MDER (IMXRT_LPI2C1.MDER)
  5996. #define LPI2C1_MCFGR0 (IMXRT_LPI2C1.MCFGR0)
  5997. #define LPI2C1_MCFGR1 (IMXRT_LPI2C1.MCFGR1)
  5998. #define LPI2C1_MCFGR2 (IMXRT_LPI2C1.MCFGR2)
  5999. #define LPI2C1_MCFGR3 (IMXRT_LPI2C1.MCFGR3)
  6000. #define LPI2C1_MDMR (IMXRT_LPI2C1.MDMR)
  6001. #define LPI2C1_MCCR0 (IMXRT_LPI2C1.MCCR0)
  6002. #define LPI2C1_MCCR1 (IMXRT_LPI2C1.MCCR1)
  6003. #define LPI2C1_MFCR (IMXRT_LPI2C1.MFCR)
  6004. #define LPI2C1_MFSR (IMXRT_LPI2C1.MFSR)
  6005. #define LPI2C1_MTDR (IMXRT_LPI2C1.MTDR)
  6006. #define LPI2C1_MRDR (IMXRT_LPI2C1.MRDR)
  6007. #define LPI2C1_SCR (IMXRT_LPI2C1.SCR)
  6008. #define LPI2C1_SSR (IMXRT_LPI2C1.SSR)
  6009. #define LPI2C1_SIER (IMXRT_LPI2C1.SIER)
  6010. #define LPI2C1_SDER (IMXRT_LPI2C1.SDER)
  6011. #define LPI2C1_SCFGR1 (IMXRT_LPI2C1.SCFGR1)
  6012. #define LPI2C1_SCFGR2 (IMXRT_LPI2C1.SCFGR2)
  6013. #define LPI2C1_SAMR (IMXRT_LPI2C1.SAMR)
  6014. #define LPI2C1_SASR (IMXRT_LPI2C1.SASR)
  6015. #define LPI2C1_STAR (IMXRT_LPI2C1.STAR)
  6016. #define LPI2C1_STDR (IMXRT_LPI2C1.STDR)
  6017. #define LPI2C1_SRDR (IMXRT_LPI2C1.SRDR)
  6018. #define IMXRT_LPI2C2 (*(IMXRT_LPI2C_t *)0x403F4000)
  6019. #define LPI2C2_VERID (IMXRT_LPI2C2.VERID)
  6020. #define LPI2C2_PARAM (IMXRT_LPI2C2.PARAM)
  6021. #define LPI2C2_MCR (IMXRT_LPI2C2.MCR)
  6022. #define LPI2C2_MSR (IMXRT_LPI2C2.MSR)
  6023. #define LPI2C2_MIER (IMXRT_LPI2C2.MIER)
  6024. #define LPI2C2_MDER (IMXRT_LPI2C2.MDER)
  6025. #define LPI2C2_MCFGR0 (IMXRT_LPI2C2.MCFGR0)
  6026. #define LPI2C2_MCFGR1 (IMXRT_LPI2C2.MCFGR1)
  6027. #define LPI2C2_MCFGR2 (IMXRT_LPI2C2.MCFGR2)
  6028. #define LPI2C2_MCFGR3 (IMXRT_LPI2C2.MCFGR3)
  6029. #define LPI2C2_MDMR (IMXRT_LPI2C2.MDMR)
  6030. #define LPI2C2_MCCR0 (IMXRT_LPI2C2.MCCR0)
  6031. #define LPI2C2_MCCR1 (IMXRT_LPI2C2.MCCR1)
  6032. #define LPI2C2_MFCR (IMXRT_LPI2C2.MFCR)
  6033. #define LPI2C2_MFSR (IMXRT_LPI2C2.MFSR)
  6034. #define LPI2C2_MTDR (IMXRT_LPI2C2.MTDR)
  6035. #define LPI2C2_MRDR (IMXRT_LPI2C2.MRDR)
  6036. #define LPI2C2_SCR (IMXRT_LPI2C2.SCR)
  6037. #define LPI2C2_SSR (IMXRT_LPI2C2.SSR)
  6038. #define LPI2C2_SIER (IMXRT_LPI2C2.SIER)
  6039. #define LPI2C2_SDER (IMXRT_LPI2C2.SDER)
  6040. #define LPI2C2_SCFGR1 (IMXRT_LPI2C2.SCFGR1)
  6041. #define LPI2C2_SCFGR2 (IMXRT_LPI2C2.SCFGR2)
  6042. #define LPI2C2_SAMR (IMXRT_LPI2C2.SAMR)
  6043. #define LPI2C2_SASR (IMXRT_LPI2C2.SASR)
  6044. #define LPI2C2_STAR (IMXRT_LPI2C2.STAR)
  6045. #define LPI2C2_STDR (IMXRT_LPI2C2.STDR)
  6046. #define LPI2C2_SRDR (IMXRT_LPI2C2.SRDR)
  6047. #define IMXRT_LPI2C3 (*(IMXRT_LPI2C_t *)0x403F8000)
  6048. #define LPI2C3_VERID (IMXRT_LPI2C3.VERID)
  6049. #define LPI2C3_PARAM (IMXRT_LPI2C3.PARAM)
  6050. #define LPI2C3_MCR (IMXRT_LPI2C3.MCR)
  6051. #define LPI2C3_MSR (IMXRT_LPI2C3.MSR)
  6052. #define LPI2C3_MIER (IMXRT_LPI2C3.MIER)
  6053. #define LPI2C3_MDER (IMXRT_LPI2C3.MDER)
  6054. #define LPI2C3_MCFGR0 (IMXRT_LPI2C3.MCFGR0)
  6055. #define LPI2C3_MCFGR1 (IMXRT_LPI2C3.MCFGR1)
  6056. #define LPI2C3_MCFGR2 (IMXRT_LPI2C3.MCFGR2)
  6057. #define LPI2C3_MCFGR3 (IMXRT_LPI2C3.MCFGR3)
  6058. #define LPI2C3_MDMR (IMXRT_LPI2C3.MDMR)
  6059. #define LPI2C3_MCCR0 (IMXRT_LPI2C3.MCCR0)
  6060. #define LPI2C3_MCCR1 (IMXRT_LPI2C3.MCCR1)
  6061. #define LPI2C3_MFCR (IMXRT_LPI2C3.MFCR)
  6062. #define LPI2C3_MFSR (IMXRT_LPI2C3.MFSR)
  6063. #define LPI2C3_MTDR (IMXRT_LPI2C3.MTDR)
  6064. #define LPI2C3_MRDR (IMXRT_LPI2C3.MRDR)
  6065. #define LPI2C3_SCR (IMXRT_LPI2C3.SCR)
  6066. #define LPI2C3_SSR (IMXRT_LPI2C3.SSR)
  6067. #define LPI2C3_SIER (IMXRT_LPI2C3.SIER)
  6068. #define LPI2C3_SDER (IMXRT_LPI2C3.SDER)
  6069. #define LPI2C3_SCFGR1 (IMXRT_LPI2C3.SCFGR1)
  6070. #define LPI2C3_SCFGR2 (IMXRT_LPI2C3.SCFGR2)
  6071. #define LPI2C3_SAMR (IMXRT_LPI2C3.SAMR)
  6072. #define LPI2C3_SASR (IMXRT_LPI2C3.SASR)
  6073. #define LPI2C3_STAR (IMXRT_LPI2C3.STAR)
  6074. #define LPI2C3_STDR (IMXRT_LPI2C3.STDR)
  6075. #define LPI2C3_SRDR (IMXRT_LPI2C3.SRDR)
  6076. #define IMXRT_LPI2C4 (*(IMXRT_LPI2C_t *)0x403FC000)
  6077. #define LPI2C4_VERID (IMXRT_LPI2C4.VERID)
  6078. #define LPI2C4_PARAM (IMXRT_LPI2C4.PARAM)
  6079. #define LPI2C4_MCR (IMXRT_LPI2C4.MCR)
  6080. #define LPI2C4_MSR (IMXRT_LPI2C4.MSR)
  6081. #define LPI2C4_MIER (IMXRT_LPI2C4.MIER)
  6082. #define LPI2C4_MDER (IMXRT_LPI2C4.MDER)
  6083. #define LPI2C4_MCFGR0 (IMXRT_LPI2C4.MCFGR0)
  6084. #define LPI2C4_MCFGR1 (IMXRT_LPI2C4.MCFGR1)
  6085. #define LPI2C4_MCFGR2 (IMXRT_LPI2C4.MCFGR2)
  6086. #define LPI2C4_MCFGR3 (IMXRT_LPI2C4.MCFGR3)
  6087. #define LPI2C4_MDMR (IMXRT_LPI2C4.MDMR)
  6088. #define LPI2C4_MCCR0 (IMXRT_LPI2C4.MCCR0)
  6089. #define LPI2C4_MCCR1 (IMXRT_LPI2C4.MCCR1)
  6090. #define LPI2C4_MFCR (IMXRT_LPI2C4.MFCR)
  6091. #define LPI2C4_MFSR (IMXRT_LPI2C4.MFSR)
  6092. #define LPI2C4_MTDR (IMXRT_LPI2C4.MTDR)
  6093. #define LPI2C4_MRDR (IMXRT_LPI2C4.MRDR)
  6094. #define LPI2C4_SCR (IMXRT_LPI2C4.SCR)
  6095. #define LPI2C4_SSR (IMXRT_LPI2C4.SSR)
  6096. #define LPI2C4_SIER (IMXRT_LPI2C4.SIER)
  6097. #define LPI2C4_SDER (IMXRT_LPI2C4.SDER)
  6098. #define LPI2C4_SCFGR1 (IMXRT_LPI2C4.SCFGR1)
  6099. #define LPI2C4_SCFGR2 (IMXRT_LPI2C4.SCFGR2)
  6100. #define LPI2C4_SAMR (IMXRT_LPI2C4.SAMR)
  6101. #define LPI2C4_SASR (IMXRT_LPI2C4.SASR)
  6102. #define LPI2C4_STAR (IMXRT_LPI2C4.STAR)
  6103. #define LPI2C4_STDR (IMXRT_LPI2C4.STDR)
  6104. #define LPI2C4_SRDR (IMXRT_LPI2C4.SRDR)
  6105. #define LPI2C_MCR_RRF ((uint32_t)(1<<9))
  6106. #define LPI2C_MCR_RTF ((uint32_t)(1<<8))
  6107. #define LPI2C_MCR_DBGEN ((uint32_t)(1<<3))
  6108. #define LPI2C_MCR_DOZEN ((uint32_t)(1<<2))
  6109. #define LPI2C_MCR_RST ((uint32_t)(1<<1))
  6110. #define LPI2C_MCR_MEN ((uint32_t)(1<<0))
  6111. #define LPI2C_MSR_BBF ((uint32_t)(1<<25))
  6112. #define LPI2C_MSR_MBF ((uint32_t)(1<<24))
  6113. #define LPI2C_MSR_DMF ((uint32_t)(1<<14))
  6114. #define LPI2C_MSR_PLTF ((uint32_t)(1<<13))
  6115. #define LPI2C_MSR_FEF ((uint32_t)(1<<12))
  6116. #define LPI2C_MSR_ALF ((uint32_t)(1<<11))
  6117. #define LPI2C_MSR_NDF ((uint32_t)(1<<10))
  6118. #define LPI2C_MSR_SDF ((uint32_t)(1<<9))
  6119. #define LPI2C_MSR_EPF ((uint32_t)(1<<8))
  6120. #define LPI2C_MSR_RDF ((uint32_t)(1<<1))
  6121. #define LPI2C_MSR_TDF ((uint32_t)(1<<0))
  6122. #define LPI2C_MIER_DMIE ((uint32_t)(1<<14))
  6123. #define LPI2C_MIER_PLTIE ((uint32_t)(1<<13))
  6124. #define LPI2C_MIER_FEIE ((uint32_t)(1<<12))
  6125. #define LPI2C_MIER_ALIE ((uint32_t)(1<<11))
  6126. #define LPI2C_MIER_NDIE ((uint32_t)(1<<10))
  6127. #define LPI2C_MIER_SDIE ((uint32_t)(1<<9))
  6128. #define LPI2C_MIER_EPIE ((uint32_t)(1<<8))
  6129. #define LPI2C_MIER_RDIE ((uint32_t)(1<<1))
  6130. #define LPI2C_MIER_TDIE ((uint32_t)(1<<0))
  6131. #define LPI2C_MDER_RDDE ((uint32_t)(1<<1))
  6132. #define LPI2C_MDER_TDDE ((uint32_t)(1<<0))
  6133. #define LPI2C_MCFGR0_RDMO ((uint32_t)(1<<9))
  6134. #define LPI2C_MCFGR0_CIRFIFO ((uint32_t)(1<<8))
  6135. #define LPI2C_MCFGR0_HRSEL ((uint32_t)(1<<2))
  6136. #define LPI2C_MCFGR0_HRPOL ((uint32_t)(1<<1))
  6137. #define LPI2C_MCFGR0_HREN ((uint32_t)(1<<0))
  6138. #define LPI2C_MCFGR1_PINCFG(n) ((uint32_t)(((n) & 0x07) << 24))
  6139. #define LPI2C_MCFGR1_MATCFG(n) ((uint32_t)(((n) & 0x07) << 16))
  6140. #define LPI2C_MCFGR1_TIMECFG ((uint32_t)(1<<10))
  6141. #define LPI2C_MCFGR1_IGNACK ((uint32_t)(1<<9))
  6142. #define LPI2C_MCFGR1_AUTOSTOP ((uint32_t)(1<<8))
  6143. #define LPI2C_MCFGR1_PRESCALE(n) ((uint32_t)(((n) & 0x07) << 0))
  6144. #define LPI2C_MCFGR2_FILTSDA(n) ((uint32_t)(((n) & 0x0F) << 24))
  6145. #define LPI2C_MCFGR2_FILTSCL(n) ((uint32_t)(((n) & 0x0F) << 16))
  6146. #define LPI2C_MCFGR2_BUSIDLE(n) ((uint32_t)(((n) & 0xFFF) << 0))
  6147. #define LPI2C_MCFGR3_PINLOW(n) ((uint32_t)(((n) & 0xFFF) << 8))
  6148. #define LPI2C_MDMR_MATCH1(n) ((uint32_t)(((n) & 0xFF) << 16))
  6149. #define LPI2C_MDMR_MATCH0(n) ((uint32_t)(((n) & 0xFF) << 0))
  6150. #define LPI2C_MCCR0_DATAVD(n) ((uint32_t)(((n) & 0x3F) << 24))
  6151. #define LPI2C_MCCR0_SETHOLD(n) ((uint32_t)(((n) & 0x3F) << 16))
  6152. #define LPI2C_MCCR0_CLKHI(n) ((uint32_t)(((n) & 0x3F) << 8))
  6153. #define LPI2C_MCCR0_CLKLO(n) ((uint32_t)(((n) & 0x3F) << 0))
  6154. #define LPI2C_MCCR1_DATAVD(n) ((uint32_t)(((n) & 0x3F) << 24))
  6155. #define LPI2C_MCCR1_SETHOLD(n) ((uint32_t)(((n) & 0x3F) << 16))
  6156. #define LPI2C_MCCR1_CLKHI(n) ((uint32_t)(((n) & 0x3F) << 8))
  6157. #define LPI2C_MCCR1_CLKLO(n) ((uint32_t)(((n) & 0x3F) << 0))
  6158. #define LPI2C_MFCR_RXWATER(n) ((uint32_t)(((n) & 0x03) << 16))
  6159. #define LPI2C_MFCR_TXWATER(n) ((uint32_t)(((n) & 0x03) << 0))
  6160. #define LPI2C_MFSR_RXCOUNT(n) ((uint32_t)(((n) & 0x07) << 16))
  6161. #define LPI2C_MFSR_TXCOUNT(n) ((uint32_t)(((n) & 0x07) << 16))
  6162. #define LPI2C_MTDR_CMD(n) ((uint32_t)(((n) & 0x07) << 8))
  6163. #define LPI2C_MTDR_CMD_TRANSMIT ((uint32_t)(0 << 8))
  6164. #define LPI2C_MTDR_CMD_RECEIVE ((uint32_t)(1 << 8))
  6165. #define LPI2C_MTDR_CMD_STOP ((uint32_t)(2 << 8))
  6166. #define LPI2C_MTDR_CMD_DISCARD ((uint32_t)(3 << 8))
  6167. #define LPI2C_MTDR_CMD_START ((uint32_t)(4 << 8))
  6168. #define LPI2C_MTDR_CMD_START_NACK ((uint32_t)(5 << 8))
  6169. #define LPI2C_MTDR_CMD_HS_START ((uint32_t)(6 << 8))
  6170. #define LPI2C_MTDR_CMD_HS_START_NAcK ((uint32_t)(7 << 8))
  6171. #define LPI2C_MTDR_DATA(n) ((uint32_t)(((n) & 0xFF) << 0))
  6172. #define LPI2C_MRDR_RXEMPTY ((uint32_t)(1<<14))
  6173. #define LPI2C_MRDR_DATA(n) ((uint32_t)(((n) & 0xFF) << 0))
  6174. #define LPI2C_SCR_RRF ((uint32_t)(1<<9))
  6175. #define LPI2C_SCR_RTF ((uint32_t)(1<<8))
  6176. #define LPI2C_SCR_FILTDZ ((uint32_t)(1<<5))
  6177. #define LPI2C_SCR_FILTEN ((uint32_t)(1<<4))
  6178. #define LPI2C_SCR_RST ((uint32_t)(1<<1))
  6179. #define LPI2C_SCR_SEN ((uint32_t)(1<<0))
  6180. #define LPI2C_SSR_BBF ((uint32_t)(1<<25))
  6181. #define LPI2C_SSR_SBF ((uint32_t)(1<<24))
  6182. #define LPI2C_SSR_SARF ((uint32_t)(1<<15))
  6183. #define LPI2C_SSR_GCF ((uint32_t)(1<<14))
  6184. #define LPI2C_SSR_AM1F ((uint32_t)(1<<13))
  6185. #define LPI2C_SSR_AM0F ((uint32_t)(1<<12))
  6186. #define LPI2C_SSR_FEF ((uint32_t)(1<<11))
  6187. #define LPI2C_SSR_BEF ((uint32_t)(1<<10))
  6188. #define LPI2C_SSR_SDF ((uint32_t)(1<<9))
  6189. #define LPI2C_SSR_RSF ((uint32_t)(1<<8))
  6190. #define LPI2C_SSR_TAF ((uint32_t)(1<<3))
  6191. #define LPI2C_SSR_AVF ((uint32_t)(1<<2))
  6192. #define LPI2C_SSR_RDF ((uint32_t)(1<<1))
  6193. #define LPI2C_SSR_TDF ((uint32_t)(1<<0))
  6194. #define LPI2C_SIER_SARIE ((uint32_t)(1<<25))
  6195. #define LPI2C_SIER_GCIE ((uint32_t)(1<<24))
  6196. #define LPI2C_SIER_AM1F ((uint32_t)(1<<13))
  6197. #define LPI2C_SIER_AM0IE ((uint32_t)(1<<12))
  6198. #define LPI2C_SIER_FEIE ((uint32_t)(1<<11))
  6199. #define LPI2C_SIER_BEIE ((uint32_t)(1<<10))
  6200. #define LPI2C_SIER_SDIE ((uint32_t)(1<<9))
  6201. #define LPI2C_SIER_RSIE ((uint32_t)(1<<8))
  6202. #define LPI2C_SIER_TAIE ((uint32_t)(1<<3))
  6203. #define LPI2C_SIER_AVIE ((uint32_t)(1<<2))
  6204. #define LPI2C_SIER_RDIE ((uint32_t)(1<<1))
  6205. #define LPI2C_SIER_TDIE ((uint32_t)(1<<0))
  6206. #define LPI2C_SDER_AVDE ((uint32_t)(1<<2))
  6207. #define LPI2C_SDER_RDDE ((uint32_t)(1<<1))
  6208. #define LPI2C_SDER_TDDE ((uint32_t)(1<<0))
  6209. #define LPI2C_SCFGR1_ADDRCFG(n) ((uint32_t)(((n) & 0x07) << 16))
  6210. #define LPI2C_SCFGR1_HSMEN ((uint32_t)(1<<13))
  6211. #define LPI2C_SCFGR1_IGNACK ((uint32_t)(1<<12))
  6212. #define LPI2C_SCFGR1_RXCFG ((uint32_t)(1<<11))
  6213. #define LPI2C_SCFGR1_TXCFG ((uint32_t)(1<<10))
  6214. #define LPI2C_SCFGR1_SAEN ((uint32_t)(1<<9))
  6215. #define LPI2C_SCFGR1_GCEN ((uint32_t)(1<<8))
  6216. #define LPI2C_SCFGR1_ACKSTALL ((uint32_t)(1<<3))
  6217. #define LPI2C_SCFGR1_TXDSTALL ((uint32_t)(1<<2))
  6218. #define LPI2C_SCFGR1_RXSTALL ((uint32_t)(1<<1))
  6219. #define LPI2C_SCFGR1_ADRSTALL ((uint32_t)(1<<0))
  6220. #define LPI2C_SCFGR2_FILTSDA(n) ((uint32_t)(((n) & 0x0F) << 24))
  6221. #define LPI2C_SCFGR2_FILTSCL(n) ((uint32_t)(((n) & 0x0F) << 16))
  6222. #define LPI2C_SCFGR2_DATAVD(n) ((uint32_t)(((n) & 0x3F) << 8))
  6223. #define LPI2C_SCFGR2_CLKHOLD(n) ((uint32_t)(((n) & 0x0F) << 0))
  6224. #define LPI2C_SAMR_ADDR1(n) ((uint32_t)(((n) & 0x7F) << 17))
  6225. #define LPI2C_SAMR_ADDR0(n) ((uint32_t)(((n) & 0x7F) << 1))
  6226. #define LPI2C_SASR_ANV ((uint32_t)(1<<14))
  6227. #define LPI2C_SASR_RADDR(n) ((uint32_t)(((n) & 0x7FF) << 0))
  6228. #define LPI2C_STAR_TXNACK ((uint32_t)(1<<0))
  6229. #define LPI2C_STDR_DATA(n) ((uint32_t)(((n) & 0xFF) << 0))
  6230. #define LPI2C_SRDR_SOF ((uint32_t)(1<<15))
  6231. #define LPI2C_SRDR_RXEMPTY ((uint32_t)(1<<14))
  6232. #define LPI2C_SRDR_DATA(n) ((uint32_t)(((n) & 0xFF) << 0))
  6233. // 38.3.5.2: page 2422
  6234. typedef struct {
  6235. const uint32_t VERID; // 0
  6236. const uint32_t PARAM; // 0x04
  6237. const uint32_t UNUSED0; // 0x08
  6238. const uint32_t UNUSED1; // 0x0c
  6239. volatile uint32_t CR; // 0x10
  6240. volatile uint32_t SR; // 0x14
  6241. volatile uint32_t IER; // 0x18
  6242. volatile uint32_t DER; // 0x1c
  6243. volatile uint32_t CFGR0; // 0x20
  6244. volatile uint32_t CFGR1; // 0x24
  6245. const uint32_t UNUSED3; // 0x28
  6246. const uint32_t UNUSED4; // 0x2c
  6247. volatile uint32_t DMR0; // 0x30
  6248. volatile uint32_t DMR1; // 0x34
  6249. const uint32_t UNUSED5; // 0x38
  6250. const uint32_t UNUSED6; // 0x3c
  6251. volatile uint32_t CCR; // 0x40
  6252. const uint32_t UNUSED7; // 0x44
  6253. const uint32_t UNUSED8; // 0x48
  6254. const uint32_t UNUSED9; // 0x4c
  6255. const uint32_t UNUSED10; // 0x50
  6256. const uint32_t UNUSED11; // 0x54
  6257. volatile uint32_t FCR; // 0x58
  6258. volatile uint32_t FSR; // 0x5C
  6259. volatile uint32_t TCR; // 0x60
  6260. volatile uint32_t TDR; // 0x64
  6261. const uint32_t UNUSED12; // 0x68
  6262. const uint32_t UNUSED13; // 0x6c
  6263. volatile uint32_t RSR; // 0x70
  6264. volatile uint32_t RDR; // 0x74
  6265. } IMXRT_LPSPI_t;
  6266. #define IMXRT_LPSPI1 (*(IMXRT_REGISTER32_t *)0x40394000)
  6267. #define IMXRT_LPSPI1_S (*(IMXRT_LPSPI_t *)0x40394000)
  6268. #define LPSPI1_VERID (IMXRT_LPSPI1.offset000)
  6269. #define LPSPI1_PARAM (IMXRT_LPSPI1.offset004)
  6270. #define LPSPI1_CR (IMXRT_LPSPI1.offset010)
  6271. #define LPSPI1_SR (IMXRT_LPSPI1.offset014)
  6272. #define LPSPI1_IER (IMXRT_LPSPI1.offset018)
  6273. #define LPSPI1_DER (IMXRT_LPSPI1.offset01C)
  6274. #define LPSPI1_CFGR0 (IMXRT_LPSPI1.offset020)
  6275. #define LPSPI1_CFGR1 (IMXRT_LPSPI1.offset024)
  6276. #define LPSPI1_DMR0 (IMXRT_LPSPI1.offset030)
  6277. #define LPSPI1_DMR1 (IMXRT_LPSPI1.offset034)
  6278. #define LPSPI1_CCR (IMXRT_LPSPI1.offset040)
  6279. #define LPSPI1_FCR (IMXRT_LPSPI1.offset058)
  6280. #define LPSPI1_FSR (IMXRT_LPSPI1.offset05C)
  6281. #define LPSPI1_TCR (IMXRT_LPSPI1.offset060)
  6282. #define LPSPI1_TDR (IMXRT_LPSPI1.offset064)
  6283. #define LPSPI1_RSR (IMXRT_LPSPI1.offset070)
  6284. #define LPSPI1_RDR (IMXRT_LPSPI1.offset074)
  6285. #define IMXRT_LPSPI2 (*(IMXRT_REGISTER32_t *)0x40398000)
  6286. #define IMXRT_LPSPI2_S (*(IMXRT_LPSPI_t *)0x40398000)
  6287. #define LPSPI2_VERID (IMXRT_LPSPI2.offset000)
  6288. #define LPSPI2_PARAM (IMXRT_LPSPI2.offset004)
  6289. #define LPSPI2_CR (IMXRT_LPSPI2.offset010)
  6290. #define LPSPI2_SR (IMXRT_LPSPI2.offset014)
  6291. #define LPSPI2_IER (IMXRT_LPSPI2.offset018)
  6292. #define LPSPI2_DER (IMXRT_LPSPI2.offset01C)
  6293. #define LPSPI2_CFGR0 (IMXRT_LPSPI2.offset020)
  6294. #define LPSPI2_CFGR1 (IMXRT_LPSPI2.offset024)
  6295. #define LPSPI2_DMR0 (IMXRT_LPSPI2.offset030)
  6296. #define LPSPI2_DMR1 (IMXRT_LPSPI2.offset034)
  6297. #define LPSPI2_CCR (IMXRT_LPSPI2.offset040)
  6298. #define LPSPI2_FCR (IMXRT_LPSPI2.offset058)
  6299. #define LPSPI2_FSR (IMXRT_LPSPI2.offset05C)
  6300. #define LPSPI2_TCR (IMXRT_LPSPI2.offset060)
  6301. #define LPSPI2_TDR (IMXRT_LPSPI2.offset064)
  6302. #define LPSPI2_RSR (IMXRT_LPSPI2.offset070)
  6303. #define LPSPI2_RDR (IMXRT_LPSPI2.offset074)
  6304. #define IMXRT_LPSPI3 (*(IMXRT_REGISTER32_t *)0x4039C000)
  6305. #define IMXRT_LPSPI3_S (*(IMXRT_LPSPI_t *)0x4039C000)
  6306. #define LPSPI3_VERID (IMXRT_LPSPI3.offset000)
  6307. #define LPSPI3_PARAM (IMXRT_LPSPI3.offset004)
  6308. #define LPSPI3_CR (IMXRT_LPSPI3.offset010)
  6309. #define LPSPI3_SR (IMXRT_LPSPI3.offset014)
  6310. #define LPSPI3_IER (IMXRT_LPSPI3.offset018)
  6311. #define LPSPI3_DER (IMXRT_LPSPI3.offset01C)
  6312. #define LPSPI3_CFGR0 (IMXRT_LPSPI3.offset020)
  6313. #define LPSPI3_CFGR1 (IMXRT_LPSPI3.offset024)
  6314. #define LPSPI3_DMR0 (IMXRT_LPSPI3.offset030)
  6315. #define LPSPI3_DMR1 (IMXRT_LPSPI3.offset034)
  6316. #define LPSPI3_CCR (IMXRT_LPSPI3.offset040)
  6317. #define LPSPI3_FCR (IMXRT_LPSPI3.offset058)
  6318. #define LPSPI3_FSR (IMXRT_LPSPI3.offset05C)
  6319. #define LPSPI3_TCR (IMXRT_LPSPI3.offset060)
  6320. #define LPSPI3_TDR (IMXRT_LPSPI3.offset064)
  6321. #define LPSPI3_RSR (IMXRT_LPSPI3.offset070)
  6322. #define LPSPI3_RDR (IMXRT_LPSPI3.offset074)
  6323. #define IMXRT_LPSPI4 (*(IMXRT_REGISTER32_t *)0x403A0000)
  6324. #define IMXRT_LPSPI4_S (*(IMXRT_LPSPI_t *)0x403A0000)
  6325. #define LPSPI4_VERID (IMXRT_LPSPI4.offset000)
  6326. #define LPSPI4_PARAM (IMXRT_LPSPI4.offset004)
  6327. #define LPSPI4_CR (IMXRT_LPSPI4.offset010)
  6328. #define LPSPI4_SR (IMXRT_LPSPI4.offset014)
  6329. #define LPSPI4_IER (IMXRT_LPSPI4.offset018)
  6330. #define LPSPI4_DER (IMXRT_LPSPI4.offset01C)
  6331. #define LPSPI4_CFGR0 (IMXRT_LPSPI4.offset020)
  6332. #define LPSPI4_CFGR1 (IMXRT_LPSPI4.offset024)
  6333. #define LPSPI4_DMR0 (IMXRT_LPSPI4.offset030)
  6334. #define LPSPI4_DMR1 (IMXRT_LPSPI4.offset034)
  6335. #define LPSPI4_CCR (IMXRT_LPSPI4.offset040)
  6336. #define LPSPI4_FCR (IMXRT_LPSPI4.offset058)
  6337. #define LPSPI4_FSR (IMXRT_LPSPI4.offset05C)
  6338. #define LPSPI4_TCR (IMXRT_LPSPI4.offset060)
  6339. #define LPSPI4_TDR (IMXRT_LPSPI4.offset064)
  6340. #define LPSPI4_RSR (IMXRT_LPSPI4.offset070)
  6341. #define LPSPI4_RDR (IMXRT_LPSPI4.offset074)
  6342. #define LPSPI_CR_RRF ((uint32_t)(1<<9))
  6343. #define LPSPI_CR_RTF ((uint32_t)(1<<8))
  6344. #define LPSPI_CR_DBGEN ((uint32_t)(1<<3))
  6345. #define LPSPI_CR_DOZEN ((uint32_t)(1<<2))
  6346. #define LPSPI_CR_RST ((uint32_t)(1<<1))
  6347. #define LPSPI_CR_MEN ((uint32_t)(1<<0))
  6348. #define LPSPI_SR_MBF ((uint32_t)(1<<24))
  6349. #define LPSPI_SR_DMF ((uint32_t)(1<<13))
  6350. #define LPSPI_SR_REF ((uint32_t)(1<<12))
  6351. #define LPSPI_SR_TEF ((uint32_t)(1<<11))
  6352. #define LPSPI_SR_TCF ((uint32_t)(1<<10))
  6353. #define LPSPI_SR_FCF ((uint32_t)(1<<9))
  6354. #define LPSPI_SR_WCF ((uint32_t)(1<<8))
  6355. #define LPSPI_SR_RDF ((uint32_t)(1<<1))
  6356. #define LPSPI_SR_TDF ((uint32_t)(1<<0))
  6357. #define LPSPI_IER_DMIE ((uint32_t)(1<<13))
  6358. #define LPSPI_IER_REIE ((uint32_t)(1<<12))
  6359. #define LPSPI_IER_TEIE ((uint32_t)(1<<11))
  6360. #define LPSPI_IER_TCIE ((uint32_t)(1<<10))
  6361. #define LPSPI_IER_FCIE ((uint32_t)(1<<9))
  6362. #define LPSPI_IER_WCIE ((uint32_t)(1<<8))
  6363. #define LPSPI_IER_RDIE ((uint32_t)(1<<1))
  6364. #define LPSPI_IER_TDIE ((uint32_t)(1<<0))
  6365. #define LPSPI_DER_RDDE ((uint32_t)(1<<1))
  6366. #define LPSPI_DER_TDDE ((uint32_t)(1<<0))
  6367. #define LPSPI_CFGR0_RDMO ((uint32_t)(1<<9))
  6368. #define LPSPI_CFGR0_CIRFIFO ((uint32_t)(1<<8))
  6369. #define LPSPI_CFGR0_HRSEL ((uint32_t)(1<<2))
  6370. #define LPSPI_CFGR0_HRPOL ((uint32_t)(1<<1))
  6371. #define LPSPI_CFGR0_HREN ((uint32_t)(1<<0))
  6372. #define LPSPI_CFGR1_PCSCFG ((uint32_t)(1<<27))
  6373. #define LPSPI_CFGR1_OUTCFG ((uint32_t)(1<<26))
  6374. #define LPSPI_CFGR1_PINCFG(n) ((uint32_t)(((n) & 0x03) << 24))
  6375. #define LPSPI_CFGR1_MATCFG(n) ((uint32_t)(((n) & 0x07) << 16))
  6376. #define LPSPI_CFGR1_PCSPOL(n) ((uint32_t)(((n) & 0x0F) << 8))
  6377. #define LPSPI_CFGR1_NOSTALL ((uint32_t)(1<<3))
  6378. #define LPSPI_CFGR1_AUTOPCS ((uint32_t)(1<<2))
  6379. #define LPSPI_CFGR1_SAMPLE ((uint32_t)(1<<1))
  6380. #define LPSPI_CFGR1_MASTER ((uint32_t)(1<<0))
  6381. #define LPSPI_CCR_SCKPCS(n) ((uint32_t)(((n) & 0xFF) << 24))
  6382. #define LPSPI_CCR_PCSSCK(n) ((uint32_t)(((n) & 0xFF) << 16))
  6383. #define LPSPI_CCR_DBT(n) ((uint32_t)(((n) & 0xFF) << 8))
  6384. #define LPSPI_CCR_SCKDIV(n) ((uint32_t)(((n) & 0xFF) << 0))
  6385. #define LPSPI_FCR_RXWATER(n) ((uint32_t)(((n) & 0x0F) << 16))
  6386. #define LPSPI_FCR_TXWATER(n) ((uint32_t)(((n) & 0x0F) << 0))
  6387. #define LPSPI_FSR_RXCOUNT(n) ((uint32_t)(((n) & 0x1F) << 16))
  6388. #define LPSPI_FSR_TXCOUNT(n) ((uint32_t)(((n) & 0x1F) << 0))
  6389. #define LPSPI_TCR_CPOL ((uint32_t)(1<<31))
  6390. #define LPSPI_TCR_CPHA ((uint32_t)(1<<30))
  6391. #define LPSPI_TCR_PRESCALE(n) ((uint32_t)(((n) & 0x07) << 27))
  6392. #define LPSPI_TCR_PCS(n) ((uint32_t)(((n) & 0x03) << 24))
  6393. #define LPSPI_TCR_LSBF ((uint32_t)(1<<23))
  6394. #define LPSPI_TCR_BYSW ((uint32_t)(1<<22))
  6395. #define LPSPI_TCR_CONT ((uint32_t)(1<<21))
  6396. #define LPSPI_TCR_CONTC ((uint32_t)(1<<20))
  6397. #define LPSPI_TCR_RXMSK ((uint32_t)(1<<19))
  6398. #define LPSPI_TCR_TXMSK ((uint32_t)(1<<18))
  6399. #define LPSPI_TCR_WIDTH(n) ((uint32_t)(((n) & 0x03) << 16))
  6400. #define LPSPI_TCR_FRAMESZ(n) ((uint32_t)(((n) & 0xFFF) << 0))
  6401. #define LPSPI_RSR_RXEMPTY ((uint32_t)(1<<1))
  6402. #define LPSPI_RSR_SOF ((uint32_t)(1<<0))
  6403. // 39.3.1.1: page 2466
  6404. typedef struct {
  6405. const uint32_t VERID;
  6406. const uint32_t PARAM;
  6407. volatile uint32_t GLOBAL;
  6408. volatile uint32_t PINCFG;
  6409. volatile uint32_t BAUD;
  6410. volatile uint32_t STAT;
  6411. volatile uint32_t CTRL;
  6412. volatile uint32_t DATA;
  6413. volatile uint32_t MATCH;
  6414. volatile uint32_t MODIR;
  6415. volatile uint32_t FIFO;
  6416. volatile uint32_t WATER;
  6417. } IMXRT_LPUART_t;
  6418. #define IMXRT_LPUART1 (*(IMXRT_LPUART_t *)0x40184000)
  6419. #define LPUART1_VERID (IMXRT_LPUART1.VERID)
  6420. #define LPUART1_PARAM (IMXRT_LPUART1.PARAM)
  6421. #define LPUART1_GLOBAL (IMXRT_LPUART1.GLOBAL)
  6422. #define LPUART1_PINCFG (IMXRT_LPUART1.PINCFG)
  6423. #define LPUART1_BAUD (IMXRT_LPUART1.BAUD)
  6424. #define LPUART1_STAT (IMXRT_LPUART1.STAT)
  6425. #define LPUART1_CTRL (IMXRT_LPUART1.CTRL)
  6426. #define LPUART1_DATA (IMXRT_LPUART1.DATA)
  6427. #define LPUART1_MATCH (IMXRT_LPUART1.MATCH)
  6428. #define LPUART1_MODIR (IMXRT_LPUART1.MODIR)
  6429. #define LPUART1_FIFO (IMXRT_LPUART1.FIFO)
  6430. #define LPUART1_WATER (IMXRT_LPUART1.WATER)
  6431. #define IMXRT_LPUART2 (*(IMXRT_LPUART_t *)0x40188000)
  6432. #define LPUART2_VERID (IMXRT_LPUART2.VERID)
  6433. #define LPUART2_PARAM (IMXRT_LPUART2.PARAM)
  6434. #define LPUART2_GLOBAL (IMXRT_LPUART2.GLOBAL)
  6435. #define LPUART2_PINCFG (IMXRT_LPUART2.PINCFG)
  6436. #define LPUART2_BAUD (IMXRT_LPUART2.BAUD)
  6437. #define LPUART2_STAT (IMXRT_LPUART2.STAT)
  6438. #define LPUART2_CTRL (IMXRT_LPUART2.CTRL)
  6439. #define LPUART2_DATA (IMXRT_LPUART2.DATA)
  6440. #define LPUART2_MATCH (IMXRT_LPUART2.MATCH)
  6441. #define LPUART2_MODIR (IMXRT_LPUART2.MODIR)
  6442. #define LPUART2_FIFO (IMXRT_LPUART2.FIFO)
  6443. #define LPUART2_WATER (IMXRT_LPUART2.WATER)
  6444. #define IMXRT_LPUART3 (*(IMXRT_LPUART_t *)0x4018C000)
  6445. #define LPUART3_VERID (IMXRT_LPUART3.VERID)
  6446. #define LPUART3_PARAM (IMXRT_LPUART3.PARAM)
  6447. #define LPUART3_GLOBAL (IMXRT_LPUART3.GLOBAL)
  6448. #define LPUART3_PINCFG (IMXRT_LPUART3.PINCFG)
  6449. #define LPUART3_BAUD (IMXRT_LPUART3.BAUD)
  6450. #define LPUART3_STAT (IMXRT_LPUART3.STAT)
  6451. #define LPUART3_CTRL (IMXRT_LPUART3.CTRL)
  6452. #define LPUART3_DATA (IMXRT_LPUART3.DATA)
  6453. #define LPUART3_MATCH (IMXRT_LPUART3.MATCH)
  6454. #define LPUART3_MODIR (IMXRT_LPUART3.MODIR)
  6455. #define LPUART3_FIFO (IMXRT_LPUART3.FIFO)
  6456. #define LPUART3_WATER (IMXRT_LPUART3.WATER)
  6457. #define IMXRT_LPUART4 (*(IMXRT_LPUART_t *)0x40190000)
  6458. #define LPUART4_VERID (IMXRT_LPUART4.VERID)
  6459. #define LPUART4_PARAM (IMXRT_LPUART4.PARAM)
  6460. #define LPUART4_GLOBAL (IMXRT_LPUART4.GLOBAL)
  6461. #define LPUART4_PINCFG (IMXRT_LPUART4.PINCFG)
  6462. #define LPUART4_BAUD (IMXRT_LPUART4.BAUD)
  6463. #define LPUART4_STAT (IMXRT_LPUART4.STAT)
  6464. #define LPUART4_CTRL (IMXRT_LPUART4.CTRL)
  6465. #define LPUART4_DATA (IMXRT_LPUART4.DATA)
  6466. #define LPUART4_MATCH (IMXRT_LPUART4.MATCH)
  6467. #define LPUART4_MODIR (IMXRT_LPUART4.MODIR)
  6468. #define LPUART4_FIFO (IMXRT_LPUART4.FIFO)
  6469. #define LPUART4_WATER (IMXRT_LPUART4.WATER)
  6470. #define IMXRT_LPUART5 (*(IMXRT_LPUART_t *)0x40194000)
  6471. #define LPUART5_VERID (IMXRT_LPUART5.VERID)
  6472. #define LPUART5_PARAM (IMXRT_LPUART5.PARAM)
  6473. #define LPUART5_GLOBAL (IMXRT_LPUART5.GLOBAL)
  6474. #define LPUART5_PINCFG (IMXRT_LPUART5.PINCFG)
  6475. #define LPUART5_BAUD (IMXRT_LPUART5.BAUD)
  6476. #define LPUART5_STAT (IMXRT_LPUART5.STAT)
  6477. #define LPUART5_CTRL (IMXRT_LPUART5.CTRL)
  6478. #define LPUART5_DATA (IMXRT_LPUART5.DATA)
  6479. #define LPUART5_MATCH (IMXRT_LPUART5.MATCH)
  6480. #define LPUART5_MODIR (IMXRT_LPUART5.MODIR)
  6481. #define LPUART5_FIFO (IMXRT_LPUART5.FIFO)
  6482. #define LPUART5_WATER (IMXRT_LPUART5.WATER)
  6483. #define IMXRT_LPUART6 (*(IMXRT_LPUART_t *)0x40198000)
  6484. #define LPUART6_VERID (IMXRT_LPUART6.VERID)
  6485. #define LPUART6_PARAM (IMXRT_LPUART6.PARAM)
  6486. #define LPUART6_GLOBAL (IMXRT_LPUART6.GLOBAL)
  6487. #define LPUART6_PINCFG (IMXRT_LPUART6.PINCFG)
  6488. #define LPUART6_BAUD (IMXRT_LPUART6.BAUD)
  6489. #define LPUART6_STAT (IMXRT_LPUART6.STAT)
  6490. #define LPUART6_CTRL (IMXRT_LPUART6.CTRL)
  6491. #define LPUART6_DATA (IMXRT_LPUART6.DATA)
  6492. #define LPUART6_MATCH (IMXRT_LPUART6.MATCH)
  6493. #define LPUART6_MODIR (IMXRT_LPUART6.MODIR)
  6494. #define LPUART6_FIFO (IMXRT_LPUART6.FIFO)
  6495. #define LPUART6_WATER (IMXRT_LPUART6.WATER)
  6496. #define IMXRT_LPUART7 (*(IMXRT_LPUART_t *)0x4019C000)
  6497. #define LPUART7_VERID (IMXRT_LPUART7.VERID)
  6498. #define LPUART7_PARAM (IMXRT_LPUART7.PARAM)
  6499. #define LPUART7_GLOBAL (IMXRT_LPUART7.GLOBAL)
  6500. #define LPUART7_PINCFG (IMXRT_LPUART7.PINCFG)
  6501. #define LPUART7_BAUD (IMXRT_LPUART7.BAUD)
  6502. #define LPUART7_STAT (IMXRT_LPUART7.STAT)
  6503. #define LPUART7_CTRL (IMXRT_LPUART7.CTRL)
  6504. #define LPUART7_DATA (IMXRT_LPUART7.DATA)
  6505. #define LPUART7_MATCH (IMXRT_LPUART7.MATCH)
  6506. #define LPUART7_MODIR (IMXRT_LPUART7.MODIR)
  6507. #define LPUART7_FIFO (IMXRT_LPUART7.FIFO)
  6508. #define LPUART7_WATER (IMXRT_LPUART7.WATER)
  6509. #define IMXRT_LPUART8 (*(IMXRT_LPUART_t *)0x401A0000)
  6510. #define LPUART8_VERID (IMXRT_LPUART8.VERID)
  6511. #define LPUART8_PARAM (IMXRT_LPUART8.PARAM)
  6512. #define LPUART8_GLOBAL (IMXRT_LPUART8.GLOBAL)
  6513. #define LPUART8_PINCFG (IMXRT_LPUART8.PINCFG)
  6514. #define LPUART8_BAUD (IMXRT_LPUART8.BAUD)
  6515. #define LPUART8_STAT (IMXRT_LPUART8.STAT)
  6516. #define LPUART8_CTRL (IMXRT_LPUART8.CTRL)
  6517. #define LPUART8_DATA (IMXRT_LPUART8.DATA)
  6518. #define LPUART8_MATCH (IMXRT_LPUART8.MATCH)
  6519. #define LPUART8_MODIR (IMXRT_LPUART8.MODIR)
  6520. #define LPUART8_FIFO (IMXRT_LPUART8.FIFO)
  6521. #define LPUART8_WATER (IMXRT_LPUART8.WATER)
  6522. #define LPUART_VERID_MAJOR(n) ((uint32_t)(((n) & 0xFF) << 24))
  6523. #define LPUART_VERID_MINOR(n) ((uint32_t)(((n) & 0xFF) << 16))
  6524. #define LPUART_VERID_FEATURE(n) ((uint32_t)(((n) & 0xFFFF) << 0))
  6525. #define LPUART_PARAM_RXFIFO(n) ((uint32_t)(((n) & 0xFF) << 8))
  6526. #define LPUART_PARAM_TXFIFO(n) ((uint32_t)(((n) & 0xFF) << 0))
  6527. #define LPUART_GLOBAL_RST ((uint32_t)(1<<1))
  6528. #define LPUART_PINCFG_TRGSEL(n) ((uint32_t)(((n) & 0x03) << 0))
  6529. #define LPUART_BAUD_MAEN1 ((uint32_t)(1<<31))
  6530. #define LPUART_BAUD_MAEN2 ((uint32_t)(1<<30))
  6531. #define LPUART_BAUD_M10 ((uint32_t)(1<<29))
  6532. #define LPUART_BAUD_OSR(n) ((uint32_t)(((n) & 0x1F) << 24))
  6533. #define LPUART_BAUD_TDMAE ((uint32_t)(1<<23))
  6534. #define LPUART_BAUD_RDMAE ((uint32_t)(1<<21))
  6535. #define LPUART_BAUD_MATCFG(n) ((uint32_t)(((n) & 0x03) << 18))
  6536. #define LPUART_BAUD_BOTHEDGE ((uint32_t)(1<<17))
  6537. #define LPUART_BAUD_RESYNCDIS ((uint32_t)(1<<16))
  6538. #define LPUART_BAUD_LBKDIE ((uint32_t)(1<<15))
  6539. #define LPUART_BAUD_RXEDGIE ((uint32_t)(1<<14))
  6540. #define LPUART_BAUD_SBNS ((uint32_t)(1<<13))
  6541. #define LPUART_BAUD_SBR(n) ((uint32_t)(((n) & 0x01FFF) << 0))
  6542. #define LPUART_STAT_LBKDIF ((uint32_t)(1<<31))
  6543. #define LPUART_STAT_RXEDGIF ((uint32_t)(1<<30))
  6544. #define LPUART_STAT_MSBF ((uint32_t)(1<<29))
  6545. #define LPUART_STAT_RXINV ((uint32_t)(1<<28))
  6546. #define LPUART_STAT_RWUID ((uint32_t)(1<<27))
  6547. #define LPUART_STAT_BRK13 ((uint32_t)(1<<26))
  6548. #define LPUART_STAT_LBKDE ((uint32_t)(1<<25))
  6549. #define LPUART_STAT_RAF ((uint32_t)(1<<24))
  6550. #define LPUART_STAT_TDRE ((uint32_t)(1<<23))
  6551. #define LPUART_STAT_TC ((uint32_t)(1<<22))
  6552. #define LPUART_STAT_RDRF ((uint32_t)(1<<21))
  6553. #define LPUART_STAT_IDLE ((uint32_t)(1<<20))
  6554. #define LPUART_STAT_OR ((uint32_t)(1<<19))
  6555. #define LPUART_STAT_NF ((uint32_t)(1<<18))
  6556. #define LPUART_STAT_FE ((uint32_t)(1<<17))
  6557. #define LPUART_STAT_PF ((uint32_t)(1<<16))
  6558. #define LPUART_STAT_MA1F ((uint32_t)(1<<15))
  6559. #define LPUART_STAT_MA2F ((uint32_t)(1<<14))
  6560. #define LPUART_CTRL_R8T9 ((uint32_t)(1<<31))
  6561. #define LPUART_CTRL_R9T8 ((uint32_t)(1<<30))
  6562. #define LPUART_CTRL_TXDIR ((uint32_t)(1<<29))
  6563. #define LPUART_CTRL_TXINV ((uint32_t)(1<<28))
  6564. #define LPUART_CTRL_ORIE ((uint32_t)(1<<27))
  6565. #define LPUART_CTRL_NEIE ((uint32_t)(1<<26))
  6566. #define LPUART_CTRL_FEIE ((uint32_t)(1<<25))
  6567. #define LPUART_CTRL_PEIE ((uint32_t)(1<<24))
  6568. #define LPUART_CTRL_TIE ((uint32_t)(1<<23))
  6569. #define LPUART_CTRL_TCIE ((uint32_t)(1<<22))
  6570. #define LPUART_CTRL_RIE ((uint32_t)(1<<21))
  6571. #define LPUART_CTRL_ILIE ((uint32_t)(1<<20))
  6572. #define LPUART_CTRL_TE ((uint32_t)(1<<19))
  6573. #define LPUART_CTRL_RE ((uint32_t)(1<<18))
  6574. #define LPUART_CTRL_RWU ((uint32_t)(1<<17))
  6575. #define LPUART_CTRL_SBK ((uint32_t)(1<<16))
  6576. #define LPUART_CTRL_MA1IE ((uint32_t)(1<<15))
  6577. #define LPUART_CTRL_MA2IE ((uint32_t)(1<<14))
  6578. #define LPUART_CTRL_M7 ((uint32_t)(1<<11))
  6579. #define LPUART_CTRL_IDLECFG(n) ((uint32_t)(((n) & 0x07) << 8))
  6580. #define LPUART_CTRL_LOOPS ((uint32_t)(1<<7))
  6581. #define LPUART_CTRL_DOZEEN ((uint32_t)(1<<6))
  6582. #define LPUART_CTRL_RSRC ((uint32_t)(1<<5))
  6583. #define LPUART_CTRL_M ((uint32_t)(1<<4))
  6584. #define LPUART_CTRL_WAKE ((uint32_t)(1<<3))
  6585. #define LPUART_CTRL_ILT ((uint32_t)(1<<2))
  6586. #define LPUART_CTRL_PE ((uint32_t)(1<<1))
  6587. #define LPUART_CTRL_PT ((uint32_t)(1<<0))
  6588. #define LPUART_DATA_NOISY ((uint32_t)(1<<15))
  6589. #define LPUART_DATA_PARITYE ((uint32_t)(1<<14))
  6590. #define LPUART_DATA_FRETSC ((uint32_t)(1<<13))
  6591. #define LPUART_DATA_RXEMPT ((uint32_t)(1<<12))
  6592. #define LPUART_DATA_IDLINE ((uint32_t)(1<<11))
  6593. #define LPUART_MATCH_MA2(n) ((uint32_t)(((n) & 0x3FF) << 16))
  6594. #define LPUART_MATCH_MA1(n) ((uint32_t)(((n) & 0x3FF) << 0))
  6595. #define LPUART_MODIR_IREN ((uint32_t)(1<<18))
  6596. #define LPUART_MODIR_TNP(n) ((uint32_t)(((n) & 0x03) << 16))
  6597. #define LPUART_MODIR_RTSWATER(n) ((uint32_t)(((n) & 0x03) << 8))
  6598. #define LPUART_MODIR_TXCTSSRC ((uint32_t)(1<<5))
  6599. #define LPUART_MODIR_TXCTSC ((uint32_t)(1<<4))
  6600. #define LPUART_MODIR_RXRTSE ((uint32_t)(1<<3))
  6601. #define LPUART_MODIR_TXRTSPOL ((uint32_t)(1<<2))
  6602. #define LPUART_MODIR_TXRTSE ((uint32_t)(1<<1))
  6603. #define LPUART_MODIR_TXCTSE ((uint32_t)(1<<0))
  6604. #define LPUART_FIFO_TXEMPT ((uint32_t)(1<<23))
  6605. #define LPUART_FIFO_RXEMPT ((uint32_t)(1<<22))
  6606. #define LPUART_FIFO_TXOF ((uint32_t)(1<<17))
  6607. #define LPUART_FIFO_RXUF ((uint32_t)(1<<16))
  6608. #define LPUART_FIFO_TXFLUSH ((uint32_t)(1<<15))
  6609. #define LPUART_FIFO_RXFLUSH ((uint32_t)(1<<14))
  6610. #define LPUART_FIFO_RXIDEN(n) ((uint32_t)(((n) & 0x07) << 10))
  6611. #define LPUART_FIFO_TXOFE ((uint32_t)(1<<9))
  6612. #define LPUART_FIFO_RXUFE ((uint32_t)(1<<8))
  6613. #define LPUART_FIFO_TXFE ((uint32_t)(1<<7))
  6614. #define LPUART_FIFO_TXFIFOSIZE(n) ((uint32_t)(((n) & 0x07) << 4))
  6615. #define LPUART_FIFO_RXFE ((uint32_t)(1<<3))
  6616. #define LPUART_FIFO_RXFIFOSIZE(n) ((uint32_t)(((n) & 0x07) << 0))
  6617. #define LPUART_WATER_RXCOUNT(n) ((uint32_t)(((n) & 0x07) << 24))
  6618. #define LPUART_WATER_RXWATER(n) ((uint32_t)(((n) & 0x03) << 16))
  6619. #define LPUART_WATER_TXCOUNT(n) ((uint32_t)(((n) & 0x07) << 8))
  6620. #define LPUART_WATER_TXWATER(n) ((uint32_t)(((n) & 0x03) << 0))
  6621. // 40.4: page 2495
  6622. // 41.3: page 2498 TODO...
  6623. // 42.5.1.1: page 2509
  6624. #define IMXRT_OCOTP (*(IMXRT_REGISTER32_t *)0x401F4000)
  6625. #define HW_OCOTP_CTRL (IMXRT_OCOTP.offset000)
  6626. #define HW_OCOTP_CTRL_SET (IMXRT_OCOTP.offset004)
  6627. #define HW_OCOTP_CTRL_CLR (IMXRT_OCOTP.offset008)
  6628. #define HW_OCOTP_CTRL_TOG (IMXRT_OCOTP.offset00C)
  6629. #define HW_OCOTP_TIMING (IMXRT_OCOTP.offset010)
  6630. #define HW_OCOTP_DATA (IMXRT_OCOTP.offset020)
  6631. #define HW_OCOTP_READ_CTRL (IMXRT_OCOTP.offset030)
  6632. #define HW_OCOTP_READ_FUSE_DATA (IMXRT_OCOTP.offset040)
  6633. #define HW_OCOTP_SW_STICKY (IMXRT_OCOTP.offset050)
  6634. #define HW_OCOTP_SCS (IMXRT_OCOTP.offset060)
  6635. #define HW_OCOTP_SCS_SET (IMXRT_OCOTP.offset064)
  6636. #define HW_OCOTP_SCS_CLR (IMXRT_OCOTP.offset068)
  6637. #define HW_OCOTP_SCS_TOG (IMXRT_OCOTP.offset06C)
  6638. #define HW_OCOTP_VERSION (IMXRT_OCOTP.offset090)
  6639. #define HW_OCOTP_TIMING2 (IMXRT_OCOTP.offset100)
  6640. #define HW_OCOTP_CTRL_WR_UNLOCK(n) ((uint32_t)(((n) & 0xFFFF) << 16))
  6641. #define HW_OCOTP_CTRL_RELOAD_SHADOWS ((uint32_t)(1<<10))
  6642. #define HW_OCOTP_CTRL_ERROR ((uint32_t)(1<<9))
  6643. #define HW_OCOTP_CTRL_BUSY ((uint32_t)(1<<8))
  6644. #define HW_OCOTP_CTRL_ADDR(n) ((uint32_t)(((n) & 0x3F) << 0))
  6645. #define HW_OCOTP_TIMING_WAIT(n) ((uint32_t)(((n) & 0x3F) << 22))
  6646. #define HW_OCOTP_TIMING_STROBE_READ(n) ((uint32_t)(((n) & 0x3F) << 16))
  6647. #define HW_OCOTP_TIMING_RELAX(n) ((uint32_t)(((n) & 0x0F) << 12))
  6648. #define HW_OCOTP_TIMING_STROBE_PROG(n) ((uint32_t)(((n) & 0xFFF) << 0))
  6649. #define HW_OCOTP_READ_CTRL_READ_FUSE ((uint32_t)(1<<0))
  6650. #define HW_OCOTP_SW_STICKY_JTAG_BLOCK_RELEASE ((uint32_t)(1<<4))
  6651. #define HW_OCOTP_SW_STICKY_BLOCK_ROM_PART ((uint32_t)(1<<3))
  6652. #define HW_OCOTP_SW_STICKY_FIELD_RETURN_LOCK ((uint32_t)(1<<2))
  6653. #define HW_OCOTP_SW_STICKY_SRK_REVOKE_LOCK ((uint32_t)(1<<1))
  6654. #define HW_OCOTP_SW_STICKY_BLOCK_DTCP_KEY ((uint32_t)(1<<0))
  6655. #define HW_OCOTP_SCS_LOCK ((uint32_t)(1<<31))
  6656. #define HW_OCOTP_SCS_HAB_JDE ((uint32_t)(1<<0))
  6657. #define HW_OCOTP_TIMING2_RELAX1(n) ((uint32_t)(((n) & 0x7F) << 24))
  6658. #define HW_OCOTP_TIMING2_RELAX_READ(n) ((uint32_t)(((n) & 0x3F) << 16))
  6659. #define HW_OCOTP_TIMING2_RELAX_PROG(n) ((uint32_t)(((n) & 0xFFF) << 0))
  6660. #define IMXRT_OCOTP_VALUE (*(IMXRT_REGISTER32_t *)0x401F4400)
  6661. #define HW_OCOTP_LOCK (IMXRT_OCOTP_VALUE.offset000)
  6662. #define HW_OCOTP_CFG0 (IMXRT_OCOTP_VALUE.offset010)
  6663. #define HW_OCOTP_CFG1 (IMXRT_OCOTP_VALUE.offset020)
  6664. #define HW_OCOTP_CFG2 (IMXRT_OCOTP_VALUE.offset030)
  6665. #define HW_OCOTP_CFG3 (IMXRT_OCOTP_VALUE.offset040)
  6666. #define HW_OCOTP_CFG4 (IMXRT_OCOTP_VALUE.offset050)
  6667. #define HW_OCOTP_CFG5 (IMXRT_OCOTP_VALUE.offset060)
  6668. #define HW_OCOTP_CFG6 (IMXRT_OCOTP_VALUE.offset070)
  6669. #define HW_OCOTP_MEM0 (IMXRT_OCOTP_VALUE.offset080)
  6670. #define HW_OCOTP MEM1 (IMXRT_OCOTP_VALUE.offset090)
  6671. #define HW_OCOTP_MEM2 (IMXRT_OCOTP_VALUE.offset0A0)
  6672. #define HW_OCOTP_MEM3 (IMXRT_OCOTP_VALUE.offset0B0)
  6673. #define HW_OCOTP_MEM4 (IMXRT_OCOTP_VALUE.offset0C0)
  6674. #define HW_OCOTP_ANA0 (IMXRT_OCOTP_VALUE.offset0D0)
  6675. #define HW_OCOTP_ANA1 (IMXRT_OCOTP_VALUE.offset0E0)
  6676. #define HW_OCOTP_ANA2 (IMXRT_OCOTP_VALUE.offset0F0)
  6677. #define HW_OCOTP_OTPMK0 (IMXRT_OCOTP_VALUE.offset100)
  6678. #define HW_OCOTP_OTPMK1 (IMXRT_OCOTP_VALUE.offset110)
  6679. #define HW_OCOTP_OTPMK2 (IMXRT_OCOTP_VALUE.offset120)
  6680. #define HW_OCOTP_OTPMK3 (IMXRT_OCOTP_VALUE.offset130)
  6681. #define HW_OCOTP_OTPMK4 (IMXRT_OCOTP_VALUE.offset140)
  6682. #define HW_OCOTP_OTPMK5 (IMXRT_OCOTP_VALUE.offset150)
  6683. #define HW_OCOTP_OTPMK6 (IMXRT_OCOTP_VALUE.offset160)
  6684. #define HW_OCOTP_OTPMK7 (IMXRT_OCOTP_VALUE.offset170)
  6685. #define HW_OCOTP_SRK0 (IMXRT_OCOTP_VALUE.offset180)
  6686. #define HW_OCOTP_SRK1 (IMXRT_OCOTP_VALUE.offset190)
  6687. #define HW_OCOTP_SRK2 (IMXRT_OCOTP_VALUE.offset1A0)
  6688. #define HW_OCOTP_SRK3 (IMXRT_OCOTP_VALUE.offset1B0)
  6689. #define HW_OCOTP_SRK4 (IMXRT_OCOTP_VALUE.offset1C0)
  6690. #define HW_OCOTP_SRK5 (IMXRT_OCOTP_VALUE.offset1D0)
  6691. #define HW_OCOTP_SRK6 (IMXRT_OCOTP_VALUE.offset1E0)
  6692. #define HW_OCOTP_SRK7 (IMXRT_OCOTP_VALUE.offset1F0)
  6693. #define HW_OCOTP_SJC_RESP0 (IMXRT_OCOTP_VALUE.offset200)
  6694. #define HW_OCOTP_SJC_RESP1 (IMXRT_OCOTP_VALUE.offset210)
  6695. #define HW_OCOTP_MAC0 (IMXRT_OCOTP_VALUE.offset220)
  6696. #define HW_OCOTP_MAC1 (IMXRT_OCOTP_VALUE.offset230)
  6697. #define HW_OCOTP_MAC2 (IMXRT_OCOTP_VALUE.offset240)
  6698. #define HW_OCOTP_GP3 (IMXRT_OCOTP_VALUE.offset250) /* IMXRT1052 */
  6699. #define HW_OCOTP_OTPMK_CRC32 (IMXRT_OCOTP_VALUE.offset250) /* IMXRT1062 */
  6700. #define HW_OCOTP_GP1 (IMXRT_OCOTP_VALUE.offset260)
  6701. #define HW_OCOTP_GP2 (IMXRT_OCOTP_VALUE.offset270)
  6702. #define HW_OCOTP_SW_GP1 (IMXRT_OCOTP_VALUE.offset280)
  6703. #define HW_OCOTP_SW_GP20 (IMXRT_OCOTP_VALUE.offset290)
  6704. #define HW_OCOTP_SW_GP21 (IMXRT_OCOTP_VALUE.offset2A0)
  6705. #define HW_OCOTP_SW_GP22 (IMXRT_OCOTP_VALUE.offset2B0)
  6706. #define HW_OCOTP_SW_GP23 (IMXRT_OCOTP_VALUE.offset2C0)
  6707. #define HW_OCOTP_MISC_CONF0 (IMXRT_OCOTP_VALUE.offset2D0)
  6708. #define HW_OCOTP_MISC_CONF1 (IMXRT_OCOTP_VALUE.offset2E0)
  6709. #define HW_OCOTP_SRK_REVOKE (IMXRT_OCOTP_VALUE.offset2F0)
  6710. #if defined(__IMXRT1062__)
  6711. #define IMXRT_OCOTP_VALUE2 (*(IMXRT_REGISTER32_t *)0x401F4800)
  6712. #define HW_OCOTP_ROM_PATCH0 (IMXRT_OCOTP_VALUE2.offset000)
  6713. #define HW_OCOTP_ROM_PATCH1 (IMXRT_OCOTP_VALUE2.offset010)
  6714. #define HW_OCOTP_ROM_PATCH2 (IMXRT_OCOTP_VALUE2.offset020)
  6715. #define HW_OCOTP_ROM_PATCH3 (IMXRT_OCOTP_VALUE2.offset030)
  6716. #define HW_OCOTP_ROM_PATCH4 (IMXRT_OCOTP_VALUE2.offset040)
  6717. #define HW_OCOTP_ROM_PATCH5 (IMXRT_OCOTP_VALUE2.offset050)
  6718. #define HW_OCOTP_ROM_PATCH6 (IMXRT_OCOTP_VALUE2.offset060)
  6719. #define HW_OCOTP_ROM_PATCH7 (IMXRT_OCOTP_VALUE2.offset070)
  6720. #define HW_OCOTP_GP30 (IMXRT_OCOTP_VALUE2.offset080)
  6721. #define HW_OCOTP_GP31 (IMXRT_OCOTP_VALUE2.offset090)
  6722. #define HW_OCOTP_GP32 (IMXRT_OCOTP_VALUE2.offset0A0)
  6723. #define HW_OCOTP_GP33 (IMXRT_OCOTP_VALUE2.offset0B0)
  6724. #define HW_OCOTP_GP40 (IMXRT_OCOTP_VALUE2.offset0C0)
  6725. #define HW_OCOTP_GP41 (IMXRT_OCOTP_VALUE2.offset0D0)
  6726. #define HW_OCOTP_GP42 (IMXRT_OCOTP_VALUE2.offset0E0)
  6727. #define HW_OCOTP_GP43 (IMXRT_OCOTP_VALUE2.offset0F0)
  6728. #endif
  6729. // 44.8.1: page 2583
  6730. #define IMXRT_PIT (*(IMXRT_REGISTER32_t *)0x40084000)
  6731. #define PIT_MCR (IMXRT_PIT.offset000)
  6732. #define PIT_LTMR64H (IMXRT_PIT.offset0E0)
  6733. #define PIT_LTMR64L (IMXRT_PIT.offset0E4)
  6734. typedef struct {
  6735. volatile uint32_t LDVAL;
  6736. volatile uint32_t CVAL;
  6737. volatile uint32_t TCTRL;
  6738. volatile uint32_t TFLG;
  6739. } IMXRT_PIT_CHANNEL_t;
  6740. #define IMXRT_PIT_CHANNELS ((IMXRT_PIT_CHANNEL_t *)(&(IMXRT_PIT.offset100)))
  6741. #define PIT_LDVAL0 (IMXRT_PIT.offset100)
  6742. #define PIT_CVAL0 (IMXRT_PIT.offset104)
  6743. #define PIT_TCTRL0 (IMXRT_PIT.offset108)
  6744. #define PIT_TFLG0 (IMXRT_PIT.offset10C)
  6745. #define PIT_LDVAL1 (IMXRT_PIT.offset110)
  6746. #define PIT_CVAL1 (IMXRT_PIT.offset114)
  6747. #define PIT_TCTRL1 (IMXRT_PIT.offset118)
  6748. #define PIT_TFLG1 (IMXRT_PIT.offset11C)
  6749. #define PIT_LDVAL2 (IMXRT_PIT.offset120)
  6750. #define PIT_CVAL2 (IMXRT_PIT.offset124)
  6751. #define PIT_TCTRL2 (IMXRT_PIT.offset128)
  6752. #define PIT_TFLG2 (IMXRT_PIT.offset12C)
  6753. #define PIT_LDVAL3 (IMXRT_PIT.offset130)
  6754. #define PIT_CVAL3 (IMXRT_PIT.offset134)
  6755. #define PIT_TCTRL3 (IMXRT_PIT.offset138)
  6756. #define PIT_TFLG3 (IMXRT_PIT.offset13C)
  6757. #define PIT_MCR_MDIS ((uint32_t)(1<<1))
  6758. #define PIT_MCR_FRZ ((uint32_t)(1<<0))
  6759. #define PIT_TCTRL_CHN ((uint32_t)(1<<2))
  6760. #define PIT_TCTRL_TIE ((uint32_t)(1<<1))
  6761. #define PIT_TCTRL_TEN ((uint32_t)(1<<0))
  6762. #define PIT_TFLG_TIF ((uint32_t)(1<<0))
  6763. // 45.7: page 2598
  6764. #define IMXRT_PMU (*(IMXRT_REGISTER32_t *)0x400D8000)
  6765. #define PMU_REG_1P1 (IMXRT_PMU.offset110)
  6766. #define PMU_REG_1P1_SET (IMXRT_PMU.offset114)
  6767. #define PMU_REG_1P1_CLR (IMXRT_PMU.offset118)
  6768. #define PMU_REG_1P1_TOG (IMXRT_PMU.offset11C)
  6769. #define PMU_REG_3P0 (IMXRT_PMU.offset120)
  6770. #define PMU_REG_3P0_SET (IMXRT_PMU.offset124)
  6771. #define PMU_REG_3P0_CLR (IMXRT_PMU.offset128)
  6772. #define PMU_REG_3P0_TOG (IMXRT_PMU.offset12C)
  6773. #define PMU_REG_2P5 (IMXRT_PMU.offset130)
  6774. #define PMU_REG_2P5_SET (IMXRT_PMU.offset134)
  6775. #define PMU_REG_2P5_CLR (IMXRT_PMU.offset138)
  6776. #define PMU_REG_2P5_TOG (IMXRT_PMU.offset13C)
  6777. #define PMU_REG_CORE (IMXRT_PMU.offset140)
  6778. #define PMU_REG_CORE_SET (IMXRT_PMU.offset144)
  6779. #define PMU_REG_CORE_CLR (IMXRT_PMU.offset148)
  6780. #define PMU_REG_CORE_TOG (IMXRT_PMU.offset14C)
  6781. #define PMU_MISC0 (IMXRT_PMU.offset150)
  6782. #define PMU_MISC0_SET (IMXRT_PMU.offset154)
  6783. #define PMU_MISC0_CLR (IMXRT_PMU.offset158)
  6784. #define PMU_MISC0_TOG (IMXRT_PMU.offset15C)
  6785. #define PMU_MISC1 (IMXRT_PMU.offset160)
  6786. #define PMU_MISC1_SET (IMXRT_PMU.offset164)
  6787. #define PMU_MISC1_CLR (IMXRT_PMU.offset168)
  6788. #define PMU_MISC1_TOG (IMXRT_PMU.offset16C)
  6789. #define PMU_MISC2 (IMXRT_PMU.offset170)
  6790. #define PMU_MISC2_SET (IMXRT_PMU.offset174)
  6791. #define PMU_MISC2_CLR (IMXRT_PMU.offset178)
  6792. #define PMU_MISC2_TOG (IMXRT_PMU.offset17C)
  6793. #define PMU_REG_1P1_SELREF_WEAK_LINREG ((uint32_t)(1<<19))
  6794. #define PMU_REG_1P1_ENABLE_WEAK_LINREG ((uint32_t)(1<<18))
  6795. #define PMU_REG_1P1_OK_VDD1P1 ((uint32_t)(1<<17))
  6796. #define PMU_REG_1P1_BO_VDD1P1 ((uint32_t)(1<<16))
  6797. #define PMU_REG_1P1_OUTPUT_TRG(n) ((uint32_t)(((n) & 0x0F) << 8))
  6798. #define PMU_REG_1P1_BO_OFFSET(n) ((uint32_t)(((n) & 0x07) << 4))
  6799. #define PMU_REG_1P1_ENABLE_PULLDOWN ((uint32_t)(1<<3))
  6800. #define PMU_REG_1P1_ENABLE_ILIMIT ((uint32_t)(1<<2))
  6801. #define PMU_REG_1P1_ENABLE_BO ((uint32_t)(1<<1))
  6802. #define PMU_REG_1P1_ENABLE_LINREG ((uint32_t)(1<<0))
  6803. #define PMU_REG_3P0_OK_VDD3P0 ((uint32_t)(1<<17))
  6804. #define PMU_REG_3P0_BO_VDD3P0 ((uint32_t)(1<<16))
  6805. #define PMU_REG_3P0_OUTPUT_TRG(n) ((uint32_t)(((n) & 0x1F) << 8))
  6806. #define PMU_REG_3P0_VBUS_SEL ((uint32_t)(1<<7))
  6807. #define PMU_REG_3P0_BO_OFFSET(n) ((uint32_t)(((n) & 0x07) << 4))
  6808. #define PMU_REG_3P0_ENABLE_ILIMIT ((uint32_t)(1<<2))
  6809. #define PMU_REG_3P0_ENABLE_BO ((uint32_t)(1<<1))
  6810. #define PMU_REG_3P0_ENABLE_LINREG ((uint32_t)(1<<0))
  6811. #define PMU_REG_2P5_ENABLE_WEAK_LINREG ((uint32_t)(1<<18))
  6812. #define PMU_REG_2P5_OK_VDD2P5 ((uint32_t)(1<<17))
  6813. #define PMU_REG_2P5_BO_VDD2P5 ((uint32_t)(1<<16))
  6814. #define PMU_REG_2P5_OUTPUT_TRG(n) ((uint32_t)(((n) & 0x0F) << 8))
  6815. #define PMU_REG_2P5_BO_OFFSET(n) ((uint32_t)(((n) & 0x07) << 4))
  6816. #define PMU_REG_2P5_ENABLE_PULLDOWN ((uint32_t)(1<<3))
  6817. #define PMU_REG_2P5_ENABLE_ILIMIT ((uint32_t)(1<<2))
  6818. #define PMU_REG_2P5_ENABLE_BO ((uint32_t)(1<<1))
  6819. #define PMU_REG_2P5_ENABLE_LINREG ((uint32_t)(1<<0))
  6820. #define PMU_REG_CORE_FET_ODRIVE ((uint32_t)(1<<29))
  6821. #define PMU_REG_CORE_RAMP_RATE(n) ((uint32_t)(((n) & 0x03) << 27))
  6822. #define PMU_REG_CORE_REG2_ADJ(n) ((uint32_t)(((n) & 0x0F) << 23))
  6823. #define PMU_REG_CORE_REG2_TARG(n) ((uint32_t)(((n) & 0x1F) << 18))
  6824. #define PMU_REG_CORE_REG1_ADJ(n) ((uint32_t)(((n) & 0x0F) << 14))
  6825. #define PMU_REG_CORE_REG1_TARG(n) ((uint32_t)(((n) & 0x1F) << 9))
  6826. #define PMU_REG_CORE_REG0_ADJ(n) ((uint32_t)(((n) & 0x0F) << 5))
  6827. #define PMU_REG_CORE_REG0_TARG(n) ((uint32_t)(((n) & 0x1F) << 0))
  6828. #define PMU_MISC0_VID_PLL_PREDIV ((uint32_t)(1<<31))
  6829. #define PMU_MISC0_XTAL_24M_PWD ((uint32_t)(1<<30))
  6830. #define PMU_MISC0_RTC_XTAL_SOURCE ((uint32_t)(1<<29))
  6831. #define PMU_MISC0_CLKGATE_DELAY(n) ((uint32_t)(((n) & 0x07) << 26))
  6832. #define PMU_MISC0_CLKGATE_CTRL ((uint32_t)(1<<25))
  6833. #define PMU_MISC0_OSC_XTALOK_EN ((uint32_t)(1<<16))
  6834. #define PMU_MISC0_OSC_XTALOK ((uint32_t)(1<<15))
  6835. #define PMU_MISC0_OSC_I(n) ((uint32_t)(((n) & 0x03) << 13))
  6836. #define PMU_MISC0_DISCON_HIGH_SNVS ((uint32_t)(1<<12))
  6837. #define PMU_MISC0_STOP_MODE_CONFIG(n) ((uint32_t)(((n) & 0x03) << 10))
  6838. #define PMU_MISC0_REFTOP_VBGUP ((uint32_t)(1<<7))
  6839. #define PMU_MISC0_REFTOP_VBGADJ(n) ((uint32_t)(((n) & 0x07) << 4))
  6840. #define PMU_MISC0_REFTOP_SELFBIASOFF ((uint32_t)(1<<3))
  6841. #define PMU_MISC0_REFTOP_PWD ((uint32_t)(1<<0))
  6842. #define PMU_MISC1_IRQ_DIG_BO ((uint32_t)(1<<31))
  6843. #define PMU_MISC1_IRQ_ANA_BO ((uint32_t)(1<<30))
  6844. #define PMU_MISC1_IRQ_TEMPHIGH ((uint32_t)(1<<29))
  6845. #define PMU_MISC1_IRQ_TEMPLOW ((uint32_t)(1<<28))
  6846. #define PMU_MISC1_IRQ_TEMPPANIC ((uint32_t)(1<<27))
  6847. #define PMU_MISC1_PFD_528_AUTOGATE_EN ((uint32_t)(1<<17))
  6848. #define PMU_MISC1_PFD_480_AUTOGATE_EN ((uint32_t)(1<<16))
  6849. #define PMU_MISC1_LVDSCLK2_IBEN ((uint32_t)(1<<13))
  6850. #define PMU_MISC1_LVDSCLK1_IBEN ((uint32_t)(1<<12))
  6851. #define PMU_MISC1_LVDSCLK2_OBEN ((uint32_t)(1<<11))
  6852. #define PMU_MISC1_LVDSCLK1_OBEN ((uint32_t)(1<<10))
  6853. #define PMU_MISC1_LVDS2_CLK_SEL(n) ((uint32_t)(((n) & 0x1F) << 5))
  6854. #define PMU_MISC1_LVDS1_CLK_SEL(n) ((uint32_t)(((n) & 0x1F) << 0))
  6855. #define PMU_MISC2_VIDEO_DIV(n) ((uint32_t)(((n) & 0x03) << 30))
  6856. #define PMU_MISC2_REG2_STEP_TIME(n) ((uint32_t)(((n) & 0x03) << 28))
  6857. #define PMU_MISC2_REG1_STEP_TIME(n) ((uint32_t)(((n) & 0x03) << 26))
  6858. #define PMU_MISC2_REG0_STEP_TIME(n) ((uint32_t)(((n) & 0x03) << 24))
  6859. #define PMU_MISC2_AUDIO_DIV_MSB ((uint32_t)(1<<23))
  6860. #define PMU_MISC2_REG2_OK ((uint32_t)(1<<22))
  6861. #define PMU_MISC2_REG2_ENABLE_BO ((uint32_t)(1<<21))
  6862. #define PMU_MISC2_REG2_BO_STATUS ((uint32_t)(1<<19))
  6863. #define PMU_MISC2_REG2_BO_OFFSET(n) ((uint32_t)(((n) & 0x07) << 16))
  6864. #define PMU_MISC2_AUDIO_DIV_LSB ((uint32_t)(1<<15))
  6865. #define PMU_MISC2_REG1_ENABLE_BO ((uint32_t)(1<<13))
  6866. #define PMU_MISC2_REG1_BO_STATUS ((uint32_t)(1<<11))
  6867. #define PMU_MISC2_REG1_BO_OFFSET(n) ((uint32_t)(((n) & 0x07) << 8))
  6868. #define PMU_MISC2_PLL3_DISABLE ((uint32_t)(1<<7))
  6869. #define PMU_MISC2_REG0_ENABLE_BO ((uint32_t)(1<<5))
  6870. #define PMU_MISC2_REG0_BO_STATUS ((uint32_t)(1<<3))
  6871. #define PMU_MISC2_REG0_BO_OFFSET(n) ((uint32_t)(((n) & 0x07) << 0))
  6872. // 46.7: page 2656
  6873. #define IMXRT_PXP (*(IMXRT_REGISTER32_t *)0x402B4000)
  6874. #define IMXRT_PXP_b (*(IMXRT_REGISTER32_t *)0x402B4400)
  6875. #define PXP_CTRL (IMXRT_PXP.offset000)
  6876. #define PXP_CTRL_SET (IMXRT_PXP.offset004)
  6877. #define PXP_CTRL_CLR (IMXRT_PXP.offset008)
  6878. #define PXP_CTRL_TOG (IMXRT_PXP.offset00C)
  6879. #define PXP_STAT (IMXRT_PXP.offset010)
  6880. #define PXP_STAT_SET (IMXRT_PXP.offset014)
  6881. #define PXP_STAT_CLR (IMXRT_PXP.offset018)
  6882. #define PXP_STAT_TOG (IMXRT_PXP.offset01C)
  6883. #define PXP_OUT_CTRL (IMXRT_PXP.offset020)
  6884. #define PXP_OUT_CTRL_SET (IMXRT_PXP.offset024)
  6885. #define PXP_OUT_CTRL_CLR (IMXRT_PXP.offset028)
  6886. #define PXP_OUT_CTRL_TOG (IMXRT_PXP.offset02C)
  6887. #define PXP_OUT_BUF (IMXRT_PXP.offset030)
  6888. #define PXP_OUT_BUF2 (IMXRT_PXP.offset040)
  6889. #define PXP_OUT_PITCH (IMXRT_PXP.offset050)
  6890. #define PXP_OUT_LRC (IMXRT_PXP.offset060)
  6891. #define PXP_OUT_PS_ULC (IMXRT_PXP.offset070)
  6892. #define PXP_OUT_PS_LRC (IMXRT_PXP.offset080)
  6893. #define PXP_OUT_AS_ULC (IMXRT_PXP.offset090)
  6894. #define PXP_OUT_AS_LRC (IMXRT_PXP.offset0A0)
  6895. #define PXP_PS_CTRL (IMXRT_PXP.offset0B0)
  6896. #define PXP_PS_CTRL_SET (IMXRT_PXP.offset0B4)
  6897. #define PXP_PS_CTRL_CLR (IMXRT_PXP.offset0B8)
  6898. #define PXP_PS_CTRL_TOG (IMXRT_PXP.offset0BC)
  6899. #define PXP_PS_BUF (IMXRT_PXP.offset0C0)
  6900. #define PXP_PS_UBUF (IMXRT_PXP.offset0D0)
  6901. #define PXP_PS_VBUF (IMXRT_PXP.offset0E0)
  6902. #define PXP_PS_PITCH (IMXRT_PXP.offset0F0)
  6903. #define PXP_PS_BACKGROUND_0 (IMXRT_PXP.offset100)
  6904. #define PXP_PS_SCALE (IMXRT_PXP.offset110)
  6905. #define PXP_PS_OFFSET (IMXRT_PXP.offset120)
  6906. #define PXP_PS_CLRKEYLOW_0 (IMXRT_PXP.offset130)
  6907. #define PXP_PS_CLRKEYHIGH_0 (IMXRT_PXP.offset140)
  6908. #define PXP_AS_CTRL (IMXRT_PXP.offset150)
  6909. #define PXP_AS_BUF (IMXRT_PXP.offset160)
  6910. #define PXP_AS_PITCH (IMXRT_PXP.offset170)
  6911. #define PXP_AS_CLRKEYLOW_0 (IMXRT_PXP.offset180)
  6912. #define PXP_AS_CLRKEYHIGH_0 (IMXRT_PXP.offset190)
  6913. #define PXP_CSC1_COEF0 (IMXRT_PXP.offset1A0)
  6914. #define PXP_CSC1_COEF1 (IMXRT_PXP.offset1B0)
  6915. #define PXP_CSC1_COEF2 (IMXRT_PXP.offset1C0)
  6916. #define PXP_POWER (IMXRT_PXP_b.offset000)
  6917. #define PXP_PORTER_DUFF_CTRL (IMXRT_PXP_b.offset040)
  6918. // 47.5: page 2695
  6919. typedef struct {
  6920. union {
  6921. struct {
  6922. volatile uint16_t COMP1;
  6923. volatile uint16_t COMP2;
  6924. volatile uint16_t CAPT;
  6925. volatile uint16_t LOAD;
  6926. volatile uint16_t HOLD;
  6927. volatile uint16_t CNTR;
  6928. volatile uint16_t CTRL;
  6929. volatile uint16_t SCTRL;
  6930. volatile uint16_t CMPLD1;
  6931. volatile uint16_t CMPLD2;
  6932. volatile uint16_t CSCTRL;
  6933. volatile uint16_t FILT;
  6934. volatile uint16_t DMA;
  6935. volatile uint16_t unused1[3];
  6936. } CH[4];
  6937. struct {
  6938. volatile uint16_t unused2[15];
  6939. volatile uint16_t ENBL;
  6940. };
  6941. };
  6942. } IMXRT_TMR_t;
  6943. #define IMXRT_TMR1 (*(IMXRT_TMR_t *)0x401DC000)
  6944. #define TMR1_COMP10 (IMXRT_TMR1.CH[0].COMP1)
  6945. #define TMR1_COMP20 (IMXRT_TMR1.CH[0].COMP2)
  6946. #define TMR1_CAPT0 (IMXRT_TMR1.CH[0].CAPT)
  6947. #define TMR1_LOAD0 (IMXRT_TMR1.CH[0].LOAD)
  6948. #define TMR1_HOLD0 (IMXRT_TMR1.CH[0].HOLD)
  6949. #define TMR1_CNTR0 (IMXRT_TMR1.CH[0].CNTR)
  6950. #define TMR1_CTRL0 (IMXRT_TMR1.CH[0].CTRL)
  6951. #define TMR1_SCTRL0 (IMXRT_TMR1.CH[0].SCTRL)
  6952. #define TMR1_CMPLD10 (IMXRT_TMR1.CH[0].CMPLD1)
  6953. #define TMR1_CMPLD20 (IMXRT_TMR1.CH[0].CMPLD2)
  6954. #define TMR1_CSCTRL0 (IMXRT_TMR1.CH[0].CSCTRL)
  6955. #define TMR1_FILT0 (IMXRT_TMR1.CH[0].FILT)
  6956. #define TMR1_DMA0 (IMXRT_TMR1.CH[0].DMA)
  6957. #define TMR1_ENBL (IMXRT_TMR1.ENBL)
  6958. #define TMR1_COMP11 (IMXRT_TMR1.CH[1].COMP1)
  6959. #define TMR1_COMP21 (IMXRT_TMR1.CH[1].COMP2)
  6960. #define TMR1_CAPT1 (IMXRT_TMR1.CH[1].CAPT)
  6961. #define TMR1_LOAD1 (IMXRT_TMR1.CH[1].LOAD)
  6962. #define TMR1_HOLD1 (IMXRT_TMR1.CH[1].HOLD)
  6963. #define TMR1_CNTR1 (IMXRT_TMR1.CH[1].CNTR)
  6964. #define TMR1_CTRL1 (IMXRT_TMR1.CH[1].CTRL)
  6965. #define TMR1_SCTRL1 (IMXRT_TMR1.CH[1].SCTRL)
  6966. #define TMR1_CMPLD11 (IMXRT_TMR1.CH[1].CMPLD1)
  6967. #define TMR1_CMPLD21 (IMXRT_TMR1.CH[1].CMPLD2)
  6968. #define TMR1_CSCTRL1 (IMXRT_TMR1.CH[1].CSCTRL)
  6969. #define TMR1_FILT1 (IMXRT_TMR1.CH[1].FILT)
  6970. #define TMR1_DMA1 (IMXRT_TMR1.CH[1].DMA)
  6971. #define TMR1_COMP12 (IMXRT_TMR1.CH[2].COMP1)
  6972. #define TMR1_COMP22 (IMXRT_TMR1.CH[2].COMP2)
  6973. #define TMR1_CAPT2 (IMXRT_TMR1.CH[2].CAPT)
  6974. #define TMR1_LOAD2 (IMXRT_TMR1.CH[2].LOAD)
  6975. #define TMR1_HOLD2 (IMXRT_TMR1.CH[2].HOLD)
  6976. #define TMR1_CNTR2 (IMXRT_TMR1.CH[2].CNTR)
  6977. #define TMR1_CTRL2 (IMXRT_TMR1.CH[2].CTRL)
  6978. #define TMR1_SCTRL2 (IMXRT_TMR1.CH[2].SCTRL)
  6979. #define TMR1_CMPLD12 (IMXRT_TMR1.CH[2].CMPLD1)
  6980. #define TMR1_CMPLD22 (IMXRT_TMR1.CH[2].CMPLD2)
  6981. #define TMR1_CSCTRL2 (IMXRT_TMR1.CH[2].CSCTRL)
  6982. #define TMR1_FILT2 (IMXRT_TMR1.CH[2].FILT)
  6983. #define TMR1_DMA2 (IMXRT_TMR1.CH[2].DMA)
  6984. #define TMR1_COMP13 (IMXRT_TMR1.CH[3].COMP1)
  6985. #define TMR1_COMP23 (IMXRT_TMR1.CH[3].COMP2)
  6986. #define TMR1_CAPT3 (IMXRT_TMR1.CH[3].CAPT)
  6987. #define TMR1_LOAD3 (IMXRT_TMR1.CH[3].LOAD)
  6988. #define TMR1_HOLD3 (IMXRT_TMR1.CH[3].HOLD)
  6989. #define TMR1_CNTR3 (IMXRT_TMR1.CH[3].CNTR)
  6990. #define TMR1_CTRL3 (IMXRT_TMR1.CH[3].CTRL)
  6991. #define TMR1_SCTRL3 (IMXRT_TMR1.CH[3].SCTRL)
  6992. #define TMR1_CMPLD13 (IMXRT_TMR1.CH[3].CMPLD1)
  6993. #define TMR1_CMPLD23 (IMXRT_TMR1.CH[3].CMPLD2)
  6994. #define TMR1_CSCTRL3 (IMXRT_TMR1.CH[3].CSCTRL)
  6995. #define TMR1_FILT3 (IMXRT_TMR1.CH[3].FILT)
  6996. #define TMR1_DMA3 (IMXRT_TMR1.CH[3].DMA)
  6997. #define IMXRT_TMR2 (*(IMXRT_TMR_t *)0x401E0000)
  6998. #define TMR2_COMP10 (IMXRT_TMR2.CH[0].COMP1)
  6999. #define TMR2_COMP20 (IMXRT_TMR2.CH[0].COMP2)
  7000. #define TMR2_CAPT0 (IMXRT_TMR2.CH[0].CAPT)
  7001. #define TMR2_LOAD0 (IMXRT_TMR2.CH[0].LOAD)
  7002. #define TMR2_HOLD0 (IMXRT_TMR2.CH[0].HOLD)
  7003. #define TMR2_CNTR0 (IMXRT_TMR2.CH[0].CNTR)
  7004. #define TMR2_CTRL0 (IMXRT_TMR2.CH[0].CTRL)
  7005. #define TMR2_SCTRL0 (IMXRT_TMR2.CH[0].SCTRL)
  7006. #define TMR2_CMPLD10 (IMXRT_TMR2.CH[0].CMPLD1)
  7007. #define TMR2_CMPLD20 (IMXRT_TMR2.CH[0].CMPLD2)
  7008. #define TMR2_CSCTRL0 (IMXRT_TMR2.CH[0].CSCTRL)
  7009. #define TMR2_FILT0 (IMXRT_TMR2.CH[0].FILT)
  7010. #define TMR2_DMA0 (IMXRT_TMR2.CH[0].DMA)
  7011. #define TMR2_ENBL (IMXRT_TMR2.ENBL)
  7012. #define TMR2_COMP11 (IMXRT_TMR2.CH[1].COMP1)
  7013. #define TMR2_COMP21 (IMXRT_TMR2.CH[1].COMP2)
  7014. #define TMR2_CAPT1 (IMXRT_TMR2.CH[1].CAPT)
  7015. #define TMR2_LOAD1 (IMXRT_TMR2.CH[1].LOAD)
  7016. #define TMR2_HOLD1 (IMXRT_TMR2.CH[1].HOLD)
  7017. #define TMR2_CNTR1 (IMXRT_TMR2.CH[1].CNTR)
  7018. #define TMR2_CTRL1 (IMXRT_TMR2.CH[1].CTRL)
  7019. #define TMR2_SCTRL1 (IMXRT_TMR2.CH[1].SCTRL)
  7020. #define TMR2_CMPLD11 (IMXRT_TMR2.CH[1].CMPLD1)
  7021. #define TMR2_CMPLD21 (IMXRT_TMR2.CH[1].CMPLD2)
  7022. #define TMR2_CSCTRL1 (IMXRT_TMR2.CH[1].CSCTRL)
  7023. #define TMR2_FILT1 (IMXRT_TMR2.CH[1].FILT)
  7024. #define TMR2_DMA1 (IMXRT_TMR2.CH[1].DMA)
  7025. #define TMR2_COMP12 (IMXRT_TMR2.CH[2].COMP1)
  7026. #define TMR2_COMP22 (IMXRT_TMR2.CH[2].COMP2)
  7027. #define TMR2_CAPT2 (IMXRT_TMR2.CH[2].CAPT)
  7028. #define TMR2_LOAD2 (IMXRT_TMR2.CH[2].LOAD)
  7029. #define TMR2_HOLD2 (IMXRT_TMR2.CH[2].HOLD)
  7030. #define TMR2_CNTR2 (IMXRT_TMR2.CH[2].CNTR)
  7031. #define TMR2_CTRL2 (IMXRT_TMR2.CH[2].CTRL)
  7032. #define TMR2_SCTRL2 (IMXRT_TMR2.CH[2].SCTRL)
  7033. #define TMR2_CMPLD12 (IMXRT_TMR2.CH[2].CMPLD1)
  7034. #define TMR2_CMPLD22 (IMXRT_TMR2.CH[2].CMPLD2)
  7035. #define TMR2_CSCTRL2 (IMXRT_TMR2.CH[2].CSCTRL)
  7036. #define TMR2_FILT2 (IMXRT_TMR2.CH[2].FILT)
  7037. #define TMR2_DMA2 (IMXRT_TMR2.CH[2].DMA)
  7038. #define TMR2_COMP13 (IMXRT_TMR2.CH[3].COMP1)
  7039. #define TMR2_COMP23 (IMXRT_TMR2.CH[3].COMP2)
  7040. #define TMR2_CAPT3 (IMXRT_TMR2.CH[3].CAPT)
  7041. #define TMR2_LOAD3 (IMXRT_TMR2.CH[3].LOAD)
  7042. #define TMR2_HOLD3 (IMXRT_TMR2.CH[3].HOLD)
  7043. #define TMR2_CNTR3 (IMXRT_TMR2.CH[3].CNTR)
  7044. #define TMR2_CTRL3 (IMXRT_TMR2.CH[3].CTRL)
  7045. #define TMR2_SCTRL3 (IMXRT_TMR2.CH[3].SCTRL)
  7046. #define TMR2_CMPLD13 (IMXRT_TMR2.CH[3].CMPLD1)
  7047. #define TMR2_CMPLD23 (IMXRT_TMR2.CH[3].CMPLD2)
  7048. #define TMR2_CSCTRL3 (IMXRT_TMR2.CH[3].CSCTRL)
  7049. #define TMR2_FILT3 (IMXRT_TMR2.CH[3].FILT)
  7050. #define TMR2_DMA3 (IMXRT_TMR2.CH[3].DMA)
  7051. #define IMXRT_TMR3 (*(IMXRT_TMR_t *)0x401E4000)
  7052. #define TMR3_COMP10 (IMXRT_TMR3.CH[0].COMP1)
  7053. #define TMR3_COMP20 (IMXRT_TMR3.CH[0].COMP2)
  7054. #define TMR3_CAPT0 (IMXRT_TMR3.CH[0].CAPT)
  7055. #define TMR3_LOAD0 (IMXRT_TMR3.CH[0].LOAD)
  7056. #define TMR3_HOLD0 (IMXRT_TMR3.CH[0].HOLD)
  7057. #define TMR3_CNTR0 (IMXRT_TMR3.CH[0].CNTR)
  7058. #define TMR3_CTRL0 (IMXRT_TMR3.CH[0].CTRL)
  7059. #define TMR3_SCTRL0 (IMXRT_TMR3.CH[0].SCTRL)
  7060. #define TMR3_CMPLD10 (IMXRT_TMR3.CH[0].CMPLD1)
  7061. #define TMR3_CMPLD20 (IMXRT_TMR3.CH[0].CMPLD2)
  7062. #define TMR3_CSCTRL0 (IMXRT_TMR3.CH[0].CSCTRL)
  7063. #define TMR3_FILT0 (IMXRT_TMR3.CH[0].FILT)
  7064. #define TMR3_DMA0 (IMXRT_TMR3.CH[0].DMA)
  7065. #define TMR3_ENBL (IMXRT_TMR3.ENBL)
  7066. #define TMR3_COMP11 (IMXRT_TMR3.CH[1].COMP1)
  7067. #define TMR3_COMP21 (IMXRT_TMR3.CH[1].COMP2)
  7068. #define TMR3_CAPT1 (IMXRT_TMR3.CH[1].CAPT)
  7069. #define TMR3_LOAD1 (IMXRT_TMR3.CH[1].LOAD)
  7070. #define TMR3_HOLD1 (IMXRT_TMR3.CH[1].HOLD)
  7071. #define TMR3_CNTR1 (IMXRT_TMR3.CH[1].CNTR)
  7072. #define TMR3_CTRL1 (IMXRT_TMR3.CH[1].CTRL)
  7073. #define TMR3_SCTRL1 (IMXRT_TMR3.CH[1].SCTRL)
  7074. #define TMR3_CMPLD11 (IMXRT_TMR3.CH[1].CMPLD1)
  7075. #define TMR3_CMPLD21 (IMXRT_TMR3.CH[1].CMPLD2)
  7076. #define TMR3_CSCTRL1 (IMXRT_TMR3.CH[1].CSCTRL)
  7077. #define TMR3_FILT1 (IMXRT_TMR3.CH[1].FILT)
  7078. #define TMR3_DMA1 (IMXRT_TMR3.CH[1].DMA)
  7079. #define TMR3_COMP12 (IMXRT_TMR3.CH[2].COMP1)
  7080. #define TMR3_COMP22 (IMXRT_TMR3.CH[2].COMP2)
  7081. #define TMR3_CAPT2 (IMXRT_TMR3.CH[2].CAPT)
  7082. #define TMR3_LOAD2 (IMXRT_TMR3.CH[2].LOAD)
  7083. #define TMR3_HOLD2 (IMXRT_TMR3.CH[2].HOLD)
  7084. #define TMR3_CNTR2 (IMXRT_TMR3.CH[2].CNTR)
  7085. #define TMR3_CTRL2 (IMXRT_TMR3.CH[2].CTRL)
  7086. #define TMR3_SCTRL2 (IMXRT_TMR3.CH[2].SCTRL)
  7087. #define TMR3_CMPLD12 (IMXRT_TMR3.CH[2].CMPLD1)
  7088. #define TMR3_CMPLD22 (IMXRT_TMR3.CH[2].CMPLD2)
  7089. #define TMR3_CSCTRL2 (IMXRT_TMR3.CH[2].CSCTRL)
  7090. #define TMR3_FILT2 (IMXRT_TMR3.CH[2].FILT)
  7091. #define TMR3_DMA2 (IMXRT_TMR3.CH[2].DMA)
  7092. #define TMR3_COMP13 (IMXRT_TMR3.CH[3].COMP1)
  7093. #define TMR3_COMP23 (IMXRT_TMR3.CH[3].COMP2)
  7094. #define TMR3_CAPT3 (IMXRT_TMR3.CH[3].CAPT)
  7095. #define TMR3_LOAD3 (IMXRT_TMR3.CH[3].LOAD)
  7096. #define TMR3_HOLD3 (IMXRT_TMR3.CH[3].HOLD)
  7097. #define TMR3_CNTR3 (IMXRT_TMR3.CH[3].CNTR)
  7098. #define TMR3_CTRL3 (IMXRT_TMR3.CH[3].CTRL)
  7099. #define TMR3_SCTRL3 (IMXRT_TMR3.CH[3].SCTRL)
  7100. #define TMR3_CMPLD13 (IMXRT_TMR3.CH[3].CMPLD1)
  7101. #define TMR3_CMPLD23 (IMXRT_TMR3.CH[3].CMPLD2)
  7102. #define TMR3_CSCTRL3 (IMXRT_TMR3.CH[3].CSCTRL)
  7103. #define TMR3_FILT3 (IMXRT_TMR3.CH[3].FILT)
  7104. #define TMR3_DMA3 (IMXRT_TMR3.CH[3].DMA)
  7105. #define IMXRT_TMR4 (*(IMXRT_TMR_t *)0x401E8000)
  7106. #define TMR4_COMP10 (IMXRT_TMR4.CH[0].COMP1)
  7107. #define TMR4_COMP20 (IMXRT_TMR4.CH[0].COMP2)
  7108. #define TMR4_CAPT0 (IMXRT_TMR4.CH[0].CAPT)
  7109. #define TMR4_LOAD0 (IMXRT_TMR4.CH[0].LOAD)
  7110. #define TMR4_HOLD0 (IMXRT_TMR4.CH[0].HOLD)
  7111. #define TMR4_CNTR0 (IMXRT_TMR4.CH[0].CNTR)
  7112. #define TMR4_CTRL0 (IMXRT_TMR4.CH[0].CTRL)
  7113. #define TMR4_SCTRL0 (IMXRT_TMR4.CH[0].SCTRL)
  7114. #define TMR4_CMPLD10 (IMXRT_TMR4.CH[0].CMPLD1)
  7115. #define TMR4_CMPLD20 (IMXRT_TMR4.CH[0].CMPLD2)
  7116. #define TMR4_CSCTRL0 (IMXRT_TMR4.CH[0].CSCTRL)
  7117. #define TMR4_FILT0 (IMXRT_TMR4.CH[0].FILT)
  7118. #define TMR4_DMA0 (IMXRT_TMR4.CH[0].DMA)
  7119. #define TMR4_ENBL (IMXRT_TMR4.ENBL)
  7120. #define TMR4_COMP11 (IMXRT_TMR4.CH[1].COMP1)
  7121. #define TMR4_COMP21 (IMXRT_TMR4.CH[1].COMP2)
  7122. #define TMR4_CAPT1 (IMXRT_TMR4.CH[1].CAPT)
  7123. #define TMR4_LOAD1 (IMXRT_TMR4.CH[1].LOAD)
  7124. #define TMR4_HOLD1 (IMXRT_TMR4.CH[1].HOLD)
  7125. #define TMR4_CNTR1 (IMXRT_TMR4.CH[1].CNTR)
  7126. #define TMR4_CTRL1 (IMXRT_TMR4.CH[1].CTRL)
  7127. #define TMR4_SCTRL1 (IMXRT_TMR4.CH[1].SCTRL)
  7128. #define TMR4_CMPLD11 (IMXRT_TMR4.CH[1].CMPLD1)
  7129. #define TMR4_CMPLD21 (IMXRT_TMR4.CH[1].CMPLD2)
  7130. #define TMR4_CSCTRL1 (IMXRT_TMR4.CH[1].CSCTRL)
  7131. #define TMR4_FILT1 (IMXRT_TMR4.CH[1].FILT)
  7132. #define TMR4_DMA1 (IMXRT_TMR4.CH[1].DMA)
  7133. #define TMR4_COMP12 (IMXRT_TMR4.CH[2].COMP1)
  7134. #define TMR4_COMP22 (IMXRT_TMR4.CH[2].COMP2)
  7135. #define TMR4_CAPT2 (IMXRT_TMR4.CH[2].CAPT)
  7136. #define TMR4_LOAD2 (IMXRT_TMR4.CH[2].LOAD)
  7137. #define TMR4_HOLD2 (IMXRT_TMR4.CH[2].HOLD)
  7138. #define TMR4_CNTR2 (IMXRT_TMR4.CH[2].CNTR)
  7139. #define TMR4_CTRL2 (IMXRT_TMR4.CH[2].CTRL)
  7140. #define TMR4_SCTRL2 (IMXRT_TMR4.CH[2].SCTRL)
  7141. #define TMR4_CMPLD12 (IMXRT_TMR4.CH[2].CMPLD1)
  7142. #define TMR4_CMPLD22 (IMXRT_TMR4.CH[2].CMPLD2)
  7143. #define TMR4_CSCTRL2 (IMXRT_TMR4.CH[2].CSCTRL)
  7144. #define TMR4_FILT2 (IMXRT_TMR4.CH[2].FILT)
  7145. #define TMR4_DMA2 (IMXRT_TMR4.CH[2].DMA)
  7146. #define TMR4_COMP13 (IMXRT_TMR4.CH[3].COMP1)
  7147. #define TMR4_COMP23 (IMXRT_TMR4.CH[3].COMP2)
  7148. #define TMR4_CAPT3 (IMXRT_TMR4.CH[3].CAPT)
  7149. #define TMR4_LOAD3 (IMXRT_TMR4.CH[3].LOAD)
  7150. #define TMR4_HOLD3 (IMXRT_TMR4.CH[3].HOLD)
  7151. #define TMR4_CNTR3 (IMXRT_TMR4.CH[3].CNTR)
  7152. #define TMR4_CTRL3 (IMXRT_TMR4.CH[3].CTRL)
  7153. #define TMR4_SCTRL3 (IMXRT_TMR4.CH[3].SCTRL)
  7154. #define TMR4_CMPLD13 (IMXRT_TMR4.CH[3].CMPLD1)
  7155. #define TMR4_CMPLD23 (IMXRT_TMR4.CH[3].CMPLD2)
  7156. #define TMR4_CSCTRL3 (IMXRT_TMR4.CH[3].CSCTRL)
  7157. #define TMR4_FILT3 (IMXRT_TMR4.CH[3].FILT)
  7158. #define TMR4_DMA3 (IMXRT_TMR4.CH[3].DMA)
  7159. #define TMR_CTRL_CM(n) ((uint16_t)(((n) & 0x07) << 13))
  7160. #define TMR_CTRL_PCS(n) ((uint16_t)(((n) & 0x0F) << 9))
  7161. #define TMR_CTRL_SCS(n) ((uint16_t)(((n) & 0x03) << 7))
  7162. #define TMR_CTRL_ONCE ((uint16_t)(1<<6))
  7163. #define TMR_CTRL_LENGTH ((uint16_t)(1<<5))
  7164. #define TMR_CTRL_DIR ((uint16_t)(1<<4))
  7165. #define TMR_CTRL_COINIT ((uint16_t)(1<<3))
  7166. #define TMR_CTRL_OUTMODE(n) ((uint16_t)(((n) & 0x07) << 0))
  7167. #define TMR_SCTRL_TCF ((uint16_t)(1<<15))
  7168. #define TMR_SCTRL_TCFIE ((uint16_t)(1<<14))
  7169. #define TMR_SCTRL_TOF ((uint16_t)(1<<13))
  7170. #define TMR_SCTRL_TOFIE ((uint16_t)(1<<12))
  7171. #define TMR_SCTRL_IEF ((uint16_t)(1<<11))
  7172. #define TMR_SCTRL_IEFIE ((uint16_t)(1<<10))
  7173. #define TMR_SCTRL_IPS ((uint16_t)(1<<9))
  7174. #define TMR_SCTRL_INPUT ((uint16_t)(1<<8))
  7175. #define TMR_SCTRL_CAPTURE_MODE(n) ((uint16_t)(((n) & 0x03) << 6))
  7176. #define TMR_SCTRL_MSTR ((uint16_t)(1<<5))
  7177. #define TMR_SCTRL_EEOF ((uint16_t)(1<<4))
  7178. #define TMR_SCTRL_VAL ((uint16_t)(1<<3))
  7179. #define TMR_SCTRL_FORCE ((uint16_t)(1<<2))
  7180. #define TMR_SCTRL_OPS ((uint16_t)(1<<1))
  7181. #define TMR_SCTRL_OEN ((uint16_t)(1<<0))
  7182. #define TMR_CSCTRL_DBG_EN(n) ((uint16_t)(((n) & 0x03) << 14))
  7183. #define TMR_CSCTRL_FAULT ((uint16_t)(1<<13))
  7184. #define TMR_CSCTRL_ALT_LOAD ((uint16_t)(1<<12))
  7185. #define TMR_CSCTRL_ROC ((uint16_t)(1<<11))
  7186. #define TMR_CSCTRL_TCI ((uint16_t)(1<<10))
  7187. #define TMR_CSCTRL_UP ((uint16_t)(1<<9))
  7188. #define TMR_CSCTRL_TCF2EN ((uint16_t)(1<<7))
  7189. #define TMR_CSCTRL_TCF1EN ((uint16_t)(1<<6))
  7190. #define TMR_CSCTRL_TCF2 ((uint16_t)(1<<5))
  7191. #define TMR_CSCTRL_TCF1 ((uint16_t)(1<<4))
  7192. #define TMR_CSCTRL_CL2(n) ((uint16_t)(((n) & 0x03) << 2))
  7193. #define TMR_CSCTRL_CL1(n) ((uint16_t)(((n) & 0x03) << 0))
  7194. #define TMR_FILT_FILT_CNT(n) ((uint16_t)(((n) & 0x07) << 8))
  7195. #define TMR_FILT_FILT_PER(n) ((uint16_t)(((n) & 0xFF) << 0))
  7196. #define TMR_DMA_CMPLD2DE ((uint16_t)(1<<2))
  7197. #define TMR_DMA_CMPLD1DE ((uint16_t)(1<<1))
  7198. #define TMR_DMA_IEFDE ((uint16_t)(1<<0))
  7199. // 48.4.1.1: page 2748
  7200. #define IMXRT_I2S1 (*(IMXRT_REGISTER32_t *)0x40384000)
  7201. #define I2S1_VERID (IMXRT_I2S1.offset000)
  7202. #define I2S1_PARAM (IMXRT_I2S1.offset004)
  7203. #define I2S1_TCSR (IMXRT_I2S1.offset008)
  7204. #define I2S1_TCR1 (IMXRT_I2S1.offset00C)
  7205. #define I2S1_TCR2 (IMXRT_I2S1.offset010)
  7206. #define I2S1_TCR3 (IMXRT_I2S1.offset014)
  7207. #define I2S1_TCR4 (IMXRT_I2S1.offset018)
  7208. #define I2S1_TCR5 (IMXRT_I2S1.offset01C)
  7209. #define I2S1_TDR0 (IMXRT_I2S1.offset020)
  7210. #define I2S1_TDR1 (IMXRT_I2S1.offset024)
  7211. #define I2S1_TDR2 (IMXRT_I2S1.offset028)
  7212. #define I2S1_TDR3 (IMXRT_I2S1.offset02C)
  7213. #define I2S1_TFR0 (IMXRT_I2S1.offset040)
  7214. #define I2S1_TFR1 (IMXRT_I2S1.offset044)
  7215. #define I2S1_TFR2 (IMXRT_I2S1.offset048)
  7216. #define I2S1_TFR3 (IMXRT_I2S1.offset04C)
  7217. #define I2S1_TMR (IMXRT_I2S1.offset060)
  7218. #define I2S1_RCSR (IMXRT_I2S1.offset088)
  7219. #define I2S1_RCR1 (IMXRT_I2S1.offset08C)
  7220. #define I2S1_RCR2 (IMXRT_I2S1.offset090)
  7221. #define I2S1_RCR3 (IMXRT_I2S1.offset094)
  7222. #define I2S1_RCR4 (IMXRT_I2S1.offset098)
  7223. #define I2S1_RCR5 (IMXRT_I2S1.offset09C)
  7224. #define I2S1_RDR0 (IMXRT_I2S1.offset0A0)
  7225. #define I2S1_RDR1 (IMXRT_I2S1.offset0A4)
  7226. #define I2S1_RDR2 (IMXRT_I2S1.offset0A8)
  7227. #define I2S1_RDR3 (IMXRT_I2S1.offset0AC)
  7228. #define I2S1_RFR0 (IMXRT_I2S1.offset0C0)
  7229. #define I2S1_RFR1 (IMXRT_I2S1.offset0C4)
  7230. #define I2S1_RFR2 (IMXRT_I2S1.offset0C8)
  7231. #define I2S1_RFR3 (IMXRT_I2S1.offset0CC)
  7232. #define I2S1_RMR (IMXRT_I2S1.offset0E0)
  7233. #define IMXRT_I2S2 (*(IMXRT_REGISTER32_t *)0x40388000)
  7234. #define I2S2_VERID (IMXRT_I2S2.offset000)
  7235. #define I2S2_PARAM (IMXRT_I2S2.offset004)
  7236. #define I2S2_TCSR (IMXRT_I2S2.offset008)
  7237. #define I2S2_TCR1 (IMXRT_I2S2.offset00C)
  7238. #define I2S2_TCR2 (IMXRT_I2S2.offset010)
  7239. #define I2S2_TCR3 (IMXRT_I2S2.offset014)
  7240. #define I2S2_TCR4 (IMXRT_I2S2.offset018)
  7241. #define I2S2_TCR5 (IMXRT_I2S2.offset01C)
  7242. #define I2S2_TDR0 (IMXRT_I2S2.offset020)
  7243. #define I2S2_TDR1 (IMXRT_I2S2.offset024)
  7244. #define I2S2_TDR2 (IMXRT_I2S2.offset028)
  7245. #define I2S2_TDR3 (IMXRT_I2S2.offset02C)
  7246. #define I2S2_TFR0 (IMXRT_I2S2.offset040)
  7247. #define I2S2_TFR1 (IMXRT_I2S2.offset044)
  7248. #define I2S2_TFR2 (IMXRT_I2S2.offset048)
  7249. #define I2S2_TFR3 (IMXRT_I2S2.offset04C)
  7250. #define I2S2_TMR (IMXRT_I2S2.offset060)
  7251. #define I2S2_RCSR (IMXRT_I2S2.offset088)
  7252. #define I2S2_RCR1 (IMXRT_I2S2.offset08C)
  7253. #define I2S2_RCR2 (IMXRT_I2S2.offset090)
  7254. #define I2S2_RCR3 (IMXRT_I2S2.offset094)
  7255. #define I2S2_RCR4 (IMXRT_I2S2.offset098)
  7256. #define I2S2_RCR5 (IMXRT_I2S2.offset09C)
  7257. #define I2S2_RDR0 (IMXRT_I2S2.offset0A0)
  7258. #define I2S2_RDR1 (IMXRT_I2S2.offset0A4)
  7259. #define I2S2_RDR2 (IMXRT_I2S2.offset0A8)
  7260. #define I2S2_RDR3 (IMXRT_I2S2.offset0AC)
  7261. #define I2S2_RFR0 (IMXRT_I2S2.offset0C0)
  7262. #define I2S2_RFR1 (IMXRT_I2S2.offset0C4)
  7263. #define I2S2_RFR2 (IMXRT_I2S2.offset0C8)
  7264. #define I2S2_RFR3 (IMXRT_I2S2.offset0CC)
  7265. #define I2S2_RMR (IMXRT_I2S2.offset0E0)
  7266. #define IMXRT_I2S3 (*(IMXRT_REGISTER32_t *)0x4038C000)
  7267. #define I2S3_VERID (IMXRT_I2S3.offset000)
  7268. #define I2S3_PARAM (IMXRT_I2S3.offset004)
  7269. #define I2S3_TCSR (IMXRT_I2S3.offset008)
  7270. #define I2S3_TCR1 (IMXRT_I2S3.offset00C)
  7271. #define I2S3_TCR2 (IMXRT_I2S3.offset010)
  7272. #define I2S3_TCR3 (IMXRT_I2S3.offset014)
  7273. #define I2S3_TCR4 (IMXRT_I2S3.offset018)
  7274. #define I2S3_TCR5 (IMXRT_I2S3.offset01C)
  7275. #define I2S3_TDR0 (IMXRT_I2S3.offset020)
  7276. #define I2S3_TDR1 (IMXRT_I2S3.offset024)
  7277. #define I2S3_TDR2 (IMXRT_I2S3.offset028)
  7278. #define I2S3_TDR3 (IMXRT_I2S3.offset02C)
  7279. #define I2S3_TFR0 (IMXRT_I2S3.offset040)
  7280. #define I2S3_TFR1 (IMXRT_I2S3.offset044)
  7281. #define I2S3_TFR2 (IMXRT_I2S3.offset048)
  7282. #define I2S3_TFR3 (IMXRT_I2S3.offset04C)
  7283. #define I2S3_TMR (IMXRT_I2S3.offset060)
  7284. #define I2S3_RCSR (IMXRT_I2S3.offset088)
  7285. #define I2S3_RCR1 (IMXRT_I2S3.offset08C)
  7286. #define I2S3_RCR2 (IMXRT_I2S3.offset090)
  7287. #define I2S3_RCR3 (IMXRT_I2S3.offset094)
  7288. #define I2S3_RCR4 (IMXRT_I2S3.offset098)
  7289. #define I2S3_RCR5 (IMXRT_I2S3.offset09C)
  7290. #define I2S3_RDR0 (IMXRT_I2S3.offset0A0)
  7291. #define I2S3_RDR1 (IMXRT_I2S3.offset0A4)
  7292. #define I2S3_RDR2 (IMXRT_I2S3.offset0A8)
  7293. #define I2S3_RDR3 (IMXRT_I2S3.offset0AC)
  7294. #define I2S3_RFR0 (IMXRT_I2S3.offset0C0)
  7295. #define I2S3_RFR1 (IMXRT_I2S3.offset0C4)
  7296. #define I2S3_RFR2 (IMXRT_I2S3.offset0C8)
  7297. #define I2S3_RFR3 (IMXRT_I2S3.offset0CC)
  7298. #define I2S3_RMR (IMXRT_I2S3.offset0E0)
  7299. #define I2S_RCR1_RFW(n) ((uint32_t)n & 0x1f) // Receive FIFO watermark
  7300. #define I2S_RCR2_DIV(n) ((uint32_t)n & 0xff) // Bit clock divide by (DIV+1)*2
  7301. #define I2S_RCR2_BCD ((uint32_t)1<<24) // Bit clock direction
  7302. #define I2S_RCR2_MSEL(n) ((uint32_t)(n & 3)<<26) // MCLK select, 0=bus clock, 1=I2S0_MCLK
  7303. #define I2S_RCR2_SYNC(n) ((uint32_t)(n & 3)<<30) // 0=async 1=sync with trasmitter
  7304. #define I2S_RCR3_RCE ((uint32_t)0x10000) // receive channel enable
  7305. #define I2S_RCR4_FSD ((uint32_t)1) // Frame Sync Direction
  7306. #define I2S_RCR4_FSP ((uint32_t)1<<1)
  7307. #define I2S_RCR4_FSE ((uint32_t)8) // Frame Sync Early
  7308. #define I2S_RCR4_MF ((uint32_t)0x10) // MSB First
  7309. #define I2S_RCR4_SYWD(n) ((uint32_t)(n & 0x1f)<<8) // Sync Width
  7310. #define I2S_RCR4_FRSZ(n) ((uint32_t)(n & 0x0f)<<16) // Frame Size
  7311. #define I2S_RCR4_FCONT ((uint32_t)1<<28) // FIFO Continue on Error
  7312. #define I2S_RCR5_FBT(n) ((uint32_t)(n & 0x1f)<<8) // First Bit Shifted
  7313. #define I2S_RCR5_W0W(n) ((uint32_t)(n & 0x1f)<<16) // Word 0 Width
  7314. #define I2S_RCR5_WNW(n) ((uint32_t)(n & 0x1f)<<24) // Word N Width
  7315. #define I2S_RCR2_BCP ((uint32_t)1<<25)
  7316. #define I2S_RCSR_RE ((uint32_t)0x80000000) // Receiver Enable
  7317. #define I2S_RCSR_FR ((uint32_t)0x02000000) // FIFO Reset
  7318. #define I2S_RCSR_FRDE ((uint32_t)0x00000001) // FIFO Request DMA Enable
  7319. #define I2S_RCSR_BCE ((uint32_t)0x10000000) // Bit Clock Enable
  7320. #define I2S_TCR1_RFW(n) ((uint32_t)n & 0x1f) // Receive FIFO watermark
  7321. #define I2S_TCR2_DIV(n) ((uint32_t)n & 0xff) // Bit clock divide by (DIV+1)*2
  7322. #define I2S_TCR2_BCD ((uint32_t)1<<24) // Bit clock direction
  7323. #define I2S_TCR2_MSEL(n) ((uint32_t)(n & 3)<<26) // MCLK select, 0=bus clock, 1=I2S0_MCLK
  7324. #define I2S_TCR2_SYNC(n) ((uint32_t)(n & 3)<<30) // 0=async 1=sync with receiver
  7325. #define I2S_TCR3_TCE ((uint32_t)0x10000) // receive channel enable
  7326. #define I2S_TCR4_FSD ((uint32_t)1) // Frame Sync Direction
  7327. #define I2S_TCR4_FSP ((uint32_t)1<<1)
  7328. #define I2S_TCR4_FSE ((uint32_t)8) // Frame Sync Early
  7329. #define I2S_TCR4_MF ((uint32_t)0x10) // MSB First
  7330. #define I2S_TCR4_SYWD(n) ((uint32_t)(n & 0x1f)<<8) // Sync Width
  7331. #define I2S_TCR4_FRSZ(n) ((uint32_t)(n & 0x0f)<<16) // Frame Size
  7332. #define I2S_TCR4_FCONT ((uint32_t)1<<28) // FIFO Continue on Error
  7333. #define I2S_TCR5_FBT(n) ((uint32_t)(n & 0x1f)<<8) // First Bit Shifted
  7334. #define I2S_TCR5_W0W(n) ((uint32_t)(n & 0x1f)<<16) // Word 0 Width
  7335. #define I2S_TCR5_WNW(n) ((uint32_t)(n & 0x1f)<<24) // Word N Width
  7336. #define I2S_TCR2_BCP ((uint32_t)1<<25)
  7337. #define I2S_TCSR_TE ((uint32_t)0x80000000) // Receiver Enable
  7338. #define I2S_TCSR_BCE ((uint32_t)0x10000000) // Bit Clock Enable
  7339. #define I2S_TCSR_FR ((uint32_t)0x02000000) // FIFO Reset
  7340. #define I2S_TCSR_FRDE ((uint32_t)0x00000001) // FIFO Request DMA Enable
  7341. // 49.3.1.1: page 2784
  7342. #define IMXRT_SEMC (*(IMXRT_REGISTER32_t *)0x402F0000)
  7343. #define SEMC_MCR (IMXRT_SEMC.offset000)
  7344. #define SEMC_IOCR (IMXRT_SEMC.offset004)
  7345. #define SEMC_BMCR0 (IMXRT_SEMC.offset008)
  7346. #define SEMC_BMCR1 (IMXRT_SEMC.offset00C)
  7347. #define SEMC_BR0 (IMXRT_SEMC.offset010)
  7348. #define SEMC_BR1 (IMXRT_SEMC.offset014)
  7349. #define SEMC_BR2 (IMXRT_SEMC.offset018)
  7350. #define SEMC_BR3 (IMXRT_SEMC.offset01C)
  7351. #define SEMC_BR4 (IMXRT_SEMC.offset020)
  7352. #define SEMC_BR5 (IMXRT_SEMC.offset024)
  7353. #define SEMC_BR6 (IMXRT_SEMC.offset028)
  7354. #define SEMC_BR7 (IMXRT_SEMC.offset02C)
  7355. #define SEMC_BR8 (IMXRT_SEMC.offset030)
  7356. #define SEMC_INTEN (IMXRT_SEMC.offset038)
  7357. #define SEMC_INTR (IMXRT_SEMC.offset03C)
  7358. #define SEMC_SDRAMCR0 (IMXRT_SEMC.offset040)
  7359. #define SEMC_SDRAMCR1 (IMXRT_SEMC.offset044)
  7360. #define SEMC_SDRAMCR2 (IMXRT_SEMC.offset048)
  7361. #define SEMC_SDRAMCR3 (IMXRT_SEMC.offset04C)
  7362. #define SEMC_NANDCR0 (IMXRT_SEMC.offset050)
  7363. #define SEMC_NANDCR1 (IMXRT_SEMC.offset054)
  7364. #define SEMC_NANDCR2 (IMXRT_SEMC.offset058)
  7365. #define SEMC_NANDCR3 (IMXRT_SEMC.offset05C)
  7366. #define SEMC_ORCR0 (IMXRT_SEMC.offset060)
  7367. #define SEMC_ORCR1 (IMXRT_SEMC.offset064)
  7368. #define SEMC_ORCR2 (IMXRT_SEMC.offset068)
  7369. #define SEMC_ORCR3 (IMXRT_SEMC.offset06C)
  7370. #define SEMC_SRAMCR0 (IMXRT_SEMC.offset070)
  7371. #define SEMC_SRAMCR1 (IMXRT_SEMC.offset074)
  7372. #define SEMC_SRAMCR2 (IMXRT_SEMC.offset078)
  7373. #define SEMC_SRAMCR3 (IMXRT_SEMC.offset07C)
  7374. #define SEMC_DBICR0 (IMXRT_SEMC.offset080)
  7375. #define SEMC_DBICR1 (IMXRT_SEMC.offset084)
  7376. #define SEMC_IPCR0 (IMXRT_SEMC.offset090)
  7377. #define SEMC_IPCR1 (IMXRT_SEMC.offset094)
  7378. #define SEMC_IPCR2 (IMXRT_SEMC.offset098)
  7379. #define SEMC_IPCMD (IMXRT_SEMC.offset09C)
  7380. #define SEMC_IPTXDAT (IMXRT_SEMC.offset0A0)
  7381. #define SEMC_IPRXDAT (IMXRT_SEMC.offset0B0)
  7382. #define SEMC_STS0 (IMXRT_SEMC.offset0C0)
  7383. #define SEMC_STS1 (IMXRT_SEMC.offset0C4)
  7384. #define SEMC_STS2 (IMXRT_SEMC.offset0C8)
  7385. #define SEMC_STS3 (IMXRT_SEMC.offset0CC)
  7386. #define SEMC_STS4 (IMXRT_SEMC.offset0D0)
  7387. #define SEMC_STS5 (IMXRT_SEMC.offset0D4)
  7388. #define SEMC_STS6 (IMXRT_SEMC.offset0D8)
  7389. #define SEMC_STS7 (IMXRT_SEMC.offset0DC)
  7390. #define SEMC_STS8 (IMXRT_SEMC.offset0E0)
  7391. #define SEMC_STS9 (IMXRT_SEMC.offset0E4)
  7392. #define SEMC_STS10 (IMXRT_SEMC.offset0E8)
  7393. #define SEMC_STS11 (IMXRT_SEMC.offset0EC)
  7394. #define SEMC_STS12 (IMXRT_SEMC.offset0F0)
  7395. #define SEMC_STS13 (IMXRT_SEMC.offset0F4)
  7396. #define SEMC_STS14 (IMXRT_SEMC.offset0F8)
  7397. #define SEMC_STS15 (IMXRT_SEMC.offset0FC)
  7398. // 50.6.1: page 2895
  7399. #define IMXRT_SNVS (*(IMXRT_REGISTER32_t *)0x400D4000)
  7400. #define SNVS_HPLR (IMXRT_SNVS.offset000)
  7401. #define SNVS_HPCOMR (IMXRT_SNVS.offset004)
  7402. #define SNVS_HPCR (IMXRT_SNVS.offset008)
  7403. #define SNVS_HPSICR (IMXRT_SNVS.offset00C)
  7404. #define SNVS_HPSVCR (IMXRT_SNVS.offset010)
  7405. #define SNVS_HPSR (IMXRT_SNVS.offset014)
  7406. #define SNVS_HPSVSR (IMXRT_SNVS.offset018)
  7407. #define SNVS_HPHACIVR (IMXRT_SNVS.offset01C)
  7408. #define SNVS_HPHACR (IMXRT_SNVS.offset020)
  7409. #define SNVS_HPRTCMR (IMXRT_SNVS.offset024)
  7410. #define SNVS_HPRTCLR (IMXRT_SNVS.offset028)
  7411. #define SNVS_HPTAMR (IMXRT_SNVS.offset02C)
  7412. #define SNVS_HPTALR (IMXRT_SNVS.offset030)
  7413. #define SNVS_LPLR (IMXRT_SNVS.offset034)
  7414. #define SNVS_LPCR (IMXRT_SNVS.offset038)
  7415. #define SNVS_LPMKCR (IMXRT_SNVS.offset03C)
  7416. #define SNVS_LPSVCR (IMXRT_SNVS.offset040)
  7417. #define SNVS_LPTDCR (IMXRT_SNVS.offset048)
  7418. #define SNVS_LPSR (IMXRT_SNVS.offset04C)
  7419. #define SNVS_LPSRTCMR (IMXRT_SNVS.offset050)
  7420. #define SNVS_LPSRTCLR (IMXRT_SNVS.offset054)
  7421. #define SNVS_LPTAR (IMXRT_SNVS.offset058)
  7422. #define SNVS_LPSMCMR (IMXRT_SNVS.offset05C)
  7423. #define SNVS_LPSMCLR (IMXRT_SNVS.offset060)
  7424. #define SNVS_LPPGDR (IMXRT_SNVS.offset064)
  7425. #define SNVS_LPGPR (IMXRT_SNVS.offset068)
  7426. #define IMXRT_SNVS_b (*(IMXRT_REGISTER32_t *)0x400D4800)
  7427. #define SNVS_HPVIDR1 (IMXRT_SNVS_b.offset3F8)
  7428. #define SNVS_HPVIDR2 (IMXRT_SNVS_b.offset3FC)
  7429. #define SNVS_HPCR_BTN_MASK ((uint32_t)(1 << 27))
  7430. #define SNVS_HPCR_BTN_CONFIG(n) ((uint32_t)(((n) & 0x07) << 24))
  7431. #define SNVS_HPCR_HP_TS ((uint32_t)(1 << 16))
  7432. #define SNVS_HPCR_HPCALB_VAL(n) ((uint32_t)(((n) & 0x1F) << 10))
  7433. #define SNVS_HPCR_HPCALB_EN ((uint32_t)(1 << 8))
  7434. #define SNVS_HPCR_PI_FREQ(n) ((uint32_t)(((n) & 0x0F) << 4))
  7435. #define SNVS_HPCR_PI_EN ((uint32_t)(1 << 3))
  7436. #define SNVS_HPCR_DIS_PI ((uint32_t)(1 << 2))
  7437. #define SNVS_HPCR_HPTA_EN ((uint32_t)(1 << 1))
  7438. #define SNVS_HPCR_RTC_EN ((uint32_t)(1 << 0))
  7439. #define SNVS_DEFAULT_PGD_VALUE (0x41736166U)
  7440. #define SNVS_LPCR_SRTC_ENV ((uint32_t)(1 << 0))
  7441. #define SNVS_LPCR_MC_ENV ((uint32_t)(1 << 2))
  7442. #define SNVS_LPCR_LPWUI_EN ((uint32_t)(1 << 3))
  7443. #define SNVS_LPCR_DP_EN ((uint32_t)(1 << 5))
  7444. #define SNVS_LPCR_TOP ((uint32_t)(1 << 6))
  7445. #define SNVS_LPCR_PWR_GLITCH_EN ((uint32_t)(1 << 7))
  7446. #define SNVS_LPCR_BTN_PRESS_TIME(n) ((uint32_t)(((n) & 0x03) << 16))
  7447. #define SNVS_LPCR_DEBOUNCE(n) ((uint32_t)(((n) & 0x03) << 18))
  7448. #define SNVS_LPCR_ON_TIME(n) ((uint32_t)(((n) & 0x03) << 20))
  7449. #define SNVS_LPCR_PK_EN ((uint32_t)(1 << 22))
  7450. #define SNVS_LPCR_PK_OVERRIDE ((uint32_t)(1 << 23))
  7451. // 51.5: page 2938
  7452. #define IMXRT_SPDIF (*(IMXRT_REGISTER32_t *)0x40380000)
  7453. #define SPDIF_SCR (IMXRT_SPDIF.offset000)
  7454. #define SPDIF_SRCD (IMXRT_SPDIF.offset004)
  7455. #define SPDIF_SRPC (IMXRT_SPDIF.offset008)
  7456. #define SPDIF_SIE (IMXRT_SPDIF.offset00C)
  7457. #define SPDIF_SIS (IMXRT_SPDIF.offset010)
  7458. #define SPDIF_SIC (IMXRT_SPDIF.offset010)
  7459. #define SPDIF_SRL (IMXRT_SPDIF.offset014)
  7460. #define SPDIF_SRR (IMXRT_SPDIF.offset018)
  7461. #define SPDIF_SRCSH (IMXRT_SPDIF.offset01C)
  7462. #define SPDIF_SRCSL (IMXRT_SPDIF.offset020)
  7463. #define SPDIF_SRU (IMXRT_SPDIF.offset024)
  7464. #define SPDIF_SRQ (IMXRT_SPDIF.offset028)
  7465. #define SPDIF_STL (IMXRT_SPDIF.offset02C)
  7466. #define SPDIF_STR (IMXRT_SPDIF.offset030)
  7467. #define SPDIF_STCSCH (IMXRT_SPDIF.offset034)
  7468. #define SPDIF_STCSCL (IMXRT_SPDIF.offset038)
  7469. #define SPDIF_SRFM (IMXRT_SPDIF.offset044)
  7470. #define SPDIF_STC (IMXRT_SPDIF.offset050)
  7471. #define SPDIF_SCR_RXFIFO_CTR ((uint32_t)(1 << 23))
  7472. #define SPDIF_SCR_RXFIFO_OFF_ON ((uint32_t)(1 << 22))
  7473. #define SPDIF_SCR_RXFIFO_RST ((uint32_t)(1 << 21))
  7474. #define SPDIF_SCR_RXFIFOFULL_SEL(n) ((uint32_t)(((n) & 0x03) << 19))
  7475. #define SPDIF_SCR_RXAUTOSYNC ((uint32_t)(1 << 18))
  7476. #define SPDIF_SCR_TXAUTOSYNC ((uint32_t)(1 << 17))
  7477. #define SPDIF_SCR_TXFIFOEMPTY_SEL(n) ((uint32_t)(((n) & 0x03) << 15))
  7478. #define SPDIF_SCR_LOW_POWER ((uint32_t)(1 << 13))
  7479. #define SPDIF_SCR_SOFT_RESET ((uint32_t)(1 << 12))
  7480. #define SPDIF_SCR_TXFIFO_CTRL(n) ((uint32_t)(((n) & 0x03) << 10))
  7481. #define SPDIF_SCR_DMA_RX_EN ((uint32_t)(1 << 9))
  7482. #define SPDIF_SCR_DMA_TX_EN ((uint32_t)(1 << 8))
  7483. #define SPDIF_SCR_VALCTRL ((uint32_t)(1 << 5))
  7484. #define SPDIF_SCR_TXSEL(n) ((uint32_t)(((n) & 0x07) << 2))
  7485. #define SPDIF_SCR_USRC_SEL(n) ((uint32_t)(((n) & 0x03) << 0))
  7486. #define SPDIF_SRCD_USYNCMODE ((uint32_t)(1 << 1))
  7487. #define SPDIF_SRPC_CLKSRC_SEL(n) ((uint32_t)(((n) & 0x0f) << 7))
  7488. #define SPDIF_SRPC_LOCK ((uint32_t)(1 << 6))
  7489. #define SPDIF_SRPC_GAINSEL(n) ((uint32_t)(((n) & 0x07) << 3))
  7490. #define SPDIF_SIE_LOCK ((uint32_t)(1 << 20))
  7491. #define SPDIF_SIE_TXUNOV ((uint32_t)(1 << 19))
  7492. #define SPDIF_SIE_TXRESYN ((uint32_t)(1 << 18))
  7493. #define SPDIF_SIE_CNEW ((uint32_t)(1 << 17))
  7494. #define SPDIF_SIE_VALNOGOOD ((uint32_t)(1 << 16))
  7495. #define SPDIF_SIE_SYMERR ((uint32_t)(1 << 15))
  7496. #define SPDIF_SIE_BITERR ((uint32_t)(1 << 14))
  7497. #define SPDIF_SIE_URXFUL ((uint32_t)(1 << 10))
  7498. #define SPDIF_SIE_URXOV ((uint32_t)(1 << 9))
  7499. #define SPDIF_SIE_QRXFUL ((uint32_t)(1 << 8))
  7500. #define SPDIF_SIE_QRXOV ((uint32_t)(1 << 7))
  7501. #define SPDIF_SIE_UQSYNC ((uint32_t)(1 << 6))
  7502. #define SPDIF_SIE_UQERR ((uint32_t)(1 << 5))
  7503. #define SPDIF_SIE_RXFIFOUNOV ((uint32_t)(1 << 4))
  7504. #define SPDIF_SIE_RXFIFORESYN ((uint32_t)(1 << 3))
  7505. #define SPDIF_SIE_LOCKLOSS ((uint32_t)(1 << 2))
  7506. #define SPDIF_SIE_TXEM ((uint32_t)(1 << 1))
  7507. #define SPDIF_SIE_RXFIFOFUL ((uint32_t)(1 << 0))
  7508. #define SPDIF_SIS_LOCK ((uint32_t)(1 << 20))
  7509. #define SPDIF_SIS_TXUNOV ((uint32_t)(1 << 19))
  7510. #define SPDIF_SIS_TXRESYN ((uint32_t)(1 << 18))
  7511. #define SPDIF_SIS_CNEW ((uint32_t)(1 << 17))
  7512. #define SPDIF_SIS_VALNOGOOD ((uint32_t)(1 << 16))
  7513. #define SPDIF_SIS_SYMERR ((uint32_t)(1 << 15))
  7514. #define SPDIF_SIS_BITERR ((uint32_t)(1 << 14))
  7515. #define SPDIF_SIS_URXFUL ((uint32_t)(1 << 10))
  7516. #define SPDIF_SIS_URXOV ((uint32_t)(1 << 9))
  7517. #define SPDIF_SIS_QRXFUL ((uint32_t)(1 << 8))
  7518. #define SPDIF_SIS_QRXOV ((uint32_t)(1 << 7))
  7519. #define SPDIF_SIS_UQSYNC ((uint32_t)(1 << 6))
  7520. #define SPDIF_SIS_UQERR ((uint32_t)(1 << 5))
  7521. #define SPDIF_SIS_RXFIFOUNOV ((uint32_t)(1 << 4))
  7522. #define SPDIF_SIS_RXFIFORESYN ((uint32_t)(1 << 3))
  7523. #define SPDIF_SIS_LOCKLOSS ((uint32_t)(1 << 2))
  7524. #define SPDIF_SIS_TXEM ((uint32_t)(1 << 1))
  7525. #define SPDIF_SIS_RXFIFOFUL ((uint32_t)(1 << 0))
  7526. #define SPDIF_SIC_LOCK ((uint32_t)(1 << 20))
  7527. #define SPDIF_SIC_TXUNOV ((uint32_t)(1 << 19))
  7528. #define SPDIF_SIC_TXRESYN ((uint32_t)(1 << 18))
  7529. #define SPDIF_SIC_CNEW ((uint32_t)(1 << 17))
  7530. #define SPDIF_SIC_VALNOGOOD ((uint32_t)(1 << 16))
  7531. #define SPDIF_SIC_SYMERR ((uint32_t)(1 << 15))
  7532. #define SPDIF_SIC_BITERR ((uint32_t)(1 << 14))
  7533. #define SPDIF_SIC_URXFUL ((uint32_t)(1 << 10))
  7534. #define SPDIF_SIC_URXOV ((uint32_t)(1 << 9))
  7535. #define SPDIF_SIC_QRXOV ((uint32_t)(1 << 7))
  7536. #define SPDIF_SIC_UQSYNC ((uint32_t)(1 << 6))
  7537. #define SPDIF_SIC_UQERR ((uint32_t)(1 << 5))
  7538. #define SPDIF_SIC_RXFIFOUNOV ((uint32_t)(1 << 4))
  7539. #define SPDIF_SIC_RXFIFORESYN ((uint32_t)(1 << 3))
  7540. #define SPDIF_SIC_LOCKLOSS ((uint32_t)(1 << 2))
  7541. #define SPDIF_STC_SYSCLK_DF(n) ((uint32_t)(((n) & 0x1ff) << 11))
  7542. #define SPDIF_STC_TXCLK_SOURCE(n) ((uint32_t)(((n) & 0x07) << 8))
  7543. #define SPDIF_STC_TX_ALL_CLK_EN ((uint32_t)(1 << 7))
  7544. #define SPDIF_STC_TXCLK_DF(n) ((uint32_t)(((n) & 0x7f) << 0))
  7545. // 52.7: page 2969
  7546. #define IMXRT_SRC (*(IMXRT_REGISTER32_t *)0x400F8000)
  7547. #define SRC_SCR (IMXRT_SRC.offset000)
  7548. #define SRC_SBMR1 (IMXRT_SRC.offset004)
  7549. #define SRC_SRSR (IMXRT_SRC.offset008)
  7550. #define SRC_SBMR2 (IMXRT_SRC.offset01C)
  7551. /*
  7552. These register are used by the ROM code and should not be used by application software
  7553. #define SRC_GPR1 (IMXRT_SRC.offset020)
  7554. #define SRC_GPR2 (IMXRT_SRC.offset024)
  7555. #define SRC_GPR3 (IMXRT_SRC.offset028)
  7556. #define SRC_GPR4 (IMXRT_SRC.offset02C)
  7557. #define SRC_GPR5 (IMXRT_SRC.offset030)
  7558. #define SRC_GPR6 (IMXRT_SRC.offset034)
  7559. #define SRC_GPR7 (IMXRT_SRC.offset038)
  7560. #define SRC_GPR8 (IMXRT_SRC.offset03C)
  7561. #define SRC_GPR9 (IMXRT_SRC.offset040)
  7562. #define SRC_GPR10 (IMXRT_SRC.offset044)
  7563. */
  7564. #define SRC_SCR_MASK_WDOG3_RST(n) ((uint32_t)(((n) & 0x0f) << 28))
  7565. #define SRC_SCR_DBG_RST_MSK_PG ((uint32_t)(1 << 25))
  7566. #define SRC_SCR_CORE0_DBG_RST ((uint32_t)(1 << 17))
  7567. #define SRC_SCR_CORE0_RST ((uint32_t)(1 << 13))
  7568. #define SRC_SCR_MASK_WDOG_RST(n) ((uint32_t)(((n) & 0x0f) << 7))
  7569. #define SRC_SBMR1_BOOT_CFG4(n) ((uint32_t)(((n) & 0xff) << 24))
  7570. #define SRC_SBMR1_BOOT_CFG3(n) ((uint32_t)(((n) & 0xff) << 16))
  7571. #define SRC_SBMR1_BOOT_CFG2(n) ((uint32_t)(((n) & 0xff) << 8))
  7572. #define SRC_SBMR1_BOOT_CFG1(n) ((uint32_t)(((n) & 0xff) << 0))
  7573. #define SRC_SRSR_TEMPSENSE_RST_B ((uint32_t)(1 << 8))
  7574. #define SRC_SRSR_WDOG3_RST_B ((uint32_t)(1 << 7))
  7575. #define SRC_SRSR_JTAG_SW_RST ((uint32_t)(1 << 6))
  7576. #define SRC_SRSR_JTAG_RST_B ((uint32_t)(1 << 5))
  7577. #define SRC_SRSR_WDOG_RST_B ((uint32_t)(1 << 4))
  7578. #define SRC_SRSR_IPP_USER_RESET_B ((uint32_t)(1 << 3))
  7579. #define SRC_SRSR_CSU_RESET_B ((uint32_t)(1 << 2))
  7580. #define SRC_SRSR_LOCKUP_SYSRESETREQ ((uint32_t)(1 << 1))
  7581. #define SRC_SRSR_IPP_RESET_B ((uint32_t)(1 << 0))
  7582. #define SRC_SBMR2_BMOD(n) ((uint32_t)(((n) & 0x03) << 24))
  7583. #define SRC_SBMR2_BT_FUSE_SEL ((uint32_t)(1 << 4))
  7584. #define SRC_SBMR2_DIR_BT_DIS ((uint32_t)(1 << 3))
  7585. #define SRC_SBMR2_SEC_CONFIG(n) ((uint32_t)(((n) & 0x03) << 0))
  7586. // 53.3: page 2986
  7587. #define IMXRT_TEMPMON (*(IMXRT_REGISTER32_t *)0x400D8180)
  7588. #define TEMPMON_TEMPSENSE0 (IMXRT_TEMPMON.offset000)
  7589. #define TEMPMON_TEMPSENSE0_SET (IMXRT_TEMPMON.offset004)
  7590. #define TEMPMON_TEMPSENSE0_CLR (IMXRT_TEMPMON.offset008)
  7591. #define TEMPMON_TEMPSENSE0_TOG (IMXRT_TEMPMON.offset08c)
  7592. #define TEMPMON_TEMPSENSE1 (IMXRT_TEMPMON.offset090)
  7593. #define TEMPMON_TEMPSENSE1_SET (IMXRT_TEMPMON.offset094)
  7594. #define TEMPMON_TEMPSENSE1_CLR (IMXRT_TEMPMON.offset098)
  7595. #define TEMPMON_TEMPSENSE1_TOG (IMXRT_TEMPMON.offset09C)
  7596. #define TEMPMON_TEMPSENSE2 (IMXRT_TEMPMON.offset110)
  7597. #define TEMPMON_TEMPSENSE2_SET (IMXRT_TEMPMON.offset114)
  7598. #define TEMPMON_TEMPSENSE2_CLR (IMXRT_TEMPMON.offset118)
  7599. #define TEMPMON_TEMPSENSE2_TOG (IMXRT_TEMPMON.offset11C)
  7600. #define TEMPMON_CTRL0_ALARM_VALUE(n) ((uint32_t)(((n) & 0x0fff) << 20))
  7601. #define TEMPMON_CTRL0_TEMP_CNT(n) ((uint32_t)(((n) & 0x0fff) << 8))
  7602. #define TEMPMON_CTRL0_FINISHED ((uint32_t)(1 << 2))
  7603. #define TEMPMON_CTRL0_MEASURE_TEMP ((uint32_t)(1 << 1))
  7604. #define TEMPMON_CTRL0_POWER_DOWN ((uint32_t)(1 << 0))
  7605. #define TEMPMON_CTRL1_MEASURE_FREQ(n) ((uint32_t)(((n) & 0xffff) << 0))
  7606. #define TEMPMON_CTRL2_PANIC_ALARM_VALUE(n) ((uint32_t)(((n) & 0x0fff) << 16))
  7607. #define TEMPMON_CTRL2_LOW_ALARM_VALUE(n) ((uint32_t)(((n) & 0x0fff) << 0))
  7608. // 54.3: page 2998
  7609. #define IMXRT_TSC (*(IMXRT_REGISTER32_t *)0x400E0000)
  7610. #define TSC_BASIC_SETTING (IMXRT_TSC.offset000)
  7611. #define TSC_PS_INPUT_BUFFER_ADDR (IMXRT_TSC.offset010)
  7612. #define TSC_FLOW_CONTROL (IMXRT_TSC.offset020)
  7613. #define TSC_MEASEURE_VALUE (IMXRT_TSC.offset030)
  7614. #define TSC_INT_EN (IMXRT_TSC.offset040)
  7615. #define TSC_INT_SIG_EN (IMXRT_TSC.offset050)
  7616. #define TSC_INT_STATUS (IMXRT_TSC.offset060)
  7617. #define TSC_DEBUG_MODE (IMXRT_TSC.offset070)
  7618. #define TSC_DEBUG_MODE2 (IMXRT_TSC.offset080)
  7619. // 55.4.1.1: page 3022
  7620. #define IMXRT_USB1 (*(IMXRT_REGISTER32_t *)0x402E0000)
  7621. #define USB1_ID (IMXRT_USB1.offset000)
  7622. #define USB1_HWGENERAL (IMXRT_USB1.offset004)
  7623. #define USB1_HWHOST (IMXRT_USB1.offset008)
  7624. #define USB1_HWDEVICE (IMXRT_USB1.offset00C)
  7625. #define USB1_HWTXBUF (IMXRT_USB1.offset010)
  7626. #define USB1_HWRXBUF (IMXRT_USB1.offset014)
  7627. #define USB1_GPTIMER0LD (IMXRT_USB1.offset080)
  7628. #define USB1_GPTIMER0CTRL (IMXRT_USB1.offset084)
  7629. #define USB1_GPTIMER1LD (IMXRT_USB1.offset088)
  7630. #define USB1_GPTIMER1CTRL (IMXRT_USB1.offset08C)
  7631. #define USB1_SBUSCFG (IMXRT_USB1.offset090)
  7632. #define USB1_HCIVERSION (IMXRT_USB1.offset100)
  7633. #define USB1_HCSPARAMS (IMXRT_USB1.offset104)
  7634. #define USB1_HCCPARAMS (IMXRT_USB1.offset108)
  7635. #define USB1_DCIVERSION (IMXRT_USB1.offset120)
  7636. #define USB1_DCCPARAMS (IMXRT_USB1.offset124)
  7637. #define USB1_USBCMD (IMXRT_USB1.offset140)
  7638. #define USB1_USBSTS (IMXRT_USB1.offset144)
  7639. #define USB1_USBINTR (IMXRT_USB1.offset148)
  7640. #define USB1_FRINDEX (IMXRT_USB1.offset14C)
  7641. #define USB1_PERIODICLISTBASE (IMXRT_USB1.offset154)
  7642. #define USB1_DEVICEADDR (IMXRT_USB1.offset154)
  7643. #define USB1_ASYNCLISTADDR (IMXRT_USB1.offset158)
  7644. #define USB1_ENDPOINTLISTADDR (IMXRT_USB1.offset158)
  7645. #define USB1_BURSTSIZE (IMXRT_USB1.offset160)
  7646. #define USB1_TXFILLTUNING (IMXRT_USB1.offset164)
  7647. #define USB1_ENDPTNAK (IMXRT_USB1.offset178)
  7648. #define USB1_ENDPTNAKEN (IMXRT_USB1.offset17C)
  7649. #define USB1_CONFIGFLAG (IMXRT_USB1.offset180)
  7650. #define USB1_PORTSC1 (IMXRT_USB1.offset184)
  7651. #define USB1_OTGSC (IMXRT_USB1.offset1A4)
  7652. #define USB1_USBMODE (IMXRT_USB1.offset1A8)
  7653. #define USB1_ENDPTSETUPSTAT (IMXRT_USB1.offset1AC)
  7654. #define USB1_ENDPTPRIME (IMXRT_USB1.offset1B0)
  7655. #define USB1_ENDPTFLUSH (IMXRT_USB1.offset1B4)
  7656. #define USB1_ENDPTSTATUS (IMXRT_USB1.offset1B8)
  7657. #define USB1_ENDPTCOMPLETE (IMXRT_USB1.offset1BC)
  7658. #define USB1_ENDPTCTRL0 (IMXRT_USB1.offset1C0)
  7659. #define USB1_ENDPTCTRL1 (IMXRT_USB1.offset1C4)
  7660. #define USB1_ENDPTCTRL2 (IMXRT_USB1.offset1C8)
  7661. #define USB1_ENDPTCTRL3 (IMXRT_USB1.offset1CC)
  7662. #define USB1_ENDPTCTRL4 (IMXRT_USB1.offset1D0)
  7663. #define USB1_ENDPTCTRL5 (IMXRT_USB1.offset1D4)
  7664. #define USB1_ENDPTCTRL6 (IMXRT_USB1.offset1D8)
  7665. #define USB1_ENDPTCTRL7 (IMXRT_USB1.offset1DC)
  7666. #define IMXRT_USB2 (*(IMXRT_REGISTER32_t *)0x402E0200)
  7667. #define USB2_ID (IMXRT_USB2.offset000)
  7668. #define USB2_HWGENERAL (IMXRT_USB2.offset004)
  7669. #define USB2_HWHOST (IMXRT_USB2.offset008)
  7670. #define USB2_HWDEVICE (IMXRT_USB2.offset00C)
  7671. #define USB2_HWTXBUF (IMXRT_USB2.offset010)
  7672. #define USB2_HWRXBUF (IMXRT_USB2.offset014)
  7673. #define USB2_GPTIMER0LD (IMXRT_USB2.offset080)
  7674. #define USB2_GPTIMER0CTRL (IMXRT_USB2.offset084)
  7675. #define USB2_GPTIMER1LD (IMXRT_USB2.offset088)
  7676. #define USB2_GPTIMER1CTRL (IMXRT_USB2.offset08C)
  7677. #define USB2_SBUSCFG (IMXRT_USB2.offset090)
  7678. #define USB2_HCIVERSION (IMXRT_USB2.offset100)
  7679. #define USB2_HCSPARAMS (IMXRT_USB2.offset104)
  7680. #define USB2_HCCPARAMS (IMXRT_USB2.offset108)
  7681. #define USB2_DCIVERSION (IMXRT_USB2.offset120)
  7682. #define USB2_DCCPARAMS (IMXRT_USB2.offset124)
  7683. #define USB2_USBCMD (IMXRT_USB2.offset140)
  7684. #define USB2_USBSTS (IMXRT_USB2.offset144)
  7685. #define USB2_USBINTR (IMXRT_USB2.offset148)
  7686. #define USB2_FRINDEX (IMXRT_USB2.offset14C)
  7687. #define USB2_PERIODICLISTBASE (IMXRT_USB2.offset154)
  7688. #define USB2_DEVICEADDR (IMXRT_USB2.offset154)
  7689. #define USB2_ASYNCLISTADDR (IMXRT_USB2.offset158)
  7690. #define USB2_ENDPOINTLISTADDR (IMXRT_USB2.offset158)
  7691. #define USB2_BURSTSIZE (IMXRT_USB2.offset160)
  7692. #define USB2_TXFILLTUNING (IMXRT_USB2.offset164)
  7693. #define USB2_ENDPTNAK (IMXRT_USB2.offset178)
  7694. #define USB2_ENDPTNAKEN (IMXRT_USB2.offset17C)
  7695. #define USB2_CONFIGFLAG (IMXRT_USB2.offset180)
  7696. #define USB2_PORTSC1 (IMXRT_USB2.offset184)
  7697. #define USB2_OTGSC (IMXRT_USB2.offset1A4)
  7698. #define USB2_USBMODE (IMXRT_USB2.offset1A8)
  7699. #define USB2_ENDPTSETUPSTAT (IMXRT_USB2.offset1AC)
  7700. #define USB2_ENDPTPRIME (IMXRT_USB2.offset1B0)
  7701. #define USB2_ENDPTFLUSH (IMXRT_USB2.offset1B4)
  7702. #define USB2_ENDPTSTATUS (IMXRT_USB2.offset1B8)
  7703. #define USB2_ENDPTCOMPLETE (IMXRT_USB2.offset1BC)
  7704. #define USB2_ENDPTCTRL0 (IMXRT_USB2.offset1C0)
  7705. #define USB2_ENDPTCTRL1 (IMXRT_USB2.offset1C4)
  7706. #define USB2_ENDPTCTRL2 (IMXRT_USB2.offset1C8)
  7707. #define USB2_ENDPTCTRL3 (IMXRT_USB2.offset1CC)
  7708. #define USB2_ENDPTCTRL4 (IMXRT_USB2.offset1D0)
  7709. #define USB2_ENDPTCTRL5 (IMXRT_USB2.offset1D4)
  7710. #define USB2_ENDPTCTRL6 (IMXRT_USB2.offset1D8)
  7711. #define USB2_ENDPTCTRL7 (IMXRT_USB2.offset1DC)
  7712. #define USB_USBCMD_ITC(n) ((uint32_t)(((n) & 0xFF) << 16))
  7713. #define USB_USBCMD_FS_2 ((uint32_t)(1<<15))
  7714. #define USB_USBCMD_ATDTW ((uint32_t)(1<<14))
  7715. #define USB_USBCMD_SUTW ((uint32_t)(1<<13))
  7716. #define USB_USBCMD_ASPE ((uint32_t)(1<<11))
  7717. #define USB_USBCMD_ASP(n) ((uint32_t)(((n) & 0x03) << 8))
  7718. #define USB_USBCMD_IAA ((uint32_t)(1<<6))
  7719. #define USB_USBCMD_ASE ((uint32_t)(1<<5))
  7720. #define USB_USBCMD_PSE ((uint32_t)(1<<4))
  7721. #define USB_USBCMD_FS_1(n) ((uint32_t)(((n) & 0x03) << 2))
  7722. #define USB_USBCMD_RST ((uint32_t)(1<<1))
  7723. #define USB_USBCMD_RS ((uint32_t)(1<<0))
  7724. #define USB_USBSTS_TI1 ((uint32_t)(1<<25))
  7725. #define USB_USBSTS_TI0 ((uint32_t)(1<<24))
  7726. #define USB_USBSTS_NAKI ((uint32_t)(1<<16))
  7727. #define USB_USBSTS_AS ((uint32_t)(1<<15))
  7728. #define USB_USBSTS_PS ((uint32_t)(1<<14))
  7729. #define USB_USBSTS_RCL ((uint32_t)(1<<13))
  7730. #define USB_USBSTS_HCH ((uint32_t)(1<<12))
  7731. #define USB_USBSTS_ULPII ((uint32_t)(1<<10))
  7732. #define USB_USBSTS_SLI ((uint32_t)(1<<8))
  7733. #define USB_USBSTS_SRI ((uint32_t)(1<<7))
  7734. #define USB_USBSTS_URI ((uint32_t)(1<<6))
  7735. #define USB_USBSTS_AAI ((uint32_t)(1<<5))
  7736. #define USB_USBSTS_SEI ((uint32_t)(1<<4))
  7737. #define USB_USBSTS_FRI ((uint32_t)(1<<3))
  7738. #define USB_USBSTS_PCI ((uint32_t)(1<<2))
  7739. #define USB_USBSTS_UEI ((uint32_t)(1<<1))
  7740. #define USB_USBSTS_UI ((uint32_t)(1<<0))
  7741. #define USB_USBINTR_TIE1 ((uint32_t)(1<<25))
  7742. #define USB_USBINTR_TIE0 ((uint32_t)(1<<24))
  7743. #define USB_USBINTR_UPIE ((uint32_t)(1<<19))
  7744. #define USB_USBINTR_UAIE ((uint32_t)(1<<18))
  7745. #define USB_USBINTR_NAKE ((uint32_t)(1<<16))
  7746. #define USB_USBINTR_ULPIE ((uint32_t)(1<<10))
  7747. #define USB_USBINTR_SLE ((uint32_t)(1<<8))
  7748. #define USB_USBINTR_SRE ((uint32_t)(1<<7))
  7749. #define USB_USBINTR_URE ((uint32_t)(1<<6))
  7750. #define USB_USBINTR_AAE ((uint32_t)(1<<5))
  7751. #define USB_USBINTR_SEE ((uint32_t)(1<<4))
  7752. #define USB_USBINTR_FRE ((uint32_t)(1<<3))
  7753. #define USB_USBINTR_PCE ((uint32_t)(1<<2))
  7754. #define USB_USBINTR_UEE ((uint32_t)(1<<1))
  7755. #define USB_USBINTR_UE ((uint32_t)(1<<0))
  7756. #define USB_DEVICEADDR_USBADR(n) ((uint32_t)(((n) & 0x7F) << 25))
  7757. #define USB_DEVICEADDR_USBADRA ((uint32_t)(1<<24))
  7758. #define USB_PORTSC1_PTS_1(n) ((uint32_t)(((n) & 0x03) << 30))
  7759. #define USB_PORTSC1_STS ((uint32_t)(1<<29))
  7760. #define USB_PORTSC1_PTW ((uint32_t)(1<<28))
  7761. #define USB_PORTSC1_PSPD(n) ((uint32_t)(((n) & 0x03) << 26))
  7762. #define USB_PORTSC1_PTS_2 ((uint32_t)(1<<25))
  7763. #define USB_PORTSC1_PFSC ((uint32_t)(1<<24))
  7764. #define USB_PORTSC1_PHCD ((uint32_t)(1<<23))
  7765. #define USB_PORTSC1_WKOC ((uint32_t)(1<<22))
  7766. #define USB_PORTSC1_WKDC ((uint32_t)(1<<21))
  7767. #define USB_PORTSC1_WKCN ((uint32_t)(1<<20))
  7768. #define USB_PORTSC1_PTC(n) ((uint32_t)(((n) & 0x0F) << 16))
  7769. #define USB_PORTSC1_PIC(n) ((uint32_t)(((n) & 0x03) << 14))
  7770. #define USB_PORTSC1_PO ((uint32_t)(1<<13))
  7771. #define USB_PORTSC1_PP ((uint32_t)(1<<12))
  7772. #define USB_PORTSC1_LS(n) ((uint32_t)(((n) & 0x03) << 10))
  7773. #define USB_PORTSC1_HSP ((uint32_t)(1<<9))
  7774. #define USB_PORTSC1_PR ((uint32_t)(1<<8))
  7775. #define USB_PORTSC1_SUSP ((uint32_t)(1<<7))
  7776. #define USB_PORTSC1_FPR ((uint32_t)(1<<6))
  7777. #define USB_PORTSC1_OCC ((uint32_t)(1<<5))
  7778. #define USB_PORTSC1_OCA ((uint32_t)(1<<4))
  7779. #define USB_PORTSC1_PEC ((uint32_t)(1<<3))
  7780. #define USB_PORTSC1_PE ((uint32_t)(1<<2))
  7781. #define USB_PORTSC1_CSC ((uint32_t)(1<<1))
  7782. #define USB_PORTSC1_CCS ((uint32_t)(1<<0))
  7783. #define USB_USBMODE_SDIS ((uint32_t)(1<<4))
  7784. #define USB_USBMODE_SLOM ((uint32_t)(1<<3))
  7785. #define USB_USBMODE_ES ((uint32_t)(1<<2))
  7786. #define USB_USBMODE_CM(n) ((uint32_t)(((n) & 0x03) << 0))
  7787. #define USB_USBMODE_CM_MASK USB_USBMODE_CM(3)
  7788. #define USB_ENDPTCTRL_TXE ((uint32_t)(1<<23))
  7789. #define USB_ENDPTCTRL_TXR ((uint32_t)(1<<22))
  7790. #define USB_ENDPTCTRL_TXI ((uint32_t)(1<<21))
  7791. #define USB_ENDPTCTRL_TXT(n) ((uint32_t)(((n) & 0x03) << 18))
  7792. #define USB_ENDPTCTRL_TXD ((uint32_t)(1<<17))
  7793. #define USB_ENDPTCTRL_TXS ((uint32_t)(1<<16))
  7794. #define USB_ENDPTCTRL_RXE ((uint32_t)(1<<7))
  7795. #define USB_ENDPTCTRL_RXR ((uint32_t)(1<<6))
  7796. #define USB_ENDPTCTRL_RXI ((uint32_t)(1<<5))
  7797. #define USB_ENDPTCTRL_RXT(n) ((uint32_t)(((n) & 0x03) << 2))
  7798. #define USB_ENDPTCTRL_RXD ((uint32_t)(1<<0))
  7799. #define USB_ENDPTCTRL_RXS ((uint32_t)(1<<1))
  7800. #define USB_GPTIMERCTRL_GPTRUN ((uint32_t)(1<<31))
  7801. #define USB_GPTIMERCTRL_GPTRST ((uint32_t)(1<<30))
  7802. #define USB_GPTIMERCTRL_GPTMODE ((uint32_t)(1<<24))
  7803. #define USB_GPTIMERCTRL_GPTCNT(n) ((uint32_t)(((n) & 0xFFFFFF) << 0))
  7804. // 56.3: page 3283
  7805. #define IMXRT_USBPHY1 (*(IMXRT_REGISTER32_t *)0x400D9000)
  7806. #define USBPHY1_PWD (IMXRT_USBPHY1.offset000)
  7807. #define USBPHY1_PWD_SET (IMXRT_USBPHY1.offset004)
  7808. #define USBPHY1_PWD_CLR (IMXRT_USBPHY1.offset008)
  7809. #define USBPHY1_PWD_TOG (IMXRT_USBPHY1.offset00C)
  7810. #define USBPHY1_TX (IMXRT_USBPHY1.offset010)
  7811. #define USBPHY1_TX_SET (IMXRT_USBPHY1.offset014)
  7812. #define USBPHY1_TX_CLR (IMXRT_USBPHY1.offset018)
  7813. #define USBPHY1_TX_TOG (IMXRT_USBPHY1.offset01C)
  7814. #define USBPHY1_RX (IMXRT_USBPHY1.offset020)
  7815. #define USBPHY1_RX_SET (IMXRT_USBPHY1.offset024)
  7816. #define USBPHY1_RX_CLR (IMXRT_USBPHY1.offset028)
  7817. #define USBPHY1_RX_TOG (IMXRT_USBPHY1.offset02C)
  7818. #define USBPHY1_CTRL (IMXRT_USBPHY1.offset030)
  7819. #define USBPHY1_CTRL_SET (IMXRT_USBPHY1.offset034)
  7820. #define USBPHY1_CTRL_CLR (IMXRT_USBPHY1.offset038)
  7821. #define USBPHY1_CTRL_TOG (IMXRT_USBPHY1.offset03C)
  7822. #define USBPHY1_STATUS (IMXRT_USBPHY1.offset040)
  7823. #define USBPHY1_DEBUG (IMXRT_USBPHY1.offset050)
  7824. #define USBPHY1_DEBUG_SET (IMXRT_USBPHY1.offset054)
  7825. #define USBPHY1_DEBUG_CLR (IMXRT_USBPHY1.offset058)
  7826. #define USBPHY1_DEBUG_TOG (IMXRT_USBPHY1.offset05C)
  7827. #define USBPHY1_DEBUG0_STATUS (IMXRT_USBPHY1.offset060)
  7828. #define USBPHY1_DEBUG1 (IMXRT_USBPHY1.offset070)
  7829. #define USBPHY1_DEBUG1_SET (IMXRT_USBPHY1.offset074)
  7830. #define USBPHY1_DEBUG1_CLR (IMXRT_USBPHY1.offset078)
  7831. #define USBPHY1_DEBUG1_TOG (IMXRT_USBPHY1.offset07C)
  7832. #define USBPHY1_VERSION (IMXRT_USBPHY1.offset080)
  7833. #define IMXRT_USBPHY2 (*(IMXRT_REGISTER32_t *)0x400DA000)
  7834. #define USBPHY2_PWD (IMXRT_USBPHY2.offset000)
  7835. #define USBPHY2_PWD_SET (IMXRT_USBPHY2.offset004)
  7836. #define USBPHY2_PWD_CLR (IMXRT_USBPHY2.offset008)
  7837. #define USBPHY2_PWD_TOG (IMXRT_USBPHY2.offset00C)
  7838. #define USBPHY2_TX (IMXRT_USBPHY2.offset010)
  7839. #define USBPHY2_TX_SET (IMXRT_USBPHY2.offset014)
  7840. #define USBPHY2_TX_CLR (IMXRT_USBPHY2.offset018)
  7841. #define USBPHY2_TX_TOG (IMXRT_USBPHY2.offset01C)
  7842. #define USBPHY2_RX (IMXRT_USBPHY2.offset020)
  7843. #define USBPHY2_RX_SET (IMXRT_USBPHY2.offset024)
  7844. #define USBPHY2_RX_CLR (IMXRT_USBPHY2.offset028)
  7845. #define USBPHY2_RX_TOG (IMXRT_USBPHY2.offset02C)
  7846. #define USBPHY2_CTRL (IMXRT_USBPHY2.offset030)
  7847. #define USBPHY2_CTRL_SET (IMXRT_USBPHY2.offset034)
  7848. #define USBPHY2_CTRL_CLR (IMXRT_USBPHY2.offset038)
  7849. #define USBPHY2_CTRL_TOG (IMXRT_USBPHY2.offset03C)
  7850. #define USBPHY2_STATUS (IMXRT_USBPHY2.offset040)
  7851. #define USBPHY2_DEBUG (IMXRT_USBPHY2.offset050)
  7852. #define USBPHY2_DEBUG_SET (IMXRT_USBPHY2.offset054)
  7853. #define USBPHY2_DEBUG_CLR (IMXRT_USBPHY2.offset058)
  7854. #define USBPHY2_DEBUG_TOG (IMXRT_USBPHY2.offset05C)
  7855. #define USBPHY2_DEBUG0_STATUS (IMXRT_USBPHY2.offset060)
  7856. #define USBPHY2_DEBUG1 (IMXRT_USBPHY2.offset070)
  7857. #define USBPHY2_DEBUG1_SET (IMXRT_USBPHY2.offset074)
  7858. #define USBPHY2_DEBUG1_CLR (IMXRT_USBPHY2.offset078)
  7859. #define USBPHY2_DEBUG1_TOG (IMXRT_USBPHY2.offset07C)
  7860. #define USBPHY2_VERSION (IMXRT_USBPHY2.offset080)
  7861. #define USBPHY_PWD_RXPWDRX ((uint32_t)(1<<20))
  7862. #define USBPHY_PWD_RXPWDDIFF ((uint32_t)(1<<19))
  7863. #define USBPHY_PWD_RXPWD1PT1 ((uint32_t)(1<<18))
  7864. #define USBPHY_PWD_RXPWDENV ((uint32_t)(1<<17))
  7865. #define USBPHY_PWD_TXPWDV2I ((uint32_t)(1<<12))
  7866. #define USBPHY_PWD_TXPWDIBIAS ((uint32_t)(1<<11))
  7867. #define USBPHY_PWD_TXPWDFS ((uint32_t)(1<<10))
  7868. #define USBPHY_TX_USBPHY_TX_EDGECTRL(n) ((uint32_t)(((n) & 0x07) << 26))
  7869. #define USBPHY_TX_TXCAL45DP(n) ((uint32_t)(((n) & 0x0F) << 16))
  7870. #define USBPHY_TX_TXCAL45DN(n) ((uint32_t)(((n) & 0x0F) << 8))
  7871. #define USBPHY_TX_D_CAL(n) ((uint32_t)(((n) & 0x0F) << 0))
  7872. #define USBPHY_RX_RXDBYPASS ((uint32_t)(1<<22))
  7873. #define USBPHY_RX_DISCONADJ(n) ((uint32_t)(((n) & 0x07) << 4))
  7874. #define USBPHY_RX_ENVADJ(n) ((uint32_t)(((n) & 0x07) << 0))
  7875. #define USBPHY_CTRL_SFTRST ((uint32_t)(1<<31))
  7876. #define USBPHY_CTRL_CLKGATE ((uint32_t)(1<<30))
  7877. #define USBPHY_CTRL_UTMI_SUSPENDM ((uint32_t)(1<<29))
  7878. #define USBPHY_CTRL_HOST_FORCE_LS_SE0 ((uint32_t)(1<<28))
  7879. #define USBPHY_CTRL_OTG_ID_VALUE ((uint32_t)(1<<27))
  7880. #define USBPHY_CTRL_FSDLL_RST_EN ((uint32_t)(1<<24))
  7881. #define USBPHY_CTRL_ENVBUSCHG_WKUP ((uint32_t)(1<<23))
  7882. #define USBPHY_CTRL_ENIDCHG_WKUP ((uint32_t)(1<<22))
  7883. #define USBPHY_CTRL_ENDPDMCHG_WKUP ((uint32_t)(1<<21))
  7884. #define USBPHY_CTRL_ENAUTOCLR_PHY_PWD ((uint32_t)(1<<20))
  7885. #define USBPHY_CTRL_ENAUTOCLR_CLKGATE ((uint32_t)(1<<19))
  7886. #define USBPHY_CTRL_ENAUTO_PWRON_PLL ((uint32_t)(1<<18))
  7887. #define USBPHY_CTRL_WAKEUP_IRQ ((uint32_t)(1<<17))
  7888. #define USBPHY_CTRL_ENIRQWAKEUP ((uint32_t)(1<<16))
  7889. #define USBPHY_CTRL_ENUTMILEVEL3 ((uint32_t)(1<<15))
  7890. #define USBPHY_CTRL_ENUTMILEVEL2 ((uint32_t)(1<<14))
  7891. #define USBPHY_CTRL_DATA_ON_LRADC ((uint32_t)(1<<13))
  7892. #define USBPHY_CTRL_DEVPLUGIN_IRQ ((uint32_t)(1<<12))
  7893. #define USBPHY_CTRL_ENIRQDEVPLUGIN ((uint32_t)(1<<11))
  7894. #define USBPHY_CTRL_RESUME_IRQ ((uint32_t)(1<<10))
  7895. #define USBPHY_CTRL_ENIRQRESUMEDETECT ((uint32_t)(1<<9))
  7896. #define USBPHY_CTRL_RESUMEIRQSTICKY ((uint32_t)(1<<8))
  7897. #define USBPHY_CTRL_ENOTGIDDETECT ((uint32_t)(1<<7))
  7898. #define USBPHY_CTRL_OTG_ID_CHG_IRQ ((uint32_t)(1<<6))
  7899. #define USBPHY_CTRL_DEVPLUGIN_POLARITY ((uint32_t)(1<<5))
  7900. #define USBPHY_CTRL_ENDEVPLUGINDETECT ((uint32_t)(1<<4))
  7901. #define USBPHY_CTRL_HOSTDISCONDETECT_IRQ ((uint32_t)(1<<3))
  7902. #define USBPHY_CTRL_ENIRQHOSTDISCON ((uint32_t)(1<<2))
  7903. #define USBPHY_CTRL_ENHOSTDISCONDETECT ((uint32_t)(1<<1))
  7904. #define USBPHY_CTRL_ENOTG_ID_CHG_IRQ ((uint32_t)(1<<0))
  7905. // 57.9.1.1: page 3381
  7906. #define IMXRT_USDHC1 (*(IMXRT_REGISTER32_t *)0x402C0000)
  7907. #define USDHC1_DS_ADDR (IMXRT_USDHC1.offset000)
  7908. #define USDHC1_BLK_ATT (IMXRT_USDHC1.offset004)
  7909. #define USDHC1_CMD_ARG (IMXRT_USDHC1.offset008)
  7910. #define USDHC1_CMD_XFR_TYP (IMXRT_USDHC1.offset00C)
  7911. #define USDHC1_CMD_RSP0 (IMXRT_USDHC1.offset010)
  7912. #define USDHC1_CMD_RSP1 (IMXRT_USDHC1.offset014)
  7913. #define USDHC1_CMD_RSP2 (IMXRT_USDHC1.offset018)
  7914. #define USDHC1_CMD_RSP3 (IMXRT_USDHC1.offset01C)
  7915. #define USDHC1_DATA_BUFF_ACC_PORT (IMXRT_USDHC1.offset020)
  7916. #define USDHC1_PRES_STATE (IMXRT_USDHC1.offset024)
  7917. #define USDHC1_PROT_CTRL (IMXRT_USDHC1.offset028)
  7918. #define USDHC1_SYS_CTRL (IMXRT_USDHC1.offset02C)
  7919. #define USDHC1_INT_STATUS (IMXRT_USDHC1.offset030)
  7920. #define USDHC1_INT_STATUS_EN (IMXRT_USDHC1.offset034)
  7921. #define USDHC1_INT_SIGNAL_EN (IMXRT_USDHC1.offset038)
  7922. #define USDHC1_AUTOCMD12_ERR_STATUS (IMXRT_USDHC1.offset03C)
  7923. #define USDHC1_HOST_CTRL_CAP (IMXRT_USDHC1.offset040)
  7924. #define USDHC1_WTMK_LVL (IMXRT_USDHC1.offset044)
  7925. #define USDHC1_MIX_CTRL (IMXRT_USDHC1.offset048)
  7926. #define USDHC1_FORCE_EVENT (IMXRT_USDHC1.offset050)
  7927. #define USDHC1_ADMA_ERR_STATUS (IMXRT_USDHC1.offset054)
  7928. #define USDHC1_ADMA_SYS_ADDR (IMXRT_USDHC1.offset058)
  7929. #define USDHC1_DLL_CTRL (IMXRT_USDHC1.offset060)
  7930. #define USDHC1_DLL_STATUS (IMXRT_USDHC1.offset064)
  7931. #define USDHC1_CLK_TUNE_CTRL_STATUS (IMXRT_USDHC1.offset068)
  7932. #define USDHC1_VEND_SPEC (IMXRT_USDHC1.offset0C0)
  7933. #define USDHC1_MMC_BOOT (IMXRT_USDHC1.offset0C4)
  7934. #define USDHC1_VEND_SPEC2 (IMXRT_USDHC1.offset0C8)
  7935. #define USDHC1_TUNING_CTRL (IMXRT_USDHC1.offset0CC)
  7936. #define IMXRT_USDHC2 (*(IMXRT_REGISTER32_t *)0x402C4000)
  7937. #define USDHC2_DS_ADDR (IMXRT_USDHC2.offset000)
  7938. #define USDHC2_BLK_ATT (IMXRT_USDHC2.offset004)
  7939. #define USDHC2_CMD_ARG (IMXRT_USDHC2.offset008)
  7940. #define USDHC2_CMD_XFR_TYP (IMXRT_USDHC2.offset00C)
  7941. #define USDHC2_CMD_RSP0 (IMXRT_USDHC2.offset010)
  7942. #define USDHC2_CMD_RSP1 (IMXRT_USDHC2.offset014)
  7943. #define USDHC2_CMD_RSP2 (IMXRT_USDHC2.offset018)
  7944. #define USDHC2_CMD_RSP3 (IMXRT_USDHC2.offset01C)
  7945. #define USDHC2_DATA_BUFF_ACC_PORT (IMXRT_USDHC2.offset020)
  7946. #define USDHC2_PRES_STATE (IMXRT_USDHC2.offset024)
  7947. #define USDHC2_PROT_CTRL (IMXRT_USDHC2.offset028)
  7948. #define USDHC2_SYS_CTRL (IMXRT_USDHC2.offset02C)
  7949. #define USDHC2_INT_STATUS (IMXRT_USDHC2.offset030)
  7950. #define USDHC2_INT_STATUS_EN (IMXRT_USDHC2.offset034)
  7951. #define USDHC2_INT_SIGNAL_EN (IMXRT_USDHC2.offset038)
  7952. #define USDHC2_AUTOCMD12_ERR_STATUS (IMXRT_USDHC2.offset03C)
  7953. #define USDHC2_HOST_CTRL_CAP (IMXRT_USDHC2.offset040)
  7954. #define USDHC2_WTMK_LVL (IMXRT_USDHC2.offset044)
  7955. #define USDHC2_MIX_CTRL (IMXRT_USDHC2.offset048)
  7956. #define USDHC2_FORCE_EVENT (IMXRT_USDHC2.offset050)
  7957. #define USDHC2_ADMA_ERR_STATUS (IMXRT_USDHC2.offset054)
  7958. #define USDHC2_ADMA_SYS_ADDR (IMXRT_USDHC2.offset058)
  7959. #define USDHC2_DLL_CTRL (IMXRT_USDHC2.offset060)
  7960. #define USDHC2_DLL_STATUS (IMXRT_USDHC2.offset064)
  7961. #define USDHC2_CLK_TUNE_CTRL_STATUS (IMXRT_USDHC2.offset068)
  7962. #define USDHC2_VEND_SPEC (IMXRT_USDHC2.offset0C0)
  7963. #define USDHC2_MMC_BOOT (IMXRT_USDHC2.offset0C4)
  7964. #define USDHC2_VEND_SPEC2 (IMXRT_USDHC2.offset0C8)
  7965. #define USDHC2_TUNING_CTRL (IMXRT_USDHC2.offset0CC)
  7966. // 58.7.1.1: page 3461
  7967. #define IMXRT_WDOG1 (*(IMXRT_REGISTER16_t *)0x400B8000)
  7968. #define WDOG1_WCR (IMXRT_WDOG1.offset000)
  7969. #define WDOG1_WSR (IMXRT_WDOG1.offset002)
  7970. #define WDOG1_WRSR (IMXRT_WDOG1.offset004)
  7971. #define WDOG1_WICR (IMXRT_WDOG1.offset006)
  7972. #define WDOG1_WMCR (IMXRT_WDOG1.offset008)
  7973. #define IMXRT_WDOG2 (*(IMXRT_REGISTER16_t *)0x400D0000)
  7974. #define WDOG2_WCR (IMXRT_WDOG2.offset000)
  7975. #define WDOG2_WSR (IMXRT_WDOG2.offset002)
  7976. #define WDOG2_WRSR (IMXRT_WDOG2.offset004)
  7977. #define WDOG2_WICR (IMXRT_WDOG2.offset006)
  7978. #define WDOG2_WMCR (IMXRT_WDOG2.offset008)
  7979. #define WDOG_WCR_WDZST ((uint16_t)(1<<0))
  7980. #define WDOG_WCR_WDBG ((uint16_t)(1<<1))
  7981. #define WDOG_WCR_WDE ((uint16_t)(1<<2))
  7982. #define WDOG_WCR_WDT ((uint16_t)(1<<3))
  7983. #define WDOG_WCR_SRS ((uint16_t)(1<<4))
  7984. #define WDOG_WCR_WDA ((uint16_t)(1<<5))
  7985. #define WDOG_WCR_SRE ((uint16_t)(1<<6))
  7986. #define WDOG_WCR_WDW ((uint16_t)(1<<7))
  7987. #define WDOG_WCR_WT(n) ((uint16_t)(((n) & 0xFF) << 8))
  7988. #define WDOG_WRSR_SFTW ((uint16_t)(1<<0))
  7989. #define WDOG_WRSR_TOUT ((uint16_t)(1<<1))
  7990. #define WDOG_WRSR_POR ((uint16_t)(1<<4))
  7991. // 59.3.1.1: page 3471
  7992. #define IMXRT_WDOG3 (*(IMXRT_REGISTER32_t *)0x400BC000)
  7993. #define WDOG3_CS (IMXRT_WDOG3.offset000)
  7994. #define WDOG3_CNT (IMXRT_WDOG3.offset004)
  7995. #define WDOG3_TOVAL (IMXRT_WDOG3.offset008)
  7996. #define WDOG3_WIN (IMXRT_WDOG3.offset00C)
  7997. #define WDOG_CS_STOP ((uint16_t)(1<<0))
  7998. #define WDOG_CS_WAIT ((uint16_t)(1<<1))
  7999. #define WDOG_CS_DBG ((uint16_t)(1<<2))
  8000. #define WDOG_CS_TST(n) ((uint16_t)(((n) & 0x03) << 3))
  8001. #define WDOG_CS_UPDATE ((uint16_t)(1<<5))
  8002. #define WDOG_CS_INT ((uint16_t)(1<<6))
  8003. #define WDOG_CS_EN ((uint16_t)(1<<7))
  8004. #define WDOG_CS_CLK(n) ((uint16_t)(((n) & 0x03) << 8))
  8005. #define WDOG_CS_RCS ((uint16_t)(1<<10))
  8006. #define WDOG_CS_ULK ((uint16_t)(1<<11))
  8007. #define WDOG_CS_PRES ((uint16_t)(1<<12))
  8008. #define WDOG_CS_CMD32EN ((uint16_t)(1<<13))
  8009. #define WDOG_CS_FLG ((uint16_t)(1<<14))
  8010. #define WDOG_CS_WIN ((uint16_t)(1<<15))
  8011. // 60.4: page 3491
  8012. #define IMXRT_XBARA1 (*(IMXRT_REGISTER16_t *)0x403BC000)
  8013. #define XBARA1_SEL0 (IMXRT_XBARA1.offset000)
  8014. #define XBARA1_SEL1 (IMXRT_XBARA1.offset002)
  8015. #define XBARA1_SEL2 (IMXRT_XBARA1.offset004)
  8016. #define XBARA1_SEL3 (IMXRT_XBARA1.offset006)
  8017. #define XBARA1_SEL4 (IMXRT_XBARA1.offset008)
  8018. #define XBARA1_SEL5 (IMXRT_XBARA1.offset00A)
  8019. #define XBARA1_SEL6 (IMXRT_XBARA1.offset00C)
  8020. #define XBARA1_SEL7 (IMXRT_XBARA1.offset00E)
  8021. #define XBARA1_SEL8 (IMXRT_XBARA1.offset010)
  8022. #define XBARA1_SEL9 (IMXRT_XBARA1.offset012)
  8023. #define XBARA1_SEL10 (IMXRT_XBARA1.offset014)
  8024. #define XBARA1_SEL11 (IMXRT_XBARA1.offset016)
  8025. #define XBARA1_SEL12 (IMXRT_XBARA1.offset018)
  8026. #define XBARA1_SEL13 (IMXRT_XBARA1.offset01A)
  8027. #define XBARA1_SEL14 (IMXRT_XBARA1.offset01C)
  8028. #define XBARA1_SEL15 (IMXRT_XBARA1.offset01E)
  8029. #define XBARA1_SEL16 (IMXRT_XBARA1.offset020)
  8030. #define XBARA1_SEL17 (IMXRT_XBARA1.offset022)
  8031. #define XBARA1_SEL18 (IMXRT_XBARA1.offset024)
  8032. #define XBARA1_SEL19 (IMXRT_XBARA1.offset026)
  8033. #define XBARA1_SEL20 (IMXRT_XBARA1.offset028)
  8034. #define XBARA1_SEL21 (IMXRT_XBARA1.offset02A)
  8035. #define XBARA1_SEL22 (IMXRT_XBARA1.offset02C)
  8036. #define XBARA1_SEL23 (IMXRT_XBARA1.offset02E)
  8037. #define XBARA1_SEL24 (IMXRT_XBARA1.offset030)
  8038. #define XBARA1_SEL25 (IMXRT_XBARA1.offset032)
  8039. #define XBARA1_SEL26 (IMXRT_XBARA1.offset034)
  8040. #define XBARA1_SEL27 (IMXRT_XBARA1.offset036)
  8041. #define XBARA1_SEL28 (IMXRT_XBARA1.offset038)
  8042. #define XBARA1_SEL29 (IMXRT_XBARA1.offset03A)
  8043. #define XBARA1_CTRL0 (IMXRT_XBARA1.offset03C)
  8044. #define XBARA1_CTRL1 (IMXRT_XBARA1.offset03E)
  8045. // 61.3: page 3537
  8046. #define IMXRT_XBARB2 (*(IMXRT_REGISTER16_t *)0x403C0000)
  8047. #define XBARB2_SEL0 (IMXRT_XBARB2.offset000)
  8048. #define XBARB2_SEL1 (IMXRT_XBARB2.offset002)
  8049. #define XBARB2_SEL2 (IMXRT_XBARB2.offset004)
  8050. #define XBARB2_SEL3 (IMXRT_XBARB2.offset006)
  8051. #define XBARB2_SEL4 (IMXRT_XBARB2.offset008)
  8052. #define XBARB2_SEL5 (IMXRT_XBARB2.offset00A)
  8053. #define XBARB2_SEL6 (IMXRT_XBARB2.offset00C)
  8054. #define XBARB2_SEL7 (IMXRT_XBARB2.offset00E)
  8055. #define IMXRT_XBARB3 (*(IMXRT_REGISTER16_t *)0x403C4000)
  8056. #define XBARB3_SEL0 (IMXRT_XBARB3.offset000)
  8057. #define XBARB3_SEL1 (IMXRT_XBARB3.offset002)
  8058. #define XBARB3_SEL2 (IMXRT_XBARB3.offset004)
  8059. #define XBARB3_SEL3 (IMXRT_XBARB3.offset006)
  8060. #define XBARB3_SEL4 (IMXRT_XBARB3.offset008)
  8061. #define XBARB3_SEL5 (IMXRT_XBARB3.offset00A)
  8062. #define XBARB3_SEL6 (IMXRT_XBARB3.offset00C)
  8063. #define XBARB3_SEL7 (IMXRT_XBARB3.offset00E)
  8064. // 62.5: page 3548
  8065. #define IMXRT_XTALOSC24M (*(IMXRT_REGISTER32_t *)0x400D8000)
  8066. #define XTALOSC24M_MISC0 (IMXRT_XTALOSC24M.offset150)
  8067. #define XTALOSC24M_LOWPWR_CTRL (IMXRT_XTALOSC24M.offset270)
  8068. #define XTALOSC24M_LOWPWR_CTRL_SET (IMXRT_XTALOSC24M.offset274)
  8069. #define XTALOSC24M_LOWPWR_CTRL_CLR (IMXRT_XTALOSC24M.offset278)
  8070. #define XTALOSC24M_LOWPWR_CTRL_TOG (IMXRT_XTALOSC24M.offset27C)
  8071. #define XTALOSC24M_OSC_CONFIG0 (IMXRT_XTALOSC24M.offset2A0)
  8072. #define XTALOSC24M_OSC_CONFIG0_SET (IMXRT_XTALOSC24M.offset2A4)
  8073. #define XTALOSC24M_OSC_CONFIG0_CLR (IMXRT_XTALOSC24M.offset2A8)
  8074. #define XTALOSC24M_OSC_CONFIG0_TOG (IMXRT_XTALOSC24M.offset2AC)
  8075. #define XTALOSC24M_OSC_CONFIG1 (IMXRT_XTALOSC24M.offset2B0)
  8076. #define XTALOSC24M_OSC_CONFIG1_SET (IMXRT_XTALOSC24M.offset2B4)
  8077. #define XTALOSC24M_OSC_CONFIG1_CLR (IMXRT_XTALOSC24M.offset2B8)
  8078. #define XTALOSC24M_OSC_CONFIG1_TOG (IMXRT_XTALOSC24M.offset2BC)
  8079. #define XTALOSC24M_OSC_CONFIG2 (IMXRT_XTALOSC24M.offset2C0)
  8080. #define XTALOSC24M_OSC_CONFIG2_SET (IMXRT_XTALOSC24M.offset2C4)
  8081. #define XTALOSC24M_OSC_CONFIG2_CLR (IMXRT_XTALOSC24M.offset2C8)
  8082. #define XTALOSC24M_OSC_CONFIG2_TOG (IMXRT_XTALOSC24M.offset2CC)
  8083. // 0 = highest priority
  8084. // Cortex-M7: 0,16,32,48,64,80,96,112,128,144,160,176,192,208,224,240
  8085. #define NVIC_SET_PRIORITY(irqnum, priority) (*((volatile uint8_t *)0xE000E400 + (irqnum)) = (uint8_t)(priority))
  8086. #define NVIC_GET_PRIORITY(irqnum) (*((uint8_t *)0xE000E400 + (irqnum)))
  8087. #define __disable_irq() __asm__ volatile("CPSID i":::"memory");
  8088. #define __enable_irq() __asm__ volatile("CPSIE i":::"memory");
  8089. // System Control Space (SCS), ARMv7 ref manual, B3.2, page 708
  8090. #define SCB_CPUID (*(const uint32_t *)0xE000ED00) // CPUID Base Register
  8091. #define SCB_ICSR (*(volatile uint32_t *)0xE000ED04) // Interrupt Control and State
  8092. #define SCB_ICSR_NMIPENDSET ((uint32_t)(1<<31))
  8093. #define SCB_ICSR_PENDSVSET ((uint32_t)(1<<28))
  8094. #define SCB_ICSR_PENDSVCLR ((uint32_t)(1<<27))
  8095. #define SCB_ICSR_PENDSTSET ((uint32_t)(1<<26))
  8096. #define SCB_ICSR_PENDSTCLR ((uint32_t)(1<<25))
  8097. #define SCB_ICSR_ISRPREEMPT ((uint32_t)(1<<23))
  8098. #define SCB_ICSR_ISRPENDING ((uint32_t)(1<<22))
  8099. #define SCB_ICSR_RETTOBASE ((uint32_t)(1<<11))
  8100. #define SCB_VTOR (*(volatile uint32_t *)0xE000ED08) // Vector Table Offset
  8101. #define SCB_AIRCR (*(volatile uint32_t *)0xE000ED0C) // Application Interrupt & Reset
  8102. #define SCB_SCR (*(volatile uint32_t *)0xE000ED10) // System Control Register
  8103. #define SCB_SCR_SEVONPEND ((uint8_t)0x10) // Send Event on Pending bit
  8104. #define SCB_SCR_SLEEPDEEP ((uint8_t)0x04) // Sleep or Deep Sleep
  8105. #define SCB_SCR_SLEEPONEXIT ((uint8_t)0x02) // Sleep-on-exit
  8106. #define SCB_CCR (*(volatile uint32_t *)0xE000ED14) // Configuration and Control
  8107. #define SCB_CCR_BP ((uint32_t)(1<<18)) // Branch prediction enable
  8108. #define SCB_CCR_IC ((uint32_t)(1<<17)) // Instruction caches enable
  8109. #define SCB_CCR_DC ((uint32_t)(1<<16))
  8110. #define SCB_CCR_STKALIGN ((uint32_t)(1<<9))
  8111. #define SCB_CCR_BFHFNMIGN ((uint32_t)(1<<8))
  8112. #define SCB_CCR_DIV_0_TRP ((uint32_t)(1<<4))
  8113. #define SCB_CCR_UNALIGN_TRP ((uint32_t)(1<<3))
  8114. #define SCB_CCR_USERSETMPEND ((uint32_t)(1<<1))
  8115. #define SCB_CCR_NONBASETHRDENA ((uint32_t)(1<<0))
  8116. #define SCB_SHPR1 (*(volatile uint32_t *)0xE000ED18) // System Handler Priority 1
  8117. #define SCB_SHPR2 (*(volatile uint32_t *)0xE000ED1C) // System Handler Priority 2
  8118. #define SCB_SHPR3 (*(volatile uint32_t *)0xE000ED20) // System Handler Priority 3
  8119. #define SCB_SHCSR (*(volatile uint32_t *)0xE000ED24) // System Handler Control & State
  8120. #define SCB_CFSR (*(volatile uint32_t *)0xE000ED28) // Configurable Fault Status
  8121. #define SCB_HFSR (*(volatile uint32_t *)0xE000ED2C) // HardFault Status
  8122. #define SCB_DFSR (*(volatile uint32_t *)0xE000ED30) // Debug Fault Status
  8123. #define SCB_MMFAR (*(volatile uint32_t *)0xE000ED34) // MemManage Fault Address
  8124. #define SCB_BFAR (*(volatile uint32_t *)0xE000ED38) // Bus Fault Address
  8125. #define SCB_AFAR (*(volatile uint32_t *)0xE000ED3C) // Aux Fault Address
  8126. #define SCB_ID_PFR0 (*(const uint32_t *)0xE000ED40) // Processor Feature 0
  8127. #define SCB_ID_PFR1 (*(const uint32_t *)0xE000ED44) // Processor Feature 1
  8128. #define SCB_ID_DFR0 (*(const uint32_t *)0xE000ED48) // Debug Feature 0
  8129. #define SCB_ID_AFR0 (*(const uint32_t *)0xE000ED4C) // Auxiliary Feature 0
  8130. #define SCB_ID_MMFR0 (*(const uint32_t *)0xE000ED50) // Memory Model Feature 0
  8131. #define SCB_ID_MMFR1 (*(const uint32_t *)0xE000ED54) // Memory Model Feature 1
  8132. #define SCB_ID_MMFR2 (*(const uint32_t *)0xE000ED58) // Memory Model Feature 2
  8133. #define SCB_ID_MMFR3 (*(const uint32_t *)0xE000ED5C) // Memory Model Feature 3
  8134. #define SCB_ID_ISAR0 (*(const uint32_t *)0xE000ED60) // Instruction Set Attribute 0
  8135. #define SCB_ID_ISAR1 (*(const uint32_t *)0xE000ED64) // Instruction Set Attribute 1
  8136. #define SCB_ID_ISAR2 (*(const uint32_t *)0xE000ED68) // Instruction Set Attribute 2
  8137. #define SCB_ID_ISAR3 (*(const uint32_t *)0xE000ED6C) // Instruction Set Attribute 3
  8138. #define SCB_ID_ISAR4 (*(const uint32_t *)0xE000ED70) // Instruction Set Attribute 4
  8139. #define SCB_ID_CLIDR (*(const uint32_t *)0xE000ED78) // Cache Level ID
  8140. #define SCB_ID_CTR (*(const uint32_t *)0xE000ED7C) // Cache Type
  8141. #define SCB_ID_CCSIDR (*(const uint32_t *)0xE000ED80) // Cache Size ID
  8142. #define SCB_ID_CSSELR (*(const uint32_t *)0xE000ED84) // Cache Size Selection
  8143. #define SCB_CPACR (*(volatile uint32_t *)0xE000ED88) // Coprocessor Access Control
  8144. #define SCB_FPCCR (*(volatile uint32_t *)0xE000EF34) // FP Context Control
  8145. #define SCB_FPCAR (*(volatile uint32_t *)0xE000EF38) // FP Context Address
  8146. #define SCB_FPDSCR (*(volatile uint32_t *)0xE000EF3C) // FP Default Status Control
  8147. #define SCB_MVFR0 (*(volatile uint32_t *)0xE000EF40) // Media & FP Feature 0
  8148. #define SCB_MVFR1 (*(volatile uint32_t *)0xE000EF44) // Media & FP Feature 1
  8149. #define SCB_MVFR2 (*(volatile uint32_t *)0xE000EF48) // Media & FP Feature 2
  8150. #define SYST_CSR (*(volatile uint32_t *)0xE000E010) // SysTick Control and Status
  8151. #define SYST_CSR_COUNTFLAG ((uint32_t)(1<<16))
  8152. #define SYST_CSR_CLKSOURCE ((uint32_t)(1<<2))
  8153. #define SYST_CSR_TICKINT ((uint32_t)(1<<1))
  8154. #define SYST_CSR_ENABLE ((uint32_t)(1<<0))
  8155. #define SYST_RVR (*(volatile uint32_t *)0xE000E014) // SysTick Reload Value Register
  8156. #define SYST_CVR (*(volatile uint32_t *)0xE000E018) // SysTick Current Value Register
  8157. #define SYST_CALIB (*(const uint32_t *)0xE000E01C) // SysTick Calibration Value
  8158. // Nested Vectored Interrupt Controller, Table 3-4 & ARMv7 ref, appendix B3.4 (page 750)
  8159. #define NVIC_ISER0 (*(volatile uint32_t *)0xE000E100)
  8160. #define NVIC_ISER1 (*(volatile uint32_t *)0xE000E104)
  8161. #define NVIC_ISER2 (*(volatile uint32_t *)0xE000E108)
  8162. #define NVIC_ISER3 (*(volatile uint32_t *)0xE000E10C)
  8163. #define NVIC_ISER4 (*(volatile uint32_t *)0xE000E110)
  8164. #define NVIC_ICER0 (*(volatile uint32_t *)0xE000E180)
  8165. #define NVIC_ICER1 (*(volatile uint32_t *)0xE000E184)
  8166. #define NVIC_ICER2 (*(volatile uint32_t *)0xE000E188)
  8167. #define NVIC_ICER3 (*(volatile uint32_t *)0xE000E18C)
  8168. #define NVIC_ICER4 (*(volatile uint32_t *)0xE000E190)
  8169. #define NVIC_STIR (*(volatile uint32_t *)0xE000EF00)
  8170. #define NVIC_ENABLE_IRQ(n) (*(&NVIC_ISER0 + ((n) >> 5)) = (1 << ((n) & 31)))
  8171. #define NVIC_DISABLE_IRQ(n) (*(&NVIC_ICER0 + ((n) >> 5)) = (1 << ((n) & 31)))
  8172. #define NVIC_SET_PENDING(n) (*((volatile uint32_t *)0xE000E200 + ((n) >> 5)) = (1 << ((n) & 31)))
  8173. #define NVIC_CLEAR_PENDING(n) (*((volatile uint32_t *)0xE000E280 + ((n) >> 5)) = (1 << ((n) & 31)))
  8174. #define NVIC_IS_ENABLED(n) (*(&NVIC_ISER0 + ((n) >> 5)) & (1 << ((n) & 31)))
  8175. #define NVIC_IS_PENDING(n) (*((volatile uint32_t *)0xE000E200 + ((n) >> 5)) & (1 << ((n) & 31)))
  8176. #define NVIC_IS_ACTIVE(n) (*((volatile uint32_t *)0xE000E300 + ((n) >> 5)) & (1 << ((n) & 31)))
  8177. #define NVIC_TRIGGER_IRQ(n) NVIC_STIR=(n)
  8178. #define ARM_DEMCR (*(volatile uint32_t *)0xE000EDFC) // Debug Exception and Monitor Control
  8179. #define ARM_DEMCR_TRCENA (1 << 24) // Enable debugging & monitoring blocks
  8180. #define ARM_DWT_CTRL (*(volatile uint32_t *)0xE0001000) // DWT control register
  8181. #define ARM_DWT_CTRL_CYCCNTENA (1 << 0) // Enable cycle count
  8182. #define ARM_DWT_CYCCNT (*(volatile uint32_t *)0xE0001004) // Cycle count register
  8183. #define SCB_MPU_TYPE (*(volatile uint32_t *)0xE000ED90) //
  8184. #define SCB_MPU_CTRL (*(volatile uint32_t *)0xE000ED94) //
  8185. #define SCB_MPU_CTRL_PRIVDEFENA ((uint32_t)(1<<2)) // Enables default memory map
  8186. #define SCB_MPU_CTRL_HFNMIENA ((uint32_t)(1<<1)) // Use MPU for HardFault & NMI
  8187. #define SCB_MPU_CTRL_ENABLE ((uint32_t)(1<<0)) // Enables MPU
  8188. #define SCB_MPU_RNR (*(volatile uint32_t *)0xE000ED98) //
  8189. #define SCB_MPU_RBAR (*(volatile uint32_t *)0xE000ED9C) //
  8190. #define SCB_MPU_RBAR_ADDR_MASK ((uint32_t)(0xFFFFFFE0))
  8191. #define SCB_MPU_RBAR_VALID ((uint32_t)(1<<4))
  8192. #define SCB_MPU_RBAR_REGION(n) ((uint32_t)((n) & 15))
  8193. #define SCB_MPU_RASR (*(volatile uint32_t *)0xE000EDA0) // ARM DDI0403E, pg 696
  8194. #define SCB_MPU_RASR_XN ((uint32_t)(1<<28))
  8195. #define SCB_MPU_RASR_AP(n) ((uint32_t)(((n) & 7) << 24))
  8196. #define SCB_MPU_RASR_TEX(n) ((uint32_t)(((n) & 7) << 19))
  8197. #define SCB_MPU_RASR_S ((uint32_t)(1<<18))
  8198. #define SCB_MPU_RASR_C ((uint32_t)(1<<17))
  8199. #define SCB_MPU_RASR_B ((uint32_t)(1<<16))
  8200. #define SCB_MPU_RASR_SRD(n) ((uint32_t)(((n) & 255) << 8))
  8201. #define SCB_MPU_RASR_SIZE(n) ((uint32_t)(((n) & 31) << 1))
  8202. #define SCB_MPU_RASR_ENABLE ((uint32_t)(1<<0))
  8203. #define SCB_MPU_RBAR_A1 (*(volatile uint32_t *)0xE000EDA4) //
  8204. #define SCB_MPU_RASR_A1 (*(volatile uint32_t *)0xE000EDA8) //
  8205. #define SCB_MPU_RBAR_A2 (*(volatile uint32_t *)0xE000EDAC) //
  8206. #define SCB_MPU_RASR_A2 (*(volatile uint32_t *)0xE000EDB0) //
  8207. #define SCB_MPU_RBAR_A3 (*(volatile uint32_t *)0xE000EDB4) //
  8208. #define SCB_MPU_RASR_A3 (*(volatile uint32_t *)0xE000EDB8) //
  8209. #define SCB_CACHE_ICIALLU (*(volatile uint32_t *)0xE000EF50)
  8210. #define SCB_CACHE_ICIMVAU (*(volatile uint32_t *)0xE000EF58)
  8211. #define SCB_CACHE_DCIMVAC (*(volatile uint32_t *)0xE000EF5C)
  8212. #define SCB_CACHE_DCISW (*(volatile uint32_t *)0xE000EF60)
  8213. #define SCB_CACHE_DCCMVAU (*(volatile uint32_t *)0xE000EF64)
  8214. #define SCB_CACHE_DCCMVAC (*(volatile uint32_t *)0xE000EF68)
  8215. #define SCB_CACHE_DCCSW (*(volatile uint32_t *)0xE000EF6C)
  8216. #define SCB_CACHE_DCCIMVAC (*(volatile uint32_t *)0xE000EF70)
  8217. #define SCB_CACHE_DCCISW (*(volatile uint32_t *)0xE000EF74)
  8218. #define SCB_CACHE_BPIALL (*(volatile uint32_t *)0xE000EF78)
  8219. // Flush data from cache to memory
  8220. //
  8221. // Normally arm_dcache_flush() is used when metadata written to memory
  8222. // will be used by a DMA or a bus-master peripheral. Any data in the
  8223. // cache is written to memory. A copy remains in the cache, so this is
  8224. // typically used with special fields you will want to quickly access
  8225. // in the future. For data transmission, use arm_dcache_flush_delete().
  8226. __attribute__((always_inline, unused))
  8227. static inline void arm_dcache_flush(void *addr, uint32_t size)
  8228. {
  8229. uint32_t location = (uint32_t)addr & 0xFFFFFFE0;
  8230. uint32_t end_addr = (uint32_t)addr + size;
  8231. asm("dsb");
  8232. do {
  8233. SCB_CACHE_DCCMVAC = location;
  8234. location += 32;
  8235. } while (location < end_addr);
  8236. asm("dsb");
  8237. asm("isb");
  8238. }
  8239. // Delete data from the cache, without touching memory
  8240. //
  8241. // Normally arm_dcache_delete() is used before receiving data via
  8242. // DMA or from bus-master peripherals which write to memory. You
  8243. // want to delete anything the cache may have stored, so your next
  8244. // read is certain to access the physical memory.
  8245. __attribute__((always_inline, unused))
  8246. static inline void arm_dcache_delete(void *addr, uint32_t size)
  8247. {
  8248. uint32_t location = (uint32_t)addr & 0xFFFFFFE0;
  8249. uint32_t end_addr = (uint32_t)addr + size;
  8250. asm("dsb");
  8251. do {
  8252. SCB_CACHE_DCIMVAC = location;
  8253. location += 32;
  8254. } while (location < end_addr);
  8255. asm("dsb");
  8256. asm("isb");
  8257. }
  8258. // Flush data from cache to memory, and delete it from the cache
  8259. //
  8260. // Normally arm_dcache_flush_delete() is used when transmitting data
  8261. // via DMA or bus-master peripherals which read from memory. You want
  8262. // any cached data written to memory, and then removed from the cache,
  8263. // because you no longer need to access the data after transmission.
  8264. __attribute__((always_inline, unused))
  8265. static inline void arm_dcache_flush_delete(void *addr, uint32_t size)
  8266. {
  8267. uint32_t location = (uint32_t)addr & 0xFFFFFFE0;
  8268. uint32_t end_addr = (uint32_t)addr + size;
  8269. asm("dsb");
  8270. do {
  8271. SCB_CACHE_DCCIMVAC = location;
  8272. location += 32;
  8273. } while (location < end_addr);
  8274. asm("dsb");
  8275. asm("isb");
  8276. }