[Nouveau] Interrupt setting
Younes Manton
younes.m at gmail.com
Fri Mar 12 20:52:53 PST 2010
On Fri, Mar 12, 2010 at 8:45 PM, Shinpei KATO
<shinpei at il.is.s.u-tokyo.ac.jp> wrote:
> Dear Younes,
>
> Thank you for your reply.
>
>> Nouveau doesn't really make use of interrupts so you wont see them
>> while running OpenGL. In general we make use of fences to signal when
>> things of interest have occured. Is there something particular you're
>> trying to accomplish or is this just a learning exercise?
>
> I have been using Nouveau for a research purpose, though it has been just a
> month.
> So I can say both something particular and a learning exercise.
> I have tried understanding the behavir of fences, but a bit hard to catch up
> the execution flow.
>
> To my understanding, for instance every time pushbuf ioctl is called, you
> create a fence object.
> Does this make a caller process to wait for a completion of a GPU command?
> I inserted printk()s in nouveau_fence_wait(), but the process does not seem
> sleeping.
I'm not the expert on these things so some of this may be incorrect.
If so I hope someone will correct me...
We create a fence for every pushbuf, so when that fence is signalled
we know that every command in the pushbuf has completed. Each fence
has a sequence number which is simply an integer. So after the first
pushbuf we will emit a fence with sequence #0, then 1, and so on. As
the GPU is processing pushbufs it will write the sequence # of each
fence it encounters in a register. By reading this register we know
which commands are completed.
We use this mechanism when synchronization is required instead of
interrupts. For example in the OpenGL driver if you issue a draw
command referring to texture A that draw command will be in some
pushbuf B. If you then attempt to write to texture A with the CPU
immediately after, the OpenGL driver will check if texture A is
referenced in a pending draw command and if so will flush the
associated pushbuf, which results in a fence being emitted. The OpenGL
driver will then attempt to map the texture. The kernel module will
wait until that fence is signalled before allowing the OpenGL driver
to map it so that synchronization is maintained, otherwise the CPU
might alter the contents of the texture before the previous draw
command was even seen by the GPU.
> I am also wondering if current GPUs can be set up to generate interrupts
> when GPU commands are done.
> My guess is that NV_MEMORY_TO_MEMORY_FORMAT_NOTIFY is to generate interrupts
> when DMA transfers are done.
> Am I misunderstanding?
There's another similar mechanism that the GPU supports, which is a
notifier/semaphore. With this you can specify a memory location and a
value and attach it to a specific command. The GPU will write the
value to the memory location after that command completes and you can
use the CPU to check it. You can also request that an interrupt be
generated. This is independent of the pushbuf sequence numbering and
is intended for more precise control. I don't know if we have any
example code using a notifier that you can look at unfortunately, but
it should be possible to generate an interrupt or write to a notifier
after using M2MF to copy some memory like you said.
More information about the Nouveau
mailing list