-/* $OpenBSD: clienttest.c,v 1.37 2022/06/10 22:00:15 tb Exp $ */
+/* $OpenBSD: clienttest.c,v 1.38 2022/07/19 18:56:12 tb Exp $ */
/*
* Copyright (c) 2015 Joel Sing <jsing@openbsd.org>
*
#define TLS13_RANDOM_OFFSET (TLS13_HM_OFFSET + 2)
#define TLS13_SESSION_OFFSET (TLS13_HM_OFFSET + 34)
#define TLS13_CIPHER_OFFSET (TLS13_HM_OFFSET + 69)
-#define TLS13_KEY_SHARE_OFFSET (TLS13_HM_OFFSET + 194)
+#define TLS13_KEY_SHARE_OFFSET (TLS13_HM_OFFSET + 192)
#define TLS13_ONLY_KEY_SHARE_OFFSET (TLS13_HM_OFFSET + 98)
#define TLS1_3_VERSION_ONLY (TLS1_3_VERSION | 0x10000)
0x00, 0x88, 0x00, 0x81, 0x00, 0x35, 0x00, 0x84,
0xc0, 0x13, 0xc0, 0x09, 0x00, 0x33, 0x00, 0x45,
0x00, 0x2f, 0x00, 0x41, 0xc0, 0x11, 0xc0, 0x07,
- 0x00, 0x05, 0x00, 0x04, 0xc0, 0x12, 0xc0, 0x08,
- 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff,
+ 0x00, 0x05, 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16,
+ 0x00, 0x0a, 0x00, 0xff,
};
static const uint8_t client_hello_tls10[] = {
- 0x16, 0x03, 0x01, 0x00, 0x73, 0x01, 0x00, 0x00,
- 0x6f, 0x03, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x16, 0x03, 0x01, 0x00, 0x71, 0x01, 0x00, 0x00,
+ 0x6d, 0x03, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x2e, 0xc0, 0x14,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x2c, 0xc0, 0x14,
0xc0, 0x0a, 0x00, 0x39, 0xff, 0x85, 0x00, 0x88,
0x00, 0x81, 0x00, 0x35, 0x00, 0x84, 0xc0, 0x13,
0xc0, 0x09, 0x00, 0x33, 0x00, 0x45, 0x00, 0x2f,
0x00, 0x41, 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05,
- 0x00, 0x04, 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16,
- 0x00, 0x0a, 0x00, 0xff, 0x01, 0x00, 0x00, 0x18,
- 0x00, 0x0b, 0x00, 0x02, 0x01, 0x00, 0x00, 0x0a,
- 0x00, 0x0a, 0x00, 0x08, 0x00, 0x1d, 0x00, 0x17,
- 0x00, 0x18, 0x00, 0x19, 0x00, 0x23, 0x00, 0x00,
+ 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
+ 0x00, 0xff, 0x01, 0x00, 0x00, 0x18, 0x00, 0x0b,
+ 0x00, 0x02, 0x01, 0x00, 0x00, 0x0a, 0x00, 0x0a,
+ 0x00, 0x08, 0x00, 0x1d, 0x00, 0x17, 0x00, 0x18,
+ 0x00, 0x19, 0x00, 0x23, 0x00, 0x00,
};
static const uint8_t cipher_list_tls11[] = {
0x00, 0x88, 0x00, 0x81, 0x00, 0x35, 0x00, 0x84,
0xc0, 0x13, 0xc0, 0x09, 0x00, 0x33, 0x00, 0x45,
0x00, 0x2f, 0x00, 0x41, 0xc0, 0x11, 0xc0, 0x07,
- 0x00, 0x05, 0x00, 0x04, 0xc0, 0x12, 0xc0, 0x08,
- 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff,
+ 0x00, 0x05, 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16,
+ 0x00, 0x0a, 0x00, 0xff,
};
static const uint8_t client_hello_tls11[] = {
- 0x16, 0x03, 0x01, 0x00, 0x73, 0x01, 0x00, 0x00,
- 0x6f, 0x03, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x16, 0x03, 0x01, 0x00, 0x71, 0x01, 0x00, 0x00,
+ 0x6d, 0x03, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x2e, 0xc0, 0x14,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x2c, 0xc0, 0x14,
0xc0, 0x0a, 0x00, 0x39, 0xff, 0x85, 0x00, 0x88,
0x00, 0x81, 0x00, 0x35, 0x00, 0x84, 0xc0, 0x13,
0xc0, 0x09, 0x00, 0x33, 0x00, 0x45, 0x00, 0x2f,
0x00, 0x41, 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05,
- 0x00, 0x04, 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16,
- 0x00, 0x0a, 0x00, 0xff, 0x01, 0x00, 0x00, 0x18,
- 0x00, 0x0b, 0x00, 0x02, 0x01, 0x00, 0x00, 0x0a,
- 0x00, 0x0a, 0x00, 0x08, 0x00, 0x1d, 0x00, 0x17,
- 0x00, 0x18, 0x00, 0x19, 0x00, 0x23, 0x00, 0x00,
+ 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
+ 0x00, 0xff, 0x01, 0x00, 0x00, 0x18, 0x00, 0x0b,
+ 0x00, 0x02, 0x01, 0x00, 0x00, 0x0a, 0x00, 0x0a,
+ 0x00, 0x08, 0x00, 0x1d, 0x00, 0x17, 0x00, 0x18,
+ 0x00, 0x19, 0x00, 0x23, 0x00, 0x00,
};
static const uint8_t cipher_list_tls12_aes[] = {
0x00, 0x67, 0x00, 0x33, 0x00, 0xbe, 0x00, 0x45,
0x00, 0x9c, 0x00, 0x3c, 0x00, 0x2f, 0x00, 0xba,
0x00, 0x41, 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05,
- 0x00, 0x04, 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16,
- 0x00, 0x0a, 0x00, 0xff,
+ 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
+ 0x00, 0xff,
};
static const uint8_t cipher_list_tls12_chacha[] = {
0x00, 0x67, 0x00, 0x33, 0x00, 0xbe, 0x00, 0x45,
0x00, 0x9c, 0x00, 0x3c, 0x00, 0x2f, 0x00, 0xba,
0x00, 0x41, 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05,
- 0x00, 0x04, 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16,
- 0x00, 0x0a, 0x00, 0xff,
+ 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
+ 0x00, 0xff,
};
static const uint8_t client_hello_tls12[] = {
- 0x16, 0x03, 0x01, 0x00, 0xbd, 0x01, 0x00, 0x00,
- 0xb9, 0x03, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x16, 0x03, 0x01, 0x00, 0xbb, 0x01, 0x00, 0x00,
+ 0xb7, 0x03, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x5c, 0xc0, 0x30,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x5a, 0xc0, 0x30,
0xc0, 0x2c, 0xc0, 0x28, 0xc0, 0x24, 0xc0, 0x14,
0xc0, 0x0a, 0x00, 0x9f, 0x00, 0x6b, 0x00, 0x39,
0xcc, 0xa9, 0xcc, 0xa8, 0xcc, 0xaa, 0xff, 0x85,
0xc0, 0x13, 0xc0, 0x09, 0x00, 0x9e, 0x00, 0x67,
0x00, 0x33, 0x00, 0xbe, 0x00, 0x45, 0x00, 0x9c,
0x00, 0x3c, 0x00, 0x2f, 0x00, 0xba, 0x00, 0x41,
- 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05, 0x00, 0x04,
- 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
- 0x00, 0xff, 0x01, 0x00, 0x00, 0x34, 0x00, 0x0b,
- 0x00, 0x02, 0x01, 0x00, 0x00, 0x0a, 0x00, 0x0a,
- 0x00, 0x08, 0x00, 0x1d, 0x00, 0x17, 0x00, 0x18,
- 0x00, 0x19, 0x00, 0x23, 0x00, 0x00, 0x00, 0x0d,
- 0x00, 0x18, 0x00, 0x16, 0x08, 0x06, 0x06, 0x01,
- 0x06, 0x03, 0x08, 0x05, 0x05, 0x01, 0x05, 0x03,
- 0x08, 0x04, 0x04, 0x01, 0x04, 0x03, 0x02, 0x01,
- 0x02, 0x03,
+ 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05, 0xc0, 0x12,
+ 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff,
+ 0x01, 0x00, 0x00, 0x34, 0x00, 0x0b, 0x00, 0x02,
+ 0x01, 0x00, 0x00, 0x0a, 0x00, 0x0a, 0x00, 0x08,
+ 0x00, 0x1d, 0x00, 0x17, 0x00, 0x18, 0x00, 0x19,
+ 0x00, 0x23, 0x00, 0x00, 0x00, 0x0d, 0x00, 0x18,
+ 0x00, 0x16, 0x08, 0x06, 0x06, 0x01, 0x06, 0x03,
+ 0x08, 0x05, 0x05, 0x01, 0x05, 0x03, 0x08, 0x04,
+ 0x04, 0x01, 0x04, 0x03, 0x02, 0x01, 0x02, 0x03,
};
static const uint8_t cipher_list_tls13_aes[] = {
0xc0, 0x13, 0xc0, 0x09, 0x00, 0x9e, 0x00, 0x67,
0x00, 0x33, 0x00, 0xbe, 0x00, 0x45, 0x00, 0x9c,
0x00, 0x3c, 0x00, 0x2f, 0x00, 0xba, 0x00, 0x41,
- 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05, 0x00, 0x04,
- 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
- 0x00, 0xff
+ 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05, 0xc0, 0x12,
+ 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff,
};
static const uint8_t cipher_list_tls13_chacha[] = {
0xc0, 0x13, 0xc0, 0x09, 0x00, 0x9e, 0x00, 0x67,
0x00, 0x33, 0x00, 0xbe, 0x00, 0x45, 0x00, 0x9c,
0x00, 0x3c, 0x00, 0x2f, 0x00, 0xba, 0x00, 0x41,
- 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05, 0x00, 0x04,
- 0xc0, 0x12, 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a,
- 0x00, 0xff,
+ 0xc0, 0x11, 0xc0, 0x07, 0x00, 0x05, 0xc0, 0x12,
+ 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff,
};
static const uint8_t client_hello_tls13[] = {
- 0x16, 0x03, 0x01, 0x01, 0x1a, 0x01, 0x00, 0x01,
- 0x16, 0x03, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0x16, 0x03, 0x01, 0x01, 0x18, 0x01, 0x00, 0x01,
+ 0x14, 0x03, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x62, 0x13, 0x03,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x60, 0x13, 0x03,
0x13, 0x02, 0x13, 0x01, 0xcc, 0xa9, 0xcc, 0xa8,
0xcc, 0xaa, 0xc0, 0x30, 0xc0, 0x2c, 0xc0, 0x28,
0xc0, 0x24, 0xc0, 0x14, 0xc0, 0x0a, 0x00, 0x9f,
0xc0, 0x09, 0x00, 0x9e, 0x00, 0x67, 0x00, 0x33,
0x00, 0xbe, 0x00, 0x45, 0x00, 0x9c, 0x00, 0x3c,
0x00, 0x2f, 0x00, 0xba, 0x00, 0x41, 0xc0, 0x11,
- 0xc0, 0x07, 0x00, 0x05, 0x00, 0x04, 0xc0, 0x12,
- 0xc0, 0x08, 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff,
- 0x01, 0x00, 0x00, 0x6b, 0x00, 0x2b, 0x00, 0x09,
- 0x08, 0x03, 0x04, 0x03, 0x03, 0x03, 0x02, 0x03,
- 0x01, 0x00, 0x33, 0x00, 0x26, 0x00, 0x24, 0x00,
- 0x1d, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00,
+ 0xc0, 0x07, 0x00, 0x05, 0xc0, 0x12, 0xc0, 0x08,
+ 0x00, 0x16, 0x00, 0x0a, 0x00, 0xff, 0x01, 0x00,
+ 0x00, 0x6b, 0x00, 0x2b, 0x00, 0x09, 0x08, 0x03,
+ 0x04, 0x03, 0x03, 0x03, 0x02, 0x03, 0x01, 0x00,
+ 0x33, 0x00, 0x26, 0x00, 0x24, 0x00, 0x1d, 0x00,
+ 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x0b, 0x00, 0x02, 0x01,
- 0x00, 0x00, 0x0a, 0x00, 0x0a, 0x00, 0x08, 0x00,
- 0x1d, 0x00, 0x17, 0x00, 0x18, 0x00, 0x19, 0x00,
- 0x23, 0x00, 0x00, 0x00, 0x0d, 0x00, 0x18, 0x00,
- 0x16, 0x08, 0x06, 0x06, 0x01, 0x06, 0x03, 0x08,
- 0x05, 0x05, 0x01, 0x05, 0x03, 0x08, 0x04, 0x04,
- 0x01, 0x04, 0x03, 0x02, 0x01, 0x02, 0x03,
+ 0x00, 0x00, 0x0b, 0x00, 0x02, 0x01, 0x00, 0x00,
+ 0x0a, 0x00, 0x0a, 0x00, 0x08, 0x00, 0x1d, 0x00,
+ 0x17, 0x00, 0x18, 0x00, 0x19, 0x00, 0x23, 0x00,
+ 0x00, 0x00, 0x0d, 0x00, 0x18, 0x00, 0x16, 0x08,
+ 0x06, 0x06, 0x01, 0x06, 0x03, 0x08, 0x05, 0x05,
+ 0x01, 0x05, 0x03, 0x08, 0x04, 0x04, 0x01, 0x04,
+ 0x03, 0x02, 0x01, 0x02, 0x03,
};
static const uint8_t cipher_list_tls13_only_aes[] = {