[PATCH] eal/linux: enhance ASLR verification
Yang Ming
ming.1.yang at nokia-sbell.com
Fri Feb 28 10:44:04 CET 2025
This change ensures that the current process is checked for
being run with 'setarch' before verifying the value of
'/proc/sys/kernel/randomize_va_space'. The '-R' or
'--addr-no-randomize' parameter of the 'setarch' command is used
to disable the randomization of the virtual address space.
Fixes: af75078fece3 ("first public release")
Cc: stable at dpdk.org
Signed-off-by: Yang Ming <ming.1.yang at nokia-sbell.com>
---
lib/eal/linux/eal_memory.c | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/lib/eal/linux/eal_memory.c b/lib/eal/linux/eal_memory.c
index 9dda60c0e1..ab1fd83cf2 100644
--- a/lib/eal/linux/eal_memory.c
+++ b/lib/eal/linux/eal_memory.c
@@ -15,6 +15,7 @@
#include <sys/stat.h>
#include <sys/file.h>
#include <sys/resource.h>
+#include <sys/personality.h>
#include <unistd.h>
#include <limits.h>
#include <signal.h>
@@ -26,7 +27,6 @@
#include <numa.h>
#include <numaif.h>
#endif
-
#include <rte_errno.h>
#include <rte_log.h>
#include <rte_memory.h>
@@ -200,6 +200,14 @@ static int
aslr_enabled(void)
{
char c;
+
+ /*
+ * check whether the current process is executed with command line
+ * "setarch ... --addr-no-randomize ...".
+ */
+ if ((personality(0xffffffff) & ADDR_NO_RANDOMIZE) == ADDR_NO_RANDOMIZE)
+ return 0;
+
int retval, fd = open(RANDOMIZE_VA_SPACE_FILE, O_RDONLY);
if (fd < 0)
return -errno;
--
2.34.1
More information about the stable
mailing list