]> git.baikalelectronics.ru Git - kernel.git/commit
coccinelle: semantic code search for missing put_device()
authorWen Yang <wen.yang99@zte.com.cn>
Fri, 15 Feb 2019 07:55:19 +0000 (15:55 +0800)
committerMasahiro Yamada <yamada.masahiro@socionext.com>
Sun, 17 Mar 2019 03:55:45 +0000 (12:55 +0900)
commit07afc1b2cd93ad1a33b98f7c8a38fd9ba456bfa0
tree0056ffa422491fbb45ea5153ec1cdd3b42422887
parent7a95a79a3442cbf9096ca9ab859382d89a52268f
coccinelle: semantic code search for missing put_device()

The of_find_device_by_node() takes a reference to the underlying device
structure, we should release that reference.
The implementation of this semantic code search is:
In a function, for a local variable returned by calling
of_find_device_by_node(),
a, if it is released by a function such as
   put_device()/of_dev_put()/platform_device_put() after the last use,
   it is considered that there is no reference leak;
b, if it is passed back to the caller via
   dev_get_drvdata()/platform_get_drvdata()/get_device(), etc., the
   reference will be released in other functions, and the current function
   also considers that there is no reference leak;
c, for the rest of the situation, the current function should release the
   reference by calling put_device, this code search will report the
   corresponding error message.

By using this semantic code search, we have found some object reference leaks,
such as:
commit 466e49caf670 ("ASoC: fsl-asoc-card: fix object reference leaks in
fsl_asoc_card_probe")
commit 228ea981e36b ("mtd: rawnand: atmel: fix possible object reference leak")
commit a9b06e3f65f5 ("mtd: rawnand: jz4780: fix possible object reference leak")

There are still dozens of reference leaks in the current kernel code.

Further, for the case of b, the object returned to other functions may also
have a reference leak, we will continue to develop other cocci scripts to
further check the reference leak.

Signed-off-by: Wen Yang <wen.yang99@zte.com.cn>
Reviewed-by: Julia Lawall <Julia.Lawall@lip6.fr>
Reviewed-by: Markus Elfring <Markus.Elfring@web.de>
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
scripts/coccinelle/free/put_device.cocci [new file with mode: 0644]