diff options
Diffstat (limited to 'drivers/char/random.c')
-rw-r--r-- | drivers/char/random.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/drivers/char/random.c b/drivers/char/random.c index 6b11d6b2129f..7999da25fe40 100644 --- a/drivers/char/random.c +++ b/drivers/char/random.c | |||
@@ -1589,6 +1589,40 @@ u32 secure_tcpv6_port_ephemeral(const __u32 *saddr, const __u32 *daddr, __u16 dp | |||
1589 | EXPORT_SYMBOL(secure_tcpv6_port_ephemeral); | 1589 | EXPORT_SYMBOL(secure_tcpv6_port_ephemeral); |
1590 | #endif | 1590 | #endif |
1591 | 1591 | ||
1592 | #if defined(CONFIG_IP_DCCP) || defined(CONFIG_IP_DCCP_MODULE) | ||
1593 | /* Similar to secure_tcp_sequence_number but generate a 48 bit value | ||
1594 | * bit's 32-47 increase every key exchange | ||
1595 | * 0-31 hash(source, dest) | ||
1596 | */ | ||
1597 | u64 secure_dccp_sequence_number(__u32 saddr, __u32 daddr, | ||
1598 | __u16 sport, __u16 dport) | ||
1599 | { | ||
1600 | struct timeval tv; | ||
1601 | u64 seq; | ||
1602 | __u32 hash[4]; | ||
1603 | struct keydata *keyptr = get_keyptr(); | ||
1604 | |||
1605 | hash[0] = saddr; | ||
1606 | hash[1] = daddr; | ||
1607 | hash[2] = (sport << 16) + dport; | ||
1608 | hash[3] = keyptr->secret[11]; | ||
1609 | |||
1610 | seq = half_md4_transform(hash, keyptr->secret); | ||
1611 | seq |= ((u64)keyptr->count) << (32 - HASH_BITS); | ||
1612 | |||
1613 | do_gettimeofday(&tv); | ||
1614 | seq += tv.tv_usec + tv.tv_sec * 1000000; | ||
1615 | seq &= (1ull << 48) - 1; | ||
1616 | #if 0 | ||
1617 | printk("dccp init_seq(%lx, %lx, %d, %d) = %d\n", | ||
1618 | saddr, daddr, sport, dport, seq); | ||
1619 | #endif | ||
1620 | return seq; | ||
1621 | } | ||
1622 | |||
1623 | EXPORT_SYMBOL(secure_dccp_sequence_number); | ||
1624 | #endif | ||
1625 | |||
1592 | #endif /* CONFIG_INET */ | 1626 | #endif /* CONFIG_INET */ |
1593 | 1627 | ||
1594 | 1628 | ||