* FPGA access over PCI-E on MPC8536
@ 2009-09-17  4:17 Felix Radensky
  2009-09-17  6:48 ` Kumar Gala
                   ` (2 more replies)
  0 siblings, 3 replies; 7+ messages in thread
From: Felix Radensky @ 2009-09-17  4:17 UTC (permalink / raw)
  To: linuxppc-dev
Hi,
On my custom MPC8536 based board running 2.6.31 kernel
FPGA is connected via x2 PCI-E lane. FPGA is identified
during PCI scan and is visible via lspci.
0000:01:00.0 Class ff00: Altera Corporation Unknown device 0004 (rev 01)
         Subsystem: Altera Corporation Unknown device 0004
         Flags: fast devsel, IRQ 16
         Memory at 98000000 (32-bit, non-prefetchable) [disabled] [size=1M]
         Capabilities: [50] Message Signalled Interrupts: Mask+ 64bit+ 
Queue=0/5 Enable-
         Capabilities: [78] Power Management version 3
         Capabilities: [80] Express Endpoint IRQ 0
         Capabilities: [100] Virtual Channel
However when I attempt to access FPGA memory my mmapping it in userspace 
the read hangs. The same happens in kernel space. Does it happen because 
FPGA memory is marked as disabled, or because FPGA code is doing 
something wrong ?
Another question is what can cause PCI device memory be marked as
disabled.
Thanks a lot.
Felix.
^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: FPGA access over PCI-E on MPC8536
  2009-09-17  4:17 FPGA access over PCI-E on MPC8536 Felix Radensky
@ 2009-09-17  6:48 ` Kumar Gala
  2009-09-17  8:43   ` Benjamin Herrenschmidt
  2009-09-17 15:43   ` David Hawkins
       [not found] ` <fa686aa40909180636jb2f8676k94a50b176319c249@mail.gmail.com>
  2009-09-19 18:31 ` Leon Woestenberg
  2 siblings, 2 replies; 7+ messages in thread
From: Kumar Gala @ 2009-09-17  6:48 UTC (permalink / raw)
  To: Felix Radensky; +Cc: linuxppc-dev
On Sep 16, 2009, at 11:17 PM, Felix Radensky wrote:
> Hi,
>
> On my custom MPC8536 based board running 2.6.31 kernel
> FPGA is connected via x2 PCI-E lane. FPGA is identified
> during PCI scan and is visible via lspci.
>
> 0000:01:00.0 Class ff00: Altera Corporation Unknown device 0004 (rev  
> 01)
>        Subsystem: Altera Corporation Unknown device 0004
>        Flags: fast devsel, IRQ 16
>        Memory at 98000000 (32-bit, non-prefetchable) [disabled]  
> [size=1M]
>        Capabilities: [50] Message Signalled Interrupts: Mask+ 64bit+  
> Queue=0/5 Enable-
>        Capabilities: [78] Power Management version 3
>        Capabilities: [80] Express Endpoint IRQ 0
>        Capabilities: [100] Virtual Channel
>
>
> However when I attempt to access FPGA memory my mmapping it in  
> userspace the read hangs. The same happens in kernel space. Does it  
> happen because FPGA memory is marked as disabled, or because FPGA  
> code is doing something wrong ?
Can you access the device in u-boot?  That would possible tell you if  
the HW is functioning or not.
> Another question is what can cause PCI device memory be marked as
> disabled.
Good question, no idea how lspci decided to print [disabled].  Take a  
look at lspci source and see :)
- k
^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: FPGA access over PCI-E on MPC8536
  2009-09-17  6:48 ` Kumar Gala
@ 2009-09-17  8:43   ` Benjamin Herrenschmidt
  2009-09-19 15:52     ` Felix Radensky
  2009-09-17 15:43   ` David Hawkins
  1 sibling, 1 reply; 7+ messages in thread
From: Benjamin Herrenschmidt @ 2009-09-17  8:43 UTC (permalink / raw)
  To: Kumar Gala; +Cc: linuxppc-dev, Felix Radensky
> > However when I attempt to access FPGA memory my mmapping it in  
> > userspace the read hangs. The same happens in kernel space. Does it  
> > happen because FPGA memory is marked as disabled, or because FPGA  
> > code is doing something wrong ?
> 
> Can you access the device in u-boot?  That would possible tell you if  
> the HW is functioning or not.
> 
> > Another question is what can cause PCI device memory be marked as
> > disabled.
> 
> Good question, no idea how lspci decided to print [disabled].  Take a  
> look at lspci source and see :)
Maybe the memory enable in the PCI command register isn't set ?
If you don't have a kernel driver that sets it (by calling
pci_enable_device) and u-boot doesn't set it then it's going
to be off and you'll get hangs or machine checks trying to
access the device...
Just an idea...
Cheers,
Ben.
^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: FPGA access over PCI-E on MPC8536
  2009-09-17  6:48 ` Kumar Gala
  2009-09-17  8:43   ` Benjamin Herrenschmidt
@ 2009-09-17 15:43   ` David Hawkins
  1 sibling, 0 replies; 7+ messages in thread
