Commit 5be8824f authored by Vasanthakumar Thiagarajan's avatar Vasanthakumar Thiagarajan Committed by Kalle Valo

ath6kl: Move block_sz and block_mask from ath6kl_device to htc_target

Signed-off-by: default avatarVasanthakumar Thiagarajan <vthiagar@qca.qualcomm.com>
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent 3b2f5e51
...@@ -181,7 +181,7 @@ static int htc_issue_send(struct htc_target *target, struct htc_packet *packet) ...@@ -181,7 +181,7 @@ static int htc_issue_send(struct htc_target *target, struct htc_packet *packet)
ath6kl_dbg(ATH6KL_DBG_HTC_SEND, "%s: transmit len : %d (%s)\n", ath6kl_dbg(ATH6KL_DBG_HTC_SEND, "%s: transmit len : %d (%s)\n",
__func__, send_len, sync ? "sync" : "async"); __func__, send_len, sync ? "sync" : "async");
padded_len = CALC_TXRX_PADDED_LEN(target->dev, send_len); padded_len = CALC_TXRX_PADDED_LEN(target, send_len);
ath6kl_dbg(ATH6KL_DBG_HTC_SEND, ath6kl_dbg(ATH6KL_DBG_HTC_SEND,
"DevSendPacket, padded len: %d mbox:0x%X (mode:%s)\n", "DevSendPacket, padded len: %d mbox:0x%X (mode:%s)\n",
...@@ -287,7 +287,7 @@ static void htc_tx_pkts_get(struct htc_target *target, ...@@ -287,7 +287,7 @@ static void htc_tx_pkts_get(struct htc_target *target,
"got head pkt:0x%p , queue depth: %d\n", "got head pkt:0x%p , queue depth: %d\n",
packet, get_queue_depth(&endpoint->txq)); packet, get_queue_depth(&endpoint->txq));
len = CALC_TXRX_PADDED_LEN(target->dev, len = CALC_TXRX_PADDED_LEN(target,
packet->act_len + HTC_HDR_LENGTH); packet->act_len + HTC_HDR_LENGTH);
if (htc_check_credits(target, endpoint, &flags, if (htc_check_credits(target, endpoint, &flags,
...@@ -365,7 +365,7 @@ static int htc_setup_send_scat_list(struct htc_target *target, ...@@ -365,7 +365,7 @@ static int htc_setup_send_scat_list(struct htc_target *target,
break; break;
packet = list_first_entry(queue, struct htc_packet, list); packet = list_first_entry(queue, struct htc_packet, list);
len = CALC_TXRX_PADDED_LEN(target->dev, len = CALC_TXRX_PADDED_LEN(target,
packet->act_len + HTC_HDR_LENGTH); packet->act_len + HTC_HDR_LENGTH);
cred_pad = htc_get_credit_padding(target->tgt_cred_sz, cred_pad = htc_get_credit_padding(target->tgt_cred_sz,
...@@ -904,7 +904,7 @@ static int dev_rx_pkt(struct htc_target *target, struct htc_packet *packet, ...@@ -904,7 +904,7 @@ static int dev_rx_pkt(struct htc_target *target, struct htc_packet *packet,
u32 padded_len; u32 padded_len;
int status; int status;
padded_len = CALC_TXRX_PADDED_LEN(dev, rx_len); padded_len = CALC_TXRX_PADDED_LEN(target, rx_len);
if (padded_len > packet->buf_len) { if (padded_len > packet->buf_len) {
ath6kl_err("not enough receive space for packet - padlen:%d recvlen:%d bufferlen:%d\n", ath6kl_err("not enough receive space for packet - padlen:%d recvlen:%d bufferlen:%d\n",
...@@ -972,7 +972,7 @@ static int htc_setup_rxpkts(struct htc_target *target, struct htc_endpoint *ep, ...@@ -972,7 +972,7 @@ static int htc_setup_rxpkts(struct htc_target *target, struct htc_endpoint *ep,
int status = 0, j, full_len; int status = 0, j, full_len;
bool no_recycle; bool no_recycle;
full_len = CALC_TXRX_PADDED_LEN(target->dev, full_len = CALC_TXRX_PADDED_LEN(target,
le16_to_cpu(htc_hdr->payld_len) + le16_to_cpu(htc_hdr->payld_len) +
sizeof(*htc_hdr)); sizeof(*htc_hdr));
...@@ -1571,7 +1571,7 @@ static int htc_issue_rxpkt_bundle(struct htc_target *target, ...@@ -1571,7 +1571,7 @@ static int htc_issue_rxpkt_bundle(struct htc_target *target,
packet = list_first_entry(rxq, struct htc_packet, list); packet = list_first_entry(rxq, struct htc_packet, list);
list_del(&packet->list); list_del(&packet->list);
pad_len = CALC_TXRX_PADDED_LEN(target->dev, pad_len = CALC_TXRX_PADDED_LEN(target,
packet->act_len); packet->act_len);
if ((rem_space - pad_len) < 0) { if ((rem_space - pad_len) < 0) {
...@@ -2202,7 +2202,7 @@ static void htc_setup_msg_bndl(struct htc_target *target) ...@@ -2202,7 +2202,7 @@ static void htc_setup_msg_bndl(struct htc_target *target)
if (target->max_rx_bndl_sz) if (target->max_rx_bndl_sz)
target->rx_bndl_enable = true; target->rx_bndl_enable = true;
if ((target->tgt_cred_sz % target->dev->block_sz) != 0) { if ((target->tgt_cred_sz % target->block_sz) != 0) {
ath6kl_warn("credit size: %d is not block aligned! Disabling send bundling\n", ath6kl_warn("credit size: %d is not block aligned! Disabling send bundling\n",
target->tgt_cred_sz); target->tgt_cred_sz);
......
...@@ -530,6 +530,9 @@ struct htc_target { ...@@ -530,6 +530,9 @@ struct htc_target {
int rx_bndl_enable; int rx_bndl_enable;
int max_rx_bndl_sz; int max_rx_bndl_sz;
int max_tx_bndl_sz; int max_tx_bndl_sz;
u32 block_sz;
u32 block_mask;
}; };
void *htc_create(struct ath6kl *ar); void *htc_create(struct ath6kl *ar);
......
...@@ -615,19 +615,19 @@ int ath6kldev_setup(struct ath6kl_device *dev) ...@@ -615,19 +615,19 @@ int ath6kldev_setup(struct ath6kl_device *dev)
* for SDIO the block size on mailbox 0 is artificially set to 1. * for SDIO the block size on mailbox 0 is artificially set to 1.
* So we use the block size that is set for the other 3 mailboxes. * So we use the block size that is set for the other 3 mailboxes.
*/ */
dev->block_sz = dev->ar->mbox_info.block_size; dev->htc_cnxt->block_sz = dev->ar->mbox_info.block_size;
/* must be a power of 2 */ /* must be a power of 2 */
if ((dev->block_sz & (dev->block_sz - 1)) != 0) { if ((dev->htc_cnxt->block_sz & (dev->htc_cnxt->block_sz - 1)) != 0) {
WARN_ON(1); WARN_ON(1);
goto fail_setup; goto fail_setup;
} }
/* assemble mask, used for padding to a block */ /* assemble mask, used for padding to a block */
dev->block_mask = dev->block_sz - 1; dev->htc_cnxt->block_mask = dev->htc_cnxt->block_sz - 1;
ath6kl_dbg(ATH6KL_DBG_TRC, "block size: %d, mbox addr:0x%X\n", ath6kl_dbg(ATH6KL_DBG_TRC, "block size: %d, mbox addr:0x%X\n",
dev->block_sz, dev->ar->mbox_info.htc_addr); dev->htc_cnxt->block_sz, dev->ar->mbox_info.htc_addr);
ath6kl_dbg(ATH6KL_DBG_TRC, ath6kl_dbg(ATH6KL_DBG_TRC,
"hif interrupt processing is sync only\n"); "hif interrupt processing is sync only\n");
......
...@@ -79,8 +79,6 @@ struct ath6kl_device { ...@@ -79,8 +79,6 @@ struct ath6kl_device {
u8 pad2[A_CACHE_LINE_PAD]; u8 pad2[A_CACHE_LINE_PAD];
struct ath6kl_irq_enable_reg irq_en_reg; struct ath6kl_irq_enable_reg irq_en_reg;
u8 pad3[A_CACHE_LINE_PAD]; u8 pad3[A_CACHE_LINE_PAD];
u32 block_sz;
u32 block_mask;
struct htc_target *htc_cnxt; struct htc_target *htc_cnxt;
struct hif_dev_scat_sup_info hif_scat_info; struct hif_dev_scat_sup_info hif_scat_info;
int chk_irq_status_cnt; int chk_irq_status_cnt;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment