All of lore.kernel.org
 help / color / mirror / Atom feed
From: Christophe Ricard <christophe.ricard@gmail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v2 18/28] tpm: Report tpm errors on the command line
Date: Mon, 24 Aug 2015 22:21:55 +0200	[thread overview]
Message-ID: <55DB7CE3.7050400@gmail.com> (raw)
In-Reply-To: <1440289904-31280-19-git-send-email-sjg@chromium.org>

Hi Simon,

This one looks good to me.

Acked-by: Christophe Ricard<christophe-h.ricard@st.com>

Best Regards
Christophe

On 23/08/2015 02:31, Simon Glass wrote:
> When a 'tpm' command fails, we set the return code but give no indication
> of failure. This can be confusing.
>
> Add an error message when any tpm command fails.
>
> Signed-off-by: Simon Glass <sjg@chromium.org>
> ---
>
> Changes in v2:
> - Correct error-checking code in report_return_code()
>
>   common/cmd_tpm.c | 46 ++++++++++++++++++++++++----------------------
>   1 file changed, 24 insertions(+), 22 deletions(-)
>
> diff --git a/common/cmd_tpm.c b/common/cmd_tpm.c
> index bad2006..65e7371 100644
> --- a/common/cmd_tpm.c
> +++ b/common/cmd_tpm.c
> @@ -80,17 +80,19 @@ static void *parse_byte_string(char *bytes, uint8_t *data, size_t *count_ptr)
>   }
>   
>   /**
> - * Convert TPM command return code to U-Boot command error codes.
> + * report_return_code() - Report any error and return failure or success
>    *
>    * @param return_code	TPM command return code
>    * @return value of enum command_ret_t
>    */
> -static int convert_return_code(uint32_t return_code)
> +static int report_return_code(int return_code)
>   {
> -	if (return_code)
> +	if (return_code) {
> +		printf("Error: %d\n", return_code);
>   		return CMD_RET_FAILURE;
> -	else
> +	} else {
>   		return CMD_RET_SUCCESS;
> +	}
>   }
>   
>   /**
> @@ -252,7 +254,7 @@ static int do_tpm_startup(cmd_tbl_t *cmdtp, int flag,
>   		return CMD_RET_FAILURE;
>   	}
>   
> -	return convert_return_code(tpm_startup(mode));
> +	return report_return_code(tpm_startup(mode));
>   }
>   
>   static int do_tpm_nv_define_space(cmd_tbl_t *cmdtp, int flag,
> @@ -266,7 +268,7 @@ static int do_tpm_nv_define_space(cmd_tbl_t *cmdtp, int flag,
>   	perm = simple_strtoul(argv[2], NULL, 0);
>   	size = simple_strtoul(argv[3], NULL, 0);
>   
> -	return convert_return_code(tpm_nv_define_space(index, perm, size));
> +	return report_return_code(tpm_nv_define_space(index, perm, size));
>   }
>   
>   static int do_tpm_nv_read_value(cmd_tbl_t *cmdtp, int flag,
> @@ -287,7 +289,7 @@ static int do_tpm_nv_read_value(cmd_tbl_t *cmdtp, int flag,
>   		print_byte_string(data, count);
>   	}
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   static int do_tpm_nv_write_value(cmd_tbl_t *cmdtp, int flag,
> @@ -309,7 +311,7 @@ static int do_tpm_nv_write_value(cmd_tbl_t *cmdtp, int flag,
>   	rc = tpm_nv_write_value(index, data, count);
>   	free(data);
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   static int do_tpm_extend(cmd_tbl_t *cmdtp, int flag,
> @@ -332,7 +334,7 @@ static int do_tpm_extend(cmd_tbl_t *cmdtp, int flag,
>   		print_byte_string(out_digest, sizeof(out_digest));
>   	}
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   static int do_tpm_pcr_read(cmd_tbl_t *cmdtp, int flag,
> @@ -353,7 +355,7 @@ static int do_tpm_pcr_read(cmd_tbl_t *cmdtp, int flag,
>   		print_byte_string(data, count);
>   	}
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   static int do_tpm_tsc_physical_presence(cmd_tbl_t *cmdtp, int flag,
> @@ -365,7 +367,7 @@ static int do_tpm_tsc_physical_presence(cmd_tbl_t *cmdtp, int flag,
>   		return CMD_RET_USAGE;
>   	presence = (uint16_t)simple_strtoul(argv[1], NULL, 0);
>   
> -	return convert_return_code(tpm_tsc_physical_presence(presence));
> +	return report_return_code(tpm_tsc_physical_presence(presence));
>   }
>   
>   static int do_tpm_read_pubek(cmd_tbl_t *cmdtp, int flag,
> @@ -385,7 +387,7 @@ static int do_tpm_read_pubek(cmd_tbl_t *cmdtp, int flag,
>   		print_byte_string(data, count);
>   	}
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   static int do_tpm_physical_set_deactivated(cmd_tbl_t *cmdtp, int flag,
> @@ -397,7 +399,7 @@ static int do_tpm_physical_set_deactivated(cmd_tbl_t *cmdtp, int flag,
>   		return CMD_RET_USAGE;
>   	state = (uint8_t)simple_strtoul(argv[1], NULL, 0);
>   
> -	return convert_return_code(tpm_physical_set_deactivated(state));
> +	return report_return_code(tpm_physical_set_deactivated(state));
>   }
>   
>   static int do_tpm_get_capability(cmd_tbl_t *cmdtp, int flag,
> @@ -420,7 +422,7 @@ static int do_tpm_get_capability(cmd_tbl_t *cmdtp, int flag,
>   		print_byte_string(cap, count);
>   	}
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   #define TPM_COMMAND_NO_ARG(cmd)				\
> @@ -429,7 +431,7 @@ static int do_##cmd(cmd_tbl_t *cmdtp, int flag,		\
>   {							\
>   	if (argc != 1)					\
>   		return CMD_RET_USAGE;			\
> -	return convert_return_code(cmd());		\
> +	return report_return_code(cmd());		\
>   }
>   
>   TPM_COMMAND_NO_ARG(tpm_init)
> @@ -485,7 +487,7 @@ static int do_tpm_raw_transfer(cmd_tbl_t *cmdtp, int flag,
>   		print_byte_string(response, response_length);
>   	}
>   
> -	return convert_return_code(rc);
> +	return report_return_code(rc);
>   }
>   
>   static int do_tpm_nv_define(cmd_tbl_t *cmdtp, int flag,
> @@ -503,7 +505,7 @@ static int do_tpm_nv_define(cmd_tbl_t *cmdtp, int flag,
>   	index = simple_strtoul(argv[2], NULL, 0);
>   	perm = simple_strtoul(argv[3], NULL, 0);
>   
> -	return convert_return_code(tpm_nv_define_space(index, perm, size));
> +	return report_return_code(tpm_nv_define_space(index, perm, size));
>   }
>   
>   static int do_tpm_nv_read(cmd_tbl_t *cmdtp, int flag,
> @@ -532,7 +534,7 @@ static int do_tpm_nv_read(cmd_tbl_t *cmdtp, int flag,
>   	}
>   	free(data);
>   
> -	return convert_return_code(err);
> +	return report_return_code(err);
>   }
>   
>   static int do_tpm_nv_write(cmd_tbl_t *cmdtp, int flag,
> @@ -560,7 +562,7 @@ static int do_tpm_nv_write(cmd_tbl_t *cmdtp, int flag,
>   	err = tpm_nv_write_value(index, data, count);
>   	free(data);
>   
> -	return convert_return_code(err);
> +	return report_return_code(err);
>   }
>   
>   #ifdef CONFIG_TPM_AUTH_SESSIONS
> @@ -572,7 +574,7 @@ static int do_tpm_oiap(cmd_tbl_t *cmdtp, int flag,
>   
>   	err = tpm_oiap(&auth_handle);
>   
> -	return convert_return_code(err);
> +	return report_return_code(err);
>   }
>   
>   static int do_tpm_load_key2_oiap(cmd_tbl_t *cmdtp, int flag,
> @@ -597,7 +599,7 @@ static int do_tpm_load_key2_oiap(cmd_tbl_t *cmdtp, int flag,
>   	if (!err)
>   		printf("Key handle is 0x%x\n", key_handle);
>   
> -	return convert_return_code(err);
> +	return report_return_code(err);
>   }
>   
>   static int do_tpm_get_pub_key_oiap(cmd_tbl_t *cmdtp, int flag,
> @@ -622,7 +624,7 @@ static int do_tpm_get_pub_key_oiap(cmd_tbl_t *cmdtp, int flag,
>   		printf("dump of received pub key structure:\n");
>   		print_byte_string(pub_key_buffer, pub_key_len);
>   	}
> -	return convert_return_code(err);
> +	return report_return_code(err);
>   }
>   
>   TPM_COMMAND_NO_ARG(tpm_end_oiap)

  reply	other threads:[~2015-08-24 20:21 UTC|newest]

Thread overview: 81+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-08-23  0:31 [U-Boot] [PATCH v2 00/28] dm: Convert TPM drivers to driver model Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 01/28] tpm: Remove old pre-driver-model I2C code Simon Glass
2015-08-24  4:50   ` Heiko Schocher
2015-08-24  4:52     ` Simon Glass
2015-08-24  5:15       ` Heiko Schocher
2015-08-30 22:42         ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 02/28] tpm: Drop two unused options Simon Glass
2015-08-30 22:42   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 03/28] tpm: Add Kconfig options for TPMs Simon Glass
2015-08-24 20:24   ` Christophe Ricard
2015-08-30 22:42     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 04/28] tpm: Convert board config TPM options to Kconfig Simon Glass
2015-08-24 20:20   ` Christophe Ricard
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 05/28] tpm: Convert drivers to use SPDX Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 06/28] tpm: Move the I2C TPM code into one file Simon Glass
2015-08-24 20:24   ` Christophe Ricard
2015-08-25  4:13     ` Simon Glass
2015-08-25 18:38       ` Christophe Ricard
2015-08-30 22:43         ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 07/28] tpm: tpm_tis_i2c: Drop unnecessary methods Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 08/28] tpm: tpm_tis_i2c: Drop struct tpm_vendor_specific Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 09/28] tpm: tpm_tis_i2c: Merge struct tpm_dev into tpm_chip Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 10/28] tpm: tpm_tis_i2c: Merge struct tpm " Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 11/28] tpm: tpm_tis_i2c: Move definitions into the header file Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 12/28] tpm: tpm_tis_i2c: Simplify init code Simon Glass
2015-08-24 20:20   ` Christophe Ricard
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 13/28] tpm: tpm_tis_i2c: Use a consistent tpm_tis_i2c_ prefix Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 14/28] tpm: tpm_tis_i2c: Tidy up delays Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 15/28] dm: tpm: Add a uclass for Trusted Platform Modules Simon Glass
2015-08-24 20:21   ` Christophe Ricard
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 16/28] dm: tpm: Convert the TPM command and library to driver model Simon Glass
2015-08-24 20:21   ` Christophe Ricard
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 17/28] dm: i2c: Add a command to adjust the offset length Simon Glass
2015-08-24 20:21   ` Christophe Ricard
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 18/28] tpm: Report tpm errors on the command line Simon Glass
2015-08-24 20:21   ` Christophe Ricard [this message]
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 19/28] dm: tpm: sandbox: Convert TPM driver to driver model Simon Glass
2015-08-30 22:43   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 20/28] tpm: Check that parse_byte_string() has data to parse Simon Glass
2015-08-24 20:22   ` Christophe Ricard
2015-08-25  4:13     ` Simon Glass
2015-08-25 18:40       ` Christophe Ricard
2015-08-30 22:43         ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 21/28] exynos: x86: dts: Add tpm nodes to the device tree for Chrome OS devices Simon Glass
2015-08-24 20:22   ` Christophe Ricard
2015-08-30 22:43     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 22/28] dm: tpm: Convert I2C driver to driver model Simon Glass
2015-08-24 20:22   ` Christophe Ricard
2015-08-30 22:44     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 23/28] dm: tpm: Convert LPC " Simon Glass
2015-08-24 20:23   ` Christophe Ricard
2015-08-30 22:44     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 24/28] tpm: Add a 'tpm info' command Simon Glass
2015-08-30 22:44   ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 25/28] tpm: Add functions to access flags and permissions Simon Glass
2015-08-24 20:23   ` Christophe Ricard
2015-08-30 22:44     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 26/28] dm: tpm: Add a 'tpmtest' command Simon Glass
2015-08-24 20:23   ` Christophe Ricard
2015-08-30 22:44     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 27/28] tpm: Enable 'tpmtest' command for Chrome OS boards with TPMs Simon Glass
2015-08-24 20:23   ` Christophe Ricard
2015-08-30 22:44     ` Simon Glass
2015-08-23  0:31 ` [U-Boot] [PATCH v2 28/28] tegra: nyan: Enable TPM command and driver Simon Glass
2015-08-30 22:44   ` Simon Glass
2015-08-24 20:20 ` [U-Boot] [PATCH v2 00/28] dm: Convert TPM drivers to driver model Christophe Ricard
2015-08-25  4:13   ` Simon Glass

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=55DB7CE3.7050400@gmail.com \
    --to=christophe.ricard@gmail.com \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.