275 OP_NODEFAULT, sizeof (struct group_source_req),
276 -1 /* not initialized */ },
277 { MCAST_UNBLOCK_SOURCE, IPPROTO_IPV6, OA_X, OA_X, OP_NP,
278 OP_NODEFAULT, sizeof (struct group_source_req),
279 -1 /* not initialized */ },
280 { MCAST_JOIN_SOURCE_GROUP, IPPROTO_IPV6, OA_X, OA_X, OP_NP,
281 OP_NODEFAULT, sizeof (struct group_source_req),
282 -1 /* not initialized */ },
283 { MCAST_LEAVE_SOURCE_GROUP, IPPROTO_IPV6, OA_X, OA_X, OP_NP,
284 OP_NODEFAULT, sizeof (struct group_source_req),
285 -1 /* not initialized */ },
286
287 { UDP_ANONPRIVBIND, IPPROTO_UDP, OA_R, OA_RW, OP_PRIVPORT, 0,
288 sizeof (int), 0 },
289 { UDP_EXCLBIND, IPPROTO_UDP, OA_RW, OA_RW, OP_NP, 0, sizeof (int), 0
290 },
291 { UDP_RCVHDR, IPPROTO_UDP, OA_RW, OA_RW, OP_NP, 0, sizeof (int), 0
292 },
293 { UDP_NAT_T_ENDPOINT, IPPROTO_UDP, OA_RW, OA_RW, OP_PRIVPORT, 0, sizeof (int),
294 0 },
295 };
296
297 /*
298 * Table of all supported levels
299 * Note: Some levels (e.g. XTI_GENERIC) may be valid but may not have
300 * any supported options so we need this info separately.
301 *
302 * This is needed only for topmost tpi providers and is used only by
303 * XTI interfaces.
304 */
305 optlevel_t udp_valid_levels_arr[] = {
306 XTI_GENERIC,
307 SOL_SOCKET,
308 IPPROTO_UDP,
309 IPPROTO_IP,
310 IPPROTO_IPV6
311 };
312
313 #define UDP_VALID_LEVELS_CNT A_CNT(udp_valid_levels_arr)
314 #define UDP_OPT_ARR_CNT A_CNT(udp_opt_arr)
|
275 OP_NODEFAULT, sizeof (struct group_source_req),
276 -1 /* not initialized */ },
277 { MCAST_UNBLOCK_SOURCE, IPPROTO_IPV6, OA_X, OA_X, OP_NP,
278 OP_NODEFAULT, sizeof (struct group_source_req),
279 -1 /* not initialized */ },
280 { MCAST_JOIN_SOURCE_GROUP, IPPROTO_IPV6, OA_X, OA_X, OP_NP,
281 OP_NODEFAULT, sizeof (struct group_source_req),
282 -1 /* not initialized */ },
283 { MCAST_LEAVE_SOURCE_GROUP, IPPROTO_IPV6, OA_X, OA_X, OP_NP,
284 OP_NODEFAULT, sizeof (struct group_source_req),
285 -1 /* not initialized */ },
286
287 { UDP_ANONPRIVBIND, IPPROTO_UDP, OA_R, OA_RW, OP_PRIVPORT, 0,
288 sizeof (int), 0 },
289 { UDP_EXCLBIND, IPPROTO_UDP, OA_RW, OA_RW, OP_NP, 0, sizeof (int), 0
290 },
291 { UDP_RCVHDR, IPPROTO_UDP, OA_RW, OA_RW, OP_NP, 0, sizeof (int), 0
292 },
293 { UDP_NAT_T_ENDPOINT, IPPROTO_UDP, OA_RW, OA_RW, OP_PRIVPORT, 0, sizeof (int),
294 0 },
295 { UDP_SND_TO_CONNECTED, IPPROTO_UDP, OA_R, OA_RW, OP_CONFIG, 0, sizeof (int),
296 0 }
297 };
298
299 /*
300 * Table of all supported levels
301 * Note: Some levels (e.g. XTI_GENERIC) may be valid but may not have
302 * any supported options so we need this info separately.
303 *
304 * This is needed only for topmost tpi providers and is used only by
305 * XTI interfaces.
306 */
307 optlevel_t udp_valid_levels_arr[] = {
308 XTI_GENERIC,
309 SOL_SOCKET,
310 IPPROTO_UDP,
311 IPPROTO_IP,
312 IPPROTO_IPV6
313 };
314
315 #define UDP_VALID_LEVELS_CNT A_CNT(udp_valid_levels_arr)
316 #define UDP_OPT_ARR_CNT A_CNT(udp_opt_arr)
|