From 5c6b967b020098294b50c1ee3400e78329461e45 Mon Sep 17 00:00:00 2001 From: MSVSphere Packaging Team Date: Mon, 11 Dec 2023 16:36:33 +0300 Subject: [PATCH] import linux-firmware-20230824-119.git0e048b06.el8_9 --- .gitignore | 2 +- .linux-firmware.metadata | 2 +- ...ux-firmware-Update-AMD-cpu-microcode.patch | 167 ----- ...ux-firmware-Update-AMD-cpu-microcode.patch | 591 ------------------ ...ware-Update-AMD-fam17h-cpu-microcode.patch | 245 -------- SOURCES/amd_ucode_info.py | 374 +++++++++++ SPECS/linux-firmware.spec | 65 +- 7 files changed, 425 insertions(+), 1021 deletions(-) delete mode 100644 SOURCES/0001-linux-firmware-Update-AMD-cpu-microcode.patch delete mode 100644 SOURCES/0002-linux-firmware-Update-AMD-cpu-microcode.patch delete mode 100644 SOURCES/0003-linux-firmware-Update-AMD-fam17h-cpu-microcode.patch create mode 100755 SOURCES/amd_ucode_info.py diff --git a/.gitignore b/.gitignore index 2f6c058..a7fab66 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1 @@ -SOURCES/linux-firmware-20230404.tar.xz +SOURCES/linux-firmware-20230824.tar.xz diff --git a/.linux-firmware.metadata b/.linux-firmware.metadata index 88dd85b..71ab2b1 100644 --- a/.linux-firmware.metadata +++ b/.linux-firmware.metadata @@ -1 +1 @@ -f584e174d59343652ceab6a8a4a2d929a8355efa SOURCES/linux-firmware-20230404.tar.xz +074c0923c1a85e1ea5843bf77d5e88d2da87522b SOURCES/linux-firmware-20230824.tar.xz diff --git a/SOURCES/0001-linux-firmware-Update-AMD-cpu-microcode.patch b/SOURCES/0001-linux-firmware-Update-AMD-cpu-microcode.patch deleted file mode 100644 index a899e34..0000000 --- a/SOURCES/0001-linux-firmware-Update-AMD-cpu-microcode.patch +++ /dev/null @@ -1,167 +0,0 @@ -From 69143e8eca62a80b9791b8d358d1cc4c90e373c9 Mon Sep 17 00:00:00 2001 -From: John Allen -Date: Fri, 14 Apr 2023 16:13:58 +0000 -Subject: [PATCH] linux-firmware: Update AMD cpu microcode - -* Update AMD cpu microcode for processor family 17h - -Key Name = AMD Microcode Signing Key (for signing microcode container files only) -Key ID = F328AE73 -Key Fingerprint = FC7C 6C50 5DAF CC14 7183 57CA E4BE 5339 F328 AE73 - -Signed-off-by: John Allen -Signed-off-by: Josh Boyer ---- - WHENCE | 2 +- - amd-ucode/README | 2 +- - amd-ucode/microcode_amd_fam17h.bin | Bin 9700 -> 9700 bytes - amd-ucode/microcode_amd_fam17h.bin.asc | 16 ++++++++-------- - 4 files changed, 10 insertions(+), 10 deletions(-) - -diff --git a/WHENCE b/WHENCE -index e7073606..68814918 100644 ---- a/WHENCE -+++ b/WHENCE -@@ -3917,7 +3917,7 @@ Version: 2018-05-24 - File: amd-ucode/microcode_amd_fam16h.bin - Version: 2014-10-28 - File: amd-ucode/microcode_amd_fam17h.bin --Version: 2022-04-08 -+Version: 2023-04-13 - File: amd-ucode/microcode_amd_fam19h.bin - Version: 2023-01-31 - File: amd-ucode/README -diff --git a/amd-ucode/README b/amd-ucode/README -index 0adfde27..0d97f910 100644 ---- a/amd-ucode/README -+++ b/amd-ucode/README -@@ -33,7 +33,7 @@ Microcode patches in microcode_amd_fam16h.bin: - Microcode patches in microcode_amd_fam17h.bin: - Family=0x17 Model=0x08 Stepping=0x02: Patch=0x0800820d Length=3200 bytes - Family=0x17 Model=0x01 Stepping=0x02: Patch=0x0800126e Length=3200 bytes -- Family=0x17 Model=0x31 Stepping=0x00: Patch=0x08301055 Length=3200 bytes -+ Family=0x17 Model=0x31 Stepping=0x00: Patch=0x08301072 Length=3200 bytes - - Microcode patches in microcode_amd_fam19h.bin: - Family=0x19 Model=0x01 Stepping=0x00: Patch=0x0a001078 Length=5568 bytes -diff --git a/amd-ucode/microcode_amd_fam17h.bin b/amd-ucode/microcode_amd_fam17h.bin -index dec3871929a36792a261578aa834e807b5bea77d..37d899cd534789e461a5cf3ad666fcd587b8ab93 100644 -GIT binary patch -delta 2695 -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 -BMdttj - -delta 2505 -zcmZ8ie{dA_6@Rz4tb4Ghmt$|agbVjgIFdD{B*CC-2jrxg(S%U1O33k}O`M^&nbwJd -z4y(o9wK*Z+4Pz&frp`GY8fY58UbWMSh;5`gY86IladdFhRyxd388wcI@*{rU-Y%oP -zf8Krf`@ZkT=Y8ILCs&+YQTl16uWP8Ua&G3)#??=59{ys}?tOdPkCy&(eDmDCU!4B= -zk$JBV>{)ln{-p2fzt-MTTzv2D_m=Lw{~y-rx6jYovGe--p84m1^2&z|Yj577Ca-_> -z-LAEB{h!|2JAVAJKfJlVZqqY^>*U}3@%Gtsu6lXuz}e4tFVQzWaL<=b@l$=9eA}*i -zs{Qn9FaOLubn@V}dpBmLPV72tPgtqtCw}zUJ-=lUub6DhKWn|X -z;o$M^!h*gdD-UeG^62RJv$x;3as1fxEm~FbyRVP5*N9`r(a2uyr3$O+9sRjd^+&%e -zp6FgJUwGrymCGZ8w?235##hd5ZyV6B+&l90;ypdbHorSC@46?a2IhC4{rIk{rAPKX -zaXu(D`-rG3)T|!;$%>g5rv9d#-8deoYAFTdcXwzjpISOI+4qCM*?sMSzkE7hyZ_FE -z+R&f;bwiW>nVAdIH8SO!qP~j~>9Ld@B30-yVN+BTjmCcSROoS1No}QIon7l!DOvCp -z13tA?*EZNb*3GZA=ldnN?`<)(gheEjNGJt~Um@cNmLJ6>nJC#pkDAu>g3H%Ow6u+L -z=7)x6UQ*sNN207>-5-gWxD+BATWGvz>;t*Y7iW3CmktB{j(lRu-%$0`<%@|XOb;Oeo-?%HXHc{i=9Lo -z`^P+|4C|m@Z8Q)NoR-)LoVK!4TsaxCvsz$e06n%t+HJyn_cU;u=up*yu};7Pm|{KFVMC&u -z2J0K;^{EkkSjd1kGnRHgc+MD(yGc!CgQhJ>Dn+!E{RRgXlZpeRjy{aT}s* -z)5L=n9vmZDX=RctAelfJ=Z|C1RsJk~3&pu@g2MKL42$!f_TRxgLZLr!<;R#J -zV4&QEzMFKvz3<9u_pMVKmz^>g&Go}z80G$a8*s_V)X3@Z9f*2ZB!I7J@I0)pvmIHe -zWx6N8uIQ#v;3V|+E5`~B4AHM -zlDSokME@Au)J6YTS~t;};S#xBat2f9|8*|LzpdjW`HlEj#p-OfNB>Sta2~5-we}f+ -z<>lh!p)JfB?ILZ$XDRro*F`j#QAM+UXi>9@F%MY^K}I0G0)2)eM$0-S;p&*KPBZVFLX(ppFynWQ -z9e&SrWeku5mSuxAjiPMW6F(nxr1PS5& -tnr}7Wx}9NJ!q9Y-G$^4L_{_k2&eFUA*hv|9&>oAGgm>N_!FdWOd=0i-fGhw2 - -diff --git a/amd-ucode/microcode_amd_fam17h.bin.asc b/amd-ucode/microcode_amd_fam17h.bin.asc -index f5b1e4d7..27da52c8 100644 ---- a/amd-ucode/microcode_amd_fam17h.bin.asc -+++ b/amd-ucode/microcode_amd_fam17h.bin.asc -@@ -1,11 +1,11 @@ - -----BEGIN PGP SIGNATURE----- - --iQEzBAABCgAdFiEE/HxsUF2vzBRxg1fK5L5TOfMornMFAmJQi+QACgkQ5L5TOfMo --rnOMKAf/T14Ixwan/IPPOEZHhsB5reCrEWLM89hey7z3vn/h8RWLAfJnAQwTuv1A --B18gOWwUQMNARsoeDQZnnDvIQBB4w/DpzAaoWBoPnUR8Ko9jdl8ou7aUwdJzYC4T --h6+LeSmHGhQ/h7AIJWABplXJg+weYfQiDr9u/ulFsZdCvfBx+8USNp75HddVTXWr --+SunY5MrUZKmQvj147fCojByYVGzNCkWHJe3V6obd19kubTT357QwUX8A7/ZwgYO --8DlxoVbYg9X224/7Cck6dECE9jKbmaVJkmdMg6ACVirjDH5U/HAACYNwwcO2olPn --BOxF9sZMYY9cl14WCj2R7WS+gEjYWA== --=pSDv -+iQEzBAABCgAdFiEE/HxsUF2vzBRxg1fK5L5TOfMornMFAmQeEvgACgkQ5L5TOfMo -+rnPOpAf/dYhPqq/ktg1muI/khV4EhDiguX6OXib3fmfSZdvPIAI0cRI77M3Lvf0b -+nlV8D67e5HOQ5foJbix5tunz0sZjqr2QU8U9dNk/ut0KC7UiCRc8VH40aSi/OQBG -+Y8c7tb6IJ+N+jyJ6Ii6koUuRO2Lk2MckcrWLRuLRV4bB+osyJrGjc/X54Z6UJ/Ma -+VDg13Yxy5WvC7sMmlmnY42JLeLBKDVUvg0zDvJ4aOLLxRE2l3eiAKE+TV122LmxN -+ca5WA/ESYQ9BjxHYIrpTd9nQaWa/TIZ+rOmJGLMtnQ1gGlW97zQuJR7zh+8vdLzC -+iwVlS1cu7kcV7KYDytTkWJ+2gwb3uQ== -+=lP2S - -----END PGP SIGNATURE----- --- -2.41.0 - diff --git a/SOURCES/0002-linux-firmware-Update-AMD-cpu-microcode.patch b/SOURCES/0002-linux-firmware-Update-AMD-cpu-microcode.patch deleted file mode 100644 index 540b822..0000000 --- a/SOURCES/0002-linux-firmware-Update-AMD-cpu-microcode.patch +++ /dev/null @@ -1,591 +0,0 @@ -From b250b32ab1d044953af2dc5e790819a7703b7ee6 Mon Sep 17 00:00:00 2001 -From: John Allen -Date: Tue, 18 Jul 2023 23:19:59 +0000 -Subject: [PATCH] linux-firmware: Update AMD cpu microcode - -* Update AMD cpu microcode for processor family 19h - -Key Name = AMD Microcode Signing Key (for signing microcode container files only) -Key ID = F328AE73 -Key Fingerprint = FC7C 6C50 5DAF CC14 7183 57CA E4BE 5339 F328 AE73 - -Signed-off-by: John Allen -Signed-off-by: Josh Boyer -[Minor adjustments around the whence file to make it apply cleanly] -Signed-off-by: Lucas Zampieri ---- - WHENCE | 2 +- - amd-ucode/README | 6 +++--- - amd-ucode/microcode_amd_fam19h.bin | Bin 16804 -> 16804 bytes - amd-ucode/microcode_amd_fam19h.bin.asc | 16 ++++++++-------- - 4 files changed, 12 insertions(+), 12 deletions(-) - -diff --git a/WHENCE b/WHENCE -index bdb0181..21f7817 100644 ---- a/WHENCE -+++ b/WHENCE -@@ -3919,7 +3919,7 @@ Version: 2014-10-28 - File: amd-ucode/microcode_amd_fam17h.bin - Version: 2023-04-13 - File: amd-ucode/microcode_amd_fam19h.bin --Version: 2023-01-31 -+Version: 2023-07-18 - File: amd-ucode/README - - License: Redistributable. See LICENSE.amd-ucode for details -diff --git a/amd-ucode/README b/amd-ucode/README -index 0d97f91..4308fe2 100644 ---- a/amd-ucode/README -+++ b/amd-ucode/README -@@ -36,6 +36,6 @@ Microcode patches in microcode_amd_fam17h.bin: - Family=0x17 Model=0x31 Stepping=0x00: Patch=0x08301072 Length=3200 bytes - - Microcode patches in microcode_amd_fam19h.bin: -- Family=0x19 Model=0x01 Stepping=0x00: Patch=0x0a001078 Length=5568 bytes -- Family=0x19 Model=0x01 Stepping=0x01: Patch=0x0a0011ce Length=5568 bytes -- Family=0x19 Model=0x01 Stepping=0x02: Patch=0x0a001231 Length=5568 bytes -+ Family=0x19 Model=0x01 Stepping=0x01: Patch=0x0a0011d1 Length=5568 bytes -+ Family=0x19 Model=0x01 Stepping=0x00: Patch=0x0a001079 Length=5568 bytes -+ Family=0x19 Model=0x01 Stepping=0x02: Patch=0x0a001234 Length=5568 bytes -diff --git a/amd-ucode/microcode_amd_fam19h.bin b/amd-ucode/microcode_amd_fam19h.bin -index 4bd623e14006b3a2eeb287e52708d3bea1c3a728..50470c3f461a068e832a1ebe33683a041d4515fe 100644 -GIT binary patch -literal 16804 -zcmeI&Q;%k0+b-&|ZQHhO+qPZRW!vhqZFku=p0aJL%bM?-nU!y@HGja`=`$H4xkg6r -zz3bjMbBM_c1N}Eb|9OxR3;y%|-$5<_0z&#fW~BejDF4Td@}K$t8{q$Z=tl=4dARAv8YrGO%oMvFAg!{$lAVN$g-T#D{>;i!j?1KK|q$@wCynBV3w23pH* -zr8)2_v}j)#KV>W@f_&#`F~Un?x0NcjG&6fMlx8H(O9XB0hjaWJW15RSn8)WchyF#P -zj^254)ABW%ozHqwJpD{kC2A2-{!8t`I*WbMuPESqz}bnq*ieONM;;vz79SD$8*1uA -zHV3F`1+WD~V=tkGGYQ3zi%f|@UHhJ-BRYLm`x2oh$Ywp_fJvkcRP_y86{V-yZIeW4)m?z7R5uxYZpYcNcQi4{3+hRq0VAEYNy+Dg&p*!6G2w -z9E8-z$7p%@8E)76Oqh+*4N!%Afh#?%3bd6fD)tnS` -zQ4i$VwnBog{k*O(LqF6*FD3_K6Q9?oeQ4U0!q3(rZ>d8A+mxt3gJ8yQu7mAS5qy$Z -z`F4e!Q*r9kvFgmGF#V0YDyc}Ulbf&+($uKrJ9Z!j^<%mDDVol?4lN>&>kXtGp@@9| -zKnMQMqWpJ15RJ!c?avM=WPT(ylH16hZrB7mBO`?EY=yQsU#={6TE -zh^7&3DR?0`{#0*|h+z?-X3vEx5rW_jB3vAg$Apm7ot*x2o`yO(Skp|I7+8$7rOEKS!CM5P@O9B6 -z(e*NhlAaWoj+3qd^|ExTeD%qNRhbf+X!2_=mi)`|ufXOFn8g)B@x(2sw7{8`u3}`H -z#C-}OV)OW9<2)ZG4*ySu%!Ul{xt>a!>USxy>Cm6PuisG;N6&c+Qk*1&n -zxlWDNOo@oMu)nhOzozWZH!|K91E%UPfKXX+&yP2L=4(p{vBk%yV4&C3>)UXLD_;DMaOV;GAgK6{f -z6KpM?^av*CIhjZJNv#B6{Jk#4G{iK4a6A$qzSBIMmZ1FBsuM!rcpS;(>(>M@6C_c5 -zq)KLO7hm37Hy*rs8af~GV5P6b`+TJo#v;>&SXziwH8?_lYr(WKs@@JUP<0+K{fV$g -z<>Dt<6AdpUo}B~sCV9pkio8w1lX(qLeWfN0l=Ffi%6uZsvA29V<7PmIr>tb_b6bkq -zix!Mr)~|}Wa-+dF|3W{M&Zdu~Twjhr7|wIJ1hY_D{G9~`g5eL;Qd4PAallF|Mnus& -zGuP)7-hxWs=0^WIkHGrb13cxnPh4z@N^gWaofZX+($KBS(nf7sl2tSu%@c~W=V|He -zW_j?+Ac5CO);TTZ-@t&F_)zOau(w;8z}d@h%PHkx<}Ed_e#{u2)D86$yOo2-I4;DQ -z7(I@mX9d}h8Fcqpw=t33a~cQ;Ge=h)75F=WDZv^32iL6XUG~E4s1f#1mYVtuRMVId -zr!mAcwG>Qgy5{XKZ0yLr)Aa!O`Bp${j>|xK -zo>+Y|1If(Ev(K&vnD)ZpRTpSvNiK0QnsBd@clkXDdp;b04lW%I|H5+=CQ>gmrq6lV`bSE9BknBAGIi7%m4evX4w -zx&=O2v9r+Jerd4v;mhosqRycVqGqbOZwOu4*Gv}?9D7~XZ(^KB`hxMaXG^Pr8Cn- -z!&ms{BTxp-vdw*TynFko$~Bff)Qhon3}I1rKh}t?>8|%OYTL5FM5ZRLlR?O}ajw9i -zPf?RoEK8B_qYqR~P71ofI=76x^4(+9c))!_zTAglct53`?^(Ygh(*-4!yM+viF`HI -z;o93WUV-@>#49&2GdoODmjg^n$ -ziK~IRaed}N5E1xPB8B!|{{qr-XJ}4Qf(JUvmv$NyCt$3L4^1t=a-7g)$mB=zojJ;x -zic170L*4d+6d7aUM3?=7-@*bB1K^@C^I?vQMQ#VA0*SB91S;h4IU*~^@N1~OWW(=Z -z&M;mgexaSt<~`-`Ez<$s`cShPaA~)J^YT1} -zD@IEL-}3f_GAPlvw8TyIs(JoYcxe`+)U~dwX8kCpQre0w^laKjLe)ivBfH;hBG8$1 -zs$CasUsUY47%B6LBT3;%072wN+aZhc93G9s|GqiJ;JF$*In?HI6Yf`xHeuE&Ub_{F -z3e!rFldI>qA;yk#)C=lmv%Pz2Loz*HxuIXl!N>(|_GQEG2rfcoW|Bv-Fn&)7W!qlA -z!&eHJr5_YspF66-I5>tIl0r5e6l>+lQF_E*xg^*w1h%wk(C~zi*$a`9hQn>b?Oxww -zRX-~-B71~c91@)FrKx6WX+kXRR%%s0e(smkP*%~!snK^ZKDst6p{i`o^6QyfEYvCr -z$_>(kYIn_*WFhuMVQEgqfakw-K@xwCVDn` -zsOT!}N}Onjw3-y$=9&x2NJnDT#GSD}dx>lNWRYj)+ljg3rE(oxB9S&$)%0W=C$(yD -zOx@Nv5-q{l{Bi}mnLij?=V*JX?;ssx)Zz4?!7`zGgdjt5SbxbWHp2Uc7f2-0M_ptY -z^;_&M+Mo~h9O5u&0V-$<$rI;!_G<#jgbgMG%E)H@010&6wL#C;r}y(}ge5ZNR+Vc* -zRqCi&gpkz>m0`fBH<=I@n-&lDM)heJMloLHpok?e{1LW~T~eeJt2Ga**i;WrQtIT9 -z`JLM^zD={GXOsnwh9Zm2hmL_J_pWJ3Lq+wSie?sRL;n(q&_2J&?XJrVJio5|;O1Q; -zqHFa^VI?Y*Z)KHi{<2@_HTB|14sYqQ`!4g`guyU#S%28hniZoN9p=xQn3g|mVDqhN -zP-saAd#+Hd!oE{ImIb=qHXyTsiqu)?l0P$*Au83q+J>Cj=%CsjqV -zv%EXD&c1B-+9TvpiZM9C%TCS`^quf$`DXwh=dpXOG3!|LWu{AmvG{rCIAcIpcFtq0 -zRP~OGiFLIwxlmLBmA;L3!?pRJT -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 -zlcRCD#ZTzi@ -zJF<=St-{ljx?!d}RJJcjWY&4{WyXmFU7EG$8yI|hpp3AQx0<2;UBHS-Vi&K?!G#fj -z6_Q%c;$_*Od%VuJq~|2cevt0rY>`&O+#5U(l3I{YL>IMWE&o^tf$*isEdV;*=w)Bv%{h$$Kfgzbp4$wJ5H3QX>0bIQ3!w=yRe0sXtohzZTbdn -zhB31)uEK?YI}*7cZj-;O6gjsXR~p_kPr<5kJolc@VQtL^THXDjfnVggb;Dw@9IFrF -zwSCF$PeE0$gzYYP!9q>|+#XXNSajBhnjN%ZJhp5t&5*P+S<ZabVmMedy@Y6Bvy{;gK_qKmjval@+9)k{sEj3^=R4$bnjiLAY%aO; -z_g?6-(I%M8z`z2Jy*I?uKN32UKr=xw%-2_$*v`txnAT}5(WlQq2etB5EHbWr`u07g -zU!#m?a{)=&gwd2i0+9Qlq3NVbUV<2NvE2#DyR#3*asep?8*)5*Hm>Nh%M>`ew``rZ -zERyxSqY^0Ny`F~l*io9!z~s8p?Sd@I`U?iA?Y;|=wil`ss&jhdwc_COm#H~8W~f57 -za&)mk}`Khy%|T5alObOm+4mWC~EuY9ri%! -zOG-3Tc;e_nmI?UrLyyS{Ro>`d@c||bV3s`2SuczGFmn#u^CXTM*W4TC{VBbXK)4QP -zrxq%APv;u#K@%(|&hA!YQN2*OJbGhu5T(Tlp|_AxbfgxYNBM+}H~Gs;e9P87V2`4` -zgU_!_W$jyM>DdkpG0CjR)&^rw8CX)RJoU6;i>Cz7uy0`2d@u~u6V>*6bcG;@QwLHN -z_e{}f7kPkb!27v1qGj=V#eLIM5-vHP5&|b$+oEs7lV`e^>d&8K|Ge!MZ?q!KKRK+( -z`kqn57avd+REO38muI9V8VLJHoW7#*ot? -zLh|!Y0h-94LhjJV>@(P}_6}eXL1`|yS_$?`@@xKpms$4}R3gXAC4-Xg)}Xb(ZBGRj9vWMV^J3}ur#h|u^Dcba?D{ccehbuAS7PSs={QwR;~J1A -z{y~;A-S^S;)`~p>HK=r8jWje3BBRpP&9Y0rNg6Zd<+@n%$_rz@Ce9No<12uceyw`G -z8VxnhUPEWXR!Gtpjm*1j1(B@^-`_*iMjgkY77ljgND0^@ -zXh2J0yJELL^>Y2tNd})&N`D@Q3eNNI3Of&255(yFS3q&ecsFEf+J&H@Z<8lC(`NO6 -zblB3l#Qw6}t)9ON$x4Z`KOAI=Z3A*LQR2QvCesdA$O?~r_(S#3wkF)+;hk{;wJs4V -zZ`B*&-L?Vq?(egse+~((rK5t7Y7UoMd^=`xO_Up3hIfASWld_3e3Oy+Al}IWUO8Wp -z1mji5x)uhwXVka_YHQ=1w&E|qLML6g@A*WH_J20_COgAXz&M=WQ~ib>(MJ3R9))?t@=0Lx5;{fSidZn0o@K~zpz -ztsad$Qm2Qb?zHt7GG7jB5~(=sk%}iG2ne?vELq7A=%M*0h*jU0PZ?j(O(#0&Wfos( -zAuYwueshJEZFngJ3YhPTh^T7y(GMvZrps&1JA|3nbo=}%MM{|IEGPu>-uK_XRR0tq -z#dy9}vFxHA~(IBkh+5 -ze37S6VG&mRXH*>(EqQrcev(?PSWIai(jE$gq -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 -zJ7!=)Vv2p`ck37rjC`ckU@dDw{&Xf(n+y -zOG}~&AhhXiKUd&Ncsq&}!6zNHJ3@yBTBk;nq97*MRbLdu-YtvR`ayYz@Csmm&E`p4 -zebM!2RF$`?8~~h7Es=i^XOynNZn`n_$_1UTy{{eBNh2QAZ5(SP!O(#HU`#jdBnbiG -z9fh*2u{d1u=0;v4FP>4*A0lvBKgx!VNY<5W8q7F@X7e|>(#{cnIe@N8Eb_i -ziGpRX#?_@UDUoGLG@x${OG$Uyo(_c`zf1FGp2qSEA((li3Zi8Av!zl9E5@oNsYF3HY>!Mr3&N;L*unF{3k8Qp -zQIO@A2z+5PCLj3mnjl#BOla>Oj-W?OWMX4s7vGh(ZmplZekKHb6NWGRKw^XpKXwHy -zbYOuGDw^~oB~dnP8}!WbM4AW=sG6F7eRSbY$x?sooxhtyOK)KY`&HbY7;rzuLuu~@ -zZC5T(-MY{>SFx-Dyh+D@!B2hdxI`_Hx`=W&evwAMg-Et8w}x*?tag%y6$DgcB`VTJ -zqEJ4LVNxc`+=su4#&8n#2h06_=dao!)cmDu$gpsGH1Dzh5779O_05WOcGw+RXceA^ -zrw)JID_$+v(o_PWd*#1SO -zAx?^#cI`r~CA9$d|6hcGC6o=$`|Y}oG!2Y&TKaEcb_8r!ZtS@t!T%O%Tc8D&8{;PW -zIGVF76;&8OpGl2A(Xz^ -zit~{)zONU`4@NOQpDv0KWIX72I#nr0R6Im}ej%mY=Xd->iUs&mL<$-SZG)u(^k -z-wA~Jnz@8#P9)q#d@z}x+<6wsjm|`HrilVK_Jm%`Dbf$*0Qx_03)siEeID^NqocB! -ztJtpL({45jmY8A?7T8RJ8z%V}@qN>=SZ8kYjTIi}kkRSUw0hGJQPB0ns(IGwQh8`$ -zrg9gDa!o2DEm@7|3mW^M05!(F8fJfvO!>*5OFwX+22dirHGS-+dE0Io8yjUBlGNs=rDMZ;9JhrNTQ`fArsQZ -zO?cXE;l_Ii8@{H=a221Xd0#g=pep%)ptTaW=f* -zIQAuH%Z)r%tsQ~YD^K2EAB=l*gi?J7wc-}#9%ntoqD~jI5Up5{b@a45+1$c}zgLq)eSm+g0yMRC1gDUCA>!4IhRefPUCp6KeAs}bV|FY9cgkI$dMKe7 -zly@Zyx1Fh3Z(Km$UAiDcAe@R=GPxF;9e7UY_O`@K)K*`Z~< -zYQt1C4#<>Xrs2NcQl4j9eLalj#LT6)E9kWO5&503qJ$z20nC5)vZqZGRsY=}HhP%A -zGI#HxFN5?@G&!43DrT9wseYVZ%dj%Y>^A=OeaU|Z7B(SzN$WY^Ex{{RnVO!t -zwlUZta9w7mzw5t9NJP&~42C$%z%cy@2`h<2H(NZ$x#*__9Z%RjQ5dYrjE5%ATZo}J -zw<+gTl(W*}! -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 -z!SHB-swu&Rj%|je+Y|oZcZBVG@ek*?+ -zO3pL_%&-C(x+$H*7Enj%x44e+rk(MYjQ_#*y=+uiY#mX#HH>)~`!@>Fi`K8Nk5fe{#n!wH`-UrTQ930POv@SZVL -zd&Bf#r=U`iYTXCmKNGQti_c}lE-^uW8_1TtE^z=_YX!o~@(+KD -ztQI1Z!9ni+wK?J5k!fV0;m)_deewWTb -z73VHwIJ8{~Vt0B9v1Jq^B8g0?Qf17`=-lg)e*_8nnTDUaCL@`!$K6J*w+XvkDCwti -z65db%tBtvgr_!*Ro=w8497S!&7nl_-fgBVM{2w$`gr7Q>IuPw^ZIrI0)m-Joa4vG7 -zBPnTS=1se-a3B%(iIWiMlARbmxqYG{PeX;Jwj~o;X#JT((X2pnun*F|s^Oo5z5c+{ -ze^YXYZI;_)&q0AjG&dF*Kmw&I4#jYL!%pTR$TJv97OcJ|Do~f;%fHyS*qdZn+REa< -zvVW9<4TxxVXVx)n-=TsuUBxV>_$lPzuQATsa#4!j#S2fj`(Xon>M!{Zh9z2@qh%nk -z$qu?k7+uhbavCJ&Eq}{@$Fd)qE&OChf6#Tv@C3m+=d&s184E}Y8L>lbvGPx+XgU5c -z&GIlNQ()Pr{r0ve+igoJ|Ml1jUIh;JZ-q#%(;S3Aoex0b+ArDyQ;T~oaMMs0xF1^QCi8}_b -zdGlLxBiTGxzJ$bam)M>Yni9hLnD}hdUZm5mbrWCM(~Qc+7Epo|k>0SJr#yR)<+i!LoKof+`h8Ou`)Ox>pYQgC-Sn9kWg_&O)}Au-{wSbsz`vzDIV~ -z5j(GDwn9qLfOeuWtTz(1`?*W^YS8YCwGO~h+^vG}#57$iTz`ZD>N};JaqqzR_N -z&IKO6zZsD)bXuji&pkIvcq<@+J{?+T&V276;!Y=e9e+3MWz$Nqq!%&|DUo=#jJ;%~ -z>v+dc_)%U*fp(U^WsxGWe>T)mJtmdj@3t2CJqcp*cq0r;&ZEdgvc9o?F*{^!R{82B>UeOL`^HqU00qz3+T-EiPNtdcE*{j?WjyXiv>)ugbsPs+f; -z!JSd5hsIbx!pd)dxf@L{4&Ntg4m1tvklA(yAK%=mF*D6jJR8pIe+H$7!_IPcycA85 -z{FC9K*uwi#R#8_4PvL5Jmo{>F=&rzm=!M~Omz!s<8wEhQC-{c!ecFr6y1WRl!V-I -z+TH$9;Mv+yFHa~Ze+$Rh7`rtI0<(}`8s^tey14g2Wt)>VlQI?@enJ-QsM}xalVe~h -zS%OKgx&xGjhc0_$+o&KOUZhj=7pY+=E^MUeHhXYbQP9hb#Cv4 -z1O#Vw1vr#KZchFurFg})O#XGd)dCCW5`i}cOCc)#nc35ie;ExR1)rB~L*-p2wO#t; -zu>YO-;H_L1jPM%;NhWqDMjyp!qw5WbZ*T;k;<~VG|8+0@HqK!a9eppuvc?M65RHO+ -zN2(|bs{Wyd!tU+g!p|-+Jk~0f5)0S~;2zJK5#llu^=yrZQMA-m&T*|#Hs?J9GYIu* -zc1h{P|DqPwPG1!(nJ#wcS(e_x&QmfzUQRrbmF -zjFz<~N`Jt8#ZRi_7ZdZV3SZ006)h001K(7XdMo=_?z5nRFXiv3-{ShD~v6 -z!M%>55>dn|1IOOm)jNe|d(V1?+K#$7@GyG5YkTeHCrHjWnqI25E+fr4X`x -z9XjXAx?uNPZmcYY=igwRsHkXL*01?KKwtg*OMWJwfL-tj_f#pAQ_YK-aHPK8hIEAZ0yWiDvec1ubok1F#f_5a(-~ACrcdih%@zv -zW);dUF7NkkdW&=hG&{SL5PNh>=Sb=MrO@h9gNyU75k -zi^-I?{mO}-PvuM%L|dCP8Q}Bx??}s@LZCqQq_9^p*rxXRZF=te%fpz-fjXi=EmXC}`9S!>} -zzIV=;U0;{SGc5nh7YS}P#=H!c%8#~Ow*maha60m@O>!MZ@xsBUP7ipmk#xLZ*}rni -zfpWaR236g50ZE&VWc`|doTS{$gi+K>-?GEcslV7 -zQB6KgGk)$v0qKXFP~)xQ>M{Y}6O@(xh|Oid`fk-wzojs$qxVv^CtGu=(l=Y_*d*Jy5}@)JRhKufOJV_PX> -zsWK%N8*1z+Y?|GFj-|i`QG;AKf6G(UWB)x(5&)RXuZVedfcAuy+Xw6AOQAKDDEcCh -z=0DbHmkjdBHbDsoluAv?xHCGLQvPKAVX$s9*muOEsRVFHlxwp}ia`9uh;&7T$}qS+ -zR;QEV9}`UbgX2)j6NBmiRX7wfnULL@VGDVfVm{F3{Zvh2o1nT+)^+8$;b!Z7I -zzXLY}m?jZCw%Jcb?s)DgPkCL&76+OJ0%?vXum>ZXrqBD3%=)V$Xj6lgRm*R>wZjW0 -zvQqgJaTiHd4c5KDvMmz6K}sg*R05?8eC -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 -zQGTZ-nzbSccf*az!dpybnjoErSG& -zO_&;kHe=xvEOQl2_J{tLf(&7Sf))?>6-A?UI}>sff<(!N*|bi7Dw*xgRGY=z$$jt8 -z)&?5iDzG@03Ert|BEo*yg6Y)U=PBZ#!Mq6x+uCP6_s&HOU*cg17mY*F#}oNAm=a4b -zo!yRNHB~f=-f_y;_Y{oH*$h2Ux>zh^*JH8g(+96<{CuseJCNp3;fxn$HEGOuZU}R$ -z>h8@rkI*v`9kEw`UX0N6DVky7I9A{+72oPaSu)v|s6rMzV(&JULJ`_P -z=?~#)8(w972PiQ!jJxsT1Lu#GQv!LWPjIK2tK=!@tQ|7J6O_vP1M$gd5=bw^7UV<= -zAleYYc(KsB%jh@gjzZI|{(P)Mgl>Ptil)Rtm75m7)wTJ5Tn(H=hb(>|JUVV!Cz9Ik -zGFAE$PNBc&K%nu9V9lndHE^r;h8<}9kcLQ8|7>1Fu~YF~j9D1*EY!w%!J-6ARTY+O -zn(frxm~HQ_we*TFco;k?6cx;&B=_k`KJla^=$&$PKA+Ket59{pA?MGzV4UjRb^ZG$ -zUh;qya<;sG5D#RuAv%mbmipKYh1$S1;RY0@?!R4M!G6Y{Z;fSUcLG0WjJPJ?yH-bs -z8^^{Cnkp##6~LEzDA|i9w^OgZSKT0JwvdZ1aHBRt-H1QnG86_OPY`0|Mxo|wj0XU< -z$e$E)I3Ix1!>m@hGyzw&fbf*VTGqro!slWs1Y8+^bYJzbZ}0I&J{!Og-&GazMZtEa -zsgyf3@7^hSQ~(aDZa5;1(BPP(ae#{mb=&Ihu9*Ly(9>p$OXnuH`zO=o){dYJ-R_AS -z-6eheWomez+qJh(xy_B5&1YPeCcy8}72pkys+MSKbUO*MSTcrd_a32W&x)b6)k$vI -z8~O8pB#HeLEOH-s;qZq;1+IvmBmF}v1-+498{SH-z)qW?>QH7q&NQMkGYbvq)KheT -zX&;Zq6Pemcg6_27)DlS^=*uS_IrPzf(t(*NwT>dopqI9Tg%#3ePCT;6*!!LqLq8LW -zKxyMQ{1y}4>oX&7iKM@Z>DD}TO72x0rNxc^C=EHRsG7`d_vfI?*JSz(6IU+*4%g({nW -z1S#Q{pCVMpaIDVC*9W@WtQkOT(x}JRs})*cdE5!b}2j-|@tN(+8=49^2XG5FvGiA}TQDNR+u_3aSHhCR>6Q0FY>_z1%65rZ*>G$2&Oe!rnX%%B+ -zgqYhnM_cR4TaH14k!F`ay&(U2;o+27@|9{>1UncPx#s}%aQO=|D)PyU95G2j=2h{a -zE-LA7dVbcs$6NWY`#-D(`fZm!F=Et<7QQ)gVQ2( -Date: Wed, 19 Jul 2023 19:17:57 +0000 -Subject: [PATCH] linux-firmware: Update AMD fam17h cpu microcode - -* Update AMD cpu microcode for processor family 17h - -Key Name = AMD Microcode Signing Key (for signing microcode container files only) -Key ID = F328AE73 -Key Fingerprint = FC7C 6C50 5DAF CC14 7183 57CA E4BE 5339 F328 AE73 - -Signed-off-by: John Allen -Signed-off-by: Josh Boyer -[Minor adjustment on WHENCE file, to make it apply cleanly] -Signed-off-by: Lucas Zampieri ---- - WHENCE | 2 +- - amd-ucode/README | 3 ++- - amd-ucode/microcode_amd_fam17h.bin | Bin 9700 -> 12924 bytes - amd-ucode/microcode_amd_fam17h.bin.asc | 16 ++++++++-------- - 4 files changed, 11 insertions(+), 10 deletions(-) - -diff --git a/WHENCE b/WHENCE -index 21f7817..bad8897 100644 ---- a/WHENCE -+++ b/WHENCE -@@ -3917,7 +3917,7 @@ Version: 2018-05-24 - File: amd-ucode/microcode_amd_fam16h.bin - Version: 2014-10-28 - File: amd-ucode/microcode_amd_fam17h.bin --Version: 2023-04-13 -+Version: 2023-07-19 - File: amd-ucode/microcode_amd_fam19h.bin - Version: 2023-07-18 - File: amd-ucode/README -diff --git a/amd-ucode/README b/amd-ucode/README -index 4308fe2..1d39da3 100644 ---- a/amd-ucode/README -+++ b/amd-ucode/README -@@ -32,8 +32,9 @@ Microcode patches in microcode_amd_fam16h.bin: - - Microcode patches in microcode_amd_fam17h.bin: - Family=0x17 Model=0x08 Stepping=0x02: Patch=0x0800820d Length=3200 bytes -+ Family=0x17 Model=0x31 Stepping=0x00: Patch=0x0830107a Length=3200 bytes -+ Family=0x17 Model=0xa0 Stepping=0x00: Patch=0x08a00008 Length=3200 bytes - Family=0x17 Model=0x01 Stepping=0x02: Patch=0x0800126e Length=3200 bytes -- Family=0x17 Model=0x31 Stepping=0x00: Patch=0x08301072 Length=3200 bytes - - Microcode patches in microcode_amd_fam19h.bin: - Family=0x19 Model=0x01 Stepping=0x01: Patch=0x0a0011d1 Length=5568 bytes -diff --git a/amd-ucode/microcode_amd_fam17h.bin b/amd-ucode/microcode_amd_fam17h.bin -index 37d899cd534789e461a5cf3ad666fcd587b8ab93..f9841b65b8d6ea156a402f45bba17f0e31eaf4ea 100644 -GIT binary patch -delta 5515 -zcmYk8RZtuZvPK7jySq%V;4T4zJAvTt?(RBxa1Rz_&;WzO;BLVoxCQs%1edx0ZtdNB -zzpAb}UsXT#OP{^ZFP4hZ$`XKoMfINv!w&fu{ySkI000hl_#t#j|ZT}icQL6u7i2O&l7_~t1tENe0U+A -z>aiT*n=7;5{Mj*6^>@9B!N`TNQ-(IF^RO<@Ck{?X@^XsXb!)_}-TIAF$J$y#|42zO -zC|hgIJ+wL{5>J6AJ`siL$1omP$DdlPwvuAH<+$`+r%e)0zM2p+D6o%|6Nf~PEhHKL -z@~d~0!eD+r^;H1mX{fR5!$*GDB#v+S?#K!+-w!f*ZkT=c9B4+TXIP7I--6xZHsHj10RaW -z#(7u5oYbEZiZEIJ8$XuWuBfrP+)w95`gc!gb>CFHzU-C7em{*tL5Www0twaNI-@qH -z{gmf9>-kl8tD@GxIp)2o7*6|!*ay%IOe~Um_8cY_vyrWG3HV!QD?!m@FYxe9aHrHy -zxpkGs7F(hL1wGq?Z!J^%C(iiBaxNqn6z9XV}@Xwp)Cg8j|0{2BCfzU5y*+GhWkXIYbAF^s`C~wRQ{Jxn7b+SkU9}FddM| -zAQlvHLsaXVi9B3@_BE-16tG?eRfn&7ZJ_FK)Z*CM5L#9me}pZLWQy`Q7nGcGZg1^AtMOaMxSeF_G0zLL!m= -zob1B6&H0G_fnYwdRnX6hrDYx{)$mr;yb2NjI7IvehpYaJ(|4~8arH)%xQ)0RUFGyw -zq${*LQh~k2_`1K}H#uAlzk2p*Xn)HehKTmbr_5VtHGNT`PtNllJgAEC)(%N^}Of{egQEuhE?I|Vw&LL7}I7; -z`ls+cZvQeNANzJ)Mve~aD2|O~xW3M}dAwlr2=VWXUak!j@ckln8fWD5{HH}jJ+aNe -zEW2CsDm1WY0%*ATmz3%WzT3C}Su|PU-oX-Ah0gO!^Sa#Ll4{?nCDKCcUiLg42LQH6 -zgi^hWC`^I$cDr5+)Q?N|cDKGLuy -zyQeik2^k0S(qJ-b9*Jz`TWzcLq8V-3@Ym>O`;8a+AbFL&xLVvE`)MWya)(D<9*XM1 -zXFFW&pUh>V^$0Z+4@LQynM%tIms?a?7zE)OsDe42J9k`(_gl1aOhjm#3&Y39=jfVs^ -zx3l>{Qc$CEH&uCms0U#(jqUp=&8ZpoK6XSEReo^&&+nuK!sA@GU~>l8_@4YgP%z?XatsQ7kb3sM}LrHLFa+PIfYXN5c{2KDpO;y)72 -zI}wc`NPF2&Nh>MRib!@5`+2UmQ`hC!i|s6v<0+Jg>*rwGIiz*mv%IR@O%IyqSJtg~ -zvOJ50s8b)sz=%G}c^O`r9q2wGMYv<#yz(MyBXAP*M0-cHw -z6gIj~5nw9g(&#RlT;W2E<HGfZ4pBbf%gQpdfa7(r8(gK!X`ZHE0FXW(K&G8us!`CF|H(dx -zzeE_KfOD@G7xA@sJdvFt3!U{?dOcjfX)SztR^RF`AE)RSt*&Jb2J8hFT4|AcFCNik -z_GS548p2O?R78M~A2GJhzDl)Hgb$n6pO -zb#Izuq&|Q^%3Fn}fDW}K+Nf~$&Jn#G7wZRkam(bor8h?Ui@rq{|Ea9HVe_Y{jxQRv -zVPU)}sl8#>^(VH-${rR3eHZ^muUv!@F4b6KF&-D!$5(0-CAV?shS|TA%y6J9pw%OZ~_a -zt}TS^ZK(Z8&E3;ngME15MF)dpQV>yPQz^lyRhD(4xhhX5&x8E -z%=0phG=g5WFU0gY6D$-DsH4Qcej|F+Xfro4O{Il6Rz>Qj -znAc{|Zq{DXYxcjQUS}-(wGS1%G@w1`8>H3-hrS)MtC4}6PYUD%*J;ZAtthpUdwP>r -zNyimboG(_nD~KS^t0p@Qp2(WMQ|#Y|?$YW0knCR7xNh69>KsdE4#jqlgT0JWtVU&h -zdcQB6{>UlO3ak_Xw~-mUHlv-pt&9Q$Vhf<;46L>G!?xm*9|W`Hf2E)Yb^Rk;fDjA- -zfEGxIgaQJ9Q4m7@&szUY|FKwyBUOdpdCxxO=@D2lm6Vm<-}V@R?|qKEo7}JEP$oPa -z1q&9G7>h*x=6zF?l?)gMrTMOEi`nkbGWjs?6MV7;45FAVQrB|@n*i74@p>-I$|y^~ -zO8;rXyaaI)Ks^sx7w`~-R#w5Kvns~QNBE1qq)JL%=G*ud&Wdgia@+JpeR4?kH6#O` -zt3$OjAkqkRhCGY8e}-`OW6r}R#a#`LP%fFU(zb;FLdhTAct!$Du7?6J#M;d@Mn*4y -zx_ZE~+cRUol&M&1p#3@AjsHdh{?5lZa -zGEUf=J^CK2!O_bu6DHw?v&v9o -z2_mlFPCxLTAs=+q(2+a@l-zZmjUb2S{r>!+7R{kR%#n`m-%61F0fE{5Snr95QhZ%RHU5fo;SppyEMvZTK -zBRw_7x}#4r{Tly-(V)1O4QJkg@Mj<=rQ*Sn_Ei7T>KkyuI$eN;=FQGnT0HV+3(5zQ -z*X?P!xGP@C7Bm77Zxu3f(J{OozO)xnzEDz5{Ce_W7hVQM{N>vQxY12=!rpV#%*D`b -zixKbKr`1#WJ)O4r$>TygH$Pwf$EZ(ZjR~aeix$f)gB9p7<)jjc8yMz#+0gvWLvZQD -zj1Tj0zc;HNXa8cZY$`3p8ai~lei;XI=!uxw@8DJJQRmi*It5S8wmWisZ~r`wQ{WEC@m -zPsjNRZr47m9;wp0+b{G2G+nty1n{^DJGHH62!i}hG0zoWg9ZECWQwN(@n_>tp-t^z -zA+5I;6$?<21b3!L)ePGDl&XGgmG0@%1$&x48mD)1+zq= -zj9Yc|S_!+PSuLe9{J8$2C9hHm{t$eVIL6{G`y_&$6yN;>+mstD%;3;>j^mcZrAmK- -zt5~@Ki)g8W(sK<-Vi793=|IG&ftJ%}wg6ywsS&KbqR#_vppo -zyntL|6EOyPfwh(NslOa-S>vd7p{0qn#Ew-#5`H}VJ1!2cMhw!$%NniBTOOk?k#kti -zks|^*gV{Q~ALd?jD=)XzmeU_v+>}yQXDY>iA1I4rekhw3gJ0DEtkBku3hp+I?y!E^ -z`NAQT9jQC6-E-M@=pdXpZYaVkKMGNpl>x0VlZjQqY$%j1XXCAB_LZ>9c?Syhl0>~6 -ztY4&kiF9uu^O9Wc_oGn8N;tK5L(cZ0EyhL4O7P*q -z-T^tWD*-Un`o#l@(HD}yKe3KT6BnNV4c+wV%tkR?yE3|ck%qWs3!l-sHe8y%k%9KZ -zGftz-tWk}d)5+&b@$-t|Pl1vwnj&}JY~}m{P46v+lJ)(cq+^#E??;jonm2CnDm(4( -z6-A&=bWq08;JHY=Q2U8>}pYG-Tp;8U*UeG^b{33TsT$?A8{as*Kjz -z;Y0tvL!|hDbS_bTLH;gna3Ks@a*AW5nc^RP2BowqPt=eQQT7#foHGdYUO+?0+fp>f -zMT3h-YL-&V%SY_2b*w)3f_K+;U~0?y31W?~U5p1WA{?VB6HXNN^1d#eH23uZMbxVdI)y^zwGG&O7Mc(#pFPfM -zuf9aoZ4ERGB!{6t@+WQTBGHUNhBd#ns6)qmS{<8M%60ooeW>*|zcn5G7#E~33{0oB -z>phpOtH5%v3<|m=?@%JJ&;@P4EUjFJ2~l7?A#={fYB(3=)h%LN1vES3WQUVwNsKa- -zm~YIJSh#Z${++Ie6uIFc{T@w-RlmYBb55h-GAWn70gw7yF{l@DjT*cZ$amhbN>kNr -zSTh040SRcc>sU;A9um%_!_Povujr?Xq8rJb`2idLt4fnT9slQBbC6F~hBCpgDy-bHMCf;&k{@uE4dwa((8}ItIb}f`LvZTh`0U}^q!1>&V)*0eKWL)^fe?Goa -z23N_0Sf&9$$p?5)m~CUD!3H>a6%9v5;t{o%U5Th&s@TK3kF#4v6ixx@?D_DZ2`t|I&(34 -zA`P7VMvC>o(}UfgT|PLShH%|@isZiXMoJHiqq~~#q7tNTvggZI -z1eH3}{K-Z{%8tD11YBa= -zb_7FO3xP*#Y4f2rLQ5(WVczX29%nodL9Ov*>DI>16AxvHueJY%H)l~NbcicZxvnKP~-dZi -z)z=jN<0LY!kS*KISK*gdXw-R&E`(s@c6L0Izh@NCRQLifd03hlVG6nq5E%Q~SG_!r -zi-uhg%Or+^L&t>|jcEG3atgujiSBDNCfqI7&oSstXiun(tb&=lSq>bSe2I!Q?Z{Di -zf8d`9Dh=FL#?_{Nr@Z+p&LhA|n{;CmWS8>DKuC0gYs^)6NlE#;8*1y^X|~#5VqJbH -zZ+f`&0=_}j{dp^5Mq#I|;$ODtORP+K$zOvl$rO)lG}=<$8*KM1BeYlUK|B3&gxT(s -z7G?W{DJi797Yjm?rTLhwIY2Pf*AhxhM-eFvDj~ZG4aYJz%AI=&Ip3Y`@UqBqdVpS` -z>CnmC9G~w}L!-YvK(3^uK0!K#ac| -z2fGO8EX(7gOtO?8A2A`a+bH_j=KK5ox`+R6J!TA0QyN*|7vA6hHPrV&TwLeIZHxen -F{{gHxepLVf - -delta 2769 -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 -XI8~N^f?XgDZsTXPhi>+WOwD$}@;OgK - -diff --git a/amd-ucode/microcode_amd_fam17h.bin.asc b/amd-ucode/microcode_amd_fam17h.bin.asc -index 27da52c..34a4024 100644 ---- a/amd-ucode/microcode_amd_fam17h.bin.asc -+++ b/amd-ucode/microcode_amd_fam17h.bin.asc -@@ -1,11 +1,11 @@ - -----BEGIN PGP SIGNATURE----- - --iQEzBAABCgAdFiEE/HxsUF2vzBRxg1fK5L5TOfMornMFAmQeEvgACgkQ5L5TOfMo --rnPOpAf/dYhPqq/ktg1muI/khV4EhDiguX6OXib3fmfSZdvPIAI0cRI77M3Lvf0b --nlV8D67e5HOQ5foJbix5tunz0sZjqr2QU8U9dNk/ut0KC7UiCRc8VH40aSi/OQBG --Y8c7tb6IJ+N+jyJ6Ii6koUuRO2Lk2MckcrWLRuLRV4bB+osyJrGjc/X54Z6UJ/Ma --VDg13Yxy5WvC7sMmlmnY42JLeLBKDVUvg0zDvJ4aOLLxRE2l3eiAKE+TV122LmxN --ca5WA/ESYQ9BjxHYIrpTd9nQaWa/TIZ+rOmJGLMtnQ1gGlW97zQuJR7zh+8vdLzC --iwVlS1cu7kcV7KYDytTkWJ+2gwb3uQ== --=lP2S -+iQEzBAABCgAdFiEE/HxsUF2vzBRxg1fK5L5TOfMornMFAmS4Mm4ACgkQ5L5TOfMo -+rnN35wgAkllCunxE6J5hQyLMx5o4WTHZkbNvXmu6nV1Y3vjiL1oeaK+pmx8BlkPt -+fGZJCe/068kqmp3N4EtOZLxXn55t3jNBYectPr0RmFqpjMsEJEcfXfuXROA4N9Ti -+Zd/o6X21eHEsm0kK0q4YfppfgTd5Ze7k1jTkUuuU6/yh6uRk1MiFreEzkPO3Aayh -+iEWlYx33vq3HccTPgdY3D64Zr8gmgKG+8mdEvqb1jK4SVZ1/9vy4OKIIpUZB/eqx -+46h9Ejwn9pktnYkHi/A/zCREEcIQ10HXFF5bjxJTFQkM5S46/QEO7uuvnpMb+6Yy -+4V1/QIWMG6ixqCRx9GqbBK7GHdYODw== -+=+IsI - -----END PGP SIGNATURE----- --- -2.41.0 - diff --git a/SOURCES/amd_ucode_info.py b/SOURCES/amd_ucode_info.py new file mode 100755 index 0000000..8186cbc --- /dev/null +++ b/SOURCES/amd_ucode_info.py @@ -0,0 +1,374 @@ +#!/usr/bin/python3 +# SPDX-License-Identifier: MIT License +# Copyright (C) 2020 Advanced Micro Devices, Inc. + +""" +Parse an amd-ucode container file and print the family, model, stepping number, +and patch level for each patch in the file. The --extract option will dump the +raw microcode patches to a provided directory. +""" + +import argparse +import sys +import os + +from collections import namedtuple +from collections import OrderedDict + +EQ_TABLE_ENTRY_SIZE = 16 +EQ_TABLE_LEN_OFFSET = 8 +EQ_TABLE_OFFSET = 12 +EQ_TABLE_TYPE = 0 +PATCH_TYPE = 1 + +VERBOSE_DEBUG = 2 + +FMS = namedtuple("FMS", ("family", "model", "stepping")) +EquivTableEntry = namedtuple("EquivTableEntry", ("cpuid", "equiv_id", "data", "offset")) +PatchEntry = namedtuple("PatchEntry", ("file", "offset", "size", "equiv_id", "level")) + +def read_int32(ucode_file): + """ Read four bytes of binary data and return as a 32 bit int """ + return int.from_bytes(ucode_file.read(4), 'little') + +def read_int16(ucode_file): + """ Read two bytes of binary data and return as a 16 bit int """ + return int.from_bytes(ucode_file.read(2), 'little') + +def read_int8(ucode_file): + """ Read one byte of binary data and return as a 8 bit int """ + return int.from_bytes(ucode_file.read(1), 'little') + +def cpuid2fms(cpu_id): + family = (cpu_id >> 8) & 0xf + family += (cpu_id >> 20) & 0xff + + model = (cpu_id >> 4) & 0xf + model |= (cpu_id >> 12) & 0xf0 + + stepping = cpu_id & 0xf + + return FMS(family, model, stepping) + +def fms2str(fms): + return "Family=%#04x Model=%#04x Stepping=%#04x" % \ + (fms.family, fms.model, fms.stepping) + +def parse_equiv_table(opts, ucode_file, start_offset, eq_table_len): + """ + Read equivalence table and return a list of the equivalence ids contained + """ + table = {} + raw_table = [] + # For sanity check only + cpuid_map = {} + + table_item = start_offset + EQ_TABLE_OFFSET + table_stop = start_offset + EQ_TABLE_OFFSET + eq_table_len + + while table_item < table_stop: + ucode_file.seek(table_item, 0) + data = ucode_file.read(EQ_TABLE_ENTRY_SIZE) + ucode_file.seek(table_item, 0) + + cpu_id = read_int32(ucode_file) + + if opts.verbose >= VERBOSE_DEBUG: + errata_mask = read_int32(ucode_file) + errata_compare = read_int32(ucode_file) + else: + # Skip errata mask and compare fields + ucode_file.seek(8, 1) + + equiv_id = read_int16(ucode_file) + if opts.verbose >= VERBOSE_DEBUG: + res = read_int16(ucode_file) + + if equiv_id != 0: + if equiv_id not in table: + table[equiv_id] = OrderedDict() + + if cpu_id in table[equiv_id]: + print("WARNING: Duplicate CPUID %#010x (%s) in the equivalence table for equiv_id %#06x " % + (fms2str(cpuid2fms(cpu_id)), equiv_id)) + + if cpu_id in cpuid_map: + if equiv_id != cpuid_map[cpu_id]: + print("WARNING: Different equiv_id's (%#06x and %#06x) are present in the equivalence table for CPUID %#010x (%s)" % + (equiv_id, cpuid_map[cpu_id], cpu_id, + fms2str(cpuid2fms(cpu_id)))) + else: + cpuid_map[cpu_id] = equiv_id + + entry = EquivTableEntry(cpu_id, equiv_id, data, table_item) + table[equiv_id][cpu_id] = entry + raw_table.append(entry) + + if opts.verbose >= VERBOSE_DEBUG: + print(" [equiv entry@%#010x: cpuid %#010x, equiv id %#06x, errata mask %#010x, errata compare %#010x, res %#06x]" % + (table_item, cpu_id, equiv_id, errata_mask, errata_compare, res)) + + table_item += EQ_TABLE_ENTRY_SIZE + + return (table, raw_table) + +def extract_patch(opts, out_dir, ucode_file, patch, equiv_table=None): + """ + Extract raw microcode patch starting at patch_start to the directory + provided by the -o option or the current directory if not specified. + Directory will be created if it doesn't already exist. + """ + cwd = os.getcwd() + + if not os.path.exists(out_dir): + os.makedirs(out_dir) + + os.chdir(out_dir) + + if equiv_table is None: + # Raw patch + out_file_name = "mc_patch_0%x.bin" % patch.level + else: + out_file_name = "mc_equivid_%#06x" % patch.equiv_id + for cpuid in equiv_table[patch.equiv_id]: + out_file_name += '_cpuid_%#010x' % cpuid + out_file_name += "_patch_%#010x.bin" % patch.level + + out_path = "%s/%s" % (os.getcwd(), out_file_name) + out_file = open(out_file_name, "wb") + + os.chdir(cwd) + + if equiv_table is not None: + cpuids = equiv_table[patch.equiv_id].values() if patch.equiv_id in equiv_table else [] + else: + cpuids = None + + write_mc(opts, out_file, [patch], ucode_file, cpuids) + + out_file.close() + + print(" Patch extracted to %s" % out_path) + +def merge_mc(opts, out_path, table, patches): + # Do some sanity checks, ut only warn about the issues + equivid_map = {} + cpuid_map = {} + + for entry in table: + if entry.equiv_id not in equivid_map: + equivid_map[entry.equiv_id] = dict() + + if entry.cpuid in equivid_map[entry.equiv_id]: + print("WARNING: Duplicate CPUID %#010x (%s) in the equivalence table for equiv_id %#06x " % + (fms2str(cpuid2fms(entry.cpuid)), entry.equiv_id)) + else: + equivid_map[entry.equiv_id][entry.cpuid] = entry + + if entry.cpuid in cpuid_map: + if entry.equiv_id != cpuid_map[entry.cpuid]: + print("WARNING: Different equiv_id's (%#06x and %#06x) are present in the equivalence table for CPUID %#010x (%s)" % + (entry.equiv_id, cpuid_map[entry.cpuid], entry.cpuid, + fms2str(cpuid2fms(entry.cpuid)))) + else: + cpuid_map[entry.cpuid] = entry.equiv_id + + with open(out_path, "wb") as out_file: + write_mc(opts, out_file, patches, equiv_table=table) + + print("Microcode written to %s" % out_path) + +def write_mc(opts, out_file, patches, ucode_file=None, equiv_table=None): + """ + Writes microcode data to the specified file. + """ + if equiv_table is not None: + # Container header + out_file.write(b'DMA\x00') + + # Equivalence table header + out_file.write(EQ_TABLE_TYPE.to_bytes(4, 'little')) + table_size = EQ_TABLE_ENTRY_SIZE * (len(equiv_table) + 1) + out_file.write(table_size.to_bytes(4, 'little')) + + # Equivalence table + for cpuid in equiv_table: + out_file.write(cpuid.data) + + out_file.write(b'\0' * EQ_TABLE_ENTRY_SIZE) + + for patch in patches: + # Patch header + if equiv_table is not None: + out_file.write(PATCH_TYPE.to_bytes(4, 'little')) + out_file.write(patch.size.to_bytes(4, 'little')) + + if ucode_file is None: + in_file = open(patch.file, "rb") + else: + in_file = ucode_file + + in_file.seek(patch.offset, 0) + out_file.write(in_file.read(patch.size)) + + if ucode_file is None: + in_file.close() + +def parse_ucode_file(opts, path, start_offset): + """ + Scan through microcode container file printing the microcode patch level + for each model contained in the file. + """ + table = None + patches = [] + + with open(path, "rb") as ucode_file: + print("Microcode patches in %s%s:" % + (path, "+%#x" % start_offset if start_offset else "")) + + # Seek to end of file to determine file size + ucode_file.seek(0, 2) + end_of_file = ucode_file.tell() + + # Check magic number + ucode_file.seek(start_offset, 0) + if ucode_file.read(4) != b'DMA\x00': + print("ERROR: Missing magic number at beginning of container") + return (None, None, None) + + # Check the equivalence table type + eq_table_type = read_int32(ucode_file) + if eq_table_type != EQ_TABLE_TYPE: + print("ERROR: Invalid equivalence table identifier: %#010x" % + eq_table_type) + return (None, None, None) + + # Read the equivalence table length + eq_table_len = read_int32(ucode_file) + + ids, table = parse_equiv_table(opts, ucode_file, start_offset, eq_table_len) + + cursor = start_offset + EQ_TABLE_OFFSET + eq_table_len + while cursor < end_of_file: + # Seek to the start of the patch information + ucode_file.seek(cursor, 0) + + patch_start = cursor + 8 + + patch_type_bytes = ucode_file.read(4) + # Beginning of a new container + if patch_type_bytes == b'DMA\x00': + return (cursor, table, patches) + patch_type = int.from_bytes(patch_type_bytes, 'little') + if patch_type != PATCH_TYPE: + print("Invalid patch identifier: %#010x" % (patch_type)) + return (None, table, patches) + + patch_length = read_int32(ucode_file) + if opts.verbose: + data_code = read_int32(ucode_file) + else: + ucode_file.seek(4, 1) + ucode_level = read_int32(ucode_file) + if opts.verbose >= VERBOSE_DEBUG: + mc_patch_data_id = read_int16(ucode_file) + mc_patch_data_len = read_int8(ucode_file) + init_flag = read_int8(ucode_file) + mc_patch_data_checksum = read_int32(ucode_file) + nb_dev_id = read_int32(ucode_file) + sb_dev_id = read_int32(ucode_file) + else: + ucode_file.seek(16, 1) + equiv_id = read_int16(ucode_file) + if opts.verbose >= VERBOSE_DEBUG: + nb_rev_id = read_int8(ucode_file) + sb_rev_id = read_int8(ucode_file) + bios_api_rev = read_int8(ucode_file) + reserved1 = [read_int8(ucode_file) for _ in range(3)] + match_reg = [read_int32(ucode_file) for _ in range(8)] + + if opts.verbose: + add_info = " Start=%u bytes Date=%04x-%02x-%02x Equiv_id=%#06x" % \ + (patch_start, data_code & 0xffff, data_code >> 24, + (data_code >> 16) & 0xff, equiv_id) + else: + add_info = "" + + if equiv_id not in ids: + print("Patch equivalence id not present in equivalence table (%#06x)" + % (equiv_id)) + print(" Family=???? Model=???? Stepping=????: Patch=%#010x Length=%u bytes%s" + % (ucode_level, patch_length, add_info)) + + # The cpu_id is the equivalent to CPUID_Fn00000001_EAX + for cpuid in ids[equiv_id]: + print(" %s: Patch=%#010x Length=%u bytes%s" + % (fms2str(cpuid2fms(cpuid)), ucode_level, patch_length, add_info)) + + if opts.verbose >= VERBOSE_DEBUG: + print(" [data_code=%#010x, mc_patch_data_id=%#06x, mc_patch_data_len=%#04x, init_flag=%#04x, mc_patch_data_checksum=%#010x]" % + (data_code, mc_patch_data_id, mc_patch_data_len, init_flag, mc_patch_data_checksum)) + print(" [nb_dev_id=%#010x, sb_dev_id=%#010x, nb_rev_id=%#04x, sb_rev_id=%#04x, bios_api_rev=%#04x, reserved=[%#04x, %#04x, %#04x]]" % + (nb_dev_id, sb_dev_id, nb_rev_id, sb_rev_id, bios_api_rev, reserved1[0], reserved1[1], reserved1[2])) + + patch = PatchEntry(path, patch_start, patch_length, equiv_id, ucode_level) + patches.append(patch) + + if opts.extract: + extract_patch(opts, opts.extract, ucode_file, patch) + + if opts.split: + extract_patch(opts, opts.split, ucode_file, patch, ids) + + cursor = cursor + patch_length + 8 + + return (None, table, patches) + +def parse_ucode_files(opts): + all_tables = [] + all_patches = [] + + for f in opts.container_file: + offset = 0 + while offset is not None: + offset, table, patches = parse_ucode_file(opts, f, offset) + if opts.merge: + if table is not None: + all_tables += table + if patches is not None: + all_patches += patches + + if opts.merge: + merge_mc(opts, opts.merge, all_tables, all_patches) + +def parse_options(): + """ Parse options """ + parser = argparse.ArgumentParser(description="Print information about an amd-ucode container") + parser.add_argument("container_file", nargs='+') + parser.add_argument("-e", "--extract", + help="Dump each patch in container to the specified directory") + parser.add_argument("-s", "--split", + help="Split out each patch in a separate container to the specified directory") + parser.add_argument("-m", "--merge", + help="Write a merged container to the specified file") + parser.add_argument("-v", "--verbose", action="count", default=0, + help="Be verbose about the information in the container file") + opts = parser.parse_args() + + for f in opts.container_file: + if not os.path.isfile(f): + parser.print_help() + print() + print("ERROR: Container file \"%s\" does not exist" % f) + sys.exit() + + return opts + +def main(): + """ main """ + opts = parse_options() + + parse_ucode_files(opts) + +if __name__ == "__main__": + main() diff --git a/SPECS/linux-firmware.spec b/SPECS/linux-firmware.spec index e26429a..077fcb6 100644 --- a/SPECS/linux-firmware.spec +++ b/SPECS/linux-firmware.spec @@ -1,12 +1,12 @@ -%global checkout 2e92a49f +%global checkout 0e048b06 -%global firmware_release 117 +%global firmware_release 119 %global _firmwarepath /usr/lib/firmware %define _binaries_in_noarch_packages_terminate_build 0 Name: linux-firmware -Version: 20230404 +Version: 20230824 Release: %{firmware_release}.git%{checkout}%{?dist} Summary: Firmware files used by the Linux kernel License: GPL+ and GPLv2+ and MIT and Redistributable, no modification permitted @@ -18,11 +18,7 @@ BuildArch: noarch # This is still causing problems in RHEL9 (see bug 1959913) and because of that we should keep out of RHEL8 too # 2) git archive --worktree-attributes --format=tar --prefix=linux-firmware-%%{checkout}/ %%{checkout} | xz > linux-firmware-%%{version}.tar.xz Source0: %{name}-%{version}.tar.xz - -# Update AMD CPU microcode requested for https://bugzilla.redhat.com/show_bug.cgi?id=222715 -Patch01: 0001-linux-firmware-Update-AMD-cpu-microcode.patch -Patch02: 0002-linux-firmware-Update-AMD-cpu-microcode.patch -Patch03: 0003-linux-firmware-Update-AMD-fam17h-cpu-microcode.patch +Source1: amd_ucode_info.py Provides: kernel-firmware = %{version} xorg-x11-drv-ati-firmware = 7.0 Obsoletes: kernel-firmware < %{version} xorg-x11-drv-ati-firmware < 6.13.0-0.22 @@ -46,6 +42,7 @@ Conflicts: microcode_ctl < 2.1-0 Obsoletes: ivtv-firmware < 2:20080701-28 BuildRequires: git make +BuildRequires: python3 %description This package includes firmware files required for some devices to @@ -236,7 +233,7 @@ contained inside the provided LICENSE file. Please read it carefully. %package -n libertas-usb8388-firmware Summary: Firmware for Marvell Libertas USB 8388 Network Adapter License: Redistributable, no modification permitted -Epoch: 2 +Epoch: 2 Obsoletes: libertas-usb8388-firmware < 2:5.110.22.p23-8 %description -n libertas-usb8388-firmware Firmware for Marvell Libertas USB 8388 Network Adapter @@ -262,8 +259,27 @@ License: Redistributable, no modification permitted Firmware for Marvell Libertas SD 8787 Network Adapter %prep +%setup -q -n linux-firmware-%{checkout} + +# Repack AMD Family 19h microcode +/usr/bin/python3 %{SOURCE1} -vv -s amd-ucode/fam19 amd-ucode/microcode_amd_fam19h.bin +rm -rvf amd-ucode/fam19/*cpuid_0x00aa0f0*.bin +/usr/bin/python3 %{SOURCE1} -vv amd-ucode/fam19/* -m amd-ucode/microcode_amd_fam19h.bin +/usr/bin/python3 %{SOURCE1} -vv amd-ucode/microcode_amd_fam19h.bin +rm -rvf amd-ucode/fam19 + +%if 0 +git init . +if [ -z "$GIT_COMMITTER_NAME" ]; then + git config user.email "nobody@fedoraproject.org" + git config user.name "Fedora linux-firmware packagers" +fi +git add . +git commit -m init . -%autosetup -S git -p1 -n linux-firmware-%{checkout} +git am %{patches} + +%endif %build @@ -422,14 +438,31 @@ sed -e 's/^/%%dir /' linux-firmware.dirs >> linux-firmware.files %config(noreplace) %{_firmwarepath}/netronome/nic_AMDA* %changelog -* Wed Aug 03 2023 Lucas Zampieri - 20230404-117.git2e92a49f -- Update amd-ucode firmware for CVE-2023-20593 (rhbz 2227152) +* Tue Sep 26 2023 Patrick Talbert - 20230824-119.git0e048b06 +- Exclude AMD cpu ucode for fam19/*cpuid_0x00aa0f0* +Resolves: RHEL-3903 + +* Thu Aug 24 2023 Denys Vlasenko - 20230824-118.git0e048b06 +- Update to latest upstream linux-firmware image for assorted updates +- AMD Zen3 and Zen4 firmware update for return address predictor velunerability +Resolves: rhbz#2230415 -* Wed Aug 02 2023 Lucas Zampieri - 20230404-116.git2e92a49f -- Update amd-ucode firmware for CVE-2023-20593 (rhbz 2227152) +* Tue Aug 08 2023 Denys Vlasenko - 20230808-117.git0ab353f8 +- Update to latest upstream linux-firmware image for assorted updates +- Navi32 dGPU firmware +- Update to fix multi monitor behind TBT3 dock & random flickers +- AMD Zen2 firmware update for cross-process information leak +Resolves: rhbz#2047482, rhbz#2227846, rhbz#2227153 -* Mon Jul 31 2023 Lucas Zampieri - 20230404-115.git2e92a49f -- Update amd-ucode firmware for CVE-2023-20593 (rhbz 2227152) +* Tue Jul 11 2023 Denys Vlasenko - 20230711-116.gitd3f66064 +- Update to latest upstream linux-firmware image for assorted updates +- AMD GPU firmware update: fix PSR-SU issues with kernel 6.2 or later +Resolves: rhbz#2218670 + +* Mon May 15 2023 Denys Vlasenko - 20230515-115.gitd1962891 +- Update to latest upstream linux-firmware image for assorted updates +- [RHEL8] Add latest NVIDIA signed firmware for Turing GPUs and later +Resolves: rhbz#2183606 * Wed Apr 05 2023 Patrick Talbert - 20230404-114.git2e92a49f - Update to latest upstream linux-firmware image for assorted updates