File: tls.h

package info (click to toggle)
trinity 1.9%2Bgit20230109.87f1530-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 3,116 kB
  • sloc: ansic: 33,463; sh: 536; makefile: 163
file content (32 lines) | stat: -rw-r--r-- 1,011 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#pragma once

/* From linux/tls.h */
struct tls_crypto_info {
	unsigned short version;
	unsigned short cipher_type;
};

#define TLS_CIPHER_AES_GCM_128_IV_SIZE 8
#define TLS_CIPHER_AES_GCM_128_KEY_SIZE 16
#define TLS_CIPHER_AES_GCM_128_SALT_SIZE 4
#define TLS_CIPHER_AES_GCM_128_REC_SEQ_SIZE 8

#define TLS_VERSION_MINOR(ver)  ((ver) & 0xFF)
#define TLS_VERSION_MAJOR(ver)  (((ver) >> 8) & 0xFF)
#define TLS_VERSION_NUMBER(id)  ((((id##_VERSION_MAJOR) & 0xFF) << 8) | \
                                 ((id##_VERSION_MINOR) & 0xFF))
#define TLS_1_2_VERSION_MAJOR   0x3
#define TLS_1_2_VERSION_MINOR   0x3
#define TLS_1_2_VERSION         TLS_VERSION_NUMBER(TLS_1_2)

#define TLS_CIPHER_AES_GCM_128 51

#define TLS_TX 1

struct tls12_crypto_info_aes_gcm_128 {
	struct tls_crypto_info info;
	unsigned char iv[TLS_CIPHER_AES_GCM_128_IV_SIZE];
	unsigned char key[TLS_CIPHER_AES_GCM_128_KEY_SIZE];
	unsigned char salt[TLS_CIPHER_AES_GCM_128_SALT_SIZE];
	unsigned char rec_seq[TLS_CIPHER_AES_GCM_128_REC_SEQ_SIZE];
};