Re: [PATCH] scripts: coccinelle: kfree with TRACE_RET before ref is ok (resent)

From: BjÃrn Mork
Date: Tue Jul 22 2014 - 09:52:54 EST


Nicholas Mc Guire <der.herr@xxxxxxx> writes:

> kfree.cocci currently triggers on constructs like
> (resending with proper CC list and subject line)
>
> drivers/staging/rts5208/spi.c
> 596 if (retval < 0) {
> 597 kfree(buf);
> 598 rtsx_clear_spi_error(chip);
> 599 spi_set_err_code(chip, SPI_HW_ERR);
> 600 TRACE_RET(chip, STATUS_FAIL);
> 601 }
> 602
> 603 rtsx_stor_access_xfer_buf(buf, pagelen, srb, &index, &offset,
> TO_XFER_BUF);
>
> with:
>
> ./drivers/staging/rts5208/spi.c:603:28-31: ERROR: reference preceded
> by free on line 597
>
> but this should be fine - so TRACE_RET is added to the list of calls
> "protecting" access to freed objects see drivers/staging/rts5208/trace.h

The TRACE_RET macro is a serious coding style violation. Fix that and
the error will go away. Don't change scripts to hide issues with the
code. The code above won't just trigger an error in kfree.cocci but also
in the head of any sane person.

>From Documentation/CodingStyle:

<quote>
Things to avoid when using macros:

1) macros that affect control flow:

#define FOO(x) \
do { \
if (blah(x) < 0) \
return -EBUGGERED; \
} while(0)

is a _very_ bad idea. It looks like a function call but exits the "calling"
function; don't break the internal parsers of those who will read the code.
</quote>


BjÃrn
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/