ACK: [PATCH] lib: fwts_klog: handle the case where klog_old is empty list
ivanhu
ivan.hu at canonical.com
Thu Feb 18 06:57:30 UTC 2016
On 2016年02月17日 08:01, Colin King wrote:
> From: Colin Ian King <colin.king at canonical.com>
>
> scan-build detected that an empty klog_old list would lead to l_old_last
> being null and hence we get a null pointer dereference when assigning
> old to the data in the null list. Check for a empty list and ensure
> l_new is initialized to NULL for this corner case.
>
> Signed-off-by: Colin Ian King <colin.king at canonical.com>
> ---
> src/lib/src/fwts_klog.c | 21 ++++++++++++---------
> 1 file changed, 12 insertions(+), 9 deletions(-)
>
> diff --git a/src/lib/src/fwts_klog.c b/src/lib/src/fwts_klog.c
> index 48a0e45..b5f0965 100644
> --- a/src/lib/src/fwts_klog.c
> +++ b/src/lib/src/fwts_klog.c
> @@ -51,7 +51,7 @@ void fwts_klog_free(fwts_list *klog)
> */
> fwts_list *fwts_klog_find_changes(fwts_list *klog_old, fwts_list *klog_new)
> {
> - fwts_list_link *l_old, *l_new;
> + fwts_list_link *l_old, *l_new = NULL;
> fwts_list *klog_diff;
>
> if (klog_new == NULL) {
> @@ -74,14 +74,17 @@ fwts_list *fwts_klog_find_changes(fwts_list *klog_old, fwts_list *klog_new)
> fwts_list_foreach(l_old, klog_old)
> l_old_last = l_old;
>
> - /* And now look for that last line in the new log */
> - old = fwts_list_data(char *, l_old_last);
> - fwts_list_foreach(l_new, klog_new) {
> - char *new = fwts_list_data(char *, l_new);
> - if (!strcmp(new, old)) {
> - /* Found last line that matches, bump to next */
> - l_new = l_new->next;
> - break;
> + if (l_old_last) {
> + /* And now look for that last line in the new log */
> + old = fwts_list_data(char *, l_old_last);
> + fwts_list_foreach(l_new, klog_new) {
> + const char *new = fwts_list_data(char *, l_new);
> +
> + if (!strcmp(new, old)) {
> + /* Found last line that matches, bump to next */
> + l_new = l_new->next;
> + break;
> + }
> }
> }
> }
>
Acked-by: Ivan Hu <ivan.hu at canonical.com>
More information about the fwts-devel
mailing list