提交 47882fa4 编写于 作者: L Li Qiang 提交者: Jason Wang

net: vmxnet: use g_new for pkt initialisation

When network transport abstraction layer initialises pkt, the maximum
fragmentation count is not checked. This could lead to an integer
overflow causing a NULL pointer dereference. Replace g_malloc() with
g_new() to catch the multiplication overflow.
Reported-by: NLi Qiang <liqiang6-s@360.cn>
Signed-off-by: NPrasad J Pandit <pjp@fedoraproject.org>
Acked-by: NDmitry Fleytman <dmitry@daynix.com>
Signed-off-by: NJason Wang <jasowang@redhat.com>
上级 5f0e7753
...@@ -65,10 +65,9 @@ void net_tx_pkt_init(struct NetTxPkt **pkt, PCIDevice *pci_dev, ...@@ -65,10 +65,9 @@ void net_tx_pkt_init(struct NetTxPkt **pkt, PCIDevice *pci_dev,
p->pci_dev = pci_dev; p->pci_dev = pci_dev;
p->vec = g_malloc((sizeof *p->vec) * p->vec = g_new(struct iovec, max_frags + NET_TX_PKT_PL_START_FRAG);
(max_frags + NET_TX_PKT_PL_START_FRAG));
p->raw = g_malloc((sizeof *p->raw) * max_frags); p->raw = g_new(struct iovec, max_frags);
p->max_payload_frags = max_frags; p->max_payload_frags = max_frags;
p->max_raw_frags = max_frags; p->max_raw_frags = max_frags;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册