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 [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to