On Wed, Oct 08, 2014 at 01:28:14AM +0300, Jarkko Sakkinen wrote: > > > @@ -714,15 +709,10 @@ static int tpm_tis_i2c_remove(struct i2c_client > > > *client) > > > struct tpm_chip *chip = tpm_dev.chip; > > > release_locality(chip, chip->vendor.locality, 1); > > > > > > - /* close file handles */ > > > - tpm_dev_vendor_release(chip); > > > - > > > /* remove hardware */ > > > tpm_remove_hardware(chip->dev); > > > > Wrong ordering here, tpm_remove_hardware should always be first - > > drivers should not tear down internal state before calling it, so > > release_locality should be second. > > > > Noting that since we use devm the kfree will not happen until > > remove returns, so the chip pointer is still valid. > > Should I fix this ordering? I was thinking to focus putting proper > patterns in place only in tpm_tis and tpm_crb because they are the > that I'm able to test easily and then they can work as guideline for > other drivers.
I think since this patch is already touching this function there is no reason not to make it be correct (especially since it was noticed) The rest can wait till we globally replace tpm_remove_hardware with tpm_unregister - at that time the ordering can be audited and checked. Then the drivers will be clean and the core can finally be fixed. Jason -- 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/