From 8e0cebbd45502c6f54f0f1f67d947d6c9aff98e9 Mon Sep 17 00:00:00 2001 From: "rice.chen" Date: Mon, 16 Aug 2021 10:05:49 +0800 Subject: [PATCH] [add]add nrf52833 BSP --- bsp/nrf5x/docs/images/nrf52833.jpg | Bin 0 -> 143407 bytes bsp/nrf5x/nrf52833/.config | 591 + bsp/nrf5x/nrf52833/Kconfig | 21 + bsp/nrf5x/nrf52833/README.md | 68 + bsp/nrf5x/nrf52833/SConscript | 15 + bsp/nrf5x/nrf52833/SConstruct | 57 + bsp/nrf5x/nrf52833/applications/SConscript | 11 + bsp/nrf5x/nrf52833/applications/application.c | 23 + bsp/nrf5x/nrf52833/board/Kconfig | 97 + bsp/nrf5x/nrf52833/board/SConscript | 11 + bsp/nrf5x/nrf52833/board/board.c | 90 + bsp/nrf5x/nrf52833/board/board.h | 40 + .../nrf52833/board/linker_scripts/link.lds | 15 + .../nrf52833/board/linker_scripts/link.sct | 15 + bsp/nrf5x/nrf52833/board/nrfx_config.h | 47 + bsp/nrf5x/nrf52833/board/nrfx_glue.h | 269 + bsp/nrf5x/nrf52833/board/nrfx_log.h | 135 + bsp/nrf5x/nrf52833/board/sdk_config.h | 11701 ++++++++++++++++ bsp/nrf5x/nrf52833/project.uvoptx | 184 + bsp/nrf5x/nrf52833/project.uvprojx | 636 + bsp/nrf5x/nrf52833/rtconfig.h | 196 + bsp/nrf5x/nrf52833/rtconfig.py | 92 + bsp/nrf5x/nrf52833/template.uvoptx | 184 + bsp/nrf5x/nrf52833/template.uvprojx | 390 + 24 files changed, 14888 insertions(+) create mode 100644 bsp/nrf5x/docs/images/nrf52833.jpg create mode 100644 bsp/nrf5x/nrf52833/.config create mode 100644 bsp/nrf5x/nrf52833/Kconfig create mode 100644 bsp/nrf5x/nrf52833/README.md create mode 100644 bsp/nrf5x/nrf52833/SConscript create mode 100644 bsp/nrf5x/nrf52833/SConstruct create mode 100644 bsp/nrf5x/nrf52833/applications/SConscript create mode 100644 bsp/nrf5x/nrf52833/applications/application.c create mode 100644 bsp/nrf5x/nrf52833/board/Kconfig create mode 100644 bsp/nrf5x/nrf52833/board/SConscript create mode 100644 bsp/nrf5x/nrf52833/board/board.c create mode 100644 bsp/nrf5x/nrf52833/board/board.h create mode 100644 bsp/nrf5x/nrf52833/board/linker_scripts/link.lds create mode 100644 bsp/nrf5x/nrf52833/board/linker_scripts/link.sct create mode 100644 bsp/nrf5x/nrf52833/board/nrfx_config.h create mode 100644 bsp/nrf5x/nrf52833/board/nrfx_glue.h create mode 100644 bsp/nrf5x/nrf52833/board/nrfx_log.h create mode 100644 bsp/nrf5x/nrf52833/board/sdk_config.h create mode 100644 bsp/nrf5x/nrf52833/project.uvoptx create mode 100644 bsp/nrf5x/nrf52833/project.uvprojx create mode 100644 bsp/nrf5x/nrf52833/rtconfig.h create mode 100644 bsp/nrf5x/nrf52833/rtconfig.py create mode 100644 bsp/nrf5x/nrf52833/template.uvoptx create mode 100644 bsp/nrf5x/nrf52833/template.uvprojx diff --git a/bsp/nrf5x/docs/images/nrf52833.jpg b/bsp/nrf5x/docs/images/nrf52833.jpg new file mode 100644 index 0000000000000000000000000000000000000000..aed069b6613c3bd07ddf318a2e3ecf70f274e91c GIT binary patch literal 143407 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�K*VHgOz6;W^$Q~>k}0BnLAp%ikfSaO%WbJ6v-OPwNU zB1sld21^nE9{ksxO%p=qHyB~<(zM^icZM{IS)NGnH*`{eF2B~R-_IP@sA2__90uu+ zZ*QmNQ%)`;pS`J33W2zg*gXwI!Jepf=vh2SCQ7v3-};%sQ;9e^FL-qzS3azwICAQ`D(^ z1qvvltjJMYJ{P@@Pu8KDeh`A2{{Xw5^@*QavuI&6#x8gH8@_)p?_=7N)ihLhx!CG{ z6rTF`?KZa&c~TwQiRdZX-lU7D+FM!4GszO|Ee1Ce>CY71CJhSyU$ffUU&y1EEc;M> zerkhNk4c993q3L@g}`tb+bo0YT-R?$(Cd;(U3DVy8eF}+Q(VO?W1tecllUs|D-%ik zDb$f~8)~w$qhx@s*qn2U>3l~O^J$;y^4b!FZ4rVG^Q>{nC7}45ks9VCy}o5l9a{E56l5v>_?uJ z8`CfCmI0;BB^8mN>S?1UjL-raN?eLUMFSI)MJVY=I?wMB@|K`Kopc!n=2cO`Al}vJcM=HI3HRDR{B-T9Ww7x zlWnvt-lwAeb=B#94vsCdU%!~&^UX#Sem(1_iYVZXV~RD7G0{|D3RfMDZ%Ocly}sAJ zVR0bmZ$uyCT`DTZfmJ|J&;fucPHG8mV~eTWeFY4w9tB88r2x{<1km0|5yAPF-n1dO zieZ3o-iESB9qG9s{HGKFw9ATNsu13~aVN|w+FVB<`CA9j)d+VqpweSBP$EETMKuT` z)}E%2$!Tez;*=bk1U`&VI#SRBl(z28WO}Jk)_WuA1rrON&EvgKLg^3vMYV0G{Zsh&cY#1Gc zWaq6-Z+UNZ81m!?HHQVv&7)e#SQ!s3k=C|gi*yRIsw;O2F^T}RF^mqB!n~7JE}2*~ zan2G??{V_ge=tSE-^Ix8K+OPNc?Nl^mv<>|7U?oc`=~qBXTGp({R z&Gk?5G;7dTUCC{96}OdS^L}B@I@S3slW}A_8T#x!{{T9TH5(-hhaEq=PJLRPK|~s@yz}tEeam8>{jq3EC}KeG>qjdA z_O^=>?MO%msN~d_qUDu-%Bov9`S`%6TirD9mPFh-XEiYam3KDMzVv{~g397nXSkLo zkaa4%znQB7(YE}O51>Wo^r_~N?e>_XFUM|wm1m~98eo|L^NyV<0c~uhJbk7`^#Bfk zN<*h_$ZLuD{{U=?ZSJS`K&E}8aN}v@)tf7%xwrEdcOJY`12*GAj!6p^l0%L+Hc0$Q zqCGC&*-2zSDC)#uREw&tmwsNy;jxp_rN7iIZKqgnu)D@`I|_Gu2Aho2C5B5~&?*eK zP;vZ)D7A!7ER)9*vvuU>^%VOFEn^;B6DTL<`H1GJUBWLeWD=Q*t^jCQ56+NY#T{2p zgHXAVEr*eL8iKzzR#EThYoA-I-9F=oc-k}bA#X@E0r~}fb&Adpq{{Uo4sNkxx$_M=I@U zT}IHDY53YZeJWJ&MzbgS>!jN$LbGSs`|f_5U_wc zspaQUgCW9^?dw^~@b2ul&v^j)DK#{I4gUbYexv=^zxwnDmThV-jdNnZc0c&|&fhHL z^c@dstiB|NcbaZ(`Q0|pn37K$PaQ{UxStNK2j9Jz{{Xt6QFZX@&F#pwx}9go23#_q zr~ps~Myan`3rS&1l(_xc!UDp>a`h|;JQ32lNTgC&qXW(cM>N~}DRk?(Ep8WVk+ul_ zwR1$$p}5oTFD8QaLkn>5Z74t92cOEW60sAF$kiFMj>B>JdwSPLVP!1(EIw8H#uydA zl~gCq(D%hQ&quSCVIiN+1a0!;fza|g{#<6W_4ua$0EBu#V1;2on{oHlt zOj>=trs8r#hAq<@PI;{h)spW)dv&wAjFeKXaCU-5I0T<#*R5w{YW6r{t>te14C6la zWpxSG$}40fMv{4e1B0J`%97H?Tidj^w_HfzwpieBGHUF;9KD7omQxUnW9JN5Hb!{B zu8B3&Cul?qjP>X%YyJ^Sue1oB zXw}SSLZMiY20LS(y{eqLL@`)A(p>H$b%$q^%F5q~^r*ZIQkj7>+~aqhAwTa_3}*7T zNX^N|Enb;7g0!QtbLt87G;MSL{B`_FKbp$|UkXb)WBU9X|}#Xc(=%5-8?V=G#1&Cuv0{m>Gj% z91&6{Km~e!nt)S%hGN_W+P)!*$xfEnp$iM;m z{#59X@6^<6)hs_W$T`U)9OED3QB!7V4biC^lz@f%!=F%3zok^2%C__OPhK(kRhW`P zBC?@u^}x^LPMusglJSNO&Ts}RgzhQE(cG0sUzC4%V1f0fUs>CxcH7OKpn>xKb$Zs? zCw5ZXSbq)=BD7|=Q2<13io+}KNDfvg=9!i@1tU|?{{ULnic)lqP8Myz2*~^zl2PPD zQ2pLZ8qA7Z+g<^Wo->>uaa4rIU0Y9QBF8*tHf0Zk=z3Hc=B#SBaa}E&LpPYwz>z=6 zw*^K&8m6b7y?uLEWjP#^j-=V36HE<*PX{$*Sav<=#VGr|DS6vWLE4g*l93@r6i@+6 zNlQQr$8q^lM<<#I<^6gOB(XAqTmo$@)`C1M5Zapv|cMZwF2P08H+|{M1$s?AGp- z@Xes=7Ee47%I_P-C6FLE&UrOM`!{djzOno#2l-YhsJ5BBqs*0x81|{H=bGKiK`haN zFhp!u`BlHLz&`e;YM(&u{Fa^eEj)j$)l>ch1E1%LeDM;4L^^HRvee?dk$l#Tw-tZl zxBIrZ{%ua#pfBE=P?P=CMW~We z?r9sYsM*!EYZ+|j3x74lk0P{4yT5h^*NQbgR>Dhb^;_8{^Y)nI1%b%wTO$>SWzg59 zwxK8c(xU$WC8qteN?*C8&VS##{{RK3Eti_ups`FUG^uI zJHX`%GzA8 z?0mC|yqXTDG;U3-q5COL-(1#j+wPd=OR41cGBq`(a;JQcyS7`5Q2D%vXqQiiH9&uP zZ{_>5sQ$F!qRapc_OYMuHOhZ1)=&e|mm`r;?+cnejTO@bZme&tmjoa6!2bX$HL0MR zQkqM45+Uf=)o@NTN#ctXEd&0^yP)Yej|C2mq1onFDL^j+)fpxR=D2B=)J3$kEpDp@Es51Em251 zQr0DfB`qZYHi{^q0+N=H&@n|Bq@sWpl7qz{IiLlmo=q-kI?w`A9%)FVpakzhpqfn3 z0?|bj#w8^cBrwTwAdVDgkn~j<%^)MGt!*c~m_=<9NawPQ*G;7OIo}d$FSUC4N!0yM zYU?d5?d)O^+r+W2pdEg+t~8EgN$_|WlTmU109@1hn(A%sp|ylZZyKTwfkp*Q)KqfK z94qrT;YpT~L+UB65-+^pfT}ZJGo7e5tyC;nl27MAi&NgaWG4ctu`YAp){~k-eJNZI zAePbM_Z1Fne1P3*oyC$qSw2?%4N#2S(&C*YFB$oi)On;ZD@lw~!KJ`7?f|zECq~Uq zx4HZ4Rmua>kfthb1?0Po_r*!)rZ`}0H)-^w+DENWi%)pq{Jc{I{NLWFahgz~kjZ}C zKllFtK}XxC{{H~!QEa1S06nhfZ~16xo869BlS#J}<>G)II#EEPq+vxAPyt00Py*3K z6u??2qL>Lq6i@+4MHB!GX1!;?Ab)2qc_`~%tMK`=WCcXJ0o{(2P$-}Uq<_0hNZl%c z^B;(T4yd_bm&(B->s;lXoq;yyIc@~5M)hb&1Kb|<)p+-Loyzd4pD_cTr=??QH(qSk z3H_rxgn#u?MS!1=dVIn0FMdeW*ioBne=@DciYNkl#$yd%$g8c(mG~o66p$fC$3}pL*AVOFc@- z8ec6{zI+e8^sZKY6IRu9m46~A*;pST2h85&)~1`NwXKv;`6qIK7!rE@Dx(&}-HpL% zr$*bOM{i6<-{DST01m@yuN)qp!``#bu7Br({-&CK(|+nUkr?Vv0Yz!b-sCpA5^s}G zmum3<>Uv;Q%cNUv`C*y8$pbY#x+GS+fF44OfO@(0`co&nx|ue?5n%Q(tZ@)da;G%KmT97BuP(oO-3)ATk7}sZuu# zV2to7*3cD&qm>nj;PJr~hvEHx`u6Ol%P!InDu82(>!F4=gXU*!_rVmKupIvY_IQT$ zNQ<~1;VL*3Yg$BFkWVp8Y@F^;GmlEwNEpo9WoZ;2<6JWPcH*YHK^!>}7XU@|!ATEZJ?oD!<#c*&_ef=>(wVe3`Lnl3!KSYcNsju$_zUocq> zeI~|PmF0__aUSbaUK zl-GuAWx|ww_pC{RH5TD`>dHk_J ztY}eG;xmmxK_rUNvgK3^V+XnKS=P5Q&v6CBes&$oNx0zv=Kv1>08vaVZqREo1bA<5 zgIqk@lrRiO%h!MhZYv(yt{cd?w}}ztR`UkzyoU#q+ZmuNbn7f^SS*Olzjy)(A6j>M z=X9WDyR*1YB@dLsL{3TLs~@jw=&?cuc_+j%x5ZPR??#98su~xNbgR!XZ1;!C`Ijas zKj0&wtv`sV{{R(4pY_E*m1by9w@AKUF~BE~EJUFFTdLC$(_gLBdK8jpQ5zLlJhv#o zbmxktXENMrLL+6U$WG;Efkq!EJn>UW_Cumf6ZW1MM1?nsON8kRgmmvt$!49wrCoUV?A*(PPl0~x^W?Ogu=wJ_qk91}T|+BXM^ZbV9p zZEUfCRIXTqkO!|FJ62=rQkcwX6mdpoS+<}&Fc{#HYMJX!{v*5o0!OVbL|?R#)?fI- z-%(T&=#fmoVN1Uw@)@f4mQASX7PnS-a60?DHE1@tl4YB-&&j zW0qK?n<&eKk}$i&9AtA*DA?6Xv#ac8PRpep-aVl=v)Tz!tD#i(c&3008l2S)4PGzGSMpRU( z+LILE4QygQmnM)>(M9u5_B| zZ|&oYNfJXXpUj9I5n}{`0VEvm&UmhRvS&pYqafCSOj9R<~zR%Mb^0~sUBzA!Z(fxx ztH&!yk^If&Il_OsXoxc{f0aE?-5ojWOaqKl*QPpwU2!>OxhNGPj8sZRO1Z5On;aUR z4-~+)FP7mqY;C@~PAY^liaJq2m{CO(08vF0hAkZ_GeI=KLTRMZF{b9Iafq~0M_NVP zD#TW@N;gLnx4Nk{x8S`d9Y<3?X&d8-ca;9|?VoDswXYQa0A%WaVz#u6ql^vxzbscg zs=L`ENWnFBdGjvT!2};dDJ#+ZS!HQ=;r71>t1>FOwlHve8uO~CPn^!AIat~$)K-KE zMHEm1QPWGv&fQpibx~4HEfu!(|6sJf6Ecm>c8Po)r3>P9Vo?H)1uC+XsW(=-lVFjY_56Z z>0O=O-IbK6^4f<&r5T-7N}g~wkHeaWI~u~B)y@NBdUf`vBv0n;F}{0^r=@yLw2_-z zQY3}l9JwB14XcC4Ue#Ms*X^ujR#&udGBAXR1GsM4BeiGke2smP!Od+n3JkDI8lHvF zjQ({Mb~?|Mt=azoqTR)DEFin>>yJT!&2g>4#c2t17)m^>Pr!a1>!|QGq%WzPnVlEN zA0ie2mOb(9T*YnpTUi=DqnW?s-fSzJecwY$ro}_zJv;3&5)?{=_5k&%J7%GVWxGCV zHt5FzyB||h%*9YB<(q+AEbX}(4>DGhu=!TGKOO1th*s}*BqwPDzrA)Sp;K?AdDo3K zBX_8I5x4H*RNdUKvWwS^xC=Im>z(eLf- zygjm5TyIWt_1S#F9!(w4C_3PVdsXaOjqiU3Lt z6dDF46j49{IHr!Yr zwEa5QPmCqBO1`J5KT}sJtjd7yV6`O*NzF$jsTj)~Rax&y$d8|Tr0&jg=O&Rwsjo|M z9|P8@vlcmGSke+`{U{_u)|zR@ts$fWQc}`T2brhK+6ZJu#QA)!x!$t8(e=IgP&qRi4^a>WA>9U;x7u zZ{nG;*Q%e&f_UjgfKX^AnVK?aD3f&=sOTpYgh)>mt5Ig2lmR6a3Mc@giYNf0iYNf0 ziYNhSqKW`0G*D@P+6@$jfsb5oT-U1nKSB0Qz;~}E4Ti5t_;~KF;z@o@qXYN&5MI$$x@{^omkQ#ZadY#wUtfZVS=27ymOq#TyD92i4 zs~nNC$Q6|J4bamO0-K-kz<(5QTCTb+mY*o+N|7P%Pff!+q~nuZ0q&tDu!JbQ7)Z`+(wPS zEuZPut6D^f4sD@@+tlX=@TI%dt?Xb|yn=0ja0F$5{HrwhpG&%5D%~y%6OF<=Vvb-p z7G+4*N&KkL@OLiX=TO{U!{so860tujs`WJZX0X_UA4)RCAab!ekqquT@qmXQyy6x~jQ#+OqT3r9P?V7VQ~Lrj}X zxk$X>a29;@Ood_ZTav@F(WO^b0B3=aYdRZ-W3ov6)g0zBIQ%Mab52_v#<5|mUEW*C zZe;tvF%N;(ss8|AYahQ3$LIe5rk#1N>N}{;N0%a>Mp}_&&-XpW12~IM3+gE}5=|&o zkDtCt139ju(!hmw`((`_InK~VK9!>GrC2cldkU#zaAxy-u7F`p0jWH8Fr*|H)pNmR zK&SMnp_XJGS~B@cFbNqoUI(~*d4xuw@&f~!NY}}on2Pl0o#-8Yc*!d zv6FRimvl>s6^iF>-~yja;+ED~<%L#jb$NE2joh%$y<34~mOakCT)jvNr#|_`Fr$TL zc^#Cg9%cY2J*z-->bkF9k2 zbiQ;Onnra6wzQ5{ARfF|HR2}Qr%16eF&P1GA$P`3e~H_bKEi-It1tNQgm>6Kl{8sH z_Sr59gCWKn=qc6>{(%Ai0APPAb33exp+}b4$)H7XX>gZMBvY!#Aq>jNoF8MFV`&!6 zGfY&Oi*NG-5rg#US{TTxOCuS9Qdn-<-7vi4^PmMfdYj>LWt(u|C~PPmn5Bxs2xcy! z`6aMe?F99}=qk*Ogk$I`oxWOBal**FiIdR#c2c*ypcm3 zZ2tgws^FTN>qtj50E-eKB~e#Cf}e^{PHB7frZdX^BaC>Lcl|M6>sfvrjz-h(ytwB$ z?-k&SAMg|Rt6$5BCUO4& zeE0eq<`|p-mg&$kgnUhkdDc)P$-MT|9)Y3FEPqgoiQG%84fyX|TQ_1l1+)3sO zPa|L@!?sIv&}Sp1aiQ4;&<;EN-~D=xj!kH(d6DgxV_(ECVDAUm+5*b0yudKMeqYBG zidhI=066)MbDnzA-~miH&01D6lfI%R$E9@IHLsOmjrV3J zdbl`sJ+a@X@SX_iQEGNj-ENZEV~XhV(Z)VWNB5J{-D)|tv3#0b=c%Tpon+!!Frq?2 zo(6G%YHK*ZeISuTmEfj%BmI&%&-1G#A=)*(GU|wKWN4vM8QDn~8OLv}UA(f=?QHH9 zCxG2yQ4%jPxeduBh6fb{amN(WD#%PSfQum*!Q2nbJ9Mqj6KNJ!wvBlO!Fe8B6gVTF zr}^fhTC+r~iZILKJBtK+XP!%O8AWiboxR3SC#PR(qohTuyH6gOEQ&x3{{T2pdE+_i zb6rl0<;|g6vKy1JWB|rKSO+|G?VkBaLuzQiy+Oy=2x+1R3 zeN}J1-v0pFMa=s~?cG2lAbWi(xc~r9L9o8ozlp(*S!7`*;TnDZN#obJtc~8)y)?OW zIjUcnX)(p5TL+W+QlZ-Whv9>Y(2I`66qz*A$JaCrQfY;$ z7}E))K2h1tNofkts9W30M#q&=iuw`<6<;+iqinvmlcpt8`ijm*(9qr1d@uGpJNuNl zk)yVpMyTCLJ@Z_$mUY^#UazdlYc;N;Wg`CiX4~^C;}{!QZ3m`Ja^4!!Ev;@ZTK@n{ zxw{zx-*ioaIpl%(b*@vQ#~J}GwRZ!YJlmw zneiFa(+KEmTty|V!$ol!Nf#MY+aom=YHdTz z`&Q`;tX&n0JYjRkr=>$(l;1RNa@38Ov{6MfF=(QY)PRK3Nubke%M8&;OF#!|daex! zxu*(GQ8T;nPLp?LuX!<89M%77jNaob3O%~-(T|N zW@Yl50giFfy4_Po)3pn)GUhdD3gO?*Dp%8iToo>*so71Z9SE;tgT$Hx3ptr$Ad~=O zk=Tm!2L(%m*y6n>?K)?L^qC@#edjF7n}ahk`gE^0ke7Boq?*=`UdA={LJpKyb8VvO z4R2v2dSurEof3qz_ zR<^euYY}qtk-a^IO{MsH!Yj+BltC$CRw$W)*uJEC()P$+#he8d+gw>k4B8{b3{JcJ zxe6dE+~DWdvvpl2%<7jdCZ}y}^Pk=9Vps4K{h+;*IoR!{m;GE$z<+f~#V~@TsZt2* zkzKM(bp10%TN{()w54PyxDtHWIR?4k62;`}w+K3K%?hR6f^g+mGU(|_deR!u#M1E0 zs}{d*OKn!%rzZoDYpA-=?9P`gHueHb$uaxqk#nB-=YjOD3phUY-+yV`L!)W;EpY?j zwL2)i1b}GvcE4tgZ0*mMRhi`l$t#1%&w5E0Pt+{d!%j;hu!d|B zS%B-#D~+E}xiMTJvmm<-(vWgF{HorCs%kMbP}$jenIsqI=Ohu-@&5qotWz~Ri~W}R zWUkRcZwf}ps}h`oae>f!SDHV~D<4yu?X^i}Zw|*8H;`=Yb5%Rm$A&d1^vz;9reEEVQJedq_pK%HnMdMB zsaabkt(sfHyJL+)ic~w@pZG@#KdlB(&<`x<%=@SM)QW*dGn(ONaUH{9Qa!;7@$?<* zl<|I*4A!FVBO1uRcw`KU>zX*<{bXp^{`!Ml{{V~b;j+@&5gbBEh5*_)9<_Au%&bi9 z%I;$LTJk$xE=IVNz_}nvB)f zP<>w+tZijuT~bhn-yOV5&6@9&q+BW z=sQqXDaYx47`@am?xx-o{7yMPL0zVoqFL#R3^9h2ySFX>0M@M`NJteU0MSwbjMD9(3R(bRLG4xU;@uIz=B^P<+ny)` z1l!67+%%p{pWHRP$;K)sjOKxu{{Uu_Jt#KPdseBAno@xozC!`dDWGjNpvpO_GVt_< z8KX4J(V9aanlntz8K4K|jMFnlXaV`7G|bVO0DkH>Q!_?r0sE-kOx;PkfF#W!JX3d3 zngBw1%~`b6E-hpa6pW;L8me(fO#?f)d~<#xNbTln6;uLbUzIx+Rm$;;&f#_LZ7wWQu`{JZ^APRx}OR8K;wB9n~zWjeG?0&_i z+Fi$sIPw*e4hR^mK-q$W;(m1$dP_RvTByLiC$D!O;k&(Ja7VXV zr6CdP5{pO{;%WS~QU?PA*EDXn7@d5Xh&NOAd& z;{e7AD2pG{w=k$EB1>S7jedS3<_32TaT8o zd{ls0bkDG;QY)0}?rxIm+8H1xYquK-86Qzlv@s+_rh$Dj%e(p32Ze5BHW9+8B-xe< zc<<7>jYsX)+AP;8X>Q1fU6G_9;1BnD(Jjha6X;f6Mt}e-^YMUl)YS2`7RE)6EQ@d(|RzowdF14H8QfRccHy9m4{i531jmFNL5zpyHk9{Ssr5Jre^tF?!4Y5b6)3^}k>L@(8BreO_xc14UwDTGt-p27r!!8-K`qe#OSJW)LL8n;S zT8S;@$(8U={{X8UYhF+iUI*~w= zw?FjFf0aorPVy;M#tv~&X@@#xzx#{)s!5&El!oeYjCG&~lx_RB9+=zOqg!&AKJQ{{Vqi?9c;fpwKCS=6@1L{7&Kj z0InnXn$7UT+$ELxw>pk7&)H!|QOEIa{*|xsC4b^=Zr}9B`kKJdql~53nG_CojCr@F z-2NErOp|SzBcxCJ%VU_ogHAD?p1;?%W{oCK?8AOcQOA$nsbiPH=b)|M^rq3S7G>2x z)N$s{j=ep4oF-Wk2%*gp1cKZ8QRBUb@-ap<1lg(FI{%LtpkV!b&Ij&Ys zO7SL=Xu={$8Yc3W2>I*vHKb)GXDG%fqkUl|jntO&6=@S0Dsnjh{{UL5u=%K>G&{g0 zv(p2(tCx2&-rP0Bq!}0hNKiTq3QJk!wR1dMcOW2!0E`|ngIe3&G3HnDF6lbKwtz!( zhK-b}NHE1maKpO$cI{TBm8C{5ODV$w4@233_4IGR)=Sujw);)C89~g52Qi=U_oB}6 zp&=ZWgy$LRx$BQ_QQoqYdZSp*+A;THNNh#4k*tt!Efm{uz@DK00EJbz^9Jp)??6Fg zw4JN(j@77HW$-on5vL}p-&^ayF$p(w${NJ80Y-+T1Qo4Ww{LQjVSW{ zah#vSKEGP*{9Q900ytV^c{i%LRReJx?(5U=t|ax?F|#?T?DV-V?mo{EPd~B}7d&UF zqEOj{YHquohlh1bdtVR59QUwCjo>N9SCV=CO=9>;{wq8ClQrOoGH~T{xaaZrs85Eq z6@*B}1yApplmIh~pKR4B^t+3FNp$(VwV#ZB^X2EKHJXfHQj?PCPvU#HZ?$%s-c9k8 zQIpu?pyIMCd;Sq!NQc@j*^rPz$Vnu11CM&o)bz`ZE_H_JBFM-b0CRw9;cbzfME9{q zigNq^04nNid?y{mQM+m%D<eA0~5Dbr}iVN4>u9ef?8g<~j}9CBpnIp?SI zs(M@|Jn7K^AOL2-Gl+`5@peYufsZ=euc`fsZ0xNPe$n zkzLJoEIN(TMut#hB%Q3IIOO!E+ITMC2{p^znB8IkCNc~4C)iefuCw9|O6+}_ZLb=$ zVFIYfa^0&}L)3L4eK48Q^5KH0&DzJ)kN_MSIY-P@(X@2_)Yj}4M@ZsQqmh;yyPSG@ zRGR*Wr`TFFki_ZaT`Y2C_ZLz#(xCpz*6(kwZtY`un&H?miNcS)gWsk_M{%KQjwV^= zEa{nD8gNO#wn8C+le?P*j_%7DYYZ;n*VI!G#7G(ru z0OOjkvMYPYz|tMR;Uiaw+ef}qN1e)YdUX7$z9?q?*qeRKb25@Jia=j#(9FBr=Z zwipsP3BlRH!Tc)!0E#r(bvx@wZK8%ZWq+B@I&wk4?N!ZYy$I!PKU0mncK*qgWI;5fq8XIAFAgs~GwH1?L=phhw)g5xEI-l0!IDT6=)?(RP#Bo?j&uPwm|$iNxL zbIoHdWX+?bQBLe4v@D7SVnT5lLDSrv{c5-*8tr7!^`+6i%x1KP(W6yo!8k=69OAic zM#@b-`dew8S&;Hn=Q$b8bkUNvj#{zmQW?!WQHo03=NB}_G>mDq?`=znw3M_^0s&3} zfH|iDKnf_Lih&o`OVpToiEDA3XCg8CN%LtPHBs84(0?K@H!S)-lCRB*UFe<4tKx!QSbE}P~u+anX| zaa9@K$j(r*B=GLJ{hg*>EZ2A-f1|>A89B)nvt{B9A?1ep>gA)lFzl5A5)bKEz7F!p z)C-i2mLSV3pnaV4#X!2X{Mx}5vqyVA3~@M!4!ywb_||ieyv<`PBu^Hrr(0Znx?4!e zDUt~k>@ChlMN+fWuI1O7`YU5B&5}_;=tetNO1JVyt?8DMAGF*?3eP^yGDkpts}2bD zIQ4tTEQHJR?vu*G$X7jyr3AYUOm>^7>sC_DYj14tB$;)M<0QsUap_s@q-wI>I!SFH znDX1W>))E{b%?L7MVxk0PK@vmG8rTZGpIe!tv6J#hVnZFyJojoA}=gX;h$*jp5)W! zu$(WUn_!+I(_>p}coo6RsC})s)Q)(rZthv;x{^zVEi*ALPpx#edXrrEhRnq(!DfJ> z#9wGc0FHk{SUR+87NICv5ypC>1|OKJhURrP(_)ySiYs#g052k_##n$e?_Q8D>}_FN z64HI40+AFE5&>Li9CWWWJ%3v7TIfk@4c)cJlRN$2+$%`?xWLPDGhFqR&Z;4MVQ+H; zkt|nHi3u#`CpaYaBRHcXY2i)ywyoU>HAbXux;<5QaGswrmj)fF-L za!oDl{{U>Xf;(Hep^?}3F$n@T3GQ*z@vLlgGUG`##6DHdpCnPvLP+9OJ9}q?UVExr zt)=wPp)3)I1pRBdg46pkCVfKg;&+8ZGf5%Xdw>USYlYNq#pV3h8$$15a4TvjJ${8? zGtO~GwILh2b4TM_oaWx2;w?tS7C7b%s<=@i=V+^K;|*Pp`sl~fFtm~`Gi^(_LO7k``mNgD3K<272is)x5vy#=3Gf1Oqvu)~B6NC6s z3~iEeRyG1^%n|&ijzr~hU27sJxJr;y6Qw@5<+*K9QAh-&CWA#WiA5BY0EU8SG=_lzG-sMaNkATL znlntzC^cdqnoxPBQi=eSQ?pTnN(}%=DQSSyfusV`(o)g@rjbshpa{y-8ERupY5;+g zil=i2QY%D^)NG*eXc>rj?Lg+W+TJtTqBf{IW`Hw=EoxiA7@2oO7-yw=J&ui~+}Xz{ zvA5-axH{4q6|`xNp;T5t)8QZT%|9y5)Um8-a~u#xKD6&G&tqNF zTE>I!FXdHbRb2d|@}=!d_8w;+c%_;r^OZHiRyIR;ZZ9cU=&|b{Q7INqA)REZ8Tjs@U#cw31 z0ZnRJ=&jan2d8>`*B>HAMZKH0*y9<;Kr2^FkL;Jx`IrYBir2NahifcFPTs0HKal32 zmrr}_fCQJ7#cjS!exLBzC54Klxp^|1raN-UqOI>I_JLc z@l%w1-*|IcawC~lljw97nvuM_3mTZymSS5bt|qT)s-w+$8#pCFtgSB*$)7O?2OIbq z`qNIHWRa%1y@7JVL*=&%^sL>EsNJiUY@oeM%Yw1Uv9S402=7eM?QcHSs4*|Gqyrnd z&M7XLF6|^1n$d&N(fJ3`u;B3SqLVk7tT_%4IBp>73CQmcdB787nQb7xyJne07~@8 zw7V}SV%w-tNg#~#pL#A;Vbh$&W#&E`X+-FG=72odS?iO^s~v&C8Q}3+HX28WEXcVQ zfmuny2=|ltR&4t2uXhtf_bwyG3V;XlsE3F(i)B?y`-R5<6I2JGXu3t;l(OH$X0x~O zrMN=A*&pFszE|#uJ7MGRDXfnQYZB_3cx#+_oaM)Q+LQvgW1dIzr1TjCw^xy&R4F4b zTrVc2fR>LfpD~6=J#*<<+K-3@kBIDa#kAk{k-N<4x9C3#*12_$Ewll%am7k$jjI{U zs7P;ouOzbMjoVHJJ^LD4i;)$>MyTYTb}F&Y@=v{N=>Gum^)Oq> z?vE#QVQ{0X-RclFznnpFaaUE@%NvAh9_(JeBpKAXJdax%V;28@Q-vn5^ogNIk&$ zNBh+FW?8oteTSh9!2BozM1>KzC_J3?;2)(pA}cXf8=I;1sE`%AU>TSc&JS*TQX+-9 zlm;ZSsXhH@0!X8YHwczB=jIFR??iJ&ChslL_8d0W2NhB%vmuQ{W98b-8*`t2DS%BN zl!Ft29@W?m3G~nSP$J;EiKA%)e5u!iPl`b@ZUL9sl&SoUQ;00SW3hJ(n^=sf9>7$# zL9qEU`FZ&~-0t`5&OWpZ;XWjf_?TLsSkLpWe?TdlpwdFWE`NJuZZrP?#MepjEDyHX zpZaFs&apf#_J;dkk~KEUjQx^SLEo{n$Qa6Sm-c5T~j3r|EXn z-B?^aQ+cYgI^j0P21noe(#Q6Jq+Aa+@Ma8h98PN0Ih~Oh;8JZHvs*qN(%{skVJp5d@~mf^=Nz0IS4cc3 zrNfUgr)J095)YW;J%{q8DX5Ax z2lEwbKb(BH!*DqMpVRWH`B`@{7?5>eU!^e|qh)_DTG1Ka#8Pb%kUD*8?u+L(uW$Bo z`|#Oa{Ei2IYONv(2Ib+u&+AuwKX|qp#4@@TUQvRKoG`~9of7z2Q23GB3t8IM1(9xA z2tSKr`D{VRVwv1PKgzi6SM8thl1R4#Ked?@{DTU|j338}^rpZ60EvF(jD!h-{QwyB z>z`~_oN9Mh6L_1=irv;lbW}&-zEA+qxy5l&=55^Tp2uhXpL=s{BpXsiGBZm4af^E% zs-Z#PV;t8Z;=3s=F73-o&l|(F1AXYioE0a&J!{Y{F6a9zF|;waEMtDE$CHd_JRU6TxIKdk5cx9U26rWPOX+SNNn*cfP2jg7Qczj(?aV6F0wp)HBl1@t;o_QnC zR8n}B?hQ5^-Q28!NK8TiW#E0|*QZ*cCy6ef8*XoYT;PXZeKW;#)8~tKHgQt1*=f23 zjM_XOX+ClDKKUeNbHe`sD&+i4r`p(SQ(M}7zyT}QZborY*lP~+NDEzgjNV{&y9fgT z)PgzYn`3Wvt50z=NS`myEYm&!&jXsONve)gdJ$4fl_a$nLz>pw@y+f$u&xx84~F9e z1IJ@s6x!C3VUjy@6eDmkJaCdh&r&grR#mr!wHt_*KqEmTw$>*gf!~gx_N9-*dwlV8 zaP2%2tSFG6V#gUBNWiV7%FLHC=vlbbEUzvvP+TN&$Y5+X(+O-Xyn(M$F|&$ZQua zjE}Adn3^#zZvee+M->MN&`J&tc{Bch!6j`L0|(Mb@-WcXiM zveV&_FC~&Q$y{WE_zv~S&sUN1$77*#-FwD**lMY-tOyU=v*rdb{{W9>v}Lx{G%Z3M zM^Ha(j|{D{QhI~OBZ{Qjy|D2Ky;$UHf4W0C+()lp(xmYYwP~nCklH}w4YdTv`}kRyf>P|ZCdW;D}(Wlg8lWIhzl|adS zb@~d(@4&@WZP15%YFn_>ZnW!y_Oh7CToZtDKN_~${-@?6{ivfZa8*=eKZRwAT-9=- zZzO2Rt?H7LEqysD(+!M%RaNfpn&a&ab1$F$^5=KwU7nTU`wN{m#zSOe^W)tl#!@yM zdR9E17?j+^u}+>;&gzAf}@J@FeH{)U(Aw6c|W|&N&M-Av2DbbC%HMU z;@`u1R@;9u*`#P2BM0VT)xQr)&i?>}R?(I<`*go(nOaDf%K#8N8adz`k~w3X@@Yr6 z>0NZb6tRxpK(|x1*n`dk<=c&ZGm<`;s@cPOiqbCTZZ;FWYA&-c*dn(u#hAWW=I443Zfh*jnwcw=dmBmOtx_zh zkxoZaxyKl)QfpVTS^b&hMvM#t<&D_RahjveB|b>@AGMKs=Ty79MN65QNX7{V>5t`A z8ymRJ-r1<>)a*ld96#Bl@68|X(chY4CLJmD80k`qvl)shX$2^zWXGpkxo^m3fJW9jR)9I4&bi$;r8j8|AdM@xxS~#YfY0V>1ol(jLk=XrZ#nw;V}&2%K}j67hMRY&$P(HT$__V?g&$L0c9-ERdu_5^x1T8f z9*RH4x)`EJqgdlmsJ#_N1wXATl%gbRk)R5oDChv7;-Z$}BOQ74sxsZXoDKy;Y-P!A zQZd&isLOKBcsoTzPJ7c$F^Wk&X}A=$lmJptO(g&nlu}4o9tNylUWrD>*Bg(`_7N(SoM4CyT9hxB6jR zydx{zRuuO6Vlj%rs~xGPVYDaGqcAt6Z2gy-QE5+@IZQvZk=mRsN#?g!%W=ls)|IA) z&xSk-e9W0>a?$D1OVC!mpNCz-w7f6tU1h$V4Z4676H>_0#5WQZM^oun$jl{Ev6BXu z3<^B7A5uA_xQ-Mbyk%VR$;DIEJWUKmlFfYSI&VL8e~ogld2>C_opT|Py93aD1yV*b zk=$Boi)m`JTCA-k+_MKz2jF?D66oyeTJ4vG+%Vjl$+6e|(yAo1Pu+|LB>w;^ymgnH zvWVjVjC4F!+StS0*kf71kp&S)`1Pt%$dX+=3fRo{AryOy554uQ zty4|ZFJ=A4rz9JG>IDQ>nXicN-BLG`J5ORkKU`O%_+wRj{XJxnkr{a4WS`EHL%AGU zCDMT=p?`C5Q;-uJeig55>v0rr7D&(xVb=$bTCl|#b0miy`%?>B6T$xg$BjtGmohh( z9(InVoFPujxqVMHlc?W3AjfFJCOuq?&lf`hwSY?#p8aD$kQSqD_ ze9dh37Y^yc+l{}0?^tqbm)gFk4a_z(!lMClg#Kq0+DmAX#UiY)wfH$;cKtmnD|^U= z*Yf2BcpGOUQiZCv)G z2c>v(!^@{>(9LBdi6p^r*&n5C zd9qBRP9r5i8Rm_^mA4jIp4tyFMgy~qkH(oS*^Q)?<3o-DoYD)Z2Oe(X2P2>8Df?3F zqx`#jg1u^G%Mv9bl1~DoVom!;%tDh^Ew@h|;2C-2a&6=B6{8)jD1}u3$m9yCA=z}X zs;K!18Dq~Pvvpi;&bRCxH8O3WNHr-+!xUkcaSZzoexrk2{{V=c9?8}s3}QjJTfkZ} zbNo^s{{TwpNSJC(B(bC{>PF>5C?ItD8t1%49D_@FBuUsSf*M&CEOXi+*XvyaM|q-u z$R5|f?w9#g@il<+2R4@vqf|0~A}tCi6BAGuD(_#I9UMfscGuchz+C<*#kj`^YN1 zo+8oHhSY8U00+f{>rMqrm1pra_mRIez3*Td8ej>T;2wSw% zdBabCljZwd<}b?~YNo5H+-mpDd2+*X;Z$@{*b0|IzlO?b8hf#5jF<%5EZO|}RS4?r ztP2RQ>6#(h1j zJIb_EMwd|NUNL`VYqLveVw%$4V7ujTpr1~9k^&eA%O z+=5RP$WGD=5UyKiot8qJZo%h1y?ClDG52xxHBU_eYpJhuX*@C7v+UaH3OcapbBxqM zOUJo});$RvKhxf~JTIqN-D(zVcPE)2lvpFmt{H**ynWHh;MYy!iw!y-4>U@V#>pmP z002SHAbu5pShGsTQlouOIpt1QuS`^s7xSZ%E#6>ZjlFYBC(KmC4n}kR54~K`rHSWSHl9OA^t$tRR3kmIG)!dhuL$i42dg-ODU5 z3ppPtAod)BI~w$qytPXeSn|ua8x=_n`1HrUdB=$E;+s{BM8ZXaB|^iYBd$HWS0xvA z(b-c(b&(tCp#^Pb6UnwlR0?(txEU-!$sLD0*FWOZDy5WZ5=U%-gj^6qWNuamq2O^{ zexI({&1vUE+q3gBZcxf`$RLqie~WckZ+y6+bZw5(F+-3E000ku2Q*Tf3&n{qRPn+mE`cNgO&8#>rWB;rnJ4urFlnl%C!xq!qJp+3#mI8clA6U!l-WB z{{YrC(Ox7oX!E?A1BuU-8^qZPPiD>s(wU^&{krvFgHE++B_|t$VL=^w^cc-&XSt^_ znWTK$i0k)HLW8%faaxuavgvIkad|Tfgd4+Q)Qn^fJBrlQ^gI1BDX$=g-C_H!<)9=1 z#&E#?l?I#Pi~H+n=Z)fsOUi;yaqGbSD@t~136uu3im z;af+NMiTajY#Oc1Hgj6rq*1Jh%Oi-!N}iw^t#fMg=+H|HJCzy3GOtejob&lo$JM>i z@P3tMIriwyYveimhj7U2F06N!QKG7Fy+QdDA3UBsxm|%X#4)0xpvF0{0p8nWdypMeYSeVgc zfDlSZ52aVvCpXqQv`Wu7V;O_wVh;m2;<{C~wokil68#WVv~vOHS_Qq$rk|=U-L1?i zBp6a+Y-gWtE0+=z>0a3?B(St{4anfD4^doBo8W6Z>oanf@~Rd;AW_)Xk)4d?4r7f3 zk&)Z2E^*sGTF}?Dn6#ZzJ80x~MhbT}Gs(fOvJV64(m>l5=0+oe(_^2?wDzjTZj&l# zdfm0udTor>j?=)~Qb8uv&%P_8hT7;5*AUyej#g-hb{li}R&|$#ZFD_DPPthn^W`lY zE3jZ2X*_Z5T^sXU?n$$uM##$hE$nf`K(vxbivU}9-94%mwADPeT-XK~2-_H#!R#w! zjMh!hiL`51^5wsWaO$a+{z9hgVnL=}d7JJpBjOJyiny4}btvmeMFvEItU!KYRhFzn z_k|-l>_>7jb)QjBq`cyFKBAL6S1n(N^zhE~(Bn<1t?jNZ=1A@1F2}GH)M=g$Vnny^ zx4)Mk^)->yqH{L3Q(sCWf+lu8gMsxm)aiZ=MEUREdH(>OXmCFhT}8E=7Lj>yM3JcM zqNg78u0B*nZ*LX6N|7SQqq2-thMOd)gPNr^*=`qsNTSq}qp5Ykf8PykQh`f~0B$J7I~2H}24aj;@kS{C%u}&W#VA?;ZYgoa zI4wIIPy|?`6#cZjX#mVn1wU;rC;^zG6#PG(%OVmO8t!zh zVk^`N%mkjEwdccuQbjD0FlgMV9+W*m^&$ZkQsTlHf!v^?2sUiq0qJ(2; zE$V8=%0CLpz40BDvK_K{&Dmq;^{!u1*KYL>lXsIB_Y=R=)u^InCUiQli0y32NdEwR zH}_Yd`kLhR9Zv63keOVpW29@qALCWAjwx|hV?D+tzUJG|S6`=iG8>3iNiLtBaH=bq zPC%`DE6d0f3wb2lj*3lXQ9Ud)j+WoSRxt8sowM5@e@eWbAF+i91;NKsdRG^1d8=w` zB0(nYogLke^{R_!ue`s!5fPqw&VM@8l@xR{ZS!P}K4Pp#9r^22uHHpoFAS_dx^Y(g zwu@#t!0p9UyDPbifTO6%>sgdV63Xto*s_iY%}+PW8z5b*M{i1s+4ca)yHxYXIjLGz zCAYUEWS>u^A)F%5VIH97_6L$Zo*Fg8NdL3wcY6cANw_waL)oU+qKSlRn1&g zfYfE$yJEoh&N6Ej-Xwn(`HLiEq$8o{zvo&*!@5fRtrNf2Lf_2P@LAYt{{ZSO<4;ml zWd1bl1Lj@-0COJa6<<<#qOy`P_M*(Ei*?=q0P3p~-7ej+$qxSj;m-o6jI#`~qjC4w z6u|Klc4KcW2Mi7fVNuB=Tz%DJk81V%xHP7pHwgmE{71@D`r@p^rd!79VqP(jLVzd( znDAbl&_NvLDAYE0WPHcd71G|_n`B%^G^LI)5Cqhh)^WN<*AMp_DirPhU1`uVvw)-J z>BR(;4UNqA9%@{)G4&`>OMZ2=XA2}4ExG$UV>H<~gk6D&c0_jeqA zl@f$lt#WU)khl^?&D>zteB?=R(zA&WE&u?oDJQ#%#zg^3GlPZPzt){^vf($TPII4_ zWAvr$qodx#Wku9S+c2<7eqF!2a0vSP)+dNG>zkVyKFw=s9~-y1Eg>1tTIkZ&WVn*z zNEI+}xMJIfxTZ}ElP{GldqMvIWb_rFk0pxsdr4ViX=9OiAxQ)u!li9q{$IZ>s|J-9o>U%(;>BgClaxA3P|J;?^)pZiKg<_OBGdP4nmW|jOXy6qmLIi@^pge{sx!J z)MQ|*VQ}X-`-hY1U6MJzb}(}8y(2V`fDEb;l$oiksNjDuHfqa?!+W9DIl`cMZN zEOkd+$)`=XX?)}OeSVcH=-T5m5A69kWl{?Pf_itZv;GmCO}57Rwb6__L-MXac1B73 z>8s&u>0!*8mY`%XlEZdBaDGno4CYfn*JNO;Xo;3(8=ZQuUi5>*nz4(_X17%GeDA;f zImhQ+VDM`Rxt{s3(XcHr9e)1+dXan?YZFJkW@X(VAkEc3gitG-qj+mjSqOXUMcFiQ zlbrJ45PEdxm3%cm=={xA-FLK$*P&1G#}(ASgDjTZk|X~Bk8rH*G2!#WepNGgYf25~ zMz*S+d~Ns30088EGy%sqhg4gc4zCkPEyT)!hb`TD_N@IgN4(S_^C62U9}Mi{3Ga@$ z_peE_(X^<1xm9f&$!R3POpG^TeXB0&dwUIT)@x= z713z+*NI^Yg-4i0uzcG@X`GCl9G{@=S60p%kqGOdPsM3@9e|o|FUx1;cV(FL8Nk2- zlfpBY?PNi88xktAZ8;9u0E5#M-xVbB=?x#39AzDR{&yJx&ejZhJm;vY{t(mTo(7&j z?|`UI23MWO9Gqu?Qqokl8u-nPYR2mBDS?o*J2x|*zDPVS-Uc|$UDIDi8hxCR{h3pr z?u;B9=k=(j)2<_uK(`4S&6f`rR52YxDI^{{)_$j@TU}Wwj?xIhR{_)IZ!{B}ame8H ztZbzf%Jem{%J`n*%Hr|zzZG0s^*cCkZ8E$sU5zvv4KIv}V zeJQi(7Aa|U_9$#-lG#z)b31Sc&DY=Fw6%#dv`zBOX46FPYKlv5ASfB&Jj$=qA1BOXxr^lO&p}izJVkwDYaO+*j4E@VEM)r{%B46RKUz_t7%L*BT2eIR@gAuA zzkU}zF%tZv&~ehU?&q5J;qE7sbIHqa27fALC0uF6Y)q<3T}Fl5w+uPXeXF4Ggf@3N zgInI9kTBgEws2T~J}U;V=z46LuA;EVCzL?k&*(j=RsI`Su~fb!bv_}pu}v}|0>>2K zxJ`fpMh+=Lbg#cq5^PVe)lU$z_&Z?Kb!>=_x9JS+c^xEINS0i!z#)Opw;d}&F9+#IAj@&`wlY``!>2W$wnm=8oE0#WTK*~1 zEwr6gV6)xjn8OfTBoa+zc~Wi9miPm9cAlQKqMBs7Z4Ay$6*a7BE#wi(N{3(@XvqMY z-`8}D3tcu#i)ii=M4U(a%#|aYka0=Xv$0B(YUea)0)Q#NRZ2!+C?7LR!(ClV|!SL=gbA1K7Qq{?SWYvavc z8MjRF%^rU1MhEIE(0o0wTkE!dY(FfE{<1UGPxx1hKQ+_*Jh*s#MzJBn%#0X)27jdj zJz#-cKla_OovzHUe#;ar$}QtYI63D$0bRlAUU<+(d|Q1JTO(%Ucbf4lg~-o2G{k23 zr&hJqwJ4^v59P*y63e$IIpVc0d~Qb3X&uaJ2ra_phjEb@r;w z(zN7OGxm<>X$Oeyb)OUIa+^uuD&;^j#nmwg_ir$coY-H}1Zq3>QHk&e7quJ|$shr>3aRoKN#0DTF_ zpiI!#mwuNh+*boR3ao!7;hddiVqI2ih$fFEHU#`I1$qXgo^6E63$9ZjslogW za9%0NTQ)LoAvO?LlgHMzrxe+o^hY{)T0zP5r@G)%5a9I9b)2G_Z8@p5z)?=7j}KO}*`*ZtEv_yjd0~Z~Bpm>T96Vd?PHoUj6*EKl06aZ^ZVgJS1~*C#gY? z&bv7AT$NwEdRQgN%W)wvyyo<+|py7X?PTXPPCMy(og|K6qEo`QqoWXNkOEb0+Na-0Sz?L zno434l9rli0ci=Oq|E>=A)=a10}_&hNkD>%LqVVp2nt+M(&DT@1t=7tQsRIcicl%o zpb7v?QsSHiE-3)aQiZ2tmlOcdDZo;JN(BHjZ7$lA6k?DO?W1i;iZMVD5lM=96qul6 zaY`w`aYiWsnWZL|Z2@sW5rfT0xy>#qz+_MZ)#U9XerA!uJxM=}Dr8g0%>Y)x^)v-F zKH5;Uz=SP0ElL)Y0Z0NE%eYnQP6c)vXNRs<+_1TgLykd@Jbrb^sVKmMiqwn5H@2|t zS;o=afK6v6{zWEr8c&ATP7k)=Fmuo*G5Xc!(o}lg5{S;iVba5pwH z`cy35D4IYnm6jrT0%QFRY0#48+XP}8=1_1k*XvYWi~j(vP0QOH)rsP9KR7GX*NTir zzHS>oPioAf1t0<=8&^2%&*e|@a}#HF)02>C*C>JhM(5BDzgkJli+0NG7@!U+(k(Uh z0rvTtIJceKMtIG1Ge_Xhm0>bJs{rD-=0Pm7vo_92-=R$u2A(Pq{={Se6@k(A2xBE3R?{4 z^$jGQbx<2`|Fwftv{2lOd+`RB7BB8W+Ty{T;!7N`h`OmrRfc`1W_1%)n)tK1iSQJ&#Hwh%6+p;b7 zy}Yh5mkY_VDR2s&b4y~OVv%O)_OYn!221*cIozXMKq%UK#{hxSzD4)L*`DrGK}jgw4!P zxoc5hM_xulle3>T2_};d&hyyyV3PV<&U;q)WwTv*{<7T*8)28aF`!w~FCXW`mq&Oc zLz36k0$uj57#vVya1SNmXr@X_9^{H76UVSj{gPIx>3iR9L z1v%JqWNr}1s)g{1bvyk)S;O5|&F*a?GE!L~AP%l!p-i`f5e00+gt^(Imne7WgnyCk^GbE449oc36WT3sirZ702AN%1Udg3VtSo8U3QjIKUE3K;$)InR(qRhw`$@{|bsIvCU;2;s`F>oRV!jBzp;eoKQP z>Fa6;>O3|!`4sCYV)^B-0yarppHO#wfl(V1Zt%2EeM9o~^7SMedLZlpX8+B4l|)PA z$q|{_61_j=jC*2HC6O}GmkFnMC_cE{u0C393z&{NHi#E}!Q_5TFAE`DsQe;|+~BV| zNa!f*_=Unc z6V(lIjY9rfSfdd(S*XVD2@@3PM-mv)g(4z z;wKEs8(Pje5d20Y+96GV`^%olW*tjC8XUxhQJ)5BSUPsb}-qLTpTy!e$ zyTmCU$teiVaOdElP>^Gs!ysR{CK?VhX_IZ+ge zdo79L5(w4$a-{vPQZ-8WNtZm)r|8wf-x(S7y9pq3nk ziXM^NvoKa0Df5a!K}h=Wk+vOFSLBg?#lO&5V5mY9334cQ&-(pke#AAc?IT#(PInHz zx~@XVXl)vNz7idi(=l^2yD{qOXbCM!O-Q<`bCbKw0uXL#9j2zHC64e~yJ)@VcC8&d zn9_YrW>WnO2iLF$e=N?Pv*GS{J(`8f=VM>>&q&RviHz${(eYRVYvACG?Qc&#O{{AO zNwEV+SGc4<2gX9ZBy90sN661j#indRneC=VCFqTv`kg$Jx(h(~`aZaA6i+ zmSOW}U~h7TC$=NLOkO6?#Dalt?XC*npik>)fq3+;6uhnHRt&&Ubv(&|7nTZ%rBwFV zm`??i05TG=Qs_2nkj0Xo$XMv>XoFUZf4qJFFpZ->fa!Kk8^T$VcWn~CiB?MSXi5m~ zj(%fFz`63;yF8T^tG?@`CG&)A-D8td;JRs{-lI`I+tJE^K|?Kx6ugWrD`PBNSM_K> ziAS8#Gb%|4AI=ALl3CL@onUZLvCxVP#iWWeT)bHIE2_!o9+DV6)82Yo7c~xn?U5^w zn(M8?puCOJqKY7Xr1V;D`G+P?RE04@Fx19;sZ5L}!!>cJ9Y4R*l4g>K0Xy0n~p`#L77(sJTdVrrZ zImIKna)Tar}Q6k-?tdxQ&Py%f1kLn z>hQ;BOdSXLC+z_8JnOf+yK`46E#xG|_YMSlw)}YKT zIa3GkxS}a6DK&NdYeca+KX~(S;Z}g-?V4g8-RX9}A}Wwl3GGE+c0!1zQ3IymrS7SO-s=bF+OKbYeN+(A#jjxU=dQ%^ zd&^uS}0MCL5!n*LJ7GkO9=@OK}`cYZ$;*2VyJz^w7`5`?R<7KKLUf~?) z`|MTqUw{5$E>q6sS0j#`)o*DPs}UFaY=NIQf#UrYF)$PhH?2n7@ zDm$~9V_9PG(H*cx)LjC~bhJtG&9h0YqZ%-3W_uGeJT@CQhQHj2M-Z(^(FT5}<%$~j z{Ph|JQKeoTI-NN_XCz~B!KTq2Khz~F8Em=i%uOjh*4Mu~?mE^1G&jk+EZ1C3;45k= zZ!HKNGKLL$wUrGC_pY&}h%2rulW6%BxbiQD&P8kSsHC*^PNek-R=uxGBq3#NyZ%N& zn{6LFJ9$wkyttY**rl>ld&$&}^3JosI|1onZOxlD%n3&7j(92`R9w}B!jM3m{~~`f z7;g*Wp#T*XBn3ZyS|0GWWCjVkf6Kw)uJ#{8R#3@zMiX^E9?F3aU}3c_$^*3- z+$I*!bhrac+D4@bR*X{|1c3+p61pZlZaF`T6u;WjWUh!}udUtQRr>@(1@ha?YpYz# zx+6J@`zezpT*GmX2E^l15rP55CycUps+l%1SwR&&r23nEZPmlpsn3q9!0w--_a~;b z<2#D%YMIGdHZ%E-z7rF2Y505BF*}UO4*eEtTjFO~Cr;Q%aw8M{L`x(u@5?d^tl6oD zBIbZ{z>liqJs&1Sp1m)W5Hwczr@F&$Inp7~hYqfz@)SfqDlpl`{OnjjloVqw zUNFLnd-dl!#nH`)wqf{{`gnEDEogg0^nxs4q^dFmA`JrMTNNLPERISzyx6}Via|I9 zR7eKyZ?VN-rx?uXmKRF2g}Dv8I!*VlrdVKk?~H%gW{+A^7?aV*qJMuQWdB8=Xs)&} z`rc{u?nOOeHCc?(PD~KZ(?_$k~t<{mqaCAdG)_*sJ?SDB+V=MFBFP zK1!gzFG{c8+d7Oamv|(NtV+>9H?`ooVQr`GVd>CTX`1v}HzWt-e&MrE?)-7BGmkXO zZRaQe560v76z42R`aQWgJKNr!8^?A0WV&H3ZVoSyJ3g*nN&%K_HF@B^8K7|ztKeq{ z^eiR8Bj0nH|5&q)rKt4-Z|NWkjDz)O=aAF(OywFOHIK1g6tl_Y7~^?B@0n*fO%0JB`Kz>U9uxrgd6?iM z##Kcm-r47yll!=d0D;UQm(wY`%vjljumOpM zV~W?C41#O0m>mk-F2&@-WyV#*r{pX>USl4@|P?=Y^5{tT?swgv#OQ%tY2ONSz%x!dc ze!a~&jD3 z3F5jk)!XHm$Xc)&|K1R({EhPg#n%OPP1W{fM(K9oDm5~bv?n$S&2wjoWNqzNJgY@c zYYD4pxii^i_6Y+X(+H=715T5=o@#VI>&7UhKTErNMiF-u5_+3*+H;8ck{09PuZiaC z5UL78FwwDF)_NbV&9m8N`m?0%B37Cw7q>Hwz; zdl@K@?U&8PoLNtE3%}wqPn*y^{^xalq(1Gy^Uf;4nfD`3Wjq=NcVOvE?Mdn;7(al7 zv%ZMQodZ4TSmrm?^Wz(7cC@X6 zUDhh+;$%(b`=JfC1___#^ysMr)%xADY(&vcp!;ua-f(=1Bn_cBCbWB7@#-A1;V7^= z1eGm)xfm5^yb>8AknS*MqgUAy4+{6JUpc|N+;7Xk?}=^1bIXgj^uhw(*L+}&@WhF> zXl!W6fQ{7I=@En6qvqBVM-q&3bVjHLBO5Ck7oJrmP%XN znS!So4E*1f=zg{5>KEBJ&Kz|^?aFMGG4Hz;Civv&&%NWW8goeaqe_@?pUm>0lp}XW8pY!Y@?pQzg5j>qz+YZm)-gD7!~m+ZURtlRKVD zA|ulCI)Z4EHb~pP>AjXB$?5L0O3e26g{ZkPwdGPqXHSz`1|8QZJs`tDu_}I?+?+>5 z%^o~rNc&S6@66enri-56{O8x^i)xJ>O-Yui4ZC#e+v~p9D=qhPPDKo`D}IHwqSoJ! zQ4Whqqr{5blg!|Iz4Uml%w@sKRW9m#DUr4u$^ytb(=`cuK>yh-V{5L?>`I#C5wNmU zf#ik6N(`c*GtIrI;fT7i@)hs5OuF32XYN-_Iav$(aGq$e_uZ!LX8{ofr3AT(9NuO301DuKKM*%Y5vc8|CAj!&yE+E$?AE{Z^;j$z=?>eEry^uiV~{|@dt~bTfU8a z_@TjCSAI7w%W^6WcB`W#_p<<+Tz}kJaw)eExLPsh=qQ)NT5aF`vPNGl*1Mqkuedo5 zWkTIJZ@?>urDgWr%m?%7O7s_$&=G9J{{R*Fe{%9|3Vp8C?lYA1R^yG=c9=Tdui8x( zGmRn???r|dQ zv3e~=L)Lgfa`=^qJJ|v ze=C#YH09SQ_7&9+t-CsdL3yKy5>cBseTi1r1da*N$Q)reBzhb6dfpj}380 zMr}X))#OYot?)FOs!=iht;q4>4wasrgjFp9ZZyyKM>eOSMJ8 zvId}Ck@Wv+3nij4AZE6RC%HjV9S6X}Z{BOm{mS>XSiLJBdGz^7YJB!S--Xv2_jDI$ zdX`%nCQRYz9r3iVLQOf~a4hvk)n2(6-eDj4)+LTItdwo)02(RJq%_=^VBvP`{pnP4 z2^u{ll`>=a*X!~8`gETxhAAu|lm6`qauH+@h}YH(OSE!jj^-VRLAfRfehw&iE2x>^ zcWm6q;t^akP-6=hX5S!PenUz9}w z&#(RhZ6#?A&c&EpnEIBV=vr@kswr-WyL=zLoQfWs?|;DuIMbF+V;o%DgxX@^9Sh!6 zUy-eyj>U9pMM%j+D&>Qg-KiFL%})V(yw=g(cv z6ikhBsh_;>3$iquWaqt0vQw20&v?f|qK{7h^pIGkuIRW|pybRp99hrI@h~_zJo(AI zWo*&JYOKa}LZV9jw(!g1z6O^D_zAIF#k~8Xm%GtM`0BH&W4VyaN@t&XCU(qL+NNYh zZf`GjrmNvGxfIpaZgb~9xB9j7elp5?iA$5{O6ICWF0S$({FQb;C1J$e!uA#GYZ>fF zx-ac<4m;IuzAb70w0}?h5XDU#@zeL%oATWGR-&)7q!&>*++DU6$J%r=F3}NXsNayr z*$%Y8(pn~iMN4NGg?rfM8=z+3aZ!b9&6LpKY$xq|OWFy|3tJ+mrsUYr?=w;O01+fv zCjLMEX)ulo2RopsAbtwfI_iTm6oAhP2EzbUDxeR@qGs75N%q%o)QSqyG2W82BGo*S zSrrYTwJFp$O17-X!En1=o)xKvM$|10z*-i!Qeqn4JJ!PmZssVAWNPB$gCX? zN$@AFC=feffS0`>m;}c}OH~QeyOg7NfCV64{g!06lt_li0_tt2jZEFV^fcWxB;(f5Y!iuRNR3@uuJI@J7AI&db<2tdtmY$b?XPmiz3SiSVkf8;Ay-&RJoB2d$s)obOkFMXH^_l-JbanA?iJIkHU8 z4|ScF1D|S^Z1tOZW%#KXA*eh&+f2(tmE;qngLWVIf3U8g^mL0J+c968?z)G%VJh$Z zDZzTTwa%ptn@3M9M4%?65){4P%34&b96;Y9+wvy(9hI`QT4qE^?yWxoAT=4K8Ijnb zw!E46cDo-;Xlm7w=pHk2K&|^Obgww8`w(5R>zuk$A#uY&~;?lbG)dTzM~MoaXb@!lyGGq`Q(4 zHYVd=P^2q=U^{dX^+o@qE8TjS`!VO7G7=0@WG5l-Qt>R)1AI!@9~*a|I$B71Yw)AY#~D}vT&6T=(aHX zAAs*A`J{z8src6(tpEbL9~bSE^2@N`cJS4+yXyY{uN*JZ;_C+e&OabdWX8ow6SrdG zv19zAvP6d%e#bagQ)eod^xG0i8XgD_#ri(#t2Km~w8Pii`I(|M)>sNl& z{pJgYc0fQG(NvJtMAdr}#gNIdT4b*PPV*gbtXkmI=K&Zy^V;ETY0!pJ;dKe7;F0$G2wqxp~KvYdnI%sJU&3)R`3S0k6J z6OG0X?dS~*%wODRX>6jp+%3@+ytxkQPI7WpYV*__9Sdu-eL|~#|BQFNrpgdW{r-_E z^*i1u&#ri3y8mu&dyD6gWJO7m)EUEiK&Ckdt9E^*Px`R|TgYGil$T0#A>~lh{*U=h z=kbZ|xBIOD?{r(gtA?Am%rX(3$1txpr%Z|>s&$=5%c9MgptJ^`;4kBG_nCcSJK4XI zH}U(K;cZHKjL$CvL3~&fQWp&KlEzxFALNN6AOC&r{)&^G8&VNSH%CWNq%8coE_Sv1 zA27br_omth#)MRV?6ul{Mai3{{uwN$#4YzxX(9;leMxRZPdJ)>Rni*c6EQN~R?jIo zh%|;l1SXt2=LNzP}_}2p_W=2w;AaJ4owzoh@{f2G$WRw5-{S4Qxp zO}5i4IHk|5el}KOxq2#LV@D&!s>NE!ggr}B)su~PbvS7>eJjjHat_v7%a7wk4jr*4}ijE89V)`eZzElT1gGf^~W8w_u_pE%oFPCeT`!(lo=p}!`qp0@M4V^Qo&N>cr z0#m#C-*&%H?X3xjI&N56MG*hqn%vPe{%iuWPYOtnU8@}nX?e2$ptZQFS*L1*xG2bo z3!eD`gcA`+$S*$7G48w~?p}t}$@k$)fLuJEGz1XxQBom`b8YI<_yAv$vS(4{3oW z?i6#h`H@>LCBsIzuUUCno!3||{FIkFRul@XnX`zETGp=a) z@EKwL?t4+fq+xF96uNoBrN-!!4{rv^OS?cfz$fvq7}@=?R)iS`DO&ELCyBO~wCs8Sx@6A+fzx54327p5JJM60VksC!=B z8It1h0rpvHD1~v8sgEPTK7jE!&!mY9m$P0h-G=z6;eMN7J%MAf72vlo-h#XLU$wX7 zw8Jnp-gUDhskzm_2Na#8llyN~_#nNOKhLn`Yf4^ITs}ZT$Ra?GI_So)l__yd8jaTwi=Jy zu0RSF1@QL7WTKKr>)5Txow87&w>^do>FGN76Puy6w{FU=8Xg-~hItw<(BU^1$ljNyF!fz2h_5c>nyF}TE5ZfswKUbXaHUn_Vomk7 zzS4{w30_V9zt#9Zji1OH zwH!tklkylfV$8#0e0dHqu>Mp(k2A208w!s9WO)|6JM}O)gioG27K%Sz2B`y23v7Uq~IcvT{>) zLl##5576jT^35hwr`3pw-h+|df zX-c8N8sK)^6Tbi)eh-iNw7KDs^avfgRF81>xHZQ8mWnh!0m#l`W_3*ZTl}i7|A3dC z73@Jl*vCz$+s-Ve27#M`iIOc<&-AL9`YqoIQ;3pn-a$84n6NMnr+JB2jT%xvGzq7u z@}F{bLSI(SxeA&q1L#MlKj6tn5g`-hd(3~V3(P3CTS8Vo#B2rA>lg=O)~l-8Bh3{r zQadetLwXQC0D?ZUicM%dpPJm7qs=cJV=hsZ+wH*|i`r|430St*8TzV(5dZS|aiZNZ zv)0u(y{9xLL~9H@;{Ms$kaavKyIeX02$f}KcHDs*w9eMvnlcQ~#w0YaP|07L8UX%T zx2=4biT=s)9o7D*L=sj9I=>3D-7pUocRw-n_9IF4PL$=97#ha^o&dd_U1*eUxOr8} zocJbDj5&gWv`lP~L_Ne-LQCFoLT8&<9;Rdxgx)n~ zkb!1~*rv8UhYcF(eA8*+eKma6UCXub_6PL?I*|nb!8wp2ZlaAtHGdK$sUowm8NT28 z9Taz(z&!(G*J?rcK4@0ynG`P1ANM4yv|Er5oce5siEONpTB`Z^rxD|lso`a8E>jz_ zzrVeCnjoUhmY#xshqZ*v2cx%}TI+Y{5{nRM{!z3$ak8G1C^dFIJt#ZGz_;Tz3Dedk*ygSVTQ2Oy#K_>qGMWJuR}arJvEAP z7x@oa92a?rfka}O|6hAVGAuca z075fV_(D^tGgN|V<9x57pJt%Q84D_BTQbGKnj}P}0@&%^&jIA&Xz9OoRbemALrwkv zRdFbDTF9}Ay&xF}fNV;RM}F^rN2&2R9RDY))hlqgBL_FF0U(tXG6mNk^|esQGY_5Q zQaMUX21oua$@yF|-rUqVG%vpJSrl$vyxd2-ftRt!c@OEC#5|dQ} zcrcfJPtbi_7WHR>ULYK_z~xd^@xj@l5d$e7XJ^+Z?K_w^^HlY*Z?s#`N*=<)GPza_ zyX#4fUTG?i)|Yowy5v3Y)A9`#w9UiXl{?CL70$OXgHk}D+tg+LqegDOZlbwVnS(fC zKLiwM!{zz-LE=BAaT`wST zqAs^scHYsSHYu+d+z?o|6>YaOiuvoL?S_-7KKkhM>xwGyxvErASv~yrUB}YZV%^WL z41sQ!!wgmrje^++8`)ukeQBv(%Lz&4sxHrjS<6hNBpcd8FH8wWB zHa02(fB%d0uUrS{3p#=9nRYD`HEVSJ2wFZR zADk2tvR~4im{VFQ*I~c?EJ$|+j_+5OsgBKnJE(1j>p4Bf_GIh=vJ5XCw;v>5d1m6b zho6>qVF&d#X7=A{ZCDj#C(Zp10FL`e6?4~_CSO}IQBt~t+7u2N@WzaqUlX{2`4nxW zqqtX``EZK@`hO3J>>O&4iv1lKVjH)+dS43V8a_9S&S-YO&Uv}bFWlNs0#cY^1{`6Z zy>nW5)R4kP9ejQh==yiN@<*bmm!mxLogGQanr>+iO!f~u!0$nS5o&Pt7-?{_SgaA0 z?*?0l?G2*dAl6CI3ng|d2!4B(L*>Gonx-TbK_O0})?BTf%125TdYR56UNxeU!=((w z7Yq@nd-G%vnZkj z;JXE~YYS(P>;#Kx5v87bs%FB!nSn(H^Flgy;$&B9j--UUW-qAEw1+(ja87*)6sH!X zzF&=sSZrR!SnBJR-dDd|RuG*vnZ2EbN59=QK^-adCHkTBcM&5HSI5_lh#_xK#g5=lPlJ+M*bPla@y_YdV@G6!$QH^2%t(yg#>E_um_*y@VjDRxojY zm>}lx*(aPtrQZ8Ji~FB}DO1WFG-sqgF5kAVcR4dQ+pN&jWZ_saZD@de>p0!)c;@J2 zdy149f9GiIsIOn2ot`PJ3@xS21#nK1d_?XNIb5bMW6b7GDmH3eBxA%Sp%wcvAY6v@VonqAt4 zzljs89}TyXg;!Pz&^?)*u!^m|IU9#A8nm|mvW^@7L>!r$3F$5SYoqZ~XYp%Oi}qBV zxeT)h-Td-#4&m&V*$q`cOCus>Hg}pA>(-(R5icqo#a|D@0<8CLb25hlTJ@{(6LB(Q&z7X*v%R zWM)7~H}$uZ=(!8N;fzqVSq~|t!$^jif&~-*sINbK+SHEBOEohy{p;lY65g!i#p#8D zqmy|it$#BXNozW#*Q4W_J^2c2sE?M>`(#m0KhG*2FQTnc*4F06sBKYfBPMJY$ycJR z?bh_5zDrw+{E_40E+0BgZ|XsLnr_$1?Q9*bh)OX3x{NV{5Js|Z0Ju%~uEg_I)mw$sY521)7v3jSJS!R*JSIsR6*8G&gXWhtf4&|_&f#CZHhjXXG|6 z2gk0aDko%GCZ?m@-fGk)m6Z=_z2Rt*Qm{6s+_vL8`@K-VcJD|g&lui*#MjkoPjVvm zEhhEs0piplEq!3orEpWJ;Kxff=`nR8bEo<*y{Zb1 z1)uy!3YoBkMD57TOz-V(*HKiEXOX&VitIA(+?F6cGebS;yg53fTY z{NrAa>QJF^J`k3G|LJNy1goE9lK*OG2(MqOXgx|ad~FQ zLkW?q;!{L7C|&`lvXZeWwEPcX+{lpIA{~M1Ze+&W*!W#1mUv1*B2V_HJ;_-4x)U$2 z6Y9ORyEVAM`P^jD%pJ5>!YA1YMt4Ds48(Y>xhq|f9oxo|`!%o`30pGd`o=)*-wS0_ z8w*59Quk_DKYDh!V;c~~G=^mD!z7gLZJdh`?oRcT@?)Q90mBbJDQWA?9H3bVAZ|H! zV;f3N_qgtbnuOZpG-m=RYvflpApiFmJR}`zCyjrZoSH7nC*c=t4FkO%>4i&L(nQ4f zP0?|s{QVvzToMsKc$#bLSfzNcsAU9w`PiY$F<^Y8uYAFL0Il}xI&BcLzh+n~1P;?I(1+YA!+G9VA$ZUnc#g&O zf7Ot}Dw6|NsRXELU1ccmK#O0k?9GrEm^Wwk zCVA))_TyX0HLriK`Oy&KruH3Mt8}qpnMJ6zdmpsgo^?T78w z#6Gp8(dDa-JU5NJn$4VmM}w$iY2->%aYfQvK%tuDvp3-u6S|yyeByIOOany6eLt$M(0qIPIpED6VpSp@$fr zki|~Vgx7z#-d(bv7*UPz_3U&EsGFogFVqkTAyf?!S-L5kiB)4J1x z$Kn3~7mY8ZgUQI7Ri^!Y+-lUq!&B{&P}}0lNTy4BFrve+vLjCz-X+y6f&Ik5%@uT z7v)434)WKJni(I}K4^6&qBpIOo^7v8B6N&?@hY2u)^OvbUcKRHldQt(v>mr7mmHsm z+P$}4|4NV6llSJv_PmGLM(W8Kj2lrR{?2Uq2V?Sv88*#ckMjAX$>66TWiO@^6KL@mc;0h-v*d62rK*2T`dUfwQmB zIsxe0nQaB&#k%qLlR9(emCK`kH2(t_mX42(eNtlu3*ggei;xS2{ijLEqcCP>%|_mp zXrj)l@d!c9alou;LNm62aaQE)ggT>bLz0n4psPKts{a-Y=CJ+0itRkDC=7sv_6!bk z2IBbtCpiGxGul(AA*wP3MHmH9Ai$@Ys82{=Ar>-`hWr>lmjb7W>nFxw;?#KLS=17$+tgUNu(C!#HkSx@-)!JCas&Bdf?88jFKJSJR#b!-S%}|Hj=&^)u&?qty{fm2^_()=hnP-9C8 zr7#u?+P)yKbILV#JIgZHcRKA;^FYrOB(YeENl5LJP^K;RUO3HlOBHtkS;UrS@jrls zB}1UDX|>GNxS)Jj^ITqXFS!NgF}|mFoTm`pbd{S5aI^_f?x}&k(H}I;tG03aRO40m z>|+0Y&f(q7a!30rIB&R{Hw^7Y5+CPZ^iY$8xKL7~vbQ6VC{pxUl7|4p>^(8h@|6V) zB>j`*o#`|15-K6M`KFtnZmVu%a>9eiNbC^xUG4=vOc^C}vx{$mPXu6|Js4b;cr7$9 zX)#HDmsl~c`$hMc(S%{`h`JxuLHoaX$&YrO)iIOIxpq!&>eA1;vOLA*ES46zT2Kfz zZrUu}kvS_Vkmt}YZYQocp0=MHm50SiMg04<1DaATwBJW6g)Qnuo)@J zd;Fmk>Bf|D!zu^h^d%Y$;VCgeV1@+K#gWQueL13KAY;enYrvBN7gpb+&dK}z4G|nU z@?pv&qkGl8b!8&@_2L~9#;9mbd-o%a zqDmXo*zrpBUtM({ujtUE>`W5c_=KwNqrbMYS4DlJ2qBJuy|MP6no=9?@I0{SFcE$? zTJE3fS`6?z$8BRDGwKLLyiv#AYU(*w*?t~@$WC-V1kpw6>WN!ktSRDTPJ)2|9X=^; z8STxTTfvl&1oJAu5DF8`0pr)7fu~)G9j2}t&L7sFhdpiHr@4qo zmtc_^ZYTxqHSbD4&aeKhRDsRi;!oLWN*?t_$n-F09fStLhea}XeL^m(rS$vI{gdL< zIU>CB?ftCq@Hv3cw~SBgx(nVpUQdg}aSlPZC-6)ABj51wn0nJHMxfkaEcF{k2ogBn z%F+N|kr=(zR!}11N5BD!G!B0v1rW^P_re5P%5M|~8beXg9t{*r?V89QKY&bDABI|S z*-adWk!0hMAGA^m-mOSFWBprw26b^aHGseh{(_sC7er4peZq|}sBb3moZ{@A9!T1b?{fA1@l zk_0xe+A^N<$SZ07kl?iDfe@ZmtBQPU;n4z*zu&~o6n9RY7qqpJ-K7yaqQ~U-67vyO z8_bp@PF#tn|GE;{0+pQQCvEDugD%k@^$YThdzfbisgzkvmvo+R4*}cFC5@pMy}f#` z@ZNx;Q=(zKVrMs4!XVXgH2qk*D_}z*7s*I>{y7rpdZr6s4-|D+nVIgG2rHrS*^I~XHBwg6mJ2A^p*TJi(-CZ)j4kYwGpF8pt-2ziIcK7|6RS9{mJ}vEiC&Z zNRhU$_r;$b)ej9a&z<`^GXDM2E406#o`MdA2UUd{TNA-l%7psvNt!twQ%8&emA`(r zg74`aX3x$^CF+^&dIAK*bV115q#i4|;ieU+i4@_=I)qlA-k0WdwSp%8hM*^XGjo2I z%Q3&?8+T=&ekhT1cjb3dnzR3bIVSM3#BgKHaJ}m8szJok%u}Tsv6>cXiN?A@P? z@}9c8%}%Y-pb=un)$cHf>;-h?mEmCi5&g<5AtDmUZ4G0FzV3$MprM=Cm1KpZww9GQ z&4n{}>Jj+`%f$M3CW@nBNqM(6x=!Cm82_jQpCS|SMZK=*ifhY#IsD97H`MUj+g5=< zYHaH#@L2Swys8TR&_JUUrh!68@I$)=7GRKL?#L+L?-A&Uehp)lHM;el&+g?uDY)Z=~79 z#R5I;5x8AFX%Yd$@h@;yEmCqlI2r$-ur4OCmvl~1J=)%S$kgKdZKS>dAGaO%q#f&h zw~;I=FM2j0_qaYLXTKQ7WL`DoalQ%&4>LV9K$^?S;{4*mM+ zLeXjh%hubn;bK;(ecoPOvX;EE5~z9WL88-ZJhOf0dbZY9}&4LO?*_3|#U@S9w|H&>$Wj~N%S#sg$zJkD1)3)?7Lb$zn z^1xPKz$aum-=ywPozsT$SfFLVotEwU%wmaM4%Y1XKG<>n%;Y+p^7Bak>=Uk)BZFUg z&Q|jCj7Z!_#qN@KU#8KQnG&c;c*a%mBf;(5CTC}I`3W`QOg4p{OjN#}0)Q3+nEUU5 zCJvNi9w*%Xk2#Pobx9d#C=pAZCUugo^IMI(gh7GY)+FJ$UE`|UptS?cTBm!Gwbg!H zY-4c%b4oEfi0><|7b83-2FlL``)l{Nqf0yRhBJs283tV#$PK@d)SeF0M9}1J;JHbI zJaZzg3cs}hxvxl1NBMZN_?%!_vlwskYb7q@epr(yeqKWCGiA>x6sAb!8RX}rkY}{) z%)%|)rnd%YXoMVFyn2Re3VUBjTRJ)*`**BA=CREwzSN%~ihV_KsM8luq6DEeUm-E* zGM&NQRT?D4f8ZgoRWPrmzUXpR+0N{dv7NoR;rybKVJRWJ2dFdMa-sg#9jU%a>*xsG ziwMe3n4EQ!W;^t-h_}ZW_?6q|uC}r4=9n#$@wd}^T+g(0GFsrT3UJa6DbRjEMwoMh z7`5-?e;EF27GC@--RC8?ktRGa&_6V^#NrxbAc`)sfA@yluKt4h4{*Tq&IQ+a-`x>+ zMIh0wkmAfxx0WKCzhD<;?Nn*Cm1%2fD9mA*BN&|NK5p#odIfQIjZM^#)*pD2R94>?>|}UCqS*;N~V`LSH3CeC#30q8$OF&sdItM3 zhI>QWx9TapVq40`V{fnpbXn1}hV!tHj`@a8D?^dP&VLy$q?-?!%_7kz#zKxecSYP- zW}KpIxc3Tbdfwb_n<@4b%2}S5up@9gYpT=e!@L_}Q7AL=u1I*A3QR}GM5|qs$-qWJ zkevK(%!TuYuat5`H93b-!)%^ON6Q5Z4!kxIY)qM~EGDM{^TXaKeamy7DVhR-i`htK zXM&ORM_>_ade}HJL^cIbdz&}&Mg|+q&We=6+=XDtaC5R`ZDd;<=s&3|iaif&R*kZ# z2=%)VK0P(oTp2auh2vM;@HLZ8L?R4Mo$Ky5DZL`0kO?sIE-INnj z#4P`*TfUzCjvb(>3S;e+QUCkMfB5#D#o;b)Lx7#NU);)<$SYX zxS6De?TEm**9;{j#}gSdV4El!O6?1liCpH^5-6!q){}C9akMKL`R-cH{+qA&<2|xr zx5jr|{uO=cJQFLwQpx0f_`w_fufuyHUdC|dgPFaRdbh|4Hc2~TEBS}1VURj(nVez-9W6cuzA3A ze6g_x3mWbd(@#SPe$jN^Bn3$&P9ZEk$PJU9ukF1m|K0cMn-rDzp5?h4{OxBt<`o)w zJvW|4e2H4Qp)6YF&4LB;%^%0;OZOkg5(5zyF_k05TF3fn4v-#`B!ZB?-#sHa2>q0s6wi=!#weKAv0t9^ze=9OfD~$KrEaD+ZsKS?@^r8kSU6fW;an z*`(V^*zw6D@~aM_HPna_(3;Jo7AV?55=tq@9{5|ig8?=BQw=8=CxNf=m#&%F4vp6UA!HrqWfh<;dH*ZSIC-i`#R(CHoXDIDPZ3j`Gq@~?pY;=PW{~R}sX3EZA zaOH?fTW4BtRy6c`{EOJJ(N;lseEI0v%k*zjYW(qP@)9HA&wsDvlseqe{2Bnm6 z!uCMxz%LS=**3^^M}C|MbHz==e=l?wY6G>017kL*jnmHvNf!5|%a;j0^-kmj?U(Ax zEQzsRM+RvsqJo}6nAtm~*;6Jz9+A8shnd=JhvDoEVk+ic;^gcq=(@f(^?YLu(7Bl0 z({KGVQN@z9YzCRG9nF(G*{V}G=51GqO17O;?dWRkYRaN?j@x`CNNe;}QhKmiIk;Rf z(YIJe`tMV++2t68=DnrzpatqPH4YM+9KYDatwdKAtzUQQM2ou#3L|M%bY{9MDJpOb zVIb(`8%K5_WR{ui5WQlsr~`1=XEixnW{VNKX}T#$)Yv! z=e~o;)7`KDg~)qS+-1|rLp1}XF_Y1MXV$mm>mxy1=5?s&=lg>MzJm@MeO7J*p|60q zG_?h0KOa`Ri2ycly;yBW1}y7pYjkw~+4_tl`>2l9H$CJ~p95w8`$qKVz7c8$8*k^( z6fr!fvhC|ATGqiAcanWZ`3Mw6i?uky zK=1ylHOCEPZRFKq`qr%Ye{Tw8P!FeK%GiX z?_=2yG{l6FH+`9GLSa7_#*Cr;ygE1B?`pl#bB2Q7gp0yUvM%hPzXc9wET_?)YL`a* zP5CZV8)%JTh*tyh((!lA3=Udm;LIE}SaHJzHS4LjV4ed0j{&L6O*5j+{O7o2q=br2=ddD?vZw|N2d!s#erV0C%I5E8|B+G2LXIY7=;$t%jTwkE94| zn8Gv-Co0^^9y(wAn`xjC6m)1pC(qB}`wX-Z%bJG2R)I*m^HUi=iSb<~EPyAW8$%k# z(gzna6IlkZB&n>9JxQIm^Ihh!*zvKpDSD{^Bshihr47LDTbtJot-Jo;>dEoW^lqo7m?3*(8Wly zD9eOz`GMEeLBmo>84zpcaD93Hnfjw*qd&`5>a3bvu{hmi{9}TFZuQNNEK%%MO~U+J ze}qH-ZY}tGV>J=Q&PlJ~R=&;O-P4LuemZ*}{sWLg(to#zfyai%j#;*TOQGJvh98!7 ze|9!zX6*YKk=hz#zR_O#8W1J`OUx|ij`deRr<}gUA|<@93Quoarc!#7@SbieHOU-? zR%f4=vA$y@*+i*tAkO7Ds$Z0t-9uWz*ot`qGem zxuG&O;St&xC61KP3+)$_-zpbZ!Yh{+hbT%DT=9a`&+6Ib`NZZMGwIOST;sf)crd-& zDH!+jeQt;?RG9DnpLm(z$W2tyq2fT71ETQjcGLO8bR}#^f2{v2{pezozFUf6$7xW8 zC%^ix?B{}~HEGv#YNrFa>MkYYnAz$#l|p`P-g|98CNq0Uq%2UL1wD{ zFW$j^F!b{4hvF-$wt7)Yn9qk$!^7AmCX$Z2;``<+v}6*YABX4HNlYaa9MwIy^iS<& z6JA5B6!WF3fn$za&6TEX+7TVfyY7i><*o)Y$I1Dz%j6kV=t+O$n%$EHv__o)PG-<3 zAkRlDcp+c(vFQ}s z%^o`~VUFysOo+>_{NX+cRku>_^}8u`?9B@ME?KseN@2NR;K9q_Bl#SWZk^^IFo(SFRveONw)g`Z_P+ll{~Yul~i~(`-fBJv93Ucc`uwuE*bQ zzrL+#WG+R?rq5lpl(E0x-cHe~k4*U-*;Bo*Mg+((t=nA1|Cs!a(o_$e1}^S!Mrp-z zAz&DFIYFC`+6BMj>eZK2nXTR>TnOr3W}^tgVL?Dp#QN-ZHK0-999 z8!Feg>CQ#9cuE^(@j;nLEOgPW92fuu1eC9c3|AJ}%LGO*sjw5Hj_L z0=t`4DKx}JnePd7fIQc#LS$0N<9q&i{~gyE!%y^D!#D^1T)t|DCZbwIt6LazP{Agt z^PznHS>@P>lr0)d{~UvI9DxVY_d}YSsA$}t)qazMh1jq173o8>spa=(k?ABt;^Q8aSKzWSz| z7*Q;PQX4CLgZ^HMu~_lS(lk!SW<^UE0u~*fGPLE~?+oxy#<@d&(K4`_9E#OoO@OhQ zc!e*2K0FYo1s2K=YO@e|u`>okc^`fOjdbyTSLvbg80b@ZW4Z2$Ufs`xEGP zB^xmvkk8isBxUZK=sjZ1 z)7d^LUt!B`NgX17qtgzm;VlM`B7Y$@yS6X@h#o^=JJ+&ZIof)O2k>P5E)Ry(Q<* z@gKU}>;Qg`@8W{inEu$L{@iU0-WI!`IkNFY#yNO6ImhXw{Rg1KQ%rKx9Q~c-@8a3; z<*kQEmumBXygnjOTQLW3l>KNB+Hy6m=yA{YBwwSyuAhbPJO*Ozq7!;pFFA^T1W=6N z(d+$}Ho0e&ea?CM{v|^&!rW79Wc~-85PK3ZU{W#5K9%-P zSq61mkB1mGGBD&!er?Yt~ zu5U0aRC^@1$V}n;m&mTKtlSr$_f|K)AbLpmL=azQL-3{_}XH%B+!u z1@OwMduXZJbca%fV7f-lPYO>*Z=w}3o>fXUl>+-?yp$ez-{(_@=^pGtgr@Vu8Dqwc z2{Y?_Aj(eX&1=k;Ns_jKKf$4ict&WYiKo3!teuL;oop9AS&KpDt2x3uea82qZB1R* z<^4RwyAx3il<(Ig^9Z|R)n-(S^1Po3EmEqfh5bc6dO>@}$Fs4>CS@w$_qRss$kdxU zh%Xx>;1MFAb}S!90Q9(6RhTqu>uODUnDdDUJS4wB>3-!|U68J3Hkpaom)Cv!@1I{~ z`GZZ>f^B$rX}K)2-Kkld#D5?1h_m6dr-5C*z#0x(_vm`ARFbqd^l}h75I^^J{&T*0 z*2xgrNUhYJ2nJ1_@9sRwE|BqJwdZ!QnU#9yNk|=Ah^JGL#+R+6#7`A^+Prv9)CaLW z%vm2)3!4vppbKZ3kpT)OYR;z2KlaQJE%`dFeq4}EysdLGtGyFFR%?joJS8xN1STVp z$eUwyz1PD3;jg5%E_P4-`3O_6JJZ`p__b1}Z&@;%H!MPXvVG`fs9L9n-*L?inJKX5faqb8FHa7Ii_ZN#e?q_Y00fE~$oZNN5Jr zqMil#O7(KfIUD_Rvi&+AsNG4bH?1&H9if}McnE39z%PXDN#uU2+fLrF-5pB{xdYTt zK&4yUJLQ>A*Nqn^e%7u12gp*9FZ^&SnDs%0seyGpU-oA6k2uelg_%KjXk**VH+vqt zjM2+UlnMMf*Z0;r!JU~v{^CZ8;ifmDEf%}UVNOepcBW_#F}FXh$ZMOgsK5xen5Cck zv(8EQ?(8)hKi6dA-~0!VKbS1H_fgj?+XMIU=FVr9IR`2*%(B9-RIybz^_lfH&T!A3 zv4!P+XdF72A5y-&{FU{ymsIWKBTt#Kn_RnVv!eQPyZr|;%;t>#I4wcx3eB6nf+EHH zz(N~3grHLuR8Y(`=8W!zo$f8Ghh)y9VcYIOs!T6&d3Bqv)|rZ!CmI$z#`O5AH=FQP z_|pDhZ_AbONX&uTM_=i!-NbvTx=1~=WS6DA_I|=;5cr_n;#jb z@4+q2G(qrc+oh^+a>VV%|A>cY>H}AeE zsh5)44R98U{sY`Yci)OtTm9Id5xBmU$AENpvkgM&n1Sup zM+Y>q^uisB5GltUNW}LQdoPLpf-@0a< zQoe88EbN-(Dp>uS^#6CRm!Dmhkqn2sJCzFVUcI_0oY@!X)u}1OKD$?Ib?tQ9F?CD) z1(&jRP2`4FlQi!U^J;D0T$Yjvx)s@)FD`H9gA)QZnyuFPUMVl1KfA%Xz}9g*=jYIv zvJ|1MNwSpn?Ra^|$Mr9SoJfW$o)8!BK(O)u_nR}Hv_~yTvW+X9g?>uPZT^I1hmEs< zTU$I`_z|7aFGI4oBL0N!Bt_bMG-%d-BbZ02WHKRKDT8zJ0DLJfk2rdGS@3B{#ht1s zrBuDvcA24yE3=$Zq>qPb93q%i)P(4*{qbD@E8l61JxhPIcN0+CEo&NkD}J$RG;?I; zahvJ2G!&j>>;1If8(#t*SZcNO{gJ9uTTE!ty6VcVZz%WY)?1$mToq5YCxL zN7EUyE1uYW2u4Hd2tMyAsIfLrsVIz+O@Ek+zVCIz7L^Q*sv3cpV~1p?Ggpm zU2bNG{|^ui|FqlxdzRtDJ?$)*uqEwTd3qBaW465J7TnNlIc687IB7dwJdwW}IiooL z@s<2~(ASr{e?X<|p&8ehkcYICi4-);F^+mi+(|m^TquPb_jbSf)%(3|6m~V0gkTU; zQ^a{DVeY5R3~@>D)9_UDa$%=>~-{M7zb94F|q5~`lnfy%!$L}Za zuOO)EebK<~_WuB1#@XI^?HQrkxDf#3^st1K6PL7yT3yxct-mM-7b55zG!Z6BMLK< zl}Y(6-;LqK;Ni60g#K|evq$6#wDIco!x1jd{gU*LFp$}~Ia>W3@r?X>D^jLKaPY6H zl$C2K%z8{7&YSSwO@CKUld)wQw~0A6!^SJ^*Yfh1eBZ}6`hE&d7c84Lby@4nq`Z;- z)O)f+cdgi_-h1IIw_l)olKtQ)P4QZ@Q|A2M;X5&_>3<4>Uq!KQSNCmWtI-e6Ek9A} zpxh;xG}}7=TPJ&v=6XI4jejN4jCgxs75lcM(b~V-g{P)1<~K?$|>6Wo&KQ59<*=KC!dq!KX;|o3s?@;ML*0#Ri|jaxTC0JF$IE|L5Rw0 z!{Pe(n}4eaqbVNf_rFZEAt-oC4+WAf19;w>fKJPl6k|G4I2}K|i8@k4STdfw{UNxG zsb1M@DECleBnSVt!QrZ0RnL9Chxwdc*#_PfNlMDVlx6>7eRzq;;YJv=)3qt_(-x*@ zU~Oql>XOB6H7T9Ra|=sQ>NVCDD_s@JRi10EIt{YYVg`^0LUTpNF~Pkuy&ZZ+)6|j9 z&DK)zS|98olJIj>@jKsIL&*w%axjlLLCW1*6rbPxPKLS8+{{He?W&dVkAbq1O2J3t z5cNcJsN5nYs@ADlgF|`B_>5;hijL*&hjUm{uva&o}dXsQuIy|H*(KsV|G9vJ3=24XqXmgzX8{YEubjmrrL}+Kw@Y*Q6F4B9XCSCo-0wibrxxuZ;TG<&g zzpC5(tYVn;=7{|ov{d4Syt=DWn3Jr2F!9q+=+qgt%{bj&os z%k@#M9P`?xKep12L+G?VCaP*A~1lDoY_D+QC6%)RJuE2+9P7x`5fh*lgHQ~-?bH~S*d^80mXkz7&GR<^YkjX;9DmdqZY79qVcF63t6LlwL>6w)M(F zGn6Yn{s(|Bk7bf~ISfxOQ1Oxt7XCJ{9^H`gdb$=VkQUFQB)*>%;P8GsVap?ck$eoZ z!?|tx56hf>Qu87G=?<^e4>J7&lLXcolQPfccxl0j5OLHD%5lj(&AC2JveCYbc@??> z|2)tMXKH)6s8mE5&~WBC^$b{C&{q7?WEqoz?KG1=D+e4VuN0q%_nlt!yQa`<;Z-qiIu1lVyWTqDcdvC`xH#F z>{-u6fj4>$pjJ#MUwU1bHC~by^nrtq%%_KO2E}e6nx+D@S;nLKzWU~d!6K0)13lX7 zSP}^y&KXQzvo}q9+nZQP2ZlV!y*T$$@ivLml*aP9Us+=dv7tOYt>n3F{Y~DcH1UJ* z*8r2FQ{015L#8&H?wjlzxEYz#+{Wu9A4~N;)4Jv`EBCl}Ej#vl=BaI$@-;)=Z*BZT znkEwON|HG_u1yK&E!%}jzr-aOeXtw4%31KBrcPZ^?|HZsEL`y)sUsh`<`Ca-GV{1= zIgMzx|A&o+*AG!C>~BWDDt%WzX@WsZU35D>+^y}%X0HGXJdgdt=4$TE7!0Yt>7WSz zlqdVb&*81POnZAQvio{YRh6)%adl7T z0=NJ0QZ}Hi)v2&{qt^OO2fw?16QrfFpI+!k{4vd1*TLagF*tIObNR2XzJRw+7s|cR zC1FDvG@ADW?Z;UhPS-J?xF%}haCYd}-1<^;DHc#{4Eq(AS@BPorzrzTYTg<418C>( zHDi&ExwC!#<6KnJtFviAyxDiNy-2VTZHOJ0K+k@HH`R)H4AX?W5$T1u_RlhP^PP?m;^c|3xCJ7JvJ@Q#P$eFdu zl^fs0-~HK&KIa)<9;dWZa`Wqe9-vqxUnoSwzms{^pK8Rl1tAvs=&q{Rv$(--q&c#Q zgDHt;CiMdR_N1+y#))&ynniyE?&U>(N)Sf2DM)F2=%l=zrZNZ-ceA>SnZ>d5B41=`Nf5&KxBtfcONG7iTatHwQU3urL#Ma!Fj2x0 zeGi%I6-AeAYrJ+p&yv{knc4buc2m?0uO<2K)?ZDiUX;~niIRgO^5+?Ly%5iGfQRK9XQ8T zIe|Jpy^braef!qvkzS|)fkDCS??OI9DmgA599&=RR^Vy0=Ij*yYcWHR<&jy-sTzSW z-y<^FDOTy$Y z&DQ)wzUOOuJXJ5w{D)BOVHV{jlu`a~$5Y^fF^$e2#P)CVytg0pPldPc34*{uaTO3Z zi2;(rtqA?~J=5}8A(k)Gha#p$>i#*7Ka<=U<%)Jh2YTP~?cA;{tC6!MnPiyY9dqwm zVyElP$@DzC*%IEb9k)6XPkQW$8mf~I@0!GnH{;Fs=)_-x7K`hEVQ_R+&+sj@a8U)X zn<><+4OgjB>D?84uGL`$IiilSDnx456sQtkRE&EWB@n#cye?k2~8 zn|XsD^XjG$u*g;Is0s#MR`;*Sx|OpO#`l4SD~FX#SL}^#v#sS5$!2TzEeCT-V)r!x z&`9$$>sfpZqxsA76d|O7_xd!oQ%<;y>d2hwzKGf9uz9f*f#el&J5R!LBW`y_m`?1J z>1y@Q5QtpE*FflfYue;};mKPt)pz`Jy;}t$a1NZz*Z3%JhLMzN3b}7`u2UlxjW#u2 zfbCTXz4rgsk4fSyXrxYsi)rX$>kcu^G)+zQ5)nUM5mh-3;a|RnygcxkGMUfQlo?v= zu2)o22~PW>5N)!#chx_getg>=kr{)&s+8U-EHH8cHBTJ>mA7~)Yz8BlvA{gj6^w=x zGsu-n4WBH1Ui{dyxrS`d8H;o<*y&(nV5XL&JbFIT^3vsh>RPBz+;hR_08obRIBz)! zXoRSnH2yQ!+>*xD%1}oc?9E*#Uz5x+-=0#*pymcLz>5=PtuVsjL6o0hqf32o-o7a6 z{{@?fd4SlB6JTjN_TAK%XsoeQK#ETfAmI7ma|(^^Xd8$?d{u>{N(dN@o~d$!0S3*i z0AgiK;<*yeo{q;xIpa((ZEwjVAgtZHde!njz+k6iO+(L6rRG%$sl+K^$u5`aJ`}oXEEtXWBO?+~JS&a<3e|_v*=S-nXe(arHzJC}sVg_vhk32PK8WTB`Eo zYUwWruDn65j9USm0<)!W8E9hvUbJUV35muS*`ctjhK$rsVBb@@!POfRim10nf}r zrSiD7a`a^to7w7-YR{;<@cUyJT$Xh-(diG0j?!ccmNGVo{VhrYY3iKBABW1`Z#c7{mE6HCQ^-p)&@z11WMbUUG1{fyN2h*Nt4#?00bTV`T5o-h@#qyOn z!n_i=5LH0{sIr9QTq`1TU5S*{btx?h!I5YbxDiFK4y=|!;1Q;EOtB7FePzBVh%h<4 z`+5&uXu`0kuSp|aWd~lyMw`;Md%QL(jp-C=4Ufbz>h}a4-L@s%Nl{^Xojhq);?x&1 z%zRr~EnMdc(gzTqrGH#lB`91CVKbyP4Zj=eZ-$xeu(Tu-xLCg@Jw@`))BXu7H#6AC z8r#{cvXwKa5AFpOpRz#iBAsHKg|1N0L0q*_#Zy6Wg|Vo4Eq0%d)ylAK)wRSi0`0^3SqvD*J5f{X#8xrTNO{;VEAP4u&21eys`C?fQ;)d@KpP!{$W!JeT1IH2x?AP|Uzi9iY z*Dzle`}%U8xtMd_&INH^)U~ZspNU@G$IB&JWSAUJU`ZOUC-@M<*F^JO-Q}U$7U^X^ zd;?{++KrE`F#MVHAH&`o-mZkts04r@7(1 zRP7VVYonH<3A0Z2kfwhhv9U}yO+CNme|x%2d}9f1Z=0>l$mSN*wC3dmUehNdFdfgj z@xx3K9(#3}j8fP|qNGhV)6@xM;G?h9@$J6PiIjoNK^0@67nK7AA&!LUIVh12xaA8P z`@H>X7=i2WAuG?24hU`xyIGkYDdE>_*@LyI6nG$7{1j&{C08 z*^e^*Tk-z@yQL2%Gym@k%~g*}q$%e$KF!4j)CSmXLxQ}a`S-j@# z5Cri2PuqYUqhePl>%o!G-oo zpt=AO7~q3CjM!w|UweCsz2POF+hDWy_9-T*Jg9^)lc`#Q(PST)A{516?Se2pGOB$8 zoKP;ocN>TR8$a``qV$n;DPR$d#YFLwXBXjk%}K{;ZWL6~Gy}{jH)8S*j8h+%MK48D zwfO6sPJ%O|R;wg_VO zE|b#1pq7&21Vp*FgotunO^sAbgB|XxLs(Uj+znN@I3M7_d2?BrEM^pR$M+(Fhc=32 zCzUKBGZb@kJA-5TSwxou^s{4@TKcl&r{!@c@Q^$lpYuREF)9Q0DD*D31oG zX0Qr5GH#gnMcEg5i0l;GKxzT8Att{S4lr;JQ}0rb_S{;}i7wU}Ynbsm$@i>%wOLaH zxO1<^ba8uo;kUk@$hiI5r#MjeY%5r-O4HQL*>`zZ@}@EEAenD0)cWXeo=KS54^>rS z7?rw%CU}%$ZGf^@`7Jo_bkFz2Psah&^IG1&hEOO!w~>C;G`(>0kSb0niP5yGGAahE z>%@vLjR57?XF9Q#m?{8!Y>B=qcSwuXRxURzR32kChLPtC2<^@M7$RDQnEX8azeHQ&RDsK{rPs(CinxwfC_9(rC zoC`l{>@@8>PX>%bo|kD3uR~SveG_petLoNFX>TjHvb@9091;208%lEIs}?$SkVSPu zb}m82)V*DNK6$E&aZ;QQwp;e#O@pLrV2so*(<;>&C|YzK%3l*4DdjP zE5X}vnNW2zo%4*pZz{Dj*7D(6dx=1O8p^~f^SYP}P58@jh^gh|h_E~q!I{XW7x?_R zCP~gXTXa?GZxx0LPjI-(hv=WVT#cR6!l&%O%7<6{ghX<)qCyNysGU4^FTzrB`s@ll z4uZ$V&EhUFn>}AGRZt6m?e(hJyVNf;G18@0A7)~HN;aFia>xBLv0!MLoqrm)6&ld= z*tlX8+jZ;y_I4=fmcEH0flys*EU0JCyml^|l_BvwMJunDqm|%8mEqE>!Gh#07O!TG z%LyoIWet2}TY++-3MYRV2xQ;7q4Fv}XK|Awevgn%bnSi~&~I_wF=t~bErNs(;%3eq zeG(fZR4_Dg$r=R*Fr?&u+dcww8o(%VE3Z{)$F*gv`i4yD#MwT=-a?|`5$?Pidr2U3 zVN8g)^aMmiUF2<=bcp!DaP4NxdCrQl>yv&TMG&u->f)j}gDFeq006@n?L%k<(fR0NM4NMoA3?Z?`(dCMTdr6n5 zWET;z!+Z{u$S4#2+_lwPqmPMl#V%{ll=h6llUpOCY=s?aluE=@VUGC%jeTMq1kA|B z=cl-}Z0w2X;x%~!Cu`eDU!grt!9y8hLWnzk-zbAJzH`;DPTy-Y3Tr_v3+CAxOpHdD zQOUS;6-~4fIj~Q<0>we*1^|{JBnqUEc<;56qQ*6dfN{#wB{)9jo{}!4Qfi@?r|MvU z;b7<+4-)!!BHXYLr?pC=E#jBTdm3b_ASRRs!7VbAaYm!0ur!L3b`aD@msWEF zeDKXa(i5V^1{a;MdMg@Wl>HQb?)a0lom`9PemX&&m#wW}drn6BAQ2r_%HAF1Hz3T( z=gqjBLgf34GLAX|5z5^IUHOm-biw_!X6oSaMiiw9^MxcH%zP68^5X#*W@u>W>;m(a zAa_!GN~A>XC(71jypMXz0s)e~gawL)3|P$sF~Hyrvaux5C3kQei9I$u=gW+hIO*U1Q8I? zZRCz0DZOW2!ARhgC6e)iqm#ChGpmv>iVL~Oy8)W%G69vvKv!S^_S#I$!1~e<%hCFa z(ZvV4la(cSpr7aSnJ`ZPZ~2}wC?*O>GL1=3-I~HX*WoDg5z#DKQ;g3V*ow1z7++b++h{wN@$q-*#Y3STN^pMnxYi@xo< zSI@|?k;ppFGK@P+)5P6{yO+n)qBbqolbj5sh@0Yqm6zI^|dDdB4~eC#W5V;3ft6(!k$O~><5d>!&ZP&owfmY#?GVrQp%GHylTCj~^ zAKr8)tQXKqEE-PW4w?7sdpoRPjZMSaXc;8F9dk3UF$zVI(({zI>nlB)1aDq;K7)kz zs}Hk{+=iJumAs-@h+%3qlj;;0=H^n#qi4GHBpc`bZDM?+tF^I*(QcxEC5e@Y-Q+m zUcq1ST_--jnqc_?Dg}tY!aE|A3fr}=#z1LA*7mC_S~Xu+8V=95l6rFxJXt`j zKp1fqYeI$7M27#vA8}Q8wb#_tims0I5NUf^GoMLCvw88iRNV56SqS}ZeS z6Q)4p9}17_1^fy?IhlBE@;t#Qm>2Do2a6=i&(<1deRmsM{aWZEmdD^9e9vdq{&rE~ z#j4%xEO&AiLTcG~d~jhmhcie?m8~=ugO-~vNC)h@+fGmdRg!g08(LP@oXBL&ig-K@ z%AV{CN;TVbS_zAijMj!JF?B<*y#60j8&Qlh#wl8=d*f08C4`Qd zLT=pf&?&s2je^oxbuEAoVF3{k_6>-r!~yIS_Y2b-&PQ=>q{c22X0eBmQEH1ESp_k( z1oL@mnkx3mOo>tOazyE4@{-*yE<=( zE&zF;$Rc#Xlp6q4U}SWvL`DR|))-8CCFe>#m*w0rf8+nHhZ<@Sl$OWS32{>P#r^n$ zTc;ZUH-E<&xdtWQj*Z>^v~{l!1?>E4&E7WzQlgW?cDFa;FTF?M@ddTLMkhs^=OvMbPqAox$y2 zCIks`1sFqL3tx{*>GA_z#JI>uEiy6)k2tH_tJ^ZdLQ_GzbR^1{6N^2qbi^1L$BZs!X)`6jhU!z0*1y!E-O4FYS^@cqI`=+p~ znwBMx^gGO5>}6fsOq_TKb65?y6CK1G_q;)@SlJwPvB%k)vCV>lC_@JG#(@TglLtW&CVkE<{Fhha zc?_Ez;`6ILLV`;Y$5=WNgAa;i4D}5UcF{1?Y3eQry}ULmg*PEB3>93=9;u0s50b)}F9Cr{Ji zBk(lsg}aaQb=}X3@R)Q`xF>w#7u^=ii(B^3bxg?A&Vr1!oc@ZJho9<=Tr!9H6FA{Y zD{}$i6@*A5*{MxOlVvW#iujkwbb61fOJ-qEZFMIHA12@~Y%#7Eyovr;STV|t3Yh=w z44W5iA2(wB40^An1%-pBzKf}YWiZA7N*+WHQzfY$@Yyicl;?8|$UAysdI&Fe-58jO z&ctD?W_q+y#UQOblGX1Y$P}bR~i)H;u`t0HNO_3k%Y@* zddNEn`UR+9PhYI`xNu^Q-AGAvh`6RqZ!*5(h(YBW9s3H$CZ z`mdr7&3r_siz4E4CwL51X-kxN`_hvy0Q+F&|9Midk#vFzV@O{VBd^l`MgfQRzTyex395 z=ryxHi}Vd$;0+G&76Q8%wEre@Fx8y2)s=R`v6vBoM~JCw;jIXI1+if$)Mj|W#}s8XZ1O446r_E91%RMJTY zs^o_2Co;~Z5{Nvx_SGN^DItnqf_%@WdMpi!{@~SRfL}<;E9a|W?U>2y<*!7zK@G2v zgByvhWynnduptwMwSqz1G7z9N8;(;Z1p@q0lScH&^S*{HDmEe2a{x94o#SI7uTBD#LC;jJ07}ddby@Y>uRp@ z6eRH9=&!{3zVE+8K96ks`sO~IziQ@U)J8sN`8&l2M2eoM&w(pv|?PsCwG zyZg||$d?ehKHleT)qbmt>oTFUi7jUWPCMd8R-fPK$?rG)4_4)kE%00g|0YAEK{(nP zHKhLw43)xoKVXmNXxwy$JuszI0KQoSWRExTSAe)^v49ns)o)vf66n)hoB_A|o*}HL zc^kW&zJx%1`r7zcdm}rK;WcD#e?W8J|4>5JJSnY%eniHJ?q*%y-L9L92<1+nEK^2| zO?hvqz7gbj=OY>p?ZMh~^K?heuzPPcY;NVHdMmr2@l0!V_&s4x`KB3VJiOtboyPGv#P4j9b6)R)P9-$ z)QGSd`guZ}Yx3f6Hj>Jtj}t3Bs;b13&WSQb8G>v2?!V z|D)^8?T{xj9uBIl$6~R zW2l6(7Sdu(me2Pd^?9D>_x-+pf0*@c%#8Pao$FlZI_KW@x?_A_K(k9UwnxV<3xYiw zFXdHKz%T2S5e9wG6SF5zzUO#9tLee1N~D!nkHx}GpOV`t1bLJRO$cXXVFcdYIe&9n zPBGDIrC15qw|L?Wr}M_J7*?dtRQ#6rS%cb1TNaA-{o+5}asE8&j29<`s~=L_SOZGq^^LTUa;UO|d>0juoMTk@=?PvHIr zaV*Su(lR1huB(7`4>lT?n0hoiB?V?EP!b?Vg_!w|5b^gDJ>OJ9EGj$sg*9~tGr!S& z4ERiJ2nfD@I;R zkW1DGnJfX?_uqp|AAp~I72`|#xJpSSLY#gNnrTzki(`SQhb0j4_8-VwLy_5(XfC1} zsxYgaD$&k%-{2N=sz~JO7b%d{n1W%Fd_**$;hy53iFTBv<#v`ssqB?X%ev>TR#vLL zv~MhT(ECZ-?VNpP2i~TlP60Z53OG_Z@scbR5i6l1Ra*EdtIjIURE>qSwdf@;+w-v zB0gKTpk1i?U7*>kt&Z$&GRtsA7HA7Ig-XZ2*A+l0N5@pX|@G1pQh#$9T;yYyUrhU-ly zrS&A_*8~B>v!?l2KD+Xn8%Hl7y46p%kQ&)%z>^7hM||8NA*CK}VtM3$lAjTt#-FiZ04sy6!M6Y9Q(U zs6CVZc-6=D#%t%yFYYL1Kg%t@lND4Ui}@XVLT(V9u$k_*U|nx@qy$HiHj5t=CY#}J z*Q>$5Kl3@-zj>kN4U(Rp%Sr!zP(i8ww8jR}cJ7O+)kNvxZ}iJnE{_%LF2q)v)e968 zsKkRTn2ryYfz~XT(o#jyhXf~({6{hf^~^5rTe6>vI}(3 zX2k?RSS`TD=0NL&Lfn%lQ{uq{QhYHMQLqO@uK4o>)_7hrv()XWZk|_L^_kcFd}WSX z_4e~3kCTs${vK*=|4m=HIb;~x%v;T$Lg1DtxPTGD67W=&y{5R! zzi5b~r=Mhf!g7fKKvsRqm< z*f&R$JHiGv_xl@gw55q~a!bsCJu)=0Ag!?EF&0~)&mkS*kob4AsoIphx~R!0mf;*$ z8T>VCiM{Qjc&6E0gT1Jec>18ld7=eT4FOyQa1xF4ROn>#!PIu;Z9JDhpkCqxJUcBj z1p1@~7JZ;yiwSiOL0OVx+D0AGolMr$rCouyV*Cv{!RgF?jz`q-=nVR|d(9C=XNzvc&2)}^jQ$nY&vqF%Jg9pzG{QD}-+|R-ksz^` zEkR)(vBxU(E@6x!x?JS-5R>09oUR$hX%Kt`_8WC?u^8gO!8*oqBYTAXmD-?hit-fH6qP zHIAqcD|(4v@!J7Dt5Chl?*85U4I1m}$*+>Y`KJj*JSm~i^7QI-E}T!CE4q)#u# zp59iNW0TRhOssuWSQ})XEpbGa>B(@W*TW#++V)3FRz`EU7i6iK>U3k-Lq$z*4jp^% zi$bv0r8a(h!Lm}R1t;B^#XkQ~f7aHN=?pcsw;vQ&A`lq`X}i45`BrO+w04!2n74~r^T_7jsd}leZH2RO@7p#Ev8&9ri{vi; z5HVKYL=8nKns^S1alhfo1mjkeC}0C2pXdWol!gjHjBd!+_dUZzHiYo2iQef8d zpm2k9KRtU@z~ZF9AePY5QGA< zG$lCZ6;!|V%y$z|d@?7dl3qtCU^9rYUIU&YI2hb4e|oC&w9fF(Es}AB;B0c4k^qz` zQO|uNQhu;u;JdE@jEi+Of;DI@%sIC}%*IH6TvBSN#-A3YI~g*v7bmmX_c&yE`rF%P&_v8dfcEv#j%s1#c7#@(d529d{RN(guL{Xs}IGll} zOmr0VF(t-`&*0F3+oLwe+fhfWp&KSxIONy#*k0->4)vq^3{VEF5HrI?b3mDHx3=$@ zjoQCDnas(~mQRG7YV}7D@gn^y20RNUtTG1VMFR*6T&0zSr7G+roHOB7m+?|nLCHi( zgHdXlaCcxbv;b``SOfq(15T8*L=h1Z1kbxhbEA0>A;I6S(Wb?b=S2pi;H`K8cy=kr zWY$Xpgo#p%9!Xv)fY87v%&}&k#ya$yt&*mbK+nB-b5__IiE`9pHf^f~Rs<$y^N3VR z2te;Y!Xv0Gl1B-t_@h<$->C7zS4M&(`U$roTb?Xh!-=_tXXlSm1bR%j*FJ%1uobi| zMQ?nA`Hkb!>zhSCD%-7}9#{DSbK2*l^zu+fr0(-MKAx{y?C+227c273Num&8(TrgkvU^L&DdEx+32-rCv5wEo~aLJAB~~g+c^S0 zni;SmXdjEg85#3`6?tGVMTTPbqm4!JX;2~W=7L_(_4FX9loWbkDcq|_(8{bx+csWL z#_`^;`e+~Y+OXb(3Xu%p++^*J5 z#ntVnhdvh#dfql{xA(VmAsb9K+*M6cAf7LEurX<{XfHzQZ!l}trKjVB!rSDZ@9N%&W3}%X-Fs_PU>fyklwciO|o5 zm9FyDrWcR#BZ(~s>KYH!J;Ob67xlN)1|vULeAkxQ_LTD!HWntE3pKBtH`ZRRsSYtU zmKC+0x9Z6JQCP3V**M%b%dCGVfYQ`>D$%x?u)yu=HT>?fy6M^aH@Mu@lb4?JbstAu z>N|pOrCo@(`wTmxO>RHUBX2;5T&d(f#8DL_km5el)cq!`=pInEfj!5g+@!1ovRQD> zx<}yLvJ+4Kr0^4UuIGJ*TZ)biJFw{1WpwQ3)BdC4hek$TxFv|l)u_43KUVKn^a)9| zzl&C`5FE*tl@uX@h&~U3IW(xMxa}&3n5|-C{A!g0HfF!p)SQ7>^wlbdkzC5TKAo~a z2hC@)L~FbEd%WjIiL;x7?GO}v$w_a+srK3+tELv2ElP|>P9~d(dQW2cp=OCDxQ7(8 z7#xHEkvGr`1<~r)p;-eTQoBUKm7+?B9Q+3p|6ybp5n_85U-5MC?u7(8q+i7f-G15% z{vZLOeH&ow?KB~XKV|T~K*=%{0^A_|670B0fs)O^*2(Co4$n)N3-@9H9nUL{7mCfH z$8{I%b-J)$UUJmND^UHWqQC@tL_0@Y+xa`4)T-A85dZG#KV_+*1)ng#++27NijN0(I>wWxAgi-kOeo z&q6C?%gtFQv5ZBF*q9{e2&oazDS6?^B;9^yETR}IV9m@z)xGBDr31XFkR%G8TX&+_ z72d`HipTQpdAWfl<_+VAE(K||isR1NFW4W0_qLpJZuogfluHcqn>Y`D!|{@X_xkns zI$ysOZFv_aYE2rO4cVFsut1q&C?PnmAp0kJSDueCo_t{JK$nM<=`a~i7G_MiiUip41c{WRFp^C$ z_T|qsOHMheAh0J10=e{0{t5P80M(uI#(+`y0A2x^XO&hAynw%k3!b;t4(JL(@TFb$ zx+8?!c-&)C98vNOZz)5_sq%cI&iXXlx&CB0N~o+-T`IID=~xB$KZ>PSA5~)&^ePH0 zB^e!9@;-si!1}pLEsDzLOTG0urW%}z2x$N_5&C5gWzf;;`s)n+vZ*QuCQRz z{g!MD^6hCj+8CXM&hsRZ_C(F*6XUNGD=O@(_lDgz_8)29uV-_me7q7=Q97gAbV^yFFvq7{*WxAEsqOgGvam5UyE5s>iQ)8HO~%Ut*E@@8WjF)(H2m{;J2_jqX^~dbN(n!I8mfM4Mqlcx{1xTijqK=)g;px|X&bPWjig_8tM#{93Mb)$J3ps~%5;WG zq&%>E+H*BvH-`fbtomN@L7U@4xy4SQmuIRs9E+=~nmscd&Iq_Ezo^pK8LK=#qSnF7 zK2k%RP9GRFLDp*`O+KQ{jO}V3FBh`>x^+gTxkzC?Bz;aN0Ds3z+ggX;7nI4k(KiOM zccDKmpr1TXw8PWtE+j+X1%uZHZ$Y#$1kYk?U>Abb0q#bdy$`qznNfYg5Rf=XkfH|I zx1KQ$NGIbyQ4Q#Z_lZtmixDCy*l=1wWpTdvIRlPPA`|E)wq}VV@41j|ZonSqN4Z+e zlg1GwL8bsbYXC)s^s|)Wo5)lEmtTLPXETE!T0*DjWAtnwv$>O;Y-AGXOdfrEE)-p4 zD`aOQ+jSMN9YD34d1(|}m?Z{+G$7F!B1op7o3nVnBOM9uc<@%n5JVqf)XFYQg>tBw z;N?gPcLCuuhA2uD!P8nn0wE27(DSOMMS061r5kfRQnP$C5o2A~Nw)XMUOt%AqypKMGqppm2 z+%$NV`TZZrrNQ6Cxy8lv4N1MX_@TjQvtxlcmz$Ca87RZ8j)j@xu`TbC+XA2BO%ERP zJRt`XN!2qMdMgf|p{*ruk57M3wUuu6_~a-5453SFvO9)2q5bKTjci^W8aa880H`Y$ z5p-%ZgN7O4(vbuHO42U2?e6CCm*g1$L5(4*L7VG4j5==jw59ok~Z2S1ZL=0ln{g-BBSfguq0sqaVnP|pL|;8=Qt)Z6ssZouQ^V!N7eBF) z1;v{~RQn0{m1j}`$NbSMlclI*jeM#G2Iv=F@h`PL^+n3h+B|)Opf4%b+W6QC!D6@S zw_y};?tgwbhr6b)rtdwCBWac0mj(9jn5Cji|3E(SBlRw<<(>Y@YA`jD9QP08sl2Mp zH)G6MH|@{^$=7>Qi2RMqMj~SM50YCJOu=kMXTep&GtvuI_808NT3q=Lo?SYwx_-up zAb*lNXEM7|KBLkkEm*SNNEZG;OSEp1D^9Ak=NV7?v^Zy;cJ)}LQ+0B?j>fg+GdGOv z3a{tM3so0p#9qZ8XZrO=4C00{xD#DW{f;mW7g8CkIQRJEc+}nIr$Z253ppGO814}qu)krlE!5v z$LsJBE%FzI%lR!W4`NKYE-N@XDTqZ)-11dmx9$m1cRBmW!SS{6hSM_Gd-Gyf_pKya zP4RL2o}kGuWh>jHt0wn=c3bhoQa%%&W_^_xI)AP>rX3<1hDIP^kiuL>qdlu418xR( z$6JHlipU^#A4(JQfks7mQZ+JwV%0=(&xjHwTH^skeZm`-%-Qs_)KU>oxUAQURVJgD z=>_yqfMF#hcrd6SbDjfqEtVz(iq>qi@%?x?ruP647^MSFe1VuJ)0VYA;gsh|IVLVn zq!EB7En^l1O|Ds6kJrT# zLUGs8=4v)P5o(&yf@#S3%JKIHV4 zob!s4wqgYV5tQh6vw%rujI1yD`~#tQZ=-?^ttI15A8kxPn-(l!KZVf)%&Mnk2`Qbo z+BFdO*ky^OiUYofqiwsTmhc=z#|+m_e&?*}X>ii~CoN>8hm6#a`Cr5U*B$?X6aXvI zfGh0+5GYO={Hv7#c?^^q3I-T2W5H6XjZzLGv$H*_MA=e4;r9mA-~t+k*|NCVp5YL* zQs0tqG&KA`qa6Hqx$mz}L&V=X>KE;Z9=RCZnn!h@7T0XiAzrDHaPpR2hE39m572#q zZf{Rc*8T%IxGK7C^LFGl+Xw&7_3|uw)!C5VCRrkutmOUys?ctg)>@;5&>yFCA4^4| zdH5p+yaK9bP3RIo<$B7JA*WCE$YhL2^-?LoUXsM zx-GZF=pu<(D(F-Ohfq>`^LN4q);Y%u?EJS*Wt|=`%yG@%oJLH`FbsB$KBg}=6>BeJ^U^QdYBm;k`zb+K7g z|F(&q3oX8pEHkTDcX7TiMiBtf&Z5k0QDDD>kvP)%RWNB^AdQUSm_x+dFrU_|+jJk9 zL7k4}F(Ak9{Gtht%sm}38LM{m1Dnw8*v1s~P=?h{-tsX#dPu&QxR9>#iIgZn-=4aA zj3>>5h&=IDyI&844Ys_rZvHdM_-U*%jMLxBNY61;vK!qL*nSG*0w%f04;3-juT?Bx z%*3X)d_~{r+n(c{u!lg-@xVInr=Drj2p)LZmQo`W;l$ec%PyfxNZF9;@oll)+*>JA zh8NPGHGgV0K^pS;p0Q^jtGidmlT51NYNd{M$wm1vv3kBFRm}%y28b!Db>`n|-pq7G z25*VGE;w6>xRU+tlS9?`zv#p)Iv=e|_g&2n6m!>4$WI^*WztEG-3NxAEq>-LrB#}@*fE}q|}ZHjs21lNv= zj$xk&b<>}9I{6L6hn77#8g6Qvv1(zkCuy+7rlBr-RJCe+Gr`O8T|399$?U2m`3xtd z{QzmET&+Curerr_p9m+87pG9NB;{{2VFCSV_)Zk>PcUqUX_ElJh{8OX@PR0D0V@?S zqbN~xu%R{N`0gX@?wRl&Yy2*4<#eKff+`ZmU_5__6PE!TY-k-q0^AE!UGbhwbS$_q z*21cp=Ws$oBUCKjz;nOIMDqd&s|`M|3vj6G7fOsF_$Y!DG~>7e>jSwrN~9VEScvD2f8}(DF?%5?O!8$;^uA{C zqmugK%<U(Z;=PUgw6Si zx?Uf>lMVg1R(*k;VxX1sl#q*(NEC%7$#PP{N z;h%{53rA5%hB|LC@R#E3QXRmG7_h5ymvQ-Dd?J8gQkTXMywa?h2LK6#f^Pu>q5cIp zCWJAlc$p*2*d=DkB16}gF%P;P@+rR@+cevH-F$FUl0H#uUlhJTEb#IU)yNS7jfvN^ zms+wG+U93^jR*6P9ov?@ zZK~^uPN!w%s<8LxHKLcrqHL}<`@9NfJ7Xh1z3*yO$9M;q?e+*agHt8l>D)rPt#vM! zzM2dzq@x`!sl^Z8n_Y`pPvtdH7kzj}e_UPh;qN(sJtd2#-=)P?UyQD~7&f%H{R0Uj zF6q{&o(_H(7Sy;^2kzg;54~x@(7swd`gj!dEi2+Fuvk+vUJSuu6m3AbyfJ5^^whWe z`EwKSW16nCwNlgrV9?rXT$vPGN=dWbq*|%;j?JCEzBM}7q!E6{^Ly~|#u=j)HZ@YRW4#QA@VGJC5J7q$|9woa?fsW+*c8&T@}tPOvz&YefkSN9F5 zlckzC!rl7!QkkJaWb87{W0oWy0p#U_*ugk8bkcJxm*-~O_s@)J><_8B@!CIXm5M7j zVe3j-!U6?Yf-4)B>MRm~HKcdUe`TLFn?uql$`} z`nfQwo2P_KN~TOo)P9-}*36TMk_xA!fXy~Q0f+5u?ftODlXewiG2=Bwfg*&qx+%Z8 zdv@7Wj0QbOw4|`4t27)!Waf`J-#=_jTJ*Rg;ve&-z%i_yWeneF%}*yrRB;kx73C8 zbm*5g!fd2cLW_Gm{39h6;hDYWBV{s5}-7s)33_@(N{uxECyUId~5a;CIA-k0I7Je z#8aU~WMIG3q-? zUl^JV1pkA4_fTXk%GH1k4`50SWG~>#V)y7K#=C@p%Y!;8_la@>bqraG1&NO$IMV@{ zGM0wuC)C|ddAC*WVg6%gW`g(Vo%50>@=L|qnzv6F*FCa!O}di*F~SP?hHq?G+FSe> znt3gDel6r5$j_-?_KxRCIQ+bB$%}|@qp9|uU@#90@@1{XRa-$TL%ePgxPsZEL9ovnXR_eDv#$_$&(YQYeib$ zt+N{lHxTCjF6zhN571Se4|pRqHO{4m`Gp0QUb9ob^@8AB{9wUR)cebi+Rw$aiJXsS zk~>P?SlA?>>wVo+78G9TFLCAn*a<2b%AVxiV14r|Qs;GX8&%?`Bo&NBnVOwiK!1pQ zcz*%o2xcP;bq*JSscSBp!?n(qpZhO1j%RMqUwn=LBqMS)WgDLX@WZOoK2WpYJo4#~ zc8TJ1U~gizXgn^=T`*wG%3KxJzmQ1(GWV?snkqlSj{rLdnOrc|j#ji>ispB}UYRZ+ zgv_wmN4G81o~}Qb6*f3`bJ+&$e^RoebD}?Dl^GiT8@)cKpO~Y!4Y?xZ@;klq3lB|! z9jV`ZcJ;|&$}_!nUu7$?pW!n;mH9|B zjD7$6MFf#Bjy}qnJRB>Po`n&@A>HB-hVb}So;uck-_?@$ttEM<0%Hhwb%z47kY!)Y zmhy&JR9vYrLHMA}h1qvkNDE;5)^Em%PM8=Jv|w2Fu`XuNkg-b-kVtkXhJk1U;`I-F zEByj!2iAwz^$nIV(d+v0c!)a?PIeb2!yEWVnH1sPUB2vS6jc!-IGb^w77yA^-;<%O z_{k{F;1CKh%SAznczAYUlo&U3bbx5USU8Mee%x4`Ww~2Nzf1nm=fy45J?DP^ zjy2dt=kj;`%LODoY}%l%erSZzrKJb@9osuMo^Y!f)DF`3-$0xIyxef4-k`MuwwI-p zWL?0!Q@?LMW_GfyH@L(vMs~Oiq0klTWu%A-VISp3&s^1(8uU+;15I{?1U9flz)ZCi zg6kmyXmb7cJpvG-?WY098>n6t056Ih3CPy&pqS;f8^+Pb61R2>SqvQdqx9~sRScR4 zVWeA(*J7x>$&6eEM1Kr;VKqi(VzvjKhPIqK&@of|Veb2p(Je)_(v?aD?ZytKiCF&l z5|e#v?h{z-MOMd<+RcId%{>Dl2<}$wD7Pm7{GX>bSGwG zI5oIp?DCEwc3Z#lB6h+(ZAU7!&dJ3JZTt^JJkaJISZrIX(8!+~>h8~t8jJhfoUAm5 zv-fUK=i{!p{QRjoe4qFCd%b$M;Dfx+WrvGPj%dE9>09abGm_B&>F>!QL*=8K2U1 zJ$c_fB%8r1TcgEn#%)EDh*bo-5m)GtJNNQ?rDluVX4?(R+u~fW2Q{-bx@>NpIdy2% z%97oy<4L2p`JCeDZO_*$J-jl+z zIHS^~|75(LsVC7}fY{`%FYMTeB=vc9mK{&EaAzqk$-{)%97B{>zl4z=NOsRz*Yb_u zz{{sp-z57L3?OXWW$+YG4`;@n7_0>he%~ysA{+zoK}*OF{sJhee^xv|ij)ij1Poih zks}8I@plAmz)PlTfO8%O+D_+TO#hzTAiDhJ?6g^+c&LF)V-LtQGU2U$@K0($IQ1`J z=R**UX!k)$TaXfC0?gwegk#*3cin+e;%2BLBzUV+KTHk^WKBL}=_C6X>u5Jl{asK% zFa&>tl>sYzMU6EQ)4+j4RDI-AI`6mhT00vPrc=(rnG@#TPU-`jr;DmVrTV)CkGq=-)^MDn6rTOE4vq$k7x+VVMf5YF!_Bpt&Dz_0!a4!i4|!xLxY3`iH^NulvG?&bUi13oZ+Grsw~x{~NrkDSu%A{GV^eW8^;c=O(1j zJo(TISG=uwV8+U;sc2#D5_ijryRpIP%keehR%8rKUFi}2>RF3%r@nc6Iz6Fm#Opxw z{GkW3UuxT5$O7>yuFgDNW!z|AIV(Nu-SkwF1!(%2TzY3VQs3v}Wql(-E}*l4_2QR| ziNYs2j?#ViT-`i!Hm6#g>xs^eeT|O?(+}hI{E{wb672R09wL@BL@#Xn$X*Y`NfApRpUo8&KnBULh(xVsi!$#m3k zy~#0loPJ{TaMBb-vaX?iIQQK4Sj-8TFEeRu*TemtI*OsgzjN-5rsLC}1@HuT2U;|~ zRjhR6Yu~poYx`@=%o~fVY>(8r@Rdq=upiE#8BD0zRAqU4{^QN_-gz|B?q6>W`Q(e$ z=O^^`gbF-QNcEMPyfI&N?A`An!G}>@cbCq^zj4EQ&n_OgAUo=<-h^F{(J z_jW$03bJhDP_M>AQ%wZ?^8y`gZ=_k?QAdr^7ZAfl9*7IlCG00z*fT6SA8rKFc-TG| zh*EpNZtEw3xCm;(P-_X$H7$hXw!Uk&c?;HE_EV3C+v-InwrP42w$ugUZY|TzWdzc* zzzA&RekO{a%YyZIKoQUR>EHCrM=R|^T3}r6 zhVUk!gVI19B@o31l!x8?m!UlDru><3u$m#^Al1(V<%|I$An(cy`1t!InCH2RCg3i} z_Cd7dB02#P0>Ze>uv7y+%sBebZARz?l?SFkMuNaf{gY9H4)7vIE)WHtW0-6HUIB_P z_j{#)wXnFRrukX2srTOGt4I9wD9vL^Z7RkM=4;F1HApXI4xJLQPz7xZuE|2c#-W-xScwA@~Ponp!=T<~^ zsZMQ=45;UVJv4T20yuHjj}vp#pO%!R6}kM{N&(7a*3Eq6oygAVeB`a)qGNild^>u1 zSvi&~V3c`Mamm~5YeV<^?(D42JJD6d$Ln>8QgYSi*g%vbqB%V_u;9mtNq3Nxztr11 z1#O9Ht4Hj}PsY!x8JE3hZRAAU8}xnipaR7<;7*vI3jBV{G^4~X;M%srgU5-2vqFx& zeuEp=o-Td%^`DzV6g1r{Jf?#3zj~~OWAW$C!yB)Lt4f!Ov#*w&_|O$yc+2YbM_gCG zdoCDkD-v9z;2QGy98)Lx(nskJ9kUCTk0zAGBRIr!55eXKqA8~cXhz=(@g5GcagV@tG@iijTreU(GX(+ z=;+>jFVDEkuG#8*L8bRgOI#|w`3`9io;0+zwGiZbLVIt7P?s9(Jt(~vo`)JD$LHVd@X5_T@!f-OXs0y-94n5HMJ2s zTeqjioIWHB{kV5(mg>^bn7(&1BmWwscT~jwzYM&{Kxx_0^bc{1#4^D zPv=-EiXnI5(Hkaam0SpopZ&JiF)QEA19QiS2YDum-23&j#keItz0Hmzuig82vph10 zfPXqbwDi8SVoa6QD$J~B7Bpr{Np2$`k-#FD`l}Qq+{~#l#A?3jz~OS1c{!7p5R{X1 zy!_xAp?wN9W-`(6AT-Txv@`YV4AuK!io9mJeT#kQT@jx2!)NPx9=x^U`1nc>arH`x z05MR=-Ag3#%V4|)*ol;zUpi|AgBiYgcelFxmqr6zkyeB#9%ocqK)w!=+u2=#0JxTc zrT`>^zmH@8pab9@3=LpEs2gX4x-d%#g*KbqiDqyZU_xe~$6tU+1+Kiqa16#B;0!|u zfXpKqD1w8j0R_Pmq%Gi389d_-Kpikc1|Xif&t*k=uLuWCL_}|uODVq&EHa| z@$)7@J;C%Mzec#%Uf+XyPd9C~tFm|IJ|L&6gB@=sjhC8V`4*zZ?@%oZSYlgS^(@He zfQG`Dl(75eK#}Ke-LqOH!d@8Q(5Qdk74r0T>&TLH~_GN6r;deAkTAfsyR- zR4HaT!Ma4L1gm=WjWRpFpi^Ey=ZJ+IAIKi_AD6g6>f$#XbERV2amTPx|C>+`rG4<% zy;-o&&Z`b9vQhp@w_dtrWS5B*`Bdc8k`)>GaXR=p-79}3vxL60Q3@KG&B79_zT@gl z6bZ%a36@k7UNBUN@ME+-E+%IW{;~b2DW>)1K|GYgNQG^NlHQywc>R zdtVk>*{l;a)QKO7AAW>_`qW?SFk5JMq^-KteC!T_yN8}izPYAXJY1V1ukx(uSf${3R~zM{3cgk^o$BUBwY$)CE&B?3`+b=1IW481i+Fvs3MPqj~}yk|QrDnIF=DnW}e zrxECVLp}i$Rf_KK9y~C(DL2viphW#zlajimZZ$_X*f>I^Pj|O8qEteS>ki*=RfB;4nX$(Uc9rBQ{Jes8J5uA^{ktgMBKU!5l+06HvfsT$8ZpOL zYciQ=K`>F5i2?*;FW5DBHYI)l^gnU$p^2qIXrUnF_e*@}5@5^DW2kc%rW*=V%}^3> zYX_Pq5Zyt8Ek_`tj#$rMt|{}-$Sdl4TXp(b%oJA+!vNCU2ZTmY?*#P>uyTLzRy7o% zfDAx@3r;x39|JF@jb!8$%w`G>lW+OBGK>tpR< zJnh~mgs;gpIKHZWSR#^NS}r=5VsVehYQl!{)V<4+RhT#6YpPUa$g<7MQ}>AwesoTC zw>D)q{e{HW={!q339JCK^FZY^2jl_xYXNcq4_`beR|qo9+PifM@KJWZCx%7sPj2_W z4`=@?f&hjHVYJRO(3WxJpDXZ+{}ECd2^)BZ3CLFNQTqT2ESiLu0RC2_M+dH6_l(pQ z$esZ(p_PU490Igf0A^TV%~C1{U=T3U8$d8ir6yKJ86wqfVlkW)4qcLMbf2cj7^D!0S4b9{`X5E=BPR0!=DL!a;-0*iM*i|-8-^xXKj@vMCGI;ykF$F(z)oO-ixDHlFuU8Tnk!Vp$-1PAX*GS(8L-1A zOv0vlD7E$8*~hy9%H04X z<(fB=Tc_mr+h{DETihzUD!B1nXY$oxbF0K1v=7=#BNlyd%g}Bx(M#*&6KM-E1=^-8ZZI!t*8Gb7TgLvAaEw?T6sDGJw+Kk64}yFJ7`Vz-|^jkpn|JRq0|IW`6nT_~h& z!GZ!C%o{d!-8?S;6#r3GYccS3WnlA8XLh2SufuROsbj$0iso}=g_+|<<5k`2Ew6Q? zch4Qr>xgv`v(tY~Rvl>yMqpGjF4@8!#!c$KE>)||siq3Hl322{6CD5(It6kDMsl&c ztQpGYzd6Z&ZUDHH1J<@(ZdI5{)Gh$jfGWa(i2q&!ZDb$g75=R#FjSA-mu0*PI3A>A zj6cFr^pinRE)1B$0|8iSgJuU9j9ZQb@zlj$qY)vNo(%1^4!{tH6L6I=8n74z3q?2) zXJiIIB_$b1NzgI6FNvA93sW>S!q5-_-XK$wt<%(=ASy1bTpD3AmIFG~8|~ioX{oy~ zmUsA@&D*sroB2n>Nm~go%70h?1Bnao+`L`r$foA22M8I_7{I9e3iWl*Ee* zwtiJ8tNGzP`p)}(VXWk>P3oDmd@-2&*7vS-+leTBm-3DFe&q0=-|EA|?^V8(BV{?$ z5iIrlpv3;=1(K()Tdc2!iqr2&%A;pCR!0~5Qr-qH-th}uK)dt|j-gbyJ1)Fip=xx% zQ!b(8ZmSIuK8xQ%-8Fvlp{vh_wIF2C+)XkkXDFyS87J%)Ve0eh8hr^ja(Cv|W!ncQ z-QO9A-!i_oPh&Znwe_*U>rX0}GwflvBR=9XwM!_At7UPj@4Q!_Nh9gMIZYRBE=p2< z{GJaSkvHY8%OItVY4Dtw8h*4IoLvu#=pU#f1n+$R7IlKN+DCmYUZVL_S?#{EMr|>Y zoolVyH($i`;E{I&VfmF;5Uo{Ljprlk2b7Sj%K1z)lRK)0#!&k+ZPHMTHItbYh?>mR z?2;wrKeev#=l9c-duJM}OH*Kn;$C9HBTo|lprlF z9eDq)nI}nxK|fKDLvzT9^9e-5)K-39VcFEoPqy{Z5~2!%_Krd(_vP9>7kmBfrV=iQ z#*y*7#w3nKCtAt-8iEKd469K~j|0Ha$~0Uf_fYha2r<`M@%Sel8y^{1v_xykhzs)0 zGb@?A5^jj!3W!}TsZltv`3i`YY1YjB++a!nW}NDPb7V29nxMR~yVwuy8Xx}HA9ViB zSN^Dbe;Gm=1_PX0fHQj;1To}Ia9%SI1HjI1jF!HHe_ISCEwXQQbNLdQB3!)&prQKk(1vVTp0wxh{jWu45|kqo>OB-fKw=` z8w?k+E0`oM$?r=gkQLWdCAX-kuNux*Z3Nw!OR3@XBU@f~`v9a4f^6c|LrG1n1%oK5 z&;e8d!2pT@hzxiFurPoR+w|W&ivfeXBxtw(@o#+IRcQV%RpxJA_2)QXgZ(@Cy3B606pBw zm262QG@Ds{K zo5&?_6U?5Hyu2)+KQ&PrvmJ=-+`6s~kF4?<*#8d%qnC)MBbDiWgHk}tm4hD)%45yg zld`5g>u~d46qho8dBv}cj}|wC&3TW1kzWj$lH~tH!g<%B);jcL>;}FVOEi+Ez@{aamM6SivI$#J&?Dt(P44tnv= z7Vcp$G{tYx0|E)C$@}XG@aXQ7tPwZvZDL7N(Dx^>N4~6zBE5aoES6faGl?P!Zalvh z9Kv!(GaDCmV_Y>)ge%xBoQZclQ*l5xTZr|ts`~lPmWy8YCcjr++rT0x(5;j^N?)Fb zKdYxH0`~CxrSrj+hghy3VrP}6KzQV*``<;F7z<8D9ZZFL5KkG142njH&_L6IEX!~i zHLSFayK}hIT&*v{eG8^K#n$^av(4-#GAu}41dbl1Fe4@<4bzZ1RhAK3Hh zb+c9a{U*^8s+z8~>L};Z*;v2g1v3`081)MZvaSFmetk-mt_n*Z?xHEny>$EDn`8T{ zvgi)xWUD3AJvlUGDTKdQKE=HUb`Ty@IC!ddb-`DD!&?ll+2x>jgpDxS#`di7I;SpC~My~8!tTvEMjanC<|(Yw(I;Z)Y=G;qa7 z2-iGfdKXGdnu`3QaLKiRB&CG4m3d|?j7?oIbj*04Zh|XAg%#bb*zia(T2?m(vrA=D z+ylEy;(*G`XkaPKVo;o2eAw+z2Gf!N^8rwYkN*$U{Q_#R8mHw7WZuY-1Qt7J0-)^&hUP!w%^wQJg#e7?ua-jsj_BKp z5{#sR!Bdz(AzHA2Ifa1S1Kzff5hqLyG*TT8G=!(|8MHG#;cm@0xu4~1dAFS~**=AI z5g)oGpAPCJrfHkD!~ zs+XOxF&Ke)QY7TfPAAFjFR#nJ!4rv$ADqaZ@cXG^C(4;~z(C0D4!mhk&(Dv7Y_w0e zKM-DrUVoV>)!0Op8tnDkaibkRsoE)1v|!MA8|QaU2g^3%RC(l7#<=mZTw_Sd9HKX$ z%o?-Q7AtVx$geH^+3$Wyb2BM(;+&*5yhSRi7nL=$ahw1`NC^(0AN zP*=3CtQ&S`^NoDZA3xtATpKbN0F$qa<=9(!LYPn3HAua&{rtq@BgGzQ< z-`K;Jyr(wmOfTvx*1IW)O%|o-zvqvTdl2Pu>o+k`YV`S$5&838!rwi9K0F@elvvU( zA@te*mG|S{lc~MgA7*`u2Kn)lX6^825nn2*tm8O~$EOFEu3=A(P8MDxZs2Hkc ziHf9kw3c>gDsM&TLO zCSbe(y(+sTn+x=00>9L*;?FP@f*%n1_DCWe%s=42`vxTj= zw!Y$DU2RDnB+j5Bif3bU&fT?;q|9*>0W_mbD(vW7C@3(juow%1w`T208e>o$(2gDb*Mh1H7CLB@0F)vX4s;S4Fie5}9e7zP zU}-T1Z82sb<*2Zfe=-y^Uf|y@k)B0A9J?)MMYh;R**~2eu_Bwpd;@&iCw`+<`8Ho| zzFaM~;+bd)Ige&f=)$c9P1I4*cnq$TvE=oxt9GWpUbg>(w&v)-wFI z)o%~WWyhUR^sMIAa?!N7D*N^P$HvNyn=-|C;mvfx!0i!|kr7C`3c=_B3=xd2s6&Gh zoy@SNV&;}FBE~(m+bm>37o5JxsU3#zunRnMB{5(vICO-g8c4pp!C z)TgBBpL1xIxpv9@C(EDC#P1J)UFAF=hT(_SJI7c^#lX6EzEsHD-BJ&x7NKg0MJLWP zxh~rKtk7mGVr4fA>lPRJArMxv8&&Q5B{`miFZ5Psoh%G`$u(^3aO?o&liUh_5VPC| zsHW72RHK|xrp@I&D-clT9EH^p+f?XoJD;25uXmlu9SzcSlR$SdR(40V!6u_O4 zvJspQmoIwl0MgwYLT73>x#y^*gKuD+4N7nDPPFXXdZb^(Ps$>Dy$XL%*XLu?pC6T` z>|sgoUN5!N4YXo`eq+&n@PQCwp@b7i`agYLc|4Ts`yTt!LK$Tr*+Q0N$xg)>Th@^! zs3j)*v3+dkd&fiJ2I9;IU*`5rID@lz2B*GPM^>DeSUvn%slhH z&%B>`uJ^j{>$>m9J!P0}=t8Ago>VO(bcm{%no#8LHy6LZbxNg{uDm6^-YThJe*jx= z9X>A9WpEd>=0z?-IR=l1QS44r_~ zynd`VtP8qkzlB7|qs`j(GfB zxtmbouN7Bk)ZZOtNCM#~qL`)u!8-xC335|zhlD^JD;eN!Wd$BEh#e3$_FttIi3t#= zLtO1Id=oXa>&LaTiffP(MA2o2GGV(lj|^pJ@7syU)wsDTm8S zv3FyYN9H|@l+0AjZO^~<^G!{Z>`oL56K%(+g}GxsCUJa6savcqL6kP|5&H>Ose9zl zppr9D=|$zMt@EXw)@6N%moHTsg0M+ll`-9}-p}sY=tvqQ z41bf#E;MAKW1PB;8q<&FhodWq-$FAyKE8c7soqj?ebj>eBQ=_G$oaG81+`JxExp() zQwfjg9-{YkD~>O@EOSq%N>hEl4#tFY*5>J}=e5=o6ISt!caM!Vf)zhBQaJy5@QS7@ zVKnVdvS?*@FqR`a)%-wE)Shvd#)A^$YbScCRa-Vi2vpu}+hU(Lc;|jc1?MYfF)AyO zGiw;%ptTsb+M7EZUKMo}tKhYObvE-qj22>646Ov|aUWWp3UVCk^Y)~ks{4Hh;rE%u zYbKjg-*V8eh*v0?6Emcp&U_K}6F>eO+jL;4`e6Y5*^!17%JmRk_xVy6$EAx;MX(0K zMRj(o$@M{kDj9B-Q`$yv!)B5^u8~qXQ!x$agKWKl{)1(rEAL9 z+}S6%);)1Fq*pvupk6rX-M-F#vwoIyA;*}DH+13jYxg2n^}Gs6b+7rbP?RbAb=I~2 zw{upHx)(#+jQ!TRE>iy7b$!jR=5<4+pL`xAiSi~zu3j@-VE@pa9l{;E+}7TIGdLg~ zUHW{ub#j2@%IfY!+GC2^Z2iKOpKFfaL#zG?G2)OL)x<6WfLJ!d~xlT4Bn~<+`vf(@;<$k z?e~+Kdm=quk+AwCzFJ)-?q%vU6P?$^IT$!6lN2(V zMy-4{N6U>nd5ub^4Lrxy8!z*C(6IsR zx&U<$Lm}h}Bw4m+G$aXv#AB?$N(fTYmK0O90B%YE4KNW@UI=+W4f-Wz1@izh1Ro?D zU=uzh3rv6ffs89|4>I1t8fxyiL0UC!Q=phD6~^C z%VG0F$3Decoe1{Ma1G~<(=cvvZ%^B8chE7UwDnfSyJj(KeWrVwXAbh>~mCM zfI=iq#79?q2Hz1`Z>u~T!4JTfQ!_j3=^8lSmD`v=C~qyt3K}xZVOma5bE3AEHk(05F8L-axYOsCLS3Rq{TSQLO9WY>d&R z4X^=5PBB;N{duf$^UPNr)ck`x^k-=}$?T6WeEj9<*n4VQVRP{VFB302^L{B`n5cCb z(MDyjAFER|jfJ5(Q|jj~hbDX9kWL+R=D$HkJMBk1iG_RBoz7_|?6n}Bk2O*JN>nH? z3GpAHaL$K6c;X;;BYl@E+Z=wxOp&(pxP+?0 zLpoKcV!1#vbC-RafjN`p)J!K$sy~TVQaYXBqf+KFM;T~DuAkRg9tgazL z(z`>m^LV$drf78%!#ZrMPKRGZ)Fl-=Z9&mlE1tLe7psmE)OMpAii<|#rHX^fJES;{ z*WEl8fu2m@I)0eRUYv@xyWM8*WN}c#;h=kKNTNcDryW7lb!epMVcd7r&MKVx%iN{w zF&nlDVWqCVTo*V$)P3aG{=&vfa~p^{W(6wU1!G=8{cJqxVOZtHb2XFQ$yH|^tKOJv zO*a!?+toEWt9fK+-_FZroHP(92pinC3vUfJq_2^H+vmEafGtr~%lL!X;6P2sj-!VDiy68r)ylHzBv^e|2x^c53#C8-G+h&^GI8;)xt%NJS=&=! zrhSzsal!37YHGAg>c&oYRD0p=SvyV}(^Y(@dTmg_YY!K%O^o+<{m+#ga}&U%Qw0pp z^7;N|mLf}1&hi-Y5*(-w>F0`%9n~{QzqTiVAs*hQAs4jP8Smu$d}Flj$DG8x7rQQ< zGxGS5_MqN7MaI5{ikHkj>~wJu>l%+&7$Br=``z!G(m~&Dazgaut6oh2c<1I`W#`}G zq0);xjKZv@azAME~Vh9B^8+MDEN{k$|89x5s2atw+Vu6;fT!xiAPyRR>I%( zie*Uq2ciDo2MFr_YJXKiYJYyZSdxFRUtqiPNRXBd?m<o=HrtbU#rrUwEYt%tKe46-}_ zqIbAF^pJA&g92oDb{f&gXoc~>BK;s{R14&za?BTI&C{raMP|_g;A_C9;^G&Ixt;Gw zF+n~OPn9?J=ZvomO<#^wbMnTFsm~Y@`{fH4bd6^iwz89K60JtJJXn*Og~C+ySCYQ>$LHU9mYX_WY0%3 z-#dtDdd2sMKyHq_Q{R#8&U<@Hrtt9%#uks(cor?(&kZIEzv}U}?IPrLNho$OD?;2f zGo~eCZ;sWD-%MpYJ)bpNUUA*MHlI5GbhW+wn%XVzuYdR&?*1%Ht-(D_R<9>DZ@6j_ zZUHoiox0j+TvD0Rz`Q0?B7@g%d@AzDgwI{X@an7+*Fvd=>m%1e%ivY%%H1lp5Amb{ z)t#t`3R%PU{E155T#3FQHohny6Gh#{Qq`s_KF3;|XHccEo$`UbGPpq!f6O+mizOPP ziR!|el$AC0Q?r*%^Y4N&%;INUGFSywFW{5V5ZW5iMmla+ghqN%IpGrxbekx4Z(dfNe9hfvzuHnj8VbhG$CK&m| zZhpdDWG)`kDLzb2u-(<^u-b(apGhdPb?3&knegWvqaK?q9CwKoczblHQ@w>yXe`RG z``UQz8#DG%t$Fu$+WF=Fwoe7i0rxH&By~cZ;9)uEXEJx|J4%cc8HC$^;oMSYY*pa5 zLiOc0_bzWQ;01l?{BmE2QhVXsa>gTp)p5*gmrTZ(Nh4V(6xQ;l0ng_-dig{v{X?Ywa@f$N{m;TVrjPaifBd;My_KWpjBH{~W=&thKI zocV)C%-d)97Cl1g$7iY|&DYJjMb}{8F+>fY3ds8AQIhM0F(fC@$DzFK9Z;BGM0LdS zi}XV11{8=v^DCl?0dam1rXN&`#~zcOUDwv%n1AW)CfckD;~9k4@#RMZpb<>1H`#w=F2gyZccnF3!#;K`p7 zAyOiQWVXS<%&KvQc?klVUIcKv=Wd*Ru}B6qsehT;Pj(4i9H3JeLy1b!hrB*$@vwtq zK#wM3C_u7ZfxJH&>A^|TPv0XMoGiJp!pLG$IZW2*CRR2DrFCc&zX9VU-S z6knN|murqfV$umc^nBFS##shkZ6t2^tB1bDxos|40}}k5_lDHwhLujIkaZRW3jRiST;X68m7xgE3+X=iX42>&QGsF;`{>9Lq zz4KBJ8aw6Gipn3FeNJn_C=|_)?Yk%-EQ76BG#8VWnSYf&)ltsLYv7#UUpCE_bcy7& z;y^h4BYwU`TIc5?+_F6URK(}!zmCoL7b?!sX{!P}HJr1`%+(@U!^3pb! z9ePn#dRW1+EjV}T&>q{UC+o4NXNctlyKd$)c{5C;efnlm(KOZeVhfd|{4BQ!Qrpf~ zO3%jz{|GPd(K8&6cKKBJY%>KrHC=^v6OT7es0j{tE0I%zdbZ5xbqf8S4hdMbB0}cD z@%$%T+l|UwjcfxkSt2&sUn?4*aWg{jj3LaXDcCGU)&Oq4i?^g!e-h=^ryna8xOr5&dH9 z8%#rTt(;0Uc zuidkP6SR!>kFxxCe@#3DsT<9kYR)CBPTOzA+n*{T zu9eiP7KRLyRYJR@O2|7hi!H5BhVNB2*y=cNYbfKqcRlfjFg_CMgpT8$?30!>(X{!j z2YUwWP2MtfkN+UQB27+Jo0e*9xo!a_z0*2rYBkxoR&xTjQxoin5Q~}YXVB{gvUFr^ zD`o-;YjNJ)YOPsI{h3CmSNhC#*qfvtzMC_cHH+BOChR<6I)L(uKm^tFAYCb&+t)cdS1T)%gvoXI|phF1bx8RQ+#1U1FQ q? \ No newline at end of file diff --git a/bsp/nrf5x/nrf52833/SConscript b/bsp/nrf5x/nrf52833/SConscript new file mode 100644 index 0000000000..20f7689c53 --- /dev/null +++ b/bsp/nrf5x/nrf52833/SConscript @@ -0,0 +1,15 @@ +# for module compiling +import os +Import('RTT_ROOT') +from building import * + +cwd = GetCurrentDir() +objs = [] +list = os.listdir(cwd) + +for d in list: + path = os.path.join(cwd, d) + if os.path.isfile(os.path.join(path, 'SConscript')): + objs = objs + SConscript(os.path.join(d, 'SConscript')) + +Return('objs') diff --git a/bsp/nrf5x/nrf52833/SConstruct b/bsp/nrf5x/nrf52833/SConstruct new file mode 100644 index 0000000000..2ac1ce6674 --- /dev/null +++ b/bsp/nrf5x/nrf52833/SConstruct @@ -0,0 +1,57 @@ +import os +import sys +import rtconfig + +if os.getenv('RTT_ROOT'): + RTT_ROOT = os.getenv('RTT_ROOT') +else: + RTT_ROOT = os.path.normpath(os.getcwd() + '/../../..') + +sys.path = sys.path + [os.path.join(RTT_ROOT, 'tools')] +try: + from building import * +except: + print('Cannot found RT-Thread root directory, please check RTT_ROOT') + print(RTT_ROOT) + exit(-1) + +TARGET = 'rt-thread.' + rtconfig.TARGET_EXT + +DefaultEnvironment(tools=[]) +env = Environment(tools = ['mingw'], + AS = rtconfig.AS, ASFLAGS = rtconfig.AFLAGS, + CC = rtconfig.CC, CCFLAGS = rtconfig.CFLAGS, + AR = rtconfig.AR, ARFLAGS = '-rc', + LINK = rtconfig.LINK, LINKFLAGS = rtconfig.LFLAGS) +env.PrependENVPath('PATH', rtconfig.EXEC_PATH) + +if rtconfig.PLATFORM == 'iar': + env.Replace(CCCOM = ['$CC $CCFLAGS $CPPFLAGS $_CPPDEFFLAGS $_CPPINCFLAGS -o $TARGET $SOURCES']) + env.Replace(ARFLAGS = ['']) + env.Replace(LINKCOM = env["LINKCOM"] + ' --map rt-thread.map') + +Export('RTT_ROOT') +Export('rtconfig') + +SDK_ROOT = os.path.abspath('./') + +if os.path.exists(SDK_ROOT + '/libraries'): + libraries_path_prefix = SDK_ROOT + '/libraries' +else: + libraries_path_prefix = os.path.dirname(SDK_ROOT) + '/libraries' + +SDK_LIB = libraries_path_prefix +Export('SDK_LIB') +print(SDK_LIB) + +# prepare building environment +objs = PrepareBuilding(env, RTT_ROOT, has_libcpu=False) + +# include drivers +objs.extend(SConscript(os.path.join(libraries_path_prefix, 'drivers', 'SConscript'))) + +# include cmsis +objs.extend(SConscript(os.path.join(libraries_path_prefix, 'cmsis', 'SConscript'))) + +# make a building +DoBuilding(TARGET, objs) diff --git a/bsp/nrf5x/nrf52833/applications/SConscript b/bsp/nrf5x/nrf52833/applications/SConscript new file mode 100644 index 0000000000..fc2501998c --- /dev/null +++ b/bsp/nrf5x/nrf52833/applications/SConscript @@ -0,0 +1,11 @@ +Import('RTT_ROOT') +Import('rtconfig') +from building import * + +cwd = os.path.join(str(Dir('#')), 'applications') +src = Glob('*.c') +CPPPATH = [cwd, str(Dir('#'))] + +group = DefineGroup('Applications', src, depend = [''], CPPPATH = CPPPATH) + +Return('group') diff --git a/bsp/nrf5x/nrf52833/applications/application.c b/bsp/nrf5x/nrf52833/applications/application.c new file mode 100644 index 0000000000..87d0f04b86 --- /dev/null +++ b/bsp/nrf5x/nrf52833/applications/application.c @@ -0,0 +1,23 @@ +/* + * Copyright (c) 2006-2021, RT-Thread Development Team + * + * SPDX-License-Identifier: Apache-2.0 + * + * Change Logs: + * Date Author Notes + * 2020-04-29 supperthomas first version + * + */ + +#include +#include + +int main(void) +{ + while (1) + { + rt_thread_mdelay(500); + } + return RT_EOK; +} + diff --git a/bsp/nrf5x/nrf52833/board/Kconfig b/bsp/nrf5x/nrf52833/board/Kconfig new file mode 100644 index 0000000000..029128ebee --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/Kconfig @@ -0,0 +1,97 @@ +menu "Hardware Drivers Config" + +config SOC_NRF52833 + bool + select RT_USING_COMPONENTS_INIT + select RT_USING_USER_MAIN + default y + +config SOC_NORDIC + bool + default y + +choice + prompt "Select BSP board " + default BSP_BOARD_PCA_10100 + + config BSP_BOARD_PCA_10100 + bool "NRF52833 pca10100" + +endchoice + +menu "On-chip Peripheral Drivers" + config BSP_USING_UART + bool "Enable UART" + default y + select RT_USING_SERIAL + config BSP_USING_UART0 + bool "Enable UART0" + default y + depends on BSP_USING_UART + + config BSP_UART0_RX_PIN + depends on BSP_USING_UART0 + int "uart0 rx pin number" + default 8 if BSP_BOARD_PCA_10100 + + config BSP_UART0_TX_PIN + depends on BSP_USING_UART0 + int "uart0 tx pin number" + default 6 if BSP_BOARD_PCA_10100 + + menu "On-chip flash config" + + config MCU_FLASH_START_ADDRESS + hex "MCU FLASH START ADDRESS" + default 0x00000000 + + config MCU_FLASH_SIZE_KB + int "MCU FLASH SIZE, MAX size 1024 KB" + default 1024 + + config MCU_SRAM_START_ADDRESS + hex "MCU RAM START ADDRESS" + default 0x20000000 + + config MCU_SRAM_SIZE_KB + int "MCU RAM SIZE" + default 256 + + config MCU_FLASH_PAGE_SIZE + hex "MCU FLASH PAGE SIZE, please not change,nrfx default is 0x1000" + default 0x1000 + endmenu + +endmenu + +if SOC_NORDIC + config NRFX_CLOCK_ENABLED + int + default 1 + config NRFX_CLOCK_DEFAULT_CONFIG_IRQ_PRIORITY + int + default 7 + config NRFX_CLOCK_CONFIG_LF_SRC + int + default 1 +endif + +if BSP_USING_UART + config NRFX_USING_UART + bool + default y + + config NRFX_UART_ENABLED + int + default 1 + + config NRFX_UART0_ENABLED + int + default 1 + depends on BSP_USING_UART0 +endif + + +endmenu + + diff --git a/bsp/nrf5x/nrf52833/board/SConscript b/bsp/nrf5x/nrf52833/board/SConscript new file mode 100644 index 0000000000..27bcddd310 --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/SConscript @@ -0,0 +1,11 @@ +Import('RTT_ROOT') +Import('rtconfig') +from building import * + +cwd = GetCurrentDir() +src = Glob('*.c') +CPPPATH = [cwd] +define = ['USE_APP_CONFIG'] + +group = DefineGroup('Drivers', src, depend = [''], CPPPATH = CPPPATH,CPPDEFINES = define) +Return('group') diff --git a/bsp/nrf5x/nrf52833/board/board.c b/bsp/nrf5x/nrf52833/board/board.c new file mode 100644 index 0000000000..2cb94fb6fa --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/board.c @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2006-2021, RT-Thread Development Team + * + * SPDX-License-Identifier: Apache-2.0 + * + * Change Logs: + * Date Author Notes + * 2020-04-29 supperthomas first version + * + */ +#include +#include +#include + +#include "board.h" +#include "drv_uart.h" +#include + +/** + * This is the timer interrupt service routine. + * + */ +void SysTick_Handler(void) +{ + /* enter interrupt */ + rt_interrupt_enter(); + + rt_tick_increase(); + + /* leave interrupt */ + rt_interrupt_leave(); +} + +static void clk_event_handler(nrfx_clock_evt_type_t event){} + +void SysTick_Configuration(void) +{ + nrfx_clock_init(clk_event_handler); + nrfx_clock_enable(); + nrfx_clock_lfclk_start(); + /* Set interrupt priority */ + NVIC_SetPriority(SysTick_IRQn, 0xf); + + /* Configure SysTick to interrupt at the requested rate. */ + nrf_systick_load_set(SystemCoreClock / RT_TICK_PER_SECOND); + nrf_systick_val_clear(); + nrf_systick_csr_set(NRF_SYSTICK_CSR_CLKSOURCE_CPU | NRF_SYSTICK_CSR_TICKINT_ENABLE + | NRF_SYSTICK_CSR_ENABLE); + +} + + +void rt_hw_board_init(void) +{ + rt_hw_interrupt_enable(0); + + SysTick_Configuration(); + +#if defined(RT_USING_HEAP) + rt_system_heap_init((void *)HEAP_BEGIN, (void *)HEAP_END); +#endif + +#ifdef RT_USING_SERIAL + rt_hw_uart_init(); +#endif + +#ifdef RT_USING_CONSOLE + rt_console_set_device(RT_CONSOLE_DEVICE_NAME); +#endif + +#ifdef RT_USING_COMPONENTS_INIT + rt_components_board_init(); +#endif + +#ifdef BSP_USING_SOFTDEVICE + extern uint32_t Image$$RW_IRAM1$$Base; + uint32_t const *const m_ram_start = &Image$$RW_IRAM1$$Base; + if ((uint32_t)m_ram_start == 0x20000000) + { + rt_kprintf("\r\n using softdevice the RAM couldn't be %p,please use the templete from package\r\n", m_ram_start); + while (1); + } + else + { + rt_kprintf("\r\n using softdevice the RAM at %p\r\n", m_ram_start); + } +#endif + +} + diff --git a/bsp/nrf5x/nrf52833/board/board.h b/bsp/nrf5x/nrf52833/board/board.h new file mode 100644 index 0000000000..52e812fac6 --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/board.h @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2006-2021, RT-Thread Development Team + * + * SPDX-License-Identifier: Apache-2.0 + * + * Change Logs: + * Date Author Notes + * 2020-04-29 supperthomas first version + * + */ +#ifndef _BOARD_H_ +#define _BOARD_H_ + +#include +#include +#include "nrf.h" + +#define MCU_FLASH_SIZE MCU_FLASH_SIZE_KB*1024 +#define MCU_FLASH_END_ADDRESS ((uint32_t)(MCU_FLASH_START_ADDRESS + MCU_FLASH_SIZE)) +#define MCU_SRAM_SIZE MCU_SRAM_SIZE_KB*1024 +#define MCU_SRAM_END_ADDRESS (MCU_SRAM_START_ADDRESS + MCU_SRAM_SIZE) + +#if defined(__CC_ARM) || defined(__CLANG_ARM) +extern int Image$$RW_IRAM1$$ZI$$Limit; +#define HEAP_BEGIN ((void *)&Image$$RW_IRAM1$$ZI$$Limit) +#elif __ICCARM__ +#pragma section="CSTACK" +#define HEAP_BEGIN (__segment_end("CSTACK")) +#else +extern int __bss_end__; +#define HEAP_BEGIN ((void *)&__bss_end__) +#endif + + +#define HEAP_END (MCU_SRAM_END_ADDRESS) + +void rt_hw_board_init(void); + +#endif + diff --git a/bsp/nrf5x/nrf52833/board/linker_scripts/link.lds b/bsp/nrf5x/nrf52833/board/linker_scripts/link.lds new file mode 100644 index 0000000000..f91b8466ca --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/linker_scripts/link.lds @@ -0,0 +1,15 @@ +/* Linker script to configure memory regions. */ + +SEARCH_DIR(.) +GROUP(-lgcc -lc -lnosys) + +MEMORY +{ + FLASH (rx) : ORIGIN = 0x0, LENGTH = 0x100000 + RAM (rwx) : ORIGIN = 0x20000000, LENGTH = 0x40000 +} + +INCLUDE "packages/nrfx-v2.1.0/mdk/nrf_common.ld" + + + diff --git a/bsp/nrf5x/nrf52833/board/linker_scripts/link.sct b/bsp/nrf5x/nrf52833/board/linker_scripts/link.sct new file mode 100644 index 0000000000..a2f8ebd922 --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/linker_scripts/link.sct @@ -0,0 +1,15 @@ +; ************************************************************* +; *** Scatter-Loading Description File generated by uVision *** +; ************************************************************* + +LR_IROM1 0x00000000 0x100000 { ; load region size_region + ER_IROM1 0x00000000 0x100000 { ; load address = execution address + *.o (RESET, +First) + *(InRoot$$Sections) + .ANY (+RO) + } + RW_IRAM1 0x20000000 0x40000 { ; RW data + .ANY (+RW +ZI) + } +} + diff --git a/bsp/nrf5x/nrf52833/board/nrfx_config.h b/bsp/nrf5x/nrf52833/board/nrfx_config.h new file mode 100644 index 0000000000..b006b6bcd5 --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/nrfx_config.h @@ -0,0 +1,47 @@ +/** + * Copyright (c) 2017 - 2019, Nordic Semiconductor ASA + * + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, must reproduce the above copyright notice, this list of + * conditions and the following disclaimer in the documentation and/or other + * materials provided with the distribution. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE + * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT + * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + */ + +#ifndef NRFX_CONFIG_H__ +#define NRFX_CONFIG_H__ + +// TODO - temporary redirection +#include + +#endif // NRFX_CONFIG_H__ diff --git a/bsp/nrf5x/nrf52833/board/nrfx_glue.h b/bsp/nrf5x/nrf52833/board/nrfx_glue.h new file mode 100644 index 0000000000..28025dafae --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/nrfx_glue.h @@ -0,0 +1,269 @@ +/* + * Copyright (c) 2017 - 2020, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * 3. Neither the name of the copyright holder nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef NRFX_GLUE_H__ +#define NRFX_GLUE_H__ + +// THIS IS A TEMPLATE FILE. +// It should be copied to a suitable location within the host environment into +// which nrfx is integrated, and the following macros should be provided with +// appropriate implementations. +// And this comment should be removed from the customized file. + +#ifdef __cplusplus +extern "C" { +#endif +#include +#include "nrf.h" +/** + * @defgroup nrfx_glue nrfx_glue.h + * @{ + * @ingroup nrfx + * + * @brief This file contains macros that should be implemented according to + * the needs of the host environment into which @em nrfx is integrated. + */ + +// Uncomment this line to use the standard MDK way of binding IRQ handlers +// at linking time. +#include + +//------------------------------------------------------------------------------ + +/** + * @brief Macro for placing a runtime assertion. + * + * @param expression Expression to be evaluated. + */ +#define NRFX_ASSERT(expression) + +/** + * @brief Macro for placing a compile time assertion. + * + * @param expression Expression to be evaluated. + */ +#define NRFX_STATIC_ASSERT(expression) + +//------------------------------------------------------------------------------ + +/** + * @brief Macro for setting the priority of a specific IRQ. + * + * @param irq_number IRQ number. + * @param priority Priority to be set. + */ +#define NRFX_IRQ_PRIORITY_SET(irq_number, priority) NVIC_SetPriority(irq_number, priority) + +/** + * @brief Macro for enabling a specific IRQ. + * + * @param irq_number IRQ number. + */ +#define NRFX_IRQ_ENABLE(irq_number) NVIC_EnableIRQ(irq_number) + +/** + * @brief Macro for checking if a specific IRQ is enabled. + * + * @param irq_number IRQ number. + * + * @retval true If the IRQ is enabled. + * @retval false Otherwise. + */ +#define NRFX_IRQ_IS_ENABLED(irq_number) _NRFX_IRQ_IS_ENABLED(irq_number) +static inline bool _NRFX_IRQ_IS_ENABLED(IRQn_Type irq_number) +{ + return 0 != (NVIC->ISER[irq_number / 32] & (1UL << (irq_number % 32))); +} + + +/** + * @brief Macro for disabling a specific IRQ. + * + * @param irq_number IRQ number. + */ +#define NRFX_IRQ_DISABLE(irq_number) _NRFX_IRQ_DISABLE(irq_number) +static inline void _NRFX_IRQ_DISABLE(IRQn_Type irq_number) +{ + NVIC_DisableIRQ(irq_number); +} + + +/** + * @brief Macro for setting a specific IRQ as pending. + * + * @param irq_number IRQ number. + */ +#define NRFX_IRQ_PENDING_SET(irq_number) + +/** + * @brief Macro for clearing the pending status of a specific IRQ. + * + * @param irq_number IRQ number. + */ +#define NRFX_IRQ_PENDING_CLEAR(irq_number) + +/** + * @brief Macro for checking the pending status of a specific IRQ. + * + * @retval true If the IRQ is pending. + * @retval false Otherwise. + */ +#define NRFX_IRQ_IS_PENDING(irq_number) + +/** @brief Macro for entering into a critical section. */ +#define NRFX_CRITICAL_SECTION_ENTER() + +/** @brief Macro for exiting from a critical section. */ +#define NRFX_CRITICAL_SECTION_EXIT() + +//------------------------------------------------------------------------------ + +/** + * @brief When set to a non-zero value, this macro specifies that + * @ref nrfx_coredep_delay_us uses a precise DWT-based solution. + * A compilation error is generated if the DWT unit is not present + * in the SoC used. + */ +#define NRFX_DELAY_DWT_BASED 0 + +/** + * @brief Macro for delaying the code execution for at least the specified time. + * + * @param us_time Number of microseconds to wait. + */ +#define NRFX_DELAY_US(us_time) + +//------------------------------------------------------------------------------ + +/** @brief Atomic 32-bit unsigned type. */ +#define nrfx_atomic_t + +/** + * @brief Macro for storing a value to an atomic object and returning its previous value. + * + * @param[in] p_data Atomic memory pointer. + * @param[in] value Value to store. + * + * @return Previous value of the atomic object. + */ +#define NRFX_ATOMIC_FETCH_STORE(p_data, value) + +/** + * @brief Macro for running a bitwise OR operation on an atomic object and returning its previous value. + * + * @param[in] p_data Atomic memory pointer. + * @param[in] value Value of the second operand in the OR operation. + * + * @return Previous value of the atomic object. + */ +#define NRFX_ATOMIC_FETCH_OR(p_data, value) + +/** + * @brief Macro for running a bitwise AND operation on an atomic object + * and returning its previous value. + * + * @param[in] p_data Atomic memory pointer. + * @param[in] value Value of the second operand in the AND operation. + * + * @return Previous value of the atomic object. + */ +#define NRFX_ATOMIC_FETCH_AND(p_data, value) + +/** + * @brief Macro for running a bitwise XOR operation on an atomic object + * and returning its previous value. + * + * @param[in] p_data Atomic memory pointer. + * @param[in] value Value of the second operand in the XOR operation. + * + * @return Previous value of the atomic object. + */ +#define NRFX_ATOMIC_FETCH_XOR(p_data, value) + +/** + * @brief Macro for running an addition operation on an atomic object + * and returning its previous value. + * + * @param[in] p_data Atomic memory pointer. + * @param[in] value Value of the second operand in the ADD operation. + * + * @return Previous value of the atomic object. + */ +#define NRFX_ATOMIC_FETCH_ADD(p_data, value) + +/** + * @brief Macro for running a subtraction operation on an atomic object + * and returning its previous value. + * + * @param[in] p_data Atomic memory pointer. + * @param[in] value Value of the second operand in the SUB operation. + * + * @return Previous value of the atomic object. + */ +#define NRFX_ATOMIC_FETCH_SUB(p_data, value) + +//------------------------------------------------------------------------------ + +/** + * @brief When set to a non-zero value, this macro specifies that the + * @ref nrfx_error_codes and the @ref nrfx_err_t type itself are defined + * in a customized way and the default definitions from @c + * should not be used. + */ +#define NRFX_CUSTOM_ERROR_CODES 0 + +//------------------------------------------------------------------------------ + +/** @brief Bitmask that defines DPPI channels that are reserved for use outside of the nrfx library. */ +#define NRFX_DPPI_CHANNELS_USED 0 + +/** @brief Bitmask that defines DPPI groups that are reserved for use outside of the nrfx library. */ +#define NRFX_DPPI_GROUPS_USED 0 + +/** @brief Bitmask that defines PPI channels that are reserved for use outside of the nrfx library. */ +#define NRFX_PPI_CHANNELS_USED 0 + +/** @brief Bitmask that defines PPI groups that are reserved for use outside of the nrfx library. */ +#define NRFX_PPI_GROUPS_USED 0 + +/** @brief Bitmask that defines EGU instances that are reserved for use outside of the nrfx library. */ +#define NRFX_EGUS_USED 0 + +/** @brief Bitmask that defines TIMER instances that are reserved for use outside of the nrfx library. */ +#define NRFX_TIMERS_USED 0 + +/** @} */ + +#ifdef __cplusplus +} +#endif + +#endif // NRFX_GLUE_H__ diff --git a/bsp/nrf5x/nrf52833/board/nrfx_log.h b/bsp/nrf5x/nrf52833/board/nrfx_log.h new file mode 100644 index 0000000000..80d8efbdf1 --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/nrfx_log.h @@ -0,0 +1,135 @@ +/* + * Copyright (c) 2017 - 2020, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * 3. Neither the name of the copyright holder nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef NRFX_LOG_H__ +#define NRFX_LOG_H__ + +// THIS IS A TEMPLATE FILE. +// It should be copied to a suitable location within the host environment into +// which nrfx is integrated, and the following macros should be provided with +// appropriate implementations. +// And this comment should be removed from the customized file. + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @defgroup nrfx_log nrfx_log.h + * @{ + * @ingroup nrfx + * + * @brief This file contains macros that should be implemented according to + * the needs of the host environment into which @em nrfx is integrated. + */ + +/** + * @brief Macro for logging a message with the severity level ERROR. + * + * @param format printf-style format string, optionally followed by arguments + * to be formatted and inserted in the resulting string. + */ +#define NRFX_LOG_ERROR(format, ...) + +/** + * @brief Macro for logging a message with the severity level WARNING. + * + * @param format printf-style format string, optionally followed by arguments + * to be formatted and inserted in the resulting string. + */ +#define NRFX_LOG_WARNING(format, ...) + +/** + * @brief Macro for logging a message with the severity level INFO. + * + * @param format printf-style format string, optionally followed by arguments + * to be formatted and inserted in the resulting string. + */ +#define NRFX_LOG_INFO(format, ...) + +/** + * @brief Macro for logging a message with the severity level DEBUG. + * + * @param format printf-style format string, optionally followed by arguments + * to be formatted and inserted in the resulting string. + */ +#define NRFX_LOG_DEBUG(format, ...) + + +/** + * @brief Macro for logging a memory dump with the severity level ERROR. + * + * @param[in] p_memory Pointer to the memory region to be dumped. + * @param[in] length Length of the memory region in bytes. + */ +#define NRFX_LOG_HEXDUMP_ERROR(p_memory, length) + +/** + * @brief Macro for logging a memory dump with the severity level WARNING. + * + * @param[in] p_memory Pointer to the memory region to be dumped. + * @param[in] length Length of the memory region in bytes. + */ +#define NRFX_LOG_HEXDUMP_WARNING(p_memory, length) + +/** + * @brief Macro for logging a memory dump with the severity level INFO. + * + * @param[in] p_memory Pointer to the memory region to be dumped. + * @param[in] length Length of the memory region in bytes. + */ +#define NRFX_LOG_HEXDUMP_INFO(p_memory, length) + +/** + * @brief Macro for logging a memory dump with the severity level DEBUG. + * + * @param[in] p_memory Pointer to the memory region to be dumped. + * @param[in] length Length of the memory region in bytes. + */ +#define NRFX_LOG_HEXDUMP_DEBUG(p_memory, length) + + +/** + * @brief Macro for getting the textual representation of a given error code. + * + * @param[in] error_code Error code. + * + * @return String containing the textual representation of the error code. + */ +#define NRFX_LOG_ERROR_STRING_GET(error_code) + +/** @} */ + +#ifdef __cplusplus +} +#endif + +#endif // NRFX_LOG_H__ diff --git a/bsp/nrf5x/nrf52833/board/sdk_config.h b/bsp/nrf5x/nrf52833/board/sdk_config.h new file mode 100644 index 0000000000..25fa4938fa --- /dev/null +++ b/bsp/nrf5x/nrf52833/board/sdk_config.h @@ -0,0 +1,11701 @@ +/** + * Copyright (c) 2017 - 2019, Nordic Semiconductor ASA + * + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, must reproduce the above copyright notice, this list of + * conditions and the following disclaimer in the documentation and/or other + * materials provided with the distribution. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE + * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT + * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + */ + + + +#ifndef SDK_CONFIG_H +#define SDK_CONFIG_H +// <<< Use Configuration Wizard in Context Menu >>>\n +// nRF_BLE + +#include +//========================================================== +// BLE_ADVERTISING_ENABLED - ble_advertising - Advertising module + + +#ifndef BLE_ADVERTISING_ENABLED +#define BLE_ADVERTISING_ENABLED 0 +#endif + +// BLE_DTM_ENABLED - ble_dtm - Module for testing RF/PHY using DTM commands + + +#ifndef BLE_DTM_ENABLED +#define BLE_DTM_ENABLED 0 +#endif + +// BLE_RACP_ENABLED - ble_racp - Record Access Control Point library + + +#ifndef BLE_RACP_ENABLED +#define BLE_RACP_ENABLED 0 +#endif + +// NRF_BLE_QWR_ENABLED - nrf_ble_qwr - Queued writes support module (prepare/execute write) +//========================================================== +#ifndef NRF_BLE_QWR_ENABLED +#define NRF_BLE_QWR_ENABLED 0 +#endif +// NRF_BLE_QWR_MAX_ATTR - Maximum number of attribute handles that can be registered. This number must be adjusted according to the number of attributes for which Queued Writes will be enabled. If it is zero, the module will reject all Queued Write requests. +#ifndef NRF_BLE_QWR_MAX_ATTR +#define NRF_BLE_QWR_MAX_ATTR 0 +#endif + +// + +// PEER_MANAGER_ENABLED - peer_manager - Peer Manager +//========================================================== +#ifndef PEER_MANAGER_ENABLED +#define PEER_MANAGER_ENABLED 0 +#endif +// PM_MAX_REGISTRANTS - Number of event handlers that can be registered. +#ifndef PM_MAX_REGISTRANTS +#define PM_MAX_REGISTRANTS 3 +#endif + +// PM_FLASH_BUFFERS - Number of internal buffers for flash operations. +// Decrease this value to lower RAM usage. + +#ifndef PM_FLASH_BUFFERS +#define PM_FLASH_BUFFERS 4 +#endif + +// PM_CENTRAL_ENABLED - Enable/disable central-specific Peer Manager functionality. + + +// Enable/disable central-specific Peer Manager functionality. + +#ifndef PM_CENTRAL_ENABLED +#define PM_CENTRAL_ENABLED 1 +#endif + +// PM_SERVICE_CHANGED_ENABLED - Enable/disable the service changed management for GATT server in Peer Manager. + + +// If not using a GATT server, or using a server wihout a service changed characteristic, +// disable this to save code space. + +#ifndef PM_SERVICE_CHANGED_ENABLED +#define PM_SERVICE_CHANGED_ENABLED 1 +#endif + +// PM_PEER_RANKS_ENABLED - Enable/disable the peer rank management in Peer Manager. + + +// Set this to false to save code space if not using the peer rank API. + +#ifndef PM_PEER_RANKS_ENABLED +#define PM_PEER_RANKS_ENABLED 1 +#endif + +// PM_LESC_ENABLED - Enable/disable LESC support in Peer Manager. + + +// If set to true, you need to call nrf_ble_lesc_request_handler() in the main loop to respond to LESC-related BLE events. If LESC support is not required, set this to false to save code space. + +#ifndef PM_LESC_ENABLED +#define PM_LESC_ENABLED 0 +#endif + +// PM_RA_PROTECTION_ENABLED - Enable/disable protection against repeated pairing attempts in Peer Manager. +//========================================================== +#ifndef PM_RA_PROTECTION_ENABLED +#define PM_RA_PROTECTION_ENABLED 0 +#endif +// PM_RA_PROTECTION_TRACKED_PEERS_NUM - Maximum number of peers whose authorization status can be tracked. +#ifndef PM_RA_PROTECTION_TRACKED_PEERS_NUM +#define PM_RA_PROTECTION_TRACKED_PEERS_NUM 8 +#endif + +// PM_RA_PROTECTION_MIN_WAIT_INTERVAL - Minimum waiting interval (in ms) before a new pairing attempt can be initiated. +#ifndef PM_RA_PROTECTION_MIN_WAIT_INTERVAL +#define PM_RA_PROTECTION_MIN_WAIT_INTERVAL 4000 +#endif + +// PM_RA_PROTECTION_MAX_WAIT_INTERVAL - Maximum waiting interval (in ms) before a new pairing attempt can be initiated. +#ifndef PM_RA_PROTECTION_MAX_WAIT_INTERVAL +#define PM_RA_PROTECTION_MAX_WAIT_INTERVAL 64000 +#endif + +// PM_RA_PROTECTION_REWARD_PERIOD - Reward period (in ms). +// The waiting interval is gradually decreased when no new failed pairing attempts are made during reward period. + +#ifndef PM_RA_PROTECTION_REWARD_PERIOD +#define PM_RA_PROTECTION_REWARD_PERIOD 10000 +#endif + +// + +// PM_HANDLER_SEC_DELAY_MS - Delay before starting security. +// This might be necessary for interoperability reasons, especially as peripheral. + +#ifndef PM_HANDLER_SEC_DELAY_MS +#define PM_HANDLER_SEC_DELAY_MS 0 +#endif + +// + +// +//========================================================== + +// nRF_BLE_Services + +//========================================================== +// BLE_ANCS_C_ENABLED - ble_ancs_c - Apple Notification Service Client + + +#ifndef BLE_ANCS_C_ENABLED +#define BLE_ANCS_C_ENABLED 0 +#endif + +// BLE_ANS_C_ENABLED - ble_ans_c - Alert Notification Service Client + + +#ifndef BLE_ANS_C_ENABLED +#define BLE_ANS_C_ENABLED 0 +#endif + +// BLE_BAS_C_ENABLED - ble_bas_c - Battery Service Client + + +#ifndef BLE_BAS_C_ENABLED +#define BLE_BAS_C_ENABLED 0 +#endif + +// BLE_BAS_ENABLED - ble_bas - Battery Service +//========================================================== +#ifndef BLE_BAS_ENABLED +#define BLE_BAS_ENABLED 0 +#endif +// BLE_BAS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef BLE_BAS_CONFIG_LOG_ENABLED +#define BLE_BAS_CONFIG_LOG_ENABLED 0 +#endif +// BLE_BAS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef BLE_BAS_CONFIG_LOG_LEVEL +#define BLE_BAS_CONFIG_LOG_LEVEL 3 +#endif + +// BLE_BAS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef BLE_BAS_CONFIG_INFO_COLOR +#define BLE_BAS_CONFIG_INFO_COLOR 0 +#endif + +// BLE_BAS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef BLE_BAS_CONFIG_DEBUG_COLOR +#define BLE_BAS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// BLE_CSCS_ENABLED - ble_cscs - Cycling Speed and Cadence Service + + +#ifndef BLE_CSCS_ENABLED +#define BLE_CSCS_ENABLED 0 +#endif + +// BLE_CTS_C_ENABLED - ble_cts_c - Current Time Service Client + + +#ifndef BLE_CTS_C_ENABLED +#define BLE_CTS_C_ENABLED 0 +#endif + +// BLE_DIS_ENABLED - ble_dis - Device Information Service + + +#ifndef BLE_DIS_ENABLED +#define BLE_DIS_ENABLED 0 +#endif + +// BLE_GLS_ENABLED - ble_gls - Glucose Service + + +#ifndef BLE_GLS_ENABLED +#define BLE_GLS_ENABLED 0 +#endif + +// BLE_HIDS_ENABLED - ble_hids - Human Interface Device Service + + +#ifndef BLE_HIDS_ENABLED +#define BLE_HIDS_ENABLED 0 +#endif + +// BLE_HRS_C_ENABLED - ble_hrs_c - Heart Rate Service Client + + +#ifndef BLE_HRS_C_ENABLED +#define BLE_HRS_C_ENABLED 0 +#endif + +// BLE_HRS_ENABLED - ble_hrs - Heart Rate Service + + +#ifndef BLE_HRS_ENABLED +#define BLE_HRS_ENABLED 0 +#endif + +// BLE_HTS_ENABLED - ble_hts - Health Thermometer Service + + +#ifndef BLE_HTS_ENABLED +#define BLE_HTS_ENABLED 0 +#endif + +// BLE_IAS_C_ENABLED - ble_ias_c - Immediate Alert Service Client + + +#ifndef BLE_IAS_C_ENABLED +#define BLE_IAS_C_ENABLED 0 +#endif + +// BLE_IAS_ENABLED - ble_ias - Immediate Alert Service +//========================================================== +#ifndef BLE_IAS_ENABLED +#define BLE_IAS_ENABLED 0 +#endif +// BLE_IAS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef BLE_IAS_CONFIG_LOG_ENABLED +#define BLE_IAS_CONFIG_LOG_ENABLED 0 +#endif +// BLE_IAS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef BLE_IAS_CONFIG_LOG_LEVEL +#define BLE_IAS_CONFIG_LOG_LEVEL 3 +#endif + +// BLE_IAS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef BLE_IAS_CONFIG_INFO_COLOR +#define BLE_IAS_CONFIG_INFO_COLOR 0 +#endif + +// BLE_IAS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef BLE_IAS_CONFIG_DEBUG_COLOR +#define BLE_IAS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// BLE_LBS_C_ENABLED - ble_lbs_c - Nordic LED Button Service Client + + +#ifndef BLE_LBS_C_ENABLED +#define BLE_LBS_C_ENABLED 0 +#endif + +// BLE_LBS_ENABLED - ble_lbs - LED Button Service + + +#ifndef BLE_LBS_ENABLED +#define BLE_LBS_ENABLED 0 +#endif + +// BLE_LLS_ENABLED - ble_lls - Link Loss Service + + +#ifndef BLE_LLS_ENABLED +#define BLE_LLS_ENABLED 0 +#endif + +// BLE_NUS_C_ENABLED - ble_nus_c - Nordic UART Central Service + + +#ifndef BLE_NUS_C_ENABLED +#define BLE_NUS_C_ENABLED 0 +#endif + +// BLE_NUS_ENABLED - ble_nus - Nordic UART Service +//========================================================== +#ifndef BLE_NUS_ENABLED +#define BLE_NUS_ENABLED 0 +#endif +// BLE_NUS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef BLE_NUS_CONFIG_LOG_ENABLED +#define BLE_NUS_CONFIG_LOG_ENABLED 0 +#endif +// BLE_NUS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef BLE_NUS_CONFIG_LOG_LEVEL +#define BLE_NUS_CONFIG_LOG_LEVEL 3 +#endif + +// BLE_NUS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef BLE_NUS_CONFIG_INFO_COLOR +#define BLE_NUS_CONFIG_INFO_COLOR 0 +#endif + +// BLE_NUS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef BLE_NUS_CONFIG_DEBUG_COLOR +#define BLE_NUS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// BLE_RSCS_C_ENABLED - ble_rscs_c - Running Speed and Cadence Client + + +#ifndef BLE_RSCS_C_ENABLED +#define BLE_RSCS_C_ENABLED 0 +#endif + +// BLE_RSCS_ENABLED - ble_rscs - Running Speed and Cadence Service + + +#ifndef BLE_RSCS_ENABLED +#define BLE_RSCS_ENABLED 0 +#endif + +// BLE_TPS_ENABLED - ble_tps - TX Power Service + + +#ifndef BLE_TPS_ENABLED +#define BLE_TPS_ENABLED 0 +#endif + +// +//========================================================== + +// nRF_Core + +//========================================================== +// NRF_MPU_LIB_ENABLED - nrf_mpu_lib - Module for MPU +//========================================================== +#ifndef NRF_MPU_LIB_ENABLED +#define NRF_MPU_LIB_ENABLED 0 +#endif +// NRF_MPU_LIB_CLI_CMDS - Enable CLI commands specific to the module. + + +#ifndef NRF_MPU_LIB_CLI_CMDS +#define NRF_MPU_LIB_CLI_CMDS 0 +#endif + +// + +// NRF_STACK_GUARD_ENABLED - nrf_stack_guard - Stack guard +//========================================================== +#ifndef NRF_STACK_GUARD_ENABLED +#define NRF_STACK_GUARD_ENABLED 0 +#endif +// NRF_STACK_GUARD_CONFIG_SIZE - Size of the stack guard. + +// <5=> 32 bytes +// <6=> 64 bytes +// <7=> 128 bytes +// <8=> 256 bytes +// <9=> 512 bytes +// <10=> 1024 bytes +// <11=> 2048 bytes +// <12=> 4096 bytes + +#ifndef NRF_STACK_GUARD_CONFIG_SIZE +#define NRF_STACK_GUARD_CONFIG_SIZE 7 +#endif + +// + +// +//========================================================== + +// nRF_Crypto + +//========================================================== +// NRF_CRYPTO_ENABLED - nrf_crypto - Cryptography library. +//========================================================== +#ifndef NRF_CRYPTO_ENABLED +#define NRF_CRYPTO_ENABLED 1 +#endif +// NRF_CRYPTO_ALLOCATOR - Memory allocator + + +// Choose memory allocator used by nrf_crypto. Default is alloca if possible or nrf_malloc otherwise. If 'User macros' are selected, the user has to create 'nrf_crypto_allocator.h' file that contains NRF_CRYPTO_ALLOC, NRF_CRYPTO_FREE, and NRF_CRYPTO_ALLOC_ON_STACK. +// <0=> Default +// <1=> User macros +// <2=> On stack (alloca) +// <3=> C dynamic memory (malloc) +// <4=> SDK Memory Manager (nrf_malloc) + +#ifndef NRF_CRYPTO_ALLOCATOR +#define NRF_CRYPTO_ALLOCATOR 0 +#endif + +// NRF_CRYPTO_BACKEND_CC310_BL_ENABLED - Enable the ARM Cryptocell CC310 reduced backend. + +// The CC310 hardware-accelerated cryptography backend with reduced functionality and footprint (only available on nRF52840). +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_BL_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_CC310_BL_ECC_SECP224R1_ENABLED - Enable the secp224r1 elliptic curve support using CC310_BL. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_ECC_SECP224R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_BL_ECC_SECP224R1_ENABLED 0 +#endif + +// NRF_CRYPTO_BACKEND_CC310_BL_ECC_SECP256R1_ENABLED - Enable the secp256r1 elliptic curve support using CC310_BL. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_ECC_SECP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_BL_ECC_SECP256R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_BL_HASH_SHA256_ENABLED - CC310_BL SHA-256 hash functionality. + + +// CC310_BL backend implementation for hardware-accelerated SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_HASH_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_BL_HASH_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_ENABLED - nrf_cc310_bl buffers to RAM before running hash operation + + +// Enabling this makes hashing of addresses in FLASH range possible. Size of buffer allocated for hashing is set by NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_SIZE + +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_ENABLED 0 +#endif + +// NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_SIZE - nrf_cc310_bl hash outputs digests in little endian +// Makes the nrf_cc310_bl hash functions output digests in little endian format. Only for use in nRF SDK DFU! + +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_SIZE +#define NRF_CRYPTO_BACKEND_CC310_BL_HASH_AUTOMATIC_RAM_BUFFER_SIZE 4096 +#endif + +// NRF_CRYPTO_BACKEND_CC310_BL_INTERRUPTS_ENABLED - Enable Interrupts while support using CC310 bl. + + +// Select a library version compatible with the configuration. When interrupts are disable, a version named _noint must be used + +#ifndef NRF_CRYPTO_BACKEND_CC310_BL_INTERRUPTS_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_BL_INTERRUPTS_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_CC310_ENABLED - Enable the ARM Cryptocell CC310 backend. + +// The CC310 hardware-accelerated cryptography backend (only available on nRF52840). +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_CC310_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_CC310_AES_CBC_ENABLED - Enable the AES CBC mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_CBC_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_CBC_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_AES_CTR_ENABLED - Enable the AES CTR mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_CTR_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_CTR_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_AES_ECB_ENABLED - Enable the AES ECB mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_ECB_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_ECB_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_AES_CBC_MAC_ENABLED - Enable the AES CBC_MAC mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_CBC_MAC_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_CBC_MAC_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_AES_CMAC_ENABLED - Enable the AES CMAC mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_CMAC_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_CMAC_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_AES_CCM_ENABLED - Enable the AES CCM mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_CCM_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_CCM_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_AES_CCM_STAR_ENABLED - Enable the AES CCM* mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_AES_CCM_STAR_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_AES_CCM_STAR_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_CHACHA_POLY_ENABLED - Enable the CHACHA-POLY mode using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_CHACHA_POLY_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_CHACHA_POLY_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP160R1_ENABLED - Enable the secp160r1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP160R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP160R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP160R2_ENABLED - Enable the secp160r2 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP160R2_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP160R2_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP192R1_ENABLED - Enable the secp192r1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP192R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP192R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP224R1_ENABLED - Enable the secp224r1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP224R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP224R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP256R1_ENABLED - Enable the secp256r1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP256R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP384R1_ENABLED - Enable the secp384r1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP384R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP384R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP521R1_ENABLED - Enable the secp521r1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP521R1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP521R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP160K1_ENABLED - Enable the secp160k1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP160K1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP160K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP192K1_ENABLED - Enable the secp192k1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP192K1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP192K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP224K1_ENABLED - Enable the secp224k1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP224K1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP224K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_SECP256K1_ENABLED - Enable the secp256k1 elliptic curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_SECP256K1_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_SECP256K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_CURVE25519_ENABLED - Enable the Curve25519 curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_CURVE25519_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_CURVE25519_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_ECC_ED25519_ENABLED - Enable the Ed25519 curve support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_ECC_ED25519_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_ECC_ED25519_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_HASH_SHA256_ENABLED - CC310 SHA-256 hash functionality. + + +// CC310 backend implementation for hardware-accelerated SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_CC310_HASH_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_HASH_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_HASH_SHA512_ENABLED - CC310 SHA-512 hash functionality + + +// CC310 backend implementation for SHA-512 (in software). + +#ifndef NRF_CRYPTO_BACKEND_CC310_HASH_SHA512_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_HASH_SHA512_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_HMAC_SHA256_ENABLED - CC310 HMAC using SHA-256 + + +// CC310 backend implementation for HMAC using hardware-accelerated SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_CC310_HMAC_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_HMAC_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_HMAC_SHA512_ENABLED - CC310 HMAC using SHA-512 + + +// CC310 backend implementation for HMAC using SHA-512 (in software). + +#ifndef NRF_CRYPTO_BACKEND_CC310_HMAC_SHA512_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_HMAC_SHA512_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_RNG_ENABLED - Enable RNG support using CC310. + + +#ifndef NRF_CRYPTO_BACKEND_CC310_RNG_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_RNG_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_CC310_INTERRUPTS_ENABLED - Enable Interrupts while support using CC310. + + +// Select a library version compatible with the configuration. When interrupts are disable, a version named _noint must be used + +#ifndef NRF_CRYPTO_BACKEND_CC310_INTERRUPTS_ENABLED +#define NRF_CRYPTO_BACKEND_CC310_INTERRUPTS_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_CIFRA_ENABLED - Enable the Cifra backend. +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_CIFRA_ENABLED +#define NRF_CRYPTO_BACKEND_CIFRA_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_CIFRA_AES_EAX_ENABLED - Enable the AES EAX mode using Cifra. + + +#ifndef NRF_CRYPTO_BACKEND_CIFRA_AES_EAX_ENABLED +#define NRF_CRYPTO_BACKEND_CIFRA_AES_EAX_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_MBEDTLS_ENABLED - Enable the mbed TLS backend. +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_ENABLED - Enable the AES CBC mode mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR_ENABLED - Enable the AES CTR mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_CTR_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB_ENABLED - Enable the AES CFB mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_CFB_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB_ENABLED - Enable the AES ECB mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_ECB_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC_ENABLED - Enable the AES CBC MAC mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_CBC_MAC_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC_ENABLED - Enable the AES CMAC mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_CMAC_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_CCM_ENABLED - Enable the AES CCM mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_CCM_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_CCM_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_AES_GCM_ENABLED - Enable the AES GCM mode using mbed TLS. + + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_AES_GCM_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_AES_GCM_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP192R1_ENABLED - Enable secp192r1 (NIST 192-bit) curve + + +// Enable this setting if you need secp192r1 (NIST 192-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP192R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP192R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP224R1_ENABLED - Enable secp224r1 (NIST 224-bit) curve + + +// Enable this setting if you need secp224r1 (NIST 224-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP224R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP224R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP256R1_ENABLED - Enable secp256r1 (NIST 256-bit) curve + + +// Enable this setting if you need secp256r1 (NIST 256-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP256R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP384R1_ENABLED - Enable secp384r1 (NIST 384-bit) curve + + +// Enable this setting if you need secp384r1 (NIST 384-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP384R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP384R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP521R1_ENABLED - Enable secp521r1 (NIST 521-bit) curve + + +// Enable this setting if you need secp521r1 (NIST 521-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP521R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP521R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP192K1_ENABLED - Enable secp192k1 (Koblitz 192-bit) curve + + +// Enable this setting if you need secp192k1 (Koblitz 192-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP192K1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP192K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP224K1_ENABLED - Enable secp224k1 (Koblitz 224-bit) curve + + +// Enable this setting if you need secp224k1 (Koblitz 224-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP224K1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP224K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP256K1_ENABLED - Enable secp256k1 (Koblitz 256-bit) curve + + +// Enable this setting if you need secp256k1 (Koblitz 256-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP256K1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_SECP256K1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP256R1_ENABLED - Enable bp256r1 (Brainpool 256-bit) curve + + +// Enable this setting if you need bp256r1 (Brainpool 256-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP256R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP384R1_ENABLED - Enable bp384r1 (Brainpool 384-bit) curve + + +// Enable this setting if you need bp384r1 (Brainpool 384-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP384R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP384R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP512R1_ENABLED - Enable bp512r1 (Brainpool 512-bit) curve + + +// Enable this setting if you need bp512r1 (Brainpool 512-bit) support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP512R1_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_BP512R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_ECC_CURVE25519_ENABLED - Enable Curve25519 curve + + +// Enable this setting if you need Curve25519 support using MBEDTLS + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_ECC_CURVE25519_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_ECC_CURVE25519_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_HASH_SHA256_ENABLED - Enable mbed TLS SHA-256 hash functionality. + + +// mbed TLS backend implementation for SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_HASH_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_HASH_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_HASH_SHA512_ENABLED - Enable mbed TLS SHA-512 hash functionality. + + +// mbed TLS backend implementation for SHA-512. + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_HASH_SHA512_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_HASH_SHA512_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_HMAC_SHA256_ENABLED - Enable mbed TLS HMAC using SHA-256. + + +// mbed TLS backend implementation for HMAC using SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_HMAC_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_HMAC_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MBEDTLS_HMAC_SHA512_ENABLED - Enable mbed TLS HMAC using SHA-512. + + +// mbed TLS backend implementation for HMAC using SHA-512. + +#ifndef NRF_CRYPTO_BACKEND_MBEDTLS_HMAC_SHA512_ENABLED +#define NRF_CRYPTO_BACKEND_MBEDTLS_HMAC_SHA512_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_MICRO_ECC_ENABLED - Enable the micro-ecc backend. +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_MICRO_ECC_ENABLED +#define NRF_CRYPTO_BACKEND_MICRO_ECC_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP192R1_ENABLED - Enable secp192r1 (NIST 192-bit) curve + + +// Enable this setting if you need secp192r1 (NIST 192-bit) support using micro-ecc + +#ifndef NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP192R1_ENABLED +#define NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP192R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP224R1_ENABLED - Enable secp224r1 (NIST 224-bit) curve + + +// Enable this setting if you need secp224r1 (NIST 224-bit) support using micro-ecc + +#ifndef NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP224R1_ENABLED +#define NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP224R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP256R1_ENABLED - Enable secp256r1 (NIST 256-bit) curve + + +// Enable this setting if you need secp256r1 (NIST 256-bit) support using micro-ecc + +#ifndef NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP256R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP256K1_ENABLED - Enable secp256k1 (Koblitz 256-bit) curve + + +// Enable this setting if you need secp256k1 (Koblitz 256-bit) support using micro-ecc + +#ifndef NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP256K1_ENABLED +#define NRF_CRYPTO_BACKEND_MICRO_ECC_ECC_SECP256K1_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_NRF_HW_RNG_ENABLED - Enable the nRF HW RNG backend. + +// The nRF HW backend provide access to RNG peripheral in nRF5x devices. +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_NRF_HW_RNG_ENABLED +#define NRF_CRYPTO_BACKEND_NRF_HW_RNG_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_NRF_HW_RNG_MBEDTLS_CTR_DRBG_ENABLED - Enable mbed TLS CTR-DRBG algorithm. + + +// Enable mbed TLS CTR-DRBG standardized by NIST (NIST SP 800-90A Rev. 1). The nRF HW RNG is used as an entropy source for seeding. + +#ifndef NRF_CRYPTO_BACKEND_NRF_HW_RNG_MBEDTLS_CTR_DRBG_ENABLED +#define NRF_CRYPTO_BACKEND_NRF_HW_RNG_MBEDTLS_CTR_DRBG_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_NRF_SW_ENABLED - Enable the legacy nRFx sw for crypto. + +// The nRF SW cryptography backend (only used in bootloader context). +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_NRF_SW_ENABLED +#define NRF_CRYPTO_BACKEND_NRF_SW_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_NRF_SW_HASH_SHA256_ENABLED - nRF SW hash backend support for SHA-256 + + +// The nRF SW backend provide access to nRF SDK legacy hash implementation of SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_NRF_SW_HASH_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_NRF_SW_HASH_SHA256_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_OBERON_ENABLED - Enable the Oberon backend + +// The Oberon backend +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_OBERON_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_OBERON_CHACHA_POLY_ENABLED - Enable the CHACHA-POLY mode using Oberon. + + +#ifndef NRF_CRYPTO_BACKEND_OBERON_CHACHA_POLY_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_CHACHA_POLY_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_ECC_SECP256R1_ENABLED - Enable secp256r1 curve + + +// Enable this setting if you need secp256r1 curve support using Oberon library + +#ifndef NRF_CRYPTO_BACKEND_OBERON_ECC_SECP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_ECC_SECP256R1_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_ECC_CURVE25519_ENABLED - Enable Curve25519 ECDH + + +// Enable this setting if you need Curve25519 ECDH support using Oberon library + +#ifndef NRF_CRYPTO_BACKEND_OBERON_ECC_CURVE25519_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_ECC_CURVE25519_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_ECC_ED25519_ENABLED - Enable Ed25519 signature scheme + + +// Enable this setting if you need Ed25519 support using Oberon library + +#ifndef NRF_CRYPTO_BACKEND_OBERON_ECC_ED25519_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_ECC_ED25519_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_HASH_SHA256_ENABLED - Oberon SHA-256 hash functionality + + +// Oberon backend implementation for SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_OBERON_HASH_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_HASH_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_HASH_SHA512_ENABLED - Oberon SHA-512 hash functionality + + +// Oberon backend implementation for SHA-512. + +#ifndef NRF_CRYPTO_BACKEND_OBERON_HASH_SHA512_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_HASH_SHA512_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_HMAC_SHA256_ENABLED - Oberon HMAC using SHA-256 + + +// Oberon backend implementation for HMAC using SHA-256. + +#ifndef NRF_CRYPTO_BACKEND_OBERON_HMAC_SHA256_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_HMAC_SHA256_ENABLED 1 +#endif + +// NRF_CRYPTO_BACKEND_OBERON_HMAC_SHA512_ENABLED - Oberon HMAC using SHA-512 + + +// Oberon backend implementation for HMAC using SHA-512. + +#ifndef NRF_CRYPTO_BACKEND_OBERON_HMAC_SHA512_ENABLED +#define NRF_CRYPTO_BACKEND_OBERON_HMAC_SHA512_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_BACKEND_OPTIGA_ENABLED - Enable the nrf_crypto Optiga Trust X backend. + +// Enables the nrf_crypto backend for Optiga Trust X devices. +//========================================================== +#ifndef NRF_CRYPTO_BACKEND_OPTIGA_ENABLED +#define NRF_CRYPTO_BACKEND_OPTIGA_ENABLED 0 +#endif +// NRF_CRYPTO_BACKEND_OPTIGA_RNG_ENABLED - Optiga backend support for RNG + + +// The Optiga backend provide external chip RNG. + +#ifndef NRF_CRYPTO_BACKEND_OPTIGA_RNG_ENABLED +#define NRF_CRYPTO_BACKEND_OPTIGA_RNG_ENABLED 0 +#endif + +// NRF_CRYPTO_BACKEND_OPTIGA_ECC_SECP256R1_ENABLED - Optiga backend support for ECC secp256r1 + + +// The Optiga backend provide external chip ECC using secp256r1. + +#ifndef NRF_CRYPTO_BACKEND_OPTIGA_ECC_SECP256R1_ENABLED +#define NRF_CRYPTO_BACKEND_OPTIGA_ECC_SECP256R1_ENABLED 1 +#endif + +// + +// NRF_CRYPTO_CURVE25519_BIG_ENDIAN_ENABLED - Big-endian byte order in raw Curve25519 data + + +// Enable big-endian byte order in Curve25519 API, if set to 1. Use little-endian, if set to 0. + +#ifndef NRF_CRYPTO_CURVE25519_BIG_ENDIAN_ENABLED +#define NRF_CRYPTO_CURVE25519_BIG_ENDIAN_ENABLED 0 +#endif + +// + +// +//========================================================== + +// nRF_DFU + +//========================================================== +// ble_dfu - Device Firmware Update + +//========================================================== +// BLE_DFU_ENABLED - Enable DFU Service. + + +#ifndef BLE_DFU_ENABLED +#define BLE_DFU_ENABLED 0 +#endif + +// NRF_DFU_BLE_BUTTONLESS_SUPPORTS_BONDS - Buttonless DFU supports bonds. + + +#ifndef NRF_DFU_BLE_BUTTONLESS_SUPPORTS_BONDS +#define NRF_DFU_BLE_BUTTONLESS_SUPPORTS_BONDS 0 +#endif + +// +//========================================================== + +// +//========================================================== + +// nRF_Drivers + +//========================================================== +// COMP_ENABLED - nrf_drv_comp - COMP peripheral driver - legacy layer +//========================================================== +#ifndef COMP_ENABLED +#define COMP_ENABLED 0 +#endif +// COMP_CONFIG_REF - Reference voltage + +// <0=> Internal 1.2V +// <1=> Internal 1.8V +// <2=> Internal 2.4V +// <4=> VDD +// <7=> ARef + +#ifndef COMP_CONFIG_REF +#define COMP_CONFIG_REF 1 +#endif + +// COMP_CONFIG_MAIN_MODE - Main mode + +// <0=> Single ended +// <1=> Differential + +#ifndef COMP_CONFIG_MAIN_MODE +#define COMP_CONFIG_MAIN_MODE 0 +#endif + +// COMP_CONFIG_SPEED_MODE - Speed mode + +// <0=> Low power +// <1=> Normal +// <2=> High speed + +#ifndef COMP_CONFIG_SPEED_MODE +#define COMP_CONFIG_SPEED_MODE 2 +#endif + +// COMP_CONFIG_HYST - Hystheresis + +// <0=> No +// <1=> 50mV + +#ifndef COMP_CONFIG_HYST +#define COMP_CONFIG_HYST 0 +#endif + +// COMP_CONFIG_ISOURCE - Current Source + +// <0=> Off +// <1=> 2.5 uA +// <2=> 5 uA +// <3=> 10 uA + +#ifndef COMP_CONFIG_ISOURCE +#define COMP_CONFIG_ISOURCE 0 +#endif + +// COMP_CONFIG_INPUT - Analog input + +// <0=> 0 +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef COMP_CONFIG_INPUT +#define COMP_CONFIG_INPUT 0 +#endif + +// COMP_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef COMP_CONFIG_IRQ_PRIORITY +#define COMP_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// EGU_ENABLED - nrf_drv_swi - SWI(EGU) peripheral driver - legacy layer + + +#ifndef EGU_ENABLED +#define EGU_ENABLED 0 +#endif + +// GPIOTE_ENABLED - nrf_drv_gpiote - GPIOTE peripheral driver - legacy layer +//========================================================== +#ifndef GPIOTE_ENABLED +#define GPIOTE_ENABLED 0 +#endif +// GPIOTE_CONFIG_NUM_OF_LOW_POWER_EVENTS - Number of lower power input pins +#ifndef GPIOTE_CONFIG_NUM_OF_LOW_POWER_EVENTS +#define GPIOTE_CONFIG_NUM_OF_LOW_POWER_EVENTS 1 +#endif + +// GPIOTE_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef GPIOTE_CONFIG_IRQ_PRIORITY +#define GPIOTE_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// I2S_ENABLED - nrf_drv_i2s - I2S peripheral driver - legacy layer +//========================================================== +#ifndef I2S_ENABLED +#define I2S_ENABLED 0 +#endif +// I2S_CONFIG_SCK_PIN - SCK pin <0-31> + + +#ifndef I2S_CONFIG_SCK_PIN +#define I2S_CONFIG_SCK_PIN 31 +#endif + +// I2S_CONFIG_LRCK_PIN - LRCK pin <1-31> + + +#ifndef I2S_CONFIG_LRCK_PIN +#define I2S_CONFIG_LRCK_PIN 30 +#endif + +// I2S_CONFIG_MCK_PIN - MCK pin +#ifndef I2S_CONFIG_MCK_PIN +#define I2S_CONFIG_MCK_PIN 255 +#endif + +// I2S_CONFIG_SDOUT_PIN - SDOUT pin <0-31> + + +#ifndef I2S_CONFIG_SDOUT_PIN +#define I2S_CONFIG_SDOUT_PIN 29 +#endif + +// I2S_CONFIG_SDIN_PIN - SDIN pin <0-31> + + +#ifndef I2S_CONFIG_SDIN_PIN +#define I2S_CONFIG_SDIN_PIN 28 +#endif + +// I2S_CONFIG_MASTER - Mode + +// <0=> Master +// <1=> Slave + +#ifndef I2S_CONFIG_MASTER +#define I2S_CONFIG_MASTER 0 +#endif + +// I2S_CONFIG_FORMAT - Format + +// <0=> I2S +// <1=> Aligned + +#ifndef I2S_CONFIG_FORMAT +#define I2S_CONFIG_FORMAT 0 +#endif + +// I2S_CONFIG_ALIGN - Alignment + +// <0=> Left +// <1=> Right + +#ifndef I2S_CONFIG_ALIGN +#define I2S_CONFIG_ALIGN 0 +#endif + +// I2S_CONFIG_SWIDTH - Sample width (bits) + +// <0=> 8 +// <1=> 16 +// <2=> 24 + +#ifndef I2S_CONFIG_SWIDTH +#define I2S_CONFIG_SWIDTH 1 +#endif + +// I2S_CONFIG_CHANNELS - Channels + +// <0=> Stereo +// <1=> Left +// <2=> Right + +#ifndef I2S_CONFIG_CHANNELS +#define I2S_CONFIG_CHANNELS 1 +#endif + +// I2S_CONFIG_MCK_SETUP - MCK behavior + +// <0=> Disabled +// <2147483648=> 32MHz/2 +// <1342177280=> 32MHz/3 +// <1073741824=> 32MHz/4 +// <805306368=> 32MHz/5 +// <671088640=> 32MHz/6 +// <536870912=> 32MHz/8 +// <402653184=> 32MHz/10 +// <369098752=> 32MHz/11 +// <285212672=> 32MHz/15 +// <268435456=> 32MHz/16 +// <201326592=> 32MHz/21 +// <184549376=> 32MHz/23 +// <142606336=> 32MHz/30 +// <138412032=> 32MHz/31 +// <134217728=> 32MHz/32 +// <100663296=> 32MHz/42 +// <68157440=> 32MHz/63 +// <34340864=> 32MHz/125 + +#ifndef I2S_CONFIG_MCK_SETUP +#define I2S_CONFIG_MCK_SETUP 536870912 +#endif + +// I2S_CONFIG_RATIO - MCK/LRCK ratio + +// <0=> 32x +// <1=> 48x +// <2=> 64x +// <3=> 96x +// <4=> 128x +// <5=> 192x +// <6=> 256x +// <7=> 384x +// <8=> 512x + +#ifndef I2S_CONFIG_RATIO +#define I2S_CONFIG_RATIO 2000 +#endif + +// I2S_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef I2S_CONFIG_IRQ_PRIORITY +#define I2S_CONFIG_IRQ_PRIORITY 6 +#endif + +// I2S_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef I2S_CONFIG_LOG_ENABLED +#define I2S_CONFIG_LOG_ENABLED 0 +#endif +// I2S_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef I2S_CONFIG_LOG_LEVEL +#define I2S_CONFIG_LOG_LEVEL 3 +#endif + +// I2S_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef I2S_CONFIG_INFO_COLOR +#define I2S_CONFIG_INFO_COLOR 0 +#endif + +// I2S_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef I2S_CONFIG_DEBUG_COLOR +#define I2S_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// LPCOMP_ENABLED - nrf_drv_lpcomp - LPCOMP peripheral driver - legacy layer +//========================================================== +#ifndef LPCOMP_ENABLED +#define LPCOMP_ENABLED 0 +#endif +// LPCOMP_CONFIG_REFERENCE - Reference voltage + +// <0=> Supply 1/8 +// <1=> Supply 2/8 +// <2=> Supply 3/8 +// <3=> Supply 4/8 +// <4=> Supply 5/8 +// <5=> Supply 6/8 +// <6=> Supply 7/8 +// <8=> Supply 1/16 (nRF52) +// <9=> Supply 3/16 (nRF52) +// <10=> Supply 5/16 (nRF52) +// <11=> Supply 7/16 (nRF52) +// <12=> Supply 9/16 (nRF52) +// <13=> Supply 11/16 (nRF52) +// <14=> Supply 13/16 (nRF52) +// <15=> Supply 15/16 (nRF52) +// <7=> External Ref 0 +// <65543=> External Ref 1 + +#ifndef LPCOMP_CONFIG_REFERENCE +#define LPCOMP_CONFIG_REFERENCE 3 +#endif + +// LPCOMP_CONFIG_DETECTION - Detection + +// <0=> Crossing +// <1=> Up +// <2=> Down + +#ifndef LPCOMP_CONFIG_DETECTION +#define LPCOMP_CONFIG_DETECTION 2 +#endif + +// LPCOMP_CONFIG_INPUT - Analog input + +// <0=> 0 +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef LPCOMP_CONFIG_INPUT +#define LPCOMP_CONFIG_INPUT 0 +#endif + +// LPCOMP_CONFIG_HYST - Hysteresis + + +#ifndef LPCOMP_CONFIG_HYST +#define LPCOMP_CONFIG_HYST 0 +#endif + +// LPCOMP_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef LPCOMP_CONFIG_IRQ_PRIORITY +#define LPCOMP_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// NRFX_CLOCK_ENABLED - nrfx_clock - CLOCK peripheral driver +//========================================================== +#ifndef NRFX_CLOCK_ENABLED +#define NRFX_CLOCK_ENABLED 0 +#endif +// NRFX_CLOCK_CONFIG_LF_SRC - LF Clock Source + +// <0=> RC +// <1=> XTAL +// <2=> Synth +// <131073=> External Low Swing +// <196609=> External Full Swing + +#ifndef NRFX_CLOCK_CONFIG_LF_SRC +#define NRFX_CLOCK_CONFIG_LF_SRC 1 +#endif + +// NRFX_CLOCK_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_CLOCK_CONFIG_IRQ_PRIORITY +#define NRFX_CLOCK_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_CLOCK_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_CLOCK_CONFIG_LOG_ENABLED +#define NRFX_CLOCK_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_CLOCK_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_CLOCK_CONFIG_LOG_LEVEL +#define NRFX_CLOCK_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_CLOCK_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_CLOCK_CONFIG_INFO_COLOR +#define NRFX_CLOCK_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_CLOCK_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_CLOCK_CONFIG_DEBUG_COLOR +#define NRFX_CLOCK_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_COMP_ENABLED - nrfx_comp - COMP peripheral driver +//========================================================== +#ifndef NRFX_COMP_ENABLED +#define NRFX_COMP_ENABLED 0 +#endif +// NRFX_COMP_CONFIG_REF - Reference voltage + +// <0=> Internal 1.2V +// <1=> Internal 1.8V +// <2=> Internal 2.4V +// <4=> VDD +// <7=> ARef + +#ifndef NRFX_COMP_CONFIG_REF +#define NRFX_COMP_CONFIG_REF 1 +#endif + +// NRFX_COMP_CONFIG_MAIN_MODE - Main mode + +// <0=> Single ended +// <1=> Differential + +#ifndef NRFX_COMP_CONFIG_MAIN_MODE +#define NRFX_COMP_CONFIG_MAIN_MODE 0 +#endif + +// NRFX_COMP_CONFIG_SPEED_MODE - Speed mode + +// <0=> Low power +// <1=> Normal +// <2=> High speed + +#ifndef NRFX_COMP_CONFIG_SPEED_MODE +#define NRFX_COMP_CONFIG_SPEED_MODE 2 +#endif + +// NRFX_COMP_CONFIG_HYST - Hystheresis + +// <0=> No +// <1=> 50mV + +#ifndef NRFX_COMP_CONFIG_HYST +#define NRFX_COMP_CONFIG_HYST 0 +#endif + +// NRFX_COMP_CONFIG_ISOURCE - Current Source + +// <0=> Off +// <1=> 2.5 uA +// <2=> 5 uA +// <3=> 10 uA + +#ifndef NRFX_COMP_CONFIG_ISOURCE +#define NRFX_COMP_CONFIG_ISOURCE 0 +#endif + +// NRFX_COMP_CONFIG_INPUT - Analog input + +// <0=> 0 +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_COMP_CONFIG_INPUT +#define NRFX_COMP_CONFIG_INPUT 0 +#endif + +// NRFX_COMP_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_COMP_CONFIG_IRQ_PRIORITY +#define NRFX_COMP_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_COMP_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_COMP_CONFIG_LOG_ENABLED +#define NRFX_COMP_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_COMP_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_COMP_CONFIG_LOG_LEVEL +#define NRFX_COMP_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_COMP_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_COMP_CONFIG_INFO_COLOR +#define NRFX_COMP_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_COMP_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_COMP_CONFIG_DEBUG_COLOR +#define NRFX_COMP_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_GPIOTE_ENABLED - nrfx_gpiote - GPIOTE peripheral driver +//========================================================== +#ifndef NRFX_GPIOTE_ENABLED +#define NRFX_GPIOTE_ENABLED 0 +#endif +// NRFX_GPIOTE_CONFIG_NUM_OF_LOW_POWER_EVENTS - Number of lower power input pins +#ifndef NRFX_GPIOTE_CONFIG_NUM_OF_LOW_POWER_EVENTS +#define NRFX_GPIOTE_CONFIG_NUM_OF_LOW_POWER_EVENTS 1 +#endif + +// NRFX_GPIOTE_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_GPIOTE_CONFIG_IRQ_PRIORITY +#define NRFX_GPIOTE_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_GPIOTE_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_GPIOTE_CONFIG_LOG_ENABLED +#define NRFX_GPIOTE_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_GPIOTE_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_GPIOTE_CONFIG_LOG_LEVEL +#define NRFX_GPIOTE_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_GPIOTE_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_GPIOTE_CONFIG_INFO_COLOR +#define NRFX_GPIOTE_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_GPIOTE_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_GPIOTE_CONFIG_DEBUG_COLOR +#define NRFX_GPIOTE_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_I2S_ENABLED - nrfx_i2s - I2S peripheral driver +//========================================================== +#ifndef NRFX_I2S_ENABLED +#define NRFX_I2S_ENABLED 0 +#endif +// NRFX_I2S_CONFIG_SCK_PIN - SCK pin <0-31> + + +#ifndef NRFX_I2S_CONFIG_SCK_PIN +#define NRFX_I2S_CONFIG_SCK_PIN 31 +#endif + +// NRFX_I2S_CONFIG_LRCK_PIN - LRCK pin <1-31> + + +#ifndef NRFX_I2S_CONFIG_LRCK_PIN +#define NRFX_I2S_CONFIG_LRCK_PIN 30 +#endif + +// NRFX_I2S_CONFIG_MCK_PIN - MCK pin +#ifndef NRFX_I2S_CONFIG_MCK_PIN +#define NRFX_I2S_CONFIG_MCK_PIN 255 +#endif + +// NRFX_I2S_CONFIG_SDOUT_PIN - SDOUT pin <0-31> + + +#ifndef NRFX_I2S_CONFIG_SDOUT_PIN +#define NRFX_I2S_CONFIG_SDOUT_PIN 29 +#endif + +// NRFX_I2S_CONFIG_SDIN_PIN - SDIN pin <0-31> + + +#ifndef NRFX_I2S_CONFIG_SDIN_PIN +#define NRFX_I2S_CONFIG_SDIN_PIN 28 +#endif + +// NRFX_I2S_CONFIG_MASTER - Mode + +// <0=> Master +// <1=> Slave + +#ifndef NRFX_I2S_CONFIG_MASTER +#define NRFX_I2S_CONFIG_MASTER 0 +#endif + +// NRFX_I2S_CONFIG_FORMAT - Format + +// <0=> I2S +// <1=> Aligned + +#ifndef NRFX_I2S_CONFIG_FORMAT +#define NRFX_I2S_CONFIG_FORMAT 0 +#endif + +// NRFX_I2S_CONFIG_ALIGN - Alignment + +// <0=> Left +// <1=> Right + +#ifndef NRFX_I2S_CONFIG_ALIGN +#define NRFX_I2S_CONFIG_ALIGN 0 +#endif + +// NRFX_I2S_CONFIG_SWIDTH - Sample width (bits) + +// <0=> 8 +// <1=> 16 +// <2=> 24 + +#ifndef NRFX_I2S_CONFIG_SWIDTH +#define NRFX_I2S_CONFIG_SWIDTH 1 +#endif + +// NRFX_I2S_CONFIG_CHANNELS - Channels + +// <0=> Stereo +// <1=> Left +// <2=> Right + +#ifndef NRFX_I2S_CONFIG_CHANNELS +#define NRFX_I2S_CONFIG_CHANNELS 1 +#endif + +// NRFX_I2S_CONFIG_MCK_SETUP - MCK behavior + +// <0=> Disabled +// <2147483648=> 32MHz/2 +// <1342177280=> 32MHz/3 +// <1073741824=> 32MHz/4 +// <805306368=> 32MHz/5 +// <671088640=> 32MHz/6 +// <536870912=> 32MHz/8 +// <402653184=> 32MHz/10 +// <369098752=> 32MHz/11 +// <285212672=> 32MHz/15 +// <268435456=> 32MHz/16 +// <201326592=> 32MHz/21 +// <184549376=> 32MHz/23 +// <142606336=> 32MHz/30 +// <138412032=> 32MHz/31 +// <134217728=> 32MHz/32 +// <100663296=> 32MHz/42 +// <68157440=> 32MHz/63 +// <34340864=> 32MHz/125 + +#ifndef NRFX_I2S_CONFIG_MCK_SETUP +#define NRFX_I2S_CONFIG_MCK_SETUP 536870912 +#endif + +// NRFX_I2S_CONFIG_RATIO - MCK/LRCK ratio + +// <0=> 32x +// <1=> 48x +// <2=> 64x +// <3=> 96x +// <4=> 128x +// <5=> 192x +// <6=> 256x +// <7=> 384x +// <8=> 512x + +#ifndef NRFX_I2S_CONFIG_RATIO +#define NRFX_I2S_CONFIG_RATIO 2000 +#endif + +// NRFX_I2S_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_I2S_CONFIG_IRQ_PRIORITY +#define NRFX_I2S_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_I2S_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_I2S_CONFIG_LOG_ENABLED +#define NRFX_I2S_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_I2S_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_I2S_CONFIG_LOG_LEVEL +#define NRFX_I2S_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_I2S_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_I2S_CONFIG_INFO_COLOR +#define NRFX_I2S_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_I2S_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_I2S_CONFIG_DEBUG_COLOR +#define NRFX_I2S_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_LPCOMP_ENABLED - nrfx_lpcomp - LPCOMP peripheral driver +//========================================================== +#ifndef NRFX_LPCOMP_ENABLED +#define NRFX_LPCOMP_ENABLED 0 +#endif +// NRFX_LPCOMP_CONFIG_REFERENCE - Reference voltage + +// <0=> Supply 1/8 +// <1=> Supply 2/8 +// <2=> Supply 3/8 +// <3=> Supply 4/8 +// <4=> Supply 5/8 +// <5=> Supply 6/8 +// <6=> Supply 7/8 +// <8=> Supply 1/16 (nRF52) +// <9=> Supply 3/16 (nRF52) +// <10=> Supply 5/16 (nRF52) +// <11=> Supply 7/16 (nRF52) +// <12=> Supply 9/16 (nRF52) +// <13=> Supply 11/16 (nRF52) +// <14=> Supply 13/16 (nRF52) +// <15=> Supply 15/16 (nRF52) +// <7=> External Ref 0 +// <65543=> External Ref 1 + +#ifndef NRFX_LPCOMP_CONFIG_REFERENCE +#define NRFX_LPCOMP_CONFIG_REFERENCE 3 +#endif + +// NRFX_LPCOMP_CONFIG_DETECTION - Detection + +// <0=> Crossing +// <1=> Up +// <2=> Down + +#ifndef NRFX_LPCOMP_CONFIG_DETECTION +#define NRFX_LPCOMP_CONFIG_DETECTION 2 +#endif + +// NRFX_LPCOMP_CONFIG_INPUT - Analog input + +// <0=> 0 +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_LPCOMP_CONFIG_INPUT +#define NRFX_LPCOMP_CONFIG_INPUT 0 +#endif + +// NRFX_LPCOMP_CONFIG_HYST - Hysteresis + + +#ifndef NRFX_LPCOMP_CONFIG_HYST +#define NRFX_LPCOMP_CONFIG_HYST 0 +#endif + +// NRFX_LPCOMP_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_LPCOMP_CONFIG_IRQ_PRIORITY +#define NRFX_LPCOMP_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_LPCOMP_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_LPCOMP_CONFIG_LOG_ENABLED +#define NRFX_LPCOMP_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_LPCOMP_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_LPCOMP_CONFIG_LOG_LEVEL +#define NRFX_LPCOMP_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_LPCOMP_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_LPCOMP_CONFIG_INFO_COLOR +#define NRFX_LPCOMP_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_LPCOMP_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_LPCOMP_CONFIG_DEBUG_COLOR +#define NRFX_LPCOMP_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_NFCT_ENABLED - nrfx_nfct - NFCT peripheral driver +//========================================================== +#ifndef NRFX_NFCT_ENABLED +#define NRFX_NFCT_ENABLED 0 +#endif +// NRFX_NFCT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_NFCT_CONFIG_IRQ_PRIORITY +#define NRFX_NFCT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_NFCT_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_NFCT_CONFIG_LOG_ENABLED +#define NRFX_NFCT_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_NFCT_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_NFCT_CONFIG_LOG_LEVEL +#define NRFX_NFCT_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_NFCT_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_NFCT_CONFIG_INFO_COLOR +#define NRFX_NFCT_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_NFCT_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_NFCT_CONFIG_DEBUG_COLOR +#define NRFX_NFCT_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_PDM_ENABLED - nrfx_pdm - PDM peripheral driver +//========================================================== +#ifndef NRFX_PDM_ENABLED +#define NRFX_PDM_ENABLED 0 +#endif +// NRFX_PDM_CONFIG_MODE - Mode + +// <0=> Stereo +// <1=> Mono + +#ifndef NRFX_PDM_CONFIG_MODE +#define NRFX_PDM_CONFIG_MODE 1 +#endif + +// NRFX_PDM_CONFIG_EDGE - Edge + +// <0=> Left falling +// <1=> Left rising + +#ifndef NRFX_PDM_CONFIG_EDGE +#define NRFX_PDM_CONFIG_EDGE 0 +#endif + +// NRFX_PDM_CONFIG_CLOCK_FREQ - Clock frequency + +// <134217728=> 1000k +// <138412032=> 1032k (default) +// <142606336=> 1067k + +#ifndef NRFX_PDM_CONFIG_CLOCK_FREQ +#define NRFX_PDM_CONFIG_CLOCK_FREQ 138412032 +#endif + +// NRFX_PDM_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_PDM_CONFIG_IRQ_PRIORITY +#define NRFX_PDM_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_PDM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_PDM_CONFIG_LOG_ENABLED +#define NRFX_PDM_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_PDM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_PDM_CONFIG_LOG_LEVEL +#define NRFX_PDM_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_PDM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_PDM_CONFIG_INFO_COLOR +#define NRFX_PDM_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_PDM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_PDM_CONFIG_DEBUG_COLOR +#define NRFX_PDM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_POWER_ENABLED - nrfx_power - POWER peripheral driver +//========================================================== +#ifndef NRFX_POWER_ENABLED +#define NRFX_POWER_ENABLED 0 +#endif +// NRFX_POWER_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_POWER_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_POWER_DEFAULT_CONFIG_IRQ_PRIORITY 7 +#endif + +// NRFX_POWER_CONFIG_DEFAULT_DCDCEN - The default configuration of main DCDC regulator + + +// This settings means only that components for DCDC regulator are installed and it can be enabled. + +#ifndef NRFX_POWER_CONFIG_DEFAULT_DCDCEN +#define NRFX_POWER_CONFIG_DEFAULT_DCDCEN 0 +#endif + +// NRFX_POWER_CONFIG_DEFAULT_DCDCENHV - The default configuration of High Voltage DCDC regulator + + +// This settings means only that components for DCDC regulator are installed and it can be enabled. + +#ifndef NRFX_POWER_CONFIG_DEFAULT_DCDCENHV +#define NRFX_POWER_CONFIG_DEFAULT_DCDCENHV 0 +#endif + +// + +// NRFX_PPI_ENABLED - nrfx_ppi - PPI peripheral allocator +//========================================================== +#ifndef NRFX_PPI_ENABLED +#define NRFX_PPI_ENABLED 0 +#endif +// NRFX_PPI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_PPI_CONFIG_LOG_ENABLED +#define NRFX_PPI_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_PPI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_PPI_CONFIG_LOG_LEVEL +#define NRFX_PPI_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_PPI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_PPI_CONFIG_INFO_COLOR +#define NRFX_PPI_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_PPI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_PPI_CONFIG_DEBUG_COLOR +#define NRFX_PPI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_PWM_ENABLED - nrfx_pwm - PWM peripheral driver +//========================================================== +#ifndef NRFX_PWM_ENABLED +#define NRFX_PWM_ENABLED 0 +#endif +// NRFX_PWM0_ENABLED - Enable PWM0 instance + + +#ifndef NRFX_PWM0_ENABLED +#define NRFX_PWM0_ENABLED 0 +#endif + +// NRFX_PWM1_ENABLED - Enable PWM1 instance + + +#ifndef NRFX_PWM1_ENABLED +#define NRFX_PWM1_ENABLED 0 +#endif + +// NRFX_PWM2_ENABLED - Enable PWM2 instance + + +#ifndef NRFX_PWM2_ENABLED +#define NRFX_PWM2_ENABLED 0 +#endif + +// NRFX_PWM3_ENABLED - Enable PWM3 instance + + +#ifndef NRFX_PWM3_ENABLED +#define NRFX_PWM3_ENABLED 0 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_OUT0_PIN - Out0 pin <0-31> + + +#ifndef NRFX_PWM_DEFAULT_CONFIG_OUT0_PIN +#define NRFX_PWM_DEFAULT_CONFIG_OUT0_PIN 31 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_OUT1_PIN - Out1 pin <0-31> + + +#ifndef NRFX_PWM_DEFAULT_CONFIG_OUT1_PIN +#define NRFX_PWM_DEFAULT_CONFIG_OUT1_PIN 31 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_OUT2_PIN - Out2 pin <0-31> + + +#ifndef NRFX_PWM_DEFAULT_CONFIG_OUT2_PIN +#define NRFX_PWM_DEFAULT_CONFIG_OUT2_PIN 31 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_OUT3_PIN - Out3 pin <0-31> + + +#ifndef NRFX_PWM_DEFAULT_CONFIG_OUT3_PIN +#define NRFX_PWM_DEFAULT_CONFIG_OUT3_PIN 31 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_BASE_CLOCK - Base clock + +// <0=> 16 MHz +// <1=> 8 MHz +// <2=> 4 MHz +// <3=> 2 MHz +// <4=> 1 MHz +// <5=> 500 kHz +// <6=> 250 kHz +// <7=> 125 kHz + +#ifndef NRFX_PWM_DEFAULT_CONFIG_BASE_CLOCK +#define NRFX_PWM_DEFAULT_CONFIG_BASE_CLOCK 4 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_COUNT_MODE - Count mode + +// <0=> Up +// <1=> Up and Down + +#ifndef NRFX_PWM_DEFAULT_CONFIG_COUNT_MODE +#define NRFX_PWM_DEFAULT_CONFIG_COUNT_MODE 0 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_TOP_VALUE - Top value +#ifndef NRFX_PWM_DEFAULT_CONFIG_TOP_VALUE +#define NRFX_PWM_DEFAULT_CONFIG_TOP_VALUE 1000 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_LOAD_MODE - Load mode + +// <0=> Common +// <1=> Grouped +// <2=> Individual +// <3=> Waveform + +#ifndef NRFX_PWM_DEFAULT_CONFIG_LOAD_MODE +#define NRFX_PWM_DEFAULT_CONFIG_LOAD_MODE 0 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_STEP_MODE - Step mode + +// <0=> Auto +// <1=> Triggered + +#ifndef NRFX_PWM_DEFAULT_CONFIG_STEP_MODE +#define NRFX_PWM_DEFAULT_CONFIG_STEP_MODE 0 +#endif + +// NRFX_PWM_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_PWM_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_PWM_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_PWM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_PWM_CONFIG_LOG_ENABLED +#define NRFX_PWM_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_PWM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_PWM_CONFIG_LOG_LEVEL +#define NRFX_PWM_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_PWM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_PWM_CONFIG_INFO_COLOR +#define NRFX_PWM_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_PWM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_PWM_CONFIG_DEBUG_COLOR +#define NRFX_PWM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_QDEC_ENABLED - nrfx_qdec - QDEC peripheral driver +//========================================================== +#ifndef NRFX_QDEC_ENABLED +#define NRFX_QDEC_ENABLED 0 +#endif +// NRFX_QDEC_CONFIG_REPORTPER - Report period + +// <0=> 10 Samples +// <1=> 40 Samples +// <2=> 80 Samples +// <3=> 120 Samples +// <4=> 160 Samples +// <5=> 200 Samples +// <6=> 240 Samples +// <7=> 280 Samples + +#ifndef NRFX_QDEC_CONFIG_REPORTPER +#define NRFX_QDEC_CONFIG_REPORTPER 0 +#endif + +// NRFX_QDEC_CONFIG_SAMPLEPER - Sample period + +// <0=> 128 us +// <1=> 256 us +// <2=> 512 us +// <3=> 1024 us +// <4=> 2048 us +// <5=> 4096 us +// <6=> 8192 us +// <7=> 16384 us + +#ifndef NRFX_QDEC_CONFIG_SAMPLEPER +#define NRFX_QDEC_CONFIG_SAMPLEPER 7 +#endif + +// NRFX_QDEC_CONFIG_PIO_A - A pin <0-31> + + +#ifndef NRFX_QDEC_CONFIG_PIO_A +#define NRFX_QDEC_CONFIG_PIO_A 31 +#endif + +// NRFX_QDEC_CONFIG_PIO_B - B pin <0-31> + + +#ifndef NRFX_QDEC_CONFIG_PIO_B +#define NRFX_QDEC_CONFIG_PIO_B 31 +#endif + +// NRFX_QDEC_CONFIG_PIO_LED - LED pin <0-31> + + +#ifndef NRFX_QDEC_CONFIG_PIO_LED +#define NRFX_QDEC_CONFIG_PIO_LED 31 +#endif + +// NRFX_QDEC_CONFIG_LEDPRE - LED pre +#ifndef NRFX_QDEC_CONFIG_LEDPRE +#define NRFX_QDEC_CONFIG_LEDPRE 511 +#endif + +// NRFX_QDEC_CONFIG_LEDPOL - LED polarity + +// <0=> Active low +// <1=> Active high + +#ifndef NRFX_QDEC_CONFIG_LEDPOL +#define NRFX_QDEC_CONFIG_LEDPOL 1 +#endif + +// NRFX_QDEC_CONFIG_DBFEN - Debouncing enable + + +#ifndef NRFX_QDEC_CONFIG_DBFEN +#define NRFX_QDEC_CONFIG_DBFEN 0 +#endif + +// NRFX_QDEC_CONFIG_SAMPLE_INTEN - Sample ready interrupt enable + + +#ifndef NRFX_QDEC_CONFIG_SAMPLE_INTEN +#define NRFX_QDEC_CONFIG_SAMPLE_INTEN 0 +#endif + +// NRFX_QDEC_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_QDEC_CONFIG_IRQ_PRIORITY +#define NRFX_QDEC_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_QDEC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_QDEC_CONFIG_LOG_ENABLED +#define NRFX_QDEC_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_QDEC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_QDEC_CONFIG_LOG_LEVEL +#define NRFX_QDEC_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_QDEC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_QDEC_CONFIG_INFO_COLOR +#define NRFX_QDEC_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_QDEC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_QDEC_CONFIG_DEBUG_COLOR +#define NRFX_QDEC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_QSPI_ENABLED - nrfx_qspi - QSPI peripheral driver +//========================================================== +#ifndef NRFX_QSPI_ENABLED +#define NRFX_QSPI_ENABLED 0 +#endif +// NRFX_QSPI_CONFIG_SCK_DELAY - tSHSL, tWHSL and tSHWL in number of 16 MHz periods (62.5 ns). <0-255> + + +#ifndef NRFX_QSPI_CONFIG_SCK_DELAY +#define NRFX_QSPI_CONFIG_SCK_DELAY 1 +#endif + +// NRFX_QSPI_CONFIG_XIP_OFFSET - Address offset in the external memory for Execute in Place operation. +#ifndef NRFX_QSPI_CONFIG_XIP_OFFSET +#define NRFX_QSPI_CONFIG_XIP_OFFSET 0 +#endif + +// NRFX_QSPI_CONFIG_READOC - Number of data lines and opcode used for reading. + +// <0=> FastRead +// <1=> Read2O +// <2=> Read2IO +// <3=> Read4O +// <4=> Read4IO + +#ifndef NRFX_QSPI_CONFIG_READOC +#define NRFX_QSPI_CONFIG_READOC 0 +#endif + +// NRFX_QSPI_CONFIG_WRITEOC - Number of data lines and opcode used for writing. + +// <0=> PP +// <1=> PP2O +// <2=> PP4O +// <3=> PP4IO + +#ifndef NRFX_QSPI_CONFIG_WRITEOC +#define NRFX_QSPI_CONFIG_WRITEOC 0 +#endif + +// NRFX_QSPI_CONFIG_ADDRMODE - Addressing mode. + +// <0=> 24bit +// <1=> 32bit + +#ifndef NRFX_QSPI_CONFIG_ADDRMODE +#define NRFX_QSPI_CONFIG_ADDRMODE 0 +#endif + +// NRFX_QSPI_CONFIG_MODE - SPI mode. + +// <0=> Mode 0 +// <1=> Mode 1 + +#ifndef NRFX_QSPI_CONFIG_MODE +#define NRFX_QSPI_CONFIG_MODE 0 +#endif + +// NRFX_QSPI_CONFIG_FREQUENCY - Frequency divider. + +// <0=> 32MHz/1 +// <1=> 32MHz/2 +// <2=> 32MHz/3 +// <3=> 32MHz/4 +// <4=> 32MHz/5 +// <5=> 32MHz/6 +// <6=> 32MHz/7 +// <7=> 32MHz/8 +// <8=> 32MHz/9 +// <9=> 32MHz/10 +// <10=> 32MHz/11 +// <11=> 32MHz/12 +// <12=> 32MHz/13 +// <13=> 32MHz/14 +// <14=> 32MHz/15 +// <15=> 32MHz/16 + +#ifndef NRFX_QSPI_CONFIG_FREQUENCY +#define NRFX_QSPI_CONFIG_FREQUENCY 15 +#endif + +// NRFX_QSPI_PIN_SCK - SCK pin value. +#ifndef NRFX_QSPI_PIN_SCK +#define NRFX_QSPI_PIN_SCK NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// NRFX_QSPI_PIN_CSN - CSN pin value. +#ifndef NRFX_QSPI_PIN_CSN +#define NRFX_QSPI_PIN_CSN NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// NRFX_QSPI_PIN_IO0 - IO0 pin value. +#ifndef NRFX_QSPI_PIN_IO0 +#define NRFX_QSPI_PIN_IO0 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// NRFX_QSPI_PIN_IO1 - IO1 pin value. +#ifndef NRFX_QSPI_PIN_IO1 +#define NRFX_QSPI_PIN_IO1 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// NRFX_QSPI_PIN_IO2 - IO2 pin value. +#ifndef NRFX_QSPI_PIN_IO2 +#define NRFX_QSPI_PIN_IO2 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// NRFX_QSPI_PIN_IO3 - IO3 pin value. +#ifndef NRFX_QSPI_PIN_IO3 +#define NRFX_QSPI_PIN_IO3 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// NRFX_QSPI_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_QSPI_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_QSPI_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// NRFX_RNG_ENABLED - nrfx_rng - RNG peripheral driver +//========================================================== +#ifndef NRFX_RNG_ENABLED +#define NRFX_RNG_ENABLED 0 +#endif +// NRFX_RNG_CONFIG_ERROR_CORRECTION - Error correction + + +#ifndef NRFX_RNG_CONFIG_ERROR_CORRECTION +#define NRFX_RNG_CONFIG_ERROR_CORRECTION 1 +#endif + +// NRFX_RNG_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_RNG_CONFIG_IRQ_PRIORITY +#define NRFX_RNG_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_RNG_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_RNG_CONFIG_LOG_ENABLED +#define NRFX_RNG_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_RNG_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_RNG_CONFIG_LOG_LEVEL +#define NRFX_RNG_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_RNG_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_RNG_CONFIG_INFO_COLOR +#define NRFX_RNG_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_RNG_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_RNG_CONFIG_DEBUG_COLOR +#define NRFX_RNG_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_RTC_ENABLED - nrfx_rtc - RTC peripheral driver +//========================================================== +#ifndef NRFX_RTC_ENABLED +#define NRFX_RTC_ENABLED 0 +#endif +// NRFX_RTC0_ENABLED - Enable RTC0 instance + + +#ifndef NRFX_RTC0_ENABLED +#define NRFX_RTC0_ENABLED 0 +#endif + +// NRFX_RTC1_ENABLED - Enable RTC1 instance + + +#ifndef NRFX_RTC1_ENABLED +#define NRFX_RTC1_ENABLED 0 +#endif + +// NRFX_RTC2_ENABLED - Enable RTC2 instance + + +#ifndef NRFX_RTC2_ENABLED +#define NRFX_RTC2_ENABLED 0 +#endif + +// NRFX_RTC_MAXIMUM_LATENCY_US - Maximum possible time[us] in highest priority interrupt +#ifndef NRFX_RTC_MAXIMUM_LATENCY_US +#define NRFX_RTC_MAXIMUM_LATENCY_US 2000 +#endif + +// NRFX_RTC_DEFAULT_CONFIG_FREQUENCY - Frequency <16-32768> + + +#ifndef NRFX_RTC_DEFAULT_CONFIG_FREQUENCY +#define NRFX_RTC_DEFAULT_CONFIG_FREQUENCY 32768 +#endif + +// NRFX_RTC_DEFAULT_CONFIG_RELIABLE - Ensures safe compare event triggering + + +#ifndef NRFX_RTC_DEFAULT_CONFIG_RELIABLE +#define NRFX_RTC_DEFAULT_CONFIG_RELIABLE 0 +#endif + +// NRFX_RTC_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_RTC_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_RTC_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_RTC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_RTC_CONFIG_LOG_ENABLED +#define NRFX_RTC_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_RTC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_RTC_CONFIG_LOG_LEVEL +#define NRFX_RTC_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_RTC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_RTC_CONFIG_INFO_COLOR +#define NRFX_RTC_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_RTC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_RTC_CONFIG_DEBUG_COLOR +#define NRFX_RTC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_SAADC_ENABLED - nrfx_saadc - SAADC peripheral driver +//========================================================== +#ifndef NRFX_SAADC_ENABLED +#define NRFX_SAADC_ENABLED 0 +#endif +// NRFX_SAADC_CONFIG_RESOLUTION - Resolution + +// <0=> 8 bit +// <1=> 10 bit +// <2=> 12 bit +// <3=> 14 bit + +#ifndef NRFX_SAADC_CONFIG_RESOLUTION +#define NRFX_SAADC_CONFIG_RESOLUTION 1 +#endif + +// NRFX_SAADC_CONFIG_OVERSAMPLE - Sample period + +// <0=> Disabled +// <1=> 2x +// <2=> 4x +// <3=> 8x +// <4=> 16x +// <5=> 32x +// <6=> 64x +// <7=> 128x +// <8=> 256x + +#ifndef NRFX_SAADC_CONFIG_OVERSAMPLE +#define NRFX_SAADC_CONFIG_OVERSAMPLE 0 +#endif + +// NRFX_SAADC_CONFIG_LP_MODE - Enabling low power mode + + +#ifndef NRFX_SAADC_CONFIG_LP_MODE +#define NRFX_SAADC_CONFIG_LP_MODE 0 +#endif + +// NRFX_SAADC_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_SAADC_CONFIG_IRQ_PRIORITY +#define NRFX_SAADC_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_SAADC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_SAADC_CONFIG_LOG_ENABLED +#define NRFX_SAADC_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_SAADC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_SAADC_CONFIG_LOG_LEVEL +#define NRFX_SAADC_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_SAADC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SAADC_CONFIG_INFO_COLOR +#define NRFX_SAADC_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_SAADC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SAADC_CONFIG_DEBUG_COLOR +#define NRFX_SAADC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_SPIM_ENABLED - nrfx_spim - SPIM peripheral driver +//========================================================== +#ifndef NRFX_SPIM_ENABLED +#define NRFX_SPIM_ENABLED 0 +#endif +// NRFX_SPIM0_ENABLED - Enable SPIM0 instance + + +#ifndef NRFX_SPIM0_ENABLED +#define NRFX_SPIM0_ENABLED 0 +#endif + +// NRFX_SPIM1_ENABLED - Enable SPIM1 instance + + +#ifndef NRFX_SPIM1_ENABLED +#define NRFX_SPIM1_ENABLED 0 +#endif + +// NRFX_SPIM2_ENABLED - Enable SPIM2 instance + + +#ifndef NRFX_SPIM2_ENABLED +#define NRFX_SPIM2_ENABLED 0 +#endif + +// NRFX_SPIM3_ENABLED - Enable SPIM3 instance + + +#ifndef NRFX_SPIM3_ENABLED +#define NRFX_SPIM3_ENABLED 0 +#endif + +// NRFX_SPIM_EXTENDED_ENABLED - Enable extended SPIM features + + +#ifndef NRFX_SPIM_EXTENDED_ENABLED +#define NRFX_SPIM_EXTENDED_ENABLED 0 +#endif + +// NRFX_SPIM_MISO_PULL_CFG - MISO pin pull configuration. + +// <0=> NRF_GPIO_PIN_NOPULL +// <1=> NRF_GPIO_PIN_PULLDOWN +// <3=> NRF_GPIO_PIN_PULLUP + +#ifndef NRFX_SPIM_MISO_PULL_CFG +#define NRFX_SPIM_MISO_PULL_CFG 1 +#endif + +// NRFX_SPIM_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_SPIM_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_SPIM_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_SPIM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_SPIM_CONFIG_LOG_ENABLED +#define NRFX_SPIM_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_SPIM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_SPIM_CONFIG_LOG_LEVEL +#define NRFX_SPIM_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_SPIM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SPIM_CONFIG_INFO_COLOR +#define NRFX_SPIM_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_SPIM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SPIM_CONFIG_DEBUG_COLOR +#define NRFX_SPIM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_SPIS_ENABLED - nrfx_spis - SPIS peripheral driver +//========================================================== +#ifndef NRFX_SPIS_ENABLED +#define NRFX_SPIS_ENABLED 0 +#endif +// NRFX_SPIS0_ENABLED - Enable SPIS0 instance + + +#ifndef NRFX_SPIS0_ENABLED +#define NRFX_SPIS0_ENABLED 0 +#endif + +// NRFX_SPIS1_ENABLED - Enable SPIS1 instance + + +#ifndef NRFX_SPIS1_ENABLED +#define NRFX_SPIS1_ENABLED 0 +#endif + +// NRFX_SPIS2_ENABLED - Enable SPIS2 instance + + +#ifndef NRFX_SPIS2_ENABLED +#define NRFX_SPIS2_ENABLED 0 +#endif + +// NRFX_SPIS_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_SPIS_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_SPIS_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_SPIS_DEFAULT_DEF - SPIS default DEF character <0-255> + + +#ifndef NRFX_SPIS_DEFAULT_DEF +#define NRFX_SPIS_DEFAULT_DEF 255 +#endif + +// NRFX_SPIS_DEFAULT_ORC - SPIS default ORC character <0-255> + + +#ifndef NRFX_SPIS_DEFAULT_ORC +#define NRFX_SPIS_DEFAULT_ORC 255 +#endif + +// NRFX_SPIS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_SPIS_CONFIG_LOG_ENABLED +#define NRFX_SPIS_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_SPIS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_SPIS_CONFIG_LOG_LEVEL +#define NRFX_SPIS_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_SPIS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SPIS_CONFIG_INFO_COLOR +#define NRFX_SPIS_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_SPIS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SPIS_CONFIG_DEBUG_COLOR +#define NRFX_SPIS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_SPI_ENABLED - nrfx_spi - SPI peripheral driver +//========================================================== +#ifndef NRFX_SPI_ENABLED +#define NRFX_SPI_ENABLED 0 +#endif +// NRFX_SPI0_ENABLED - Enable SPI0 instance + + +#ifndef NRFX_SPI0_ENABLED +#define NRFX_SPI0_ENABLED 0 +#endif + +// NRFX_SPI1_ENABLED - Enable SPI1 instance + + +#ifndef NRFX_SPI1_ENABLED +#define NRFX_SPI1_ENABLED 0 +#endif + +// NRFX_SPI2_ENABLED - Enable SPI2 instance + + +#ifndef NRFX_SPI2_ENABLED +#define NRFX_SPI2_ENABLED 0 +#endif + +// NRFX_SPI_MISO_PULL_CFG - MISO pin pull configuration. + +// <0=> NRF_GPIO_PIN_NOPULL +// <1=> NRF_GPIO_PIN_PULLDOWN +// <3=> NRF_GPIO_PIN_PULLUP + +#ifndef NRFX_SPI_MISO_PULL_CFG +#define NRFX_SPI_MISO_PULL_CFG 1 +#endif + +// NRFX_SPI_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_SPI_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_SPI_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_SPI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_SPI_CONFIG_LOG_ENABLED +#define NRFX_SPI_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_SPI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_SPI_CONFIG_LOG_LEVEL +#define NRFX_SPI_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_SPI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SPI_CONFIG_INFO_COLOR +#define NRFX_SPI_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_SPI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SPI_CONFIG_DEBUG_COLOR +#define NRFX_SPI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_SWI_ENABLED - nrfx_swi - SWI/EGU peripheral allocator +//========================================================== +#ifndef NRFX_SWI_ENABLED +#define NRFX_SWI_ENABLED 0 +#endif +// NRFX_EGU_ENABLED - Enable EGU support + + +#ifndef NRFX_EGU_ENABLED +#define NRFX_EGU_ENABLED 0 +#endif + +// NRFX_SWI0_DISABLED - Exclude SWI0 from being utilized by the driver + + +#ifndef NRFX_SWI0_DISABLED +#define NRFX_SWI0_DISABLED 0 +#endif + +// NRFX_SWI1_DISABLED - Exclude SWI1 from being utilized by the driver + + +#ifndef NRFX_SWI1_DISABLED +#define NRFX_SWI1_DISABLED 0 +#endif + +// NRFX_SWI2_DISABLED - Exclude SWI2 from being utilized by the driver + + +#ifndef NRFX_SWI2_DISABLED +#define NRFX_SWI2_DISABLED 0 +#endif + +// NRFX_SWI3_DISABLED - Exclude SWI3 from being utilized by the driver + + +#ifndef NRFX_SWI3_DISABLED +#define NRFX_SWI3_DISABLED 0 +#endif + +// NRFX_SWI4_DISABLED - Exclude SWI4 from being utilized by the driver + + +#ifndef NRFX_SWI4_DISABLED +#define NRFX_SWI4_DISABLED 0 +#endif + +// NRFX_SWI5_DISABLED - Exclude SWI5 from being utilized by the driver + + +#ifndef NRFX_SWI5_DISABLED +#define NRFX_SWI5_DISABLED 0 +#endif + +// NRFX_SWI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_SWI_CONFIG_LOG_ENABLED +#define NRFX_SWI_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_SWI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_SWI_CONFIG_LOG_LEVEL +#define NRFX_SWI_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_SWI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SWI_CONFIG_INFO_COLOR +#define NRFX_SWI_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_SWI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_SWI_CONFIG_DEBUG_COLOR +#define NRFX_SWI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_TIMER_ENABLED - nrfx_timer - TIMER periperal driver +//========================================================== +#ifndef NRFX_TIMER_ENABLED +#define NRFX_TIMER_ENABLED 0 +#endif +// NRFX_TIMER0_ENABLED - Enable TIMER0 instance + + +#ifndef NRFX_TIMER0_ENABLED +#define NRFX_TIMER0_ENABLED 0 +#endif + +// NRFX_TIMER1_ENABLED - Enable TIMER1 instance + + +#ifndef NRFX_TIMER1_ENABLED +#define NRFX_TIMER1_ENABLED 0 +#endif + +// NRFX_TIMER2_ENABLED - Enable TIMER2 instance + + +#ifndef NRFX_TIMER2_ENABLED +#define NRFX_TIMER2_ENABLED 0 +#endif + +// NRFX_TIMER3_ENABLED - Enable TIMER3 instance + + +#ifndef NRFX_TIMER3_ENABLED +#define NRFX_TIMER3_ENABLED 0 +#endif + +// NRFX_TIMER4_ENABLED - Enable TIMER4 instance + + +#ifndef NRFX_TIMER4_ENABLED +#define NRFX_TIMER4_ENABLED 0 +#endif + +// NRFX_TIMER_DEFAULT_CONFIG_FREQUENCY - Timer frequency if in Timer mode + +// <0=> 16 MHz +// <1=> 8 MHz +// <2=> 4 MHz +// <3=> 2 MHz +// <4=> 1 MHz +// <5=> 500 kHz +// <6=> 250 kHz +// <7=> 125 kHz +// <8=> 62.5 kHz +// <9=> 31.25 kHz + +#ifndef NRFX_TIMER_DEFAULT_CONFIG_FREQUENCY +#define NRFX_TIMER_DEFAULT_CONFIG_FREQUENCY 0 +#endif + +// NRFX_TIMER_DEFAULT_CONFIG_MODE - Timer mode or operation + +// <0=> Timer +// <1=> Counter + +#ifndef NRFX_TIMER_DEFAULT_CONFIG_MODE +#define NRFX_TIMER_DEFAULT_CONFIG_MODE 0 +#endif + +// NRFX_TIMER_DEFAULT_CONFIG_BIT_WIDTH - Timer counter bit width + +// <0=> 16 bit +// <1=> 8 bit +// <2=> 24 bit +// <3=> 32 bit + +#ifndef NRFX_TIMER_DEFAULT_CONFIG_BIT_WIDTH +#define NRFX_TIMER_DEFAULT_CONFIG_BIT_WIDTH 0 +#endif + +// NRFX_TIMER_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_TIMER_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_TIMER_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_TIMER_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_TIMER_CONFIG_LOG_ENABLED +#define NRFX_TIMER_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_TIMER_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_TIMER_CONFIG_LOG_LEVEL +#define NRFX_TIMER_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_TIMER_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TIMER_CONFIG_INFO_COLOR +#define NRFX_TIMER_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_TIMER_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TIMER_CONFIG_DEBUG_COLOR +#define NRFX_TIMER_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_TWIM_ENABLED - nrfx_twim - TWIM peripheral driver +//========================================================== +#ifndef NRFX_TWIM_ENABLED +#define NRFX_TWIM_ENABLED 0 +#endif +// NRFX_TWIM0_ENABLED - Enable TWIM0 instance + + +#ifndef NRFX_TWIM0_ENABLED +#define NRFX_TWIM0_ENABLED 0 +#endif + +// NRFX_TWIM1_ENABLED - Enable TWIM1 instance + + +#ifndef NRFX_TWIM1_ENABLED +#define NRFX_TWIM1_ENABLED 0 +#endif + +// NRFX_TWIM_DEFAULT_CONFIG_FREQUENCY - Frequency + +// <26738688=> 100k +// <67108864=> 250k +// <104857600=> 400k + +#ifndef NRFX_TWIM_DEFAULT_CONFIG_FREQUENCY +#define NRFX_TWIM_DEFAULT_CONFIG_FREQUENCY 26738688 +#endif + +// NRFX_TWIM_DEFAULT_CONFIG_HOLD_BUS_UNINIT - Enables bus holding after uninit + + +#ifndef NRFX_TWIM_DEFAULT_CONFIG_HOLD_BUS_UNINIT +#define NRFX_TWIM_DEFAULT_CONFIG_HOLD_BUS_UNINIT 0 +#endif + +// NRFX_TWIM_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_TWIM_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_TWIM_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_TWIM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_TWIM_CONFIG_LOG_ENABLED +#define NRFX_TWIM_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_TWIM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_TWIM_CONFIG_LOG_LEVEL +#define NRFX_TWIM_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_TWIM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TWIM_CONFIG_INFO_COLOR +#define NRFX_TWIM_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_TWIM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TWIM_CONFIG_DEBUG_COLOR +#define NRFX_TWIM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_TWIS_ENABLED - nrfx_twis - TWIS peripheral driver +//========================================================== +#ifndef NRFX_TWIS_ENABLED +#define NRFX_TWIS_ENABLED 0 +#endif +// NRFX_TWIS0_ENABLED - Enable TWIS0 instance + + +#ifndef NRFX_TWIS0_ENABLED +#define NRFX_TWIS0_ENABLED 0 +#endif + +// NRFX_TWIS1_ENABLED - Enable TWIS1 instance + + +#ifndef NRFX_TWIS1_ENABLED +#define NRFX_TWIS1_ENABLED 0 +#endif + +// NRFX_TWIS_ASSUME_INIT_AFTER_RESET_ONLY - Assume that any instance would be initialized only once + + +// Optimization flag. Registers used by TWIS are shared by other peripherals. Normally, during initialization driver tries to clear all registers to known state before doing the initialization itself. This gives initialization safe procedure, no matter when it would be called. If you activate TWIS only once and do never uninitialize it - set this flag to 1 what gives more optimal code. + +#ifndef NRFX_TWIS_ASSUME_INIT_AFTER_RESET_ONLY +#define NRFX_TWIS_ASSUME_INIT_AFTER_RESET_ONLY 0 +#endif + +// NRFX_TWIS_NO_SYNC_MODE - Remove support for synchronous mode + + +// Synchronous mode would be used in specific situations. And it uses some additional code and data memory to safely process state machine by polling it in status functions. If this functionality is not required it may be disabled to free some resources. + +#ifndef NRFX_TWIS_NO_SYNC_MODE +#define NRFX_TWIS_NO_SYNC_MODE 0 +#endif + +// NRFX_TWIS_DEFAULT_CONFIG_ADDR0 - Address0 +#ifndef NRFX_TWIS_DEFAULT_CONFIG_ADDR0 +#define NRFX_TWIS_DEFAULT_CONFIG_ADDR0 0 +#endif + +// NRFX_TWIS_DEFAULT_CONFIG_ADDR1 - Address1 +#ifndef NRFX_TWIS_DEFAULT_CONFIG_ADDR1 +#define NRFX_TWIS_DEFAULT_CONFIG_ADDR1 0 +#endif + +// NRFX_TWIS_DEFAULT_CONFIG_SCL_PULL - SCL pin pull configuration + +// <0=> Disabled +// <1=> Pull down +// <3=> Pull up + +#ifndef NRFX_TWIS_DEFAULT_CONFIG_SCL_PULL +#define NRFX_TWIS_DEFAULT_CONFIG_SCL_PULL 0 +#endif + +// NRFX_TWIS_DEFAULT_CONFIG_SDA_PULL - SDA pin pull configuration + +// <0=> Disabled +// <1=> Pull down +// <3=> Pull up + +#ifndef NRFX_TWIS_DEFAULT_CONFIG_SDA_PULL +#define NRFX_TWIS_DEFAULT_CONFIG_SDA_PULL 0 +#endif + +// NRFX_TWIS_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_TWIS_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_TWIS_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_TWIS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_TWIS_CONFIG_LOG_ENABLED +#define NRFX_TWIS_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_TWIS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_TWIS_CONFIG_LOG_LEVEL +#define NRFX_TWIS_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_TWIS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TWIS_CONFIG_INFO_COLOR +#define NRFX_TWIS_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_TWIS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TWIS_CONFIG_DEBUG_COLOR +#define NRFX_TWIS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_TWI_ENABLED - nrfx_twi - TWI peripheral driver +//========================================================== +#ifndef NRFX_TWI_ENABLED +#define NRFX_TWI_ENABLED 0 +#endif +// NRFX_TWI0_ENABLED - Enable TWI0 instance + + +#ifndef NRFX_TWI0_ENABLED +#define NRFX_TWI0_ENABLED 0 +#endif + +// NRFX_TWI1_ENABLED - Enable TWI1 instance + + +#ifndef NRFX_TWI1_ENABLED +#define NRFX_TWI1_ENABLED 0 +#endif + +// NRFX_TWI_DEFAULT_CONFIG_FREQUENCY - Frequency + +// <26738688=> 100k +// <67108864=> 250k +// <104857600=> 400k + +#ifndef NRFX_TWI_DEFAULT_CONFIG_FREQUENCY +#define NRFX_TWI_DEFAULT_CONFIG_FREQUENCY 26738688 +#endif + +// NRFX_TWI_DEFAULT_CONFIG_HOLD_BUS_UNINIT - Enables bus holding after uninit + + +#ifndef NRFX_TWI_DEFAULT_CONFIG_HOLD_BUS_UNINIT +#define NRFX_TWI_DEFAULT_CONFIG_HOLD_BUS_UNINIT 0 +#endif + +// NRFX_TWI_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_TWI_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_TWI_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_TWI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_TWI_CONFIG_LOG_ENABLED +#define NRFX_TWI_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_TWI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_TWI_CONFIG_LOG_LEVEL +#define NRFX_TWI_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_TWI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TWI_CONFIG_INFO_COLOR +#define NRFX_TWI_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_TWI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_TWI_CONFIG_DEBUG_COLOR +#define NRFX_TWI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_UARTE_ENABLED - nrfx_uarte - UARTE peripheral driver +//========================================================== +#ifndef NRFX_UARTE_ENABLED +#define NRFX_UARTE_ENABLED 0 +#endif +// NRFX_UARTE0_ENABLED - Enable UARTE0 instance +#ifndef NRFX_UARTE0_ENABLED +#define NRFX_UARTE0_ENABLED 0 +#endif + +// NRFX_UARTE1_ENABLED - Enable UARTE1 instance +#ifndef NRFX_UARTE1_ENABLED +#define NRFX_UARTE1_ENABLED 0 +#endif + +// NRFX_UARTE_DEFAULT_CONFIG_HWFC - Hardware Flow Control + +// <0=> Disabled +// <1=> Enabled + +#ifndef NRFX_UARTE_DEFAULT_CONFIG_HWFC +#define NRFX_UARTE_DEFAULT_CONFIG_HWFC 0 +#endif + +// NRFX_UARTE_DEFAULT_CONFIG_PARITY - Parity + +// <0=> Excluded +// <14=> Included + +#ifndef NRFX_UARTE_DEFAULT_CONFIG_PARITY +#define NRFX_UARTE_DEFAULT_CONFIG_PARITY 0 +#endif + +// NRFX_UARTE_DEFAULT_CONFIG_BAUDRATE - Default Baudrate + +// <323584=> 1200 baud +// <643072=> 2400 baud +// <1290240=> 4800 baud +// <2576384=> 9600 baud +// <3862528=> 14400 baud +// <5152768=> 19200 baud +// <7716864=> 28800 baud +// <8388608=> 31250 baud +// <10289152=> 38400 baud +// <15007744=> 56000 baud +// <15400960=> 57600 baud +// <20615168=> 76800 baud +// <30801920=> 115200 baud +// <61865984=> 230400 baud +// <67108864=> 250000 baud +// <121634816=> 460800 baud +// <251658240=> 921600 baud +// <268435456=> 1000000 baud + +#ifndef NRFX_UARTE_DEFAULT_CONFIG_BAUDRATE +#define NRFX_UARTE_DEFAULT_CONFIG_BAUDRATE 30801920 +#endif + +// NRFX_UARTE_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_UARTE_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_UARTE_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_UARTE_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_UARTE_CONFIG_LOG_ENABLED +#define NRFX_UARTE_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_UARTE_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_UARTE_CONFIG_LOG_LEVEL +#define NRFX_UARTE_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_UARTE_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_UARTE_CONFIG_INFO_COLOR +#define NRFX_UARTE_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_UARTE_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_UARTE_CONFIG_DEBUG_COLOR +#define NRFX_UARTE_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_UART_ENABLED - nrfx_uart - UART peripheral driver +//========================================================== +#ifndef NRFX_UART_ENABLED +#define NRFX_UART_ENABLED 0 +#endif +// NRFX_UART0_ENABLED - Enable UART0 instance +#ifndef NRFX_UART0_ENABLED +#define NRFX_UART0_ENABLED 0 +#endif + +// NRFX_UART_DEFAULT_CONFIG_HWFC - Hardware Flow Control + +// <0=> Disabled +// <1=> Enabled + +#ifndef NRFX_UART_DEFAULT_CONFIG_HWFC +#define NRFX_UART_DEFAULT_CONFIG_HWFC 0 +#endif + +// NRFX_UART_DEFAULT_CONFIG_PARITY - Parity + +// <0=> Excluded +// <14=> Included + +#ifndef NRFX_UART_DEFAULT_CONFIG_PARITY +#define NRFX_UART_DEFAULT_CONFIG_PARITY 0 +#endif + +// NRFX_UART_DEFAULT_CONFIG_BAUDRATE - Default Baudrate + +// <323584=> 1200 baud +// <643072=> 2400 baud +// <1290240=> 4800 baud +// <2576384=> 9600 baud +// <3866624=> 14400 baud +// <5152768=> 19200 baud +// <7729152=> 28800 baud +// <8388608=> 31250 baud +// <10309632=> 38400 baud +// <15007744=> 56000 baud +// <15462400=> 57600 baud +// <20615168=> 76800 baud +// <30924800=> 115200 baud +// <61845504=> 230400 baud +// <67108864=> 250000 baud +// <123695104=> 460800 baud +// <247386112=> 921600 baud +// <268435456=> 1000000 baud + +#ifndef NRFX_UART_DEFAULT_CONFIG_BAUDRATE +#define NRFX_UART_DEFAULT_CONFIG_BAUDRATE 30924800 +#endif + +// NRFX_UART_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_UART_DEFAULT_CONFIG_IRQ_PRIORITY +#define NRFX_UART_DEFAULT_CONFIG_IRQ_PRIORITY 4 +#endif + +// NRFX_UART_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_UART_CONFIG_LOG_ENABLED +#define NRFX_UART_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_UART_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_UART_CONFIG_LOG_LEVEL +#define NRFX_UART_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_UART_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_UART_CONFIG_INFO_COLOR +#define NRFX_UART_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_UART_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_UART_CONFIG_DEBUG_COLOR +#define NRFX_UART_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRFX_USBD_ENABLED - nrfx_usbd - USBD peripheral driver +//========================================================== +#ifndef NRFX_USBD_ENABLED +#define NRFX_USBD_ENABLED 0 +#endif +// NRFX_USBD_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_USBD_CONFIG_IRQ_PRIORITY +#define NRFX_USBD_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_USBD_CONFIG_DMASCHEDULER_MODE - USBD DMA scheduler working scheme + +// <0=> Prioritized access +// <1=> Round Robin + +#ifndef NRFX_USBD_CONFIG_DMASCHEDULER_MODE +#define NRFX_USBD_CONFIG_DMASCHEDULER_MODE 0 +#endif + +// NRFX_USBD_CONFIG_DMASCHEDULER_ISO_BOOST - Give priority to isochronous transfers + + +// This option gives priority to isochronous transfers. +// Enabling it assures that isochronous transfers are always processed, +// even if multiple other transfers are pending. +// Isochronous endpoints are prioritized before the usbd_dma_scheduler_algorithm +// function is called, so the option is independent of the algorithm chosen. + +#ifndef NRFX_USBD_CONFIG_DMASCHEDULER_ISO_BOOST +#define NRFX_USBD_CONFIG_DMASCHEDULER_ISO_BOOST 1 +#endif + +// NRFX_USBD_CONFIG_ISO_IN_ZLP - Respond to an IN token on ISO IN endpoint with ZLP when no data is ready + + +// If set, ISO IN endpoint will respond to an IN token with ZLP when no data is ready to be sent. +// Else, there will be no response. + +#ifndef NRFX_USBD_CONFIG_ISO_IN_ZLP +#define NRFX_USBD_CONFIG_ISO_IN_ZLP 0 +#endif + +// + +// NRFX_WDT_ENABLED - nrfx_wdt - WDT peripheral driver +//========================================================== +#ifndef NRFX_WDT_ENABLED +#define NRFX_WDT_ENABLED 0 +#endif +// NRFX_WDT_CONFIG_BEHAVIOUR - WDT behavior in CPU SLEEP or HALT mode + +// <1=> Run in SLEEP, Pause in HALT +// <8=> Pause in SLEEP, Run in HALT +// <9=> Run in SLEEP and HALT +// <0=> Pause in SLEEP and HALT + +#ifndef NRFX_WDT_CONFIG_BEHAVIOUR +#define NRFX_WDT_CONFIG_BEHAVIOUR 1 +#endif + +// NRFX_WDT_CONFIG_RELOAD_VALUE - Reload value <15-4294967295> + + +#ifndef NRFX_WDT_CONFIG_RELOAD_VALUE +#define NRFX_WDT_CONFIG_RELOAD_VALUE 2000 +#endif + +// NRFX_WDT_CONFIG_NO_IRQ - Remove WDT IRQ handling from WDT driver + +// <0=> Include WDT IRQ handling +// <1=> Remove WDT IRQ handling + +#ifndef NRFX_WDT_CONFIG_NO_IRQ +#define NRFX_WDT_CONFIG_NO_IRQ 0 +#endif + +// NRFX_WDT_CONFIG_IRQ_PRIORITY - Interrupt priority + +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef NRFX_WDT_CONFIG_IRQ_PRIORITY +#define NRFX_WDT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRFX_WDT_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRFX_WDT_CONFIG_LOG_ENABLED +#define NRFX_WDT_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_WDT_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_WDT_CONFIG_LOG_LEVEL +#define NRFX_WDT_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_WDT_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_WDT_CONFIG_INFO_COLOR +#define NRFX_WDT_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_WDT_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_WDT_CONFIG_DEBUG_COLOR +#define NRFX_WDT_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// + +// NRF_CLOCK_ENABLED - nrf_drv_clock - CLOCK peripheral driver - legacy layer +//========================================================== +#ifndef NRF_CLOCK_ENABLED +#define NRF_CLOCK_ENABLED 0 +#endif +// CLOCK_CONFIG_LF_SRC - LF Clock Source + +// <0=> RC +// <1=> XTAL +// <2=> Synth +// <131073=> External Low Swing +// <196609=> External Full Swing + +#ifndef CLOCK_CONFIG_LF_SRC +#define CLOCK_CONFIG_LF_SRC 1 +#endif + +// CLOCK_CONFIG_LF_CAL_ENABLED - Calibration enable for LF Clock Source + + +#ifndef CLOCK_CONFIG_LF_CAL_ENABLED +#define CLOCK_CONFIG_LF_CAL_ENABLED 0 +#endif + +// CLOCK_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef CLOCK_CONFIG_IRQ_PRIORITY +#define CLOCK_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// PDM_ENABLED - nrf_drv_pdm - PDM peripheral driver - legacy layer +//========================================================== +#ifndef PDM_ENABLED +#define PDM_ENABLED 0 +#endif +// PDM_CONFIG_MODE - Mode + +// <0=> Stereo +// <1=> Mono + +#ifndef PDM_CONFIG_MODE +#define PDM_CONFIG_MODE 1 +#endif + +// PDM_CONFIG_EDGE - Edge + +// <0=> Left falling +// <1=> Left rising + +#ifndef PDM_CONFIG_EDGE +#define PDM_CONFIG_EDGE 0 +#endif + +// PDM_CONFIG_CLOCK_FREQ - Clock frequency + +// <134217728=> 1000k +// <138412032=> 1032k (default) +// <142606336=> 1067k + +#ifndef PDM_CONFIG_CLOCK_FREQ +#define PDM_CONFIG_CLOCK_FREQ 138412032 +#endif + +// PDM_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef PDM_CONFIG_IRQ_PRIORITY +#define PDM_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// POWER_ENABLED - nrf_drv_power - POWER peripheral driver - legacy layer +//========================================================== +#ifndef POWER_ENABLED +#define POWER_ENABLED 0 +#endif +// POWER_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef POWER_CONFIG_IRQ_PRIORITY +#define POWER_CONFIG_IRQ_PRIORITY 6 +#endif + +// POWER_CONFIG_DEFAULT_DCDCEN - The default configuration of main DCDC regulator + + +// This settings means only that components for DCDC regulator are installed and it can be enabled. + +#ifndef POWER_CONFIG_DEFAULT_DCDCEN +#define POWER_CONFIG_DEFAULT_DCDCEN 0 +#endif + +// POWER_CONFIG_DEFAULT_DCDCENHV - The default configuration of High Voltage DCDC regulator + + +// This settings means only that components for DCDC regulator are installed and it can be enabled. + +#ifndef POWER_CONFIG_DEFAULT_DCDCENHV +#define POWER_CONFIG_DEFAULT_DCDCENHV 0 +#endif + +// + +// PPI_ENABLED - nrf_drv_ppi - PPI peripheral driver - legacy layer + + +#ifndef PPI_ENABLED +#define PPI_ENABLED 0 +#endif + +// PWM_ENABLED - nrf_drv_pwm - PWM peripheral driver - legacy layer +//========================================================== +#ifndef PWM_ENABLED +#define PWM_ENABLED 0 +#endif +// PWM_DEFAULT_CONFIG_OUT0_PIN - Out0 pin <0-31> + + +#ifndef PWM_DEFAULT_CONFIG_OUT0_PIN +#define PWM_DEFAULT_CONFIG_OUT0_PIN 31 +#endif + +// PWM_DEFAULT_CONFIG_OUT1_PIN - Out1 pin <0-31> + + +#ifndef PWM_DEFAULT_CONFIG_OUT1_PIN +#define PWM_DEFAULT_CONFIG_OUT1_PIN 31 +#endif + +// PWM_DEFAULT_CONFIG_OUT2_PIN - Out2 pin <0-31> + + +#ifndef PWM_DEFAULT_CONFIG_OUT2_PIN +#define PWM_DEFAULT_CONFIG_OUT2_PIN 31 +#endif + +// PWM_DEFAULT_CONFIG_OUT3_PIN - Out3 pin <0-31> + + +#ifndef PWM_DEFAULT_CONFIG_OUT3_PIN +#define PWM_DEFAULT_CONFIG_OUT3_PIN 31 +#endif + +// PWM_DEFAULT_CONFIG_BASE_CLOCK - Base clock + +// <0=> 16 MHz +// <1=> 8 MHz +// <2=> 4 MHz +// <3=> 2 MHz +// <4=> 1 MHz +// <5=> 500 kHz +// <6=> 250 kHz +// <7=> 125 kHz + +#ifndef PWM_DEFAULT_CONFIG_BASE_CLOCK +#define PWM_DEFAULT_CONFIG_BASE_CLOCK 4 +#endif + +// PWM_DEFAULT_CONFIG_COUNT_MODE - Count mode + +// <0=> Up +// <1=> Up and Down + +#ifndef PWM_DEFAULT_CONFIG_COUNT_MODE +#define PWM_DEFAULT_CONFIG_COUNT_MODE 0 +#endif + +// PWM_DEFAULT_CONFIG_TOP_VALUE - Top value +#ifndef PWM_DEFAULT_CONFIG_TOP_VALUE +#define PWM_DEFAULT_CONFIG_TOP_VALUE 1000 +#endif + +// PWM_DEFAULT_CONFIG_LOAD_MODE - Load mode + +// <0=> Common +// <1=> Grouped +// <2=> Individual +// <3=> Waveform + +#ifndef PWM_DEFAULT_CONFIG_LOAD_MODE +#define PWM_DEFAULT_CONFIG_LOAD_MODE 0 +#endif + +// PWM_DEFAULT_CONFIG_STEP_MODE - Step mode + +// <0=> Auto +// <1=> Triggered + +#ifndef PWM_DEFAULT_CONFIG_STEP_MODE +#define PWM_DEFAULT_CONFIG_STEP_MODE 0 +#endif + +// PWM_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef PWM_DEFAULT_CONFIG_IRQ_PRIORITY +#define PWM_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// PWM0_ENABLED - Enable PWM0 instance + + +#ifndef PWM0_ENABLED +#define PWM0_ENABLED 0 +#endif + +// PWM1_ENABLED - Enable PWM1 instance + + +#ifndef PWM1_ENABLED +#define PWM1_ENABLED 0 +#endif + +// PWM2_ENABLED - Enable PWM2 instance + + +#ifndef PWM2_ENABLED +#define PWM2_ENABLED 0 +#endif + +// PWM3_ENABLED - Enable PWM3 instance + + +#ifndef PWM3_ENABLED +#define PWM3_ENABLED 0 +#endif + +// + +// QDEC_ENABLED - nrf_drv_qdec - QDEC peripheral driver - legacy layer +//========================================================== +#ifndef QDEC_ENABLED +#define QDEC_ENABLED 0 +#endif +// QDEC_CONFIG_REPORTPER - Report period + +// <0=> 10 Samples +// <1=> 40 Samples +// <2=> 80 Samples +// <3=> 120 Samples +// <4=> 160 Samples +// <5=> 200 Samples +// <6=> 240 Samples +// <7=> 280 Samples + +#ifndef QDEC_CONFIG_REPORTPER +#define QDEC_CONFIG_REPORTPER 0 +#endif + +// QDEC_CONFIG_SAMPLEPER - Sample period + +// <0=> 128 us +// <1=> 256 us +// <2=> 512 us +// <3=> 1024 us +// <4=> 2048 us +// <5=> 4096 us +// <6=> 8192 us +// <7=> 16384 us + +#ifndef QDEC_CONFIG_SAMPLEPER +#define QDEC_CONFIG_SAMPLEPER 7 +#endif + +// QDEC_CONFIG_PIO_A - A pin <0-31> + + +#ifndef QDEC_CONFIG_PIO_A +#define QDEC_CONFIG_PIO_A 31 +#endif + +// QDEC_CONFIG_PIO_B - B pin <0-31> + + +#ifndef QDEC_CONFIG_PIO_B +#define QDEC_CONFIG_PIO_B 31 +#endif + +// QDEC_CONFIG_PIO_LED - LED pin <0-31> + + +#ifndef QDEC_CONFIG_PIO_LED +#define QDEC_CONFIG_PIO_LED 31 +#endif + +// QDEC_CONFIG_LEDPRE - LED pre +#ifndef QDEC_CONFIG_LEDPRE +#define QDEC_CONFIG_LEDPRE 511 +#endif + +// QDEC_CONFIG_LEDPOL - LED polarity + +// <0=> Active low +// <1=> Active high + +#ifndef QDEC_CONFIG_LEDPOL +#define QDEC_CONFIG_LEDPOL 1 +#endif + +// QDEC_CONFIG_DBFEN - Debouncing enable + + +#ifndef QDEC_CONFIG_DBFEN +#define QDEC_CONFIG_DBFEN 0 +#endif + +// QDEC_CONFIG_SAMPLE_INTEN - Sample ready interrupt enable + + +#ifndef QDEC_CONFIG_SAMPLE_INTEN +#define QDEC_CONFIG_SAMPLE_INTEN 0 +#endif + +// QDEC_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef QDEC_CONFIG_IRQ_PRIORITY +#define QDEC_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// QSPI_ENABLED - nrf_drv_qspi - QSPI peripheral driver - legacy layer +//========================================================== +#ifndef QSPI_ENABLED +#define QSPI_ENABLED 0 +#endif +// QSPI_CONFIG_SCK_DELAY - tSHSL, tWHSL and tSHWL in number of 16 MHz periods (62.5 ns). <0-255> + + +#ifndef QSPI_CONFIG_SCK_DELAY +#define QSPI_CONFIG_SCK_DELAY 1 +#endif + +// QSPI_CONFIG_XIP_OFFSET - Address offset in the external memory for Execute in Place operation. +#ifndef QSPI_CONFIG_XIP_OFFSET +#define QSPI_CONFIG_XIP_OFFSET 0 +#endif + +// QSPI_CONFIG_READOC - Number of data lines and opcode used for reading. + +// <0=> FastRead +// <1=> Read2O +// <2=> Read2IO +// <3=> Read4O +// <4=> Read4IO + +#ifndef QSPI_CONFIG_READOC +#define QSPI_CONFIG_READOC 0 +#endif + +// QSPI_CONFIG_WRITEOC - Number of data lines and opcode used for writing. + +// <0=> PP +// <1=> PP2O +// <2=> PP4O +// <3=> PP4IO + +#ifndef QSPI_CONFIG_WRITEOC +#define QSPI_CONFIG_WRITEOC 0 +#endif + +// QSPI_CONFIG_ADDRMODE - Addressing mode. + +// <0=> 24bit +// <1=> 32bit + +#ifndef QSPI_CONFIG_ADDRMODE +#define QSPI_CONFIG_ADDRMODE 0 +#endif + +// QSPI_CONFIG_MODE - SPI mode. + +// <0=> Mode 0 +// <1=> Mode 1 + +#ifndef QSPI_CONFIG_MODE +#define QSPI_CONFIG_MODE 0 +#endif + +// QSPI_CONFIG_FREQUENCY - Frequency divider. + +// <0=> 32MHz/1 +// <1=> 32MHz/2 +// <2=> 32MHz/3 +// <3=> 32MHz/4 +// <4=> 32MHz/5 +// <5=> 32MHz/6 +// <6=> 32MHz/7 +// <7=> 32MHz/8 +// <8=> 32MHz/9 +// <9=> 32MHz/10 +// <10=> 32MHz/11 +// <11=> 32MHz/12 +// <12=> 32MHz/13 +// <13=> 32MHz/14 +// <14=> 32MHz/15 +// <15=> 32MHz/16 + +#ifndef QSPI_CONFIG_FREQUENCY +#define QSPI_CONFIG_FREQUENCY 15 +#endif + +// QSPI_PIN_SCK - SCK pin value. +#ifndef QSPI_PIN_SCK +#define QSPI_PIN_SCK NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// QSPI_PIN_CSN - CSN pin value. +#ifndef QSPI_PIN_CSN +#define QSPI_PIN_CSN NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// QSPI_PIN_IO0 - IO0 pin value. +#ifndef QSPI_PIN_IO0 +#define QSPI_PIN_IO0 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// QSPI_PIN_IO1 - IO1 pin value. +#ifndef QSPI_PIN_IO1 +#define QSPI_PIN_IO1 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// QSPI_PIN_IO2 - IO2 pin value. +#ifndef QSPI_PIN_IO2 +#define QSPI_PIN_IO2 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// QSPI_PIN_IO3 - IO3 pin value. +#ifndef QSPI_PIN_IO3 +#define QSPI_PIN_IO3 NRF_QSPI_PIN_NOT_CONNECTED +#endif + +// QSPI_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef QSPI_CONFIG_IRQ_PRIORITY +#define QSPI_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// RNG_ENABLED - nrf_drv_rng - RNG peripheral driver - legacy layer +//========================================================== +#ifndef RNG_ENABLED +#define RNG_ENABLED 0 +#endif +// RNG_CONFIG_ERROR_CORRECTION - Error correction + + +#ifndef RNG_CONFIG_ERROR_CORRECTION +#define RNG_CONFIG_ERROR_CORRECTION 1 +#endif + +// RNG_CONFIG_POOL_SIZE - Pool size +#ifndef RNG_CONFIG_POOL_SIZE +#define RNG_CONFIG_POOL_SIZE 64 +#endif + +// RNG_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef RNG_CONFIG_IRQ_PRIORITY +#define RNG_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// RTC_ENABLED - nrf_drv_rtc - RTC peripheral driver - legacy layer +//========================================================== +#ifndef RTC_ENABLED +#define RTC_ENABLED 0 +#endif +// RTC_DEFAULT_CONFIG_FREQUENCY - Frequency <16-32768> + + +#ifndef RTC_DEFAULT_CONFIG_FREQUENCY +#define RTC_DEFAULT_CONFIG_FREQUENCY 32768 +#endif + +// RTC_DEFAULT_CONFIG_RELIABLE - Ensures safe compare event triggering + + +#ifndef RTC_DEFAULT_CONFIG_RELIABLE +#define RTC_DEFAULT_CONFIG_RELIABLE 0 +#endif + +// RTC_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef RTC_DEFAULT_CONFIG_IRQ_PRIORITY +#define RTC_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// RTC0_ENABLED - Enable RTC0 instance + + +#ifndef RTC0_ENABLED +#define RTC0_ENABLED 0 +#endif + +// RTC1_ENABLED - Enable RTC1 instance + + +#ifndef RTC1_ENABLED +#define RTC1_ENABLED 0 +#endif + +// RTC2_ENABLED - Enable RTC2 instance + + +#ifndef RTC2_ENABLED +#define RTC2_ENABLED 0 +#endif + +// NRF_MAXIMUM_LATENCY_US - Maximum possible time[us] in highest priority interrupt +#ifndef NRF_MAXIMUM_LATENCY_US +#define NRF_MAXIMUM_LATENCY_US 2000 +#endif + +// + +// SAADC_ENABLED - nrf_drv_saadc - SAADC peripheral driver - legacy layer +//========================================================== +#ifndef SAADC_ENABLED +#define SAADC_ENABLED 0 +#endif +// SAADC_CONFIG_RESOLUTION - Resolution + +// <0=> 8 bit +// <1=> 10 bit +// <2=> 12 bit +// <3=> 14 bit + +#ifndef SAADC_CONFIG_RESOLUTION +#define SAADC_CONFIG_RESOLUTION 1 +#endif + +// SAADC_CONFIG_OVERSAMPLE - Sample period + +// <0=> Disabled +// <1=> 2x +// <2=> 4x +// <3=> 8x +// <4=> 16x +// <5=> 32x +// <6=> 64x +// <7=> 128x +// <8=> 256x + +#ifndef SAADC_CONFIG_OVERSAMPLE +#define SAADC_CONFIG_OVERSAMPLE 0 +#endif + +// SAADC_CONFIG_LP_MODE - Enabling low power mode + + +#ifndef SAADC_CONFIG_LP_MODE +#define SAADC_CONFIG_LP_MODE 0 +#endif + +// SAADC_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef SAADC_CONFIG_IRQ_PRIORITY +#define SAADC_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// SPIS_ENABLED - nrf_drv_spis - SPIS peripheral driver - legacy layer +//========================================================== +#ifndef SPIS_ENABLED +#define SPIS_ENABLED 0 +#endif +// SPIS_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef SPIS_DEFAULT_CONFIG_IRQ_PRIORITY +#define SPIS_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// SPIS_DEFAULT_MODE - Mode + +// <0=> MODE_0 +// <1=> MODE_1 +// <2=> MODE_2 +// <3=> MODE_3 + +#ifndef SPIS_DEFAULT_MODE +#define SPIS_DEFAULT_MODE 0 +#endif + +// SPIS_DEFAULT_BIT_ORDER - SPIS default bit order + +// <0=> MSB first +// <1=> LSB first + +#ifndef SPIS_DEFAULT_BIT_ORDER +#define SPIS_DEFAULT_BIT_ORDER 0 +#endif + +// SPIS_DEFAULT_DEF - SPIS default DEF character <0-255> + + +#ifndef SPIS_DEFAULT_DEF +#define SPIS_DEFAULT_DEF 255 +#endif + +// SPIS_DEFAULT_ORC - SPIS default ORC character <0-255> + + +#ifndef SPIS_DEFAULT_ORC +#define SPIS_DEFAULT_ORC 255 +#endif + +// SPIS0_ENABLED - Enable SPIS0 instance + + +#ifndef SPIS0_ENABLED +#define SPIS0_ENABLED 0 +#endif + +// SPIS1_ENABLED - Enable SPIS1 instance + + +#ifndef SPIS1_ENABLED +#define SPIS1_ENABLED 0 +#endif + +// SPIS2_ENABLED - Enable SPIS2 instance + + +#ifndef SPIS2_ENABLED +#define SPIS2_ENABLED 0 +#endif + +// + +// SPI_ENABLED - nrf_drv_spi - SPI/SPIM peripheral driver - legacy layer +//========================================================== +#ifndef SPI_ENABLED +#define SPI_ENABLED 0 +#endif +// SPI_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef SPI_DEFAULT_CONFIG_IRQ_PRIORITY +#define SPI_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// NRF_SPI_DRV_MISO_PULLUP_CFG - MISO PIN pull-up configuration. + +// <0=> NRF_GPIO_PIN_NOPULL +// <1=> NRF_GPIO_PIN_PULLDOWN +// <3=> NRF_GPIO_PIN_PULLUP + +#ifndef NRF_SPI_DRV_MISO_PULLUP_CFG +#define NRF_SPI_DRV_MISO_PULLUP_CFG 1 +#endif + +// SPI0_ENABLED - Enable SPI0 instance +//========================================================== +#ifndef SPI0_ENABLED +#define SPI0_ENABLED 0 +#endif +// SPI0_USE_EASY_DMA - Use EasyDMA + + +#ifndef SPI0_USE_EASY_DMA +#define SPI0_USE_EASY_DMA 1 +#endif + +// + +// SPI1_ENABLED - Enable SPI1 instance +//========================================================== +#ifndef SPI1_ENABLED +#define SPI1_ENABLED 0 +#endif +// SPI1_USE_EASY_DMA - Use EasyDMA + + +#ifndef SPI1_USE_EASY_DMA +#define SPI1_USE_EASY_DMA 1 +#endif + +// + +// SPI2_ENABLED - Enable SPI2 instance +//========================================================== +#ifndef SPI2_ENABLED +#define SPI2_ENABLED 0 +#endif +// SPI2_USE_EASY_DMA - Use EasyDMA + + +#ifndef SPI2_USE_EASY_DMA +#define SPI2_USE_EASY_DMA 1 +#endif + +// + +// + +// TIMER_ENABLED - nrf_drv_timer - TIMER periperal driver - legacy layer +//========================================================== +#ifndef TIMER_ENABLED +#define TIMER_ENABLED 0 +#endif +// TIMER_DEFAULT_CONFIG_FREQUENCY - Timer frequency if in Timer mode + +// <0=> 16 MHz +// <1=> 8 MHz +// <2=> 4 MHz +// <3=> 2 MHz +// <4=> 1 MHz +// <5=> 500 kHz +// <6=> 250 kHz +// <7=> 125 kHz +// <8=> 62.5 kHz +// <9=> 31.25 kHz + +#ifndef TIMER_DEFAULT_CONFIG_FREQUENCY +#define TIMER_DEFAULT_CONFIG_FREQUENCY 0 +#endif + +// TIMER_DEFAULT_CONFIG_MODE - Timer mode or operation + +// <0=> Timer +// <1=> Counter + +#ifndef TIMER_DEFAULT_CONFIG_MODE +#define TIMER_DEFAULT_CONFIG_MODE 0 +#endif + +// TIMER_DEFAULT_CONFIG_BIT_WIDTH - Timer counter bit width + +// <0=> 16 bit +// <1=> 8 bit +// <2=> 24 bit +// <3=> 32 bit + +#ifndef TIMER_DEFAULT_CONFIG_BIT_WIDTH +#define TIMER_DEFAULT_CONFIG_BIT_WIDTH 0 +#endif + +// TIMER_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef TIMER_DEFAULT_CONFIG_IRQ_PRIORITY +#define TIMER_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// TIMER0_ENABLED - Enable TIMER0 instance + + +#ifndef TIMER0_ENABLED +#define TIMER0_ENABLED 0 +#endif + +// TIMER1_ENABLED - Enable TIMER1 instance + + +#ifndef TIMER1_ENABLED +#define TIMER1_ENABLED 0 +#endif + +// TIMER2_ENABLED - Enable TIMER2 instance + + +#ifndef TIMER2_ENABLED +#define TIMER2_ENABLED 0 +#endif + +// TIMER3_ENABLED - Enable TIMER3 instance + + +#ifndef TIMER3_ENABLED +#define TIMER3_ENABLED 0 +#endif + +// TIMER4_ENABLED - Enable TIMER4 instance + + +#ifndef TIMER4_ENABLED +#define TIMER4_ENABLED 0 +#endif + +// + +// TWIS_ENABLED - nrf_drv_twis - TWIS peripheral driver - legacy layer +//========================================================== +#ifndef TWIS_ENABLED +#define TWIS_ENABLED 0 +#endif +// TWIS0_ENABLED - Enable TWIS0 instance + + +#ifndef TWIS0_ENABLED +#define TWIS0_ENABLED 0 +#endif + +// TWIS1_ENABLED - Enable TWIS1 instance + + +#ifndef TWIS1_ENABLED +#define TWIS1_ENABLED 0 +#endif + +// TWIS_ASSUME_INIT_AFTER_RESET_ONLY - Assume that any instance would be initialized only once + + +// Optimization flag. Registers used by TWIS are shared by other peripherals. Normally, during initialization driver tries to clear all registers to known state before doing the initialization itself. This gives initialization safe procedure, no matter when it would be called. If you activate TWIS only once and do never uninitialize it - set this flag to 1 what gives more optimal code. + +#ifndef TWIS_ASSUME_INIT_AFTER_RESET_ONLY +#define TWIS_ASSUME_INIT_AFTER_RESET_ONLY 0 +#endif + +// TWIS_NO_SYNC_MODE - Remove support for synchronous mode + + +// Synchronous mode would be used in specific situations. And it uses some additional code and data memory to safely process state machine by polling it in status functions. If this functionality is not required it may be disabled to free some resources. + +#ifndef TWIS_NO_SYNC_MODE +#define TWIS_NO_SYNC_MODE 0 +#endif + +// TWIS_DEFAULT_CONFIG_ADDR0 - Address0 +#ifndef TWIS_DEFAULT_CONFIG_ADDR0 +#define TWIS_DEFAULT_CONFIG_ADDR0 0 +#endif + +// TWIS_DEFAULT_CONFIG_ADDR1 - Address1 +#ifndef TWIS_DEFAULT_CONFIG_ADDR1 +#define TWIS_DEFAULT_CONFIG_ADDR1 0 +#endif + +// TWIS_DEFAULT_CONFIG_SCL_PULL - SCL pin pull configuration + +// <0=> Disabled +// <1=> Pull down +// <3=> Pull up + +#ifndef TWIS_DEFAULT_CONFIG_SCL_PULL +#define TWIS_DEFAULT_CONFIG_SCL_PULL 0 +#endif + +// TWIS_DEFAULT_CONFIG_SDA_PULL - SDA pin pull configuration + +// <0=> Disabled +// <1=> Pull down +// <3=> Pull up + +#ifndef TWIS_DEFAULT_CONFIG_SDA_PULL +#define TWIS_DEFAULT_CONFIG_SDA_PULL 0 +#endif + +// TWIS_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef TWIS_DEFAULT_CONFIG_IRQ_PRIORITY +#define TWIS_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// TWI_ENABLED - nrf_drv_twi - TWI/TWIM peripheral driver - legacy layer +//========================================================== +#ifndef TWI_ENABLED +#define TWI_ENABLED 0 +#endif +// TWI_DEFAULT_CONFIG_FREQUENCY - Frequency + +// <26738688=> 100k +// <67108864=> 250k +// <104857600=> 400k + +#ifndef TWI_DEFAULT_CONFIG_FREQUENCY +#define TWI_DEFAULT_CONFIG_FREQUENCY 26738688 +#endif + +// TWI_DEFAULT_CONFIG_CLR_BUS_INIT - Enables bus clearing procedure during init + + +#ifndef TWI_DEFAULT_CONFIG_CLR_BUS_INIT +#define TWI_DEFAULT_CONFIG_CLR_BUS_INIT 0 +#endif + +// TWI_DEFAULT_CONFIG_HOLD_BUS_UNINIT - Enables bus holding after uninit + + +#ifndef TWI_DEFAULT_CONFIG_HOLD_BUS_UNINIT +#define TWI_DEFAULT_CONFIG_HOLD_BUS_UNINIT 0 +#endif + +// TWI_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef TWI_DEFAULT_CONFIG_IRQ_PRIORITY +#define TWI_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// TWI0_ENABLED - Enable TWI0 instance +//========================================================== +#ifndef TWI0_ENABLED +#define TWI0_ENABLED 0 +#endif +// TWI0_USE_EASY_DMA - Use EasyDMA (if present) + + +#ifndef TWI0_USE_EASY_DMA +#define TWI0_USE_EASY_DMA 0 +#endif + +// + +// TWI1_ENABLED - Enable TWI1 instance +//========================================================== +#ifndef TWI1_ENABLED +#define TWI1_ENABLED 0 +#endif +// TWI1_USE_EASY_DMA - Use EasyDMA (if present) + + +#ifndef TWI1_USE_EASY_DMA +#define TWI1_USE_EASY_DMA 0 +#endif + +// + +// + +// UART_ENABLED - nrf_drv_uart - UART/UARTE peripheral driver - legacy layer +//========================================================== +#ifndef UART_ENABLED +#define UART_ENABLED 0 +#endif +// UART_DEFAULT_CONFIG_HWFC - Hardware Flow Control + +// <0=> Disabled +// <1=> Enabled + +#ifndef UART_DEFAULT_CONFIG_HWFC +#define UART_DEFAULT_CONFIG_HWFC 0 +#endif + +// UART_DEFAULT_CONFIG_PARITY - Parity + +// <0=> Excluded +// <14=> Included + +#ifndef UART_DEFAULT_CONFIG_PARITY +#define UART_DEFAULT_CONFIG_PARITY 0 +#endif + +// UART_DEFAULT_CONFIG_BAUDRATE - Default Baudrate + +// <323584=> 1200 baud +// <643072=> 2400 baud +// <1290240=> 4800 baud +// <2576384=> 9600 baud +// <3862528=> 14400 baud +// <5152768=> 19200 baud +// <7716864=> 28800 baud +// <10289152=> 38400 baud +// <15400960=> 57600 baud +// <20615168=> 76800 baud +// <30801920=> 115200 baud +// <61865984=> 230400 baud +// <67108864=> 250000 baud +// <121634816=> 460800 baud +// <251658240=> 921600 baud +// <268435456=> 1000000 baud + +#ifndef UART_DEFAULT_CONFIG_BAUDRATE +#define UART_DEFAULT_CONFIG_BAUDRATE 30801920 +#endif + +// UART_DEFAULT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef UART_DEFAULT_CONFIG_IRQ_PRIORITY +#define UART_DEFAULT_CONFIG_IRQ_PRIORITY 6 +#endif + +// UART_EASY_DMA_SUPPORT - Driver supporting EasyDMA + + +#ifndef UART_EASY_DMA_SUPPORT +#define UART_EASY_DMA_SUPPORT 1 +#endif + +// UART_LEGACY_SUPPORT - Driver supporting Legacy mode + + +#ifndef UART_LEGACY_SUPPORT +#define UART_LEGACY_SUPPORT 1 +#endif + +// UART0_ENABLED - Enable UART0 instance +//========================================================== +#ifndef UART0_ENABLED +#define UART0_ENABLED 0 +#endif +// UART0_CONFIG_USE_EASY_DMA - Default setting for using EasyDMA + + +#ifndef UART0_CONFIG_USE_EASY_DMA +#define UART0_CONFIG_USE_EASY_DMA 1 +#endif + +// + +// UART1_ENABLED - Enable UART1 instance +//========================================================== +#ifndef UART1_ENABLED +#define UART1_ENABLED 0 +#endif +// + +// + +// USBD_ENABLED - nrf_drv_usbd - Software Component +//========================================================== +#ifndef USBD_ENABLED +#define USBD_ENABLED 0 +#endif +// USBD_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef USBD_CONFIG_IRQ_PRIORITY +#define USBD_CONFIG_IRQ_PRIORITY 6 +#endif + +// USBD_CONFIG_DMASCHEDULER_MODE - USBD SMA scheduler working scheme + +// <0=> Prioritized access +// <1=> Round Robin + +#ifndef USBD_CONFIG_DMASCHEDULER_MODE +#define USBD_CONFIG_DMASCHEDULER_MODE 0 +#endif + +// USBD_CONFIG_DMASCHEDULER_ISO_BOOST - Give priority to isochronous transfers + + +// This option gives priority to isochronous transfers. +// Enabling it assures that isochronous transfers are always processed, +// even if multiple other transfers are pending. +// Isochronous endpoints are prioritized before the usbd_dma_scheduler_algorithm +// function is called, so the option is independent of the algorithm chosen. + +#ifndef USBD_CONFIG_DMASCHEDULER_ISO_BOOST +#define USBD_CONFIG_DMASCHEDULER_ISO_BOOST 1 +#endif + +// USBD_CONFIG_ISO_IN_ZLP - Respond to an IN token on ISO IN endpoint with ZLP when no data is ready + + +// If set, ISO IN endpoint will respond to an IN token with ZLP when no data is ready to be sent. +// Else, there will be no response. +// NOTE: This option does not work on Engineering A chip. + +#ifndef USBD_CONFIG_ISO_IN_ZLP +#define USBD_CONFIG_ISO_IN_ZLP 0 +#endif + +// + +// WDT_ENABLED - nrf_drv_wdt - WDT peripheral driver - legacy layer +//========================================================== +#ifndef WDT_ENABLED +#define WDT_ENABLED 0 +#endif +// WDT_CONFIG_BEHAVIOUR - WDT behavior in CPU SLEEP or HALT mode + +// <1=> Run in SLEEP, Pause in HALT +// <8=> Pause in SLEEP, Run in HALT +// <9=> Run in SLEEP and HALT +// <0=> Pause in SLEEP and HALT + +#ifndef WDT_CONFIG_BEHAVIOUR +#define WDT_CONFIG_BEHAVIOUR 1 +#endif + +// WDT_CONFIG_RELOAD_VALUE - Reload value <15-4294967295> + + +#ifndef WDT_CONFIG_RELOAD_VALUE +#define WDT_CONFIG_RELOAD_VALUE 2000 +#endif + +// WDT_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef WDT_CONFIG_IRQ_PRIORITY +#define WDT_CONFIG_IRQ_PRIORITY 6 +#endif + +// + +// +//========================================================== + +// nRF_Drivers_External + +//========================================================== +// NRF_TWI_SENSOR_ENABLED - nrf_twi_sensor - nRF TWI Sensor module + + +#ifndef NRF_TWI_SENSOR_ENABLED +#define NRF_TWI_SENSOR_ENABLED 0 +#endif + +// +//========================================================== + +// nRF_Libraries + +//========================================================== +// APP_GPIOTE_ENABLED - app_gpiote - GPIOTE events dispatcher + + +#ifndef APP_GPIOTE_ENABLED +#define APP_GPIOTE_ENABLED 0 +#endif + +// APP_PWM_ENABLED - app_pwm - PWM functionality + + +#ifndef APP_PWM_ENABLED +#define APP_PWM_ENABLED 0 +#endif + +// APP_SCHEDULER_ENABLED - app_scheduler - Events scheduler +//========================================================== +#ifndef APP_SCHEDULER_ENABLED +#define APP_SCHEDULER_ENABLED 0 +#endif +// APP_SCHEDULER_WITH_PAUSE - Enabling pause feature + + +#ifndef APP_SCHEDULER_WITH_PAUSE +#define APP_SCHEDULER_WITH_PAUSE 0 +#endif + +// APP_SCHEDULER_WITH_PROFILER - Enabling scheduler profiling + + +#ifndef APP_SCHEDULER_WITH_PROFILER +#define APP_SCHEDULER_WITH_PROFILER 0 +#endif + +// + +// APP_SDCARD_ENABLED - app_sdcard - SD/MMC card support using SPI +//========================================================== +#ifndef APP_SDCARD_ENABLED +#define APP_SDCARD_ENABLED 0 +#endif +// APP_SDCARD_SPI_INSTANCE - SPI instance used + +// <0=> 0 +// <1=> 1 +// <2=> 2 + +#ifndef APP_SDCARD_SPI_INSTANCE +#define APP_SDCARD_SPI_INSTANCE 0 +#endif + +// APP_SDCARD_FREQ_INIT - SPI frequency + +// <33554432=> 125 kHz +// <67108864=> 250 kHz +// <134217728=> 500 kHz +// <268435456=> 1 MHz +// <536870912=> 2 MHz +// <1073741824=> 4 MHz +// <2147483648=> 8 MHz + +#ifndef APP_SDCARD_FREQ_INIT +#define APP_SDCARD_FREQ_INIT 67108864 +#endif + +// APP_SDCARD_FREQ_DATA - SPI frequency + +// <33554432=> 125 kHz +// <67108864=> 250 kHz +// <134217728=> 500 kHz +// <268435456=> 1 MHz +// <536870912=> 2 MHz +// <1073741824=> 4 MHz +// <2147483648=> 8 MHz + +#ifndef APP_SDCARD_FREQ_DATA +#define APP_SDCARD_FREQ_DATA 1073741824 +#endif + +// + +// APP_TIMER_ENABLED - app_timer - Application timer functionality +//========================================================== +#ifndef APP_TIMER_ENABLED +#define APP_TIMER_ENABLED 0 +#endif +// APP_TIMER_CONFIG_RTC_FREQUENCY - Configure RTC prescaler. + +// <0=> 32768 Hz +// <1=> 16384 Hz +// <3=> 8192 Hz +// <7=> 4096 Hz +// <15=> 2048 Hz +// <31=> 1024 Hz + +#ifndef APP_TIMER_CONFIG_RTC_FREQUENCY +#define APP_TIMER_CONFIG_RTC_FREQUENCY 1 +#endif + +// APP_TIMER_CONFIG_IRQ_PRIORITY - Interrupt priority + + +// Priorities 0,2 (nRF51) and 0,1,4,5 (nRF52) are reserved for SoftDevice +// <0=> 0 (highest) +// <1=> 1 +// <2=> 2 +// <3=> 3 +// <4=> 4 +// <5=> 5 +// <6=> 6 +// <7=> 7 + +#ifndef APP_TIMER_CONFIG_IRQ_PRIORITY +#define APP_TIMER_CONFIG_IRQ_PRIORITY 6 +#endif + +// APP_TIMER_CONFIG_OP_QUEUE_SIZE - Capacity of timer requests queue. +// Size of the queue depends on how many timers are used +// in the system, how often timers are started and overall +// system latency. If queue size is too small app_timer calls +// will fail. + +#ifndef APP_TIMER_CONFIG_OP_QUEUE_SIZE +#define APP_TIMER_CONFIG_OP_QUEUE_SIZE 10 +#endif + +// APP_TIMER_CONFIG_USE_SCHEDULER - Enable scheduling app_timer events to app_scheduler + + +#ifndef APP_TIMER_CONFIG_USE_SCHEDULER +#define APP_TIMER_CONFIG_USE_SCHEDULER 0 +#endif + +// APP_TIMER_KEEPS_RTC_ACTIVE - Enable RTC always on + + +// If option is enabled RTC is kept running even if there is no active timers. +// This option can be used when app_timer is used for timestamping. + +#ifndef APP_TIMER_KEEPS_RTC_ACTIVE +#define APP_TIMER_KEEPS_RTC_ACTIVE 0 +#endif + +// APP_TIMER_SAFE_WINDOW_MS - Maximum possible latency (in milliseconds) of handling app_timer event. +// Maximum possible timeout that can be set is reduced by safe window. +// Example: RTC frequency 16384 Hz, maximum possible timeout 1024 seconds - APP_TIMER_SAFE_WINDOW_MS. +// Since RTC is not stopped when processor is halted in debugging session, this value +// must cover it if debugging is needed. It is possible to halt processor for APP_TIMER_SAFE_WINDOW_MS +// without corrupting app_timer behavior. + +#ifndef APP_TIMER_SAFE_WINDOW_MS +#define APP_TIMER_SAFE_WINDOW_MS 300000 +#endif + +// App Timer Legacy configuration - Legacy configuration. + +//========================================================== +// APP_TIMER_WITH_PROFILER - Enable app_timer profiling + + +#ifndef APP_TIMER_WITH_PROFILER +#define APP_TIMER_WITH_PROFILER 0 +#endif + +// APP_TIMER_CONFIG_SWI_NUMBER - Configure SWI instance used. + + +#ifndef APP_TIMER_CONFIG_SWI_NUMBER +#define APP_TIMER_CONFIG_SWI_NUMBER 0 +#endif + +// +//========================================================== + +// + +// APP_USBD_AUDIO_ENABLED - app_usbd_audio - USB AUDIO class + + +#ifndef APP_USBD_AUDIO_ENABLED +#define APP_USBD_AUDIO_ENABLED 0 +#endif + +// APP_USBD_ENABLED - app_usbd - USB Device library +//========================================================== +#ifndef APP_USBD_ENABLED +#define APP_USBD_ENABLED 0 +#endif +// APP_USBD_VID - Vendor ID. <0x0000-0xFFFF> + + +// Note: This value is not editable in Configuration Wizard. +// Vendor ID ordered from USB IF: http://www.usb.org/developers/vendor/ + +#ifndef APP_USBD_VID +#define APP_USBD_VID 0 +#endif + +// APP_USBD_PID - Product ID. <0x0000-0xFFFF> + + +// Note: This value is not editable in Configuration Wizard. +// Selected Product ID + +#ifndef APP_USBD_PID +#define APP_USBD_PID 0 +#endif + +// APP_USBD_DEVICE_VER_MAJOR - Major device version <0-99> + + +// Major device version, will be converted automatically to BCD notation. Use just decimal values. + +#ifndef APP_USBD_DEVICE_VER_MAJOR +#define APP_USBD_DEVICE_VER_MAJOR 1 +#endif + +// APP_USBD_DEVICE_VER_MINOR - Minor device version <0-9> + + +// Minor device version, will be converted automatically to BCD notation. Use just decimal values. + +#ifndef APP_USBD_DEVICE_VER_MINOR +#define APP_USBD_DEVICE_VER_MINOR 0 +#endif + +// APP_USBD_DEVICE_VER_SUB - Sub-minor device version <0-9> + + +// Sub-minor device version, will be converted automatically to BCD notation. Use just decimal values. + +#ifndef APP_USBD_DEVICE_VER_SUB +#define APP_USBD_DEVICE_VER_SUB 0 +#endif + +// APP_USBD_CONFIG_SELF_POWERED - Self-powered device, as opposed to bus-powered. + + +#ifndef APP_USBD_CONFIG_SELF_POWERED +#define APP_USBD_CONFIG_SELF_POWERED 1 +#endif + +// APP_USBD_CONFIG_MAX_POWER - MaxPower field in configuration descriptor in milliamps. <0-500> + + +#ifndef APP_USBD_CONFIG_MAX_POWER +#define APP_USBD_CONFIG_MAX_POWER 100 +#endif + +// APP_USBD_CONFIG_POWER_EVENTS_PROCESS - Process power events. + + +// Enable processing power events in USB event handler. + +#ifndef APP_USBD_CONFIG_POWER_EVENTS_PROCESS +#define APP_USBD_CONFIG_POWER_EVENTS_PROCESS 1 +#endif + +// APP_USBD_CONFIG_EVENT_QUEUE_ENABLE - Enable event queue. + +// This is the default configuration when all the events are placed into internal queue. +// Disable it when an external queue is used like app_scheduler or if you wish to process all events inside interrupts. +// Processing all events from the interrupt level adds requirement not to call any functions that modifies the USBD library state from the context higher than USB interrupt context. +// Functions that modify USBD state are functions for sleep, wakeup, start, stop, enable, and disable. +//========================================================== +#ifndef APP_USBD_CONFIG_EVENT_QUEUE_ENABLE +#define APP_USBD_CONFIG_EVENT_QUEUE_ENABLE 1 +#endif +// APP_USBD_CONFIG_EVENT_QUEUE_SIZE - The size of the event queue. <16-64> + + +// The size of the queue for the events that would be processed in the main loop. + +#ifndef APP_USBD_CONFIG_EVENT_QUEUE_SIZE +#define APP_USBD_CONFIG_EVENT_QUEUE_SIZE 32 +#endif + +// APP_USBD_CONFIG_SOF_HANDLING_MODE - Change SOF events handling mode. + + +// Normal queue - SOF events are pushed normally into the event queue. +// Compress queue - SOF events are counted and binded with other events or executed when the queue is empty. +// This prevents the queue from filling up with SOF events. +// Interrupt - SOF events are processed in interrupt. +// <0=> Normal queue +// <1=> Compress queue +// <2=> Interrupt + +#ifndef APP_USBD_CONFIG_SOF_HANDLING_MODE +#define APP_USBD_CONFIG_SOF_HANDLING_MODE 1 +#endif + +// + +// APP_USBD_CONFIG_SOF_TIMESTAMP_PROVIDE - Provide a function that generates timestamps for logs based on the current SOF. + + +// The function app_usbd_sof_timestamp_get is implemented if the logger is enabled. +// Use it when initializing the logger. +// SOF processing is always enabled when this configuration parameter is active. +// Note: This option is configured outside of APP_USBD_CONFIG_LOG_ENABLED. +// This means that it works even if the logging in this very module is disabled. + +#ifndef APP_USBD_CONFIG_SOF_TIMESTAMP_PROVIDE +#define APP_USBD_CONFIG_SOF_TIMESTAMP_PROVIDE 0 +#endif + +// APP_USBD_CONFIG_DESC_STRING_SIZE - Maximum size of the NULL-terminated string of the string descriptor. <31-254> + + +// 31 characters can be stored in the internal USB buffer used for transfers. +// Any value higher than 31 creates an additional buffer just for descriptor strings. + +#ifndef APP_USBD_CONFIG_DESC_STRING_SIZE +#define APP_USBD_CONFIG_DESC_STRING_SIZE 31 +#endif + +// APP_USBD_CONFIG_DESC_STRING_UTF_ENABLED - Enable UTF8 conversion. + + +// Enable UTF8-encoded characters. In normal processing, only ASCII characters are available. + +#ifndef APP_USBD_CONFIG_DESC_STRING_UTF_ENABLED +#define APP_USBD_CONFIG_DESC_STRING_UTF_ENABLED 0 +#endif + +// APP_USBD_STRINGS_LANGIDS - Supported languages identifiers. + +// Note: This value is not editable in Configuration Wizard. +// Comma-separated list of supported languages. +#ifndef APP_USBD_STRINGS_LANGIDS +#define APP_USBD_STRINGS_LANGIDS APP_USBD_LANG_AND_SUBLANG(APP_USBD_LANG_ENGLISH, APP_USBD_SUBLANG_ENGLISH_US) +#endif + +// APP_USBD_STRING_ID_MANUFACTURER - Define manufacturer string ID. + +// Setting ID to 0 disables the string. +//========================================================== +#ifndef APP_USBD_STRING_ID_MANUFACTURER +#define APP_USBD_STRING_ID_MANUFACTURER 1 +#endif +// APP_USBD_STRINGS_MANUFACTURER_EXTERN - Define whether @ref APP_USBD_STRINGS_MANUFACTURER is created by macro or declared as a global variable. + + +#ifndef APP_USBD_STRINGS_MANUFACTURER_EXTERN +#define APP_USBD_STRINGS_MANUFACTURER_EXTERN 0 +#endif + +// APP_USBD_STRINGS_MANUFACTURER - String descriptor for the manufacturer name. + +// Note: This value is not editable in Configuration Wizard. +// Comma-separated list of manufacturer names for each defined language. +// Use @ref APP_USBD_STRING_DESC macro to create string descriptor from a NULL-terminated string. +// Use @ref APP_USBD_STRING_RAW8_DESC macro to create string descriptor from comma-separated uint8_t values. +// Use @ref APP_USBD_STRING_RAW16_DESC macro to create string descriptor from comma-separated uint16_t values. +// Alternatively, configure the macro to point to any internal variable pointer that already contains the descriptor. +// Setting string to NULL disables that string. +// The order of manufacturer names must be the same like in @ref APP_USBD_STRINGS_LANGIDS. +#ifndef APP_USBD_STRINGS_MANUFACTURER +#define APP_USBD_STRINGS_MANUFACTURER APP_USBD_STRING_DESC("Nordic Semiconductor") +#endif + +// + +// APP_USBD_STRING_ID_PRODUCT - Define product string ID. + +// Setting ID to 0 disables the string. +//========================================================== +#ifndef APP_USBD_STRING_ID_PRODUCT +#define APP_USBD_STRING_ID_PRODUCT 2 +#endif +// APP_USBD_STRINGS_PRODUCT_EXTERN - Define whether @ref APP_USBD_STRINGS_PRODUCT is created by macro or declared as a global variable. + + +#ifndef APP_USBD_STRINGS_PRODUCT_EXTERN +#define APP_USBD_STRINGS_PRODUCT_EXTERN 0 +#endif + +// APP_USBD_STRINGS_PRODUCT - String descriptor for the product name. + +// Note: This value is not editable in Configuration Wizard. +// List of product names that is defined the same way like in @ref APP_USBD_STRINGS_MANUFACTURER. +#ifndef APP_USBD_STRINGS_PRODUCT +#define APP_USBD_STRINGS_PRODUCT APP_USBD_STRING_DESC("nRF52 USB Product") +#endif + +// + +// APP_USBD_STRING_ID_SERIAL - Define serial number string ID. + +// Setting ID to 0 disables the string. +//========================================================== +#ifndef APP_USBD_STRING_ID_SERIAL +#define APP_USBD_STRING_ID_SERIAL 3 +#endif +// APP_USBD_STRING_SERIAL_EXTERN - Define whether @ref APP_USBD_STRING_SERIAL is created by macro or declared as a global variable. + + +#ifndef APP_USBD_STRING_SERIAL_EXTERN +#define APP_USBD_STRING_SERIAL_EXTERN 0 +#endif + +// APP_USBD_STRING_SERIAL - String descriptor for the serial number. + +// Note: This value is not editable in Configuration Wizard. +// Serial number that is defined the same way like in @ref APP_USBD_STRINGS_MANUFACTURER. +#ifndef APP_USBD_STRING_SERIAL +#define APP_USBD_STRING_SERIAL APP_USBD_STRING_DESC("000000000000") +#endif + +// + +// APP_USBD_STRING_ID_CONFIGURATION - Define configuration string ID. + +// Setting ID to 0 disables the string. +//========================================================== +#ifndef APP_USBD_STRING_ID_CONFIGURATION +#define APP_USBD_STRING_ID_CONFIGURATION 4 +#endif +// APP_USBD_STRING_CONFIGURATION_EXTERN - Define whether @ref APP_USBD_STRINGS_CONFIGURATION is created by macro or declared as global variable. + + +#ifndef APP_USBD_STRING_CONFIGURATION_EXTERN +#define APP_USBD_STRING_CONFIGURATION_EXTERN 0 +#endif + +// APP_USBD_STRINGS_CONFIGURATION - String descriptor for the device configuration. + +// Note: This value is not editable in Configuration Wizard. +// Configuration string that is defined the same way like in @ref APP_USBD_STRINGS_MANUFACTURER. +#ifndef APP_USBD_STRINGS_CONFIGURATION +#define APP_USBD_STRINGS_CONFIGURATION APP_USBD_STRING_DESC("Default configuration") +#endif + +// + +// APP_USBD_STRINGS_USER - Default values for user strings. + +// Note: This value is not editable in Configuration Wizard. +// This value stores all application specific user strings with the default initialization. +// The setup is done by X-macros. +// Expected macro parameters: +// @code +// X(mnemonic, [=str_idx], ...) +// @endcode +// - @c mnemonic: Mnemonic of the string descriptor that would be added to +// @ref app_usbd_string_desc_idx_t enumerator. +// - @c str_idx : String index value, can be set or left empty. +// For example, WinUSB driver requires descriptor to be present on 0xEE index. +// Then use X(USBD_STRING_WINUSB, =0xEE, (APP_USBD_STRING_DESC(...))) +// - @c ... : List of string descriptors for each defined language. +#ifndef APP_USBD_STRINGS_USER +#define APP_USBD_STRINGS_USER X(APP_USER_1, , APP_USBD_STRING_DESC("User 1")) +#endif + +// + +// APP_USBD_HID_ENABLED - app_usbd_hid - USB HID class +//========================================================== +#ifndef APP_USBD_HID_ENABLED +#define APP_USBD_HID_ENABLED 0 +#endif +// APP_USBD_HID_DEFAULT_IDLE_RATE - Default idle rate for HID class. <0-255> + + +// 0 means indefinite duration, any other value is multiplied by 4 milliseconds. Refer to Chapter 7.2.4 of HID 1.11 Specification. + +#ifndef APP_USBD_HID_DEFAULT_IDLE_RATE +#define APP_USBD_HID_DEFAULT_IDLE_RATE 0 +#endif + +// APP_USBD_HID_REPORT_IDLE_TABLE_SIZE - Size of idle rate table. <1-255> + + +// Must be higher than the highest report ID used. + +#ifndef APP_USBD_HID_REPORT_IDLE_TABLE_SIZE +#define APP_USBD_HID_REPORT_IDLE_TABLE_SIZE 4 +#endif + +// + +// APP_USBD_HID_GENERIC_ENABLED - app_usbd_hid_generic - USB HID generic + + +#ifndef APP_USBD_HID_GENERIC_ENABLED +#define APP_USBD_HID_GENERIC_ENABLED 0 +#endif + +// APP_USBD_HID_KBD_ENABLED - app_usbd_hid_kbd - USB HID keyboard + + +#ifndef APP_USBD_HID_KBD_ENABLED +#define APP_USBD_HID_KBD_ENABLED 0 +#endif + +// APP_USBD_HID_MOUSE_ENABLED - app_usbd_hid_mouse - USB HID mouse + + +#ifndef APP_USBD_HID_MOUSE_ENABLED +#define APP_USBD_HID_MOUSE_ENABLED 0 +#endif + +// APP_USBD_MSC_ENABLED - app_usbd_msc - USB MSC class + + +#ifndef APP_USBD_MSC_ENABLED +#define APP_USBD_MSC_ENABLED 0 +#endif + +// CRC16_ENABLED - crc16 - CRC16 calculation routines + + +#ifndef CRC16_ENABLED +#define CRC16_ENABLED 0 +#endif + +// CRC32_ENABLED - crc32 - CRC32 calculation routines + + +#ifndef CRC32_ENABLED +#define CRC32_ENABLED 0 +#endif + +// ECC_ENABLED - ecc - Elliptic Curve Cryptography Library + + +#ifndef ECC_ENABLED +#define ECC_ENABLED 0 +#endif + +// FDS_ENABLED - fds - Flash data storage module +//========================================================== +#ifndef FDS_ENABLED +#define FDS_ENABLED 0 +#endif +// Pages - Virtual page settings + +// Configure the number of virtual pages to use and their size. +//========================================================== +// FDS_VIRTUAL_PAGES - Number of virtual flash pages to use. +// One of the virtual pages is reserved by the system for garbage collection. +// Therefore, the minimum is two virtual pages: one page to store data and one page to be used by the system for garbage collection. +// The total amount of flash memory that is used by FDS amounts to @ref FDS_VIRTUAL_PAGES * @ref FDS_VIRTUAL_PAGE_SIZE * 4 bytes. + +#ifndef FDS_VIRTUAL_PAGES +#define FDS_VIRTUAL_PAGES 3 +#endif + +// FDS_VIRTUAL_PAGE_SIZE - The size of a virtual flash page. + + +// Expressed in number of 4-byte words. +// By default, a virtual page is the same size as a physical page. +// The size of a virtual page must be a multiple of the size of a physical page. +// <1024=> 1024 +// <2048=> 2048 + +#ifndef FDS_VIRTUAL_PAGE_SIZE +#define FDS_VIRTUAL_PAGE_SIZE 1024 +#endif + +// FDS_VIRTUAL_PAGES_RESERVED - The number of virtual flash pages that are used by other modules. +// FDS module stores its data in the last pages of the flash memory. +// By setting this value, you can move flash end address used by the FDS. +// As a result the reserved space can be used by other modules. + +#ifndef FDS_VIRTUAL_PAGES_RESERVED +#define FDS_VIRTUAL_PAGES_RESERVED 0 +#endif + +// +//========================================================== + +// Backend - Backend configuration + +// Configure which nrf_fstorage backend is used by FDS to write to flash. +//========================================================== +// FDS_BACKEND - FDS flash backend. + + +// NRF_FSTORAGE_SD uses the nrf_fstorage_sd backend implementation using the SoftDevice API. Use this if you have a SoftDevice present. +// NRF_FSTORAGE_NVMC uses the nrf_fstorage_nvmc implementation. Use this setting if you don't use the SoftDevice. +// <1=> NRF_FSTORAGE_NVMC +// <2=> NRF_FSTORAGE_SD + +#ifndef FDS_BACKEND +#define FDS_BACKEND 2 +#endif + +// +//========================================================== + +// Queue - Queue settings + +//========================================================== +// FDS_OP_QUEUE_SIZE - Size of the internal queue. +// Increase this value if you frequently get synchronous FDS_ERR_NO_SPACE_IN_QUEUES errors. + +#ifndef FDS_OP_QUEUE_SIZE +#define FDS_OP_QUEUE_SIZE 4 +#endif + +// +//========================================================== + +// CRC - CRC functionality + +//========================================================== +// FDS_CRC_CHECK_ON_READ - Enable CRC checks. + +// Save a record's CRC when it is written to flash and check it when the record is opened. +// Records with an incorrect CRC can still be 'seen' by the user using FDS functions, but they cannot be opened. +// Additionally, they will not be garbage collected until they are deleted. +//========================================================== +#ifndef FDS_CRC_CHECK_ON_READ +#define FDS_CRC_CHECK_ON_READ 0 +#endif +// FDS_CRC_CHECK_ON_WRITE - Perform a CRC check on newly written records. + + +// Perform a CRC check on newly written records. +// This setting can be used to make sure that the record data was not altered while being written to flash. +// <1=> Enabled +// <0=> Disabled + +#ifndef FDS_CRC_CHECK_ON_WRITE +#define FDS_CRC_CHECK_ON_WRITE 0 +#endif + +// + +// +//========================================================== + +// Users - Number of users + +//========================================================== +// FDS_MAX_USERS - Maximum number of callbacks that can be registered. +#ifndef FDS_MAX_USERS +#define FDS_MAX_USERS 4 +#endif + +// +//========================================================== + +// + +// HARDFAULT_HANDLER_ENABLED - hardfault_default - HardFault default handler for debugging and release + + +#ifndef HARDFAULT_HANDLER_ENABLED +#define HARDFAULT_HANDLER_ENABLED 0 +#endif + +// HCI_MEM_POOL_ENABLED - hci_mem_pool - memory pool implementation used by HCI +//========================================================== +#ifndef HCI_MEM_POOL_ENABLED +#define HCI_MEM_POOL_ENABLED 0 +#endif +// HCI_TX_BUF_SIZE - TX buffer size in bytes. +#ifndef HCI_TX_BUF_SIZE +#define HCI_TX_BUF_SIZE 600 +#endif + +// HCI_RX_BUF_SIZE - RX buffer size in bytes. +#ifndef HCI_RX_BUF_SIZE +#define HCI_RX_BUF_SIZE 600 +#endif + +// HCI_RX_BUF_QUEUE_SIZE - RX buffer queue size. +#ifndef HCI_RX_BUF_QUEUE_SIZE +#define HCI_RX_BUF_QUEUE_SIZE 4 +#endif + +// + +// HCI_SLIP_ENABLED - hci_slip - SLIP protocol implementation used by HCI +//========================================================== +#ifndef HCI_SLIP_ENABLED +#define HCI_SLIP_ENABLED 0 +#endif +// HCI_UART_BAUDRATE - Default Baudrate + +// <323584=> 1200 baud +// <643072=> 2400 baud +// <1290240=> 4800 baud +// <2576384=> 9600 baud +// <3862528=> 14400 baud +// <5152768=> 19200 baud +// <7716864=> 28800 baud +// <10289152=> 38400 baud +// <15400960=> 57600 baud +// <20615168=> 76800 baud +// <30801920=> 115200 baud +// <61865984=> 230400 baud +// <67108864=> 250000 baud +// <121634816=> 460800 baud +// <251658240=> 921600 baud +// <268435456=> 1000000 baud + +#ifndef HCI_UART_BAUDRATE +#define HCI_UART_BAUDRATE 30801920 +#endif + +// HCI_UART_FLOW_CONTROL - Hardware Flow Control + +// <0=> Disabled +// <1=> Enabled + +#ifndef HCI_UART_FLOW_CONTROL +#define HCI_UART_FLOW_CONTROL 0 +#endif + +// HCI_UART_RX_PIN - UART RX pin +#ifndef HCI_UART_RX_PIN +#define HCI_UART_RX_PIN 31 +#endif + +// HCI_UART_TX_PIN - UART TX pin +#ifndef HCI_UART_TX_PIN +#define HCI_UART_TX_PIN 31 +#endif + +// HCI_UART_RTS_PIN - UART RTS pin +#ifndef HCI_UART_RTS_PIN +#define HCI_UART_RTS_PIN 31 +#endif + +// HCI_UART_CTS_PIN - UART CTS pin +#ifndef HCI_UART_CTS_PIN +#define HCI_UART_CTS_PIN 31 +#endif + +// + +// HCI_TRANSPORT_ENABLED - hci_transport - HCI transport +//========================================================== +#ifndef HCI_TRANSPORT_ENABLED +#define HCI_TRANSPORT_ENABLED 0 +#endif +// HCI_MAX_PACKET_SIZE_IN_BITS - Maximum size of a single application packet in bits. +#ifndef HCI_MAX_PACKET_SIZE_IN_BITS +#define HCI_MAX_PACKET_SIZE_IN_BITS 8000 +#endif + +// + +// LED_SOFTBLINK_ENABLED - led_softblink - led_softblink module + + +#ifndef LED_SOFTBLINK_ENABLED +#define LED_SOFTBLINK_ENABLED 0 +#endif + +// LOW_POWER_PWM_ENABLED - low_power_pwm - low_power_pwm module + + +#ifndef LOW_POWER_PWM_ENABLED +#define LOW_POWER_PWM_ENABLED 0 +#endif + +// MEM_MANAGER_ENABLED - mem_manager - Dynamic memory allocator +//========================================================== +#ifndef MEM_MANAGER_ENABLED +#define MEM_MANAGER_ENABLED 0 +#endif +// MEMORY_MANAGER_SMALL_BLOCK_COUNT - Size of each memory blocks identified as 'small' block. <0-255> + + +#ifndef MEMORY_MANAGER_SMALL_BLOCK_COUNT +#define MEMORY_MANAGER_SMALL_BLOCK_COUNT 1 +#endif + +// MEMORY_MANAGER_SMALL_BLOCK_SIZE - Size of each memory blocks identified as 'small' block. +// Size of each memory blocks identified as 'small' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_SMALL_BLOCK_SIZE +#define MEMORY_MANAGER_SMALL_BLOCK_SIZE 32 +#endif + +// MEMORY_MANAGER_MEDIUM_BLOCK_COUNT - Size of each memory blocks identified as 'medium' block. <0-255> + + +#ifndef MEMORY_MANAGER_MEDIUM_BLOCK_COUNT +#define MEMORY_MANAGER_MEDIUM_BLOCK_COUNT 0 +#endif + +// MEMORY_MANAGER_MEDIUM_BLOCK_SIZE - Size of each memory blocks identified as 'medium' block. +// Size of each memory blocks identified as 'medium' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_MEDIUM_BLOCK_SIZE +#define MEMORY_MANAGER_MEDIUM_BLOCK_SIZE 256 +#endif + +// MEMORY_MANAGER_LARGE_BLOCK_COUNT - Size of each memory blocks identified as 'large' block. <0-255> + + +#ifndef MEMORY_MANAGER_LARGE_BLOCK_COUNT +#define MEMORY_MANAGER_LARGE_BLOCK_COUNT 0 +#endif + +// MEMORY_MANAGER_LARGE_BLOCK_SIZE - Size of each memory blocks identified as 'large' block. +// Size of each memory blocks identified as 'large' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_LARGE_BLOCK_SIZE +#define MEMORY_MANAGER_LARGE_BLOCK_SIZE 256 +#endif + +// MEMORY_MANAGER_XLARGE_BLOCK_COUNT - Size of each memory blocks identified as 'extra large' block. <0-255> + + +#ifndef MEMORY_MANAGER_XLARGE_BLOCK_COUNT +#define MEMORY_MANAGER_XLARGE_BLOCK_COUNT 0 +#endif + +// MEMORY_MANAGER_XLARGE_BLOCK_SIZE - Size of each memory blocks identified as 'extra large' block. +// Size of each memory blocks identified as 'extra large' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_XLARGE_BLOCK_SIZE +#define MEMORY_MANAGER_XLARGE_BLOCK_SIZE 1320 +#endif + +// MEMORY_MANAGER_XXLARGE_BLOCK_COUNT - Size of each memory blocks identified as 'extra extra large' block. <0-255> + + +#ifndef MEMORY_MANAGER_XXLARGE_BLOCK_COUNT +#define MEMORY_MANAGER_XXLARGE_BLOCK_COUNT 0 +#endif + +// MEMORY_MANAGER_XXLARGE_BLOCK_SIZE - Size of each memory blocks identified as 'extra extra large' block. +// Size of each memory blocks identified as 'extra extra large' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_XXLARGE_BLOCK_SIZE +#define MEMORY_MANAGER_XXLARGE_BLOCK_SIZE 3444 +#endif + +// MEMORY_MANAGER_XSMALL_BLOCK_COUNT - Size of each memory blocks identified as 'extra small' block. <0-255> + + +#ifndef MEMORY_MANAGER_XSMALL_BLOCK_COUNT +#define MEMORY_MANAGER_XSMALL_BLOCK_COUNT 0 +#endif + +// MEMORY_MANAGER_XSMALL_BLOCK_SIZE - Size of each memory blocks identified as 'extra small' block. +// Size of each memory blocks identified as 'extra large' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_XSMALL_BLOCK_SIZE +#define MEMORY_MANAGER_XSMALL_BLOCK_SIZE 64 +#endif + +// MEMORY_MANAGER_XXSMALL_BLOCK_COUNT - Size of each memory blocks identified as 'extra extra small' block. <0-255> + + +#ifndef MEMORY_MANAGER_XXSMALL_BLOCK_COUNT +#define MEMORY_MANAGER_XXSMALL_BLOCK_COUNT 0 +#endif + +// MEMORY_MANAGER_XXSMALL_BLOCK_SIZE - Size of each memory blocks identified as 'extra extra small' block. +// Size of each memory blocks identified as 'extra extra small' block. Memory block are recommended to be word-sized. + +#ifndef MEMORY_MANAGER_XXSMALL_BLOCK_SIZE +#define MEMORY_MANAGER_XXSMALL_BLOCK_SIZE 32 +#endif + +// MEM_MANAGER_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef MEM_MANAGER_CONFIG_LOG_ENABLED +#define MEM_MANAGER_CONFIG_LOG_ENABLED 0 +#endif +// MEM_MANAGER_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef MEM_MANAGER_CONFIG_LOG_LEVEL +#define MEM_MANAGER_CONFIG_LOG_LEVEL 3 +#endif + +// MEM_MANAGER_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef MEM_MANAGER_CONFIG_INFO_COLOR +#define MEM_MANAGER_CONFIG_INFO_COLOR 0 +#endif + +// MEM_MANAGER_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef MEM_MANAGER_CONFIG_DEBUG_COLOR +#define MEM_MANAGER_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// MEM_MANAGER_DISABLE_API_PARAM_CHECK - Disable API parameter checks in the module. + + +#ifndef MEM_MANAGER_DISABLE_API_PARAM_CHECK +#define MEM_MANAGER_DISABLE_API_PARAM_CHECK 0 +#endif + +// + +// NRF_BALLOC_ENABLED - nrf_balloc - Block allocator module +//========================================================== +#ifndef NRF_BALLOC_ENABLED +#define NRF_BALLOC_ENABLED 1 +#endif +// NRF_BALLOC_CONFIG_DEBUG_ENABLED - Enables debug mode in the module. +//========================================================== +#ifndef NRF_BALLOC_CONFIG_DEBUG_ENABLED +#define NRF_BALLOC_CONFIG_DEBUG_ENABLED 0 +#endif +// NRF_BALLOC_CONFIG_HEAD_GUARD_WORDS - Number of words used as head guard. <0-255> + + +#ifndef NRF_BALLOC_CONFIG_HEAD_GUARD_WORDS +#define NRF_BALLOC_CONFIG_HEAD_GUARD_WORDS 1 +#endif + +// NRF_BALLOC_CONFIG_TAIL_GUARD_WORDS - Number of words used as tail guard. <0-255> + + +#ifndef NRF_BALLOC_CONFIG_TAIL_GUARD_WORDS +#define NRF_BALLOC_CONFIG_TAIL_GUARD_WORDS 1 +#endif + +// NRF_BALLOC_CONFIG_BASIC_CHECKS_ENABLED - Enables basic checks in this module. + + +#ifndef NRF_BALLOC_CONFIG_BASIC_CHECKS_ENABLED +#define NRF_BALLOC_CONFIG_BASIC_CHECKS_ENABLED 0 +#endif + +// NRF_BALLOC_CONFIG_DOUBLE_FREE_CHECK_ENABLED - Enables double memory free check in this module. + + +#ifndef NRF_BALLOC_CONFIG_DOUBLE_FREE_CHECK_ENABLED +#define NRF_BALLOC_CONFIG_DOUBLE_FREE_CHECK_ENABLED 0 +#endif + +// NRF_BALLOC_CONFIG_DATA_TRASHING_CHECK_ENABLED - Enables free memory corruption check in this module. + + +#ifndef NRF_BALLOC_CONFIG_DATA_TRASHING_CHECK_ENABLED +#define NRF_BALLOC_CONFIG_DATA_TRASHING_CHECK_ENABLED 0 +#endif + +// NRF_BALLOC_CLI_CMDS - Enable CLI commands specific to the module + + +#ifndef NRF_BALLOC_CLI_CMDS +#define NRF_BALLOC_CLI_CMDS 0 +#endif + +// + +// + +// NRF_CSENSE_ENABLED - nrf_csense - Capacitive sensor module +//========================================================== +#ifndef NRF_CSENSE_ENABLED +#define NRF_CSENSE_ENABLED 0 +#endif +// NRF_CSENSE_PAD_HYSTERESIS - Minimum value of change required to determine that a pad was touched. +#ifndef NRF_CSENSE_PAD_HYSTERESIS +#define NRF_CSENSE_PAD_HYSTERESIS 15 +#endif + +// NRF_CSENSE_PAD_DEVIATION - Minimum value measured on a pad required to take it into account while calculating the step. +#ifndef NRF_CSENSE_PAD_DEVIATION +#define NRF_CSENSE_PAD_DEVIATION 70 +#endif + +// NRF_CSENSE_MIN_PAD_VALUE - Minimum normalized value on a pad required to take its value into account. +#ifndef NRF_CSENSE_MIN_PAD_VALUE +#define NRF_CSENSE_MIN_PAD_VALUE 20 +#endif + +// NRF_CSENSE_MAX_PADS_NUMBER - Maximum number of pads used for one instance. +#ifndef NRF_CSENSE_MAX_PADS_NUMBER +#define NRF_CSENSE_MAX_PADS_NUMBER 20 +#endif + +// NRF_CSENSE_MAX_VALUE - Maximum normalized value obtained from measurement. +#ifndef NRF_CSENSE_MAX_VALUE +#define NRF_CSENSE_MAX_VALUE 1000 +#endif + +// NRF_CSENSE_OUTPUT_PIN - Output pin used by the low-level module. +// This is used when capacitive sensor does not use COMP. + +#ifndef NRF_CSENSE_OUTPUT_PIN +#define NRF_CSENSE_OUTPUT_PIN 26 +#endif + +// + +// NRF_DRV_CSENSE_ENABLED - nrf_drv_csense - Capacitive sensor low-level module +//========================================================== +#ifndef NRF_DRV_CSENSE_ENABLED +#define NRF_DRV_CSENSE_ENABLED 0 +#endif +// USE_COMP - Use the comparator to implement the capacitive sensor driver. + +// Due to Anomaly 84, COMP I_SOURCE is not functional. It has too high a varation. +//========================================================== +#ifndef USE_COMP +#define USE_COMP 0 +#endif +// TIMER0_FOR_CSENSE - First TIMER instance used by the driver (not used on nRF51). +#ifndef TIMER0_FOR_CSENSE +#define TIMER0_FOR_CSENSE 1 +#endif + +// TIMER1_FOR_CSENSE - Second TIMER instance used by the driver (not used on nRF51). +#ifndef TIMER1_FOR_CSENSE +#define TIMER1_FOR_CSENSE 2 +#endif + +// MEASUREMENT_PERIOD - Single measurement period. +// Time of a single measurement can be calculated as +// T = (1/2)*MEASUREMENT_PERIOD*(1/f_OSC) where f_OSC = I_SOURCE / (2C*(VUP-VDOWN) ). +// I_SOURCE, VUP, and VDOWN are values used to initialize COMP and C is the capacitance of the used pad. + +#ifndef MEASUREMENT_PERIOD +#define MEASUREMENT_PERIOD 20 +#endif + +// + +// + +// NRF_FSTORAGE_ENABLED - nrf_fstorage - Flash abstraction library +//========================================================== +#ifndef NRF_FSTORAGE_ENABLED +#define NRF_FSTORAGE_ENABLED 0 +#endif +// nrf_fstorage - Common settings + +// Common settings to all fstorage implementations +//========================================================== +// NRF_FSTORAGE_PARAM_CHECK_DISABLED - Disable user input validation + + +// If selected, use ASSERT to validate user input. +// This effectively removes user input validation in production code. +// Recommended setting: OFF, only enable this setting if size is a major concern. + +#ifndef NRF_FSTORAGE_PARAM_CHECK_DISABLED +#define NRF_FSTORAGE_PARAM_CHECK_DISABLED 0 +#endif + +// +//========================================================== + +// nrf_fstorage_sd - Implementation using the SoftDevice + +// Configuration options for the fstorage implementation using the SoftDevice +//========================================================== +// NRF_FSTORAGE_SD_QUEUE_SIZE - Size of the internal queue of operations +// Increase this value if API calls frequently return the error @ref NRF_ERROR_NO_MEM. + +#ifndef NRF_FSTORAGE_SD_QUEUE_SIZE +#define NRF_FSTORAGE_SD_QUEUE_SIZE 4 +#endif + +// NRF_FSTORAGE_SD_MAX_RETRIES - Maximum number of attempts at executing an operation when the SoftDevice is busy +// Increase this value if events frequently return the @ref NRF_ERROR_TIMEOUT error. +// The SoftDevice might fail to schedule flash access due to high BLE activity. + +#ifndef NRF_FSTORAGE_SD_MAX_RETRIES +#define NRF_FSTORAGE_SD_MAX_RETRIES 8 +#endif + +// NRF_FSTORAGE_SD_MAX_WRITE_SIZE - Maximum number of bytes to be written to flash in a single operation +// This value must be a multiple of four. +// Lowering this value can increase the chances of the SoftDevice being able to execute flash operations in between radio activity. +// This value is bound by the maximum number of bytes that can be written to flash in a single call to @ref sd_flash_write. +// That is 1024 bytes for nRF51 ICs and 4096 bytes for nRF52 ICs. + +#ifndef NRF_FSTORAGE_SD_MAX_WRITE_SIZE +#define NRF_FSTORAGE_SD_MAX_WRITE_SIZE 4096 +#endif + +// +//========================================================== + +// + +// NRF_GFX_ENABLED - nrf_gfx - GFX module + + +#ifndef NRF_GFX_ENABLED +#define NRF_GFX_ENABLED 0 +#endif + +// NRF_MEMOBJ_ENABLED - nrf_memobj - Linked memory allocator module + + +#ifndef NRF_MEMOBJ_ENABLED +#define NRF_MEMOBJ_ENABLED 1 +#endif + +// NRF_PWR_MGMT_ENABLED - nrf_pwr_mgmt - Power management module +//========================================================== +#ifndef NRF_PWR_MGMT_ENABLED +#define NRF_PWR_MGMT_ENABLED 0 +#endif +// NRF_PWR_MGMT_CONFIG_DEBUG_PIN_ENABLED - Enables pin debug in the module. + +// Selected pin will be set when CPU is in sleep mode. +//========================================================== +#ifndef NRF_PWR_MGMT_CONFIG_DEBUG_PIN_ENABLED +#define NRF_PWR_MGMT_CONFIG_DEBUG_PIN_ENABLED 0 +#endif +// NRF_PWR_MGMT_SLEEP_DEBUG_PIN - Pin number + +// <0=> 0 (P0.0) +// <1=> 1 (P0.1) +// <2=> 2 (P0.2) +// <3=> 3 (P0.3) +// <4=> 4 (P0.4) +// <5=> 5 (P0.5) +// <6=> 6 (P0.6) +// <7=> 7 (P0.7) +// <8=> 8 (P0.8) +// <9=> 9 (P0.9) +// <10=> 10 (P0.10) +// <11=> 11 (P0.11) +// <12=> 12 (P0.12) +// <13=> 13 (P0.13) +// <14=> 14 (P0.14) +// <15=> 15 (P0.15) +// <16=> 16 (P0.16) +// <17=> 17 (P0.17) +// <18=> 18 (P0.18) +// <19=> 19 (P0.19) +// <20=> 20 (P0.20) +// <21=> 21 (P0.21) +// <22=> 22 (P0.22) +// <23=> 23 (P0.23) +// <24=> 24 (P0.24) +// <25=> 25 (P0.25) +// <26=> 26 (P0.26) +// <27=> 27 (P0.27) +// <28=> 28 (P0.28) +// <29=> 29 (P0.29) +// <30=> 30 (P0.30) +// <31=> 31 (P0.31) +// <32=> 32 (P1.0) +// <33=> 33 (P1.1) +// <34=> 34 (P1.2) +// <35=> 35 (P1.3) +// <36=> 36 (P1.4) +// <37=> 37 (P1.5) +// <38=> 38 (P1.6) +// <39=> 39 (P1.7) +// <40=> 40 (P1.8) +// <41=> 41 (P1.9) +// <42=> 42 (P1.10) +// <43=> 43 (P1.11) +// <44=> 44 (P1.12) +// <45=> 45 (P1.13) +// <46=> 46 (P1.14) +// <47=> 47 (P1.15) +// <4294967295=> Not connected + +#ifndef NRF_PWR_MGMT_SLEEP_DEBUG_PIN +#define NRF_PWR_MGMT_SLEEP_DEBUG_PIN 31 +#endif + +// + +// NRF_PWR_MGMT_CONFIG_CPU_USAGE_MONITOR_ENABLED - Enables CPU usage monitor. + + +// Module will trace percentage of CPU usage in one second intervals. + +#ifndef NRF_PWR_MGMT_CONFIG_CPU_USAGE_MONITOR_ENABLED +#define NRF_PWR_MGMT_CONFIG_CPU_USAGE_MONITOR_ENABLED 0 +#endif + +// NRF_PWR_MGMT_CONFIG_STANDBY_TIMEOUT_ENABLED - Enable standby timeout. +//========================================================== +#ifndef NRF_PWR_MGMT_CONFIG_STANDBY_TIMEOUT_ENABLED +#define NRF_PWR_MGMT_CONFIG_STANDBY_TIMEOUT_ENABLED 0 +#endif +// NRF_PWR_MGMT_CONFIG_STANDBY_TIMEOUT_S - Standby timeout (in seconds). +// Shutdown procedure will begin no earlier than after this number of seconds. + +#ifndef NRF_PWR_MGMT_CONFIG_STANDBY_TIMEOUT_S +#define NRF_PWR_MGMT_CONFIG_STANDBY_TIMEOUT_S 3 +#endif + +// + +// NRF_PWR_MGMT_CONFIG_FPU_SUPPORT_ENABLED - Enables FPU event cleaning. + + +#ifndef NRF_PWR_MGMT_CONFIG_FPU_SUPPORT_ENABLED +#define NRF_PWR_MGMT_CONFIG_FPU_SUPPORT_ENABLED 0 +#endif + +// NRF_PWR_MGMT_CONFIG_AUTO_SHUTDOWN_RETRY - Blocked shutdown procedure will be retried every second. + + +#ifndef NRF_PWR_MGMT_CONFIG_AUTO_SHUTDOWN_RETRY +#define NRF_PWR_MGMT_CONFIG_AUTO_SHUTDOWN_RETRY 0 +#endif + +// NRF_PWR_MGMT_CONFIG_USE_SCHEDULER - Module will use @ref app_scheduler. + + +#ifndef NRF_PWR_MGMT_CONFIG_USE_SCHEDULER +#define NRF_PWR_MGMT_CONFIG_USE_SCHEDULER 0 +#endif + +// NRF_PWR_MGMT_CONFIG_HANDLER_PRIORITY_COUNT - The number of priorities for module handlers. +// The number of stages of the shutdown process. + +#ifndef NRF_PWR_MGMT_CONFIG_HANDLER_PRIORITY_COUNT +#define NRF_PWR_MGMT_CONFIG_HANDLER_PRIORITY_COUNT 3 +#endif + +// + +// NRF_QUEUE_ENABLED - nrf_queue - Queue module +//========================================================== +#ifndef NRF_QUEUE_ENABLED +#define NRF_QUEUE_ENABLED 0 +#endif +// NRF_QUEUE_CLI_CMDS - Enable CLI commands specific to the module + + +#ifndef NRF_QUEUE_CLI_CMDS +#define NRF_QUEUE_CLI_CMDS 0 +#endif + +// + +// NRF_SECTION_ITER_ENABLED - nrf_section_iter - Section iterator + + +#ifndef NRF_SECTION_ITER_ENABLED +#define NRF_SECTION_ITER_ENABLED 1 +#endif + +// NRF_SORTLIST_ENABLED - nrf_sortlist - Sorted list + + +#ifndef NRF_SORTLIST_ENABLED +#define NRF_SORTLIST_ENABLED 1 +#endif + +// NRF_SPI_MNGR_ENABLED - nrf_spi_mngr - SPI transaction manager + + +#ifndef NRF_SPI_MNGR_ENABLED +#define NRF_SPI_MNGR_ENABLED 0 +#endif + +// NRF_STRERROR_ENABLED - nrf_strerror - Library for converting error code to string. + + +#ifndef NRF_STRERROR_ENABLED +#define NRF_STRERROR_ENABLED 1 +#endif + +// NRF_TWI_MNGR_ENABLED - nrf_twi_mngr - TWI transaction manager + + +#ifndef NRF_TWI_MNGR_ENABLED +#define NRF_TWI_MNGR_ENABLED 0 +#endif + +// SLIP_ENABLED - slip - SLIP encoding and decoding + + +#ifndef SLIP_ENABLED +#define SLIP_ENABLED 0 +#endif + +// TASK_MANAGER_ENABLED - task_manager - Task manager. +//========================================================== +#ifndef TASK_MANAGER_ENABLED +#define TASK_MANAGER_ENABLED 0 +#endif +// TASK_MANAGER_CLI_CMDS - Enable CLI commands specific to the module + + +#ifndef TASK_MANAGER_CLI_CMDS +#define TASK_MANAGER_CLI_CMDS 0 +#endif + +// TASK_MANAGER_CONFIG_MAX_TASKS - Maximum number of tasks which can be created +#ifndef TASK_MANAGER_CONFIG_MAX_TASKS +#define TASK_MANAGER_CONFIG_MAX_TASKS 2 +#endif + +// TASK_MANAGER_CONFIG_STACK_SIZE - Stack size for every task (power of 2) +#ifndef TASK_MANAGER_CONFIG_STACK_SIZE +#define TASK_MANAGER_CONFIG_STACK_SIZE 1024 +#endif + +// TASK_MANAGER_CONFIG_STACK_PROFILER_ENABLED - Enable stack profiling. + + +#ifndef TASK_MANAGER_CONFIG_STACK_PROFILER_ENABLED +#define TASK_MANAGER_CONFIG_STACK_PROFILER_ENABLED 1 +#endif + +// TASK_MANAGER_CONFIG_STACK_GUARD - Configures stack guard. + +// <0=> Disabled +// <4=> 32 bytes +// <5=> 64 bytes +// <6=> 128 bytes +// <7=> 256 bytes +// <8=> 512 bytes + +#ifndef TASK_MANAGER_CONFIG_STACK_GUARD +#define TASK_MANAGER_CONFIG_STACK_GUARD 7 +#endif + +// + +// app_button - buttons handling module + +//========================================================== +// BUTTON_ENABLED - Enables Button module + + +#ifndef BUTTON_ENABLED +#define BUTTON_ENABLED 0 +#endif + +// BUTTON_HIGH_ACCURACY_ENABLED - Enables GPIOTE high accuracy for buttons + + +#ifndef BUTTON_HIGH_ACCURACY_ENABLED +#define BUTTON_HIGH_ACCURACY_ENABLED 0 +#endif + +// +//========================================================== + +// app_usbd_cdc_acm - USB CDC ACM class + +//========================================================== +// APP_USBD_CDC_ACM_ENABLED - Enabling USBD CDC ACM Class library + + +#ifndef APP_USBD_CDC_ACM_ENABLED +#define APP_USBD_CDC_ACM_ENABLED 0 +#endif + +// APP_USBD_CDC_ACM_ZLP_ON_EPSIZE_WRITE - Send ZLP on write with same size as endpoint + + +// If enabled, CDC ACM class will automatically send a zero length packet after transfer which has the same size as endpoint. +// This may limit throughput if a lot of binary data is sent, but in terminal mode operation it makes sure that the data is always displayed right after it is sent. + +#ifndef APP_USBD_CDC_ACM_ZLP_ON_EPSIZE_WRITE +#define APP_USBD_CDC_ACM_ZLP_ON_EPSIZE_WRITE 1 +#endif + +// +//========================================================== + +// nrf_cli - Command line interface + +//========================================================== +// NRF_CLI_ENABLED - Enable/disable the CLI module. + + +#ifndef NRF_CLI_ENABLED +#define NRF_CLI_ENABLED 0 +#endif + +// NRF_CLI_ARGC_MAX - Maximum number of parameters passed to the command handler. +#ifndef NRF_CLI_ARGC_MAX +#define NRF_CLI_ARGC_MAX 12 +#endif + +// NRF_CLI_BUILD_IN_CMDS_ENABLED - CLI built-in commands. + + +#ifndef NRF_CLI_BUILD_IN_CMDS_ENABLED +#define NRF_CLI_BUILD_IN_CMDS_ENABLED 1 +#endif + +// NRF_CLI_CMD_BUFF_SIZE - Maximum buffer size for a single command. +#ifndef NRF_CLI_CMD_BUFF_SIZE +#define NRF_CLI_CMD_BUFF_SIZE 128 +#endif + +// NRF_CLI_ECHO_STATUS - CLI echo status. If set, echo is ON. + + +#ifndef NRF_CLI_ECHO_STATUS +#define NRF_CLI_ECHO_STATUS 1 +#endif + +// NRF_CLI_WILDCARD_ENABLED - Enable wildcard functionality for CLI commands. + + +#ifndef NRF_CLI_WILDCARD_ENABLED +#define NRF_CLI_WILDCARD_ENABLED 0 +#endif + +// NRF_CLI_METAKEYS_ENABLED - Enable additional control keys for CLI commands like ctrl+a, ctrl+e, ctrl+w, ctrl+u + + +#ifndef NRF_CLI_METAKEYS_ENABLED +#define NRF_CLI_METAKEYS_ENABLED 0 +#endif + +// NRF_CLI_PRINTF_BUFF_SIZE - Maximum print buffer size. +#ifndef NRF_CLI_PRINTF_BUFF_SIZE +#define NRF_CLI_PRINTF_BUFF_SIZE 23 +#endif + +// NRF_CLI_HISTORY_ENABLED - Enable CLI history mode. +//========================================================== +#ifndef NRF_CLI_HISTORY_ENABLED +#define NRF_CLI_HISTORY_ENABLED 1 +#endif +// NRF_CLI_HISTORY_ELEMENT_SIZE - Size of one memory object reserved for CLI history. +#ifndef NRF_CLI_HISTORY_ELEMENT_SIZE +#define NRF_CLI_HISTORY_ELEMENT_SIZE 32 +#endif + +// NRF_CLI_HISTORY_ELEMENT_COUNT - Number of history memory objects. +#ifndef NRF_CLI_HISTORY_ELEMENT_COUNT +#define NRF_CLI_HISTORY_ELEMENT_COUNT 8 +#endif + +// + +// NRF_CLI_VT100_COLORS_ENABLED - CLI VT100 colors. + + +#ifndef NRF_CLI_VT100_COLORS_ENABLED +#define NRF_CLI_VT100_COLORS_ENABLED 1 +#endif + +// NRF_CLI_STATISTICS_ENABLED - Enable CLI statistics. + + +#ifndef NRF_CLI_STATISTICS_ENABLED +#define NRF_CLI_STATISTICS_ENABLED 1 +#endif + +// NRF_CLI_LOG_BACKEND - Enable logger backend interface. + + +#ifndef NRF_CLI_LOG_BACKEND +#define NRF_CLI_LOG_BACKEND 1 +#endif + +// NRF_CLI_USES_TASK_MANAGER_ENABLED - Enable CLI to use task_manager + + +#ifndef NRF_CLI_USES_TASK_MANAGER_ENABLED +#define NRF_CLI_USES_TASK_MANAGER_ENABLED 0 +#endif + +// +//========================================================== + +// nrf_fprintf - fprintf function. + +//========================================================== +// NRF_FPRINTF_ENABLED - Enable/disable fprintf module. + + +#ifndef NRF_FPRINTF_ENABLED +#define NRF_FPRINTF_ENABLED 1 +#endif + +// NRF_FPRINTF_FLAG_AUTOMATIC_CR_ON_LF_ENABLED - For each printed LF, function will add CR. + + +#ifndef NRF_FPRINTF_FLAG_AUTOMATIC_CR_ON_LF_ENABLED +#define NRF_FPRINTF_FLAG_AUTOMATIC_CR_ON_LF_ENABLED 1 +#endif + +// NRF_FPRINTF_DOUBLE_ENABLED - Enable IEEE-754 double precision formatting. + + +#ifndef NRF_FPRINTF_DOUBLE_ENABLED +#define NRF_FPRINTF_DOUBLE_ENABLED 0 +#endif + +// +//========================================================== + +// +//========================================================== + +// nRF_Log + +//========================================================== +// NRF_LOG_ENABLED - nrf_log - Logger +//========================================================== +#ifndef NRF_LOG_ENABLED +#define NRF_LOG_ENABLED 0 +#endif +// Log message pool - Configuration of log message pool + +//========================================================== +// NRF_LOG_MSGPOOL_ELEMENT_SIZE - Size of a single element in the pool of memory objects. +// If a small value is set, then performance of logs processing +// is degraded because data is fragmented. Bigger value impacts +// RAM memory utilization. The size is set to fit a message with +// a timestamp and up to 2 arguments in a single memory object. + +#ifndef NRF_LOG_MSGPOOL_ELEMENT_SIZE +#define NRF_LOG_MSGPOOL_ELEMENT_SIZE 20 +#endif + +// NRF_LOG_MSGPOOL_ELEMENT_COUNT - Number of elements in the pool of memory objects +// If a small value is set, then it may lead to a deadlock +// in certain cases if backend has high latency and holds +// multiple messages for long time. Bigger value impacts +// RAM memory usage. + +#ifndef NRF_LOG_MSGPOOL_ELEMENT_COUNT +#define NRF_LOG_MSGPOOL_ELEMENT_COUNT 8 +#endif + +// +//========================================================== + +// NRF_LOG_ALLOW_OVERFLOW - Configures behavior when circular buffer is full. + + +// If set then oldest logs are overwritten. Otherwise a +// marker is injected informing about overflow. + +#ifndef NRF_LOG_ALLOW_OVERFLOW +#define NRF_LOG_ALLOW_OVERFLOW 1 +#endif + +// NRF_LOG_BUFSIZE - Size of the buffer for storing logs (in bytes). + + +// Must be power of 2 and multiple of 4. +// If NRF_LOG_DEFERRED = 0 then buffer size can be reduced to minimum. +// <128=> 128 +// <256=> 256 +// <512=> 512 +// <1024=> 1024 +// <2048=> 2048 +// <4096=> 4096 +// <8192=> 8192 +// <16384=> 16384 + +#ifndef NRF_LOG_BUFSIZE +#define NRF_LOG_BUFSIZE 1024 +#endif + +// NRF_LOG_CLI_CMDS - Enable CLI commands for the module. + + +#ifndef NRF_LOG_CLI_CMDS +#define NRF_LOG_CLI_CMDS 0 +#endif + +// NRF_LOG_DEFAULT_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_LOG_DEFAULT_LEVEL +#define NRF_LOG_DEFAULT_LEVEL 3 +#endif + +// NRF_LOG_DEFERRED - Enable deffered logger. + + +// Log data is buffered and can be processed in idle. + +#ifndef NRF_LOG_DEFERRED +#define NRF_LOG_DEFERRED 1 +#endif + +// NRF_LOG_FILTERS_ENABLED - Enable dynamic filtering of logs. + + +#ifndef NRF_LOG_FILTERS_ENABLED +#define NRF_LOG_FILTERS_ENABLED 0 +#endif + +// NRF_LOG_NON_DEFFERED_CRITICAL_REGION_ENABLED - Enable use of critical region for non deffered mode when flushing logs. + + +// When enabled NRF_LOG_FLUSH is called from critical section when non deffered mode is used. +// Log output will never be corrupted as access to the log backend is exclusive +// but system will spend significant amount of time in critical section + +#ifndef NRF_LOG_NON_DEFFERED_CRITICAL_REGION_ENABLED +#define NRF_LOG_NON_DEFFERED_CRITICAL_REGION_ENABLED 0 +#endif + +// NRF_LOG_STR_PUSH_BUFFER_SIZE - Size of the buffer dedicated for strings stored using @ref NRF_LOG_PUSH. + +// <16=> 16 +// <32=> 32 +// <64=> 64 +// <128=> 128 +// <256=> 256 +// <512=> 512 +// <1024=> 1024 + +#ifndef NRF_LOG_STR_PUSH_BUFFER_SIZE +#define NRF_LOG_STR_PUSH_BUFFER_SIZE 128 +#endif + +// NRF_LOG_STR_PUSH_BUFFER_SIZE - Size of the buffer dedicated for strings stored using @ref NRF_LOG_PUSH. + +// <16=> 16 +// <32=> 32 +// <64=> 64 +// <128=> 128 +// <256=> 256 +// <512=> 512 +// <1024=> 1024 + +#ifndef NRF_LOG_STR_PUSH_BUFFER_SIZE +#define NRF_LOG_STR_PUSH_BUFFER_SIZE 128 +#endif + +// NRF_LOG_USES_COLORS - If enabled then ANSI escape code for colors is prefixed to every string +//========================================================== +#ifndef NRF_LOG_USES_COLORS +#define NRF_LOG_USES_COLORS 0 +#endif +// NRF_LOG_COLOR_DEFAULT - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_LOG_COLOR_DEFAULT +#define NRF_LOG_COLOR_DEFAULT 0 +#endif + +// NRF_LOG_ERROR_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_LOG_ERROR_COLOR +#define NRF_LOG_ERROR_COLOR 2 +#endif + +// NRF_LOG_WARNING_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_LOG_WARNING_COLOR +#define NRF_LOG_WARNING_COLOR 4 +#endif + +// + +// NRF_LOG_USES_TIMESTAMP - Enable timestamping + +// Function for getting the timestamp is provided by the user +//========================================================== +#ifndef NRF_LOG_USES_TIMESTAMP +#define NRF_LOG_USES_TIMESTAMP 0 +#endif +// NRF_LOG_TIMESTAMP_DEFAULT_FREQUENCY - Default frequency of the timestamp (in Hz) or 0 to use app_timer frequency. +#ifndef NRF_LOG_TIMESTAMP_DEFAULT_FREQUENCY +#define NRF_LOG_TIMESTAMP_DEFAULT_FREQUENCY 0 +#endif + +// + +// nrf_log module configuration + +//========================================================== +// nrf_log in nRF_Core + +//========================================================== +// NRF_MPU_LIB_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_MPU_LIB_CONFIG_LOG_ENABLED +#define NRF_MPU_LIB_CONFIG_LOG_ENABLED 0 +#endif +// NRF_MPU_LIB_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_MPU_LIB_CONFIG_LOG_LEVEL +#define NRF_MPU_LIB_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_MPU_LIB_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_MPU_LIB_CONFIG_INFO_COLOR +#define NRF_MPU_LIB_CONFIG_INFO_COLOR 0 +#endif + +// NRF_MPU_LIB_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_MPU_LIB_CONFIG_DEBUG_COLOR +#define NRF_MPU_LIB_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_STACK_GUARD_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_STACK_GUARD_CONFIG_LOG_ENABLED +#define NRF_STACK_GUARD_CONFIG_LOG_ENABLED 0 +#endif +// NRF_STACK_GUARD_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_STACK_GUARD_CONFIG_LOG_LEVEL +#define NRF_STACK_GUARD_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_STACK_GUARD_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_STACK_GUARD_CONFIG_INFO_COLOR +#define NRF_STACK_GUARD_CONFIG_INFO_COLOR 0 +#endif + +// NRF_STACK_GUARD_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_STACK_GUARD_CONFIG_DEBUG_COLOR +#define NRF_STACK_GUARD_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// TASK_MANAGER_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef TASK_MANAGER_CONFIG_LOG_ENABLED +#define TASK_MANAGER_CONFIG_LOG_ENABLED 0 +#endif +// TASK_MANAGER_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef TASK_MANAGER_CONFIG_LOG_LEVEL +#define TASK_MANAGER_CONFIG_LOG_LEVEL 3 +#endif + +// TASK_MANAGER_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TASK_MANAGER_CONFIG_INFO_COLOR +#define TASK_MANAGER_CONFIG_INFO_COLOR 0 +#endif + +// TASK_MANAGER_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TASK_MANAGER_CONFIG_DEBUG_COLOR +#define TASK_MANAGER_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// +//========================================================== + +// nrf_log in nRF_Drivers + +//========================================================== +// CLOCK_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef CLOCK_CONFIG_LOG_ENABLED +#define CLOCK_CONFIG_LOG_ENABLED 0 +#endif +// CLOCK_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef CLOCK_CONFIG_LOG_LEVEL +#define CLOCK_CONFIG_LOG_LEVEL 3 +#endif + +// CLOCK_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef CLOCK_CONFIG_INFO_COLOR +#define CLOCK_CONFIG_INFO_COLOR 0 +#endif + +// CLOCK_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef CLOCK_CONFIG_DEBUG_COLOR +#define CLOCK_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// COMP_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef COMP_CONFIG_LOG_ENABLED +#define COMP_CONFIG_LOG_ENABLED 0 +#endif +// COMP_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef COMP_CONFIG_LOG_LEVEL +#define COMP_CONFIG_LOG_LEVEL 3 +#endif + +// COMP_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef COMP_CONFIG_INFO_COLOR +#define COMP_CONFIG_INFO_COLOR 0 +#endif + +// COMP_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef COMP_CONFIG_DEBUG_COLOR +#define COMP_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// GPIOTE_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef GPIOTE_CONFIG_LOG_ENABLED +#define GPIOTE_CONFIG_LOG_ENABLED 0 +#endif +// GPIOTE_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef GPIOTE_CONFIG_LOG_LEVEL +#define GPIOTE_CONFIG_LOG_LEVEL 3 +#endif + +// GPIOTE_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef GPIOTE_CONFIG_INFO_COLOR +#define GPIOTE_CONFIG_INFO_COLOR 0 +#endif + +// GPIOTE_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef GPIOTE_CONFIG_DEBUG_COLOR +#define GPIOTE_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// LPCOMP_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef LPCOMP_CONFIG_LOG_ENABLED +#define LPCOMP_CONFIG_LOG_ENABLED 0 +#endif +// LPCOMP_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef LPCOMP_CONFIG_LOG_LEVEL +#define LPCOMP_CONFIG_LOG_LEVEL 3 +#endif + +// LPCOMP_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef LPCOMP_CONFIG_INFO_COLOR +#define LPCOMP_CONFIG_INFO_COLOR 0 +#endif + +// LPCOMP_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef LPCOMP_CONFIG_DEBUG_COLOR +#define LPCOMP_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// MAX3421E_HOST_CONFIG_LOG_ENABLED - Enable logging in the module +//========================================================== +#ifndef MAX3421E_HOST_CONFIG_LOG_ENABLED +#define MAX3421E_HOST_CONFIG_LOG_ENABLED 0 +#endif +// MAX3421E_HOST_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef MAX3421E_HOST_CONFIG_LOG_LEVEL +#define MAX3421E_HOST_CONFIG_LOG_LEVEL 3 +#endif + +// MAX3421E_HOST_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef MAX3421E_HOST_CONFIG_INFO_COLOR +#define MAX3421E_HOST_CONFIG_INFO_COLOR 0 +#endif + +// MAX3421E_HOST_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef MAX3421E_HOST_CONFIG_DEBUG_COLOR +#define MAX3421E_HOST_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRFX_USBD_CONFIG_LOG_ENABLED - Enable logging in the module +//========================================================== +#ifndef NRFX_USBD_CONFIG_LOG_ENABLED +#define NRFX_USBD_CONFIG_LOG_ENABLED 0 +#endif +// NRFX_USBD_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRFX_USBD_CONFIG_LOG_LEVEL +#define NRFX_USBD_CONFIG_LOG_LEVEL 3 +#endif + +// NRFX_USBD_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_USBD_CONFIG_INFO_COLOR +#define NRFX_USBD_CONFIG_INFO_COLOR 0 +#endif + +// NRFX_USBD_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRFX_USBD_CONFIG_DEBUG_COLOR +#define NRFX_USBD_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// PDM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef PDM_CONFIG_LOG_ENABLED +#define PDM_CONFIG_LOG_ENABLED 0 +#endif +// PDM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef PDM_CONFIG_LOG_LEVEL +#define PDM_CONFIG_LOG_LEVEL 3 +#endif + +// PDM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PDM_CONFIG_INFO_COLOR +#define PDM_CONFIG_INFO_COLOR 0 +#endif + +// PDM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PDM_CONFIG_DEBUG_COLOR +#define PDM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// PPI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef PPI_CONFIG_LOG_ENABLED +#define PPI_CONFIG_LOG_ENABLED 0 +#endif +// PPI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef PPI_CONFIG_LOG_LEVEL +#define PPI_CONFIG_LOG_LEVEL 3 +#endif + +// PPI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PPI_CONFIG_INFO_COLOR +#define PPI_CONFIG_INFO_COLOR 0 +#endif + +// PPI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PPI_CONFIG_DEBUG_COLOR +#define PPI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// PWM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef PWM_CONFIG_LOG_ENABLED +#define PWM_CONFIG_LOG_ENABLED 0 +#endif +// PWM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef PWM_CONFIG_LOG_LEVEL +#define PWM_CONFIG_LOG_LEVEL 3 +#endif + +// PWM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PWM_CONFIG_INFO_COLOR +#define PWM_CONFIG_INFO_COLOR 0 +#endif + +// PWM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PWM_CONFIG_DEBUG_COLOR +#define PWM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// QDEC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef QDEC_CONFIG_LOG_ENABLED +#define QDEC_CONFIG_LOG_ENABLED 0 +#endif +// QDEC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef QDEC_CONFIG_LOG_LEVEL +#define QDEC_CONFIG_LOG_LEVEL 3 +#endif + +// QDEC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef QDEC_CONFIG_INFO_COLOR +#define QDEC_CONFIG_INFO_COLOR 0 +#endif + +// QDEC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef QDEC_CONFIG_DEBUG_COLOR +#define QDEC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// RNG_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef RNG_CONFIG_LOG_ENABLED +#define RNG_CONFIG_LOG_ENABLED 0 +#endif +// RNG_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef RNG_CONFIG_LOG_LEVEL +#define RNG_CONFIG_LOG_LEVEL 3 +#endif + +// RNG_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef RNG_CONFIG_INFO_COLOR +#define RNG_CONFIG_INFO_COLOR 0 +#endif + +// RNG_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef RNG_CONFIG_DEBUG_COLOR +#define RNG_CONFIG_DEBUG_COLOR 0 +#endif + +// RNG_CONFIG_RANDOM_NUMBER_LOG_ENABLED - Enables logging of random numbers. + + +#ifndef RNG_CONFIG_RANDOM_NUMBER_LOG_ENABLED +#define RNG_CONFIG_RANDOM_NUMBER_LOG_ENABLED 0 +#endif + +// + +// RTC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef RTC_CONFIG_LOG_ENABLED +#define RTC_CONFIG_LOG_ENABLED 0 +#endif +// RTC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef RTC_CONFIG_LOG_LEVEL +#define RTC_CONFIG_LOG_LEVEL 3 +#endif + +// RTC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef RTC_CONFIG_INFO_COLOR +#define RTC_CONFIG_INFO_COLOR 0 +#endif + +// RTC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef RTC_CONFIG_DEBUG_COLOR +#define RTC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// SAADC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef SAADC_CONFIG_LOG_ENABLED +#define SAADC_CONFIG_LOG_ENABLED 0 +#endif +// SAADC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef SAADC_CONFIG_LOG_LEVEL +#define SAADC_CONFIG_LOG_LEVEL 3 +#endif + +// SAADC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SAADC_CONFIG_INFO_COLOR +#define SAADC_CONFIG_INFO_COLOR 0 +#endif + +// SAADC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SAADC_CONFIG_DEBUG_COLOR +#define SAADC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// SPIS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef SPIS_CONFIG_LOG_ENABLED +#define SPIS_CONFIG_LOG_ENABLED 0 +#endif +// SPIS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef SPIS_CONFIG_LOG_LEVEL +#define SPIS_CONFIG_LOG_LEVEL 3 +#endif + +// SPIS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SPIS_CONFIG_INFO_COLOR +#define SPIS_CONFIG_INFO_COLOR 0 +#endif + +// SPIS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SPIS_CONFIG_DEBUG_COLOR +#define SPIS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// SPI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef SPI_CONFIG_LOG_ENABLED +#define SPI_CONFIG_LOG_ENABLED 0 +#endif +// SPI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef SPI_CONFIG_LOG_LEVEL +#define SPI_CONFIG_LOG_LEVEL 3 +#endif + +// SPI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SPI_CONFIG_INFO_COLOR +#define SPI_CONFIG_INFO_COLOR 0 +#endif + +// SPI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SPI_CONFIG_DEBUG_COLOR +#define SPI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// TIMER_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef TIMER_CONFIG_LOG_ENABLED +#define TIMER_CONFIG_LOG_ENABLED 0 +#endif +// TIMER_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef TIMER_CONFIG_LOG_LEVEL +#define TIMER_CONFIG_LOG_LEVEL 3 +#endif + +// TIMER_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TIMER_CONFIG_INFO_COLOR +#define TIMER_CONFIG_INFO_COLOR 0 +#endif + +// TIMER_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TIMER_CONFIG_DEBUG_COLOR +#define TIMER_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// TWIS_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef TWIS_CONFIG_LOG_ENABLED +#define TWIS_CONFIG_LOG_ENABLED 0 +#endif +// TWIS_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef TWIS_CONFIG_LOG_LEVEL +#define TWIS_CONFIG_LOG_LEVEL 3 +#endif + +// TWIS_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TWIS_CONFIG_INFO_COLOR +#define TWIS_CONFIG_INFO_COLOR 0 +#endif + +// TWIS_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TWIS_CONFIG_DEBUG_COLOR +#define TWIS_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// TWI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef TWI_CONFIG_LOG_ENABLED +#define TWI_CONFIG_LOG_ENABLED 0 +#endif +// TWI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef TWI_CONFIG_LOG_LEVEL +#define TWI_CONFIG_LOG_LEVEL 3 +#endif + +// TWI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TWI_CONFIG_INFO_COLOR +#define TWI_CONFIG_INFO_COLOR 0 +#endif + +// TWI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef TWI_CONFIG_DEBUG_COLOR +#define TWI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// UART_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef UART_CONFIG_LOG_ENABLED +#define UART_CONFIG_LOG_ENABLED 0 +#endif +// UART_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef UART_CONFIG_LOG_LEVEL +#define UART_CONFIG_LOG_LEVEL 3 +#endif + +// UART_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef UART_CONFIG_INFO_COLOR +#define UART_CONFIG_INFO_COLOR 0 +#endif + +// UART_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef UART_CONFIG_DEBUG_COLOR +#define UART_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// USBD_CONFIG_LOG_ENABLED - Enable logging in the module +//========================================================== +#ifndef USBD_CONFIG_LOG_ENABLED +#define USBD_CONFIG_LOG_ENABLED 0 +#endif +// USBD_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef USBD_CONFIG_LOG_LEVEL +#define USBD_CONFIG_LOG_LEVEL 3 +#endif + +// USBD_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef USBD_CONFIG_INFO_COLOR +#define USBD_CONFIG_INFO_COLOR 0 +#endif + +// USBD_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef USBD_CONFIG_DEBUG_COLOR +#define USBD_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// WDT_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef WDT_CONFIG_LOG_ENABLED +#define WDT_CONFIG_LOG_ENABLED 0 +#endif +// WDT_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef WDT_CONFIG_LOG_LEVEL +#define WDT_CONFIG_LOG_LEVEL 3 +#endif + +// WDT_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef WDT_CONFIG_INFO_COLOR +#define WDT_CONFIG_INFO_COLOR 0 +#endif + +// WDT_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef WDT_CONFIG_DEBUG_COLOR +#define WDT_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// +//========================================================== + +// nrf_log in nRF_Libraries + +//========================================================== +// APP_BUTTON_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef APP_BUTTON_CONFIG_LOG_ENABLED +#define APP_BUTTON_CONFIG_LOG_ENABLED 0 +#endif +// APP_BUTTON_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_BUTTON_CONFIG_LOG_LEVEL +#define APP_BUTTON_CONFIG_LOG_LEVEL 3 +#endif + +// APP_BUTTON_CONFIG_INITIAL_LOG_LEVEL - Initial severity level if dynamic filtering is enabled. + + +// If module generates a lot of logs, initial log level can +// be decreased to prevent flooding. Severity level can be +// increased on instance basis. +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_BUTTON_CONFIG_INITIAL_LOG_LEVEL +#define APP_BUTTON_CONFIG_INITIAL_LOG_LEVEL 3 +#endif + +// APP_BUTTON_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_BUTTON_CONFIG_INFO_COLOR +#define APP_BUTTON_CONFIG_INFO_COLOR 0 +#endif + +// APP_BUTTON_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_BUTTON_CONFIG_DEBUG_COLOR +#define APP_BUTTON_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// APP_TIMER_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef APP_TIMER_CONFIG_LOG_ENABLED +#define APP_TIMER_CONFIG_LOG_ENABLED 0 +#endif +// APP_TIMER_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_TIMER_CONFIG_LOG_LEVEL +#define APP_TIMER_CONFIG_LOG_LEVEL 3 +#endif + +// APP_TIMER_CONFIG_INITIAL_LOG_LEVEL - Initial severity level if dynamic filtering is enabled. + + +// If module generates a lot of logs, initial log level can +// be decreased to prevent flooding. Severity level can be +// increased on instance basis. +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_TIMER_CONFIG_INITIAL_LOG_LEVEL +#define APP_TIMER_CONFIG_INITIAL_LOG_LEVEL 3 +#endif + +// APP_TIMER_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_TIMER_CONFIG_INFO_COLOR +#define APP_TIMER_CONFIG_INFO_COLOR 0 +#endif + +// APP_TIMER_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_TIMER_CONFIG_DEBUG_COLOR +#define APP_TIMER_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// APP_USBD_CDC_ACM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef APP_USBD_CDC_ACM_CONFIG_LOG_ENABLED +#define APP_USBD_CDC_ACM_CONFIG_LOG_ENABLED 0 +#endif +// APP_USBD_CDC_ACM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_USBD_CDC_ACM_CONFIG_LOG_LEVEL +#define APP_USBD_CDC_ACM_CONFIG_LOG_LEVEL 3 +#endif + +// APP_USBD_CDC_ACM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_CDC_ACM_CONFIG_INFO_COLOR +#define APP_USBD_CDC_ACM_CONFIG_INFO_COLOR 0 +#endif + +// APP_USBD_CDC_ACM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_CDC_ACM_CONFIG_DEBUG_COLOR +#define APP_USBD_CDC_ACM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// APP_USBD_CONFIG_LOG_ENABLED - Enable logging in the module. +//========================================================== +#ifndef APP_USBD_CONFIG_LOG_ENABLED +#define APP_USBD_CONFIG_LOG_ENABLED 0 +#endif +// APP_USBD_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_USBD_CONFIG_LOG_LEVEL +#define APP_USBD_CONFIG_LOG_LEVEL 3 +#endif + +// APP_USBD_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_CONFIG_INFO_COLOR +#define APP_USBD_CONFIG_INFO_COLOR 0 +#endif + +// APP_USBD_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_CONFIG_DEBUG_COLOR +#define APP_USBD_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// APP_USBD_DUMMY_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef APP_USBD_DUMMY_CONFIG_LOG_ENABLED +#define APP_USBD_DUMMY_CONFIG_LOG_ENABLED 0 +#endif +// APP_USBD_DUMMY_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_USBD_DUMMY_CONFIG_LOG_LEVEL +#define APP_USBD_DUMMY_CONFIG_LOG_LEVEL 3 +#endif + +// APP_USBD_DUMMY_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_DUMMY_CONFIG_INFO_COLOR +#define APP_USBD_DUMMY_CONFIG_INFO_COLOR 0 +#endif + +// APP_USBD_DUMMY_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_DUMMY_CONFIG_DEBUG_COLOR +#define APP_USBD_DUMMY_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// APP_USBD_MSC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef APP_USBD_MSC_CONFIG_LOG_ENABLED +#define APP_USBD_MSC_CONFIG_LOG_ENABLED 0 +#endif +// APP_USBD_MSC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_USBD_MSC_CONFIG_LOG_LEVEL +#define APP_USBD_MSC_CONFIG_LOG_LEVEL 3 +#endif + +// APP_USBD_MSC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_MSC_CONFIG_INFO_COLOR +#define APP_USBD_MSC_CONFIG_INFO_COLOR 0 +#endif + +// APP_USBD_MSC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_MSC_CONFIG_DEBUG_COLOR +#define APP_USBD_MSC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// APP_USBD_NRF_DFU_TRIGGER_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef APP_USBD_NRF_DFU_TRIGGER_CONFIG_LOG_ENABLED +#define APP_USBD_NRF_DFU_TRIGGER_CONFIG_LOG_ENABLED 0 +#endif +// APP_USBD_NRF_DFU_TRIGGER_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef APP_USBD_NRF_DFU_TRIGGER_CONFIG_LOG_LEVEL +#define APP_USBD_NRF_DFU_TRIGGER_CONFIG_LOG_LEVEL 3 +#endif + +// APP_USBD_NRF_DFU_TRIGGER_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_NRF_DFU_TRIGGER_CONFIG_INFO_COLOR +#define APP_USBD_NRF_DFU_TRIGGER_CONFIG_INFO_COLOR 0 +#endif + +// APP_USBD_NRF_DFU_TRIGGER_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef APP_USBD_NRF_DFU_TRIGGER_CONFIG_DEBUG_COLOR +#define APP_USBD_NRF_DFU_TRIGGER_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_ATFIFO_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_ATFIFO_CONFIG_LOG_ENABLED +#define NRF_ATFIFO_CONFIG_LOG_ENABLED 0 +#endif +// NRF_ATFIFO_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_ATFIFO_CONFIG_LOG_LEVEL +#define NRF_ATFIFO_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_ATFIFO_CONFIG_LOG_INIT_FILTER_LEVEL - Initial severity level if dynamic filtering is enabled + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_ATFIFO_CONFIG_LOG_INIT_FILTER_LEVEL +#define NRF_ATFIFO_CONFIG_LOG_INIT_FILTER_LEVEL 3 +#endif + +// NRF_ATFIFO_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_ATFIFO_CONFIG_INFO_COLOR +#define NRF_ATFIFO_CONFIG_INFO_COLOR 0 +#endif + +// NRF_ATFIFO_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_ATFIFO_CONFIG_DEBUG_COLOR +#define NRF_ATFIFO_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_BALLOC_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_BALLOC_CONFIG_LOG_ENABLED +#define NRF_BALLOC_CONFIG_LOG_ENABLED 0 +#endif +// NRF_BALLOC_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BALLOC_CONFIG_LOG_LEVEL +#define NRF_BALLOC_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_BALLOC_CONFIG_INITIAL_LOG_LEVEL - Initial severity level if dynamic filtering is enabled. + + +// If module generates a lot of logs, initial log level can +// be decreased to prevent flooding. Severity level can be +// increased on instance basis. +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BALLOC_CONFIG_INITIAL_LOG_LEVEL +#define NRF_BALLOC_CONFIG_INITIAL_LOG_LEVEL 3 +#endif + +// NRF_BALLOC_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BALLOC_CONFIG_INFO_COLOR +#define NRF_BALLOC_CONFIG_INFO_COLOR 0 +#endif + +// NRF_BALLOC_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BALLOC_CONFIG_DEBUG_COLOR +#define NRF_BALLOC_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_ENABLED +#define NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_ENABLED 0 +#endif +// NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_LEVEL +#define NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_INIT_FILTER_LEVEL - Initial severity level if dynamic filtering is enabled + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_INIT_FILTER_LEVEL +#define NRF_BLOCK_DEV_EMPTY_CONFIG_LOG_INIT_FILTER_LEVEL 3 +#endif + +// NRF_BLOCK_DEV_EMPTY_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BLOCK_DEV_EMPTY_CONFIG_INFO_COLOR +#define NRF_BLOCK_DEV_EMPTY_CONFIG_INFO_COLOR 0 +#endif + +// NRF_BLOCK_DEV_EMPTY_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BLOCK_DEV_EMPTY_CONFIG_DEBUG_COLOR +#define NRF_BLOCK_DEV_EMPTY_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_BLOCK_DEV_QSPI_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_BLOCK_DEV_QSPI_CONFIG_LOG_ENABLED +#define NRF_BLOCK_DEV_QSPI_CONFIG_LOG_ENABLED 0 +#endif +// NRF_BLOCK_DEV_QSPI_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BLOCK_DEV_QSPI_CONFIG_LOG_LEVEL +#define NRF_BLOCK_DEV_QSPI_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_BLOCK_DEV_QSPI_CONFIG_LOG_INIT_FILTER_LEVEL - Initial severity level if dynamic filtering is enabled + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BLOCK_DEV_QSPI_CONFIG_LOG_INIT_FILTER_LEVEL +#define NRF_BLOCK_DEV_QSPI_CONFIG_LOG_INIT_FILTER_LEVEL 3 +#endif + +// NRF_BLOCK_DEV_QSPI_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BLOCK_DEV_QSPI_CONFIG_INFO_COLOR +#define NRF_BLOCK_DEV_QSPI_CONFIG_INFO_COLOR 0 +#endif + +// NRF_BLOCK_DEV_QSPI_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BLOCK_DEV_QSPI_CONFIG_DEBUG_COLOR +#define NRF_BLOCK_DEV_QSPI_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_BLOCK_DEV_RAM_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_BLOCK_DEV_RAM_CONFIG_LOG_ENABLED +#define NRF_BLOCK_DEV_RAM_CONFIG_LOG_ENABLED 0 +#endif +// NRF_BLOCK_DEV_RAM_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BLOCK_DEV_RAM_CONFIG_LOG_LEVEL +#define NRF_BLOCK_DEV_RAM_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_BLOCK_DEV_RAM_CONFIG_LOG_INIT_FILTER_LEVEL - Initial severity level if dynamic filtering is enabled + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_BLOCK_DEV_RAM_CONFIG_LOG_INIT_FILTER_LEVEL +#define NRF_BLOCK_DEV_RAM_CONFIG_LOG_INIT_FILTER_LEVEL 3 +#endif + +// NRF_BLOCK_DEV_RAM_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BLOCK_DEV_RAM_CONFIG_INFO_COLOR +#define NRF_BLOCK_DEV_RAM_CONFIG_INFO_COLOR 0 +#endif + +// NRF_BLOCK_DEV_RAM_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_BLOCK_DEV_RAM_CONFIG_DEBUG_COLOR +#define NRF_BLOCK_DEV_RAM_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_CLI_BLE_UART_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_CLI_BLE_UART_CONFIG_LOG_ENABLED +#define NRF_CLI_BLE_UART_CONFIG_LOG_ENABLED 0 +#endif +// NRF_CLI_BLE_UART_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_CLI_BLE_UART_CONFIG_LOG_LEVEL +#define NRF_CLI_BLE_UART_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_CLI_BLE_UART_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_CLI_BLE_UART_CONFIG_INFO_COLOR +#define NRF_CLI_BLE_UART_CONFIG_INFO_COLOR 0 +#endif + +// NRF_CLI_BLE_UART_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_CLI_BLE_UART_CONFIG_DEBUG_COLOR +#define NRF_CLI_BLE_UART_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_CLI_LIBUARTE_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_CLI_LIBUARTE_CONFIG_LOG_ENABLED +#define NRF_CLI_LIBUARTE_CONFIG_LOG_ENABLED 0 +#endif +// NRF_CLI_LIBUARTE_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_CLI_LIBUARTE_CONFIG_LOG_LEVEL +#define NRF_CLI_LIBUARTE_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_CLI_LIBUARTE_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_CLI_LIBUARTE_CONFIG_INFO_COLOR +#define NRF_CLI_LIBUARTE_CONFIG_INFO_COLOR 0 +#endif + +// NRF_CLI_LIBUARTE_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_CLI_LIBUARTE_CONFIG_DEBUG_COLOR +#define NRF_CLI_LIBUARTE_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_CLI_UART_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_CLI_UART_CONFIG_LOG_ENABLED +#define NRF_CLI_UART_CONFIG_LOG_ENABLED 0 +#endif +// NRF_CLI_UART_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_CLI_UART_CONFIG_LOG_LEVEL +#define NRF_CLI_UART_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_CLI_UART_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_CLI_UART_CONFIG_INFO_COLOR +#define NRF_CLI_UART_CONFIG_INFO_COLOR 0 +#endif + +// NRF_CLI_UART_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_CLI_UART_CONFIG_DEBUG_COLOR +#define NRF_CLI_UART_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_LIBUARTE_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_LIBUARTE_CONFIG_LOG_ENABLED +#define NRF_LIBUARTE_CONFIG_LOG_ENABLED 0 +#endif +// NRF_LIBUARTE_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_LIBUARTE_CONFIG_LOG_LEVEL +#define NRF_LIBUARTE_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_LIBUARTE_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_LIBUARTE_CONFIG_INFO_COLOR +#define NRF_LIBUARTE_CONFIG_INFO_COLOR 0 +#endif + +// NRF_LIBUARTE_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_LIBUARTE_CONFIG_DEBUG_COLOR +#define NRF_LIBUARTE_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_MEMOBJ_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_MEMOBJ_CONFIG_LOG_ENABLED +#define NRF_MEMOBJ_CONFIG_LOG_ENABLED 0 +#endif +// NRF_MEMOBJ_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_MEMOBJ_CONFIG_LOG_LEVEL +#define NRF_MEMOBJ_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_MEMOBJ_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_MEMOBJ_CONFIG_INFO_COLOR +#define NRF_MEMOBJ_CONFIG_INFO_COLOR 0 +#endif + +// NRF_MEMOBJ_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_MEMOBJ_CONFIG_DEBUG_COLOR +#define NRF_MEMOBJ_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_PWR_MGMT_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_PWR_MGMT_CONFIG_LOG_ENABLED +#define NRF_PWR_MGMT_CONFIG_LOG_ENABLED 0 +#endif +// NRF_PWR_MGMT_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_PWR_MGMT_CONFIG_LOG_LEVEL +#define NRF_PWR_MGMT_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_PWR_MGMT_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_PWR_MGMT_CONFIG_INFO_COLOR +#define NRF_PWR_MGMT_CONFIG_INFO_COLOR 0 +#endif + +// NRF_PWR_MGMT_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_PWR_MGMT_CONFIG_DEBUG_COLOR +#define NRF_PWR_MGMT_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_QUEUE_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_QUEUE_CONFIG_LOG_ENABLED +#define NRF_QUEUE_CONFIG_LOG_ENABLED 0 +#endif +// NRF_QUEUE_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_QUEUE_CONFIG_LOG_LEVEL +#define NRF_QUEUE_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_QUEUE_CONFIG_LOG_INIT_FILTER_LEVEL - Initial severity level if dynamic filtering is enabled + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_QUEUE_CONFIG_LOG_INIT_FILTER_LEVEL +#define NRF_QUEUE_CONFIG_LOG_INIT_FILTER_LEVEL 3 +#endif + +// NRF_QUEUE_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_QUEUE_CONFIG_INFO_COLOR +#define NRF_QUEUE_CONFIG_INFO_COLOR 0 +#endif + +// NRF_QUEUE_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_QUEUE_CONFIG_DEBUG_COLOR +#define NRF_QUEUE_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_SDH_ANT_LOG_ENABLED - Enable logging in SoftDevice handler (ANT) module. +//========================================================== +#ifndef NRF_SDH_ANT_LOG_ENABLED +#define NRF_SDH_ANT_LOG_ENABLED 0 +#endif +// NRF_SDH_ANT_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_SDH_ANT_LOG_LEVEL +#define NRF_SDH_ANT_LOG_LEVEL 3 +#endif + +// NRF_SDH_ANT_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_ANT_INFO_COLOR +#define NRF_SDH_ANT_INFO_COLOR 0 +#endif + +// NRF_SDH_ANT_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_ANT_DEBUG_COLOR +#define NRF_SDH_ANT_DEBUG_COLOR 0 +#endif + +// + +// NRF_SDH_BLE_LOG_ENABLED - Enable logging in SoftDevice handler (BLE) module. +//========================================================== +#ifndef NRF_SDH_BLE_LOG_ENABLED +#define NRF_SDH_BLE_LOG_ENABLED 1 +#endif +// NRF_SDH_BLE_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_SDH_BLE_LOG_LEVEL +#define NRF_SDH_BLE_LOG_LEVEL 3 +#endif + +// NRF_SDH_BLE_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_BLE_INFO_COLOR +#define NRF_SDH_BLE_INFO_COLOR 0 +#endif + +// NRF_SDH_BLE_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_BLE_DEBUG_COLOR +#define NRF_SDH_BLE_DEBUG_COLOR 0 +#endif + +// + +// NRF_SDH_LOG_ENABLED - Enable logging in SoftDevice handler module. +//========================================================== +#ifndef NRF_SDH_LOG_ENABLED +#define NRF_SDH_LOG_ENABLED 1 +#endif +// NRF_SDH_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_SDH_LOG_LEVEL +#define NRF_SDH_LOG_LEVEL 3 +#endif + +// NRF_SDH_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_INFO_COLOR +#define NRF_SDH_INFO_COLOR 0 +#endif + +// NRF_SDH_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_DEBUG_COLOR +#define NRF_SDH_DEBUG_COLOR 0 +#endif + +// + +// NRF_SDH_SOC_LOG_ENABLED - Enable logging in SoftDevice handler (SoC) module. +//========================================================== +#ifndef NRF_SDH_SOC_LOG_ENABLED +#define NRF_SDH_SOC_LOG_ENABLED 1 +#endif +// NRF_SDH_SOC_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_SDH_SOC_LOG_LEVEL +#define NRF_SDH_SOC_LOG_LEVEL 3 +#endif + +// NRF_SDH_SOC_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_SOC_INFO_COLOR +#define NRF_SDH_SOC_INFO_COLOR 0 +#endif + +// NRF_SDH_SOC_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SDH_SOC_DEBUG_COLOR +#define NRF_SDH_SOC_DEBUG_COLOR 0 +#endif + +// + +// NRF_SORTLIST_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_SORTLIST_CONFIG_LOG_ENABLED +#define NRF_SORTLIST_CONFIG_LOG_ENABLED 0 +#endif +// NRF_SORTLIST_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_SORTLIST_CONFIG_LOG_LEVEL +#define NRF_SORTLIST_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_SORTLIST_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SORTLIST_CONFIG_INFO_COLOR +#define NRF_SORTLIST_CONFIG_INFO_COLOR 0 +#endif + +// NRF_SORTLIST_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_SORTLIST_CONFIG_DEBUG_COLOR +#define NRF_SORTLIST_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// NRF_TWI_SENSOR_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NRF_TWI_SENSOR_CONFIG_LOG_ENABLED +#define NRF_TWI_SENSOR_CONFIG_LOG_ENABLED 0 +#endif +// NRF_TWI_SENSOR_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NRF_TWI_SENSOR_CONFIG_LOG_LEVEL +#define NRF_TWI_SENSOR_CONFIG_LOG_LEVEL 3 +#endif + +// NRF_TWI_SENSOR_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_TWI_SENSOR_CONFIG_INFO_COLOR +#define NRF_TWI_SENSOR_CONFIG_INFO_COLOR 0 +#endif + +// NRF_TWI_SENSOR_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NRF_TWI_SENSOR_CONFIG_DEBUG_COLOR +#define NRF_TWI_SENSOR_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// PM_LOG_ENABLED - Enable logging in Peer Manager and its submodules. +//========================================================== +#ifndef PM_LOG_ENABLED +#define PM_LOG_ENABLED 1 +#endif +// PM_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef PM_LOG_LEVEL +#define PM_LOG_LEVEL 3 +#endif + +// PM_LOG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PM_LOG_INFO_COLOR +#define PM_LOG_INFO_COLOR 0 +#endif + +// PM_LOG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef PM_LOG_DEBUG_COLOR +#define PM_LOG_DEBUG_COLOR 0 +#endif + +// + +// +//========================================================== + +// nrf_log in nRF_Serialization + +//========================================================== +// SER_HAL_TRANSPORT_CONFIG_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef SER_HAL_TRANSPORT_CONFIG_LOG_ENABLED +#define SER_HAL_TRANSPORT_CONFIG_LOG_ENABLED 0 +#endif +// SER_HAL_TRANSPORT_CONFIG_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef SER_HAL_TRANSPORT_CONFIG_LOG_LEVEL +#define SER_HAL_TRANSPORT_CONFIG_LOG_LEVEL 3 +#endif + +// SER_HAL_TRANSPORT_CONFIG_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SER_HAL_TRANSPORT_CONFIG_INFO_COLOR +#define SER_HAL_TRANSPORT_CONFIG_INFO_COLOR 0 +#endif + +// SER_HAL_TRANSPORT_CONFIG_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef SER_HAL_TRANSPORT_CONFIG_DEBUG_COLOR +#define SER_HAL_TRANSPORT_CONFIG_DEBUG_COLOR 0 +#endif + +// + +// +//========================================================== + +// +//========================================================== + +// + +// NRF_LOG_STR_FORMATTER_TIMESTAMP_FORMAT_ENABLED - nrf_log_str_formatter - Log string formatter + + +#ifndef NRF_LOG_STR_FORMATTER_TIMESTAMP_FORMAT_ENABLED +#define NRF_LOG_STR_FORMATTER_TIMESTAMP_FORMAT_ENABLED 1 +#endif + +// +//========================================================== + +// nRF_NFC + +//========================================================== +// NFC_AC_REC_ENABLED - nfc_ac_rec - NFC NDEF Alternative Carrier record encoder + + +#ifndef NFC_AC_REC_ENABLED +#define NFC_AC_REC_ENABLED 0 +#endif + +// NFC_AC_REC_PARSER_ENABLED - nfc_ac_rec_parser - Alternative Carrier record parser + + +#ifndef NFC_AC_REC_PARSER_ENABLED +#define NFC_AC_REC_PARSER_ENABLED 0 +#endif + +// NFC_BLE_OOB_ADVDATA_ENABLED - nfc_ble_oob_advdata - AD data for OOB pairing encoder +//========================================================== +#ifndef NFC_BLE_OOB_ADVDATA_ENABLED +#define NFC_BLE_OOB_ADVDATA_ENABLED 0 +#endif +// ADVANCED_ADVDATA_SUPPORT - Non-mandatory AD types for BLE OOB pairing are encoded inside the NDEF message (e.g. service UUIDs) + +// <1=> Enabled +// <0=> Disabled + +#ifndef ADVANCED_ADVDATA_SUPPORT +#define ADVANCED_ADVDATA_SUPPORT 0 +#endif + +// + +// NFC_BLE_OOB_ADVDATA_PARSER_ENABLED - nfc_ble_oob_advdata_parser - BLE OOB pairing AD data parser + + +#ifndef NFC_BLE_OOB_ADVDATA_PARSER_ENABLED +#define NFC_BLE_OOB_ADVDATA_PARSER_ENABLED 0 +#endif + +// NFC_BLE_PAIR_LIB_ENABLED - nfc_ble_pair_lib - Library parameters +//========================================================== +#ifndef NFC_BLE_PAIR_LIB_ENABLED +#define NFC_BLE_PAIR_LIB_ENABLED 0 +#endif +// NFC_BLE_PAIR_LIB_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_BLE_PAIR_LIB_LOG_ENABLED +#define NFC_BLE_PAIR_LIB_LOG_ENABLED 0 +#endif +// NFC_BLE_PAIR_LIB_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_BLE_PAIR_LIB_LOG_LEVEL +#define NFC_BLE_PAIR_LIB_LOG_LEVEL 3 +#endif + +// NFC_BLE_PAIR_LIB_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_BLE_PAIR_LIB_INFO_COLOR +#define NFC_BLE_PAIR_LIB_INFO_COLOR 0 +#endif + +// NFC_BLE_PAIR_LIB_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_BLE_PAIR_LIB_DEBUG_COLOR +#define NFC_BLE_PAIR_LIB_DEBUG_COLOR 0 +#endif + +// + +// NFC_BLE_PAIR_LIB_SECURITY_PARAMETERS - Common Peer Manager security parameters. + +//========================================================== +// BLE_NFC_SEC_PARAM_BOND - Enables device bonding. + +// If bonding is enabled at least one of the BLE_NFC_SEC_PARAM_KDIST options must be enabled. +//========================================================== +#ifndef BLE_NFC_SEC_PARAM_BOND +#define BLE_NFC_SEC_PARAM_BOND 1 +#endif +// BLE_NFC_SEC_PARAM_KDIST_OWN_ENC - Enables Long Term Key and Master Identification distribution by device. + + +#ifndef BLE_NFC_SEC_PARAM_KDIST_OWN_ENC +#define BLE_NFC_SEC_PARAM_KDIST_OWN_ENC 1 +#endif + +// BLE_NFC_SEC_PARAM_KDIST_OWN_ID - Enables Identity Resolving Key and Identity Address Information distribution by device. + + +#ifndef BLE_NFC_SEC_PARAM_KDIST_OWN_ID +#define BLE_NFC_SEC_PARAM_KDIST_OWN_ID 1 +#endif + +// BLE_NFC_SEC_PARAM_KDIST_PEER_ENC - Enables Long Term Key and Master Identification distribution by peer. + + +#ifndef BLE_NFC_SEC_PARAM_KDIST_PEER_ENC +#define BLE_NFC_SEC_PARAM_KDIST_PEER_ENC 1 +#endif + +// BLE_NFC_SEC_PARAM_KDIST_PEER_ID - Enables Identity Resolving Key and Identity Address Information distribution by peer. + + +#ifndef BLE_NFC_SEC_PARAM_KDIST_PEER_ID +#define BLE_NFC_SEC_PARAM_KDIST_PEER_ID 1 +#endif + +// + +// BLE_NFC_SEC_PARAM_MIN_KEY_SIZE - Minimal size of a security key. + +// <7=> 7 +// <8=> 8 +// <9=> 9 +// <10=> 10 +// <11=> 11 +// <12=> 12 +// <13=> 13 +// <14=> 14 +// <15=> 15 +// <16=> 16 + +#ifndef BLE_NFC_SEC_PARAM_MIN_KEY_SIZE +#define BLE_NFC_SEC_PARAM_MIN_KEY_SIZE 7 +#endif + +// BLE_NFC_SEC_PARAM_MAX_KEY_SIZE - Maximal size of a security key. + +// <7=> 7 +// <8=> 8 +// <9=> 9 +// <10=> 10 +// <11=> 11 +// <12=> 12 +// <13=> 13 +// <14=> 14 +// <15=> 15 +// <16=> 16 + +#ifndef BLE_NFC_SEC_PARAM_MAX_KEY_SIZE +#define BLE_NFC_SEC_PARAM_MAX_KEY_SIZE 16 +#endif + +// +//========================================================== + +// + +// NFC_BLE_PAIR_MSG_ENABLED - nfc_ble_pair_msg - NDEF message for OOB pairing encoder + + +#ifndef NFC_BLE_PAIR_MSG_ENABLED +#define NFC_BLE_PAIR_MSG_ENABLED 0 +#endif + +// NFC_CH_COMMON_ENABLED - nfc_ble_pair_common - OOB pairing common data + + +#ifndef NFC_CH_COMMON_ENABLED +#define NFC_CH_COMMON_ENABLED 0 +#endif + +// NFC_EP_OOB_REC_ENABLED - nfc_ep_oob_rec - EP record for BLE pairing encoder + + +#ifndef NFC_EP_OOB_REC_ENABLED +#define NFC_EP_OOB_REC_ENABLED 0 +#endif + +// NFC_HS_REC_ENABLED - nfc_hs_rec - Handover Select NDEF record encoder + + +#ifndef NFC_HS_REC_ENABLED +#define NFC_HS_REC_ENABLED 0 +#endif + +// NFC_LE_OOB_REC_ENABLED - nfc_le_oob_rec - LE record for BLE pairing encoder + + +#ifndef NFC_LE_OOB_REC_ENABLED +#define NFC_LE_OOB_REC_ENABLED 0 +#endif + +// NFC_LE_OOB_REC_PARSER_ENABLED - nfc_le_oob_rec_parser - LE record parser + + +#ifndef NFC_LE_OOB_REC_PARSER_ENABLED +#define NFC_LE_OOB_REC_PARSER_ENABLED 0 +#endif + +// NFC_NDEF_LAUNCHAPP_MSG_ENABLED - nfc_launchapp_msg - Encoding data for NDEF Application Launching message for NFC Tag + + +#ifndef NFC_NDEF_LAUNCHAPP_MSG_ENABLED +#define NFC_NDEF_LAUNCHAPP_MSG_ENABLED 0 +#endif + +// NFC_NDEF_LAUNCHAPP_REC_ENABLED - nfc_launchapp_rec - Encoding data for NDEF Application Launching record for NFC Tag + + +#ifndef NFC_NDEF_LAUNCHAPP_REC_ENABLED +#define NFC_NDEF_LAUNCHAPP_REC_ENABLED 0 +#endif + +// NFC_NDEF_MSG_ENABLED - nfc_ndef_msg - NFC NDEF Message generator module +//========================================================== +#ifndef NFC_NDEF_MSG_ENABLED +#define NFC_NDEF_MSG_ENABLED 0 +#endif +// NFC_NDEF_MSG_TAG_TYPE - NFC Tag Type + +// <2=> Type 2 Tag +// <4=> Type 4 Tag + +#ifndef NFC_NDEF_MSG_TAG_TYPE +#define NFC_NDEF_MSG_TAG_TYPE 2 +#endif + +// + +// NFC_NDEF_MSG_PARSER_ENABLED - nfc_ndef_msg_parser - NFC NDEF message parser module +//========================================================== +#ifndef NFC_NDEF_MSG_PARSER_ENABLED +#define NFC_NDEF_MSG_PARSER_ENABLED 0 +#endif +// NFC_NDEF_MSG_PARSER_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_NDEF_MSG_PARSER_LOG_ENABLED +#define NFC_NDEF_MSG_PARSER_LOG_ENABLED 0 +#endif +// NFC_NDEF_MSG_PARSER_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_NDEF_MSG_PARSER_LOG_LEVEL +#define NFC_NDEF_MSG_PARSER_LOG_LEVEL 3 +#endif + +// NFC_NDEF_MSG_PARSER_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_NDEF_MSG_PARSER_INFO_COLOR +#define NFC_NDEF_MSG_PARSER_INFO_COLOR 0 +#endif + +// + +// + +// NFC_NDEF_RECORD_ENABLED - nfc_ndef_record - NFC NDEF Record generator module + + +#ifndef NFC_NDEF_RECORD_ENABLED +#define NFC_NDEF_RECORD_ENABLED 0 +#endif + +// NFC_NDEF_RECORD_PARSER_ENABLED - nfc_ndef_record_parser - NFC NDEF Record parser module +//========================================================== +#ifndef NFC_NDEF_RECORD_PARSER_ENABLED +#define NFC_NDEF_RECORD_PARSER_ENABLED 0 +#endif +// NFC_NDEF_RECORD_PARSER_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_NDEF_RECORD_PARSER_LOG_ENABLED +#define NFC_NDEF_RECORD_PARSER_LOG_ENABLED 0 +#endif +// NFC_NDEF_RECORD_PARSER_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_NDEF_RECORD_PARSER_LOG_LEVEL +#define NFC_NDEF_RECORD_PARSER_LOG_LEVEL 3 +#endif + +// NFC_NDEF_RECORD_PARSER_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_NDEF_RECORD_PARSER_INFO_COLOR +#define NFC_NDEF_RECORD_PARSER_INFO_COLOR 0 +#endif + +// + +// + +// NFC_NDEF_TEXT_RECORD_ENABLED - nfc_text_rec - Encoding data for a text record for NFC Tag + + +#ifndef NFC_NDEF_TEXT_RECORD_ENABLED +#define NFC_NDEF_TEXT_RECORD_ENABLED 0 +#endif + +// NFC_NDEF_URI_MSG_ENABLED - nfc_uri_msg - Encoding data for NDEF message with URI record for NFC Tag + + +#ifndef NFC_NDEF_URI_MSG_ENABLED +#define NFC_NDEF_URI_MSG_ENABLED 0 +#endif + +// NFC_NDEF_URI_REC_ENABLED - nfc_uri_rec - Encoding data for a URI record for NFC Tag + + +#ifndef NFC_NDEF_URI_REC_ENABLED +#define NFC_NDEF_URI_REC_ENABLED 0 +#endif + +// NFC_PLATFORM_ENABLED - nfc_platform - NFC platform module for Clock control. +//========================================================== +#ifndef NFC_PLATFORM_ENABLED +#define NFC_PLATFORM_ENABLED 0 +#endif +// NFC_PLATFORM_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_PLATFORM_LOG_ENABLED +#define NFC_PLATFORM_LOG_ENABLED 0 +#endif +// NFC_PLATFORM_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_PLATFORM_LOG_LEVEL +#define NFC_PLATFORM_LOG_LEVEL 3 +#endif + +// NFC_PLATFORM_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_PLATFORM_INFO_COLOR +#define NFC_PLATFORM_INFO_COLOR 0 +#endif + +// NFC_PLATFORM_DEBUG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_PLATFORM_DEBUG_COLOR +#define NFC_PLATFORM_DEBUG_COLOR 0 +#endif + +// + +// + +// NFC_T2T_PARSER_ENABLED - nfc_type_2_tag_parser - Parser for decoding Type 2 Tag data +//========================================================== +#ifndef NFC_T2T_PARSER_ENABLED +#define NFC_T2T_PARSER_ENABLED 0 +#endif +// NFC_T2T_PARSER_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_T2T_PARSER_LOG_ENABLED +#define NFC_T2T_PARSER_LOG_ENABLED 0 +#endif +// NFC_T2T_PARSER_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_T2T_PARSER_LOG_LEVEL +#define NFC_T2T_PARSER_LOG_LEVEL 3 +#endif + +// NFC_T2T_PARSER_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_T2T_PARSER_INFO_COLOR +#define NFC_T2T_PARSER_INFO_COLOR 0 +#endif + +// + +// + +// NFC_T4T_APDU_ENABLED - nfc_t4t_apdu - APDU encoder/decoder for Type 4 Tag +//========================================================== +#ifndef NFC_T4T_APDU_ENABLED +#define NFC_T4T_APDU_ENABLED 0 +#endif +// NFC_T4T_APDU_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_T4T_APDU_LOG_ENABLED +#define NFC_T4T_APDU_LOG_ENABLED 0 +#endif +// NFC_T4T_APDU_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_T4T_APDU_LOG_LEVEL +#define NFC_T4T_APDU_LOG_LEVEL 3 +#endif + +// NFC_T4T_APDU_LOG_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_T4T_APDU_LOG_COLOR +#define NFC_T4T_APDU_LOG_COLOR 0 +#endif + +// + +// + +// NFC_T4T_CC_FILE_PARSER_ENABLED - nfc_t4t_cc_file - Capability Container file for Type 4 Tag +//========================================================== +#ifndef NFC_T4T_CC_FILE_PARSER_ENABLED +#define NFC_T4T_CC_FILE_PARSER_ENABLED 0 +#endif +// NFC_T4T_CC_FILE_PARSER_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_T4T_CC_FILE_PARSER_LOG_ENABLED +#define NFC_T4T_CC_FILE_PARSER_LOG_ENABLED 0 +#endif +// NFC_T4T_CC_FILE_PARSER_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_T4T_CC_FILE_PARSER_LOG_LEVEL +#define NFC_T4T_CC_FILE_PARSER_LOG_LEVEL 3 +#endif + +// NFC_T4T_CC_FILE_PARSER_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_T4T_CC_FILE_PARSER_INFO_COLOR +#define NFC_T4T_CC_FILE_PARSER_INFO_COLOR 0 +#endif + +// + +// + +// NFC_T4T_HL_DETECTION_PROCEDURES_ENABLED - nfc_t4t_hl_detection_procedures - NDEF Detection Procedure for Type 4 Tag +//========================================================== +#ifndef NFC_T4T_HL_DETECTION_PROCEDURES_ENABLED +#define NFC_T4T_HL_DETECTION_PROCEDURES_ENABLED 0 +#endif +// NFC_T4T_HL_DETECTION_PROCEDURES_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_T4T_HL_DETECTION_PROCEDURES_LOG_ENABLED +#define NFC_T4T_HL_DETECTION_PROCEDURES_LOG_ENABLED 0 +#endif +// NFC_T4T_HL_DETECTION_PROCEDURES_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_T4T_HL_DETECTION_PROCEDURES_LOG_LEVEL +#define NFC_T4T_HL_DETECTION_PROCEDURES_LOG_LEVEL 3 +#endif + +// NFC_T4T_HL_DETECTION_PROCEDURES_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_T4T_HL_DETECTION_PROCEDURES_INFO_COLOR +#define NFC_T4T_HL_DETECTION_PROCEDURES_INFO_COLOR 0 +#endif + +// + +// APDU_BUFF_SIZE - Size (in bytes) of the buffer for APDU storage +#ifndef APDU_BUFF_SIZE +#define APDU_BUFF_SIZE 250 +#endif + +// CC_STORAGE_BUFF_SIZE - Size (in bytes) of the buffer for CC file storage +#ifndef CC_STORAGE_BUFF_SIZE +#define CC_STORAGE_BUFF_SIZE 64 +#endif + +// + +// NFC_T4T_TLV_BLOCK_PARSER_ENABLED - nfc_t4t_tlv_block - TLV block for Type 4 Tag +//========================================================== +#ifndef NFC_T4T_TLV_BLOCK_PARSER_ENABLED +#define NFC_T4T_TLV_BLOCK_PARSER_ENABLED 0 +#endif +// NFC_T4T_TLV_BLOCK_PARSER_LOG_ENABLED - Enables logging in the module. +//========================================================== +#ifndef NFC_T4T_TLV_BLOCK_PARSER_LOG_ENABLED +#define NFC_T4T_TLV_BLOCK_PARSER_LOG_ENABLED 0 +#endif +// NFC_T4T_TLV_BLOCK_PARSER_LOG_LEVEL - Default Severity level + +// <0=> Off +// <1=> Error +// <2=> Warning +// <3=> Info +// <4=> Debug + +#ifndef NFC_T4T_TLV_BLOCK_PARSER_LOG_LEVEL +#define NFC_T4T_TLV_BLOCK_PARSER_LOG_LEVEL 3 +#endif + +// NFC_T4T_TLV_BLOCK_PARSER_INFO_COLOR - ANSI escape code prefix. + +// <0=> Default +// <1=> Black +// <2=> Red +// <3=> Green +// <4=> Yellow +// <5=> Blue +// <6=> Magenta +// <7=> Cyan +// <8=> White + +#ifndef NFC_T4T_TLV_BLOCK_PARSER_INFO_COLOR +#define NFC_T4T_TLV_BLOCK_PARSER_INFO_COLOR 0 +#endif + +// + +// + +// +//========================================================== + +// nRF_SoftDevice + +//========================================================== +// NRF_SDH_BLE_ENABLED - nrf_sdh_ble - SoftDevice BLE event handler +//========================================================== +#ifndef NRF_SDH_BLE_ENABLED +#define NRF_SDH_BLE_ENABLED 0 +#endif +// BLE Stack configuration - Stack configuration parameters + +// The SoftDevice handler will configure the stack with these parameters when calling @ref nrf_sdh_ble_default_cfg_set. +// Other libraries might depend on these values; keep them up-to-date even if you are not explicitely calling @ref nrf_sdh_ble_default_cfg_set. +//========================================================== +// NRF_SDH_BLE_GAP_DATA_LENGTH <27-251> + + +// Requested BLE GAP data length to be negotiated. + +#ifndef NRF_SDH_BLE_GAP_DATA_LENGTH +#define NRF_SDH_BLE_GAP_DATA_LENGTH 27 +#endif + +// NRF_SDH_BLE_PERIPHERAL_LINK_COUNT - Maximum number of peripheral links. +#ifndef NRF_SDH_BLE_PERIPHERAL_LINK_COUNT +#define NRF_SDH_BLE_PERIPHERAL_LINK_COUNT 0 +#endif + +// NRF_SDH_BLE_CENTRAL_LINK_COUNT - Maximum number of central links. +#ifndef NRF_SDH_BLE_CENTRAL_LINK_COUNT +#define NRF_SDH_BLE_CENTRAL_LINK_COUNT 0 +#endif + +// NRF_SDH_BLE_TOTAL_LINK_COUNT - Total link count. +// Maximum number of total concurrent connections using the default configuration. + +#ifndef NRF_SDH_BLE_TOTAL_LINK_COUNT +#define NRF_SDH_BLE_TOTAL_LINK_COUNT 1 +#endif + +// NRF_SDH_BLE_GAP_EVENT_LENGTH - GAP event length. +// The time set aside for this connection on every connection interval in 1.25 ms units. + +#ifndef NRF_SDH_BLE_GAP_EVENT_LENGTH +#define NRF_SDH_BLE_GAP_EVENT_LENGTH 6 +#endif + +// NRF_SDH_BLE_GATT_MAX_MTU_SIZE - Static maximum MTU size. +#ifndef NRF_SDH_BLE_GATT_MAX_MTU_SIZE +#define NRF_SDH_BLE_GATT_MAX_MTU_SIZE 23 +#endif + +// NRF_SDH_BLE_GATTS_ATTR_TAB_SIZE - Attribute Table size in bytes. The size must be a multiple of 4. +#ifndef NRF_SDH_BLE_GATTS_ATTR_TAB_SIZE +#define NRF_SDH_BLE_GATTS_ATTR_TAB_SIZE 1408 +#endif + +// NRF_SDH_BLE_VS_UUID_COUNT - The number of vendor-specific UUIDs. +#ifndef NRF_SDH_BLE_VS_UUID_COUNT +#define NRF_SDH_BLE_VS_UUID_COUNT 0 +#endif + +// NRF_SDH_BLE_SERVICE_CHANGED - Include the Service Changed characteristic in the Attribute Table. + + +#ifndef NRF_SDH_BLE_SERVICE_CHANGED +#define NRF_SDH_BLE_SERVICE_CHANGED 0 +#endif + +// +//========================================================== + +// BLE Observers - Observers and priority levels + +//========================================================== +// NRF_SDH_BLE_OBSERVER_PRIO_LEVELS - Total number of priority levels for BLE observers. +// This setting configures the number of priority levels available for BLE event handlers. +// The priority level of a handler determines the order in which it receives events, with respect to other handlers. + +#ifndef NRF_SDH_BLE_OBSERVER_PRIO_LEVELS +#define NRF_SDH_BLE_OBSERVER_PRIO_LEVELS 4 +#endif + +// BLE Observers priorities - Invididual priorities + +//========================================================== +// BLE_ADV_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Advertising module. + +#ifndef BLE_ADV_BLE_OBSERVER_PRIO +#define BLE_ADV_BLE_OBSERVER_PRIO 1 +#endif + +// BLE_ANCS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Apple Notification Service Client. + +#ifndef BLE_ANCS_C_BLE_OBSERVER_PRIO +#define BLE_ANCS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_ANS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Alert Notification Service Client. + +#ifndef BLE_ANS_C_BLE_OBSERVER_PRIO +#define BLE_ANS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_BAS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Battery Service. + +#ifndef BLE_BAS_BLE_OBSERVER_PRIO +#define BLE_BAS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_BAS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Battery Service Client. + +#ifndef BLE_BAS_C_BLE_OBSERVER_PRIO +#define BLE_BAS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_BPS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Blood Pressure Service. + +#ifndef BLE_BPS_BLE_OBSERVER_PRIO +#define BLE_BPS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_CONN_PARAMS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Connection parameters module. + +#ifndef BLE_CONN_PARAMS_BLE_OBSERVER_PRIO +#define BLE_CONN_PARAMS_BLE_OBSERVER_PRIO 1 +#endif + +// BLE_CONN_STATE_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Connection State module. + +#ifndef BLE_CONN_STATE_BLE_OBSERVER_PRIO +#define BLE_CONN_STATE_BLE_OBSERVER_PRIO 0 +#endif + +// BLE_CSCS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Cycling Speed and Cadence Service. + +#ifndef BLE_CSCS_BLE_OBSERVER_PRIO +#define BLE_CSCS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_CTS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Current Time Service Client. + +#ifndef BLE_CTS_C_BLE_OBSERVER_PRIO +#define BLE_CTS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_DB_DISC_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Database Discovery module. + +#ifndef BLE_DB_DISC_BLE_OBSERVER_PRIO +#define BLE_DB_DISC_BLE_OBSERVER_PRIO 1 +#endif + +// BLE_DFU_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the DFU Service. + +#ifndef BLE_DFU_BLE_OBSERVER_PRIO +#define BLE_DFU_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_DIS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Device Information Client. + +#ifndef BLE_DIS_C_BLE_OBSERVER_PRIO +#define BLE_DIS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_GLS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Glucose Service. + +#ifndef BLE_GLS_BLE_OBSERVER_PRIO +#define BLE_GLS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_HIDS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Human Interface Device Service. + +#ifndef BLE_HIDS_BLE_OBSERVER_PRIO +#define BLE_HIDS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_HRS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Heart Rate Service. + +#ifndef BLE_HRS_BLE_OBSERVER_PRIO +#define BLE_HRS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_HRS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Heart Rate Service Client. + +#ifndef BLE_HRS_C_BLE_OBSERVER_PRIO +#define BLE_HRS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_HTS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Health Thermometer Service. + +#ifndef BLE_HTS_BLE_OBSERVER_PRIO +#define BLE_HTS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_IAS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Immediate Alert Service. + +#ifndef BLE_IAS_BLE_OBSERVER_PRIO +#define BLE_IAS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_IAS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Immediate Alert Service Client. + +#ifndef BLE_IAS_C_BLE_OBSERVER_PRIO +#define BLE_IAS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_LBS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the LED Button Service. + +#ifndef BLE_LBS_BLE_OBSERVER_PRIO +#define BLE_LBS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_LBS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the LED Button Service Client. + +#ifndef BLE_LBS_C_BLE_OBSERVER_PRIO +#define BLE_LBS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_LLS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Link Loss Service. + +#ifndef BLE_LLS_BLE_OBSERVER_PRIO +#define BLE_LLS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_LNS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Location Navigation Service. + +#ifndef BLE_LNS_BLE_OBSERVER_PRIO +#define BLE_LNS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_NUS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the UART Service. + +#ifndef BLE_NUS_BLE_OBSERVER_PRIO +#define BLE_NUS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_NUS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the UART Central Service. + +#ifndef BLE_NUS_C_BLE_OBSERVER_PRIO +#define BLE_NUS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_OTS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Object transfer service. + +#ifndef BLE_OTS_BLE_OBSERVER_PRIO +#define BLE_OTS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_OTS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Object transfer service client. + +#ifndef BLE_OTS_C_BLE_OBSERVER_PRIO +#define BLE_OTS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_RSCS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Running Speed and Cadence Service. + +#ifndef BLE_RSCS_BLE_OBSERVER_PRIO +#define BLE_RSCS_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_RSCS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Running Speed and Cadence Client. + +#ifndef BLE_RSCS_C_BLE_OBSERVER_PRIO +#define BLE_RSCS_C_BLE_OBSERVER_PRIO 2 +#endif + +// BLE_TPS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the TX Power Service. + +#ifndef BLE_TPS_BLE_OBSERVER_PRIO +#define BLE_TPS_BLE_OBSERVER_PRIO 2 +#endif + +// BSP_BTN_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Button Control module. + +#ifndef BSP_BTN_BLE_OBSERVER_PRIO +#define BSP_BTN_BLE_OBSERVER_PRIO 1 +#endif + +// NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the NFC pairing library. + +#ifndef NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO +#define NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO 1 +#endif + +// NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the NFC pairing library. + +#ifndef NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO +#define NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO 1 +#endif + +// NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the NFC pairing library. + +#ifndef NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO +#define NFC_BLE_PAIR_LIB_BLE_OBSERVER_PRIO 1 +#endif + +// NRF_BLE_BMS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Bond Management Service. + +#ifndef NRF_BLE_BMS_BLE_OBSERVER_PRIO +#define NRF_BLE_BMS_BLE_OBSERVER_PRIO 2 +#endif + +// NRF_BLE_CGMS_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Contiuon Glucose Monitoring Service. + +#ifndef NRF_BLE_CGMS_BLE_OBSERVER_PRIO +#define NRF_BLE_CGMS_BLE_OBSERVER_PRIO 2 +#endif + +// NRF_BLE_ES_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Eddystone module. + +#ifndef NRF_BLE_ES_BLE_OBSERVER_PRIO +#define NRF_BLE_ES_BLE_OBSERVER_PRIO 2 +#endif + +// NRF_BLE_GATTS_C_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the GATT Service Client. + +#ifndef NRF_BLE_GATTS_C_BLE_OBSERVER_PRIO +#define NRF_BLE_GATTS_C_BLE_OBSERVER_PRIO 2 +#endif + +// NRF_BLE_GATT_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the GATT module. + +#ifndef NRF_BLE_GATT_BLE_OBSERVER_PRIO +#define NRF_BLE_GATT_BLE_OBSERVER_PRIO 1 +#endif + +// NRF_BLE_GQ_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the GATT Queue module. + +#ifndef NRF_BLE_GQ_BLE_OBSERVER_PRIO +#define NRF_BLE_GQ_BLE_OBSERVER_PRIO 1 +#endif + +// NRF_BLE_QWR_BLE_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the Queued writes module. + +#ifndef NRF_BLE_QWR_BLE_OBSERVER_PRIO +#define NRF_BLE_QWR_BLE_OBSERVER_PRIO 2 +#endif + +// NRF_BLE_SCAN_OBSERVER_PRIO +// Priority for dispatching the BLE events to the Scanning Module. + +#ifndef NRF_BLE_SCAN_OBSERVER_PRIO +#define NRF_BLE_SCAN_OBSERVER_PRIO 1 +#endif + +// PM_BLE_OBSERVER_PRIO - Priority with which BLE events are dispatched to the Peer Manager module. +#ifndef PM_BLE_OBSERVER_PRIO +#define PM_BLE_OBSERVER_PRIO 1 +#endif + +// +//========================================================== + +// +//========================================================== + + +// + +// NRF_SDH_ENABLED - nrf_sdh - SoftDevice handler +//========================================================== +#ifndef NRF_SDH_ENABLED +#define NRF_SDH_ENABLED 0 +#endif +// Dispatch model + +// This setting configures how Stack events are dispatched to the application. +//========================================================== +// NRF_SDH_DISPATCH_MODEL + + +// NRF_SDH_DISPATCH_MODEL_INTERRUPT: SoftDevice events are passed to the application from the interrupt context. +// NRF_SDH_DISPATCH_MODEL_APPSH: SoftDevice events are scheduled using @ref app_scheduler. +// NRF_SDH_DISPATCH_MODEL_POLLING: SoftDevice events are to be fetched manually. +// <0=> NRF_SDH_DISPATCH_MODEL_INTERRUPT +// <1=> NRF_SDH_DISPATCH_MODEL_APPSH +// <2=> NRF_SDH_DISPATCH_MODEL_POLLING + +#ifndef NRF_SDH_DISPATCH_MODEL +#define NRF_SDH_DISPATCH_MODEL 0 +#endif + +// +//========================================================== + +// Clock - SoftDevice clock configuration + +//========================================================== +// NRF_SDH_CLOCK_LF_SRC - SoftDevice clock source. + +// <0=> NRF_CLOCK_LF_SRC_RC +// <1=> NRF_CLOCK_LF_SRC_XTAL +// <2=> NRF_CLOCK_LF_SRC_SYNTH + +#ifndef NRF_SDH_CLOCK_LF_SRC +#define NRF_SDH_CLOCK_LF_SRC 1 +#endif + +// NRF_SDH_CLOCK_LF_RC_CTIV - SoftDevice calibration timer interval. +#ifndef NRF_SDH_CLOCK_LF_RC_CTIV +#define NRF_SDH_CLOCK_LF_RC_CTIV 0 +#endif + +// NRF_SDH_CLOCK_LF_RC_TEMP_CTIV - SoftDevice calibration timer interval under constant temperature. +// How often (in number of calibration intervals) the RC oscillator shall be calibrated +// if the temperature has not changed. + +#ifndef NRF_SDH_CLOCK_LF_RC_TEMP_CTIV +#define NRF_SDH_CLOCK_LF_RC_TEMP_CTIV 0 +#endif + +// NRF_SDH_CLOCK_LF_ACCURACY - External clock accuracy used in the LL to compute timing. + +// <0=> NRF_CLOCK_LF_ACCURACY_250_PPM +// <1=> NRF_CLOCK_LF_ACCURACY_500_PPM +// <2=> NRF_CLOCK_LF_ACCURACY_150_PPM +// <3=> NRF_CLOCK_LF_ACCURACY_100_PPM +// <4=> NRF_CLOCK_LF_ACCURACY_75_PPM +// <5=> NRF_CLOCK_LF_ACCURACY_50_PPM +// <6=> NRF_CLOCK_LF_ACCURACY_30_PPM +// <7=> NRF_CLOCK_LF_ACCURACY_20_PPM +// <8=> NRF_CLOCK_LF_ACCURACY_10_PPM +// <9=> NRF_CLOCK_LF_ACCURACY_5_PPM +// <10=> NRF_CLOCK_LF_ACCURACY_2_PPM +// <11=> NRF_CLOCK_LF_ACCURACY_1_PPM + +#ifndef NRF_SDH_CLOCK_LF_ACCURACY +#define NRF_SDH_CLOCK_LF_ACCURACY 7 +#endif + +// +//========================================================== + +// SDH Observers - Observers and priority levels + +//========================================================== +// NRF_SDH_REQ_OBSERVER_PRIO_LEVELS - Total number of priority levels for request observers. +// This setting configures the number of priority levels available for the SoftDevice request event handlers. +// The priority level of a handler determines the order in which it receives events, with respect to other handlers. + +#ifndef NRF_SDH_REQ_OBSERVER_PRIO_LEVELS +#define NRF_SDH_REQ_OBSERVER_PRIO_LEVELS 2 +#endif + +// NRF_SDH_STATE_OBSERVER_PRIO_LEVELS - Total number of priority levels for state observers. +// This setting configures the number of priority levels available for the SoftDevice state event handlers. +// The priority level of a handler determines the order in which it receives events, with respect to other handlers. + +#ifndef NRF_SDH_STATE_OBSERVER_PRIO_LEVELS +#define NRF_SDH_STATE_OBSERVER_PRIO_LEVELS 2 +#endif + +// NRF_SDH_STACK_OBSERVER_PRIO_LEVELS - Total number of priority levels for stack event observers. +// This setting configures the number of priority levels available for the SoftDevice stack event handlers (ANT, BLE, SoC). +// The priority level of a handler determines the order in which it receives events, with respect to other handlers. + +#ifndef NRF_SDH_STACK_OBSERVER_PRIO_LEVELS +#define NRF_SDH_STACK_OBSERVER_PRIO_LEVELS 2 +#endif + + +// State Observers priorities - Invididual priorities + +//========================================================== +// CLOCK_CONFIG_STATE_OBSERVER_PRIO +// Priority with which state events are dispatched to the Clock driver. + +#ifndef CLOCK_CONFIG_STATE_OBSERVER_PRIO +#define CLOCK_CONFIG_STATE_OBSERVER_PRIO 0 +#endif + +// POWER_CONFIG_STATE_OBSERVER_PRIO +// Priority with which state events are dispatched to the Power driver. + +#ifndef POWER_CONFIG_STATE_OBSERVER_PRIO +#define POWER_CONFIG_STATE_OBSERVER_PRIO 0 +#endif + +// RNG_CONFIG_STATE_OBSERVER_PRIO +// Priority with which state events are dispatched to this module. + +#ifndef RNG_CONFIG_STATE_OBSERVER_PRIO +#define RNG_CONFIG_STATE_OBSERVER_PRIO 0 +#endif + +// +//========================================================== + +// Stack Event Observers priorities - Invididual priorities + +//========================================================== +// NRF_SDH_ANT_STACK_OBSERVER_PRIO +// This setting configures the priority with which ANT events are processed with respect to other events coming from the stack. +// Modify this setting if you need to have ANT events dispatched before or after other stack events, such as BLE or SoC. +// Zero is the highest priority. + +#ifndef NRF_SDH_ANT_STACK_OBSERVER_PRIO +#define NRF_SDH_ANT_STACK_OBSERVER_PRIO 0 +#endif + +// NRF_SDH_BLE_STACK_OBSERVER_PRIO +// This setting configures the priority with which BLE events are processed with respect to other events coming from the stack. +// Modify this setting if you need to have BLE events dispatched before or after other stack events, such as ANT or SoC. +// Zero is the highest priority. + +#ifndef NRF_SDH_BLE_STACK_OBSERVER_PRIO +#define NRF_SDH_BLE_STACK_OBSERVER_PRIO 0 +#endif + +// NRF_SDH_SOC_STACK_OBSERVER_PRIO +// This setting configures the priority with which SoC events are processed with respect to other events coming from the stack. +// Modify this setting if you need to have SoC events dispatched before or after other stack events, such as ANT or BLE. +// Zero is the highest priority. + +#ifndef NRF_SDH_SOC_STACK_OBSERVER_PRIO +#define NRF_SDH_SOC_STACK_OBSERVER_PRIO 0 +#endif + +// +//========================================================== + +// +//========================================================== + + +// + +// NRF_SDH_SOC_ENABLED - nrf_sdh_soc - SoftDevice SoC event handler +//========================================================== +#ifndef NRF_SDH_SOC_ENABLED +#define NRF_SDH_SOC_ENABLED 0 +#endif +// SoC Observers - Observers and priority levels + +//========================================================== +// NRF_SDH_SOC_OBSERVER_PRIO_LEVELS - Total number of priority levels for SoC observers. +// This setting configures the number of priority levels available for the SoC event handlers. +// The priority level of a handler determines the order in which it receives events, with respect to other handlers. + +#ifndef NRF_SDH_SOC_OBSERVER_PRIO_LEVELS +#define NRF_SDH_SOC_OBSERVER_PRIO_LEVELS 2 +#endif + +// SoC Observers priorities - Invididual priorities + +//========================================================== +// BLE_DFU_SOC_OBSERVER_PRIO +// Priority with which BLE events are dispatched to the DFU Service. + +#ifndef BLE_DFU_SOC_OBSERVER_PRIO +#define BLE_DFU_SOC_OBSERVER_PRIO 1 +#endif + +// CLOCK_CONFIG_SOC_OBSERVER_PRIO +// Priority with which SoC events are dispatched to the Clock driver. + +#ifndef CLOCK_CONFIG_SOC_OBSERVER_PRIO +#define CLOCK_CONFIG_SOC_OBSERVER_PRIO 0 +#endif + +// POWER_CONFIG_SOC_OBSERVER_PRIO +// Priority with which SoC events are dispatched to the Power driver. + +#ifndef POWER_CONFIG_SOC_OBSERVER_PRIO +#define POWER_CONFIG_SOC_OBSERVER_PRIO 0 +#endif + +// +//========================================================== + +// +//========================================================== + +// NRFX_NVMC_ENABLED - nrfx_nvmc - NVMC peripheral driver +//========================================================== +#ifndef NRFX_NVMC_ENABLED +#define NRFX_NVMC_ENABLED 1 +#endif +// + +//========================================================== +#ifndef NRFX_SYSTICK_ENABLED +#define NRFX_SYSTICK_ENABLED 1 +#endif +// <<< end of configuration section >>> +#endif //SDK_CONFIG_H + diff --git a/bsp/nrf5x/nrf52833/project.uvoptx b/bsp/nrf5x/nrf52833/project.uvoptx new file mode 100644 index 0000000000..fc7fc40878 --- /dev/null +++ b/bsp/nrf5x/nrf52833/project.uvoptx @@ -0,0 +1,184 @@ + + + + 1.0 + +
### uVision Project, (C) Keil Software
+ + + *.c + *.s*; *.src; *.a* + *.obj; *.o + *.lib + *.txt; *.h; *.inc + *.plm + *.cpp + 0 + + + + 0 + 0 + + + + rtthread + 0x4 + ARM-ADS + + 12000000 + + 1 + 1 + 0 + 1 + 0 + + + 1 + 65535 + 0 + 0 + 0 + + + 79 + 66 + 8 + .\build\ + + + 1 + 1 + 1 + 0 + 1 + 1 + 0 + 1 + 0 + 0 + 0 + 0 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 0 + + + 0 + 0 + 1 + + 5 + + 0 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 1 + 1 + 1 + 1 + 0 + 0 + 1 + 0 + 0 + 4 + + + + + + + + + + + Segger\JL2CM3.dll + + + + 0 + UL2CM3 + UL2CM3(-S0 -C0 -P0 ) -FN2 -FC4000 -FD20000000 -FF0nrf52xxx -FF1nrf52xxx_uicr -FL0200000 -FL11000 -FS00 -FS110001000 -FP0($$Device:nRF52833_xxAA$Flash\nrf52xxx.flm) -FP1($$Device:nRF52833_xxAA$Flash\nrf52xxx_uicr.flm) + + + 0 + JL2CM3 + -U685119905 -O78 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8004 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO15 -FD20000000 -FC4000 -FN2 -FF0nrf52xxx.flm -FS00 -FL0200000 -FP0($$Device:nRF52833_xxAA$Flash\nrf52xxx.flm) -FF1nrf52xxx_uicr.flm -FS110001000 -FL11000 -FP1($$Device:nRF52833_xxAA$Flash\nrf52xxx_uicr.flm) + + + + + 0 + + + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + + + + 0 + 0 + 0 + + + + + + + + + + 1 + 1 + 0 + 2 + 10000000 + + + + +
diff --git a/bsp/nrf5x/nrf52833/project.uvprojx b/bsp/nrf5x/nrf52833/project.uvprojx new file mode 100644 index 0000000000..d6dc2b2a7b --- /dev/null +++ b/bsp/nrf5x/nrf52833/project.uvprojx @@ -0,0 +1,636 @@ + + + 2.1 +
### uVision Project, (C) Keil Software
+ + + rtthread + 0x4 + ARM-ADS + 5060422::V5.06 update 4 (build 422)::ARMCC + 0 + + + nRF52833_xxAA + Nordic Semiconductor + NordicSemiconductor.nRF_DeviceFamilyPack.8.35.0 + http://developer.nordicsemi.com/nRF5_SDK/pieces/nRF_DeviceFamilyPack/ + IRAM(0x20000000,0x00020000) IRAM2(0x00800000,0x00020000) IROM(0x00000000,0x00080000) CPUTYPE("Cortex-M4") FPU2 DSP CLOCK(12000000) ELITTLE + + + UL2CM3(-S0 -C0 -P0 -FD20000000 -FC4000 -FN2 -FF0nrf52xxx -FS00 -FL0200000 -FF1nrf52xxx_uicr -FS110001000 -FL11000 -FP0($$Device:nRF52833_xxAA$Flash\nrf52xxx.flm) -FP1($$Device:nRF52833_xxAA$Flash\nrf52xxx_uicr.flm)) + 0 + $$Device:nRF52833_xxAA$Device\Include\nrf.h + + + + + + + + + + $$Device:nRF52833_xxAA$SVD\nrf52833.svd + 0 + 0 + + + + + + + 0 + 0 + 0 + 0 + 1 + + .\build\ + rtthread + 1 + 0 + 1 + 1 + 1 + .\build\ + 1 + 0 + 0 + + 0 + 0 + + + 0 + 0 + 0 + 0 + + + 0 + 0 + + + 0 + 0 + 0 + 0 + + + 1 + 0 + fromelf --bin !L --output rtthread.bin + + 0 + 0 + 0 + 0 + + 0 + + + + 0 + 0 + 0 + 0 + 0 + 1 + 0 + 0 + 0 + 0 + 3 + + + 1 + + + SARMCM3.DLL + -MPU + DCM.DLL + -pCM4 + SARMCM3.DLL + -MPU + TCM.DLL + -pCM4 + + + + 1 + 0 + 0 + 0 + 16 + + + + + 1 + 0 + 0 + 1 + 1 + 4096 + + 1 + BIN\UL2CM3.DLL + + + + + + 0 + + + + 0 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 1 + 1 + 0 + 1 + 1 + 0 + 0 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 0 + "Cortex-M4" + + 0 + 0 + 0 + 1 + 1 + 0 + 0 + 2 + 0 + 1 + 0 + 8 + 0 + 0 + 0 + 0 + 3 + 4 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 1 + 0 + 0 + 0 + 0 + 1 + 1 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x20000000 + 0x20000 + + + 1 + 0x0 + 0x80000 + + + 0 + 0x0 + 0x0 + + + 1 + 0x0 + 0x0 + + + 1 + 0x0 + 0x0 + + + 1 + 0x0 + 0x0 + + + 1 + 0x0 + 0x80000 + + + 1 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x20000000 + 0x20000 + + + 0 + 0x800000 + 0x20000 + + + + + + 1 + 4 + 0 + 0 + 1 + 0 + 0 + 0 + 0 + 0 + 2 + 0 + 0 + 1 + 0 + 0 + 1 + 1 + 1 + 1 + 0 + 0 + 0 + + --reduce_paths + USE_APP_CONFIG, __RTTHREAD__, __CLK_TCK=RT_TICK_PER_SECOND + + applications;.;..\libraries\cmsis\include;..\..\..\libcpu\arm\common;..\..\..\libcpu\arm\cortex-m4;..\..\..\components\drivers\include;..\..\..\components\drivers\include;..\..\..\components\drivers\include;board;..\libraries\drivers;..\..\..\components\finsh;.;..\..\..\include;..\..\..\components\libc\compilers\common;..\..\..\components\libc\compilers\common\none-gcc;..\..\..\examples\utest\testcases\kernel + + + + 1 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + + --cpreproc_opts=-DBLE_STACK_SUPPORT_REQD,-DNRF_SD_BLE_API_VERSION=4,-DS132,-DSOFTDEVICE_PRESENT,-DSWI_DISABLE0,-DCONFIG_GPIO_AS_PINRESET,-DNRF52,-DNRF52832_XXAA,-DNRF52_PAN_12,-DNRF52_PAN_15,-DNRF52_PAN_20,-DNRF52_PAN_31,-DNRF52_PAN_36,-DNRF52_PAN_51,-DNRF52_PAN_54,-DNRF52_PAN_55,-DNRF52_PAN_58,-DNRF52_PAN_64,-DNRF52_PAN_74 + + + + + + + 0 + 0 + 0 + 0 + 1 + 0 + 0x00000000 + 0x20000000 + + .\board\linker_scripts\link.sct + + + + + + + + + + + Applications + + + application.c + 1 + applications\application.c + + + + + CPU + + + showmem.c + 1 + ..\..\..\libcpu\arm\common\showmem.c + + + + + backtrace.c + 1 + ..\..\..\libcpu\arm\common\backtrace.c + + + + + div0.c + 1 + ..\..\..\libcpu\arm\common\div0.c + + + + + cpuport.c + 1 + ..\..\..\libcpu\arm\cortex-m4\cpuport.c + + + + + context_rvds.S + 2 + ..\..\..\libcpu\arm\cortex-m4\context_rvds.S + + + + + DeviceDrivers + + + pin.c + 1 + ..\..\..\components\drivers\misc\pin.c + + + + + serial.c + 1 + ..\..\..\components\drivers\serial\serial.c + + + + + workqueue.c + 1 + ..\..\..\components\drivers\src\workqueue.c + + + + + dataqueue.c + 1 + ..\..\..\components\drivers\src\dataqueue.c + + + + + waitqueue.c + 1 + ..\..\..\components\drivers\src\waitqueue.c + + + + + pipe.c + 1 + ..\..\..\components\drivers\src\pipe.c + + + + + ringblk_buf.c + 1 + ..\..\..\components\drivers\src\ringblk_buf.c + + + + + completion.c + 1 + ..\..\..\components\drivers\src\completion.c + + + + + ringbuffer.c + 1 + ..\..\..\components\drivers\src\ringbuffer.c + + + + + Drivers + + + board.c + 1 + board\board.c + + + + + drv_uart.c + 1 + ..\libraries\drivers\drv_uart.c + + + + + finsh + + + shell.c + 1 + ..\..\..\components\finsh\shell.c + + + + + cmd.c + 1 + ..\..\..\components\finsh\cmd.c + + + + + msh.c + 1 + ..\..\..\components\finsh\msh.c + + + + + Kernel + + + mem.c + 1 + ..\..\..\src\mem.c + + + + + thread.c + 1 + ..\..\..\src\thread.c + + + + + object.c + 1 + ..\..\..\src\object.c + + + + + idle.c + 1 + ..\..\..\src\idle.c + + + + + clock.c + 1 + ..\..\..\src\clock.c + + + + + kservice.c + 1 + ..\..\..\src\kservice.c + + + + + device.c + 1 + ..\..\..\src\device.c + + + + + ipc.c + 1 + ..\..\..\src\ipc.c + + + + + scheduler.c + 1 + ..\..\..\src\scheduler.c + + + + + components.c + 1 + ..\..\..\src\components.c + + + + + timer.c + 1 + ..\..\..\src\timer.c + + + + + mempool.c + 1 + ..\..\..\src\mempool.c + + + + + irq.c + 1 + ..\..\..\src\irq.c + + + + + + + + + + + +
diff --git a/bsp/nrf5x/nrf52833/rtconfig.h b/bsp/nrf5x/nrf52833/rtconfig.h new file mode 100644 index 0000000000..31522ebb66 --- /dev/null +++ b/bsp/nrf5x/nrf52833/rtconfig.h @@ -0,0 +1,196 @@ +#ifndef RT_CONFIG_H__ +#define RT_CONFIG_H__ + +/* Automatically generated file; DO NOT EDIT. */ +/* RT-Thread Configuration */ + +/* RT-Thread Kernel */ + +#define RT_NAME_MAX 8 +#define RT_ALIGN_SIZE 4 +#define RT_THREAD_PRIORITY_32 +#define RT_THREAD_PRIORITY_MAX 32 +#define RT_TICK_PER_SECOND 100 +#define RT_USING_OVERFLOW_CHECK +#define RT_USING_HOOK +#define RT_USING_IDLE_HOOK +#define RT_IDLE_HOOK_LIST_SIZE 4 +#define IDLE_THREAD_STACK_SIZE 256 +#define RT_USING_TIMER_SOFT +#define RT_TIMER_THREAD_PRIO 4 +#define RT_TIMER_THREAD_STACK_SIZE 512 + +/* kservice optimization */ + +#define RT_DEBUG + +/* Inter-Thread communication */ + +#define RT_USING_SEMAPHORE +#define RT_USING_MUTEX +#define RT_USING_EVENT +#define RT_USING_MAILBOX +#define RT_USING_MESSAGEQUEUE + +/* Memory Management */ + +#define RT_USING_MEMPOOL +#define RT_USING_SMALL_MEM +#define RT_USING_HEAP + +/* Kernel Device Object */ + +#define RT_USING_DEVICE +#define RT_USING_CONSOLE +#define RT_CONSOLEBUF_SIZE 128 +#define RT_CONSOLE_DEVICE_NAME "uart0" +#define RT_VER_NUM 0x40004 + +/* RT-Thread Components */ + +#define RT_USING_COMPONENTS_INIT +#define RT_USING_USER_MAIN +#define RT_MAIN_THREAD_STACK_SIZE 2048 +#define RT_MAIN_THREAD_PRIORITY 10 + +/* C++ features */ + + +/* Command shell */ + +#define RT_USING_FINSH +#define FINSH_THREAD_NAME "tshell" +#define FINSH_USING_HISTORY +#define FINSH_HISTORY_LINES 5 +#define FINSH_USING_SYMTAB +#define FINSH_USING_DESCRIPTION +#define FINSH_THREAD_PRIORITY 20 +#define FINSH_THREAD_STACK_SIZE 4096 +#define FINSH_CMD_SIZE 80 +#define FINSH_USING_MSH +#define FINSH_USING_MSH_DEFAULT +#define FINSH_USING_MSH_ONLY +#define FINSH_ARG_MAX 10 + +/* Device virtual file system */ + + +/* Device Drivers */ + +#define RT_USING_DEVICE_IPC +#define RT_PIPE_BUFSZ 512 +#define RT_USING_SERIAL +#define RT_USING_SERIAL_V1 +#define RT_SERIAL_RB_BUFSZ 64 +#define RT_USING_PIN + +/* Using USB */ + + +/* POSIX layer and C standard library */ + + +/* Network */ + +/* Socket abstraction layer */ + + +/* Network interface device */ + + +/* light weight TCP/IP stack */ + + +/* AT commands */ + + +/* VBUS(Virtual Software BUS) */ + + +/* Utilities */ + + +/* RT-Thread Utestcases */ + + +/* RT-Thread online packages */ + +/* IoT - internet of things */ + + +/* Wi-Fi */ + +/* Marvell WiFi */ + + +/* Wiced WiFi */ + + +/* IoT Cloud */ + + +/* security packages */ + + +/* language packages */ + + +/* multimedia packages */ + + +/* tools packages */ + + +/* system packages */ + +/* acceleration: Assembly language or algorithmic acceleration packages */ + + +/* Micrium: Micrium software products porting for RT-Thread */ + + +/* peripheral libraries and drivers */ + +#define PKG_USING_NRFX +#define PKG_USING_NRFX_LATEST_VERSION + +/* AI packages */ + + +/* miscellaneous packages */ + + +/* samples: kernel and components samples */ + + +/* entertainment: terminal games and other interesting software packages */ + + +/* Hardware Drivers Config */ + +#define SOC_NRF52833 +#define SOC_NORDIC +#define BSP_BOARD_PCA_10100 + +/* On-chip Peripheral Drivers */ + +#define BSP_USING_UART +#define BSP_USING_UART0 +#define BSP_UART0_RX_PIN 8 +#define BSP_UART0_TX_PIN 6 + +/* On-chip flash config */ + +#define MCU_FLASH_START_ADDRESS 0x00000000 +#define MCU_FLASH_SIZE_KB 512 +#define MCU_SRAM_START_ADDRESS 0x20000000 +#define MCU_SRAM_SIZE_KB 128 +#define MCU_FLASH_PAGE_SIZE 0x1000 +#define NRFX_CLOCK_ENABLED 1 +#define NRFX_CLOCK_DEFAULT_CONFIG_IRQ_PRIORITY 7 +#define NRFX_CLOCK_CONFIG_LF_SRC 1 +#define NRFX_USING_UART +#define NRFX_UART_ENABLED 1 +#define NRFX_UART0_ENABLED 1 + +#endif diff --git a/bsp/nrf5x/nrf52833/rtconfig.py b/bsp/nrf5x/nrf52833/rtconfig.py new file mode 100644 index 0000000000..c809814516 --- /dev/null +++ b/bsp/nrf5x/nrf52833/rtconfig.py @@ -0,0 +1,92 @@ +import os + +# toolchains options +ARCH='arm' +CPU='cortex-m4' +CROSS_TOOL='keil' + +if os.getenv('RTT_CC'): + CROSS_TOOL = os.getenv('RTT_CC') + +# cross_tool provides the cross compiler +# EXEC_PATH is the compiler execute path, for example, CodeSourcery, Keil MDK, IAR + +if CROSS_TOOL == 'gcc': + PLATFORM = 'gcc' + EXEC_PATH = 'D:/SourceryGCC/bin' +elif CROSS_TOOL == 'keil': + PLATFORM = 'armcc' + EXEC_PATH = 'C:/Keil_v5' +elif CROSS_TOOL == 'iar': + print('================ERROR============================') + print('Not support iar yet!') + print('=================================================') + exit(0) + +if os.getenv('RTT_EXEC_PATH'): + EXEC_PATH = os.getenv('RTT_EXEC_PATH') + +BUILD = 'debug' + +if PLATFORM == 'gcc': + # toolchains + PREFIX = 'arm-none-eabi-' + CC = PREFIX + 'gcc' + AS = PREFIX + 'gcc' + AR = PREFIX + 'ar' + LINK = PREFIX + 'gcc' + TARGET_EXT = 'elf' + SIZE = PREFIX + 'size' + OBJDUMP = PREFIX + 'objdump' + OBJCPY = PREFIX + 'objcopy' + + DEVICE = ' -mcpu='+CPU + ' -mthumb -ffunction-sections -fdata-sections' + CFLAGS = DEVICE + AFLAGS = ' -c' + DEVICE + ' -x assembler-with-cpp' + LFLAGS = DEVICE + ' -Wl,--gc-sections,-Map=rtthread.map,-cref,-u,Reset_Handler -T board/linker_scripts/link.lds' + + CPATH = '' + LPATH = '' + + if BUILD == 'debug': + CFLAGS += ' -O0 -gdwarf-2' + AFLAGS += ' -gdwarf-2' + else: + CFLAGS += ' -O2' + + POST_ACTION = OBJCPY + ' -O binary $TARGET rtthread.bin\n' + SIZE + ' $TARGET \n' + +elif PLATFORM == 'armcc': + # toolchains + CC = 'armcc' + AS = 'armasm' + AR = 'armar' + LINK = 'armlink' + TARGET_EXT = 'axf' + + DEVICE = ' --device DARMSTM' + CFLAGS = DEVICE + ' --apcs=interwork' + AFLAGS = DEVICE + LFLAGS = DEVICE + ' --info sizes --info totals --info unused --info veneers --list rtthread.map --scatter "board\linker_scripts\link.sct"' + + CFLAGS += ' --c99' + CFLAGS += ' -I' + EXEC_PATH + '/ARM/RV31/INC' + LFLAGS += ' --libpath ' + EXEC_PATH + '/ARM/RV31/LIB' + + EXEC_PATH += '/arm/bin40/' + + if BUILD == 'debug': + CFLAGS += ' -g -O0' + AFLAGS += ' -g' + else: + CFLAGS += ' -O2' + + POST_ACTION = 'fromelf --bin $TARGET --output rtthread.bin \nfromelf -z $TARGET' + + +def dist_handle(BSP_ROOT, dist_dir): + import sys + cwd_path = os.getcwd() + sys.path.append(os.path.join(os.path.dirname(BSP_ROOT), 'tools')) + from sdk_dist import dist_do_building + dist_do_building(BSP_ROOT, dist_dir) diff --git a/bsp/nrf5x/nrf52833/template.uvoptx b/bsp/nrf5x/nrf52833/template.uvoptx new file mode 100644 index 0000000000..fc7fc40878 --- /dev/null +++ b/bsp/nrf5x/nrf52833/template.uvoptx @@ -0,0 +1,184 @@ + + + + 1.0 + +
### uVision Project, (C) Keil Software
+ + + *.c + *.s*; *.src; *.a* + *.obj; *.o + *.lib + *.txt; *.h; *.inc + *.plm + *.cpp + 0 + + + + 0 + 0 + + + + rtthread + 0x4 + ARM-ADS + + 12000000 + + 1 + 1 + 0 + 1 + 0 + + + 1 + 65535 + 0 + 0 + 0 + + + 79 + 66 + 8 + .\build\ + + + 1 + 1 + 1 + 0 + 1 + 1 + 0 + 1 + 0 + 0 + 0 + 0 + + + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 0 + + + 0 + 0 + 1 + + 5 + + 0 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 1 + 1 + 1 + 1 + 0 + 0 + 1 + 0 + 0 + 4 + + + + + + + + + + + Segger\JL2CM3.dll + + + + 0 + UL2CM3 + UL2CM3(-S0 -C0 -P0 ) -FN2 -FC4000 -FD20000000 -FF0nrf52xxx -FF1nrf52xxx_uicr -FL0200000 -FL11000 -FS00 -FS110001000 -FP0($$Device:nRF52833_xxAA$Flash\nrf52xxx.flm) -FP1($$Device:nRF52833_xxAA$Flash\nrf52xxx_uicr.flm) + + + 0 + JL2CM3 + -U685119905 -O78 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8004 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO15 -FD20000000 -FC4000 -FN2 -FF0nrf52xxx.flm -FS00 -FL0200000 -FP0($$Device:nRF52833_xxAA$Flash\nrf52xxx.flm) -FF1nrf52xxx_uicr.flm -FS110001000 -FL11000 -FP1($$Device:nRF52833_xxAA$Flash\nrf52xxx_uicr.flm) + + + + + 0 + + + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + + + + 0 + 0 + 0 + + + + + + + + + + 1 + 1 + 0 + 2 + 10000000 + + + + +
diff --git a/bsp/nrf5x/nrf52833/template.uvprojx b/bsp/nrf5x/nrf52833/template.uvprojx new file mode 100644 index 0000000000..47e94f959e --- /dev/null +++ b/bsp/nrf5x/nrf52833/template.uvprojx @@ -0,0 +1,390 @@ + + + + 2.1 + +
### uVision Project, (C) Keil Software
+ + + + rtthread + 0x4 + ARM-ADS + 5060422::V5.06 update 4 (build 422)::ARMCC + 0 + + + nRF52833_xxAA + Nordic Semiconductor + NordicSemiconductor.nRF_DeviceFamilyPack.8.35.0 + http://developer.nordicsemi.com/nRF5_SDK/pieces/nRF_DeviceFamilyPack/ + IRAM(0x20000000,0x00020000) IRAM2(0x00800000,0x00020000) IROM(0x00000000,0x00080000) CPUTYPE("Cortex-M4") FPU2 DSP CLOCK(12000000) ELITTLE + + + UL2CM3(-S0 -C0 -P0 -FD20000000 -FC4000 -FN2 -FF0nrf52xxx -FS00 -FL0200000 -FF1nrf52xxx_uicr -FS110001000 -FL11000 -FP0($$Device:nRF52833_xxAA$Flash\nrf52xxx.flm) -FP1($$Device:nRF52833_xxAA$Flash\nrf52xxx_uicr.flm)) + 0 + $$Device:nRF52833_xxAA$Device\Include\nrf.h + + + + + + + + + + $$Device:nRF52833_xxAA$SVD\nrf52833.svd + 0 + 0 + + + + + + + 0 + 0 + 0 + 0 + 1 + + .\build\ + rtthread + 1 + 0 + 1 + 1 + 1 + .\build\ + 1 + 0 + 0 + + 0 + 0 + + + 0 + 0 + 0 + 0 + + + 0 + 0 + + + 0 + 0 + 0 + 0 + + + 1 + 0 + fromelf --bin !L --output rtthread.bin + + 0 + 0 + 0 + 0 + + 0 + + + + 0 + 0 + 0 + 0 + 0 + 1 + 0 + 0 + 0 + 0 + 3 + + + 1 + + + SARMCM3.DLL + -MPU + DCM.DLL + -pCM4 + SARMCM3.DLL + -MPU + TCM.DLL + -pCM4 + + + + 1 + 0 + 0 + 0 + 16 + + + + + 1 + 0 + 0 + 1 + 1 + 4096 + + 1 + BIN\UL2CM3.DLL + + + + + + 0 + + + + 0 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 1 + 1 + 0 + 1 + 1 + 0 + 0 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 1 + 0 + 0 + "Cortex-M4" + + 0 + 0 + 0 + 1 + 1 + 0 + 0 + 2 + 0 + 1 + 0 + 8 + 0 + 0 + 0 + 0 + 3 + 4 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 1 + 0 + 0 + 0 + 0 + 1 + 1 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x20000000 + 0x20000 + + + 1 + 0x0 + 0x80000 + + + 0 + 0x0 + 0x0 + + + 1 + 0x0 + 0x0 + + + 1 + 0x0 + 0x0 + + + 1 + 0x0 + 0x0 + + + 1 + 0x0 + 0x80000 + + + 1 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x0 + 0x0 + + + 0 + 0x20000000 + 0x20000 + + + 0 + 0x800000 + 0x20000 + + + + + + 1 + 4 + 0 + 0 + 1 + 0 + 0 + 0 + 0 + 0 + 2 + 0 + 0 + 1 + 0 + 0 + 1 + 1 + 1 + 1 + 0 + 0 + 0 + + --reduce_paths + + + + + + + 1 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + 0 + + --cpreproc_opts=-DBLE_STACK_SUPPORT_REQD,-DNRF_SD_BLE_API_VERSION=4,-DS132,-DSOFTDEVICE_PRESENT,-DSWI_DISABLE0,-DCONFIG_GPIO_AS_PINRESET,-DNRF52,-DNRF52832_XXAA,-DNRF52_PAN_12,-DNRF52_PAN_15,-DNRF52_PAN_20,-DNRF52_PAN_31,-DNRF52_PAN_36,-DNRF52_PAN_51,-DNRF52_PAN_54,-DNRF52_PAN_55,-DNRF52_PAN_58,-DNRF52_PAN_64,-DNRF52_PAN_74 + + + + + + + 0 + 0 + 0 + 0 + 1 + 0 + 0x00000000 + 0x20000000 + + .\board\linker_scripts\link.sct + + + --diag_suppress 6330 + + + + + + + + + + + + + + +