gpioinfo: Clean up scandir allocations
authorJoel Stanley <joel@jms.id.au>
Wed, 2 Feb 2022 12:01:23 +0000 (22:31 +1030)
committerBartosz Golaszewski <brgl@bgdev.pl>
Fri, 18 Feb 2022 18:37:13 +0000 (19:37 +0100)
==3017== 176 (80 direct, 96 indirect) bytes in 1 blocks are definitely lost in loss record 2 of 2
==3017==    at 0x483F6C7: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so)
==3017==    by 0x491CE92: ??? (in /lib/libc.so.6)
==3017==    by 0x10AAAC: main (gpioinfo.c:215)

The entires must be freed, and then the array itself.

Signed-off-by: Joel Stanley <joel@jms.id.au>
Signed-off-by: Bartosz Golaszewski <brgl@bgdev.pl>
tools/gpioinfo.c

index 3d8911176281e19de773ca09ac70d6dabc447544..d50af45dbf35ae7d3542757d3c48dd5fe3c672aa 100644 (file)
@@ -231,7 +231,9 @@ int main(int argc, char **argv)
                        list_lines(chip);
 
                        gpiod_chip_unref(chip);
+                       free(entries[i]);
                }
+               free(entries);
        } else {
                for (i = 0; i < argc; i++) {
                        chip = chip_open_lookup(argv[i]);