blob: 56ec0db3b38cc5c3ba4455092fd685ccf48ea9a0 [file] [log] [blame]
vlm5ee0b9b2004-08-19 16:42:54 +00001#include <ber_decoder.c>
2#include <ber_tlv_length.c>
3#include <ber_tlv_tag.c>
4#include <der_encoder.c>
vlm9de248e2004-10-20 15:50:55 +00005#include <xer_decoder.c>
6#include <xer_support.c>
vlm337167e2005-11-26 11:25:14 +00007#include <per_support.c>
vlm5ee0b9b2004-08-19 16:42:54 +00008#include <constraints.c>
9#undef ADVANCE
10#undef RETURN
11#undef LEFT
12#include <OCTET_STRING.c>
13
14
15uint8_t *buf;
16size_t buf_size;
17size_t buf_off;
18
19static int
20write_to_buf(const void *buffer, size_t size, void *key) {
21 (void)key;
22
23 if(buf_off + size > buf_size) {
24 size_t n = buf_size?:16;
25 while(n < buf_off + size) n <<= 2;
26 buf = realloc(buf, n);
27 assert(buf);
28 buf_size = n;
29 }
30
31 memcpy(buf + buf_off, buffer, size);
32
33 buf_off += size;
34 return 0;
35}
36
37
38static void
39check(int size) {
40 OCTET_STRING_t *os;
41 OCTET_STRING_t *nos = 0;
vlm170e42c2006-07-27 11:46:25 +000042 OCTET_STRING_t **nosp = &nos;
vlm39ba4c42004-09-22 16:06:28 +000043 asn_enc_rval_t erval;
vlm9de248e2004-10-20 15:50:55 +000044 asn_dec_rval_t rval;
vlm5ee0b9b2004-08-19 16:42:54 +000045 int i;
46
vlm0f1ab762004-10-12 05:57:23 +000047 os = OCTET_STRING_new_fromBuf(&asn_DEF_OCTET_STRING, 0, size);
vlm5ee0b9b2004-08-19 16:42:54 +000048 assert(os);
49 assert(os->size == 0);
50
51 os->buf = malloc(size);
52 assert(os->buf);
53 os->size = size;
54
55 for(i = 0; i < size; i++) {
56 os->buf[i] = i;
57 }
58
59 buf_off = 0;
vlmc8964562004-09-29 13:24:33 +000060 erval = der_encode(&asn_DEF_OCTET_STRING,
vlm5ee0b9b2004-08-19 16:42:54 +000061 os, write_to_buf, 0);
62 assert(erval.encoded == buf_off);
63 assert(buf_off > size);
64
vlm170e42c2006-07-27 11:46:25 +000065 rval = ber_decode(0, &asn_DEF_OCTET_STRING, (void **)nosp, buf, buf_off);
vlm5ee0b9b2004-08-19 16:42:54 +000066 assert(rval.code == RC_OK);
67 assert(rval.consumed == buf_off);
68
69 assert(os->size == nos->size);
70
71 for(i = 0; i < size; i++) {
72 assert(os->buf[i] == nos->buf[i]);
73 }
74
75 if(0) {
vlm0f1ab762004-10-12 05:57:23 +000076 fprintf(stderr, "new(%d):", size);
vlm5ee0b9b2004-08-19 16:42:54 +000077 for(i = 0; i < (buf_off<10?buf_off:10); i++)
vlm0f1ab762004-10-12 05:57:23 +000078 fprintf(stderr, " %02x", buf[i]);
vlm5ee0b9b2004-08-19 16:42:54 +000079 printf("\n");
80 }
81
82
vlmc8964562004-09-29 13:24:33 +000083 asn_DEF_OCTET_STRING.free_struct(&asn_DEF_OCTET_STRING, os, 0);
84 asn_DEF_OCTET_STRING.free_struct(&asn_DEF_OCTET_STRING, nos, 0);
vlm5ee0b9b2004-08-19 16:42:54 +000085}
86
87int
88main() {
vlmc8964562004-09-29 13:24:33 +000089 uint8_t buf1[] = { 0x85, 0x00, 0x01, 0x02, 0x03, 0x04 };
90 uint8_t buf2[] = { 0x85, 0x00, 0x7f, 0xff, 0x03, 0x04 };
91 uint8_t buf3[] = { 0x85, 0x00, 0x7f, 0xff, 0xff, 0x04 };
vlm6c593842004-10-26 09:03:31 +000092 uint8_t buf4[] = { 0x89, 0x00, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x04 };
vlmc8964562004-09-29 13:24:33 +000093 ber_tlv_len_t tlv_len;
94 ssize_t ret;
vlm5ee0b9b2004-08-19 16:42:54 +000095 int i;
96
97 for(i = 0; i < 66000; i++) {
vlm0f1ab762004-10-12 05:57:23 +000098 if(i == 4500) i = 64000; /* Jump */
vlm5ee0b9b2004-08-19 16:42:54 +000099 check(i);
100 }
101
vlmc8964562004-09-29 13:24:33 +0000102 ret = ber_fetch_length(0, buf1, sizeof(buf1), &tlv_len);
vlm899ee7b2004-10-26 08:02:01 +0000103 printf("ret=%ld, len=%ld\n", (long)ret, (long)tlv_len);
vlmc8964562004-09-29 13:24:33 +0000104 assert(ret == sizeof(buf1));
vlm735e4612006-07-13 09:22:34 +0000105 assert(tlv_len == 0x01020304);
vlmc8964562004-09-29 13:24:33 +0000106
107 ret = ber_fetch_length(0, buf2, sizeof(buf2), &tlv_len);
vlm899ee7b2004-10-26 08:02:01 +0000108 printf("ret=%ld, len=%ld\n", (long)ret, (long)tlv_len);
vlmc8964562004-09-29 13:24:33 +0000109 assert(ret == sizeof(buf2));
vlm735e4612006-07-13 09:22:34 +0000110 assert(tlv_len == 0x7fff0304);
vlmc8964562004-09-29 13:24:33 +0000111
vlm735e4612006-07-13 09:22:34 +0000112 /*
113 * Here although tlv_len is not greater than 2^31,
114 * we ought to hit an embedded length exploitation preventive check.
115 */
vlme9395762006-07-13 12:01:26 +0000116 printf("sizeof(tlv_len) = %d\n", (int)sizeof(tlv_len));
vlm735e4612006-07-13 09:22:34 +0000117 if(sizeof(tlv_len) <= 4) {
vlm6c593842004-10-26 09:03:31 +0000118 ret = ber_fetch_length(0, buf3, sizeof(buf3), &tlv_len);
119 printf("ret=%ld\n", (long)ret);
vlm20890492006-07-27 12:07:34 +0000120 printf("len=0x%x\n", (unsigned int)tlv_len);
vlm6c593842004-10-26 09:03:31 +0000121 assert(ret == -1);
vlm735e4612006-07-13 09:22:34 +0000122 }
123 if(sizeof(tlv_len) <= 8) {
vlm6c593842004-10-26 09:03:31 +0000124 ret = ber_fetch_length(0, buf4, sizeof(buf4), &tlv_len);
vlm735e4612006-07-13 09:22:34 +0000125 printf("ret=%lld\n", (long long)ret);
vlm6c593842004-10-26 09:03:31 +0000126 assert(ret == -1);
127 }
vlmc8964562004-09-29 13:24:33 +0000128
vlm5ee0b9b2004-08-19 16:42:54 +0000129 return 0;
130}