[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090918144226.GD25309@aftab>
Date: Fri, 18 Sep 2009 16:42:26 +0200
From: Borislav Petkov <borislav.petkov@....com>
To: Keith Mannthey <kmannth@...ibm.com>
CC: lkml <linux-kernel@...r.kernel.org>, dougthompson@...ssion.com
Subject: Re: [Patch] AMD64_EDAC: Fix amd64_map_to_dcs_mask
On Thu, Sep 17, 2009 at 07:09:41PM -0700, Keith Mannthey wrote:
> I tested 2.6.31 and the mainline amd64_edac driver. Once errors were
> getting reported I noticed that a good amount of valid looking system
> addressed were not being correctly decoded to the csrow level. I was
> only able to correctly decode errors on channel 0 of a given csrow.
> Errors on channel 1 were unable to be mapped.
>
> After some digging I realized that the there was an issue with handling
> of Dram Chip Select Masks. Specifically that amd64_map_to_dcs_mask was
> returning incorrect values on my Rev F based system. See AMD #32559,
> 4.5.4, starting on pg 90 for a Rev F explanation of the correct mapping
> of DRAM CS Base and DRAM CS Mask regs. This lead to the code below. I
> can provide further explanation if needed.
>
>
> I have tested this code on Rev F based system with ecc debug dimms and
> fully expect it to work on earlier and later cpus. I am now able to
> correctly decode and map errors to csrows rows on this system.
>
>
> Submitted-by: Keith Mannthey<kmannth@...ibm.com>
> ---
This whole DSC[BM] handling is rather long-winded and overengineered. It
is on my to-be-rewritten-and-simplified list.
>
> diff -urN linux-2.6.31/drivers/edac/amd64_edac.c linux-2.6.31-fixed/drivers/edac/amd64_edac.c
> --- linux-2.6.31/drivers/edac/amd64_edac.c 2009-09-09 15:13:59.000000000 -0700
> +++ linux-2.6.31-fixed/drivers/edac/amd64_edac.c 2009-09-17 22:32:09.000000000 -0700
> @@ -1,6 +1,8 @@
> -#include "amd64_edac.h"
> +#include <linux/log2.h>
> #include <asm/k8.h>
>
> +#include "amd64_edac.h"
> +
> static struct edac_pci_ctl_info *amd64_ctl_pci;
>
> static int report_gart_errors;
> @@ -132,7 +134,7 @@
> /* Map from a CSROW entry to the mask entry that operates on it */
> static inline u32 amd64_map_to_dcs_mask(struct amd64_pvt *pvt, int csrow)
> {
> - return csrow >> (pvt->num_dcsm >> 3);
> + return csrow >> (8 >> (ilog2(pvt->num_dcsm)+1));
Almost. You have 8 DCSMs on RevE, 4 on RevF and F10h and 2 on F11h and
this way you get wrong DCSM offsets for F11h. A dirty fix would be:
if (boot_cpu_data.x86 == 0xf && pvt->ext_model < OPTERON_CPU_REV_E) {
return csrow;
else
return csrow >> 1;
The problem is, the csrow thing still goes over 0..7 which is obviously
wrong on F11h but I'll fix that later. Care to redo your patch according
to these and the comments from my previous mail and resend?
By the way, your patches made me look harder at that code region and
I've found some more problems with it which I've fixed. Would you like
to test the whole bunch of fixes on your setup?
Thanks.
--
Regards/Gruss,
Boris.
Operating | Advanced Micro Devices GmbH
System | Karl-Hammerschmidt-Str. 34, 85609 Dornach b. München, Germany
Research | Geschäftsführer: Andrew Bowd, Thomas M. McCoy, Giuliano Meroni
Center | Sitz: Dornach, Gemeinde Aschheim, Landkreis München
(OSRC) | Registergericht München, HRB Nr. 43632
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists