Commit graph

39 commits

Author SHA1 Message Date
Kevin Darbyshire-Bryant
4168cdd460 wireguard: bump to release 0.0.20170810
Compile & run tested: ar71xx: archer c7 v2

Signed-off-by: Kevin Darbyshire-Bryant <kevin@darbyshire-bryant.me.uk>
2017-08-10 09:17:54 +01:00
Jason A. Donenfeld
19e9fbaa70 wireguard: version bump
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-07-31 18:45:59 +02:00
Jason A. Donenfeld
132287156d wireguard: version bump
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-07-07 16:21:24 +02:00
Jason A. Donenfeld
4d0d9ac3f9 wireguard: assume /32 or /128 if no CIDR is given
This brings the route_allowed_ips option into parity with the addresses
option, which makes these same assumption. The parsing selection is made
to be identical between these two settings.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-07-07 16:19:50 +02:00
Jason A. Donenfeld
404657ee8a wireguard: version bump
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-06-29 21:37:14 +02:00
Jason A. Donenfeld
09148df173 wireguard: version bump
From upstream's changelog:

  * main: annotate init/exit functions to save memory
  * selftest: remove antique siphash self test
  * haskell: re-add updated haskell example
  * socket: use ip_rt_put instead of dst_release
  * device: avoid double icmp send on routing loop
  * compat: clean up cruft
  * global: cleanup IP header checking
  * compat: do not export symbols unnecessarily
  
  Various cleanups and updates.
  
  * device: netdevice destruction logic change for 4.12
  
  When Linux 4.12 is released next week, we're good to go.
  
  * device: only use one sleep notifier
  
  Rather than have a separate sleep notification for every interface, we now
  have a single notifier for every interface. This improves performance,
  especially when creating many interfaces at once.
  
  * device: remove icmp conntrack hacks
  
  We're moving hacks upstream the proper way, and then backporting them to
  compat.
  
  * receive: extend rate limiting to 1 second after under load detection
  
  After we determine that we're under load, we now wait 1 second before not
  being under load again, a timer which is global across all interfaces on a
  given system.
  
  * curve25519: satisfy sparse and use short types
  * curve25519: keep certain sandy2x functions in C
  
  Certain functions have been made into C, which should improve stack frames and
  reliability.
  
  * ratelimiter: rewrite from scratch
  
  This is a big change. We no longer rely on x_tables or xt_hashlimit, instead
  using a super minimal and sleek token bucket ratelimiter. This works much
  better than the old cruft and should allow us to run more places. It also has
  the benefit of being global, so that it's possible to have thousands of
  interfaces without killing the system with separate GCs and vmallocs, which is
  what happened prior.
  
  * socket: verify saddr belongs to interface
  
  We now more quickly react to changes of the v4 routing table, by ensuring that
  the sticky source address is actually still valid.
  
  * wg-quick: properly match IPv6 endpoint
  
  wg-quick now works better with IPv6.
  
  * wg-quick: use printf -v instead of namerefs for bash 4.2
  
  This adds support for old bash, which means wg-quick should be generically
  "bash 4 and up". I'm not happy about this but EL7 uses old bash, so we're
  stuck with it.
  
  * compat: support EL7.3
  
  Support for RHEL, CentOS, ScientificLinux, and so forth.
  
  * compat: support Ubuntu 14.04
  
  An old crufty Ubuntu is now supported, since it's LTS.
2017-06-28 14:57:04 +02:00
Jason A. Donenfeld
de97e29328 wireguard: remove misspelled debugging line
There are no other "echo" debug lines in this file, and it seems
clear that this one was accidentally left as a debugging line,
since it misspelled "dependency". So, we just remove this line.

We don't bump the package version, though, because this is
pretty inconsequential.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-06-14 03:15:27 +02:00
Jason A. Donenfeld
c833b249a9 wireguard: version bump
From upstream's changelog:

  * timers: queue up killing ephemerals only if not already

  We fix up a small detail in the timer logic that changed during the last
  snapshot.

  * receive: trim incoming packets to IP header length

  Packets are now trimmed to their actual length, not their length+padding,
  before handing to the rest of the network subsystem, so that packets look
  pretty in tcpdump. This doesn't actually affect what userspace sees, since the
  kernel trims it at a later stage, but it does make pcaps a bit nicer to use.

  * curve25519: use more standard label convention in asm

  This ensures that perf(1) shows the function name instead of the label name.

  * compat: remove padata hotplug code

  Fixes building on kernels that have HOTPLUG enabled but no PADATA support.

  * config: add new line for style
  * device: do-while assignment style
  * peer: explicitly initialize atomic

  Style.

  * noise: fix race when replacing handshake

  Handle a situation in which three peers, all running on the same system, begin
  a handshake with all three of each other, at exactly the same time, on a
  multi-CPU system.

  * random: wait for random bytes when generating nonces and ephemerals

  We've been working with upstream to add a new API to the kernel for ensuring
  that the RNG actually is seeded. Until they merge it for 4.13, we provide a
  poly-fill to the compat code. This means that WireGuard will block during
  handshakes until the RNG has enough entropy, so that it's never in a
  circumstance in which ephemeral keys are generated from bad randomness.

  * go test: properly pad message
  * go test: correct tai64n and formatting
  * external-tests: add keepalive packet
  * go test: use x/crypto for blake2s now that we have 128-bit mac
  * external-tests: trim the fat

  Improvements for the external tests.

  * wg-quick: make sure we have empty table for both v6 and v4
  * wg-quick: match ipv6 default route more broadly

  Tiny nits with wg-quick, one of which should now allow multiple v6-only
  wg-quick instances running at the same time.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-06-13 15:35:26 +02:00