From: David Hawkins @ 2009-09-17 15:43 UTC (permalink / raw)
  To: linuxppc-dev; +Cc: Felix Radensky
Hi Felix,
>> On my custom MPC8536 based board running 2.6.31 kernel
>> FPGA is connected via x2 PCI-E lane. FPGA is identified
>> during PCI scan and is visible via lspci.
>>
>> 0000:01:00.0 Class ff00: Altera Corporation Unknown device 0004 (rev 01)
>>        Subsystem: Altera Corporation Unknown device 0004
>>        Flags: fast devsel, IRQ 16
>>        Memory at 98000000 (32-bit, non-prefetchable) [disabled] [size=1M]
>>        Capabilities: [50] Message Signalled Interrupts: Mask+ 64bit+ 
>> Queue=0/5 Enable-
>>        Capabilities: [78] Power Management version 3
>>        Capabilities: [80] Express Endpoint IRQ 0
>>        Capabilities: [100] Virtual Channel
>>
>>
>> However when I attempt to access FPGA memory my mmapping it in 
>> userspace the read hangs. The same happens in kernel space. Does it 
>> happen because FPGA memory is marked as disabled, or because FPGA code 
>> is doing something wrong ?
> 
> Can you access the device in u-boot?  That would possible tell you if 
> the HW is functioning or not.
> 
>> Another question is what can cause PCI device memory be marked as
>> disabled.
> 
> Good question, no idea how lspci decided to print [disabled].  Take a 
> look at lspci source and see :)
lspci has a -x and -xxx options to print the bytes in the
PCI configuration space header. You should use that to
see what the settings are, and then you'll be able
to interpret what disabled means.
For example, here's lspci run from an x86 host CPU looking
at an MPC8349EA processor peripheral board:
# lspci -s 04:0d.0 -v
04:0d.0 Power PC: Freescale Semiconductor Inc MPC8349E (rev 30)
         Flags: 66Mhz, fast devsel, IRQ 10
         Memory at fc300000 (32-bit, non-prefetchable) [size=1M]
         Memory at fe400000 (32-bit, prefetchable) [size=4K]
         Memory at fe300000 (64-bit, prefetchable) [size=1M]
         Memory at fe200000 (64-bit, prefetchable) [size=1M]
         Capabilities: [48] #06 [0080]
# lspci -s 04:0d.0 -x
04:0d.0 Power PC: Freescale Semiconductor Inc MPC8349E (rev 30)
00: 57 19 80 00 42 01 b0 00 30 00 20 0b 08 40 00 00
10: 00 00 30 fc 08 00 40 fe 0c 00 30 fe 00 00 00 00
20: 0c 00 20 fe 00 00 00 00 00 00 00 00 00 00 00 00
30: 00 00 00 00 48 00 00 00 00 00 00 00 0a 01 00 00
The memory, non-prefetchable, and size are decoded from bits in
the base address registers. I'm pretty sure there is an
enabled/disabled bit in there too. Thats probably where your
lspci output is getting it from.
I suspect that you could perform a configuration space
write to enable that bit, or that the FPGA initialization
code should be setting that bit. It really depends on
what the PCIe component inside the FPGA was designed to
do.
For example, on the MPC8349EA processor configured as a
peripheral board, the PCI bridge can come up enabled, or
disabled. If the bridge is disabled, then it is up to the
PowerPC processor core (U-boot code) to enable the PCI
interface prior to the host CPU BIOS configuring the base
addresses in the interface. Its possible you've missed
something like this when you configured the core,
eg. an 'enable on boot option' (I haven't used the PCIe
core, so have no idea if this is an option - but you
could submit an Altera service request).
Since you're playing with an FPGA, you should be able to
connect Altera's logic analyzer core to the PCI interface
and capture traffic as well, so that could be used to
debug your problem.
Cheers,
Dave
^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: FPGA access over PCI-E on MPC8536
       [not found] ` <fa686aa40909180636jb2f8676k94a50b176319c249@mail.gmail.com>
@ 2009-09-18 13:44   ` Grant Likely
  0 siblings, 0 replies; 7+ messages in thread
From: Grant Likely @ 2009-09-18 13:44 UTC (permalink / raw)
  To: Felix Radensky; +Cc: linuxppc-dev
