From ed5abf46b3c414ef58e647145f19b3966700b206 Mon Sep 17 00:00:00 2001 From: Alistair Francis Date: Mon, 20 Jan 2020 21:36:57 -0800 Subject: [PATCH 1/6] target/riscv: Correctly implement TSR trap As reported in: https://bugs.launchpad.net/qemu/+bug/1851939 we weren't correctly handling illegal instructions based on the value of MSTATUS_TSR and the current privledge level. This patch fixes the issue raised in the bug by raising an illegal instruction if TSR is set and we are in S-Mode. Signed-off-by: Alistair Francis Reviewed-by: Jonathan Behrens --- target/riscv/op_helper.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/target/riscv/op_helper.c b/target/riscv/op_helper.c index 8736f689c2..c6412f680c 100644 --- a/target/riscv/op_helper.c +++ b/target/riscv/op_helper.c @@ -85,7 +85,7 @@ target_ulong helper_sret(CPURISCVState *env, target_ulong cpu_pc_deb) } if (env->priv_ver >= PRIV_VERSION_1_10_0 && - get_field(env->mstatus, MSTATUS_TSR)) { + get_field(env->mstatus, MSTATUS_TSR) && !(env->priv >= PRV_M)) { riscv_raise_exception(env, RISCV_EXCP_ILLEGAL_INST, GETPC()); } From bfd05e8127353339e905a45990f3af379a2c2aec Mon Sep 17 00:00:00 2001 From: Bin Meng Date: Mon, 24 Feb 2020 05:39:41 -0800 Subject: [PATCH 2/6] roms: opensbi: Upgrade from v0.5 to v0.6 Upgrade OpenSBI from v0.5 to v0.6 and the pre-built bios images. The v0.6 release includes the following commits: dd8ef28 firmware: Fix compile error for FW_PAYLOAD with latest GCC binutils 98f4a20 firmware: Introduce relocation lottery f728a0b include: Sync-up encoding with priv v1.12-draft and hypervisor v0.5-draft 18897aa include: Use _UL() and _ULL() for defines in riscv_encoding.h 7a13beb firmware: Add preferred boot HART field in struct fw_dynamic_info 215421c lib: Remove date and time from init message 838657c include: Remove ilen member of struct unpriv_trap b1d8c98 lib: No need to set VSSTATUS.MXR bit in get_insn() 0e1322b lib: Better naming of unpriv APIs for wider use 75f903d lib: Simplify trap parameters in sbi_ecall functions c96cc03 lib: Fix CPU capabilities detection function ab14f94 lib: Fix probe extension 813f7f4 lib: Add error detection for misa_extension dc40042 include: sbi_platform: fix compilation for GCC-9 bd732ae include: Add guest external interrupt related defines 6590a7d lib: Delegate guest page faults to HS-mode 4370f18 include: Extend struct sbi_trap_info for mtval2 and mtinst 086dbdf lib: Fix sbi_get_insn() for load guest page fault 2be424b lib: Extend trap redirection for hypervisor v0.5 spec 7219477 lib: Use MTINST CSR in misaligned load/store emulation b8732fe lib: Add replacement extension and function ids aa0ed1d lib: Remove redundant IPI types 1092663 lib: Add TIME extension in SBI 9777aee lib: Add IPI extension in SBI 9407202 lib: Add hfence instruction encoding 331ff6a lib: Support stage1 and stage2 tlb flushing 86a31f5 lib: Implement RFENCE extension c7d1b12 firmware: Return real DTB address when FW_xyz_FDT_ADDR is not defined 9beb573 firmware: Improve comments for fw_prev_arg1() and fw_next_arg1() fc6bd90 docs: Improve docs for FDT address passing 46a90d9 lib: utils: Support CLINT with 32bit MMIO access on RV64 system c0849cd platform: Add T-head C910 initial support e746673 lib: Remove unnecessary checks from init_coldboot() and init_warmboot() c3e406f lib: Add initial sbi_exit() API 55e191e lib: Add system early_exit and final_exit APIs 6469ed1 lib: Add timer exit API b325f6b lib: Add ipi exit API 1993182 lib: Add irqchip exit API 2aa43a1 lib: save/restore MIE CSR in sbi_hart_wait_for_coldboot() b0c9787 lib: do sbi_exit() upon halt IPI 15ed1e7 lib: improve system reboot and shutdown implementation 73c19e6 lib: zero-out memory allocated using sbi_scratch_alloc_offset() a67fd68 lib: Add sbi_init_count() API 049ad0b build: Use -ffreestanding e340bbf include: Add OPENSBI_EXTERNAL_SBI_TYPES in sbi_types.h b28b8ac docs: Add description of using OPENSBI_EXTERNAL_SBI_TYPES adf8b73 platform: thead/c910: Remove SBI_PLATFORM_HAS_PMP f95dd39 docs: platform: Update SiFive FU540 doc as-per U-Boot v2020.01 6ffe1be firmware: Fix placement of .align directives 7daccae platform: thead/c910: Don't enable L2 cache in warm boot a73d45c platform: thead/c910: Don't set plic/clint address in warm boot 30cdf00 scripts: Add C910 to platform list in the binary archive script 0492c5d include: Typo fix in comment for SBI_SCRATCH_SIZE define 046cc16 lib: Move struct sbi_ipi_data definition to sbi_ipi.c 3d2aaac lib: Introduce sbi_ipi_send_smode() API da9b76b lib: Introduce sbi_ipi_send_halt() API a8b4b83 lib: Introduce sbi_tlb_fifo_request() API 5f762d1 lib: Introduce sbi_ipi_event_create/destroy() APIs 817d50d lib: Drop _fifo from the name of various sbi_tlb_fifo_xyz() functions 84cd4fc lib: Initialize TLB management directly from coldboot/warmboot path 0a411bf include: Add generic and simple list handling APIs 37923c4 lib: Add dynamic registration of SBI extensions 7668502 lib: Factor-out SBI legacy extension 161b348 lib: Factor-out SBI replacement extensions 43ac621 lib: Factor-out SBI vendor extension 021b9e7 lib: Factor-out SBI base extension 85647a1 platform: template: typo fix in system reboot/shutdown names ac1c229 platform: Update UART base addresses for qemu/sifve_u d79173b platform: Add an platform ops to return platform specific tlb flush limit 2c2bbe7 platform: sifive/fu540: Set tlb range flush limit to zero 5ff1ab0 makefile: add support for building on macOS 6d0b4c5 platform: Drop qemu/sifive_u support 9a717ec platform: sifive: fu540: Add platform specific 'make run' cmd d6fa7f9 doc: sifive: fu540: Update QEMU instruction when using U-Boot as the payload 179edde lib: sbi_scratch: use bitwise ops in sbi_scratch_alloc_offset() 897b8fb lib: Use __builtin_ctzl() in pmp_get() 1a8ca08 lib: Initialize out value in SBI calls c2bfa2b lib: irqchip/plic: Disable all contexts and IRQs c2f23cc platform: Add Spike initial support a062200 platform: Remove stale options from config.mk files c03c8a1 scripts: Add Spike to platform list of binary archive script 29bb2a6 docs: platform: Add documentation for Spike platform 48b06ad ThirdPartyNotices: Fix doc styles 892e879 doc: coreboot: Fix doc styles fdfb533 doc: payload_linux: Fix doc styles 44d1296 doc: andes-ae350: Fix doc styles a8ef0b5 doc: ariane-fpga: Fix doc styles 82fd42f doc: qemu_virt: Fix doc styles f8ce996 doc: sifive_fu540: Fix doc styles 27a5c7f doc: thead-c910: Fix doc styles 0b41453 Revert "lib: Use __builtin_ctzl() in pmp_get()" c66543d lib: utils: htif: Fix 32-bit build bc874e3 lib: Don't check MIDELEG and MEDELEG at end of delegate_traps() 24c3082 lib: Print interrupt and exception delegation in boot prints 66fb729 platform: sifive: fu540: Add 32-bit specific fdt/payload addresses 3e7d666 platform: qemu: virt: Correct the typo in config.mk c3b3b8f lib: Fix typo in atomic exchange functions 3936243 lib: Use available hart mask for correct hbase value f8b3bb8 lib: Simplify the for-loop in sbi_ipi_send_many() ac5e821 include: Bump-up version to 0.6 Signed-off-by: Bin Meng Reviewed-by: Alistair Francis Signed-off-by: Palmer Dabbelt --- pc-bios/opensbi-riscv32-virt-fw_jump.bin | Bin 40984 -> 41280 bytes pc-bios/opensbi-riscv64-sifive_u-fw_jump.bin | Bin 49160 -> 53760 bytes pc-bios/opensbi-riscv64-virt-fw_jump.bin | Bin 45064 -> 49664 bytes roms/opensbi | 2 +- 4 files changed, 1 insertion(+), 1 deletion(-) diff --git a/pc-bios/opensbi-riscv32-virt-fw_jump.bin b/pc-bios/opensbi-riscv32-virt-fw_jump.bin index 6c5b7b89f676392b687d9835ac9fbdc34f3052cd..c9654e70471764b0ee13e4d10b6f9368c6bcbf57 100644 GIT binary patch delta 19518 zcmcJ13s@7!7VvB~yGcML7$m5ukw6esMC0RXEAk2vs)!b}+K0-DueMrCZEIU^z_7uf zh&pPd)n2p;%5ANcD%N``$SYv0Qmd$~Rcb`4wGCD&f&%}UY@%q}d++~$-ygr@?9QAy zbLO0xGc)JRvb{`HRxUDV#SALSV31bEqLBewDLgS^RK$ysmX)E7=Qyzs#SLH-N-07L zsWh6OJYopscu9L(LzVW0yx6FJ@A5%=seG=9I3v*Br1 z&d6QPoHnHg;CguUa+RDs!08N7YdLDn=c+0w?pqtxc7Q%WBXwRmwMn#zww*}sT(g1u zzMLUU8L-hdmaBReao<)@FCGy1q#x!a(T)0c}Io(`n=rk1p4ZRNauTnb? ztQfdLVN~}*YE>!{8WJSpcT*`yDU?WqGbd{Vx*QIq0u5J(IZKBJkyX)}La=_42$TrgpXuu)w2$v1no0N3IgP$M1Yjz zpKV)mXL|UJ;8b~dD8Ohz7!svR7^y?UZ*w!=br*yp`Vya^{htezrpjl9-U&ZCP}diW?4?mK(M?z8!4PSly|Pn|mRb^VF&YA#o&`4nc@!{;So zIqORYn|I+6>^N!&Uc?SCeAdM4l!u`mrfQ>IRreIHr>$Ekx;lg6+**1Yt$QeA_2-nI zWO`1yrD^ebVT5g5e_VBvV#y~feYqN)MRHo}Ryd5P>SlLF!oZ#U( zylh@d3zsev8>{=WbhV77twF5OI-cFlezPGGzbIE5ax2zYUc4>TY<8R8;dqj(X2-S( zd7*}g7U$E1i5+o3v(A^am~YtcWjtMp=;~{T zKAnM}C&+keG)14fi|C5a(Qc`qbT?Df*hm!_etHg-v)aY?s7SV4ax$mrx;J&Tmv$jb zCHKO8j8xI}%SgNM6#4{y+WIp$K|G;lbCfo3<|b$SgM{!bd62(Hbq{*KIm2XrnHO$nPLa7{r;@S9e6sFQHFt z0eNLmq-(SlwC$!{`W-5l6gBA$RJu;lFO%vUqlA7c7~RX-rR~TbninO!^Do;&8zSwh zvN?r3mzd{u{F$N;{)wZAq6p%?)u9 zw_cdZLISO-ckH36Fa;}ayUYtYd*6+*hoXtJz8^!!xG_e3Fk_6FzyL!?yYz&>A*FcV zL=mRWxGDjevhgRJZ&mLCgMY(c$_BU#9f0?FWASyFzhN&y)B;2on(d+Cx?s~OXC(%Z zRHFnQm{*{}NHUO7AIJawVh>v!I^X+_fYAst2p`d%?<%OH3JE9`$^#Zd`S6m@QZ;C_ zF=iWO)R`z+pKqXy`XkhC_T+|0Nm9;Lm|dS#7^{^GT@AL?8ps%};~2*rah7r`TEr2a zewCVXwi-z-dx#y#h~E*O+jJ=0FM4xy7#~5cNh{=ujj@M^uhRE!oXnY? zgX`}_6tya;l{pu^b8h?$LY-@@_5!;g2D{)7c40JrJ|f7l2`mDPQ`8(8$ET}}R=}tc zvoNOtYcz|uW+KHlmMUswsBf|r-kH?Y4YbaiHcn<~qfSH9F=J^zMw`+HSgFlUW~XlO zJR#cVpa7IyRCdGomQdyF4;u)B=W>kI=fPT75p8WUfVpTz-GxsW0-=V3Ih#%xdu@Ci zpE9_k7=#H@Oq~}odQ>zKKM^jG>n9UQiDfUb4JqT1G$b=!uV9gAa2_w=vaQG~%2U$O zuCN56V_VlAALUfusOWREh#C!R(q3G#yE4E0L|Odhncpotl_oV+&$u+_!b|nZXBVDX zT347IVm@R(lBEv0)($e9di<>$IfWUVMbZx|8ET@wm_=P38*;DCSMHX;b2E8fq1;TK z%gFO8WtIe6Te~`p9Ww{ya2qZn?v-&$ZQt<}w%+Y3GPDL#+!l#<(OrKkJ(gQ9?ydMB z7zrk$U|7d9VIL?z25ZpcmOnowD34F$Wn7k6j$6G@%lCBcPB13fU`##%V^Tu-$+Sx@ zI;LtMrRbYUX_vGiThsF$bg(v}c2m)Q?6}DBaV$kCQ$O1bpoVm!ItZ=mt zX$bXGUwb&*f}G<`K-WtN`t+wK}uJ}Kddh_ z2j|*DL&JA|{p1|n+dByVyNAr6QjIRm=yP1TAG9sI!4M7eY3W}X17#?lPq*%vMdpR4 ztnuz|;mOfwq9bDu#WEla(yrzNX*sTDMkSITFc)T=Y!tei*-r15AkIzJ%gJ-w_9zfY zLsKv3e(Ii26nCSkhb9*`f-*$5ES~#`VFV)~f$1LzMq(U(-XqA6ZY8>*8dK**hf=yn z9Qef%9t0b$^YYZ)R*{y~g$2I`n}d!k-zVFaEW0rRrswjs4yelir=W}+9Xzj<$x_&1FW4IK~B~y zL~aTRk_%Hw z8hoi(qLMhC42zzJV*TPaJM==u{(?vL8s779eZJgl(GxjWdg<{fPt_B-usGntU@si% z=@qyMAGEMmGkQ%qY6#71ken1~E-kq;4N=Hf5q z!$bw!@GW^iQPUPI_4Mr_!8@YDwoZYCD}us1JpBpbs)w@^WK{cbQv6UOMktoBJ&bUkSO(_el(;~NJAZp|8FEMz+NV>R{-o4Kc@KqHr1!-a`oJ;;@%b$ zSa=h=Sz!r4V=cZ>M=WbHjX?~egLJ6K&=f>*8Is-|v*=(RaniQl>CyaBuBQwfDY<9{ zU%v&mwSKmn{#||ZJmd&Gr^NM&bqNwRQx_!E17T2S-2eWVm9Mg}W)HF%&LtAY> zH+J4GmPaH;6fLSpRe;k&$F2FjN4lO#Irp7bV)z}UqT=3#7TeF~JClkZ@&#-i2V@6R zqBb|el#Q0%E8<5}0#kWP!c=x?_ZoXEfQ4Rd;`C@{sjY|Xt`@p*hIBw_``N!M_c7|( zgkASGgUEr*%6@Yps}uw|$hoKH)4;@x99f)-Q18CQu!mPr@c%r|UrJKZ!QSUeW`NO3 z^K3axQsi;&u&^S{EGH`xvAJ`~U{%T}%nISN$7D?YqK1m4;*=kN&2|4dvF|>t#77ka z<>4!hLGGw9m)C&}l-G&zb;US?V_hzonh_OjF5J>LFOJ_o2{V-)Fws?Y?~td}=ME+K zC2md>&DOy(v}%Rl*|<8kUULTd2!^~VmeeJfg*MNPszyFXGJ@9~$QqSpSIG@RBY{yD!goX!nz`SbP{%BF zo)}#!#KP-=}JYl)JD{<0=nK0h-T_Oz1#lxHG1B(`Cm7O4To)C$$qeTQt*|uD?;N;cG{B%&H}OOO(A~P*?YDjpl?) zl{3qUG7B?GeiRy!4BrvOt(AByp-J!z4V6Z56ytoe2KR{KvKTKVP*z9+gS?_v>$wHz zz49&UJPGbwG9Zv7uU342Ee z8JHAenH-cpE$}u5x+8k88!`sCp{m17N@Fn%Pxj`Va*}Ir_9&+V+{yd#izU-%*OnyB zZaYkJrq8xFPb;fEOt8pvPN{(BQM%eO$sTQMklYxPB&B0?Qd*xPH5&9QrQJ_dpBNRb zfryUdrJP(6T9~0=(!`3kap-{AjzZs5%y|dFIw+;9Go+l7k;7UDo|n%bqo8PQZB@+7 zM0loz!mX{6`9^idUFk;|l~Of-R{9ZtO-g8jGin9r%M39X3(P2W<2Wy4fecb5q_L0& zdZlU-O+Ql5jc{uRa17r0PO1%bHGG3E@WLQ%vB|TOf&q{&Yj=mMR zNg`6Tp6`0phw~oL2T}oW2_C8V$DJ*>X@F5d7Uhz2Imwb2bMRZOtsLzpHs;5oo-yBe zbMxz2Ca%c)JM>9b)vtsZ1K~#TR;%Pk5EJn8P)v87Vv^6bA?DXj`&^v=C)|V=l1ly; zyt>&omig&UAeu)Ttcj%Gr~M>~w$hs}Uc|6IQtpLMF%->F(i9jf&Q)v8>oUHoUdb?DPTv?pi|6J0;YQVP&DJ|}39 zXj9O*7ie58`zU>nR8Z3A50wNxR6*zLoL4M`L;Ly|y06ESj@S)oVB^Jq*?PPEy0>Um z(#R5Wz>mL74)msKa?qb~Y36rxE~H5d%^~YyQSd2TcgJ5fT4PQf8ai4S$IVepRci3T z(RYILMspQnQHh?rW_i!@CRh!VNvg2;Kio#72gFfvwr|9p<7D7bj&1AGw)s=pdK=Rw z+NtL}+eFE*Ej@h_4zONR$l+C>k*`>l6r3rTp1tf#CM8%i@c4PzV`I{hLn7H!h#<7)pDO0CgR>LE$g{G*Rp$aSy~Y7kh+x7d0yrX@$A zVMn{P6~8mMw;|aC`@;M2ygKA=yIQs7f!c3DhuS~7L#;{dfTL!Ovwzt(8M9`2^B~>` zjM7dqhju{cv=IDuP{PpV z&6Cy?HB5a)gcJN`jHPOsm|ePY3=)ASd{*Bd;r|(~?VD?R*SE@rkrqub(k9_$)4hk- zFVjti2FGBgSpr0Q*h3FWsT+8!7gCt|AlNmBs@}t1YB(d|F!gvtieuaL9)u-c zCXG-!;$*oKC=dPQ=O>)*fAG0e`u(SAa4s3)_-d?nIG0#I@EDgvbm}TBu24on88}k{ zDR4Yd-OKn2p(_R?6}&s7Se&X*UX_%0*;7~}(#Yz5y|LnOa(|;6&1A`~2t)Fj?8u=9+1LBDR(da-#`f;p6 zX@YoIF;ZAqYC8U)hadiDaL}L|p9JX(Gl*x9lQxR~;IqIHF+tdOsP_~89LOzNJk&#^ zNJtwVoPA(j9G?#^+Uq8JxIDEeYj}-F#MTxihEAjc9g7hkVQ;>|(^X>RS;dRTPasbz z9fB>WnncR*(UAjuS3&P(=81%v+g7>;*sl?^OM~n1_DG+eBI9Je$QZLoWYoVU!rr6) z*8jhCaowmr6CEt<4fLr|4--@B5HIS5nki-S%EU@oOmAXIG}4&91UDI_1L1bQ`gCE2 zz!>ij+vJ=07454&Z^0HlxYc+6S5Igauk0Cw`;Gn^Ir@MiEepw-Uai;>$*nt&w(Gf+ zMsz{Xy;*>EMA>rB!zs%ZF%a;FAE$>@AvnRmdQ|*E>}Ov&>w7?b{=6tGQ?BP4t5AZT zTYW_26J_grzLU`WiO_sQLJKsd$0r}ZWQg=SPU&AbzP4giv<1eE`apr(1V>zHRP@SO z!jsUX?4)yy$$X=@%qCEJ3t?_&Q>Wm^_67HYZ^Z?mLkN?JF<`~+uk%lwsyJE;&#kt+&=-%VA1wndI%T5nk0sW#b3(Z3IrF}=*L#VlQY9IxgO`F zxNQ7{etV1mv{-abOo|Q0KymxIl6Y9wqT4mR+7AL+b#tpbN(9r2q)HGK7`E&C$IGf* zD~OP%v*nIl-Qq0&arpRGZ#(mUm^gA(n=}7%&yh=%{n0Q=nm#z{*J`cShqs%*xAIKbQD&)iXBN?zaopdSOY*!mp`w^uh zo!cBuoFHq`Ao7{=OYzjCmg4a%{4Qy}i@OkCKjUl~VlNk(4`hrrhh^DOxM8p!l>dNR zYVlUi1R=38R4nPVn+0kS~%m&5U09J~Z2J&S2;* zAxCRsAp&HtTfV=0DWxOjkYCny;E(yFo{NE&G0>Jri-@#E8AwBAUHj*k3Y-=Jr+xJ< zRM_bNuVUa8VA!<>QzxFBWgFCTcWP4iCP>5dkXVTKnVtP5RGy&Gp&oJ#Xow$_K=ZZ% zEzMJtR+iE_gN!&j(z}xrdICH5gJNPFF<+aGN| zi0->9kG-6R4rK&qjWv%MuE;#wm8}QwTxS!4@n~qUh?KL)id`@$OMGn0j__mP3w9i= z8oIJmZm&w}vyUda46Jns-YKQraTHP0CjAT^#Xfk6shTP^A9!utQ!VLKcE+m z=3PAz69U(tB=Fb05ZL(hF68|9B%SW^G&~Z8K*a3o%R`~UNdMtU690{r?7xub=?hO# zT9zhzIFRZh*GJmRa@t&`jtnDX%vNwUg1d1taXW&`k<~V`RHP&pZjERgn@~WNF{Teo zPi7!?9RORjF|bK2x=t{JdnI(uEZ70*VSl>_0;q4n4yccT()FyM9AQW#4}tMh*(tKn z@V~U2m^Q&>AuT6Hk&c4aVhfnP@%aP5v88ux+S2HXXH{rN`^n0{T8cIr=9kTn{O7&8)CYkz-a7vq*%2!=DPI z8*)C!OP^A^e;&sh&sHLPL)T%v{i#6D&y2J7BV%GM*ruK9?G1)QxbCT;?w`1@27QXz zr-u$IG@j2ubp0N*HauOYWq%i`^Tj|TCm;OS4TeIT@bpvE9=!hP2x>Pz_4HsW4>v!p zrgmVji2;g+oLuAiN}$h6)Z6Ytta+|Av+ zcVwkdTg2#xVsaG#tVqM$jk=^Nh+*U>!`cG@mpo_6I8)?I^ZlIV&XjSc2vU#}xq%W8 ze*5tY1a|^LRiR2)<`hgo32ac`zZ2kkPa*HQFv2huwrs>~SP9KHjwoXRRkr_KyCd*TvH=V z_-~W^4DqK(fMdqj2(B+4FngX77VUsSPo2GNM73jonpZH46EPv=&Z5zEgRPd_S4?u; zS4@^Em~b(7bi@=%v*Qm$WasQC0QWL_Rgh#C9e3*fxX?w%+OwNtLL&FD%s^7PECK?s0I!bu0PMCAwGQMh>; z6pDASL-6JBG1PkO6*1DgVZ;Yq51CuH3oMTNE4Q^lFCIQk?nsot$&70#=rys5ihBa< zvGXKtJr82EQpTDlIPA6xVuXqQ6S@kQrIgeeULmRMfSq86f{pHo$3I5+7#i$3wpZW3 z2m2Ri)Qbd*bTHIY6OfNX1a*d=Z2g!91v5`UiW1}m8cQ7`r|!x{=Ev@N2@GtME_gOR%Ddx_LfhWLnXQJ7^;r1@`e8lk z3BG%`)n3^qv*L%0-iJ|s{v8-XCjASg7G zKf|XY6=2MkL!KApk<_OVB*0et!Nou%g)^sPzZ`JW-eCV&IHCpK@QUK~MG*Npm*dYtH`dPzJxKj=Hcm$M`v%s81xfCpqTkyB!s;}i`VvYWJ zhKVJY)QtJ=aK>vxgs^&FQ{C397QltrSsmD#hSOV#8pzXfY%Fj`E$8797{dCtt~Mv* zDW^!c)I(dp21Yig%AX1KfFsRgw-ERC9;zf$r~9ZDLZCYQfo@KaL&~~x66qsxzK|@S zl)>vAbp2b)(xU~A3QO_881J4BZ!oa%k zq#M+F{R>h=_Fy~38t~c zVfX-!3!Si4?6j8|K0K5#&@Yk9Q`b#H5`YlG5%HHvAOef@qoXtK*PAq^s}9F%!>mH{ z>>C(XSW65@+ms)Cd)*Ps_9#574Rx#=3x|%db#pQw;is(%Xru!(?&Ej#llvVB*F?wj z+oIXn-)1MzIWs5n`9sh9y)Ylzhl8oFVWz{a3FkkDTQj;t?dMNUwvLUzy=>6BLUT$n zp{4k$wM+Z%&uIVmV@k=p_T`_^7vD0%^UqBv`$``H@0t4!yzKLyrGn$(M9ryc(jX3l$?2)9@z${6@)M8RtMg>0jTum}!#rZ70>{vN(Cx;{E4_DF01aA~aa zmeL?@x>_TptHwI+jx$swcnXsl?cyr5wPFJ4!UGVrV=oTu2ZO-jtf3Bpoot!CQ&$S> zp9~Hg?o!TF~!N z6baW_;o2kIR?kNfr4FVD4lqT=z;3wiN?5uo`6dT58TTD}A9lChUgpu-v()uv0Qo9_ zd>uf(47gf(z5Hfbn!!i0Qi%>^j52?j6`94+j5mIH99-kByuWjiIR&hkq^R{i_+G~# zF5T+ebKwA%TVs_fOe+z$);f?`*pr3Sw+~4(tOLJTl_nVbqBX4fqhx@FRo3lNkZ4RXZIhesIL1PAfpXctw+K z(}FH;a}PO;pLTryd5A(<4HB)gfU37>Uo4;?h7OA$a8(UVS)ELQH(1zBc#AMQ#n6z1o%oG6s|LB zD%*hfHd}_|`d>48F=qz&Dg^1-%ch;*TZ+%W3-i=wmi*)ia!a3b<1jw|3>vJ*t(gW7 zuGcL@2V}G>l?a7dnne0*9VN0U5rCF-Siy+zyYj7~9}bi1{FD`kWezga599BLB7FZ{ zw9EZNcR?k5N%uUVxzGNP$4}XHSeTrK6E(ysXgWpQgD+i9le>mv*t+s8PRw|b;izz{ zypPWhg;>8;@||Tzlx!hp#){NK?zZn-*UYTXQ>&G5z7fggacA7%DaDpX%mQ`!B-|-IsoZ zzLKh`@1-A6Kf|zlWV|$S+v3<~etVu6F||K1qdD77S9Ke2F;7YT49)>ZL@W%r88F~# zgB}hzm_ixtHlyUHzh?1b&POc}YkVK4A65TA@8GfcoXhsNtb+-y5_75%wqK@$)&|Gr( zk#Zg>t{|TD`+7G}VKm!0P!Xa|Oso7pqED@p9d`T#6 z6{A!+8wxjKdHhDJ2OL=bP4++`~)+2-|}&2pzj2-EUWWC>bn8<0OSMgW6=?Q6n_ZX_;fcRa0hgtP78ud zB18uc!n^R_|A*?+c0R1Wv3vE?AN)_%?Uskt^SW1Gz76*q;%oR%JwLtquX;XW6VXK+ z?{fV*N2Eg)2QvN>&7ADVX!dlBNI{(Tb@xBk>+6YA#nKrsX8;j@zFU>;s%b8?3i?2y8cd}B-A(? zz7qW%z9sRlNA%1f6v-aSC8uq0&)mOc2pgdF{?9Z_yf*j8Te>$vay@GvRh-~0pq4FNyBJANfQ5}E)(d?+}2 z^-Vre%vZv*^}0_~VJ4;H9yB?c6>^)d;Y$ev4A2OCdvKMoqTc07i?2RB)e09S9js(t zSsPU~k&GtiiPuqPZ&eY-^@yak@y5tUsb zJU4yYosrMR2$2xdh1E$vVD}kbItXs4_vP1FNV@xXXL_WLREN{wsfV(7sKm_E+oK3J zHfc^f8##p+%$VxokV9at5>mJtT7%1G^c^qcS>d*+|F*Q@;;?m)Kw8@aFB^iytITUfMBh z$8qi%7Wqa%Rn;i=kcIHJde(M`WC^|CS;766@}X@8+x|=O>LlVRaKx7h*Z;KcaB#Y} zSV%uDczNKzFYdX5zvh>OIipD8s)o1|mcD(c6fo>@E7 z24BCUnJ4EL;kDzAa%`Ug+?jp76{f&4PFm%|#pd@?m?UMKTa`CF`#@KYa$YU$rZs%l z&R;tc$xPRP1t8`JD42kP?3@pGCZENGg8Mly?s&ck6AC@f8G3VH=X*IwC|X2!0>h7{ zNBdT+F2yEg4TsM8K$RMfIwyyrUc*a1LF>I?77}R`yhnCq*#(L-{#pujvAf3-sbyz`?-6OyuqF~=$~*>>+Dgn zzZgqGM{y#88a~SA+j0-s8AaG(N)?11rV9EE?66fVVaL|L<##^I{N0^Eik5psIyNKwE6_YhXx=VyFk;Z#e189J>s{zW-amE|Mx+(B zhwlW2IvP$XF_UU**_(F)RgOkpJPhw?*S-6p@a^y@u%#%7B*z2T$NdB{1 z_Pj}(1j^~rI}c}*(j4|0v;hSs%(Znpo(wKvstdILxBX@QmtB|r~9LuJ2vb|4u)z^_V+!fmqa0#n5FtHk^R9Z3D%V4A z+DfyHL#fDj9*1kxqNkOJ{oNCP4L1o8tRKO53<(}JR$kt)WM?GWF18%;E4-{QV1_uFj;Z%N`^XbKZ-5IOtT2=%fTxfapi)LzRfd7 z{z9A+OdMA$7U%Qenjjz6%T?GtC6qom*Mh@RM$iWbZO5;r1kwkW|Bl~J(NJmlc#4{u zhZ|F}pezHwzVIBBeUIZ7g@}S`@jHuN@+0mk&6&75;S&Yos2Y_u)^sE**nGe|`)`FA z5yx@oB8@106xJ*ba9`Xi`V77ZUxhd$p1D{R!oAvxJ`)q48*F)JZ%!0GJkWu0I4=IB zm@~N{V_;>6IL8aJ;SU{5Sn&f9fb9c)#|%?Fs52)E_gcnl^SZ7Vnz36S#3k$(G5d(3PiGW~ zw}$g#a^&oL5{sd1%6JOC^)SIVF?oZ!aP_h=o_U4_fxaL2eQFkqg?UoP)U=Uw>)f46*^BJUq3i7H5xpdR>z9seEt z^lNH5uj^}^{8~zYAnSeP<7InZSGho4(2b_R@dpZ;NBo3uz1BdT#wS+{70EUgwXaZ$ zCEg%^Q+{HR&zsMP)Oq$=Eb9Y*UuJxSCYO6N7Y)ec#oYW{7~jP0W6$%jVbj}7=)7s? z@o#U3i<)-g(W^ceWp2hdSA8hTTw9d&&LojUi6EXHxB%C^w^Mj-nvLIBZ6VLb0!czq z@4r{l{bS=}6X!-vONviK$ZgtdDa)RXj8(lEuplI0L6H`Y5dC$pzrOr+Rlow(qLeq@ zSh8%9YHIAW5vu2==;Gb*^P3u>lBNZY@KUp*b0Ax#Q94MdGzec zn>ie%EdU5x04YES;M{_DQvUXQl(rAxg!7%`O-@E>I{+2{lz;pg5P!4bpp5>5^0(cGJ@9=&W z(nANjx^4js`?Ra;4S*v68hBp}Ff|qipH8oupmGigH-x6@qIG?r%uJY?03#cIc=fh% zhU+EJ1i;uYySm~5$on#YNO;x&)Fh&`|Bo={55#?v9&d2TvNuv*e|_a^Z=?=SdHao& zWeZXkAiQ{cq9(qnt1BA72Ot<=AOOkh4t`De>h@8ZOE*E@0F!_2>S}PNB(FP6{<&yE zZZ9f3{qOhtefV4Mv-e(m z?X}i^t-aQs(lXhWQkgkraM*P|0(skI2;uayFg1;kil#fXI}%Z6*#u#i3`ymY6KE}s z?0|y>dc3fkMuwg*gbn2ufsU)(+Mb;~abJv9D^TtPc$b0ls1xU|*sRPEFQ?fc_OtPQJ=Dag z%OEe?b=hIfqQ}2)=qW>DBo%4ET3Mg@+$DPzXxD1}*^!<_Z?@;CR*8c|T+TZd} zZNM(nwXd$Vb9GwXU)R1Gig(ETdj{#XLoXpUM_6m>i)&?mvb<3Ii)^63>5RRYuweR8 ztKpD0*D$5^L09ta0XT#nD*HJAzeuOXM|x;AFSwKvyw4UPDUenW1yZhm4Vx1mq=g*~ zNl}LB0Y*y7NbcuWM#>PFmUG|nkd%^m3=ftE#96r%38<3&s% z*05oI2n|@e>zn)&HICf5?s*{S5Wf`j~92wo)p) zh59yUS`MChC*0A>QOk4A=kVJ&rD#+if=-zvyHnXbO*HXLixL;b4K~}d_)Kmf@980@ zjd_e~v*CBx~eO+YULXzihd%Fif&Zdy(m^dlOHrgWm&u&@>FeR}m>rjyIC zRSR2yuqJ-|!t1>332y%jX49$|W4e7@y9jJn1dqE*QYUI2G^&Msef;#O>q1qOOf+X5 z{aWJp$VtMz(m+@EP(sCN1e_!Kq#U>opoE%oL|0x$bWH{VNf3Q(BqdbeLUi?KhzyHA zXGm(K9F1ovLvj^W#=`J$$FrwopU+98FDY>EwG?G?EchN7u2iF+){}mkHPWD%mCrT! zderYcB4zbc4wcX+B$d%_m3bOoKY=1RL$ZldePE#sum6H>1}gPTv`QhrcP-kWzK#B# z<6Wh)s^waA6)_5tYuH@(z;1yVZCS8L4XKLFUt|{{FE%bxL#kpL7ip0KInA2*fl@)z zVy9-q0AAtQ6Em4eo$H#dsW1@zZw4v#m_c&BoI{YxRIL17m-@bGMjm;}Xj5O9uAVSm zLtq*|3pz<~jr1kvr}a_~6=tVqiMmFV+BO314ZefvDjy_N%0aCGNT?Wz9&7fH38fEy z-ZQ}LqTmfw{6jLGnr8nH%c)Lkfk3U+OX{a_nNy?mB2zwW!k|NG#y%yKxBoYBm28df zL~Ql+@|k6GN|92C%BARuB1N0_QiV3!c!=61cU+cJ5u7mx`-s%}b$d(cnoSIS>@)-8 z&(J3`%#2XIhoLJjGj!Ew3|)PT@$czR8~E=j!=m4*GDQR<#yLLv3K^1;kmG7KmB=M3 z46p4&hGaFRI`bghunN9c*1;stsq=IE>uHkb~*?FD2T<)*KT+-Y)n9zwkQ zt^#w{I$AzFa`LPgE5f$n*V_vzshy=lmc=4zq=ILU(eW!_+-IcBG zqgs8wgEI2nJZR;i|I@ltv9)nE)4!Q{VovqTmB=sDb}(af*5RzeOki1F2#lv{Lo)NK zW6hScA}CzBAyx>AL5{oo(Wk%GWKc1@=pneEq-N8>HW z`4|e{?SuG_JP>6(81Fyh{TZ^^H)0ZFPsK(|IylJ)?2kGnnI4On9u_27_Yrm_!d-~^;c~N?Dx_IwACREyCq^&U01u)XZ`0wL`ae$wn**L}9NDU@bw0jBy0`E?f z6jM(6(3K$t6*H&;uN;L6Gi+6&9Jh`{zjdhhx|aPQr!s7{9gGZYEzr>WVMTLDd14da zV3(0nZJ~XjglT-rshqd!V3>bYtoVMEEXJkmm@~y74ZhebxX0t1^;RW6QDRe>6hv|& zHLg|tnK(z4!Jc`?LSgE{i8=zu`wjjRnG3vweI+EybTpcZCa2A-<3X=OaCPsfCpulo z1>-HleDF-)!LsBQoa#GNX1#$A`1X}mHRBV${S{5WZ;c$EJNYQS(A(ep%c>_8Ja>lF z{)TTr2nbm5Q1viVj(0gE)ihnf(R5W1EmV!6ahUpTSx zPX&{~(jr@L;&WS&mlC1$RJU@aO>b`ttiCm5xX3^$!)Js$lFy>+-?z`|ZsfJuw^5pj zNwU=#xZ5ZN756H%H~d-$#0mK#AfKL!5A^NZYv+WFiC6}!D&Ez9g?aT-|I@Lx>{;C@kP0tX>jxT(*MSn<_yZW2p4^0ns7qvn$Q z?g=lo4Jvxn_RJ{BENNc0{5;W$dkT{tb*H3FjZHcmTPy8s2Qxx455SqS#6u!gRd_CJ zYhnj8I3G2rUBy*x_lx8`xnA~s=)#i!(b@=}W_sn@9pWCi7IDZR zUPj+V4~lkb=1rxHusN9@o&#iWqD{G!5G_&yoPBi6A+XA%vpUhk?lKbgR(cx^3-2Ol z^RQc_d+ol0E%yCnFSKo$`>lkNR1t23`WvqL{DRHuLSW1@cJu7xo%Q7^26;N0y_yMz zS-ZPn)2QP-=fTnw`>=v>HcLmscXTi-OpIZL=!Ia9j%5YYYSv$|i!r?R8j4^YjlIE` z`Zn9JfQ7U45_bj+YcL%bZ2VPXsxDh7@IZ8sCmK|I*y1WXP`A!qcIJq<;O7!L&=bU% zYW|(x>j57pf18$Y<_Ihu*p=wG1O+|Ss1PP5DFoAU1s$2I@b4+ai3)n+UWIg|lVe;k z9#UN598GFUI_x799}9%ROANjfgosJbZ&2t|-!DgbX{tNDkt#)naLX9vvYT2t=qFcU zCS(O5d%j699fEEQi!Ol0K*&p^acgTU6^HM%-d9~*i|_>n1ts0^xwVv5-lEtoZ}iYI zXFPT@y*=Dyc`Mh8XXswMcTdI5AT&>yn4o|*CwD3E9fi_yRZU_0V1!#a4X|z|fty#c?>{lq;7Q+Z@KfBz+0h;ACq`s9Tsqe(PIPQJN8vkPpoT2PEkcKh z`?NSkIVK=Q=^K!;K^Kssi`NLzpxKE=1#OZvyNfkDuCQQQNtcY(D^*;p`ECxAtm3%T z^Es-QElBkOOW_wSlEv7d)@+0eSlLR;M4~=RsNCF zu8gW)ups;*OR0b{7t@O+mXZ`&U}rbQc!<$N3_j}jtI=Fdj#6hr6RCzu~HMYhp zq?zqhroM%B0dAV>I%%$RV^%DaFpX=$hFOHyx-mJcgjq>MaP_|TO$jqF9qgjl@Gox6 zK*$Evj1A%aU&(olaLyhJC*1qd;pMwR!B%! zmb;ORb0nmS#c-A;V5KfXV_hO4MK5t91#tW*_$pKWuj|bJtFldRMVK^|(Ttc3!bN?V2L$s5T&pTK)y;I}iF; zGN7}Mr+}x-<3%*k6o95s6%2I8D*V}m>@x1V9F?z?%D2q1&dok0f~nPYr`SgqCJ{3ES zW8f<9)aY0A`5DZ%C2q^nZB;(Ph)*OK@pHRkxUVxIHrNyNg&E+#LW80))64An;- z)L;K+DDkFZPKHwQIXzt`M=45HPi}~ZGeBq~4xOv<{nJJf_|3UMcSG1;(p@s{Azl09 zbZei(KLTA3Q;4lAzo0|ql4tOeSJcy#wWEomx?IX!HY2eZ*&3t-j%=Z}EoItWAnP6$ zeJ+j=4+6tW45Z7OAc{6Mm`d3|L?Kk0hvWK}`;YjmW*b5uHrvp(neu7UY`(`|^i~x7 zu-T5T&GdsGojk-4C9};vmkwn7nbgWaA~lSX7H7WF|4$VYuaQuS2I32^1X2^Qd|rTT z)EFExZ?yN^Q9p*|HRW4k!HJ*}W6*58be;-F&+BR4Xo9=AZR=x-`aEMqCXB5&I3C$C zoC2i;ahhV*6ZMErGuNY0`|a#+1!Hehlkv z;@36FN16D|P3Tk8kEPl@BPk+wtmyW|fanua$AGtgJzQs}iz&gJUZ?~A|Lr=&`<_Mg z*ouQKcYL%jp`>;g%vFeS$`laR?HXUELSYfF#R(Q_L*v#Ec#_f?X%;k zc`gHkx#nzkennTvk#~hCANwr%N^0*s$(u->w28RgKC#urIwBXPnPo^RiRRHr#JXNZ zSA$NfK_8U`;5`A)$@6|aC}E-ru06?c?O6$%%=6Fm`_Fpw$K1F*<6Nu-p7g8M4wX~d zP#@~0>dB?b@)_m8&~D5{A)VzbOPY}~YIV0B{QddD42fap8)x$;yYba=fA<5!N2_Zs z-~aWK-iCy!!FcodXI=ou-JN2^Q4=q=D2h4MdcZ!0Lll3b$>l)Nl@S-pV^=nCRzBSL znYrr^W&|G zuMa*-gRTUl2#aPf=<5*c&rZoM1B^sCOzG%Za=~bVC`q!MHm#Jq>dc*$l(EmT@uJM` zR_N*k!ZTdRu2aVT$B2`r|1lx~iG`7rz}Th!Kk9x+MX~4N&Q3o)^AvlbF!Mmh2;1kj zXEVj1ohGeD-lp{j2#~jd7p|8&nOyJ-?q$jkZ`vAm80>gD)Et9otqlo-k0V;=ftZO7 z^*%r3$WnvRX8>Bt4NFmW?Y zPyAd)8*j@5<7iqa%b@A#72w_5L+|qN_W&2WnKmq3NbRC`c{#4FrXsw`dOCg&r5w(w zlwt7%%F*xw711+--la%XBr*p6CS`c-Dun4E8noy=2n4(co`OU+f^#%hP=*ByT;Twa z^u9K9&%H~WR`Xfg`5di(c^h33C8w+A!>XAf7i!*;L-a{bSNq6?3Uh#*t{f@X2Ha|+ zYfjU`$#Pn#z6`#{TeK?zvFHK#5)AxqBg` zw%O}l zfE}2%f+PjNeX$(FMaprd3Sl)zoyj2qkvoX@RIsph-dAz*`s&1=_pog91UIdXklHnfNcE7B^WpfwWt(? zCuj?3N5RrN^!&H88v3_fr3p_}a^MGesu&68`fM=Q=^*)iK^Ju&%=XP9H8=YN34zqU zQZ}j>|1dF#R%*s!d5pH(_E=FkU5>#1-hoHN1bJ^2X6;A9jN>Ry+_uhHZ{CJqj~UW! ziyP~y5AcqdAy4HBbs1m?>_Kb8(u@Z7woIEZM{v0r2L8o*b1wcR<~b?{>te&H_4u{e zK~xsbjMY+Bd>}S(xKiUU)RhB$k<)Iz1wEIDE+=5850DsMc{$gMm&5J^myG(00+vtm z*PQGijrO0Up<|)$GFlh*ti@q%lEsQ&l=T=kofb|0E=llwXP4PDq7c+7BBEQ0nP@8v+J%OApdsDoP&Qf!u zeI*>wy9&DVEE6hp#;alRyW-Wm;8GUB&CP*XOr6h3fk^0}EMCD4?vo5QpPuBgZym&j z?XXI%a{eqU1B(OZezA0LNax1%9K6Dc)>p2Xm7+{mx{=+8n3!ur=qx;o z@5gCU;=|xogHo@ugH^L?~YktTYVTHfI%IGSq9CI6# zs+F9K_vZQ&HsM>r`*D3$oW>uVVEU8|LHe6Iy`JBGrEf}*M$doP)K@sZ353pY1?%am z&!}Ad?(1Wv9M|qboYp4an8ibULa3Ypf=3~IB`ydiUeBq+eU&?2;@5e2 z3YGA}pwb407rZd2`VzORg2x{^84GcqBVc#(zZP^KS3$)-f%VuXLRZxxp|T1I)lJZ2 zE5iSpI?x;|G7v6Gw|id`;JBl88SO$~R6DV{=S^$)`v-R(41600<<1^)fa5SM?a0T;*lJh071w~c%Z;XDD*EW5BT=J@ z*Cf1JGA&_R$?}Bo&Uhr5Lf9JgS`N$W(yX*!Sd;|H3hBGJTW z-9}<1c<9#OmZhM0C4t5g!nbM*3}%Gl52eM3H^I%M3og>HUZqmpF_ZTusx6Z zfs4&dCFFe|Pf|Zp7Vgbfl3N>6fUWCti8Y>Z)=%B81|7ijpyNJ~8UUIXh{kgE%G`7SKJOHvMTI3NFr%;>Oae0K94X3uXwwc2Yd#tY4g|ej5by zjQvc2K!f@nvWI=`U}6k?#!`Z=8=U5M5$RLAv*}>&B|G5aOwWU`Rn_OLC8I>XhFOH5 zZm6Y>getJI1=(d447Y2B3;C2g-6&g3Djm=Rl?} z;Wa_9Sto9UbtcLiw&dNDG_m(XIN5GI-aR=-q*`zd*OvU=*<)bqmh0qba7BJUw+fZM zaArajq&i3;RF8r4{M+mZumaAZONztdK}(3$a796lhm+H5ZRahZPp8owdyW{)FV`e~ z!(NCxJEt}kVSU2LsPeY67M|=7^3t)th1D^&Xq^p1K zlqDAYbFTLer59TYZGSHz1XW+Rb{O9I6&?Ei%VLr@yzwjAdC?|){|b(Px&ad2r28(s z+=~Ou#g7FeAr=YeQ)X!9!HmysH-q#ed&H<($Dr{d?-xX?R#tHKS!9zjT{#Tz58|x( zmg(^5BHiu|iAv8V$gU?ugT{?4Tp4u=I(oFEak$zfvWC~LAlug=)>D=UON|J_>@2-_ z?P#%3k)gnBRC}CdTUrE6SFg1KY_8j`kS7EU89{f!2n9`mNmkjZ4VMuY!AfyC!)sM& zP4QouNagKr^T_qWsr2Hdw34|?ca`UtoiLZiU9eP6|8eFIbI!edHu3a=Q>hB+W|R`5 zA4wZQif9%hb0CFjG)QDo_%jLX;bm2hs<)K_hT90kbJxRcZwH3kj$YZ8Y+Hb>t=zR7 zm31`4W%;zG?mdzRaC~Z$pUS!dfnUatN$$Zx>f1Zn3?FNo{JuU{b@XvbBW+T=@{z-Jo`K3fy`Y@@rnUZ=xg%+0PLUd7Um)1!9K(cm#Q zNtl9>cy}dpvApe(E&!JX_KkRX(no-cJQrx+7S7D zN9H8zREADefxtDyz;rmQQQ^dNCPE*!Yf}r5C_nU|VfzPdeDCfoF-!5Rzd;oTn&CT9jmkLsQ0z!`Nu$HT;{{s(!Ro^Wp?aBm}U zZ&TpjrmiW#tS-T`CZRzPe6xD->A%Y8K>2;O8lmy_CRy^eS4(z+7|i6SOKg*lf;c@& zR7}RBdTwtC5tEr54E1S~&D3O%64l=Vk?Ngy(4cMuyGc4|Khm{KBKX^(u4NLD^GBpB zHo0K47s!r5c8dREBAGji-a}D$Y474`Vwa2XyjOV9}Q0?H88!>n|y+k z`K%^Z)w>_^;7D6DZ);+KfbZC3K-k>Wi&T+{jj?u6X`#I-J-J*Pu%~VPU(c*AtBlOT zi~o51&M*5L+0|4DL(l-*Af_kdrrUJEFZ?BQ_|8~uz~we_F~stWw)_tao*#q>;C(YN zA0TOC0L|7J4?(PV;2_NVrLht68ce(%gr4kavv(jE5C+$ zy!C~R!04^EPhs-C1FI#s>3_E-pZf635uo52Oo>8p$s=8C^nR%3paZ14_9KqwkT+#! zJ9uKSwF<$*i#71*28B^lNl?euNKa;bE_i#6N{`SaYpxT&{SWwU5`J1&eAnsdtlxfG z?eg~o-SdlNzLvfV?)pU*S}AWM-`3>nRw}M)#XS=Tm;qgTpx_qi44!3lrp31;-(FWn ztT#4AVrw+o61g^FU1YPF3%`HgERlyUfp3ItA4od;rQsxbU z`W@{&n89>16Vp$6%NAlgkm0Okel`brJJ715}`6*s5JyiXmhE&B_f4~>`K4Yb_bMOqvzV4W$yGN72R7c9S z8;a4BH3es|etuFv!b3qpO`4H0y7>9H?i*M7kEU;M(fnz6dpsjcuEvU_0i3I&ph`S6 zX=q=493RK9g(A2`9;l;%8}^Ex#A(8ecv;eNgA3JkcvB>yg{@6rx+a?`u3sR2{e zFrB^k8(eZ4J1_Vyw)a&XaHYG7rSzW#|J+sq79S`RD1IzPOa9uxf8uWzX#Avk2*L8o zb`yWCK%q7fy%zZ4>R}&pu5YWa<8^(A%<=C9tlSK*aZNMf#fU}m`C8T4F{nqT>cv%P z_@$e=c}g)^C5-uk_eko`Pv6~3WeF7i)Noxe(rTJ!GS94X1>}F8d7sQo& zyck>5)jV^?51Nov32$?&!Dplhu^zBU^&>83%%%q4+cz3~6gLPr&i#ZL1x$=J zN5Bkqb)Im?CDs=236(eDYq(tK?2|px~HtX0cq?2foS1MR% z(bO$&>f)jGQvGE!bmJoWrBo!am!ZT(WYiHCkxcedCy_qzXuZg56Cu(aSR8)DS#zIp6>l-bT-T)R;6G|d4}o6$M2KFx4D|9nQkhD zPD)u_DNk2;J{sw0ERD2r(=r(8PmZomaPNmI#po}1cm||mqrYhIt7uD6nm~|mi`NTe z7*u!0Abf5WyyZ?}`ImRYFR0>Qg^A3n*wHW?75Bgo141U0m{lx{IgF@^g)#44aR($b7mLvizUOW=Y*O4>CLV^N9F_wi zpb{wUckV_*p5lg7`U#Y#0gW-xM<8)v;8zwcrt0y@MOGP#!7nbJPtC(e7Vo3$U-=2Y zw&Y(_vmHPvRv8_Pob=w}W8jd<~y zSpK+No)1QA2D}9Y4-FohqNnR8?8k4W45RBi_T!IIf}n%7xH?5gm11X#mfC?;Z)HMV zF5dCh8M=PzZ+O-6P+8znyl?r-I?7l9kJ8C&(ayJ7W2&9qlFoG z@Cu!5)U!B#MPRqrTVWl#-7tP4fT z1UGR!Wz{O5dat^WEC-t#rgOc9=RLd02jKIoLg{+vDeSpgLw$#btk%%=pL~MjR)b=_ zKE|t7S5u$h@V9*d=b&TG+y95s)_Vyq7T~5wUZ5TtvGgY*bHj(Gc5;~nN5xkB%)6qY zcKe+|8}{st`1t)YW*-^f#hV@S+%QpY@W>16^DUM`-Q=-UzBtoDo|b&F0XM%p%DeWd z8xnm^zaPfOQszkt`hmlP5r==dH;i*h_x#*jnP1x655AO3;^AOqoHyr_~YB{HaA+SX29T6FmWOQxL z|KJUl0d(yrw{VeVAzkadiu+r`WZWYBvh_1rK_d29`;n~RMaO4rC&;)U1dmWnBk{e= zZPGUvf>ih4G|027igMeRWs)uwUz>dz8)S*srU{{I$XHut)ykkmM?iL<>{nVZzV07pEMsm_^PAh4!{k7e*?%%{yVq=ZR!Dj z_{!YTaT-2q0IC7X0R9E=IY1FWA;2Dhj{vp+ybrJzKm#521@Hmr32*?){u@w08yP^` z7-)DKpc&v7fXe_E0L}rN0{8}?5}*{|Fu-R3geiP(%M9J7^Bomft%qYDH-2Sxw901ANL zI+H(AHWWaA3Fvi}QT^!WN;^O(C|?J-=ioa4>i-R?!}~+0952aU?Kc=|-G9&Lp;V~s HAo>3bum3?0 diff --git a/pc-bios/opensbi-riscv64-sifive_u-fw_jump.bin b/pc-bios/opensbi-riscv64-sifive_u-fw_jump.bin index 971f2be4054d481461efbddca947c44fcfc73ce9..77f4dc8f8322212c437e7f8d7f2ddf63bae1c2cf 100644 GIT binary patch delta 24610 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 delta 19825 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 diff --git a/pc-bios/opensbi-riscv64-virt-fw_jump.bin b/pc-bios/opensbi-riscv64-virt-fw_jump.bin index 45a5aed1ce0cc2121a9e9b9733010d85da5f53ba..31e74d12ea79f390344a7fe5164846bce93714da 100644 GIT binary patch delta 23736 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 delta 19041 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 diff --git a/roms/opensbi b/roms/opensbi index be92da280d..ac5e821d50 160000 --- a/roms/opensbi +++ b/roms/opensbi @@ -1 +1 @@ -Subproject commit be92da280d87c38a2e0adc5d3f43bab7b5468f09 +Subproject commit ac5e821d50be631f26274765a59bc1b444ffd862 From a6fcc80bea1f062ffad330a1dcbc1e3d463a4493 Mon Sep 17 00:00:00 2001 From: Bin Meng Date: Mon, 24 Feb 2020 05:39:42 -0800 Subject: [PATCH 3/6] roms: opensbi: Add 32-bit firmware image for sifive_u machine Although the real world SiFive HiFive Unleashed board is a 64-bit hardware configuration, with QEMU it is possible to test 32-bit configuration with the same hardware features. This updates the roms Makefile to add the build rules for creating the 32-bit OpenSBI firmware image for sifive_u machine. A pre-built OpenSBI v0.6 image has been added as the default bios for 32-bit sifive_u machine. Signed-off-by: Bin Meng Reviewed-by: Alistair Francis Signed-off-by: Palmer Dabbelt --- Makefile | 2 +- pc-bios/opensbi-riscv32-sifive_u-fw_jump.bin | Bin 0 -> 49472 bytes roms/Makefile | 7 +++++++ 3 files changed, 8 insertions(+), 1 deletion(-) create mode 100644 pc-bios/opensbi-riscv32-sifive_u-fw_jump.bin diff --git a/Makefile b/Makefile index 7df22fcc5d..ea0e08fc57 100644 --- a/Makefile +++ b/Makefile @@ -848,7 +848,7 @@ u-boot.e500 u-boot-sam460-20100605.bin \ qemu_vga.ndrv \ edk2-licenses.txt \ hppa-firmware.img \ -opensbi-riscv32-virt-fw_jump.bin \ +opensbi-riscv32-sifive_u-fw_jump.bin opensbi-riscv32-virt-fw_jump.bin \ opensbi-riscv64-sifive_u-fw_jump.bin opensbi-riscv64-virt-fw_jump.bin diff --git a/pc-bios/opensbi-riscv32-sifive_u-fw_jump.bin b/pc-bios/opensbi-riscv32-sifive_u-fw_jump.bin new file mode 100644 index 0000000000000000000000000000000000000000..bab13f597ac9da31518f0a2bb22c2a1dbd56380d GIT binary patch literal 49472 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 z�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%0DMiNGf_$WkVuRX&6)lQo8YJYsn*8)V^6}pe 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 vz3%tTw#_A=PtMzV-L11y<`Izl+kM Date: Mon, 24 Feb 2020 05:39:43 -0800 Subject: [PATCH 4/6] riscv: sifive_u: Update BIOS_FILENAME for 32-bit Update BIOS_FILENAME to consider 32-bit bios image file name. Tested booting Linux v5.5 32-bit image (built from rv32_defconfig plus CONFIG_SOC_SIFIVE) with the default 32-bit bios image. Signed-off-by: Bin Meng Reviewed-by: Alistair Francis Signed-off-by: Palmer Dabbelt --- hw/riscv/sifive_u.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/hw/riscv/sifive_u.c b/hw/riscv/sifive_u.c index 156a003642..4409ea1ccc 100644 --- a/hw/riscv/sifive_u.c +++ b/hw/riscv/sifive_u.c @@ -56,7 +56,11 @@ #include -#define BIOS_FILENAME "opensbi-riscv64-sifive_u-fw_jump.bin" +#if defined(TARGET_RISCV32) +# define BIOS_FILENAME "opensbi-riscv32-sifive_u-fw_jump.bin" +#else +# define BIOS_FILENAME "opensbi-riscv64-sifive_u-fw_jump.bin" +#endif static const struct MemmapEntry { hwaddr base; From c6fc0fc1a71a0cb09b472cf36dded3c52bd77880 Mon Sep 17 00:00:00 2001 From: Bin Meng Date: Mon, 24 Feb 2020 05:39:44 -0800 Subject: [PATCH 5/6] gitlab-ci.yml: Add jobs to build OpenSBI firmware binaries MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add two GitLab jobs to build the OpenSBI firmware binaries. The first job builds a Docker image with the packages requisite to build OpenSBI, and stores this image in the GitLab registry. The second job pulls the image from the registry and builds the OpenSBI firmware binaries. The docker image is only rebuilt if the GitLab YAML or the Dockerfile is updated. The second job is only built when the roms/opensbi/ submodule is updated, when a git-ref starts with 'opensbi' or when the last commit contains 'OpenSBI'. The files generated are archived in the artifacts.zip file. With OpenSBI v0.6, it took 2 minutes 56 seconds to build the docker image, and 1 minute 24 seconds to generate the artifacts.zip with the firmware binaries (filesize: 111KiB). See: https://gitlab.com/lbmeng/qemu/pipelines/120520138 Suggested-by: Philippe Mathieu-Daudé Signed-off-by: Bin Meng Signed-off-by: Palmer Dabbelt --- .gitlab-ci-opensbi.yml | 63 +++++++++++++++++++++++++++++++++ .gitlab-ci.d/opensbi/Dockerfile | 33 +++++++++++++++++ .gitlab-ci.yml | 1 + 3 files changed, 97 insertions(+) create mode 100644 .gitlab-ci-opensbi.yml create mode 100644 .gitlab-ci.d/opensbi/Dockerfile diff --git a/.gitlab-ci-opensbi.yml b/.gitlab-ci-opensbi.yml new file mode 100644 index 0000000000..dd051c0124 --- /dev/null +++ b/.gitlab-ci-opensbi.yml @@ -0,0 +1,63 @@ +docker-opensbi: + stage: build + rules: # Only run this job when the Dockerfile is modified + - changes: + - .gitlab-ci-opensbi.yml + - .gitlab-ci.d/opensbi/Dockerfile + when: always + image: docker:19.03.1 + services: + - docker:19.03.1-dind + variables: + GIT_DEPTH: 3 + IMAGE_TAG: $CI_REGISTRY_IMAGE:opensbi-cross-build + # We don't use TLS + DOCKER_HOST: tcp://docker:2375 + DOCKER_TLS_CERTDIR: "" + before_script: + - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY + script: + - docker pull $IMAGE_TAG || true + - docker build --cache-from $IMAGE_TAG --tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA + --tag $IMAGE_TAG .gitlab-ci.d/opensbi + - docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA + - docker push $IMAGE_TAG + +build-opensbi: + rules: # Only run this job when ... + - changes: # ... roms/opensbi/ is modified (submodule updated) + - roms/opensbi/* + when: always + - if: '$CI_COMMIT_REF_NAME =~ /^opensbi/' # or the branch/tag starts with 'opensbi' + when: always + - if: '$CI_COMMIT_MESSAGE =~ /opensbi/i' # or last commit description contains 'OpenSBI' + when: always + artifacts: + paths: # 'artifacts.zip' will contains the following files: + - pc-bios/opensbi-riscv32-sifive_u-fw_jump.bin + - pc-bios/opensbi-riscv32-virt-fw_jump.bin + - pc-bios/opensbi-riscv64-sifive_u-fw_jump.bin + - pc-bios/opensbi-riscv64-virt-fw_jump.bin + - opensbi32-virt-stdout.log + - opensbi32-virt-stderr.log + - opensbi64-virt-stdout.log + - opensbi64-virt-stderr.log + - opensbi32-sifive_u-stdout.log + - opensbi32-sifive_u-stderr.log + - opensbi64-sifive_u-stdout.log + - opensbi64-sifive_u-stderr.log + image: $CI_REGISTRY_IMAGE:opensbi-cross-build + variables: + GIT_DEPTH: 3 + script: # Clone the required submodules and build OpenSBI + - git submodule update --init roms/opensbi + - export JOBS=$(($(getconf _NPROCESSORS_ONLN) + 1)) + - echo "=== Using ${JOBS} simultaneous jobs ===" + - make -j${JOBS} -C roms/opensbi clean + - make -j${JOBS} -C roms opensbi32-virt 2>&1 1>opensbi32-virt-stdout.log | tee -a opensbi32-virt-stderr.log >&2 + - make -j${JOBS} -C roms/opensbi clean + - make -j${JOBS} -C roms opensbi64-virt 2>&1 1>opensbi64-virt-stdout.log | tee -a opensbi64-virt-stderr.log >&2 + - make -j${JOBS} -C roms/opensbi clean + - make -j${JOBS} -C roms opensbi32-sifive_u 2>&1 1>opensbi32-sifive_u-stdout.log | tee -a opensbi32-sifive_u-stderr.log >&2 + - make -j${JOBS} -C roms/opensbi clean + - make -j${JOBS} -C roms opensbi64-sifive_u 2>&1 1>opensbi64-sifive_u-stdout.log | tee -a opensbi64-sifive_u-stderr.log >&2 diff --git a/.gitlab-ci.d/opensbi/Dockerfile b/.gitlab-ci.d/opensbi/Dockerfile new file mode 100644 index 0000000000..4ba8a4de86 --- /dev/null +++ b/.gitlab-ci.d/opensbi/Dockerfile @@ -0,0 +1,33 @@ +# +# Docker image to cross-compile OpenSBI firmware binaries +# +FROM ubuntu:18.04 + +MAINTAINER Bin Meng + +# Install packages required to build OpenSBI +RUN apt update \ + && \ + \ + DEBIAN_FRONTEND=noninteractive \ + apt install --assume-yes --no-install-recommends \ + build-essential \ + ca-certificates \ + git \ + make \ + wget \ + && \ + \ + rm -rf /var/lib/apt/lists/* + +# Manually install the kernel.org "Crosstool" based toolchains for gcc-8.3 +RUN wget -O - \ + https://mirrors.edge.kernel.org/pub/tools/crosstool/files/bin/x86_64/8.3.0/x86_64-gcc-8.3.0-nolibc-riscv32-linux.tar.xz \ + | tar -C /opt -xJ +RUN wget -O - \ + https://mirrors.edge.kernel.org/pub/tools/crosstool/files/bin/x86_64/8.3.0/x86_64-gcc-8.3.0-nolibc-riscv64-linux.tar.xz \ + | tar -C /opt -xJ + +# Export the toolchains to the system path +ENV PATH="/opt/gcc-8.3.0-nolibc/riscv32-linux/bin:${PATH}" +ENV PATH="/opt/gcc-8.3.0-nolibc/riscv64-linux/bin:${PATH}" diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 72f8b8aa51..b889fb96b6 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,5 +1,6 @@ include: - local: '/.gitlab-ci-edk2.yml' + - local: '/.gitlab-ci-opensbi.yml' before_script: - apt-get update -qq From c5969a3a3c2cb9ea02ffb7e86acb059d3cf8c264 Mon Sep 17 00:00:00 2001 From: Rajnesh Kanwal Date: Sun, 23 Feb 2020 15:28:06 +0500 Subject: [PATCH 6/6] target/riscv: Fix VS mode interrupts forwarding. Currently riscv_cpu_local_irq_pending is used to find out pending interrupt and VS mode interrupts are being shifted to represent S mode interrupts in this function. So when the cause returned by this function is passed to riscv_cpu_do_interrupt to actually forward the interrupt, the VS mode forwarding check does not work as intended and interrupt is actually forwarded to hypervisor. This patch fixes this issue. Signed-off-by: Rajnesh Kanwal Reviewed-by: Palmer Dabbelt Signed-off-by: Palmer Dabbelt --- target/riscv/cpu_helper.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/target/riscv/cpu_helper.c b/target/riscv/cpu_helper.c index 5ea5d133aa..d3ba9efb02 100644 --- a/target/riscv/cpu_helper.c +++ b/target/riscv/cpu_helper.c @@ -46,7 +46,7 @@ static int riscv_cpu_local_irq_pending(CPURISCVState *env) target_ulong pending = env->mip & env->mie & ~(MIP_VSSIP | MIP_VSTIP | MIP_VSEIP); target_ulong vspending = (env->mip & env->mie & - (MIP_VSSIP | MIP_VSTIP | MIP_VSEIP)) >> 1; + (MIP_VSSIP | MIP_VSTIP | MIP_VSEIP)); target_ulong mie = env->priv < PRV_M || (env->priv == PRV_M && mstatus_mie); @@ -907,6 +907,13 @@ void riscv_cpu_do_interrupt(CPUState *cs) if (riscv_cpu_virt_enabled(env) && ((hdeleg >> cause) & 1) && !force_hs_execp) { + /* + * See if we need to adjust cause. Yes if its VS mode interrupt + * no if hypervisor has delegated one of hs mode's interrupt + */ + if (cause == IRQ_VS_TIMER || cause == IRQ_VS_SOFT || + cause == IRQ_VS_EXT) + cause = cause - 1; /* Trap to VS mode */ } else if (riscv_cpu_virt_enabled(env)) { /* Trap into HS mode, from virt */