Hi Daniel, Welcome to drivers/staging. On Tuesday, August 17, 2021 6:30:38 AM CEST daniel watson wrote: > If this is a false positive from checkpatch, I can submit it as an > example to the checkpatch maintainers. Do you think I should? > > On Sun, Aug 15, 2021 at 08:25:51AM +0200, Greg Kroah-Hartman wrote: > > On Sat, Aug 14, 2021 at 07:31:15PM -0700, daniel watson wrote: > > > Error found by checkpatch.pl > > > > What error? Please, understand that Greg K-H is very busy, so he often is quite terse in his responses. That does not absolutely mean he doesn't care. You'll read from him questions like "Why did you do this?" or "What error?" or other similar ones. I think that while working here during the past four months I've become able to "decode" :) the meaning of the above questions (at least, I hope). First of all you should read and follow the guidelines about how to submit patches: "Submitting patches: the essential guide to getting your code into the kernel" at https://www.kernel.org/doc/html/latest/process/submitting-patches.html "What error?" may mean that you have not sufficiently described the underlying problem that motivated you to do this work. Don't assume that the reviewers can and want to deduce what the error is by just reading the "Subject" line. The "Subject" should summarize in few words the content of the commit message, and the commit message should never be written with the assumption that the readers want to compose the whole picture by merging "Subject" and "Commit message" together: they have different purposes and they should be self- contained entities. "Error found by checkpatch.pl" does say nothing about what error you're addressing. Furthermore, the above-mentioned question may also mean: "Are you sure that there are *real* errors/problems?". In this case they are just false positives. An example of a real problem that should be worked out by adding parenthesis is the following one... #define SQRT(x) (x * x) What happens if some code uses that macro like the following example? int a = 3; int b = SQRT(a + 2) Would the result differ if we put parentheses around arguments? #define SQRT(x) ((x) * (x)) As Greg wrote in another message of this thread: "checkpatch is a perl script that does pattern matching, it is really hard for it to determine for things like this specific example, that it is not needed.". The lesson is: we expect you're smarter than checkpatch.pl! :) > $ git checkout 36a21d5172 drivers/staging/iio/meter/ade7854.h # before > Updated 1 path from 638ccd1543654 > > $ ./scripts/checkpatch.pl --terse --types COMPLEX_MACRO \ > drivers/staging/iio/meter/ade7854.h > drivers/staging/iio/meter/ade7854.h:142: ERROR: Macros with complex > values should be enclosed in parentheses > drivers/staging/iio/meter/ade7854.h:143: ERROR: Macros with complex > values should be enclosed in parentheses > drivers/staging/iio/meter/ade7854.h:144: ERROR: Macros with complex > values should be enclosed in parentheses > total: 3 errors, 0 warnings, 0 checks, 173 lines checked > > $ git checkout 143b51a80978 drivers/staging/iio/meter/ade7854.h # after > Updated 1 path from 21c208a36476a OK, this is one of many common ways to explain what errors you're addressing. Unfortunately, in this case they are false positives (so you should have ignored them and move on to the next problem). > $ ./scripts/checkpatch.pl --terse --types COMPLEX_MACRO \ > drivers/staging/iio/meter/ade7854.h > > $ > > > > Signed-off-by: daniel watson <ozzloy@xxxxxxxxxxxxxxxxx> > > > > Capitalize your name? > > I can remake this patch with my name capitalized if the patch is worth > remaking. I'll be sure to capitalize in future sign-off lines for > Linux. > > > This is not a real change that is needed, just look at the code to > > verify that. > > Agreed, this is not a huge change. Minor changes are very well welcome here. Move on to something else and fix only what really needs to be fixed. > I thought small changes were acceptable, if they get rid of errors from > checkpatch. I got that impression from this video > > Write and Submit your first Linux kernel Patch > https://youtu.be/LLBrBBImJt4 > > At around 15 minutes, you create a patch which removes curly braces > from an if-else. That seemed comparable to the change in this > patch. That video was posted over a decade ago, so I would understand > if things are different now. Read again the last sentence I wrote above. I can confirm that the removal of really unneeded curly braces is wanted and welcome. Have a nice time with kernel hacking. Thanks, Fabio > > thanks, > > > > greg k-h > > You're welcome! Thank you too, that was a super fast response! I am > happy to get a direct response from you!