diff --git a/libc-test/semver/linux.txt b/libc-test/semver/linux.txt index 73414fc86baf..0d7016076614 100644 --- a/libc-test/semver/linux.txt +++ b/libc-test/semver/linux.txt @@ -3366,6 +3366,12 @@ TLS_1_2_VERSION_MINOR TLS_1_3_VERSION TLS_1_3_VERSION_MAJOR TLS_1_3_VERSION_MINOR +TLS_CIPHER_AES_CCM_128 +TLS_CIPHER_AES_CCM_128_IV_SIZE +TLS_CIPHER_AES_CCM_128_KEY_SIZE +TLS_CIPHER_AES_CCM_128_REC_SEQ_SIZE +TLS_CIPHER_AES_CCM_128_SALT_SIZE +TLS_CIPHER_AES_CCM_128_TAG_SIZE TLS_CIPHER_AES_GCM_128 TLS_CIPHER_AES_GCM_128_IV_SIZE TLS_CIPHER_AES_GCM_128_KEY_SIZE @@ -3378,16 +3384,53 @@ TLS_CIPHER_AES_GCM_256_KEY_SIZE TLS_CIPHER_AES_GCM_256_REC_SEQ_SIZE TLS_CIPHER_AES_GCM_256_SALT_SIZE TLS_CIPHER_AES_GCM_256_TAG_SIZE +TLS_CIPHER_ARIA_GCM_128 +TLS_CIPHER_ARIA_GCM_128_IV_SIZE +TLS_CIPHER_ARIA_GCM_128_KEY_SIZE +TLS_CIPHER_ARIA_GCM_128_REC_SEQ_SIZE +TLS_CIPHER_ARIA_GCM_128_SALT_SIZE +TLS_CIPHER_ARIA_GCM_128_TAG_SIZE +TLS_CIPHER_ARIA_GCM_256 +TLS_CIPHER_ARIA_GCM_256_IV_SIZE +TLS_CIPHER_ARIA_GCM_256_KEY_SIZE +TLS_CIPHER_ARIA_GCM_256_REC_SEQ_SIZE +TLS_CIPHER_ARIA_GCM_256_SALT_SIZE +TLS_CIPHER_ARIA_GCM_256_TAG_SIZE TLS_CIPHER_CHACHA20_POLY1305 TLS_CIPHER_CHACHA20_POLY1305_IV_SIZE TLS_CIPHER_CHACHA20_POLY1305_KEY_SIZE TLS_CIPHER_CHACHA20_POLY1305_REC_SEQ_SIZE TLS_CIPHER_CHACHA20_POLY1305_SALT_SIZE TLS_CIPHER_CHACHA20_POLY1305_TAG_SIZE +TLS_CIPHER_SM4_CCM +TLS_CIPHER_SM4_CCM_IV_SIZE +TLS_CIPHER_SM4_CCM_KEY_SIZE +TLS_CIPHER_SM4_CCM_REC_SEQ_SIZE +TLS_CIPHER_SM4_CCM_SALT_SIZE +TLS_CIPHER_SM4_CCM_TAG_SIZE +TLS_CIPHER_SM4_GCM +TLS_CIPHER_SM4_GCM_IV_SIZE +TLS_CIPHER_SM4_GCM_KEY_SIZE +TLS_CIPHER_SM4_GCM_REC_SEQ_SIZE +TLS_CIPHER_SM4_GCM_SALT_SIZE +TLS_CIPHER_SM4_GCM_TAG_SIZE +TLS_CONF_BASE +TLS_CONF_HW +TLS_CONF_HW_RECORD +TLS_CONF_SW TLS_GET_RECORD_TYPE +TLS_INFO_CIPHER +TLS_INFO_RXCONF +TLS_INFO_RX_NO_PAD +TLS_INFO_TXCONF +TLS_INFO_UNSPEC +TLS_INFO_VERSION +TLS_INFO_ZC_RO_TX TLS_RX +TLS_RX_EXPECT_NO_PAD TLS_SET_RECORD_TYPE TLS_TX +TLS_TX_ZEROCOPY_RO TP_STATUS_AVAILABLE TP_STATUS_BLK_TMO TP_STATUS_COPY diff --git a/src/unix/linux_like/linux/mod.rs b/src/unix/linux_like/linux/mod.rs index fdc17e3daf43..5e4442a0c5c8 100644 --- a/src/unix/linux_like/linux/mod.rs +++ b/src/unix/linux_like/linux/mod.rs @@ -966,6 +966,14 @@ s! { pub rec_seq: [c_uchar; TLS_CIPHER_AES_GCM_256_REC_SEQ_SIZE], } + pub struct tls12_crypto_info_aes_ccm_128 { + pub info: tls_crypto_info, + pub iv: [c_uchar; TLS_CIPHER_AES_CCM_128_IV_SIZE], + pub key: [c_uchar; TLS_CIPHER_AES_CCM_128_KEY_SIZE], + pub salt: [c_uchar; TLS_CIPHER_AES_CCM_128_SALT_SIZE], + pub rec_seq: [c_uchar; TLS_CIPHER_AES_CCM_128_REC_SEQ_SIZE], + } + pub struct tls12_crypto_info_chacha20_poly1305 { pub info: tls_crypto_info, pub iv: [c_uchar; TLS_CIPHER_CHACHA20_POLY1305_IV_SIZE], @@ -974,6 +982,38 @@ s! { pub rec_seq: [c_uchar; TLS_CIPHER_CHACHA20_POLY1305_REC_SEQ_SIZE], } + pub struct tls12_crypto_info_sm4_gcm { + pub info: tls_crypto_info, + pub iv: [c_uchar; TLS_CIPHER_SM4_GCM_IV_SIZE], + pub key: [c_uchar; TLS_CIPHER_SM4_GCM_KEY_SIZE], + pub salt: [c_uchar; TLS_CIPHER_SM4_GCM_SALT_SIZE], + pub rec_seq: [c_uchar; TLS_CIPHER_SM4_GCM_REC_SEQ_SIZE], + } + + pub struct tls12_crypto_info_sm4_ccm { + pub info: tls_crypto_info, + pub iv: [c_uchar; TLS_CIPHER_SM4_CCM_IV_SIZE], + pub key: [c_uchar; TLS_CIPHER_SM4_CCM_KEY_SIZE], + pub salt: [c_uchar; TLS_CIPHER_SM4_CCM_SALT_SIZE], + pub rec_seq: [c_uchar; TLS_CIPHER_SM4_CCM_REC_SEQ_SIZE], + } + + pub struct tls12_crypto_info_aria_gcm_128 { + pub info: tls_crypto_info, + pub iv: [c_uchar; TLS_CIPHER_ARIA_GCM_128_IV_SIZE], + pub key: [c_uchar; TLS_CIPHER_ARIA_GCM_128_KEY_SIZE], + pub salt: [c_uchar; TLS_CIPHER_ARIA_GCM_128_SALT_SIZE], + pub rec_seq: [c_uchar; TLS_CIPHER_ARIA_GCM_128_REC_SEQ_SIZE], + } + + pub struct tls12_crypto_info_aria_gcm_256 { + pub info: tls_crypto_info, + pub iv: [c_uchar; TLS_CIPHER_ARIA_GCM_256_IV_SIZE], + pub key: [c_uchar; TLS_CIPHER_ARIA_GCM_256_KEY_SIZE], + pub salt: [c_uchar; TLS_CIPHER_ARIA_GCM_256_SALT_SIZE], + pub rec_seq: [c_uchar; TLS_CIPHER_ARIA_GCM_256_REC_SEQ_SIZE], + } + // linux/wireless.h pub struct iw_param { @@ -4681,6 +4721,9 @@ pub const PTP_PF_PHYSYNC: c_uint = 3; pub const TLS_TX: c_int = 1; pub const TLS_RX: c_int = 2; +pub const TLS_TX_ZEROCOPY_RO: c_int = 3; +pub const TLS_RX_EXPECT_NO_PAD: c_int = 4; + pub const TLS_1_2_VERSION_MAJOR: __u8 = 0x3; pub const TLS_1_2_VERSION_MINOR: __u8 = 0x3; pub const TLS_1_2_VERSION: __u16 = @@ -4705,6 +4748,13 @@ pub const TLS_CIPHER_AES_GCM_256_SALT_SIZE: usize = 4; pub const TLS_CIPHER_AES_GCM_256_TAG_SIZE: usize = 16; pub const TLS_CIPHER_AES_GCM_256_REC_SEQ_SIZE: usize = 8; +pub const TLS_CIPHER_AES_CCM_128: __u16 = 53; +pub const TLS_CIPHER_AES_CCM_128_IV_SIZE: usize = 8; +pub const TLS_CIPHER_AES_CCM_128_KEY_SIZE: usize = 16; +pub const TLS_CIPHER_AES_CCM_128_SALT_SIZE: usize = 4; +pub const TLS_CIPHER_AES_CCM_128_TAG_SIZE: usize = 16; +pub const TLS_CIPHER_AES_CCM_128_REC_SEQ_SIZE: usize = 8; + pub const TLS_CIPHER_CHACHA20_POLY1305: __u16 = 54; pub const TLS_CIPHER_CHACHA20_POLY1305_IV_SIZE: usize = 12; pub const TLS_CIPHER_CHACHA20_POLY1305_KEY_SIZE: usize = 32; @@ -4712,11 +4762,53 @@ pub const TLS_CIPHER_CHACHA20_POLY1305_SALT_SIZE: usize = 0; pub const TLS_CIPHER_CHACHA20_POLY1305_TAG_SIZE: usize = 16; pub const TLS_CIPHER_CHACHA20_POLY1305_REC_SEQ_SIZE: usize = 8; +pub const TLS_CIPHER_SM4_GCM: __u16 = 55; +pub const TLS_CIPHER_SM4_GCM_IV_SIZE: usize = 8; +pub const TLS_CIPHER_SM4_GCM_KEY_SIZE: usize = 16; +pub const TLS_CIPHER_SM4_GCM_SALT_SIZE: usize = 4; +pub const TLS_CIPHER_SM4_GCM_TAG_SIZE: usize = 16; +pub const TLS_CIPHER_SM4_GCM_REC_SEQ_SIZE: usize = 8; + +pub const TLS_CIPHER_SM4_CCM: __u16 = 56; +pub const TLS_CIPHER_SM4_CCM_IV_SIZE: usize = 8; +pub const TLS_CIPHER_SM4_CCM_KEY_SIZE: usize = 16; +pub const TLS_CIPHER_SM4_CCM_SALT_SIZE: usize = 4; +pub const TLS_CIPHER_SM4_CCM_TAG_SIZE: usize = 16; +pub const TLS_CIPHER_SM4_CCM_REC_SEQ_SIZE: usize = 8; + +pub const TLS_CIPHER_ARIA_GCM_128: __u16 = 57; +pub const TLS_CIPHER_ARIA_GCM_128_IV_SIZE: usize = 8; +pub const TLS_CIPHER_ARIA_GCM_128_KEY_SIZE: usize = 16; +pub const TLS_CIPHER_ARIA_GCM_128_SALT_SIZE: usize = 4; +pub const TLS_CIPHER_ARIA_GCM_128_TAG_SIZE: usize = 16; +pub const TLS_CIPHER_ARIA_GCM_128_REC_SEQ_SIZE: usize = 8; + +pub const TLS_CIPHER_ARIA_GCM_256: __u16 = 58; +pub const TLS_CIPHER_ARIA_GCM_256_IV_SIZE: usize = 8; +pub const TLS_CIPHER_ARIA_GCM_256_KEY_SIZE: usize = 32; +pub const TLS_CIPHER_ARIA_GCM_256_SALT_SIZE: usize = 4; +pub const TLS_CIPHER_ARIA_GCM_256_TAG_SIZE: usize = 16; +pub const TLS_CIPHER_ARIA_GCM_256_REC_SEQ_SIZE: usize = 8; + pub const TLS_SET_RECORD_TYPE: c_int = 1; pub const TLS_GET_RECORD_TYPE: c_int = 2; pub const SOL_TLS: c_int = 282; +// enum +pub const TLS_INFO_UNSPEC: c_int = 0x00; +pub const TLS_INFO_VERSION: c_int = 0x01; +pub const TLS_INFO_CIPHER: c_int = 0x02; +pub const TLS_INFO_TXCONF: c_int = 0x03; +pub const TLS_INFO_RXCONF: c_int = 0x04; +pub const TLS_INFO_ZC_RO_TX: c_int = 0x05; +pub const TLS_INFO_RX_NO_PAD: c_int = 0x06; + +pub const TLS_CONF_BASE: c_int = 1; +pub const TLS_CONF_SW: c_int = 2; +pub const TLS_CONF_HW: c_int = 3; +pub const TLS_CONF_HW_RECORD: c_int = 4; + // linux/if_alg.h pub const ALG_SET_KEY: c_int = 1; pub const ALG_SET_IV: c_int = 2;