freebsd-nq/sys/arm
Kyle Evans 251a32b5b2 tun/tap: merge and rename to tuntap
tun(4) and tap(4) share the same general management interface and have a lot
in common. Bugs exist in tap(4) that have been fixed in tun(4), and
vice-versa. Let's reduce the maintenance requirements by merging them
together and using flags to differentiate between the three interface types
(tun, tap, vmnet).

This fixes a couple of tap(4)/vmnet(4) issues right out of the gate:
- tap devices may no longer be destroyed while they're open [0]
- VIMAGE issues already addressed in tun by kp

[0] emaste had removed an easy-panic-button in r240938 due to devdrn
blocking. A naive glance over this leads me to believe that this isn't quite
complete -- destroy_devl will only block while executing d_* functions, but
doesn't block the device from being destroyed while a process has it open.
The latter is the intent of the condvar in tun, so this is "fixed" (for
certain definitions of the word -- it wasn't really broken in tap, it just
wasn't quite ideal).

ifconfig(8) also grew the ability to map an interface name to a kld, so
that `ifconfig {tun,tap}0` can continue to autoload the correct module, and
`ifconfig vmnet0 create` will now autoload the correct module. This is a
low overhead addition.

(MFC commentary)

This may get MFC'd if many bugs in tun(4)/tap(4) are discovered after this,
and how critical they are. Changes after this are likely easily MFC'd
without taking this merge, but the merge will be easier.

I have no plans to do this MFC as of now.

Reviewed by:	bcr (manpages), tuexen (testing, syzkaller/packetdrill)
Input also from:	melifaro
Relnotes:	yes
Differential Revision:	https://reviews.freebsd.org/D20044
2019-05-08 02:32:11 +00:00
..
allwinner arm: allwinner: a10: Correct pin functions 2019-04-27 14:59:08 +00:00
altera/socfpga arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
amlogic/aml8726 arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
annapurna/alpine arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
arm Only set up the interrupts that will actually be used in arm generic_timer. 2019-04-17 15:27:11 +00:00
broadcom/bcm2835 Move the reporting of spurious interrupts under bootverbose control, because 2019-04-21 17:39:01 +00:00
cloudabi32 Remove sv_pagesize, originally introduced with r100384. 2019-03-01 16:16:38 +00:00
conf tun/tap: merge and rename to tuntap 2019-05-08 02:32:11 +00:00
freescale arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
include Use named field's initializer when constructing <foo>_platform structure. 2019-03-19 14:32:54 +00:00
mv arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
nvidia arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
qemu arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
ralink arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
rockchip arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
samsung/exynos arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
ti arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
versatile arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00
xilinx arm: Add kern_clocksource.c directly in files.arm 2019-04-16 20:04:22 +00:00