tools/firewire: nosy-dump: check for allocation failure

Behavior of null pointer dereference is undefined in the C language.
Portably implement the desired behavior.

Reported-by: Yang Yeping <yangyeping_666@hotmail.com>
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
This commit is contained in:
Stefan Richter 2012-10-22 15:17:17 +02:00
parent 9489e9dcae
commit 6fa79bcaec
1 changed files with 4 additions and 0 deletions

View File

@ -150,6 +150,8 @@ subaction_create(uint32_t *data, size_t length)
/* we put the ack in the subaction struct for easy access. */ /* we put the ack in the subaction struct for easy access. */
sa = malloc(sizeof *sa - sizeof sa->packet + length); sa = malloc(sizeof *sa - sizeof sa->packet + length);
if (!sa)
exit(EXIT_FAILURE);
sa->ack = data[length / 4 - 1]; sa->ack = data[length / 4 - 1];
sa->length = length; sa->length = length;
memcpy(&sa->packet, data, length); memcpy(&sa->packet, data, length);
@ -180,6 +182,8 @@ link_transaction_lookup(int request_node, int response_node, int tlabel)
} }
t = malloc(sizeof *t); t = malloc(sizeof *t);
if (!t)
exit(EXIT_FAILURE);
t->request_node = request_node; t->request_node = request_node;
t->response_node = response_node; t->response_node = response_node;
t->tlabel = tlabel; t->tlabel = tlabel;