On Thu, Mar 20, 2025 at 04:24:32PM +0100, Stefano Garzarella wrote:
> From: Stefano Garzarella <sgarz...@redhat.com>
> 
> Some devices do not support interrupts and provide a single operation
> to send the command and receive the response on the same buffer.
> 
> To support this scenario, a driver could set TPM_CHIP_FLAG_IRQ in the
> chip's flags to get recv() to be called immediately after send() in
> tpm_try_transmit(), or it needs to implement .status() to return 0,
> and set both .req_complete_mask and .req_complete_val to 0.
> 
> In order to simplify these drivers and avoid temporary buffers to be

Simplification can be addressed with no callback changes:

https://lore.kernel.org/linux-integrity/20250326161838.123606-1-jar...@kernel.org/T/#u

I also noticed that tpm_ftpm_tee initalized req_complete_mask and
req_complete_val explictly while they would be already implicitly
zero.

So it reduces this just a matter of getting rid off the extra
buffer.

> used between the .send() and .recv() callbacks, introduce a new callback
> send_recv(). If that callback is defined, it is called in
> tpm_try_transmit() to send the command and receive the response on
> the same buffer in a single call.

I don't find anything in the commit message addressing buf_len an
cmd_len (vs "just len"). Why two lengths are required?

Not completely rejecting but this explanation is incomplete.

BR, Jarkko

Reply via email to