aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/ath
diff options
context:
space:
mode:
authorMichal Kazior <michal.kazior@tieto.com>2015-02-09 09:04:55 -0500
committerKalle Valo <kvalo@qca.qualcomm.com>2015-03-04 07:07:15 -0500
commit6383864053cc456aa82847cd910257deaa34eb5a (patch)
tree20ebfb32c8b0adeceb57fc89f22c60205b4f2907 /drivers/net/wireless/ath
parentdb2cf865c75792f2e52596bf3e94e9a98272becf (diff)
ath10k: workaround corrupted htt rx events
qca6174 WLAN.RM.2.0-00073 firmware uses full rx reordering offload and delivers Rx via a new HTT event. The event however is incorrectly generated in firmware and becomes overly long (with trailing garbage). This was hitting defined CE buffer limit that was programmed to the device and caused device to crash upon busier Rx traffic. Increasing the CE buffer limit for HTT Rx pipe to 2KBytes seems to be enough to workaround this problem. Signed-off-by: Michal Kazior <michal.kazior@tieto.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
Diffstat (limited to 'drivers/net/wireless/ath')
-rw-r--r--drivers/net/wireless/ath/ath10k/pci.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/net/wireless/ath/ath10k/pci.c b/drivers/net/wireless/ath/ath10k/pci.c
index e6972b09333e..7681237fe298 100644
--- a/drivers/net/wireless/ath/ath10k/pci.c
+++ b/drivers/net/wireless/ath/ath10k/pci.c
@@ -104,7 +104,7 @@ static const struct ce_attr host_ce_config_wlan[] = {
104 { 104 {
105 .flags = CE_ATTR_FLAGS, 105 .flags = CE_ATTR_FLAGS,
106 .src_nentries = 0, 106 .src_nentries = 0,
107 .src_sz_max = 512, 107 .src_sz_max = 2048,
108 .dest_nentries = 512, 108 .dest_nentries = 512,
109 }, 109 },
110 110
@@ -174,7 +174,7 @@ static const struct ce_pipe_config target_ce_config_wlan[] = {
174 .pipenum = __cpu_to_le32(1), 174 .pipenum = __cpu_to_le32(1),
175 .pipedir = __cpu_to_le32(PIPEDIR_IN), 175 .pipedir = __cpu_to_le32(PIPEDIR_IN),
176 .nentries = __cpu_to_le32(32), 176 .nentries = __cpu_to_le32(32),
177 .nbytes_max = __cpu_to_le32(512), 177 .nbytes_max = __cpu_to_le32(2048),
178 .flags = __cpu_to_le32(CE_ATTR_FLAGS), 178 .flags = __cpu_to_le32(CE_ATTR_FLAGS),
179 .reserved = __cpu_to_le32(0), 179 .reserved = __cpu_to_le32(0),
180 }, 180 },