apm32f10x.h 180 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229
  1. /*!
  2. * @file apm32f10x.h
  3. *
  4. * @brief CMSIS Cortex-M3 Device Peripheral Access Layer Header File.
  5. *
  6. * @details This file contains all the peripheral register's definitions, bits definitions and memory mapping
  7. *
  8. * @version V1.0.2
  9. *
  10. * @date 2022-01-05
  11. *
  12. * @attention
  13. *
  14. * Copyright (C) 2020-2022 Geehy Semiconductor
  15. *
  16. * You may not use this file except in compliance with the
  17. * GEEHY COPYRIGHT NOTICE (GEEHY SOFTWARE PACKAGE LICENSE).
  18. *
  19. * The program is only for reference, which is distributed in the hope
  20. * that it will be usefull and instructional for customers to develop
  21. * their software. Unless required by applicable law or agreed to in
  22. * writing, the program is distributed on an "AS IS" BASIS, WITHOUT
  23. * ANY WARRANTY OR CONDITIONS OF ANY KIND, either express or implied.
  24. * See the GEEHY SOFTWARE PACKAGE LICENSE for the governing permissions
  25. * and limitations under the License.
  26. */
  27. #ifndef __APM32F10X_H
  28. #define __APM32F10X_H
  29. #ifdef __cplusplus
  30. extern "C" {
  31. #endif
  32. /*!
  33. * APM32F10X_LD: APM32 Low density devices, the Flash memory density ranges between 16 and 32 Kbytes.
  34. * APM32F10X_MD: APM32 Medium density devices, the Flash memory density ranges between 64 and 128 Kbytes.
  35. * APM32F10X_HD: APM32 High density devices, the Flash memory density ranges between 256 and 512 Kbytes.
  36. */
  37. #if !defined (APM32F10X_LD) && !defined (APM32F10X_MD) && !defined (APM32F10X_HD)
  38. #error "Please select a the target APM32F10x device used in your application (in apm32f10x.h file)"
  39. #endif
  40. /**
  41. * @brief Define Value of the External oscillator in Hz
  42. */
  43. #ifndef HSE_VALUE
  44. #define HSE_VALUE ((uint32_t)8000000)
  45. #endif
  46. /** Time out for HSE start up */
  47. #define HSE_STARTUP_TIMEOUT ((uint16_t)0x05000)
  48. /** Value of the Internal oscillator in Hz */
  49. #define HSI_VALUE ((uint32_t)8000000)
  50. /**
  51. * @brief APM32F10x Standard Peripheral Library version number
  52. */
  53. #define __APM32F10X_STDPERIPH_VERSION_MAIN (0x01) /*!< [31:24] main version */
  54. #define __APM32F10X_STDPERIPH_VERSION_SUB1 (0x00) /*!< [23:16] sub1 version */
  55. #define __APM32F10X_STDPERIPH_VERSION_SUB2 (0x02) /*!< [15:8] sub2 version */
  56. #define __APM32F10X_STDPERIPH_VERSION_RC (0x00) /*!< [7:0] release candidate */
  57. #define __APM32F10X_STDPERIPH_VERSION ( (__APM32F10X_STDPERIPH_VERSION_MAIN << 24)\
  58. |(__APM32F10X_STDPERIPH_VERSION_SUB1 << 16)\
  59. |(__APM32F10X_STDPERIPH_VERSION_SUB2 << 8)\
  60. |(__APM32F10X_STDPERIPH_VERSION_RC))
  61. /** APM32 devices does not provide an MPU */
  62. #define __MPU_PRESENT 0
  63. /** APM32 uses 4 Bits for the Priority Levels */
  64. #define __NVIC_PRIO_BITS 4
  65. /** Set to 1 if different SysTick Config is used */
  66. #define __Vendor_SysTickConfig 0
  67. /**
  68. * @brief APM32F10x Interrupt Number Definition, according to the selected device
  69. * in @ref Library_configuration_section
  70. */
  71. typedef enum IRQn
  72. {
  73. /****** Cortex-M3 Processor Exceptions Numbers ***************************************************/
  74. NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */
  75. MemoryManagement_IRQn = -12, /*!< 4 Cortex-M3 Memory Management Interrupt */
  76. BusFault_IRQn = -11, /*!< 5 Cortex-M3 Bus Fault Interrupt */
  77. UsageFault_IRQn = -10, /*!< 6 Cortex-M3 Usage Fault Interrupt */
  78. SVCall_IRQn = -5, /*!< 11 Cortex-M3 SV Call Interrupt */
  79. DebugMonitor_IRQn = -4, /*!< 12 Cortex-M3 Debug Monitor Interrupt */
  80. PendSV_IRQn = -2, /*!< 14 Cortex-M3 Pend SV Interrupt */
  81. SysTick_IRQn = -1, /*!< 15 Cortex-M3 System Tick Interrupt */
  82. /****** APM32 specific Interrupt Numbers *********************************************************/
  83. WWDT_IRQn = 0, /*!< Window WatchDog Interrupt */
  84. PVD_IRQn = 1, /*!< PVD through EINT Line detection Interrupt */
  85. TAMPER_IRQn = 2, /*!< Tamper Interrupt */
  86. RTC_IRQn = 3, /*!< RTC global Interrupt */
  87. FLASH_IRQn = 4, /*!< FLASH global Interrupt */
  88. RCM_IRQn = 5, /*!< RCM global Interrupt */
  89. EINT0_IRQn = 6, /*!< EINT Line0 Interrupt */
  90. EINT1_IRQn = 7, /*!< EINT Line1 Interrupt */
  91. EINT2_IRQn = 8, /*!< EINT Line2 Interrupt */
  92. EINT3_IRQn = 9, /*!< EINT Line3 Interrupt */
  93. EINT4_IRQn = 10, /*!< EINT Line4 Interrupt */
  94. DMA1_Channel1_IRQn = 11, /*!< DMA1 Channel 1 global Interrupt */
  95. DMA1_Channel2_IRQn = 12, /*!< DMA1 Channel 2 global Interrupt */
  96. DMA1_Channel3_IRQn = 13, /*!< DMA1 Channel 3 global Interrupt */
  97. DMA1_Channel4_IRQn = 14, /*!< DMA1 Channel 4 global Interrupt */
  98. DMA1_Channel5_IRQn = 15, /*!< DMA1 Channel 5 global Interrupt */
  99. DMA1_Channel6_IRQn = 16, /*!< DMA1 Channel 6 global Interrupt */
  100. DMA1_Channel7_IRQn = 17, /*!< DMA1 Channel 7 global Interrupt */
  101. #if defined (APM32F10X_LD)
  102. /** APM32F10X Low-density devices specific Interrupt Numbers */
  103. ADC1_2_IRQn = 18, /*!< ADC1 and ADC2 global Interrupt */
  104. USBD1_HP_CAN1_TX_IRQn = 19, /*!< USB Device 1 High Priority or CAN1 TX Interrupts */
  105. USBD1_LP_CAN1_RX0_IRQn = 20, /*!< USB Device 1 Low Priority or CAN1 RX0 Interrupts */
  106. CAN1_RX1_IRQn = 21, /*!< CAN1 RX1 Interrupt */
  107. CAN1_SCE_IRQn = 22, /*!< CAN1 SCE Interrupt */
  108. EINT9_5_IRQn = 23, /*!< External Line[9:5] Interrupts */
  109. TMR1_BRK_IRQn = 24, /*!< TMR1 Break Interrupt */
  110. TMR1_UP_IRQn = 25, /*!< TMR1 Update Interrupt */
  111. TMR1_TRG_COM_IRQn = 26, /*!< TMR1 Trigger and Commutation Interrupt */
  112. TMR1_CC_IRQn = 27, /*!< TMR1 Capture Compare Interrupt */
  113. TMR2_IRQn = 28, /*!< TMR2 global Interrupt */
  114. TMR3_IRQn = 29, /*!< TMR3 global Interrupt */
  115. I2C1_EV_IRQn = 31, /*!< I2C1 Event Interrupt */
  116. I2C1_ER_IRQn = 32, /*!< I2C1 Error Interrupt */
  117. SPI1_IRQn = 35, /*!< SPI1 global Interrupt */
  118. USART1_IRQn = 37, /*!< USART1 global Interrupt */
  119. USART2_IRQn = 38, /*!< USART2 global Interrupt */
  120. EINT15_10_IRQn = 40, /*!< External Line[15:10] Interrupts */
  121. RTCAlarm_IRQn = 41, /*!< RTC Alarm through EINT Line Interrupt */
  122. USBDWakeUp_IRQn = 42, /*!< USB Device WakeUp from suspend through EINT Line Interrupt */
  123. FPU_IRQn = 43, /*!< FPU Global Interrupt */
  124. QSPI_IRQn = 44, /*!< QSPI Global Interrupt */
  125. USBD2_HP_IRQn = 45, /*!< USB Device 2 High Priority */
  126. USBD2_LP_IRQn = 46 /*!< USB Device 2 Low Priority */
  127. #elif defined (APM32F10X_MD)
  128. /** APM32F10X Medium-density devices specific Interrupt Numbers */
  129. ADC1_2_IRQn = 18, /*!< ADC1 and ADC2 global Interrupt */
  130. USBD1_HP_CAN1_TX_IRQn = 19, /*!< USB Device 1 High Priority or CAN1 TX Interrupts */
  131. USBD1_LP_CAN1_RX0_IRQn = 20, /*!< USB Device 1 Low Priority or CAN1 RX0 Interrupts */
  132. CAN1_RX1_IRQn = 21, /*!< CAN1 RX1 Interrupt */
  133. CAN1_SCE_IRQn = 22, /*!< CAN1 SCE Interrupt */
  134. EINT9_5_IRQn = 23, /*!< External Line[9:5] Interrupts */
  135. TMR1_BRK_IRQn = 24, /*!< TMR1 Break Interrupt */
  136. TMR1_UP_IRQn = 25, /*!< TMR1 Update Interrupt */
  137. TMR1_TRG_COM_IRQn = 26, /*!< TMR1 Trigger and Commutation Interrupt */
  138. TMR1_CC_IRQn = 27, /*!< TMR1 Capture Compare Interrupt */
  139. TMR2_IRQn = 28, /*!< TMR2 global Interrupt */
  140. TMR3_IRQn = 29, /*!< TMR3 global Interrupt */
  141. TMR4_IRQn = 30, /*!< TMR4 global Interrupt */
  142. I2C1_EV_IRQn = 31, /*!< I2C1 Event Interrupt */
  143. I2C1_ER_IRQn = 32, /*!< I2C1 Error Interrupt */
  144. I2C2_EV_IRQn = 33, /*!< I2C2 Event Interrupt */
  145. I2C2_ER_IRQn = 34, /*!< I2C2 Error Interrupt */
  146. SPI1_IRQn = 35, /*!< SPI1 global Interrupt */
  147. SPI2_IRQn = 36, /*!< SPI2 global Interrupt */
  148. USART1_IRQn = 37, /*!< USART1 global Interrupt */
  149. USART2_IRQn = 38, /*!< USART2 global Interrupt */
  150. USART3_IRQn = 39, /*!< USART3 global Interrupt */
  151. EINT15_10_IRQn = 40, /*!< External Line[15:10] Interrupts */
  152. RTCAlarm_IRQn = 41, /*!< RTC Alarm through EINT Line Interrupt */
  153. USBDWakeUp_IRQn = 42, /*!< USB Device WakeUp from suspend through EINT Line Interrupt */
  154. FPU_IRQn = 43, /*!< FPU Global Interrupt */
  155. QSPI_IRQn = 44, /*!< QSPI Global Interrupt */
  156. USBD2_HP_IRQn = 45, /*!< USB Device 2 High Priority */
  157. USBD2_LP_IRQn = 46 /*!< USB Device 2 Low Priority */
  158. #elif defined (APM32F10X_HD)
  159. /** APM32F10X High-density devices specific Interrupt Numbers */
  160. ADC1_2_IRQn = 18, /*!< ADC1 and ADC2 global Interrupt */
  161. USBD1_HP_CAN1_TX_IRQn = 19, /*!< USB Device 1 High Priority or CAN1 TX Interrupts */
  162. USBD1_LP_CAN1_RX0_IRQn = 20, /*!< USB Device 1 Low Priority or CAN1 RX0 Interrupts */
  163. CAN1_RX1_IRQn = 21, /*!< CAN1 RX1 Interrupt */
  164. CAN1_SCE_IRQn = 22, /*!< CAN1 SCE Interrupt */
  165. EINT9_5_IRQn = 23, /*!< External Line[9:5] Interrupts */
  166. TMR1_BRK_IRQn = 24, /*!< TMR1 Break Interrupt */
  167. TMR1_UP_IRQn = 25, /*!< TMR1 Update Interrupt */
  168. TMR1_TRG_COM_IRQn = 26, /*!< TMR1 Trigger and Commutation Interrupt */
  169. TMR1_CC_IRQn = 27, /*!< TMR1 Capture Compare Interrupt */
  170. TMR2_IRQn = 28, /*!< TMR2 global Interrupt */
  171. TMR3_IRQn = 29, /*!< TMR3 global Interrupt */
  172. TMR4_IRQn = 30, /*!< TMR4 global Interrupt */
  173. I2C1_EV_IRQn = 31, /*!< I2C1 Event Interrupt */
  174. I2C1_ER_IRQn = 32, /*!< I2C1 Error Interrupt */
  175. I2C2_EV_IRQn = 33, /*!< I2C2 Event Interrupt */
  176. I2C2_ER_IRQn = 34, /*!< I2C2 Error Interrupt */
  177. SPI1_IRQn = 35, /*!< SPI1 global Interrupt */
  178. SPI2_IRQn = 36, /*!< SPI2 global Interrupt */
  179. USART1_IRQn = 37, /*!< USART1 global Interrupt */
  180. USART2_IRQn = 38, /*!< USART2 global Interrupt */
  181. USART3_IRQn = 39, /*!< USART3 global Interrupt */
  182. EINT15_10_IRQn = 40, /*!< External Line[15:10] Interrupts */
  183. RTCAlarm_IRQn = 41, /*!< RTC Alarm through EINT Line Interrupt */
  184. USBDWakeUp_IRQn = 42, /*!< USB Device WakeUp from suspend through EINT Line Interrupt */
  185. TMR8_BRK_IRQn = 43, /*!< TMR8 Break Interrupt */
  186. TMR8_UP_IRQn = 44, /*!< TMR8 Update Interrupt */
  187. TMR8_TRG_COM_IRQn = 45, /*!< TMR8 Trigger and Commutation Interrupt */
  188. TMR8_CC_IRQn = 46, /*!< TMR8 Capture Compare Interrupt */
  189. ADC3_IRQn = 47, /*!< ADC3 global Interrupt */
  190. EMMC_IRQn = 48, /*!< EMMC global Interrupt */
  191. SDIO_IRQn = 49, /*!< SDIO global Interrupt */
  192. TMR5_IRQn = 50, /*!< TMR5 global Interrupt */
  193. SPI3_IRQn = 51, /*!< SPI3 global Interrupt */
  194. UART4_IRQn = 52, /*!< UART4 global Interrupt */
  195. UART5_IRQn = 53, /*!< UART5 global Interrupt */
  196. TMR6_IRQn = 54, /*!< TMR6 global Interrupt */
  197. TMR7_IRQn = 55, /*!< TMR7 global Interrupt */
  198. DMA2_Channel1_IRQn = 56, /*!< DMA2 Channel 1 global Interrupt */
  199. DMA2_Channel2_IRQn = 57, /*!< DMA2 Channel 2 global Interrupt */
  200. DMA2_Channel3_IRQn = 58, /*!< DMA2 Channel 3 global Interrupt */
  201. DMA2_Channel4_5_IRQn = 59, /*!< DMA2 Channel 4 and Channel 5 global Interrupt */
  202. USBD2_HP_CAN2_TX_IRQn = 61, /*!< USB Device 2 High Priority or CAN2 TX Interrupts */
  203. USBD2_LP_CAN2_RX0_IRQn = 62, /*!< USB Device 2 Low Priority or CAN2 RX0 Interrupts */
  204. CAN2_RX1_IRQn = 63, /*!< CAN2 RX1 Interrupts */
  205. CAN2_SCE_IRQn = 64, /*!< CAN2 SCE Interrupts */
  206. #endif
  207. } IRQn_Type;
  208. /**
  209. * @}
  210. */
  211. #include "core_cm3.h"
  212. #include "system_apm32f10x.h"
  213. #include <stdint.h>
  214. typedef int32_t s32;
  215. typedef int16_t s16;
  216. typedef int8_t s8;
  217. typedef const int32_t sc32;
  218. typedef const int16_t sc16;
  219. typedef const int8_t sc8;
  220. typedef __IO int32_t vs32;
  221. typedef __IO int16_t vs16;
  222. typedef __IO int8_t vs8;
  223. typedef __I int32_t vsc32;
  224. typedef __I int16_t vsc16;
  225. typedef __I int8_t vsc8;
  226. typedef uint32_t u32;
  227. typedef uint16_t u16;
  228. typedef uint8_t u8;
  229. typedef const uint32_t uc32;
  230. typedef const uint16_t uc16;
  231. typedef const uint8_t uc8;
  232. typedef __IO uint32_t vu32;
  233. typedef __IO uint16_t vu16;
  234. typedef __IO uint8_t vu8;
  235. typedef __I uint32_t vuc32;
  236. typedef __I uint16_t vuc16;
  237. typedef __I uint8_t vuc8;
  238. #ifndef __IM
  239. #define __IM __I
  240. #endif
  241. #ifndef __OM
  242. #define __OM __O
  243. #endif
  244. #ifndef __IOM
  245. #define __IOM __IO
  246. #endif
  247. enum {BIT_RESET, BIT_SET};
  248. enum {RESET, SET};
  249. enum {DISABLE, ENABLE};
  250. enum {ERROR, SUCCESS};
  251. #ifndef NULL
  252. #define NULL ((void *)0)
  253. #endif
  254. #if defined (__CC_ARM )
  255. #pragma anon_unions
  256. #endif
  257. /**
  258. * @brief Reset and clock management unit (RCM)
  259. */
  260. typedef struct
  261. {
  262. /** Clock control register */
  263. union
  264. {
  265. __IOM uint32_t CTRL;
  266. struct
  267. {
  268. __IOM uint32_t HSIEN : 1;
  269. __IM uint32_t HSIRDYFLG : 1;
  270. __IM uint32_t RESERVED1 : 1;
  271. __IOM uint32_t HSITRIM : 5;
  272. __IM uint32_t HSICAL : 8;
  273. __IOM uint32_t HSEEN : 1;
  274. __IM uint32_t HSERDYFLG : 1;
  275. __IOM uint32_t HSEBCFG : 1;
  276. __IOM uint32_t CSSEN : 1;
  277. __IM uint32_t RESERVED2 : 4;
  278. __IOM uint32_t PLLEN : 1;
  279. __IM uint32_t PLLRDYFLG : 1;
  280. __IM uint32_t RESERVED3 : 6;
  281. } CTRL_B;
  282. };
  283. /** Clock configuration register */
  284. union
  285. {
  286. __IOM uint32_t CFG;
  287. struct
  288. {
  289. __IOM uint32_t SCLKSEL : 2;
  290. __IM uint32_t SCLKSELSTS : 2;
  291. __IOM uint32_t AHBPSC : 4;
  292. __IOM uint32_t APB1PSC : 3;
  293. __IOM uint32_t APB2PSC : 3;
  294. __IOM uint32_t ADCPSC : 2;
  295. __IOM uint32_t PLLSRCSEL : 1;
  296. __IOM uint32_t PLLHSEPSC : 1;
  297. __IOM uint32_t PLLMULCFG : 4;
  298. __IOM uint32_t USBDPSC : 2;
  299. __IOM uint32_t MCOSEL : 3;
  300. __IOM uint32_t FPUPSC : 1;
  301. __IM uint32_t RESERVED : 4;
  302. } CFG_B;
  303. } ;
  304. /** Clock interrupt control register */
  305. union
  306. {
  307. __IOM uint32_t INT;
  308. struct
  309. {
  310. __IM uint32_t LSIRDYFLG : 1;
  311. __IM uint32_t LSERDYFLG : 1;
  312. __IM uint32_t HSIRDYFLG : 1;
  313. __IM uint32_t HSERDYFLG : 1;
  314. __IM uint32_t PLLRDYFLG : 1;
  315. __IM uint32_t RESERVED1 : 2;
  316. __IM uint32_t CSSIF : 1;
  317. __IOM uint32_t LSIRDYEN : 1;
  318. __IOM uint32_t LSERDYEN : 1;
  319. __IOM uint32_t HSIRDYEN : 1;
  320. __IOM uint32_t HSERDYEN : 1;
  321. __IOM uint32_t PLLRDYEN : 1;
  322. __IM uint32_t RESERVED2 : 3;
  323. __OM uint32_t LSIRDYCLR : 1;
  324. __OM uint32_t LSERDYCLR : 1;
  325. __OM uint32_t HSIRDYCLR : 1;
  326. __OM uint32_t HSERDYCLR : 1;
  327. __OM uint32_t PLLRDYCLR : 1;
  328. __IM uint32_t RESERVED3 : 2;
  329. __OM uint32_t CSSCLR : 1;
  330. __IM uint32_t RESERVED4 : 8;
  331. } INT_B;
  332. } ;
  333. /** APB2 peripheral reset register */
  334. union
  335. {
  336. __IOM uint32_t APB2RST;
  337. struct
  338. {
  339. __IOM uint32_t AFIO : 1;
  340. __IM uint32_t RESERVED1 : 1;
  341. __IOM uint32_t PA : 1;
  342. __IOM uint32_t PB : 1;
  343. __IOM uint32_t PC : 1;
  344. __IOM uint32_t PD : 1;
  345. __IOM uint32_t PE : 1;
  346. __IOM uint32_t PF : 1;
  347. __IOM uint32_t PG : 1;
  348. __IOM uint32_t ADC1 : 1;
  349. __IOM uint32_t ADC2 : 1;
  350. __IOM uint32_t TMR1 : 1;
  351. __IOM uint32_t SPI1 : 1;
  352. __IOM uint32_t TMR8 : 1;
  353. __IOM uint32_t USART1 : 1;
  354. __IOM uint32_t ADC3 : 1;
  355. __IM uint32_t RESERVED2 : 16;
  356. } APB2RST_B;
  357. } ;
  358. /** APB1 peripheral reset register */
  359. union
  360. {
  361. __IOM uint32_t APB1RST;
  362. struct
  363. {
  364. __IOM uint32_t TMR2 : 1;
  365. __IOM uint32_t TMR3 : 1;
  366. __IOM uint32_t TMR4 : 1;
  367. __IOM uint32_t TMR5 : 1;
  368. __IOM uint32_t TMR6 : 1;
  369. __IOM uint32_t TMR7 : 1;
  370. __IM uint32_t RESERVED1 : 5;
  371. __IOM uint32_t WWDT : 1;
  372. __IM uint32_t RESERVED2 : 2;
  373. __IOM uint32_t SPI2 : 1;
  374. __IOM uint32_t SPI3 : 1;
  375. __IM uint32_t RESERVED3 : 1;
  376. __IOM uint32_t USART2 : 1;
  377. __IOM uint32_t USART3 : 1;
  378. __IOM uint32_t UART4 : 1;
  379. __IOM uint32_t UART5 : 1;
  380. __IOM uint32_t I2C1 : 1;
  381. __IOM uint32_t I2C2 : 1;
  382. __IOM uint32_t USBD : 1;
  383. __IM uint32_t RESERVED4 : 1;
  384. __IOM uint32_t CAN1 : 1;
  385. __IM uint32_t CAN2 : 1;
  386. __IOM uint32_t BAKP : 1;
  387. __IOM uint32_t PMU : 1;
  388. __IOM uint32_t DAC : 1;
  389. __IM uint32_t RESERVED5 : 2;
  390. } APB1RST_B;
  391. } ;
  392. /** AHB clock enable register */
  393. union
  394. {
  395. __IOM uint32_t AHBCLKEN;
  396. struct
  397. {
  398. __IOM uint32_t DMA1 : 1;
  399. __IOM uint32_t DMA2 : 1;
  400. __IOM uint32_t SRAM : 1;
  401. __IOM uint32_t FPU : 1;
  402. __IOM uint32_t FMC : 1;
  403. __IOM uint32_t QSPI : 1;
  404. __IOM uint32_t CRC : 1;
  405. __IM uint32_t RESERVED1 : 1;
  406. __IOM uint32_t EMMC : 1;
  407. __IM uint32_t RESERVED2 : 1;
  408. __IOM uint32_t SDIO : 1;
  409. __IM uint32_t RESERVED3 : 21;
  410. } AHBCLKEN_B;
  411. } ;
  412. /** APB2 clock enable register */
  413. union
  414. {
  415. __IOM uint32_t APB2CLKEN;
  416. struct
  417. {
  418. __IOM uint32_t AFIO : 1;
  419. __IM uint32_t RESERVED1 : 1;
  420. __IOM uint32_t PA : 1;
  421. __IOM uint32_t PB : 1;
  422. __IOM uint32_t PC : 1;
  423. __IOM uint32_t PD : 1;
  424. __IOM uint32_t PE : 1;
  425. __IOM uint32_t PF : 1;
  426. __IOM uint32_t PG : 1;
  427. __IOM uint32_t ADC1 : 1;
  428. __IOM uint32_t ADC2 : 1;
  429. __IOM uint32_t TMR1 : 1;
  430. __IOM uint32_t SPI1 : 1;
  431. __IOM uint32_t TMR8 : 1;
  432. __IOM uint32_t USART1 : 1;
  433. __IOM uint32_t ADC3 : 1;
  434. __IM uint32_t RESERVED2 : 16;
  435. } APB2CLKEN_B;
  436. };
  437. /** APB1 clock enable register */
  438. union
  439. {
  440. __IOM uint32_t APB1CLKEN;
  441. struct
  442. {
  443. __IOM uint32_t TMR2 : 1;
  444. __IOM uint32_t TMR3 : 1;
  445. __IOM uint32_t TMR4 : 1;
  446. __IOM uint32_t TMR5 : 1;
  447. __IOM uint32_t TMR6 : 1;
  448. __IOM uint32_t TMR7 : 1;
  449. __IM uint32_t RESERVED1 : 5;
  450. __IOM uint32_t WWDT : 1;
  451. __IM uint32_t RESERVED2 : 2;
  452. __IOM uint32_t SPI2 : 1;
  453. __IOM uint32_t SPI3 : 1;
  454. __IM uint32_t RESERVED3 : 1;
  455. __IOM uint32_t USART2 : 1;
  456. __IOM uint32_t USART3 : 1;
  457. __IOM uint32_t UART4 : 1;
  458. __IOM uint32_t UART5 : 1;
  459. __IOM uint32_t I2C1 : 1;
  460. __IOM uint32_t I2C2 : 1;
  461. __IOM uint32_t USBD : 1;
  462. __IM uint32_t RESERVED4 : 1;
  463. __IOM uint32_t CAN1 : 1;
  464. __IM uint32_t CAN2 : 1;
  465. __IOM uint32_t BAKP : 1;
  466. __IOM uint32_t PMU : 1;
  467. __IOM uint32_t DAC : 1;
  468. __IM uint32_t RESERVED5 : 2;
  469. } APB1CLKEN_B;
  470. } ;
  471. /** Backup domain control register */
  472. union
  473. {
  474. __IOM uint32_t BDCTRL;
  475. struct
  476. {
  477. __IOM uint32_t LSEEN : 1;
  478. __IM uint32_t LSERDYFLG : 1;
  479. __IOM uint32_t LSEBCFG : 1;
  480. __IM uint32_t RESERVED1 : 5;
  481. __IOM uint32_t RTCSRCSEL : 2;
  482. __IM uint32_t RESERVED2 : 5;
  483. __IOM uint32_t RTCCLKEN : 1;
  484. __IOM uint32_t BDRST : 1;
  485. __IM uint32_t RESERVED3 : 15;
  486. } BDCTRL_B;
  487. } ;
  488. /** Control/status register */
  489. union
  490. {
  491. __IOM uint32_t CSTS;
  492. struct
  493. {
  494. __IOM uint32_t LSIEN : 1;
  495. __IM uint32_t LSIRDYFLG : 1;
  496. __IM uint32_t RESERVED1 : 22;
  497. __IOM uint32_t RSTFLGCLR : 1;
  498. __IM uint32_t RESERVED2 : 1;
  499. __IOM uint32_t NRSTFLG : 1;
  500. __IOM uint32_t PODRSTFLG : 1;
  501. __IOM uint32_t SWRSTFLG : 1;
  502. __IOM uint32_t IWDTRSTFLG : 1;
  503. __IOM uint32_t WWDTRSTFLG : 1;
  504. __IOM uint32_t LPWRRSTFLG : 1;
  505. } CSTS_B;
  506. } ;
  507. } RCM_T;
  508. /**
  509. * @brief General purpose I/O (GPIO)
  510. */
  511. typedef struct
  512. {
  513. /** Port configure register low */
  514. union
  515. {
  516. __IOM uint32_t CFGLOW;
  517. struct
  518. {
  519. __IOM uint32_t MODE0 : 2;
  520. __IOM uint32_t CFG0 : 2;
  521. __IOM uint32_t MODE1 : 2;
  522. __IOM uint32_t CFG1 : 2;
  523. __IOM uint32_t MODE2 : 2;
  524. __IOM uint32_t CFG2 : 2;
  525. __IOM uint32_t MODE3 : 2;
  526. __IOM uint32_t CFG3 : 2;
  527. __IOM uint32_t MODE4 : 2;
  528. __IOM uint32_t CFG4 : 2;
  529. __IOM uint32_t MODE5 : 2;
  530. __IOM uint32_t CFG5 : 2;
  531. __IOM uint32_t MODE6 : 2;
  532. __IOM uint32_t CFG6 : 2;
  533. __IOM uint32_t MODE7 : 2;
  534. __IOM uint32_t CFG7 : 2;
  535. } CFGLOW_B;
  536. } ;
  537. /** Port configure register high */
  538. union
  539. {
  540. __IOM uint32_t CFGHIG;
  541. struct
  542. {
  543. __IOM uint32_t MODE8 : 2;
  544. __IOM uint32_t CFG8 : 2;
  545. __IOM uint32_t MODE9 : 2;
  546. __IOM uint32_t CFG9 : 2;
  547. __IOM uint32_t MODE10 : 2;
  548. __IOM uint32_t CFG10 : 2;
  549. __IOM uint32_t MODE11 : 2;
  550. __IOM uint32_t CFG11 : 2;
  551. __IOM uint32_t MODE12 : 2;
  552. __IOM uint32_t CFG12 : 2;
  553. __IOM uint32_t MODE13 : 2;
  554. __IOM uint32_t CFG13 : 2;
  555. __IOM uint32_t MODE14 : 2;
  556. __IOM uint32_t CFG14 : 2;
  557. __IOM uint32_t MODE15 : 2;
  558. __IOM uint32_t CFG15 : 2;
  559. } CFGHIG_B;
  560. } ;
  561. /** Port data in register */
  562. union
  563. {
  564. __IM uint32_t IDATA;
  565. struct
  566. {
  567. __IM uint32_t IDATA0 : 1;
  568. __IM uint32_t IDATA1 : 1;
  569. __IM uint32_t IDATA2 : 1;
  570. __IM uint32_t IDATA3 : 1;
  571. __IM uint32_t IDATA4 : 1;
  572. __IM uint32_t IDATA5 : 1;
  573. __IM uint32_t IDATA6 : 1;
  574. __IM uint32_t IDATA7 : 1;
  575. __IM uint32_t IDATA8 : 1;
  576. __IM uint32_t IDATA9 : 1;
  577. __IM uint32_t IDATA10 : 1;
  578. __IM uint32_t IDATA11 : 1;
  579. __IM uint32_t IDATA12 : 1;
  580. __IM uint32_t IDATA13 : 1;
  581. __IM uint32_t IDATA14 : 1;
  582. __IM uint32_t IDATA15 : 1;
  583. __IM uint32_t RESERVED : 16;
  584. } IDATA_B;
  585. } ;
  586. /** Port data output register */
  587. union
  588. {
  589. __IOM uint32_t ODATA;
  590. struct
  591. {
  592. __IOM uint32_t ODATA0 : 1;
  593. __IOM uint32_t ODATA1 : 1;
  594. __IOM uint32_t ODATA2 : 1;
  595. __IOM uint32_t ODATA3 : 1;
  596. __IOM uint32_t ODATA4 : 1;
  597. __IOM uint32_t ODATA5 : 1;
  598. __IOM uint32_t ODATA6 : 1;
  599. __IOM uint32_t ODATA7 : 1;
  600. __IOM uint32_t ODATA8 : 1;
  601. __IOM uint32_t ODATA9 : 1;
  602. __IOM uint32_t ODATA10 : 1;
  603. __IOM uint32_t ODATA11 : 1;
  604. __IOM uint32_t ODATA12 : 1;
  605. __IOM uint32_t ODATA13 : 1;
  606. __IOM uint32_t ODATA14 : 1;
  607. __IOM uint32_t ODATA15 : 1;
  608. __IM uint32_t RESERVED : 16;
  609. } ODATA_B;
  610. } ;
  611. /** Port bit set/clear register */
  612. union
  613. {
  614. __OM uint32_t BSC;
  615. struct
  616. {
  617. __OM uint32_t BS0 : 1;
  618. __OM uint32_t BS1 : 1;
  619. __OM uint32_t BS2 : 1;
  620. __OM uint32_t BS3 : 1;
  621. __OM uint32_t BS4 : 1;
  622. __OM uint32_t BS5 : 1;
  623. __OM uint32_t BS6 : 1;
  624. __OM uint32_t BS7 : 1;
  625. __OM uint32_t BS8 : 1;
  626. __OM uint32_t BS9 : 1;
  627. __OM uint32_t BS10 : 1;
  628. __OM uint32_t BS11 : 1;
  629. __OM uint32_t BS12 : 1;
  630. __OM uint32_t BS13 : 1;
  631. __OM uint32_t BS14 : 1;
  632. __OM uint32_t BS15 : 1;
  633. __OM uint32_t BR0 : 1;
  634. __OM uint32_t BC1 : 1;
  635. __OM uint32_t BC2 : 1;
  636. __OM uint32_t BR3 : 1;
  637. __OM uint32_t BC4 : 1;
  638. __OM uint32_t BC5 : 1;
  639. __OM uint32_t BC6 : 1;
  640. __OM uint32_t BC7 : 1;
  641. __OM uint32_t BC8 : 1;
  642. __OM uint32_t BC9 : 1;
  643. __OM uint32_t BC10 : 1;
  644. __OM uint32_t BC11 : 1;
  645. __OM uint32_t BC12 : 1;
  646. __OM uint32_t BC13 : 1;
  647. __OM uint32_t BC14 : 1;
  648. __OM uint32_t BC15 : 1;
  649. } BSC_B;
  650. } ;
  651. /** Port bit clear register */
  652. union
  653. {
  654. __OM uint32_t BC;
  655. struct
  656. {
  657. __OM uint32_t BC0 : 1;
  658. __OM uint32_t BC1 : 1;
  659. __OM uint32_t BC2 : 1;
  660. __OM uint32_t BC3 : 1;
  661. __OM uint32_t BC4 : 1;
  662. __OM uint32_t BC5 : 1;
  663. __OM uint32_t BC6 : 1;
  664. __OM uint32_t BC7 : 1;
  665. __OM uint32_t BC8 : 1;
  666. __OM uint32_t BC9 : 1;
  667. __OM uint32_t BC10 : 1;
  668. __OM uint32_t BC11 : 1;
  669. __OM uint32_t BC12 : 1;
  670. __OM uint32_t BC13 : 1;
  671. __OM uint32_t BC14 : 1;
  672. __OM uint32_t BC15 : 1;
  673. __IM uint32_t RESERVED : 16;
  674. } BC_B;
  675. } ;
  676. /** Port configuration lock register */
  677. union
  678. {
  679. __IOM uint32_t LOCK;
  680. struct
  681. {
  682. __IOM uint32_t LOCK0 : 1;
  683. __IOM uint32_t LOCK1 : 1;
  684. __IOM uint32_t LOCK2 : 1;
  685. __IOM uint32_t LOCK3 : 1;
  686. __IOM uint32_t LOCK4 : 1;
  687. __IOM uint32_t LOCK5 : 1;
  688. __IOM uint32_t LOCK6 : 1;
  689. __IOM uint32_t LOCK7 : 1;
  690. __IOM uint32_t LOCK8 : 1;
  691. __IOM uint32_t LOCK9 : 1;
  692. __IOM uint32_t LOCK10 : 1;
  693. __IOM uint32_t LOCK11 : 1;
  694. __IOM uint32_t LOCK12 : 1;
  695. __IOM uint32_t LOCK13 : 1;
  696. __IOM uint32_t LOCK14 : 1;
  697. __IOM uint32_t LOCK15 : 1;
  698. __IOM uint32_t LOCKKEY : 1;
  699. __IM uint32_t RESERVED : 16;
  700. } LOCK_B;
  701. } ;
  702. } GPIO_T;
  703. /**
  704. * @brief Alternate function I/O (AFIO)
  705. */
  706. typedef struct
  707. {
  708. /** Event control register */
  709. union
  710. {
  711. __IOM uint32_t EVCTRL;
  712. struct
  713. {
  714. __IOM uint32_t PINSEL : 4;
  715. __IOM uint32_t PORTSEL : 3;
  716. __IOM uint32_t EVOEN : 1;
  717. __IM uint32_t RESERVED : 24;
  718. } EVCTRL_B;
  719. } ;
  720. /** Alternate function IO remap and Serial wire JTAG configuration register */
  721. union
  722. {
  723. __IOM uint32_t REMAP1;
  724. struct
  725. {
  726. __IOM uint32_t SPI1RMP : 1;
  727. __IOM uint32_t I2C1RMP : 1;
  728. __IOM uint32_t USART1RMP : 1;
  729. __IOM uint32_t USART2RMP : 1;
  730. __IOM uint32_t USART3RMP : 2;
  731. __IOM uint32_t TMR1RMP : 2;
  732. __IOM uint32_t TMR2RMP : 2;
  733. __IOM uint32_t TMR3RMP : 2;
  734. __IOM uint32_t TMR4RMP : 1;
  735. __IOM uint32_t CAN1RMP : 2;
  736. __IOM uint32_t PD01RMP : 1;
  737. __IOM uint32_t TMR5CH4IRMP : 1;
  738. __IOM uint32_t ADC1_ETRGINJC_RMP : 1;
  739. __IOM uint32_t ADC1_ETRGREGC_RMP : 1;
  740. __IOM uint32_t ADC2_ETRGINJC_RMP : 1;
  741. __IOM uint32_t ADC2_ETRGREGC_RMP : 1;
  742. __IM uint32_t RESERVED1 : 1;
  743. __IOM uint32_t CAN2RMP : 1;
  744. __IM uint32_t RESERVED2 : 1;
  745. __OM uint32_t SWJCFG : 3;
  746. __IM uint32_t RESERVED3 : 5;
  747. } REMAP1_B;
  748. } ;
  749. /** External interrupt select register1 */
  750. union
  751. {
  752. __IOM uint32_t EINTSEL1;
  753. struct
  754. {
  755. __IOM uint32_t EINT0 : 4;
  756. __IOM uint32_t EINT1 : 4;
  757. __IOM uint32_t EINT2 : 4;
  758. __IOM uint32_t EINT3 : 4;
  759. __IM uint32_t RESERVED : 16;
  760. } EINTSEL1_B;
  761. } ;
  762. /** External interrupt select register2 */
  763. union
  764. {
  765. __IOM uint32_t EINTSEL2;
  766. struct
  767. {
  768. __IOM uint32_t EINT4 : 4;
  769. __IOM uint32_t EINT5 : 4;
  770. __IOM uint32_t EINT6 : 4;
  771. __IOM uint32_t EINT7 : 4;
  772. __IM uint32_t RESERVED : 16;
  773. } EINTSEL2_B;
  774. } ;
  775. /** External interrupt select register3 */
  776. union
  777. {
  778. __IOM uint32_t EINTSEL3;
  779. struct
  780. {
  781. __IOM uint32_t EINT8 : 4;
  782. __IOM uint32_t EINT9 : 4;
  783. __IOM uint32_t EINT10 : 4;
  784. __IOM uint32_t EINT11 : 4;
  785. __IM uint32_t RESERVED : 16;
  786. } EINTSEL3_B;
  787. } ;
  788. /** External interrupt select register4 */
  789. union
  790. {
  791. __IOM uint32_t EINTSEL4;
  792. struct
  793. {
  794. __IOM uint32_t EINT12 : 4;
  795. __IOM uint32_t EINT13 : 4;
  796. __IOM uint32_t EINT14 : 4;
  797. __IOM uint32_t EINT15 : 4;
  798. __IM uint32_t RESERVED : 16;
  799. } EINTSEL4_B;
  800. } ;
  801. __IM uint32_t RESERVED;
  802. /** Alternate function IO remap register2 */
  803. union
  804. {
  805. __IOM uint32_t REMAP2;
  806. struct
  807. {
  808. __IM uint32_t RESERVED1 : 10;
  809. __IOM uint32_t EMMCNADV : 1;
  810. __IM uint32_t RESERVED2 : 21;
  811. } REMAP2_B;
  812. } ;
  813. } AFIO_T;
  814. /**
  815. * @brief Universal synchronous asynchronous receiver transmitter (USART)
  816. */
  817. typedef struct
  818. {
  819. /** Status register */
  820. union
  821. {
  822. __IOM uint32_t STS;
  823. struct
  824. {
  825. __IM uint32_t PEFLG : 1;
  826. __IM uint32_t FEFLG : 1;
  827. __IM uint32_t NEFLG : 1;
  828. __IM uint32_t OVREFLG : 1;
  829. __IM uint32_t IDLEFLG : 1;
  830. __IOM uint32_t RXBNEFLG : 1;
  831. __IOM uint32_t TXCFLG : 1;
  832. __IM uint32_t TXBEFLG : 1;
  833. __IOM uint32_t LBDFLG : 1;
  834. __IOM uint32_t CTSFLG : 1;
  835. __IM uint32_t RESERVED : 22;
  836. } STS_B;
  837. } ;
  838. /** TX Buffer Data Register */
  839. union
  840. {
  841. __IOM uint32_t DATA;
  842. struct
  843. {
  844. __IOM uint32_t DATA : 9;
  845. __IM uint32_t RESERVED : 23;
  846. } DATA_B;
  847. } ;
  848. /** Baud rate register */
  849. union
  850. {
  851. __IOM uint32_t BR;
  852. struct
  853. {
  854. __IOM uint32_t FBR : 4;
  855. __IOM uint32_t IBR : 12;
  856. __IM uint32_t RESERVED : 16;
  857. } BR_B;
  858. } ;
  859. /** Control register 1 */
  860. union
  861. {
  862. __IOM uint32_t CTRL1;
  863. struct
  864. {
  865. __IOM uint32_t TXBF : 1;
  866. __IOM uint32_t RXMUTEEN : 1;
  867. __IOM uint32_t RXEN : 1;
  868. __IOM uint32_t TXEN : 1;
  869. __IOM uint32_t IDLEIEN : 1;
  870. __IOM uint32_t RXBNEIEN : 1;
  871. __IOM uint32_t TXCIEN : 1;
  872. __IOM uint32_t TXBEIEN : 1;
  873. __IOM uint32_t PEIEN : 1;
  874. __IOM uint32_t PCFG : 1;
  875. __IOM uint32_t PCEN : 1;
  876. __IOM uint32_t WUPMCFG : 1;
  877. __IOM uint32_t DBLCFG : 1;
  878. __IOM uint32_t UEN : 1;
  879. __IM uint32_t RESERVED : 18;
  880. } CTRL1_B;
  881. } ;
  882. /** Control register 2 */
  883. union
  884. {
  885. __IOM uint32_t CTRL2;
  886. struct
  887. {
  888. __IOM uint32_t ADDR : 4;
  889. __IM uint32_t RESERVED1 : 1;
  890. __IOM uint32_t LBDLCFG : 1;
  891. __IOM uint32_t LBDIEN : 1;
  892. __IM uint32_t RESERVED2 : 1;
  893. __IOM uint32_t LBCPOEN : 1;
  894. __IOM uint32_t CPHA : 1;
  895. __IOM uint32_t CPOL : 1;
  896. __IOM uint32_t CLKEN : 1;
  897. __IOM uint32_t STOPCFG : 2;
  898. __IOM uint32_t LINMEN : 1;
  899. __IM uint32_t RESERVED3 : 17;
  900. } CTRL2_B;
  901. } ;
  902. /** Control register 3 */
  903. union
  904. {
  905. __IOM uint32_t CTRL3;
  906. struct
  907. {
  908. __IOM uint32_t ERRIEN : 1;
  909. __IOM uint32_t IREN : 1;
  910. __IOM uint32_t IRLPEN : 1;
  911. __IOM uint32_t HDEN : 1;
  912. __IOM uint32_t SCNACKEN : 1;
  913. __IOM uint32_t SCEN : 1;
  914. __IOM uint32_t DMARXEN : 1;
  915. __IOM uint32_t DMATXEN : 1;
  916. __IOM uint32_t RTSEN : 1;
  917. __IOM uint32_t CTSEN : 1;
  918. __IOM uint32_t CTSIEN : 1;
  919. __IM uint32_t RESERVED : 21;
  920. } CTRL3_B;
  921. } ;
  922. /** Guard TMRe and divider number register */
  923. union
  924. {
  925. __IOM uint32_t GTPSC;
  926. struct
  927. {
  928. __IOM uint32_t PSC : 8;
  929. __IOM uint32_t GRDT : 8;
  930. __IM uint32_t RESERVED : 16;
  931. } GTPSC_B;
  932. } ;
  933. } USART_T;
  934. /**
  935. * @brief Flash memory controller(FMC)
  936. */
  937. typedef struct
  938. {
  939. /** FMC access control register */
  940. union
  941. {
  942. __IOM uint32_t CTRL1;
  943. struct
  944. {
  945. __IOM uint32_t WS : 3;
  946. __IOM uint32_t HCAEN : 1;
  947. __IOM uint32_t PBEN : 1;
  948. __IM uint32_t PBSF : 1;
  949. __IM uint32_t RESERVED : 26;
  950. } CTRL1_B;
  951. } ;
  952. /** key register */
  953. union
  954. {
  955. __OM uint32_t KEY;
  956. struct
  957. {
  958. __OM uint32_t KEY : 32;
  959. } KEY_B;
  960. } ;
  961. /** option byte key register */
  962. union
  963. {
  964. __OM uint32_t OBKEY;
  965. struct
  966. {
  967. __OM uint32_t OBKEY : 32;
  968. } OBKEY_B;
  969. };
  970. /** status register */
  971. union
  972. {
  973. __IOM uint32_t STS;
  974. struct
  975. {
  976. __IM uint32_t BUSYF : 1;
  977. __IM uint32_t RESERVED1 : 1;
  978. __IOM uint32_t PEF : 1;
  979. __IM uint32_t RESERVED2 : 1;
  980. __IOM uint32_t WPEF : 1;
  981. __IOM uint32_t OCF : 1;
  982. __IM uint32_t RESERVED3 : 26;
  983. } STS_B;
  984. };
  985. /** status register */
  986. union
  987. {
  988. __IOM uint32_t CTRL2;
  989. struct
  990. {
  991. __IOM uint32_t PG : 1;
  992. __IOM uint32_t PAGEERA : 1;
  993. __IOM uint32_t MASSERA : 1;
  994. __IM uint32_t RESERVED1 : 1;
  995. __IOM uint32_t OBP : 1;
  996. __IOM uint32_t OBE : 1;
  997. __IOM uint32_t STA : 1;
  998. __IOM uint32_t LOCK : 1;
  999. __IM uint32_t RESERVED2 : 1;
  1000. __IOM uint32_t OBWEN : 1;
  1001. __IOM uint32_t ERRIE : 1;
  1002. __IM uint32_t RESERVED3 : 1;
  1003. __IOM uint32_t OCIE : 1;
  1004. __IM uint32_t RESERVED4 : 19;
  1005. } CTRL2_B;
  1006. } ;
  1007. /** address register */
  1008. union
  1009. {
  1010. __OM uint32_t ADDR;
  1011. struct
  1012. {
  1013. __OM uint32_t ADDR : 32;
  1014. } ADDR_B;
  1015. };
  1016. __IM uint32_t RESERVED;
  1017. /** Option byte register */
  1018. union
  1019. {
  1020. __IOM uint32_t OBCS;
  1021. struct
  1022. {
  1023. __IM uint32_t OBE : 1;
  1024. __IM uint32_t READPROT : 1;
  1025. __IM uint32_t WDTSEL : 1;
  1026. __IM uint32_t RSTSTOP : 1;
  1027. __IM uint32_t RSTSTDB : 1;
  1028. __IM uint32_t UOB : 5;
  1029. __IM uint32_t DATA0 : 8;
  1030. __IM uint32_t DATA1 : 8;
  1031. __IM uint32_t RESERVED : 6;
  1032. } OBCS_B;
  1033. };
  1034. /** Write protection register */
  1035. union
  1036. {
  1037. __IM uint32_t WRTPROT;
  1038. struct
  1039. {
  1040. __IM uint32_t WRTPORT : 32;
  1041. } WRTPORT_B;
  1042. };
  1043. } FMC_T;
  1044. /**
  1045. * @brief CRC calculation unit (CRC)
  1046. */
  1047. typedef struct
  1048. {
  1049. /** @brief DATA register */
  1050. union
  1051. {
  1052. __IOM uint32_t DATA;
  1053. struct
  1054. {
  1055. __IOM uint32_t DATA : 32;
  1056. } DATA_B;
  1057. } ;
  1058. /** @brief independent DATA register */
  1059. union
  1060. {
  1061. __IOM uint32_t INDATA;
  1062. struct
  1063. {
  1064. __IOM uint32_t INDATA : 8;
  1065. __IM uint32_t RESERVED : 24;
  1066. } INDATA_B;
  1067. };
  1068. /** @brief Countrol register */
  1069. union
  1070. {
  1071. __IOM uint32_t CTRL;
  1072. struct
  1073. {
  1074. __IOM uint32_t RST : 1;
  1075. __IM uint32_t RESERVED : 31;
  1076. } CTRL_B;
  1077. };
  1078. } CRC_T;
  1079. /**
  1080. * @brief Real time clock (RTC)
  1081. */
  1082. typedef struct
  1083. {
  1084. /** @brief Control register */
  1085. union
  1086. {
  1087. __IOM uint32_t CTRL;
  1088. struct
  1089. {
  1090. __IOM uint32_t SECIEN : 1;
  1091. __IOM uint32_t ALRIEN : 1;
  1092. __IOM uint32_t OVRIEN : 1;
  1093. __IM uint32_t RESERVED : 29;
  1094. } CTRL_B;
  1095. };
  1096. /** @brief Control and State register */
  1097. union
  1098. {
  1099. __IOM uint32_t CSTS;
  1100. struct
  1101. {
  1102. __IOM uint32_t SECFLG : 1;
  1103. __IOM uint32_t ALRFLG : 1;
  1104. __IOM uint32_t OVRFLG : 1;
  1105. __IOM uint32_t RSYNCFLG : 1;
  1106. __IOM uint32_t CFGMFLG : 1;
  1107. __IM uint32_t OCFLG : 1;
  1108. __IM uint32_t RESERVED : 26;
  1109. } CSTS_B;
  1110. };
  1111. /** @brief RTC predivision loading register High Bit */
  1112. union
  1113. {
  1114. __OM uint32_t PSCRLDH;
  1115. struct
  1116. {
  1117. __OM uint32_t PSCRLDH : 4;
  1118. __IM uint32_t RESERVED : 28;
  1119. } PSCRLDH_B;
  1120. };
  1121. /** @brief RTC predivision loading register Low Bit */
  1122. union
  1123. {
  1124. __OM uint32_t PSCRLDL;
  1125. struct
  1126. {
  1127. __OM uint32_t PSCRLDL : 16;
  1128. __IM uint32_t RESERVED : 16;
  1129. } PSCRLDL_B;
  1130. };
  1131. /** @brief RTC predivider remainder register High Bit */
  1132. union
  1133. {
  1134. __IM uint32_t PSCH;
  1135. struct
  1136. {
  1137. __IM uint32_t PSCH : 4;
  1138. __IM uint32_t RESERVED : 28;
  1139. } PSCH_B;
  1140. };
  1141. /** @brief RTC predivider remainder register Low Bit */
  1142. union
  1143. {
  1144. __IM uint32_t PSCL;
  1145. struct
  1146. {
  1147. __IM uint32_t PSCL : 16;
  1148. __IM uint32_t RESERVED : 16;
  1149. } PSCL_B;
  1150. };
  1151. /** @brief RTC count register High Bit */
  1152. union
  1153. {
  1154. __IOM uint32_t CNTH;
  1155. struct
  1156. {
  1157. __IOM uint32_t CNTH : 16;
  1158. __IM uint32_t RESERVED : 16;
  1159. } CNTH_B;
  1160. };
  1161. /** @brief RTC count register Low Bit */
  1162. union
  1163. {
  1164. __IOM uint32_t CNTL;
  1165. struct
  1166. {
  1167. __IOM uint32_t CNTL : 16;
  1168. __IM uint32_t RESERVED : 16;
  1169. } CNTL_B;
  1170. };
  1171. /** @brief RTC alarm clock register High Bit */
  1172. union
  1173. {
  1174. __OM uint32_t ALRH;
  1175. struct
  1176. {
  1177. __OM uint32_t ALRH : 16;
  1178. __IM uint32_t RESERVED : 16;
  1179. } ALRH_B;
  1180. };
  1181. /** @brief RTC alarm clock register Low Bit */
  1182. union
  1183. {
  1184. __OM uint32_t ALRL;
  1185. struct
  1186. {
  1187. __OM uint32_t ALRL : 16;
  1188. __IM uint32_t RESERVED : 16;
  1189. } ALRL_B;
  1190. };
  1191. } RTC_T;
  1192. /**
  1193. * @brief Power Management Unit(PMU)
  1194. */
  1195. typedef struct
  1196. {
  1197. /** @brief Control register */
  1198. union
  1199. {
  1200. __IOM uint32_t CTRL;
  1201. struct
  1202. {
  1203. __IOM uint32_t LPDSCFG : 1;
  1204. __IOM uint32_t PDDSCFG : 1;
  1205. __IOM uint32_t WUFLGCLR : 1;
  1206. __IOM uint32_t SBFLGCLR : 1;
  1207. __IOM uint32_t PVDEN : 1;
  1208. __IOM uint32_t PLSEL : 3;
  1209. __IOM uint32_t BPWEN : 1;
  1210. __IM uint32_t RESERVED : 23;
  1211. } CTRL_B;
  1212. };
  1213. /** @brief PMU Status register */
  1214. union
  1215. {
  1216. __IOM uint32_t CSTS;
  1217. struct
  1218. {
  1219. __IM uint32_t WUEFLG : 1;
  1220. __IM uint32_t SBFLG : 1;
  1221. __IM uint32_t PVDOFLG : 1;
  1222. __IM uint32_t RESERVED : 5;
  1223. __IOM uint32_t WKUPCFG : 1;
  1224. __IM uint32_t RESERVED2 : 23;
  1225. } CSTS_B;
  1226. };
  1227. } PMU_T;
  1228. /**
  1229. * @brief Backup register (BAKPR)
  1230. */
  1231. typedef struct
  1232. {
  1233. __IM uint32_t RESERVED;
  1234. /** @brief BAKPR DATA1 register */
  1235. union
  1236. {
  1237. __IOM uint32_t DATA1;
  1238. struct
  1239. {
  1240. __IOM uint32_t DATA : 16;
  1241. __IM uint32_t RESERVED : 16;
  1242. } DATA1_B;
  1243. };
  1244. /** @brief BAKPR DATA2 register */
  1245. union
  1246. {
  1247. __IOM uint32_t DATA2;
  1248. struct
  1249. {
  1250. __IOM uint32_t DATA : 16;
  1251. __IM uint32_t RESERVED : 16;
  1252. } DATA2_B;
  1253. };
  1254. /** @brief BAKPR DATA3 register */
  1255. union
  1256. {
  1257. __IOM uint32_t DATA3;
  1258. struct
  1259. {
  1260. __IOM uint32_t DATA : 16;
  1261. __IM uint32_t RESERVED : 16;
  1262. } DATA3_B;
  1263. };
  1264. /** @brief BAKPR DATA4 register */
  1265. union
  1266. {
  1267. __IOM uint32_t DATA4;
  1268. struct
  1269. {
  1270. __IOM uint32_t DATA : 16;
  1271. __IM uint32_t RESERVED : 16;
  1272. } DATA4_B;
  1273. };
  1274. /** @brief BAKPR DATA5 register */
  1275. union
  1276. {
  1277. __IOM uint32_t DATA5;
  1278. struct
  1279. {
  1280. __IOM uint32_t DATA : 16;
  1281. __IM uint32_t RESERVED : 16;
  1282. } DATA5_B;
  1283. };
  1284. /** @brief BAKPR DATA6 register */
  1285. union
  1286. {
  1287. __IOM uint32_t DATA6;
  1288. struct
  1289. {
  1290. __IOM uint32_t DATA : 16;
  1291. __IM uint32_t RESERVED : 16;
  1292. } DATA6_B;
  1293. };
  1294. /** @brief BAKPR DATA7 register */
  1295. union
  1296. {
  1297. __IOM uint32_t DATA7;
  1298. struct
  1299. {
  1300. __IOM uint32_t DATA : 16;
  1301. __IM uint32_t RESERVED : 16;
  1302. } DATA7_B;
  1303. };
  1304. /** @brief BAKPR DATA8 register */
  1305. union
  1306. {
  1307. __IOM uint32_t DATA8;
  1308. struct
  1309. {
  1310. __IOM uint32_t DATA : 16;
  1311. __IM uint32_t RESERVED : 16;
  1312. } DATA8_B;
  1313. };
  1314. /** @brief BAKPR DATA9 register */
  1315. union
  1316. {
  1317. __IOM uint32_t DATA9;
  1318. struct
  1319. {
  1320. __IOM uint32_t DATA : 16;
  1321. __IM uint32_t RESERVED : 16;
  1322. } DATA9_B;
  1323. };
  1324. /** @brief BAKPR DATA10 register */
  1325. union
  1326. {
  1327. __IOM uint32_t DATA10;
  1328. struct
  1329. {
  1330. __IOM uint32_t DATA : 16;
  1331. __IM uint32_t RESERVED : 16;
  1332. } DATA10_B;
  1333. };
  1334. /** @brief BAKPR Clock Calibration register */
  1335. union
  1336. {
  1337. __IOM uint32_t CLKCAL;
  1338. struct
  1339. {
  1340. __IOM uint32_t CALVALUE : 7;
  1341. __IOM uint32_t CALCOEN : 1;
  1342. __IOM uint32_t ASPOEN : 1;
  1343. __IOM uint32_t ASPOSEL : 1;
  1344. __IM uint32_t RESERVED : 22;
  1345. } CLKCAL_B;
  1346. } ;
  1347. /** @brief BAKPR Control register */
  1348. union
  1349. {
  1350. __IOM uint32_t CTRL;
  1351. struct
  1352. {
  1353. __IOM uint32_t TPFCFG : 1;
  1354. __IOM uint32_t TPALCFG : 1;
  1355. __IM uint32_t RESERVED : 30;
  1356. } CTRL_B;
  1357. };
  1358. /** @brief BAKPR Control register */
  1359. union
  1360. {
  1361. __IOM uint32_t CSTS;
  1362. struct
  1363. {
  1364. __OM uint32_t TECLR : 1;
  1365. __OM uint32_t TICLR : 1;
  1366. __IOM uint32_t TPIEN : 1;
  1367. __IM uint32_t RESERVED1 : 5;
  1368. __IM uint32_t TEFLG : 1;
  1369. __IM uint32_t TIFLG : 1;
  1370. __IM uint32_t RESERVED2 : 22;
  1371. } CSTS_B;
  1372. };
  1373. __IM uint32_t RESERVED1[2];
  1374. /** @briefBAKPR DATA11 register */
  1375. union
  1376. {
  1377. __IOM uint32_t DATA11;
  1378. struct
  1379. {
  1380. __IOM uint32_t DATA : 16;
  1381. __IM uint32_t RESERVED : 16;
  1382. } DATA11_B;
  1383. };
  1384. /** @briefBAKPR DATA12 register */
  1385. union
  1386. {
  1387. __IOM uint32_t DATA12;
  1388. struct
  1389. {
  1390. __IOM uint32_t DATA : 16;
  1391. __IM uint32_t RESERVED : 16;
  1392. } DATA12_B;
  1393. };
  1394. /** @briefBAKPR DATA13 register */
  1395. union
  1396. {
  1397. __IOM uint32_t DATA13;
  1398. struct
  1399. {
  1400. __IOM uint32_t DATA : 16;
  1401. __IM uint32_t RESERVED : 16;
  1402. } DATA13_B;
  1403. };
  1404. /** @briefBAKPR DATA14 register */
  1405. union
  1406. {
  1407. __IOM uint32_t DATA14;
  1408. struct
  1409. {
  1410. __IOM uint32_t DATA : 16;
  1411. __IM uint32_t RESERVED : 16;
  1412. } DATA14_B;
  1413. };
  1414. /** @briefBAKPR DATA15 register */
  1415. union
  1416. {
  1417. __IOM uint32_t DATA15;
  1418. struct
  1419. {
  1420. __IOM uint32_t DATA : 16;
  1421. __IM uint32_t RESERVED : 16;
  1422. } DATA15_B;
  1423. };
  1424. /** @briefBAKPR DATA16 register */
  1425. union
  1426. {
  1427. __IOM uint32_t DATA16;
  1428. struct
  1429. {
  1430. __IOM uint32_t DATA : 16;
  1431. __IM uint32_t RESERVED : 16;
  1432. } DATA16_B;
  1433. };
  1434. /** @briefBAKPR DATA17 register */
  1435. union
  1436. {
  1437. __IOM uint32_t DATA17;
  1438. struct
  1439. {
  1440. __IOM uint32_t DATA : 16;
  1441. __IM uint32_t RESERVED : 16;
  1442. } DATA17_B;
  1443. };
  1444. /** @briefBAKPR DATA18 register */
  1445. union
  1446. {
  1447. __IOM uint32_t DATA18;
  1448. struct
  1449. {
  1450. __IOM uint32_t DATA : 16;
  1451. __IM uint32_t RESERVED : 16;
  1452. } DATA18_B;
  1453. };
  1454. /** @briefBAKPR DATA19 register */
  1455. union
  1456. {
  1457. __IOM uint32_t DATA19;
  1458. struct
  1459. {
  1460. __IOM uint32_t DATA : 16;
  1461. __IM uint32_t RESERVED : 16;
  1462. } DATA19_B;
  1463. };
  1464. /** @briefBAKPR DATA20 register */
  1465. union
  1466. {
  1467. __IOM uint32_t DATA20;
  1468. struct
  1469. {
  1470. __IOM uint32_t DATA : 16;
  1471. __IM uint32_t RESERVED : 16;
  1472. } DATA20_B;
  1473. };
  1474. /** @briefBAKPR DATA21 register */
  1475. union
  1476. {
  1477. __IOM uint32_t DATA21;
  1478. struct
  1479. {
  1480. __IOM uint32_t DATA : 16;
  1481. __IM uint32_t RESERVED : 16;
  1482. } DATA21_B;
  1483. };
  1484. /** @briefBAKPR DATA22 register */
  1485. union
  1486. {
  1487. __IOM uint32_t DATA22;
  1488. struct
  1489. {
  1490. __IOM uint32_t DATA : 16;
  1491. __IM uint32_t RESERVED : 16;
  1492. } DATA22_B;
  1493. };
  1494. /** @briefBAKPR DATA23 register */
  1495. union
  1496. {
  1497. __IOM uint32_t DATA23;
  1498. struct
  1499. {
  1500. __IOM uint32_t DATA : 16;
  1501. __IM uint32_t RESERVED : 16;
  1502. } DATA23_B;
  1503. };
  1504. /** @briefBAKPR DATA24 register */
  1505. union
  1506. {
  1507. __IOM uint32_t DATA24;
  1508. struct
  1509. {
  1510. __IOM uint32_t DATA : 16;
  1511. __IM uint32_t RESERVED : 16;
  1512. } DATA24_B;
  1513. };
  1514. /** @briefBAKPR DATA25 register */
  1515. union
  1516. {
  1517. __IOM uint32_t DATA25;
  1518. struct
  1519. {
  1520. __IOM uint32_t DATA : 16;
  1521. __IM uint32_t RESERVED : 16;
  1522. } DATA25_B;
  1523. };
  1524. /** @briefBAKPR DATA26 register */
  1525. union
  1526. {
  1527. __IOM uint32_t DATA26;
  1528. struct
  1529. {
  1530. __IOM uint32_t DATA : 16;
  1531. __IM uint32_t RESERVED : 16;
  1532. } DATA26_B;
  1533. };
  1534. /** @briefBAKPR DATA27 register */
  1535. union
  1536. {
  1537. __IOM uint32_t DATA27;
  1538. struct
  1539. {
  1540. __IOM uint32_t DATA : 16;
  1541. __IM uint32_t RESERVED : 16;
  1542. } DATA27_B;
  1543. };
  1544. /** @briefBAKPR DATA28 register */
  1545. union
  1546. {
  1547. __IOM uint32_t DATA28;
  1548. struct
  1549. {
  1550. __IOM uint32_t DATA : 16;
  1551. __IM uint32_t RESERVED : 16;
  1552. } DATA28_B;
  1553. };
  1554. /** @briefBAKPR DATA29 register */
  1555. union
  1556. {
  1557. __IOM uint32_t DATA29;
  1558. struct
  1559. {
  1560. __IOM uint32_t DATA : 16;
  1561. __IM uint32_t RESERVED : 16;
  1562. } DATA29_B;
  1563. };
  1564. /** @briefBAKPR DATA30 register */
  1565. union
  1566. {
  1567. __IOM uint32_t DATA30;
  1568. struct
  1569. {
  1570. __IOM uint32_t DATA : 16;
  1571. __IM uint32_t RESERVED : 16;
  1572. } DATA30_B;
  1573. };
  1574. /** @briefBAKPR DATA31 register */
  1575. union
  1576. {
  1577. __IOM uint32_t DATA31;
  1578. struct
  1579. {
  1580. __IOM uint32_t DATA : 16;
  1581. __IM uint32_t RESERVED : 16;
  1582. } DATA31_B;
  1583. };
  1584. /** @briefBAKPR DATA32 register */
  1585. union
  1586. {
  1587. __IOM uint32_t DATA32;
  1588. struct
  1589. {
  1590. __IOM uint32_t DATA : 16;
  1591. __IM uint32_t RESERVED : 16;
  1592. } DATA32_B;
  1593. };
  1594. /** @briefBAKPR DATA33 register */
  1595. union
  1596. {
  1597. __IOM uint32_t DATA33;
  1598. struct
  1599. {
  1600. __IOM uint32_t DATA : 16;
  1601. __IM uint32_t RESERVED : 16;
  1602. } DATA33_B;
  1603. };
  1604. /** @briefBAKPR DATA34 register */
  1605. union
  1606. {
  1607. __IOM uint32_t DATA34;
  1608. struct
  1609. {
  1610. __IOM uint32_t DATA : 16;
  1611. __IM uint32_t RESERVED : 16;
  1612. } DATA34_B;
  1613. };
  1614. /** @briefBAKPR DATA35 register */
  1615. union
  1616. {
  1617. __IOM uint32_t DATA35;
  1618. struct
  1619. {
  1620. __IOM uint32_t DATA : 16;
  1621. __IM uint32_t RESERVED : 16;
  1622. } DATA35_B;
  1623. };
  1624. /** @briefBAKPR DATA36 register */
  1625. union
  1626. {
  1627. __IOM uint32_t DATA36;
  1628. struct
  1629. {
  1630. __IOM uint32_t DATA : 16;
  1631. __IM uint32_t RESERVED : 16;
  1632. } DATA36_B;
  1633. };
  1634. /** @briefBAKPR DATA37 register */
  1635. union
  1636. {
  1637. __IOM uint32_t DATA37;
  1638. struct
  1639. {
  1640. __IOM uint32_t DATA : 16;
  1641. __IM uint32_t RESERVED : 16;
  1642. } DATA37_B;
  1643. };
  1644. /** @briefBAKPR DATA38 register */
  1645. union
  1646. {
  1647. __IOM uint32_t DATA38;
  1648. struct
  1649. {
  1650. __IOM uint32_t DATA : 16;
  1651. __IM uint32_t RESERVED : 16;
  1652. } DATA38_B;
  1653. };
  1654. /** @briefBAKPR DATA39 register */
  1655. union
  1656. {
  1657. __IOM uint32_t DATA39;
  1658. struct
  1659. {
  1660. __IOM uint32_t DATA : 16;
  1661. __IM uint32_t RESERVED : 16;
  1662. } DATA39_B;
  1663. };
  1664. /** @briefBAKPR DATA40 register */
  1665. union
  1666. {
  1667. __IOM uint32_t DATA40;
  1668. struct
  1669. {
  1670. __IOM uint32_t DATA : 16;
  1671. __IM uint32_t RESERVED : 16;
  1672. } DATA40_B;
  1673. };
  1674. /** @briefBAKPR DATA41 register */
  1675. union
  1676. {
  1677. __IOM uint32_t DATA41;
  1678. struct
  1679. {
  1680. __IOM uint32_t DATA : 16;
  1681. __IM uint32_t RESERVED : 16;
  1682. } DATA41_B;
  1683. };
  1684. /** @briefBAKPR DATA42 register */
  1685. union
  1686. {
  1687. __IOM uint32_t DATA42;
  1688. struct
  1689. {
  1690. __IOM uint32_t DATA : 16;
  1691. __IM uint32_t RESERVED : 16;
  1692. } DATA42_B;
  1693. };
  1694. } BAKPR_T;
  1695. /**
  1696. * @brief Timer register(TMR)
  1697. */
  1698. typedef struct
  1699. {
  1700. /** @brief Countrol register 1 */
  1701. union
  1702. {
  1703. __IOM uint32_t CTRL1;
  1704. struct
  1705. {
  1706. __IOM uint32_t CNTEN : 1;
  1707. __IOM uint32_t UD : 1;
  1708. __IOM uint32_t URSSEL : 1;
  1709. __IOM uint32_t SPMEN : 1;
  1710. __IOM uint32_t CNTDIR : 1;
  1711. __IOM uint32_t CAMSEL : 2;
  1712. __IOM uint32_t ARPEN : 1;
  1713. __IOM uint32_t CLKDIV : 2;
  1714. __IM uint32_t RESERVED : 22;
  1715. } CTRL1_B;
  1716. };
  1717. /** @brief Countrol register 2 */
  1718. union
  1719. {
  1720. __IOM uint32_t CTRL2;
  1721. struct
  1722. {
  1723. __IOM uint32_t CCPEN : 1;
  1724. __IM uint32_t RESERVED1 : 1;
  1725. __IOM uint32_t CCUSEL : 1;
  1726. __IOM uint32_t CCDSEL : 1;
  1727. __IOM uint32_t MMSEL : 3;
  1728. __IOM uint32_t TI1SEL : 1;
  1729. __IOM uint32_t OC1OIS : 1;
  1730. __IOM uint32_t OC1NOIS : 1;
  1731. __IOM uint32_t OC2OIS : 1;
  1732. __IOM uint32_t OC2NOIS : 1;
  1733. __IOM uint32_t OC3OIS : 1;
  1734. __IOM uint32_t OC3NOIS : 1;
  1735. __IOM uint32_t OC4OIS : 1;
  1736. __IM uint32_t RESERVED2 : 17;
  1737. } CTRL2_B;
  1738. };
  1739. /** @brief Control register from mode */
  1740. union
  1741. {
  1742. __IOM uint32_t SMCTRL;
  1743. struct
  1744. {
  1745. __IOM uint32_t SMFSEL : 3;
  1746. __IM uint32_t RESERVED1 : 1;
  1747. __IOM uint32_t TRGSEL : 3;
  1748. __IOM uint32_t MSMEN : 1;
  1749. __IOM uint32_t ETFCFG : 4;
  1750. __IOM uint32_t ETPCFG : 2;
  1751. __IOM uint32_t ECEN : 1;
  1752. __IOM uint32_t ETPOL : 1;
  1753. __IM uint32_t RESERVED2 : 16;
  1754. } SMCTRL_B;
  1755. };
  1756. /** @brief DMA and Interrupt enable register */
  1757. union
  1758. {
  1759. __IOM uint32_t DIEN;
  1760. struct
  1761. {
  1762. __IOM uint32_t UIEN : 1;
  1763. __IOM uint32_t CC1IEN : 1;
  1764. __IOM uint32_t CC2IEN : 1;
  1765. __IOM uint32_t CC3IEN : 1;
  1766. __IOM uint32_t CC4IEN : 1;
  1767. __IOM uint32_t COMIEN : 1;
  1768. __IOM uint32_t TRGIEN : 1;
  1769. __IOM uint32_t BRKIEN : 1;
  1770. __IOM uint32_t UDIEN : 1;
  1771. __IOM uint32_t CC1DEN : 1;
  1772. __IOM uint32_t CC2DEN : 1;
  1773. __IOM uint32_t CC3DEN : 1;
  1774. __IOM uint32_t CC4DEN : 1;
  1775. __IOM uint32_t COMDEN : 1;
  1776. __IOM uint32_t TRGDEN : 1;
  1777. __IM uint32_t RESERVED : 17;
  1778. } DIEN_B;
  1779. };
  1780. /** @brief Status register */
  1781. union
  1782. {
  1783. __IOM uint32_t STS;
  1784. struct
  1785. {
  1786. __IOM uint32_t UIFLG : 1;
  1787. __IOM uint32_t CC1IFLG : 1;
  1788. __IOM uint32_t CC2IFLG : 1;
  1789. __IOM uint32_t CC3IFLG : 1;
  1790. __IOM uint32_t CC4IFLG : 1;
  1791. __IOM uint32_t COMIFLG : 1;
  1792. __IOM uint32_t TRGIFLG : 1;
  1793. __IOM uint32_t BRKIFLG : 1;
  1794. __IM uint32_t RESERVED1 : 1;
  1795. __IOM uint32_t CC1RCFLG : 1;
  1796. __IOM uint32_t CC2RCFLG : 1;
  1797. __IOM uint32_t CC3RCFLG : 1;
  1798. __IOM uint32_t CC4RCFLG : 1;
  1799. __IM uint32_t RESERVED2 : 19;
  1800. } STS_B;
  1801. };
  1802. /** @brief Software controls event generation registers */
  1803. union
  1804. {
  1805. __OM uint32_t CEG;
  1806. struct
  1807. {
  1808. __OM uint32_t UEG : 1;
  1809. __OM uint32_t CC1EG : 1;
  1810. __OM uint32_t CC2EG : 1;
  1811. __OM uint32_t CC3EG : 1;
  1812. __OM uint32_t CC4EG : 1;
  1813. __OM uint32_t COMG : 1;
  1814. __OM uint32_t TEG : 1;
  1815. __OM uint32_t BEG : 1;
  1816. __IM uint32_t RESERVED : 24;
  1817. } CEG_B;
  1818. };
  1819. /** @brief Capture the compare mode register 1 */
  1820. union
  1821. {
  1822. __IOM uint32_t CCM1;
  1823. /** @brief Compare mode */
  1824. struct
  1825. {
  1826. __IOM uint32_t CC1SEL : 2;
  1827. __IOM uint32_t OC1FEN : 1;
  1828. __IOM uint32_t OC1PEN : 1;
  1829. __IOM uint32_t OC1MOD : 3;
  1830. __IOM uint32_t OC1CEN : 1;
  1831. __IOM uint32_t CC2SEL : 2;
  1832. __IOM uint32_t OC2FEN : 1;
  1833. __IOM uint32_t OC2PEN : 1;
  1834. __IOM uint32_t OC2MOD : 3;
  1835. __IOM uint32_t OC2CEN : 1;
  1836. __IM uint32_t RESERVED : 16;
  1837. } CCM1_COMPARE_B;
  1838. /** @brief Capture mode */
  1839. struct
  1840. {
  1841. __IOM uint32_t CC1SEL : 2;
  1842. __IOM uint32_t IC1PSC : 2;
  1843. __IOM uint32_t IC1F : 4;
  1844. __IOM uint32_t CC2SEL : 2;
  1845. __IOM uint32_t IC2PSC : 2;
  1846. __IOM uint32_t IC2F : 4;
  1847. __IM uint32_t RESERVED : 16;
  1848. } CCM1_CAPTURE_B;
  1849. };
  1850. /** @brief Capture the compare mode register 2 */
  1851. union
  1852. {
  1853. __IOM uint32_t CCM2;
  1854. /** @brief Compare mode */
  1855. struct
  1856. {
  1857. __IOM uint32_t CC3SEL : 2;
  1858. __IOM uint32_t OC3FEN : 1;
  1859. __IOM uint32_t OC3PEN : 1;
  1860. __IOM uint32_t OC3MOD : 3;
  1861. __IOM uint32_t OC3CEN : 1;
  1862. __IOM uint32_t CC4SEL : 2;
  1863. __IOM uint32_t OC4FEN : 1;
  1864. __IOM uint32_t OC4PEN : 1;
  1865. __IOM uint32_t OC4MOD : 3;
  1866. __IOM uint32_t OC4CEN : 1;
  1867. __IM uint32_t RESERVED : 16;
  1868. } CCM2_COMPARE_B;
  1869. /** @brief Capture mode */
  1870. struct
  1871. {
  1872. __IOM uint32_t CC3SEL : 2;
  1873. __IOM uint32_t IC3PSC : 2;
  1874. __IOM uint32_t IC3F : 4;
  1875. __IOM uint32_t CC4SEL : 2;
  1876. __IOM uint32_t IC4PSC : 2;
  1877. __IOM uint32_t IC4F : 4;
  1878. __IM uint32_t RESERVED : 16;
  1879. } CCM2_CAPTURE_B;
  1880. };
  1881. /** @brief Channel control register */
  1882. union
  1883. {
  1884. __IOM uint32_t CCEN;
  1885. struct
  1886. {
  1887. __IOM uint32_t CC1EN : 1;
  1888. __IOM uint32_t CC1POL : 1;
  1889. __IOM uint32_t CC1NEN : 1;
  1890. __IOM uint32_t CC1NPOL : 1;
  1891. __IOM uint32_t CC2EN : 1;
  1892. __IOM uint32_t CC2POL : 1;
  1893. __IOM uint32_t CC2NEN : 1;
  1894. __IOM uint32_t CC2NPOL : 1;
  1895. __IOM uint32_t CC3EN : 1;
  1896. __IOM uint32_t CC3POL : 1;
  1897. __IOM uint32_t CC3NEN : 1;
  1898. __IOM uint32_t CC3NPOL : 1;
  1899. __IOM uint32_t CC4EN : 1;
  1900. __IOM uint32_t CC4POL : 1;
  1901. __IM uint32_t RESERVED : 18;
  1902. } CCEN_B;
  1903. };
  1904. /** @brief Counting register */
  1905. union
  1906. {
  1907. __IOM uint32_t CNT;
  1908. struct
  1909. {
  1910. __IOM uint32_t CNT : 16;
  1911. __IM uint32_t RESERVED : 16;
  1912. } CNT_B;
  1913. };
  1914. /** @brief Division register */
  1915. union
  1916. {
  1917. __IOM uint32_t PSC;
  1918. struct
  1919. {
  1920. __IOM uint32_t PSC : 16;
  1921. __IM uint32_t RESERVED : 16;
  1922. } PSC_B;
  1923. };
  1924. /** @brief Automatic reload register */
  1925. union
  1926. {
  1927. __IOM uint32_t AUTORLD;
  1928. struct
  1929. {
  1930. __IOM uint32_t AUTORLD : 16;
  1931. __IM uint32_t RESERVED : 16;
  1932. } AUTORLD_B;
  1933. };
  1934. /** @brief Repeat count register */
  1935. union
  1936. {
  1937. __IOM uint32_t REPCNT;
  1938. struct
  1939. {
  1940. __IOM uint32_t REPCNT : 8;
  1941. __IM uint32_t RESERVED : 24;
  1942. } REPCNT_B;
  1943. };
  1944. /** @brief Capture comparison register channel 1 */
  1945. union
  1946. {
  1947. __IOM uint32_t CC1;
  1948. struct
  1949. {
  1950. __IOM uint32_t CC1 : 16;
  1951. __IM uint32_t RESERVED : 16;
  1952. } CC1_B;
  1953. };
  1954. /** @brief Capture comparison register channel 2 */
  1955. union
  1956. {
  1957. __IOM uint32_t CC2;
  1958. struct
  1959. {
  1960. __IOM uint32_t CC2 : 16;
  1961. __IM uint32_t RESERVED : 16;
  1962. } CC2_B;
  1963. };
  1964. /** @brief Capture comparison register channel 3 */
  1965. union
  1966. {
  1967. __IOM uint32_t CC3;
  1968. struct
  1969. {
  1970. __IOM uint32_t CC3 : 16;
  1971. __IM uint32_t RESERVED : 16;
  1972. } CC3_B;
  1973. };
  1974. /** @brief Capture comparison register channel 4 */
  1975. union
  1976. {
  1977. __IOM uint32_t CC4;
  1978. struct
  1979. {
  1980. __IOM uint32_t CC4 : 16;
  1981. __IM uint32_t RESERVED : 16;
  1982. } CC4_B;
  1983. };
  1984. /** @brief Brake and dead zone registers */
  1985. union
  1986. {
  1987. __IOM uint32_t BDT;
  1988. struct
  1989. {
  1990. __IOM uint32_t DTS : 8;
  1991. __IOM uint32_t LOCKCFG : 2;
  1992. __IOM uint32_t IMOS : 1;
  1993. __IOM uint32_t RMOS : 1;
  1994. __IOM uint32_t BRKEN : 1;
  1995. __IOM uint32_t BRKPOL : 1;
  1996. __IOM uint32_t AOEN : 1;
  1997. __IOM uint32_t MOEN : 1;
  1998. __IM uint32_t RESERVED : 16;
  1999. } BDT_B;
  2000. };
  2001. /** @brief DMA control register */
  2002. union
  2003. {
  2004. __IOM uint32_t DCTRL;
  2005. struct
  2006. {
  2007. __IOM uint32_t DBADDR : 5;
  2008. __IM uint32_t RESERVED1 : 3;
  2009. __IOM uint32_t DBLEN : 5;
  2010. __IM uint32_t RESERVED2 : 19;
  2011. } DCTRL_B;
  2012. };
  2013. /** @brief Consecutive DMA addresses */
  2014. union
  2015. {
  2016. __IOM uint32_t DMADDR;
  2017. struct
  2018. {
  2019. __IOM uint32_t DMADDR : 16;
  2020. __IM uint32_t RESERVED2 : 16;
  2021. } DMADDR_B;
  2022. };
  2023. } TMR_T;
  2024. /**
  2025. * @brief Direct Memory Access register(DMA)
  2026. */
  2027. typedef struct
  2028. {
  2029. /** @brief Interrupt status register */
  2030. union
  2031. {
  2032. __IM uint32_t INTSTS;
  2033. struct
  2034. {
  2035. __IM uint32_t GINTFLG1 : 1;
  2036. __IM uint32_t TCFLG1 : 1;
  2037. __IM uint32_t HTFLG1 : 1;
  2038. __IM uint32_t TERRFLG1 : 1;
  2039. __IM uint32_t GINTFLG2 : 1;
  2040. __IM uint32_t TCFLG2 : 1;
  2041. __IM uint32_t HTFLG2 : 1;
  2042. __IM uint32_t TERRFLG2 : 1;
  2043. __IM uint32_t GINTFLG3 : 1;
  2044. __IM uint32_t TCFLG3 : 1;
  2045. __IM uint32_t HTFLG3 : 1;
  2046. __IM uint32_t TERRFLG3 : 1;
  2047. __IM uint32_t GINTFLG4 : 1;
  2048. __IM uint32_t TCFLG4 : 1;
  2049. __IM uint32_t HTFLG4 : 1;
  2050. __IM uint32_t TERRFLG4 : 1;
  2051. __IM uint32_t GINTFLG5 : 1;
  2052. __IM uint32_t TCFLG5 : 1;
  2053. __IM uint32_t HTFLG5 : 1;
  2054. __IM uint32_t TERRFLG5 : 1;
  2055. __IM uint32_t GINTFLG6 : 1;
  2056. __IM uint32_t TCFLG6 : 1;
  2057. __IM uint32_t HTFLG6 : 1;
  2058. __IM uint32_t TERRFLG6 : 1;
  2059. __IM uint32_t GINTFLG7 : 1;
  2060. __IM uint32_t TCFLG7 : 1;
  2061. __IM uint32_t HTFLG7 : 1;
  2062. __IM uint32_t TERRFLG7 : 1;
  2063. __IM uint32_t RESERVED : 4;
  2064. } INTSTS_B;
  2065. };
  2066. /** @brief Interrupt reset register */
  2067. union
  2068. {
  2069. __OM uint32_t INTFCLR;
  2070. struct
  2071. {
  2072. __OM uint32_t GINTCLR1 : 1;
  2073. __OM uint32_t TCCLR1 : 1;
  2074. __OM uint32_t HTCLR1 : 1;
  2075. __OM uint32_t TERRCLR1 : 1;
  2076. __OM uint32_t GINTCLR2 : 1;
  2077. __OM uint32_t TCCLR2 : 1;
  2078. __OM uint32_t HTCLR2 : 1;
  2079. __OM uint32_t TERRCLR2 : 1;
  2080. __OM uint32_t GINTCLR3 : 1;
  2081. __OM uint32_t TCCLR3 : 1;
  2082. __OM uint32_t HTCLR3 : 1;
  2083. __OM uint32_t TERRCLR3 : 1;
  2084. __OM uint32_t GINTCLR4 : 1;
  2085. __OM uint32_t TCCLR4 : 1;
  2086. __OM uint32_t HTCLR4 : 1;
  2087. __OM uint32_t TERRCLR4 : 1;
  2088. __OM uint32_t GINTCLR5 : 1;
  2089. __OM uint32_t TCCLR5 : 1;
  2090. __OM uint32_t HTCLR5 : 1;
  2091. __OM uint32_t TERRCLR5 : 1;
  2092. __OM uint32_t GINTCLR6 : 1;
  2093. __OM uint32_t TCCLR6 : 1;
  2094. __OM uint32_t HTCLR6 : 1;
  2095. __OM uint32_t TERRCLR6 : 1;
  2096. __OM uint32_t GINTCLR7 : 1;
  2097. __OM uint32_t TCCLR7 : 1;
  2098. __OM uint32_t HTCLR7 : 1;
  2099. __OM uint32_t TERRCLR7 : 1;
  2100. __IM uint32_t RESERVED : 4;
  2101. } INTFCLR_B;
  2102. };
  2103. } DMA_T;
  2104. /**
  2105. * @brief DMA Channel register
  2106. */
  2107. typedef struct
  2108. {
  2109. /** @brief DMA Channel setup register */
  2110. union
  2111. {
  2112. __IOM uint32_t CHCFG;
  2113. struct
  2114. {
  2115. __IOM uint32_t CHEN : 1;
  2116. __IOM uint32_t TCINTEN : 1;
  2117. __IOM uint32_t HTINTEN : 1;
  2118. __IOM uint32_t TERRINTEN : 1;
  2119. __IOM uint32_t DIRCFG : 1;
  2120. __IOM uint32_t CIRMODE : 1;
  2121. __IOM uint32_t PERIMODE : 1;
  2122. __IOM uint32_t MIMODE : 1;
  2123. __IOM uint32_t PERSIZE : 2;
  2124. __IOM uint32_t MEMSIZE : 2;
  2125. __IOM uint32_t CHPL : 2;
  2126. __IOM uint32_t M2MMODE : 1;
  2127. __IM uint32_t RESERVED : 17;
  2128. } CHCFG_B;
  2129. };
  2130. /** @brief DMA Channel transfer number register*/
  2131. union
  2132. {
  2133. __IOM uint32_t CHNDATA;
  2134. struct
  2135. {
  2136. __IOM uint32_t NDATA : 16;
  2137. __IM uint32_t RESERVED : 16;
  2138. } CHNDATA_B;
  2139. };
  2140. /** @brief DMA Channel peripheral address register */
  2141. union
  2142. {
  2143. __IOM uint32_t CHPADDR;
  2144. struct
  2145. {
  2146. __IOM uint32_t PERADDR : 32;
  2147. } CHPADDR_B;
  2148. };
  2149. /** @brief DMA Channel memory address register */
  2150. union
  2151. {
  2152. __IOM uint32_t CHMADDR;
  2153. struct
  2154. {
  2155. __IOM uint32_t MEMADDR : 32;
  2156. } CHMADDR_B;
  2157. };
  2158. } DMA_Channel_T;
  2159. /**
  2160. * @brief CAN sending mailbox
  2161. */
  2162. typedef struct
  2163. {
  2164. /** @brief CAN Each mailbox contains the sending mailbox identifier register */
  2165. union
  2166. {
  2167. __IOM uint32_t TXMID;
  2168. struct
  2169. {
  2170. __IOM uint32_t TXMREQ : 1;
  2171. __IOM uint32_t TXRFREQ : 1;
  2172. __IOM uint32_t IDTYPESEL : 1;
  2173. __IOM uint32_t EXTID : 18;
  2174. __IOM uint32_t STDID : 11;
  2175. } TXMID_B;
  2176. };
  2177. /** @brief CAN Send the mailbox data length and timestamp register */
  2178. union
  2179. {
  2180. __IOM uint32_t TXDLEN;
  2181. struct
  2182. {
  2183. __IOM uint32_t DLCODE : 4;
  2184. __IOM uint32_t RESERVED : 28;
  2185. } TXDLEN_B;
  2186. };
  2187. /** @brief CAN Send mailbox low byte data register */
  2188. union
  2189. {
  2190. __IOM uint32_t TXMDL;
  2191. struct
  2192. {
  2193. __IOM uint32_t DATABYTE0 : 8;
  2194. __IOM uint32_t DATABYTE1 : 8;
  2195. __IOM uint32_t DATABYTE2 : 8;
  2196. __IOM uint32_t DATABYTE3 : 8;
  2197. } TXMDL_B;
  2198. };
  2199. /** @brief CAN Send mailbox High byte data register */
  2200. union
  2201. {
  2202. __IOM uint32_t TXMDH;
  2203. struct
  2204. {
  2205. __IOM uint32_t DATABYTE4 : 8;
  2206. __IOM uint32_t DATABYTE5 : 8;
  2207. __IOM uint32_t DATABYTE6 : 8;
  2208. __IOM uint32_t DATABYTE7 : 8;
  2209. } TXMDH_B;
  2210. };
  2211. } CAN_TxMailBox_T;
  2212. /**
  2213. * @brief CAN receive mailbox
  2214. */
  2215. typedef struct
  2216. {
  2217. /** @brief CAN Each mailbox contains the receive mailbox identifier register */
  2218. union
  2219. {
  2220. __IM uint32_t RXMID;
  2221. struct
  2222. {
  2223. __IM uint32_t RESERVED : 1;
  2224. __IM uint32_t RFTXREQ : 1;
  2225. __IM uint32_t IDTYPESEL : 1;
  2226. __IM uint32_t EXTID : 18;
  2227. __IM uint32_t STDID : 11;
  2228. } RXMID_B;
  2229. };
  2230. /** @brief CAN receive the mailbox data length and timestamp register */
  2231. union
  2232. {
  2233. __IM uint32_t RXDLEN;
  2234. struct
  2235. {
  2236. __IM uint32_t DLCODE : 4;
  2237. __IM uint32_t RESERVED1 : 4;
  2238. __IM uint32_t FMIDX : 8;
  2239. __IM uint32_t RESERVED2 : 16;
  2240. } RXDLEN_B;
  2241. };
  2242. /** @brief CAN receive mailbox low byte data register */
  2243. union
  2244. {
  2245. __IM uint32_t RXMDL;
  2246. struct
  2247. {
  2248. __IM uint32_t DATABYTE0 : 8;
  2249. __IM uint32_t DATABYTE1 : 8;
  2250. __IM uint32_t DATABYTE2 : 8;
  2251. __IM uint32_t DATABYTE3 : 8;
  2252. } RXMDL_B;
  2253. };
  2254. /** @briefCAN receive mailbox High byte data register */
  2255. union
  2256. {
  2257. __IOM uint32_t RXMDH;
  2258. struct
  2259. {
  2260. __IM uint32_t DATABYTE4 : 8;
  2261. __IM uint32_t DATABYTE5 : 8;
  2262. __IM uint32_t DATABYTE6 : 8;
  2263. __IM uint32_t DATABYTE7 : 8;
  2264. } RXMDH_B;
  2265. };
  2266. } CAN_RxMailBox_T;
  2267. /**
  2268. * @brief CAN Filter bank register
  2269. */
  2270. typedef struct
  2271. {
  2272. /** @brief CAN Filter bank register 1 */
  2273. union
  2274. {
  2275. __IOM uint32_t FBANK1;
  2276. struct
  2277. {
  2278. __IOM uint32_t FBIT0 : 1;
  2279. __IOM uint32_t FBIT1 : 1;
  2280. __IOM uint32_t FBIT2 : 1;
  2281. __IOM uint32_t FBIT3 : 1;
  2282. __IOM uint32_t FBIT4 : 1;
  2283. __IOM uint32_t FBIT5 : 1;
  2284. __IOM uint32_t FBIT6 : 1;
  2285. __IOM uint32_t FBIT7 : 1;
  2286. __IOM uint32_t FBIT8 : 1;
  2287. __IOM uint32_t FBIT9 : 1;
  2288. __IOM uint32_t FBIT10 : 1;
  2289. __IOM uint32_t FBIT11 : 1;
  2290. __IOM uint32_t FBIT12 : 1;
  2291. __IOM uint32_t FBIT13 : 1;
  2292. __IOM uint32_t FBIT14 : 1;
  2293. __IOM uint32_t FBIT15 : 1;
  2294. __IOM uint32_t FBIT16 : 1;
  2295. __IOM uint32_t FBIT17 : 1;
  2296. __IOM uint32_t FBIT18 : 1;
  2297. __IOM uint32_t FBIT19 : 1;
  2298. __IOM uint32_t FBIT20 : 1;
  2299. __IOM uint32_t FBIT21 : 1;
  2300. __IOM uint32_t FBIT22 : 1;
  2301. __IOM uint32_t FBIT23 : 1;
  2302. __IOM uint32_t FBIT24 : 1;
  2303. __IOM uint32_t FBIT25 : 1;
  2304. __IOM uint32_t FBIT26 : 1;
  2305. __IOM uint32_t FBIT27 : 1;
  2306. __IOM uint32_t FBIT28 : 1;
  2307. __IOM uint32_t FBIT29 : 1;
  2308. __IOM uint32_t FBIT30 : 1;
  2309. __IOM uint32_t FBIT31 : 1;
  2310. } FBANK1_B;
  2311. };
  2312. /** @brief CAN Filter bank register 2 */
  2313. union
  2314. {
  2315. __IOM uint32_t FBANK2;
  2316. struct
  2317. {
  2318. __IOM uint32_t FBIT0 : 1;
  2319. __IOM uint32_t FBIT1 : 1;
  2320. __IOM uint32_t FBIT2 : 1;
  2321. __IOM uint32_t FBIT3 : 1;
  2322. __IOM uint32_t FBIT4 : 1;
  2323. __IOM uint32_t FBIT5 : 1;
  2324. __IOM uint32_t FBIT6 : 1;
  2325. __IOM uint32_t FBIT7 : 1;
  2326. __IOM uint32_t FBIT8 : 1;
  2327. __IOM uint32_t FBIT9 : 1;
  2328. __IOM uint32_t FBIT10 : 1;
  2329. __IOM uint32_t FBIT11 : 1;
  2330. __IOM uint32_t FBIT12 : 1;
  2331. __IOM uint32_t FBIT13 : 1;
  2332. __IOM uint32_t FBIT14 : 1;
  2333. __IOM uint32_t FBIT15 : 1;
  2334. __IOM uint32_t FBIT16 : 1;
  2335. __IOM uint32_t FBIT17 : 1;
  2336. __IOM uint32_t FBIT18 : 1;
  2337. __IOM uint32_t FBIT19 : 1;
  2338. __IOM uint32_t FBIT20 : 1;
  2339. __IOM uint32_t FBIT21 : 1;
  2340. __IOM uint32_t FBIT22 : 1;
  2341. __IOM uint32_t FBIT23 : 1;
  2342. __IOM uint32_t FBIT24 : 1;
  2343. __IOM uint32_t FBIT25 : 1;
  2344. __IOM uint32_t FBIT26 : 1;
  2345. __IOM uint32_t FBIT27 : 1;
  2346. __IOM uint32_t FBIT28 : 1;
  2347. __IOM uint32_t FBIT29 : 1;
  2348. __IOM uint32_t FBIT30 : 1;
  2349. __IOM uint32_t FBIT31 : 1;
  2350. } FBANK2_B;
  2351. };
  2352. } CAN_FilterRegister_T;
  2353. /**
  2354. * @brief Controller Area Network(CAN)
  2355. */
  2356. typedef struct
  2357. {
  2358. /** @brief CAN Master control register */
  2359. union
  2360. {
  2361. __IOM uint32_t MCTRL;
  2362. struct
  2363. {
  2364. __IOM uint32_t INITREQ : 1;
  2365. __IOM uint32_t SLEEPREQ : 1;
  2366. __IOM uint32_t TXFPCFG : 1;
  2367. __IOM uint32_t RXFLOCK : 1;
  2368. __IOM uint32_t ARTXMD : 1;
  2369. __IOM uint32_t AWUPCFG : 1;
  2370. __IOM uint32_t ALBOFFM : 1;
  2371. __IM uint32_t RESERVED1 : 8;
  2372. __IOM uint32_t SWRST : 1;
  2373. __IOM uint32_t DBGFRZE : 1;
  2374. __IM uint32_t RESERVED2 : 15;
  2375. } MCTRL_B;
  2376. };
  2377. /** @brief CAN Master States register */
  2378. union
  2379. {
  2380. __IOM uint32_t MSTS;
  2381. struct
  2382. {
  2383. __IM uint32_t INITFLG : 1;
  2384. __IM uint32_t SLEEPFLG : 1;
  2385. __IOM uint32_t ERRIFLG : 1;
  2386. __IOM uint32_t WUPIFLG : 1;
  2387. __IOM uint32_t SLEEPIFLG : 1;
  2388. __IM uint32_t RESERVED1 : 3;
  2389. __IM uint32_t TXMFLG : 1;
  2390. __IM uint32_t RXMFLG : 1;
  2391. __IM uint32_t LSAMVALUE : 1;
  2392. __IM uint32_t RXSIGL : 1;
  2393. __IM uint32_t RESERVED2 : 20;
  2394. } MSTS_B;
  2395. };
  2396. /** @brief CAN Send States register */
  2397. union
  2398. {
  2399. __IOM uint32_t TXSTS;
  2400. struct
  2401. {
  2402. __IOM uint32_t REQCFLG0 : 1;
  2403. __IOM uint32_t TXSUSFLG0 : 1;
  2404. __IOM uint32_t ARBLSTFLG0 : 1;
  2405. __IOM uint32_t TXERRFLG0 : 1;
  2406. __IM uint32_t RESERVED1 : 3;
  2407. __IOM uint32_t ABREQFLG0 : 1;
  2408. __IOM uint32_t REQCFLG1 : 1;
  2409. __IOM uint32_t TXSUSFLG1 : 1;
  2410. __IOM uint32_t ARBLSTFLG1 : 1;
  2411. __IOM uint32_t TXERRFLG1 : 1;
  2412. __IM uint32_t RESERVED2 : 3;
  2413. __IOM uint32_t ABREQFLG1 : 1;
  2414. __IOM uint32_t REQCFLG2 : 1;
  2415. __IOM uint32_t TXSUSFLG2 : 1;
  2416. __IOM uint32_t ARBLSTFLG2 : 1;
  2417. __IOM uint32_t TXERRFLG2 : 1;
  2418. __IM uint32_t RESERVED3 : 3;
  2419. __IOM uint32_t ABREQFLG2 : 1;
  2420. __IM uint32_t EMNUM : 2;
  2421. __IM uint32_t TXMEFLG0 : 1;
  2422. __IM uint32_t TXMEFLG1 : 1;
  2423. __IM uint32_t TXMEFLG2 : 1;
  2424. __IM uint32_t LOWESTP0 : 1;
  2425. __IM uint32_t LOWESTP1 : 1;
  2426. __IM uint32_t LOWESTP2 : 1;
  2427. } TXSTS_B;
  2428. };
  2429. /** @brief CAN Receive FIFO 0 register */
  2430. union
  2431. {
  2432. __IOM uint32_t RXF0;
  2433. struct
  2434. {
  2435. __IM uint32_t FMNUM0 : 2;
  2436. __IM uint32_t RESERVED : 1;
  2437. __IOM uint32_t FFULLFLG0 : 1;
  2438. __IOM uint32_t FOVRFLG0 : 1;
  2439. __IOM uint32_t RFOM0 : 1;
  2440. __IM uint32_t RESERVED1 : 26;
  2441. } RXF0_B;
  2442. };
  2443. /** @brief CAN Receive FIFO 1 register */
  2444. union
  2445. {
  2446. __IOM uint32_t RXF1;
  2447. struct
  2448. {
  2449. __IM uint32_t FMNUM1 : 2;
  2450. __IM uint32_t RESERVED1 : 1;
  2451. __IOM uint32_t FFULLFLG1 : 1;
  2452. __IOM uint32_t FOVRFLG1 : 1;
  2453. __IOM uint32_t RFOM1 : 1;
  2454. __IM uint32_t RESERVED2 : 26;
  2455. } RXF1_B;
  2456. };
  2457. /** @brief CAN Interrupts register */
  2458. union
  2459. {
  2460. __IOM uint32_t INTEN;
  2461. struct
  2462. {
  2463. __IOM uint32_t TXMEIEN : 1;
  2464. __IOM uint32_t FMIEN0 : 1;
  2465. __IOM uint32_t FFULLIEN0 : 1;
  2466. __IOM uint32_t FOVRIEN0 : 1;
  2467. __IOM uint32_t FMIEN1 : 1;
  2468. __IOM uint32_t FFULLIEN1 : 1;
  2469. __IOM uint32_t FOVRIEN1 : 1;
  2470. __IM uint32_t RESERVED1 : 1;
  2471. __IOM uint32_t ERRWIEN : 1;
  2472. __IOM uint32_t ERRPIEN : 1;
  2473. __IOM uint32_t BOFFIEN : 1;
  2474. __IOM uint32_t LECIEN : 1;
  2475. __IM uint32_t RESERVED2 : 3;
  2476. __IOM uint32_t ERRIEN : 1;
  2477. __IOM uint32_t WUPIEN : 1;
  2478. __IOM uint32_t SLEEPIEN : 1;
  2479. __IM uint32_t RESERVED3 : 14;
  2480. } INTEN_B;
  2481. };
  2482. /** @brief CAN Error States register */
  2483. union
  2484. {
  2485. __IOM uint32_t ERRSTS;
  2486. struct
  2487. {
  2488. __IM uint32_t ERRWFLG : 1;
  2489. __IM uint32_t ERRPFLG : 1;
  2490. __IM uint32_t BOFLG : 1;
  2491. __IM uint32_t RESERVED1 : 1;
  2492. __IOM uint32_t LERRC : 3;
  2493. __IM uint32_t RESERVED2 : 9;
  2494. __IM uint32_t TXERRCNT : 8;
  2495. __IM uint32_t RXERRCNT : 8;
  2496. } ERRSTS_B;
  2497. };
  2498. /** @brief CAN Bit Time register */
  2499. union
  2500. {
  2501. __IOM uint32_t BITTIM;
  2502. struct
  2503. {
  2504. __IOM uint32_t BRPSC : 10;
  2505. __IM uint32_t RESERVED1 : 6;
  2506. __IOM uint32_t TIMSEG1 : 4;
  2507. __IOM uint32_t TIMSEG2 : 3;
  2508. __IM uint32_t RESERVED2 : 1;
  2509. __IOM uint32_t RSYNJW : 2;
  2510. __IM uint32_t RESERVED3 : 4;
  2511. __IOM uint32_t LBKMEN : 1;
  2512. __IOM uint32_t SILMEN : 1;
  2513. } BITTIM_B;
  2514. };
  2515. __IM uint32_t RESERVED0[88];
  2516. CAN_TxMailBox_T sTxMailBox[3];
  2517. CAN_RxMailBox_T sRxMailBox[2];
  2518. __IM uint32_t RESERVED1[12];
  2519. /** @brief CAN Filter the master control register */
  2520. union
  2521. {
  2522. __IOM uint32_t FCTRL;
  2523. struct
  2524. {
  2525. __IOM uint32_t FINITEN : 1;
  2526. __IM uint32_t RESERVED : 7;
  2527. __IOM uint32_t CAN2BN : 6;
  2528. __IM uint32_t RESERVED1 : 18;
  2529. } FCTRL_B;
  2530. };
  2531. /** @brief CAN Filter register */
  2532. union
  2533. {
  2534. __IOM uint32_t FMCFG;
  2535. struct
  2536. {
  2537. __IOM uint32_t FMCFG0 : 1;
  2538. __IOM uint32_t FMCFG1 : 1;
  2539. __IOM uint32_t FMCFG2 : 1;
  2540. __IOM uint32_t FMCFG3 : 1;
  2541. __IOM uint32_t FMCFG4 : 1;
  2542. __IOM uint32_t FMCFG5 : 1;
  2543. __IOM uint32_t FMCFG6 : 1;
  2544. __IOM uint32_t FMCFG7 : 1;
  2545. __IOM uint32_t FMCFG8 : 1;
  2546. __IOM uint32_t FMCFG9 : 1;
  2547. __IOM uint32_t FMCFG10 : 1;
  2548. __IOM uint32_t FMCFG11 : 1;
  2549. __IOM uint32_t FMCFG12 : 1;
  2550. __IOM uint32_t FMCFG13 : 1;
  2551. __IOM uint32_t FMCFG14 : 1;
  2552. __IOM uint32_t FMCFG15 : 1;
  2553. __IOM uint32_t FMCFG16 : 1;
  2554. __IOM uint32_t FMCFG17 : 1;
  2555. __IOM uint32_t FMCFG18 : 1;
  2556. __IOM uint32_t FMCFG19 : 1;
  2557. __IOM uint32_t FMCFG20 : 1;
  2558. __IOM uint32_t FMCFG21 : 1;
  2559. __IOM uint32_t FMCFG22 : 1;
  2560. __IOM uint32_t FMCFG23 : 1;
  2561. __IOM uint32_t FMCFG24 : 1;
  2562. __IOM uint32_t FMCFG25 : 1;
  2563. __IOM uint32_t FMCFG26 : 1;
  2564. __IOM uint32_t FMCFG27 : 1;
  2565. __IM uint32_t RESERVED : 4;
  2566. } FMCFG_B;
  2567. };
  2568. __IM uint32_t RESERVED2;
  2569. /** @brief CAN Filter bit scale register */
  2570. union
  2571. {
  2572. __IOM uint32_t FSCFG;
  2573. struct
  2574. {
  2575. __IOM uint32_t FSCFG0 : 1;
  2576. __IOM uint32_t FSCFG1 : 1;
  2577. __IOM uint32_t FSCFG2 : 1;
  2578. __IOM uint32_t FSCFG3 : 1;
  2579. __IOM uint32_t FSCFG4 : 1;
  2580. __IOM uint32_t FSCFG5 : 1;
  2581. __IOM uint32_t FSCFG6 : 1;
  2582. __IOM uint32_t FSCFG7 : 1;
  2583. __IOM uint32_t FSCFG8 : 1;
  2584. __IOM uint32_t FSCFG9 : 1;
  2585. __IOM uint32_t FSCFG10 : 1;
  2586. __IOM uint32_t FSCFG11 : 1;
  2587. __IOM uint32_t FSCFG12 : 1;
  2588. __IOM uint32_t FSCFG13 : 1;
  2589. __IOM uint32_t FSCFG14 : 1;
  2590. __IOM uint32_t FSCFG15 : 1;
  2591. __IOM uint32_t FSCFG16 : 1;
  2592. __IOM uint32_t FSCFG17 : 1;
  2593. __IOM uint32_t FSCFG18 : 1;
  2594. __IOM uint32_t FSCFG19 : 1;
  2595. __IOM uint32_t FSCFG20 : 1;
  2596. __IOM uint32_t FSCFG21 : 1;
  2597. __IOM uint32_t FSCFG22 : 1;
  2598. __IOM uint32_t FSCFG23 : 1;
  2599. __IOM uint32_t FSCFG24 : 1;
  2600. __IOM uint32_t FSCFG25 : 1;
  2601. __IOM uint32_t FSCFG26 : 1;
  2602. __IOM uint32_t FSCFG27 : 1;
  2603. __IM uint32_t RESERVED : 4;
  2604. } FSCFG_B;
  2605. };
  2606. __IM uint32_t RESERVED3;
  2607. /** @brief CAN Filter FIFO associated registers */
  2608. union
  2609. {
  2610. __IOM uint32_t FFASS;
  2611. struct
  2612. {
  2613. __IOM uint32_t FFASS0 : 1;
  2614. __IOM uint32_t FFASS1 : 1;
  2615. __IOM uint32_t FFASS2 : 1;
  2616. __IOM uint32_t FFASS3 : 1;
  2617. __IOM uint32_t FFASS4 : 1;
  2618. __IOM uint32_t FFASS5 : 1;
  2619. __IOM uint32_t FFASS6 : 1;
  2620. __IOM uint32_t FFASS7 : 1;
  2621. __IOM uint32_t FFASS8 : 1;
  2622. __IOM uint32_t FFASS9 : 1;
  2623. __IOM uint32_t FFASS10 : 1;
  2624. __IOM uint32_t FFASS11 : 1;
  2625. __IOM uint32_t FFASS12 : 1;
  2626. __IOM uint32_t FFASS13 : 1;
  2627. __IOM uint32_t FFASS14 : 1;
  2628. __IOM uint32_t FFASS15 : 1;
  2629. __IOM uint32_t FFASS16 : 1;
  2630. __IOM uint32_t FFASS17 : 1;
  2631. __IOM uint32_t FFASS18 : 1;
  2632. __IOM uint32_t FFASS19 : 1;
  2633. __IOM uint32_t FFASS20 : 1;
  2634. __IOM uint32_t FFASS21 : 1;
  2635. __IOM uint32_t FFASS22 : 1;
  2636. __IOM uint32_t FFASS23 : 1;
  2637. __IOM uint32_t FFASS24 : 1;
  2638. __IOM uint32_t FFASS25 : 1;
  2639. __IOM uint32_t FFASS26 : 1;
  2640. __IOM uint32_t FFASS27 : 1;
  2641. __IM uint32_t RESERVED : 4;
  2642. } FFASS_B;
  2643. };
  2644. __IM uint32_t RESERVED4;
  2645. /** @brief CAN Filter activation register */
  2646. union
  2647. {
  2648. __IOM uint32_t FACT;
  2649. struct
  2650. {
  2651. __IOM uint32_t FACT0 : 1;
  2652. __IOM uint32_t FACT1 : 1;
  2653. __IOM uint32_t FACT2 : 1;
  2654. __IOM uint32_t FACT3 : 1;
  2655. __IOM uint32_t FACT4 : 1;
  2656. __IOM uint32_t FACT5 : 1;
  2657. __IOM uint32_t FACT6 : 1;
  2658. __IOM uint32_t FACT7 : 1;
  2659. __IOM uint32_t FACT8 : 1;
  2660. __IOM uint32_t FACT9 : 1;
  2661. __IOM uint32_t FACT10 : 1;
  2662. __IOM uint32_t FACT11 : 1;
  2663. __IOM uint32_t FACT12 : 1;
  2664. __IOM uint32_t FACT13 : 1;
  2665. __IOM uint32_t FACT14 : 1;
  2666. __IOM uint32_t FACT15 : 1;
  2667. __IOM uint32_t FACT16 : 1;
  2668. __IOM uint32_t FACT17 : 1;
  2669. __IOM uint32_t FACT18 : 1;
  2670. __IOM uint32_t FACT19 : 1;
  2671. __IOM uint32_t FACT20 : 1;
  2672. __IOM uint32_t FACT21 : 1;
  2673. __IOM uint32_t FACT22 : 1;
  2674. __IOM uint32_t FACT23 : 1;
  2675. __IOM uint32_t FACT24 : 1;
  2676. __IOM uint32_t FACT25 : 1;
  2677. __IOM uint32_t FACT26 : 1;
  2678. __IOM uint32_t FACT27 : 1;
  2679. __IM uint32_t RESERVED : 4;
  2680. } FACT_B;
  2681. };
  2682. __IM uint32_t RESERVED5[8];
  2683. CAN_FilterRegister_T sFilterRegister[28];
  2684. } CAN_T;
  2685. /**
  2686. * @brief I2C register (I2C)
  2687. */
  2688. typedef struct
  2689. {
  2690. /** @brief Control register 1 */
  2691. union
  2692. {
  2693. __IOM uint32_t CTRL1;
  2694. struct
  2695. {
  2696. __IOM uint32_t I2CEN : 1;
  2697. __IOM uint32_t SMBEN : 1;
  2698. __IM uint32_t RESERVED1 : 1;
  2699. __IOM uint32_t SMBTCFG : 1;
  2700. __IOM uint32_t ARPEN : 1;
  2701. __IOM uint32_t PECEN : 1;
  2702. __IOM uint32_t SRBEN : 1;
  2703. __IOM uint32_t CLKSTRETCHD : 1;
  2704. __IOM uint32_t START : 1;
  2705. __IOM uint32_t STOP : 1;
  2706. __IOM uint32_t ACKEN : 1;
  2707. __IOM uint32_t ACKPOS : 1;
  2708. __IOM uint32_t PEC : 1;
  2709. __IOM uint32_t ALERTEN : 1;
  2710. __IM uint32_t RESERVED2 : 1;
  2711. __IOM uint32_t SWRST : 1;
  2712. __IM uint32_t RESERVED3 : 16;
  2713. } CTRL1_B;
  2714. } ;
  2715. /** @brief Control register 2 */
  2716. union
  2717. {
  2718. __IOM uint32_t CTRL2;
  2719. struct
  2720. {
  2721. __IOM uint32_t CLKFCFG : 6;
  2722. __IM uint32_t RESERVED1 : 2;
  2723. __IOM uint32_t ERRIEN : 1;
  2724. __IOM uint32_t EVIEN : 1;
  2725. __IOM uint32_t BUFIEN : 1;
  2726. __IOM uint32_t DMAEN : 1;
  2727. __IOM uint32_t LTCFG : 1;
  2728. __IM uint32_t RESERVED2 : 19;
  2729. } CTRL2_B;
  2730. } ;
  2731. /** @brief Slave machine address register 1 */
  2732. union
  2733. {
  2734. __IOM uint32_t SADDR1;
  2735. struct
  2736. {
  2737. __IOM uint32_t ADDR0 : 1;
  2738. __IOM uint32_t ADDR1_7 : 7;
  2739. __IOM uint32_t ADDR8_9 : 2;
  2740. __IM uint32_t RESERVED1 : 5;
  2741. __IOM uint32_t ADDRLEN : 1;
  2742. __IM uint32_t RESERVED2 : 16;
  2743. } SADDR1_B;
  2744. };
  2745. /** @brief Slave machine address register 2 */
  2746. union
  2747. {
  2748. __IOM uint32_t SADDR2;
  2749. struct
  2750. {
  2751. __IOM uint32_t ADDRNUM : 1;
  2752. __IOM uint32_t ADDR2 : 7;
  2753. __IM uint32_t RESERVED : 24;
  2754. } SADDR2_B;
  2755. };
  2756. /** @brief Cache data register */
  2757. union
  2758. {
  2759. __IOM uint32_t DATA;
  2760. struct
  2761. {
  2762. __IOM uint32_t DATA : 8;
  2763. __IM uint32_t RESERVED : 24;
  2764. } DATA_B;
  2765. };
  2766. /** @brief Status register 1 */
  2767. union
  2768. {
  2769. __IOM uint32_t STS1;
  2770. struct
  2771. {
  2772. __IM uint32_t STARTFLG : 1;
  2773. __IM uint32_t ADDRFLG : 1;
  2774. __IM uint32_t BTCFLG : 1;
  2775. __IM uint32_t ADDR10FLG : 1;
  2776. __IM uint32_t STOPFLG : 1;
  2777. __IM uint32_t RESERVED1 : 1;
  2778. __IM uint32_t RXBNEFLG : 1;
  2779. __IM uint32_t TXBEFLG : 1;
  2780. __IOM uint32_t BERRFLG : 1;
  2781. __IOM uint32_t ALFLG : 1;
  2782. __IOM uint32_t AEFLG : 1;
  2783. __IOM uint32_t OVRURFLG : 1;
  2784. __IOM uint32_t PECEFLG : 1;
  2785. __IM uint32_t RESERVED2 : 1;
  2786. __IOM uint32_t TTEFLG : 1;
  2787. __IOM uint32_t SMBALTFLG : 1;
  2788. __IM uint32_t RESERVED3 : 16;
  2789. } STS1_B;
  2790. };
  2791. /** @brief Status register 2 */
  2792. union
  2793. {
  2794. __IOM uint32_t STS2;
  2795. struct
  2796. {
  2797. __IM uint32_t MSFLG : 1;
  2798. __IM uint32_t BUSBSYFLG : 1;
  2799. __IM uint32_t TRFLG : 1;
  2800. __IM uint32_t RESERVED1 : 1;
  2801. __IM uint32_t GENCALLFLG : 1;
  2802. __IM uint32_t SMBDADDRFLG : 1;
  2803. __IM uint32_t SMMHADDR : 1;
  2804. __IM uint32_t DUALADDRFLG : 1;
  2805. __IM uint32_t PECVALUE : 8;
  2806. __IM uint32_t RESERVED2 : 16;
  2807. } STS2_B;
  2808. };
  2809. /** @brief Clock control register */
  2810. union
  2811. {
  2812. __IOM uint32_t CLKCTRL;
  2813. struct
  2814. {
  2815. __IOM uint32_t CLKS : 12;
  2816. __IM uint32_t RESERVED1 : 2;
  2817. __IOM uint32_t FDUTYCFG : 1;
  2818. __IOM uint32_t SPEEDCFG : 1;
  2819. __IM uint32_t RESERVED2 : 16;
  2820. } CLKCTRL_B;
  2821. };
  2822. /** @brief Maximum rise time */
  2823. union
  2824. {
  2825. __IOM uint32_t RISETMAX;
  2826. struct
  2827. {
  2828. __IOM uint32_t RISETMAX : 6;
  2829. __IM uint32_t RESERVED : 26;
  2830. } RISETMAX_B;
  2831. };
  2832. __IM uint32_t RESERVED[55];
  2833. /** @brief I2C Switching register */
  2834. union
  2835. {
  2836. __IOM uint32_t SWITCH;
  2837. struct
  2838. {
  2839. __IOM uint32_t SWITCH : 1;
  2840. __IM uint32_t RESERVED1 : 31;
  2841. } SWITCH_B;
  2842. };
  2843. } I2C_T;
  2844. typedef struct
  2845. {
  2846. __IOM uint16_t RDP;
  2847. __IOM uint16_t USER;
  2848. __IOM uint16_t Data0;
  2849. __IOM uint16_t Data1;
  2850. __IOM uint16_t WRP0;
  2851. __IOM uint16_t WRP1;
  2852. __IOM uint16_t WRP2;
  2853. __IOM uint16_t WRP3;
  2854. } OB_T;
  2855. /**
  2856. * @brief Analog to Digital Converter(ADC)
  2857. */
  2858. typedef struct
  2859. {
  2860. /** Status register */
  2861. union
  2862. {
  2863. __IOM uint32_t STS;
  2864. struct
  2865. {
  2866. __IOM uint32_t AWDFLG : 1;
  2867. __IOM uint32_t EOCFLG : 1;
  2868. __IOM uint32_t INJEOCFLG : 1;
  2869. __IOM uint32_t INJCSFLG : 1;
  2870. __IOM uint32_t REGCSFLG : 1;
  2871. __IM uint32_t RESERVED : 27;
  2872. } STS_B;
  2873. };
  2874. /** Control register1*/
  2875. union
  2876. {
  2877. __IOM uint32_t CTRL1;
  2878. struct
  2879. {
  2880. __IOM uint32_t AWDCHSEL : 5;
  2881. __IOM uint32_t EOCIEN : 1;
  2882. __IOM uint32_t AWDIEN : 1;
  2883. __IOM uint32_t INJEOCIEN : 1;
  2884. __IOM uint32_t SCANEN : 1;
  2885. __IOM uint32_t AWDSGLEN : 1;
  2886. __IOM uint32_t INJGACEN : 1;
  2887. __IOM uint32_t REGDISCEN : 1;
  2888. __IOM uint32_t INJDISCEN : 1;
  2889. __IOM uint32_t DISCNUMCFG : 3;
  2890. __IOM uint32_t DUALMCFG : 4;
  2891. __IM uint32_t RESERVED1 : 2;
  2892. __IOM uint32_t INJAWDEN : 1;
  2893. __IOM uint32_t REGAWDEN : 1;
  2894. __IM uint32_t RESERVED2 : 8;
  2895. } CTRL1_B;
  2896. };
  2897. /** Control register2*/
  2898. union
  2899. {
  2900. __IOM uint32_t CTRL2;
  2901. struct
  2902. {
  2903. __IOM uint32_t ADCEN : 1;
  2904. __IOM uint32_t CONTCEN : 1;
  2905. __IOM uint32_t CAL : 1;
  2906. __IOM uint32_t CALRST : 1;
  2907. __IM uint32_t RESERVED1 : 4;
  2908. __IOM uint32_t DMAEN : 1;
  2909. __IM uint32_t RESERVED2 : 2;
  2910. __IOM uint32_t DALIGNCFG : 1;
  2911. __IOM uint32_t INJGEXTTRGSEL : 3;
  2912. __IOM uint32_t INJEXTTRGEN : 1;
  2913. __IM uint32_t RESERVED3 : 1;
  2914. __IOM uint32_t REGEXTTRGSEL : 3;
  2915. __IOM uint32_t REGEXTTRGEN : 1;
  2916. __IOM uint32_t INJSWSC : 1;
  2917. __IOM uint32_t REGSWSC : 1;
  2918. __IOM uint32_t TSVREFEN : 1;
  2919. __IM uint32_t RESERVED4 : 8;
  2920. } CTRL2_B;
  2921. };
  2922. /** Sample time register1*/
  2923. union
  2924. {
  2925. __IOM uint32_t SMPTIM1;
  2926. struct
  2927. {
  2928. __IOM uint32_t SMPCYCCFG10 : 3;
  2929. __IOM uint32_t SMPCYCCFG11 : 3;
  2930. __IOM uint32_t SMPCYCCFG12 : 3;
  2931. __IOM uint32_t SMPCYCCFG13 : 3;
  2932. __IOM uint32_t SMPCYCCFG14 : 3;
  2933. __IOM uint32_t SMPCYCCFG15 : 3;
  2934. __IOM uint32_t SMPCYCCFG16 : 3;
  2935. __IOM uint32_t SMPCYCCFG17 : 3;
  2936. __IM uint32_t RESERVED : 8;
  2937. } SMPTIM1_B;
  2938. };
  2939. /** Sample time register2*/
  2940. union
  2941. {
  2942. __IOM uint32_t SMPTIM2;
  2943. struct
  2944. {
  2945. __IOM uint32_t SMPCYCCFG0 : 3;
  2946. __IOM uint32_t SMPCYCCFG1 : 3;
  2947. __IOM uint32_t SMPCYCCFG2 : 3;
  2948. __IOM uint32_t SMPCYCCFG3 : 3;
  2949. __IOM uint32_t SMPCYCCFG4 : 3;
  2950. __IOM uint32_t SMPCYCCFG5 : 3;
  2951. __IOM uint32_t SMPCYCCFG6 : 3;
  2952. __IOM uint32_t SMPCYCCFG7 : 3;
  2953. __IOM uint32_t SMPCYCCFG8 : 3;
  2954. __IOM uint32_t SMPCYCCFG9 : 3;
  2955. __IM uint32_t RESERVED : 2;
  2956. } SMPTIM2_B;
  2957. };
  2958. /** Injected channel Data offset register1*/
  2959. union
  2960. {
  2961. __IOM uint32_t INJDOF1;
  2962. struct
  2963. {
  2964. __IOM uint32_t INJDOF1 : 12;
  2965. __IM uint32_t RESERVED : 20;
  2966. } INJDOF1_B;
  2967. };
  2968. /** Injected channel Data offset register2*/
  2969. union
  2970. {
  2971. __IOM uint32_t INJDOF2;
  2972. struct
  2973. {
  2974. __IOM uint32_t INJDOF2 : 12;
  2975. __IM uint32_t RESERVED : 20;
  2976. } INJDOF2_B;
  2977. };
  2978. /** Injected channel Data offset register3*/
  2979. union
  2980. {
  2981. __IOM uint32_t INJDOF3;
  2982. struct
  2983. {
  2984. __IOM uint32_t INJDOF3 : 12;
  2985. __IM uint32_t RESERVED : 20;
  2986. } INJDOF3_B;
  2987. };
  2988. /** Injected channel Data offset register4*/
  2989. union
  2990. {
  2991. __IOM uint32_t INJDOF4;
  2992. struct
  2993. {
  2994. __IOM uint32_t INJDOF4 : 12;
  2995. __IM uint32_t RESERVED : 20;
  2996. } INJDOF4_B;
  2997. };
  2998. /** Analog watchdog high threshold register*/
  2999. union
  3000. {
  3001. __IOM uint32_t AWDHT;
  3002. struct
  3003. {
  3004. __IOM uint32_t AWDHT : 12;
  3005. __IM uint32_t RESERVED : 20;
  3006. } AWDHT_B;
  3007. };
  3008. /** Analog watchdog low threshold register*/
  3009. union
  3010. {
  3011. __IOM uint32_t AWDLT;
  3012. struct
  3013. {
  3014. __IOM uint32_t AWDLT : 12;
  3015. __IM uint32_t RESERVED : 20;
  3016. } AWDLT_B;
  3017. };
  3018. /** Regular channel sequence register1*/
  3019. union
  3020. {
  3021. __IOM uint32_t REGSEQ1;
  3022. struct
  3023. {
  3024. __IOM uint32_t REGSEQC13 : 5;
  3025. __IOM uint32_t REGSEQC14 : 5;
  3026. __IOM uint32_t REGSEQC15 : 5;
  3027. __IOM uint32_t REGSEQC16 : 5;
  3028. __IOM uint32_t REGSEQLEN : 4;
  3029. __IM uint32_t RESERVED : 8;
  3030. } REGSEQ1_B;
  3031. };
  3032. /** Regular channel sequence register2*/
  3033. union
  3034. {
  3035. __IOM uint32_t REGSEQ2;
  3036. struct
  3037. {
  3038. __IOM uint32_t REGSEQC7 : 5;
  3039. __IOM uint32_t REGSEQC8 : 5;
  3040. __IOM uint32_t REGSEQC9 : 5;
  3041. __IOM uint32_t REGSEQC10 : 5;
  3042. __IOM uint32_t REGSEQC11 : 5;
  3043. __IOM uint32_t REGSEQC12 : 5;
  3044. __IM uint32_t RESERVED : 2;
  3045. } REGSEQ2_B;
  3046. };
  3047. /** Regular channel sequence register3*/
  3048. union
  3049. {
  3050. __IOM uint32_t REGSEQ3;
  3051. struct
  3052. {
  3053. __IOM uint32_t REGSEQC1 : 5;
  3054. __IOM uint32_t REGSEQC2 : 5;
  3055. __IOM uint32_t REGSEQC3 : 5;
  3056. __IOM uint32_t REGSEQC4 : 5;
  3057. __IOM uint32_t REGSEQC5 : 5;
  3058. __IOM uint32_t REGSEQC6 : 5;
  3059. __IM uint32_t RESERVED : 2;
  3060. } REGSEQ3_B;
  3061. };
  3062. /** Injected sequence register*/
  3063. union
  3064. {
  3065. __IOM uint32_t INJSEQ;
  3066. struct
  3067. {
  3068. __IOM uint32_t INJSEQC1 : 5;
  3069. __IOM uint32_t INJSEQC2 : 5;
  3070. __IOM uint32_t INJSEQC3 : 5;
  3071. __IOM uint32_t INJSEQC4 : 5;
  3072. __IOM uint32_t INJSEQLEN : 2;
  3073. __IM uint32_t RESERVED : 10;
  3074. } INJSEQ_B;
  3075. };
  3076. /** Injected Data register1*/
  3077. union
  3078. {
  3079. __IM uint32_t INJDATA1;
  3080. struct
  3081. {
  3082. __IM uint32_t INJDATA : 16;
  3083. __IM uint32_t RESERVED : 16;
  3084. } INJDATA1_B;
  3085. };
  3086. /** Injected Data register2*/
  3087. union
  3088. {
  3089. __IM uint32_t INJDATA2;
  3090. struct
  3091. {
  3092. __IM uint32_t INJDATA : 16;
  3093. __IM uint32_t RESERVED : 16;
  3094. } INJDATA2_B;
  3095. };
  3096. /** Injected Data register3*/
  3097. union
  3098. {
  3099. __IM uint32_t INJDATA3;
  3100. struct
  3101. {
  3102. __IM uint32_t INJDATA : 16;
  3103. __IM uint32_t RESERVED : 16;
  3104. } INJDATA3_B;
  3105. };
  3106. /** Injected Data register4*/
  3107. union
  3108. {
  3109. __IM uint32_t INJDATA4;
  3110. struct
  3111. {
  3112. __IM uint32_t INJDATA : 16;
  3113. __IM uint32_t RESERVED : 16;
  3114. } INJDATA4_B;
  3115. };
  3116. /** Regular Data register*/
  3117. union
  3118. {
  3119. __IOM uint32_t REGDATA;
  3120. struct
  3121. {
  3122. __IM uint32_t REGDATA : 16;
  3123. __IM uint32_t ADC2DATA : 16;
  3124. } REGDATA_B;
  3125. };
  3126. } ADC_T;
  3127. /**
  3128. * @brief External Interrupt(EINT)
  3129. */
  3130. typedef struct
  3131. {
  3132. /** Interrupt mask register */
  3133. union
  3134. {
  3135. __IOM uint32_t IMASK;
  3136. struct
  3137. {
  3138. __IOM uint32_t IMASK0 : 1;
  3139. __IOM uint32_t IMASK1 : 1;
  3140. __IOM uint32_t IMASK2 : 1;
  3141. __IOM uint32_t IMASK3 : 1;
  3142. __IOM uint32_t IMASK4 : 1;
  3143. __IOM uint32_t IMASK5 : 1;
  3144. __IOM uint32_t IMASK6 : 1;
  3145. __IOM uint32_t IMASK7 : 1;
  3146. __IOM uint32_t IMASK8 : 1;
  3147. __IOM uint32_t IMASK9 : 1;
  3148. __IOM uint32_t IMASK10 : 1;
  3149. __IOM uint32_t IMASK11 : 1;
  3150. __IOM uint32_t IMASK12 : 1;
  3151. __IOM uint32_t IMASK13 : 1;
  3152. __IOM uint32_t IMASK14 : 1;
  3153. __IOM uint32_t IMASK15 : 1;
  3154. __IOM uint32_t IMASK16 : 1;
  3155. __IOM uint32_t IMASK17 : 1;
  3156. __IOM uint32_t IMASK18 : 1;
  3157. __IM uint32_t RESERVED : 12;
  3158. } IMASK_B;
  3159. };
  3160. /** Event mask register */
  3161. union
  3162. {
  3163. __IOM uint32_t EMASK;
  3164. struct
  3165. {
  3166. __IOM uint32_t EMASK0 : 1;
  3167. __IOM uint32_t EMASK1 : 1;
  3168. __IOM uint32_t EMASK2 : 1;
  3169. __IOM uint32_t EMASK3 : 1;
  3170. __IOM uint32_t EMASK4 : 1;
  3171. __IOM uint32_t EMASK5 : 1;
  3172. __IOM uint32_t EMASK6 : 1;
  3173. __IOM uint32_t EMASK7 : 1;
  3174. __IOM uint32_t EMASK8 : 1;
  3175. __IOM uint32_t EMASK9 : 1;
  3176. __IOM uint32_t EMASK10 : 1;
  3177. __IOM uint32_t EMASK11 : 1;
  3178. __IOM uint32_t EMASK12 : 1;
  3179. __IOM uint32_t EMASK13 : 1;
  3180. __IOM uint32_t EMASK14 : 1;
  3181. __IOM uint32_t EMASK15 : 1;
  3182. __IOM uint32_t EMASK16 : 1;
  3183. __IOM uint32_t EMASK17 : 1;
  3184. __IOM uint32_t EMASK18 : 1;
  3185. __IM uint32_t RESERVED : 12;
  3186. } EEN_B;
  3187. };
  3188. /** Rising Trigger Event Enable register */
  3189. union
  3190. {
  3191. __IOM uint32_t RTEN;
  3192. struct
  3193. {
  3194. __IOM uint32_t RTEN0 : 1;
  3195. __IOM uint32_t RTEN1 : 1;
  3196. __IOM uint32_t RTEN2 : 1;
  3197. __IOM uint32_t RTEN3 : 1;
  3198. __IOM uint32_t RTEN4 : 1;
  3199. __IOM uint32_t RTEN5 : 1;
  3200. __IOM uint32_t RTEN6 : 1;
  3201. __IOM uint32_t RTEN7 : 1;
  3202. __IOM uint32_t RTEN8 : 1;
  3203. __IOM uint32_t RTEN9 : 1;
  3204. __IOM uint32_t RTEN10 : 1;
  3205. __IOM uint32_t RTEN11 : 1;
  3206. __IOM uint32_t RTEN12 : 1;
  3207. __IOM uint32_t RTEN13 : 1;
  3208. __IOM uint32_t RTEN14 : 1;
  3209. __IOM uint32_t RTEN15 : 1;
  3210. __IOM uint32_t RTEN16 : 1;
  3211. __IOM uint32_t RTEN17 : 1;
  3212. __IOM uint32_t RTEN18 : 1;
  3213. __IM uint32_t RESERVED : 12;
  3214. } RTEN_B;
  3215. };
  3216. /** Falling Trigger Event Enable register */
  3217. union
  3218. {
  3219. __IOM uint32_t FTEN;
  3220. struct
  3221. {
  3222. __IOM uint32_t FTEN0 : 1;
  3223. __IOM uint32_t FTEN1 : 1;
  3224. __IOM uint32_t FTEN2 : 1;
  3225. __IOM uint32_t FTEN3 : 1;
  3226. __IOM uint32_t FTEN4 : 1;
  3227. __IOM uint32_t FTEN5 : 1;
  3228. __IOM uint32_t FTEN6 : 1;
  3229. __IOM uint32_t FTEN7 : 1;
  3230. __IOM uint32_t FTEN8 : 1;
  3231. __IOM uint32_t FTEN9 : 1;
  3232. __IOM uint32_t FTEN10 : 1;
  3233. __IOM uint32_t FTEN11 : 1;
  3234. __IOM uint32_t FTEN12 : 1;
  3235. __IOM uint32_t FTEN13 : 1;
  3236. __IOM uint32_t FTEN14 : 1;
  3237. __IOM uint32_t FTEN15 : 1;
  3238. __IOM uint32_t FTEN16 : 1;
  3239. __IOM uint32_t FTEN17 : 1;
  3240. __IOM uint32_t FTEN18 : 1;
  3241. __IM uint32_t RESERVED : 12;
  3242. } FTEN_B;
  3243. };
  3244. /** Software Interrupt Enable register */
  3245. union
  3246. {
  3247. __IOM uint32_t SWINTE;
  3248. struct
  3249. {
  3250. __IOM uint32_t SWINTE0 : 1;
  3251. __IOM uint32_t SWINTE1 : 1;
  3252. __IOM uint32_t SWINTE2 : 1;
  3253. __IOM uint32_t SWINTE3 : 1;
  3254. __IOM uint32_t SWINTE4 : 1;
  3255. __IOM uint32_t SWINTE5 : 1;
  3256. __IOM uint32_t SWINTE6 : 1;
  3257. __IOM uint32_t SWINTE7 : 1;
  3258. __IOM uint32_t SWINTE8 : 1;
  3259. __IOM uint32_t SWINTE9 : 1;
  3260. __IOM uint32_t SWINTE10 : 1;
  3261. __IOM uint32_t SWINTE11 : 1;
  3262. __IOM uint32_t SWINTE12 : 1;
  3263. __IOM uint32_t SWINTE13 : 1;
  3264. __IOM uint32_t SWINTE14 : 1;
  3265. __IOM uint32_t SWINTE15 : 1;
  3266. __IOM uint32_t SWINTE16 : 1;
  3267. __IOM uint32_t SWINTE17 : 1;
  3268. __IOM uint32_t SWINTE18 : 1;
  3269. __IM uint32_t RESERVED : 12;
  3270. } SWINTE_B;
  3271. };
  3272. /** Interrupt Flag Enable register */
  3273. union
  3274. {
  3275. __IOM uint32_t IPEND;
  3276. struct
  3277. {
  3278. __IOM uint32_t IPEND0 : 1;
  3279. __IOM uint32_t IPEND1 : 1;
  3280. __IOM uint32_t IPEND2 : 1;
  3281. __IOM uint32_t IPEND3 : 1;
  3282. __IOM uint32_t IPEND4 : 1;
  3283. __IOM uint32_t IPEND5 : 1;
  3284. __IOM uint32_t IPEND6 : 1;
  3285. __IOM uint32_t IPEND7 : 1;
  3286. __IOM uint32_t IPEND8 : 1;
  3287. __IOM uint32_t IPEND9 : 1;
  3288. __IOM uint32_t IPEND10 : 1;
  3289. __IOM uint32_t IPEND11 : 1;
  3290. __IOM uint32_t IPEND12 : 1;
  3291. __IOM uint32_t IPEND13 : 1;
  3292. __IOM uint32_t IPEND14 : 1;
  3293. __IOM uint32_t IPEND15 : 1;
  3294. __IOM uint32_t IPEND16 : 1;
  3295. __IOM uint32_t IPEND17 : 1;
  3296. __IOM uint32_t IPEND18 : 1;
  3297. __IM uint32_t RESERVED : 12;
  3298. } IF_B;
  3299. };
  3300. } EINT_T;
  3301. /**
  3302. * @brief Independent watchdog(IWDT)
  3303. */
  3304. typedef struct
  3305. {
  3306. /** Keyword register */
  3307. union
  3308. {
  3309. __OM uint32_t KEY;
  3310. struct
  3311. {
  3312. __OM uint32_t KEY : 16;
  3313. __IM uint32_t RESERVED : 16;
  3314. } KEY_B;
  3315. };
  3316. /** Frequency Divider register */
  3317. union
  3318. {
  3319. __IOM uint32_t PSC;
  3320. struct
  3321. {
  3322. __IOM uint32_t PSC : 3;
  3323. __IM uint32_t RESERVED : 29;
  3324. } DIV_B;
  3325. };
  3326. /** Reload values register */
  3327. union
  3328. {
  3329. __IOM uint32_t CNTRLD;
  3330. struct
  3331. {
  3332. __IOM uint32_t CNTRLD : 12;
  3333. __IM uint32_t RESERVED : 20;
  3334. } CNTRLD_B;
  3335. };
  3336. /** Status register */
  3337. union
  3338. {
  3339. __IM uint32_t STS;
  3340. struct
  3341. {
  3342. __IM uint32_t PSCUFLG : 1;
  3343. __IM uint32_t CNTUFLG : 1;
  3344. __IM uint32_t RESERVED : 30;
  3345. } STS_B;
  3346. };
  3347. } IWDT_T;
  3348. /**
  3349. * @brief Serial peripheral interface(SPI)
  3350. */
  3351. typedef struct
  3352. {
  3353. /** Control register 1 */
  3354. union
  3355. {
  3356. __IOM uint32_t CTRL1;
  3357. struct
  3358. {
  3359. __IOM uint32_t CPHA : 1;
  3360. __IOM uint32_t CPOL : 1;
  3361. __IOM uint32_t MSMCFG : 1;
  3362. __IOM uint32_t BRSEL : 3;
  3363. __IOM uint32_t SPIEN : 1;
  3364. __IOM uint32_t LSBSEL : 1;
  3365. __IOM uint32_t ISSEL : 1;
  3366. __IOM uint32_t SSEN : 1;
  3367. __IOM uint32_t RXOMEN : 1;
  3368. __IOM uint32_t DFLSEL : 1;
  3369. __IOM uint32_t CRCNXT : 1;
  3370. __IOM uint32_t CRCEN : 1;
  3371. __IOM uint32_t BMOEN : 1;
  3372. __IOM uint32_t BMEN : 1;
  3373. __IM uint32_t RESERVED : 16;
  3374. } CTRL1_B;
  3375. };
  3376. /** Control register 2 */
  3377. union
  3378. {
  3379. __IOM uint32_t CTRL2;
  3380. struct
  3381. {
  3382. __IOM uint32_t RXDEN : 1;
  3383. __IOM uint32_t TXDEN : 1;
  3384. __IOM uint32_t SSOEN : 1;
  3385. __IM uint32_t RESERVED1 : 2;
  3386. __IOM uint32_t ERRIEN : 1;
  3387. __IOM uint32_t RXBNEIEN : 1;
  3388. __IOM uint32_t TXBEIEN : 1;
  3389. __IM uint32_t RESERVED2 : 24;
  3390. } CTRL2_B;
  3391. };
  3392. /** Status register */
  3393. union
  3394. {
  3395. __IOM uint32_t STS;
  3396. struct
  3397. {
  3398. __IM uint32_t RXBNEFLG : 1;
  3399. __IM uint32_t TXBEFLG : 1;
  3400. __IM uint32_t SCHDIR : 1;
  3401. __IM uint32_t UDRFLG : 1;
  3402. __IOM uint32_t CRCEFLG : 1;
  3403. __IM uint32_t MEFLG : 1;
  3404. __IM uint32_t OVRFLG : 1;
  3405. __IM uint32_t BSYFLG : 1;
  3406. __IM uint32_t RESERVED : 24;
  3407. } STS_B;
  3408. };
  3409. /** Data register */
  3410. union
  3411. {
  3412. __IOM uint32_t DATA;
  3413. struct
  3414. {
  3415. __IOM uint32_t DATA : 16;
  3416. __IM uint32_t RESERVED : 16;
  3417. } DATA_B;
  3418. };
  3419. /** CRC polynomial register */
  3420. union
  3421. {
  3422. __IOM uint32_t CRCPOLY;
  3423. struct
  3424. {
  3425. __IOM uint32_t CRCPOLY : 16;
  3426. __IM uint32_t RESERVED : 16;
  3427. } CRCPOLY_B;
  3428. };
  3429. /** Receive CRC register */
  3430. union
  3431. {
  3432. __IM uint32_t RXCRC;
  3433. struct
  3434. {
  3435. __IM uint32_t RXCRC : 16;
  3436. __IM uint32_t RESERVED : 16;
  3437. } RXCRC_B;
  3438. };
  3439. /** Transmit CRC register */
  3440. union
  3441. {
  3442. __IM uint32_t TXCRC;
  3443. struct
  3444. {
  3445. __IM uint32_t TXCRC : 16;
  3446. __IM uint32_t RESERVED : 16;
  3447. } TXCRC_B;
  3448. };
  3449. /** Transmit I2S CTRL register */
  3450. union
  3451. {
  3452. __IOM uint32_t I2SCFG;
  3453. struct
  3454. {
  3455. __IOM uint32_t CHLEN : 1;
  3456. __IOM uint32_t DATLEN : 2;
  3457. __IOM uint32_t CPOL : 1;
  3458. __IOM uint32_t I2SSSEL : 2;
  3459. __IM uint32_t RESERVED1 : 1;
  3460. __IOM uint32_t PFSSEL : 1;
  3461. __IOM uint32_t I2SMOD : 2;
  3462. __IOM uint32_t I2SEN : 1;
  3463. __IOM uint32_t MODESEL : 1;
  3464. __IM uint32_t RESERVED2 : 20;
  3465. } I2SCFG_B;
  3466. };
  3467. /** Transmit I2S DIV register */
  3468. union
  3469. {
  3470. __IOM uint32_t I2SPSC;
  3471. struct
  3472. {
  3473. __IOM uint32_t I2SPSC : 8;
  3474. __IOM uint32_t ODDPSC : 1;
  3475. __IOM uint32_t MCIEN : 1;
  3476. __IM uint32_t RESERVED1 : 22;
  3477. } I2SPSC_B;
  3478. };
  3479. } SPI_T;
  3480. /**
  3481. * @brief Window watchdog (WWDT)
  3482. */
  3483. typedef struct
  3484. {
  3485. /** Control register */
  3486. union
  3487. {
  3488. __IOM uint32_t CTRL;
  3489. struct
  3490. {
  3491. __IOM uint32_t CNT : 7;
  3492. __IOM uint32_t WWDTEN : 1;
  3493. __IM uint32_t RESERVED : 24;
  3494. } CTRL_B;
  3495. };
  3496. /** Configure register */
  3497. union
  3498. {
  3499. __IOM uint32_t CFG;
  3500. struct
  3501. {
  3502. __IOM uint32_t WIN : 7;
  3503. __IOM uint32_t TBPSC : 2;
  3504. __IOM uint32_t EWIEN : 1;
  3505. __IM uint32_t RESERVED : 22;
  3506. } CFG_B;
  3507. };
  3508. /** Status register */
  3509. union
  3510. {
  3511. __IOM uint32_t STS;
  3512. struct
  3513. {
  3514. __IOM uint32_t EWIFLG : 1;
  3515. __IM uint32_t RESERVED : 31;
  3516. } STS_B;
  3517. };
  3518. } WWDT_T;
  3519. /**
  3520. * @brief Secure digital input/output interface (SDIO)
  3521. */
  3522. typedef struct
  3523. {
  3524. /** Power control register */
  3525. union
  3526. {
  3527. __IOM uint32_t PWRCTRL;
  3528. struct
  3529. {
  3530. __IOM uint32_t PWRCTRL : 2;
  3531. __IM uint32_t RESERVED : 30;
  3532. } PWRCTRL_B;
  3533. };
  3534. /** Clock control register */
  3535. union
  3536. {
  3537. __IOM uint32_t CLKCTRL;
  3538. struct
  3539. {
  3540. __IOM uint32_t CLKDIV : 8;
  3541. __IOM uint32_t CLKEN : 1;
  3542. __IOM uint32_t PWRSAV : 1;
  3543. __IOM uint32_t BYPASSEN : 1;
  3544. __IOM uint32_t WBSEL : 2;
  3545. __IOM uint32_t DEPSEL : 1;
  3546. __IOM uint32_t HFCEN : 1;
  3547. __IM uint32_t RESERVED : 17;
  3548. } CLKCTRL_B;
  3549. };
  3550. /** Argument register */
  3551. union
  3552. {
  3553. __IOM uint32_t ARG;
  3554. struct
  3555. {
  3556. __IOM uint32_t CMDARG : 32;
  3557. } ARG_B;
  3558. };
  3559. /** Command register */
  3560. union
  3561. {
  3562. __IOM uint32_t CMD;
  3563. struct
  3564. {
  3565. __IOM uint32_t CMDINDEX : 6;
  3566. __IOM uint32_t WAITRES : 2;
  3567. __IOM uint32_t WAITINT : 1;
  3568. __IOM uint32_t WENDDATA : 1;
  3569. __IOM uint32_t CPSMEN : 1;
  3570. __IOM uint32_t SDIOSC : 1;
  3571. __IOM uint32_t CMDCPEN : 1;
  3572. __IOM uint32_t INTEN : 1;
  3573. __IOM uint32_t ATACMD : 1;
  3574. __IM uint32_t RESERVED : 17;
  3575. } CMD_B;
  3576. };
  3577. /** Command response register */
  3578. union
  3579. {
  3580. __IM uint32_t CMDRES;
  3581. struct
  3582. {
  3583. __IM uint32_t CMDRES : 6;
  3584. __IM uint32_t RESERVED : 26;
  3585. } CMDRES_B;
  3586. };
  3587. /** SDIO response register1 */
  3588. union
  3589. {
  3590. __IM uint32_t RES1;
  3591. struct
  3592. {
  3593. __IM uint32_t CARDSTS1 : 32;
  3594. } RES1_B;
  3595. };
  3596. /** SDIO response register2 */
  3597. union
  3598. {
  3599. __IM uint32_t RES2;
  3600. struct
  3601. {
  3602. __IM uint32_t CARDSTS2 : 32;
  3603. } RES2_B;
  3604. };
  3605. /** SDIO response register3 */
  3606. union
  3607. {
  3608. __IM uint32_t RES3;
  3609. struct
  3610. {
  3611. __IM uint32_t CARDSTS3 : 32;
  3612. } RES3_B;
  3613. };
  3614. /** SDIO response register4 */
  3615. union
  3616. {
  3617. __IM uint32_t RES4;
  3618. struct
  3619. {
  3620. __IM uint32_t CARDSTS4 : 32;
  3621. } RES4_B;
  3622. };
  3623. /** Data timer register */
  3624. union
  3625. {
  3626. __IOM uint32_t DATATIME;
  3627. struct
  3628. {
  3629. __IOM uint32_t DATATIME : 32;
  3630. } DTMR_B;
  3631. };
  3632. /** Data length register */
  3633. union
  3634. {
  3635. __IOM uint32_t DATALEN;
  3636. struct
  3637. {
  3638. __IOM uint32_t DATALEN : 25;
  3639. __IM uint32_t RESERVED : 7;
  3640. } DLEN_B;
  3641. };
  3642. /** Data control register */
  3643. union
  3644. {
  3645. __IOM uint32_t DCTRL;
  3646. struct
  3647. {
  3648. __IOM uint32_t DTEN : 1;
  3649. __IOM uint32_t DTDRCFG : 1;
  3650. __IOM uint32_t DTSEL : 1;
  3651. __IOM uint32_t DMAEN : 1;
  3652. __IOM uint32_t DBSIZE : 4;
  3653. __IOM uint32_t RWSTR : 1;
  3654. __IOM uint32_t RWSTOP : 1;
  3655. __IOM uint32_t RDWAIT : 1;
  3656. __IOM uint32_t SDIOF : 1;
  3657. __IM uint32_t RESERVED : 20;
  3658. } DCTRL_B;
  3659. };
  3660. /** Data count register */
  3661. union
  3662. {
  3663. __IM uint32_t DCNT;
  3664. struct
  3665. {
  3666. __IM uint32_t DATACNT : 25;
  3667. __IM uint32_t RESERVED : 7;
  3668. } DCNT_B;
  3669. };
  3670. /** SDIO status register */
  3671. union
  3672. {
  3673. __IM uint32_t STS;
  3674. struct
  3675. {
  3676. __IM uint32_t COMRESP : 1;
  3677. __IM uint32_t DBDR : 1;
  3678. __IM uint32_t CMDRESTO : 1;
  3679. __IM uint32_t DATATO : 1;
  3680. __IM uint32_t TXUDRER : 1;
  3681. __IM uint32_t RXOVRER : 1;
  3682. __IM uint32_t CMDRES : 1;
  3683. __IM uint32_t CMDSENT : 1;
  3684. __IM uint32_t DATAEND : 1;
  3685. __IM uint32_t SBE : 1;
  3686. __IM uint32_t DBCP : 1;
  3687. __IM uint32_t CMDACT : 1;
  3688. __IM uint32_t TXACT : 1;
  3689. __IM uint32_t RXACT : 1;
  3690. __IM uint32_t TXFHF : 1;
  3691. __IM uint32_t RXFHF : 1;
  3692. __IM uint32_t TXFF : 1;
  3693. __IM uint32_t RXFF : 1;
  3694. __IM uint32_t TXFE : 1;
  3695. __IM uint32_t RXFE : 1;
  3696. __IM uint32_t TXDA : 1;
  3697. __IM uint32_t RXDA : 1;
  3698. __IM uint32_t SDIOINT : 1;
  3699. __IM uint32_t ATAEND : 1;
  3700. __IM uint32_t RESERVED : 8;
  3701. } STS_B;
  3702. };
  3703. /** SDIO interrupt clear register */
  3704. union
  3705. {
  3706. __IOM uint32_t ICF;
  3707. struct
  3708. {
  3709. __IOM uint32_t DBCE : 1;
  3710. __IOM uint32_t CRCE : 1;
  3711. __IOM uint32_t CRTO : 1;
  3712. __IOM uint32_t DTO : 1;
  3713. __IOM uint32_t TXFUE : 1;
  3714. __IOM uint32_t RXFOE : 1;
  3715. __IOM uint32_t CMDRES : 1;
  3716. __IOM uint32_t CMDSENT : 1;
  3717. __IOM uint32_t DATAEND : 1;
  3718. __IOM uint32_t SBE : 1;
  3719. __IOM uint32_t DBCP : 1;
  3720. __IM uint32_t RESERVED1 : 11;
  3721. __IOM uint32_t SDIOIT : 1;
  3722. __IOM uint32_t ATAEND : 1;
  3723. __IM uint32_t RESERVED2 : 8;
  3724. } ICF_B;
  3725. };
  3726. /** SDIO interrupt mask register */
  3727. union
  3728. {
  3729. __IOM uint32_t MASK;
  3730. struct
  3731. {
  3732. __IOM uint32_t CCRCFAIL : 1;
  3733. __IOM uint32_t DCRCFAIL : 1;
  3734. __IOM uint32_t CMDTO : 1;
  3735. __IOM uint32_t DATATO : 1;
  3736. __IOM uint32_t TXURER : 1;
  3737. __IOM uint32_t RXORER : 1;
  3738. __IOM uint32_t CMDRESRC : 1;
  3739. __IOM uint32_t CMDSENT : 1;
  3740. __IOM uint32_t DATAEND : 1;
  3741. __IOM uint32_t STRTER : 1;
  3742. __IOM uint32_t DBEND : 1;
  3743. __IOM uint32_t CMDACT : 1;
  3744. __IOM uint32_t TXACT : 1;
  3745. __IOM uint32_t RXACT : 1;
  3746. __IOM uint32_t TXHFERT : 1;
  3747. __IOM uint32_t RXHFFUL : 1;
  3748. __IOM uint32_t TXFUL : 1;
  3749. __IOM uint32_t RXFUL : 1;
  3750. __IOM uint32_t TXEPT : 1;
  3751. __IOM uint32_t RXFEIE : 1;
  3752. __IOM uint32_t TXDAVB : 1;
  3753. __IOM uint32_t RXDAVB : 1;
  3754. __IOM uint32_t SDIOINTREC : 1;
  3755. __IOM uint32_t ATACLPREC : 1;
  3756. __IM uint32_t RESERVED : 8;
  3757. } MASK_B;
  3758. };
  3759. __IM uint32_t RESERVED[2];
  3760. /** SDIO FIFO count register */
  3761. union
  3762. {
  3763. __IM uint32_t FIFOCNT;
  3764. struct
  3765. {
  3766. __IM uint32_t FIFOCNT : 24;
  3767. __IM uint32_t RESERVED : 8;
  3768. } FIFOCNT_B;
  3769. };
  3770. __IM uint32_t RESERVED1[13];
  3771. /** SDIO data FIFO register */
  3772. union
  3773. {
  3774. __IOM uint32_t FIFODATA;
  3775. struct
  3776. {
  3777. __IOM uint32_t FIFODATA : 32;
  3778. } FIFODATA_B;
  3779. };
  3780. } SDIO_T;
  3781. /**
  3782. * @brief Digital to Analog Converter(DAC)
  3783. */
  3784. typedef struct
  3785. {
  3786. /** Control register */
  3787. union
  3788. {
  3789. __IOM uint32_t CTRL;
  3790. struct
  3791. {
  3792. __IOM uint32_t ENCH1 : 1;
  3793. __IOM uint32_t BUFFDCH1 : 1;
  3794. __IOM uint32_t TRGENCH1 : 1;
  3795. __IOM uint32_t TRGSELCH1 : 3;
  3796. __IOM uint32_t WAVENCH1 : 2;
  3797. __IOM uint32_t MAMPSELCH1 : 4;
  3798. __IOM uint32_t DMAENCH1 : 1;
  3799. __IM uint32_t RESERVED1 : 3;
  3800. __IOM uint32_t ENCH2 : 1;
  3801. __IOM uint32_t BUFFDCH2 : 1;
  3802. __IOM uint32_t TRGENCH2 : 1;
  3803. __IOM uint32_t TRGSELCH2 : 3;
  3804. __IOM uint32_t WAVENCH2 : 2;
  3805. __IOM uint32_t MAMPSELCH2 : 4;
  3806. __IOM uint32_t DMAENCH2 : 1;
  3807. __IM uint32_t RESERVED2 : 3;
  3808. } CTRL_B;
  3809. };
  3810. /** Software trigger register */
  3811. union
  3812. {
  3813. __OM uint32_t SWTRG;
  3814. struct
  3815. {
  3816. __OM uint32_t SWTRG1 : 1;
  3817. __OM uint32_t SWTRG2 : 1;
  3818. __IM uint32_t RESERVED : 30;
  3819. } SWTRG_B;
  3820. };
  3821. /** Channel1 12-bit right-aligned register */
  3822. union
  3823. {
  3824. __IOM uint32_t DH12R1;
  3825. struct
  3826. {
  3827. __IOM uint32_t DATA : 12;
  3828. __IM uint32_t RESERVED : 20;
  3829. } DH12R1_B;
  3830. };
  3831. /** Channel1 12-bit left-aligned register */
  3832. union
  3833. {
  3834. __IOM uint32_t DH12L1;
  3835. struct
  3836. {
  3837. __IM uint32_t RESERVED1 : 4;
  3838. __IOM uint32_t DATA : 12;
  3839. __IM uint32_t RESERVED2 : 16;
  3840. } DH12L1_B;
  3841. };
  3842. /** Channel1 8-bit right-aligned register */
  3843. union
  3844. {
  3845. __IOM uint32_t DH8R1;
  3846. struct
  3847. {
  3848. __IOM uint32_t DATA : 8;
  3849. __IM uint32_t RESERVED : 24;
  3850. } DH8R1_B;
  3851. };
  3852. /** Channel2 12-bit right-aligned register */
  3853. union
  3854. {
  3855. __IOM uint32_t DH12R2;
  3856. struct
  3857. {
  3858. __IOM uint32_t DATA : 12;
  3859. __IM uint32_t RESERVED : 20;
  3860. } DH12R2_B;
  3861. };
  3862. /** Channel2 12-bit left-aligned register */
  3863. union
  3864. {
  3865. __IOM uint32_t DH12L2;
  3866. struct
  3867. {
  3868. __IM uint32_t RESERVED1 : 4;
  3869. __IOM uint32_t DATA : 12;
  3870. __IM uint32_t RESERVED2 : 16;
  3871. } DH12L2_B;
  3872. };
  3873. /** Channel2 8-bit right-aligned register */
  3874. union
  3875. {
  3876. __IOM uint32_t DH8R2;
  3877. struct
  3878. {
  3879. __IOM uint32_t DATA : 8;
  3880. __IM uint32_t RESERVED : 24;
  3881. } DH8R2_B;
  3882. };
  3883. /** Channel1,Channel2 12-bit right-aligned register */
  3884. union
  3885. {
  3886. __IOM uint32_t DH12RDUAL;
  3887. struct
  3888. {
  3889. __IOM uint32_t DATACH1 : 12;
  3890. __IM uint32_t RESERVED1 : 4;
  3891. __IOM uint32_t DATACH2 : 12;
  3892. __IM uint32_t RESERVED2 : 4;
  3893. } DH12RDUAL_B;
  3894. };
  3895. /** Channel1,Channel2 12-bit left-aligned register */
  3896. union
  3897. {
  3898. __IOM uint32_t DH12LDUAL;
  3899. struct
  3900. {
  3901. __IM uint32_t RESERVED1 : 4;
  3902. __IOM uint32_t DATACH1 : 12;
  3903. __IM uint32_t RESERVED2 : 4;
  3904. __IOM uint32_t DATACH2 : 12;
  3905. } DH12LDUAL_B;
  3906. };
  3907. /** Channel1,Channel2 8-bit right-aligned register */
  3908. union
  3909. {
  3910. __IOM uint32_t DH8RDUAL;
  3911. struct
  3912. {
  3913. __IOM uint32_t DATACH1 : 8;
  3914. __IOM uint32_t DATACH2 : 8;
  3915. __IM uint32_t RESERVED : 16;
  3916. } DH8RDUAL_B;
  3917. };
  3918. /** Channel1 data output register */
  3919. union
  3920. {
  3921. __IM uint32_t DATAOCH1;
  3922. struct
  3923. {
  3924. __IM uint32_t DATA : 12;
  3925. __IM uint32_t RESERVED : 20;
  3926. } DATAOCH1_B;
  3927. };
  3928. /** Channel2 data output register */
  3929. union
  3930. {
  3931. __IM uint32_t DATAOCH2;
  3932. struct
  3933. {
  3934. __IM uint32_t DATA : 12;
  3935. __IM uint32_t RESERVED : 20;
  3936. } DATAOCH2_B;
  3937. };
  3938. } DAC_T;
  3939. /**
  3940. * @brief EMMC Register
  3941. */
  3942. typedef struct
  3943. {
  3944. /** SRAM/NOR-Flash chip-select control register */
  3945. union
  3946. {
  3947. __IOM uint32_t CSCTRL;
  3948. struct
  3949. {
  3950. __IOM uint32_t MBKEN : 1;
  3951. __IOM uint32_t ADMUXEN : 1;
  3952. __IOM uint32_t MTYPECFG : 2;
  3953. __IOM uint32_t MDBWIDCFG : 2;
  3954. __IOM uint32_t NORFMACCEN : 1;
  3955. __IM uint32_t RESERVED1 : 1;
  3956. __IOM uint32_t BURSTEN : 1;
  3957. __IOM uint32_t WSPOLCFG : 1;
  3958. __IOM uint32_t WRAPBEN : 1;
  3959. __IOM uint32_t WTIMCFG : 1;
  3960. __IOM uint32_t WREN : 1;
  3961. __IOM uint32_t WAITEN : 1;
  3962. __IOM uint32_t EXTMODEEN : 1;
  3963. __IOM uint32_t WSASYNCEN : 1;
  3964. __IOM uint32_t CRAMPSIZECFG : 3;
  3965. __IOM uint32_t WRBURSTEN : 1;
  3966. __IOM uint32_t RESERVED2 : 12;
  3967. } CSCTRL_B;
  3968. };
  3969. } SNCTRL_T;
  3970. typedef struct
  3971. {
  3972. /** SRAM/NOR-Flash write timing registers */
  3973. union
  3974. {
  3975. __IOM uint32_t WRTTIM;
  3976. struct
  3977. {
  3978. __IOM uint32_t ADDRSETCFG : 4;
  3979. __IOM uint32_t ADDRHLDCFG : 4;
  3980. __IOM uint32_t DATASETCFG : 8;
  3981. __IOM uint32_t BUSTURNCFG : 4;
  3982. __IOM uint32_t CLKDIVCFG : 4;
  3983. __IOM uint32_t DATALATCFG : 4;
  3984. __IOM uint32_t ACCMODECFG : 2;
  3985. __IM uint32_t RESERVED2 : 2;
  3986. } WRTTIM_T;
  3987. };
  3988. } SNWCLK_T;
  3989. /**
  3990. * @brief Flexible Static Memory Controller
  3991. */
  3992. typedef struct
  3993. {
  3994. __IO uint32_t SNCTRL_T[8];
  3995. } EMMC_Bank1_T;
  3996. /**
  3997. * @brief Flexible Static Memory Controller Bank1E
  3998. */
  3999. typedef struct
  4000. {
  4001. __IO uint32_t WRTTIM[7];
  4002. } EMMC_Bank1E_T;
  4003. /**
  4004. * @brief Flexible Static Memory Controller Bank 2
  4005. */
  4006. typedef struct
  4007. {
  4008. /** PC Card/NAND Flash control register 2 */
  4009. union
  4010. {
  4011. __IOM uint32_t CTRL2;
  4012. struct
  4013. {
  4014. __IM uint32_t RESERVED1 : 1;
  4015. __IOM uint32_t WAITFEN : 1;
  4016. __IOM uint32_t MBKEN : 1;
  4017. __IOM uint32_t MTYPECFG : 1;
  4018. __IOM uint32_t DBWIDCFG : 2;
  4019. __IOM uint32_t ECCEN : 1;
  4020. __IM uint32_t RESERVED2 : 2;
  4021. __IOM uint32_t C2RDCFG : 4;
  4022. __IOM uint32_t A2RDCFG : 4;
  4023. __IOM uint32_t ECCPSCFG : 3;
  4024. __IM uint32_t RESERVED3 : 12;
  4025. } CTRL2_B;
  4026. };
  4027. /** FIFO status and interrupt register 2 */
  4028. union
  4029. {
  4030. __IOM uint32_t STSINT2;
  4031. struct
  4032. {
  4033. __IOM uint32_t IREFLG : 1;
  4034. __IOM uint32_t IHLFLG : 1;
  4035. __IOM uint32_t IFEFLG : 1;
  4036. __IOM uint32_t IREDEN : 1;
  4037. __IOM uint32_t IHLDEN : 1;
  4038. __IOM uint32_t IFEDEN : 1;
  4039. __IM uint32_t FEFLG : 1;
  4040. __IM uint32_t RESERVED : 25;
  4041. } STSINT2_B;
  4042. };
  4043. /** Common memory space timing register 2 */
  4044. union
  4045. {
  4046. __IOM uint32_t CMSTIM2;
  4047. struct
  4048. {
  4049. __IOM uint32_t SET2 : 8;
  4050. __IOM uint32_t WAIT2 : 8;
  4051. __IOM uint32_t HLD2 : 8;
  4052. __IOM uint32_t HIZ2 : 8;
  4053. } CMSTIM2_B;
  4054. };
  4055. /** Attribute memory space timing register 2 */
  4056. union
  4057. {
  4058. __IOM uint32_t AMSTIM2;
  4059. struct
  4060. {
  4061. __IOM uint32_t SET2 : 8;
  4062. __IOM uint32_t WAIT2 : 8;
  4063. __IOM uint32_t HLD2 : 8;
  4064. __IOM uint32_t HIZ2 : 8;
  4065. } AMSTIM2_B;
  4066. };
  4067. __IOM uint32_t RESERVED;
  4068. /** ECC result register 2 */
  4069. union
  4070. {
  4071. __IM uint32_t ECCRS2;
  4072. struct
  4073. {
  4074. __IM uint32_t ECCRS2 : 32;
  4075. } ECCRS2_B;
  4076. };
  4077. } EMMC_Bank2_T;
  4078. /**
  4079. * @brief Flexible Static Memory Controller Bank 3
  4080. */
  4081. typedef struct
  4082. {
  4083. /** PC Card/NAND Flash control register 3 */
  4084. union
  4085. {
  4086. __IOM uint32_t CTRL3;
  4087. struct
  4088. {
  4089. __IM uint32_t RESERVED1 : 1;
  4090. __IOM uint32_t WAITFEN : 1;
  4091. __IOM uint32_t MBKEN : 1;
  4092. __IOM uint32_t MTYPECFG : 1;
  4093. __IOM uint32_t DBWIDCFG : 2;
  4094. __IOM uint32_t ECCEN : 1;
  4095. __IM uint32_t RESERVED2 : 2;
  4096. __IOM uint32_t C2RDCFG : 4;
  4097. __IOM uint32_t A2RDCFG : 4;
  4098. __IOM uint32_t ECCPSCFG : 3;
  4099. __IM uint32_t RESERVED3 : 12;
  4100. } CTRL3_B;
  4101. };
  4102. /** FIFO status and interrupt register 3 */
  4103. union
  4104. {
  4105. __IOM uint32_t STSINT3;
  4106. struct
  4107. {
  4108. __IOM uint32_t IREFLG : 1;
  4109. __IOM uint32_t IHLFLG : 1;
  4110. __IOM uint32_t IFEFLG : 1;
  4111. __IOM uint32_t IREDEN : 1;
  4112. __IOM uint32_t IHLDEN : 1;
  4113. __IOM uint32_t IFEDEN : 1;
  4114. __IM uint32_t FEFLG : 1;
  4115. __IM uint32_t RESERVED : 16;
  4116. } STSINT3_B;
  4117. };
  4118. /** Common memory space timing register 3 */
  4119. union
  4120. {
  4121. __IOM uint32_t CMSTIM3;
  4122. struct
  4123. {
  4124. __IOM uint32_t SET3 : 8;
  4125. __IOM uint32_t WAIT3 : 8;
  4126. __IOM uint32_t HLD3 : 8;
  4127. __IOM uint32_t HIZ3 : 8;
  4128. } CMSTIM3_B;
  4129. };
  4130. /** Attribute memory space timing register 3 */
  4131. union
  4132. {
  4133. __IOM uint32_t AMSTIM3;
  4134. struct
  4135. {
  4136. __IOM uint32_t SET3 : 8;
  4137. __IOM uint32_t WAIT3 : 8;
  4138. __IOM uint32_t HLD3 : 8;
  4139. __IOM uint32_t HIZ3 : 8;
  4140. } AMSTIM3_B;
  4141. };
  4142. __IOM uint32_t RESERVED;
  4143. /** ECC result register 3 */
  4144. union
  4145. {
  4146. __IM uint32_t ECCRS3;
  4147. struct
  4148. {
  4149. __IM uint32_t ECCRS3 : 32;
  4150. } ECCRS3_B;
  4151. };
  4152. } EMMC_Bank3_T;
  4153. /**
  4154. * @brief Flexible Static Memory Controller Bank 4
  4155. */
  4156. typedef struct
  4157. {
  4158. /** PC Card/NAND Flash control register 4 */
  4159. union
  4160. {
  4161. __IOM uint32_t CTRL4;
  4162. struct
  4163. {
  4164. __IM uint32_t RESERVED1 : 1;
  4165. __IOM uint32_t WAITFEN : 1;
  4166. __IOM uint32_t MBKEN : 1;
  4167. __IOM uint32_t MTYPECFG : 1;
  4168. __IOM uint32_t DBWIDCFG : 2;
  4169. __IOM uint32_t ECCEN : 1;
  4170. __IM uint32_t RESERVED2 : 2;
  4171. __IOM uint32_t C2RDCFG : 4;
  4172. __IOM uint32_t A2RDCFG : 4;
  4173. __IOM uint32_t ECCPSCFG : 3;
  4174. __IM uint32_t RESERVED3 : 12;
  4175. } CTRL4_B;
  4176. };
  4177. /** FIFO status and interrupt register 4 */
  4178. union
  4179. {
  4180. __IOM uint32_t STSINT4;
  4181. struct
  4182. {
  4183. __IOM uint32_t IREFLG : 1;
  4184. __IOM uint32_t IHLFLG : 1;
  4185. __IOM uint32_t IFEFLG : 1;
  4186. __IOM uint32_t IREDEN : 1;
  4187. __IOM uint32_t IHLDEN : 1;
  4188. __IOM uint32_t IFEDEN : 1;
  4189. __IM uint32_t FEFLG : 1;
  4190. __IM uint32_t RESERVED : 16;
  4191. } STSINT4_B;
  4192. };
  4193. /** Common memory space timing register 4 */
  4194. union
  4195. {
  4196. __IOM uint32_t CMSTIM4;
  4197. struct
  4198. {
  4199. __IOM uint32_t SET4 : 8;
  4200. __IOM uint32_t WAIT4 : 8;
  4201. __IOM uint32_t HLD4 : 8;
  4202. __IOM uint32_t HIZ4 : 8;
  4203. } CMSTIM4_B;
  4204. };
  4205. /** Attribute memory space timing register 4 */
  4206. union
  4207. {
  4208. __IOM uint32_t AMSTIM4;
  4209. struct
  4210. {
  4211. __IOM uint32_t SET4 : 8;
  4212. __IOM uint32_t WAIT4 : 8;
  4213. __IOM uint32_t HLD4 : 8;
  4214. __IOM uint32_t HIZ4 : 8;
  4215. } AMSTIM4_B;
  4216. };
  4217. /** I/O space timing register 4 */
  4218. union
  4219. {
  4220. __IOM uint32_t IOSTIM4;
  4221. struct
  4222. {
  4223. __IOM uint32_t SET4 : 8;
  4224. __IOM uint32_t WAIT4 : 8;
  4225. __IOM uint32_t HLD4 : 8;
  4226. __IOM uint32_t HIZ4 : 8;
  4227. } IOSTIM4_B;
  4228. };
  4229. } EMMC_Bank4_T;
  4230. /**
  4231. * @brief Queued serial peripheral interface(QSPI)
  4232. */
  4233. typedef struct
  4234. {
  4235. /** @brief Control register 1 */
  4236. union
  4237. {
  4238. __IOM uint32_t CTRL1;
  4239. struct
  4240. {
  4241. __IOM uint32_t DFS : 5;
  4242. __IM uint32_t RESERVED1 : 3;
  4243. __IOM uint32_t CPHA : 1;
  4244. __IOM uint32_t CPOL : 1;
  4245. __IOM uint32_t TXMODE : 2;
  4246. __IM uint32_t RESERVED2 : 2;
  4247. __IOM uint32_t SSTEN : 1;
  4248. __IM uint32_t RESERVED3 : 7;
  4249. __IOM uint32_t FRF : 2;
  4250. __IM uint32_t RESERVED4 : 8;
  4251. } CTRL1_B;
  4252. };
  4253. /** @brief Control register 2 */
  4254. union
  4255. {
  4256. __IOM uint32_t CTRL2;
  4257. struct
  4258. {
  4259. __IOM uint32_t NDF : 16;
  4260. __IM uint32_t RESERVED : 16;
  4261. } CTRL2_B;
  4262. };
  4263. /** @brief QSPI Enable register */
  4264. union
  4265. {
  4266. __IOM uint32_t SSIEN;
  4267. struct
  4268. {
  4269. __IOM uint32_t EN : 1;
  4270. __IM uint32_t RESERVED : 31;
  4271. } SSIEN_B;
  4272. };
  4273. __IM uint32_t RESERVED;
  4274. /** @brief QSPI Slave enable register */
  4275. union
  4276. {
  4277. __IOM uint32_t SLAEN;
  4278. struct
  4279. {
  4280. __IOM uint32_t SLAEN : 1;
  4281. __IM uint32_t RESERVED : 31;
  4282. } SLAEN_B;
  4283. };
  4284. /** @brief Baudrate register */
  4285. union
  4286. {
  4287. __IOM uint32_t BR;
  4288. struct
  4289. {
  4290. __IOM uint32_t CLKDIV : 16;
  4291. __IM uint32_t RESERVED : 16;
  4292. } BR_B;
  4293. };
  4294. /** @brief Transmission FIFO threshhold level register */
  4295. union
  4296. {
  4297. __IOM uint32_t TFTL;
  4298. struct
  4299. {
  4300. __IOM uint32_t TFT : 3;
  4301. __IM uint32_t RESERVED1 : 13;
  4302. __IOM uint32_t TFTH : 3;
  4303. __IM uint32_t RESERVED2 : 13;
  4304. } TFTL_B;
  4305. };
  4306. /** @brief Reception FIFO threshhold level register */
  4307. union
  4308. {
  4309. __IOM uint32_t RFTL;
  4310. struct
  4311. {
  4312. __IOM uint32_t RFT : 3;
  4313. __IM uint32_t RESERVED : 29;
  4314. } RFTL_B;
  4315. };
  4316. /** @brief Transmission FIFO level register */
  4317. union
  4318. {
  4319. __IOM uint32_t TFL;
  4320. struct
  4321. {
  4322. __IOM uint32_t TFL : 3;
  4323. __IM uint32_t RESERVED : 29;
  4324. } TFL_B;
  4325. };
  4326. /** @brief Reception FIFO level register */
  4327. union
  4328. {
  4329. __IOM uint32_t RFL;
  4330. struct
  4331. {
  4332. __IOM uint32_t RFL : 3;
  4333. __IM uint32_t RESERVED : 29;
  4334. } RFL_B;
  4335. };
  4336. /** @brief Status register */
  4337. union
  4338. {
  4339. __IOM uint32_t STS;
  4340. struct
  4341. {
  4342. __IOM uint32_t BUSYF : 1;
  4343. __IOM uint32_t TFNF : 1;
  4344. __IOM uint32_t TFEF : 1;
  4345. __IOM uint32_t RFNEF : 1;
  4346. __IOM uint32_t RFFF : 1;
  4347. __IM uint32_t RESERVED1 : 1;
  4348. __IOM uint32_t DCEF : 1;
  4349. __IM uint32_t RESERVED2 : 25;
  4350. } STS_B;
  4351. };
  4352. /** @brief Interrupt enable register */
  4353. union
  4354. {
  4355. __IOM uint32_t INTEN;
  4356. struct
  4357. {
  4358. __IOM uint32_t TFEIE : 1;
  4359. __IOM uint32_t TFOIE : 1;
  4360. __IOM uint32_t RFUIE : 1;
  4361. __IOM uint32_t RFOIE : 1;
  4362. __IOM uint32_t RFFIE : 1;
  4363. __IOM uint32_t MSTIE : 1;
  4364. __IM uint32_t RESERVED : 26;
  4365. } INTEN_B;
  4366. };
  4367. /** @brief Interrupt status register */
  4368. union
  4369. {
  4370. __IM uint32_t ISTS;
  4371. struct
  4372. {
  4373. __IM uint32_t TFEIF : 1;
  4374. __IM uint32_t TFOIF : 1;
  4375. __IM uint32_t RFUIF : 1;
  4376. __IM uint32_t RFOIF : 1;
  4377. __IM uint32_t RFFIF : 1;
  4378. __IM uint32_t MSTIF : 1;
  4379. __IM uint32_t RESERVED : 26;
  4380. } ISTS_B;
  4381. };
  4382. /** @brief Raw interrupt register */
  4383. union
  4384. {
  4385. __IM uint32_t RIS;
  4386. struct
  4387. {
  4388. __IM uint32_t TFEIF : 1;
  4389. __IM uint32_t TFOIF : 1;
  4390. __IM uint32_t RFUIF : 1;
  4391. __IM uint32_t RXOIR : 1;
  4392. __IM uint32_t RXFIR : 1;
  4393. __IM uint32_t MSTIR : 1;
  4394. __IM uint32_t RESERVED : 26;
  4395. } RIS_B;
  4396. };
  4397. /** @brief Transmission FIFO overflow interrupt clear register */
  4398. union
  4399. {
  4400. __IM uint32_t TFOIC;
  4401. struct
  4402. {
  4403. __IM uint32_t TFOIC : 1;
  4404. __IM uint32_t RESERVED : 31;
  4405. } TFOIC_B;
  4406. };
  4407. /** @brief Reception FIFO overflow interrupt clear register */
  4408. union
  4409. {
  4410. __IM uint32_t RFOIC;
  4411. struct
  4412. {
  4413. __IM uint32_t RFOIC : 1;
  4414. __IM uint32_t RESERVED : 31;
  4415. } RFOIC_B;
  4416. };
  4417. /** @brief Reception FIFO underflow interrupt clear register */
  4418. union
  4419. {
  4420. __IM uint32_t RFUIC;
  4421. struct
  4422. {
  4423. __IM uint32_t RFUIC : 1;
  4424. __IM uint32_t RESERVED : 31;
  4425. } RFUIC_B;
  4426. };
  4427. /** @brief Master interrupt clear register */
  4428. union
  4429. {
  4430. __IM uint32_t MIC;
  4431. struct
  4432. {
  4433. __IM uint32_t MIC : 1;
  4434. __IM uint32_t RESERVED : 31;
  4435. } MIC_B;
  4436. };
  4437. /** @brief Interrupt clear register */
  4438. union
  4439. {
  4440. __IM uint32_t ICF;
  4441. struct
  4442. {
  4443. __IM uint32_t ICF : 1;
  4444. __IM uint32_t RESERVED : 31;
  4445. } ICF_B;
  4446. };
  4447. __IM uint32_t RESERVED1[5];
  4448. /** @brief Data register */
  4449. union
  4450. {
  4451. __IOM uint32_t DATA;
  4452. struct
  4453. {
  4454. __IOM uint32_t DATA : 32;
  4455. } DATA_B;
  4456. };
  4457. __IM uint32_t RESERVED2[35];
  4458. /** @brief Reception sample register */
  4459. union
  4460. {
  4461. __IOM uint32_t RSD;
  4462. struct
  4463. {
  4464. __IOM uint32_t RSD : 8;
  4465. __IM uint32_t RESERVED1 : 8;
  4466. __IOM uint32_t RSE : 1;
  4467. __IM uint32_t RESERVED2 : 15;
  4468. } RSD_B;
  4469. };
  4470. /** @brief Reception sample register */
  4471. union
  4472. {
  4473. __IOM uint32_t CTRL3;
  4474. struct
  4475. {
  4476. __IOM uint32_t IAT : 2;
  4477. __IOM uint32_t ADDRLEN : 4;
  4478. __IM uint32_t RESERVED1 : 2;
  4479. __IOM uint32_t INSLEN : 2;
  4480. __IM uint32_t RESERVED2 : 1;
  4481. __IOM uint32_t WAITCYC : 5;
  4482. __IM uint32_t RESERVED3 : 14;
  4483. __IOM uint32_t CSEN : 1;
  4484. __IM uint32_t RESERVED4 : 1;
  4485. } CTRL3_B;
  4486. };
  4487. __IM uint32_t RESERVED3[66];
  4488. /** @brief IO switch register */
  4489. union
  4490. {
  4491. __IOM uint32_t IOSW;
  4492. struct
  4493. {
  4494. __IOM uint32_t IOSW : 1;
  4495. __IM uint32_t RESERVED : 31;
  4496. } IOSW_B;
  4497. };
  4498. } QSPI_T;
  4499. /**
  4500. * @brief SEC Inter-integrated circuit (SCI2C)
  4501. */
  4502. typedef struct
  4503. {
  4504. /** @brief Control register 1 */
  4505. union
  4506. {
  4507. __IOM uint32_t CTRL1;
  4508. struct
  4509. {
  4510. __IOM uint32_t MST : 1;
  4511. __IOM uint32_t SPD : 2;
  4512. __IOM uint32_t SAM : 1;
  4513. __IM uint32_t RESERVED1 : 1;
  4514. __IOM uint32_t RSTAEN : 1;
  4515. __IOM uint32_t SLADIS : 1;
  4516. __IOM uint32_t DSA : 1;
  4517. __IOM uint32_t TFEIC : 1;
  4518. __IOM uint32_t RFFIE : 1;
  4519. __IOM uint32_t DSMA : 1;
  4520. __IM uint32_t RESERVED2 : 21;
  4521. } CTRL1_B;
  4522. };
  4523. /** @brief Master address register */
  4524. union
  4525. {
  4526. __IOM uint32_t TARADDR;
  4527. struct
  4528. {
  4529. __IOM uint32_t ADDR : 10;
  4530. __IOM uint32_t STA : 1;
  4531. __IOM uint32_t GCEN : 1;
  4532. __IOM uint32_t MAM : 1;
  4533. __IM uint32_t RESERVED : 19;
  4534. } TARADDR_B;
  4535. };
  4536. /** @brief Slave address register */
  4537. union
  4538. {
  4539. __IOM uint32_t SLAADDR;
  4540. struct
  4541. {
  4542. __IOM uint32_t ADDR : 10;
  4543. __IM uint32_t RESERVED : 22;
  4544. } SLAADDR_B;
  4545. };
  4546. /** @brief High speed master code register */
  4547. union
  4548. {
  4549. __IOM uint32_t HSMC;
  4550. struct
  4551. {
  4552. __IOM uint32_t HSMC : 4;
  4553. __IM uint32_t RESERVED : 28;
  4554. } HSMC_B;
  4555. };
  4556. /** @brief Data register */
  4557. union
  4558. {
  4559. __IOM uint32_t DATA;
  4560. struct
  4561. {
  4562. __IOM uint32_t DATA : 8;
  4563. __IOM uint32_t CMD : 1;
  4564. __IOM uint32_t STOP : 1;
  4565. __IM uint32_t RESERVED : 22;
  4566. } DATA_B;
  4567. };
  4568. /** @brief Standard speed clock high counter register */
  4569. union
  4570. {
  4571. __IOM uint32_t SSCHC;
  4572. struct
  4573. {
  4574. __IOM uint32_t CNT : 16;
  4575. __IM uint32_t RESERVED : 16;
  4576. } SSCHC_B;
  4577. };
  4578. /** @brief Standard speed clock low counter register */
  4579. union
  4580. {
  4581. __IOM uint32_t SSCLC;
  4582. struct
  4583. {
  4584. __IOM uint32_t CNT : 16;
  4585. __IM uint32_t RESERVED : 16;
  4586. } SSCLC_B;
  4587. };
  4588. /** @brief Fast speed clock high counter register */
  4589. union
  4590. {
  4591. __IOM uint32_t FSCHC;
  4592. struct
  4593. {
  4594. __IOM uint32_t CNT : 16;
  4595. __IM uint32_t RESERVED : 16;
  4596. } FSCHC_B;
  4597. };
  4598. /** @brief Fast speed clock low counter register */
  4599. union
  4600. {
  4601. __IOM uint32_t FSCLC;
  4602. struct
  4603. {
  4604. __IOM uint32_t CNT : 16;
  4605. __IM uint32_t RESERVED : 16;
  4606. } FSCLC_B;
  4607. };
  4608. /** @brief High speed clock high counter */
  4609. union
  4610. {
  4611. __IOM uint32_t HSCHC;
  4612. struct
  4613. {
  4614. __IOM uint32_t CNT : 16;
  4615. __IM uint32_t RESERVED : 16;
  4616. } HSCHC_B;
  4617. };
  4618. /** @brief High speed clock low counter register */
  4619. union
  4620. {
  4621. __IOM uint32_t HSCLC;
  4622. struct
  4623. {
  4624. __IOM uint32_t CNT : 16;
  4625. __IM uint32_t RESERVED : 16;
  4626. } HSCLC_B;
  4627. };
  4628. /** @brief Interrupt status register */
  4629. union
  4630. {
  4631. __IM uint32_t INTSTS;
  4632. struct
  4633. {
  4634. __IM uint32_t RFUIF : 1;
  4635. __IM uint32_t RFOIF : 1;
  4636. __IM uint32_t RFFIF : 1;
  4637. __IM uint32_t TFOIF : 1;
  4638. __IM uint32_t TFEIF : 1;
  4639. __IM uint32_t RRIF : 1;
  4640. __IM uint32_t TAIF : 1;
  4641. __IM uint32_t RDIF : 1;
  4642. __IM uint32_t ACTIF : 1;
  4643. __IM uint32_t STPDIF : 1;
  4644. __IM uint32_t STADIF : 1;
  4645. __IM uint32_t GCIF : 1;
  4646. __IM uint32_t RSTADIF : 1;
  4647. __IM uint32_t MOHIF : 1;
  4648. __IM uint32_t RESERVED : 18;
  4649. } INTSTS_B;
  4650. };
  4651. /** @brief Interrupt enable register */
  4652. union
  4653. {
  4654. __IOM uint32_t INTEN;
  4655. struct
  4656. {
  4657. __IOM uint32_t RFUIE : 1;
  4658. __IOM uint32_t RFOIE : 1;
  4659. __IOM uint32_t RFFIE : 1;
  4660. __IOM uint32_t TFOIE : 1;
  4661. __IOM uint32_t TFEIE : 1;
  4662. __IOM uint32_t RRIE : 1;
  4663. __IOM uint32_t TAIE : 1;
  4664. __IOM uint32_t RDIE : 1;
  4665. __IOM uint32_t ACTIE : 1;
  4666. __IOM uint32_t STPDIE : 1;
  4667. __IOM uint32_t STADIE : 1;
  4668. __IOM uint32_t GCIE : 1;
  4669. __IOM uint32_t RSTADIE : 1;
  4670. __IOM uint32_t MOHIE : 1;
  4671. __IM uint32_t RESERVED : 18;
  4672. } INTEN_B;
  4673. };
  4674. /** @brief Raw interrupt status register */
  4675. union
  4676. {
  4677. __IM uint32_t RIS;
  4678. struct
  4679. {
  4680. __IM uint32_t RFUIF : 1;
  4681. __IM uint32_t RFOIF : 1;
  4682. __IM uint32_t RFFIF : 1;
  4683. __IM uint32_t TFOIF : 1;
  4684. __IM uint32_t TFEIF : 1;
  4685. __IM uint32_t RRIF : 1;
  4686. __IM uint32_t TAIF : 1;
  4687. __IM uint32_t RDIF : 1;
  4688. __IM uint32_t ACTIF : 1;
  4689. __IM uint32_t STPDIF : 1;
  4690. __IM uint32_t STADIF : 1;
  4691. __IM uint32_t GCIF : 1;
  4692. __IM uint32_t RSTADIF : 1;
  4693. __IM uint32_t RESERVED : 18;
  4694. } RIS_B;
  4695. };
  4696. /** @brief Reception FIFO threshold register */
  4697. union
  4698. {
  4699. __IOM uint32_t RFT;
  4700. struct
  4701. {
  4702. __IOM uint32_t RFT : 8;
  4703. __IM uint32_t RESERVED : 24;
  4704. } RFT_B;
  4705. };
  4706. /** @brief Transmission FIFO threshold register */
  4707. union
  4708. {
  4709. __IOM uint32_t TFT;
  4710. struct
  4711. {
  4712. __IOM uint32_t TFT : 8;
  4713. __IM uint32_t RESERVED : 24;
  4714. } TFT_B;
  4715. };
  4716. /** @brief Interruption clear register */
  4717. union
  4718. {
  4719. __IM uint32_t INTCLR;
  4720. struct
  4721. {
  4722. __IM uint32_t INTCLR : 1;
  4723. __IM uint32_t RESERVED : 31;
  4724. } INTCLR_B;
  4725. };
  4726. /** @brief Reception FIFO underflow interruption clear register */
  4727. union
  4728. {
  4729. __IM uint32_t RFUIC;
  4730. struct
  4731. {
  4732. __IM uint32_t RFUIC : 1;
  4733. __IM uint32_t RESERVED : 31;
  4734. } RFUIC_B;
  4735. };
  4736. /** @brief Reception FIFO overflow interruption clear register */
  4737. union
  4738. {
  4739. __IM uint32_t RFOIC;
  4740. struct
  4741. {
  4742. __IM uint32_t RFOIC : 1;
  4743. __IM uint32_t RESERVED : 31;
  4744. } RFOIC_B;
  4745. };
  4746. /** @brief Transmission FIFO overflow interruption clear register */
  4747. union
  4748. {
  4749. __IM uint32_t TFOIC;
  4750. struct
  4751. {
  4752. __IM uint32_t TFOIC : 1;
  4753. __IM uint32_t RESERVED : 31;
  4754. } TFOIC_B;
  4755. };
  4756. /** @brief Reception request interruption clear register */
  4757. union
  4758. {
  4759. __IM uint32_t RRIC;
  4760. struct
  4761. {
  4762. __IM uint32_t RRIC : 1;
  4763. __IM uint32_t RESERVED : 31;
  4764. } RRIC_B;
  4765. };
  4766. /** @brief Transmission abort interruption clear register */
  4767. union
  4768. {
  4769. __IM uint32_t TAIC;
  4770. struct
  4771. {
  4772. __IM uint32_t TAIC : 1;
  4773. __IM uint32_t RESERVED : 31;
  4774. } TAIC_B;
  4775. };
  4776. /** @brief Receive done interruption clear register */
  4777. union
  4778. {
  4779. __IM uint32_t RDIC;
  4780. struct
  4781. {
  4782. __IM uint32_t RDIC : 1;
  4783. __IM uint32_t RESERVED : 31;
  4784. } RDIC_B;
  4785. };
  4786. /** @brief Activity interruption clear register */
  4787. union
  4788. {
  4789. __IM uint32_t AIC;
  4790. struct
  4791. {
  4792. __IM uint32_t AIC : 1;
  4793. __IM uint32_t RESERVED : 31;
  4794. } AIC_B;
  4795. };
  4796. /** @brief Stop detection interruption clear register */
  4797. union
  4798. {
  4799. __IM uint32_t STPDIC;
  4800. struct
  4801. {
  4802. __IM uint32_t STPDIC : 1;
  4803. __IM uint32_t RESERVED : 31;
  4804. } STPDIC_B;
  4805. };
  4806. /** @brief Start detection interruption clear register */
  4807. union
  4808. {
  4809. __IM uint32_t STADIC;
  4810. struct
  4811. {
  4812. __IM uint32_t STADIC : 1;
  4813. __IM uint32_t RESERVED : 31;
  4814. } STADIC_B;
  4815. };
  4816. /** @brief General call interruption clear register */
  4817. union
  4818. {
  4819. __IM uint32_t GCIC;
  4820. struct
  4821. {
  4822. __IM uint32_t GCIC : 1;
  4823. __IM uint32_t RESERVED : 31;
  4824. } GCIC_B;
  4825. };
  4826. /** @brief Control register 2 */
  4827. union
  4828. {
  4829. __IOM uint32_t CTRL2;
  4830. struct
  4831. {
  4832. __IOM uint32_t I2CEN : 1;
  4833. __IOM uint32_t ABR : 1;
  4834. __IOM uint32_t TCB : 1;
  4835. __IM uint32_t RESERVED : 29;
  4836. } CTRL2_B;
  4837. };
  4838. /** @brief Status register 1 */
  4839. union
  4840. {
  4841. __IM uint32_t STS1;
  4842. struct
  4843. {
  4844. __IM uint32_t ACTF : 1;
  4845. __IM uint32_t TFNFF : 1;
  4846. __IM uint32_t TFEF : 1;
  4847. __IM uint32_t RFNEF : 1;
  4848. __IM uint32_t RFFF : 1;
  4849. __IM uint32_t MAF : 1;
  4850. __IM uint32_t SAF : 1;
  4851. __IM uint32_t RESERVED : 24;
  4852. } STS1_B;
  4853. };
  4854. /** @brief Transmission FIFO level */
  4855. union
  4856. {
  4857. __IOM uint32_t TFL;
  4858. struct
  4859. {
  4860. __IOM uint32_t TFL : 4;
  4861. __IM uint32_t RESERVED : 28;
  4862. } TFL_B;
  4863. };
  4864. /** @brief Reception FIFO level */
  4865. union
  4866. {
  4867. __IOM uint32_t RFL;
  4868. struct
  4869. {
  4870. __IOM uint32_t RFL : 4;
  4871. __IM uint32_t RESERVED : 28;
  4872. } RFL_B;
  4873. };
  4874. /** @brief SDA hold time length register */
  4875. union
  4876. {
  4877. __IOM uint32_t SDAHOLD;
  4878. struct
  4879. {
  4880. __IOM uint32_t TXHOLD : 16;
  4881. __IOM uint32_t RXHOLD : 8;
  4882. __IM uint32_t RESERVED : 8;
  4883. } SDAHOLD_B;
  4884. };
  4885. /** @brief Transmission abort source register */
  4886. union
  4887. {
  4888. __IM uint32_t TAS;
  4889. struct
  4890. {
  4891. __IM uint32_t AD7NA : 1;
  4892. __IM uint32_t AD10NA1 : 1;
  4893. __IM uint32_t AD10NA2 : 1;
  4894. __IM uint32_t TDNA : 1;
  4895. __IM uint32_t GCNA : 1;
  4896. __IM uint32_t GCR : 1;
  4897. __IM uint32_t HSAD : 1;
  4898. __IM uint32_t SNR : 1;
  4899. __IM uint32_t RNR10B : 1;
  4900. __IM uint32_t MSTDIS : 1;
  4901. __IM uint32_t ARBLOST : 1;
  4902. __IM uint32_t LFTF : 1;
  4903. __IM uint32_t SAL : 1;
  4904. __IM uint32_t SRI : 1;
  4905. __IM uint32_t USRARB : 1;
  4906. __IM uint32_t FLUCNT : 1;
  4907. __IM uint32_t RESERVED : 16;
  4908. } TAS_B;
  4909. };
  4910. /** @brief Slave data NACK only register */
  4911. union
  4912. {
  4913. __IOM uint32_t SDNO;
  4914. struct
  4915. {
  4916. __IOM uint32_t NACK : 1;
  4917. __IM uint32_t RESERVED : 31;
  4918. } SDNO_B;
  4919. };
  4920. /** @brief DMA control register */
  4921. union
  4922. {
  4923. __IOM uint32_t DMACTRL;
  4924. struct
  4925. {
  4926. __IOM uint32_t RXEN : 1;
  4927. __IOM uint32_t TXEN : 1;
  4928. __IM uint32_t RESERVED : 30;
  4929. } DMACTRL_B;
  4930. };
  4931. /** @brief DMA transmission data level register */
  4932. union
  4933. {
  4934. __IOM uint32_t DTDL;
  4935. struct
  4936. {
  4937. __IOM uint32_t DTDL : 4;
  4938. __IM uint32_t RESERVED : 28;
  4939. } DTDL_B;
  4940. };
  4941. /** @brief DMA teception data level register */
  4942. union
  4943. {
  4944. __IOM uint32_t DRDL;
  4945. struct
  4946. {
  4947. __IOM uint32_t DRDL : 4;
  4948. __IM uint32_t RESERVED : 28;
  4949. } DRDL_B;
  4950. };
  4951. /** @brief SDA delay register */
  4952. union
  4953. {
  4954. __IOM uint32_t SDADLY;
  4955. struct
  4956. {
  4957. __IOM uint32_t SDADLY : 8;
  4958. __IM uint32_t RESERVED : 24;
  4959. } SDADLY_B;
  4960. };
  4961. /** @brief Genernal call ACK register */
  4962. union
  4963. {
  4964. __IOM uint32_t GCA;
  4965. struct
  4966. {
  4967. __IOM uint32_t GCA : 1;
  4968. __IM uint32_t RESERVED : 31;
  4969. } GCA_B;
  4970. };
  4971. /** @brief Status register 2 */
  4972. union
  4973. {
  4974. __IM uint32_t STS2;
  4975. struct
  4976. {
  4977. __IM uint32_t I2CEN : 1;
  4978. __IM uint32_t SDWB : 1;
  4979. __IM uint32_t SRDL : 1;
  4980. __IM uint32_t RESERVED : 29;
  4981. } STS2_B;
  4982. };
  4983. /** @brief Low speed spike suppression limit */
  4984. union
  4985. {
  4986. __IOM uint32_t LSSSL;
  4987. struct
  4988. {
  4989. __IOM uint32_t LSSSL : 8;
  4990. __IM uint32_t RESERVED : 24;
  4991. } LSSSL_B;
  4992. };
  4993. /** @brief High speed spike suppression limit */
  4994. union
  4995. {
  4996. __IOM uint32_t HSSSL;
  4997. struct
  4998. {
  4999. __IOM uint32_t HSSSL : 8;
  5000. __IM uint32_t RESERVED : 24;
  5001. } HSSSL_B;
  5002. };
  5003. uint32_t RESERVED[22];
  5004. /** @brief Switch register */
  5005. union
  5006. {
  5007. __IOM uint32_t SW;
  5008. struct
  5009. {
  5010. __IOM uint32_t SW : 1;
  5011. __IM uint32_t RESERVED : 31;
  5012. } SW_B;
  5013. };
  5014. } SCI2C_T;
  5015. /**
  5016. * @brief Dynamic memory controler (DMC)
  5017. */
  5018. typedef struct
  5019. {
  5020. /** @brief Configuraion register */
  5021. union
  5022. {
  5023. __IOM uint32_t CFG;
  5024. struct
  5025. {
  5026. __IM uint32_t RESERVED1 : 3;
  5027. __IOM uint32_t BAWCFG : 2;
  5028. __IOM uint32_t RAWCFG : 4;
  5029. __IOM uint32_t CAWCFG : 4;
  5030. __IOM uint32_t DWCFG : 2;
  5031. __IM uint32_t RESERVED2 : 16;
  5032. } CFG_B;
  5033. };
  5034. /** @brief Timing register 0 */
  5035. union
  5036. {
  5037. __IOM uint32_t TIM0;
  5038. struct
  5039. {
  5040. __IOM uint32_t CASLSEL0 : 2;
  5041. __IOM uint32_t RASMINTSEL : 4;
  5042. __IOM uint32_t DTIMSEL : 3;
  5043. __IOM uint32_t PCPSEL : 3;
  5044. __IOM uint32_t WRTIMSEL : 2;
  5045. __IOM uint32_t ARPSEL : 4;
  5046. __IOM uint32_t XSR0 : 4;
  5047. __IOM uint32_t ATACP : 4;
  5048. __IOM uint32_t ECASLSEL1 : 1;
  5049. __IOM uint32_t EXSR1 : 5;
  5050. } TIM0_B;
  5051. };
  5052. /** @brief Timing register 1 */
  5053. union
  5054. {
  5055. __IOM uint32_t TIM1;
  5056. struct
  5057. {
  5058. __IOM uint32_t STBTIM : 16;
  5059. __IOM uint32_t ARNUMCFG : 4;
  5060. __IM uint32_t RESERVED : 12;
  5061. } TIM1_B;
  5062. };
  5063. /** @brief Control register 1 */
  5064. union
  5065. {
  5066. __IOM uint32_t CTRL1;
  5067. struct
  5068. {
  5069. __IOM uint32_t INIT : 1;
  5070. __IOM uint32_t SRMEN : 1;
  5071. __IOM uint32_t PDMEN : 1;
  5072. __IOM uint32_t PCACFG : 1;
  5073. __IOM uint32_t FRBSREN : 1;
  5074. __IOM uint32_t FRASREN : 1;
  5075. __IOM uint32_t RDNUMMCFG : 3;
  5076. __IOM uint32_t MODESET : 1;
  5077. __IM uint32_t RESERVED1 : 1;
  5078. __IM uint32_t SRMFLG : 1;
  5079. __IOM uint32_t BANKNUMCFG : 5;
  5080. __IM uint32_t RESERVED2 : 15;
  5081. } CTRL1_B;
  5082. };
  5083. /** @brief Refresh register */
  5084. union
  5085. {
  5086. __IOM uint32_t REF;
  5087. struct
  5088. {
  5089. __IOM uint32_t RCYCCFG : 16;
  5090. __IM uint32_t RESERVED : 16;
  5091. } REF_B;
  5092. };
  5093. /** @brief Chip select register */
  5094. union
  5095. {
  5096. __IOM uint32_t CHIPSEL;
  5097. struct
  5098. {
  5099. __IM uint32_t RESERVED : 16;
  5100. __IOM uint32_t BACHIPSEL : 16;
  5101. } CHIPSEL_B;
  5102. };
  5103. __IM uint32_t RESERVED[15];
  5104. /** @brief Mask register */
  5105. union
  5106. {
  5107. __IOM uint32_t MASK;
  5108. struct
  5109. {
  5110. __IOM uint32_t MSIZESEL : 5;
  5111. __IOM uint32_t MTYPESEL : 3;
  5112. __IM uint32_t RESERVED : 24;
  5113. } MASK_B;
  5114. };
  5115. __IM uint32_t RESERVED1[234];
  5116. /** @brief Switch register */
  5117. union
  5118. {
  5119. __IOM uint32_t SW;
  5120. struct
  5121. {
  5122. __IOM uint32_t MCSW : 1;
  5123. __IM uint32_t RESERVED : 31;
  5124. } SW_B;
  5125. };
  5126. /** @brief Control register 2 */
  5127. union
  5128. {
  5129. __IOM uint32_t CTRL2;
  5130. struct
  5131. {
  5132. __IOM uint32_t CPHACFG : 1;
  5133. __IOM uint32_t RDDEN : 1;
  5134. __IOM uint32_t RDDCFG : 3;
  5135. __IOM uint32_t WPEN : 1;
  5136. __IOM uint32_t BUFFEN : 1;
  5137. __IOM uint32_t WRPBSEL : 1;
  5138. __IM uint32_t RESERVED : 24;
  5139. } CTRL2_B;
  5140. };
  5141. } DMC_T;
  5142. /**
  5143. * @brief Debug MCU(DBGMCU)
  5144. */
  5145. typedef struct
  5146. {
  5147. /** @brief ID register */
  5148. union
  5149. {
  5150. __IOM uint32_t IDCODE;
  5151. struct
  5152. {
  5153. __IOM uint32_t EQR : 12;
  5154. __IM uint32_t RESERVED : 4;
  5155. __IOM uint32_t WVR : 16;
  5156. } IDCODE_B;
  5157. };
  5158. /** @brief Control register */
  5159. union
  5160. {
  5161. __IOM uint32_t CFG;
  5162. struct
  5163. {
  5164. __IOM uint32_t SLEEP_CLK_STS : 1;
  5165. __IOM uint32_t STOP_CLK_STS : 1;
  5166. __IOM uint32_t STANDBY_CLK_STS : 1;
  5167. __IM uint32_t RESERVED1 : 2;
  5168. __IOM uint32_t IOEN : 1;
  5169. __IOM uint32_t MODE : 2;
  5170. __IOM uint32_t IWDT_STS : 1;
  5171. __IOM uint32_t WWDT_STS : 1;
  5172. __IOM uint32_t TMR1_STS : 1;
  5173. __IOM uint32_t TMR2_STS : 1;
  5174. __IOM uint32_t TMR3_STS : 1;
  5175. __IOM uint32_t TMR4_STS : 1;
  5176. __IOM uint32_t CAN1_STS : 1;
  5177. __IOM uint32_t I2C1_SMBUS_TIMEOUT_STS : 1;
  5178. __IOM uint32_t I2C2_SMBUS_TIMEOUT_STS : 1;
  5179. __IOM uint32_t TMR8_STS : 1;
  5180. __IOM uint32_t TMR5_STS : 1;
  5181. __IOM uint32_t TMR6_STS : 1;
  5182. __IOM uint32_t TMR7_STS : 1;
  5183. __IOM uint32_t CAN2_STS : 1;
  5184. __IM uint32_t RESERVED2 : 3;
  5185. __IOM uint32_t TMR12_STS : 1;
  5186. __IOM uint32_t TMR13_STS : 1;
  5187. __IOM uint32_t TMR14_STS : 1;
  5188. __IOM uint32_t TMR9_STS : 1;
  5189. __IOM uint32_t TMR10_STS : 1;
  5190. __IOM uint32_t TMR11_STS : 1;
  5191. __IM uint32_t RESERVED3 : 1;
  5192. } CFG_B;
  5193. };
  5194. } DBGMCU_T;
  5195. /**
  5196. * @brief USB Device controler(USBD)
  5197. */
  5198. typedef union
  5199. {
  5200. __IOM uint32_t EP;
  5201. struct
  5202. {
  5203. __IOM uint32_t ADDR : 4;
  5204. __IOM uint32_t TXSTS : 2;
  5205. __IOM uint32_t TXDTOG : 1;
  5206. __IOM uint32_t CTFT : 1;
  5207. __IOM uint32_t KIND : 1;
  5208. __IOM uint32_t TYPE : 2;
  5209. __IOM uint32_t SETUP : 1;
  5210. __IOM uint32_t RXSTS : 2;
  5211. __IOM uint32_t RXDTOG : 1;
  5212. __IOM uint32_t CTFR : 1;
  5213. __IM uint32_t RESERVED : 16;
  5214. } EP_B;
  5215. } USBD_EP_REG_T;
  5216. typedef struct
  5217. {
  5218. /** Endpoint */
  5219. USBD_EP_REG_T EP[8];
  5220. __IM uint32_t RESERVED[8];
  5221. /** @brief Control register */
  5222. union
  5223. {
  5224. __IOM uint32_t CTRL;
  5225. struct
  5226. {
  5227. __IOM uint32_t FORRST : 1;
  5228. __IOM uint32_t PWRDOWN : 1;
  5229. __IOM uint32_t LPWREN : 1;
  5230. __IOM uint32_t FORSUS : 1;
  5231. __IOM uint32_t WUPREQ : 1;
  5232. __IM uint32_t RESERVED1 : 3;
  5233. __IOM uint32_t ESOFIEN : 1;
  5234. __IOM uint32_t SOFIEN : 1;
  5235. __IOM uint32_t RSTIEN : 1;
  5236. __IOM uint32_t SUSIEN : 1;
  5237. __IOM uint32_t WUPIEN : 1;
  5238. __IOM uint32_t ERRIEN : 1;
  5239. __IOM uint32_t PMAOUIEN : 1;
  5240. __IOM uint32_t CTRIEN : 1;
  5241. __IM uint32_t RESERVED2 : 16;
  5242. } CTRL_B;
  5243. };
  5244. /** @brief Interrupt status register */
  5245. union
  5246. {
  5247. __IOM uint32_t INTSTS;
  5248. struct
  5249. {
  5250. __IOM uint32_t EPID : 4;
  5251. __IOM uint32_t DOT : 1;
  5252. __IM uint32_t RESERVED1 : 3;
  5253. __IOM uint32_t ESOFFLG : 1;
  5254. __IOM uint32_t SOFFLG : 1;
  5255. __IOM uint32_t RSTREQ : 1;
  5256. __IOM uint32_t SUSREQ : 1;
  5257. __IOM uint32_t WUPREQ : 1;
  5258. __IOM uint32_t ERRFLG : 1;
  5259. __IOM uint32_t PMOFLG : 1;
  5260. __IOM uint32_t CTFLG : 1;
  5261. __IM uint32_t RESERVED2 : 16;
  5262. } INTSTS_B;
  5263. };
  5264. /** @brief Frame number register */
  5265. union
  5266. {
  5267. __IM uint32_t FRANUM;
  5268. struct
  5269. {
  5270. __IM uint32_t FRANUM : 11;
  5271. __IM uint32_t LSOFNUM : 2;
  5272. __IM uint32_t LOCK : 1;
  5273. __IM uint32_t RXDMSTS : 1;
  5274. __IM uint32_t RXDPSTS : 1;
  5275. __IM uint32_t RESERVED : 16;
  5276. } FRANUM_B;
  5277. };
  5278. /** @brief Device address register */
  5279. union
  5280. {
  5281. __IOM uint32_t ADDR;
  5282. struct
  5283. {
  5284. __IOM uint32_t ADDR : 7;
  5285. __IOM uint32_t USBDEN : 1;
  5286. __IM uint32_t RESERVED : 24;
  5287. } ADDR_B;
  5288. };
  5289. /** @brief Buffer table address register */
  5290. union
  5291. {
  5292. __IOM uint32_t BUFFTB;
  5293. struct
  5294. {
  5295. __IM uint32_t RESERVED1 : 3;
  5296. __IOM uint32_t BUFFTB : 13;
  5297. __IM uint32_t RESERVED2 : 16;
  5298. } BUFFTB_B;
  5299. };
  5300. __IM uint32_t RESERVED1[43];
  5301. /** @brief Buffer table address register */
  5302. union
  5303. {
  5304. __IOM uint32_t SWITCH;
  5305. struct
  5306. {
  5307. __IOM uint32_t SWITCH : 1;
  5308. __IM uint32_t RESERVED : 31;
  5309. } SWITCH_B;
  5310. };
  5311. } USBD_T;
  5312. /** FMC base address in the alias region */
  5313. #define FMC_BASE ((uint32_t)0x08000000)
  5314. /** SRAM base address in the alias region */
  5315. #define SRAM_BASE ((uint32_t)0x20000000)
  5316. /** Peripheral base address in the alias region */
  5317. #define PERIPH_BASE ((uint32_t)0x40000000)
  5318. /** SRAM base address in the bit-band region */
  5319. #define SRAM_BB_BASE ((uint32_t)0x22000000)
  5320. /** Peripheral base address in the bit-band region */
  5321. #define PERIPH_BB_BASE ((uint32_t)0x42000000)
  5322. /** EMMC registers base address */
  5323. #define EMMC_R_BASE ((uint32_t)0xA0000000)
  5324. /** QSPI registers base address */
  5325. #define QSPI_BASE ((uint32_t)0xA0000000)
  5326. /** DMC registers base address */
  5327. #define DMC_BASE ((uint32_t)0xA0000000)
  5328. /** Peripheral memory map */
  5329. #define APB1PERIPH_BASE PERIPH_BASE
  5330. #define APB2PERIPH_BASE (PERIPH_BASE + 0x10000)
  5331. #define AHBPERIPH_BASE (PERIPH_BASE + 0x20000)
  5332. #define TMR2_BASE (APB1PERIPH_BASE + 0x0000)
  5333. #define TMR3_BASE (APB1PERIPH_BASE + 0x0400)
  5334. #define TMR4_BASE (APB1PERIPH_BASE + 0x0800)
  5335. #define TMR5_BASE (APB1PERIPH_BASE + 0x0C00)
  5336. #define TMR6_BASE (APB1PERIPH_BASE + 0x1000)
  5337. #define TMR7_BASE (APB1PERIPH_BASE + 0x1400)
  5338. #define TMR12_BASE (APB1PERIPH_BASE + 0x1800)
  5339. #define TMR13_BASE (APB1PERIPH_BASE + 0x1C00)
  5340. #define TMR14_BASE (APB1PERIPH_BASE + 0x2000)
  5341. #define RTC_BASE (APB1PERIPH_BASE + 0x2800)
  5342. #define WWDT_BASE (APB1PERIPH_BASE + 0x2C00)
  5343. #define IWDT_BASE (APB1PERIPH_BASE + 0x3000)
  5344. #define SPI2_BASE (APB1PERIPH_BASE + 0x3800)
  5345. #define SPI3_BASE (APB1PERIPH_BASE + 0x3C00)
  5346. #define USART2_BASE (APB1PERIPH_BASE + 0x4400)
  5347. #define USART3_BASE (APB1PERIPH_BASE + 0x4800)
  5348. #define UART4_BASE (APB1PERIPH_BASE + 0x4C00)
  5349. #define UART5_BASE (APB1PERIPH_BASE + 0x5000)
  5350. #define I2C1_BASE (APB1PERIPH_BASE + 0x5400)
  5351. #define I2C2_BASE (APB1PERIPH_BASE + 0x5800)
  5352. #define USBD_BASE (APB1PERIPH_BASE + 0X5C00)
  5353. #define CAN1_BASE (APB1PERIPH_BASE + 0x6400)
  5354. #define CAN2_BASE (APB1PERIPH_BASE + 0x6800)
  5355. #define BAKPR_BASE (APB1PERIPH_BASE + 0x6C00)
  5356. #define PMU_BASE (APB1PERIPH_BASE + 0x7000)
  5357. #define DAC_BASE (APB1PERIPH_BASE + 0x7400)
  5358. #define CEC_BASE (APB1PERIPH_BASE + 0x7800)
  5359. #define AFIO_BASE (APB2PERIPH_BASE + 0x0000)
  5360. #define EINT_BASE (APB2PERIPH_BASE + 0x0400)
  5361. #define GPIOA_BASE (APB2PERIPH_BASE + 0x0800)
  5362. #define GPIOB_BASE (APB2PERIPH_BASE + 0x0C00)
  5363. #define GPIOC_BASE (APB2PERIPH_BASE + 0x1000)
  5364. #define GPIOD_BASE (APB2PERIPH_BASE + 0x1400)
  5365. #define GPIOE_BASE (APB2PERIPH_BASE + 0x1800)
  5366. #define GPIOF_BASE (APB2PERIPH_BASE + 0x1C00)
  5367. #define GPIOG_BASE (APB2PERIPH_BASE + 0x2000)
  5368. #define ADC1_BASE (APB2PERIPH_BASE + 0x2400)
  5369. #define ADC2_BASE (APB2PERIPH_BASE + 0x2800)
  5370. #define TMR1_BASE (APB2PERIPH_BASE + 0x2C00)
  5371. #define SPI1_BASE (APB2PERIPH_BASE + 0x3000)
  5372. #define TMR8_BASE (APB2PERIPH_BASE + 0x3400)
  5373. #define USART1_BASE (APB2PERIPH_BASE + 0x3800)
  5374. #define ADC3_BASE (APB2PERIPH_BASE + 0x3C00)
  5375. #define TMR15_BASE (APB2PERIPH_BASE + 0x4000)
  5376. #define TMR16_BASE (APB2PERIPH_BASE + 0x4400)
  5377. #define TMR17_BASE (APB2PERIPH_BASE + 0x4800)
  5378. #define TMR9_BASE (APB2PERIPH_BASE + 0x4C00)
  5379. #define TMR10_BASE (APB2PERIPH_BASE + 0x5000)
  5380. #define TMR11_BASE (APB2PERIPH_BASE + 0x5400)
  5381. #define SDIO_BASE (PERIPH_BASE + 0x18000)
  5382. #define DMA1_BASE (AHBPERIPH_BASE + 0x0000)
  5383. #define DMA1_Channel1_BASE (AHBPERIPH_BASE + 0x0008)
  5384. #define DMA1_Channel2_BASE (AHBPERIPH_BASE + 0x001C)
  5385. #define DMA1_Channel3_BASE (AHBPERIPH_BASE + 0x0030)
  5386. #define DMA1_Channel4_BASE (AHBPERIPH_BASE + 0x0044)
  5387. #define DMA1_Channel5_BASE (AHBPERIPH_BASE + 0x0058)
  5388. #define DMA1_Channel6_BASE (AHBPERIPH_BASE + 0x006C)
  5389. #define DMA1_Channel7_BASE (AHBPERIPH_BASE + 0x0080)
  5390. #define DMA2_BASE (AHBPERIPH_BASE + 0x0400)
  5391. #define DMA2_Channel1_BASE (AHBPERIPH_BASE + 0x0408)
  5392. #define DMA2_Channel2_BASE (AHBPERIPH_BASE + 0x041C)
  5393. #define DMA2_Channel3_BASE (AHBPERIPH_BASE + 0x0430)
  5394. #define DMA2_Channel4_BASE (AHBPERIPH_BASE + 0x0444)
  5395. #define DMA2_Channel5_BASE (AHBPERIPH_BASE + 0x0458)
  5396. #define RCM_BASE (AHBPERIPH_BASE + 0x1000)
  5397. #define CRC_BASE (AHBPERIPH_BASE + 0x3000)
  5398. /** FMC registers base address */
  5399. #define FMC_R_BASE (AHBPERIPH_BASE + 0x2000)
  5400. /** FMC Option Bytes base address */
  5401. #define OB_BASE ((uint32_t)0x1FFFF800)
  5402. /** EMMC Bank1 registers base address */
  5403. #define EMMC_Bank1_R_BASE (EMMC_R_BASE + 0x0000)
  5404. /** EMMC Bank1E registers base address */
  5405. #define EMMC_Bank1E_R_BASE (EMMC_R_BASE + 0x0104)
  5406. /** EMMC Bank2 registers base address */
  5407. #define EMMC_Bank2_R_BASE (EMMC_R_BASE + 0x0060)
  5408. /** EMMC Bank3 registers base address */
  5409. #define EMMC_Bank3_R_BASE (EMMC_R_BASE + 0x0080)
  5410. /**EMMC Bank4 registers base address */
  5411. #define EMMC_Bank4_R_BASE (EMMC_R_BASE + 0x00A0)
  5412. /** Debug MCU registers base address */
  5413. #define DBGMCU_BASE ((uint32_t)0xE0042000)
  5414. #define CRC ((CRC_T *) CRC_BASE)
  5415. #define RTC ((RTC_T *) RTC_BASE)
  5416. #define PMU ((PMU_T *) PMU_BASE)
  5417. #define BAKPR ((BAKPR_T *) BAKPR_BASE)
  5418. #define TMR1 ((TMR_T *) TMR1_BASE)
  5419. #define TMR2 ((TMR_T *) TMR2_BASE)
  5420. #define TMR3 ((TMR_T *) TMR3_BASE)
  5421. #define TMR4 ((TMR_T *) TMR4_BASE)
  5422. #define TMR5 ((TMR_T *) TMR5_BASE)
  5423. #define TMR6 ((TMR_T *) TMR6_BASE)
  5424. #define TMR7 ((TMR_T *) TMR7_BASE)
  5425. #define TMR8 ((TMR_T *) TMR8_BASE)
  5426. #define TMR9 ((TMR_T *) TMR9_BASE)
  5427. #define TMR10 ((TMR_T *) TMR10_BASE)
  5428. #define TMR11 ((TMR_T *) TMR11_BASE)
  5429. #define TMR12 ((TMR_T *) TMR12_BASE)
  5430. #define TMR13 ((TMR_T *) TMR13_BASE)
  5431. #define TMR14 ((TMR_T *) TMR14_BASE)
  5432. #define TMR15 ((TMR_T *) TMR15_BASE)
  5433. #define TMR16 ((TMR_T *) TMR16_BASE)
  5434. #define TMR17 ((TMR_T *) TMR17_BASE)
  5435. #define DMA1 ((DMA_T *) DMA1_BASE)
  5436. #define DMA2 ((DMA_T *) DMA2_BASE)
  5437. #define DMA1_Channel1 ((DMA_Channel_T *) DMA1_Channel1_BASE)
  5438. #define DMA1_Channel2 ((DMA_Channel_T *) DMA1_Channel2_BASE)
  5439. #define DMA1_Channel3 ((DMA_Channel_T *) DMA1_Channel3_BASE)
  5440. #define DMA1_Channel4 ((DMA_Channel_T *) DMA1_Channel4_BASE)
  5441. #define DMA1_Channel5 ((DMA_Channel_T *) DMA1_Channel5_BASE)
  5442. #define DMA1_Channel6 ((DMA_Channel_T *) DMA1_Channel6_BASE)
  5443. #define DMA1_Channel7 ((DMA_Channel_T *) DMA1_Channel7_BASE)
  5444. #define DMA2_Channel1 ((DMA_Channel_T *) DMA2_Channel1_BASE)
  5445. #define DMA2_Channel2 ((DMA_Channel_T *) DMA2_Channel2_BASE)
  5446. #define DMA2_Channel3 ((DMA_Channel_T *) DMA2_Channel3_BASE)
  5447. #define DMA2_Channel4 ((DMA_Channel_T *) DMA2_Channel4_BASE)
  5448. #define DMA2_Channel5 ((DMA_Channel_T *) DMA2_Channel5_BASE)
  5449. #define CAN1 ((CAN_T *) CAN1_BASE)
  5450. #define CAN2 ((CAN_T *) CAN2_BASE)
  5451. #define I2C1 ((I2C_T *) I2C1_BASE)
  5452. #define I2C2 ((I2C_T *) I2C2_BASE)
  5453. #define OB ((OB_T *) OB_BASE)
  5454. #define ADC1 ((ADC_T *) ADC1_BASE)
  5455. #define ADC2 ((ADC_T *) ADC2_BASE)
  5456. #define ADC3 ((ADC_T *) ADC3_BASE)
  5457. #define EINT ((EINT_T *) EINT_BASE)
  5458. #define IWDT ((IWDT_T *) IWDT_BASE)
  5459. #define SDIO ((SDIO_T *) SDIO_BASE)
  5460. #define DAC ((DAC_T *) DAC_BASE)
  5461. #define SPI1 ((SPI_T *) SPI1_BASE)
  5462. #define SPI2 ((SPI_T *) SPI2_BASE)
  5463. #define SPI3 ((SPI_T *) SPI3_BASE)
  5464. #define WWDT ((WWDT_T *) WWDT_BASE)
  5465. #define USART2 ((USART_T *) USART2_BASE)
  5466. #define USART3 ((USART_T *) USART3_BASE)
  5467. #define UART4 ((USART_T *) UART4_BASE)
  5468. #define UART5 ((USART_T *) UART5_BASE)
  5469. #define AFIO ((AFIO_T *) AFIO_BASE)
  5470. #define GPIOA ((GPIO_T *) GPIOA_BASE)
  5471. #define GPIOB ((GPIO_T *) GPIOB_BASE)
  5472. #define GPIOC ((GPIO_T *) GPIOC_BASE)
  5473. #define GPIOD ((GPIO_T *) GPIOD_BASE)
  5474. #define GPIOE ((GPIO_T *) GPIOE_BASE)
  5475. #define GPIOF ((GPIO_T *) GPIOF_BASE)
  5476. #define GPIOG ((GPIO_T *) GPIOG_BASE)
  5477. #define USART1 ((USART_T *) USART1_BASE)
  5478. #define RCM ((RCM_T *) RCM_BASE)
  5479. #define FMC ((FMC_T *) FMC_R_BASE)
  5480. #define USBD ((USBD_T *)USBD_BASE)
  5481. #define EMMC_Bank1 ((EMMC_Bank1_T *) EMMC_Bank1_R_BASE)
  5482. #define EMMC_Bank1E ((EMMC_Bank1E_T *)EMMC_Bank1E_R_BASE)
  5483. #define EMMC_Bank2 ((EMMC_Bank2_T *) EMMC_Bank2_R_BASE)
  5484. #define EMMC_Bank3 ((EMMC_Bank3_T *) EMMC_Bank3_R_BASE)
  5485. #define EMMC_Bank4 ((EMMC_Bank4_T *) EMMC_Bank4_R_BASE)
  5486. #define DBGMCU ((DBGMCU_T *) DBGMCU_BASE)
  5487. #define I2C3 ((SCI2C_T *)(I2C1_BASE))
  5488. #define I2C4 ((SCI2C_T *)(I2C2_BASE))
  5489. #if defined (APM32F10X_MD) || defined (APM32F10X_LD)
  5490. #define QSPI ((QSPI_T *)QSPI_BASE)
  5491. #endif
  5492. #if defined (APM32F10X_HD)
  5493. #define DMC ((DMC_T *)DMC_BASE)
  5494. #endif
  5495. /** Define one bit mask */
  5496. #define BIT0 ((uint32_t)0x00000001)
  5497. #define BIT1 ((uint32_t)0x00000002)
  5498. #define BIT2 ((uint32_t)0x00000004)
  5499. #define BIT3 ((uint32_t)0x00000008)
  5500. #define BIT4 ((uint32_t)0x00000010)
  5501. #define BIT5 ((uint32_t)0x00000020)
  5502. #define BIT6 ((uint32_t)0x00000040)
  5503. #define BIT7 ((uint32_t)0x00000080)
  5504. #define BIT8 ((uint32_t)0x00000100)
  5505. #define BIT9 ((uint32_t)0x00000200)
  5506. #define BIT10 ((uint32_t)0x00000400)
  5507. #define BIT11 ((uint32_t)0x00000800)
  5508. #define BIT12 ((uint32_t)0x00001000)
  5509. #define BIT13 ((uint32_t)0x00002000)
  5510. #define BIT14 ((uint32_t)0x00004000)
  5511. #define BIT15 ((uint32_t)0x00008000)
  5512. #define BIT16 ((uint32_t)0x00010000)
  5513. #define BIT17 ((uint32_t)0x00020000)
  5514. #define BIT18 ((uint32_t)0x00040000)
  5515. #define BIT19 ((uint32_t)0x00080000)
  5516. #define BIT20 ((uint32_t)0x00100000)
  5517. #define BIT21 ((uint32_t)0x00200000)
  5518. #define BIT22 ((uint32_t)0x00400000)
  5519. #define BIT23 ((uint32_t)0x00800000)
  5520. #define BIT24 ((uint32_t)0x01000000)
  5521. #define BIT25 ((uint32_t)0x02000000)
  5522. #define BIT26 ((uint32_t)0x04000000)
  5523. #define BIT27 ((uint32_t)0x08000000)
  5524. #define BIT28 ((uint32_t)0x10000000)
  5525. #define BIT29 ((uint32_t)0x20000000)
  5526. #define BIT30 ((uint32_t)0x40000000)
  5527. #define BIT31 ((uint32_t)0x80000000)
  5528. #define SET_BIT(REG, BIT) ((REG) |= (BIT))
  5529. #define CLEAR_BIT(REG, BIT) ((REG) &= ~(BIT))
  5530. #define READ_BIT(REG, BIT) ((REG) & (BIT))
  5531. #define CLEAR_REG(REG) ((REG) = (0x0))
  5532. #define WRITE_REG(REG, VAL) ((REG) = (VAL))
  5533. #define READ_REG(REG) ((REG))
  5534. #define MODIFY_REG(REG, CLEARMASK, SETMASK) WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK)))
  5535. #ifdef __cplusplus
  5536. }
  5537. #endif
  5538. #endif /* __APM32F10X_H */