Hi,
On Wed, May 9, 2018 at 10:01 AM, Lina Iyer <ilina@xxxxxxxxxxxxxx> wrote:
/**
@@ -137,6 +140,8 @@ void rpmh_tx_done(const struct tcs_request *msg, int r)
dev_err(rpm_msg->dev, "RPMH TX fail in msg addr=%#x, err=%d\n",
rpm_msg->msg.cmds[0].addr, r);
+ kfree(rpm_msg->free);
+
The way the code is written makes it seem like you could free memory
_and_ have a completion but you can't. Specifically:
* The only plausible thing that "rpm_msg->free" could point to is "rpm_msg".
* The complete(compl) would then be accessing freed memory.
I believe the kfree() should be at the end of the function.
Personally I'd make it more obvious that this is just a boolean value
and change to:
if (rpm_msg->needs_free)
kgree(rpm_msg)
...then the reader of the code doesn't need to go figure out what
you're trying to free.
-Doug