From: Jorge Pereira Date: Thu, 23 Mar 2023 00:10:20 +0000 (-0300) Subject: Fix runtime LSAN/ASAN error in command.c X-Git-Tag: release_3_2_3~124 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=99cd075978b74aad3f43e680ae6884574f7cc5ce;p=thirdparty%2Ffreeradius-server.git Fix runtime LSAN/ASAN error in command.c Such error: src/main/command.c:185:12: runtime error: member access within null pointer of type 'struct sockaddr_un' SUMMARY: UndefinedBehaviorSanitizer: undefined-behavior src/main/command.c:185:12 in --- diff --git a/src/include/socket.h b/src/include/socket.h new file mode 100644 index 0000000000..821c2a0b7a --- /dev/null +++ b/src/include/socket.h @@ -0,0 +1,53 @@ +#pragma once + +/* + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA + */ + +/** Functions for establishing and managing low level sockets + * + * @file src/include/socket.h + * + * @author Arran Cudbard-Bell (a.cudbardb@freeradius.org) + * @author Alan DeKok (aland@freeradius.org) + * + * @copyright 2015 The FreeRADIUS project + */ +RCSIDH(socket_h, "$Id$") + +#ifdef __cplusplus +extern "C" { +#endif + +#include +#include + +#ifdef HAVE_SYS_UN_H +# include +/* + * The linux headers define the macro as: + * + * # define SUN_LEN(ptr) ((size_t) (((struct sockaddr_un *) 0)->sun_path) \ + * + strlen ((ptr)->sun_path)) + * + * Which trips UBSAN, because it sees an operation on a NULL pointer. + */ +# undef SUN_LEN +# define SUN_LEN(su) (sizeof(*(su)) - sizeof((su)->sun_path) + strlen((su)->sun_path)) +#endif + +#ifdef __cplusplus +} +#endif diff --git a/src/lib/socket.c b/src/lib/socket.c index 3c88b78f9f..970f4f495e 100644 --- a/src/lib/socket.c +++ b/src/lib/socket.c @@ -24,14 +24,10 @@ * * @copyright 2015 The FreeRADIUS project */ - #include +#include +#include #ifdef HAVE_SYS_UN_H -# include -# ifndef SUN_LEN -# define SUN_LEN(su) (sizeof(*(su)) - sizeof((su)->sun_path) + strlen((su)->sun_path)) -# endif - /** Open a Unix socket * * @note If the file doesn't exist then errno will be set to ENOENT. diff --git a/src/main/command.c b/src/main/command.c index 12d1afdfdb..988f43bb02 100644 --- a/src/main/command.c +++ b/src/main/command.c @@ -28,19 +28,13 @@ #include #include #include +#include #include #ifdef HAVE_INTTYPES_H #include #endif -#ifdef HAVE_SYS_UN_H -#include -#ifndef SUN_LEN -#define SUN_LEN(su) (sizeof(*(su)) - sizeof((su)->sun_path) + strlen((su)->sun_path)) -#endif -#endif - #ifdef HAVE_SYS_STAT_H #include #endif