diff options
author | Donald Sharp <sharpd@cumulusnetworks.com> | 2017-10-09 14:16:04 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-09 14:16:04 +0200 |
commit | 613aa4ddb2989faf3dd6357d093e8d661fdac5a1 (patch) | |
tree | 56a79b16f7cf4e912b129769e620ab6a75474136 | |
parent | Merge pull request #1309 from vjardin6WIND/clean (diff) | |
parent | lib: fix wrong warning from clang (diff) | |
download | frr-613aa4ddb2989faf3dd6357d093e8d661fdac5a1.tar.xz frr-613aa4ddb2989faf3dd6357d093e8d661fdac5a1.zip |
Merge pull request #1310 from vjardin6WIND/null_references
lib: linklist avoid access NULL->data
-rw-r--r-- | lib/csv.c | 2 | ||||
-rw-r--r-- | lib/ferr.c | 1 | ||||
-rw-r--r-- | lib/linklist.h | 3 | ||||
-rw-r--r-- | lib/nexthop.c | 2 |
4 files changed, 6 insertions, 2 deletions
@@ -284,6 +284,8 @@ csv_record_t *csv_encode_record(csv_t *csv, csv_record_t *rec, int count, ...) va_start(list, count); str = csv_field_iter(rec, &fld); + if (!fld) + return NULL; for (tempc = 0; tempc < count; tempc++) { col = va_arg(list, char *); for (i = 0; i < fld->field_len; i++) { diff --git a/lib/ferr.c b/lib/ferr.c index 2a039d208..69aeb3db4 100644 --- a/lib/ferr.c +++ b/lib/ferr.c @@ -74,6 +74,7 @@ static ferr_r ferr_set_va(const char *file, int line, const char *func, /* we're screwed */ zlog_err("out of memory while allocating error info"); raise(SIGSEGV); + abort(); /* raise() can return, but raise(SIGSEGV) shall not */ } pthread_setspecific(errkey, error); diff --git a/lib/linklist.h b/lib/linklist.h index 4a65fead8..8a43fbe64 100644 --- a/lib/linklist.h +++ b/lib/linklist.h @@ -56,7 +56,8 @@ struct list { #define listtail(X) ((X) ? ((X)->tail) : NULL) #define listcount(X) ((X)->count) #define list_isempty(X) ((X)->head == NULL && (X)->tail == NULL) -#define listgetdata(X) (assert((X)->data != NULL), (X)->data) +/* return X->data only if X and X->data are not NULL */ +#define listgetdata(X) (assert(X), assert((X)->data != NULL), (X)->data) /* Prototypes. */ extern struct list * diff --git a/lib/nexthop.c b/lib/nexthop.c index ea6a310a4..f6b2c9788 100644 --- a/lib/nexthop.c +++ b/lib/nexthop.c @@ -128,7 +128,7 @@ int nexthop_labels_match(struct nexthop *nh1, struct nexthop *nh2) nhl1 = nh1->nh_label; nhl2 = nh2->nh_label; - if ((nhl1 && !nhl2) || (!nhl1 && nhl2)) + if (!nhl1 || !nhl2) return 0; if (nhl1->num_labels != nhl2->num_labels) |