]> git.baikalelectronics.ru Git - kernel.git/commit
firewire-ohci: work around oversized DMA reads on JMicron controllers
authorHector Martin <marcan@marcan.st>
Fri, 3 Nov 2017 11:28:57 +0000 (20:28 +0900)
committerStefan Richter <stefanr@s5r6.in-berlin.de>
Sat, 13 Jan 2018 16:19:12 +0000 (17:19 +0100)
commit77dd72d316c1c216080ed21e09a70f6bfab9674c
tree86bcbf8f533dee75628fd02977083bb55ae4d166
parentb844cc8e61b552ebde0bbf97e2a2933608f8800f
firewire-ohci: work around oversized DMA reads on JMicron controllers

At least some JMicron controllers issue buggy oversized DMA reads when
fetching context descriptors, always fetching 0x20 bytes at once for
descriptors which are only 0x10 bytes long. This is often harmless, but
can cause page faults on modern systems with IOMMUs:

DMAR: [DMA Read] Request device [05:00.0] fault addr fff56000 [fault reason 06] PTE Read access is not set
firewire_ohci 0000:05:00.0: DMA context IT0 has stopped, error code: evt_descriptor_read

This works around the problem by always leaving 0x10 padding bytes at
the end of descriptor buffer pages, which should be harmless to do
unconditionally for controllers in case others have the same behavior.

Signed-off-by: Hector Martin <marcan@marcan.st>
Reviewed-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
drivers/firewire/ohci.c