Re: [PATCH v2] tpm_tis_spi: fix:release chip select when flow control fails

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Dear Peijie,


Thank you for your patch.

The fix: tag in your commit message summary is uncommon. I suggest:

tpm_tis_spi: Release chip select when flow control fails


Am 22.05.23 um 09:01 schrieb shaopeijie@xxxxxxxx:
From: Peijie Shao <shaopeijie@xxxxxxxx>

The failure paths in tpm_tis_spi_transfer() do not deactivate
chip select. Send an empty message (cs_select == 0) to overcome
this.

Does the standard require to deactivate it?

A note on your test setup would be nice to have in the commit message.

Signed-off-by: Peijie Shao <shaopeijie@xxxxxxxx>
---
Changes since v1:
     1. Deactive cs all of the failure path, not only flow control.

Deactivate


Kind regards,

Paul


     2. change and update comments.
---
  drivers/char/tpm/tpm_tis_spi_main.c | 8 ++++++++
  1 file changed, 8 insertions(+)

diff --git a/drivers/char/tpm/tpm_tis_spi_main.c b/drivers/char/tpm/tpm_tis_spi_main.c
index 1f5207974..9bfaba092 100644
--- a/drivers/char/tpm/tpm_tis_spi_main.c
+++ b/drivers/char/tpm/tpm_tis_spi_main.c
@@ -136,6 +136,14 @@ int tpm_tis_spi_transfer(struct tpm_tis_data *data, u32 addr, u16 len,
  	}
exit:
+	if (ret < 0) {
+		/* Deactivate chip select */
+		memset(&spi_xfer, 0, sizeof(spi_xfer));
+		spi_message_init(&m);
+		spi_message_add_tail(&spi_xfer, &m);
+		spi_sync_locked(phy->spi_device, &m);
+	}
+
  	spi_bus_unlock(phy->spi_device->master);
  	return ret;
  }



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux Kernel]     [Linux Kernel Hardening]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux SCSI]

  Powered by Linux