From 2b4a4070c99439898e22c9c9da2c21877d18a367 Mon Sep 17 00:00:00 2001 From: William Wilgus Date: Tue, 20 Dec 2022 18:10:44 -0500 Subject: [PATCH] buflib.c strip path from alloc name Change-Id: I6a0f1cc9037fcbe0245d94b4c77ba4ec08378434 --- firmware/buflib.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/firmware/buflib.c b/firmware/buflib.c index 2ce9cc344c..d9f82f8854 100644 --- a/firmware/buflib.c +++ b/firmware/buflib.c @@ -35,6 +35,7 @@ #include "panic.h" #include "crc32.h" #include "system.h" /* for ALIGN_*() */ +#include "pathfuncs.h" /* path_basename() */ /* The main goal of this design is fast fetching of the pointer for a handle. * For that reason, the handles are stored in a table at the end of the buffer @@ -658,6 +659,9 @@ int buflib_alloc_ex(struct buflib_context *ctx, size_t size, const char *name, struct buflib_callbacks *ops) { + if (name) /* if name is a path strip everything but the filename */ + path_basename(name, &name); + union buflib_data *handle, *block; size_t name_len = name ? B_ALIGN_UP(strlen(name)+1) : 0; bool last;