RE: [PATCH] megaraid_sas: Quirk mmio hook for 1078 MR controller

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----Original Message-----
> From: Bjorn Helgaas [mailto:bhelgaas@xxxxxxxxxx]
> Sent: Monday, December 23, 2013 11:28 PM
> To: Desai, Kashyap
> Cc: linux-scsi@xxxxxxxxxxxxxxx; linux-pci@xxxxxxxxxxxxxxx; James E.J.
> Bottomley; Saxena, Sumit; Adam Radford
> Subject: Re: [PATCH] megaraid_sas: Quirk mmio hook for 1078 MR controller
> 
> On Mon, Dec 23, 2013 at 8:13 AM,  <Kashyap.Desai@xxxxxxx> wrote:
> > This patch has fix for LSI Gen-1 MR controller issue which only pop-up
> > on few systems and it is not generic.
> >
> > On few system, MR 1078 MR controller is not working if mmio decoding is
> off.
> > This patch proposed early quirck entry for Device id 0x1000/0x0411 to
> enable mmio.
> >
> > Signed-off-by: Kashyap Desai <kashyap.desai@xxxxxxx>
> > ---
> > diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index
> > f6c31fa..a20fe41 100644
> > --- a/drivers/pci/quirks.c
> > +++ b/drivers/pci/quirks.c
> > @@ -43,6 +43,10 @@ static void quirk_mmio_always_on(struct pci_dev
> > *dev)  }  DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_ANY_ID, PCI_ANY_ID,
> >                                 PCI_CLASS_BRIDGE_HOST, 8,
> > quirk_mmio_always_on);
> > +/* LSI controller device id 0x0411 has some issues if mmio_always_on is
> not set.
> > + * It pop-up only on few specific system, where decoding disable is not
> working.
> > + */
> > +DECLARE_PCI_FIXUP_EARLY(0x1000, 0x0411, quirk_mmio_always_on);
> 
> What is the actual problem that happens without this quirk?  Is there some
> hardware defect in the MR 1078 that makes it fail when we disable decoding?
> 
> Disabling decoding is important because it prevents conflicts with other
> devices while sizing and updating BARs, so I don't want to use this quirk
> unless it's really necessary.
LSI is still investigating on h/w issue. It was originally reported from customer site and they have found this issue when they upgrade RHEL6.3 to RHEL6.4.

Kernel/Driver fault with machine check on RHEL6.4 at the time of driver reading base address registers. New way, used in RHEL6.4 (similar to upstream kernel) is to disable mmio memory mapping a and i/o to the device, read the value and then re-enable mmio memory mapping and i/o.  This seems to cause problems on customer setup.

1078 MR controller is pretty old h/w and we may need more time to actually figure out why new pci_read method is failing on customer system.  As an alternative (consider that LSI h/w has some issue), we opt to enable mmio via quirk entry. 

 ~ Kashyap

> 
> Bjorn
> 

��.n��������+%������w��{.n�����{������ܨ}���Ơz�j:+v�����w����ޙ��&�)ߡ�a����z�ޗ���ݢj��w�f





[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux