pfc-sh73a0.c 120 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004
  1. /*
  2. * sh73a0 processor support - PFC hardware block
  3. *
  4. * Copyright (C) 2010 Renesas Solutions Corp.
  5. * Copyright (C) 2010 NISHIMOTO Hiroki
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation; version 2 of the
  10. * License.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. #include <linux/io.h>
  22. #include <linux/kernel.h>
  23. #include <linux/pinctrl/pinconf-generic.h>
  24. #include <mach/sh73a0.h>
  25. #include <mach/irqs.h>
  26. #include "core.h"
  27. #include "sh_pfc.h"
  28. #define CPU_ALL_PORT(fn, pfx, sfx) \
  29. PORT_10(fn, pfx, sfx), PORT_90(fn, pfx, sfx), \
  30. PORT_10(fn, pfx##10, sfx), \
  31. PORT_1(fn, pfx##110, sfx), PORT_1(fn, pfx##111, sfx), \
  32. PORT_1(fn, pfx##112, sfx), PORT_1(fn, pfx##113, sfx), \
  33. PORT_1(fn, pfx##114, sfx), PORT_1(fn, pfx##115, sfx), \
  34. PORT_1(fn, pfx##116, sfx), PORT_1(fn, pfx##117, sfx), \
  35. PORT_1(fn, pfx##118, sfx), \
  36. PORT_1(fn, pfx##128, sfx), PORT_1(fn, pfx##129, sfx), \
  37. PORT_10(fn, pfx##13, sfx), PORT_10(fn, pfx##14, sfx), \
  38. PORT_10(fn, pfx##15, sfx), \
  39. PORT_1(fn, pfx##160, sfx), PORT_1(fn, pfx##161, sfx), \
  40. PORT_1(fn, pfx##162, sfx), PORT_1(fn, pfx##163, sfx), \
  41. PORT_1(fn, pfx##164, sfx), \
  42. PORT_1(fn, pfx##192, sfx), PORT_1(fn, pfx##193, sfx), \
  43. PORT_1(fn, pfx##194, sfx), PORT_1(fn, pfx##195, sfx), \
  44. PORT_1(fn, pfx##196, sfx), PORT_1(fn, pfx##197, sfx), \
  45. PORT_1(fn, pfx##198, sfx), PORT_1(fn, pfx##199, sfx), \
  46. PORT_10(fn, pfx##20, sfx), PORT_10(fn, pfx##21, sfx), \
  47. PORT_10(fn, pfx##22, sfx), PORT_10(fn, pfx##23, sfx), \
  48. PORT_10(fn, pfx##24, sfx), PORT_10(fn, pfx##25, sfx), \
  49. PORT_10(fn, pfx##26, sfx), PORT_10(fn, pfx##27, sfx), \
  50. PORT_1(fn, pfx##280, sfx), PORT_1(fn, pfx##281, sfx), \
  51. PORT_1(fn, pfx##282, sfx), \
  52. PORT_1(fn, pfx##288, sfx), PORT_1(fn, pfx##289, sfx), \
  53. PORT_10(fn, pfx##29, sfx), PORT_10(fn, pfx##30, sfx)
  54. enum {
  55. PINMUX_RESERVED = 0,
  56. PINMUX_DATA_BEGIN,
  57. PORT_ALL(DATA), /* PORT0_DATA -> PORT309_DATA */
  58. PINMUX_DATA_END,
  59. PINMUX_INPUT_BEGIN,
  60. PORT_ALL(IN), /* PORT0_IN -> PORT309_IN */
  61. PINMUX_INPUT_END,
  62. PINMUX_OUTPUT_BEGIN,
  63. PORT_ALL(OUT), /* PORT0_OUT -> PORT309_OUT */
  64. PINMUX_OUTPUT_END,
  65. PINMUX_FUNCTION_BEGIN,
  66. PORT_ALL(FN_IN), /* PORT0_FN_IN -> PORT309_FN_IN */
  67. PORT_ALL(FN_OUT), /* PORT0_FN_OUT -> PORT309_FN_OUT */
  68. PORT_ALL(FN0), /* PORT0_FN0 -> PORT309_FN0 */
  69. PORT_ALL(FN1), /* PORT0_FN1 -> PORT309_FN1 */
  70. PORT_ALL(FN2), /* PORT0_FN2 -> PORT309_FN2 */
  71. PORT_ALL(FN3), /* PORT0_FN3 -> PORT309_FN3 */
  72. PORT_ALL(FN4), /* PORT0_FN4 -> PORT309_FN4 */
  73. PORT_ALL(FN5), /* PORT0_FN5 -> PORT309_FN5 */
  74. PORT_ALL(FN6), /* PORT0_FN6 -> PORT309_FN6 */
  75. PORT_ALL(FN7), /* PORT0_FN7 -> PORT309_FN7 */
  76. MSEL2CR_MSEL19_0, MSEL2CR_MSEL19_1,
  77. MSEL2CR_MSEL18_0, MSEL2CR_MSEL18_1,
  78. MSEL2CR_MSEL17_0, MSEL2CR_MSEL17_1,
  79. MSEL2CR_MSEL16_0, MSEL2CR_MSEL16_1,
  80. MSEL2CR_MSEL14_0, MSEL2CR_MSEL14_1,
  81. MSEL2CR_MSEL13_0, MSEL2CR_MSEL13_1,
  82. MSEL2CR_MSEL12_0, MSEL2CR_MSEL12_1,
  83. MSEL2CR_MSEL11_0, MSEL2CR_MSEL11_1,
  84. MSEL2CR_MSEL10_0, MSEL2CR_MSEL10_1,
  85. MSEL2CR_MSEL9_0, MSEL2CR_MSEL9_1,
  86. MSEL2CR_MSEL8_0, MSEL2CR_MSEL8_1,
  87. MSEL2CR_MSEL7_0, MSEL2CR_MSEL7_1,
  88. MSEL2CR_MSEL6_0, MSEL2CR_MSEL6_1,
  89. MSEL2CR_MSEL4_0, MSEL2CR_MSEL4_1,
  90. MSEL2CR_MSEL5_0, MSEL2CR_MSEL5_1,
  91. MSEL2CR_MSEL3_0, MSEL2CR_MSEL3_1,
  92. MSEL2CR_MSEL2_0, MSEL2CR_MSEL2_1,
  93. MSEL2CR_MSEL1_0, MSEL2CR_MSEL1_1,
  94. MSEL2CR_MSEL0_0, MSEL2CR_MSEL0_1,
  95. MSEL3CR_MSEL28_0, MSEL3CR_MSEL28_1,
  96. MSEL3CR_MSEL15_0, MSEL3CR_MSEL15_1,
  97. MSEL3CR_MSEL11_0, MSEL3CR_MSEL11_1,
  98. MSEL3CR_MSEL9_0, MSEL3CR_MSEL9_1,
  99. MSEL3CR_MSEL6_0, MSEL3CR_MSEL6_1,
  100. MSEL3CR_MSEL2_0, MSEL3CR_MSEL2_1,
  101. MSEL4CR_MSEL29_0, MSEL4CR_MSEL29_1,
  102. MSEL4CR_MSEL27_0, MSEL4CR_MSEL27_1,
  103. MSEL4CR_MSEL26_0, MSEL4CR_MSEL26_1,
  104. MSEL4CR_MSEL22_0, MSEL4CR_MSEL22_1,
  105. MSEL4CR_MSEL21_0, MSEL4CR_MSEL21_1,
  106. MSEL4CR_MSEL20_0, MSEL4CR_MSEL20_1,
  107. MSEL4CR_MSEL19_0, MSEL4CR_MSEL19_1,
  108. MSEL4CR_MSEL15_0, MSEL4CR_MSEL15_1,
  109. MSEL4CR_MSEL13_0, MSEL4CR_MSEL13_1,
  110. MSEL4CR_MSEL12_0, MSEL4CR_MSEL12_1,
  111. MSEL4CR_MSEL11_0, MSEL4CR_MSEL11_1,
  112. MSEL4CR_MSEL10_0, MSEL4CR_MSEL10_1,
  113. MSEL4CR_MSEL9_0, MSEL4CR_MSEL9_1,
  114. MSEL4CR_MSEL8_0, MSEL4CR_MSEL8_1,
  115. MSEL4CR_MSEL7_0, MSEL4CR_MSEL7_1,
  116. MSEL4CR_MSEL4_0, MSEL4CR_MSEL4_1,
  117. MSEL4CR_MSEL1_0, MSEL4CR_MSEL1_1,
  118. PINMUX_FUNCTION_END,
  119. PINMUX_MARK_BEGIN,
  120. /* Hardware manual Table 25-1 (Function 0-7) */
  121. VBUS_0_MARK,
  122. GPI0_MARK,
  123. GPI1_MARK,
  124. GPI2_MARK,
  125. GPI3_MARK,
  126. GPI4_MARK,
  127. GPI5_MARK,
  128. GPI6_MARK,
  129. GPI7_MARK,
  130. SCIFA7_RXD_MARK,
  131. SCIFA7_CTS__MARK,
  132. GPO7_MARK, MFG0_OUT2_MARK,
  133. GPO6_MARK, MFG1_OUT2_MARK,
  134. GPO5_MARK, SCIFA0_SCK_MARK, FSICOSLDT3_MARK, PORT16_VIO_CKOR_MARK,
  135. SCIFA0_TXD_MARK,
  136. SCIFA7_TXD_MARK,
  137. SCIFA7_RTS__MARK, PORT19_VIO_CKO2_MARK,
  138. GPO0_MARK,
  139. GPO1_MARK,
  140. GPO2_MARK, STATUS0_MARK,
  141. GPO3_MARK, STATUS1_MARK,
  142. GPO4_MARK, STATUS2_MARK,
  143. VINT_MARK,
  144. TCKON_MARK,
  145. XDVFS1_MARK, PORT27_I2C_SCL2_MARK, PORT27_I2C_SCL3_MARK, \
  146. MFG0_OUT1_MARK, PORT27_IROUT_MARK,
  147. XDVFS2_MARK, PORT28_I2C_SDA2_MARK, PORT28_I2C_SDA3_MARK, \
  148. PORT28_TPU1TO1_MARK,
  149. SIM_RST_MARK, PORT29_TPU1TO1_MARK,
  150. SIM_CLK_MARK, PORT30_VIO_CKOR_MARK,
  151. SIM_D_MARK, PORT31_IROUT_MARK,
  152. SCIFA4_TXD_MARK,
  153. SCIFA4_RXD_MARK, XWUP_MARK,
  154. SCIFA4_RTS__MARK,
  155. SCIFA4_CTS__MARK,
  156. FSIBOBT_MARK, FSIBIBT_MARK,
  157. FSIBOLR_MARK, FSIBILR_MARK,
  158. FSIBOSLD_MARK,
  159. FSIBISLD_MARK,
  160. VACK_MARK,
  161. XTAL1L_MARK,
  162. SCIFA0_RTS__MARK, FSICOSLDT2_MARK,
  163. SCIFA0_RXD_MARK,
  164. SCIFA0_CTS__MARK, FSICOSLDT1_MARK,
  165. FSICOBT_MARK, FSICIBT_MARK, FSIDOBT_MARK, FSIDIBT_MARK,
  166. FSICOLR_MARK, FSICILR_MARK, FSIDOLR_MARK, FSIDILR_MARK,
  167. FSICOSLD_MARK, PORT47_FSICSPDIF_MARK,
  168. FSICISLD_MARK, FSIDISLD_MARK,
  169. FSIACK_MARK, PORT49_IRDA_OUT_MARK, PORT49_IROUT_MARK, FSIAOMC_MARK,
  170. FSIAOLR_MARK, BBIF2_TSYNC2_MARK, TPU2TO2_MARK, FSIAILR_MARK,
  171. FSIAOBT_MARK, BBIF2_TSCK2_MARK, TPU2TO3_MARK, FSIAIBT_MARK,
  172. FSIAOSLD_MARK, BBIF2_TXD2_MARK,
  173. FSIASPDIF_MARK, PORT53_IRDA_IN_MARK, TPU3TO3_MARK, FSIBSPDIF_MARK, \
  174. PORT53_FSICSPDIF_MARK,
  175. FSIBCK_MARK, PORT54_IRDA_FIRSEL_MARK, TPU3TO2_MARK, FSIBOMC_MARK, \
  176. FSICCK_MARK, FSICOMC_MARK,
  177. FSIAISLD_MARK, TPU0TO0_MARK,
  178. A0_MARK, BS__MARK,
  179. A12_MARK, PORT58_KEYOUT7_MARK, TPU4TO2_MARK,
  180. A13_MARK, PORT59_KEYOUT6_MARK, TPU0TO1_MARK,
  181. A14_MARK, KEYOUT5_MARK,
  182. A15_MARK, KEYOUT4_MARK,
  183. A16_MARK, KEYOUT3_MARK, MSIOF0_SS1_MARK,
  184. A17_MARK, KEYOUT2_MARK, MSIOF0_TSYNC_MARK,
  185. A18_MARK, KEYOUT1_MARK, MSIOF0_TSCK_MARK,
  186. A19_MARK, KEYOUT0_MARK, MSIOF0_TXD_MARK,
  187. A20_MARK, KEYIN0_MARK, MSIOF0_RSCK_MARK,
  188. A21_MARK, KEYIN1_MARK, MSIOF0_RSYNC_MARK,
  189. A22_MARK, KEYIN2_MARK, MSIOF0_MCK0_MARK,
  190. A23_MARK, KEYIN3_MARK, MSIOF0_MCK1_MARK,
  191. A24_MARK, KEYIN4_MARK, MSIOF0_RXD_MARK,
  192. A25_MARK, KEYIN5_MARK, MSIOF0_SS2_MARK,
  193. A26_MARK, KEYIN6_MARK,
  194. KEYIN7_MARK,
  195. D0_NAF0_MARK,
  196. D1_NAF1_MARK,
  197. D2_NAF2_MARK,
  198. D3_NAF3_MARK,
  199. D4_NAF4_MARK,
  200. D5_NAF5_MARK,
  201. D6_NAF6_MARK,
  202. D7_NAF7_MARK,
  203. D8_NAF8_MARK,
  204. D9_NAF9_MARK,
  205. D10_NAF10_MARK,
  206. D11_NAF11_MARK,
  207. D12_NAF12_MARK,
  208. D13_NAF13_MARK,
  209. D14_NAF14_MARK,
  210. D15_NAF15_MARK,
  211. CS4__MARK,
  212. CS5A__MARK, PORT91_RDWR_MARK,
  213. CS5B__MARK, FCE1__MARK,
  214. CS6B__MARK, DACK0_MARK,
  215. FCE0__MARK, CS6A__MARK,
  216. WAIT__MARK, DREQ0_MARK,
  217. RD__FSC_MARK,
  218. WE0__FWE_MARK, RDWR_FWE_MARK,
  219. WE1__MARK,
  220. FRB_MARK,
  221. CKO_MARK,
  222. NBRSTOUT__MARK,
  223. NBRST__MARK,
  224. BBIF2_TXD_MARK,
  225. BBIF2_RXD_MARK,
  226. BBIF2_SYNC_MARK,
  227. BBIF2_SCK_MARK,
  228. SCIFA3_CTS__MARK, MFG3_IN2_MARK,
  229. SCIFA3_RXD_MARK, MFG3_IN1_MARK,
  230. BBIF1_SS2_MARK, SCIFA3_RTS__MARK, MFG3_OUT1_MARK,
  231. SCIFA3_TXD_MARK,
  232. HSI_RX_DATA_MARK, BBIF1_RXD_MARK,
  233. HSI_TX_WAKE_MARK, BBIF1_TSCK_MARK,
  234. HSI_TX_DATA_MARK, BBIF1_TSYNC_MARK,
  235. HSI_TX_READY_MARK, BBIF1_TXD_MARK,
  236. HSI_RX_READY_MARK, BBIF1_RSCK_MARK, PORT115_I2C_SCL2_MARK, \
  237. PORT115_I2C_SCL3_MARK,
  238. HSI_RX_WAKE_MARK, BBIF1_RSYNC_MARK, PORT116_I2C_SDA2_MARK, \
  239. PORT116_I2C_SDA3_MARK,
  240. HSI_RX_FLAG_MARK, BBIF1_SS1_MARK, BBIF1_FLOW_MARK,
  241. HSI_TX_FLAG_MARK,
  242. VIO_VD_MARK, PORT128_LCD2VSYN_MARK, VIO2_VD_MARK, LCD2D0_MARK,
  243. VIO_HD_MARK, PORT129_LCD2HSYN_MARK, PORT129_LCD2CS__MARK, \
  244. VIO2_HD_MARK, LCD2D1_MARK,
  245. VIO_D0_MARK, PORT130_MSIOF2_RXD_MARK, LCD2D10_MARK,
  246. VIO_D1_MARK, PORT131_KEYOUT6_MARK, PORT131_MSIOF2_SS1_MARK, \
  247. PORT131_KEYOUT11_MARK, LCD2D11_MARK,
  248. VIO_D2_MARK, PORT132_KEYOUT7_MARK, PORT132_MSIOF2_SS2_MARK, \
  249. PORT132_KEYOUT10_MARK, LCD2D12_MARK,
  250. VIO_D3_MARK, MSIOF2_TSYNC_MARK, LCD2D13_MARK,
  251. VIO_D4_MARK, MSIOF2_TXD_MARK, LCD2D14_MARK,
  252. VIO_D5_MARK, MSIOF2_TSCK_MARK, LCD2D15_MARK,
  253. VIO_D6_MARK, PORT136_KEYOUT8_MARK, LCD2D16_MARK,
  254. VIO_D7_MARK, PORT137_KEYOUT9_MARK, LCD2D17_MARK,
  255. VIO_D8_MARK, PORT138_KEYOUT8_MARK, VIO2_D0_MARK, LCD2D6_MARK,
  256. VIO_D9_MARK, PORT139_KEYOUT9_MARK, VIO2_D1_MARK, LCD2D7_MARK,
  257. VIO_D10_MARK, TPU0TO2_MARK, VIO2_D2_MARK, LCD2D8_MARK,
  258. VIO_D11_MARK, TPU0TO3_MARK, VIO2_D3_MARK, LCD2D9_MARK,
  259. VIO_D12_MARK, PORT142_KEYOUT10_MARK, VIO2_D4_MARK, LCD2D2_MARK,
  260. VIO_D13_MARK, PORT143_KEYOUT11_MARK, PORT143_KEYOUT6_MARK, \
  261. VIO2_D5_MARK, LCD2D3_MARK,
  262. VIO_D14_MARK, PORT144_KEYOUT7_MARK, VIO2_D6_MARK, LCD2D4_MARK,
  263. VIO_D15_MARK, TPU1TO3_MARK, PORT145_LCD2DISP_MARK, \
  264. PORT145_LCD2RS_MARK, VIO2_D7_MARK, LCD2D5_MARK,
  265. VIO_CLK_MARK, LCD2DCK_MARK, PORT146_LCD2WR__MARK, VIO2_CLK_MARK, \
  266. LCD2D18_MARK,
  267. VIO_FIELD_MARK, LCD2RD__MARK, VIO2_FIELD_MARK, LCD2D19_MARK,
  268. VIO_CKO_MARK,
  269. A27_MARK, PORT149_RDWR_MARK, MFG0_IN1_MARK, PORT149_KEYOUT9_MARK,
  270. MFG0_IN2_MARK,
  271. TS_SPSYNC3_MARK, MSIOF2_RSCK_MARK,
  272. TS_SDAT3_MARK, MSIOF2_RSYNC_MARK,
  273. TPU1TO2_MARK, TS_SDEN3_MARK, PORT153_MSIOF2_SS1_MARK,
  274. SCIFA2_TXD1_MARK, MSIOF2_MCK0_MARK,
  275. SCIFA2_RXD1_MARK, MSIOF2_MCK1_MARK,
  276. SCIFA2_RTS1__MARK, PORT156_MSIOF2_SS2_MARK,
  277. SCIFA2_CTS1__MARK, PORT157_MSIOF2_RXD_MARK,
  278. DINT__MARK, SCIFA2_SCK1_MARK, TS_SCK3_MARK,
  279. PORT159_SCIFB_SCK_MARK, PORT159_SCIFA5_SCK_MARK, NMI_MARK,
  280. PORT160_SCIFB_TXD_MARK, PORT160_SCIFA5_TXD_MARK,
  281. PORT161_SCIFB_CTS__MARK, PORT161_SCIFA5_CTS__MARK,
  282. PORT162_SCIFB_RXD_MARK, PORT162_SCIFA5_RXD_MARK,
  283. PORT163_SCIFB_RTS__MARK, PORT163_SCIFA5_RTS__MARK, TPU3TO0_MARK,
  284. LCDD0_MARK,
  285. LCDD1_MARK, PORT193_SCIFA5_CTS__MARK, BBIF2_TSYNC1_MARK,
  286. LCDD2_MARK, PORT194_SCIFA5_RTS__MARK, BBIF2_TSCK1_MARK,
  287. LCDD3_MARK, PORT195_SCIFA5_RXD_MARK, BBIF2_TXD1_MARK,
  288. LCDD4_MARK, PORT196_SCIFA5_TXD_MARK,
  289. LCDD5_MARK, PORT197_SCIFA5_SCK_MARK, MFG2_OUT2_MARK, TPU2TO1_MARK,
  290. LCDD6_MARK,
  291. LCDD7_MARK, TPU4TO1_MARK, MFG4_OUT2_MARK,
  292. LCDD8_MARK, D16_MARK,
  293. LCDD9_MARK, D17_MARK,
  294. LCDD10_MARK, D18_MARK,
  295. LCDD11_MARK, D19_MARK,
  296. LCDD12_MARK, D20_MARK,
  297. LCDD13_MARK, D21_MARK,
  298. LCDD14_MARK, D22_MARK,
  299. LCDD15_MARK, PORT207_MSIOF0L_SS1_MARK, D23_MARK,
  300. LCDD16_MARK, PORT208_MSIOF0L_SS2_MARK, D24_MARK,
  301. LCDD17_MARK, D25_MARK,
  302. LCDD18_MARK, DREQ2_MARK, PORT210_MSIOF0L_SS1_MARK, D26_MARK,
  303. LCDD19_MARK, PORT211_MSIOF0L_SS2_MARK, D27_MARK,
  304. LCDD20_MARK, TS_SPSYNC1_MARK, MSIOF0L_MCK0_MARK, D28_MARK,
  305. LCDD21_MARK, TS_SDAT1_MARK, MSIOF0L_MCK1_MARK, D29_MARK,
  306. LCDD22_MARK, TS_SDEN1_MARK, MSIOF0L_RSCK_MARK, D30_MARK,
  307. LCDD23_MARK, TS_SCK1_MARK, MSIOF0L_RSYNC_MARK, D31_MARK,
  308. LCDDCK_MARK, LCDWR__MARK,
  309. LCDRD__MARK, DACK2_MARK, PORT217_LCD2RS_MARK, MSIOF0L_TSYNC_MARK, \
  310. VIO2_FIELD3_MARK, PORT217_LCD2DISP_MARK,
  311. LCDHSYN_MARK, LCDCS__MARK, LCDCS2__MARK, DACK3_MARK, \
  312. PORT218_VIO_CKOR_MARK,
  313. LCDDISP_MARK, LCDRS_MARK, PORT219_LCD2WR__MARK, DREQ3_MARK, \
  314. MSIOF0L_TSCK_MARK, VIO2_CLK3_MARK, LCD2DCK_2_MARK,
  315. LCDVSYN_MARK, LCDVSYN2_MARK,
  316. LCDLCLK_MARK, DREQ1_MARK, PORT221_LCD2CS__MARK, PWEN_MARK, \
  317. MSIOF0L_RXD_MARK, VIO2_HD3_MARK, PORT221_LCD2HSYN_MARK,
  318. LCDDON_MARK, LCDDON2_MARK, DACK1_MARK, OVCN_MARK, MSIOF0L_TXD_MARK, \
  319. VIO2_VD3_MARK, PORT222_LCD2VSYN_MARK,
  320. SCIFA1_TXD_MARK, OVCN2_MARK,
  321. EXTLP_MARK, SCIFA1_SCK_MARK, PORT226_VIO_CKO2_MARK,
  322. SCIFA1_RTS__MARK, IDIN_MARK,
  323. SCIFA1_RXD_MARK,
  324. SCIFA1_CTS__MARK, MFG1_IN1_MARK,
  325. MSIOF1_TXD_MARK, SCIFA2_TXD2_MARK,
  326. MSIOF1_TSYNC_MARK, SCIFA2_CTS2__MARK,
  327. MSIOF1_TSCK_MARK, SCIFA2_SCK2_MARK,
  328. MSIOF1_RXD_MARK, SCIFA2_RXD2_MARK,
  329. MSIOF1_RSCK_MARK, SCIFA2_RTS2__MARK, VIO2_CLK2_MARK, LCD2D20_MARK,
  330. MSIOF1_RSYNC_MARK, MFG1_IN2_MARK, VIO2_VD2_MARK, LCD2D21_MARK,
  331. MSIOF1_MCK0_MARK, PORT236_I2C_SDA2_MARK,
  332. MSIOF1_MCK1_MARK, PORT237_I2C_SCL2_MARK,
  333. MSIOF1_SS1_MARK, VIO2_FIELD2_MARK, LCD2D22_MARK,
  334. MSIOF1_SS2_MARK, VIO2_HD2_MARK, LCD2D23_MARK,
  335. SCIFA6_TXD_MARK,
  336. PORT241_IRDA_OUT_MARK, PORT241_IROUT_MARK, MFG4_OUT1_MARK, TPU4TO0_MARK,
  337. PORT242_IRDA_IN_MARK, MFG4_IN2_MARK,
  338. PORT243_IRDA_FIRSEL_MARK, PORT243_VIO_CKO2_MARK,
  339. PORT244_SCIFA5_CTS__MARK, MFG2_IN1_MARK, PORT244_SCIFB_CTS__MARK, \
  340. MSIOF2R_RXD_MARK,
  341. PORT245_SCIFA5_RTS__MARK, MFG2_IN2_MARK, PORT245_SCIFB_RTS__MARK, \
  342. MSIOF2R_TXD_MARK,
  343. PORT246_SCIFA5_RXD_MARK, MFG1_OUT1_MARK, PORT246_SCIFB_RXD_MARK, \
  344. TPU1TO0_MARK,
  345. PORT247_SCIFA5_TXD_MARK, MFG3_OUT2_MARK, PORT247_SCIFB_TXD_MARK, \
  346. TPU3TO1_MARK,
  347. PORT248_SCIFA5_SCK_MARK, MFG2_OUT1_MARK, PORT248_SCIFB_SCK_MARK, \
  348. TPU2TO0_MARK, PORT248_I2C_SCL3_MARK, MSIOF2R_TSCK_MARK,
  349. PORT249_IROUT_MARK, MFG4_IN1_MARK, PORT249_I2C_SDA3_MARK, \
  350. MSIOF2R_TSYNC_MARK,
  351. SDHICLK0_MARK,
  352. SDHICD0_MARK,
  353. SDHID0_0_MARK,
  354. SDHID0_1_MARK,
  355. SDHID0_2_MARK,
  356. SDHID0_3_MARK,
  357. SDHICMD0_MARK,
  358. SDHIWP0_MARK,
  359. SDHICLK1_MARK,
  360. SDHID1_0_MARK, TS_SPSYNC2_MARK,
  361. SDHID1_1_MARK, TS_SDAT2_MARK,
  362. SDHID1_2_MARK, TS_SDEN2_MARK,
  363. SDHID1_3_MARK, TS_SCK2_MARK,
  364. SDHICMD1_MARK,
  365. SDHICLK2_MARK,
  366. SDHID2_0_MARK, TS_SPSYNC4_MARK,
  367. SDHID2_1_MARK, TS_SDAT4_MARK,
  368. SDHID2_2_MARK, TS_SDEN4_MARK,
  369. SDHID2_3_MARK, TS_SCK4_MARK,
  370. SDHICMD2_MARK,
  371. MMCCLK0_MARK,
  372. MMCD0_0_MARK,
  373. MMCD0_1_MARK,
  374. MMCD0_2_MARK,
  375. MMCD0_3_MARK,
  376. MMCD0_4_MARK, TS_SPSYNC5_MARK,
  377. MMCD0_5_MARK, TS_SDAT5_MARK,
  378. MMCD0_6_MARK, TS_SDEN5_MARK,
  379. MMCD0_7_MARK, TS_SCK5_MARK,
  380. MMCCMD0_MARK,
  381. RESETOUTS__MARK, EXTAL2OUT_MARK,
  382. MCP_WAIT__MCP_FRB_MARK,
  383. MCP_CKO_MARK, MMCCLK1_MARK,
  384. MCP_D15_MCP_NAF15_MARK,
  385. MCP_D14_MCP_NAF14_MARK,
  386. MCP_D13_MCP_NAF13_MARK,
  387. MCP_D12_MCP_NAF12_MARK,
  388. MCP_D11_MCP_NAF11_MARK,
  389. MCP_D10_MCP_NAF10_MARK,
  390. MCP_D9_MCP_NAF9_MARK,
  391. MCP_D8_MCP_NAF8_MARK, MMCCMD1_MARK,
  392. MCP_D7_MCP_NAF7_MARK, MMCD1_7_MARK,
  393. MCP_D6_MCP_NAF6_MARK, MMCD1_6_MARK,
  394. MCP_D5_MCP_NAF5_MARK, MMCD1_5_MARK,
  395. MCP_D4_MCP_NAF4_MARK, MMCD1_4_MARK,
  396. MCP_D3_MCP_NAF3_MARK, MMCD1_3_MARK,
  397. MCP_D2_MCP_NAF2_MARK, MMCD1_2_MARK,
  398. MCP_D1_MCP_NAF1_MARK, MMCD1_1_MARK,
  399. MCP_D0_MCP_NAF0_MARK, MMCD1_0_MARK,
  400. MCP_NBRSTOUT__MARK,
  401. MCP_WE0__MCP_FWE_MARK, MCP_RDWR_MCP_FWE_MARK,
  402. /* MSEL2 special cases */
  403. TSIF2_TS_XX1_MARK,
  404. TSIF2_TS_XX2_MARK,
  405. TSIF2_TS_XX3_MARK,
  406. TSIF2_TS_XX4_MARK,
  407. TSIF2_TS_XX5_MARK,
  408. TSIF1_TS_XX1_MARK,
  409. TSIF1_TS_XX2_MARK,
  410. TSIF1_TS_XX3_MARK,
  411. TSIF1_TS_XX4_MARK,
  412. TSIF1_TS_XX5_MARK,
  413. TSIF0_TS_XX1_MARK,
  414. TSIF0_TS_XX2_MARK,
  415. TSIF0_TS_XX3_MARK,
  416. TSIF0_TS_XX4_MARK,
  417. TSIF0_TS_XX5_MARK,
  418. MST1_TS_XX1_MARK,
  419. MST1_TS_XX2_MARK,
  420. MST1_TS_XX3_MARK,
  421. MST1_TS_XX4_MARK,
  422. MST1_TS_XX5_MARK,
  423. MST0_TS_XX1_MARK,
  424. MST0_TS_XX2_MARK,
  425. MST0_TS_XX3_MARK,
  426. MST0_TS_XX4_MARK,
  427. MST0_TS_XX5_MARK,
  428. /* MSEL3 special cases */
  429. SDHI0_VCCQ_MC0_ON_MARK,
  430. SDHI0_VCCQ_MC0_OFF_MARK,
  431. DEBUG_MON_VIO_MARK,
  432. DEBUG_MON_LCDD_MARK,
  433. LCDC_LCDC0_MARK,
  434. LCDC_LCDC1_MARK,
  435. /* MSEL4 special cases */
  436. IRQ9_MEM_INT_MARK,
  437. IRQ9_MCP_INT_MARK,
  438. A11_MARK,
  439. KEYOUT8_MARK,
  440. TPU4TO3_MARK,
  441. RESETA_N_PU_ON_MARK,
  442. RESETA_N_PU_OFF_MARK,
  443. EDBGREQ_PD_MARK,
  444. EDBGREQ_PU_MARK,
  445. PINMUX_MARK_END,
  446. };
  447. #define _PORT_DATA(pfx, sfx) PORT_DATA_IO(pfx)
  448. #define PINMUX_DATA_GP_ALL() CPU_ALL_PORT(_PORT_DATA, , unused)
  449. static const pinmux_enum_t pinmux_data[] = {
  450. /* specify valid pin states for each pin in GPIO mode */
  451. PINMUX_DATA_GP_ALL(),
  452. /* Table 25-1 (Function 0-7) */
  453. PINMUX_DATA(VBUS_0_MARK, PORT0_FN1),
  454. PINMUX_DATA(GPI0_MARK, PORT1_FN1),
  455. PINMUX_DATA(GPI1_MARK, PORT2_FN1),
  456. PINMUX_DATA(GPI2_MARK, PORT3_FN1),
  457. PINMUX_DATA(GPI3_MARK, PORT4_FN1),
  458. PINMUX_DATA(GPI4_MARK, PORT5_FN1),
  459. PINMUX_DATA(GPI5_MARK, PORT6_FN1),
  460. PINMUX_DATA(GPI6_MARK, PORT7_FN1),
  461. PINMUX_DATA(GPI7_MARK, PORT8_FN1),
  462. PINMUX_DATA(SCIFA7_RXD_MARK, PORT12_FN2),
  463. PINMUX_DATA(SCIFA7_CTS__MARK, PORT13_FN2),
  464. PINMUX_DATA(GPO7_MARK, PORT14_FN1), \
  465. PINMUX_DATA(MFG0_OUT2_MARK, PORT14_FN4),
  466. PINMUX_DATA(GPO6_MARK, PORT15_FN1), \
  467. PINMUX_DATA(MFG1_OUT2_MARK, PORT15_FN4),
  468. PINMUX_DATA(GPO5_MARK, PORT16_FN1), \
  469. PINMUX_DATA(SCIFA0_SCK_MARK, PORT16_FN2), \
  470. PINMUX_DATA(FSICOSLDT3_MARK, PORT16_FN3), \
  471. PINMUX_DATA(PORT16_VIO_CKOR_MARK, PORT16_FN4),
  472. PINMUX_DATA(SCIFA0_TXD_MARK, PORT17_FN2),
  473. PINMUX_DATA(SCIFA7_TXD_MARK, PORT18_FN2),
  474. PINMUX_DATA(SCIFA7_RTS__MARK, PORT19_FN2), \
  475. PINMUX_DATA(PORT19_VIO_CKO2_MARK, PORT19_FN3),
  476. PINMUX_DATA(GPO0_MARK, PORT20_FN1),
  477. PINMUX_DATA(GPO1_MARK, PORT21_FN1),
  478. PINMUX_DATA(GPO2_MARK, PORT22_FN1), \
  479. PINMUX_DATA(STATUS0_MARK, PORT22_FN2),
  480. PINMUX_DATA(GPO3_MARK, PORT23_FN1), \
  481. PINMUX_DATA(STATUS1_MARK, PORT23_FN2),
  482. PINMUX_DATA(GPO4_MARK, PORT24_FN1), \
  483. PINMUX_DATA(STATUS2_MARK, PORT24_FN2),
  484. PINMUX_DATA(VINT_MARK, PORT25_FN1),
  485. PINMUX_DATA(TCKON_MARK, PORT26_FN1),
  486. PINMUX_DATA(XDVFS1_MARK, PORT27_FN1), \
  487. PINMUX_DATA(PORT27_I2C_SCL2_MARK, PORT27_FN2, MSEL2CR_MSEL17_0,
  488. MSEL2CR_MSEL16_1), \
  489. PINMUX_DATA(PORT27_I2C_SCL3_MARK, PORT27_FN3, MSEL2CR_MSEL19_0,
  490. MSEL2CR_MSEL18_1), \
  491. PINMUX_DATA(MFG0_OUT1_MARK, PORT27_FN4), \
  492. PINMUX_DATA(PORT27_IROUT_MARK, PORT27_FN7),
  493. PINMUX_DATA(XDVFS2_MARK, PORT28_FN1), \
  494. PINMUX_DATA(PORT28_I2C_SDA2_MARK, PORT28_FN2, MSEL2CR_MSEL17_0,
  495. MSEL2CR_MSEL16_1), \
  496. PINMUX_DATA(PORT28_I2C_SDA3_MARK, PORT28_FN3, MSEL2CR_MSEL19_0,
  497. MSEL2CR_MSEL18_1), \
  498. PINMUX_DATA(PORT28_TPU1TO1_MARK, PORT28_FN7),
  499. PINMUX_DATA(SIM_RST_MARK, PORT29_FN1), \
  500. PINMUX_DATA(PORT29_TPU1TO1_MARK, PORT29_FN4),
  501. PINMUX_DATA(SIM_CLK_MARK, PORT30_FN1), \
  502. PINMUX_DATA(PORT30_VIO_CKOR_MARK, PORT30_FN4),
  503. PINMUX_DATA(SIM_D_MARK, PORT31_FN1), \
  504. PINMUX_DATA(PORT31_IROUT_MARK, PORT31_FN4),
  505. PINMUX_DATA(SCIFA4_TXD_MARK, PORT32_FN2),
  506. PINMUX_DATA(SCIFA4_RXD_MARK, PORT33_FN2), \
  507. PINMUX_DATA(XWUP_MARK, PORT33_FN3),
  508. PINMUX_DATA(SCIFA4_RTS__MARK, PORT34_FN2),
  509. PINMUX_DATA(SCIFA4_CTS__MARK, PORT35_FN2),
  510. PINMUX_DATA(FSIBOBT_MARK, PORT36_FN1), \
  511. PINMUX_DATA(FSIBIBT_MARK, PORT36_FN2),
  512. PINMUX_DATA(FSIBOLR_MARK, PORT37_FN1), \
  513. PINMUX_DATA(FSIBILR_MARK, PORT37_FN2),
  514. PINMUX_DATA(FSIBOSLD_MARK, PORT38_FN1),
  515. PINMUX_DATA(FSIBISLD_MARK, PORT39_FN1),
  516. PINMUX_DATA(VACK_MARK, PORT40_FN1),
  517. PINMUX_DATA(XTAL1L_MARK, PORT41_FN1),
  518. PINMUX_DATA(SCIFA0_RTS__MARK, PORT42_FN2), \
  519. PINMUX_DATA(FSICOSLDT2_MARK, PORT42_FN3),
  520. PINMUX_DATA(SCIFA0_RXD_MARK, PORT43_FN2),
  521. PINMUX_DATA(SCIFA0_CTS__MARK, PORT44_FN2), \
  522. PINMUX_DATA(FSICOSLDT1_MARK, PORT44_FN3),
  523. PINMUX_DATA(FSICOBT_MARK, PORT45_FN1), \
  524. PINMUX_DATA(FSICIBT_MARK, PORT45_FN2), \
  525. PINMUX_DATA(FSIDOBT_MARK, PORT45_FN3), \
  526. PINMUX_DATA(FSIDIBT_MARK, PORT45_FN4),
  527. PINMUX_DATA(FSICOLR_MARK, PORT46_FN1), \
  528. PINMUX_DATA(FSICILR_MARK, PORT46_FN2), \
  529. PINMUX_DATA(FSIDOLR_MARK, PORT46_FN3), \
  530. PINMUX_DATA(FSIDILR_MARK, PORT46_FN4),
  531. PINMUX_DATA(FSICOSLD_MARK, PORT47_FN1), \
  532. PINMUX_DATA(PORT47_FSICSPDIF_MARK, PORT47_FN2),
  533. PINMUX_DATA(FSICISLD_MARK, PORT48_FN1), \
  534. PINMUX_DATA(FSIDISLD_MARK, PORT48_FN3),
  535. PINMUX_DATA(FSIACK_MARK, PORT49_FN1), \
  536. PINMUX_DATA(PORT49_IRDA_OUT_MARK, PORT49_FN2, MSEL4CR_MSEL19_1), \
  537. PINMUX_DATA(PORT49_IROUT_MARK, PORT49_FN4), \
  538. PINMUX_DATA(FSIAOMC_MARK, PORT49_FN5),
  539. PINMUX_DATA(FSIAOLR_MARK, PORT50_FN1), \
  540. PINMUX_DATA(BBIF2_TSYNC2_MARK, PORT50_FN2), \
  541. PINMUX_DATA(TPU2TO2_MARK, PORT50_FN3), \
  542. PINMUX_DATA(FSIAILR_MARK, PORT50_FN5),
  543. PINMUX_DATA(FSIAOBT_MARK, PORT51_FN1), \
  544. PINMUX_DATA(BBIF2_TSCK2_MARK, PORT51_FN2), \
  545. PINMUX_DATA(TPU2TO3_MARK, PORT51_FN3), \
  546. PINMUX_DATA(FSIAIBT_MARK, PORT51_FN5),
  547. PINMUX_DATA(FSIAOSLD_MARK, PORT52_FN1), \
  548. PINMUX_DATA(BBIF2_TXD2_MARK, PORT52_FN2),
  549. PINMUX_DATA(FSIASPDIF_MARK, PORT53_FN1), \
  550. PINMUX_DATA(PORT53_IRDA_IN_MARK, PORT53_FN2, MSEL4CR_MSEL19_1), \
  551. PINMUX_DATA(TPU3TO3_MARK, PORT53_FN3), \
  552. PINMUX_DATA(FSIBSPDIF_MARK, PORT53_FN5), \
  553. PINMUX_DATA(PORT53_FSICSPDIF_MARK, PORT53_FN6),
  554. PINMUX_DATA(FSIBCK_MARK, PORT54_FN1), \
  555. PINMUX_DATA(PORT54_IRDA_FIRSEL_MARK, PORT54_FN2, MSEL4CR_MSEL19_1), \
  556. PINMUX_DATA(TPU3TO2_MARK, PORT54_FN3), \
  557. PINMUX_DATA(FSIBOMC_MARK, PORT54_FN5), \
  558. PINMUX_DATA(FSICCK_MARK, PORT54_FN6), \
  559. PINMUX_DATA(FSICOMC_MARK, PORT54_FN7),
  560. PINMUX_DATA(FSIAISLD_MARK, PORT55_FN1), \
  561. PINMUX_DATA(TPU0TO0_MARK, PORT55_FN3),
  562. PINMUX_DATA(A0_MARK, PORT57_FN1), \
  563. PINMUX_DATA(BS__MARK, PORT57_FN2),
  564. PINMUX_DATA(A12_MARK, PORT58_FN1), \
  565. PINMUX_DATA(PORT58_KEYOUT7_MARK, PORT58_FN2), \
  566. PINMUX_DATA(TPU4TO2_MARK, PORT58_FN4),
  567. PINMUX_DATA(A13_MARK, PORT59_FN1), \
  568. PINMUX_DATA(PORT59_KEYOUT6_MARK, PORT59_FN2), \
  569. PINMUX_DATA(TPU0TO1_MARK, PORT59_FN4),
  570. PINMUX_DATA(A14_MARK, PORT60_FN1), \
  571. PINMUX_DATA(KEYOUT5_MARK, PORT60_FN2),
  572. PINMUX_DATA(A15_MARK, PORT61_FN1), \
  573. PINMUX_DATA(KEYOUT4_MARK, PORT61_FN2),
  574. PINMUX_DATA(A16_MARK, PORT62_FN1), \
  575. PINMUX_DATA(KEYOUT3_MARK, PORT62_FN2), \
  576. PINMUX_DATA(MSIOF0_SS1_MARK, PORT62_FN4, MSEL3CR_MSEL11_0),
  577. PINMUX_DATA(A17_MARK, PORT63_FN1), \
  578. PINMUX_DATA(KEYOUT2_MARK, PORT63_FN2), \
  579. PINMUX_DATA(MSIOF0_TSYNC_MARK, PORT63_FN4, MSEL3CR_MSEL11_0),
  580. PINMUX_DATA(A18_MARK, PORT64_FN1), \
  581. PINMUX_DATA(KEYOUT1_MARK, PORT64_FN2), \
  582. PINMUX_DATA(MSIOF0_TSCK_MARK, PORT64_FN4, MSEL3CR_MSEL11_0),
  583. PINMUX_DATA(A19_MARK, PORT65_FN1), \
  584. PINMUX_DATA(KEYOUT0_MARK, PORT65_FN2), \
  585. PINMUX_DATA(MSIOF0_TXD_MARK, PORT65_FN4, MSEL3CR_MSEL11_0),
  586. PINMUX_DATA(A20_MARK, PORT66_FN1), \
  587. PINMUX_DATA(KEYIN0_MARK, PORT66_FN2), \
  588. PINMUX_DATA(MSIOF0_RSCK_MARK, PORT66_FN4, MSEL3CR_MSEL11_0),
  589. PINMUX_DATA(A21_MARK, PORT67_FN1), \
  590. PINMUX_DATA(KEYIN1_MARK, PORT67_FN2), \
  591. PINMUX_DATA(MSIOF0_RSYNC_MARK, PORT67_FN4, MSEL3CR_MSEL11_0),
  592. PINMUX_DATA(A22_MARK, PORT68_FN1), \
  593. PINMUX_DATA(KEYIN2_MARK, PORT68_FN2), \
  594. PINMUX_DATA(MSIOF0_MCK0_MARK, PORT68_FN4, MSEL3CR_MSEL11_0),
  595. PINMUX_DATA(A23_MARK, PORT69_FN1), \
  596. PINMUX_DATA(KEYIN3_MARK, PORT69_FN2), \
  597. PINMUX_DATA(MSIOF0_MCK1_MARK, PORT69_FN4, MSEL3CR_MSEL11_0),
  598. PINMUX_DATA(A24_MARK, PORT70_FN1), \
  599. PINMUX_DATA(KEYIN4_MARK, PORT70_FN2), \
  600. PINMUX_DATA(MSIOF0_RXD_MARK, PORT70_FN4, MSEL3CR_MSEL11_0),
  601. PINMUX_DATA(A25_MARK, PORT71_FN1), \
  602. PINMUX_DATA(KEYIN5_MARK, PORT71_FN2), \
  603. PINMUX_DATA(MSIOF0_SS2_MARK, PORT71_FN4, MSEL3CR_MSEL11_0),
  604. PINMUX_DATA(A26_MARK, PORT72_FN1), \
  605. PINMUX_DATA(KEYIN6_MARK, PORT72_FN2),
  606. PINMUX_DATA(KEYIN7_MARK, PORT73_FN2),
  607. PINMUX_DATA(D0_NAF0_MARK, PORT74_FN1),
  608. PINMUX_DATA(D1_NAF1_MARK, PORT75_FN1),
  609. PINMUX_DATA(D2_NAF2_MARK, PORT76_FN1),
  610. PINMUX_DATA(D3_NAF3_MARK, PORT77_FN1),
  611. PINMUX_DATA(D4_NAF4_MARK, PORT78_FN1),
  612. PINMUX_DATA(D5_NAF5_MARK, PORT79_FN1),
  613. PINMUX_DATA(D6_NAF6_MARK, PORT80_FN1),
  614. PINMUX_DATA(D7_NAF7_MARK, PORT81_FN1),
  615. PINMUX_DATA(D8_NAF8_MARK, PORT82_FN1),
  616. PINMUX_DATA(D9_NAF9_MARK, PORT83_FN1),
  617. PINMUX_DATA(D10_NAF10_MARK, PORT84_FN1),
  618. PINMUX_DATA(D11_NAF11_MARK, PORT85_FN1),
  619. PINMUX_DATA(D12_NAF12_MARK, PORT86_FN1),
  620. PINMUX_DATA(D13_NAF13_MARK, PORT87_FN1),
  621. PINMUX_DATA(D14_NAF14_MARK, PORT88_FN1),
  622. PINMUX_DATA(D15_NAF15_MARK, PORT89_FN1),
  623. PINMUX_DATA(CS4__MARK, PORT90_FN1),
  624. PINMUX_DATA(CS5A__MARK, PORT91_FN1), \
  625. PINMUX_DATA(PORT91_RDWR_MARK, PORT91_FN2),
  626. PINMUX_DATA(CS5B__MARK, PORT92_FN1), \
  627. PINMUX_DATA(FCE1__MARK, PORT92_FN2),
  628. PINMUX_DATA(CS6B__MARK, PORT93_FN1), \
  629. PINMUX_DATA(DACK0_MARK, PORT93_FN4),
  630. PINMUX_DATA(FCE0__MARK, PORT94_FN1), \
  631. PINMUX_DATA(CS6A__MARK, PORT94_FN2),
  632. PINMUX_DATA(WAIT__MARK, PORT95_FN1), \
  633. PINMUX_DATA(DREQ0_MARK, PORT95_FN2),
  634. PINMUX_DATA(RD__FSC_MARK, PORT96_FN1),
  635. PINMUX_DATA(WE0__FWE_MARK, PORT97_FN1), \
  636. PINMUX_DATA(RDWR_FWE_MARK, PORT97_FN2),
  637. PINMUX_DATA(WE1__MARK, PORT98_FN1),
  638. PINMUX_DATA(FRB_MARK, PORT99_FN1),
  639. PINMUX_DATA(CKO_MARK, PORT100_FN1),
  640. PINMUX_DATA(NBRSTOUT__MARK, PORT101_FN1),
  641. PINMUX_DATA(NBRST__MARK, PORT102_FN1),
  642. PINMUX_DATA(BBIF2_TXD_MARK, PORT103_FN3),
  643. PINMUX_DATA(BBIF2_RXD_MARK, PORT104_FN3),
  644. PINMUX_DATA(BBIF2_SYNC_MARK, PORT105_FN3),
  645. PINMUX_DATA(BBIF2_SCK_MARK, PORT106_FN3),
  646. PINMUX_DATA(SCIFA3_CTS__MARK, PORT107_FN3), \
  647. PINMUX_DATA(MFG3_IN2_MARK, PORT107_FN4),
  648. PINMUX_DATA(SCIFA3_RXD_MARK, PORT108_FN3), \
  649. PINMUX_DATA(MFG3_IN1_MARK, PORT108_FN4),
  650. PINMUX_DATA(BBIF1_SS2_MARK, PORT109_FN2), \
  651. PINMUX_DATA(SCIFA3_RTS__MARK, PORT109_FN3), \
  652. PINMUX_DATA(MFG3_OUT1_MARK, PORT109_FN4),
  653. PINMUX_DATA(SCIFA3_TXD_MARK, PORT110_FN3),
  654. PINMUX_DATA(HSI_RX_DATA_MARK, PORT111_FN1), \
  655. PINMUX_DATA(BBIF1_RXD_MARK, PORT111_FN3),
  656. PINMUX_DATA(HSI_TX_WAKE_MARK, PORT112_FN1), \
  657. PINMUX_DATA(BBIF1_TSCK_MARK, PORT112_FN3),
  658. PINMUX_DATA(HSI_TX_DATA_MARK, PORT113_FN1), \
  659. PINMUX_DATA(BBIF1_TSYNC_MARK, PORT113_FN3),
  660. PINMUX_DATA(HSI_TX_READY_MARK, PORT114_FN1), \
  661. PINMUX_DATA(BBIF1_TXD_MARK, PORT114_FN3),
  662. PINMUX_DATA(HSI_RX_READY_MARK, PORT115_FN1), \
  663. PINMUX_DATA(BBIF1_RSCK_MARK, PORT115_FN3), \
  664. PINMUX_DATA(PORT115_I2C_SCL2_MARK, PORT115_FN5, MSEL2CR_MSEL17_1), \
  665. PINMUX_DATA(PORT115_I2C_SCL3_MARK, PORT115_FN6, MSEL2CR_MSEL19_1),
  666. PINMUX_DATA(HSI_RX_WAKE_MARK, PORT116_FN1), \
  667. PINMUX_DATA(BBIF1_RSYNC_MARK, PORT116_FN3), \
  668. PINMUX_DATA(PORT116_I2C_SDA2_MARK, PORT116_FN5, MSEL2CR_MSEL17_1), \
  669. PINMUX_DATA(PORT116_I2C_SDA3_MARK, PORT116_FN6, MSEL2CR_MSEL19_1),
  670. PINMUX_DATA(HSI_RX_FLAG_MARK, PORT117_FN1), \
  671. PINMUX_DATA(BBIF1_SS1_MARK, PORT117_FN2), \
  672. PINMUX_DATA(BBIF1_FLOW_MARK, PORT117_FN3),
  673. PINMUX_DATA(HSI_TX_FLAG_MARK, PORT118_FN1),
  674. PINMUX_DATA(VIO_VD_MARK, PORT128_FN1), \
  675. PINMUX_DATA(PORT128_LCD2VSYN_MARK, PORT128_FN4, MSEL3CR_MSEL2_0), \
  676. PINMUX_DATA(VIO2_VD_MARK, PORT128_FN6, MSEL4CR_MSEL27_0), \
  677. PINMUX_DATA(LCD2D0_MARK, PORT128_FN7),
  678. PINMUX_DATA(VIO_HD_MARK, PORT129_FN1), \
  679. PINMUX_DATA(PORT129_LCD2HSYN_MARK, PORT129_FN4), \
  680. PINMUX_DATA(PORT129_LCD2CS__MARK, PORT129_FN5), \
  681. PINMUX_DATA(VIO2_HD_MARK, PORT129_FN6, MSEL4CR_MSEL27_0), \
  682. PINMUX_DATA(LCD2D1_MARK, PORT129_FN7),
  683. PINMUX_DATA(VIO_D0_MARK, PORT130_FN1), \
  684. PINMUX_DATA(PORT130_MSIOF2_RXD_MARK, PORT130_FN3, MSEL4CR_MSEL11_0,
  685. MSEL4CR_MSEL10_1), \
  686. PINMUX_DATA(LCD2D10_MARK, PORT130_FN7),
  687. PINMUX_DATA(VIO_D1_MARK, PORT131_FN1), \
  688. PINMUX_DATA(PORT131_KEYOUT6_MARK, PORT131_FN2), \
  689. PINMUX_DATA(PORT131_MSIOF2_SS1_MARK, PORT131_FN3), \
  690. PINMUX_DATA(PORT131_KEYOUT11_MARK, PORT131_FN4), \
  691. PINMUX_DATA(LCD2D11_MARK, PORT131_FN7),
  692. PINMUX_DATA(VIO_D2_MARK, PORT132_FN1), \
  693. PINMUX_DATA(PORT132_KEYOUT7_MARK, PORT132_FN2), \
  694. PINMUX_DATA(PORT132_MSIOF2_SS2_MARK, PORT132_FN3), \
  695. PINMUX_DATA(PORT132_KEYOUT10_MARK, PORT132_FN4), \
  696. PINMUX_DATA(LCD2D12_MARK, PORT132_FN7),
  697. PINMUX_DATA(VIO_D3_MARK, PORT133_FN1), \
  698. PINMUX_DATA(MSIOF2_TSYNC_MARK, PORT133_FN3, MSEL4CR_MSEL11_0), \
  699. PINMUX_DATA(LCD2D13_MARK, PORT133_FN7),
  700. PINMUX_DATA(VIO_D4_MARK, PORT134_FN1), \
  701. PINMUX_DATA(MSIOF2_TXD_MARK, PORT134_FN3, MSEL4CR_MSEL11_0), \
  702. PINMUX_DATA(LCD2D14_MARK, PORT134_FN7),
  703. PINMUX_DATA(VIO_D5_MARK, PORT135_FN1), \
  704. PINMUX_DATA(MSIOF2_TSCK_MARK, PORT135_FN3, MSEL4CR_MSEL11_0), \
  705. PINMUX_DATA(LCD2D15_MARK, PORT135_FN7),
  706. PINMUX_DATA(VIO_D6_MARK, PORT136_FN1), \
  707. PINMUX_DATA(PORT136_KEYOUT8_MARK, PORT136_FN2), \
  708. PINMUX_DATA(LCD2D16_MARK, PORT136_FN7),
  709. PINMUX_DATA(VIO_D7_MARK, PORT137_FN1), \
  710. PINMUX_DATA(PORT137_KEYOUT9_MARK, PORT137_FN2), \
  711. PINMUX_DATA(LCD2D17_MARK, PORT137_FN7),
  712. PINMUX_DATA(VIO_D8_MARK, PORT138_FN1), \
  713. PINMUX_DATA(PORT138_KEYOUT8_MARK, PORT138_FN2), \
  714. PINMUX_DATA(VIO2_D0_MARK, PORT138_FN6), \
  715. PINMUX_DATA(LCD2D6_MARK, PORT138_FN7),
  716. PINMUX_DATA(VIO_D9_MARK, PORT139_FN1), \
  717. PINMUX_DATA(PORT139_KEYOUT9_MARK, PORT139_FN2), \
  718. PINMUX_DATA(VIO2_D1_MARK, PORT139_FN6), \
  719. PINMUX_DATA(LCD2D7_MARK, PORT139_FN7),
  720. PINMUX_DATA(VIO_D10_MARK, PORT140_FN1), \
  721. PINMUX_DATA(TPU0TO2_MARK, PORT140_FN4), \
  722. PINMUX_DATA(VIO2_D2_MARK, PORT140_FN6), \
  723. PINMUX_DATA(LCD2D8_MARK, PORT140_FN7),
  724. PINMUX_DATA(VIO_D11_MARK, PORT141_FN1), \
  725. PINMUX_DATA(TPU0TO3_MARK, PORT141_FN4), \
  726. PINMUX_DATA(VIO2_D3_MARK, PORT141_FN6), \
  727. PINMUX_DATA(LCD2D9_MARK, PORT141_FN7),
  728. PINMUX_DATA(VIO_D12_MARK, PORT142_FN1), \
  729. PINMUX_DATA(PORT142_KEYOUT10_MARK, PORT142_FN2), \
  730. PINMUX_DATA(VIO2_D4_MARK, PORT142_FN6), \
  731. PINMUX_DATA(LCD2D2_MARK, PORT142_FN7),
  732. PINMUX_DATA(VIO_D13_MARK, PORT143_FN1), \
  733. PINMUX_DATA(PORT143_KEYOUT11_MARK, PORT143_FN2), \
  734. PINMUX_DATA(PORT143_KEYOUT6_MARK, PORT143_FN3), \
  735. PINMUX_DATA(VIO2_D5_MARK, PORT143_FN6), \
  736. PINMUX_DATA(LCD2D3_MARK, PORT143_FN7),
  737. PINMUX_DATA(VIO_D14_MARK, PORT144_FN1), \
  738. PINMUX_DATA(PORT144_KEYOUT7_MARK, PORT144_FN2), \
  739. PINMUX_DATA(VIO2_D6_MARK, PORT144_FN6), \
  740. PINMUX_DATA(LCD2D4_MARK, PORT144_FN7),
  741. PINMUX_DATA(VIO_D15_MARK, PORT145_FN1), \
  742. PINMUX_DATA(TPU1TO3_MARK, PORT145_FN3), \
  743. PINMUX_DATA(PORT145_LCD2DISP_MARK, PORT145_FN4), \
  744. PINMUX_DATA(PORT145_LCD2RS_MARK, PORT145_FN5), \
  745. PINMUX_DATA(VIO2_D7_MARK, PORT145_FN6), \
  746. PINMUX_DATA(LCD2D5_MARK, PORT145_FN7),
  747. PINMUX_DATA(VIO_CLK_MARK, PORT146_FN1), \
  748. PINMUX_DATA(LCD2DCK_MARK, PORT146_FN4), \
  749. PINMUX_DATA(PORT146_LCD2WR__MARK, PORT146_FN5), \
  750. PINMUX_DATA(VIO2_CLK_MARK, PORT146_FN6, MSEL4CR_MSEL27_0), \
  751. PINMUX_DATA(LCD2D18_MARK, PORT146_FN7),
  752. PINMUX_DATA(VIO_FIELD_MARK, PORT147_FN1), \
  753. PINMUX_DATA(LCD2RD__MARK, PORT147_FN4), \
  754. PINMUX_DATA(VIO2_FIELD_MARK, PORT147_FN6, MSEL4CR_MSEL27_0), \
  755. PINMUX_DATA(LCD2D19_MARK, PORT147_FN7),
  756. PINMUX_DATA(VIO_CKO_MARK, PORT148_FN1),
  757. PINMUX_DATA(A27_MARK, PORT149_FN1), \
  758. PINMUX_DATA(PORT149_RDWR_MARK, PORT149_FN2), \
  759. PINMUX_DATA(MFG0_IN1_MARK, PORT149_FN3), \
  760. PINMUX_DATA(PORT149_KEYOUT9_MARK, PORT149_FN4),
  761. PINMUX_DATA(MFG0_IN2_MARK, PORT150_FN3),
  762. PINMUX_DATA(TS_SPSYNC3_MARK, PORT151_FN4), \
  763. PINMUX_DATA(MSIOF2_RSCK_MARK, PORT151_FN5),
  764. PINMUX_DATA(TS_SDAT3_MARK, PORT152_FN4), \
  765. PINMUX_DATA(MSIOF2_RSYNC_MARK, PORT152_FN5),
  766. PINMUX_DATA(TPU1TO2_MARK, PORT153_FN3), \
  767. PINMUX_DATA(TS_SDEN3_MARK, PORT153_FN4), \
  768. PINMUX_DATA(PORT153_MSIOF2_SS1_MARK, PORT153_FN5),
  769. PINMUX_DATA(SCIFA2_TXD1_MARK, PORT154_FN2, MSEL3CR_MSEL9_0), \
  770. PINMUX_DATA(MSIOF2_MCK0_MARK, PORT154_FN5),
  771. PINMUX_DATA(SCIFA2_RXD1_MARK, PORT155_FN2, MSEL3CR_MSEL9_0), \
  772. PINMUX_DATA(MSIOF2_MCK1_MARK, PORT155_FN5),
  773. PINMUX_DATA(SCIFA2_RTS1__MARK, PORT156_FN2, MSEL3CR_MSEL9_0), \
  774. PINMUX_DATA(PORT156_MSIOF2_SS2_MARK, PORT156_FN5),
  775. PINMUX_DATA(SCIFA2_CTS1__MARK, PORT157_FN2, MSEL3CR_MSEL9_0), \
  776. PINMUX_DATA(PORT157_MSIOF2_RXD_MARK, PORT157_FN5, MSEL4CR_MSEL11_0,
  777. MSEL4CR_MSEL10_0),
  778. PINMUX_DATA(DINT__MARK, PORT158_FN1), \
  779. PINMUX_DATA(SCIFA2_SCK1_MARK, PORT158_FN2, MSEL3CR_MSEL9_0), \
  780. PINMUX_DATA(TS_SCK3_MARK, PORT158_FN4),
  781. PINMUX_DATA(PORT159_SCIFB_SCK_MARK, PORT159_FN1, MSEL4CR_MSEL22_0), \
  782. PINMUX_DATA(PORT159_SCIFA5_SCK_MARK, PORT159_FN2, MSEL4CR_MSEL21_1), \
  783. PINMUX_DATA(NMI_MARK, PORT159_FN3),
  784. PINMUX_DATA(PORT160_SCIFB_TXD_MARK, PORT160_FN1, MSEL4CR_MSEL22_0), \
  785. PINMUX_DATA(PORT160_SCIFA5_TXD_MARK, PORT160_FN2, MSEL4CR_MSEL21_1),
  786. PINMUX_DATA(PORT161_SCIFB_CTS__MARK, PORT161_FN1, MSEL4CR_MSEL22_0), \
  787. PINMUX_DATA(PORT161_SCIFA5_CTS__MARK, PORT161_FN2, MSEL4CR_MSEL21_1),
  788. PINMUX_DATA(PORT162_SCIFB_RXD_MARK, PORT162_FN1, MSEL4CR_MSEL22_0), \
  789. PINMUX_DATA(PORT162_SCIFA5_RXD_MARK, PORT162_FN2, MSEL4CR_MSEL21_1),
  790. PINMUX_DATA(PORT163_SCIFB_RTS__MARK, PORT163_FN1, MSEL4CR_MSEL22_0), \
  791. PINMUX_DATA(PORT163_SCIFA5_RTS__MARK, PORT163_FN2, MSEL4CR_MSEL21_1), \
  792. PINMUX_DATA(TPU3TO0_MARK, PORT163_FN5),
  793. PINMUX_DATA(LCDD0_MARK, PORT192_FN1),
  794. PINMUX_DATA(LCDD1_MARK, PORT193_FN1), \
  795. PINMUX_DATA(PORT193_SCIFA5_CTS__MARK, PORT193_FN3, MSEL4CR_MSEL21_0,
  796. MSEL4CR_MSEL20_1), \
  797. PINMUX_DATA(BBIF2_TSYNC1_MARK, PORT193_FN5),
  798. PINMUX_DATA(LCDD2_MARK, PORT194_FN1), \
  799. PINMUX_DATA(PORT194_SCIFA5_RTS__MARK, PORT194_FN3, MSEL4CR_MSEL21_0,
  800. MSEL4CR_MSEL20_1), \
  801. PINMUX_DATA(BBIF2_TSCK1_MARK, PORT194_FN5),
  802. PINMUX_DATA(LCDD3_MARK, PORT195_FN1), \
  803. PINMUX_DATA(PORT195_SCIFA5_RXD_MARK, PORT195_FN3, MSEL4CR_MSEL21_0,
  804. MSEL4CR_MSEL20_1), \
  805. PINMUX_DATA(BBIF2_TXD1_MARK, PORT195_FN5),
  806. PINMUX_DATA(LCDD4_MARK, PORT196_FN1), \
  807. PINMUX_DATA(PORT196_SCIFA5_TXD_MARK, PORT196_FN3, MSEL4CR_MSEL21_0,
  808. MSEL4CR_MSEL20_1),
  809. PINMUX_DATA(LCDD5_MARK, PORT197_FN1), \
  810. PINMUX_DATA(PORT197_SCIFA5_SCK_MARK, PORT197_FN3, MSEL4CR_MSEL21_0,
  811. MSEL4CR_MSEL20_1), \
  812. PINMUX_DATA(MFG2_OUT2_MARK, PORT197_FN5), \
  813. PINMUX_DATA(TPU2TO1_MARK, PORT197_FN7),
  814. PINMUX_DATA(LCDD6_MARK, PORT198_FN1),
  815. PINMUX_DATA(LCDD7_MARK, PORT199_FN1), \
  816. PINMUX_DATA(TPU4TO1_MARK, PORT199_FN2), \
  817. PINMUX_DATA(MFG4_OUT2_MARK, PORT199_FN5),
  818. PINMUX_DATA(LCDD8_MARK, PORT200_FN1), \
  819. PINMUX_DATA(D16_MARK, PORT200_FN6),
  820. PINMUX_DATA(LCDD9_MARK, PORT201_FN1), \
  821. PINMUX_DATA(D17_MARK, PORT201_FN6),
  822. PINMUX_DATA(LCDD10_MARK, PORT202_FN1), \
  823. PINMUX_DATA(D18_MARK, PORT202_FN6),
  824. PINMUX_DATA(LCDD11_MARK, PORT203_FN1), \
  825. PINMUX_DATA(D19_MARK, PORT203_FN6),
  826. PINMUX_DATA(LCDD12_MARK, PORT204_FN1), \
  827. PINMUX_DATA(D20_MARK, PORT204_FN6),
  828. PINMUX_DATA(LCDD13_MARK, PORT205_FN1), \
  829. PINMUX_DATA(D21_MARK, PORT205_FN6),
  830. PINMUX_DATA(LCDD14_MARK, PORT206_FN1), \
  831. PINMUX_DATA(D22_MARK, PORT206_FN6),
  832. PINMUX_DATA(LCDD15_MARK, PORT207_FN1), \
  833. PINMUX_DATA(PORT207_MSIOF0L_SS1_MARK, PORT207_FN2, MSEL3CR_MSEL11_1), \
  834. PINMUX_DATA(D23_MARK, PORT207_FN6),
  835. PINMUX_DATA(LCDD16_MARK, PORT208_FN1), \
  836. PINMUX_DATA(PORT208_MSIOF0L_SS2_MARK, PORT208_FN2, MSEL3CR_MSEL11_1), \
  837. PINMUX_DATA(D24_MARK, PORT208_FN6),
  838. PINMUX_DATA(LCDD17_MARK, PORT209_FN1), \
  839. PINMUX_DATA(D25_MARK, PORT209_FN6),
  840. PINMUX_DATA(LCDD18_MARK, PORT210_FN1), \
  841. PINMUX_DATA(DREQ2_MARK, PORT210_FN2), \
  842. PINMUX_DATA(PORT210_MSIOF0L_SS1_MARK, PORT210_FN5, MSEL3CR_MSEL11_1), \
  843. PINMUX_DATA(D26_MARK, PORT210_FN6),
  844. PINMUX_DATA(LCDD19_MARK, PORT211_FN1), \
  845. PINMUX_DATA(PORT211_MSIOF0L_SS2_MARK, PORT211_FN5, MSEL3CR_MSEL11_1), \
  846. PINMUX_DATA(D27_MARK, PORT211_FN6),
  847. PINMUX_DATA(LCDD20_MARK, PORT212_FN1), \
  848. PINMUX_DATA(TS_SPSYNC1_MARK, PORT212_FN2), \
  849. PINMUX_DATA(MSIOF0L_MCK0_MARK, PORT212_FN5, MSEL3CR_MSEL11_1), \
  850. PINMUX_DATA(D28_MARK, PORT212_FN6),
  851. PINMUX_DATA(LCDD21_MARK, PORT213_FN1), \
  852. PINMUX_DATA(TS_SDAT1_MARK, PORT213_FN2), \
  853. PINMUX_DATA(MSIOF0L_MCK1_MARK, PORT213_FN5, MSEL3CR_MSEL11_1), \
  854. PINMUX_DATA(D29_MARK, PORT213_FN6),
  855. PINMUX_DATA(LCDD22_MARK, PORT214_FN1), \
  856. PINMUX_DATA(TS_SDEN1_MARK, PORT214_FN2), \
  857. PINMUX_DATA(MSIOF0L_RSCK_MARK, PORT214_FN5, MSEL3CR_MSEL11_1), \
  858. PINMUX_DATA(D30_MARK, PORT214_FN6),
  859. PINMUX_DATA(LCDD23_MARK, PORT215_FN1), \
  860. PINMUX_DATA(TS_SCK1_MARK, PORT215_FN2), \
  861. PINMUX_DATA(MSIOF0L_RSYNC_MARK, PORT215_FN5, MSEL3CR_MSEL11_1), \
  862. PINMUX_DATA(D31_MARK, PORT215_FN6),
  863. PINMUX_DATA(LCDDCK_MARK, PORT216_FN1), \
  864. PINMUX_DATA(LCDWR__MARK, PORT216_FN2),
  865. PINMUX_DATA(LCDRD__MARK, PORT217_FN1), \
  866. PINMUX_DATA(DACK2_MARK, PORT217_FN2), \
  867. PINMUX_DATA(PORT217_LCD2RS_MARK, PORT217_FN3), \
  868. PINMUX_DATA(MSIOF0L_TSYNC_MARK, PORT217_FN5, MSEL3CR_MSEL11_1), \
  869. PINMUX_DATA(VIO2_FIELD3_MARK, PORT217_FN6, MSEL4CR_MSEL27_1,
  870. MSEL4CR_MSEL26_1), \
  871. PINMUX_DATA(PORT217_LCD2DISP_MARK, PORT217_FN7),
  872. PINMUX_DATA(LCDHSYN_MARK, PORT218_FN1), \
  873. PINMUX_DATA(LCDCS__MARK, PORT218_FN2), \
  874. PINMUX_DATA(LCDCS2__MARK, PORT218_FN3), \
  875. PINMUX_DATA(DACK3_MARK, PORT218_FN4), \
  876. PINMUX_DATA(PORT218_VIO_CKOR_MARK, PORT218_FN5),
  877. PINMUX_DATA(LCDDISP_MARK, PORT219_FN1), \
  878. PINMUX_DATA(LCDRS_MARK, PORT219_FN2), \
  879. PINMUX_DATA(PORT219_LCD2WR__MARK, PORT219_FN3), \
  880. PINMUX_DATA(DREQ3_MARK, PORT219_FN4), \
  881. PINMUX_DATA(MSIOF0L_TSCK_MARK, PORT219_FN5, MSEL3CR_MSEL11_1), \
  882. PINMUX_DATA(VIO2_CLK3_MARK, PORT219_FN6, MSEL4CR_MSEL27_1,
  883. MSEL4CR_MSEL26_1), \
  884. PINMUX_DATA(LCD2DCK_2_MARK, PORT219_FN7),
  885. PINMUX_DATA(LCDVSYN_MARK, PORT220_FN1), \
  886. PINMUX_DATA(LCDVSYN2_MARK, PORT220_FN2),
  887. PINMUX_DATA(LCDLCLK_MARK, PORT221_FN1), \
  888. PINMUX_DATA(DREQ1_MARK, PORT221_FN2), \
  889. PINMUX_DATA(PORT221_LCD2CS__MARK, PORT221_FN3), \
  890. PINMUX_DATA(PWEN_MARK, PORT221_FN4), \
  891. PINMUX_DATA(MSIOF0L_RXD_MARK, PORT221_FN5, MSEL3CR_MSEL11_1), \
  892. PINMUX_DATA(VIO2_HD3_MARK, PORT221_FN6, MSEL4CR_MSEL27_1,
  893. MSEL4CR_MSEL26_1), \
  894. PINMUX_DATA(PORT221_LCD2HSYN_MARK, PORT221_FN7),
  895. PINMUX_DATA(LCDDON_MARK, PORT222_FN1), \
  896. PINMUX_DATA(LCDDON2_MARK, PORT222_FN2), \
  897. PINMUX_DATA(DACK1_MARK, PORT222_FN3), \
  898. PINMUX_DATA(OVCN_MARK, PORT222_FN4), \
  899. PINMUX_DATA(MSIOF0L_TXD_MARK, PORT222_FN5, MSEL3CR_MSEL11_1), \
  900. PINMUX_DATA(VIO2_VD3_MARK, PORT222_FN6, MSEL4CR_MSEL27_1,
  901. MSEL4CR_MSEL26_1), \
  902. PINMUX_DATA(PORT222_LCD2VSYN_MARK, PORT222_FN7, MSEL3CR_MSEL2_1),
  903. PINMUX_DATA(SCIFA1_TXD_MARK, PORT225_FN2), \
  904. PINMUX_DATA(OVCN2_MARK, PORT225_FN4),
  905. PINMUX_DATA(EXTLP_MARK, PORT226_FN1), \
  906. PINMUX_DATA(SCIFA1_SCK_MARK, PORT226_FN2), \
  907. PINMUX_DATA(PORT226_VIO_CKO2_MARK, PORT226_FN5),
  908. PINMUX_DATA(SCIFA1_RTS__MARK, PORT227_FN2), \
  909. PINMUX_DATA(IDIN_MARK, PORT227_FN4),
  910. PINMUX_DATA(SCIFA1_RXD_MARK, PORT228_FN2),
  911. PINMUX_DATA(SCIFA1_CTS__MARK, PORT229_FN2), \
  912. PINMUX_DATA(MFG1_IN1_MARK, PORT229_FN3),
  913. PINMUX_DATA(MSIOF1_TXD_MARK, PORT230_FN1), \
  914. PINMUX_DATA(SCIFA2_TXD2_MARK, PORT230_FN2, MSEL3CR_MSEL9_1),
  915. PINMUX_DATA(MSIOF1_TSYNC_MARK, PORT231_FN1), \
  916. PINMUX_DATA(SCIFA2_CTS2__MARK, PORT231_FN2, MSEL3CR_MSEL9_1),
  917. PINMUX_DATA(MSIOF1_TSCK_MARK, PORT232_FN1), \
  918. PINMUX_DATA(SCIFA2_SCK2_MARK, PORT232_FN2, MSEL3CR_MSEL9_1),
  919. PINMUX_DATA(MSIOF1_RXD_MARK, PORT233_FN1), \
  920. PINMUX_DATA(SCIFA2_RXD2_MARK, PORT233_FN2, MSEL3CR_MSEL9_1),
  921. PINMUX_DATA(MSIOF1_RSCK_MARK, PORT234_FN1), \
  922. PINMUX_DATA(SCIFA2_RTS2__MARK, PORT234_FN2, MSEL3CR_MSEL9_1), \
  923. PINMUX_DATA(VIO2_CLK2_MARK, PORT234_FN6, MSEL4CR_MSEL27_1,
  924. MSEL4CR_MSEL26_0), \
  925. PINMUX_DATA(LCD2D20_MARK, PORT234_FN7),
  926. PINMUX_DATA(MSIOF1_RSYNC_MARK, PORT235_FN1), \
  927. PINMUX_DATA(MFG1_IN2_MARK, PORT235_FN3), \
  928. PINMUX_DATA(VIO2_VD2_MARK, PORT235_FN6, MSEL4CR_MSEL27_1,
  929. MSEL4CR_MSEL26_0), \
  930. PINMUX_DATA(LCD2D21_MARK, PORT235_FN7),
  931. PINMUX_DATA(MSIOF1_MCK0_MARK, PORT236_FN1), \
  932. PINMUX_DATA(PORT236_I2C_SDA2_MARK, PORT236_FN2, MSEL2CR_MSEL17_0,
  933. MSEL2CR_MSEL16_0),
  934. PINMUX_DATA(MSIOF1_MCK1_MARK, PORT237_FN1), \
  935. PINMUX_DATA(PORT237_I2C_SCL2_MARK, PORT237_FN2, MSEL2CR_MSEL17_0,
  936. MSEL2CR_MSEL16_0),
  937. PINMUX_DATA(MSIOF1_SS1_MARK, PORT238_FN1), \
  938. PINMUX_DATA(VIO2_FIELD2_MARK, PORT238_FN6, MSEL4CR_MSEL27_1,
  939. MSEL4CR_MSEL26_0), \
  940. PINMUX_DATA(LCD2D22_MARK, PORT238_FN7),
  941. PINMUX_DATA(MSIOF1_SS2_MARK, PORT239_FN1), \
  942. PINMUX_DATA(VIO2_HD2_MARK, PORT239_FN6, MSEL4CR_MSEL27_1,
  943. MSEL4CR_MSEL26_0), \
  944. PINMUX_DATA(LCD2D23_MARK, PORT239_FN7),
  945. PINMUX_DATA(SCIFA6_TXD_MARK, PORT240_FN1),
  946. PINMUX_DATA(PORT241_IRDA_OUT_MARK, PORT241_FN1, MSEL4CR_MSEL19_0), \
  947. PINMUX_DATA(PORT241_IROUT_MARK, PORT241_FN2), \
  948. PINMUX_DATA(MFG4_OUT1_MARK, PORT241_FN3), \
  949. PINMUX_DATA(TPU4TO0_MARK, PORT241_FN4),
  950. PINMUX_DATA(PORT242_IRDA_IN_MARK, PORT242_FN1, MSEL4CR_MSEL19_0), \
  951. PINMUX_DATA(MFG4_IN2_MARK, PORT242_FN3),
  952. PINMUX_DATA(PORT243_IRDA_FIRSEL_MARK, PORT243_FN1, MSEL4CR_MSEL19_0), \
  953. PINMUX_DATA(PORT243_VIO_CKO2_MARK, PORT243_FN2),
  954. PINMUX_DATA(PORT244_SCIFA5_CTS__MARK, PORT244_FN1, MSEL4CR_MSEL21_0,
  955. MSEL4CR_MSEL20_0), \
  956. PINMUX_DATA(MFG2_IN1_MARK, PORT244_FN2), \
  957. PINMUX_DATA(PORT244_SCIFB_CTS__MARK, PORT244_FN3, MSEL4CR_MSEL22_1), \
  958. PINMUX_DATA(MSIOF2R_RXD_MARK, PORT244_FN7, MSEL4CR_MSEL11_1),
  959. PINMUX_DATA(PORT245_SCIFA5_RTS__MARK, PORT245_FN1, MSEL4CR_MSEL21_0,
  960. MSEL4CR_MSEL20_0), \
  961. PINMUX_DATA(MFG2_IN2_MARK, PORT245_FN2), \
  962. PINMUX_DATA(PORT245_SCIFB_RTS__MARK, PORT245_FN3, MSEL4CR_MSEL22_1), \
  963. PINMUX_DATA(MSIOF2R_TXD_MARK, PORT245_FN7, MSEL4CR_MSEL11_1),
  964. PINMUX_DATA(PORT246_SCIFA5_RXD_MARK, PORT246_FN1, MSEL4CR_MSEL21_0,
  965. MSEL4CR_MSEL20_0), \
  966. PINMUX_DATA(MFG1_OUT1_MARK, PORT246_FN2), \
  967. PINMUX_DATA(PORT246_SCIFB_RXD_MARK, PORT246_FN3, MSEL4CR_MSEL22_1), \
  968. PINMUX_DATA(TPU1TO0_MARK, PORT246_FN4),
  969. PINMUX_DATA(PORT247_SCIFA5_TXD_MARK, PORT247_FN1, MSEL4CR_MSEL21_0,
  970. MSEL4CR_MSEL20_0), \
  971. PINMUX_DATA(MFG3_OUT2_MARK, PORT247_FN2), \
  972. PINMUX_DATA(PORT247_SCIFB_TXD_MARK, PORT247_FN3, MSEL4CR_MSEL22_1), \
  973. PINMUX_DATA(TPU3TO1_MARK, PORT247_FN4),
  974. PINMUX_DATA(PORT248_SCIFA5_SCK_MARK, PORT248_FN1, MSEL4CR_MSEL21_0,
  975. MSEL4CR_MSEL20_0), \
  976. PINMUX_DATA(MFG2_OUT1_MARK, PORT248_FN2), \
  977. PINMUX_DATA(PORT248_SCIFB_SCK_MARK, PORT248_FN3, MSEL4CR_MSEL22_1), \
  978. PINMUX_DATA(TPU2TO0_MARK, PORT248_FN4), \
  979. PINMUX_DATA(PORT248_I2C_SCL3_MARK, PORT248_FN5, MSEL2CR_MSEL19_0,
  980. MSEL2CR_MSEL18_0), \
  981. PINMUX_DATA(MSIOF2R_TSCK_MARK, PORT248_FN7, MSEL4CR_MSEL11_1),
  982. PINMUX_DATA(PORT249_IROUT_MARK, PORT249_FN1), \
  983. PINMUX_DATA(MFG4_IN1_MARK, PORT249_FN2), \
  984. PINMUX_DATA(PORT249_I2C_SDA3_MARK, PORT249_FN5, MSEL2CR_MSEL19_0,
  985. MSEL2CR_MSEL18_0), \
  986. PINMUX_DATA(MSIOF2R_TSYNC_MARK, PORT249_FN7, MSEL4CR_MSEL11_1),
  987. PINMUX_DATA(SDHICLK0_MARK, PORT250_FN1),
  988. PINMUX_DATA(SDHICD0_MARK, PORT251_FN1),
  989. PINMUX_DATA(SDHID0_0_MARK, PORT252_FN1),
  990. PINMUX_DATA(SDHID0_1_MARK, PORT253_FN1),
  991. PINMUX_DATA(SDHID0_2_MARK, PORT254_FN1),
  992. PINMUX_DATA(SDHID0_3_MARK, PORT255_FN1),
  993. PINMUX_DATA(SDHICMD0_MARK, PORT256_FN1),
  994. PINMUX_DATA(SDHIWP0_MARK, PORT257_FN1),
  995. PINMUX_DATA(SDHICLK1_MARK, PORT258_FN1),
  996. PINMUX_DATA(SDHID1_0_MARK, PORT259_FN1), \
  997. PINMUX_DATA(TS_SPSYNC2_MARK, PORT259_FN3),
  998. PINMUX_DATA(SDHID1_1_MARK, PORT260_FN1), \
  999. PINMUX_DATA(TS_SDAT2_MARK, PORT260_FN3),
  1000. PINMUX_DATA(SDHID1_2_MARK, PORT261_FN1), \
  1001. PINMUX_DATA(TS_SDEN2_MARK, PORT261_FN3),
  1002. PINMUX_DATA(SDHID1_3_MARK, PORT262_FN1), \
  1003. PINMUX_DATA(TS_SCK2_MARK, PORT262_FN3),
  1004. PINMUX_DATA(SDHICMD1_MARK, PORT263_FN1),
  1005. PINMUX_DATA(SDHICLK2_MARK, PORT264_FN1),
  1006. PINMUX_DATA(SDHID2_0_MARK, PORT265_FN1), \
  1007. PINMUX_DATA(TS_SPSYNC4_MARK, PORT265_FN3),
  1008. PINMUX_DATA(SDHID2_1_MARK, PORT266_FN1), \
  1009. PINMUX_DATA(TS_SDAT4_MARK, PORT266_FN3),
  1010. PINMUX_DATA(SDHID2_2_MARK, PORT267_FN1), \
  1011. PINMUX_DATA(TS_SDEN4_MARK, PORT267_FN3),
  1012. PINMUX_DATA(SDHID2_3_MARK, PORT268_FN1), \
  1013. PINMUX_DATA(TS_SCK4_MARK, PORT268_FN3),
  1014. PINMUX_DATA(SDHICMD2_MARK, PORT269_FN1),
  1015. PINMUX_DATA(MMCCLK0_MARK, PORT270_FN1, MSEL4CR_MSEL15_0),
  1016. PINMUX_DATA(MMCD0_0_MARK, PORT271_FN1, MSEL4CR_MSEL15_0),
  1017. PINMUX_DATA(MMCD0_1_MARK, PORT272_FN1, MSEL4CR_MSEL15_0),
  1018. PINMUX_DATA(MMCD0_2_MARK, PORT273_FN1, MSEL4CR_MSEL15_0),
  1019. PINMUX_DATA(MMCD0_3_MARK, PORT274_FN1, MSEL4CR_MSEL15_0),
  1020. PINMUX_DATA(MMCD0_4_MARK, PORT275_FN1, MSEL4CR_MSEL15_0),
  1021. PINMUX_DATA(TS_SPSYNC5_MARK, PORT275_FN3),
  1022. PINMUX_DATA(MMCD0_5_MARK, PORT276_FN1, MSEL4CR_MSEL15_0),
  1023. PINMUX_DATA(TS_SDAT5_MARK, PORT276_FN3),
  1024. PINMUX_DATA(MMCD0_6_MARK, PORT277_FN1, MSEL4CR_MSEL15_0),
  1025. PINMUX_DATA(TS_SDEN5_MARK, PORT277_FN3),
  1026. PINMUX_DATA(MMCD0_7_MARK, PORT278_FN1, MSEL4CR_MSEL15_0),
  1027. PINMUX_DATA(TS_SCK5_MARK, PORT278_FN3),
  1028. PINMUX_DATA(MMCCMD0_MARK, PORT279_FN1, MSEL4CR_MSEL15_0),
  1029. PINMUX_DATA(RESETOUTS__MARK, PORT281_FN1), \
  1030. PINMUX_DATA(EXTAL2OUT_MARK, PORT281_FN2),
  1031. PINMUX_DATA(MCP_WAIT__MCP_FRB_MARK, PORT288_FN1),
  1032. PINMUX_DATA(MCP_CKO_MARK, PORT289_FN1), \
  1033. PINMUX_DATA(MMCCLK1_MARK, PORT289_FN2, MSEL4CR_MSEL15_1),
  1034. PINMUX_DATA(MCP_D15_MCP_NAF15_MARK, PORT290_FN1),
  1035. PINMUX_DATA(MCP_D14_MCP_NAF14_MARK, PORT291_FN1),
  1036. PINMUX_DATA(MCP_D13_MCP_NAF13_MARK, PORT292_FN1),
  1037. PINMUX_DATA(MCP_D12_MCP_NAF12_MARK, PORT293_FN1),
  1038. PINMUX_DATA(MCP_D11_MCP_NAF11_MARK, PORT294_FN1),
  1039. PINMUX_DATA(MCP_D10_MCP_NAF10_MARK, PORT295_FN1),
  1040. PINMUX_DATA(MCP_D9_MCP_NAF9_MARK, PORT296_FN1),
  1041. PINMUX_DATA(MCP_D8_MCP_NAF8_MARK, PORT297_FN1), \
  1042. PINMUX_DATA(MMCCMD1_MARK, PORT297_FN2, MSEL4CR_MSEL15_1),
  1043. PINMUX_DATA(MCP_D7_MCP_NAF7_MARK, PORT298_FN1), \
  1044. PINMUX_DATA(MMCD1_7_MARK, PORT298_FN2, MSEL4CR_MSEL15_1),
  1045. PINMUX_DATA(MCP_D6_MCP_NAF6_MARK, PORT299_FN1), \
  1046. PINMUX_DATA(MMCD1_6_MARK, PORT299_FN2, MSEL4CR_MSEL15_1),
  1047. PINMUX_DATA(MCP_D5_MCP_NAF5_MARK, PORT300_FN1), \
  1048. PINMUX_DATA(MMCD1_5_MARK, PORT300_FN2, MSEL4CR_MSEL15_1),
  1049. PINMUX_DATA(MCP_D4_MCP_NAF4_MARK, PORT301_FN1), \
  1050. PINMUX_DATA(MMCD1_4_MARK, PORT301_FN2, MSEL4CR_MSEL15_1),
  1051. PINMUX_DATA(MCP_D3_MCP_NAF3_MARK, PORT302_FN1), \
  1052. PINMUX_DATA(MMCD1_3_MARK, PORT302_FN2, MSEL4CR_MSEL15_1),
  1053. PINMUX_DATA(MCP_D2_MCP_NAF2_MARK, PORT303_FN1), \
  1054. PINMUX_DATA(MMCD1_2_MARK, PORT303_FN2, MSEL4CR_MSEL15_1),
  1055. PINMUX_DATA(MCP_D1_MCP_NAF1_MARK, PORT304_FN1), \
  1056. PINMUX_DATA(MMCD1_1_MARK, PORT304_FN2, MSEL4CR_MSEL15_1),
  1057. PINMUX_DATA(MCP_D0_MCP_NAF0_MARK, PORT305_FN1), \
  1058. PINMUX_DATA(MMCD1_0_MARK, PORT305_FN2, MSEL4CR_MSEL15_1),
  1059. PINMUX_DATA(MCP_NBRSTOUT__MARK, PORT306_FN1),
  1060. PINMUX_DATA(MCP_WE0__MCP_FWE_MARK, PORT309_FN1), \
  1061. PINMUX_DATA(MCP_RDWR_MCP_FWE_MARK, PORT309_FN2),
  1062. /* MSEL2 special cases */
  1063. PINMUX_DATA(TSIF2_TS_XX1_MARK, MSEL2CR_MSEL14_0, MSEL2CR_MSEL13_0,
  1064. MSEL2CR_MSEL12_0),
  1065. PINMUX_DATA(TSIF2_TS_XX2_MARK, MSEL2CR_MSEL14_0, MSEL2CR_MSEL13_0,
  1066. MSEL2CR_MSEL12_1),
  1067. PINMUX_DATA(TSIF2_TS_XX3_MARK, MSEL2CR_MSEL14_0, MSEL2CR_MSEL13_1,
  1068. MSEL2CR_MSEL12_0),
  1069. PINMUX_DATA(TSIF2_TS_XX4_MARK, MSEL2CR_MSEL14_0, MSEL2CR_MSEL13_1,
  1070. MSEL2CR_MSEL12_1),
  1071. PINMUX_DATA(TSIF2_TS_XX5_MARK, MSEL2CR_MSEL14_1, MSEL2CR_MSEL13_0,
  1072. MSEL2CR_MSEL12_0),
  1073. PINMUX_DATA(TSIF1_TS_XX1_MARK, MSEL2CR_MSEL11_0, MSEL2CR_MSEL10_0,
  1074. MSEL2CR_MSEL9_0),
  1075. PINMUX_DATA(TSIF1_TS_XX2_MARK, MSEL2CR_MSEL11_0, MSEL2CR_MSEL10_0,
  1076. MSEL2CR_MSEL9_1),
  1077. PINMUX_DATA(TSIF1_TS_XX3_MARK, MSEL2CR_MSEL11_0, MSEL2CR_MSEL10_1,
  1078. MSEL2CR_MSEL9_0),
  1079. PINMUX_DATA(TSIF1_TS_XX4_MARK, MSEL2CR_MSEL11_0, MSEL2CR_MSEL10_1,
  1080. MSEL2CR_MSEL9_1),
  1081. PINMUX_DATA(TSIF1_TS_XX5_MARK, MSEL2CR_MSEL11_1, MSEL2CR_MSEL10_0,
  1082. MSEL2CR_MSEL9_0),
  1083. PINMUX_DATA(TSIF0_TS_XX1_MARK, MSEL2CR_MSEL8_0, MSEL2CR_MSEL7_0,
  1084. MSEL2CR_MSEL6_0),
  1085. PINMUX_DATA(TSIF0_TS_XX2_MARK, MSEL2CR_MSEL8_0, MSEL2CR_MSEL7_0,
  1086. MSEL2CR_MSEL6_1),
  1087. PINMUX_DATA(TSIF0_TS_XX3_MARK, MSEL2CR_MSEL8_0, MSEL2CR_MSEL7_1,
  1088. MSEL2CR_MSEL6_0),
  1089. PINMUX_DATA(TSIF0_TS_XX4_MARK, MSEL2CR_MSEL8_0, MSEL2CR_MSEL7_1,
  1090. MSEL2CR_MSEL6_1),
  1091. PINMUX_DATA(TSIF0_TS_XX5_MARK, MSEL2CR_MSEL8_1, MSEL2CR_MSEL7_0,
  1092. MSEL2CR_MSEL6_0),
  1093. PINMUX_DATA(MST1_TS_XX1_MARK, MSEL2CR_MSEL5_0, MSEL2CR_MSEL4_0,
  1094. MSEL2CR_MSEL3_0),
  1095. PINMUX_DATA(MST1_TS_XX2_MARK, MSEL2CR_MSEL5_0, MSEL2CR_MSEL4_0,
  1096. MSEL2CR_MSEL3_1),
  1097. PINMUX_DATA(MST1_TS_XX3_MARK, MSEL2CR_MSEL5_0, MSEL2CR_MSEL4_1,
  1098. MSEL2CR_MSEL3_0),
  1099. PINMUX_DATA(MST1_TS_XX4_MARK, MSEL2CR_MSEL5_0, MSEL2CR_MSEL4_1,
  1100. MSEL2CR_MSEL3_1),
  1101. PINMUX_DATA(MST1_TS_XX5_MARK, MSEL2CR_MSEL5_1, MSEL2CR_MSEL4_0,
  1102. MSEL2CR_MSEL3_0),
  1103. PINMUX_DATA(MST0_TS_XX1_MARK, MSEL2CR_MSEL2_0, MSEL2CR_MSEL1_0,
  1104. MSEL2CR_MSEL0_0),
  1105. PINMUX_DATA(MST0_TS_XX2_MARK, MSEL2CR_MSEL2_0, MSEL2CR_MSEL1_0,
  1106. MSEL2CR_MSEL0_1),
  1107. PINMUX_DATA(MST0_TS_XX3_MARK, MSEL2CR_MSEL2_0, MSEL2CR_MSEL1_1,
  1108. MSEL2CR_MSEL0_0),
  1109. PINMUX_DATA(MST0_TS_XX4_MARK, MSEL2CR_MSEL2_0, MSEL2CR_MSEL1_1,
  1110. MSEL2CR_MSEL0_1),
  1111. PINMUX_DATA(MST0_TS_XX5_MARK, MSEL2CR_MSEL2_1, MSEL2CR_MSEL1_0,
  1112. MSEL2CR_MSEL0_0),
  1113. /* MSEL3 special cases */
  1114. PINMUX_DATA(SDHI0_VCCQ_MC0_ON_MARK, MSEL3CR_MSEL28_1),
  1115. PINMUX_DATA(SDHI0_VCCQ_MC0_OFF_MARK, MSEL3CR_MSEL28_0),
  1116. PINMUX_DATA(DEBUG_MON_VIO_MARK, MSEL3CR_MSEL15_0),
  1117. PINMUX_DATA(DEBUG_MON_LCDD_MARK, MSEL3CR_MSEL15_1),
  1118. PINMUX_DATA(LCDC_LCDC0_MARK, MSEL3CR_MSEL6_0),
  1119. PINMUX_DATA(LCDC_LCDC1_MARK, MSEL3CR_MSEL6_1),
  1120. /* MSEL4 special cases */
  1121. PINMUX_DATA(IRQ9_MEM_INT_MARK, MSEL4CR_MSEL29_0),
  1122. PINMUX_DATA(IRQ9_MCP_INT_MARK, MSEL4CR_MSEL29_1),
  1123. PINMUX_DATA(A11_MARK, MSEL4CR_MSEL13_0, MSEL4CR_MSEL12_0),
  1124. PINMUX_DATA(KEYOUT8_MARK, MSEL4CR_MSEL13_0, MSEL4CR_MSEL12_1),
  1125. PINMUX_DATA(TPU4TO3_MARK, MSEL4CR_MSEL13_1, MSEL4CR_MSEL12_0),
  1126. PINMUX_DATA(RESETA_N_PU_ON_MARK, MSEL4CR_MSEL4_0),
  1127. PINMUX_DATA(RESETA_N_PU_OFF_MARK, MSEL4CR_MSEL4_1),
  1128. PINMUX_DATA(EDBGREQ_PD_MARK, MSEL4CR_MSEL1_0),
  1129. PINMUX_DATA(EDBGREQ_PU_MARK, MSEL4CR_MSEL1_1),
  1130. };
  1131. #define SH73A0_PIN(pin, cfgs) \
  1132. { \
  1133. .name = __stringify(PORT##pin), \
  1134. .enum_id = PORT##pin##_DATA, \
  1135. .configs = cfgs, \
  1136. }
  1137. #define __I (SH_PFC_PIN_CFG_INPUT)
  1138. #define __O (SH_PFC_PIN_CFG_OUTPUT)
  1139. #define __IO (SH_PFC_PIN_CFG_INPUT | SH_PFC_PIN_CFG_OUTPUT)
  1140. #define __PD (SH_PFC_PIN_CFG_PULL_DOWN)
  1141. #define __PU (SH_PFC_PIN_CFG_PULL_UP)
  1142. #define __PUD (SH_PFC_PIN_CFG_PULL_DOWN | SH_PFC_PIN_CFG_PULL_UP)
  1143. #define SH73A0_PIN_I_PD(pin) SH73A0_PIN(pin, __I | __PD)
  1144. #define SH73A0_PIN_I_PU(pin) SH73A0_PIN(pin, __I | __PU)
  1145. #define SH73A0_PIN_I_PU_PD(pin) SH73A0_PIN(pin, __I | __PUD)
  1146. #define SH73A0_PIN_IO(pin) SH73A0_PIN(pin, __IO)
  1147. #define SH73A0_PIN_IO_PD(pin) SH73A0_PIN(pin, __IO | __PD)
  1148. #define SH73A0_PIN_IO_PU(pin) SH73A0_PIN(pin, __IO | __PU)
  1149. #define SH73A0_PIN_IO_PU_PD(pin) SH73A0_PIN(pin, __IO | __PUD)
  1150. #define SH73A0_PIN_O(pin) SH73A0_PIN(pin, __O)
  1151. static struct sh_pfc_pin pinmux_pins[] = {
  1152. /* Table 25-1 (I/O and Pull U/D) */
  1153. SH73A0_PIN_I_PD(0),
  1154. SH73A0_PIN_I_PU(1),
  1155. SH73A0_PIN_I_PU(2),
  1156. SH73A0_PIN_I_PU(3),
  1157. SH73A0_PIN_I_PU(4),
  1158. SH73A0_PIN_I_PU(5),
  1159. SH73A0_PIN_I_PU(6),
  1160. SH73A0_PIN_I_PU(7),
  1161. SH73A0_PIN_I_PU(8),
  1162. SH73A0_PIN_I_PD(9),
  1163. SH73A0_PIN_I_PD(10),
  1164. SH73A0_PIN_I_PU_PD(11),
  1165. SH73A0_PIN_IO_PU_PD(12),
  1166. SH73A0_PIN_IO_PU_PD(13),
  1167. SH73A0_PIN_IO_PU_PD(14),
  1168. SH73A0_PIN_IO_PU_PD(15),
  1169. SH73A0_PIN_IO_PD(16),
  1170. SH73A0_PIN_IO_PD(17),
  1171. SH73A0_PIN_IO_PU(18),
  1172. SH73A0_PIN_IO_PU(19),
  1173. SH73A0_PIN_O(20),
  1174. SH73A0_PIN_O(21),
  1175. SH73A0_PIN_O(22),
  1176. SH73A0_PIN_O(23),
  1177. SH73A0_PIN_O(24),
  1178. SH73A0_PIN_I_PD(25),
  1179. SH73A0_PIN_I_PD(26),
  1180. SH73A0_PIN_IO_PU(27),
  1181. SH73A0_PIN_IO_PU(28),
  1182. SH73A0_PIN_IO_PD(29),
  1183. SH73A0_PIN_IO_PD(30),
  1184. SH73A0_PIN_IO_PU(31),
  1185. SH73A0_PIN_IO_PD(32),
  1186. SH73A0_PIN_I_PU_PD(33),
  1187. SH73A0_PIN_IO_PD(34),
  1188. SH73A0_PIN_I_PU_PD(35),
  1189. SH73A0_PIN_IO_PD(36),
  1190. SH73A0_PIN_IO(37),
  1191. SH73A0_PIN_O(38),
  1192. SH73A0_PIN_I_PU(39),
  1193. SH73A0_PIN_I_PU_PD(40),
  1194. SH73A0_PIN_O(41),
  1195. SH73A0_PIN_IO_PD(42),
  1196. SH73A0_PIN_IO_PU_PD(43),
  1197. SH73A0_PIN_IO_PU_PD(44),
  1198. SH73A0_PIN_IO_PD(45),
  1199. SH73A0_PIN_IO_PD(46),
  1200. SH73A0_PIN_IO_PD(47),
  1201. SH73A0_PIN_I_PD(48),
  1202. SH73A0_PIN_IO_PU_PD(49),
  1203. SH73A0_PIN_IO_PD(50),
  1204. SH73A0_PIN_IO_PD(51),
  1205. SH73A0_PIN_O(52),
  1206. SH73A0_PIN_IO_PU_PD(53),
  1207. SH73A0_PIN_IO_PU_PD(54),
  1208. SH73A0_PIN_IO_PD(55),
  1209. SH73A0_PIN_I_PU_PD(56),
  1210. SH73A0_PIN_IO(57),
  1211. SH73A0_PIN_IO(58),
  1212. SH73A0_PIN_IO(59),
  1213. SH73A0_PIN_IO(60),
  1214. SH73A0_PIN_IO(61),
  1215. SH73A0_PIN_IO_PD(62),
  1216. SH73A0_PIN_IO_PD(63),
  1217. SH73A0_PIN_IO_PU_PD(64),
  1218. SH73A0_PIN_IO_PD(65),
  1219. SH73A0_PIN_IO_PU_PD(66),
  1220. SH73A0_PIN_IO_PU_PD(67),
  1221. SH73A0_PIN_IO_PU_PD(68),
  1222. SH73A0_PIN_IO_PU_PD(69),
  1223. SH73A0_PIN_IO_PU_PD(70),
  1224. SH73A0_PIN_IO_PU_PD(71),
  1225. SH73A0_PIN_IO_PU_PD(72),
  1226. SH73A0_PIN_I_PU_PD(73),
  1227. SH73A0_PIN_IO_PU(74),
  1228. SH73A0_PIN_IO_PU(75),
  1229. SH73A0_PIN_IO_PU(76),
  1230. SH73A0_PIN_IO_PU(77),
  1231. SH73A0_PIN_IO_PU(78),
  1232. SH73A0_PIN_IO_PU(79),
  1233. SH73A0_PIN_IO_PU(80),
  1234. SH73A0_PIN_IO_PU(81),
  1235. SH73A0_PIN_IO_PU(82),
  1236. SH73A0_PIN_IO_PU(83),
  1237. SH73A0_PIN_IO_PU(84),
  1238. SH73A0_PIN_IO_PU(85),
  1239. SH73A0_PIN_IO_PU(86),
  1240. SH73A0_PIN_IO_PU(87),
  1241. SH73A0_PIN_IO_PU(88),
  1242. SH73A0_PIN_IO_PU(89),
  1243. SH73A0_PIN_O(90),
  1244. SH73A0_PIN_IO_PU(91),
  1245. SH73A0_PIN_O(92),
  1246. SH73A0_PIN_IO_PU(93),
  1247. SH73A0_PIN_O(94),
  1248. SH73A0_PIN_I_PU_PD(95),
  1249. SH73A0_PIN_IO(96),
  1250. SH73A0_PIN_IO(97),
  1251. SH73A0_PIN_IO(98),
  1252. SH73A0_PIN_I_PU(99),
  1253. SH73A0_PIN_O(100),
  1254. SH73A0_PIN_O(101),
  1255. SH73A0_PIN_I_PU(102),
  1256. SH73A0_PIN_IO_PD(103),
  1257. SH73A0_PIN_I_PU_PD(104),
  1258. SH73A0_PIN_I_PD(105),
  1259. SH73A0_PIN_I_PD(106),
  1260. SH73A0_PIN_I_PU_PD(107),
  1261. SH73A0_PIN_I_PU_PD(108),
  1262. SH73A0_PIN_IO_PD(109),
  1263. SH73A0_PIN_IO_PD(110),
  1264. SH73A0_PIN_IO_PU_PD(111),
  1265. SH73A0_PIN_IO_PU_PD(112),
  1266. SH73A0_PIN_IO_PU_PD(113),
  1267. SH73A0_PIN_IO_PD(114),
  1268. SH73A0_PIN_IO_PU(115),
  1269. SH73A0_PIN_IO_PU(116),
  1270. SH73A0_PIN_IO_PU_PD(117),
  1271. SH73A0_PIN_IO_PU_PD(118),
  1272. SH73A0_PIN_IO_PD(128),
  1273. SH73A0_PIN_IO_PD(129),
  1274. SH73A0_PIN_IO_PU_PD(130),
  1275. SH73A0_PIN_IO_PD(131),
  1276. SH73A0_PIN_IO_PD(132),
  1277. SH73A0_PIN_IO_PD(133),
  1278. SH73A0_PIN_IO_PU_PD(134),
  1279. SH73A0_PIN_IO_PU_PD(135),
  1280. SH73A0_PIN_IO_PU_PD(136),
  1281. SH73A0_PIN_IO_PU_PD(137),
  1282. SH73A0_PIN_IO_PD(138),
  1283. SH73A0_PIN_IO_PD(139),
  1284. SH73A0_PIN_IO_PD(140),
  1285. SH73A0_PIN_IO_PD(141),
  1286. SH73A0_PIN_IO_PD(142),
  1287. SH73A0_PIN_IO_PD(143),
  1288. SH73A0_PIN_IO_PU_PD(144),
  1289. SH73A0_PIN_IO_PD(145),
  1290. SH73A0_PIN_IO_PU_PD(146),
  1291. SH73A0_PIN_IO_PU_PD(147),
  1292. SH73A0_PIN_IO_PU_PD(148),
  1293. SH73A0_PIN_IO_PU_PD(149),
  1294. SH73A0_PIN_I_PU_PD(150),
  1295. SH73A0_PIN_IO_PU_PD(151),
  1296. SH73A0_PIN_IO_PU_PD(152),
  1297. SH73A0_PIN_IO_PD(153),
  1298. SH73A0_PIN_IO_PD(154),
  1299. SH73A0_PIN_I_PU_PD(155),
  1300. SH73A0_PIN_IO_PU_PD(156),
  1301. SH73A0_PIN_I_PD(157),
  1302. SH73A0_PIN_IO_PD(158),
  1303. SH73A0_PIN_IO_PU_PD(159),
  1304. SH73A0_PIN_IO_PU_PD(160),
  1305. SH73A0_PIN_I_PU_PD(161),
  1306. SH73A0_PIN_I_PU_PD(162),
  1307. SH73A0_PIN_IO_PU_PD(163),
  1308. SH73A0_PIN_I_PU_PD(164),
  1309. SH73A0_PIN_IO_PD(192),
  1310. SH73A0_PIN_IO_PU_PD(193),
  1311. SH73A0_PIN_IO_PD(194),
  1312. SH73A0_PIN_IO_PU_PD(195),
  1313. SH73A0_PIN_IO_PD(196),
  1314. SH73A0_PIN_IO_PD(197),
  1315. SH73A0_PIN_IO_PD(198),
  1316. SH73A0_PIN_IO_PD(199),
  1317. SH73A0_PIN_IO_PU_PD(200),
  1318. SH73A0_PIN_IO_PU_PD(201),
  1319. SH73A0_PIN_IO_PU_PD(202),
  1320. SH73A0_PIN_IO_PU_PD(203),
  1321. SH73A0_PIN_IO_PU_PD(204),
  1322. SH73A0_PIN_IO_PU_PD(205),
  1323. SH73A0_PIN_IO_PU_PD(206),
  1324. SH73A0_PIN_IO_PD(207),
  1325. SH73A0_PIN_IO_PD(208),
  1326. SH73A0_PIN_IO_PD(209),
  1327. SH73A0_PIN_IO_PD(210),
  1328. SH73A0_PIN_IO_PD(211),
  1329. SH73A0_PIN_IO_PD(212),
  1330. SH73A0_PIN_IO_PD(213),
  1331. SH73A0_PIN_IO_PU_PD(214),
  1332. SH73A0_PIN_IO_PU_PD(215),
  1333. SH73A0_PIN_IO_PD(216),
  1334. SH73A0_PIN_IO_PD(217),
  1335. SH73A0_PIN_O(218),
  1336. SH73A0_PIN_IO_PD(219),
  1337. SH73A0_PIN_IO_PD(220),
  1338. SH73A0_PIN_IO_PU_PD(221),
  1339. SH73A0_PIN_IO_PU_PD(222),
  1340. SH73A0_PIN_I_PU_PD(223),
  1341. SH73A0_PIN_I_PU_PD(224),
  1342. SH73A0_PIN_IO_PU_PD(225),
  1343. SH73A0_PIN_O(226),
  1344. SH73A0_PIN_IO_PU_PD(227),
  1345. SH73A0_PIN_I_PU_PD(228),
  1346. SH73A0_PIN_I_PD(229),
  1347. SH73A0_PIN_IO(230),
  1348. SH73A0_PIN_IO_PU_PD(231),
  1349. SH73A0_PIN_IO_PU_PD(232),
  1350. SH73A0_PIN_I_PU_PD(233),
  1351. SH73A0_PIN_IO_PU_PD(234),
  1352. SH73A0_PIN_IO_PU_PD(235),
  1353. SH73A0_PIN_IO_PU_PD(236),
  1354. SH73A0_PIN_IO_PD(237),
  1355. SH73A0_PIN_IO_PU_PD(238),
  1356. SH73A0_PIN_IO_PU_PD(239),
  1357. SH73A0_PIN_IO_PU_PD(240),
  1358. SH73A0_PIN_O(241),
  1359. SH73A0_PIN_I_PD(242),
  1360. SH73A0_PIN_IO_PU_PD(243),
  1361. SH73A0_PIN_IO_PU_PD(244),
  1362. SH73A0_PIN_IO_PU_PD(245),
  1363. SH73A0_PIN_IO_PU_PD(246),
  1364. SH73A0_PIN_IO_PU_PD(247),
  1365. SH73A0_PIN_IO_PU_PD(248),
  1366. SH73A0_PIN_IO_PU_PD(249),
  1367. SH73A0_PIN_IO_PU_PD(250),
  1368. SH73A0_PIN_IO_PU_PD(251),
  1369. SH73A0_PIN_IO_PU_PD(252),
  1370. SH73A0_PIN_IO_PU_PD(253),
  1371. SH73A0_PIN_IO_PU_PD(254),
  1372. SH73A0_PIN_IO_PU_PD(255),
  1373. SH73A0_PIN_IO_PU_PD(256),
  1374. SH73A0_PIN_IO_PU_PD(257),
  1375. SH73A0_PIN_IO_PU_PD(258),
  1376. SH73A0_PIN_IO_PU_PD(259),
  1377. SH73A0_PIN_IO_PU_PD(260),
  1378. SH73A0_PIN_IO_PU_PD(261),
  1379. SH73A0_PIN_IO_PU_PD(262),
  1380. SH73A0_PIN_IO_PU_PD(263),
  1381. SH73A0_PIN_IO_PU_PD(264),
  1382. SH73A0_PIN_IO_PU_PD(265),
  1383. SH73A0_PIN_IO_PU_PD(266),
  1384. SH73A0_PIN_IO_PU_PD(267),
  1385. SH73A0_PIN_IO_PU_PD(268),
  1386. SH73A0_PIN_IO_PU_PD(269),
  1387. SH73A0_PIN_IO_PU_PD(270),
  1388. SH73A0_PIN_IO_PU_PD(271),
  1389. SH73A0_PIN_IO_PU_PD(272),
  1390. SH73A0_PIN_IO_PU_PD(273),
  1391. SH73A0_PIN_IO_PU_PD(274),
  1392. SH73A0_PIN_IO_PU_PD(275),
  1393. SH73A0_PIN_IO_PU_PD(276),
  1394. SH73A0_PIN_IO_PU_PD(277),
  1395. SH73A0_PIN_IO_PU_PD(278),
  1396. SH73A0_PIN_IO_PU_PD(279),
  1397. SH73A0_PIN_IO_PU_PD(280),
  1398. SH73A0_PIN_O(281),
  1399. SH73A0_PIN_O(282),
  1400. SH73A0_PIN_I_PU(288),
  1401. SH73A0_PIN_IO_PU_PD(289),
  1402. SH73A0_PIN_IO_PU_PD(290),
  1403. SH73A0_PIN_IO_PU_PD(291),
  1404. SH73A0_PIN_IO_PU_PD(292),
  1405. SH73A0_PIN_IO_PU_PD(293),
  1406. SH73A0_PIN_IO_PU_PD(294),
  1407. SH73A0_PIN_IO_PU_PD(295),
  1408. SH73A0_PIN_IO_PU_PD(296),
  1409. SH73A0_PIN_IO_PU_PD(297),
  1410. SH73A0_PIN_IO_PU_PD(298),
  1411. SH73A0_PIN_IO_PU_PD(299),
  1412. SH73A0_PIN_IO_PU_PD(300),
  1413. SH73A0_PIN_IO_PU_PD(301),
  1414. SH73A0_PIN_IO_PU_PD(302),
  1415. SH73A0_PIN_IO_PU_PD(303),
  1416. SH73A0_PIN_IO_PU_PD(304),
  1417. SH73A0_PIN_IO_PU_PD(305),
  1418. SH73A0_PIN_O(306),
  1419. SH73A0_PIN_O(307),
  1420. SH73A0_PIN_I_PU(308),
  1421. SH73A0_PIN_O(309),
  1422. };
  1423. static const struct pinmux_range pinmux_ranges[] = {
  1424. {.begin = 0, .end = 118,},
  1425. {.begin = 128, .end = 164,},
  1426. {.begin = 192, .end = 282,},
  1427. {.begin = 288, .end = 309,},
  1428. };
  1429. /* Pin numbers for pins without a corresponding GPIO port number are computed
  1430. * from the row and column numbers with a 1000 offset to avoid collisions with
  1431. * GPIO port numbers.
  1432. */
  1433. #define PIN_NUMBER(row, col) (1000+((row)-1)*34+(col)-1)
  1434. /* - BSC -------------------------------------------------------------------- */
  1435. static const unsigned int bsc_data_0_7_pins[] = {
  1436. /* D[0:7] */
  1437. 74, 75, 76, 77, 78, 79, 80, 81,
  1438. };
  1439. static const unsigned int bsc_data_0_7_mux[] = {
  1440. D0_NAF0_MARK, D1_NAF1_MARK, D2_NAF2_MARK, D3_NAF3_MARK,
  1441. D4_NAF4_MARK, D5_NAF5_MARK, D6_NAF6_MARK, D7_NAF7_MARK,
  1442. };
  1443. static const unsigned int bsc_data_8_15_pins[] = {
  1444. /* D[8:15] */
  1445. 82, 83, 84, 85, 86, 87, 88, 89,
  1446. };
  1447. static const unsigned int bsc_data_8_15_mux[] = {
  1448. D8_NAF8_MARK, D9_NAF9_MARK, D10_NAF10_MARK, D11_NAF11_MARK,
  1449. D12_NAF12_MARK, D13_NAF13_MARK, D14_NAF14_MARK, D15_NAF15_MARK,
  1450. };
  1451. static const unsigned int bsc_cs4_pins[] = {
  1452. /* CS */
  1453. 90,
  1454. };
  1455. static const unsigned int bsc_cs4_mux[] = {
  1456. CS4__MARK,
  1457. };
  1458. static const unsigned int bsc_cs5_a_pins[] = {
  1459. /* CS */
  1460. 91,
  1461. };
  1462. static const unsigned int bsc_cs5_a_mux[] = {
  1463. CS5A__MARK,
  1464. };
  1465. static const unsigned int bsc_cs5_b_pins[] = {
  1466. /* CS */
  1467. 92,
  1468. };
  1469. static const unsigned int bsc_cs5_b_mux[] = {
  1470. CS5B__MARK,
  1471. };
  1472. static const unsigned int bsc_cs6_a_pins[] = {
  1473. /* CS */
  1474. 94,
  1475. };
  1476. static const unsigned int bsc_cs6_a_mux[] = {
  1477. CS6A__MARK,
  1478. };
  1479. static const unsigned int bsc_cs6_b_pins[] = {
  1480. /* CS */
  1481. 93,
  1482. };
  1483. static const unsigned int bsc_cs6_b_mux[] = {
  1484. CS6B__MARK,
  1485. };
  1486. static const unsigned int bsc_rd_pins[] = {
  1487. /* RD */
  1488. 96,
  1489. };
  1490. static const unsigned int bsc_rd_mux[] = {
  1491. RD__FSC_MARK,
  1492. };
  1493. static const unsigned int bsc_rdwr_0_pins[] = {
  1494. /* RDWR */
  1495. 91,
  1496. };
  1497. static const unsigned int bsc_rdwr_0_mux[] = {
  1498. PORT91_RDWR_MARK,
  1499. };
  1500. static const unsigned int bsc_rdwr_1_pins[] = {
  1501. /* RDWR */
  1502. 97,
  1503. };
  1504. static const unsigned int bsc_rdwr_1_mux[] = {
  1505. RDWR_FWE_MARK,
  1506. };
  1507. static const unsigned int bsc_rdwr_2_pins[] = {
  1508. /* RDWR */
  1509. 149,
  1510. };
  1511. static const unsigned int bsc_rdwr_2_mux[] = {
  1512. PORT149_RDWR_MARK,
  1513. };
  1514. static const unsigned int bsc_we0_pins[] = {
  1515. /* WE0 */
  1516. 97,
  1517. };
  1518. static const unsigned int bsc_we0_mux[] = {
  1519. WE0__FWE_MARK,
  1520. };
  1521. static const unsigned int bsc_we1_pins[] = {
  1522. /* WE1 */
  1523. 98,
  1524. };
  1525. static const unsigned int bsc_we1_mux[] = {
  1526. WE1__MARK,
  1527. };
  1528. /* - FSIA ------------------------------------------------------------------- */
  1529. static const unsigned int fsia_mclk_in_pins[] = {
  1530. /* CK */
  1531. 49,
  1532. };
  1533. static const unsigned int fsia_mclk_in_mux[] = {
  1534. FSIACK_MARK,
  1535. };
  1536. static const unsigned int fsia_mclk_out_pins[] = {
  1537. /* OMC */
  1538. 49,
  1539. };
  1540. static const unsigned int fsia_mclk_out_mux[] = {
  1541. FSIAOMC_MARK,
  1542. };
  1543. static const unsigned int fsia_sclk_in_pins[] = {
  1544. /* ILR, IBT */
  1545. 50, 51,
  1546. };
  1547. static const unsigned int fsia_sclk_in_mux[] = {
  1548. FSIAILR_MARK, FSIAIBT_MARK,
  1549. };
  1550. static const unsigned int fsia_sclk_out_pins[] = {
  1551. /* OLR, OBT */
  1552. 50, 51,
  1553. };
  1554. static const unsigned int fsia_sclk_out_mux[] = {
  1555. FSIAOLR_MARK, FSIAOBT_MARK,
  1556. };
  1557. static const unsigned int fsia_data_in_pins[] = {
  1558. /* ISLD */
  1559. 55,
  1560. };
  1561. static const unsigned int fsia_data_in_mux[] = {
  1562. FSIAISLD_MARK,
  1563. };
  1564. static const unsigned int fsia_data_out_pins[] = {
  1565. /* OSLD */
  1566. 52,
  1567. };
  1568. static const unsigned int fsia_data_out_mux[] = {
  1569. FSIAOSLD_MARK,
  1570. };
  1571. static const unsigned int fsia_spdif_pins[] = {
  1572. /* SPDIF */
  1573. 53,
  1574. };
  1575. static const unsigned int fsia_spdif_mux[] = {
  1576. FSIASPDIF_MARK,
  1577. };
  1578. /* - FSIB ------------------------------------------------------------------- */
  1579. static const unsigned int fsib_mclk_in_pins[] = {
  1580. /* CK */
  1581. 54,
  1582. };
  1583. static const unsigned int fsib_mclk_in_mux[] = {
  1584. FSIBCK_MARK,
  1585. };
  1586. static const unsigned int fsib_mclk_out_pins[] = {
  1587. /* OMC */
  1588. 54,
  1589. };
  1590. static const unsigned int fsib_mclk_out_mux[] = {
  1591. FSIBOMC_MARK,
  1592. };
  1593. static const unsigned int fsib_sclk_in_pins[] = {
  1594. /* ILR, IBT */
  1595. 37, 36,
  1596. };
  1597. static const unsigned int fsib_sclk_in_mux[] = {
  1598. FSIBILR_MARK, FSIBIBT_MARK,
  1599. };
  1600. static const unsigned int fsib_sclk_out_pins[] = {
  1601. /* OLR, OBT */
  1602. 37, 36,
  1603. };
  1604. static const unsigned int fsib_sclk_out_mux[] = {
  1605. FSIBOLR_MARK, FSIBOBT_MARK,
  1606. };
  1607. static const unsigned int fsib_data_in_pins[] = {
  1608. /* ISLD */
  1609. 39,
  1610. };
  1611. static const unsigned int fsib_data_in_mux[] = {
  1612. FSIBISLD_MARK,
  1613. };
  1614. static const unsigned int fsib_data_out_pins[] = {
  1615. /* OSLD */
  1616. 38,
  1617. };
  1618. static const unsigned int fsib_data_out_mux[] = {
  1619. FSIBOSLD_MARK,
  1620. };
  1621. static const unsigned int fsib_spdif_pins[] = {
  1622. /* SPDIF */
  1623. 53,
  1624. };
  1625. static const unsigned int fsib_spdif_mux[] = {
  1626. FSIBSPDIF_MARK,
  1627. };
  1628. /* - FSIC ------------------------------------------------------------------- */
  1629. static const unsigned int fsic_mclk_in_pins[] = {
  1630. /* CK */
  1631. 54,
  1632. };
  1633. static const unsigned int fsic_mclk_in_mux[] = {
  1634. FSICCK_MARK,
  1635. };
  1636. static const unsigned int fsic_mclk_out_pins[] = {
  1637. /* OMC */
  1638. 54,
  1639. };
  1640. static const unsigned int fsic_mclk_out_mux[] = {
  1641. FSICOMC_MARK,
  1642. };
  1643. static const unsigned int fsic_sclk_in_pins[] = {
  1644. /* ILR, IBT */
  1645. 46, 45,
  1646. };
  1647. static const unsigned int fsic_sclk_in_mux[] = {
  1648. FSICILR_MARK, FSICIBT_MARK,
  1649. };
  1650. static const unsigned int fsic_sclk_out_pins[] = {
  1651. /* OLR, OBT */
  1652. 46, 45,
  1653. };
  1654. static const unsigned int fsic_sclk_out_mux[] = {
  1655. FSICOLR_MARK, FSICOBT_MARK,
  1656. };
  1657. static const unsigned int fsic_data_in_pins[] = {
  1658. /* ISLD */
  1659. 48,
  1660. };
  1661. static const unsigned int fsic_data_in_mux[] = {
  1662. FSICISLD_MARK,
  1663. };
  1664. static const unsigned int fsic_data_out_pins[] = {
  1665. /* OSLD, OSLDT1, OSLDT2, OSLDT3 */
  1666. 47, 44, 42, 16,
  1667. };
  1668. static const unsigned int fsic_data_out_mux[] = {
  1669. FSICOSLD_MARK, FSICOSLDT1_MARK, FSICOSLDT2_MARK, FSICOSLDT3_MARK,
  1670. };
  1671. static const unsigned int fsic_spdif_0_pins[] = {
  1672. /* SPDIF */
  1673. 53,
  1674. };
  1675. static const unsigned int fsic_spdif_0_mux[] = {
  1676. PORT53_FSICSPDIF_MARK,
  1677. };
  1678. static const unsigned int fsic_spdif_1_pins[] = {
  1679. /* SPDIF */
  1680. 47,
  1681. };
  1682. static const unsigned int fsic_spdif_1_mux[] = {
  1683. PORT47_FSICSPDIF_MARK,
  1684. };
  1685. /* - FSID ------------------------------------------------------------------- */
  1686. static const unsigned int fsid_sclk_in_pins[] = {
  1687. /* ILR, IBT */
  1688. 46, 45,
  1689. };
  1690. static const unsigned int fsid_sclk_in_mux[] = {
  1691. FSIDILR_MARK, FSIDIBT_MARK,
  1692. };
  1693. static const unsigned int fsid_sclk_out_pins[] = {
  1694. /* OLR, OBT */
  1695. 46, 45,
  1696. };
  1697. static const unsigned int fsid_sclk_out_mux[] = {
  1698. FSIDOLR_MARK, FSIDOBT_MARK,
  1699. };
  1700. static const unsigned int fsid_data_in_pins[] = {
  1701. /* ISLD */
  1702. 48,
  1703. };
  1704. static const unsigned int fsid_data_in_mux[] = {
  1705. FSIDISLD_MARK,
  1706. };
  1707. /* - I2C2 ------------------------------------------------------------------- */
  1708. static const unsigned int i2c2_0_pins[] = {
  1709. /* SCL, SDA */
  1710. 237, 236,
  1711. };
  1712. static const unsigned int i2c2_0_mux[] = {
  1713. PORT237_I2C_SCL2_MARK, PORT236_I2C_SDA2_MARK,
  1714. };
  1715. static const unsigned int i2c2_1_pins[] = {
  1716. /* SCL, SDA */
  1717. 27, 28,
  1718. };
  1719. static const unsigned int i2c2_1_mux[] = {
  1720. PORT27_I2C_SCL2_MARK, PORT28_I2C_SDA2_MARK,
  1721. };
  1722. static const unsigned int i2c2_2_pins[] = {
  1723. /* SCL, SDA */
  1724. 115, 116,
  1725. };
  1726. static const unsigned int i2c2_2_mux[] = {
  1727. PORT115_I2C_SCL2_MARK, PORT116_I2C_SDA2_MARK,
  1728. };
  1729. /* - I2C3 ------------------------------------------------------------------- */
  1730. static const unsigned int i2c3_0_pins[] = {
  1731. /* SCL, SDA */
  1732. 248, 249,
  1733. };
  1734. static const unsigned int i2c3_0_mux[] = {
  1735. PORT248_I2C_SCL3_MARK, PORT249_I2C_SDA3_MARK,
  1736. };
  1737. static const unsigned int i2c3_1_pins[] = {
  1738. /* SCL, SDA */
  1739. 27, 28,
  1740. };
  1741. static const unsigned int i2c3_1_mux[] = {
  1742. PORT27_I2C_SCL3_MARK, PORT28_I2C_SDA3_MARK,
  1743. };
  1744. static const unsigned int i2c3_2_pins[] = {
  1745. /* SCL, SDA */
  1746. 115, 116,
  1747. };
  1748. static const unsigned int i2c3_2_mux[] = {
  1749. PORT115_I2C_SCL3_MARK, PORT116_I2C_SDA3_MARK,
  1750. };
  1751. /* - IrDA ------------------------------------------------------------------- */
  1752. static const unsigned int irda_0_pins[] = {
  1753. /* OUT, IN, FIRSEL */
  1754. 241, 242, 243,
  1755. };
  1756. static const unsigned int irda_0_mux[] = {
  1757. PORT241_IRDA_OUT_MARK, PORT242_IRDA_IN_MARK, PORT243_IRDA_FIRSEL_MARK,
  1758. };
  1759. static const unsigned int irda_1_pins[] = {
  1760. /* OUT, IN, FIRSEL */
  1761. 49, 53, 54,
  1762. };
  1763. static const unsigned int irda_1_mux[] = {
  1764. PORT49_IRDA_OUT_MARK, PORT53_IRDA_IN_MARK, PORT54_IRDA_FIRSEL_MARK,
  1765. };
  1766. /* - KEYSC ------------------------------------------------------------------ */
  1767. static const unsigned int keysc_in5_pins[] = {
  1768. /* KEYIN[0:4] */
  1769. 66, 67, 68, 69, 70,
  1770. };
  1771. static const unsigned int keysc_in5_mux[] = {
  1772. KEYIN0_MARK, KEYIN1_MARK, KEYIN2_MARK, KEYIN3_MARK,
  1773. KEYIN4_MARK,
  1774. };
  1775. static const unsigned int keysc_in6_pins[] = {
  1776. /* KEYIN[0:5] */
  1777. 66, 67, 68, 69, 70, 71,
  1778. };
  1779. static const unsigned int keysc_in6_mux[] = {
  1780. KEYIN0_MARK, KEYIN1_MARK, KEYIN2_MARK, KEYIN3_MARK,
  1781. KEYIN4_MARK, KEYIN5_MARK,
  1782. };
  1783. static const unsigned int keysc_in7_pins[] = {
  1784. /* KEYIN[0:6] */
  1785. 66, 67, 68, 69, 70, 71, 72,
  1786. };
  1787. static const unsigned int keysc_in7_mux[] = {
  1788. KEYIN0_MARK, KEYIN1_MARK, KEYIN2_MARK, KEYIN3_MARK,
  1789. KEYIN4_MARK, KEYIN5_MARK, KEYIN6_MARK,
  1790. };
  1791. static const unsigned int keysc_in8_pins[] = {
  1792. /* KEYIN[0:7] */
  1793. 66, 67, 68, 69, 70, 71, 72, 73,
  1794. };
  1795. static const unsigned int keysc_in8_mux[] = {
  1796. KEYIN0_MARK, KEYIN1_MARK, KEYIN2_MARK, KEYIN3_MARK,
  1797. KEYIN4_MARK, KEYIN5_MARK, KEYIN6_MARK, KEYIN7_MARK,
  1798. };
  1799. static const unsigned int keysc_out04_pins[] = {
  1800. /* KEYOUT[0:4] */
  1801. 65, 64, 63, 62, 61,
  1802. };
  1803. static const unsigned int keysc_out04_mux[] = {
  1804. KEYOUT0_MARK, KEYOUT1_MARK, KEYOUT2_MARK, KEYOUT3_MARK, KEYOUT4_MARK,
  1805. };
  1806. static const unsigned int keysc_out5_pins[] = {
  1807. /* KEYOUT5 */
  1808. 60,
  1809. };
  1810. static const unsigned int keysc_out5_mux[] = {
  1811. KEYOUT5_MARK,
  1812. };
  1813. static const unsigned int keysc_out6_0_pins[] = {
  1814. /* KEYOUT6 */
  1815. 59,
  1816. };
  1817. static const unsigned int keysc_out6_0_mux[] = {
  1818. PORT59_KEYOUT6_MARK,
  1819. };
  1820. static const unsigned int keysc_out6_1_pins[] = {
  1821. /* KEYOUT6 */
  1822. 131,
  1823. };
  1824. static const unsigned int keysc_out6_1_mux[] = {
  1825. PORT131_KEYOUT6_MARK,
  1826. };
  1827. static const unsigned int keysc_out6_2_pins[] = {
  1828. /* KEYOUT6 */
  1829. 143,
  1830. };
  1831. static const unsigned int keysc_out6_2_mux[] = {
  1832. PORT143_KEYOUT6_MARK,
  1833. };
  1834. static const unsigned int keysc_out7_0_pins[] = {
  1835. /* KEYOUT7 */
  1836. 58,
  1837. };
  1838. static const unsigned int keysc_out7_0_mux[] = {
  1839. PORT58_KEYOUT7_MARK,
  1840. };
  1841. static const unsigned int keysc_out7_1_pins[] = {
  1842. /* KEYOUT7 */
  1843. 132,
  1844. };
  1845. static const unsigned int keysc_out7_1_mux[] = {
  1846. PORT132_KEYOUT7_MARK,
  1847. };
  1848. static const unsigned int keysc_out7_2_pins[] = {
  1849. /* KEYOUT7 */
  1850. 144,
  1851. };
  1852. static const unsigned int keysc_out7_2_mux[] = {
  1853. PORT144_KEYOUT7_MARK,
  1854. };
  1855. static const unsigned int keysc_out8_0_pins[] = {
  1856. /* KEYOUT8 */
  1857. PIN_NUMBER(6, 26),
  1858. };
  1859. static const unsigned int keysc_out8_0_mux[] = {
  1860. KEYOUT8_MARK,
  1861. };
  1862. static const unsigned int keysc_out8_1_pins[] = {
  1863. /* KEYOUT8 */
  1864. 136,
  1865. };
  1866. static const unsigned int keysc_out8_1_mux[] = {
  1867. PORT136_KEYOUT8_MARK,
  1868. };
  1869. static const unsigned int keysc_out8_2_pins[] = {
  1870. /* KEYOUT8 */
  1871. 138,
  1872. };
  1873. static const unsigned int keysc_out8_2_mux[] = {
  1874. PORT138_KEYOUT8_MARK,
  1875. };
  1876. static const unsigned int keysc_out9_0_pins[] = {
  1877. /* KEYOUT9 */
  1878. 137,
  1879. };
  1880. static const unsigned int keysc_out9_0_mux[] = {
  1881. PORT137_KEYOUT9_MARK,
  1882. };
  1883. static const unsigned int keysc_out9_1_pins[] = {
  1884. /* KEYOUT9 */
  1885. 139,
  1886. };
  1887. static const unsigned int keysc_out9_1_mux[] = {
  1888. PORT139_KEYOUT9_MARK,
  1889. };
  1890. static const unsigned int keysc_out9_2_pins[] = {
  1891. /* KEYOUT9 */
  1892. 149,
  1893. };
  1894. static const unsigned int keysc_out9_2_mux[] = {
  1895. PORT149_KEYOUT9_MARK,
  1896. };
  1897. static const unsigned int keysc_out10_0_pins[] = {
  1898. /* KEYOUT10 */
  1899. 132,
  1900. };
  1901. static const unsigned int keysc_out10_0_mux[] = {
  1902. PORT132_KEYOUT10_MARK,
  1903. };
  1904. static const unsigned int keysc_out10_1_pins[] = {
  1905. /* KEYOUT10 */
  1906. 142,
  1907. };
  1908. static const unsigned int keysc_out10_1_mux[] = {
  1909. PORT142_KEYOUT10_MARK,
  1910. };
  1911. static const unsigned int keysc_out11_0_pins[] = {
  1912. /* KEYOUT11 */
  1913. 131,
  1914. };
  1915. static const unsigned int keysc_out11_0_mux[] = {
  1916. PORT131_KEYOUT11_MARK,
  1917. };
  1918. static const unsigned int keysc_out11_1_pins[] = {
  1919. /* KEYOUT11 */
  1920. 143,
  1921. };
  1922. static const unsigned int keysc_out11_1_mux[] = {
  1923. PORT143_KEYOUT11_MARK,
  1924. };
  1925. /* - LCD -------------------------------------------------------------------- */
  1926. static const unsigned int lcd_data8_pins[] = {
  1927. /* D[0:7] */
  1928. 192, 193, 194, 195, 196, 197, 198, 199,
  1929. };
  1930. static const unsigned int lcd_data8_mux[] = {
  1931. LCDD0_MARK, LCDD1_MARK, LCDD2_MARK, LCDD3_MARK,
  1932. LCDD4_MARK, LCDD5_MARK, LCDD6_MARK, LCDD7_MARK,
  1933. };
  1934. static const unsigned int lcd_data9_pins[] = {
  1935. /* D[0:8] */
  1936. 192, 193, 194, 195, 196, 197, 198, 199,
  1937. 200,
  1938. };
  1939. static const unsigned int lcd_data9_mux[] = {
  1940. LCDD0_MARK, LCDD1_MARK, LCDD2_MARK, LCDD3_MARK,
  1941. LCDD4_MARK, LCDD5_MARK, LCDD6_MARK, LCDD7_MARK,
  1942. LCDD8_MARK,
  1943. };
  1944. static const unsigned int lcd_data12_pins[] = {
  1945. /* D[0:11] */
  1946. 192, 193, 194, 195, 196, 197, 198, 199,
  1947. 200, 201, 202, 203,
  1948. };
  1949. static const unsigned int lcd_data12_mux[] = {
  1950. LCDD0_MARK, LCDD1_MARK, LCDD2_MARK, LCDD3_MARK,
  1951. LCDD4_MARK, LCDD5_MARK, LCDD6_MARK, LCDD7_MARK,
  1952. LCDD8_MARK, LCDD9_MARK, LCDD10_MARK, LCDD11_MARK,
  1953. };
  1954. static const unsigned int lcd_data16_pins[] = {
  1955. /* D[0:15] */
  1956. 192, 193, 194, 195, 196, 197, 198, 199,
  1957. 200, 201, 202, 203, 204, 205, 206, 207,
  1958. };
  1959. static const unsigned int lcd_data16_mux[] = {
  1960. LCDD0_MARK, LCDD1_MARK, LCDD2_MARK, LCDD3_MARK,
  1961. LCDD4_MARK, LCDD5_MARK, LCDD6_MARK, LCDD7_MARK,
  1962. LCDD8_MARK, LCDD9_MARK, LCDD10_MARK, LCDD11_MARK,
  1963. LCDD12_MARK, LCDD13_MARK, LCDD14_MARK, LCDD15_MARK,
  1964. };
  1965. static const unsigned int lcd_data18_pins[] = {
  1966. /* D[0:17] */
  1967. 192, 193, 194, 195, 196, 197, 198, 199,
  1968. 200, 201, 202, 203, 204, 205, 206, 207,
  1969. 208, 209,
  1970. };
  1971. static const unsigned int lcd_data18_mux[] = {
  1972. LCDD0_MARK, LCDD1_MARK, LCDD2_MARK, LCDD3_MARK,
  1973. LCDD4_MARK, LCDD5_MARK, LCDD6_MARK, LCDD7_MARK,
  1974. LCDD8_MARK, LCDD9_MARK, LCDD10_MARK, LCDD11_MARK,
  1975. LCDD12_MARK, LCDD13_MARK, LCDD14_MARK, LCDD15_MARK,
  1976. LCDD16_MARK, LCDD17_MARK,
  1977. };
  1978. static const unsigned int lcd_data24_pins[] = {
  1979. /* D[0:23] */
  1980. 192, 193, 194, 195, 196, 197, 198, 199,
  1981. 200, 201, 202, 203, 204, 205, 206, 207,
  1982. 208, 209, 210, 211, 212, 213, 214, 215
  1983. };
  1984. static const unsigned int lcd_data24_mux[] = {
  1985. LCDD0_MARK, LCDD1_MARK, LCDD2_MARK, LCDD3_MARK,
  1986. LCDD4_MARK, LCDD5_MARK, LCDD6_MARK, LCDD7_MARK,
  1987. LCDD8_MARK, LCDD9_MARK, LCDD10_MARK, LCDD11_MARK,
  1988. LCDD12_MARK, LCDD13_MARK, LCDD14_MARK, LCDD15_MARK,
  1989. LCDD16_MARK, LCDD17_MARK, LCDD18_MARK, LCDD19_MARK,
  1990. LCDD20_MARK, LCDD21_MARK, LCDD22_MARK, LCDD23_MARK,
  1991. };
  1992. static const unsigned int lcd_display_pins[] = {
  1993. /* DON */
  1994. 222,
  1995. };
  1996. static const unsigned int lcd_display_mux[] = {
  1997. LCDDON_MARK,
  1998. };
  1999. static const unsigned int lcd_lclk_pins[] = {
  2000. /* LCLK */
  2001. 221,
  2002. };
  2003. static const unsigned int lcd_lclk_mux[] = {
  2004. LCDLCLK_MARK,
  2005. };
  2006. static const unsigned int lcd_sync_pins[] = {
  2007. /* VSYN, HSYN, DCK, DISP */
  2008. 220, 218, 216, 219,
  2009. };
  2010. static const unsigned int lcd_sync_mux[] = {
  2011. LCDVSYN_MARK, LCDHSYN_MARK, LCDDCK_MARK, LCDDISP_MARK,
  2012. };
  2013. static const unsigned int lcd_sys_pins[] = {
  2014. /* CS, WR, RD, RS */
  2015. 218, 216, 217, 219,
  2016. };
  2017. static const unsigned int lcd_sys_mux[] = {
  2018. LCDCS__MARK, LCDWR__MARK, LCDRD__MARK, LCDRS_MARK,
  2019. };
  2020. /* - LCD2 ------------------------------------------------------------------- */
  2021. static const unsigned int lcd2_data8_pins[] = {
  2022. /* D[0:7] */
  2023. 128, 129, 142, 143, 144, 145, 138, 139,
  2024. };
  2025. static const unsigned int lcd2_data8_mux[] = {
  2026. LCD2D0_MARK, LCD2D1_MARK, LCD2D2_MARK, LCD2D3_MARK,
  2027. LCD2D4_MARK, LCD2D5_MARK, LCD2D6_MARK, LCD2D7_MARK,
  2028. };
  2029. static const unsigned int lcd2_data9_pins[] = {
  2030. /* D[0:8] */
  2031. 128, 129, 142, 143, 144, 145, 138, 139,
  2032. 140,
  2033. };
  2034. static const unsigned int lcd2_data9_mux[] = {
  2035. LCD2D0_MARK, LCD2D1_MARK, LCD2D2_MARK, LCD2D3_MARK,
  2036. LCD2D4_MARK, LCD2D5_MARK, LCD2D6_MARK, LCD2D7_MARK,
  2037. LCD2D8_MARK,
  2038. };
  2039. static const unsigned int lcd2_data12_pins[] = {
  2040. /* D[0:12] */
  2041. 128, 129, 142, 143, 144, 145, 138, 139,
  2042. 140, 141, 130, 131,
  2043. };
  2044. static const unsigned int lcd2_data12_mux[] = {
  2045. LCD2D0_MARK, LCD2D1_MARK, LCD2D2_MARK, LCD2D3_MARK,
  2046. LCD2D4_MARK, LCD2D5_MARK, LCD2D6_MARK, LCD2D7_MARK,
  2047. LCD2D8_MARK, LCD2D9_MARK, LCD2D10_MARK, LCD2D11_MARK,
  2048. };
  2049. static const unsigned int lcd2_data16_pins[] = {
  2050. /* D[0:15] */
  2051. 128, 129, 142, 143, 144, 145, 138, 139,
  2052. 140, 141, 130, 131, 132, 133, 134, 135,
  2053. };
  2054. static const unsigned int lcd2_data16_mux[] = {
  2055. LCD2D0_MARK, LCD2D1_MARK, LCD2D2_MARK, LCD2D3_MARK,
  2056. LCD2D4_MARK, LCD2D5_MARK, LCD2D6_MARK, LCD2D7_MARK,
  2057. LCD2D8_MARK, LCD2D9_MARK, LCD2D10_MARK, LCD2D11_MARK,
  2058. LCD2D12_MARK, LCD2D13_MARK, LCD2D14_MARK, LCD2D15_MARK,
  2059. };
  2060. static const unsigned int lcd2_data18_pins[] = {
  2061. /* D[0:17] */
  2062. 128, 129, 142, 143, 144, 145, 138, 139,
  2063. 140, 141, 130, 131, 132, 133, 134, 135,
  2064. 136, 137,
  2065. };
  2066. static const unsigned int lcd2_data18_mux[] = {
  2067. LCD2D0_MARK, LCD2D1_MARK, LCD2D2_MARK, LCD2D3_MARK,
  2068. LCD2D4_MARK, LCD2D5_MARK, LCD2D6_MARK, LCD2D7_MARK,
  2069. LCD2D8_MARK, LCD2D9_MARK, LCD2D10_MARK, LCD2D11_MARK,
  2070. LCD2D12_MARK, LCD2D13_MARK, LCD2D14_MARK, LCD2D15_MARK,
  2071. LCD2D16_MARK, LCD2D17_MARK,
  2072. };
  2073. static const unsigned int lcd2_data24_pins[] = {
  2074. /* D[0:23] */
  2075. 128, 129, 142, 143, 144, 145, 138, 139,
  2076. 140, 141, 130, 131, 132, 133, 134, 135,
  2077. 136, 137, 146, 147, 234, 235, 238, 239
  2078. };
  2079. static const unsigned int lcd2_data24_mux[] = {
  2080. LCD2D0_MARK, LCD2D1_MARK, LCD2D2_MARK, LCD2D3_MARK,
  2081. LCD2D4_MARK, LCD2D5_MARK, LCD2D6_MARK, LCD2D7_MARK,
  2082. LCD2D8_MARK, LCD2D9_MARK, LCD2D10_MARK, LCD2D11_MARK,
  2083. LCD2D12_MARK, LCD2D13_MARK, LCD2D14_MARK, LCD2D15_MARK,
  2084. LCD2D16_MARK, LCD2D17_MARK, LCD2D18_MARK, LCD2D19_MARK,
  2085. LCD2D20_MARK, LCD2D21_MARK, LCD2D22_MARK, LCD2D23_MARK,
  2086. };
  2087. static const unsigned int lcd2_sync_0_pins[] = {
  2088. /* VSYN, HSYN, DCK, DISP */
  2089. 128, 129, 146, 145,
  2090. };
  2091. static const unsigned int lcd2_sync_0_mux[] = {
  2092. PORT128_LCD2VSYN_MARK, PORT129_LCD2HSYN_MARK,
  2093. LCD2DCK_MARK, PORT145_LCD2DISP_MARK,
  2094. };
  2095. static const unsigned int lcd2_sync_1_pins[] = {
  2096. /* VSYN, HSYN, DCK, DISP */
  2097. 222, 221, 219, 217,
  2098. };
  2099. static const unsigned int lcd2_sync_1_mux[] = {
  2100. PORT222_LCD2VSYN_MARK, PORT221_LCD2HSYN_MARK,
  2101. LCD2DCK_2_MARK, PORT217_LCD2DISP_MARK,
  2102. };
  2103. static const unsigned int lcd2_sys_0_pins[] = {
  2104. /* CS, WR, RD, RS */
  2105. 129, 146, 147, 145,
  2106. };
  2107. static const unsigned int lcd2_sys_0_mux[] = {
  2108. PORT129_LCD2CS__MARK, PORT146_LCD2WR__MARK,
  2109. LCD2RD__MARK, PORT145_LCD2RS_MARK,
  2110. };
  2111. static const unsigned int lcd2_sys_1_pins[] = {
  2112. /* CS, WR, RD, RS */
  2113. 221, 219, 147, 217,
  2114. };
  2115. static const unsigned int lcd2_sys_1_mux[] = {
  2116. PORT221_LCD2CS__MARK, PORT219_LCD2WR__MARK,
  2117. LCD2RD__MARK, PORT217_LCD2RS_MARK,
  2118. };
  2119. /* - MMCIF ------------------------------------------------------------------ */
  2120. static const unsigned int mmc0_data1_0_pins[] = {
  2121. /* D[0] */
  2122. 271,
  2123. };
  2124. static const unsigned int mmc0_data1_0_mux[] = {
  2125. MMCD0_0_MARK,
  2126. };
  2127. static const unsigned int mmc0_data4_0_pins[] = {
  2128. /* D[0:3] */
  2129. 271, 272, 273, 274,
  2130. };
  2131. static const unsigned int mmc0_data4_0_mux[] = {
  2132. MMCD0_0_MARK, MMCD0_1_MARK, MMCD0_2_MARK, MMCD0_3_MARK,
  2133. };
  2134. static const unsigned int mmc0_data8_0_pins[] = {
  2135. /* D[0:7] */
  2136. 271, 272, 273, 274, 275, 276, 277, 278,
  2137. };
  2138. static const unsigned int mmc0_data8_0_mux[] = {
  2139. MMCD0_0_MARK, MMCD0_1_MARK, MMCD0_2_MARK, MMCD0_3_MARK,
  2140. MMCD0_4_MARK, MMCD0_5_MARK, MMCD0_6_MARK, MMCD0_7_MARK,
  2141. };
  2142. static const unsigned int mmc0_ctrl_0_pins[] = {
  2143. /* CMD, CLK */
  2144. 279, 270,
  2145. };
  2146. static const unsigned int mmc0_ctrl_0_mux[] = {
  2147. MMCCMD0_MARK, MMCCLK0_MARK,
  2148. };
  2149. static const unsigned int mmc0_data1_1_pins[] = {
  2150. /* D[0] */
  2151. 305,
  2152. };
  2153. static const unsigned int mmc0_data1_1_mux[] = {
  2154. MMCD1_0_MARK,
  2155. };
  2156. static const unsigned int mmc0_data4_1_pins[] = {
  2157. /* D[0:3] */
  2158. 305, 304, 303, 302,
  2159. };
  2160. static const unsigned int mmc0_data4_1_mux[] = {
  2161. MMCD1_0_MARK, MMCD1_1_MARK, MMCD1_2_MARK, MMCD1_3_MARK,
  2162. };
  2163. static const unsigned int mmc0_data8_1_pins[] = {
  2164. /* D[0:7] */
  2165. 305, 304, 303, 302, 301, 300, 299, 298,
  2166. };
  2167. static const unsigned int mmc0_data8_1_mux[] = {
  2168. MMCD1_0_MARK, MMCD1_1_MARK, MMCD1_2_MARK, MMCD1_3_MARK,
  2169. MMCD1_4_MARK, MMCD1_5_MARK, MMCD1_6_MARK, MMCD1_7_MARK,
  2170. };
  2171. static const unsigned int mmc0_ctrl_1_pins[] = {
  2172. /* CMD, CLK */
  2173. 297, 289,
  2174. };
  2175. static const unsigned int mmc0_ctrl_1_mux[] = {
  2176. MMCCMD1_MARK, MMCCLK1_MARK,
  2177. };
  2178. /* - SCIFA0 ----------------------------------------------------------------- */
  2179. static const unsigned int scifa0_data_pins[] = {
  2180. /* RXD, TXD */
  2181. 43, 17,
  2182. };
  2183. static const unsigned int scifa0_data_mux[] = {
  2184. SCIFA0_RXD_MARK, SCIFA0_TXD_MARK,
  2185. };
  2186. static const unsigned int scifa0_clk_pins[] = {
  2187. /* SCK */
  2188. 16,
  2189. };
  2190. static const unsigned int scifa0_clk_mux[] = {
  2191. SCIFA0_SCK_MARK,
  2192. };
  2193. static const unsigned int scifa0_ctrl_pins[] = {
  2194. /* RTS, CTS */
  2195. 42, 44,
  2196. };
  2197. static const unsigned int scifa0_ctrl_mux[] = {
  2198. SCIFA0_RTS__MARK, SCIFA0_CTS__MARK,
  2199. };
  2200. /* - SCIFA1 ----------------------------------------------------------------- */
  2201. static const unsigned int scifa1_data_pins[] = {
  2202. /* RXD, TXD */
  2203. 228, 225,
  2204. };
  2205. static const unsigned int scifa1_data_mux[] = {
  2206. SCIFA1_RXD_MARK, SCIFA1_TXD_MARK,
  2207. };
  2208. static const unsigned int scifa1_clk_pins[] = {
  2209. /* SCK */
  2210. 226,
  2211. };
  2212. static const unsigned int scifa1_clk_mux[] = {
  2213. SCIFA1_SCK_MARK,
  2214. };
  2215. static const unsigned int scifa1_ctrl_pins[] = {
  2216. /* RTS, CTS */
  2217. 227, 229,
  2218. };
  2219. static const unsigned int scifa1_ctrl_mux[] = {
  2220. SCIFA1_RTS__MARK, SCIFA1_CTS__MARK,
  2221. };
  2222. /* - SCIFA2 ----------------------------------------------------------------- */
  2223. static const unsigned int scifa2_data_0_pins[] = {
  2224. /* RXD, TXD */
  2225. 155, 154,
  2226. };
  2227. static const unsigned int scifa2_data_0_mux[] = {
  2228. SCIFA2_RXD1_MARK, SCIFA2_TXD1_MARK,
  2229. };
  2230. static const unsigned int scifa2_clk_0_pins[] = {
  2231. /* SCK */
  2232. 158,
  2233. };
  2234. static const unsigned int scifa2_clk_0_mux[] = {
  2235. SCIFA2_SCK1_MARK,
  2236. };
  2237. static const unsigned int scifa2_ctrl_0_pins[] = {
  2238. /* RTS, CTS */
  2239. 156, 157,
  2240. };
  2241. static const unsigned int scifa2_ctrl_0_mux[] = {
  2242. SCIFA2_RTS1__MARK, SCIFA2_CTS1__MARK,
  2243. };
  2244. static const unsigned int scifa2_data_1_pins[] = {
  2245. /* RXD, TXD */
  2246. 233, 230,
  2247. };
  2248. static const unsigned int scifa2_data_1_mux[] = {
  2249. SCIFA2_RXD2_MARK, SCIFA2_TXD2_MARK,
  2250. };
  2251. static const unsigned int scifa2_clk_1_pins[] = {
  2252. /* SCK */
  2253. 232,
  2254. };
  2255. static const unsigned int scifa2_clk_1_mux[] = {
  2256. SCIFA2_SCK2_MARK,
  2257. };
  2258. static const unsigned int scifa2_ctrl_1_pins[] = {
  2259. /* RTS, CTS */
  2260. 234, 231,
  2261. };
  2262. static const unsigned int scifa2_ctrl_1_mux[] = {
  2263. SCIFA2_RTS2__MARK, SCIFA2_CTS2__MARK,
  2264. };
  2265. /* - SCIFA3 ----------------------------------------------------------------- */
  2266. static const unsigned int scifa3_data_pins[] = {
  2267. /* RXD, TXD */
  2268. 108, 110,
  2269. };
  2270. static const unsigned int scifa3_data_mux[] = {
  2271. SCIFA3_RXD_MARK, SCIFA3_TXD_MARK,
  2272. };
  2273. static const unsigned int scifa3_ctrl_pins[] = {
  2274. /* RTS, CTS */
  2275. 109, 107,
  2276. };
  2277. static const unsigned int scifa3_ctrl_mux[] = {
  2278. SCIFA3_RTS__MARK, SCIFA3_CTS__MARK,
  2279. };
  2280. /* - SCIFA4 ----------------------------------------------------------------- */
  2281. static const unsigned int scifa4_data_pins[] = {
  2282. /* RXD, TXD */
  2283. 33, 32,
  2284. };
  2285. static const unsigned int scifa4_data_mux[] = {
  2286. SCIFA4_RXD_MARK, SCIFA4_TXD_MARK,
  2287. };
  2288. static const unsigned int scifa4_ctrl_pins[] = {
  2289. /* RTS, CTS */
  2290. 34, 35,
  2291. };
  2292. static const unsigned int scifa4_ctrl_mux[] = {
  2293. SCIFA4_RTS__MARK, SCIFA4_CTS__MARK,
  2294. };
  2295. /* - SCIFA5 ----------------------------------------------------------------- */
  2296. static const unsigned int scifa5_data_0_pins[] = {
  2297. /* RXD, TXD */
  2298. 246, 247,
  2299. };
  2300. static const unsigned int scifa5_data_0_mux[] = {
  2301. PORT246_SCIFA5_RXD_MARK, PORT247_SCIFA5_TXD_MARK,
  2302. };
  2303. static const unsigned int scifa5_clk_0_pins[] = {
  2304. /* SCK */
  2305. 248,
  2306. };
  2307. static const unsigned int scifa5_clk_0_mux[] = {
  2308. PORT248_SCIFA5_SCK_MARK,
  2309. };
  2310. static const unsigned int scifa5_ctrl_0_pins[] = {
  2311. /* RTS, CTS */
  2312. 245, 244,
  2313. };
  2314. static const unsigned int scifa5_ctrl_0_mux[] = {
  2315. PORT245_SCIFA5_RTS__MARK, PORT244_SCIFA5_CTS__MARK,
  2316. };
  2317. static const unsigned int scifa5_data_1_pins[] = {
  2318. /* RXD, TXD */
  2319. 195, 196,
  2320. };
  2321. static const unsigned int scifa5_data_1_mux[] = {
  2322. PORT195_SCIFA5_RXD_MARK, PORT196_SCIFA5_TXD_MARK,
  2323. };
  2324. static const unsigned int scifa5_clk_1_pins[] = {
  2325. /* SCK */
  2326. 197,
  2327. };
  2328. static const unsigned int scifa5_clk_1_mux[] = {
  2329. PORT197_SCIFA5_SCK_MARK,
  2330. };
  2331. static const unsigned int scifa5_ctrl_1_pins[] = {
  2332. /* RTS, CTS */
  2333. 194, 193,
  2334. };
  2335. static const unsigned int scifa5_ctrl_1_mux[] = {
  2336. PORT194_SCIFA5_RTS__MARK, PORT193_SCIFA5_CTS__MARK,
  2337. };
  2338. static const unsigned int scifa5_data_2_pins[] = {
  2339. /* RXD, TXD */
  2340. 162, 160,
  2341. };
  2342. static const unsigned int scifa5_data_2_mux[] = {
  2343. PORT162_SCIFA5_RXD_MARK, PORT160_SCIFA5_TXD_MARK,
  2344. };
  2345. static const unsigned int scifa5_clk_2_pins[] = {
  2346. /* SCK */
  2347. 159,
  2348. };
  2349. static const unsigned int scifa5_clk_2_mux[] = {
  2350. PORT159_SCIFA5_SCK_MARK,
  2351. };
  2352. static const unsigned int scifa5_ctrl_2_pins[] = {
  2353. /* RTS, CTS */
  2354. 163, 161,
  2355. };
  2356. static const unsigned int scifa5_ctrl_2_mux[] = {
  2357. PORT163_SCIFA5_RTS__MARK, PORT161_SCIFA5_CTS__MARK,
  2358. };
  2359. /* - SCIFA6 ----------------------------------------------------------------- */
  2360. static const unsigned int scifa6_pins[] = {
  2361. /* TXD */
  2362. 240,
  2363. };
  2364. static const unsigned int scifa6_mux[] = {
  2365. SCIFA6_TXD_MARK,
  2366. };
  2367. /* - SCIFA7 ----------------------------------------------------------------- */
  2368. static const unsigned int scifa7_data_pins[] = {
  2369. /* RXD, TXD */
  2370. 12, 18,
  2371. };
  2372. static const unsigned int scifa7_data_mux[] = {
  2373. SCIFA7_RXD_MARK, SCIFA7_TXD_MARK,
  2374. };
  2375. static const unsigned int scifa7_ctrl_pins[] = {
  2376. /* RTS, CTS */
  2377. 19, 13,
  2378. };
  2379. static const unsigned int scifa7_ctrl_mux[] = {
  2380. SCIFA7_RTS__MARK, SCIFA7_CTS__MARK,
  2381. };
  2382. /* - SCIFB ------------------------------------------------------------------ */
  2383. static const unsigned int scifb_data_0_pins[] = {
  2384. /* RXD, TXD */
  2385. 162, 160,
  2386. };
  2387. static const unsigned int scifb_data_0_mux[] = {
  2388. PORT162_SCIFB_RXD_MARK, PORT160_SCIFB_TXD_MARK,
  2389. };
  2390. static const unsigned int scifb_clk_0_pins[] = {
  2391. /* SCK */
  2392. 159,
  2393. };
  2394. static const unsigned int scifb_clk_0_mux[] = {
  2395. PORT159_SCIFB_SCK_MARK,
  2396. };
  2397. static const unsigned int scifb_ctrl_0_pins[] = {
  2398. /* RTS, CTS */
  2399. 163, 161,
  2400. };
  2401. static const unsigned int scifb_ctrl_0_mux[] = {
  2402. PORT163_SCIFB_RTS__MARK, PORT161_SCIFB_CTS__MARK,
  2403. };
  2404. static const unsigned int scifb_data_1_pins[] = {
  2405. /* RXD, TXD */
  2406. 246, 247,
  2407. };
  2408. static const unsigned int scifb_data_1_mux[] = {
  2409. PORT246_SCIFB_RXD_MARK, PORT247_SCIFB_TXD_MARK,
  2410. };
  2411. static const unsigned int scifb_clk_1_pins[] = {
  2412. /* SCK */
  2413. 248,
  2414. };
  2415. static const unsigned int scifb_clk_1_mux[] = {
  2416. PORT248_SCIFB_SCK_MARK,
  2417. };
  2418. static const unsigned int scifb_ctrl_1_pins[] = {
  2419. /* RTS, CTS */
  2420. 245, 244,
  2421. };
  2422. static const unsigned int scifb_ctrl_1_mux[] = {
  2423. PORT245_SCIFB_RTS__MARK, PORT244_SCIFB_CTS__MARK,
  2424. };
  2425. /* - SDHI0 ------------------------------------------------------------------ */
  2426. static const unsigned int sdhi0_data1_pins[] = {
  2427. /* D0 */
  2428. 252,
  2429. };
  2430. static const unsigned int sdhi0_data1_mux[] = {
  2431. SDHID0_0_MARK,
  2432. };
  2433. static const unsigned int sdhi0_data4_pins[] = {
  2434. /* D[0:3] */
  2435. 252, 253, 254, 255,
  2436. };
  2437. static const unsigned int sdhi0_data4_mux[] = {
  2438. SDHID0_0_MARK, SDHID0_1_MARK, SDHID0_2_MARK, SDHID0_3_MARK,
  2439. };
  2440. static const unsigned int sdhi0_ctrl_pins[] = {
  2441. /* CMD, CLK */
  2442. 256, 250,
  2443. };
  2444. static const unsigned int sdhi0_ctrl_mux[] = {
  2445. SDHICMD0_MARK, SDHICLK0_MARK,
  2446. };
  2447. static const unsigned int sdhi0_cd_pins[] = {
  2448. /* CD */
  2449. 251,
  2450. };
  2451. static const unsigned int sdhi0_cd_mux[] = {
  2452. SDHICD0_MARK,
  2453. };
  2454. static const unsigned int sdhi0_wp_pins[] = {
  2455. /* WP */
  2456. 257,
  2457. };
  2458. static const unsigned int sdhi0_wp_mux[] = {
  2459. SDHIWP0_MARK,
  2460. };
  2461. /* - SDHI1 ------------------------------------------------------------------ */
  2462. static const unsigned int sdhi1_data1_pins[] = {
  2463. /* D0 */
  2464. 259,
  2465. };
  2466. static const unsigned int sdhi1_data1_mux[] = {
  2467. SDHID1_0_MARK,
  2468. };
  2469. static const unsigned int sdhi1_data4_pins[] = {
  2470. /* D[0:3] */
  2471. 259, 260, 261, 262,
  2472. };
  2473. static const unsigned int sdhi1_data4_mux[] = {
  2474. SDHID1_0_MARK, SDHID1_1_MARK, SDHID1_2_MARK, SDHID1_3_MARK,
  2475. };
  2476. static const unsigned int sdhi1_ctrl_pins[] = {
  2477. /* CMD, CLK */
  2478. 263, 258,
  2479. };
  2480. static const unsigned int sdhi1_ctrl_mux[] = {
  2481. SDHICMD1_MARK, SDHICLK1_MARK,
  2482. };
  2483. /* - SDHI2 ------------------------------------------------------------------ */
  2484. static const unsigned int sdhi2_data1_pins[] = {
  2485. /* D0 */
  2486. 265,
  2487. };
  2488. static const unsigned int sdhi2_data1_mux[] = {
  2489. SDHID2_0_MARK,
  2490. };
  2491. static const unsigned int sdhi2_data4_pins[] = {
  2492. /* D[0:3] */
  2493. 265, 266, 267, 268,
  2494. };
  2495. static const unsigned int sdhi2_data4_mux[] = {
  2496. SDHID2_0_MARK, SDHID2_1_MARK, SDHID2_2_MARK, SDHID2_3_MARK,
  2497. };
  2498. static const unsigned int sdhi2_ctrl_pins[] = {
  2499. /* CMD, CLK */
  2500. 269, 264,
  2501. };
  2502. static const unsigned int sdhi2_ctrl_mux[] = {
  2503. SDHICMD2_MARK, SDHICLK2_MARK,
  2504. };
  2505. /* - USB -------------------------------------------------------------------- */
  2506. static const unsigned int usb_vbus_pins[] = {
  2507. /* VBUS */
  2508. 0,
  2509. };
  2510. static const unsigned int usb_vbus_mux[] = {
  2511. VBUS_0_MARK,
  2512. };
  2513. static const struct sh_pfc_pin_group pinmux_groups[] = {
  2514. SH_PFC_PIN_GROUP(bsc_data_0_7),
  2515. SH_PFC_PIN_GROUP(bsc_data_8_15),
  2516. SH_PFC_PIN_GROUP(bsc_cs4),
  2517. SH_PFC_PIN_GROUP(bsc_cs5_a),
  2518. SH_PFC_PIN_GROUP(bsc_cs5_b),
  2519. SH_PFC_PIN_GROUP(bsc_cs6_a),
  2520. SH_PFC_PIN_GROUP(bsc_cs6_b),
  2521. SH_PFC_PIN_GROUP(bsc_rd),
  2522. SH_PFC_PIN_GROUP(bsc_rdwr_0),
  2523. SH_PFC_PIN_GROUP(bsc_rdwr_1),
  2524. SH_PFC_PIN_GROUP(bsc_rdwr_2),
  2525. SH_PFC_PIN_GROUP(bsc_we0),
  2526. SH_PFC_PIN_GROUP(bsc_we1),
  2527. SH_PFC_PIN_GROUP(fsia_mclk_in),
  2528. SH_PFC_PIN_GROUP(fsia_mclk_out),
  2529. SH_PFC_PIN_GROUP(fsia_sclk_in),
  2530. SH_PFC_PIN_GROUP(fsia_sclk_out),
  2531. SH_PFC_PIN_GROUP(fsia_data_in),
  2532. SH_PFC_PIN_GROUP(fsia_data_out),
  2533. SH_PFC_PIN_GROUP(fsia_spdif),
  2534. SH_PFC_PIN_GROUP(fsib_mclk_in),
  2535. SH_PFC_PIN_GROUP(fsib_mclk_out),
  2536. SH_PFC_PIN_GROUP(fsib_sclk_in),
  2537. SH_PFC_PIN_GROUP(fsib_sclk_out),
  2538. SH_PFC_PIN_GROUP(fsib_data_in),
  2539. SH_PFC_PIN_GROUP(fsib_data_out),
  2540. SH_PFC_PIN_GROUP(fsib_spdif),
  2541. SH_PFC_PIN_GROUP(fsic_mclk_in),
  2542. SH_PFC_PIN_GROUP(fsic_mclk_out),
  2543. SH_PFC_PIN_GROUP(fsic_sclk_in),
  2544. SH_PFC_PIN_GROUP(fsic_sclk_out),
  2545. SH_PFC_PIN_GROUP(fsic_data_in),
  2546. SH_PFC_PIN_GROUP(fsic_data_out),
  2547. SH_PFC_PIN_GROUP(fsic_spdif_0),
  2548. SH_PFC_PIN_GROUP(fsic_spdif_1),
  2549. SH_PFC_PIN_GROUP(fsid_sclk_in),
  2550. SH_PFC_PIN_GROUP(fsid_sclk_out),
  2551. SH_PFC_PIN_GROUP(fsid_data_in),
  2552. SH_PFC_PIN_GROUP(i2c2_0),
  2553. SH_PFC_PIN_GROUP(i2c2_1),
  2554. SH_PFC_PIN_GROUP(i2c2_2),
  2555. SH_PFC_PIN_GROUP(i2c3_0),
  2556. SH_PFC_PIN_GROUP(i2c3_1),
  2557. SH_PFC_PIN_GROUP(i2c3_2),
  2558. SH_PFC_PIN_GROUP(irda_0),
  2559. SH_PFC_PIN_GROUP(irda_1),
  2560. SH_PFC_PIN_GROUP(keysc_in5),
  2561. SH_PFC_PIN_GROUP(keysc_in6),
  2562. SH_PFC_PIN_GROUP(keysc_in7),
  2563. SH_PFC_PIN_GROUP(keysc_in8),
  2564. SH_PFC_PIN_GROUP(keysc_out04),
  2565. SH_PFC_PIN_GROUP(keysc_out5),
  2566. SH_PFC_PIN_GROUP(keysc_out6_0),
  2567. SH_PFC_PIN_GROUP(keysc_out6_1),
  2568. SH_PFC_PIN_GROUP(keysc_out6_2),
  2569. SH_PFC_PIN_GROUP(keysc_out7_0),
  2570. SH_PFC_PIN_GROUP(keysc_out7_1),
  2571. SH_PFC_PIN_GROUP(keysc_out7_2),
  2572. SH_PFC_PIN_GROUP(keysc_out8_0),
  2573. SH_PFC_PIN_GROUP(keysc_out8_1),
  2574. SH_PFC_PIN_GROUP(keysc_out8_2),
  2575. SH_PFC_PIN_GROUP(keysc_out9_0),
  2576. SH_PFC_PIN_GROUP(keysc_out9_1),
  2577. SH_PFC_PIN_GROUP(keysc_out9_2),
  2578. SH_PFC_PIN_GROUP(keysc_out10_0),
  2579. SH_PFC_PIN_GROUP(keysc_out10_1),
  2580. SH_PFC_PIN_GROUP(keysc_out11_0),
  2581. SH_PFC_PIN_GROUP(keysc_out11_1),
  2582. SH_PFC_PIN_GROUP(lcd_data8),
  2583. SH_PFC_PIN_GROUP(lcd_data9),
  2584. SH_PFC_PIN_GROUP(lcd_data12),
  2585. SH_PFC_PIN_GROUP(lcd_data16),
  2586. SH_PFC_PIN_GROUP(lcd_data18),
  2587. SH_PFC_PIN_GROUP(lcd_data24),
  2588. SH_PFC_PIN_GROUP(lcd_display),
  2589. SH_PFC_PIN_GROUP(lcd_lclk),
  2590. SH_PFC_PIN_GROUP(lcd_sync),
  2591. SH_PFC_PIN_GROUP(lcd_sys),
  2592. SH_PFC_PIN_GROUP(lcd2_data8),
  2593. SH_PFC_PIN_GROUP(lcd2_data9),
  2594. SH_PFC_PIN_GROUP(lcd2_data12),
  2595. SH_PFC_PIN_GROUP(lcd2_data16),
  2596. SH_PFC_PIN_GROUP(lcd2_data18),
  2597. SH_PFC_PIN_GROUP(lcd2_data24),
  2598. SH_PFC_PIN_GROUP(lcd2_sync_0),
  2599. SH_PFC_PIN_GROUP(lcd2_sync_1),
  2600. SH_PFC_PIN_GROUP(lcd2_sys_0),
  2601. SH_PFC_PIN_GROUP(lcd2_sys_1),
  2602. SH_PFC_PIN_GROUP(mmc0_data1_0),
  2603. SH_PFC_PIN_GROUP(mmc0_data4_0),
  2604. SH_PFC_PIN_GROUP(mmc0_data8_0),
  2605. SH_PFC_PIN_GROUP(mmc0_ctrl_0),
  2606. SH_PFC_PIN_GROUP(mmc0_data1_1),
  2607. SH_PFC_PIN_GROUP(mmc0_data4_1),
  2608. SH_PFC_PIN_GROUP(mmc0_data8_1),
  2609. SH_PFC_PIN_GROUP(mmc0_ctrl_1),
  2610. SH_PFC_PIN_GROUP(scifa0_data),
  2611. SH_PFC_PIN_GROUP(scifa0_clk),
  2612. SH_PFC_PIN_GROUP(scifa0_ctrl),
  2613. SH_PFC_PIN_GROUP(scifa1_data),
  2614. SH_PFC_PIN_GROUP(scifa1_clk),
  2615. SH_PFC_PIN_GROUP(scifa1_ctrl),
  2616. SH_PFC_PIN_GROUP(scifa2_data_0),
  2617. SH_PFC_PIN_GROUP(scifa2_clk_0),
  2618. SH_PFC_PIN_GROUP(scifa2_ctrl_0),
  2619. SH_PFC_PIN_GROUP(scifa2_data_1),
  2620. SH_PFC_PIN_GROUP(scifa2_clk_1),
  2621. SH_PFC_PIN_GROUP(scifa2_ctrl_1),
  2622. SH_PFC_PIN_GROUP(scifa3_data),
  2623. SH_PFC_PIN_GROUP(scifa3_ctrl),
  2624. SH_PFC_PIN_GROUP(scifa4_data),
  2625. SH_PFC_PIN_GROUP(scifa4_ctrl),
  2626. SH_PFC_PIN_GROUP(scifa5_data_0),
  2627. SH_PFC_PIN_GROUP(scifa5_clk_0),
  2628. SH_PFC_PIN_GROUP(scifa5_ctrl_0),
  2629. SH_PFC_PIN_GROUP(scifa5_data_1),
  2630. SH_PFC_PIN_GROUP(scifa5_clk_1),
  2631. SH_PFC_PIN_GROUP(scifa5_ctrl_1),
  2632. SH_PFC_PIN_GROUP(scifa5_data_2),
  2633. SH_PFC_PIN_GROUP(scifa5_clk_2),
  2634. SH_PFC_PIN_GROUP(scifa5_ctrl_2),
  2635. SH_PFC_PIN_GROUP(scifa6),
  2636. SH_PFC_PIN_GROUP(scifa7_data),
  2637. SH_PFC_PIN_GROUP(scifa7_ctrl),
  2638. SH_PFC_PIN_GROUP(scifb_data_0),
  2639. SH_PFC_PIN_GROUP(scifb_clk_0),
  2640. SH_PFC_PIN_GROUP(scifb_ctrl_0),
  2641. SH_PFC_PIN_GROUP(scifb_data_1),
  2642. SH_PFC_PIN_GROUP(scifb_clk_1),
  2643. SH_PFC_PIN_GROUP(scifb_ctrl_1),
  2644. SH_PFC_PIN_GROUP(sdhi0_data1),
  2645. SH_PFC_PIN_GROUP(sdhi0_data4),
  2646. SH_PFC_PIN_GROUP(sdhi0_ctrl),
  2647. SH_PFC_PIN_GROUP(sdhi0_cd),
  2648. SH_PFC_PIN_GROUP(sdhi0_wp),
  2649. SH_PFC_PIN_GROUP(sdhi1_data1),
  2650. SH_PFC_PIN_GROUP(sdhi1_data4),
  2651. SH_PFC_PIN_GROUP(sdhi1_ctrl),
  2652. SH_PFC_PIN_GROUP(sdhi2_data1),
  2653. SH_PFC_PIN_GROUP(sdhi2_data4),
  2654. SH_PFC_PIN_GROUP(sdhi2_ctrl),
  2655. SH_PFC_PIN_GROUP(usb_vbus),
  2656. };
  2657. static const char * const bsc_groups[] = {
  2658. "bsc_data_0_7",
  2659. "bsc_data_8_15",
  2660. "bsc_cs4",
  2661. "bsc_cs5_a",
  2662. "bsc_cs5_b",
  2663. "bsc_cs6_a",
  2664. "bsc_cs6_b",
  2665. "bsc_rd",
  2666. "bsc_rdwr_0",
  2667. "bsc_rdwr_1",
  2668. "bsc_rdwr_2",
  2669. "bsc_we0",
  2670. "bsc_we1",
  2671. };
  2672. static const char * const fsia_groups[] = {
  2673. "fsia_mclk_in",
  2674. "fsia_mclk_out",
  2675. "fsia_sclk_in",
  2676. "fsia_sclk_out",
  2677. "fsia_data_in",
  2678. "fsia_data_out",
  2679. "fsia_spdif",
  2680. };
  2681. static const char * const fsib_groups[] = {
  2682. "fsib_mclk_in",
  2683. "fsib_mclk_out",
  2684. "fsib_sclk_in",
  2685. "fsib_sclk_out",
  2686. "fsib_data_in",
  2687. "fsib_data_out",
  2688. "fsib_spdif",
  2689. };
  2690. static const char * const fsic_groups[] = {
  2691. "fsic_mclk_in",
  2692. "fsic_mclk_out",
  2693. "fsic_sclk_in",
  2694. "fsic_sclk_out",
  2695. "fsic_data_in",
  2696. "fsic_data_out",
  2697. "fsic_spdif",
  2698. };
  2699. static const char * const fsid_groups[] = {
  2700. "fsid_sclk_in",
  2701. "fsid_sclk_out",
  2702. "fsid_data_in",
  2703. };
  2704. static const char * const i2c2_groups[] = {
  2705. "i2c2_0",
  2706. "i2c2_1",
  2707. "i2c2_2",
  2708. };
  2709. static const char * const i2c3_groups[] = {
  2710. "i2c3_0",
  2711. "i2c3_1",
  2712. "i2c3_2",
  2713. };
  2714. static const char * const irda_groups[] = {
  2715. "irda_0",
  2716. "irda_1",
  2717. };
  2718. static const char * const keysc_groups[] = {
  2719. "keysc_in5",
  2720. "keysc_in6",
  2721. "keysc_in7",
  2722. "keysc_in8",
  2723. "keysc_out04",
  2724. "keysc_out5",
  2725. "keysc_out6_0",
  2726. "keysc_out6_1",
  2727. "keysc_out6_2",
  2728. "keysc_out7_0",
  2729. "keysc_out7_1",
  2730. "keysc_out7_2",
  2731. "keysc_out8_0",
  2732. "keysc_out8_1",
  2733. "keysc_out8_2",
  2734. "keysc_out9_0",
  2735. "keysc_out9_1",
  2736. "keysc_out9_2",
  2737. "keysc_out10_0",
  2738. "keysc_out10_1",
  2739. "keysc_out11_0",
  2740. "keysc_out11_1",
  2741. };
  2742. static const char * const lcd_groups[] = {
  2743. "lcd_data8",
  2744. "lcd_data9",
  2745. "lcd_data12",
  2746. "lcd_data16",
  2747. "lcd_data18",
  2748. "lcd_data24",
  2749. "lcd_display",
  2750. "lcd_lclk",
  2751. "lcd_sync",
  2752. "lcd_sys",
  2753. };
  2754. static const char * const lcd2_groups[] = {
  2755. "lcd2_data8",
  2756. "lcd2_data9",
  2757. "lcd2_data12",
  2758. "lcd2_data16",
  2759. "lcd2_data18",
  2760. "lcd2_data24",
  2761. "lcd2_sync_0",
  2762. "lcd2_sync_1",
  2763. "lcd2_sys_0",
  2764. "lcd2_sys_1",
  2765. };
  2766. static const char * const mmc0_groups[] = {
  2767. "mmc0_data1_0",
  2768. "mmc0_data4_0",
  2769. "mmc0_data8_0",
  2770. "mmc0_ctrl_0",
  2771. "mmc0_data1_1",
  2772. "mmc0_data4_1",
  2773. "mmc0_data8_1",
  2774. "mmc0_ctrl_1",
  2775. };
  2776. static const char * const scifa0_groups[] = {
  2777. "scifa0_data",
  2778. "scifa0_clk",
  2779. "scifa0_ctrl",
  2780. };
  2781. static const char * const scifa1_groups[] = {
  2782. "scifa1_data",
  2783. "scifa1_clk",
  2784. "scifa1_ctrl",
  2785. };
  2786. static const char * const scifa2_groups[] = {
  2787. "scifa2_data_0",
  2788. "scifa2_clk_0",
  2789. "scifa2_ctrl_0",
  2790. "scifa2_data_1",
  2791. "scifa2_clk_1",
  2792. "scifa2_ctrl_1",
  2793. };
  2794. static const char * const scifa3_groups[] = {
  2795. "scifa3_data",
  2796. "scifa3_ctrl",
  2797. };
  2798. static const char * const scifa4_groups[] = {
  2799. "scifa4_data",
  2800. "scifa4_ctrl",
  2801. };
  2802. static const char * const scifa5_groups[] = {
  2803. "scifa5_data_0",
  2804. "scifa5_clk_0",
  2805. "scifa5_ctrl_0",
  2806. "scifa5_data_1",
  2807. "scifa5_clk_1",
  2808. "scifa5_ctrl_1",
  2809. "scifa5_data_2",
  2810. "scifa5_clk_2",
  2811. "scifa5_ctrl_2",
  2812. };
  2813. static const char * const scifa6_groups[] = {
  2814. "scifa6",
  2815. };
  2816. static const char * const scifa7_groups[] = {
  2817. "scifa7_data",
  2818. "scifa7_ctrl",
  2819. };
  2820. static const char * const scifb_groups[] = {
  2821. "scifb_data_0",
  2822. "scifb_clk_0",
  2823. "scifb_ctrl_0",
  2824. "scifb_data_1",
  2825. "scifb_clk_1",
  2826. "scifb_ctrl_1",
  2827. };
  2828. static const char * const sdhi0_groups[] = {
  2829. "sdhi0_data1",
  2830. "sdhi0_data4",
  2831. "sdhi0_ctrl",
  2832. "sdhi0_cd",
  2833. "sdhi0_wp",
  2834. };
  2835. static const char * const sdhi1_groups[] = {
  2836. "sdhi1_data1",
  2837. "sdhi1_data4",
  2838. "sdhi1_ctrl",
  2839. };
  2840. static const char * const sdhi2_groups[] = {
  2841. "sdhi2_data1",
  2842. "sdhi2_data4",
  2843. "sdhi2_ctrl",
  2844. };
  2845. static const char * const usb_groups[] = {
  2846. "usb_vbus",
  2847. };
  2848. static const struct sh_pfc_function pinmux_functions[] = {
  2849. SH_PFC_FUNCTION(bsc),
  2850. SH_PFC_FUNCTION(fsia),
  2851. SH_PFC_FUNCTION(fsib),
  2852. SH_PFC_FUNCTION(fsic),
  2853. SH_PFC_FUNCTION(fsid),
  2854. SH_PFC_FUNCTION(i2c2),
  2855. SH_PFC_FUNCTION(i2c3),
  2856. SH_PFC_FUNCTION(irda),
  2857. SH_PFC_FUNCTION(keysc),
  2858. SH_PFC_FUNCTION(lcd),
  2859. SH_PFC_FUNCTION(lcd2),
  2860. SH_PFC_FUNCTION(mmc0),
  2861. SH_PFC_FUNCTION(scifa0),
  2862. SH_PFC_FUNCTION(scifa1),
  2863. SH_PFC_FUNCTION(scifa2),
  2864. SH_PFC_FUNCTION(scifa3),
  2865. SH_PFC_FUNCTION(scifa4),
  2866. SH_PFC_FUNCTION(scifa5),
  2867. SH_PFC_FUNCTION(scifa6),
  2868. SH_PFC_FUNCTION(scifa7),
  2869. SH_PFC_FUNCTION(scifb),
  2870. SH_PFC_FUNCTION(sdhi0),
  2871. SH_PFC_FUNCTION(sdhi1),
  2872. SH_PFC_FUNCTION(sdhi2),
  2873. SH_PFC_FUNCTION(usb),
  2874. };
  2875. #define PINMUX_FN_BASE GPIO_FN_VBUS_0
  2876. static const struct pinmux_func pinmux_func_gpios[] = {
  2877. /* Table 25-1 (Functions 0-7) */
  2878. GPIO_FN(VBUS_0),
  2879. GPIO_FN(GPI0),
  2880. GPIO_FN(GPI1),
  2881. GPIO_FN(GPI2),
  2882. GPIO_FN(GPI3),
  2883. GPIO_FN(GPI4),
  2884. GPIO_FN(GPI5),
  2885. GPIO_FN(GPI6),
  2886. GPIO_FN(GPI7),
  2887. GPIO_FN(GPO7), \
  2888. GPIO_FN(MFG0_OUT2),
  2889. GPIO_FN(GPO6), \
  2890. GPIO_FN(MFG1_OUT2),
  2891. GPIO_FN(GPO5), \
  2892. GPIO_FN(PORT16_VIO_CKOR),
  2893. GPIO_FN(PORT19_VIO_CKO2),
  2894. GPIO_FN(GPO0),
  2895. GPIO_FN(GPO1),
  2896. GPIO_FN(GPO2), \
  2897. GPIO_FN(STATUS0),
  2898. GPIO_FN(GPO3), \
  2899. GPIO_FN(STATUS1),
  2900. GPIO_FN(GPO4), \
  2901. GPIO_FN(STATUS2),
  2902. GPIO_FN(VINT),
  2903. GPIO_FN(TCKON),
  2904. GPIO_FN(XDVFS1), \
  2905. GPIO_FN(MFG0_OUT1), \
  2906. GPIO_FN(PORT27_IROUT),
  2907. GPIO_FN(XDVFS2), \
  2908. GPIO_FN(PORT28_TPU1TO1),
  2909. GPIO_FN(SIM_RST), \
  2910. GPIO_FN(PORT29_TPU1TO1),
  2911. GPIO_FN(SIM_CLK), \
  2912. GPIO_FN(PORT30_VIO_CKOR),
  2913. GPIO_FN(SIM_D), \
  2914. GPIO_FN(PORT31_IROUT),
  2915. GPIO_FN(XWUP),
  2916. GPIO_FN(VACK),
  2917. GPIO_FN(XTAL1L),
  2918. GPIO_FN(PORT49_IRDA_OUT), \
  2919. GPIO_FN(PORT49_IROUT), \
  2920. GPIO_FN(BBIF2_TSYNC2), \
  2921. GPIO_FN(TPU2TO2), \
  2922. GPIO_FN(BBIF2_TSCK2), \
  2923. GPIO_FN(TPU2TO3), \
  2924. GPIO_FN(BBIF2_TXD2),
  2925. GPIO_FN(PORT53_IRDA_IN), \
  2926. GPIO_FN(TPU3TO3), \
  2927. GPIO_FN(PORT54_IRDA_FIRSEL), \
  2928. GPIO_FN(TPU3TO2), \
  2929. GPIO_FN(TPU0TO0),
  2930. GPIO_FN(A0), \
  2931. GPIO_FN(BS_),
  2932. GPIO_FN(A12), \
  2933. GPIO_FN(TPU4TO2),
  2934. GPIO_FN(A13), \
  2935. GPIO_FN(TPU0TO1),
  2936. GPIO_FN(A14), \
  2937. GPIO_FN(A15), \
  2938. GPIO_FN(A16), \
  2939. GPIO_FN(MSIOF0_SS1),
  2940. GPIO_FN(A17), \
  2941. GPIO_FN(MSIOF0_TSYNC),
  2942. GPIO_FN(A18), \
  2943. GPIO_FN(MSIOF0_TSCK),
  2944. GPIO_FN(A19), \
  2945. GPIO_FN(MSIOF0_TXD),
  2946. GPIO_FN(A20), \
  2947. GPIO_FN(MSIOF0_RSCK),
  2948. GPIO_FN(A21), \
  2949. GPIO_FN(MSIOF0_RSYNC),
  2950. GPIO_FN(A22), \
  2951. GPIO_FN(MSIOF0_MCK0),
  2952. GPIO_FN(A23), \
  2953. GPIO_FN(MSIOF0_MCK1),
  2954. GPIO_FN(A24), \
  2955. GPIO_FN(MSIOF0_RXD),
  2956. GPIO_FN(A25), \
  2957. GPIO_FN(MSIOF0_SS2),
  2958. GPIO_FN(A26), \
  2959. GPIO_FN(D0_NAF0),
  2960. GPIO_FN(D1_NAF1),
  2961. GPIO_FN(D2_NAF2),
  2962. GPIO_FN(D3_NAF3),
  2963. GPIO_FN(D4_NAF4),
  2964. GPIO_FN(D5_NAF5),
  2965. GPIO_FN(D6_NAF6),
  2966. GPIO_FN(D7_NAF7),
  2967. GPIO_FN(D8_NAF8),
  2968. GPIO_FN(D9_NAF9),
  2969. GPIO_FN(D10_NAF10),
  2970. GPIO_FN(D11_NAF11),
  2971. GPIO_FN(D12_NAF12),
  2972. GPIO_FN(D13_NAF13),
  2973. GPIO_FN(D14_NAF14),
  2974. GPIO_FN(D15_NAF15),
  2975. GPIO_FN(CS4_),
  2976. GPIO_FN(CS5A_), \
  2977. GPIO_FN(PORT91_RDWR),
  2978. GPIO_FN(CS5B_), \
  2979. GPIO_FN(FCE1_),
  2980. GPIO_FN(CS6B_), \
  2981. GPIO_FN(DACK0),
  2982. GPIO_FN(FCE0_), \
  2983. GPIO_FN(CS6A_),
  2984. GPIO_FN(WAIT_), \
  2985. GPIO_FN(DREQ0),
  2986. GPIO_FN(RD__FSC),
  2987. GPIO_FN(WE0__FWE), \
  2988. GPIO_FN(RDWR_FWE),
  2989. GPIO_FN(WE1_),
  2990. GPIO_FN(FRB),
  2991. GPIO_FN(CKO),
  2992. GPIO_FN(NBRSTOUT_),
  2993. GPIO_FN(NBRST_),
  2994. GPIO_FN(BBIF2_TXD),
  2995. GPIO_FN(BBIF2_RXD),
  2996. GPIO_FN(BBIF2_SYNC),
  2997. GPIO_FN(BBIF2_SCK),
  2998. GPIO_FN(MFG3_IN2),
  2999. GPIO_FN(MFG3_IN1),
  3000. GPIO_FN(BBIF1_SS2), \
  3001. GPIO_FN(MFG3_OUT1),
  3002. GPIO_FN(HSI_RX_DATA), \
  3003. GPIO_FN(BBIF1_RXD),
  3004. GPIO_FN(HSI_TX_WAKE), \
  3005. GPIO_FN(BBIF1_TSCK),
  3006. GPIO_FN(HSI_TX_DATA), \
  3007. GPIO_FN(BBIF1_TSYNC),
  3008. GPIO_FN(HSI_TX_READY), \
  3009. GPIO_FN(BBIF1_TXD),
  3010. GPIO_FN(HSI_RX_READY), \
  3011. GPIO_FN(BBIF1_RSCK), \
  3012. GPIO_FN(HSI_RX_WAKE), \
  3013. GPIO_FN(BBIF1_RSYNC), \
  3014. GPIO_FN(HSI_RX_FLAG), \
  3015. GPIO_FN(BBIF1_SS1), \
  3016. GPIO_FN(BBIF1_FLOW),
  3017. GPIO_FN(HSI_TX_FLAG),
  3018. GPIO_FN(VIO_VD), \
  3019. GPIO_FN(VIO2_VD), \
  3020. GPIO_FN(VIO_HD), \
  3021. GPIO_FN(VIO2_HD), \
  3022. GPIO_FN(VIO_D0), \
  3023. GPIO_FN(PORT130_MSIOF2_RXD), \
  3024. GPIO_FN(VIO_D1), \
  3025. GPIO_FN(PORT131_MSIOF2_SS1), \
  3026. GPIO_FN(VIO_D2), \
  3027. GPIO_FN(PORT132_MSIOF2_SS2), \
  3028. GPIO_FN(VIO_D3), \
  3029. GPIO_FN(MSIOF2_TSYNC), \
  3030. GPIO_FN(VIO_D4), \
  3031. GPIO_FN(MSIOF2_TXD), \
  3032. GPIO_FN(VIO_D5), \
  3033. GPIO_FN(MSIOF2_TSCK), \
  3034. GPIO_FN(VIO_D6), \
  3035. GPIO_FN(VIO_D7), \
  3036. GPIO_FN(VIO_D8), \
  3037. GPIO_FN(VIO2_D0), \
  3038. GPIO_FN(VIO_D9), \
  3039. GPIO_FN(VIO2_D1), \
  3040. GPIO_FN(VIO_D10), \
  3041. GPIO_FN(TPU0TO2), \
  3042. GPIO_FN(VIO2_D2), \
  3043. GPIO_FN(VIO_D11), \
  3044. GPIO_FN(TPU0TO3), \
  3045. GPIO_FN(VIO2_D3), \
  3046. GPIO_FN(VIO_D12), \
  3047. GPIO_FN(VIO2_D4), \
  3048. GPIO_FN(VIO_D13), \
  3049. GPIO_FN(VIO2_D5), \
  3050. GPIO_FN(VIO_D14), \
  3051. GPIO_FN(VIO2_D6), \
  3052. GPIO_FN(VIO_D15), \
  3053. GPIO_FN(TPU1TO3), \
  3054. GPIO_FN(VIO2_D7), \
  3055. GPIO_FN(VIO_CLK), \
  3056. GPIO_FN(VIO2_CLK), \
  3057. GPIO_FN(VIO_FIELD), \
  3058. GPIO_FN(VIO2_FIELD), \
  3059. GPIO_FN(VIO_CKO),
  3060. GPIO_FN(A27), \
  3061. GPIO_FN(PORT149_RDWR), \
  3062. GPIO_FN(MFG0_IN1), \
  3063. GPIO_FN(MFG0_IN2),
  3064. GPIO_FN(TS_SPSYNC3), \
  3065. GPIO_FN(MSIOF2_RSCK),
  3066. GPIO_FN(TS_SDAT3), \
  3067. GPIO_FN(MSIOF2_RSYNC),
  3068. GPIO_FN(TPU1TO2), \
  3069. GPIO_FN(TS_SDEN3), \
  3070. GPIO_FN(PORT153_MSIOF2_SS1),
  3071. GPIO_FN(MSIOF2_MCK0),
  3072. GPIO_FN(MSIOF2_MCK1),
  3073. GPIO_FN(PORT156_MSIOF2_SS2),
  3074. GPIO_FN(PORT157_MSIOF2_RXD),
  3075. GPIO_FN(DINT_), \
  3076. GPIO_FN(TS_SCK3),
  3077. GPIO_FN(NMI),
  3078. GPIO_FN(TPU3TO0),
  3079. GPIO_FN(BBIF2_TSYNC1),
  3080. GPIO_FN(BBIF2_TSCK1),
  3081. GPIO_FN(BBIF2_TXD1),
  3082. GPIO_FN(MFG2_OUT2), \
  3083. GPIO_FN(TPU2TO1),
  3084. GPIO_FN(TPU4TO1), \
  3085. GPIO_FN(MFG4_OUT2),
  3086. GPIO_FN(D16),
  3087. GPIO_FN(D17),
  3088. GPIO_FN(D18),
  3089. GPIO_FN(D19),
  3090. GPIO_FN(D20),
  3091. GPIO_FN(D21),
  3092. GPIO_FN(D22),
  3093. GPIO_FN(PORT207_MSIOF0L_SS1), \
  3094. GPIO_FN(D23),
  3095. GPIO_FN(PORT208_MSIOF0L_SS2), \
  3096. GPIO_FN(D24),
  3097. GPIO_FN(D25),
  3098. GPIO_FN(DREQ2), \
  3099. GPIO_FN(PORT210_MSIOF0L_SS1), \
  3100. GPIO_FN(D26),
  3101. GPIO_FN(PORT211_MSIOF0L_SS2), \
  3102. GPIO_FN(D27),
  3103. GPIO_FN(TS_SPSYNC1), \
  3104. GPIO_FN(MSIOF0L_MCK0), \
  3105. GPIO_FN(D28),
  3106. GPIO_FN(TS_SDAT1), \
  3107. GPIO_FN(MSIOF0L_MCK1), \
  3108. GPIO_FN(D29),
  3109. GPIO_FN(TS_SDEN1), \
  3110. GPIO_FN(MSIOF0L_RSCK), \
  3111. GPIO_FN(D30),
  3112. GPIO_FN(TS_SCK1), \
  3113. GPIO_FN(MSIOF0L_RSYNC), \
  3114. GPIO_FN(D31),
  3115. GPIO_FN(DACK2), \
  3116. GPIO_FN(MSIOF0L_TSYNC), \
  3117. GPIO_FN(VIO2_FIELD3), \
  3118. GPIO_FN(DACK3), \
  3119. GPIO_FN(PORT218_VIO_CKOR),
  3120. GPIO_FN(DREQ3), \
  3121. GPIO_FN(MSIOF0L_TSCK), \
  3122. GPIO_FN(VIO2_CLK3), \
  3123. GPIO_FN(DREQ1), \
  3124. GPIO_FN(PWEN), \
  3125. GPIO_FN(MSIOF0L_RXD), \
  3126. GPIO_FN(VIO2_HD3), \
  3127. GPIO_FN(DACK1), \
  3128. GPIO_FN(OVCN), \
  3129. GPIO_FN(MSIOF0L_TXD), \
  3130. GPIO_FN(VIO2_VD3), \
  3131. GPIO_FN(OVCN2),
  3132. GPIO_FN(EXTLP), \
  3133. GPIO_FN(PORT226_VIO_CKO2),
  3134. GPIO_FN(IDIN),
  3135. GPIO_FN(MFG1_IN1),
  3136. GPIO_FN(MSIOF1_TXD), \
  3137. GPIO_FN(MSIOF1_TSYNC), \
  3138. GPIO_FN(MSIOF1_TSCK), \
  3139. GPIO_FN(MSIOF1_RXD), \
  3140. GPIO_FN(MSIOF1_RSCK), \
  3141. GPIO_FN(VIO2_CLK2), \
  3142. GPIO_FN(MSIOF1_RSYNC), \
  3143. GPIO_FN(MFG1_IN2), \
  3144. GPIO_FN(VIO2_VD2), \
  3145. GPIO_FN(MSIOF1_MCK0), \
  3146. GPIO_FN(MSIOF1_MCK1), \
  3147. GPIO_FN(MSIOF1_SS1), \
  3148. GPIO_FN(VIO2_FIELD2), \
  3149. GPIO_FN(MSIOF1_SS2), \
  3150. GPIO_FN(VIO2_HD2), \
  3151. GPIO_FN(PORT241_IRDA_OUT), \
  3152. GPIO_FN(PORT241_IROUT), \
  3153. GPIO_FN(MFG4_OUT1), \
  3154. GPIO_FN(TPU4TO0),
  3155. GPIO_FN(PORT242_IRDA_IN), \
  3156. GPIO_FN(MFG4_IN2),
  3157. GPIO_FN(PORT243_IRDA_FIRSEL), \
  3158. GPIO_FN(PORT243_VIO_CKO2),
  3159. GPIO_FN(MFG2_IN1), \
  3160. GPIO_FN(MSIOF2R_RXD),
  3161. GPIO_FN(MFG2_IN2), \
  3162. GPIO_FN(MSIOF2R_TXD),
  3163. GPIO_FN(MFG1_OUT1), \
  3164. GPIO_FN(TPU1TO0),
  3165. GPIO_FN(MFG3_OUT2), \
  3166. GPIO_FN(TPU3TO1),
  3167. GPIO_FN(MFG2_OUT1), \
  3168. GPIO_FN(TPU2TO0), \
  3169. GPIO_FN(MSIOF2R_TSCK),
  3170. GPIO_FN(PORT249_IROUT), \
  3171. GPIO_FN(MFG4_IN1), \
  3172. GPIO_FN(MSIOF2R_TSYNC),
  3173. GPIO_FN(SDHICLK0),
  3174. GPIO_FN(SDHICD0),
  3175. GPIO_FN(SDHID0_0),
  3176. GPIO_FN(SDHID0_1),
  3177. GPIO_FN(SDHID0_2),
  3178. GPIO_FN(SDHID0_3),
  3179. GPIO_FN(SDHICMD0),
  3180. GPIO_FN(SDHIWP0),
  3181. GPIO_FN(SDHICLK1),
  3182. GPIO_FN(SDHID1_0), \
  3183. GPIO_FN(TS_SPSYNC2),
  3184. GPIO_FN(SDHID1_1), \
  3185. GPIO_FN(TS_SDAT2),
  3186. GPIO_FN(SDHID1_2), \
  3187. GPIO_FN(TS_SDEN2),
  3188. GPIO_FN(SDHID1_3), \
  3189. GPIO_FN(TS_SCK2),
  3190. GPIO_FN(SDHICMD1),
  3191. GPIO_FN(SDHICLK2),
  3192. GPIO_FN(SDHID2_0), \
  3193. GPIO_FN(TS_SPSYNC4),
  3194. GPIO_FN(SDHID2_1), \
  3195. GPIO_FN(TS_SDAT4),
  3196. GPIO_FN(SDHID2_2), \
  3197. GPIO_FN(TS_SDEN4),
  3198. GPIO_FN(SDHID2_3), \
  3199. GPIO_FN(TS_SCK4),
  3200. GPIO_FN(SDHICMD2),
  3201. GPIO_FN(MMCCLK0),
  3202. GPIO_FN(MMCD0_0),
  3203. GPIO_FN(MMCD0_1),
  3204. GPIO_FN(MMCD0_2),
  3205. GPIO_FN(MMCD0_3),
  3206. GPIO_FN(MMCD0_4), \
  3207. GPIO_FN(TS_SPSYNC5),
  3208. GPIO_FN(MMCD0_5), \
  3209. GPIO_FN(TS_SDAT5),
  3210. GPIO_FN(MMCD0_6), \
  3211. GPIO_FN(TS_SDEN5),
  3212. GPIO_FN(MMCD0_7), \
  3213. GPIO_FN(TS_SCK5),
  3214. GPIO_FN(MMCCMD0),
  3215. GPIO_FN(RESETOUTS_), \
  3216. GPIO_FN(EXTAL2OUT),
  3217. GPIO_FN(MCP_WAIT__MCP_FRB),
  3218. GPIO_FN(MCP_CKO), \
  3219. GPIO_FN(MMCCLK1),
  3220. GPIO_FN(MCP_D15_MCP_NAF15),
  3221. GPIO_FN(MCP_D14_MCP_NAF14),
  3222. GPIO_FN(MCP_D13_MCP_NAF13),
  3223. GPIO_FN(MCP_D12_MCP_NAF12),
  3224. GPIO_FN(MCP_D11_MCP_NAF11),
  3225. GPIO_FN(MCP_D10_MCP_NAF10),
  3226. GPIO_FN(MCP_D9_MCP_NAF9),
  3227. GPIO_FN(MCP_D8_MCP_NAF8), \
  3228. GPIO_FN(MMCCMD1),
  3229. GPIO_FN(MCP_D7_MCP_NAF7), \
  3230. GPIO_FN(MMCD1_7),
  3231. GPIO_FN(MCP_D6_MCP_NAF6), \
  3232. GPIO_FN(MMCD1_6),
  3233. GPIO_FN(MCP_D5_MCP_NAF5), \
  3234. GPIO_FN(MMCD1_5),
  3235. GPIO_FN(MCP_D4_MCP_NAF4), \
  3236. GPIO_FN(MMCD1_4),
  3237. GPIO_FN(MCP_D3_MCP_NAF3), \
  3238. GPIO_FN(MMCD1_3),
  3239. GPIO_FN(MCP_D2_MCP_NAF2), \
  3240. GPIO_FN(MMCD1_2),
  3241. GPIO_FN(MCP_D1_MCP_NAF1), \
  3242. GPIO_FN(MMCD1_1),
  3243. GPIO_FN(MCP_D0_MCP_NAF0), \
  3244. GPIO_FN(MMCD1_0),
  3245. GPIO_FN(MCP_NBRSTOUT_),
  3246. GPIO_FN(MCP_WE0__MCP_FWE), \
  3247. GPIO_FN(MCP_RDWR_MCP_FWE),
  3248. /* MSEL2 special cases */
  3249. GPIO_FN(TSIF2_TS_XX1),
  3250. GPIO_FN(TSIF2_TS_XX2),
  3251. GPIO_FN(TSIF2_TS_XX3),
  3252. GPIO_FN(TSIF2_TS_XX4),
  3253. GPIO_FN(TSIF2_TS_XX5),
  3254. GPIO_FN(TSIF1_TS_XX1),
  3255. GPIO_FN(TSIF1_TS_XX2),
  3256. GPIO_FN(TSIF1_TS_XX3),
  3257. GPIO_FN(TSIF1_TS_XX4),
  3258. GPIO_FN(TSIF1_TS_XX5),
  3259. GPIO_FN(TSIF0_TS_XX1),
  3260. GPIO_FN(TSIF0_TS_XX2),
  3261. GPIO_FN(TSIF0_TS_XX3),
  3262. GPIO_FN(TSIF0_TS_XX4),
  3263. GPIO_FN(TSIF0_TS_XX5),
  3264. GPIO_FN(MST1_TS_XX1),
  3265. GPIO_FN(MST1_TS_XX2),
  3266. GPIO_FN(MST1_TS_XX3),
  3267. GPIO_FN(MST1_TS_XX4),
  3268. GPIO_FN(MST1_TS_XX5),
  3269. GPIO_FN(MST0_TS_XX1),
  3270. GPIO_FN(MST0_TS_XX2),
  3271. GPIO_FN(MST0_TS_XX3),
  3272. GPIO_FN(MST0_TS_XX4),
  3273. GPIO_FN(MST0_TS_XX5),
  3274. /* MSEL3 special cases */
  3275. GPIO_FN(SDHI0_VCCQ_MC0_ON),
  3276. GPIO_FN(SDHI0_VCCQ_MC0_OFF),
  3277. GPIO_FN(DEBUG_MON_VIO),
  3278. GPIO_FN(DEBUG_MON_LCDD),
  3279. GPIO_FN(LCDC_LCDC0),
  3280. GPIO_FN(LCDC_LCDC1),
  3281. /* MSEL4 special cases */
  3282. GPIO_FN(IRQ9_MEM_INT),
  3283. GPIO_FN(IRQ9_MCP_INT),
  3284. GPIO_FN(A11),
  3285. GPIO_FN(TPU4TO3),
  3286. GPIO_FN(RESETA_N_PU_ON),
  3287. GPIO_FN(RESETA_N_PU_OFF),
  3288. GPIO_FN(EDBGREQ_PD),
  3289. GPIO_FN(EDBGREQ_PU),
  3290. };
  3291. #undef PORTCR
  3292. #define PORTCR(nr, reg) \
  3293. { \
  3294. PINMUX_CFG_REG("PORT" nr "CR", reg, 8, 4) { \
  3295. _PCRH(PORT##nr##_IN, 0, 0, PORT##nr##_OUT), \
  3296. PORT##nr##_FN0, PORT##nr##_FN1, \
  3297. PORT##nr##_FN2, PORT##nr##_FN3, \
  3298. PORT##nr##_FN4, PORT##nr##_FN5, \
  3299. PORT##nr##_FN6, PORT##nr##_FN7 } \
  3300. }
  3301. static const struct pinmux_cfg_reg pinmux_config_regs[] = {
  3302. PORTCR(0, 0xe6050000), /* PORT0CR */
  3303. PORTCR(1, 0xe6050001), /* PORT1CR */
  3304. PORTCR(2, 0xe6050002), /* PORT2CR */
  3305. PORTCR(3, 0xe6050003), /* PORT3CR */
  3306. PORTCR(4, 0xe6050004), /* PORT4CR */
  3307. PORTCR(5, 0xe6050005), /* PORT5CR */
  3308. PORTCR(6, 0xe6050006), /* PORT6CR */
  3309. PORTCR(7, 0xe6050007), /* PORT7CR */
  3310. PORTCR(8, 0xe6050008), /* PORT8CR */
  3311. PORTCR(9, 0xe6050009), /* PORT9CR */
  3312. PORTCR(10, 0xe605000a), /* PORT10CR */
  3313. PORTCR(11, 0xe605000b), /* PORT11CR */
  3314. PORTCR(12, 0xe605000c), /* PORT12CR */
  3315. PORTCR(13, 0xe605000d), /* PORT13CR */
  3316. PORTCR(14, 0xe605000e), /* PORT14CR */
  3317. PORTCR(15, 0xe605000f), /* PORT15CR */
  3318. PORTCR(16, 0xe6050010), /* PORT16CR */
  3319. PORTCR(17, 0xe6050011), /* PORT17CR */
  3320. PORTCR(18, 0xe6050012), /* PORT18CR */
  3321. PORTCR(19, 0xe6050013), /* PORT19CR */
  3322. PORTCR(20, 0xe6050014), /* PORT20CR */
  3323. PORTCR(21, 0xe6050015), /* PORT21CR */
  3324. PORTCR(22, 0xe6050016), /* PORT22CR */
  3325. PORTCR(23, 0xe6050017), /* PORT23CR */
  3326. PORTCR(24, 0xe6050018), /* PORT24CR */
  3327. PORTCR(25, 0xe6050019), /* PORT25CR */
  3328. PORTCR(26, 0xe605001a), /* PORT26CR */
  3329. PORTCR(27, 0xe605001b), /* PORT27CR */
  3330. PORTCR(28, 0xe605001c), /* PORT28CR */
  3331. PORTCR(29, 0xe605001d), /* PORT29CR */
  3332. PORTCR(30, 0xe605001e), /* PORT30CR */
  3333. PORTCR(31, 0xe605001f), /* PORT31CR */
  3334. PORTCR(32, 0xe6051020), /* PORT32CR */
  3335. PORTCR(33, 0xe6051021), /* PORT33CR */
  3336. PORTCR(34, 0xe6051022), /* PORT34CR */
  3337. PORTCR(35, 0xe6051023), /* PORT35CR */
  3338. PORTCR(36, 0xe6051024), /* PORT36CR */
  3339. PORTCR(37, 0xe6051025), /* PORT37CR */
  3340. PORTCR(38, 0xe6051026), /* PORT38CR */
  3341. PORTCR(39, 0xe6051027), /* PORT39CR */
  3342. PORTCR(40, 0xe6051028), /* PORT40CR */
  3343. PORTCR(41, 0xe6051029), /* PORT41CR */
  3344. PORTCR(42, 0xe605102a), /* PORT42CR */
  3345. PORTCR(43, 0xe605102b), /* PORT43CR */
  3346. PORTCR(44, 0xe605102c), /* PORT44CR */
  3347. PORTCR(45, 0xe605102d), /* PORT45CR */
  3348. PORTCR(46, 0xe605102e), /* PORT46CR */
  3349. PORTCR(47, 0xe605102f), /* PORT47CR */
  3350. PORTCR(48, 0xe6051030), /* PORT48CR */
  3351. PORTCR(49, 0xe6051031), /* PORT49CR */
  3352. PORTCR(50, 0xe6051032), /* PORT50CR */
  3353. PORTCR(51, 0xe6051033), /* PORT51CR */
  3354. PORTCR(52, 0xe6051034), /* PORT52CR */
  3355. PORTCR(53, 0xe6051035), /* PORT53CR */
  3356. PORTCR(54, 0xe6051036), /* PORT54CR */
  3357. PORTCR(55, 0xe6051037), /* PORT55CR */
  3358. PORTCR(56, 0xe6051038), /* PORT56CR */
  3359. PORTCR(57, 0xe6051039), /* PORT57CR */
  3360. PORTCR(58, 0xe605103a), /* PORT58CR */
  3361. PORTCR(59, 0xe605103b), /* PORT59CR */
  3362. PORTCR(60, 0xe605103c), /* PORT60CR */
  3363. PORTCR(61, 0xe605103d), /* PORT61CR */
  3364. PORTCR(62, 0xe605103e), /* PORT62CR */
  3365. PORTCR(63, 0xe605103f), /* PORT63CR */
  3366. PORTCR(64, 0xe6051040), /* PORT64CR */
  3367. PORTCR(65, 0xe6051041), /* PORT65CR */
  3368. PORTCR(66, 0xe6051042), /* PORT66CR */
  3369. PORTCR(67, 0xe6051043), /* PORT67CR */
  3370. PORTCR(68, 0xe6051044), /* PORT68CR */
  3371. PORTCR(69, 0xe6051045), /* PORT69CR */
  3372. PORTCR(70, 0xe6051046), /* PORT70CR */
  3373. PORTCR(71, 0xe6051047), /* PORT71CR */
  3374. PORTCR(72, 0xe6051048), /* PORT72CR */
  3375. PORTCR(73, 0xe6051049), /* PORT73CR */
  3376. PORTCR(74, 0xe605104a), /* PORT74CR */
  3377. PORTCR(75, 0xe605104b), /* PORT75CR */
  3378. PORTCR(76, 0xe605104c), /* PORT76CR */
  3379. PORTCR(77, 0xe605104d), /* PORT77CR */
  3380. PORTCR(78, 0xe605104e), /* PORT78CR */
  3381. PORTCR(79, 0xe605104f), /* PORT79CR */
  3382. PORTCR(80, 0xe6051050), /* PORT80CR */
  3383. PORTCR(81, 0xe6051051), /* PORT81CR */
  3384. PORTCR(82, 0xe6051052), /* PORT82CR */
  3385. PORTCR(83, 0xe6051053), /* PORT83CR */
  3386. PORTCR(84, 0xe6051054), /* PORT84CR */
  3387. PORTCR(85, 0xe6051055), /* PORT85CR */
  3388. PORTCR(86, 0xe6051056), /* PORT86CR */
  3389. PORTCR(87, 0xe6051057), /* PORT87CR */
  3390. PORTCR(88, 0xe6051058), /* PORT88CR */
  3391. PORTCR(89, 0xe6051059), /* PORT89CR */
  3392. PORTCR(90, 0xe605105a), /* PORT90CR */
  3393. PORTCR(91, 0xe605105b), /* PORT91CR */
  3394. PORTCR(92, 0xe605105c), /* PORT92CR */
  3395. PORTCR(93, 0xe605105d), /* PORT93CR */
  3396. PORTCR(94, 0xe605105e), /* PORT94CR */
  3397. PORTCR(95, 0xe605105f), /* PORT95CR */
  3398. PORTCR(96, 0xe6052060), /* PORT96CR */
  3399. PORTCR(97, 0xe6052061), /* PORT97CR */
  3400. PORTCR(98, 0xe6052062), /* PORT98CR */
  3401. PORTCR(99, 0xe6052063), /* PORT99CR */
  3402. PORTCR(100, 0xe6052064), /* PORT100CR */
  3403. PORTCR(101, 0xe6052065), /* PORT101CR */
  3404. PORTCR(102, 0xe6052066), /* PORT102CR */
  3405. PORTCR(103, 0xe6052067), /* PORT103CR */
  3406. PORTCR(104, 0xe6052068), /* PORT104CR */
  3407. PORTCR(105, 0xe6052069), /* PORT105CR */
  3408. PORTCR(106, 0xe605206a), /* PORT106CR */
  3409. PORTCR(107, 0xe605206b), /* PORT107CR */
  3410. PORTCR(108, 0xe605206c), /* PORT108CR */
  3411. PORTCR(109, 0xe605206d), /* PORT109CR */
  3412. PORTCR(110, 0xe605206e), /* PORT110CR */
  3413. PORTCR(111, 0xe605206f), /* PORT111CR */
  3414. PORTCR(112, 0xe6052070), /* PORT112CR */
  3415. PORTCR(113, 0xe6052071), /* PORT113CR */
  3416. PORTCR(114, 0xe6052072), /* PORT114CR */
  3417. PORTCR(115, 0xe6052073), /* PORT115CR */
  3418. PORTCR(116, 0xe6052074), /* PORT116CR */
  3419. PORTCR(117, 0xe6052075), /* PORT117CR */
  3420. PORTCR(118, 0xe6052076), /* PORT118CR */
  3421. PORTCR(128, 0xe6052080), /* PORT128CR */
  3422. PORTCR(129, 0xe6052081), /* PORT129CR */
  3423. PORTCR(130, 0xe6052082), /* PORT130CR */
  3424. PORTCR(131, 0xe6052083), /* PORT131CR */
  3425. PORTCR(132, 0xe6052084), /* PORT132CR */
  3426. PORTCR(133, 0xe6052085), /* PORT133CR */
  3427. PORTCR(134, 0xe6052086), /* PORT134CR */
  3428. PORTCR(135, 0xe6052087), /* PORT135CR */
  3429. PORTCR(136, 0xe6052088), /* PORT136CR */
  3430. PORTCR(137, 0xe6052089), /* PORT137CR */
  3431. PORTCR(138, 0xe605208a), /* PORT138CR */
  3432. PORTCR(139, 0xe605208b), /* PORT139CR */
  3433. PORTCR(140, 0xe605208c), /* PORT140CR */
  3434. PORTCR(141, 0xe605208d), /* PORT141CR */
  3435. PORTCR(142, 0xe605208e), /* PORT142CR */
  3436. PORTCR(143, 0xe605208f), /* PORT143CR */
  3437. PORTCR(144, 0xe6052090), /* PORT144CR */
  3438. PORTCR(145, 0xe6052091), /* PORT145CR */
  3439. PORTCR(146, 0xe6052092), /* PORT146CR */
  3440. PORTCR(147, 0xe6052093), /* PORT147CR */
  3441. PORTCR(148, 0xe6052094), /* PORT148CR */
  3442. PORTCR(149, 0xe6052095), /* PORT149CR */
  3443. PORTCR(150, 0xe6052096), /* PORT150CR */
  3444. PORTCR(151, 0xe6052097), /* PORT151CR */
  3445. PORTCR(152, 0xe6052098), /* PORT152CR */
  3446. PORTCR(153, 0xe6052099), /* PORT153CR */
  3447. PORTCR(154, 0xe605209a), /* PORT154CR */
  3448. PORTCR(155, 0xe605209b), /* PORT155CR */
  3449. PORTCR(156, 0xe605209c), /* PORT156CR */
  3450. PORTCR(157, 0xe605209d), /* PORT157CR */
  3451. PORTCR(158, 0xe605209e), /* PORT158CR */
  3452. PORTCR(159, 0xe605209f), /* PORT159CR */
  3453. PORTCR(160, 0xe60520a0), /* PORT160CR */
  3454. PORTCR(161, 0xe60520a1), /* PORT161CR */
  3455. PORTCR(162, 0xe60520a2), /* PORT162CR */
  3456. PORTCR(163, 0xe60520a3), /* PORT163CR */
  3457. PORTCR(164, 0xe60520a4), /* PORT164CR */
  3458. PORTCR(192, 0xe60520c0), /* PORT192CR */
  3459. PORTCR(193, 0xe60520c1), /* PORT193CR */
  3460. PORTCR(194, 0xe60520c2), /* PORT194CR */
  3461. PORTCR(195, 0xe60520c3), /* PORT195CR */
  3462. PORTCR(196, 0xe60520c4), /* PORT196CR */
  3463. PORTCR(197, 0xe60520c5), /* PORT197CR */
  3464. PORTCR(198, 0xe60520c6), /* PORT198CR */
  3465. PORTCR(199, 0xe60520c7), /* PORT199CR */
  3466. PORTCR(200, 0xe60520c8), /* PORT200CR */
  3467. PORTCR(201, 0xe60520c9), /* PORT201CR */
  3468. PORTCR(202, 0xe60520ca), /* PORT202CR */
  3469. PORTCR(203, 0xe60520cb), /* PORT203CR */
  3470. PORTCR(204, 0xe60520cc), /* PORT204CR */
  3471. PORTCR(205, 0xe60520cd), /* PORT205CR */
  3472. PORTCR(206, 0xe60520ce), /* PORT206CR */
  3473. PORTCR(207, 0xe60520cf), /* PORT207CR */
  3474. PORTCR(208, 0xe60520d0), /* PORT208CR */
  3475. PORTCR(209, 0xe60520d1), /* PORT209CR */
  3476. PORTCR(210, 0xe60520d2), /* PORT210CR */
  3477. PORTCR(211, 0xe60520d3), /* PORT211CR */
  3478. PORTCR(212, 0xe60520d4), /* PORT212CR */
  3479. PORTCR(213, 0xe60520d5), /* PORT213CR */
  3480. PORTCR(214, 0xe60520d6), /* PORT214CR */
  3481. PORTCR(215, 0xe60520d7), /* PORT215CR */
  3482. PORTCR(216, 0xe60520d8), /* PORT216CR */
  3483. PORTCR(217, 0xe60520d9), /* PORT217CR */
  3484. PORTCR(218, 0xe60520da), /* PORT218CR */
  3485. PORTCR(219, 0xe60520db), /* PORT219CR */
  3486. PORTCR(220, 0xe60520dc), /* PORT220CR */
  3487. PORTCR(221, 0xe60520dd), /* PORT221CR */
  3488. PORTCR(222, 0xe60520de), /* PORT222CR */
  3489. PORTCR(223, 0xe60520df), /* PORT223CR */
  3490. PORTCR(224, 0xe60530e0), /* PORT224CR */
  3491. PORTCR(225, 0xe60530e1), /* PORT225CR */
  3492. PORTCR(226, 0xe60530e2), /* PORT226CR */
  3493. PORTCR(227, 0xe60530e3), /* PORT227CR */
  3494. PORTCR(228, 0xe60530e4), /* PORT228CR */
  3495. PORTCR(229, 0xe60530e5), /* PORT229CR */
  3496. PORTCR(230, 0xe60530e6), /* PORT230CR */
  3497. PORTCR(231, 0xe60530e7), /* PORT231CR */
  3498. PORTCR(232, 0xe60530e8), /* PORT232CR */
  3499. PORTCR(233, 0xe60530e9), /* PORT233CR */
  3500. PORTCR(234, 0xe60530ea), /* PORT234CR */
  3501. PORTCR(235, 0xe60530eb), /* PORT235CR */
  3502. PORTCR(236, 0xe60530ec), /* PORT236CR */
  3503. PORTCR(237, 0xe60530ed), /* PORT237CR */
  3504. PORTCR(238, 0xe60530ee), /* PORT238CR */
  3505. PORTCR(239, 0xe60530ef), /* PORT239CR */
  3506. PORTCR(240, 0xe60530f0), /* PORT240CR */
  3507. PORTCR(241, 0xe60530f1), /* PORT241CR */
  3508. PORTCR(242, 0xe60530f2), /* PORT242CR */
  3509. PORTCR(243, 0xe60530f3), /* PORT243CR */
  3510. PORTCR(244, 0xe60530f4), /* PORT244CR */
  3511. PORTCR(245, 0xe60530f5), /* PORT245CR */
  3512. PORTCR(246, 0xe60530f6), /* PORT246CR */
  3513. PORTCR(247, 0xe60530f7), /* PORT247CR */
  3514. PORTCR(248, 0xe60530f8), /* PORT248CR */
  3515. PORTCR(249, 0xe60530f9), /* PORT249CR */
  3516. PORTCR(250, 0xe60530fa), /* PORT250CR */
  3517. PORTCR(251, 0xe60530fb), /* PORT251CR */
  3518. PORTCR(252, 0xe60530fc), /* PORT252CR */
  3519. PORTCR(253, 0xe60530fd), /* PORT253CR */
  3520. PORTCR(254, 0xe60530fe), /* PORT254CR */
  3521. PORTCR(255, 0xe60530ff), /* PORT255CR */
  3522. PORTCR(256, 0xe6053100), /* PORT256CR */
  3523. PORTCR(257, 0xe6053101), /* PORT257CR */
  3524. PORTCR(258, 0xe6053102), /* PORT258CR */
  3525. PORTCR(259, 0xe6053103), /* PORT259CR */
  3526. PORTCR(260, 0xe6053104), /* PORT260CR */
  3527. PORTCR(261, 0xe6053105), /* PORT261CR */
  3528. PORTCR(262, 0xe6053106), /* PORT262CR */
  3529. PORTCR(263, 0xe6053107), /* PORT263CR */
  3530. PORTCR(264, 0xe6053108), /* PORT264CR */
  3531. PORTCR(265, 0xe6053109), /* PORT265CR */
  3532. PORTCR(266, 0xe605310a), /* PORT266CR */
  3533. PORTCR(267, 0xe605310b), /* PORT267CR */
  3534. PORTCR(268, 0xe605310c), /* PORT268CR */
  3535. PORTCR(269, 0xe605310d), /* PORT269CR */
  3536. PORTCR(270, 0xe605310e), /* PORT270CR */
  3537. PORTCR(271, 0xe605310f), /* PORT271CR */
  3538. PORTCR(272, 0xe6053110), /* PORT272CR */
  3539. PORTCR(273, 0xe6053111), /* PORT273CR */
  3540. PORTCR(274, 0xe6053112), /* PORT274CR */
  3541. PORTCR(275, 0xe6053113), /* PORT275CR */
  3542. PORTCR(276, 0xe6053114), /* PORT276CR */
  3543. PORTCR(277, 0xe6053115), /* PORT277CR */
  3544. PORTCR(278, 0xe6053116), /* PORT278CR */
  3545. PORTCR(279, 0xe6053117), /* PORT279CR */
  3546. PORTCR(280, 0xe6053118), /* PORT280CR */
  3547. PORTCR(281, 0xe6053119), /* PORT281CR */
  3548. PORTCR(282, 0xe605311a), /* PORT282CR */
  3549. PORTCR(288, 0xe6052120), /* PORT288CR */
  3550. PORTCR(289, 0xe6052121), /* PORT289CR */
  3551. PORTCR(290, 0xe6052122), /* PORT290CR */
  3552. PORTCR(291, 0xe6052123), /* PORT291CR */
  3553. PORTCR(292, 0xe6052124), /* PORT292CR */
  3554. PORTCR(293, 0xe6052125), /* PORT293CR */
  3555. PORTCR(294, 0xe6052126), /* PORT294CR */
  3556. PORTCR(295, 0xe6052127), /* PORT295CR */
  3557. PORTCR(296, 0xe6052128), /* PORT296CR */
  3558. PORTCR(297, 0xe6052129), /* PORT297CR */
  3559. PORTCR(298, 0xe605212a), /* PORT298CR */
  3560. PORTCR(299, 0xe605212b), /* PORT299CR */
  3561. PORTCR(300, 0xe605212c), /* PORT300CR */
  3562. PORTCR(301, 0xe605212d), /* PORT301CR */
  3563. PORTCR(302, 0xe605212e), /* PORT302CR */
  3564. PORTCR(303, 0xe605212f), /* PORT303CR */
  3565. PORTCR(304, 0xe6052130), /* PORT304CR */
  3566. PORTCR(305, 0xe6052131), /* PORT305CR */
  3567. PORTCR(306, 0xe6052132), /* PORT306CR */
  3568. PORTCR(307, 0xe6052133), /* PORT307CR */
  3569. PORTCR(308, 0xe6052134), /* PORT308CR */
  3570. PORTCR(309, 0xe6052135), /* PORT309CR */
  3571. { PINMUX_CFG_REG("MSEL2CR", 0xe605801c, 32, 1) {
  3572. 0, 0,
  3573. 0, 0,
  3574. 0, 0,
  3575. 0, 0,
  3576. 0, 0,
  3577. 0, 0,
  3578. 0, 0,
  3579. 0, 0,
  3580. 0, 0,
  3581. 0, 0,
  3582. 0, 0,
  3583. 0, 0,
  3584. MSEL2CR_MSEL19_0, MSEL2CR_MSEL19_1,
  3585. MSEL2CR_MSEL18_0, MSEL2CR_MSEL18_1,
  3586. MSEL2CR_MSEL17_0, MSEL2CR_MSEL17_1,
  3587. MSEL2CR_MSEL16_0, MSEL2CR_MSEL16_1,
  3588. 0, 0,
  3589. MSEL2CR_MSEL14_0, MSEL2CR_MSEL14_1,
  3590. MSEL2CR_MSEL13_0, MSEL2CR_MSEL13_1,
  3591. MSEL2CR_MSEL12_0, MSEL2CR_MSEL12_1,
  3592. MSEL2CR_MSEL11_0, MSEL2CR_MSEL11_1,
  3593. MSEL2CR_MSEL10_0, MSEL2CR_MSEL10_1,
  3594. MSEL2CR_MSEL9_0, MSEL2CR_MSEL9_1,
  3595. MSEL2CR_MSEL8_0, MSEL2CR_MSEL8_1,
  3596. MSEL2CR_MSEL7_0, MSEL2CR_MSEL7_1,
  3597. MSEL2CR_MSEL6_0, MSEL2CR_MSEL6_1,
  3598. MSEL2CR_MSEL5_0, MSEL2CR_MSEL5_1,
  3599. MSEL2CR_MSEL4_0, MSEL2CR_MSEL4_1,
  3600. MSEL2CR_MSEL3_0, MSEL2CR_MSEL3_1,
  3601. MSEL2CR_MSEL2_0, MSEL2CR_MSEL2_1,
  3602. MSEL2CR_MSEL1_0, MSEL2CR_MSEL1_1,
  3603. MSEL2CR_MSEL0_0, MSEL2CR_MSEL0_1,
  3604. }
  3605. },
  3606. { PINMUX_CFG_REG("MSEL3CR", 0xe6058020, 32, 1) {
  3607. 0, 0,
  3608. 0, 0,
  3609. 0, 0,
  3610. MSEL3CR_MSEL28_0, MSEL3CR_MSEL28_1,
  3611. 0, 0,
  3612. 0, 0,
  3613. 0, 0,
  3614. 0, 0,
  3615. 0, 0,
  3616. 0, 0,
  3617. 0, 0,
  3618. 0, 0,
  3619. 0, 0,
  3620. 0, 0,
  3621. 0, 0,
  3622. 0, 0,
  3623. MSEL3CR_MSEL15_0, MSEL3CR_MSEL15_1,
  3624. 0, 0,
  3625. 0, 0,
  3626. 0, 0,
  3627. MSEL3CR_MSEL11_0, MSEL3CR_MSEL11_1,
  3628. 0, 0,
  3629. MSEL3CR_MSEL9_0, MSEL3CR_MSEL9_1,
  3630. 0, 0,
  3631. 0, 0,
  3632. MSEL3CR_MSEL6_0, MSEL3CR_MSEL6_1,
  3633. 0, 0,
  3634. 0, 0,
  3635. 0, 0,
  3636. MSEL3CR_MSEL2_0, MSEL3CR_MSEL2_1,
  3637. 0, 0,
  3638. 0, 0,
  3639. }
  3640. },
  3641. { PINMUX_CFG_REG("MSEL4CR", 0xe6058024, 32, 1) {
  3642. 0, 0,
  3643. 0, 0,
  3644. MSEL4CR_MSEL29_0, MSEL4CR_MSEL29_1,
  3645. 0, 0,
  3646. MSEL4CR_MSEL27_0, MSEL4CR_MSEL27_1,
  3647. MSEL4CR_MSEL26_0, MSEL4CR_MSEL26_1,
  3648. 0, 0,
  3649. 0, 0,
  3650. 0, 0,
  3651. MSEL4CR_MSEL22_0, MSEL4CR_MSEL22_1,
  3652. MSEL4CR_MSEL21_0, MSEL4CR_MSEL21_1,
  3653. MSEL4CR_MSEL20_0, MSEL4CR_MSEL20_1,
  3654. MSEL4CR_MSEL19_0, MSEL4CR_MSEL19_1,
  3655. 0, 0,
  3656. 0, 0,
  3657. 0, 0,
  3658. MSEL4CR_MSEL15_0, MSEL4CR_MSEL15_1,
  3659. 0, 0,
  3660. MSEL4CR_MSEL13_0, MSEL4CR_MSEL13_1,
  3661. MSEL4CR_MSEL12_0, MSEL4CR_MSEL12_1,
  3662. MSEL4CR_MSEL11_0, MSEL4CR_MSEL11_1,
  3663. MSEL4CR_MSEL10_0, MSEL4CR_MSEL10_1,
  3664. MSEL4CR_MSEL9_0, MSEL4CR_MSEL9_1,
  3665. MSEL4CR_MSEL8_0, MSEL4CR_MSEL8_1,
  3666. MSEL4CR_MSEL7_0, MSEL4CR_MSEL7_1,
  3667. 0, 0,
  3668. 0, 0,
  3669. MSEL4CR_MSEL4_0, MSEL4CR_MSEL4_1,
  3670. 0, 0,
  3671. 0, 0,
  3672. MSEL4CR_MSEL1_0, MSEL4CR_MSEL1_1,
  3673. 0, 0,
  3674. }
  3675. },
  3676. { },
  3677. };
  3678. static const struct pinmux_data_reg pinmux_data_regs[] = {
  3679. { PINMUX_DATA_REG("PORTL031_000DR", 0xe6054000, 32) {
  3680. PORT31_DATA, PORT30_DATA, PORT29_DATA, PORT28_DATA,
  3681. PORT27_DATA, PORT26_DATA, PORT25_DATA, PORT24_DATA,
  3682. PORT23_DATA, PORT22_DATA, PORT21_DATA, PORT20_DATA,
  3683. PORT19_DATA, PORT18_DATA, PORT17_DATA, PORT16_DATA,
  3684. PORT15_DATA, PORT14_DATA, PORT13_DATA, PORT12_DATA,
  3685. PORT11_DATA, PORT10_DATA, PORT9_DATA, PORT8_DATA,
  3686. PORT7_DATA, PORT6_DATA, PORT5_DATA, PORT4_DATA,
  3687. PORT3_DATA, PORT2_DATA, PORT1_DATA, PORT0_DATA }
  3688. },
  3689. { PINMUX_DATA_REG("PORTD063_032DR", 0xe6055000, 32) {
  3690. PORT63_DATA, PORT62_DATA, PORT61_DATA, PORT60_DATA,
  3691. PORT59_DATA, PORT58_DATA, PORT57_DATA, PORT56_DATA,
  3692. PORT55_DATA, PORT54_DATA, PORT53_DATA, PORT52_DATA,
  3693. PORT51_DATA, PORT50_DATA, PORT49_DATA, PORT48_DATA,
  3694. PORT47_DATA, PORT46_DATA, PORT45_DATA, PORT44_DATA,
  3695. PORT43_DATA, PORT42_DATA, PORT41_DATA, PORT40_DATA,
  3696. PORT39_DATA, PORT38_DATA, PORT37_DATA, PORT36_DATA,
  3697. PORT35_DATA, PORT34_DATA, PORT33_DATA, PORT32_DATA }
  3698. },
  3699. { PINMUX_DATA_REG("PORTD095_064DR", 0xe6055004, 32) {
  3700. PORT95_DATA, PORT94_DATA, PORT93_DATA, PORT92_DATA,
  3701. PORT91_DATA, PORT90_DATA, PORT89_DATA, PORT88_DATA,
  3702. PORT87_DATA, PORT86_DATA, PORT85_DATA, PORT84_DATA,
  3703. PORT83_DATA, PORT82_DATA, PORT81_DATA, PORT80_DATA,
  3704. PORT79_DATA, PORT78_DATA, PORT77_DATA, PORT76_DATA,
  3705. PORT75_DATA, PORT74_DATA, PORT73_DATA, PORT72_DATA,
  3706. PORT71_DATA, PORT70_DATA, PORT69_DATA, PORT68_DATA,
  3707. PORT67_DATA, PORT66_DATA, PORT65_DATA, PORT64_DATA }
  3708. },
  3709. { PINMUX_DATA_REG("PORTR127_096DR", 0xe6056000, 32) {
  3710. 0, 0, 0, 0,
  3711. 0, 0, 0, 0,
  3712. 0, PORT118_DATA, PORT117_DATA, PORT116_DATA,
  3713. PORT115_DATA, PORT114_DATA, PORT113_DATA, PORT112_DATA,
  3714. PORT111_DATA, PORT110_DATA, PORT109_DATA, PORT108_DATA,
  3715. PORT107_DATA, PORT106_DATA, PORT105_DATA, PORT104_DATA,
  3716. PORT103_DATA, PORT102_DATA, PORT101_DATA, PORT100_DATA,
  3717. PORT99_DATA, PORT98_DATA, PORT97_DATA, PORT96_DATA }
  3718. },
  3719. { PINMUX_DATA_REG("PORTR159_128DR", 0xe6056004, 32) {
  3720. PORT159_DATA, PORT158_DATA, PORT157_DATA, PORT156_DATA,
  3721. PORT155_DATA, PORT154_DATA, PORT153_DATA, PORT152_DATA,
  3722. PORT151_DATA, PORT150_DATA, PORT149_DATA, PORT148_DATA,
  3723. PORT147_DATA, PORT146_DATA, PORT145_DATA, PORT144_DATA,
  3724. PORT143_DATA, PORT142_DATA, PORT141_DATA, PORT140_DATA,
  3725. PORT139_DATA, PORT138_DATA, PORT137_DATA, PORT136_DATA,
  3726. PORT135_DATA, PORT134_DATA, PORT133_DATA, PORT132_DATA,
  3727. PORT131_DATA, PORT130_DATA, PORT129_DATA, PORT128_DATA }
  3728. },
  3729. { PINMUX_DATA_REG("PORTR191_160DR", 0xe6056008, 32) {
  3730. 0, 0, 0, 0,
  3731. 0, 0, 0, 0,
  3732. 0, 0, 0, 0,
  3733. 0, 0, 0, 0,
  3734. 0, 0, 0, 0,
  3735. 0, 0, 0, 0,
  3736. 0, 0, 0, PORT164_DATA,
  3737. PORT163_DATA, PORT162_DATA, PORT161_DATA, PORT160_DATA }
  3738. },
  3739. { PINMUX_DATA_REG("PORTR223_192DR", 0xe605600C, 32) {
  3740. PORT223_DATA, PORT222_DATA, PORT221_DATA, PORT220_DATA,
  3741. PORT219_DATA, PORT218_DATA, PORT217_DATA, PORT216_DATA,
  3742. PORT215_DATA, PORT214_DATA, PORT213_DATA, PORT212_DATA,
  3743. PORT211_DATA, PORT210_DATA, PORT209_DATA, PORT208_DATA,
  3744. PORT207_DATA, PORT206_DATA, PORT205_DATA, PORT204_DATA,
  3745. PORT203_DATA, PORT202_DATA, PORT201_DATA, PORT200_DATA,
  3746. PORT199_DATA, PORT198_DATA, PORT197_DATA, PORT196_DATA,
  3747. PORT195_DATA, PORT194_DATA, PORT193_DATA, PORT192_DATA }
  3748. },
  3749. { PINMUX_DATA_REG("PORTU255_224DR", 0xe6057000, 32) {
  3750. PORT255_DATA, PORT254_DATA, PORT253_DATA, PORT252_DATA,
  3751. PORT251_DATA, PORT250_DATA, PORT249_DATA, PORT248_DATA,
  3752. PORT247_DATA, PORT246_DATA, PORT245_DATA, PORT244_DATA,
  3753. PORT243_DATA, PORT242_DATA, PORT241_DATA, PORT240_DATA,
  3754. PORT239_DATA, PORT238_DATA, PORT237_DATA, PORT236_DATA,
  3755. PORT235_DATA, PORT234_DATA, PORT233_DATA, PORT232_DATA,
  3756. PORT231_DATA, PORT230_DATA, PORT229_DATA, PORT228_DATA,
  3757. PORT227_DATA, PORT226_DATA, PORT225_DATA, PORT224_DATA }
  3758. },
  3759. { PINMUX_DATA_REG("PORTU287_256DR", 0xe6057004, 32) {
  3760. 0, 0, 0, 0,
  3761. 0, PORT282_DATA, PORT281_DATA, PORT280_DATA,
  3762. PORT279_DATA, PORT278_DATA, PORT277_DATA, PORT276_DATA,
  3763. PORT275_DATA, PORT274_DATA, PORT273_DATA, PORT272_DATA,
  3764. PORT271_DATA, PORT270_DATA, PORT269_DATA, PORT268_DATA,
  3765. PORT267_DATA, PORT266_DATA, PORT265_DATA, PORT264_DATA,
  3766. PORT263_DATA, PORT262_DATA, PORT261_DATA, PORT260_DATA,
  3767. PORT259_DATA, PORT258_DATA, PORT257_DATA, PORT256_DATA }
  3768. },
  3769. { PINMUX_DATA_REG("PORTR319_288DR", 0xe6056010, 32) {
  3770. 0, 0, 0, 0,
  3771. 0, 0, 0, 0,
  3772. 0, 0, PORT309_DATA, PORT308_DATA,
  3773. PORT307_DATA, PORT306_DATA, PORT305_DATA, PORT304_DATA,
  3774. PORT303_DATA, PORT302_DATA, PORT301_DATA, PORT300_DATA,
  3775. PORT299_DATA, PORT298_DATA, PORT297_DATA, PORT296_DATA,
  3776. PORT295_DATA, PORT294_DATA, PORT293_DATA, PORT292_DATA,
  3777. PORT291_DATA, PORT290_DATA, PORT289_DATA, PORT288_DATA }
  3778. },
  3779. { },
  3780. };
  3781. /* IRQ pins through INTCS with IRQ0->15 from 0x200 and IRQ16-31 from 0x3200 */
  3782. #define EXT_IRQ16L(n) intcs_evt2irq(0x200 + ((n) << 5))
  3783. #define EXT_IRQ16H(n) intcs_evt2irq(0x3200 + ((n - 16) << 5))
  3784. static const struct pinmux_irq pinmux_irqs[] = {
  3785. PINMUX_IRQ(EXT_IRQ16H(19), 9),
  3786. PINMUX_IRQ(EXT_IRQ16L(1), 10),
  3787. PINMUX_IRQ(EXT_IRQ16L(0), 11),
  3788. PINMUX_IRQ(EXT_IRQ16H(18), 13),
  3789. PINMUX_IRQ(EXT_IRQ16H(20), 14),
  3790. PINMUX_IRQ(EXT_IRQ16H(21), 15),
  3791. PINMUX_IRQ(EXT_IRQ16H(31), 26),
  3792. PINMUX_IRQ(EXT_IRQ16H(30), 27),
  3793. PINMUX_IRQ(EXT_IRQ16H(29), 28),
  3794. PINMUX_IRQ(EXT_IRQ16H(22), 40),
  3795. PINMUX_IRQ(EXT_IRQ16H(23), 53),
  3796. PINMUX_IRQ(EXT_IRQ16L(10), 54),
  3797. PINMUX_IRQ(EXT_IRQ16L(9), 56),
  3798. PINMUX_IRQ(EXT_IRQ16H(26), 115),
  3799. PINMUX_IRQ(EXT_IRQ16H(27), 116),
  3800. PINMUX_IRQ(EXT_IRQ16H(28), 117),
  3801. PINMUX_IRQ(EXT_IRQ16H(24), 118),
  3802. PINMUX_IRQ(EXT_IRQ16L(6), 147),
  3803. PINMUX_IRQ(EXT_IRQ16L(2), 149),
  3804. PINMUX_IRQ(EXT_IRQ16L(7), 150),
  3805. PINMUX_IRQ(EXT_IRQ16L(12), 156),
  3806. PINMUX_IRQ(EXT_IRQ16L(4), 159),
  3807. PINMUX_IRQ(EXT_IRQ16H(25), 164),
  3808. PINMUX_IRQ(EXT_IRQ16L(8), 223),
  3809. PINMUX_IRQ(EXT_IRQ16L(3), 224),
  3810. PINMUX_IRQ(EXT_IRQ16L(5), 227),
  3811. PINMUX_IRQ(EXT_IRQ16H(17), 234),
  3812. PINMUX_IRQ(EXT_IRQ16L(11), 238),
  3813. PINMUX_IRQ(EXT_IRQ16L(13), 239),
  3814. PINMUX_IRQ(EXT_IRQ16H(16), 249),
  3815. PINMUX_IRQ(EXT_IRQ16L(14), 251),
  3816. PINMUX_IRQ(EXT_IRQ16L(9), 308),
  3817. };
  3818. #define PORTnCR_PULMD_OFF (0 << 6)
  3819. #define PORTnCR_PULMD_DOWN (2 << 6)
  3820. #define PORTnCR_PULMD_UP (3 << 6)
  3821. #define PORTnCR_PULMD_MASK (3 << 6)
  3822. static const unsigned int sh73a0_portcr_offsets[] = {
  3823. 0x00000000, 0x00001000, 0x00001000, 0x00002000, 0x00002000,
  3824. 0x00002000, 0x00002000, 0x00003000, 0x00003000, 0x00002000,
  3825. };
  3826. static unsigned int sh73a0_pinmux_get_bias(struct sh_pfc *pfc, unsigned int pin)
  3827. {
  3828. void __iomem *addr = pfc->window->virt
  3829. + sh73a0_portcr_offsets[pin >> 5] + pin;
  3830. u32 value = ioread8(addr) & PORTnCR_PULMD_MASK;
  3831. switch (value) {
  3832. case PORTnCR_PULMD_UP:
  3833. return PIN_CONFIG_BIAS_PULL_UP;
  3834. case PORTnCR_PULMD_DOWN:
  3835. return PIN_CONFIG_BIAS_PULL_DOWN;
  3836. case PORTnCR_PULMD_OFF:
  3837. default:
  3838. return PIN_CONFIG_BIAS_DISABLE;
  3839. }
  3840. }
  3841. static void sh73a0_pinmux_set_bias(struct sh_pfc *pfc, unsigned int pin,
  3842. unsigned int bias)
  3843. {
  3844. void __iomem *addr = pfc->window->virt
  3845. + sh73a0_portcr_offsets[pin >> 5] + pin;
  3846. u32 value = ioread8(addr) & ~PORTnCR_PULMD_MASK;
  3847. switch (bias) {
  3848. case PIN_CONFIG_BIAS_PULL_UP:
  3849. value |= PORTnCR_PULMD_UP;
  3850. break;
  3851. case PIN_CONFIG_BIAS_PULL_DOWN:
  3852. value |= PORTnCR_PULMD_DOWN;
  3853. break;
  3854. }
  3855. iowrite8(value, addr);
  3856. }
  3857. static const struct sh_pfc_soc_operations sh73a0_pinmux_ops = {
  3858. .get_bias = sh73a0_pinmux_get_bias,
  3859. .set_bias = sh73a0_pinmux_set_bias,
  3860. };
  3861. const struct sh_pfc_soc_info sh73a0_pinmux_info = {
  3862. .name = "sh73a0_pfc",
  3863. .ops = &sh73a0_pinmux_ops,
  3864. .input = { PINMUX_INPUT_BEGIN, PINMUX_INPUT_END },
  3865. .output = { PINMUX_OUTPUT_BEGIN, PINMUX_OUTPUT_END },
  3866. .function = { PINMUX_FUNCTION_BEGIN, PINMUX_FUNCTION_END },
  3867. .pins = pinmux_pins,
  3868. .nr_pins = ARRAY_SIZE(pinmux_pins),
  3869. .ranges = pinmux_ranges,
  3870. .nr_ranges = ARRAY_SIZE(pinmux_ranges),
  3871. .groups = pinmux_groups,
  3872. .nr_groups = ARRAY_SIZE(pinmux_groups),
  3873. .functions = pinmux_functions,
  3874. .nr_functions = ARRAY_SIZE(pinmux_functions),
  3875. .func_gpios = pinmux_func_gpios,
  3876. .nr_func_gpios = ARRAY_SIZE(pinmux_func_gpios),
  3877. .cfg_regs = pinmux_config_regs,
  3878. .data_regs = pinmux_data_regs,
  3879. .gpio_data = pinmux_data,
  3880. .gpio_data_size = ARRAY_SIZE(pinmux_data),
  3881. .gpio_irq = pinmux_irqs,
  3882. .gpio_irq_size = ARRAY_SIZE(pinmux_irqs),
  3883. };