diff options
author | Dan Williams <dan.j.williams@intel.com> | 2024-01-05 19:03:06 -0800 |
---|---|---|
committer | Dan Williams <dan.j.williams@intel.com> | 2024-01-05 19:03:06 -0800 |
commit | 80dda9a69a487c72ded1ac69234c8a89d5922b04 (patch) | |
tree | 24130c9b4980f6a171cbed0d154beaf527a9bfa7 /lib/vsprintf.c | |
parent | d3953c78fc78d37f1b795740632ec7c3d83ef98a (diff) | |
parent | c7ad3dc3649730af483ee1e78be5d0362da25bfe (diff) |
Merge branch 'for-6.8/cxl-misc' into for-6.8/cxl
Pick up some miscellaneous fixups for v6.8.
Diffstat (limited to 'lib/vsprintf.c')
-rw-r--r-- | lib/vsprintf.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/lib/vsprintf.c b/lib/vsprintf.c index 3e3733a7084f..552738f14275 100644 --- a/lib/vsprintf.c +++ b/lib/vsprintf.c @@ -2111,15 +2111,20 @@ char *fwnode_full_name_string(struct fwnode_handle *fwnode, char *buf, /* Loop starting from the root node to the current node. */ for (depth = fwnode_count_parents(fwnode); depth >= 0; depth--) { - struct fwnode_handle *__fwnode = - fwnode_get_nth_parent(fwnode, depth); + /* + * Only get a reference for other nodes (i.e. parent nodes). + * fwnode refcount may be 0 here. + */ + struct fwnode_handle *__fwnode = depth ? + fwnode_get_nth_parent(fwnode, depth) : fwnode; buf = string(buf, end, fwnode_get_name_prefix(__fwnode), default_str_spec); buf = string(buf, end, fwnode_get_name(__fwnode), default_str_spec); - fwnode_handle_put(__fwnode); + if (depth) + fwnode_handle_put(__fwnode); } return buf; |