Commit 4e26c5fe authored by Julian Wiedmann's avatar Julian Wiedmann Committed by David S. Miller

s390/qeth: cache max number of available buffer elements

The QETH_MAX_BUFFER_ELEMENTS() macro effectively returns a constant
value. To avoid some redundant pointer chasing and computations in the
xmit hot path, cache this value in the queue struct.

Take this as opportunity to shrink some of the queue struct's fields to
their appropriate value range, slightly reducing its total size.
Signed-off-by: default avatarJulian Wiedmann <jwi@linux.ibm.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 7b579ce5
...@@ -484,14 +484,12 @@ struct qeth_qdio_out_q { ...@@ -484,14 +484,12 @@ struct qeth_qdio_out_q {
struct qeth_qdio_out_buffer *bufs[QDIO_MAX_BUFFERS_PER_Q]; struct qeth_qdio_out_buffer *bufs[QDIO_MAX_BUFFERS_PER_Q];
struct qdio_outbuf_state *bufstates; /* convenience pointer */ struct qdio_outbuf_state *bufstates; /* convenience pointer */
struct qeth_out_q_stats stats; struct qeth_out_q_stats stats;
int queue_no; u8 next_buf_to_fill;
u8 max_elements;
u8 queue_no;
u8 do_pack;
struct qeth_card *card; struct qeth_card *card;
atomic_t state; atomic_t state;
int do_pack;
/*
* index of buffer to be filled by driver; state EMPTY or PACKING
*/
int next_buf_to_fill;
/* /*
* number of buffers that are currently filled (PRIMED) * number of buffers that are currently filled (PRIMED)
* -> these buffers are hardware-owned * -> these buffers are hardware-owned
......
...@@ -1165,15 +1165,14 @@ static void qeth_clear_output_buffer(struct qeth_qdio_out_q *queue, ...@@ -1165,15 +1165,14 @@ static void qeth_clear_output_buffer(struct qeth_qdio_out_q *queue,
qeth_release_skbs(buf); qeth_release_skbs(buf);
for (i = 0; i < QETH_MAX_BUFFER_ELEMENTS(queue->card); ++i) { for (i = 0; i < queue->max_elements; ++i) {
if (buf->buffer->element[i].addr && buf->is_header[i]) if (buf->buffer->element[i].addr && buf->is_header[i])
kmem_cache_free(qeth_core_header_cache, kmem_cache_free(qeth_core_header_cache,
buf->buffer->element[i].addr); buf->buffer->element[i].addr);
buf->is_header[i] = 0; buf->is_header[i] = 0;
} }
qeth_scrub_qdio_buffer(buf->buffer, qeth_scrub_qdio_buffer(buf->buffer, queue->max_elements);
QETH_MAX_BUFFER_ELEMENTS(queue->card));
buf->next_element_to_fill = 0; buf->next_element_to_fill = 0;
atomic_set(&buf->state, QETH_QDIO_BUF_EMPTY); atomic_set(&buf->state, QETH_QDIO_BUF_EMPTY);
} }
...@@ -2727,14 +2726,15 @@ int qeth_init_qdio_queues(struct qeth_card *card) ...@@ -2727,14 +2726,15 @@ int qeth_init_qdio_queues(struct qeth_card *card)
/* outbound queue */ /* outbound queue */
for (i = 0; i < card->qdio.no_out_queues; ++i) { for (i = 0; i < card->qdio.no_out_queues; ++i) {
qdio_reset_buffers(card->qdio.out_qs[i]->qdio_bufs, struct qeth_qdio_out_q *queue = card->qdio.out_qs[i];
QDIO_MAX_BUFFERS_PER_Q);
card->qdio.out_qs[i]->next_buf_to_fill = 0; qdio_reset_buffers(queue->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
card->qdio.out_qs[i]->do_pack = 0; queue->max_elements = QETH_MAX_BUFFER_ELEMENTS(card);
atomic_set(&card->qdio.out_qs[i]->used_buffers, 0); queue->next_buf_to_fill = 0;
atomic_set(&card->qdio.out_qs[i]->set_pci_flags_count, 0); queue->do_pack = 0;
atomic_set(&card->qdio.out_qs[i]->state, atomic_set(&queue->used_buffers, 0);
QETH_OUT_Q_UNLOCKED); atomic_set(&queue->set_pci_flags_count, 0);
atomic_set(&queue->state, QETH_OUT_Q_UNLOCKED);
} }
return 0; return 0;
} }
...@@ -3558,7 +3558,7 @@ static void qeth_qdio_output_handler(struct ccw_device *ccwdev, ...@@ -3558,7 +3558,7 @@ static void qeth_qdio_output_handler(struct ccw_device *ccwdev,
/* prepare the queue slot for re-use: */ /* prepare the queue slot for re-use: */
qeth_scrub_qdio_buffer(buffer->buffer, qeth_scrub_qdio_buffer(buffer->buffer,
QETH_MAX_BUFFER_ELEMENTS(card)); queue->max_elements);
if (qeth_init_qdio_out_buf(queue, bidx)) { if (qeth_init_qdio_out_buf(queue, bidx)) {
QETH_CARD_TEXT(card, 2, "outofbuf"); QETH_CARD_TEXT(card, 2, "outofbuf");
qeth_schedule_recovery(card); qeth_schedule_recovery(card);
...@@ -3705,8 +3705,8 @@ static int qeth_add_hw_header(struct qeth_qdio_out_q *queue, ...@@ -3705,8 +3705,8 @@ static int qeth_add_hw_header(struct qeth_qdio_out_q *queue,
unsigned int hdr_len, unsigned int proto_len, unsigned int hdr_len, unsigned int proto_len,
unsigned int *elements) unsigned int *elements)
{ {
const unsigned int max_elements = QETH_MAX_BUFFER_ELEMENTS(queue->card);
const unsigned int contiguous = proto_len ? proto_len : 1; const unsigned int contiguous = proto_len ? proto_len : 1;
const unsigned int max_elements = queue->max_elements;
unsigned int __elements; unsigned int __elements;
addr_t start, end; addr_t start, end;
bool push_ok; bool push_ok;
...@@ -3878,8 +3878,8 @@ static int qeth_fill_buffer(struct qeth_qdio_out_q *queue, ...@@ -3878,8 +3878,8 @@ static int qeth_fill_buffer(struct qeth_qdio_out_q *queue,
QETH_TXQ_STAT_INC(queue, skbs_pack); QETH_TXQ_STAT_INC(queue, skbs_pack);
/* If the buffer still has free elements, keep using it. */ /* If the buffer still has free elements, keep using it. */
if (!flush && buf->next_element_to_fill < if (!flush &&
QETH_MAX_BUFFER_ELEMENTS(queue->card)) buf->next_element_to_fill < queue->max_elements)
return 0; return 0;
} }
...@@ -3959,8 +3959,8 @@ int qeth_do_send_packet(struct qeth_card *card, struct qeth_qdio_out_q *queue, ...@@ -3959,8 +3959,8 @@ int qeth_do_send_packet(struct qeth_card *card, struct qeth_qdio_out_q *queue,
if (queue->do_pack) { if (queue->do_pack) {
do_pack = 1; do_pack = 1;
/* does packet fit in current buffer? */ /* does packet fit in current buffer? */
if ((QETH_MAX_BUFFER_ELEMENTS(card) - if (buffer->next_element_to_fill + elements_needed >
buffer->next_element_to_fill) < elements_needed) { queue->max_elements) {
/* ... no -> set state PRIMED */ /* ... no -> set state PRIMED */
atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED); atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED);
flush_count++; flush_count++;
......
...@@ -581,7 +581,7 @@ static int qeth_l2_xmit_osn(struct qeth_card *card, struct sk_buff *skb, ...@@ -581,7 +581,7 @@ static int qeth_l2_xmit_osn(struct qeth_card *card, struct sk_buff *skb,
} }
elements += qeth_count_elements(skb, hd_len); elements += qeth_count_elements(skb, hd_len);
if (elements > QETH_MAX_BUFFER_ELEMENTS(card)) { if (elements > queue->max_elements) {
rc = -E2BIG; rc = -E2BIG;
goto out; goto out;
} }
......
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