Lines Matching full:mfc

110 static void mroute_netlink_event(struct mr_table *mrt, struct mfc_cache *mfc,
648 struct mfc_cache *mfc, u32 tb_id) in call_ipmr_mfc_entry_notifiers() argument
651 &mfc->_c, tb_id, &net->ipv4.ipmr_seq); in call_ipmr_mfc_entry_notifiers()
1186 /* MFC cache manipulation by user space mroute daemon */
1188 static int ipmr_mfc_delete(struct mr_table *mrt, struct mfcctl *mfc, int parent) in ipmr_mfc_delete() argument
1195 c = ipmr_cache_find_parent(mrt, mfc->mfcc_origin.s_addr, in ipmr_mfc_delete()
1196 mfc->mfcc_mcastgrp.s_addr, parent); in ipmr_mfc_delete()
1210 struct mfcctl *mfc, int mrtsock, int parent) in ipmr_mfc_add() argument
1217 if (mfc->mfcc_parent >= MAXVIFS) in ipmr_mfc_add()
1222 c = ipmr_cache_find_parent(mrt, mfc->mfcc_origin.s_addr, in ipmr_mfc_add()
1223 mfc->mfcc_mcastgrp.s_addr, parent); 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()
1238 if (mfc->mfcc_mcastgrp.s_addr != htonl(INADDR_ANY) && in ipmr_mfc_add()
1239 !ipv4_is_multicast(mfc->mfcc_mcastgrp.s_addr)) in ipmr_mfc_add()
1246 c->mfc_origin = mfc->mfcc_origin.s_addr; in ipmr_mfc_add()
1247 c->mfc_mcastgrp = mfc->mfcc_mcastgrp.s_addr; in ipmr_mfc_add()
1248 c->_c.mfc_parent = mfc->mfcc_parent; in ipmr_mfc_add()
1249 ipmr_update_thresholds(mrt, &c->_c, mfc->mfcc_ttls); in ipmr_mfc_add()
1376 struct mfcctl mfc; in ip_mroute_setsockopt() local
1465 if (optlen != sizeof(mfc)) { in ip_mroute_setsockopt()
1469 if (copy_from_sockptr(&mfc, optval, sizeof(mfc))) { in ip_mroute_setsockopt()
1474 parent = mfc.mfcc_parent; in ip_mroute_setsockopt()
1476 ret = ipmr_mfc_delete(mrt, &mfc, parent); in ip_mroute_setsockopt()
1478 ret = ipmr_mfc_add(net, mrt, &mfc, in ip_mroute_setsockopt()
2401 static void mroute_netlink_event(struct mr_table *mrt, struct mfc_cache *mfc, in mroute_netlink_event() argument
2408 skb = nlmsg_new(mroute_msgsize(mfc->_c.mfc_parent >= MAXVIFS, in mroute_netlink_event()
2414 err = ipmr_fill_mroute(mrt, skb, 0, 0, mfc, cmd, 0); in mroute_netlink_event()
3005 const struct mfc_cache *mfc = v; in ipmr_mfc_seq_show() local
3010 (__force u32) mfc->mfc_mcastgrp, in ipmr_mfc_seq_show()
3011 (__force u32) mfc->mfc_origin, in ipmr_mfc_seq_show()
3012 mfc->_c.mfc_parent); in ipmr_mfc_seq_show()
3016 mfc->_c.mfc_un.res.pkt, in ipmr_mfc_seq_show()
3017 mfc->_c.mfc_un.res.bytes, in ipmr_mfc_seq_show()
3018 mfc->_c.mfc_un.res.wrong_if); in ipmr_mfc_seq_show()
3019 for (n = mfc->_c.mfc_un.res.minvif; in ipmr_mfc_seq_show()
3020 n < mfc->_c.mfc_un.res.maxvif; n++) { in ipmr_mfc_seq_show()
3022 mfc->_c.mfc_un.res.ttls[n] < 255) in ipmr_mfc_seq_show()
3025 n, mfc->_c.mfc_un.res.ttls[n]); in ipmr_mfc_seq_show()