xref: /freebsd/sbin/devd/hyperv.conf (revision a0409676120c1e558d0ade943019934e0f15118d)
1# $FreeBSD$
2#
3# Hyper-V specific events
4
5notify 10 {
6	match "system"		"DEVFS";
7	match "subsystem"	"CDEV";
8	match "type"		"CREATE";
9	match "cdev"		"hv_kvp_dev";
10	action "/usr/sbin/hv_kvp_daemon";
11};
12
13notify 10 {
14	match "system"		"DEVFS";
15	match "subsystem"	"CDEV";
16	match "type"		"DESTROY";
17	match "cdev"		"hv_kvp_dev";
18	action "pkill -x hv_kvp_daemon";
19};
20
21notify 11 {
22	match "system"		"DEVFS";
23	match "subsystem"	"CDEV";
24	match "type"		"CREATE";
25	match "cdev"		"hv_fsvss_dev";
26	action "/usr/sbin/hv_vss_daemon";
27};
28
29notify 11 {
30	match "system"		"DEVFS";
31	match "subsystem"	"CDEV";
32	match "type"		"DESTROY";
33	match "cdev"		"hv_fsvss_dev";
34	action "pkill -x hv_vss_daemon";
35};
36
37#
38# Rules for non-transparent network VF.
39#
40# How network VF works with hn(4) on Hyper-V in non-transparent mode:
41#
42# - Each network VF has a corresponding hn(4).
43# - The network VF and the it's corresponding hn(4) have the same hardware
44#   address.
45# - Once the network VF is up, e.g. ifconfig VF up:
46#   o  All of the transmission should go through the network VF.
47#   o  Most of the reception goes through the network VF.
48#   o  Small amount of reception may go through the corresponding hn(4).
49#      This reception will happen, even if the corresponding hn(4) is
50#      down.  The corresponding hn(4) will change the reception interface
51#      to the network VF, so that network layer and application layer will
52#      be tricked into thinking that these packets were received by the
53#      network VF.
54#   o  The corresponding hn(4) pretends the physical link is down.
55# - Once the network VF is down or detached:
56#   o  All of the transmission should go through the corresponding hn(4).
57#   o  All of the reception goes through the corresponding hn(4).
58#   o  The corresponding hn(4) fallbacks to the original physical link
59#      detection logic.
60#
61# All these features are mainly used to help live migration, during which
62# the network VF will be detached, while the network communication to the
63# VM must not be cut off.  In order to reach this level of live migration
64# transparency, we use failover mode lagg(4) with the network VF and the
65# corresponding hn(4) attached to it.
66#
67# To ease user configuration for both network VF and non-network VF, the
68# lagg(4) will be created by the following rules, and the configuration
69# of the corresponding hn(4) will be applied to the lagg(4) automatically.
70#
71# NOTE:
72# If live migration is not needed at all, the following rules could be
73# commented out, and the network VF interface could be used exclusively.
74# Most often the corresponding hn(4) could be completely ignored.
75#
76#
77# Default workflow for the network VF bringup:
78# 1) ETHERNET/IFATTACH -> VF interface up (delayed by rc.conf hyperv_vf_delay
79#    seconds).  This operation will trigger HYPERV_NIC_VF/VF_UP.
80# 2) HYPERV_NIC_VF/VF_UP:
81#    a) Create laggX coresponding to hnX.
82#    b) Add hnX and VF to laggX.
83#    c) Whack all previous network configuration on hnX, including stopping
84#       dhclient.
85#    d) Apply rc.conf ifconfig_hnX to laggX; i.e. including starting dhclient.
86#
87# NOTE:
88# HYPERV_NIC_VF/VF_UP action script could be customized per-interface by
89# adding /usr/libexec/hyperv/hyperv_vfup.hnX script.
90# /usr/libexec/hyperv/hyperv_vfup could be used as the template for the
91# customized per-interface script.
92#
93# NOTE:
94# For transparent network VF, hyperv_vfattach does nothing and
95# HYPERV_NIC_VF/VF_UP will not be triggered at all.
96#
97
98notify 10 {
99	match "system"		"HYPERV_NIC_VF";
100	match "type"		"VF_UP";
101	action "/usr/libexec/hyperv/hyperv_vfup $subsystem";
102};
103
104notify 10 {
105	match "system"		"ETHERNET";
106	match "type"		"IFATTACH";
107	action "/usr/libexec/hyperv/hyperv_vfattach $subsystem 0";
108};
109