device: Add checks for NULL in device_const.c functions

This change checks to ensure that device/path passed into any of the
functions in device_const.c is not NULL. Since NULL is not expected to
be passed into these functions, this change adds a die() call in case
the assumption is broken.

Change-Id: I1ad8d2bcb9d0546104c5e065af1eeff331cdf96d
Signed-off-by: Furquan Shaikh <furquan@google.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/40475
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Reviewed-by: Angel Pons <th3fanbus@gmail.com>
This commit is contained in:
Furquan Shaikh 2020-04-16 23:13:28 -07:00
parent 4cd150f5b5
commit 86803784d3
1 changed files with 15 additions and 0 deletions

View File

@ -1,6 +1,7 @@
/* SPDX-License-Identifier: GPL-2.0-only */
/* This file is part of the coreboot project. */
#include <assert.h>
#include <console/console.h>
#include <device/device.h>
#include <device/path.h>
@ -86,6 +87,13 @@ static int path_eq(const struct device_path *path1,
{
int equal = 0;
if (!path1 || !path2) {
assert(path1);
assert(path2);
/* Return 0 in case assert is considered non-fatal. */
return 0;
}
if (path1->type != path2->type)
return 0;
@ -156,6 +164,13 @@ DEVTREE_CONST struct device *find_dev_path(
const struct bus *parent, const struct device_path *path)
{
DEVTREE_CONST struct device *child;
if (!parent) {
assert(0);
/* Return NULL in case asserts are considered non-fatal. */
return NULL;
}
for (child = parent->children; child; child = child->sibling) {
if (path_eq(path, &child->path))
break;