danrl
a9f39cff42 wireguard: version bump
From upstreams changelog:
 This rather large snapshot touches quite a few sensitive areas, so I'm
  releasing it now rather than later to receive feedback on any possible issues.
  It also contains fixes, so everybody should upgrade.

  * man: fix psk mention in wg-quick man page
  * man: update wg-quick(8) to show Debian resolvconf braindamage

  Documentation cleanups.

  * wg-quick: use src routing for default routes in v6

  ip-rule(8) doesn't do the right thing with source addresses, unless we
  explicitly set it inside the route. This fixes wg-quick on IPv6 systems.

  * curve25519: actually, do some things on heap sometimes
  * curve25519: align the basepoint to 32 bytes
  * curve25519: add NEON versions for ARM
  * data: enable BH during parallel crypto on ARM/NEON
  * chacha20poly1305: move constants to rodata
  * chacha20poly1305: add NEON versions for ARM and ARM64

  We now have faster primitives on ARM and ARM64 processors, which should
  improve performance.

  * handshake: process in parallel

  Handshakes are now processed in parallel using all cores, which should improve
  throughput during a storm.

  * noise: no need to store ephemeral public key
  * noise: precompute static-static ECDH operation

  We can precompute the ECDH(s, s) calculation, which improves handshake
  initiation message performance by double.

  * style: spaces after for loops
  * peer: use iterator macro instead of callback

  The most unreadable C ever produced. It might be wise to find a sexier-looking
  alternative at some point.

  * compat: remove warning for < 4.1
  * compat: ship padata if kernel doesn't have it

  The usual array of annoying compat things.

  * rust test: convert screech test to snow
  * rust test: add icmp ping

  We now use Jake's snow library for Noise in the test, which we've expanded to
  complete a ping.

  * config: do not error out when getting if no peers
  * tools: allow creating device with no peers

  Fixing some small things in the tool/config interaction.

  * device: keep going when share_check fails
  * routingtable: remove unnecessary check in node_placement()
  * config: it's faster to memcpy than strncpy
  * timers: fix typo in comment

  Nits.

  * debug: print interface name in dmesg

  For those who compile with `make debug`, you'll be happy to see a bit better
  information in dmesg.

  * timers: rework handshake reply control flow
  * timers: the completion of a handshake also is on key confirmation
  * timers: reset retry-attempt counter when not retrying

  Tightening up our timer implementation, which is quite important.

Signed-off-by: Dan Luedtke <mail@danrl.com>
2017-06-01 10:54:25 +02:00
Jason A. Donenfeld
1eeea05307 wireguard: version bump
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-05-17 20:21:36 +02:00
Jason A. Donenfeld
658ffbb3fd wireguard: preshared-key is now an attribute of the peer
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-05-09 16:51:34 +02:00
Jason A. Donenfeld
39af272f36 net/wireguard: update to 0.0.20170421
Simple version bump.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-04-21 06:22:51 +02:00
Jason A. Donenfeld
ac90f93973 net/wireguard: version bump
Simple version bump to 20170409.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-04-09 16:37:55 +02:00
Jason A. Donenfeld
056aeb26fc net/wireguard: version bump
Simple version bump to 20170324.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-03-24 05:03:56 +01:00
Jason A. Donenfeld
db983cc080 net/wireguard: version bump
Simple version bump to 20170320.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-03-20 04:19:58 +01:00
danrl
7a255f29f1 net/wireguard: add support for fwmark option
Adds support for the fwmark option.

FwMark is a 32-bit fwmark for outgoing packets.
If set to 0 or "off", this option is disabled.

Signed-off-by: Dan Luedtke <mail@danrl.com>
2017-02-27 20:44:33 +01:00
danrl
5d961f28c9 wireguard: version bump
Signed-off-by: Dan Luedtke <mail@danrl.com>
2017-02-23 16:46:41 +01:00
Jason A. Donenfeld
fd8a7479cf net/wireguard: add stub install section
This is in response to the metapackage discussion in openwrt/luci#1030.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-02-21 12:37:22 +01:00
Sven Roederer
0cc3e97f66 wireguard: move into VPN-submenu
Wireguard is a VPN-implementation and should
be located in VPN-submenu

