cregit-Linux how code gets into the kernel

Release 4.8 net/core/secure_seq.c

Directory: net/core
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/cryptohash.h>
#include <linux/module.h>
#include <linux/cache.h>
#include <linux/random.h>
#include <linux/hrtimer.h>
#include <linux/ktime.h>
#include <linux/string.h>
#include <linux/net.h>

#include <net/secure_seq.h>

#if IS_ENABLED(CONFIG_IPV6) || IS_ENABLED(CONFIG_INET)

#define NET_SECRET_SIZE (MD5_MESSAGE_BYTES / 4)


static u32 net_secret[NET_SECRET_SIZE] ____cacheline_aligned;


static __always_inline void net_secret_init(void) { net_get_random_once(net_secret, sizeof(net_secret)); }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller1052.63%120.00%
eric dumazeteric dumazet631.58%240.00%
hannes frederic sowahannes frederic sowa315.79%240.00%
Total19100.00%5100.00%

#endif #ifdef CONFIG_INET
static u32 seq_scale(u32 seq) { /* * As close as possible to RFC 793, which * suggests using a 250 kHz clock. * Further reading shows this assumes 2 Mb/s networks. * For 10 Mb/s Ethernet, a 1 MHz clock is appropriate. * For 10 Gb/s Ethernet, a 1 GHz clock should be ok, but * we also need to limit the resolution so that the u32 seq * overlaps less than one time per MSL (2 minutes). * Choosing a clock of 64 ns period is OK. (period of 274 s) */ return seq + (ktime_get_real_ns() >> 6); }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller1995.00%150.00%
eric dumazeteric dumazet15.00%150.00%
Total20100.00%2100.00%

#endif #if IS_ENABLED(CONFIG_IPV6)
__u32 secure_tcpv6_sequence_number(const __be32 *saddr, const __be32 *daddr, __be16 sport, __be16 dport) { u32 secret[MD5_MESSAGE_BYTES / 4]; u32 hash[MD5_DIGEST_WORDS]; u32 i; net_secret_init(); memcpy(hash, saddr, 16); for (i = 0; i < 4; i++) secret[i] = net_secret[i] + (__force u32)daddr[i]; secret[4] = net_secret[4] + (((__force u16)sport << 16) + (__force u16)dport); for (i = 5; i < MD5_MESSAGE_BYTES / 4; i++) secret[i] = net_secret[i]; md5_transform(hash, secret); return seq_scale(hash[0]); }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller14294.04%125.00%
eric dumazeteric dumazet95.96%375.00%
Total151100.00%4100.00%

EXPORT_SYMBOL(secure_tcpv6_sequence_number);
u32 secure_ipv6_port_ephemeral(const __be32 *saddr, const __be32 *daddr, __be16 dport) { u32 secret[MD5_MESSAGE_BYTES / 4]; u32 hash[MD5_DIGEST_WORDS]; u32 i; net_secret_init(); memcpy(hash, saddr, 16); for (i = 0; i < 4; i++) secret[i] = net_secret[i] + (__force u32) daddr[i]; secret[4] = net_secret[4] + (__force u32)dport; for (i = 5; i < MD5_MESSAGE_BYTES / 4; i++) secret[i] = net_secret[i]; md5_transform(hash, secret); return hash[0]; }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller13097.74%150.00%
eric dumazeteric dumazet32.26%150.00%
Total133100.00%2100.00%

EXPORT_SYMBOL(secure_ipv6_port_ephemeral); #endif #ifdef CONFIG_INET
__u32 secure_tcp_sequence_number(__be32 saddr, __be32 daddr, __be16 sport, __be16 dport) { u32 hash[MD5_DIGEST_WORDS]; net_secret_init(); hash[0] = (__force u32)saddr; hash[1] = (__force u32)daddr; hash[2] = ((__force u16)sport << 16) + (__force u16)dport; hash[3] = net_secret[15]; md5_transform(hash, net_secret); return seq_scale(hash[0]); }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller9296.84%150.00%
eric dumazeteric dumazet33.16%150.00%
Total95100.00%2100.00%


u32 secure_ipv4_port_ephemeral(__be32 saddr, __be32 daddr, __be16 dport) { u32 hash[MD5_DIGEST_WORDS]; net_secret_init(); hash[0] = (__force u32)saddr; hash[1] = (__force u32)daddr; hash[2] = (__force u32)dport ^ net_secret[14]; hash[3] = net_secret[15]; md5_transform(hash, net_secret); return hash[0]; }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller8196.43%150.00%
eric dumazeteric dumazet33.57%150.00%
Total84100.00%2100.00%

EXPORT_SYMBOL_GPL(secure_ipv4_port_ephemeral); #endif #if IS_ENABLED(CONFIG_IP_DCCP)
u64 secure_dccp_sequence_number(__be32 saddr, __be32 daddr, __be16 sport, __be16 dport) { u32 hash[MD5_DIGEST_WORDS]; u64 seq; net_secret_init(); hash[0] = (__force u32)saddr; hash[1] = (__force u32)daddr; hash[2] = ((__force u16)sport << 16) + (__force u16)dport; hash[3] = net_secret[15]; md5_transform(hash, net_secret); seq = hash[0] | (((u64)hash[1]) << 32); seq += ktime_get_real_ns(); seq &= (1ull << 48) - 1; return seq; }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller12496.88%133.33%
eric dumazeteric dumazet43.12%266.67%
Total128100.00%3100.00%

EXPORT_SYMBOL(secure_dccp_sequence_number); #if IS_ENABLED(CONFIG_IPV6)
u64 secure_dccpv6_sequence_number(__be32 *saddr, __be32 *daddr, __be16 sport, __be16 dport) { u32 secret[MD5_MESSAGE_BYTES / 4]; u32 hash[MD5_DIGEST_WORDS]; u64 seq; u32 i; net_secret_init(); memcpy(hash, saddr, 16); for (i = 0; i < 4; i++) secret[i] = net_secret[i] + (__force u32)daddr[i]; secret[4] = net_secret[4] + (((__force u16)sport << 16) + (__force u16)dport); for (i = 5; i < MD5_MESSAGE_BYTES / 4; i++) secret[i] = net_secret[i]; md5_transform(hash, secret); seq = hash[0] | (((u64)hash[1]) << 32); seq += ktime_get_real_ns(); seq &= (1ull << 48) - 1; return seq; }

Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller17495.60%125.00%
eric dumazeteric dumazet84.40%375.00%
Total182100.00%4100.00%

EXPORT_SYMBOL(secure_dccpv6_sequence_number); #endif #endif

Overall Contributors

PersonTokensPropCommitsCommitProp
david s. millerdavid s. miller85592.03%17.14%
eric dumazeteric dumazet444.74%750.00%
fabio estevamfabio estevam131.40%17.14%
hannes frederic sowahannes frederic sowa60.65%214.29%
patrick mchardypatrick mchardy50.54%17.14%
stephen boydstephen boyd50.54%17.14%
igor maravicigor maravic10.11%17.14%
Total929100.00%14100.00%
Directory: net/core
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.