Re: [PATCH] tpm: Support for new chip type

From: Alexey Dobriyan
Date: Fri Jul 08 2005 - 02:11:22 EST


On Friday 08 July 2005 02:42, Marcel Selhorst wrote:
> after some corrections here is a newer patch supporting the Infineon Trusted
> Platform Module SLD 9630 (TPM 1.1b), which is embedded on Intel-mainboards or
> in HP/Fujitsu-Siemens/Toshiba-Notebooks.

> --- linux-2.6.12.2/drivers/char/tpm/tpm_infineon.c
> +++ linux/drivers/char/tpm/tpm_infineon.c

> +static int empty_fifo(struct tpm_chip *chip, int clear_wrfifo)
> +{
> + int status;
> + int check = 0;
> + int i;
> + int j = 0;
> +
> + if (clear_wrfifo) {
> + for (i = 0; i < 4096; i++) {
> + status = inb(chip->vendor->base + WRFIFO);
> + if (status == 0xff) {
> + if (check == 5)
> + break;
> + else
> + check++;
> + }
> + }
> + }
> + /* Note: The values which are currently in the FIFO of the TPM
> + are thrown away since there is no usage for them. Usually,
> + this has nothing to say, since the TPM will give its answer immediately
> + or will be aborted anyway, so the data here is usually garbage and useless.
> + We have to clean this, because the next communication with the TPM would
> + be rubbish, if there is still some old data in the Read FIFO.
> + */

Could you reformat it a little to fit in 80 columns?

> + i = 0;

i is used only in clear_wrfifo loop. Or sacrifice j instead.

> + do {
> + status = inb(chip->vendor->base + RDFIFO);
> + status = inb(chip->vendor->base + STAT);
> + j++;
> + if (j == TPM_MAX_TRIES)
> + return -EIO;
> + } while ((status & (1 << STAT_RDA)) != 0);
> + return 0;
> +}

> +static int wait(struct tpm_chip *chip, int wait_for_bit)
> +{

> + if (i == TPM_MAX_TRIES) { /* when timeout occurs, print information and return -EIO */

We see dev_err() calls, we see -EIO. So only "timeout occurs" should be left.

> + dev_err(&chip->pci_dev->dev, "Timeout in wait(");
> + if (wait_for_bit == STAT_XFE)
> + dev_err(&chip->pci_dev->dev, "STAT_XFE)\n");
> + if (wait_for_bit == STAT_RDA)
> + dev_err(&chip->pci_dev->dev, "STAT_RDA)\n");
> + return -EIO;
> + }

> +/* Note: WTX means Waiting-Time-Extension. Whenever the TPM
> +needs more calculation time, it sends a WTX-package, which has to
> +be acknowledged or aborted. This usually occurs if you are hammering
> +the TPM with key creation. Set the maximum number of WTX-packages in
> +the definitions above, if the number is reached, the waiting-time will be denied
> +and the TPM command has to be resend.
> +*/

Be consistent with the rest of the driver:

/* This style
is OK.
*/

> +static int tpm_inf_recv(struct tpm_chip *chip, u8 * buf, size_t count)
> +{

> + recv_begin:

Labels are placed at column zero usually.

> + dev_dbg(&chip->pci_dev->dev, "Receiving header: ");
> +
> + for (i = 0; i < 4; i++) {
> + ret = wait(chip, STAT_RDA);
> + if (ret)
> + return -EIO;
> +
> + buf[i] = inb(chip->vendor->base + RDFIFO);
> + dev_dbg(&chip->pci_dev->dev, "%02x ", buf[i]);
> + }
> + dev_dbg(&chip->pci_dev->dev, "\n");

One of dev_dbg jobs is to print KERN_DEBUG, but only at the very beginning of
the line.

> + dev_dbg(&chip->pci_dev->dev, "Receiving data: ");
> +
> + for (i = 0; i < size; i++) {
> + wait(chip, STAT_RDA);
> + buf[i] = inb(chip->vendor->base + RDFIFO);
> + dev_dbg(&chip->pci_dev->dev, "%02x ", buf[i]);
> + }
> + dev_dbg(&chip->pci_dev->dev, "\n");

dev_dbg() in the middle.

> + "-> Negative acknowledgement - retransmit commando!\n");

command?

> +static int tpm_inf_send(struct tpm_chip *chip, u8 * buf, size_t count)
> +{

> + count_high = 0;
> + count_low = 0;

What's the point?

> +
> + count_high = (count & 0xffff0000);
> + count_low = (count & 0x0000ffff);

> + dev_dbg(&chip->pci_dev->dev,
> + "Sending data %02x %02x %02x %02x %02x %02x ", TPM_VL_VER,
> + TPM_VL_CHANNEL_TPM, count_4, count_3, count_2, count_1);
> +
> + wait_and_send(chip, TPM_VL_VER);
> + wait_and_send(chip, TPM_VL_CHANNEL_TPM);
> + wait_and_send(chip, count_4);
> + wait_and_send(chip, count_3);
> + wait_and_send(chip, count_2);
> + wait_and_send(chip, count_1);
> +
> + for (i = 0; i < count; i++) {
> + wait_and_send(chip, buf[i]);
> + dev_dbg(&chip->pci_dev->dev, "%02x ", buf[i]);
> + }

dev_dbg in the middle.

> +static int __init tpm_inf_probe(struct pci_dev *pci_dev,
> + const struct pci_device_id *pci_id)
> +{

> + dev_dbg(&pci_dev->dev,
> + "Device activate register status : %x \n", status);

%x\n
-
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/