提交 ea4d8241 编写于 作者: Z Zhou Jie 提交者: Max Filippov

hw/net/opencores_eth: Allocating Large sized arrays to heap

open_eth_start_xmit has a huge stack usage of 65536 bytes approx.
Moving large arrays to heap to reduce stack usage.

Reduce size of a buffer allocated on stack to 0x600 bytes, which is the
maximal frame length when HUGEN bit is not set in MODER, only allocate
buffer on heap when that is too small. Thus heap is not used in typical
use case.
Signed-off-by: NZhou Jie <zhoujie2011@cn.fujitsu.com>
Signed-off-by: NMax Filippov <jcmvbkbc@gmail.com>
上级 aa8e0ab9
...@@ -482,7 +482,8 @@ static NetClientInfo net_open_eth_info = { ...@@ -482,7 +482,8 @@ static NetClientInfo net_open_eth_info = {
static void open_eth_start_xmit(OpenEthState *s, desc *tx) static void open_eth_start_xmit(OpenEthState *s, desc *tx)
{ {
uint8_t buf[65536]; uint8_t *buf = NULL;
uint8_t buffer[0x600];
unsigned len = GET_FIELD(tx->len_flags, TXD_LEN); unsigned len = GET_FIELD(tx->len_flags, TXD_LEN);
unsigned tx_len = len; unsigned tx_len = len;
...@@ -497,6 +498,11 @@ static void open_eth_start_xmit(OpenEthState *s, desc *tx) ...@@ -497,6 +498,11 @@ static void open_eth_start_xmit(OpenEthState *s, desc *tx)
trace_open_eth_start_xmit(tx->buf_ptr, len, tx_len); trace_open_eth_start_xmit(tx->buf_ptr, len, tx_len);
if (tx_len > sizeof(buffer)) {
buf = g_new(uint8_t, tx_len);
} else {
buf = buffer;
}
if (len > tx_len) { if (len > tx_len) {
len = tx_len; len = tx_len;
} }
...@@ -505,6 +511,9 @@ static void open_eth_start_xmit(OpenEthState *s, desc *tx) ...@@ -505,6 +511,9 @@ static void open_eth_start_xmit(OpenEthState *s, desc *tx)
memset(buf + len, 0, tx_len - len); memset(buf + len, 0, tx_len - len);
} }
qemu_send_packet(qemu_get_queue(s->nic), buf, tx_len); qemu_send_packet(qemu_get_queue(s->nic), buf, tx_len);
if (tx_len > sizeof(buffer)) {
g_free(buf);
}
if (tx->len_flags & TXD_WR) { if (tx->len_flags & TXD_WR) {
s->tx_desc = 0; s->tx_desc = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册