Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/tests/libexec/ld.elf_so Avoid casting fun by switching ifunc...



details:   https://anonhg.NetBSD.org/src/rev/af4c4aab1c47
branches:  trunk
changeset: 360409:af4c4aab1c47
user:      joerg <joerg%NetBSD.org@localhost>
date:      Fri Mar 09 20:15:03 2018 +0000

description:
Avoid casting fun by switching ifunc helper functions to return
long long. Dead beef is too useful to switch to a different constant.

diffstat:

 tests/libexec/ld.elf_so/h_ifunc.c                         |   6 +-
 tests/libexec/ld.elf_so/helper_ifunc_dso/h_helper_ifunc.c |  22 ++++----
 tests/libexec/ld.elf_so/t_ifunc.c                         |  34 +++++++-------
 3 files changed, 31 insertions(+), 31 deletions(-)

diffs (180 lines):

diff -r 3a0d5db98373 -r af4c4aab1c47 tests/libexec/ld.elf_so/h_ifunc.c
--- a/tests/libexec/ld.elf_so/h_ifunc.c Fri Mar 09 18:56:02 2018 +0000
+++ b/tests/libexec/ld.elf_so/h_ifunc.c Fri Mar 09 20:15:03 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: h_ifunc.c,v 1.1 2014/08/25 20:40:53 joerg Exp $        */
+/*     $NetBSD: h_ifunc.c,v 1.2 2018/03/09 20:15:03 joerg Exp $        */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
 
 #include <stdlib.h>
 
-extern int ifunc(void);
+extern long long ifunc(void);
 
 int
 main(int argc, char **argv)
@@ -39,5 +39,5 @@
 
        if (argc != 2)
                return 1;
-       return ifunc() != atoi(argv[1]);
+       return ifunc() != atoll(argv[1]);
 }
diff -r 3a0d5db98373 -r af4c4aab1c47 tests/libexec/ld.elf_so/helper_ifunc_dso/h_helper_ifunc.c
--- a/tests/libexec/ld.elf_so/helper_ifunc_dso/h_helper_ifunc.c Fri Mar 09 18:56:02 2018 +0000
+++ b/tests/libexec/ld.elf_so/helper_ifunc_dso/h_helper_ifunc.c Fri Mar 09 20:15:03 2018 +0000
@@ -30,27 +30,27 @@
 #include <stdlib.h>
 #include <string.h>
 
-static int
+static long long
 ifunc1(void)
 {
-       return 0xdeadbeef;
+       return 0xdeadbeefll;
 }
 
-static int
+static long long
 ifunc2(void)
 {
-       return 0xbeefdead;
+       return 0xbeefdeadll;
 }
 
 static __attribute__((used))
-int (*resolve_ifunc(void))(void)
+long long (*resolve_ifunc(void))(void)
 {
        const char *e = getenv("USE_IFUNC2");
        return e && strcmp(e, "1") == 0 ? ifunc2 : ifunc1;
 }
 
 static __attribute__((used))
-int (*resolve_ifunc2(void))(void)
+long long (*resolve_ifunc2(void))(void)
 {
        const char *e = getenv("USE_IFUNC2");
        return e && strcmp(e, "1") == 0 ? ifunc1 : ifunc2;
@@ -59,17 +59,17 @@
 __ifunc(ifunc, resolve_ifunc);
 __hidden_ifunc(ifunc_hidden, resolve_ifunc2);
 
-int ifunc_hidden(void);
-int ifunc_plt(void);
+long long ifunc_hidden(void);
+long long ifunc_plt(void);
 
-int ifunc_plt(void)
+long long ifunc_plt(void)
 {
        return ifunc_hidden();
 }
 
-int (*ifunc_indirect(void))(void);
+long long (*ifunc_indirect(void))(void);
 
-int (*ifunc_indirect(void))(void)
+long long (*ifunc_indirect(void))(void)
 {
        return ifunc_hidden;
 }
diff -r 3a0d5db98373 -r af4c4aab1c47 tests/libexec/ld.elf_so/t_ifunc.c
--- a/tests/libexec/ld.elf_so/t_ifunc.c Fri Mar 09 18:56:02 2018 +0000
+++ b/tests/libexec/ld.elf_so/t_ifunc.c Fri Mar 09 20:15:03 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: t_ifunc.c,v 1.7 2018/01/01 06:34:13 maya Exp $ */
+/*     $NetBSD: t_ifunc.c,v 1.8 2018/03/09 20:15:03 joerg Exp $        */
 
 /*
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -53,12 +53,12 @@
        const char *envstr[] = {
            "0", "1"
        };
-       int expected_result[] = {
-           0xdeadbeef, 0xbeefdead
+       long long expected_result[] = {
+           0xdeadbeefll, 0xbeefdeadll
        };
        void *handle;
-       int (*sym)(void);
-       int result;
+       long long (*sym)(void);
+       long long result;
        const char *error;
        size_t i;
 
@@ -86,7 +86,7 @@
                ATF_CHECK(error == NULL);
 
                char *command;
-               easprintf(&command, "%s/h_ifunc %d",
+               easprintf(&command, "%s/h_ifunc %lld",
                    atf_tc_get_config_var(tc, "srcdir"), expected_result[i]);
                if (system(command) != EXIT_SUCCESS)
                        atf_tc_fail("Test failed; see output for details");
@@ -106,13 +106,13 @@
        const char *envstr[] = {
            "0", "1"
        };
-       int expected_result[] = {
-           0xdeadbeef, 0xbeefdead
+       long long expected_result[] = {
+           0xdeadbeefll, 0xbeefdeadll
        };
        void *handle;
-       int (*sym)(void);
-       int (*(*sym2)(void))(void);
-       int result;
+       long long (*sym)(void);
+       long long (*(*sym2)(void))(void);
+       long long result;
        const char *error;
        size_t i;
 
@@ -149,7 +149,7 @@
                ATF_CHECK(error == NULL);
 
                char *command;
-               easprintf(&command, "%s/h_ifunc %d",
+               easprintf(&command, "%s/h_ifunc %lld",
                    atf_tc_get_config_var(tc, "srcdir"), expected_result[i]);
                if (system(command) != EXIT_SUCCESS)
                        atf_tc_fail("Test failed; see output for details");
@@ -165,26 +165,26 @@
 }
 
 #if LINKER_SUPPORT
-static unsigned int
+static long long
 ifunc_helper(void)
 {
-       return 0xdeadbeef;
+       return 0xdeadbeefll;
 }
 
 static __attribute__((used))
-unsigned int (*resolve_ifunc(void))(void)
+long long (*resolve_ifunc(void))(void)
 {
        return ifunc_helper;
 }
 __hidden_ifunc(ifunc, resolve_ifunc);
 #endif
-unsigned int ifunc(void);
+long long ifunc(void);
 
 ATF_TC_BODY(rtld_main_ifunc, tc)
 {
        if (!LINKER_SUPPORT)
                atf_tc_skip("Missing linker support for ifunc relocations");
-       ATF_CHECK(ifunc() == 0xdeadbeef);
+       ATF_CHECK(ifunc() == 0xdeadbeefll);
 }
 
 ATF_TP_ADD_TCS(tp)



Home | Main Index | Thread Index | Old Index