Commit 38b9e0c2 authored by Jarkko Sakkinen's avatar Jarkko Sakkinen Committed by Tim Gardner

keys, trusted: fix: *do not* allow duplicate key options

BugLink: http://bugs.launchpad.net/bugs/1398274

The trusted keys option parsing allows specifying the same option
multiple times. The last option value specified is used.

This is problematic because:

* No gain.
* This makes complicated to specify options that are dependent on other
  options.

This patch changes the behavior in a way that option can be specified
only once.
Reported-by: default avatarJames Morris James Morris <jmorris@namei.org>
Reviewed-by: default avatarMimi Zohar <zohar@linux.vnet.ibm.com>
Signed-off-by: default avatarJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
Acked-by: default avatarPeter Huewe <peterhuewe@gmx.de>
(cherry picked from commit 5208cc83)
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent 13f5c17d
...@@ -736,11 +736,14 @@ static int getoptions(char *c, struct trusted_key_payload *pay, ...@@ -736,11 +736,14 @@ static int getoptions(char *c, struct trusted_key_payload *pay,
int res; int res;
unsigned long handle; unsigned long handle;
unsigned long lock; unsigned long lock;
unsigned long token_mask = 0;
while ((p = strsep(&c, " \t"))) { while ((p = strsep(&c, " \t"))) {
if (*p == '\0' || *p == ' ' || *p == '\t') if (*p == '\0' || *p == ' ' || *p == '\t')
continue; continue;
token = match_token(p, key_tokens, args); token = match_token(p, key_tokens, args);
if (test_and_set_bit(token, &token_mask))
return -EINVAL;
switch (token) { switch (token) {
case Opt_pcrinfo: case Opt_pcrinfo:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment