Ryzen public erratas

Gary Jennejohn gljennjohn at gmail.com
Wed Jun 13 14:53:00 UTC 2018


On Wed, 13 Jun 2018 14:46:25 +0300
Konstantin Belousov <kostikbel at gmail.com> wrote:

> On Wed, Jun 13, 2018 at 12:06:42PM +0100, Johannes Lundberg wrote:
> > 
> > Konstantin Belousov writes:
> >   
> > > Today I noted that AMD published the public errata document for Ryzens,
> > > https://developer.amd.com/wp-content/resources/55449_1.12.pdf
> > >
> > > Some of the issues listed there looks quite relevant to the potential
> > > hangs that some people still experience with the machines.  I wrote
> > > a script which should apply the recommended workarounds to the erratas
> > > that I find interesting.
> > >
> > > To run it, kldload cpuctl, then apply the latest firmware update to your
> > > CPU, then run the following shell script.  Comments indicate the errata
> > > number for the workarounds.
> > >
> > > Please report the results.  If the script helps, I will code the kernel
> > > change to apply the workarounds.
> > >
> > > #!/bin/sh
> > >
> > > # Enable workarounds for erratas listed in
> > > # https://developer.amd.com/wp-content/resources/55449_1.12.pdf
> > >
> > > # 1057, 1109
> > > sysctl machdep.idle_mwait=0
> > > sysctl machdep.idle=hlt
> > >
> > > for x in /dev/cpuctl*; do
> > > 	# 1021
> > > 	cpucontrol -m '0xc0011029|=0x2000' $x
> > > 	# 1033
> > > 	cpucontrol -m '0xc0011020|=0x10' $x
> > > 	# 1049
> > > 	cpucontrol -m '0xc0011028|=0x10' $x
> > > 	# 1095
> > > 	cpucontrol -m '0xc0011020|=0x200000000000000' $x
> > > done
> > >  
> > 
> > Hi
> > 
> > Thanks for the fix! I'm trying it now on my Ryzen 3 2200G which does
> > experience some random occasional resets.
> > 
> > About updating to latest firmware, is this something that's done from BIOS or
> > from FreeBSD? If the latter, how?  
> From FreeBSD, install sysutils/devcpu-data then do
> 	service microcode_update start
> and of course, you must flash latest BIOS.
> 
> The microcode_update must be applied before running this script.
>

I added before and after outputs to my version of the script and
saw that my BIOS is setting all the relevant bits at start up.

So, a BIOS update might help.

-- 
Gary Jennejohn


More information about the freebsd-amd64 mailing list