mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
iwlwifi: pcie: switch to correct RBD/CD layout for 22560
The layout of the RBD (receive buffer descriptor) isn't quite right, the hardware ended up being implemented differently. Switch to the correct RBD layout. While at it, remove the now useless extra defines. Also, switch the CD (completion descriptor) to the right format, which is basically just a code cleanup because the only field we really used (rbid) is still in the same place. We may need fragmentation later if we ever want to use it. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
This commit is contained in:
parent
fd1190b68a
commit
f826faaa1f
@ -8,7 +8,7 @@
|
|||||||
* Copyright(c) 2012 - 2014 Intel Corporation. All rights reserved.
|
* Copyright(c) 2012 - 2014 Intel Corporation. All rights reserved.
|
||||||
* Copyright(c) 2013 - 2015 Intel Mobile Communications GmbH
|
* Copyright(c) 2013 - 2015 Intel Mobile Communications GmbH
|
||||||
* Copyright(c) 2015 - 2017 Intel Deutschland GmbH
|
* Copyright(c) 2015 - 2017 Intel Deutschland GmbH
|
||||||
* Copyright(c) 2018 Intel Corporation
|
* Copyright(c) 2018 - 2019 Intel Corporation
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of version 2 of the GNU General Public License as
|
* it under the terms of version 2 of the GNU General Public License as
|
||||||
@ -31,7 +31,7 @@
|
|||||||
* Copyright(c) 2012 - 2014 Intel Corporation. All rights reserved.
|
* Copyright(c) 2012 - 2014 Intel Corporation. All rights reserved.
|
||||||
* Copyright(c) 2013 - 2015 Intel Mobile Communications GmbH
|
* Copyright(c) 2013 - 2015 Intel Mobile Communications GmbH
|
||||||
* Copyright(c) 2015 - 2017 Intel Deutschland GmbH
|
* Copyright(c) 2015 - 2017 Intel Deutschland GmbH
|
||||||
* Copyright(c) 2018 Intel Corporation
|
* Copyright(c) 2018 - 2019 Intel Corporation
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -688,13 +688,6 @@ struct iwl_rx_mpdu_desc {
|
|||||||
|
|
||||||
#define IWL_RX_DESC_SIZE_V1 offsetofend(struct iwl_rx_mpdu_desc, v1)
|
#define IWL_RX_DESC_SIZE_V1 offsetofend(struct iwl_rx_mpdu_desc, v1)
|
||||||
|
|
||||||
#define IWL_CD_STTS_OPTIMIZED_POS 0
|
|
||||||
#define IWL_CD_STTS_OPTIMIZED_MSK 0x01
|
|
||||||
#define IWL_CD_STTS_TRANSFER_STATUS_POS 1
|
|
||||||
#define IWL_CD_STTS_TRANSFER_STATUS_MSK 0x0E
|
|
||||||
#define IWL_CD_STTS_WIFI_STATUS_POS 4
|
|
||||||
#define IWL_CD_STTS_WIFI_STATUS_MSK 0xF0
|
|
||||||
|
|
||||||
#define RX_NO_DATA_CHAIN_A_POS 0
|
#define RX_NO_DATA_CHAIN_A_POS 0
|
||||||
#define RX_NO_DATA_CHAIN_A_MSK (0xff << RX_NO_DATA_CHAIN_A_POS)
|
#define RX_NO_DATA_CHAIN_A_MSK (0xff << RX_NO_DATA_CHAIN_A_POS)
|
||||||
#define RX_NO_DATA_CHAIN_B_POS 8
|
#define RX_NO_DATA_CHAIN_B_POS 8
|
||||||
@ -747,62 +740,6 @@ struct iwl_rx_no_data {
|
|||||||
__le32 rx_vec[2];
|
__le32 rx_vec[2];
|
||||||
} __packed; /* RX_NO_DATA_NTFY_API_S_VER_1 */
|
} __packed; /* RX_NO_DATA_NTFY_API_S_VER_1 */
|
||||||
|
|
||||||
/**
|
|
||||||
* enum iwl_completion_desc_transfer_status - transfer status (bits 1-3)
|
|
||||||
* @IWL_CD_STTS_UNUSED: unused
|
|
||||||
* @IWL_CD_STTS_UNUSED_2: unused
|
|
||||||
* @IWL_CD_STTS_END_TRANSFER: successful transfer complete.
|
|
||||||
* In sniffer mode, when split is used, set in last CD completion. (RX)
|
|
||||||
* @IWL_CD_STTS_OVERFLOW: In sniffer mode, when using split - used for
|
|
||||||
* all CD completion. (RX)
|
|
||||||
* @IWL_CD_STTS_ABORTED: CR abort / close flow. (RX)
|
|
||||||
* @IWL_CD_STTS_ERROR: general error (RX)
|
|
||||||
*/
|
|
||||||
enum iwl_completion_desc_transfer_status {
|
|
||||||
IWL_CD_STTS_UNUSED,
|
|
||||||
IWL_CD_STTS_UNUSED_2,
|
|
||||||
IWL_CD_STTS_END_TRANSFER,
|
|
||||||
IWL_CD_STTS_OVERFLOW,
|
|
||||||
IWL_CD_STTS_ABORTED,
|
|
||||||
IWL_CD_STTS_ERROR,
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* enum iwl_completion_desc_wifi_status - wifi status (bits 4-7)
|
|
||||||
* @IWL_CD_STTS_VALID: the packet is valid (RX)
|
|
||||||
* @IWL_CD_STTS_FCS_ERR: frame check sequence error (RX)
|
|
||||||
* @IWL_CD_STTS_SEC_KEY_ERR: error handling the security key of rx (RX)
|
|
||||||
* @IWL_CD_STTS_DECRYPTION_ERR: error decrypting the frame (RX)
|
|
||||||
* @IWL_CD_STTS_DUP: duplicate packet (RX)
|
|
||||||
* @IWL_CD_STTS_ICV_MIC_ERR: MIC error (RX)
|
|
||||||
* @IWL_CD_STTS_INTERNAL_SNAP_ERR: problems removing the snap (RX)
|
|
||||||
* @IWL_CD_STTS_SEC_PORT_FAIL: security port fail (RX)
|
|
||||||
* @IWL_CD_STTS_BA_OLD_SN: block ack received old SN (RX)
|
|
||||||
* @IWL_CD_STTS_QOS_NULL: QoS null packet (RX)
|
|
||||||
* @IWL_CD_STTS_MAC_HDR_ERR: MAC header conversion error (RX)
|
|
||||||
* @IWL_CD_STTS_MAX_RETRANS: reached max number of retransmissions (TX)
|
|
||||||
* @IWL_CD_STTS_EX_LIFETIME: exceeded lifetime (TX)
|
|
||||||
* @IWL_CD_STTS_NOT_USED: completed but not used (RX)
|
|
||||||
* @IWL_CD_STTS_REPLAY_ERR: pn check failed, replay error (RX)
|
|
||||||
*/
|
|
||||||
enum iwl_completion_desc_wifi_status {
|
|
||||||
IWL_CD_STTS_VALID,
|
|
||||||
IWL_CD_STTS_FCS_ERR,
|
|
||||||
IWL_CD_STTS_SEC_KEY_ERR,
|
|
||||||
IWL_CD_STTS_DECRYPTION_ERR,
|
|
||||||
IWL_CD_STTS_DUP,
|
|
||||||
IWL_CD_STTS_ICV_MIC_ERR,
|
|
||||||
IWL_CD_STTS_INTERNAL_SNAP_ERR,
|
|
||||||
IWL_CD_STTS_SEC_PORT_FAIL,
|
|
||||||
IWL_CD_STTS_BA_OLD_SN,
|
|
||||||
IWL_CD_STTS_QOS_NULL,
|
|
||||||
IWL_CD_STTS_MAC_HDR_ERR,
|
|
||||||
IWL_CD_STTS_MAX_RETRANS,
|
|
||||||
IWL_CD_STTS_EX_LIFETIME,
|
|
||||||
IWL_CD_STTS_NOT_USED,
|
|
||||||
IWL_CD_STTS_REPLAY_ERR,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct iwl_frame_release {
|
struct iwl_frame_release {
|
||||||
u8 baid;
|
u8 baid;
|
||||||
u8 reserved;
|
u8 reserved;
|
||||||
|
@ -274,7 +274,6 @@ struct iwl_rx_cmd_buffer {
|
|||||||
bool _page_stolen;
|
bool _page_stolen;
|
||||||
u32 _rx_page_order;
|
u32 _rx_page_order;
|
||||||
unsigned int truesize;
|
unsigned int truesize;
|
||||||
u8 status;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline void *rxb_addr(struct iwl_rx_cmd_buffer *r)
|
static inline void *rxb_addr(struct iwl_rx_cmd_buffer *r)
|
||||||
|
@ -106,7 +106,6 @@ struct iwl_host_cmd;
|
|||||||
* @page: driver's pointer to the rxb page
|
* @page: driver's pointer to the rxb page
|
||||||
* @invalid: rxb is in driver ownership - not owned by HW
|
* @invalid: rxb is in driver ownership - not owned by HW
|
||||||
* @vid: index of this rxb in the global table
|
* @vid: index of this rxb in the global table
|
||||||
* @size: size used from the buffer
|
|
||||||
*/
|
*/
|
||||||
struct iwl_rx_mem_buffer {
|
struct iwl_rx_mem_buffer {
|
||||||
dma_addr_t page_dma;
|
dma_addr_t page_dma;
|
||||||
@ -114,7 +113,6 @@ struct iwl_rx_mem_buffer {
|
|||||||
u16 vid;
|
u16 vid;
|
||||||
bool invalid;
|
bool invalid;
|
||||||
struct list_head list;
|
struct list_head list;
|
||||||
u32 size;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -135,46 +133,32 @@ struct isr_statistics {
|
|||||||
u32 unhandled;
|
u32 unhandled;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define IWL_RX_TD_TYPE_MSK 0xff000000
|
|
||||||
#define IWL_RX_TD_SIZE_MSK 0x00ffffff
|
|
||||||
#define IWL_RX_TD_SIZE_2K BIT(11)
|
|
||||||
#define IWL_RX_TD_TYPE 0
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct iwl_rx_transfer_desc - transfer descriptor
|
* struct iwl_rx_transfer_desc - transfer descriptor
|
||||||
* @type_n_size: buffer type (bit 0: external buff valid,
|
|
||||||
* bit 1: optional footer valid, bit 2-7: reserved)
|
|
||||||
* and buffer size
|
|
||||||
* @addr: ptr to free buffer start address
|
* @addr: ptr to free buffer start address
|
||||||
* @rbid: unique tag of the buffer
|
* @rbid: unique tag of the buffer
|
||||||
* @reserved: reserved
|
* @reserved: reserved
|
||||||
*/
|
*/
|
||||||
struct iwl_rx_transfer_desc {
|
struct iwl_rx_transfer_desc {
|
||||||
__le32 type_n_size;
|
|
||||||
__le64 addr;
|
|
||||||
__le16 rbid;
|
__le16 rbid;
|
||||||
__le16 reserved;
|
__le16 reserved[3];
|
||||||
|
__le64 addr;
|
||||||
} __packed;
|
} __packed;
|
||||||
|
|
||||||
#define IWL_RX_CD_SIZE 0xffffff00
|
#define IWL_RX_CD_FLAGS_FRAGMENTED BIT(0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct iwl_rx_completion_desc - completion descriptor
|
* struct iwl_rx_completion_desc - completion descriptor
|
||||||
* @type: buffer type (bit 0: external buff valid,
|
|
||||||
* bit 1: optional footer valid, bit 2-7: reserved)
|
|
||||||
* @status: status of the completion
|
|
||||||
* @reserved1: reserved
|
* @reserved1: reserved
|
||||||
* @rbid: unique tag of the received buffer
|
* @rbid: unique tag of the received buffer
|
||||||
* @size: buffer size, masked by IWL_RX_CD_SIZE
|
* @flags: flags (0: fragmented, all others: reserved)
|
||||||
* @reserved2: reserved
|
* @reserved2: reserved
|
||||||
*/
|
*/
|
||||||
struct iwl_rx_completion_desc {
|
struct iwl_rx_completion_desc {
|
||||||
u8 type;
|
__le32 reserved1;
|
||||||
u8 status;
|
|
||||||
__le16 reserved1;
|
|
||||||
__le16 rbid;
|
__le16 rbid;
|
||||||
__le32 size;
|
u8 flags;
|
||||||
u8 reserved2[22];
|
u8 reserved2[25];
|
||||||
} __packed;
|
} __packed;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -282,9 +282,8 @@ static void iwl_pcie_restock_bd(struct iwl_trans *trans,
|
|||||||
if (trans->cfg->device_family >= IWL_DEVICE_FAMILY_22560) {
|
if (trans->cfg->device_family >= IWL_DEVICE_FAMILY_22560) {
|
||||||
struct iwl_rx_transfer_desc *bd = rxq->bd;
|
struct iwl_rx_transfer_desc *bd = rxq->bd;
|
||||||
|
|
||||||
bd[rxq->write].type_n_size =
|
BUILD_BUG_ON(sizeof(*bd) != 2 * sizeof(u64));
|
||||||
cpu_to_le32((IWL_RX_TD_TYPE & IWL_RX_TD_TYPE_MSK) |
|
|
||||||
((IWL_RX_TD_SIZE_2K >> 8) & IWL_RX_TD_SIZE_MSK));
|
|
||||||
bd[rxq->write].addr = cpu_to_le64(rxb->page_dma);
|
bd[rxq->write].addr = cpu_to_le64(rxb->page_dma);
|
||||||
bd[rxq->write].rbid = cpu_to_le16(rxb->vid);
|
bd[rxq->write].rbid = cpu_to_le16(rxb->vid);
|
||||||
} else {
|
} else {
|
||||||
@ -1265,9 +1264,6 @@ static void iwl_pcie_rx_handle_rb(struct iwl_trans *trans,
|
|||||||
.truesize = max_len,
|
.truesize = max_len,
|
||||||
};
|
};
|
||||||
|
|
||||||
if (trans->cfg->device_family >= IWL_DEVICE_FAMILY_22560)
|
|
||||||
rxcb.status = rxq->cd[i].status;
|
|
||||||
|
|
||||||
pkt = rxb_addr(&rxcb);
|
pkt = rxb_addr(&rxcb);
|
||||||
|
|
||||||
if (pkt->len_n_flags == cpu_to_le32(FH_RSCSR_FRAME_INVALID)) {
|
if (pkt->len_n_flags == cpu_to_le32(FH_RSCSR_FRAME_INVALID)) {
|
||||||
@ -1394,6 +1390,8 @@ static struct iwl_rx_mem_buffer *iwl_pcie_get_rxb(struct iwl_trans *trans,
|
|||||||
struct iwl_rx_mem_buffer *rxb;
|
struct iwl_rx_mem_buffer *rxb;
|
||||||
u16 vid;
|
u16 vid;
|
||||||
|
|
||||||
|
BUILD_BUG_ON(sizeof(struct iwl_rx_completion_desc) != 32);
|
||||||
|
|
||||||
if (!trans->cfg->mq_rx_supported) {
|
if (!trans->cfg->mq_rx_supported) {
|
||||||
rxb = rxq->queue[i];
|
rxb = rxq->queue[i];
|
||||||
rxq->queue[i] = NULL;
|
rxq->queue[i] = NULL;
|
||||||
@ -1415,9 +1413,6 @@ static struct iwl_rx_mem_buffer *iwl_pcie_get_rxb(struct iwl_trans *trans,
|
|||||||
|
|
||||||
IWL_DEBUG_RX(trans, "Got virtual RB ID %u\n", (u32)rxb->vid);
|
IWL_DEBUG_RX(trans, "Got virtual RB ID %u\n", (u32)rxb->vid);
|
||||||
|
|
||||||
if (trans->cfg->device_family >= IWL_DEVICE_FAMILY_22560)
|
|
||||||
rxb->size = le32_to_cpu(rxq->cd[i].size) & IWL_RX_CD_SIZE;
|
|
||||||
|
|
||||||
rxb->invalid = true;
|
rxb->invalid = true;
|
||||||
|
|
||||||
return rxb;
|
return rxb;
|
||||||
|
Loading…
Reference in New Issue
Block a user