[-- Attachment #1: Type: text/plain, Size: 1594 bytes --]
Can you access fpga memory from u-boot?
Could very well be an fpga problem.  Same thing can happen on xilinx parts
when accessing an undefined register address via pci bridge --> plb bus -->
ipif register block --> bad address.  The pci core goes into some kind of
retry loop with the plb bus (I'm wasn't the one to look at the pci analyzer,
so I don't know the details), and it completely locks up.
g.
On Sep 16, 2009 11:02 PM, "Felix Radensky" <felix@embedded-sol.com> wrote:
Hi,
On my custom MPC8536 based board running 2.6.31 kernel
FPGA is connected via x2 PCI-E lane. FPGA is identified
during PCI scan and is visible via lspci.
0000:01:00.0 Class ff00: Altera Corporation Unknown device 0004 (rev 01)
       Subsystem: Altera Corporation Unknown device 0004
       Flags: fast devsel, IRQ 16
       Memory at 98000000 (32-bit, non-prefetchable) [disabled] [size=1M]
       Capabilities: [50] Message Signalled Interrupts: Mask+ 64bit+
Queue=0/5 Enable-
       Capabilities: [78] Power Management version 3
       Capabilities: [80] Express Endpoint IRQ 0
       Capabilities: [100] Virtual Channel
However when I attempt to access FPGA memory my mmapping it in userspace the
read hangs. The same happens in kernel space. Does it happen because FPGA
memory is marked as disabled, or because FPGA code is doing something wrong
?
Another question is what can cause PCI device memory be marked as
disabled.
Thanks a lot.
Felix.
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev
[-- Attachment #2: Type: text/html, Size: 2048 bytes --]
^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: FPGA access over PCI-E on MPC8536
  2009-09-17  8:43   ` Benjamin Herrenschmidt
@ 2009-09-19 15:52     ` Felix Radensky
  0 siblings, 0 replies; 7+ messages in thread
From: Felix Radensky @ 2009-09-19 15:52 UTC (permalink / raw)
  To: linuxppc-dev
Hi, Benjamin
Benjamin Herrenschmidt wrote:
>>> However when I attempt to access FPGA memory my mmapping it in  
>>> userspace the read hangs. The same happens in kernel space. Does it  
>>> happen because FPGA memory is marked as disabled, or because FPGA  
>>> code is doing something wrong ?
>> Can you access the device in u-boot?  That would possible tell you if  
>> the HW is functioning or not.
>>
>>> Another question is what can cause PCI device memory be marked as
>>> disabled.
>> Good question, no idea how lspci decided to print [disabled].  Take a  
>> look at lspci source and see :)
> 
> Maybe the memory enable in the PCI command register isn't set ?
> 
> If you don't have a kernel driver that sets it (by calling
> pci_enable_device) and u-boot doesn't set it then it's going
> to be off and you'll get hangs or machine checks trying to
> access the device...
> 
> Just an idea...
Yes, that was my problem exactly ! Setting this bit via setpci
fixed it.
Thanks a lot for your help.
Felix
^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: FPGA access over PCI-E on MPC8536
  2009-09-17  4:17 FPGA access over PCI-E on MPC8536 Felix Radensky
  2009-09-17  6:48 ` Kumar Gala
       [not found] ` <fa686aa40909180636jb2f8676k94a50b176319c249@mail.gmail.com>
@ 2009-09-19 18:31 ` Leon Woestenberg
  2 siblings, 0 replies; 7+ messages in thread
From: Leon Woestenberg @ 2009-09-19 18:31 UTC (permalink / raw)
  To: Felix Radensky, Greg KH, Greg KH; +Cc: linuxppc-dev
Hello Felix,
On Thu, Sep 17, 2009 at 6:17 AM, Felix Radensky <felix@embedded-sol.com> wrote:
> On my custom MPC8536 based board running 2.6.31 kernel
> FPGA is connected via x2 PCI-E lane. FPGA is identified
> during PCI scan and is visible via lspci.
>
I committed a PCI Express device driver for an Altera FPGA (chaining
DMA reference) design upstream that resides in the upstream Linux
kernel at drivers/staging/altpciechdma/
It can act as a reference for the generic part of your design.
Regards,
-- 
Leon
^ permalink raw reply	[flat|nested] 7+ messages in thread
end of thread, other threads:[~2009-09-19 18:31 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-09-17  4:17 FPGA access over PCI-E on MPC8536 Felix Radensky
2009-09-17  6:48 ` Kumar Gala
2009-09-17  8:43   ` Benjamin Herrenschmidt
2009-09-19 15:52     ` Felix Radensky
2009-09-17 15:43   ` David Hawkins
     [not found] ` <fa686aa40909180636jb2f8676k94a50b176319c249@mail.gmail.com>
2009-09-18 13:44   ` Grant Likely
2009-09-19 18:31 ` Leon Woestenberg
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).