test: memory leak: free group id list
authorDenys Vlasenko <vda.linux@googlemail.com>
Sat, 1 Oct 2016 23:49:13 +0000 (01:49 +0200)
committerDenys Vlasenko <vda.linux@googlemail.com>
Sat, 1 Oct 2016 23:49:13 +0000 (01:49 +0200)
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
coreutils/test.c
shell/ash.c

index 7b8b10cd9736eb58ee676c5647835df805c18e82..afdb1413f50c77df4a9d160e7a12227444212281 100644 (file)
@@ -394,6 +394,7 @@ extern struct test_statics *const test_ptr_to_statics;
        barrier(); \
 } while (0)
 #define DEINIT_S() do { \
+       free(S.group_array); \
        free(test_ptr_to_statics); \
 } while (0)
 
index b8160433eb88c35046615c01cafcdbe36f3e8e94..731c4b2b0a3d0712ab0c2db94b5e891cabce66cd 100644 (file)
@@ -412,8 +412,6 @@ static void trace_vprintf(const char *fmt, va_list va);
 
 
 /* ============ Utility functions */
-#define xbarrier() do { __asm__ __volatile__ ("": : :"memory"); } while (0)
-
 #define is_name(c)      ((c) == '_' || isalpha((unsigned char)(c)))
 #define is_in_name(c)   ((c) == '_' || isalnum((unsigned char)(c)))
 
@@ -446,7 +444,7 @@ static void exitshell(void) NORETURN;
  */
 #define INT_OFF do { \
        suppress_int++; \
-       xbarrier(); \
+       barrier(); \
 } while (0)
 
 /*
@@ -516,7 +514,7 @@ raise_interrupt(void)
 static IF_ASH_OPTIMIZE_FOR_SIZE(inline) void
 int_on(void)
 {
-       xbarrier();
+       barrier();
        if (--suppress_int == 0 && pending_int) {
                raise_interrupt();
        }
@@ -525,7 +523,7 @@ int_on(void)
 static IF_ASH_OPTIMIZE_FOR_SIZE(inline) void
 force_int_on(void)
 {
-       xbarrier();
+       barrier();
        suppress_int = 0;
        if (pending_int)
                raise_interrupt();
@@ -535,7 +533,7 @@ force_int_on(void)
 #define SAVE_INT(v) ((v) = suppress_int)
 
 #define RESTORE_INT(v) do { \
-       xbarrier(); \
+       barrier(); \
        suppress_int = (v); \
        if (suppress_int == 0 && pending_int) \
                raise_interrupt(); \
@@ -8432,7 +8430,7 @@ dotrap(void)
 
        last_status = exitstatus;
        pending_sig = 0;
-       xbarrier();
+       barrier();
 
        TRACE(("dotrap entered\n"));
        for (sig = 1, g = gotsig; sig < NSIG; sig++, g++) {