mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-24 19:44:55 +00:00
ctcm: use correct idal word list for ctcmpc
Communication Server Linux uses the ctcmpc code of the ctcm driver. Sending problems have shown up caused by a wrong idal word list for the first ccw. Function ctcmpc_chx_txdone() invokes the function to prepare the idal word list without setting an appropriate length for the first ccw, which may lead to an incomplete idal word list. This patch sets the maximum buffer size as data length of the first ccw. Thus correct idal word lists are guaranteed in all cases. Signed-off-by: Belinda Thompson <belindat@us.ibm.com> Reviewed-by: Ursula Braun <ursula.braun@de.ibm.com> Signed-off-by: Frank Blaschka <frank.blaschka@de.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
ce1f893837
commit
205a8b649c
@ -1341,6 +1341,12 @@ static void ctcmpc_chx_txdone(fsm_instance *fi, int event, void *arg)
|
|||||||
|
|
||||||
spin_unlock(&ch->collect_lock);
|
spin_unlock(&ch->collect_lock);
|
||||||
clear_normalized_cda(&ch->ccw[1]);
|
clear_normalized_cda(&ch->ccw[1]);
|
||||||
|
|
||||||
|
CTCM_PR_DBGDATA("ccwcda=0x%p data=0x%p\n",
|
||||||
|
(void *)(unsigned long)ch->ccw[1].cda,
|
||||||
|
ch->trans_skb->data);
|
||||||
|
ch->ccw[1].count = ch->max_bufsize;
|
||||||
|
|
||||||
if (set_normalized_cda(&ch->ccw[1], ch->trans_skb->data)) {
|
if (set_normalized_cda(&ch->ccw[1], ch->trans_skb->data)) {
|
||||||
dev_kfree_skb_any(ch->trans_skb);
|
dev_kfree_skb_any(ch->trans_skb);
|
||||||
ch->trans_skb = NULL;
|
ch->trans_skb = NULL;
|
||||||
@ -1350,6 +1356,11 @@ static void ctcmpc_chx_txdone(fsm_instance *fi, int event, void *arg)
|
|||||||
fsm_event(priv->mpcg->fsm, MPCG_EVENT_INOP, dev);
|
fsm_event(priv->mpcg->fsm, MPCG_EVENT_INOP, dev);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CTCM_PR_DBGDATA("ccwcda=0x%p data=0x%p\n",
|
||||||
|
(void *)(unsigned long)ch->ccw[1].cda,
|
||||||
|
ch->trans_skb->data);
|
||||||
|
|
||||||
ch->ccw[1].count = ch->trans_skb->len;
|
ch->ccw[1].count = ch->trans_skb->len;
|
||||||
fsm_addtimer(&ch->timer, CTCM_TIME_5_SEC, CTC_EVENT_TIMER, ch);
|
fsm_addtimer(&ch->timer, CTCM_TIME_5_SEC, CTC_EVENT_TIMER, ch);
|
||||||
ch->prof.send_stamp = current_kernel_time(); /* xtime */
|
ch->prof.send_stamp = current_kernel_time(); /* xtime */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user