linux-pinenote/drivers/net/wireless/iwlwifi/pcie
Johannes Berg 38c0f334b3 iwlwifi: use coherent DMA memory for command header
Recently in commit 8a964f44e0
("iwlwifi: always copy first 16 bytes of commands") we fixed
the problem that the hardware writes back to the command and
that could overwrite parts of the data that was still needed
and would thus be corrupted.

Investigating this problem more closely we found that this
write-back isn't really ordered very well with respect to
other DMA traffic. Therefore, it sometimes happened that the
write-back occurred after unmapping the command again which
is clearly an issue and could corrupt the next allocation
that goes to that spot, or (better) cause IOMMU faults.

To fix this, allocate coherent memory for the first 16 bytes
of each command, containing the write-back part, and use it
for all queues. All the dynamic DMA mappings only need to be
TO_DEVICE then. This ensures that even when the write-back
happens "too late" it can't hit memory that has been freed
or a mapping that doesn't exist any more.

Since now the actual command is no longer modified, we can
also remove CMD_WANT_HCMD and get rid of the DMA sync that
was necessary to update the scratch pointer.

Reviewed-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
2013-02-28 11:49:42 +01:00
..
1000.c iwlwifi: update copyright 2013-01-24 13:00:55 +01:00
2000.c iwlwifi: update copyright 2013-01-24 13:00:55 +01:00
5000.c iwlwifi: update copyright 2013-01-24 13:00:55 +01:00
6000.c iwlwifi: update copyright 2013-01-24 13:00:55 +01:00
7000.c iwlwifi: add 7000 series device configuration 2013-01-30 21:41:24 +01:00
cfg.h iwlwifi: add 7000 series device configuration 2013-01-30 21:41:24 +01:00
drv.c iwlwifi: add 7000 series device configuration 2013-01-30 21:41:24 +01:00
internal.h iwlwifi: use coherent DMA memory for command header 2013-02-28 11:49:42 +01:00
rx.c iwlwifi: use coherent DMA memory for command header 2013-02-28 11:49:42 +01:00
trans.c iwlwifi: use threaded interrupt handler 2013-02-05 14:39:12 +01:00
tx.c iwlwifi: use coherent DMA memory for command header 2013-02-28 11:49:42 +01:00