mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
scd: Make app_genkey and supporting ISO function more flexible.
* scd/app.c (app_genkey): Add arg keytype. * scd/app-common.h (struct app_ctx_s): Fitto for the genkey member. * scd/command.c (cmd_genkey): Adjust for change. * scd/iso7816.c (do_generate_keypair): Replace arg read_only by new args p1 and p2. (iso7816_read_public_key): Adjust for this. (iso7816_generate_keypair): Add new args p1 and p2. * scd/app-openpgp.c (do_genkey): Adjust for changes. -- The OpenPGP card creates keys according to parameters read from a data object. Other cards we are about to implement require a direct specification of the requested keytype. This patch implements the required changes. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
c26af8ac26
commit
9a9cb0257a
6 changed files with 24 additions and 19 deletions
|
@ -709,7 +709,7 @@ iso7816_general_authenticate (int slot, int extended_mode,
|
|||
returned. In that case a value of -1 uses a large default
|
||||
(e.g. 4096 bytes), a value larger 256 used that value. */
|
||||
static gpg_error_t
|
||||
do_generate_keypair (int slot, int extended_mode, int read_only,
|
||||
do_generate_keypair (int slot, int extended_mode, int p1, int p2,
|
||||
const char *data, size_t datalen, int le,
|
||||
unsigned char **result, size_t *resultlen)
|
||||
{
|
||||
|
@ -721,7 +721,7 @@ do_generate_keypair (int slot, int extended_mode, int read_only,
|
|||
*resultlen = 0;
|
||||
|
||||
sw = apdu_send_le (slot, extended_mode,
|
||||
0x00, CMD_GENERATE_KEYPAIR, read_only? 0x81:0x80, 0,
|
||||
0x00, CMD_GENERATE_KEYPAIR, p1, p2,
|
||||
datalen, data,
|
||||
le >= 0 && le < 256? 256:le,
|
||||
result, resultlen);
|
||||
|
@ -739,12 +739,12 @@ do_generate_keypair (int slot, int extended_mode, int read_only,
|
|||
|
||||
|
||||
gpg_error_t
|
||||
iso7816_generate_keypair (int slot, int extended_mode,
|
||||
iso7816_generate_keypair (int slot, int extended_mode, int p1, int p2,
|
||||
const char *data, size_t datalen,
|
||||
int le,
|
||||
unsigned char **result, size_t *resultlen)
|
||||
{
|
||||
return do_generate_keypair (slot, extended_mode, 0,
|
||||
return do_generate_keypair (slot, extended_mode, p1, p2,
|
||||
data, datalen, le, result, resultlen);
|
||||
}
|
||||
|
||||
|
@ -755,7 +755,7 @@ iso7816_read_public_key (int slot, int extended_mode,
|
|||
int le,
|
||||
unsigned char **result, size_t *resultlen)
|
||||
{
|
||||
return do_generate_keypair (slot, extended_mode, 1,
|
||||
return do_generate_keypair (slot, extended_mode, 0x81, 0,
|
||||
data, datalen, le, result, resultlen);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue