s390/qeth: handle error when backing RX buffer
[ Upstream commit1741385280
] qeth_init_qdio_queues() fills the RX ring with an initial set of RX buffers. If qeth_init_input_buffer() fails to back one of the RX buffers with memory, we need to bail out and report the error. Fixes:4a71df5004
("qeth: new qeth device driver") Signed-off-by: Julian Wiedmann <jwi@linux.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
8b6cccd9bd
commit
ee3bc48664
@ -2633,12 +2633,12 @@ static int qeth_init_input_buffer(struct qeth_card *card,
|
||||
buf->rx_skb = netdev_alloc_skb(card->dev,
|
||||
QETH_RX_PULL_LEN + ETH_HLEN);
|
||||
if (!buf->rx_skb)
|
||||
return 1;
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
pool_entry = qeth_find_free_buffer_pool_entry(card);
|
||||
if (!pool_entry)
|
||||
return 1;
|
||||
return -ENOBUFS;
|
||||
|
||||
/*
|
||||
* since the buffer is accessed only from the input_tasklet
|
||||
@ -2670,10 +2670,15 @@ int qeth_init_qdio_queues(struct qeth_card *card)
|
||||
/* inbound queue */
|
||||
qdio_reset_buffers(card->qdio.in_q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
|
||||
memset(&card->rx, 0, sizeof(struct qeth_rx));
|
||||
|
||||
qeth_initialize_working_pool_list(card);
|
||||
/*give only as many buffers to hardware as we have buffer pool entries*/
|
||||
for (i = 0; i < card->qdio.in_buf_pool.buf_count - 1; ++i)
|
||||
qeth_init_input_buffer(card, &card->qdio.in_q->bufs[i]);
|
||||
for (i = 0; i < card->qdio.in_buf_pool.buf_count - 1; i++) {
|
||||
rc = qeth_init_input_buffer(card, &card->qdio.in_q->bufs[i]);
|
||||
if (rc)
|
||||
return rc;
|
||||
}
|
||||
|
||||
card->qdio.in_q->next_buf_to_init =
|
||||
card->qdio.in_buf_pool.buf_count - 1;
|
||||
rc = do_QDIO(CARD_DDEV(card), QDIO_FLAG_SYNC_INPUT, 0, 0,
|
||||
|
Loading…
Reference in New Issue
Block a user