Skip to content

Commit

Permalink
Merge pull request #16155 from httpstorm/gcc-14-compatibility
Browse files Browse the repository at this point in the history
zebra: fix compilation with GCC14
  • Loading branch information
donaldsharp authored Jun 5, 2024
2 parents 17e1f7c + f7242fb commit c5bb472
Showing 1 changed file with 9 additions and 6 deletions.
15 changes: 9 additions & 6 deletions zebra/zebra_netns_notify.c
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
#include <sched.h>
#endif
#include <dirent.h>
#include <libgen.h>
#include <sys/inotify.h>
#include <sys/stat.h>

Expand Down Expand Up @@ -234,6 +235,7 @@ static void zebra_ns_ready_read(struct event *t)
{
struct zebra_netns_info *zns_info = EVENT_ARG(t);
const char *netnspath;
const char *netnspath_basename;
int err, stop_retry = 0;

if (!zns_info)
Expand Down Expand Up @@ -261,23 +263,24 @@ static void zebra_ns_ready_read(struct event *t)
zebra_ns_continue_read(zns_info, stop_retry);
return;
}
netnspath_basename = basename(strdupa(netnspath));

/* check default name is not already set */
if (strmatch(VRF_DEFAULT_NAME, basename(netnspath))) {
zlog_warn("NS notify : NS %s is already default VRF.Cancel VRF Creation", basename(netnspath));
if (strmatch(VRF_DEFAULT_NAME, netnspath_basename)) {
zlog_warn("NS notify : NS %s is already default VRF.Cancel VRF Creation", netnspath_basename);
zebra_ns_continue_read(zns_info, 1);
return;
}
if (zebra_ns_notify_is_default_netns(basename(netnspath))) {
if (zebra_ns_notify_is_default_netns(netnspath_basename)) {
zlog_warn(
"NS notify : NS %s is default VRF. Ignore VRF creation",
basename(netnspath));
netnspath_basename);
zebra_ns_continue_read(zns_info, 1);
return;
}

/* success : close fd and create zns context */
zebra_ns_notify_create_context_from_entry_name(basename(netnspath));
zebra_ns_notify_create_context_from_entry_name(netnspath_basename);
zebra_ns_continue_read(zns_info, 1);
}

Expand Down Expand Up @@ -396,7 +399,7 @@ void zebra_ns_notify_parse(void)
continue;
}
/* check default name is not already set */
if (strmatch(VRF_DEFAULT_NAME, basename(dent->d_name))) {
if (strmatch(VRF_DEFAULT_NAME, basename(strdupa(dent->d_name)))) {
zlog_warn("NS notify : NS %s is already default VRF.Cancel VRF Creation", dent->d_name);
continue;
}
Expand Down

0 comments on commit c5bb472

Please sign in to comment.