On Tue 17-12-19 15:28:14, Chris Down wrote: > Michal Hocko writes: > > On Tue 17-12-19 15:09:21, Chris Down wrote: > > [...] > > > (Side note: I'm moderately baffled that a tightly scoped __maybe_unused is > > > considered sinister but somehow disabling -Wunused-function is on the table > > > :-)) > > > > Well, I usually do not like to see __maybe_unused because that is prone > > to bit-rot and loses its usefulness. Looking into the recent git logs > > most -Wunused-function led to the code removal (which is really good > > but the compiler is likely to do that already so the overall impact is > > not that large) or more ifdefery. I do not really see many instance of > > __maybe_unused. > > Hmm, but __maybe_unused is easy to find and document the reasons behind > nearby, and then reevaluate at some later time. On the other hand, it's much > *harder* to reevaluate which functions actually are unused in the long term > if we remove -Wunused-function, because enabling it to find candidates will > result in an incredibly amount of noise from those who have missed unused > functions previously due to the lack of the warning. I usually git grep for the function and that covers many cases. But realistically, I am more than skeptical people are going to do a regular cleanup like that. And that is the biggest deal with this annotation. Once it gets marked it will just stay that way and potentially get really unused eventually. So the overall benefit is close the zero in that case. Maybe dropping -Wunused-function is an overreaction. Git log shows there has been some code removed which is probably the most viable reaction to those reports. Maybe we just want to add those for W=1 or something like that. > Maybe Qian is right and we should just ignore such patches, but I think that > comes with its own risks that we will alienate perfectly well intentioned > new contributors to mm without them having any idea why we did that. I believe that both possitive and negative reaction to _any_ patch has to be properly justified - same applies to the patch itself. A warning report/fix is not an expcetion. In this particular case it has been pointed out that the reported function is a general purpose one which just happens to be used only for CONFIG_SWAP (rather than CONFIG_MMU) and using additional ifdeferry is likely not going to help long term. -- Michal Hocko SUSE Labs