mirror of
https://github.com/openssl/openssl.git
synced 2024-12-15 06:01:37 +08:00
25f2138b0a
Currently, there are two different directories which contain internal header files of libcrypto which are meant to be shared internally: While header files in 'include/internal' are intended to be shared between libcrypto and libssl, the files in 'crypto/include/internal' are intended to be shared inside libcrypto only. To make things complicated, the include search path is set up in such a way that the directive #include "internal/file.h" could refer to a file in either of these two directoroes. This makes it necessary in some cases to add a '_int.h' suffix to some files to resolve this ambiguity: #include "internal/file.h" # located in 'include/internal' #include "internal/file_int.h" # located in 'crypto/include/internal' This commit moves the private crypto headers from 'crypto/include/internal' to 'include/crypto' As a result, the include directives become unambiguous #include "internal/file.h" # located in 'include/internal' #include "crypto/file.h" # located in 'include/crypto' hence the superfluous '_int.h' suffixes can be stripped. The files 'store_int.h' and 'store.h' need to be treated specially; they are joined into a single file. Reviewed-by: Richard Levitte <levitte@openssl.org> (Merged from https://github.com/openssl/openssl/pull/9333)
185 lines
5.7 KiB
C
185 lines
5.7 KiB
C
/*
|
|
* Copyright 2019 The OpenSSL Project Authors. All Rights Reserved.
|
|
*
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
* in the file LICENSE in the source distribution or at
|
|
* https://www.openssl.org/source/license.html
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include <openssl/bn.h>
|
|
#include "crypto/asn1_dsa.h"
|
|
#include "testutil.h"
|
|
|
|
static unsigned char t_dsa_sig[] = {
|
|
0x30, 0x06, /* SEQUENCE tag + length */
|
|
0x02, 0x01, 0x01, /* INTEGER tag + length + content */
|
|
0x02, 0x01, 0x02 /* INTEGER tag + length + content */
|
|
};
|
|
|
|
static unsigned char t_dsa_sig_extra[] = {
|
|
0x30, 0x06, /* SEQUENCE tag + length */
|
|
0x02, 0x01, 0x01, /* INTEGER tag + length + content */
|
|
0x02, 0x01, 0x02, /* INTEGER tag + length + content */
|
|
0x05, 0x00 /* NULL tag + length */
|
|
};
|
|
|
|
static unsigned char t_dsa_sig_msb[] = {
|
|
0x30, 0x08, /* SEQUENCE tag + length */
|
|
0x02, 0x02, 0x00, 0x81, /* INTEGER tag + length + content */
|
|
0x02, 0x02, 0x00, 0x82 /* INTEGER tag + length + content */
|
|
};
|
|
|
|
static unsigned char t_dsa_sig_two[] = {
|
|
0x30, 0x08, /* SEQUENCE tag + length */
|
|
0x02, 0x02, 0x01, 0x00, /* INTEGER tag + length + content */
|
|
0x02, 0x02, 0x02, 0x00 /* INTEGER tag + length + content */
|
|
};
|
|
|
|
/*
|
|
* Badly coded ASN.1 INTEGER zero wrapped in a sequence along with another
|
|
* (valid) INTEGER.
|
|
*/
|
|
static unsigned char t_invalid_int_zero[] = {
|
|
0x30, 0x05, /* SEQUENCE tag + length */
|
|
0x02, 0x00, /* INTEGER tag + length */
|
|
0x02, 0x01, 0x2a /* INTEGER tag + length */
|
|
};
|
|
|
|
/*
|
|
* Badly coded ASN.1 INTEGER (with leading zeros) wrapped in a sequence along
|
|
* with another (valid) INTEGER.
|
|
*/
|
|
static unsigned char t_invalid_int[] = {
|
|
0x30, 0x07, /* SEQUENCE tag + length */
|
|
0x02, 0x02, 0x00, 0x7f, /* INTEGER tag + length */
|
|
0x02, 0x01, 0x2a /* INTEGER tag + length */
|
|
};
|
|
|
|
/*
|
|
* Negative ASN.1 INTEGER wrapped in a sequence along with another
|
|
* (valid) INTEGER.
|
|
*/
|
|
static unsigned char t_neg_int[] = {
|
|
0x30, 0x06, /* SEQUENCE tag + length */
|
|
0x02, 0x01, 0xaa, /* INTEGER tag + length */
|
|
0x02, 0x01, 0x2a /* INTEGER tag + length */
|
|
};
|
|
|
|
static unsigned char t_trunc_der[] = {
|
|
0x30, 0x08, /* SEQUENCE tag + length */
|
|
0x02, 0x02, 0x00, 0x81, /* INTEGER tag + length */
|
|
0x02, 0x02, 0x00 /* INTEGER tag + length */
|
|
};
|
|
|
|
static unsigned char t_trunc_seq[] = {
|
|
0x30, 0x07, /* SEQUENCE tag + length */
|
|
0x02, 0x02, 0x00, 0x81, /* INTEGER tag + length */
|
|
0x02, 0x02, 0x00, 0x82 /* INTEGER tag + length */
|
|
};
|
|
|
|
static int test_decode(void)
|
|
{
|
|
int rv = 0;
|
|
BIGNUM *r;
|
|
BIGNUM *s;
|
|
const unsigned char *pder;
|
|
|
|
r = BN_new();
|
|
s = BN_new();
|
|
|
|
/* Positive tests */
|
|
pder = t_dsa_sig;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_dsa_sig)) == 0
|
|
|| !TEST_ptr_eq(pder, (t_dsa_sig + sizeof(t_dsa_sig)))
|
|
|| !TEST_BN_eq_word(r, 1) || !TEST_BN_eq_word(s, 2)) {
|
|
TEST_info("asn1_dsa test_decode: t_dsa_sig failed");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_dsa_sig_extra;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_dsa_sig_extra)) == 0
|
|
|| !TEST_ptr_eq(pder,
|
|
(t_dsa_sig_extra + sizeof(t_dsa_sig_extra) - 2))
|
|
|| !TEST_BN_eq_word(r, 1) || !TEST_BN_eq_word(s, 2)) {
|
|
TEST_info("asn1_dsa test_decode: t_dsa_sig_extra failed");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_dsa_sig_msb;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_dsa_sig_msb)) == 0
|
|
|| !TEST_ptr_eq(pder, (t_dsa_sig_msb + sizeof(t_dsa_sig_msb)))
|
|
|| !TEST_BN_eq_word(r, 0x81) || !TEST_BN_eq_word(s, 0x82)) {
|
|
TEST_info("asn1_dsa test_decode: t_dsa_sig_msb failed");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_dsa_sig_two;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_dsa_sig_two)) == 0
|
|
|| !TEST_ptr_eq(pder, (t_dsa_sig_two + sizeof(t_dsa_sig_two)))
|
|
|| !TEST_BN_eq_word(r, 0x100) || !TEST_BN_eq_word(s, 0x200)) {
|
|
TEST_info("asn1_dsa test_decode: t_dsa_sig_two failed");
|
|
goto fail;
|
|
}
|
|
|
|
/* Negative tests */
|
|
pder = t_invalid_int_zero;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_invalid_int_zero)) != 0) {
|
|
TEST_info("asn1_dsa test_decode: Expected t_invalid_int_zero to fail");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_invalid_int;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_invalid_int)) != 0) {
|
|
TEST_info("asn1_dsa test_decode: Expected t_invalid_int to fail");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_neg_int;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_neg_int)) != 0) {
|
|
TEST_info("asn1_dsa test_decode: Expected t_neg_int to fail");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_trunc_der;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_trunc_der)) != 0) {
|
|
TEST_info("asn1_dsa test_decode: Expected fail t_trunc_der");
|
|
goto fail;
|
|
}
|
|
|
|
BN_clear(r);
|
|
BN_clear(s);
|
|
pder = t_trunc_seq;
|
|
if (decode_der_dsa_sig(r, s, &pder, sizeof(t_trunc_seq)) != 0) {
|
|
TEST_info("asn1_dsa test_decode: Expected fail t_trunc_seq");
|
|
goto fail;
|
|
}
|
|
|
|
rv = 1;
|
|
fail:
|
|
BN_free(r);
|
|
BN_free(s);
|
|
return rv;
|
|
}
|
|
|
|
int setup_tests(void)
|
|
{
|
|
ADD_TEST(test_decode);
|
|
return 1;
|
|
}
|