/* Copyright (C) 2015-2017 Jason A. Donenfeld . All Rights Reserved. */ #include "version.h" #include "device.h" #include "noise.h" #include "packets.h" #include "ratelimiter.h" #include "crypto/chacha20poly1305.h" #include "crypto/blake2s.h" #include "crypto/curve25519.h" #include #include #include #include static int __init mod_init(void) { int ret; chacha20poly1305_fpu_init(); blake2s_fpu_init(); curve25519_fpu_init(); #ifdef DEBUG if (!routing_table_selftest() || !packet_counter_selftest() || !curve25519_selftest() || !chacha20poly1305_selftest() || !blake2s_selftest() || !ratelimiter_selftest()) return -ENOTRECOVERABLE; #endif noise_init(); ret = init_crypt_ctx_cache(); if (ret < 0) goto err_packet; ret = device_init(); if (ret < 0) goto err_device; pr_info("WireGuard " WIREGUARD_VERSION " loaded. See www.wireguard.com for information.\n"); pr_info("Copyright (C) 2015-2017 Jason A. Donenfeld . All Rights Reserved.\n"); return 0; err_device: deinit_crypt_ctx_cache(); err_packet: return ret; } static void __exit mod_exit(void) { device_uninit(); deinit_crypt_ctx_cache(); pr_debug("WireGuard unloaded\n"); } module_init(mod_init); module_exit(mod_exit); MODULE_LICENSE("GPL v2"); MODULE_DESCRIPTION("Fast, secure, and modern VPN tunnel"); MODULE_AUTHOR("Jason A. Donenfeld "); MODULE_VERSION(WIREGUARD_VERSION); MODULE_ALIAS_RTNL_LINK(KBUILD_MODNAME);