Signed-off-by: Sven Roederer <freifunk@it-solutions.geroedel.de>
2017-02-18 01:49:46 +01:00
Jason A. Donenfeld
d1564042ef wireguard: simple package bump to 0.0.20170214
While I'm at it, add myself as maintainer, since I'm doing many of the
bumps anyway.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2017-02-14 19:45:45 +08:00
danrl
e0c2f5bdc8 wireguard: new version and usability improvements
Signed-off-by: Dan Luedtke <mail@danrl.com>
2017-01-16 11:20:07 +08:00
danrl
65cd2a6e43 wireguard: version bump
Signed-off-by: Dan Luedtke <mail@danrl.com>
2017-01-11 21:09:11 +01:00
Jason A. Donenfeld
37425e787e net/wireguard: update to 0.0.20161230
Simple version bump; no changes needed other than filename and hash.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2016-12-31 03:26:08 +01:00
Jason A. Donenfeld
52039ed443 net/wireguard: version bump
Update to a new wireguard version. Simple version bump.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com>
2016-12-24 14:48:44 +08:00
danrl
7d34e8e5f4 wireguard: add protocol dependency for endpoints
Endpoint dependency implemented. The actual endpoint is used exclusively. Using
this approach we are dual-stack safe (not errors on missing protocol) and create
only the dependency that are really necessary.

Signed-off-by: Dan Luedtke <mail@danrl.com>
2016-12-24 14:33:00 +08:00
Jason A. Donenfeld
c3f5ca5683 net/wireguard: version bump
Update to new snapshot version. We also make IPV6 optional, and
conditionally selecting the udptunnel6 module, using the same trick that
the strongswan package also uses for this kind of dependency expression.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2016-12-18 18:36:54 +01:00
Jason A. Donenfeld
f8916c2f33 net/wireguard: version bump
Update to new snapshot version.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
2016-11-29 23:52:01 +01:00
viisauksena
a56138a8cd net/wireguard - bump to experimental-0.0.20161116.1
use latest tag https://git.zx2c4.com/WireGuard/tag/?h=experimental-0.0.20161116.1
Maintainer @zorun
Signed-off-by: Jens Viisauksena <wireguard@viisauksena.de>
2016-11-23 03:10:08 +01:00
danrl
c5a6eb25d9 wireguard-tools: Add missing directory
fixes issue #3515

Signed-off-by: Dan Luedtke <mail@danrl.com>
2016-11-16 11:02:44 +01:00
danrl
124ee5c30d wireguard-tools: Add netifd protocol helper
Signed-off-by: Dan Luedtke <mail@danrl.com>
2016-11-15 16:45:12 +01:00
Baptiste Jonglez
ff769f54b0 wireguard: Bump to 0.0.20161110
Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-11-14 00:25:12 +01:00
Baptiste Jonglez
70c72dc0cf wireguard: Bump to 0.0.20161105
Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-11-07 22:55:09 +01:00
Baptiste Jonglez
766b146fbe wireguard: Bump to 0.0.20161103
Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-11-03 21:53:59 +01:00
Baptiste Jonglez
0c60737b38 wireguard: Bump to 0.0.20161025
Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-10-29 23:20:26 +02:00
Baptiste Jonglez
c5d9fa8fb9 wireguard: Bump to 0.0.20161001
This should massively improve performance for (at least) MIPS targets:

    * poly1305: optimize unaligned access

    This is a very appreciated fix from René van Dorst, adjusting the
    arithmetic in Poly1305 to work fast on platforms with slow unaligned
    access, such as MIPS. According to his calculation, this gives a 50%
    improvement on small MIPS boxes.

Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-10-01 01:44:08 +02:00
Baptiste Jonglez
3f2be1ad5c wireguard: Bump to 0.0.20160722
Also fix a new compilation error, due to upstream changes in the build
system.  SUBDIRS= is deprecated when building external kernel modules, use
M= instead to fix compilation.

Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-07-23 14:02:24 +02:00
Baptiste Jonglez
d0e989aa3c wireguard: Bump to 0.0.20160711
Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-07-17 23:03:20 +02:00
Baptiste Jonglez
b960814cd4 wireguard: Bump to 0.0.20160708.1
Also add the SHA256 checksum, since upstream now publishes it when releasing:

  https://lists.zx2c4.com/pipermail/wireguard/2016-July/000196.html

Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-07-10 14:18:30 +02:00
Baptiste Jonglez
facf22d31f wireguard: Initial upload
Signed-off-by: Baptiste Jonglez <git@bitsofnetworks.org>
2016-07-02 19:00:31 +02:00