On Fri, 23 May 2014, Stephen Boyd wrote: > Failure to terminate an of_device_id table can lead to confusing > failures depending on where the compiler places the array. Add a > check to make sure these tables are terminated. Thanks to Mitchel > Humpherys for coming up with the initial pattern. > > Cc: Mitchel Humpherys <mitch...@codeaurora.org> > Cc: Julia Lawall <julia.law...@lip6.fr> > Cc: Gilles Muller <gilles.mul...@lip6.fr> > Cc: Nicolas Palix <nicolas.pa...@imag.fr> > Cc: Grant Likely <grant.lik...@linaro.org> > Cc: Rob Herring <robh...@kernel.org> > Cc: devicet...@vger.kernel.org > Signed-off-by: Stephen Boyd <sb...@codeaurora.org> > --- > scripts/coccinelle/misc/of_table.cocci | 81 > ++++++++++++++++++++++++++++++++++ > 1 file changed, 81 insertions(+) > create mode 100644 scripts/coccinelle/misc/of_table.cocci > > diff --git a/scripts/coccinelle/misc/of_table.cocci > b/scripts/coccinelle/misc/of_table.cocci > new file mode 100644 > index 000000000000..da8bfa69fa3e > --- /dev/null > +++ b/scripts/coccinelle/misc/of_table.cocci > @@ -0,0 +1,81 @@ > +/// Make sure of_device_id tables are NULL terminated > +// > +// Keywords: of_table > +// Confidence: Medium > +// Options: --include-headers > + > +virtual patch > +virtual context > +virtual org > +virtual report > + > +@bad_of_table exists@ > +identifier var, arr; > +expression E; > +@@ > +... struct of_device_id arr[] = { > + ..., > + { > + ..., > + .var = E, > + ... > + } > +};
You shouldn't need any of the ...s in these rules. julia > +@depends on bad_of_table && context@ > +identifier var, arr; > +expression E; > +@@ > + ... struct of_device_id arr[] = { > + ..., > + { > + ..., > +* .var = E, > + ... > + } > +}; > + > +@depends on bad_of_table && patch@ > +identifier var, arr; > +expression E; > +@@ > +... struct of_device_id arr[] = { > + ..., > + { > + ..., > + .var = E, > + ... > +- } > ++ }, > ++ { } > +}; > + > +@r depends on bad_of_table exists@ > +position p1; > +identifier var, arr; > +expression E; > +@@ > +... struct of_device_id arr[] = { > + ..., > + { > + ..., > + .var = E, > + ... > + } > + @p1 > +}; > + > +@script:python depends on org@ > +p1 << r.p1; > +arr << r.arr; > +@@ > + > +cocci.print_main(arr,p1) > + > +@script:python depends on report@ > +p1 << r.p1; > +arr << r.arr; > +@@ > + > +msg = "%s is not NULL terminated at line %s" % (arr, p1[0].line) > +coccilib.report.print_report(p1[0],msg) > -- > The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, > hosted by The Linux Foundation > > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/