On Wed, Jan 09, 2019 at 11:27:33AM +0300, Dan Carpenter wrote: > Hello Mel Gorman, > > The patch 1688e2896de4: "mm, compaction: round-robin the order while > searching the free lists for a target" from Jan 8, 2019, leads to the > following static checker warning: > > mm/compaction.c:1252 next_search_order() > warn: impossible condition '(cc->search_order < 0) => (0-u16max < 0)' > Thanks Dan! Does the following combination of two patches address it? The two patches address separate problems with two patches in the series. diff --git a/mm/compaction.c b/mm/compaction.c index cc17f0c01811..a3b665e15ab2 100644 --- a/mm/compaction.c +++ b/mm/compaction.c @@ -1269,6 +1269,10 @@ fast_isolate_freepages(struct compact_control *cc) bool scan_start = false; int order; + /* Full compaction passes in a negative order */ + if (order <= 0) + return cc->free_pfn; + /* * If starting the scan, use a deeper search and use the highest * PFN found if a suitable one is not found. diff --git a/mm/internal.h b/mm/internal.h index 6b1e5e313855..bebfb4b655dd 100644 --- a/mm/internal.h +++ b/mm/internal.h @@ -192,7 +192,7 @@ struct compact_control { unsigned long total_migrate_scanned; unsigned long total_free_scanned; unsigned short fast_search_fail;/* failures to use free list searches */ - unsigned short search_order; /* order to start a fast search at */ + short search_order; /* order to start a fast search at */ const gfp_t gfp_mask; /* gfp mask of a direct compactor */ int order; /* order a direct compactor needs */ int migratetype; /* migratetype of direct compactor */