Lines Matching full:mfc

105 static void mroute_netlink_event(struct mr_table *mrt, struct mfc_cache *mfc,
631 struct mfc_cache *mfc, u32 tb_id) in call_ipmr_mfc_entry_notifiers() argument
634 &mfc->_c, tb_id, &net->ipv4.ipmr_seq); in call_ipmr_mfc_entry_notifiers()
1165 /* MFC cache manipulation by user space mroute daemon */
1167 static int ipmr_mfc_delete(struct mr_table *mrt, struct mfcctl *mfc, int parent) in ipmr_mfc_delete() argument
1174 c = ipmr_cache_find_parent(mrt, mfc->mfcc_origin.s_addr, in ipmr_mfc_delete()
1175 mfc->mfcc_mcastgrp.s_addr, parent); in ipmr_mfc_delete()
1189 struct mfcctl *mfc, int mrtsock, int parent) in ipmr_mfc_add() argument
1196 if (mfc->mfcc_parent >= MAXVIFS) in ipmr_mfc_add()
1201 c = ipmr_cache_find_parent(mrt, mfc->mfcc_origin.s_addr, in ipmr_mfc_add()
1202 mfc->mfcc_mcastgrp.s_addr, parent); in ipmr_mfc_add()
1206 c->_c.mfc_parent = mfc->mfcc_parent; in ipmr_mfc_add()
1207 ipmr_update_thresholds(mrt, &c->_c, mfc->mfcc_ttls); in ipmr_mfc_add()
1217 if (mfc->mfcc_mcastgrp.s_addr != htonl(INADDR_ANY) && in ipmr_mfc_add()
1218 !ipv4_is_multicast(mfc->mfcc_mcastgrp.s_addr)) in ipmr_mfc_add()
1225 c->mfc_origin = mfc->mfcc_origin.s_addr; in ipmr_mfc_add()
1226 c->mfc_mcastgrp = mfc->mfcc_mcastgrp.s_addr; in ipmr_mfc_add()
1227 c->_c.mfc_parent = mfc->mfcc_parent; in ipmr_mfc_add()
1228 ipmr_update_thresholds(mrt, &c->_c, mfc->mfcc_ttls); in ipmr_mfc_add()
1355 struct mfcctl mfc; in ip_mroute_setsockopt() local
1444 if (optlen != sizeof(mfc)) { in ip_mroute_setsockopt()
1448 if (copy_from_sockptr(&mfc, optval, sizeof(mfc))) { in ip_mroute_setsockopt()
1453 parent = mfc.mfcc_parent; in ip_mroute_setsockopt()
1455 ret = ipmr_mfc_delete(mrt, &mfc, parent); in ip_mroute_setsockopt()
1457 ret = ipmr_mfc_add(net, mrt, &mfc, in ip_mroute_setsockopt()
2369 static void mroute_netlink_event(struct mr_table *mrt, struct mfc_cache *mfc, in mroute_netlink_event() argument
2376 skb = nlmsg_new(mroute_msgsize(mfc->_c.mfc_parent >= MAXVIFS, in mroute_netlink_event()
2382 err = ipmr_fill_mroute(mrt, skb, 0, 0, mfc, cmd, 0); in mroute_netlink_event()
2966 const struct mfc_cache *mfc = v; in ipmr_mfc_seq_show() local
2971 (__force u32) mfc->mfc_mcastgrp, in ipmr_mfc_seq_show()
2972 (__force u32) mfc->mfc_origin, in ipmr_mfc_seq_show()
2973 mfc->_c.mfc_parent); in ipmr_mfc_seq_show()
2977 mfc->_c.mfc_un.res.pkt, in ipmr_mfc_seq_show()
2978 mfc->_c.mfc_un.res.bytes, in ipmr_mfc_seq_show()
2979 mfc->_c.mfc_un.res.wrong_if); in ipmr_mfc_seq_show()
2980 for (n = mfc->_c.mfc_un.res.minvif; in ipmr_mfc_seq_show()
2981 n < mfc->_c.mfc_un.res.maxvif; n++) { in ipmr_mfc_seq_show()
2983 mfc->_c.mfc_un.res.ttls[n] < 255) in ipmr_mfc_seq_show()
2986 n, mfc->_c.mfc_un.res.ttls[n]); in ipmr_mfc_seq_show()