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)
 |