From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ian Campbell Subject: Re: [PATCH] Fixed tpm_tis bug when some devices report invalid timeout values. Date: Wed, 29 Oct 2014 14:24:43 +0000 Message-ID: <1414592683.29580.3.camel@citrix.com> References: <1414603685-31671-1-git-send-email-emilcondrea@gmail.com> <1414603685-31671-2-git-send-email-emilcondrea@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <1414603685-31671-2-git-send-email-emilcondrea@gmail.com> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xen.org Errors-To: xen-devel-bounces@lists.xen.org To: Emil Condrea Cc: xen-devel@lists.xen.org List-Id: xen-devel@lists.xenproject.org On Wed, 2014-10-29 at 19:28 +0200, Emil Condrea wrote: Thanks. Please see http://wiki.xen.org/wiki/Submitting_Xen_Patches which describes some of the requirements for submitting a patch. In particular we need a Signed-off-by in order to accept a contribution, but also note the bit about CCing the relevant maintainer and the bit about what a good changelog entry might contain. Thanks, Ian. > --- > extras/mini-os/tpm_tis.c | 12 ++++++++++++ > 1 file changed, 12 insertions(+) > > diff --git a/extras/mini-os/tpm_tis.c b/extras/mini-os/tpm_tis.c > index b067cb7..81d426a 100644 > --- a/extras/mini-os/tpm_tis.c > +++ b/extras/mini-os/tpm_tis.c > @@ -33,6 +33,11 @@ > #ifndef min > #define min( a, b ) ( ((a) < (b)) ? (a) : (b) ) > #endif > +#define ADJUST_TIMEOUTS_TO_STANDARD(initial,standard,timeout_no) \ > + if((initial) < (standard)){ \ > + (initial) = (standard); \ > + printk("Timeout %c was adjusted to standard value.\n",timeout_no); \ > + } > > #define TPM_HEADER_SIZE 10 > > @@ -997,15 +1002,22 @@ int tpm_get_timeouts(struct tpm_chip *chip) > } > if (timeout) > chip->timeout_a = MICROSECS(timeout * scale); /*Convert to msec */ > + ADJUST_TIMEOUTS_TO_STANDARD(chip->timeout_a,MILLISECS(TIS_SHORT_TIMEOUT),'a'); > + > timeout = be32_to_cpu(timeout_cap->b); > if (timeout) > chip->timeout_b = MICROSECS(timeout * scale); /*Convert to msec */ > + ADJUST_TIMEOUTS_TO_STANDARD(chip->timeout_b,MILLISECS(TIS_LONG_TIMEOUT),'b'); > + > timeout = be32_to_cpu(timeout_cap->c); > if (timeout) > chip->timeout_c = MICROSECS(timeout * scale); /*Convert to msec */ > + ADJUST_TIMEOUTS_TO_STANDARD(chip->timeout_c,MILLISECS(TIS_SHORT_TIMEOUT),'c'); > + > timeout = be32_to_cpu(timeout_cap->d); > if (timeout) > chip->timeout_d = MICROSECS(timeout * scale); /*Convert to msec */ > + ADJUST_TIMEOUTS_TO_STANDARD(chip->timeout_d,MILLISECS(TIS_SHORT_TIMEOUT),'d'); > > duration: > tpm_cmd.header.in = tpm_getcap_header;