* grub-core/net/drivers/emu/emunet.c (get_card_packet): Allocate the
reserved bytes. * grub-core/net/drivers/i386/pc/pxe.c (grub_pxe_recv): Likewise. * grub-core/net/drivers/ieee1275/ofnet.c (get_card_packet): Likewise. Handle malloc error correctly.
This commit is contained in:
parent
cde393c9a3
commit
531e2241a6
4 changed files with 15 additions and 6 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
2012-06-21 Vladimir Serbinenko <phcoder@gmail.com>
|
||||||
|
|
||||||
|
* grub-core/net/drivers/emu/emunet.c (get_card_packet): Allocate the
|
||||||
|
reserved bytes.
|
||||||
|
* grub-core/net/drivers/i386/pc/pxe.c (grub_pxe_recv): Likewise.
|
||||||
|
* grub-core/net/drivers/ieee1275/ofnet.c (get_card_packet): Likewise.
|
||||||
|
Handle malloc error correctly.
|
||||||
|
|
||||||
2012-06-21 Vladimir Serbinenko <phcoder@gmail.com>
|
2012-06-21 Vladimir Serbinenko <phcoder@gmail.com>
|
||||||
|
|
||||||
* grub-core/script/execute.c (grub_script_arglist_to_argv): Escape
|
* grub-core/script/execute.c (grub_script_arglist_to_argv): Escape
|
||||||
|
|
|
@ -52,7 +52,7 @@ get_card_packet (struct grub_net_card *dev __attribute__ ((unused)))
|
||||||
ssize_t actual;
|
ssize_t actual;
|
||||||
struct grub_net_buff *nb;
|
struct grub_net_buff *nb;
|
||||||
|
|
||||||
nb = grub_netbuff_alloc (1536);
|
nb = grub_netbuff_alloc (1536 + 2);
|
||||||
if (!nb)
|
if (!nb)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
|
|
@ -213,7 +213,7 @@ grub_pxe_recv (struct grub_net_card *dev __attribute__ ((unused)))
|
||||||
grub_pxe_call (GRUB_PXENV_UNDI_ISR, isr, pxe_rm_entry);
|
grub_pxe_call (GRUB_PXENV_UNDI_ISR, isr, pxe_rm_entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
buf = grub_netbuff_alloc (isr->frame_len);
|
buf = grub_netbuff_alloc (isr->frame_len + 2);
|
||||||
if (!buf)
|
if (!buf)
|
||||||
return NULL;
|
return NULL;
|
||||||
/* Reserve 2 bytes so that 2 + 14/18 bytes of ethernet header is divisible
|
/* Reserve 2 bytes so that 2 + 14/18 bytes of ethernet header is divisible
|
||||||
|
|
|
@ -95,15 +95,16 @@ get_card_packet (struct grub_net_card *dev)
|
||||||
grub_uint64_t start_time;
|
grub_uint64_t start_time;
|
||||||
struct grub_net_buff *nb;
|
struct grub_net_buff *nb;
|
||||||
|
|
||||||
nb = grub_netbuff_alloc (dev->mtu + 64);
|
nb = grub_netbuff_alloc (dev->mtu + 64 + 2);
|
||||||
/* Reserve 2 bytes so that 2 + 14/18 bytes of ethernet header is divisible
|
|
||||||
by 4. So that IP header is aligned on 4 bytes. */
|
|
||||||
grub_netbuff_reserve (nb, 2);
|
|
||||||
if (!nb)
|
if (!nb)
|
||||||
{
|
{
|
||||||
grub_netbuff_free (nb);
|
grub_netbuff_free (nb);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
/* Reserve 2 bytes so that 2 + 14/18 bytes of ethernet header is divisible
|
||||||
|
by 4. So that IP header is aligned on 4 bytes. */
|
||||||
|
grub_netbuff_reserve (nb, 2);
|
||||||
|
|
||||||
start_time = grub_get_time_ms ();
|
start_time = grub_get_time_ms ();
|
||||||
do
|
do
|
||||||
rc = grub_ieee1275_read (data->handle, nb->data, dev->mtu + 64, &actual);
|
rc = grub_ieee1275_read (data->handle, nb->data, dev->mtu + 64, &actual);
|
||||||
|
|
Loading…
Reference in a new issue