summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar Stefan Richter 2010-06-05 14:55:53 +0200
committerGravatar Stefan Richter 2010-09-07 11:18:05 +0200
commit9d47becf251d8601e834e777d6f7f10eb62ec8dc (patch)
treeb4456c1c530787eda26ed71d784efdc4aca9f8c3 /src
parentFix for overlooked device HUP with 'firewire' stack (diff)
Add missing malloc failure checks
Also add errno = ENOMEM because it is said that that some malloc implementations might miss to do so. Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'src')
-rw-r--r--src/fw-iso.c4
-rw-r--r--src/fw.c20
2 files changed, 19 insertions, 5 deletions
diff --git a/src/fw-iso.c b/src/fw-iso.c
index 88909dc..5aac9fe 100644
--- a/src/fw-iso.c
+++ b/src/fw-iso.c
@@ -463,8 +463,10 @@ iso_init(fw_handle_t handle, int type,
handle->iso.packet_count = 0;
handle->iso.packets =
malloc(handle->iso.irq_interval * sizeof handle->iso.packets[0]);
- if (handle->iso.packets == NULL)
+ if (handle->iso.packets == NULL) {
+ errno = ENOMEM;
return -1;
+ }
handle->iso.fd = open(handle->iso.filename, O_RDWR);
if (handle->iso.fd < 0) {
diff --git a/src/fw.c b/src/fw.c
index d525ac9..f92c1b6 100644
--- a/src/fw.c
+++ b/src/fw.c
@@ -419,9 +419,13 @@ fw_handle_t fw_new_handle(void)
struct epoll_event ep;
int i;
- memset(&ep, 0, sizeof(ep));
-
handle = malloc(sizeof *handle);
+ if (handle == NULL) {
+ errno = ENOMEM;
+ return NULL;
+ }
+
+ memset(&ep, 0, sizeof(ep));
memset(handle, 0, sizeof(*handle));
handle->tag_handler = default_tag_handler;
@@ -775,6 +779,10 @@ handle_arm_request(raw1394handle_t handle, struct address_closure *ac,
return 0;
rrb = malloc(sizeof *rrb + in_length + response.length);
+ if (rrb == NULL) {
+ errno == ENOMEM;
+ return -1;
+ }
rrb->request_response.request = &rrb->request;
rrb->request_response.response = &rrb->response;
@@ -818,8 +826,10 @@ fw_arm_register(fw_handle_t handle, nodeaddr_t start,
int retval;
allocation = malloc(sizeof *allocation + length);
- if (allocation == NULL)
+ if (allocation == NULL) {
+ errno = ENOMEM;
return -1;
+ }
allocation->closure.callback = handle_arm_request;
allocation->buffer = initial_value;
@@ -1318,8 +1328,10 @@ fw_start_fcp_listen(fw_handle_t handle)
struct address_closure *closure;
closure = malloc(sizeof *closure);
- if (closure == NULL)
+ if (closure == NULL) {
+ errno = ENOMEM;
return -1;
+ }
closure->callback = handle_fcp_request;
t-3&id=d661b7d4e7f67337192dae80fadc3a2700b0e16f&follow=1'>DTO to DTDGravatar John Cowan 1-55/+52 2021-07-26typoGravatar John Cowan 1-1/+1 2021-07-26switching to explicit dtosGravatar John Cowan 1-88/+102 2021-07-26errorsGravatar John Cowan 1-1/+4 2021-07-26more MN-W reviewGravatar John Cowan 1-5/+5 2021-07-26update preview linkGravatar John Cowan 1-1/+1 2021-07-26MN-W reviewGravatar John Cowan 1-6/+6 2021-07-26paired mutatorsGravatar John Cowan 1-43/+68 2021-07-25exceptionsGravatar John Cowan 1-1/+15 2021-07-25new exampleGravatar John Cowan 1-1/+4 2021-07-25updatesGravatar John Cowan 1-2/+4 2021-07-24dtd always first argumentGravatar John Cowan 1-9/+9 2021-07-23DTO to DTDGravatar John Cowan 1-55/+52 2021-07-22typoGravatar John Cowan 1-1/+1 2021-07-22switching to explicit dtosGravatar John Cowan 1-88/+102 2021-07-22errorsGravatar John Cowan 1-1/+4 2021-07-22more MN-W reviewGravatar John Cowan 1-5/+5 2021-07-20update preview linkGravatar John Cowan 1-1/+1 2021-07-20MN-W reviewGravatar John Cowan 1-6/+6 2021-07-18Fix typo.Gravatar Arthur A. Gleckler 2-4/+4 2021-07-18Add <p> around abstract.Gravatar Arthur A. Gleckler 1-2/+2 2021-07-18Publish first draft.draft-1Gravatar Arthur A. Gleckler 3-0/+114 2021-07-18Ignore trailing whitespace.Gravatar Arthur A. Gleckler 11-129/+129 2021-07-18Ignore "Dictionaries.log".Gravatar Arthur A. Gleckler 1-1/+2 2021-07-18Fix errors reported by W3C HTML Validator.Gravatar Arthur A. Gleckler 1-27/+27 2021-07-18Eliminate unnecessary redirect by using TLS/SSL.Gravatar Arthur A. Gleckler 1-1/+1