From 7b040b3688e0342edd6aa18ef6db9fcccc34b601 Mon Sep 17 00:00:00 2001 From: Alexandre Courbot Date: Fri, 10 Mar 2017 16:12:21 +0900 Subject: [PATCH 1/2] nvidia: add GP10B signed firmware These NVIDIA-signed firmwares are required to enable the graphics engine on the Jetson TX2 board and other TX2-based devices. Signed-off-by: Alexandre Courbot --- WHENCE | 18 ++++++++++++++++++ nvidia/gp10b/acr/bl.bin | Bin 0 -> 1280 bytes nvidia/gp10b/acr/ucode_load.bin | Bin 0 -> 19456 bytes nvidia/gp10b/gr/fecs_bl.bin | Bin 0 -> 576 bytes nvidia/gp10b/gr/fecs_data.bin | Bin 0 -> 3668 bytes nvidia/gp10b/gr/fecs_inst.bin | Bin 0 -> 22306 bytes nvidia/gp10b/gr/fecs_sig.bin | Bin 0 -> 76 bytes nvidia/gp10b/gr/gpccs_bl.bin | Bin 0 -> 576 bytes nvidia/gp10b/gr/gpccs_data.bin | Bin 0 -> 2340 bytes nvidia/gp10b/gr/gpccs_inst.bin | Bin 0 -> 12921 bytes nvidia/gp10b/gr/gpccs_sig.bin | Bin 0 -> 76 bytes nvidia/gp10b/gr/sw_bundle_init.bin | Bin 0 -> 7664 bytes nvidia/gp10b/gr/sw_ctx.bin | Bin 0 -> 6036 bytes nvidia/gp10b/gr/sw_method_init.bin | Bin 0 -> 11928 bytes nvidia/gp10b/gr/sw_nonctx.bin | Bin 0 -> 2744 bytes nvidia/gp10b/pmu/desc.bin | Bin 0 -> 652 bytes nvidia/gp10b/pmu/image.bin | Bin 0 -> 49408 bytes nvidia/gp10b/pmu/sig.bin | Bin 0 -> 76 bytes 18 files changed, 18 insertions(+) create mode 100644 nvidia/gp10b/acr/bl.bin create mode 100644 nvidia/gp10b/acr/ucode_load.bin create mode 100644 nvidia/gp10b/gr/fecs_bl.bin create mode 100644 nvidia/gp10b/gr/fecs_data.bin create mode 100644 nvidia/gp10b/gr/fecs_inst.bin create mode 100644 nvidia/gp10b/gr/fecs_sig.bin create mode 100644 nvidia/gp10b/gr/gpccs_bl.bin create mode 100644 nvidia/gp10b/gr/gpccs_data.bin create mode 100644 nvidia/gp10b/gr/gpccs_inst.bin create mode 100644 nvidia/gp10b/gr/gpccs_sig.bin create mode 100644 nvidia/gp10b/gr/sw_bundle_init.bin create mode 100644 nvidia/gp10b/gr/sw_ctx.bin create mode 100644 nvidia/gp10b/gr/sw_method_init.bin create mode 100644 nvidia/gp10b/gr/sw_nonctx.bin create mode 100644 nvidia/gp10b/pmu/desc.bin create mode 100644 nvidia/gp10b/pmu/image.bin create mode 100644 nvidia/gp10b/pmu/sig.bin diff --git a/WHENCE b/WHENCE index ee82bdb9..aad8e6a6 100644 --- a/WHENCE +++ b/WHENCE @@ -3447,6 +3447,24 @@ File: nvidia/gp107/nvdec/scrubber.bin File: nvidia/gp107/sec2/desc.bin File: nvidia/gp107/sec2/image.bin File: nvidia/gp107/sec2/sig.bin +File: nvidia/gp10b/acr/bl.bin +File: nvidia/gp10b/acr/ucode_load.bin +File: nvidia/gp10b/gr/fecs_bl.bin +File: nvidia/gp10b/gr/fecs_data.bin +File: nvidia/gp10b/gr/fecs_inst.bin +File: nvidia/gp10b/gr/fecs_sig.bin +File: nvidia/gp10b/gr/gpccs_bl.bin +File: nvidia/gp10b/gr/gpccs_data.bin +File: nvidia/gp10b/gr/gpccs_inst.bin +File: nvidia/gp10b/gr/gpccs_sig.bin +File: nvidia/gp10b/gr/sw_bundle_init.bin +File: nvidia/gp10b/gr/sw_ctx.bin +File: nvidia/gp10b/gr/sw_method_init.bin +File: nvidia/gp10b/gr/sw_nonctx.bin +File: nvidia/gp10b/pmu/desc.bin +File: nvidia/gp10b/pmu/image.bin +File: nvidia/gp10b/pmu/sig.bin + Licence: Redistributable. See LICENCE.nvidia for details diff --git a/nvidia/gp10b/acr/bl.bin b/nvidia/gp10b/acr/bl.bin new file mode 100644 index 0000000000000000000000000000000000000000..b598f8fece4b4063cad7fb3ff421c54c05ad81f9 GIT binary patch literal 1280 zcmd^7u};G<5Is9dacE0TSH2=U%FZ7kAtb(py$fUr!l6(v6(0bi$`F4846Gp5P6X+M zl0Xe-nt`ET(4O>s)=Bs7z0nx|V9ZqmsV;1XomAq_s$GZ!rlLIKK?0420S^yd5}{A2ejxQj Xj3h?87!6HIBhB<{gYIL^&mVpPO+kR; literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/acr/ucode_load.bin b/nvidia/gp10b/acr/ucode_load.bin new file mode 100644 index 0000000000000000000000000000000000000000..016144cc0eb80308a66a6fa11985700d4e6500c5 GIT binary patch literal 19456 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 G!2bg1ZhFiB literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/fecs_bl.bin b/nvidia/gp10b/gr/fecs_bl.bin new file mode 100644 index 0000000000000000000000000000000000000000..4e03f76fc371da00886a1fcf3841a14a8da01b2d GIT binary patch literal 576 zcmew$B5Tda009a>$^pb=0uc}p17m<_kU|)SieF$5VPN>j!mxKqoj?r352j9__>B3S zGv)})n9cX^8v}&TG36)6lz%*b=du2ufA!yOs3`Z0nOu9H?3w?;E-Z%O*F2UTGl8b> zcn2hw&Huvj@drCh>1}pDm=miP<+`4zk52#y5De8v+09D#br2qf` literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/fecs_data.bin b/nvidia/gp10b/gr/fecs_data.bin new file mode 100644 index 0000000000000000000000000000000000000000..da44e384a592be92f1f2c79ec19aef2c4c78b98e GIT binary patch literal 3668 zcmeHIA&(P56n-spWyFXPO(@xl4XLO&lD#6Xxs>GFWV1biSW!{Z6B|-|1)}1_iiWhP z3Iy`Ri3%k0Lwy_4P(q1D_VHs_1ioY^Ag;`I{Fcer2jZtm9Ke|aERgsMX+KsSM41NhfKQ$lot z5Go0wQ}Q|SHiTS+FdylECRBvOegsJ)n2h|6P%%u4IEilJr5dxq#n zL#WXZB4bD}h8~g6h}jrMCJ;;b6R328_QeDPKZSHtn9US+JB7ZUqWzt`p7G8(#LUsX zB1?w$G$Svev4oNp^s^NtBQ7_gddhd3TA26bW}#)h*3vRoFN~EwtgOFUIpaGM)}o)2 zSx1L=Ti&C2{(xsgyz{Mi3F_oJS&2AClY$y zN34kz^Gr$V^l44^pSnbHQ2a|*u#1@`Ygxfx@Ll&fm#ng?162pA4&1c^a@Pa?asQw0 zE8>zB9}jg-PQOAfxQn~B++3bG&kd!Uvzr$tJEx4htm50z&xG7zzFRK+-*b2KGNDM@ zH@XDE(OxSK+U2+zEvItWyX$X3?h|>~5Hea)qn6g7f*Sn;>PG_<9LP7qY2A$YKwZBj zmJu~NrlyYJ55{PwPLHXB)I!rCN7O^7iMJERsmHCf&_|iU`ZH=ib@H^-%IzE`$a2lJ smRjr+3H58XgdeTwuh7|$w?y`aOkfT5n6+0{b)f1%)q$!5|EB{#0N+%33IG5A literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/fecs_inst.bin b/nvidia/gp10b/gr/fecs_inst.bin new file mode 100644 index 0000000000000000000000000000000000000000..dec162d3a51e97578ff53d8a5b9bac95a2f10ced GIT binary patch literal 22306 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 O#0L7jiSH`o?7snyfhHmV literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/fecs_sig.bin b/nvidia/gp10b/gr/fecs_sig.bin new file mode 100644 index 0000000000000000000000000000000000000000..fbdae6e06ec9891721e5cbb9e80e4b06e937b4ea GIT binary patch literal 76 zcmbQgTXOB6t$oQ`_tDfV3V$)En4C$;}<`oze$^pb=0uc~k0%L$^kU|)SieF%0VPN>j!mxKqoq!3$52j9__>B3S zGv)})n9cX^8v}&TG36)6lz%*b=du2ufA!yOs3`Z0nOu9H?3w?;F3g1C*F2UTGl8b> zcn2hw&Huvj@drCh=wo1D+w*V2ub-?t{(}_$`NHx32lL)9oeUjJ czve>>1}pDm=miP<+`4zk52#y5De8v+01p#M^#A|> literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/gpccs_data.bin b/nvidia/gp10b/gr/gpccs_data.bin new file mode 100644 index 0000000000000000000000000000000000000000..4b46d729662ef66154b036513df157e1b7906e72 GIT binary patch literal 2340 zcmeH`A#7Sv6o!B3?csMVggaI?`~}}!ICAbVk5zm7HI} z4=hx`!4*v4CRAL?OXWPX)|j`Z$~o3XDm5bMEp$Ky<`iVMpi$6%ia#l^msJ>(SJ_Dy zPG*XoIh99MzE@?QuyhX&pa;sbUslFtr8<1$T`OLR!i3zn&{F@cM_p_mMypa3$m|A+ z-UTYBXgkH91*#wB6u!^N82p!kVwY2Cfd81Sy3{CTJ>S%Um|B$3+=a`KHRv>G>v?_a zXh&1{h`rELgtWpM^bFw|Ju%bb;l{6i?DKv`{^wbR^gtp$X{sT$FK9<2i_KyU)~Ly6 z|HQtRgl_l2W+)9ghOk8q$k&9#N+9(yS7j`azxDa|(2oWihYHKkKm%IrG4>1}O_AuO zrI)R|N?zaBHAP-yD^lcj&gfWcT@hOCXY>laXtwv76Z+{$ux4eNSUD9dPPXaD3BJH3 z{scRwCcZ8=RrX*i;Y|&@3omdFq087Ow(vzOQm-;ln}ZYV=>v1$k0EhKFkZlfvFQT7 zGd6=C3z#!@y8tiRL5tJd!S=8N&M^HpL;TTS7;|T5e4E4Ve-d%%66oD=g!T0A@aNLO z0MbCo74{k?|G<4dAAHm-d&+=JTU|E4> I1^%qSPvVKQ#Q*>R literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/gpccs_inst.bin b/nvidia/gp10b/gr/gpccs_inst.bin new file mode 100644 index 0000000000000000000000000000000000000000..dd13acbebdcf592d6518dee5108abd8aff53ba78 GIT binary patch literal 12921 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 QG&u5{{@!5bd3}uiFSK9lh5!Hn literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/gpccs_sig.bin b/nvidia/gp10b/gr/gpccs_sig.bin new file mode 100644 index 0000000000000000000000000000000000000000..3eaad83b7deea5c2f544372fd46b7dea93802194 GIT binary patch literal 76 zcmdN8e|)XX!L{j@qS+ee%7ty)b!ORa{(e0EQ~9)W`EU1a(g(xd8|z> fUvcbn5NGv8wl;&w7w)}cxV@8+fq?;pnSmGp*;FFP literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/gr/sw_bundle_init.bin b/nvidia/gp10b/gr/sw_bundle_init.bin new file mode 100644 index 0000000000000000000000000000000000000000..ef5d650d83659ea50d6f55d375c158cdc02d0f9b GIT binary patch literal 7664 zcmdtnXLuD=9>?)X2oQRx(h0ryVnWN^U0;9#MxQ`{flz&G(Nd>aSgK=jtd zpLbrdC>F!wSOQC8DV(Hwto&3hc0Pl&*q2$RjxS7j=w7*OYB`O`GDs-}Q!x#nO1l-F zYq4?(n21ZI^-nlP;4+NDIN4bhT$E~tGfVBZG#lsOT%3o&7=ob~hVyX&F2qH+7?O%!6-Hq+#^7p<#W-Ap zYth#(5~Z403u|K?tc&%qJ~qIH*a#bA6KsmjusO!ljs#4^BuvH>OvN-z#|&JDnYbP| z;6~hpEoeteY=y0{4YtL0_#*nDKeopX*bzHnXAHp2v||fy#ch~{+i?f(#9g=>_uyXK zhx_pWX5&HHaR?9N5j={=@Hn2plXwbG zY>Z8?DK^9AxY-`oN?UL%Zo@3xjyrHC?!w);2lwJW+>Zw^8)xBcoP%?59tL9whGH1b z#|5|$7vW-Df=lrNUc^gy8L!|~yoT2?2XEj_yoI;%4&KFk7>*IR442~yjKr0=3ZpO@ zV{kRbVjQl)wRj&N;6wZlzsE=T7@y!%e1^~Q2mBF#!k;l0yJ|?JIwFS* z8|`-M`m!_$C*u_S9H-(moQ^>_1HZs8aVCC+U*k783uogToQv}?7(*}=!*D(>z=gO7 z7vmCKis2Z6%Wyfaz(`z)t1t?qF$Py-EXLs)T#NCTfQgud$(Vwvn1<85gKOVqrJcx(zFdo69cnpu@2|S6X@HBplXYeeZ z!}E9nFXAP8{gE#Od-oo2>2k+uNypIp?A%2J7<0E{GPw*)|!{_(|{)j)} z&zOrt^pLRU#87?M^KY01O2cskevBjW6C8z~;%FR$V{sgg#|iiuPDD3O!pS%VKgX#! z4X0xe&cHA5OPq;c;n(;L&cfL^2j}8E48{-)#W0+Y3veMW!o|1*mtr_Z;4)l}D=-pQ z;wp^7XpF(t7>jYZ2G?RdCSW2aVKSy*DyCsNX5c!^#PzrVH{vGTj9YLkZo@3xjyrHC z?!w);2lwJW+>Zw^8!za+=u<+!N8lyAj92g~Uc>8{gE#Od-oo2>2k+uN^pTFn8Ktod zmc?>d9xLDrSP?5>Wvqf#u^Lv#8t5zSf9i(Po(C=R*5~H7#8%iE+hAL4hcBWZ`eS?S zfE}?DcE$h<#MiJVzK*@HH}=84*bn>T8~7%^g>T~k9EgMP9efx6j{m@a;$VCahv578 z0e*->@gw{f{u`&t0QJKtY2)5;(tb;vCS7u}bjv9ioVVWPgh+dKg~|e+-rjLiLtQ6K zdT4}rTIy$R=S*JgI7e|S`e{6C{qK+MrHv~)5O>5*tnW;m&UiWl*I_2E#|^jc}h0$ADJBwgZEQZCg1eU~7=p$|arLhc_#d264E8q)Q5i4P3tb$ds z8dk>|=qs)LHL(`f#yVIR>tTItAg%oku@N@LCfF34VRL+!e(Zu>@nw7kyJ2_ifv;j9 zj>LY_uD4wMzoMxE=L5w`t`Bi&p1HXn;aY8{OTvlA$I^}~QTe@PoMO8lhO6DS-3aND zAIm1%a6IuR(pT$8Nh|*;@o3_{(&`x?eOwiM2a;bxjkKmrP+VM2QDE_OedOi_IN?&a zisRDGy|w4RNVmTJmH2PO|F82zzs&Qk)_Jh&HCF2Qe|O$5Q~BA-KOlqZ3~%JG{&O}@ zb+wmPZkoj&j=N)?9!@9IaeGdeR_?!@H*BZ#Z~gtt{9$YBkC$HZ`m^(he>6|^XXnA< zx8z^<37CjUn2afyifMQd58+`vf=BTf9>)`yE^S^c8#83kj_1G5&y~%}pXVuu<*@?R QmiB{`uk`Q;`gK0ULk~p?E)q0Cg&rd8p@+hb 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 ghhhgR&Yi)Tj?dz3`Q~W!68GT9UP7r z^oUU-+@V*hcIeQ-!J$Kkq8)_WA#gi%aOlvXpo2rv4jl^d_vZa}uOR4~;gjFDvZ8PGAhB=3HA|!gW(}uCQ%1@) zas{hcmO1sEB#CRcxfyR4H*iy4)%+GYYxurChD$z|=e_lgw;@NPk~G4nabNz6a?^&RpM zcgF^{Cxcv|^CR^sIw#CxX_i`LtXUOP*`AehVIT8-)`j-OXL}~|W}#CfO1(vl zaS}^d#wnb}3Rba(bxg2zH5zn>dRtY-0z*r+(clGRj@HBXVKj>oNAYk4*R9|GJ(-Ig(ZG#~PMi&e#pr zGwH^eee#(D@|i>BK>ZEsOW1Vv3wqv=+fFrhTwVQhGAHNBx8+c|i;*lUzkQ+YG&bcY z8I!-@77nHRUEAb!eDj;T%lh`t=>dI*=k$oa<8yjK-|0EEfBkWfmi>7uNcTU|AlIZj zFD94JJ$)Q^d_5g9KhXQ)__~&Ee+znFbh*fTV~mqn h!ZJ?bG*+;MZK>Bb>&UA1o5>)T5BoAICFwEG`|m4%T*~-h_ccLxh3hx(5S80V@N8yB`C?6`+1;e+Gs?pnOg!14A+k1H<`9 V1_pZppj}xE3|=75j)FlK0stAq9CZKy literal 0 HcmV?d00001 diff --git a/nvidia/gp10b/pmu/image.bin b/nvidia/gp10b/pmu/image.bin new file mode 100644 index 0000000000000000000000000000000000000000..2aa09012f94a0ada706462119ec4e8bc94bd89c0 GIT binary patch literal 49408 zcmdSCdwf*Yxj($to;}IznMr060!%KD0mCI+Bu*F$NH)RZC5nbxJq_9_wbT~tIrYZr zO-Dp(4Jg@!iS7i*Y&50~g2X);4k0rgw9{I8sA!8lrd6Olu{y2FpaW(I$^LzxJqcjz zIsd%B_w#vQ{Y>`WYdz~(YdveNXFa#Ic%98;Y(!+Sj)2?828B(GF=th}>h(+ddi09eIz%((>azwwbY<=!kMQW8H56qVrtZc5={?86WEy8efId z&-vKm-oeFtTa{Mcxjk(=J&1PwzwzJe2k&4kWg!v-))#;P;SOeR+;3&^Hgy*tWQ|dJ z#q%JZA@i$M+Z*YkEHf$Il@avr&P>`-VCII@E{-o}^(K^5ck_5}Jg;xN00MZt@!lpX zW5fochnk~16itfvn#klQ8O!JT--fu0Hzur13k@&PgL}nn`({z2sCj!eG>sZ0 zZ{zGSRImYrTaV7f7ot*yRm2ynt=Z0_r(u!pkbl8h)01dLhHB0XEzK0Jqs~bBOUkyg zz{55cw=28MS|y{iI9*y4cWhL0n9^r6>$yZ=O*E{Tcz)c77AujY&>2d59F6Fi>=9Ta z8WC@cI|v@gE+R^hO{giVsff*AhxTniopOV~#)eG3-hwvN6g8t!Qe4`M{<#ZyFeL5^ z3ek`fZCA|xoItHo@I&!@MiY%rNWse4Hy}hmJP|#4LfygRQrs2!kO$k%;_V8d0}8dB z2Q%Wnv=Ggt8s9=vCe?W|T{u*0e7ND381GQj&e6@$Q9UHrO0Z9ePn zWa;v`?y0=Gg6G67aVas`_{S3Q*3RVV(sDzt7g)6y>jl)%wqhJ^3cNQuH$%;%vt|c7 zz#2P1(AID(+sk4V8!-PKLxCR?`C=AElOsEW)qH1s38qL=4F2t+X^Z}0KFc(8@s(rq zHEpvBJYI+SQKZ(Hv%_A7rGV)X&Q1-ijfwI(pm$?lO6HizA6uB7ic84)P__fo%kycq z(cI=mvGnN5voS80fg_56vuK%p=u6b8CR%XW`9{fuEaTIk4QuSGK!wO2#cXkJfa9Rt2$k2Tkhzzx?*%%1#Yk~Fq@n~+t6j1srs|}OWpf&(NmsF^@S@~ zzPUmb`DY^2y=tDb^NqCQq0v=~C0m@%b9YZ?sX30+bS}Rkvh0VNpA$STO121h_H7X& zQf{!HX5Z)}>rAFgeg7NFxWF*<($RGp#zYvjQLl%lWQ28?hjFRv3hgWwS zt1d}0@ET6BaigU%K(>Iw7&Sf%USNV3nBXFT7i7WRRN2MgLp)uT&fJ7?=^0tdl>(1e zMni3Gie=aov2B_dD+| z>azm>VPzL)0b##@@t=^5^`J6;bW=E!!_-QPI?t_M$}zx^N=s)uQM3|oYGuAU+oH~K z>(^0#EA!2Ps4QSSssOUUY!hR4%=C%5EM5$P7wEU@rGYCzgf3QRTxc8?z%5Q9#hoBU z#3V)8MWpcl6Dh{&ITtrxsc@es#*}>3>!Pntce?bd_!TBWuKRyTka_uPrHeKl2|J|& zQ(~4t9ltHx<$QIXpkC@$=bCe`(wuwqM&}+VC8(8!qeL;sESx3E9I%>&CQK-9-oU2LR*_JNN!Nw6!#?q0!A~C+?AWQq)X`Xfu4e8j~u9|4BaxA0*Fvy*OYCF?4 zwAHDX#d-qm_(Be3-e>IpB=hQB@@_lxZfibFQzo2XgP1fgV%(dfEOs>d!HMYbsmNZg zy*S8P4te(V*!CrC!`rOUw^QJ*9$JT(mfBwIR_o(0=|9t7_5IHGuG-Cs&jfCfSR;*H zYhs*%x$YynH=f90OIkrFdre2cS~v=TTM)eBjI+ZpC_XTb8eGZ1#rhP%Dk!cy(hRxNP!@2QTME;F~C4Or} z@BLW8K2;nXXg7?`k+f}YbCL&-yN9=l>C!3Db&8RBGipfzrQ__dRgOB?+2NdMKBMB* z2br_*Fz?Jwm+l|=E*rUqjl5uT{6S0LdlFIi(R9^d#utw_zrtekp{M9?E3Ix%%&vvh zK3+2r*~a6Fx`ju*-sokQ>DwY(xz-$b&(4PYw*ReUK9=tO5 znI~D~Hn{Rp(R3wU>Zl2Nlk#RKOJs~_*NN%a4F57H4Dqp2C{yoZr#@krj0U7rXKuBK zK@fb$e8=TCovhH{W=X}j0<+t*^dcT15xBOlt3{8S!Wa%XiVJI9)) z=F!N;Iv&b+ny$=ai!(NPVm=!vHVlk#_ZDd+WRZCH8J3=$e+;Uc#TW^uwmYg@*>e}B z(TsI8!CX|Sw!>~z53~OO$Do-eaj#@IWPd(u>9^g#{eE@DYrJU{V*^P{h!A+%gC~jx z4jD$%D^66sA5Fhhf4C+szkvq!EAQ~>y;!oK@AOa7wo~}y$iM6TwBxq>Kakt<*!{`- zUrTLeJt--;!$ug&4%6B^d)7*IXr1{KJEYh?X(&6{aqwkV22QC<~^@lX%kW` zksTtmbnpq;;esN`Q9OD)6-ilKyl+VCHP~>7wlCiSlJ6i_d7*Af970<(qeR=D?c57d z&up4ce@-w|jn@>(t6f}?6Y!6KmVoAf|Pr| z{(Q}9wS(t!d4`)M>iB8Lb4>lRkodY0EEa<0XuCJ+!-^#o;XUjpqwQGidq0}-Mg*Qn zTEanL`b915dZqJ7+BU~Hvcou17VT<|NL>CHg@deEy@N;Z3&x6iTiI|%jND;n#EMkO z0)95fNh`chLCIQ)V2(_`$Mc8qG&{&r3q`57BZ4f6jhZLr(T9W?Fp z{O{-jf0Rr>y-VLqn&ITx`ho6!c#bp9?lyX#PEWQDvR*Qj^d8`&N#!YdSpn6 zZ^?B9tYxperPpnAZ7~jL!*L$%?cUepjvmk;3RIn|V?HvXjI>(1pN95%*~oRgCaCPP z`n!ZW&Q5J*%-dBbm@f{Czl)D8pz?9@ZwuI|pkZWGxrMAZx_#t&uJl<0U-i&x5+R6f zyw(AlPhf#>6tYx@feJ5U>6ws0>Q;zn+E8W??<0-;xM6(i!b%uXS)i*BX^kEyThbQT zI|1+6zXXZBbZXrbIY*k=qw`@-@yfRpW>-RPyg1W>*{&3bnD8mUeA>*0yuh=}0jpO= z&_Yt#kye&(JMs~03At%nw$th}LgIkLY-vYspt_LZRY*Iq;wAA@$UP{#q-_Yb_UE#7 ztey#HGEACtB*gUgBT3d55?*@xJqyIdIwk=3sUWL03*V?RWFN;o@?uXulVmq;r-bag zt2P!q6Jp0d9QkmhF39jY$P!%!wub$!n!qxJzCFQ^aAbsqPcWavKh3apXh!2|NLf7I z<`T1(zF5K!Hq*}aZQfAe8Y>&#Y1QmQMYcg^7X!9&zzGq;d;)P@urO12q@6I%yBL|2 zJ5mp=$>z;S*2oCghx{2KmiR0>7dEYPFh`Po(e4eoQgsRO(-3=<+Oz^~a>v^+=&^*- zXEzIKR;^^H2qUk)Xo>GlBq7Tc^n(&^h#v7B^58gjWEkSP08W@15RCp{X9)Y0uMKT; zRz1zk_d(|5HAe&c#-khQsub$h+OXM2whO2#(r(e;-uU)77I=38a@~W>*JT%~o_3|3 zmxF2VZ(YS15irB-7GL}HZRyf-5In{sBmxiaqrug-6H_ON3PF66F?d7ygluC6GADL98#UXsrxk%bL2({bThS+)eM%wpg&{5 zL>B!S-iR_<62=03mcnK_MBN!^9nZqG7?JCmOGiJ=89g%|0xFEf=&EG=AKIQJiO)W? z0i%=Zu+*;*f?dLJn-%MFkmXf5=NviCj=aV&waA8YdQ=|(lW1k}UD&@drdLXHV3~PI z{{`5V9)t)1BTB|vtuecu%d;l3BXz8=S?JuFw*3{n%MN8^=0q6fGS(`XU$#3^Pjg?} zP%SB}YMiUTI27^!TYnpC9jpnRtLY#MerBq3CM+j41C+zZkyrz3jR_O*{1* zV|AjrGgfV}N!C0|Y@lijV}gTMadG)N7WnQ|a7in3h)zLk3tUBCPROc(p>lTJhYQT| zHnV)501PP2MQ(RkstVY0Y=l($t0-;L+VrSd8oPkjb{)IfEa@Dpxh4n^5jBefcjQz} zVa^B5qN`98)jFMK(QlhYcYnn!nm1Nd5`Cq4+-x>A`O$2p_fV5j(q@*t$1J)0TV~1p zY;*Z&a~VoG@|QDi*0}C7<(PvSn}4@i4(b#niELFiM*&Kpp(t#Ydy>jI(M_|y?M@c! z(b~Wg_FTe1u%NI8TdJ_}FEBbh ze+dhWlUN{x0o{S$p%SQyjW;`(KO_VeVbuF3vA{d{oyBM$#pw6pS$_$5pOd5t`XBHe zPUgi_gM1*C3GR4n6A)mzrh*(?h|(K7otSl`*?2?#5VlYOW~I_IWT!H@DE2ejQTk>o zyDGF^tt&9OjKx;hKo6{$4`0W?dNxC_@t?4n0!b5YV;=UPbtJKi}C8wA97AmEpH0le}E9Vs7I4} zy6yTszOMz|EoDBf+Rdg_Yx(7YUzD=y4mJ_GZ`1Qm7Hw5X!`UkMgU~%{29&8{=Zw>( z_ZcQn1RHZ!cjS2F-syB+1EAwxkQT+UYye zrQ&9kZs%(HDus~B%f z^^~VN$^+jnU`+sQoVrv}hXweU@;OMoW)kf64p2Fo3=a2OJI|(VANQ}I!tDfIXDo>j zuq8E69y=OKIJmqAC62qJ@wC$KiS}apSe4^NQ0K9JZ{boI z?VK)1gm~89_kGDt-&~rB2MyWv5<7+MZXJ!4oix3`d@QvElkv5w8)L}>5|*w43bo}m ztq@rxnQ?Yt5878`+A{ltvZvASXZ?fO}$T&|tl*sUOX|9yxO(rq|i~&oMso*euz`SLC40&OtMKzv{ABk3X6FYDV=Z z#aA;AzG~d-Pg?yaa{^~4Lk($EtfRY=%R&l{H`KJ^S$AU*m>1Z{d1e-bLl0i>^WSCv z$lL~5{e~R0?Nke+770M2d6u zIgtWuq`*FKonbWZ;$&F4RSRsqglQ#Yd2J$ZYSxM$&w!8(e5<-0KGDDx zaI#>co!+<`-hO;+JUIF!?>~LRA5KqlN;UyT3z46)2~b){_Dx}pKO=z+TU=2SIW{vC zB=B_FY1K|`J_^TExig-Gv*QRHan z1$XAtX%GB~@a^6AS^Ih;?CYD!z8;Dvqgw>1MjmqX{Avo*PUt03mwvH*y%CldngBn_ z2&MoUf^{Ml##VRydHg32qR?I##g$!R=eD#Bn_wfXGfiZ(YXjTbgwlPz!oG;Gc1WaQ zMZPJwLJxV#w1Jz(zI9~mv%|0t1__ssg!q8-Q2N0OaJu6>B;nP=)Mbm@Lkjg6Qr#w$7{~rgx$cvdfgb>n21r0xcOLDNss7TlJ zKs19C3USa`3*J7kaUL9<5G6_8L9_&>mKH+w@S1C(K&wO|%^=fWXnt{7BV$#O4|24m zzBd+ZHm=prY8i}zM(hU*@JjtTy$6!m59}+>yHUQQU!h+|dyxJt?75VT!PyC*<RDvkUt5@H;mz;sn?D7SS_WqD3sOh}{x#jnfp#Q0(rA=!W|kE@4_2VRZaQ&3Nl2=k5sVZCx3qO=VXrxVOZ+C^c=LnPDOd?s-umXm1U+jby(TR za>U|1RqJHR;i8RmRQnWwHf2m-rwrGE9N;4Kc zsl<;Xh^HS6xA~+S&Go+`tU9E;BPvs&z>3P@9A(!!rLQ(zA^tqp1JRg}6Bk^%4op!m z+c@V-=I1)-we+18f$-N?K{{~FQRSojwSUfEd&1@a&|5d>CX%$*CJXA=DtfC&!Y7RV zC?u>+7Mcq)$ww_e^Pw=$@_#J&hb<6Ty&vj-*Uvh+@3&-n8Pndg8ZahKj}`mXP{kZb zbQ&8!%D=}fxaS#q)^1Bif`QEXz_S(DoJOwUBVXi!|Cq*<@6A!F=ga$Nn0k5p*ecEs$TBku_OA$P?2HiPs+#`&vYha{tP# zJ*0b!9VOrhfn6r33i6g2Y)LUTvXVxOSF}a#dEKsMj=aOV-;m_S87$wJ4nh1HPq{@B zz5iAt`oC-Oui^exf_^tNisB;7dNAI0v(t*Fm`C3~5kHxC4zj9VLY9;rWJ%FZ%A01u z48!v&gOb}tL^Np`)ZA(xWK~bw)6Q{lfX=K|#G9*w!u_&!27<=Md#jbn%d3M0cgi(0 z*g9xt@*nVAoqa;@DV5j*CeNVujrT5uRbz?8zmV&TYJ#yI|3X3jG2o$>ndP7_(KBw> ze*}>V791?UGem$v$y02BilHx3`WE{aT55t-TksSlhj-zUNm33lR=rU}z12&6vjYX= z*=Fi>GODI}6e)hHv-osrYy{CrSsVOgBV)22kp+&*9c=LkT8n`VU^NYGC>w;8)Bz>W z`|y&MXCu>qP|BzNTbm% zL`Md@pB7EtDcStJT;N{8)6e}9_w);XNm%m6^ul!M3^kME`Jn)v`tdJ|E4BK#|BSAyO$`58FBO1ztibZDf}1LJnLZ;rYy;?Yb>8&#Hzb zwbB}ymy^|l!)e-KK#I!ASgEMiAF7qVQ3m2j;;a$%(9t6IHUBJNDgms z*gScKs?&n)K6TUx9I~?pm!lCmu^u~L8xlRPBE{)>YU&E&SN@Q_!DaEcxg*RalGe2uYeO<;Z6>GTqufT%3buA6H&QG#m91b>PNbZBi-(F} zzpNV+VGQr>f<3PsUZ{#xusqtPxQxCG>1k)hzBbb_a58OVo|g~IVu?_>1VW_xLRQLZ zWk#|CIIshekc?O>Q$+}wbdR*6d0wd$<9nl$8VSun0BxjgrmrM0?*=Bh{dHWDybB)=`Y#jLF65|^YL13f zrFCXxp+M$E_~>7HOog|kLjLt^mMDheFeP5)fDtwD@3Y_w%+}y>Om+&X9wTsB9mDpu zZ#-A3MMRGMzNUlbMRb=&3NFMG&mLag!#w>})1e!+qf^7CvvWiwRi~d#LFx{240z!K zNINR~wP^&G=qm5s%Tnp`zN8h4TQWd&a8(G}HXme={wjiM1^XQ{jH2CBO_jQp>(BaL z#!Q89S(+DshOcY#nmKT7N4JTw4o6PlaghyF8m_7dEOpM2I)m6u4+z;m9}UzIjZj1O z@0TxS2*P&95>H_i^Z9l2rw1-6f*FlWu}()ShsQeLswPyh31i7q)tM{NYwB^A;L-S_ zNFkAOs}ab|X4QMxTPz_M`zwDfLL#w{SJG{?Ulp(0*HRvC<$bh$P@|jErPDm+WEOx; zp%l>t`&+Xm;HZeVW`Q@GJ|*}5g%8}4kDmC=SSnyxilJE zMTA#^TfJ@0j3aqG`uhRnB<6tRohz4J%Dk2E)@n!0iKCZ5M0NyTF&pdFOGe){mcL{+ zy7ar*%x=)M>({sdMZdYVHr@{Dq*6*5nV_pF)shP{SiOOlD!jZKLc|4QlZTU5dF!Q2 zYJz7vb-EUR!IKZtTT(PJX@p5@hftF<#+$)`FaCrGKS=%>p-!Q&%iloN1}kw4r>yd^ zOIfc(PH$wvIDq6y*S~KuWn_oGd!sbZ^jt{>+L==mglQj$>zv~ty$rXBoo%Vzjx0$* zLt@^E9RxX*?0=s9{p;3^jeJNt7dcsAWCrBr^O*WkfthDQWv2!;9|5D-EIra3JAbtm zj?Id|n}BuMJ()5@LyY%i=HQV}b9=W#Zk|U@TQr7t8BgmRyJ42e4U|-WPU3eyFHxk# ze#U8y+By88h&0UW7tQZi+ptTcC;oTb8*AP1<8|?&V?|Hby5BD9TU>h{u znz?$)o3YzB)n30G4xk?w(R@#DT<3KEi7|s=g`e0e=38iaBO_-}>fh~jyYo4baGll; z6Wb<8Gg^pB=urZ`0BZV-Otoo zw-$23TgWWJz)8cUZ3q61NY+9Qf@mmI z9(Ih4Ok{brfxkK+>(yc{#U%w3Rx(GgR%DNaHUl7)&JAWPSdE)Sk!jnahJu-aPi;Ha zwJlJ58EYcg%!*dN3VI$fV~^3>65k%U`7(?n(Q;07Ce*b=p_fi4C>70|GP?15aJX zI$?hMM86*54nCZsUa|?82zHYPa3$KmP&!h}keYo%zSBw&N;Tg%jf0OoLrr<4H5JTF zJMv8DYz1{}XoGm3h?$!(nV|`QOtB6a`Q``yvx*%*xP7TRo^jYV;w6?q*xpm@eT$aK z=jVq(pmner=pk%Al2kr+KcKLi^mk)LG4Uvo>M>-|I8fLM#sWM!I~I?uB;pV3FpPK- zl9$4unvU$!NYebGSU*H_qR26}4XeondBg+=-0m}1u-axF+tEyfunnBcOce~cMJbM$ zkFd&cM@xjWW@VB}xTrFC&TF%Z>mb#SMTHb*SrN%$npJ})IK zDTUw)J}ev6=igPy{#lY&6UhT#szL{AMCu|zGsB!z`AfE8(?k52WVg|33hca;_SOmv zAa-`Dy;)SZaa9r2Ef!S22(m*VtgTo}tDvEgDSXHNRE23aY(FY*nNJc2N&)hGDPW*dt;U}s!zZl6r>sWvnyP2!zV@TI%i&Eb-`S`pJ`{{_jO9{nH?sw=00b4 zkC=9@>3<8O`_MKOOFa|Z--UpXV4H9RqG}MVl;Tp{a=o8jlmR9S<2G{Y82_}3$q$a^ z!V&7ma+mKL{jN7Zu^&;}$#Dkq`ogjN&8$w%J+cj2S#(z_ajsk$;k`))w*d8{U5WO$ z^tFrn?|YjWf@LHQ$t>Dl6g`)UZWsHG!|T}hwirwFzQa0y18qml1uBw7dO8!WX*^8@OF6V@QVK2iO|F6^#n`>dDS~|8<~8~7no$93t2I~ zGG1kh@7B!o>PjBHGYuL-nv2&F7pcRMk5mgzaYz@7^Z$v{JtoT>T19aW#{ONf0>kon z<^^*CWv+}J-OL2RWP}zj9OmcP5t%PQBonA`N&HB(CP>l4hzUIv1omM?l+S#D86V@r zt-a-BXI*NXSZ99|$RSj>qLMzacz-xT`E|C7A{)s}^2hG@@`X|r7ntJ+F7*u+BLl-yW zGG4)A>keY|H5?zH)t4EBKAK4f{-c(RkBM1K?p?sLUwWxNC-Ckp7T8?NTxW`qbZkK#^`Qe33-EKa7cIZ0FH7tIc&mQ>CWel4XX>wCZ zlZ)dl%6DK$+E~ltYs@Of$5+~USShxLgA*wk}R>f}!AEhlgTruu)&)a1P8=t8jM~LVE7zCzcIL!;(SPrt) z-(MzQyNC_{+)5AsTjp1|Vtl!$zbw0p7q)T$r5#QLm=Ztf5*0JjRar){e?jf;a5r{a-g@Xk%Rh-EsE!<&o3i96V7jzocLrYC!2A;%hqwhs{g1CXcWejbyu@%`iop$VE@vmp~bDO1R z8KQV!zk)2wRgqN=48 zRa>s8nlkO)`^G7|7QjBJ^g(EX$rFaDh$Kc}@@l^V4JDEll>z4^a`Xxa0XDKNdZbB2 ze`yk4D6RrSlDxn;Cb9brn%RLlE;D3N-)$OsmA)#|#Jh)095%D>aWQ#t0hYvIrqD&g zB^f^vVCZiX)@~E@E#45UnWY!3nPy}o*_>_ylYCCsp)tc5+a1g~?Q9T^KX~z~b$)@# z+hv$#aBjrZ11ezJ_Hh*MqK-3*{pLYH`Kfd82ES@fFVvEr| zA!|Jpd30$|JCv1yT{Z-AK*gYi?D4Jyq<i*lSTHn|8ry`}^QBHARt=7Ig`Z4oM!v0$)ZXDW%dz6OQ<6q98zQ3hHXu}F zD|WciG#8mo`k*%+@$9l7u!d~E(aihR8ZW8poRm#vO2{{pO0D@gnvvLR!156dt*%a5-en|#e`2Z;U##>gEYXIyhDcoZuSM(6?3f-KuW01%CPk6E{i@XG@Yc0mCr1>Kff)A5Tn?DhI$& z7J!=b1_5CwPnT8#$mFR28s0(`%Kb|iRiU;D#u}1x0_UzJ8EG{M@OP4ZvZhFXT5aY( z29U^qPn42vPA_N3A|tqiYUa0pXyC`SH21Fc@7xI9f2QA!thz-C=DUe&cce zAuCAQN&dT1-6xqT@cExhOgVCh_AXA6zkh1{Ys)K>T+vgx8T%*LY%haHDGI+r3k z6GugR3JcUqI=Wp1ulO&3yt^1CKoBPfR!`Y(0|m}gFcMySpOx!?-$?q1VjR* zdWIFTjq=`QEU^ZA)=NVCQS7L+xPmngdKb#UWlSy3a`dgj@t5)Ipt_X>}f+KZ#t_t4sLiD*PQ&w@czLLm%FB?iUpqS=>@ z;(2Br7PG>ws8CSLB_JtGwTS2jR0NSM{N<8-`xjwU5Gv4hZ&)j=ME4htb-z?CrU4oM z&r~RN<=7{p5u;5a(uViAN~vRXQ1g5zau5PTnPxwN6DRm?&Gyle9|-uFSuE(9_z$Jb zdv}p+huDUMhT*M^G$fSjFNiBCEzr?`zScT;?fwP zh|6JIJW}qAOm@U8l~#@}f9>l389wJC_O7$ z<_WmW1(ipVPAY=uIsTGL7?rATO660>CaFa4vv6%T>Lr#yAFK;q>^I>DJX_l%GHOw8U1f0 zKtb;}g=a!LI%55(B|@A|)FkdOoNiMBbSr&j(M6ip8;SEs zw-DK9G3i~*)p9|-(Q0-_G2CEbSk99p#g<690FA-C^rE4zP%Yt9QCHfN-%vL$`)Zp2 z-#FUg4|xMYNT-ioOJd&Ynb>;^K}TE@U>XEo_OyyH!Z@pg*7u82@70{SEO0HF z;Y<5_Wr}>V$PbKW#nRcVu?#?Aaqe$T<7nYe2?p@-y;&G!;LNI-2QU{mac8q2A3;XR zio<038hwL%8*es}W9km(9BDJx&-wxWWnb8*{S<_{l zcC>J%PK+i!fde;SE6D=`%!fu7DbAChyq@XhHNl3FGIuLZrwI=XFjsZZ{fU3_OnJ@q z%rm(XL1o2`s=wl#)@`Q$ydHA(VB$SP`9T?i)z#CvDvqba^fNztd$9Wrhcei3`03TL zibothDMxgMrZ9wbb|6&Y@UGQRUHdwPzP$qZ=c3P5b=uOUe~gTCc#09T!zQT34)ai? zQ!RE9S1ER$uW&(ZKybxGbz!brBkEu1{&Rl!mb~saoH_2ER9?^PPGuI?{~kTtp=VG{ zU$c0)b#-4C-9%+u-tgdTb%~|JF|IP$x-|Nw)dg>_7rK1ekAE+F{4JY>7iFPW#RdZSa_f5t}e_Fsviy16J0Z zsv<=c8x`ra<76AmtuxHY+HR@|BQ+gr5}q!RGzs!};X)^pu)$5S6rKVm*m*KnCSEjr z&q`bm!?hvgzj-iHlB1N& zr1&_=9T}JBFRt{>3LL0oPQmwrQnGzCIH9@%x2o7T-CJOW9Y#td0JU7tknA#B-LH=`ID^46`Wj*m#K;k$TErzD z{{oN_Z$BUi5eEy5eWGpu zF2JR%1!VWt*eQ{h>Nvi5Cnf2lI#BOD{>x zHk<;z;!Mf@R;nGQ`gS_4#fMK?;SDhlIpR96S3i0pxI@^_76@=Q=u0qJ_K8AdVeS!$ zt<99}YjLm5Ov3&POE8>ir5~U%Rbbyj#+#|qPauTw6`buCPCE}kLt&EE$@+ITyKD(&quzWA?`81FR)f6l`}!|8gSw$*IT@uDuq1on2;v zVW-K&N8p)AWXctoYyO*jB7MnRa*AAtRaw;^W^BG$K%$#hM&JlmLKb*I0F5$ca7!)< zqy}8s_?D!&DjzP8arHO`daml6*L36JP(b$X0(b|=yny4|E!sBfY;0g1GU=GQTfV)X z#rMRe&i<^%zn2?tx4^Z6OR(T>{CnE=F5!xIrK^Z3?{sv(Vb}jde;*+-!e-5*m#Sb2^4a=}zr|=}l0cyH#pjtZF=m(x z=AyiFH1!?o-|!BExKMGVo<|2~5~1@Hi%5DUl#64->B)Jh2aXcTz+0~YuZdYHEGJ|5 z<%c1I6q^oyI*AZ(9jyyutyvlHqCOL97MGs|a0#g@rS)vIsp>3zN82>HV+HHJ3-QDS zN{QI~9UhnukbVIq9R(Zc@4)4Rb;jT9^o<)20G~QvWc})z?LQZzeI8? z;h%&1BwBGxlmJ$!P7+LS^d9yEu1Z2+nD-9y)IfvJlFrVxM)_}FW>T$P%)ZqGpBgVP z?@Dif96Balh3Lu6=iXzTnbW0TG!anIB`f8}zQhP}Nk6uQ5=z@lUrB^?P7;=^#A5=K zVxaGQ=Co&uAiw`*^L8u(G!GKs8Lz?MhWlBDFR4pxH#*Oq_IyZ#Pj>m^gY5Usip_}wD)A^_S2;=fYW(bUR*^d3XYPrjeUls zo2bV4rDlbQk~&`@Sk!%^WzwFz%pwkR6w;oCi%TH*?m|Vcvzqf|e4i;(fi}kHVLd>Z z1fl8-+!gp`7FN?e{|j zVz>09>^-kLqUFu|o)MzYC|bWMYK*zWMwU^8IK_!y4Xb*EvTU(Zy+HY1m2y{YBch|@ zZTfB5L*!wNeN5AnzrbKQYy@AzJzF7M?hrxvCFrXy@rJbeM(`?csKJ@P8O-Y`@UaIH z%<26=J1+m^W_HUV!JC9LBlQdTskA?m7}4OQt5x+yv7Yx1Kg;zS1K+BL*@c`ZOX?n3 z;<*hMTljy#CBeG}!u}coakFdS0a*J8_b`k12h<7}KmDsLksp|rZ2fNiN2c-mlABre z4$D$QZ4f@Esr6{;5^AbY>kY+rw{8p!`oJKQ3gECYbx;usr;RjE5h|w{Z{<%~yhDjY zxbH~w>?(u`=Rap2D>#dbRf!ll<^uh4gVQvU-0x{~>p{2(D+2f2!eT`q>~hage#+&$ z{)MTyXrh`g-tsfb!H4nF-2e2)83b*?>>L zFG+rv{o!EZZwB;c>Z>tT`Dl9FsSoI<5O%yOgI;@+u^t$)XMTk}@>)Z`#dBP^E1Ayo z!f~@1hTdR?BXD9>bK{eUgUzJ;pKzIfg>IS(Qi!mb_DJTgcI?2bMyR}?^l{~|iDDuG z)4}i_DpwcRnjkq3P0lFqI6DudZO>#^$a-K{_Y|CE)l*|d%J-%}j-J)r{P42H_o+}= zN*0!A6|YtC>$OzZ|ab ze)vIIU&%07)jJCQlbee*!PPHu+OEmjW;yL_=6`w!*XlgfyB|terpHrk^_1o`1 z)A4T;%%t2V^+FQL!~6g%<22+ofwY@I2p}Z*t;nPp^?gAy2(5a?Q(2^zTW~XD>?qi% z{Nn~(fnh<+0SM%7K+yP*Wi6t|{|?I(0?wVCZ{zka`6nxx|B~_kOD51;LrFobXQ0b4 zv`SC872YfVJe#LD$6x98lzIKrC;I0UdCI4x5=Qj!LI1o0;vuLrTb|m~s$m&GYNqp0 zky$*PJxvD0YMB@tfZ_QPyjF70pSb580rnHK(|qx{{YYHAErY*ELF;hG3-CtIy$+jP-c0_1ANMoyGq}0cX0fW{LBakZ;b!i}BTWZ@LHU_yF#Aq!T-PSlNh~ zMef{ReFd$7Xbp?aA+8lEaiR znn&prh-V(2fvmh<|CJu`4fIsms}sy&9B9E509!xR!Hnu!Hj%_WFiB(2o6FZBL|T6K zR(4U+L5iAw=WF0kbX#An;t90mCphXW&%BK-d2%C@E~+*9)q~NO4_>Hy9dfJdSQVpP zW%(0)U@kOz;ELzLa>YRGn;I#Vh5F^?*KQQig>{`^l$I!?o5ap>JTrWDJpXvUq4d-TXm!)Fh&H$F* zc>-#GCvJXuH?~^62L!c`_2fbaDE_~68iuQ;M}eGmV$~>aq|mqJ{5Rbow5oa;E~mus z#JA(}wKnh8WMa zJG#$6dHW()7f!%MJ=v<1R=TbyvT#CR^*2Y`pe~%O`p2n0oZp1FDaAVEuYQ%OS47Rku=<{t>1wEHkqw zAsac!k9ENKmd)-)C{V0NwttPOH4{~NLa@=(a-YrEGQMS{t!1{Ydnprmv{dir7F@1X zHASqNVnfWw&8ulDep{{asB$r2C}XD$Kzix<-0RdUCc?aN-D)&oaw-Vc>^e{NTUJq` zNjCHW%+I0Qaa3Ra8d?KC*ZkFVu4RoV*ME%`kQ3pf6}MuJ;8vue4f9Qw4L5>!TX&BI zmm~GxLp*oP{ZNO~AvghK8i#F&kRUUrAld!rEc#h*2D2)=X(MJEbIKL&VGgxRkbnI( z7VZ(G*M0+O0O=*+9zFq=qel-ZBrTX)6;5eng^Y{KF-%RA`}DW}V>xX{*2Gv7)DHN2 zXZm}m`+H}Y3???T?a}o6-5)b+--d-WPlY_wgWX4^YxMI1~~6 z>G!rwbm$YY=xjzJE>|BCA8Bw{tp?66*I-LaXZp z_|Y#z0`R!WFtZN6TKUaYte?ba823yt9I@^gnxgJ8@3BVzprA?By@-GC6ioDpUq5SLTpzL7P=GbJXM*`8NG&ZvRPUyrG(LU1K z4-SlTU1XVq%?1CA0LJYm$rbzsg%4~M^*4Ki#9(|FN{9`!)faP26HVd{SKlY%@Q2oT z(x{_5O0=Zfm1A0o2gZ7W|no!aQBmF^lYyAotw~O}%?x0WM;Q z1?yEo>j!s*;;Dt|YXuzjgCbhbkYJ7A%#jl>xsgy#y&Er5BxI}i;KdOM+3Sn&k{1a% z>&x)siiGm(*P(bpB;>B&fR}NRP+|QOco`oF71ck9mx+}@hH;qgl0!Vl`bO^np$sjMnadk?u~?|*WZhb8LoRG zp_#6VXy1uQXcolJU>v7J-iOE;Z^Z(C4bqz&`Ubjux@tf8b#{e5i#ckZ8z_Pjrsv^O zxF6q%c?quWfJsX}@(mU*%TgLci3oz{zro(yC4o!O-I5A3_E~M&)KeX>&1tx7m+<=Z zUjQ%e4qzVg80IMj?tjEwx!T06*U)$k`JEVJCjuQH{@4Pm)+xxS=9V`TC;l>6^|!1-MB_9Ja4AkWRAAL$syO&B z_pCENP-6{ZS!ttHoi;di=nH0wK;E59UkpdBJuv56I8bGquPnflh!x?;P4*H)+yb>P z?S%HMO!XqHEJyj?Oe5r%Z~mq!M=USm(ebZC@5(OKXwmCfaAhVBA~9pRhiAJBf`T8) z@;6z0wmOIF4`0mwW{iSnS1sg*W9MbXb}Y89f0NmBhSt*U@$tRH6Q}Fi`L_9*yU*aN z0#B@nZWDmM=bN2p_9|RtI|V*+4SEK;lC-g$)sDW}o!5-MInKX1o!=Wx%RB!@cSvRn z+p=&TX$B~q4{VZinLI)?z?+FIOZ-A4jLRm-)9)f@_n0{0x<(7(-;7Y$&9d+ z13w*!RN4E!_O~wJbZw|<_b=3A`pde8>4A$sOct*r0(bdL^J55#xrXp^(}YIKImq+9 zhm^Y>RBlJ_XC($F@mvvyyOR{=mYhK+_Tq$IM~D|26RkQJHJ+V=RuMb z``^L@%^Zb8dW%QHZT-A^OL6y>lI|@NJ$s!b(0lQ(?Fdbf;Jq2}Xy_f+5&WuV zse#WP1N4R4Om{b;HSGFg@QgbkDZI0W4t@vzyb^pMdwvrCfR95k%XV4SJvrK%$iH%R zr$zmlpmtDLJ?JBSViY4@51toeY4Eh8gQ;tH{JZEMxb8|wWx1@Ob%S`R;t4R$UmbA>vS~E0k2R6keK`4 zz*DF#`l0d^;9gyOKVI|7Azw;(4)OT zGN;46+~CA6vc`h-Z#LjeD4DvhG`E}TIm*=eN_WIpS!Yvp^5;t@FvfU>C z>2555SWhD9_8hn3_^Wy4Se{(?9hd-dC)5-Z0l0PEFO%+6#4WqN!=#g`=iNZ?%l35x zNyf*@L2AmA>!}>xrkmxU0=nJ>$f*eIkJo<(miduW&m;0U8GN^$;cj(yzEZ?7Ae4d% z<1JelIxrP>n}wgC!Y3~jUS|vh$10{%yYeroEZ#0LE2iUA#z4z(k5zuMsxE#ZW#-(|pRiU=Pp1;n;G{nIV}N*LZ@9+L0D z1d}G~v%L6Mtw>Wv5II80&B-?ZZV2W7Kl#tYSPp(p{0i~&;5Qk+3jAi_SB2l@_$|io zO8lanY4 zT{Y!u#>)K*{NMNgi~lY^V>=eSu;AqdhZp?U0><8`f1~~w{{IO7&s{NhMa}C4*NV2%ySe#qQOw^_m=R}UqJ91*BvXXVJ-HS|)m!I^pr;|)8UI-w700Iag zfB*srATTR|Wm%OqS(mPC$fj(`p5%6mN>BFXKy0PgaxRLS=~5~#joZnHAAbC(R!`3euAgQ@o^kd2(^zDv|UXV$<_%?>X>KxYqX9 d^}4$4N4EFxbltr^En4z3w4RZHfdPa;001~WA0Yq$ literal 0 HcmV?d00001 From 7c7785c3fca909d876e506e337eaa771a8f4dcbc Mon Sep 17 00:00:00 2001 From: Alexandre Courbot Date: Thu, 30 Mar 2017 15:02:04 +0900 Subject: [PATCH 2/2] nvidia: fix GP107 signed firmware It has been reported that the GP107 firmware would not pass signature verification due to the wrong files being released. Replace them with the proper files. Signed-off-by: Alexandre Courbot --- nvidia/gp107/gr/fecs_bl.bin | Bin 26 -> 576 bytes nvidia/gp107/gr/fecs_data.bin | Bin 2756 -> 2756 bytes nvidia/gp107/gr/fecs_inst.bin | Bin 22879 -> 22879 bytes nvidia/gp107/gr/fecs_sig.bin | Bin 192 -> 192 bytes nvidia/gp107/gr/gpccs_bl.bin | Bin 27 -> 576 bytes nvidia/gp107/gr/gpccs_data.bin | Bin 2100 -> 2100 bytes nvidia/gp107/gr/gpccs_inst.bin | Bin 12587 -> 12587 bytes nvidia/gp107/gr/gpccs_sig.bin | Bin 192 -> 192 bytes 8 files changed, 0 insertions(+), 0 deletions(-) mode change 120000 => 100644 nvidia/gp107/gr/fecs_bl.bin mode change 120000 => 100644 nvidia/gp107/gr/gpccs_bl.bin diff --git a/nvidia/gp107/gr/fecs_bl.bin b/nvidia/gp107/gr/fecs_bl.bin deleted file mode 120000 index c36d749c..00000000 --- a/nvidia/gp107/gr/fecs_bl.bin +++ /dev/null @@ -1 +0,0 @@ -../../gp102/gr/fecs_bl.bin \ No newline at end of file diff --git a/nvidia/gp107/gr/fecs_bl.bin b/nvidia/gp107/gr/fecs_bl.bin new file mode 100644 index 0000000000000000000000000000000000000000..bea29ce9f7e3f1e3ae05b5e3b9beafa0d1bafcd8 GIT binary patch literal 576 zcmew$B5Tda009a>$^pb=0uc}p17m<_kU|)SieF$5U|{&i!mxKqoj?r352j9__>6g+ zGv;&sWSTKsXxmec8FTozeUX?kOZe|U))^B-{(WNrtC`O+{KZvHqWb_1|r% zD9?JxK+rDyan{3r=0h#P)Y{3=3zFWvfPrTd a_s^qtcVZZR9^Jd-H!NtNz8$5|LjVACT4)Ub literal 0 HcmV?d00001 diff --git a/nvidia/gp107/gr/fecs_data.bin b/nvidia/gp107/gr/fecs_data.bin index e4f350e7629e86d63a999fe93a324b554e11d2be..4184ad4c6dd426ffd4f6208382c84d02c3b139c3 100644 GIT binary patch delta 29 kcmX>idPG#jD=|;O$Xvn5z|fq*(89{t!pg{SqsRs>0Cp}1eEidPG#jB{f;W$N-28%@_<#tqd%!j7&F*Y~TU_bX5mu diff --git a/nvidia/gp107/gr/fecs_inst.bin b/nvidia/gp107/gr/fecs_inst.bin index af6ee546fcb75acab10c5512672b4dc40850f705..8048c04df7fe9cca9a8e2a17b9c60fe67bae4189 100644 GIT binary patch delta 16 Ycmcb=iShm>#tn1A7@0QD4LigH07J|NGynhq delta 16 Ycmcb=iShm>#tn1A7#TOu4LigH07J$HGXMYp diff --git a/nvidia/gp107/gr/fecs_sig.bin b/nvidia/gp107/gr/fecs_sig.bin index e74faf2466ca4b08446dba93dae839006ded74d1..73b8c07796cce885f7443e699d71dc8f1e43b84b 100644 GIT binary patch delta 72 zcmV-O0Js0Z0l)!31#M&_pvef`mv|`!MyYchCfFkYa3!NaZKl-b*?zg1F@6pkL)p6z ec0@xeZ{iEEfBZRH{u20s9UG`J$j>eskwAbmQ68WG delta 72 zcmV-O0Js0Z0l)!3PwM1zsbRej)|wYq{-gfv{*nn`VeZR-B5Kd@C&U(*SaKMdZXMR4 eajK``fM5n6Wf={F8_ZWmk4NV~>nfxNkwAbxU?R-` diff --git a/nvidia/gp107/gr/gpccs_bl.bin b/nvidia/gp107/gr/gpccs_bl.bin deleted file mode 120000 index 82f88240..00000000 --- a/nvidia/gp107/gr/gpccs_bl.bin +++ /dev/null @@ -1 +0,0 @@ -../../gp102/gr/gpccs_bl.bin \ No newline at end of file diff --git a/nvidia/gp107/gr/gpccs_bl.bin b/nvidia/gp107/gr/gpccs_bl.bin new file mode 100644 index 0000000000000000000000000000000000000000..e924af4d68e799def9b8afc6b24c67eba852f48b GIT binary patch literal 576 zcmew$B5Tda009a>$^pb=0uc~k0%L$^kU|)SieF%0VPN>j!mxKqoq!3$52j9__>6g+ zGv;&sWSTKsXxmec8FTozeUX?kOZe|U))^B-{(WNrtC`O+{KZvHqWb_1|r% zD9?JxK+rDyan{3r=0h#P)Y{3=3zFWvfPrTd a_s^qtcT5<59^Jd-H!NtNz8$5|LjV8{YiBtC literal 0 HcmV?d00001 diff --git a/nvidia/gp107/gr/gpccs_data.bin b/nvidia/gp107/gr/gpccs_data.bin index 0dda3f37024c156fca0ad2b77c449ad879880ac4..081b91307199864e65f9b70fca78aee841e8cdcc 100644 GIT binary patch delta 29 kcmdlYuth+`D=|;O$Xvn5z|fq*(89{t!pg{aqlf|r0C0!~!vFvP delta 29 jcmdlYuth+`B{f;W$N-28%@_<#tqd%!jLbKRC~yD(Zm$Nd diff --git a/nvidia/gp107/gr/gpccs_inst.bin b/nvidia/gp107/gr/gpccs_inst.bin index cb641c518b4e721a6adba05434fa673b3ce13e2f..27f735030ba45651e8545832bca6b1d9f9a6b7c1 100644 GIT binary patch delta 14 VcmZ3Tv^r_SReeUL&DZop838hr1>gVx delta 14 VcmZ3Tv^r_SReeUr&DZop838hl1>XPw diff --git a/nvidia/gp107/gr/gpccs_sig.bin b/nvidia/gp107/gr/gpccs_sig.bin index 966ba907db400d104f471da3b8e13a8a18a130f5..26db2fde8398eb60a5b13ce6d43fa0dea9676e28 100644 GIT binary patch delta 72 zcmV-O0Js0Z0l)!3pIN$&d?d!8uN5SHNA@MkHL-9IxA{1K4mr&ZnqX!h5hB1^H0p>{ eIMR}KKm*@RcPbe#?RI^GeJZxgkK0}XkwAcT!XIA% delta 72 zcmV-O0Js0Z0l)!3(LRwHEP|mjCfc05YoKZ(