]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
selftests/mm: convert page_size to unsigned long
authorSiddarth G <siddarthsgml@gmail.com>
Thu, 3 Apr 2025 10:13:45 +0000 (15:43 +0530)
committerAndrew Morton <akpm@linux-foundation.org>
Mon, 12 May 2025 00:48:09 +0000 (17:48 -0700)
Cppcheck warning:
int result is assigned to long long variable. If the variable is long long
to avoid loss of information, then you have loss of information.

This patch changes the type of page_size from 'unsigned int' to
'unsigned long' instead of using ULL suffixes. Changing hpage_size to
'unsigned long' was considered, but since gethugepage() expects an int,
this change was avoided.

Link: https://lkml.kernel.org/r/20250403101345.29226-1-siddarthsgml@gmail.com
Signed-off-by: Siddarth G <siddarthsgml@gmail.com>
Reported-by: David Binderman <dcb314@hotmail.com>
Closes: https://lore.kernel.org/all/AS8PR02MB10217315060BBFDB21F19643E9CA62@AS8PR02MB10217.eurprd02.prod.outlook.com/
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
tools/testing/selftests/mm/pagemap_ioctl.c

index 57b4bba2b45f34b1deb62fa7c53b8ecafeb2364b..fe5ae8b25ff61e01e4e8def9eb544ba2336bca70 100644 (file)
@@ -34,7 +34,7 @@
 #define PAGEMAP "/proc/self/pagemap"
 int pagemap_fd;
 int uffd;
-unsigned int page_size;
+unsigned long page_size;
 unsigned int hpage_size;
 const char *progname;
 
@@ -184,7 +184,7 @@ void *gethugetlb_mem(int size, int *shmid)
 
 int userfaultfd_tests(void)
 {
-       int mem_size, vec_size, written, num_pages = 16;
+       long mem_size, vec_size, written, num_pages = 16;
        char *mem, *vec;
 
        mem_size = num_pages * page_size;
@@ -213,7 +213,7 @@ int userfaultfd_tests(void)
        written = pagemap_ioctl(mem, mem_size, vec, 1, PM_SCAN_WP_MATCHING | PM_SCAN_CHECK_WPASYNC,
                                vec_size - 2, PAGE_IS_WRITTEN, 0, 0, PAGE_IS_WRITTEN);
        if (written < 0)
-               ksft_exit_fail_msg("error %d %d %s\n", written, errno, strerror(errno));
+               ksft_exit_fail_msg("error %ld %d %s\n", written, errno, strerror(errno));
 
        ksft_test_result(written == 0, "%s all new pages must not be written (dirty)\n", __func__);
 
@@ -995,7 +995,7 @@ int unmapped_region_tests(void)
 {
        void *start = (void *)0x10000000;
        int written, len = 0x00040000;
-       int vec_size = len / page_size;
+       long vec_size = len / page_size;
        struct page_region *vec = malloc(sizeof(struct page_region) * vec_size);
 
        /* 1. Get written pages */
@@ -1051,7 +1051,7 @@ static void test_simple(void)
 int sanity_tests(void)
 {
        unsigned long long mem_size, vec_size;
-       int ret, fd, i, buf_size;
+       long ret, fd, i, buf_size;
        struct page_region *vec;
        char *mem, *fmem;
        struct stat sbuf;
@@ -1160,7 +1160,7 @@ int sanity_tests(void)
 
        ret = stat(progname, &sbuf);
        if (ret < 0)
-               ksft_exit_fail_msg("error %d %d %s\n", ret, errno, strerror(errno));
+               ksft_exit_fail_msg("error %ld %d %s\n", ret, errno, strerror(errno));
 
        fmem = mmap(NULL, sbuf.st_size, PROT_READ, MAP_PRIVATE, fd, 0);
        if (fmem == MAP_FAILED)